From c6952702e634a82b29d5af87f3270f489ddaabf9 Mon Sep 17 00:00:00 2001 From: "lina.wolf" Date: Sun, 22 Dec 2024 10:08:09 +0100 Subject: [PATCH] [!!!][TASK] Move menus properties into dataprocessor Keep HMENU / TMENU for backward compability reasons but remove outdated examples. Some special menu types still rely on HMENU, I will work on them in follow-ups. Releases: main, 13.4 --- Documentation/ContentObjects/Hmenu/Index.rst | 441 +++++------------- .../ContentObjects/Hmenu/Tmenu/Index.rst | 218 +-------- .../ContentObjects/Hmenu/Tmenu/Tmenuitem.rst | 28 +- Documentation/DataProcessing/Index.rst | 2 +- .../DataProcessing/MenuProcessor.rst | 120 ----- .../MenuProcessor}/Browse.rst | 2 +- .../MenuProcessor}/Categories.rst | 7 +- .../MenuProcessor}/Directory.rst | 1 + .../DataProcessing/MenuProcessor/Index.rst | 238 ++++++++++ .../MenuProcessor}/Keywords.rst | 1 + .../MenuProcessor}/Language.rst | 9 + .../MenuProcessor}/List.rst | 1 + .../MenuProcessor}/Rootline.rst | 1 + .../MenuProcessor}/Updated.rst | 1 + .../MenuProcessor}/Userfunction.rst | 20 +- .../_BreadcrumbDataProcessor.typoscript | 0 .../_code-snippets/_BreadcrumbLib.typoscript | 0 .../_LanguageMenuLib.typoscript | 0 .../_RelPrevNextMenu.typoscript | 0 .../_code-snippets/_entryLevel.typoscript | 14 + ...ectsCommonPropertiesSubmenuObjSuffixes.png | Bin 15333 -> 0 bytes 21 files changed, 433 insertions(+), 671 deletions(-) delete mode 100644 Documentation/DataProcessing/MenuProcessor.rst rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Browse.rst (99%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Categories.rst (98%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Directory.rst (98%) create mode 100644 Documentation/DataProcessing/MenuProcessor/Index.rst rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Keywords.rst (99%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Language.rst (91%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/List.rst (98%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Rootline.rst (98%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Updated.rst (99%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/Userfunction.rst (68%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/_code-snippets/_BreadcrumbDataProcessor.typoscript (100%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/_code-snippets/_BreadcrumbLib.typoscript (100%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/_code-snippets/_LanguageMenuLib.typoscript (100%) rename Documentation/{ContentObjects/Hmenu => DataProcessing/MenuProcessor}/_code-snippets/_RelPrevNextMenu.typoscript (100%) create mode 100644 Documentation/DataProcessing/MenuProcessor/_code-snippets/_entryLevel.typoscript delete mode 100644 Documentation/Images/ManualScreenshots/FrontendOutput/Hmenu/MenuObjectsCommonPropertiesSubmenuObjSuffixes.png diff --git a/Documentation/ContentObjects/Hmenu/Index.rst b/Documentation/ContentObjects/Hmenu/Index.rst index eed18f994..324bde13c 100644 --- a/Documentation/ContentObjects/Hmenu/Index.rst +++ b/Documentation/ContentObjects/Hmenu/Index.rst @@ -9,6 +9,12 @@ HMENU ===== +.. warning:: + This TypoScript object is still available to provide backward compatibility + for old sites. When creating a new menu or refactoring an existing one + always use the `menu data processor `_ + and a Fluid template. + Objects of type HMENU generate hierarchical menus. In a :ref:`FLUIDTEMPLATE ` the HMENU can be used as a DataProcessor called :ref:`MenuProcessor `, which @@ -24,9 +30,6 @@ structured in the page tree, HMENU also allows you to use the menus. These special menus take characteristics of special menu types into account. -.. contents:: - :local: - .. _cobj-hmenu-options: Properties @@ -36,375 +39,189 @@ Properties :display: table :type: -.. _hmenu-number: - -.. confval:: 1, 2, 3, ... - :name: hmenu-array - :type: :ref:`menu object ` - :Default: (no menu) - - For every menu level, that should be rendered, an according entry must - exist. It defines the menu object that should render the menu items on - the according level. 1 is the first level, 2 is the second level, 3 is - the third level and so on. - - **The property "1" is required!** - - The entry 1 for the first level always must exist. All other levels only - will be generated when they are configured. - - **Example:** - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - temp.sidemenu = HMENU - temp.sidemenu.1 = TMENU - temp.sidemenu.1 { - # Configuration of that TMENU here... - } - temp.sidemenu.2 = TMENU - temp.sidemenu.2 { - # Configuration of that TMENU here... - } - temp.sidemenu.3 = TMENU - temp.sidemenu.3 { - # Configuration of that TMENU here... - } - - This creates a menu with up to three levels: Each TMENU level can hold a - different menu configuration. - - TYPO3 offers :ref:`a variety of menu objects `. - - -.. _hmenu-cache-period: - -.. confval:: cache_period - :name: hmenu-cache-period - :type: :ref:`data-type-integer` - - The number of seconds a menu may remain in cache. If this value is not - set, the first available value of the following will be used: - - 1) cache\_timeout of the current page - - 2) config.cache\_period defined globally - - 3) 86400 (= 1 day) - - -.. _hmenu-cache: - -.. confval:: cache - :name: hmenu-cache - :type: :ref:`cache ` - - See :ref:`cache function description ` for details. - - -.. _hmenu-entrylevel: - -.. confval:: entryLevel - :name: hmenu-entryLevel - :type: :ref:`data-type-integer` / :ref:`stdWrap ` - :Default: 0 - - Defines at which level in the rootLine the menu should start. - - Default is "0" which gives us a menu of the very first pages on the - site. - - If the value is < 0, entryLevel is chosen from "behind" in the - rootLine. Thus "-1" is a menu with items from the outermost level, - "-2" is the level before the outermost... - - **Note:** :typoscript:`entryLevel` does not show a menu **of a certain level of pages** - (use :typoscript:`special = directory` for that) - but it means that it will start to be visible **from that level on**. - - So, for example if you build a simple "sitemap" menu like this one: - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - page.10 = HMENU - page.10 { - entryLevel = 4 - 1 = TMENU - 1.wrap =
    |
- 1.NO.wrapItemAndSub =
  • |
  • - 1.expAll = 1 - 2 < .1 - 3 < .2 - 4 < .3 - 5 < .4 - 6 < .5 - 7 < .6 - } - - it will start to be visible from the 4th level (and will contain only the subpages from that level). - Please note also that this affects also the menu generated with :typoscript:`MenuProcessor`. Example: - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - page.10 { - dataProcessing { - 10 = TYPO3\CMS\Frontend\DataProcessing\MenuProcessor - 10 { - special = list - special.value.field = pages - levels = 7 - entryLevel = 4 - as = menu - expandAll = 1 - titleField = nav_title // title - } - } - } - -.. _hmenu-special: - -.. confval:: special - :name: hmenu-special - :type: *"directory" / "list" / "updated" / "rootline" / "browse" / "keywords" - / "categories" / "language" / "userfunction"* - - Lets you define special types of menus. - - See the section about the :ref:`.special property `! - - -.. _hmenu-special-value: - -.. confval:: special.value - :name: hmenu-special-value - :type: *list of page-uid's* / :ref:`stdWrap ` - - List of page uid's to use for the special menu. What they are used - for depends on the menu type as defined by ".special"; see the - section about the :ref:`.special property `! - - -.. _hmenu-minitems: - -.. confval:: minItems - :name: hmenu-minItems - :type: :ref:`data-type-integer` / :ref:`stdWrap ` - - The minimum number of items in the menu. If the number of pages does - not reach this level, a dummy-page with the title "..." and - uid=[currentpage\_id] is inserted. - - **Note:** Affects all sub menus as well. To set the value for each - menu level individually, set the properties in the menu objects (see - "Common properties" table). - - -.. _hmenu-maxitems: - -.. confval:: maxItems - :name: hmenu-maxItems - :type: :ref:`data-type-integer` / :ref:`stdWrap ` - - The maximum number of items in the menu. Additional items will be - ignored. - - **Note:** Affects all sub menus as well. (See "minItems" for a - notice.) - - -.. _hmenu-begin: - -.. confval:: begin - :name: hmenu-begin - :type: :ref:`data-type-integer` / :ref:`stdWrap ` :ref:`+calc ` + .. _hmenu-number: - The first item in the menu. + .. confval:: 1, 2, 3, ... + :name: hmenu-array + :type: :ref:`menu object ` + :Default: (no menu) - **Example:** + For every menu level, that should be rendered, an according entry must + exist. It defines the menu object that should render the menu items on + the according level. 1 is the first level, 2 is the second level, 3 is + the third level and so on. - This results in a menu, where the first two items are skipped starting - with item number 3: + **The property "1" is required!** - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + The entry 1 for the first level always must exist. All other levels only + will be generated when they are configured. - begin = 3 + TYPO3 offers :ref:`the menu object TMENU `. - **Note:** Affects all sub menus as well. (See "minItems" for a - notice.) + .. _hmenu-cache-period: + .. confval:: cache_period + :name: hmenu-cache-period + :type: :ref:`data-type-integer` -.. _hmenu-excludeuidlist: + The number of seconds a menu may remain in cache. If this value is not + set, the first available value of the following will be used: -.. confval:: excludeUidList - :name: hmenu-excludeUidList - :type: list of :ref:`data-type-integer` / :ref:`stdWrap ` + 1) cache\_timeout of the current page - This is a list of page uids to exclude when the select statement is - done. Comma-separated. You may add "current" to the list to exclude - the current page. + 2) config.cache\_period defined globally - **Example:** + 3) 86400 (= 1 day) - The pages with these uid-numbers will **not** be within the menu! - Additionally the current page is always excluded too. + .. _hmenu-cache: - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + .. confval:: cache + :name: hmenu-cache + :type: :ref:`cache ` - excludeUidList = 34,2,current + See :ref:`cache function description ` for details. + .. _hmenu-entrylevel: -.. _hmenu-excludedoktypes: + .. confval:: entryLevel + :name: hmenu-entryLevel + :type: :ref:`data-type-integer` / :ref:`stdWrap ` + :Default: 0 -.. confval:: excludeDoktypes - :name: hmenu-excludeDoktypes - :type: list of :ref:`data-type-integer` - :Default: 6,254 + Defines at which level in the rootLine the menu should start. - Enter the list of page document types (doktype) to exclude from menus. - By default pages that are "backend user access only" (6) or "folder" - (254) are excluded. + .. _hmenu-special: -.. _hmenu-includenotinmenu: + .. confval:: special + :name: hmenu-special + :type: *"directory" / "list" / "updated" / "rootline" / "browse" / "keywords" + / "categories" / "language" / "userfunction"* -.. confval:: includeNotInMenu - :name: hmenu-includeNotInMenu - :type: :ref:`data-type-boolean` / :ref:`stdWrap ` + Lets you define special types of menus. - If set, pages with the checkbox "Page enabled in menus" disabled will still be included - in menus. + See the section about the :ref:`.special property `! -.. _hmenu-alwaysactivepidlist: + .. _hmenu-special-value: -.. confval:: alwaysActivePIDlist - :name: hmenu-alwaysActivePIDlist - :type: list of :ref:`data-type-integer` /:ref:`stdWrap ` + .. confval:: special.value + :name: hmenu-special-value + :type: *list of page-uid's* / :ref:`stdWrap ` - This is a list of page UID numbers that will always be regarded as - active menu items and thereby automatically opened regardless of the - rootline. + List of page uid's to use for the special menu. What they are used + for depends on the menu type as defined by ".special"; see the + section about the :ref:`.special property `! + .. _hmenu-minitems: -.. _hmenu-protectlvar: + .. confval:: minItems + :name: hmenu-minItems + :type: :ref:`data-type-integer` / :ref:`stdWrap ` -.. confval:: protectLvar - :name: hmenu-protectlvar - :type: :ref:`data-type-boolean` / keyword + The minimum number of items in the menu. If the number of pages does + not reach this level, a dummy-page with the title "..." and + `uid=[currentpage\_id]` is inserted. - If set, then for each page in the menu it will be checked if an - Alternative Page Language record for the language defined in - "config.sys\_language\_uid" exists for the - page. If that is not the case and the pages "Localization settings" - have the "Hide page if no translation for current language exists" - flag set, then the menu item will link to a non accessible page that - will yield an error page to the user. Setting this option will prevent - that situation by adding "&L=0" for such pages, meaning that - they will switch to the default language rather than keeping the - current language. + **Note:** Affects all sub menus as well. To set the value for each + menu level individually, set the properties in the menu objects (see + "Common properties" table). - The check is only carried out if a translation is requested - ("config.sys\_language\_uid" is not zero). + .. _hmenu-maxitems: - **Keyword: "all"** + .. confval:: maxItems + :name: hmenu-maxItems + :type: :ref:`data-type-integer` / :ref:`stdWrap ` - When set to "all" the same check is carried out but it will not look - if "Hide page if no translation for current language exists" is set - - it always reverts to default language if no translation is found. + The maximum number of items in the menu. Additional items will be + ignored. - For these options to make sense, they should only be used when - "config.sys\_language\_mode" is not set to "content\_fallback". + **Note:** Affects all sub menus as well. (See "minItems" for a + notice.) + .. _hmenu-begin: -.. _hmenu-addquerystring: + .. confval:: begin + :name: hmenu-begin + :type: :ref:`data-type-integer` / :ref:`stdWrap ` :ref:`+calc ` -.. confval:: addQueryString - :name: hmenu-addquerystring - :type: :ref:`->addQueryString ` + The first item in the menu. - **Note:** This works only for *special=language*. + **Note:** Affects all sub menus as well. (See "minItems" for a + notice.) + .. _hmenu-excludeuidlist: -.. _hmenu-if: + .. confval:: excludeUidList + :name: hmenu-excludeUidList + :type: list of :ref:`data-type-integer` / :ref:`stdWrap ` -.. confval:: if - :name: hmenu-if - :type: :ref:`->if ` + See :confval:`MenuProcessor-excludeUidList`. - If "if" returns false, the menu is not generated. + .. _hmenu-excludedoktypes: + .. confval:: excludeDoktypes + :name: hmenu-excludeDoktypes + :type: list of :ref:`data-type-integer` + :Default: 6,254 -.. _hmenu-wrap: + See :confval:`MenuProcessor-excludeDoktypes`. -.. confval:: wrap - :name: hmenu-wrap - :type: :ref:`wrap ` / :ref:`stdWrap ` + .. _hmenu-includenotinmenu: - Wrap for the HMENU. + .. confval:: includeNotInMenu + :name: hmenu-includeNotInMenu + :type: :ref:`data-type-boolean` / :ref:`stdWrap ` + See :confval:`MenuProcessor-includeNotInMenu` -.. _hmenu-stdwrap: + .. _hmenu-alwaysactivepidlist: -.. confval:: stdWrap - :name: hmenu-stdWrap - :type: :ref:`->stdWrap ` + .. confval:: alwaysActivePIDlist + :name: hmenu-alwaysActivePIDlist + :type: list of :ref:`data-type-integer` /:ref:`stdWrap ` - (Executed after ".wrap".) + See :confval:`MenuProcessor-alwaysActivePIDlist` + .. _hmenu-protectlvar: -.. _hmenu-examples: + .. confval:: protectLvar + :name: hmenu-protectlvar + :type: :ref:`data-type-boolean` / keyword -Example -======= + See :confval:`MenuProcessor-protectlvar`. -.. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + .. _hmenu-if: - temp.sidemenu = HMENU - temp.sidemenu.entryLevel = 1 - temp.sidemenu.1 = TMENU - temp.sidemenu.1 { - target = page - NO.afterImg = media/bullets/dots2.gif |*||*| _ - NO.afterImgTagParams = style="margin: 0px 20px;" - NO.linkWrap = {$fontTag} - NO.ATagBeforeWrap = 1 + .. confval:: if + :name: hmenu-if + :type: :ref:`->if ` - ACT < .NO - ACT = 1 - ACT.linkWrap = {$fontTag} - } + If "if" returns false, the menu is not generated. + .. _hmenu-wrap: + .. confval:: wrap + :name: hmenu-wrap + :type: :ref:`wrap ` / :ref:`stdWrap ` -.. index:: HMENU; special -.. _hmenu-special-property: + Wrap for the HMENU. -The .special property -===================== + .. _hmenu-stdwrap: -This property makes it possible to create menus that are not strictly -reflecting the current page-structure, but rather creating a -:ref:`breadcrumb menu `, a -:ref:`language menu ` or menus with -links to pages like :ref:`next/previous `, -:ref:`last modified `, -:ref:`all subpages of a page ` and so on. + .. confval:: stdWrap + :name: hmenu-stdWrap + :type: :ref:`->stdWrap ` -.. note:: - :typoscript:`.entryLevel` generally is not supported together with the - :typoscript:`.special` property! The only exception is :typoscript:`special = keywords`. + (Executed after ".wrap".) -Also be aware that this property selects pages for the first level in -the menu. Submenus by menuObjects 2+ will be created as usual. + .. _hmenu-examples: + .. _hmenu-special-property: -See the following menus types based on the :typoscript:`special` property: + For examples on how to use the HMENU please refer to old version of this + document, for example :ref:`HMENU ` -.. toctree:: - :titlesonly: - :glob: + .. toctree:: + :titlesonly: + :glob: + :hidden: - Tmenu/Index - * + Tmenu/Index + * diff --git a/Documentation/ContentObjects/Hmenu/Tmenu/Index.rst b/Documentation/ContentObjects/Hmenu/Tmenu/Index.rst index 7b3ef8f79..42ba8ceb1 100644 --- a/Documentation/ContentObjects/Hmenu/Tmenu/Index.rst +++ b/Documentation/ContentObjects/Hmenu/Tmenu/Index.rst @@ -8,7 +8,14 @@ TMENU ===== -:typoscript:`TMENU` is a menu object type. +.. warning:: + This TypoScript object is still available to provide backward compatibility + for old sites. When creating a new menu or refactoring an existing one + always use the `menu data processor `_ + and a Fluid template. + +For examples on how to use the TMENU please refer to old version of this +document, for example :ref:`TMENU `-. .. toctree:: :glob: @@ -20,16 +27,16 @@ TMENU .. index:: TMENU; Item states -.. _tmenu-common-property-no: -.. _tmenu-common-property-ifsub: -.. _tmenu-common-property-act: -.. _tmenu-common-property-actifsub: -.. _tmenu-common-property-cur: -.. _tmenu-common-property-curifsub: -.. _tmenu-common-property-usr: -.. _tmenu-common-property-spc: -.. _tmenu-common-property-userdef1: -.. _tmenu-common-property-userdef2: +.. _tmenu-common-property-no: +.. _tmenu-common-property-ifsub: +.. _tmenu-common-property-act: +.. _tmenu-common-property-actifsub: +.. _tmenu-common-property-cur: +.. _tmenu-common-property-curifsub: +.. _tmenu-common-property-usr: +.. _tmenu-common-property-spc: +.. _tmenu-common-property-userdef1: +.. _tmenu-common-property-userdef2: .. _tmenu-common-properties: TMENU item states @@ -61,23 +68,6 @@ The following Item states are listed from the least to the highest priority: The default "Normal" state rendering of Item. This is required for all menus. - If you specify properties for the "NO" property you do not have to set - it "1". Otherwise with no properties setting "NO=1" will render the - menu anyways (for TMENU this may make sense). - - The simplest menu TYPO3 can generate is then: - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - page.20 = HMENU - page.20.1 = TMENU - page.20.1.NO = 1 - - That will be pure `` tags wrapped around page titles. - - - .. confval:: IFSUB :name: tmenu-common-property-ifsub :type: :ref:`data-type-boolean` / :ref:`tmenuitem` @@ -85,8 +75,6 @@ The following Item states are listed from the least to the highest priority: Enable/Configuration for menu items which has subpages. - - .. confval:: ACT :name: tmenu-common-property-act :type: :ref:`data-type-boolean` / :ref:`tmenuitem` @@ -107,7 +95,6 @@ The following Item states are listed from the least to the highest priority: :type: :ref:`data-type-boolean` / :ref:`tmenuitem` :Default: 0 - Enable/Configuration for a menu item if the item is the current page. .. confval:: CURIFSUB @@ -236,55 +223,6 @@ Properties tt_content.menu.20.3.1.sectionIndex.useColPos = -1 - - .. rubric:: The data record in sectionIndex menus - - When the menu-records are selected it works like this: The parent page - record is used as the "base" for the menu-record. That means that any - "no\_cache" or "target"-properties of the parent page are used for the - whole menu. - - But of course some fields from the tt\_content records are - transferred. This is how it is mapped: - - .. code-block:: none - :caption: Example of data mapping - - $temp[$row[uid]]=$basePageRow; - $temp[$row[uid]]['title']=$row['header']; - $temp[$row[uid]]['subtitle']=$row['subheader']; - $temp[$row[uid]]['starttime']=$row['starttime']; - $temp[$row[uid]]['endtime']=$row['endtime']; - $temp[$row[uid]]['fe_group']=$row['fe_group']; - $temp[$row[uid]]['media']=$row['media']; - $temp[$row[uid]]['header_layout']=$row['header_layout']; - $temp[$row[uid]]['bodytext']=$row['bodytext']; - $temp[$row[uid]]['image']=$row['image']; - $temp[$row[uid]]['sectionIndex_uid']=$row['uid']; - - Basically this shows that - - - the field "header" and "subheader" from tt\_content are mapped to - "title" and "subtitle" in the pages-record. Thus you shouldn't need to - change your standard menu objects to fit this thing. - - - the fields "starttime", "endtime", "fe\_group", "media" from - tt\_content are mapped to the same fields in a pages-record. - - - the fields "header\_layout", "bodytext" and "image" are mapped to - non-existing fields in the page-record - - - a new field, "sectionIndex\_uid" is introduced in the page record - which is detected by the `\TYPO3\CMS\Frontend\Typolink\PageLinkBuilder`. If this field - is present in a page record, the `PageLinkBuilder` will prepend a - hash-mark and the number of the field. - - .. note:: - You cannot create submenus to sectionIndex menus. These elements are not - pages and thereby have no children. - - - .. confval:: target :name: menu-common-properties-target :type: string @@ -292,8 +230,6 @@ Properties Target of the menu links - - .. confval:: forceTypeValue :name: menu-common-properties-forceTypeValue :type: :ref:`data-type-integer` @@ -309,29 +245,12 @@ Properties Wraps the whole block of sub items. - .. rubric:: Example - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - 2 = TMENU - 2 { - stdWrap.dataWrap =
      |
    - NO { - // ... - } - } - - - .. confval:: wrap :name: menu-common-properties-wrap :type: :ref:`wrap ` Wraps the whole block of sub items, but only if there were items in the menu! - - .. confval:: IProcFunc :name: menu-common-properties-IProcFunc :type: function name @@ -341,7 +260,6 @@ Properties compiled by implode()'ing the array $I[parts] in the passed array. Thus you may modify this if you need to. - .. confval:: alternativeSortingField :name: menu-common-properties-alternativeSortingField :type: :ref:`data-type-string` @@ -351,19 +269,11 @@ Properties is used in the SQL- "ORDER BY" statement instead. You can also provide the sorting order. - **Examples (for "pages" table):** - - alternativeSortingField = title desc - - (This will render the menu in reversed alphabetical order.) - **Limitations:** This property works with normal menus, sectionsIndex menus and special-menus of type "directory". - - .. confval:: minItems :name: menu-common-properties-minItems :type: :ref:`data-type-integer` / :ref:`stdWrap ` @@ -378,34 +288,16 @@ Properties :name: menu-common-properties-maxItems :type: :ref:`data-type-integer` / :ref:`stdWrap ` - The maximum items in the menu. More items will be ignored. Takes precedence over HMENU property :ref:`hmenu-maxitems`. - - .. confval:: begin :name: menu-common-properties-begin :type: :ref:`data-type-integer` / :ref:`stdWrap ` :ref:`+calc ` - The first item in the menu. - **Example:** - - This results in a menu, where the first two items are skipped starting - with item number 3: - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - begin = 3 - - Takes precedence over :HMENU property :ref:`hmenu-begin`. - - - .. confval:: debugItemConf :name: menu-common-properties-debugItemConf :type: :ref:`data-type-boolean` @@ -413,8 +305,6 @@ Properties Outputs (by the :php:`debug()` function) the configuration arrays for each menu item. Useful to debug :ref:`optionsplit` things and such... - - .. confval:: overrideId :name: menu-common-properties-overrideId :type: :ref:`data-type-integer` (page id) @@ -432,17 +322,12 @@ Properties Additional parameter for the menu links. - **Example:** - - "&some\_var=some%20value" - Must be rawurlencoded. .. confval:: showAccessRestrictedPages :name: menu-common-properties-showaccessrestrictedpages :type: :ref:`data-type-integer` (page ID) / keyword "NONE" - If set, pages in the menu will include pages with frontend user group access enabled. However the page is of course not accessible and therefore the URL in the menu will be linked to the page with the ID @@ -466,20 +351,6 @@ Properties **.ATagParams**: Add custom attributes to the anchor tag. - .. rubric:: Example - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - showAccessRestrictedPages = 22 - showAccessRestrictedPages.addParams = &return_url=###RETURN_URL###&pageId=###PAGE_ID### - showAccessRestrictedPages.ATagParams = class="restricted" - - The example will link access restricted menu items to page ID 22 with - the return URL in the GET variable `return_url` and the page ID in the GET - variable "pageId". Additionally, a CSS class "restricted" is added to the - anchor tag. - .. confval:: additionalWhere :name: menu-common-properties-additionalWhere :type: :ref:`data-type-string` / :ref:`stdWrap ` @@ -487,20 +358,10 @@ Properties Adds an additional part to the WHERE clause for this menu. Make sure to start the part with "AND "! - .. rubric:: Example - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - lib.authormenu = HMENU - lib.authormenu.1 = TMENU - lib.authormenu.1.additionalWhere = AND author!="" - .. confval:: itemArrayProcFunc :name: menu-common-properties-itemArrayProcFunc :type: function name - The first variable passed to this function is the "menuArr" array with the menu items as they are collected based on the type of menu. @@ -523,45 +384,4 @@ Properties :name: menu-common-properties-submenuObjSuffixes :type: :ref:`data-type-string` / :ref:`optionsplit` - Defines a suffix for alternative sub-level menu objects. Useful to - create special submenus depending on their parent menu element. See - example below. - - .. rubric:: Example - - This example will generate a menu where the menu objects for the - second level will differ depending on the number of the first level - item for which the submenu is rendered. The second level objects used - are "2" (the default), "2a" and "2b" (the alternatives). Which of them - is used is defined by "1.submenuObjSuffixes" which has the - configuration "a \|\*\| \|\*\| b". This configuration means that the - first menu element will use configuration "2a" and the last will use - "2b" while anything in between will use "2" (no suffix applied) : - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - page.200 = HMENU - page.200 { - 1 = TMENU - 1.wrap =
    |
    - 1.expAll = 1 - 1.submenuObjSuffixes = a |*| |*| b - 1.NO.allWrap = |
    - - 2 = TMENU - 2.NO.allWrap =
    |
    - - 2a = TMENU - 2a.NO.allWrap =
    |
    - - 2b = TMENU - 2b.NO.allWrap =
    |
    - } - - The result can be seen in the image below: - - .. figure:: /Images/ManualScreenshots/FrontendOutput/Hmenu/MenuObjectsCommonPropertiesSubmenuObjSuffixes.png - :alt: Output of the above example. - - Applies to TMENU on >= 2 :sup:`nd` level in a menu. + Defines a suffix for alternative sub-level menu objects. diff --git a/Documentation/ContentObjects/Hmenu/Tmenu/Tmenuitem.rst b/Documentation/ContentObjects/Hmenu/Tmenu/Tmenuitem.rst index fe95e5cac..753e5070a 100644 --- a/Documentation/ContentObjects/Hmenu/Tmenu/Tmenuitem.rst +++ b/Documentation/ContentObjects/Hmenu/Tmenu/Tmenuitem.rst @@ -6,10 +6,21 @@ TMENUITEM ========= +.. warning:: + This TypoScript object is still available to provide backward compatibility + for old sites. When creating a new menu or refactoring an existing one + always use the `menu data processor `_ + and a Fluid template. + +For examples on how to use the TMENUITEM please refer to old version of this +document, for example :ref:`TMENUITEM `-. + The current record is the page record of the menu item. If you would like to get data from the current menu item's page record, use :typoscript:`stdWrap.data = field : [field name]`. +.. _tmenuitem-properties: + Properties ========== @@ -118,13 +129,6 @@ Properties Additional parameters - **Example:** : - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - ATagParams = class="board" - .. _tmenuitem-ATagTitle: @@ -135,16 +139,6 @@ Properties Allows you to specify the "title" attribute of the :html:`
    ` tag around the menu item. - **Example:** : - - .. code-block:: typoscript - :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript - - ATagTitle.field = abstract // description - - This would use the abstract or description field for the - :html:`` attribute. - .. _tmenuitem-additionalParams: diff --git a/Documentation/DataProcessing/Index.rst b/Documentation/DataProcessing/Index.rst index 27e3e7b83..232b8b270 100644 --- a/Documentation/DataProcessing/Index.rst +++ b/Documentation/DataProcessing/Index.rst @@ -27,7 +27,7 @@ for example for comma-separated values, related files or related records. FlexFormProcessor GalleryProcessor LanguageMenuProcessor - MenuProcessor + MenuProcessor/Index PageContentFetchingProcessor RecordTransformationProcessor SiteProcessor diff --git a/Documentation/DataProcessing/MenuProcessor.rst b/Documentation/DataProcessing/MenuProcessor.rst deleted file mode 100644 index 6864c7908..000000000 --- a/Documentation/DataProcessing/MenuProcessor.rst +++ /dev/null @@ -1,120 +0,0 @@ -:navigation-title: menu -.. include:: /Includes.rst.txt -.. _MenuProcessor: - -===================== -`menu` data processor -===================== - -The :php:`\TYPO3\CMS\Frontend\DataProcessing\MenuProcessor`, -alias `menu`, utilizes :ref:`HMENU ` to generate a list -of menu items which can be assigned to :typoscript:`FLUIDTEMPLATE` as a -variable. - -Additional data processing is supported and will be applied to each record. - -.. contents:: Table of contents - -.. hint:: - The third party extension `b13/menus - `__ also provides menu - processors like :php:`\B13\Menus\DataProcessing\TreeMenu` and - :php:`\B13\Menus\DataProcessing\BreadcrumbsMenu`. - - Refer to the `manual of the extension b13/menus - `__ for more - information. - -.. _MenuProcessor-options: - -Options -======= - -.. confval-menu:: - :display: table - :type: - :Default: - - .. _MenuProcessor-levels: - - .. confval:: levels - :name: MenuProcessor-levels - :Required: true - :type: :ref:`data-type-integer` / :ref:`stdWrap` - :Default: 1 - :Example: 5 - - Maximal number of levels to be included in the output array. - - .. _MenuProcessor-expandAll: - - .. confval:: expandAll - :name: MenuProcessor-expandAll - :Required: true - :type: :ref:`data-type-boolean` / :ref:`stdWrap` - :Default: 1 - :Example: 0 - - Include all submenus (`1`) or only those of the active pages (`0`). - - .. _MenuProcessor-includeSpacer: - - .. confval:: includeSpacer - :name: MenuProcessor-includeSpacer - :Required: true - :type: :ref:`data-type-boolean` / :ref:`stdWrap` - :Default: 0 - :Example: 1 - - Include pages with type "spacer". - - .. _MenuProcessor-titleField: - - .. confval:: titleField - :name: MenuProcessor-titleField - :Required: true - :type: :ref:`data-type-string` / :ref:`stdWrap` - :Default: "nav_title // title" - :Example: "subtitle" - - Fields to be used as title. - - - .. _MenuProcessor-as: - - .. confval:: as - :name: MenuProcessor-as - :Required: false - :type: :ref:`data-type-string` - :Default: "menu" - - Name for the variable in the Fluid template. - - .. hint:: - Additionally, all :ref:`HMENU options ` are available. - -.. _MenuProcessor-example-two-levels: - -Example: Two level menu of the web page -======================================= - -Please see also :ref:`dataProcessing-about-examples`. - -.. rubric:: TypoScript - -Using the :php:`MenuProcessor` the following scenario is possible: - -.. include:: /CodeSnippets/DataProcessing/TypoScript/MenuProcessor.rst.txt - -.. rubric:: The Fluid template - -This generated menu can be used in Fluid like this: - -.. include:: /CodeSnippets/DataProcessing/Template/DataProcMenu.rst.txt - -.. rubric:: Output - -The array now contains the menu items on level one. Each item in return has the -menu items of level 2 in an array called :php:`children`. - -.. include:: /Images/AutomaticScreenshots/DataProcessing/MenuProcessor.rst.txt diff --git a/Documentation/ContentObjects/Hmenu/Browse.rst b/Documentation/DataProcessing/MenuProcessor/Browse.rst similarity index 99% rename from Documentation/ContentObjects/Hmenu/Browse.rst rename to Documentation/DataProcessing/MenuProcessor/Browse.rst index a6fa53a8b..a4cd6fb51 100644 --- a/Documentation/ContentObjects/Hmenu/Browse.rst +++ b/Documentation/DataProcessing/MenuProcessor/Browse.rst @@ -1,5 +1,5 @@ +:navigation-title: Browse .. include:: /Includes.rst.txt -.. index:: HMENU; special = browse .. _hmenu-special-browse: ================================ diff --git a/Documentation/ContentObjects/Hmenu/Categories.rst b/Documentation/DataProcessing/MenuProcessor/Categories.rst similarity index 98% rename from Documentation/ContentObjects/Hmenu/Categories.rst rename to Documentation/DataProcessing/MenuProcessor/Categories.rst index 0d4c03b9b..e80bceb5a 100644 --- a/Documentation/ContentObjects/Hmenu/Categories.rst +++ b/Documentation/DataProcessing/MenuProcessor/Categories.rst @@ -1,11 +1,12 @@ +:navigation-title: Categories .. include:: /Includes.rst.txt .. index:: HMENU; special = categories .. _hmenu-special-categories: -================ -Categories HMENU -================ +========== +Categories +========== Makes a menu of pages belonging to one or more categories. If a page belongs to several of the selected categories, it will appear only once. diff --git a/Documentation/ContentObjects/Hmenu/Directory.rst b/Documentation/DataProcessing/MenuProcessor/Directory.rst similarity index 98% rename from Documentation/ContentObjects/Hmenu/Directory.rst rename to Documentation/DataProcessing/MenuProcessor/Directory.rst index 72199c217..b28218068 100644 --- a/Documentation/ContentObjects/Hmenu/Directory.rst +++ b/Documentation/DataProcessing/MenuProcessor/Directory.rst @@ -1,3 +1,4 @@ +:navigation-title: Directory .. include:: /Includes.rst.txt .. index:: HMENU; special = directory .. _hmenu-special-directory: diff --git a/Documentation/DataProcessing/MenuProcessor/Index.rst b/Documentation/DataProcessing/MenuProcessor/Index.rst new file mode 100644 index 000000000..fde8220c9 --- /dev/null +++ b/Documentation/DataProcessing/MenuProcessor/Index.rst @@ -0,0 +1,238 @@ +:navigation-title: menu +.. include:: /Includes.rst.txt +.. _MenuProcessor: + +===================== +`menu` data processor +===================== + +The :php:`\TYPO3\CMS\Frontend\DataProcessing\MenuProcessor`, +alias `menu`, utilizes :ref:`HMENU ` to generate a list +of menu items which can be assigned to :typoscript:`FLUIDTEMPLATE` as a +variable. + +Additional data processing is supported and will be applied to each record. + +.. contents:: Table of contents + +.. hint:: + The third party extension `b13/menus + `__ also provides menu + processors like :php:`\B13\Menus\DataProcessing\TreeMenu` and + :php:`\B13\Menus\DataProcessing\BreadcrumbsMenu`. + + Refer to the `manual of the extension b13/menus + `__ for more + information. + +.. _MenuProcessor-options: + +Options +======= + +.. confval-menu:: + :display: table + :type: + :Default: + + .. _MenuProcessor-as: + + .. confval:: as + :name: MenuProcessor-as + :Required: false + :type: :ref:`data-type-string` + :Default: "menu" + + Name for the variable in the Fluid template. + + .. confval:: alwaysActivePIDlist + :name: MenuProcessor-alwaysActivePIDlist + :type: list of :ref:`data-type-integer` /:ref:`stdWrap ` + + This is a list of page UID numbers that will always be regarded as + active menu items and thereby automatically opened regardless of the + rootline. + + .. confval:: entryLevel + :name: MenuProcessor-entryLevel + :type: :ref:`data-type-integer` / :ref:`stdWrap ` + :Default: 0 + + Defines at which level in the rootLine the menu should start. + + Default is "0" which gives us a menu of the very first pages on the + site. + + If the value is < 0, entryLevel is chosen from "behind" in the + rootLine. Thus "-1" is a menu with items from the outermost level, + "-2" is the level before the outermost... + + **Note:** :typoscript:`entryLevel` does not show a menu **of a certain level of pages** + (use :typoscript:`special = directory` for that) + but it means that it will start to be visible **from that level on**. + + So, for example if you build a simple "sitemap" menu like this one: + + .. literalinclude:: _code-snippets/_entryLevel.typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + + it will start to be visible from the 4th level (and will contain only + the subpages from that level). + + .. confval:: excludeDoktypes + :name: MenuProcessor-excludeDoktypes + :type: list of :ref:`data-type-integer` + :Default: 6,254 + + Enter the list of page document types (doktype) to exclude from menus. + By default pages that are "backend user access only" (6) or "folder" + (254) are excluded. + + .. confval:: excludeUidList + :name: MenuProcessor-excludeUidList + :type: list of :ref:`data-type-integer` / :ref:`stdWrap ` + + This is a list of page uids to exclude when the select statement is + done. Comma-separated. You may add "current" to the list to exclude + the current page. + + **Example:** + + The pages with these uid-numbers will **not** be within the menu! + Additionally the current page is always excluded too. + + .. code-block:: typoscript + :caption: EXT:site_package/Configuration/TypoScript/setup.typoscript + + page.10.dataProcessing.20.excludeUidList = 34,2,current + + .. _MenuProcessor-expandAll: + + .. confval:: expandAll + :name: MenuProcessor-expandAll + :Required: true + :type: :ref:`data-type-boolean` / :ref:`stdWrap` + :Default: 1 + :Example: 0 + + Include all submenus (`1`) or only those of the active pages (`0`). + + .. _MenuProcessor-levels: + + .. confval:: levels + :name: MenuProcessor-levels + :Required: true + :type: :ref:`data-type-integer` / :ref:`stdWrap` + :Default: 1 + :Example: 5 + + Maximal number of levels to be included in the output array. + + .. confval:: includeNotInMenu + :name: MenuProcessor-includeNotInMenu + :type: :ref:`data-type-boolean` / :ref:`stdWrap ` + + If set, pages with the checkbox "Page enabled in menus" disabled will still be included + in menus. + + .. _MenuProcessor-includeSpacer: + + .. confval:: includeSpacer + :name: MenuProcessor-includeSpacer + :Required: true + :type: :ref:`data-type-boolean` / :ref:`stdWrap` + :Default: 0 + :Example: 1 + + Include pages with type "spacer". + + .. confval:: protectLvar + :name: MenuProcessor-protectlvar + :type: :ref:`data-type-boolean` / keyword + + If set, then for each page in the menu it will be checked if an + Alternative Page Language record for the language defined in + the site exists for the + page. If that is not the case and the pages "Localization settings" + have the "Hide page if no translation for current language exists" + flag set, then the menu item will link to a non accessible page that + will yield an error page to the user. Setting this option will prevent + that situation by adding "&L=0" for such pages, meaning that + they will switch to the default language rather than keeping the + current language. + + The check is only carried out if a translation is requested, not for the + standard language. + + **Keyword: "all"** + + When set to "all" the same check is carried out but it will not look + if "Hide page if no translation for current language exists" is set - + it always reverts to default language if no translation is found. + + .. confval:: special + :name: MenuProcessor-special + :type: *"directory" / "list" / "updated" / "rootline" / "browse" / "keywords" + / "categories" / "language" / "userfunction"* + + Lets you define special types of menus. + + See the section about the :ref:`.special property `! + + .. confval:: value + :name: MenuProcessor-special-value + :type: *list of page-uid's* / :ref:`stdWrap ` + + List of page uid's to use for the special menu. What they are used + for depends on the menu type as defined by ".special"; see the + section about the :ref:`.special property `! + + .. _MenuProcessor-titleField: + + .. confval:: titleField + :name: MenuProcessor-titleField + :Required: true + :type: :ref:`data-type-string` / :ref:`stdWrap` + :Default: "nav_title // title" + :Example: "subtitle" + + Fields to be used as title. + +.. _MenuProcessor-special: + +Special menu types +================== + +The following special menu types are available: + +.. toctree:: + :glob: + :titlesonly: + + * + +.. _MenuProcessor-example-two-levels: + +Example: Two level menu of the web page +======================================= + +Please see also :ref:`dataProcessing-about-examples`. + +.. rubric:: TypoScript + +Using the :php:`MenuProcessor` the following scenario is possible: + +.. include:: /CodeSnippets/DataProcessing/TypoScript/MenuProcessor.rst.txt + +.. rubric:: The Fluid template + +This generated menu can be used in Fluid like this: + +.. include:: /CodeSnippets/DataProcessing/Template/DataProcMenu.rst.txt + +.. rubric:: Output + +The array now contains the menu items on level one. Each item in return has the +menu items of level 2 in an array called :php:`children`. + +.. include:: /Images/AutomaticScreenshots/DataProcessing/MenuProcessor.rst.txt diff --git a/Documentation/ContentObjects/Hmenu/Keywords.rst b/Documentation/DataProcessing/MenuProcessor/Keywords.rst similarity index 99% rename from Documentation/ContentObjects/Hmenu/Keywords.rst rename to Documentation/DataProcessing/MenuProcessor/Keywords.rst index bbcc89fbf..b06ec563a 100644 --- a/Documentation/ContentObjects/Hmenu/Keywords.rst +++ b/Documentation/DataProcessing/MenuProcessor/Keywords.rst @@ -1,3 +1,4 @@ +:navigation-title: Keywords .. include:: /Includes.rst.txt .. index:: HMENU; special = keywords .. _hmenu-special-keywords: diff --git a/Documentation/ContentObjects/Hmenu/Language.rst b/Documentation/DataProcessing/MenuProcessor/Language.rst similarity index 91% rename from Documentation/ContentObjects/Hmenu/Language.rst rename to Documentation/DataProcessing/MenuProcessor/Language.rst index 0cd6f3250..d50d4e87c 100644 --- a/Documentation/ContentObjects/Hmenu/Language.rst +++ b/Documentation/DataProcessing/MenuProcessor/Language.rst @@ -1,3 +1,4 @@ +:navigation-title: Language .. include:: /Includes.rst.txt .. index:: HMENU; special = categories .. _hmenu-special-language: @@ -47,6 +48,14 @@ Properties If set, the button for a language will be rendered as a non- disabled button even if no translation is found for the language. +.. _hmenu-addquerystring: + +.. confval:: addQueryString + :name: hmenu-addquerystring + :type: :ref:`->addQueryString ` + + **Note:** This works only for *special=language*. + .. _hmenu-special-language-examples: diff --git a/Documentation/ContentObjects/Hmenu/List.rst b/Documentation/DataProcessing/MenuProcessor/List.rst similarity index 98% rename from Documentation/ContentObjects/Hmenu/List.rst rename to Documentation/DataProcessing/MenuProcessor/List.rst index 69ae4c7d6..f168a9b59 100644 --- a/Documentation/ContentObjects/Hmenu/List.rst +++ b/Documentation/DataProcessing/MenuProcessor/List.rst @@ -1,3 +1,4 @@ +:navigation-title: List .. include:: /Includes.rst.txt .. index:: HMENU; special = list .. _hmenu-special-list: diff --git a/Documentation/ContentObjects/Hmenu/Rootline.rst b/Documentation/DataProcessing/MenuProcessor/Rootline.rst similarity index 98% rename from Documentation/ContentObjects/Hmenu/Rootline.rst rename to Documentation/DataProcessing/MenuProcessor/Rootline.rst index 43c2f222b..7986d37d7 100644 --- a/Documentation/ContentObjects/Hmenu/Rootline.rst +++ b/Documentation/DataProcessing/MenuProcessor/Rootline.rst @@ -1,3 +1,4 @@ +:navigation-title: Rootline / Breadcrumb .. include:: /Includes.rst.txt .. index:: HMENU; special = rootline .. _hmenu-special-rootline: diff --git a/Documentation/ContentObjects/Hmenu/Updated.rst b/Documentation/DataProcessing/MenuProcessor/Updated.rst similarity index 99% rename from Documentation/ContentObjects/Hmenu/Updated.rst rename to Documentation/DataProcessing/MenuProcessor/Updated.rst index 1a2bfbaef..0b6670e56 100644 --- a/Documentation/ContentObjects/Hmenu/Updated.rst +++ b/Documentation/DataProcessing/MenuProcessor/Updated.rst @@ -1,3 +1,4 @@ +:navigation-title: Updated .. include:: /Includes.rst.txt .. index:: HMENU; special = updated .. _hmenu-special-updated: diff --git a/Documentation/ContentObjects/Hmenu/Userfunction.rst b/Documentation/DataProcessing/MenuProcessor/Userfunction.rst similarity index 68% rename from Documentation/ContentObjects/Hmenu/Userfunction.rst rename to Documentation/DataProcessing/MenuProcessor/Userfunction.rst index 99f0fe42d..83befa48f 100644 --- a/Documentation/ContentObjects/Hmenu/Userfunction.rst +++ b/Documentation/DataProcessing/MenuProcessor/Userfunction.rst @@ -1,6 +1,8 @@ +:navigation-title: Userfunction .. include:: /Includes.rst.txt .. index:: HMENU; special = userfunction .. _hmenu-special-userfunction: +.. _hmenu-special-userfunction-examples: ================= Userfunction menu @@ -24,10 +26,6 @@ page records for the menu. Properties ========== -.. confval-menu:: - :display: table - :type: - .. _hmenu-special-userfunction-userfunc: .. confval:: special.userFunc @@ -35,17 +33,3 @@ Properties :type: string Name of the user function - -.. _hmenu-special-userfunction-examples: - -Example: Set a userFunc -======================= - -.. code-block:: typoscript - :caption: This is still possible for backward compability reasons but not recommended: - - lib.custommenu = HMENU - lib.custommenu { - special = userfunction - special.userFunc = MyVendor\MyExtension\Userfuncs\CustomMenu->makeMenuArray - } diff --git a/Documentation/ContentObjects/Hmenu/_code-snippets/_BreadcrumbDataProcessor.typoscript b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_BreadcrumbDataProcessor.typoscript similarity index 100% rename from Documentation/ContentObjects/Hmenu/_code-snippets/_BreadcrumbDataProcessor.typoscript rename to Documentation/DataProcessing/MenuProcessor/_code-snippets/_BreadcrumbDataProcessor.typoscript diff --git a/Documentation/ContentObjects/Hmenu/_code-snippets/_BreadcrumbLib.typoscript b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_BreadcrumbLib.typoscript similarity index 100% rename from Documentation/ContentObjects/Hmenu/_code-snippets/_BreadcrumbLib.typoscript rename to Documentation/DataProcessing/MenuProcessor/_code-snippets/_BreadcrumbLib.typoscript diff --git a/Documentation/ContentObjects/Hmenu/_code-snippets/_LanguageMenuLib.typoscript b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_LanguageMenuLib.typoscript similarity index 100% rename from Documentation/ContentObjects/Hmenu/_code-snippets/_LanguageMenuLib.typoscript rename to Documentation/DataProcessing/MenuProcessor/_code-snippets/_LanguageMenuLib.typoscript diff --git a/Documentation/ContentObjects/Hmenu/_code-snippets/_RelPrevNextMenu.typoscript b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_RelPrevNextMenu.typoscript similarity index 100% rename from Documentation/ContentObjects/Hmenu/_code-snippets/_RelPrevNextMenu.typoscript rename to Documentation/DataProcessing/MenuProcessor/_code-snippets/_RelPrevNextMenu.typoscript diff --git a/Documentation/DataProcessing/MenuProcessor/_code-snippets/_entryLevel.typoscript b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_entryLevel.typoscript new file mode 100644 index 000000000..389273d07 --- /dev/null +++ b/Documentation/DataProcessing/MenuProcessor/_code-snippets/_entryLevel.typoscript @@ -0,0 +1,14 @@ +page.10 { + dataProcessing { + 10 = menu + 10 { + special = list + special.value.field = pages + levels = 7 + entryLevel = 4 + as = menu + expandAll = 1 + titleField = nav_title // title + } + } +} diff --git a/Documentation/Images/ManualScreenshots/FrontendOutput/Hmenu/MenuObjectsCommonPropertiesSubmenuObjSuffixes.png b/Documentation/Images/ManualScreenshots/FrontendOutput/Hmenu/MenuObjectsCommonPropertiesSubmenuObjSuffixes.png deleted file mode 100644 index 2e5ceb489f2c80f05fa8f464d1c42186c900e616..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15333 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 Z&P!%hyoFP8{@T6^5EGITtmN16`(M5--kJaa