TYPO3 CMS  TYPO3_7-6
TYPO3\CMS\Backend\Form\InlineStackProcessor Class Reference

Public Member Functions

 initializeByGivenStructure (array $structure=[])
 
 initializeByParsingDomObjectIdString ($domObjectId)
 
 injectAjaxConfiguration ($contextString='')
 
 getStructure ()
 
 pushStableStructureItem (array $structureItem=[])
 
 getCurrentStructureFormPrefix ()
 
 getCurrentStructureDomObjectIdPrefix ($inlineFirstPid)
 
 getStructureLevel ($level)
 
 getUnstableStructure ()
 
 getStructureDepth ()
 

Protected Member Functions

 calculateStructureLevel ($level)
 
 getStructurePath ($structureDepth=-1)
 
 getStructureItemName ($levelData, $disposal='Disposal_AttributeId')
 

Protected Attributes

 $inlineStructure = []
 

Detailed Description

Handle inline stack.

Code related to inline elements need to know their nesting level. This class takes care of the according handling and can return field prefixes to be used in DOM.

Definition at line 29 of file InlineStackProcessor.php.

Member Function Documentation

◆ calculateStructureLevel()

TYPO3\CMS\Backend\Form\InlineStackProcessor::calculateStructureLevel (   $level)
protected

Calculates structure level.

Parameters
int$levelWhich level to return
Returns
bool|int

Definition at line 232 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureDepth().

Referenced by TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureLevel(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\injectAjaxConfiguration().

◆ getCurrentStructureDomObjectIdPrefix()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getCurrentStructureDomObjectIdPrefix (   $inlineFirstPid)

DOM object-id for this inline level

Parameters
int$inlineFirstPidPid of top level inline element storage
Returns
string

Definition at line 180 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureLevel(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructurePath().

◆ getCurrentStructureFormPrefix()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getCurrentStructureFormPrefix ( )

◆ getStructure()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getStructure ( )

Get current structure stack

Returns
array Current structure stack

Definition at line 142 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\$inlineStructure.

◆ getStructureDepth()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getStructureDepth ( )

Get the depth of the stable structure stack. (count($this->inlineStructure['stable'])

Returns
int The depth of the structure stack

Definition at line 271 of file InlineStackProcessor.php.

Referenced by TYPO3\CMS\Backend\Form\InlineStackProcessor\calculateStructureLevel(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructurePath().

◆ getStructureItemName()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getStructureItemName (   $levelData,
  $disposal = 'Disposal_AttributeId' 
)
protected

Create a name/id for usage in HTML output of a level of the structure stack to be used in form names.

Parameters
array$levelDataArray of a level of the structure stack (containing the keys table, uid and field)
string$disposalHow the structure name is used (e.g. as
or <input name="...">)
Returns
string The name/id of that level, to be used for HTML output

Definition at line 286 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureLevel().

Referenced by TYPO3\CMS\Backend\Form\InlineStackProcessor\getCurrentStructureFormPrefix(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructurePath().

◆ getStructureLevel()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getStructureLevel (   $level)

Get a level from the stack and return the data. If the $level value is negative, this function works top-down, if the $level value is positive, this function works bottom-up. Hint: If -1 is given, the "current" - most bottom "stable" item is returned

Parameters
int$levelWhich level to return
Returns
array The item of the stack at the requested level

Definition at line 200 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\calculateStructureLevel().

Referenced by TYPO3\CMS\Backend\Form\InlineStackProcessor\getCurrentStructureDomObjectIdPrefix(), TYPO3\CMS\Backend\Form\InlineStackProcessor\getCurrentStructureFormPrefix(), TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureItemName(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructurePath().

◆ getStructurePath()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getStructurePath (   $structureDepth = -1)
protected

Get the identifiers of a given depth of level, from the top of the stack to the bottom. An identifier looks like "<table>-<uid>-<field>".

Parameters
int$structureDepthHow much levels to output, beginning from the top of the stack
Returns
string The path of identifiers

Definition at line 252 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureDepth(), TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureItemName(), and TYPO3\CMS\Backend\Form\InlineStackProcessor\getStructureLevel().

Referenced by TYPO3\CMS\Backend\Form\InlineStackProcessor\getCurrentStructureDomObjectIdPrefix().

◆ getUnstableStructure()

TYPO3\CMS\Backend\Form\InlineStackProcessor::getUnstableStructure ( )

Get the "unstable" structure item from structure stack. This is typically initialized by initializeByParsingDomObjectIdString()

Returns
array Unstable structure item
Exceptions

Definition at line 218 of file InlineStackProcessor.php.

◆ initializeByGivenStructure()

TYPO3\CMS\Backend\Form\InlineStackProcessor::initializeByGivenStructure ( array  $structure = [])

One of two possible initialize methods setting a given structure.

Parameters
array$structure

Definition at line 43 of file InlineStackProcessor.php.

◆ initializeByParsingDomObjectIdString()

TYPO3\CMS\Backend\Form\InlineStackProcessor::initializeByParsingDomObjectIdString (   $domObjectId)

Convert the DOM object-id of an inline container to an array. The object-id could look like 'data-parentPageId-tx_mmftest_company-1-employees'. This initializes $this->inlineStructure - used by AJAX entry points There are two keys:

  • 'stable': Containing full qualified identifiers (table, uid and field)
  • 'unstable': Containing partly filled data (e.g. only table and possibly field)
Parameters
string$domObjectIdThe DOM object-id
Returns
void

Definition at line 59 of file InlineStackProcessor.php.

References $GLOBALS, TYPO3\CMS\Backend\Utility\BackendUtility\getInlineLocalizationMode(), TYPO3\CMS\Backend\Form\Utility\FormEngineUtility\getTSconfigForTableRow(), TYPO3\CMS\Backend\Form\Utility\FormEngineUtility\overrideFieldConf(), and TYPO3\CMS\Core\Utility\GeneralUtility\trimExplode().

Referenced by TYPO3\CMS\Backend\Tests\Unit\Form\InlineStackProcessorTest\structureStringIsParsedDataProvider().

◆ injectAjaxConfiguration()

TYPO3\CMS\Backend\Form\InlineStackProcessor::injectAjaxConfiguration (   $contextString = '')

Injects configuration via AJAX calls. This is used by inline ajax calls that transfer configuration options back to the stack for initialization The configuration is validated using HMAC to avoid hijacking.

Parameters
string$contextStringGiven context string from ajax call
Returns
void
Todo:
: Review this construct - Why can't the ajax call fetch these data on its own and transfers it to client instead?

Definition at line 117 of file InlineStackProcessor.php.

References TYPO3\CMS\Backend\Form\InlineStackProcessor\calculateStructureLevel(), TYPO3\CMS\Backend\Utility\BackendUtility\getInlineLocalizationMode(), and TYPO3\CMS\Core\Utility\GeneralUtility\hmac().

◆ pushStableStructureItem()

TYPO3\CMS\Backend\Form\InlineStackProcessor::pushStableStructureItem ( array  $structureItem = [])

Add a stable structure to the stack

Parameters
array$structureItem
Returns
void

Definition at line 153 of file InlineStackProcessor.php.

Member Data Documentation

◆ $inlineStructure

TYPO3\CMS\Backend\Form\InlineStackProcessor::$inlineStructure = []
protected