From a7414bbc6c703907720faceb8f01891e9bbdb373 Mon Sep 17 00:00:00 2001 From: Lina Wolf <48202465+linawolf@users.noreply.github.com> Date: Wed, 3 Apr 2024 18:56:44 +0200 Subject: [PATCH] [TASK] Overhaul PAGE chapter (#1166) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * [TASK] Overhaul PAGE chapter * Use confvals instead of tables * Correct indentation * Give headlines to examples * Introduce a toc for the properties * Apply suggestions from code review Co-authored-by: Chris Müller <2566282+brotkrueml@users.noreply.github.com> --------- Co-authored-by: Chris Müller <2566282+brotkrueml@users.noreply.github.com> --- Documentation/Setup/Page/Index.rst | 1457 +++++++++++++--------------- 1 file changed, 684 insertions(+), 773 deletions(-) diff --git a/Documentation/Setup/Page/Index.rst b/Documentation/Setup/Page/Index.rst index 1ac023133..ceeeacb00 100644 --- a/Documentation/Setup/Page/Index.rst +++ b/Documentation/Setup/Page/Index.rst @@ -1,10 +1,10 @@ -.. include:: /Includes.rst.txt -.. index:: +.. include:: /Includes.rst.txt +.. index:: PAGE Top-level objects; page -.. _page: -.. _page-datatype: -.. _object-type-page: +.. _page: +.. _page-datatype: +.. _object-type-page: ==== PAGE @@ -18,8 +18,8 @@ the content-page on a website. TYPO3 does not initialize :typoscript:`page` by default. You must initialize this explicitly, for example: -.. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript page = PAGE @@ -31,7 +31,7 @@ page is found. Most of this code is executed in the PHP script :php:`\TYPO3\CMS\Frontend\Http\RequestHandler`. -.. _page_output: +.. _page_output: Output of the PAGE object ========================= @@ -39,44 +39,46 @@ Output of the PAGE object An empty :typoscript:`PAGE` object without further configuration renders a HTML page like the following: -.. code-block:: html - - - - - - - Page title - - - - - +.. code-block:: html + + + + + + + Page title + + + + + This default behaviour can be changed by setting the property :ref:`setup-config-disableallheadercode`: -.. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - page.config.disableAllHeaderCode = 1 + page.config.disableAllHeaderCode = 1 If the output represents another format different from HTML the HTTP header should also be set, for example: -.. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - page.config.additionalHeaders.10.header = Content-type:application/json + page.config.additionalHeaders.10.header = Content-type:application/json -.. index:: - PAGE; typeNum - PAGE; Multiple pages +.. index:: + PAGE; typeNum + PAGE; Multiple pages + +.. _page_multiple: Multiple pages ============== @@ -92,8 +94,8 @@ the page will be used. Example: -.. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript page = PAGE page.typeNum = 0 @@ -114,6 +116,8 @@ an id parameter (for the page id), example (for json and page id 22): :samp:`/index.php?id=22&type=1` +.. _page_guidelines: + Guidelines ---------- @@ -126,6 +130,7 @@ Good, general PAGE object names to use are: These are just recommendations. However, especially the name page for the content bearing page is very common and most documentation will imply that your main page object is called page. +.. _page_examples: Examples ======== @@ -134,187 +139,138 @@ Please see the dedicated example page about examples of how to use the PAGE object: :ref:`page_examples` -.. index:: PAGE; Properties +.. index:: PAGE; Properties +.. _page_properties: Properties ========== -.. container:: ts-properties - - ============================== ===================================== ====================== ======================== - Property Data Type :ref:`stdwrap` Default - ============================== ===================================== ====================== ======================== - `1,2,3,4...`_ :ref:`cObject ` - `bodyTag`_ :ref:`data-type-tag` - `bodyTagAdd`_ :ref:`data-type-string` - `bodyTagCObject`_ :ref:`cObject ` - `config`_ :ref:`->CONFIG ` - `cssInline.[array]`_ :ref:`cObject ` - `footerData.[array]`_ :ref:`cObject ` - `headerData.[array]`_ :ref:`cObject ` - `headTag`_ :ref:`data-type-tag` / :ref:`stdwrap` - `includeCSS.[array]`_ :ref:`data-type-resource` - `includeCSSLibs.[array]`_ :ref:`data-type-resource` - `includeJS.[array]`_ :ref:`data-type-resource` - `includeJSFooter.[array]`_ :ref:`data-type-resource` - `includeJSFooterlibs.[array]`_ :ref:`data-type-resource` - `includeJSLibs.[array]`_ :ref:`data-type-resource` - `inlineLanguageLabelFiles`_ (array of strings) - `inlineSettings`_ (array of strings) - `jsFooterInline.[array]`_ :ref:`cObject ` - `jsInline.[array]`_ :ref:`cObject ` - `meta`_ (array of strings) - `shortcutIcon`_ :ref:`data-type-resource` - `stdWrap`_ :ref:`stdwrap` - `typeNum`_ :ref:`data-type-integer` 0 - `wrap`_ :ref:`data-type-wrap` - ============================== ===================================== ====================== ======================== - -.. ### BEGIN~OF~TABLE ### - - -.. index:: PAGE; Content objects -.. _setup-page-1-2-3-4: +.. contents:: + :local: + +.. index:: PAGE; Content objects +.. _setup-page-array: 1,2,3,4... -========== +---------- -.. container:: table-row +.. confval:: 1,2,3,4... + :name: page-array + :type: :ref:`cObject ` - Property - 1,2,3,4... + These properties can be used to define any number of objects, + just like you can do with a :ref:`COA content object `. - Data type - :ref:`cObject ` + The content of these objects will be rendered on the page in the + order of the numbers, not in the order they get defined in the TypoScript + definition. - Description - These properties can be used to define any number of objects, - just like you can do with a :ref:`COA content object `. + It is considered best practice to leave space between the numbers such + that it will be possible to place objects before and after other objects + in the future. Therefore you will often see that people use the number + 10 and no number 1 is found. - The content of these objects will be rendered on the page in the - order of the numbers, not in the order they get defined in the TypoScript - definition. +.. _setup-page-array-example: - It is considered best practice to leave space between the numbers such - that it will be possible to place objects before and after other objects - in the future. Therefore you will often see that people use the number - 10 and no number 1 is found. +Example: Render "Hello World" +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - page = PAGE - page.20 = TEXT - page.20.value = World - page.10 = TEXT - page.10.value = Hello + page = PAGE + page.20 = TEXT + page.20.value = World + page.10 = TEXT + page.10.value = Hello - This renders to :html:`HelloWorld`. +This renders to :html:`HelloWorld`. -.. index:: PAGE; bodyTag -.. _setup-page-bodytag: +.. index:: PAGE; bodyTag +.. _setup-page-bodytag: bodyTag -======= +------- -.. container:: table-row +.. confval:: bodyTag + :name: page-bodyTag + :type: :ref:`data-type-tag` + :default: `` - Property - bodyTag + Body tag on the page - Data type - :ref:`data-type-tag` +.. _setup-page-bodytag-example: - Default - +Example: Set a class on the body tag +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - Description - Body tag on the page +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + # This will lead to if constant "bodyClass" is set accordingly. + page.bodyTag = - # This will lead to if constant "bodyClass" is set accordingly. - page.bodyTag = - -.. index:: PAGE; -.. _setup-page-bodytagadd: +.. index:: PAGE; +.. _setup-page-bodytagadd: bodyTagAdd -========== - -.. container:: table-row - - Property - bodyTagAdd +---------- - Data type - :ref:`data-type-string` +.. confval:: bodyTagAdd + :name: page-bodyTagAdd + :type: :ref:`data-type-string` - Description - This content is added inside of the opening :html:`` tag right - before the :html:`>` character. This is mostly useful for adding - attributes to the :html:`` tag. + This content is added inside of the opening :html:`` tag right + before the :html:`>` character. This is mostly useful for adding + attributes to the :html:`` tag. - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. _setup-page-bodytagadd-example: - # This will lead to - page.bodyTagAdd = class="example" +Example: Add a parameter to the body tag +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + # This will lead to + page.bodyTagAdd = class="example" -.. index:: PAGE; bodyTagCObject -.. _setup-page-bodytagcobject: +.. index:: PAGE; bodyTagCObject +.. _setup-page-bodytagcobject: bodyTagCObject ============== -.. container:: table-row - - Property - bodyTagCObject +.. confval:: bodyTagCObject + :name: page-bodyTagCObject + :type: cObject - Data type - cObject + This is the default body tag. It is overridden by :ref:`setup-page-bodyTag`, + if that is set. - Description - This is the default body tag. It is overridden by :ref:`setup-page-bodyTag`, - if that is set. + .. note:: Additionally to the body tag properties noted here, + there also is the property :ref:`setup-config-disableBodyTag`, + which, if set, disables body tag generation independently + from what might be set here. - **Note:** Additionally to the body tag properties noted here, - there also is the property :ref:`setup-config-disableBodyTag`, - which, if set, disables body tag generation independently - from what might be set here. - - -.. index:: PAGE; config -.. _setup-page-config: +.. index:: PAGE; config +.. _setup-page-config: config ====== -.. container:: table-row - - Property - config - - Data type - :ref:`->CONFIG ` +.. confval:: config + :name: page-config + :type: :ref:`->CONFIG ` - Description - Configuration for the page. Any entries made here override the same - entries in the top-level object :ref:`config`. + Configuration for the page. Any entries made here override the same + entries in the top-level object :ref:`config`. - -.. _setup-page-css-inlinestyle: +.. _setup-page-css-inlinestyle: CSS\_inlineStyle ================ @@ -324,831 +280,786 @@ CSS\_inlineStyle :ref:`page.cssInline ` instead. -.. index:: PAGE; cssInline.[array] -.. _setup-page-cssinline: +.. index:: PAGE; cssInline.[array] +.. _setup-page-cssinline: cssInline.[array] ================= -.. container:: table-row +.. confval:: cssInline.[array] + :name: page-cssInline + :type: :ref:`cObject ` - Property - cssInline.[array] + Allows to add inline CSS to the page :html:`` section. + The :typoscript:`cssInline` property contains any number of numeric keys, each representing one cObject. + Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. - Data type - :ref:`cObject ` - Description - Allows to add inline CSS to the page :html:`` section. - The :typoscript:`cssInline` property contains any number of numeric keys, each representing one cObject. - Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. +.. _setup-page-cssinline-example: - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +Example: Add inline styles for the h1 tag +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - cssInline { - 10 = TEXT - 10.value = h1 {margin:15px;} +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - 20 = TEXT - 20.value = h1 span {color: blue;} - } + cssInline { + 10 = TEXT + 10.value = h1 {margin:15px;} + + 20 = TEXT + 20.value = h1 span {color: blue;} + } -.. index:: PAGE; footerData.[array] -.. _setup-page-footerdata: +.. index:: PAGE; footerData.[array] +.. _setup-page-footerdata: footerData.[array] -================== +------------------ -.. container:: table-row +.. confval:: footerData.[array] + :name: page-footerData + :type: :ref:`cObject ` - Property - footerData.[array] + Same as :ref:`setup-page-headerData`, + except that this block gets included at the bottom of the page + (just before the closing :html:`` tag). - Data type - :ref:`cObject ` + The :typoscript:`footerData` property contains any number of numeric keys, each representing one cObject. + Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. - Description - Same as :ref:`setup-page-headerData`, - except that this block gets included at the bottom of the page - (just before the closing :html:`` tag). +.. _setup-page-footerdata-example: - The :typoscript:`footerData` property contains any number of numeric keys, each representing one cObject. - Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. +Example: Add a script and a comment to the page footer +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - footerData { - 3 = TEXT - 3.value = + footerData { + 3 = TEXT + 3.value = - 50 = TEXT - 50.value = - } + 50 = TEXT + 50.value = + } -.. index:: PAGE; headerData.[array] -.. _setup-page-headerdata: +.. index:: PAGE; headerData.[array] +.. _setup-page-headerdata: headerData.[array] -================== +------------------ -.. container:: table-row +.. confval:: headerData.[array] + :name: page-headerData + :type: :ref:`cObject ` - Property - headerData.[array] + Inserts custom content in the head section of the website. - Data type - :ref:`cObject ` + While you can also use this to include stylesheet references or JavaScript, + you should better use :ref:`page.includeCSS ` + and :ref:`page.includeJS ` for such files. + Features like file concatenation and file compression will not work on files, + which are included using :typoscript:`headerData`. - Description - Inserts custom content in the head section of the website. + For meta tags, use the dedicated configuration :ref:`page.meta `. - While you can also use this to include stylesheet references or JavaScript, - you should better use :ref:`page.includeCSS ` - and :ref:`page.includeJS ` for such files. - Features like file concatenation and file compression will not work on files, - which are included using :typoscript:`headerData`. + By default, gets inserted after all the style definitions. - For meta tags, use the dedicated configuration :ref:`page.meta `. + The :typoscript:`headerData` property contains any number of numeric keys, each representing one cObject. + Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. - By default, gets inserted after all the style definitions. +.. _setup-page-headerdata-example: - The :typoscript:`headerData` property contains any number of numeric keys, each representing one cObject. - Internally handled as PHP integer, maximum number is therefore restricted to :php:`PHP_INT_MAX`. +Example: Add a script tag and a comment to the head tag +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - Example - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript +.. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - page.headerData { - 3 = TEXT - 3.value = - - 50 = TEXT - 50.value = - } + page.headerData { + 3 = TEXT + 3.value = + 50 = TEXT + 50.value = + } -.. index:: PAGE; headTag -.. _setup-page-headtag: +.. index:: PAGE; headTag +.. _setup-page-headtag: headTag -======= - -.. container:: table-row - - Property - headTag - - Data type - :ref:`data-type-tag` / :ref:`stdwrap` +------- - Default - +.. confval:: headTag + :name: page-headTag + :type: :ref:`data-type-tag` / :ref:`stdwrap` + :Default: `` - Description - Head-tag if alternatives are wanted + Head-tag if alternatives are wanted - - -.. index:: PAGE; includeCSS.[array] -.. _setup-page-includecss-array: +.. index:: PAGE; includeCSS.[array] +.. _setup-page-includecss-array: includeCSS.[array] -================== - -.. container:: table-row - - Property - includeCSS.[array] - - Data type - :ref:`data-type-resource` - - Description - Inserts a stylesheet (just like the :typoscript:`stylesheet` property), but allows - setting up more than a single stylesheet, because you can enter files - in an array. - - The file definition must be a valid :ref:`data-type-resource` data type, - otherwise nothing is inserted. - - Each file has *optional properties*: - - **allWrap**: Wraps the complete tag, useful for conditional - comments. - - **allWrap.splitChar**: Defines an alternative splitting character - (default is "\|" - the vertical line). - - **alternate**: If set (boolean) then the rel-attribute will be - "alternate stylesheet". - - **disableCompression**: If :typoscript:`config.compressCss` is enabled, this - disables the compression of this file. - - **excludeFromConcatenation**: If :typoscript:`config.concatenateCss` is - enabled, this prevents the file from being concatenated. - - **external**: If set, there is no file existence check. Useful for - inclusion of external files. - - **forceOnTop**: Boolean flag. If set, this file will be added on top - of all other files. - - **if**: Allows to define conditions, which must evaluate to TRUE for - the file to be included. If they do not evaluate to TRUE, the file - will not be included. Extensive usage might cause huge numbers of - temporary files to be created. See ->if for details. - - **inline**: If set, the content of the CSS file is inlined using - :html:`