From 100896d35985c7f5436f9ee7ec8cedc5a528c91d Mon Sep 17 00:00:00 2001 From: Ilyas Ronef Date: Fri, 3 Jun 2022 11:20:36 +0300 Subject: [PATCH 1/4] =?UTF-8?q?+=20Parameters=20=E2=86=92=20`providerParam?= =?UTF-8?q?s->groupBy`:=20The=20new=20parameter.=20Allows=20to=20group=20i?= =?UTF-8?q?tems=20that=20have=20the=20same=20field=20values=20into=20summa?= =?UTF-8?q?ry=20item=20(like=20SQL=20`GROUP=20BY`).=20See=20README.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 51 ++++++++++++++++++++++++++++++- src/DataProvider/DataProvider.php | 16 ++++++++-- src/Input.php | 5 +-- 3 files changed, 67 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 5ad500d..7ecd873 100644 --- a/README.md +++ b/README.md @@ -63,7 +63,7 @@ require_once( #### Core parameters * `fieldDelimiter` - * Desctription: The field delimiter to be used in order to distinct data base column names in those parameters which can contain SQL queries directly, e. g. `providerParams->orderBy` and `providerParams->filter`. + * Desctription: The field delimiter to be used in order to distinct data base column names in those parameters which can contain SQL queries directly, e. g. `providerParams->groupBy`, `providerParams->orderBy` and `providerParams->filter`. * Valid values: `string` * Default value: ``'`'`` @@ -105,6 +105,16 @@ require_once( * Valid values: `integer` * Default value: `0` +* `providerParams->groupBy` + * Desctription: Group items that have the same values into summary item (like SQL `GROUP BY`). + * Valid values: `stringCommaSeparated` + * Default value: — + +* `providerParams->groupBy[$i]` + * Desctription: Document field or TV by which the items will be grouped. + * Valid values: `string` + * **Required** + * `providerParams->orderBy` * Desctription: A string representing the sorting rule. TV names also can be used. @@ -955,6 +965,45 @@ Returns: ``` +#### Group items that have the same field values into summary item (`providerParams->orderBy`) + +For example we have the following documents with TV `gender`: + +* Mary Teresa, female +* Mahatma Gandhi, male +* Tenzin Gyatso, male +* Dmitry Muratov, male +* ICAN, none + +And we want to make a gender list with unique items: + +``` +[[ddGetDocuments? + &fieldDelimiter=`#` + &providerParams=`{ + //The parent of our documents + parentIds: 42 + //The field by which the items will be grouped + groupBy: "#gender#" + }` + &outputter=`json` + &outputterParams=`{ + docFields: gender + }` +]] +``` + +Returns: + +```json +[ + {"gender": "female"}, + {"gender": "male"}, + {"gender": "none"} +] +``` + + #### Extenders → Pagination (``&extenders=`pagination` ``) ``` diff --git a/src/DataProvider/DataProvider.php b/src/DataProvider/DataProvider.php index 5bc7f44..80779b9 100644 --- a/src/DataProvider/DataProvider.php +++ b/src/DataProvider/DataProvider.php @@ -22,6 +22,7 @@ abstract class DataProvider extends \DDTools\BaseClass { $total, $filter = '', $offset = 0, + $groupBy = '', $orderBy = '' ; @@ -454,7 +455,7 @@ protected final function prepareQueryData_fromAndFilter($filterStr){ /** * prepareQueryData - * @version 2.1.1 (2020-03-10) + * @version 2.2 (2022-06-03) * * @param $params {arrayAssociative|stdClass} * @param $params['resourcesIds'] — Document IDs to get. Default: ''. @@ -462,6 +463,7 @@ protected final function prepareQueryData_fromAndFilter($filterStr){ * @return $result {stdClass} * @return $result->from {string} * @return $result->where {string} + * @return $result->groupBy {string} * @return $result->orderBy {string} * @return $result->limit {string} */ @@ -479,10 +481,18 @@ protected final function prepareQueryData($params = []){ $result = (object) [ 'from' => $fromAndFilterQueries->from, 'where' => '', + 'groupBy' => '', 'orderBy' => '', 'limit' => '', ]; + if(!empty($this->groupBy)){ + $result->groupBy = + 'GROUP BY ' . + $this->groupBy + ; + } + if(!empty($this->orderBy)){ $result->orderBy = 'ORDER BY ' . @@ -543,7 +553,7 @@ protected final function prepareQueryData($params = []){ /** * prepareQuery - * @version 1.3 (2020-05-20) + * @version 1.4 (2022-06-03) * * @param $params {arrayAssociative|stdClass} * @param $params['resourcesIds'] — Document IDs to get ($this->filter will be used). Default: ''. @@ -601,6 +611,8 @@ protected function prepareQuery($params = []){ ' AS `resources` ' . $queryData->where . ' ' . + $queryData->groupBy . + ' ' . $queryData->orderBy . ' ' . $queryData->limit . diff --git a/src/Input.php b/src/Input.php index b114b1d..0d63029 100644 --- a/src/Input.php +++ b/src/Input.php @@ -40,7 +40,7 @@ class Input extends \DDTools\BaseClass { /** * __construct - * @version 4.4.2 (2021-07-18) + * @version 4.5 (2022-06-03) * * @param $snippetParams {stdClass} — The object of parameters. @required * @param $snippetParams->providerParams {stdClass|arrayAssociative|stringJsonObject} @@ -99,10 +99,11 @@ public function __construct($snippetParams){ $this->setExistingProps($snippetParams); - //Make sure orderBy and filter looks like SQL + //Make sure groupBy, orderBy and filter looks like SQL foreach ( [ 'filter', + 'groupBy', 'orderBy' ] as $paramName From d5890425d7a14c87633779bd23bd2b40871eff3a Mon Sep 17 00:00:00 2001 From: Ilyas Ronef Date: Fri, 3 Jun 2022 11:23:55 +0300 Subject: [PATCH 2/4] =?UTF-8?q?-=20README=20=E2=86=92=20Documentation:=20U?= =?UTF-8?q?seless=20header=20level=20has=20been=20deleted.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 65 ++++++++++++++++++++++++++----------------------------- 1 file changed, 31 insertions(+), 34 deletions(-) diff --git a/README.md b/README.md index 7ecd873..d3a4608 100644 --- a/README.md +++ b/README.md @@ -11,16 +11,13 @@ A snippet for fetching and parsing resources from the document tree or custom DB * [(MODX)EvolutionCMS.libraries.ddTools](https://code.divandesign.biz/modx/ddtools) >= 0.50 -## Documentation +## Installation -### Installation +### Manually -#### Manually - - -##### 1. Elements → Snippets: Create a new snippet with the following data +#### 1. Elements → Snippets: Create a new snippet with the following data 1. Snippet name: `ddGetDocuments`. 2. Description: `1.4 A snippet for fetching and parsing resources from the document tree or custom DB table by a custom rule.`. @@ -29,13 +26,13 @@ A snippet for fetching and parsing resources from the document tree or custom DB 5. Snippet code (php): Insert content of the `ddGetDocuments_snippet.php` file from the archive. -##### 2. Elements → Manage Files: +#### 2. Elements → Manage Files: 1. Create a new folder `assets/snippets/ddGetDocuments/`. 2. Extract the archive to the folder (except `ddGetDocuments_snippet.php`). -#### Using [(MODX)EvolutionCMS.libraries.ddInstaller](https://github.com/DivanDesign/EvolutionCMS.libraries.ddInstaller) +### Using [(MODX)EvolutionCMS.libraries.ddInstaller](https://github.com/DivanDesign/EvolutionCMS.libraries.ddInstaller) Just run the following PHP code in your sources or [Console](https://github.com/vanchelo/MODX-Evolution-Ajax-Console): @@ -57,10 +54,10 @@ require_once( * If `ddGetDocuments` is already exist on your site, `ddInstaller` will check it version and update it if needed. -### Parameters description +## Parameters description -#### Core parameters +### Core parameters * `fieldDelimiter` * Desctription: The field delimiter to be used in order to distinct data base column names in those parameters which can contain SQL queries directly, e. g. `providerParams->groupBy`, `providerParams->orderBy` and `providerParams->filter`. @@ -68,7 +65,7 @@ require_once( * Default value: ``'`'`` -#### Data provider parameters +### Data provider parameters * `provider` * Desctription: Name of the provider that will be used to fetch documents. @@ -122,7 +119,7 @@ require_once( * Default value: — -##### Providers → Parent (``&provider=`parent` ``) +#### Providers → Parent (``&provider=`parent` ``) * `providerParams->parentIds` * Desctription: Parent ID(s). @@ -154,7 +151,7 @@ require_once( * **Required** -##### Providers → Select (``&provider=`select` ``) +#### Providers → Select (``&provider=`select` ``) * `providerParams->ids` * Desctription: Document IDs to output. @@ -169,7 +166,7 @@ require_once( * **Required** -##### Providers → Customdbtable (``&provider=`customdbtable` ``) +#### Providers → Customdbtable (``&provider=`customdbtable` ``) Get resources from custom DB table. @@ -179,7 +176,7 @@ Get resources from custom DB table. * **Required** -#### Output format parameters +### Output format parameters * `outputter` * Desctription: Format of the output. @@ -209,7 +206,7 @@ Get resources from custom DB table. * Default value: — -##### Outputter → String (``&outputter=`string` ``) +#### Outputter → String (``&outputter=`string` ``) * `outputterParams->templates->item` * Desctription: Item template. @@ -276,7 +273,7 @@ Get resources from custom DB table. * Default value: `''` -##### Outputter → Json (``&outputter=`json` ``) +#### Outputter → Json (``&outputter=`json` ``) * `outputterParams->docFields` * Desctription: Document fields to output (including TVs). @@ -307,7 +304,7 @@ Get resources from custom DB table. * **Required** -##### Outputter → Sitemap (``&outputter=`sitemap` ``) +#### Outputter → Sitemap (``&outputter=`sitemap` ``) Output in [Sitemap XML format](https://en.wikipedia.org/wiki/Sitemaps). @@ -358,7 +355,7 @@ Output in [Sitemap XML format](https://en.wikipedia.org/wiki/Sitemaps). ``` -##### Outputter → Yandexmarket (``&outputter=`yandexmarket` ``) +#### Outputter → Yandexmarket (``&outputter=`yandexmarket` ``) Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). @@ -640,7 +637,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). * Default: — -#### Extenders parameters +### Extenders parameters * `extenders` * Desctription: Comma-separated string determining which extenders should be applied to the snippet. @@ -677,7 +674,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). * Default value: — -##### Extenders → Pagination (``&extenders=`pagination` ``) +#### Extenders → Pagination (``&extenders=`pagination` ``) * `extendersParams->pagination->wrapperTpl` * Desctription: Chunk to be used to output the pagination. @@ -781,7 +778,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). ``` -##### Extenders → Tagging (``&extenders=`tagging` ``) +#### Extenders → Tagging (``&extenders=`tagging` ``) * `extendersParams->tagging->tagsDocumentField` * Desctription: The document field (TV) contains tags. @@ -799,7 +796,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). * Default value: `'tags'` -##### Extenders → Search (``&extenders=`search` ``) +#### Extenders → Search (``&extenders=`search` ``) * `extendersParams->search->docFieldsToSearch` * Desctription: Document fields to search in (including TVs). @@ -816,7 +813,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). * **Required** -##### Extenders → SortFromURL (``&extenders=`sortFromURL` ``) +#### Extenders → SortFromURL (``&extenders=`sortFromURL` ``) * `$_GET['orderBy']` * Desctription: A string representing the sorting rule similar to `providerParams->orderBy`. @@ -824,10 +821,10 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). * Default value: — -### Examples +## Examples -#### Simple fetching child documents from a parent with ID = `1` +### Simple fetching child documents from a parent with ID = `1` ```html [[ddGetDocuments? @@ -844,7 +841,7 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). ``` -#### Simple fetching child documents from a parent with ID = `1` with the `providerParams->filter` +### Simple fetching child documents from a parent with ID = `1` with the `providerParams->filter` Add a filter that would not output everything. Let's say we need only published documents. @@ -885,7 +882,7 @@ So we can filter as much as we like (we can use `AND` and `OR`, doucument fields ``` -#### Sorting by TV with the `date` type (`providerParams->orderBy`) +### Sorting by TV with the `date` type (`providerParams->orderBy`) Dates in DB stored in specific format (`01-02-2017 08:59:45`) and sorting works unexpectedly at first sight. So, we can't just type: @@ -907,7 +904,7 @@ For correct working we need to convert date from DB to Unixtime for sorting: When `TVName` — TV name for sorting by. -#### Outputters → JSON (``&outputter=`json` ``): Fetch documents and output in JSON +### Outputters → JSON (``&outputter=`json` ``): Fetch documents and output in JSON ``` [[ddGetDocuments? @@ -927,7 +924,7 @@ Returns: ``` -#### Outputters → JSON (``&outputter=`json` ``): Set documents fields to output +### Outputters → JSON (``&outputter=`json` ``): Set documents fields to output ``` [[ddGetDocuments? @@ -965,7 +962,7 @@ Returns: ``` -#### Group items that have the same field values into summary item (`providerParams->orderBy`) +### Group items that have the same field values into summary item (`providerParams->orderBy`) For example we have the following documents with TV `gender`: @@ -1004,7 +1001,7 @@ Returns: ``` -#### Extenders → Pagination (``&extenders=`pagination` ``) +### Extenders → Pagination (``&extenders=`pagination` ``) ``` [[ddGetDocuments? @@ -1047,7 +1044,7 @@ Returns: * ``&extendersParams=`{"pagination": {}}` `` — pagination templates (see the parameters description). -#### Extenders → Search (``&extenders=`search` ``) +### Extenders → Search (``&extenders=`search` ``) Call the snippet at the page with search results. Let's specify where and how deep we will search. @@ -1078,7 +1075,7 @@ Then just add to the page URL `?query=Some query text` and the snippet returns o We recommend to use cashed snippet calls and turn on document caching type with $_GET parameters in CMS configuration. -#### Run the snippet through `\DDTools\Snippet::runSnippet` without DB and eval +### Run the snippet through `\DDTools\Snippet::runSnippet` without DB and eval ```php //Include (MODX)EvolutionCMS.libraries.ddTools From 96d811d740ce5bd6e5df31a7e4368fd8d640beeb Mon Sep 17 00:00:00 2001 From: Ilyas Ronef Date: Fri, 3 Jun 2022 11:31:22 +0300 Subject: [PATCH 3/4] =?UTF-8?q?*=20README=20=E2=86=92=20Examples:=20HJSON?= =?UTF-8?q?=20is=20used=20for=20all=20examples.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 121 ++++++++++++++++++++++++++++++++---------------------- 1 file changed, 72 insertions(+), 49 deletions(-) diff --git a/README.md b/README.md index d3a4608..01400b1 100644 --- a/README.md +++ b/README.md @@ -823,18 +823,27 @@ Output in [YML format](https://yandex.ru/support/partnermarket/export/yml.html). ## Examples +All examples are written using [HJSON](https://hjson.github.io/), but if you want you can use vanilla JSON instead. + ### Simple fetching child documents from a parent with ID = `1` ```html [[ddGetDocuments? &providerParams=`{ - "parentIds": "1", - "depth": 1 + parentIds: 1 + depth: 1 }` &outputterParams=`{ - "templates": { - "item": "@CODE:

[+pagetitle+]

[+introtext+]

[+someTV+]
" + templates: { + item: + ''' + @CODE:
+

[+pagetitle+]

+

[+introtext+]

+ [+someTV+] +
+ ''' } }` ]] @@ -851,13 +860,13 @@ _Don't forget about `fieldDelimiter`._ [[ddGetDocuments? &fieldDelimiter=`#` &providerParams=`{ - "parentIds": "1", - "depth": 1, - "filter": "#published# = 1" + parentIds: 1 + depth: 1 + filter: "#published# = 1" }` &outputterParams=`{ - "templates": { - "item": "documents_item" + templates: { + item: documents_item } }` ]] @@ -869,13 +878,18 @@ So we can filter as much as we like (we can use `AND` and `OR`, doucument fields [[ddGetDocuments? &fieldDelimiter=`#` &providerParams=`{ - "parentIds": "1", - "depth": 1, - "filter": "#published# = 1 AND #hidemenu# = 0 OR #SomeTVName# = 1" + parentIds: 1 + depth: 1 + filter: + ''' + #published# = 1 AND + #hidemenu# = 0 OR + #SomeTVName# = 1 + ''' }` &outputterParams=`{ - "templates: { - "item": "documents_item" + templates: { + item: documents_item } }` ]] @@ -889,7 +903,7 @@ So, we can't just type: ``` &providerParams=`{ - "orderBy": "#TVName# DESC" + orderBy: "#TVName# DESC" }` ``` @@ -897,7 +911,7 @@ For correct working we need to convert date from DB to Unixtime for sorting: ``` &providerParams=`{ - "orderBy": "STR_TO_DATE(#TVName#, '%d-%m-%Y %H:%i:%s') DESC" + orderBy: "STR_TO_DATE(#TVName#, '%d-%m-%Y %H:%i:%s') DESC" }` ``` @@ -908,7 +922,7 @@ When `TVName` — TV name for sorting by. ``` [[ddGetDocuments? - &providerParams=`{"parentIds": "1"}` + &providerParams=`{parentIds: 1}` &outputter=`json` ]] ``` @@ -928,10 +942,10 @@ Returns: ``` [[ddGetDocuments? - &providerParams=`{"parentIds": "1"}` + &providerParams=`{parentIds: 1}` &outputter=`json` &outputterParams=`{ - "docFields": "id,pagetitle,menuindex,someTV" + docFields: id,pagetitle,menuindex,someTV }` ]] ``` @@ -1007,41 +1021,45 @@ Returns: [[ddGetDocuments? &fieldDelimiter=`#` &providerParams=`{ - "parentIds": "[*id*]", - "filter": "#published# = 1", - "total": 3, - "orderBy": "#pub_date# DESC`" + parentIds: "[*id*]" + filter: "#published# = 1" + total: 3 + orderBy: "#pub_date# DESC`" }` &outputterParams=`{ - "templates": { - "item": "documents_item", - "wrapper": "@CODE:[+ddGetDocuments_items+][+extenders.pagination+]", - "noResults": "@CODE:" + templates: { + item: documents_item + wrapper: + '''' + @CODE:[+ddGetDocuments_items+] + [+extenders.pagination+] + ''' + noResults: "@CODE:" } }` &extenders=`pagination` &extendersParams=`{ - "pagination": { - "wrapperTpl": "general_pagination", - "nextTpl": "general_pagination_next", - "previousTpl": "general_pagination_prev", - "nextOffTpl": "general_pagination_nextOff", - "previousOffTpl": "general_pagination_prevOff", - "pageTpl": "general_pagination_page", - "currentPageTpl": "general_pagination_pageCurrent" + pagination: { + wrapperTpl: general_pagination + nextTpl: general_pagination_next + previousTpl: general_pagination_prev + nextOffTpl: general_pagination_nextOff + previousOffTpl: general_pagination_prevOff + pageTpl: general_pagination_page + currentPageTpl: general_pagination_pageCurrent } }` ]] ``` -* ``&providerParams=`{"parentIds": "[*id*]"}` `` — fetch current doc children. -* ``&providerParams=`{"filter": "#published# = 1"}` `` — only published. -* ``&providerParams=`{"total": 3}` `` — items per page. -* ``&providerParams=`{"orderBy": "#pub_date# DESC"} `` — sort by publish date, new first. -* ``&outputterParams=`{"templates": {"item": "documents_item"}}` `` — item template (chunk name). -* ``&outputterParams=`{"templates": {"wrapper": "@CODE:[+ddGetDocuments_items+][+extenders.pagination+]"}}` `` — we need set where pagination will being outputted. -* ``&outputterParams=`{"templates": {"noResults": "@CODE:"}}` `` — return nothing if nothing found. -* ``&extendersParams=`{"pagination": {}}` `` — pagination templates (see the parameters description). +* ``&providerParams=`{parentIds: "[*id*]"}` `` — fetch current doc children. +* ``&providerParams=`{filter: "#published# = 1"}` `` — only published. +* ``&providerParams=`{total: 3}` `` — items per page. +* ``&providerParams=`{orderBy: "#pub_date# DESC"} `` — sort by publish date, new first. +* ``&outputterParams=`{templates: {item: documents_item}}` `` — item template (chunk name). +* ``&outputterParams=`{templates: {wrapper: "@CODE:[+ddGetDocuments_items+][+extenders.pagination+]"}}` `` — we need set where pagination will being outputted. +* ``&outputterParams=`{templates: {noResults: "@CODE:"}}` `` — return nothing if nothing found. +* ``&extendersParams=`{pagination: {}}` `` — pagination templates (see the parameters description). ### Extenders → Search (``&extenders=`search` ``) @@ -1054,17 +1072,22 @@ Set up filter to get only necessary documets. [[ddGetDocuments? &fieldDelimiter=`#` &providerParams=`{ - "parentIds": 1, - "depth": 3, - "filter": "#published# = 1 AND #deleted# = 0 AND #template# = 11" + parentIds: 1 + depth: 3 + filter: + ''' + #published# = 1 AND + #deleted# = 0 AND + #template# = 11 + ''' }` &extenders=`search` &extendersParams=`{ - "docFieldsToSearch": "pagetitle,content,someTv" + docFieldsToSearch: pagetitle,content,someTv }` &outputterParams=`{ - "templates": { - "item": "documents_item" + templates: { + item: documents_item } } ]] From c1613ad79d8d59f1f3e5caa11cd9348900f9e1ef Mon Sep 17 00:00:00 2001 From: Ilyas Ronef Date: Fri, 3 Jun 2022 11:40:56 +0300 Subject: [PATCH 4/4] Prerelease --- CHANGELOG.md | 5 +++++ CHANGELOG_ru.md | 5 +++++ README.md | 2 +- composer.json | 2 +- ddGetDocuments_snippet.php | 4 ++-- src/Snippet.php | 2 +- 6 files changed, 15 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 645eea1..20727ee 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,11 @@ # (MODX)EvolutionCMS.snippets.ddGetDocuments changelog +## Version 1.5 (2022-06-03) +* \+ Parameters → `providerParams->groupBy`: The new parameter. Allows to group items that have the same field values into summary item (like SQL `GROUP BY`). See README. +* \* README → Examples: HJSON is used for all examples. + + ## Version 1.4 (2021-07-27) * \* Attention! PHP >= 5.6 is required. * \* Attention! (MODX)EvolutionCMS.libraries.ddTools >= 0.50 is required. diff --git a/CHANGELOG_ru.md b/CHANGELOG_ru.md index d9c52de..708470a 100644 --- a/CHANGELOG_ru.md +++ b/CHANGELOG_ru.md @@ -1,6 +1,11 @@ # (MODX)EvolutionCMS.snippets.ddGetDocuments changelog +## Version 1.5 (2022-06-03) +* \+ Параметры → `providerParams->groupBy`: Новый параметр. Позволяет сгруппировать элементы, имеющие одинаковые значения полей, в один сводный элемент (как SQL `GROUP BY`). См. README. +* \* README → Примеры: HJSON используется для всех примеров. + + ## Версия 1.4 (2021-07-27) * \* Внимание! Требуется PHP >= 5.6. * \* Внимание! Требуется (MODX)EvolutionCMS.libraries.ddTools >= 0.50. diff --git a/README.md b/README.md index 01400b1..1fe8224 100644 --- a/README.md +++ b/README.md @@ -20,7 +20,7 @@ A snippet for fetching and parsing resources from the document tree or custom DB #### 1. Elements → Snippets: Create a new snippet with the following data 1. Snippet name: `ddGetDocuments`. -2. Description: `1.4 A snippet for fetching and parsing resources from the document tree or custom DB table by a custom rule.`. +2. Description: `1.5 A snippet for fetching and parsing resources from the document tree or custom DB table by a custom rule.`. 3. Category: `Core`. 4. Parse DocBlock: `no`. 5. Snippet code (php): Insert content of the `ddGetDocuments_snippet.php` file from the archive. diff --git a/composer.json b/composer.json index ece41da..b4d95b3 100644 --- a/composer.json +++ b/composer.json @@ -1,7 +1,7 @@ { "name": "dd/evolutioncms-snippets-ddgetdocuments", "type": "modxevo-snippet", - "version": "1.4.0", + "version": "1.5.0", "description": "A snippet for fetching and parsing resources from the document tree or custom DB table by a custom rule.", "keywords": [ "modx", diff --git a/ddGetDocuments_snippet.php b/ddGetDocuments_snippet.php index ec4e49a..806834f 100644 --- a/ddGetDocuments_snippet.php +++ b/ddGetDocuments_snippet.php @@ -1,13 +1,13 @@ 'outputFormat',