@webiny/api-headless-cms-ddb 5.34.0 → 5.34.1-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.js CHANGED
@@ -119,6 +119,12 @@ const createStorageOperations = params => {
119
119
  */
120
120
  const fieldPlugins = context.plugins.byType("cms-model-field-to-graphql");
121
121
  plugins.register(fieldPlugins);
122
+ const filterPathPlugins = context.plugins.byType(_plugins3.CmsEntryFieldFilterPathPlugin.type);
123
+ plugins.register(filterPathPlugins);
124
+ const filterPlugins = context.plugins.byType(_plugins3.CmsEntryFieldFilterPlugin.type);
125
+ plugins.register(filterPlugins);
126
+ const sortingPlugins = context.plugins.byType(_plugins3.CmsEntryFieldSortingPlugin.type);
127
+ plugins.register(sortingPlugins);
122
128
  /**
123
129
  * Pass the plugins to the parent context.
124
130
  */
package/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":["createStorageOperations","params","attributes","table","documentClient","plugins","userPlugins","tableInstance","createTable","entities","settings","createSettingsEntity","entityName","ENTITIES","SETTINGS","system","createSystemEntity","SYSTEM","groups","createGroupEntity","GROUPS","models","createModelEntity","MODELS","entries","createEntryEntity","ENTRIES","PluginsContainer","dynamoDbValueFilters","dynamoDbPlugins","createFilterCreatePlugins","name","beforeInit","context","fieldPlugins","byType","register","getEntities","getTable","createSystemStorageOperations","entity","createSettingsStorageOperations","createGroupsStorageOperations","createModelsStorageOperations","createEntriesStorageOperations"],"sources":["index.ts"],"sourcesContent":["import dynamoDbValueFilters from \"@webiny/db-dynamodb/plugins/filters\";\nimport dynamoDbPlugins from \"./dynamoDb\";\nimport { ENTITIES, StorageOperationsFactory } from \"~/types\";\nimport { createTable } from \"~/definitions/table\";\nimport { createSettingsEntity } from \"~/definitions/settings\";\nimport { createSystemEntity } from \"~/definitions/system\";\nimport { createGroupEntity } from \"~/definitions/group\";\nimport { createModelEntity } from \"~/definitions/model\";\nimport { createEntryEntity } from \"~/definitions/entry\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { createSystemStorageOperations } from \"~/operations/system\";\nimport { createSettingsStorageOperations } from \"~/operations/settings\";\nimport { createGroupsStorageOperations } from \"~/operations/group\";\nimport { createModelsStorageOperations } from \"~/operations/model\";\nimport { createEntriesStorageOperations } from \"./operations/entry\";\nimport { CmsModelFieldToGraphQLPlugin } from \"@webiny/api-headless-cms/types\";\n\nimport { createFilterCreatePlugins } from \"~/operations/entry/filtering/plugins\";\n\nexport * from \"./plugins\";\n\nexport const createStorageOperations: StorageOperationsFactory = params => {\n const { attributes, table, documentClient, plugins: userPlugins } = params;\n\n const tableInstance = createTable({\n table,\n documentClient\n });\n\n const entities = {\n settings: createSettingsEntity({\n entityName: ENTITIES.SETTINGS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SETTINGS] : {}\n }),\n system: createSystemEntity({\n entityName: ENTITIES.SYSTEM,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SYSTEM] : {}\n }),\n groups: createGroupEntity({\n entityName: ENTITIES.GROUPS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.GROUPS] : {}\n }),\n models: createModelEntity({\n entityName: ENTITIES.MODELS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.MODELS] : {}\n }),\n entries: createEntryEntity({\n entityName: ENTITIES.ENTRIES,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.ENTRIES] : {}\n })\n };\n\n const plugins = new PluginsContainer([\n /**\n * DynamoDB filter plugins for the where conditions.\n */\n dynamoDbValueFilters(),\n /**\n * Field plugins for DynamoDB.\n */\n dynamoDbPlugins(),\n /**\n * Filter create plugins.\n */\n createFilterCreatePlugins(),\n /**\n * User defined custom plugins.\n */\n ...(userPlugins || [])\n ]);\n\n return {\n name: \"dynamodb\",\n beforeInit: async context => {\n /**\n * Collect all required plugins from parent context.\n */\n const fieldPlugins = context.plugins.byType<CmsModelFieldToGraphQLPlugin>(\n \"cms-model-field-to-graphql\"\n );\n plugins.register(fieldPlugins);\n\n /**\n * Pass the plugins to the parent context.\n */\n context.plugins.register([dynamoDbPlugins()]);\n },\n getEntities: () => entities,\n getTable: () => tableInstance,\n system: createSystemStorageOperations({\n entity: entities.system\n }),\n settings: createSettingsStorageOperations({\n entity: entities.settings\n }),\n groups: createGroupsStorageOperations({\n entity: entities.groups,\n plugins\n }),\n models: createModelsStorageOperations({\n entity: entities.models\n }),\n entries: createEntriesStorageOperations({\n entity: entities.entries,\n plugins\n })\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["createStorageOperations","params","attributes","table","documentClient","plugins","userPlugins","tableInstance","createTable","entities","settings","createSettingsEntity","entityName","ENTITIES","SETTINGS","system","createSystemEntity","SYSTEM","groups","createGroupEntity","GROUPS","models","createModelEntity","MODELS","entries","createEntryEntity","ENTRIES","PluginsContainer","dynamoDbValueFilters","dynamoDbPlugins","createFilterCreatePlugins","name","beforeInit","context","fieldPlugins","byType","register","filterPathPlugins","CmsEntryFieldFilterPathPlugin","type","filterPlugins","CmsEntryFieldFilterPlugin","sortingPlugins","CmsEntryFieldSortingPlugin","getEntities","getTable","createSystemStorageOperations","entity","createSettingsStorageOperations","createGroupsStorageOperations","createModelsStorageOperations","createEntriesStorageOperations"],"sources":["index.ts"],"sourcesContent":["import dynamoDbValueFilters from \"@webiny/db-dynamodb/plugins/filters\";\nimport dynamoDbPlugins from \"./dynamoDb\";\nimport { ENTITIES, StorageOperationsFactory } from \"~/types\";\nimport { createTable } from \"~/definitions/table\";\nimport { createSettingsEntity } from \"~/definitions/settings\";\nimport { createSystemEntity } from \"~/definitions/system\";\nimport { createGroupEntity } from \"~/definitions/group\";\nimport { createModelEntity } from \"~/definitions/model\";\nimport { createEntryEntity } from \"~/definitions/entry\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { createSystemStorageOperations } from \"~/operations/system\";\nimport { createSettingsStorageOperations } from \"~/operations/settings\";\nimport { createGroupsStorageOperations } from \"~/operations/group\";\nimport { createModelsStorageOperations } from \"~/operations/model\";\nimport { createEntriesStorageOperations } from \"./operations/entry\";\nimport { CmsModelFieldToGraphQLPlugin } from \"@webiny/api-headless-cms/types\";\n\nimport { createFilterCreatePlugins } from \"~/operations/entry/filtering/plugins\";\nimport {\n CmsEntryFieldFilterPathPlugin,\n CmsEntryFieldFilterPlugin,\n CmsEntryFieldSortingPlugin\n} from \"~/plugins\";\n\nexport * from \"./plugins\";\n\nexport const createStorageOperations: StorageOperationsFactory = params => {\n const { attributes, table, documentClient, plugins: userPlugins } = params;\n\n const tableInstance = createTable({\n table,\n documentClient\n });\n\n const entities = {\n settings: createSettingsEntity({\n entityName: ENTITIES.SETTINGS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SETTINGS] : {}\n }),\n system: createSystemEntity({\n entityName: ENTITIES.SYSTEM,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SYSTEM] : {}\n }),\n groups: createGroupEntity({\n entityName: ENTITIES.GROUPS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.GROUPS] : {}\n }),\n models: createModelEntity({\n entityName: ENTITIES.MODELS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.MODELS] : {}\n }),\n entries: createEntryEntity({\n entityName: ENTITIES.ENTRIES,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.ENTRIES] : {}\n })\n };\n\n const plugins = new PluginsContainer([\n /**\n * DynamoDB filter plugins for the where conditions.\n */\n dynamoDbValueFilters(),\n /**\n * Field plugins for DynamoDB.\n */\n dynamoDbPlugins(),\n /**\n * Filter create plugins.\n */\n createFilterCreatePlugins(),\n /**\n * User defined custom plugins.\n */\n ...(userPlugins || [])\n ]);\n\n return {\n name: \"dynamodb\",\n beforeInit: async context => {\n /**\n * Collect all required plugins from parent context.\n */\n const fieldPlugins = context.plugins.byType<CmsModelFieldToGraphQLPlugin>(\n \"cms-model-field-to-graphql\"\n );\n plugins.register(fieldPlugins);\n\n const filterPathPlugins = context.plugins.byType<CmsEntryFieldFilterPathPlugin>(\n CmsEntryFieldFilterPathPlugin.type\n );\n plugins.register(filterPathPlugins);\n\n const filterPlugins = context.plugins.byType<CmsEntryFieldFilterPlugin>(\n CmsEntryFieldFilterPlugin.type\n );\n plugins.register(filterPlugins);\n\n const sortingPlugins = context.plugins.byType<CmsEntryFieldSortingPlugin>(\n CmsEntryFieldSortingPlugin.type\n );\n plugins.register(sortingPlugins);\n /**\n * Pass the plugins to the parent context.\n */\n context.plugins.register([dynamoDbPlugins()]);\n },\n getEntities: () => entities,\n getTable: () => tableInstance,\n system: createSystemStorageOperations({\n entity: entities.system\n }),\n settings: createSettingsStorageOperations({\n entity: entities.settings\n }),\n groups: createGroupsStorageOperations({\n entity: entities.groups,\n plugins\n }),\n models: createModelsStorageOperations({\n entity: entities.models\n }),\n entries: createEntriesStorageOperations({\n entity: entities.entries,\n plugins\n })\n };\n};\n"],"mappings":";;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AAMA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEO,MAAMA,uBAAiD,GAAGC,MAAM,IAAI;EACvE,MAAM;IAAEC,UAAF;IAAcC,KAAd;IAAqBC,cAArB;IAAqCC,OAAO,EAAEC;EAA9C,IAA8DL,MAApE;EAEA,MAAMM,aAAa,GAAG,IAAAC,kBAAA,EAAY;IAC9BL,KAD8B;IAE9BC;EAF8B,CAAZ,CAAtB;EAKA,MAAMK,QAAQ,GAAG;IACbC,QAAQ,EAAE,IAAAC,8BAAA,EAAqB;MAC3BC,UAAU,EAAEC,eAAA,CAASC,QADM;MAE3BX,KAAK,EAAEI,aAFoB;MAG3BL,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACW,eAAA,CAASC,QAAV,CAAb,GAAmC;IAH9B,CAArB,CADG;IAMbC,MAAM,EAAE,IAAAC,0BAAA,EAAmB;MACvBJ,UAAU,EAAEC,eAAA,CAASI,MADE;MAEvBd,KAAK,EAAEI,aAFgB;MAGvBL,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACW,eAAA,CAASI,MAAV,CAAb,GAAiC;IAHhC,CAAnB,CANK;IAWbC,MAAM,EAAE,IAAAC,wBAAA,EAAkB;MACtBP,UAAU,EAAEC,eAAA,CAASO,MADC;MAEtBjB,KAAK,EAAEI,aAFe;MAGtBL,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACW,eAAA,CAASO,MAAV,CAAb,GAAiC;IAHjC,CAAlB,CAXK;IAgBbC,MAAM,EAAE,IAAAC,wBAAA,EAAkB;MACtBV,UAAU,EAAEC,eAAA,CAASU,MADC;MAEtBpB,KAAK,EAAEI,aAFe;MAGtBL,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACW,eAAA,CAASU,MAAV,CAAb,GAAiC;IAHjC,CAAlB,CAhBK;IAqBbC,OAAO,EAAE,IAAAC,wBAAA,EAAkB;MACvBb,UAAU,EAAEC,eAAA,CAASa,OADE;MAEvBvB,KAAK,EAAEI,aAFgB;MAGvBL,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACW,eAAA,CAASa,OAAV,CAAb,GAAkC;IAHjC,CAAlB;EArBI,CAAjB;EA4BA,MAAMrB,OAAO,GAAG,IAAIsB,yBAAJ,CAAqB;EACjC;AACR;AACA;EACQ,IAAAC,gBAAA,GAJiC;EAKjC;AACR;AACA;EACQ,IAAAC,iBAAA,GARiC;EASjC;AACR;AACA;EACQ,IAAAC,mCAAA,GAZiC;EAajC;AACR;AACA;EACQ,IAAIxB,WAAW,IAAI,EAAnB,CAhBiC,CAArB,CAAhB;EAmBA,OAAO;IACHyB,IAAI,EAAE,UADH;IAEHC,UAAU,EAAE,MAAMC,OAAN,IAAiB;MACzB;AACZ;AACA;MACY,MAAMC,YAAY,GAAGD,OAAO,CAAC5B,OAAR,CAAgB8B,MAAhB,CACjB,4BADiB,CAArB;MAGA9B,OAAO,CAAC+B,QAAR,CAAiBF,YAAjB;MAEA,MAAMG,iBAAiB,GAAGJ,OAAO,CAAC5B,OAAR,CAAgB8B,MAAhB,CACtBG,uCAAA,CAA8BC,IADR,CAA1B;MAGAlC,OAAO,CAAC+B,QAAR,CAAiBC,iBAAjB;MAEA,MAAMG,aAAa,GAAGP,OAAO,CAAC5B,OAAR,CAAgB8B,MAAhB,CAClBM,mCAAA,CAA0BF,IADR,CAAtB;MAGAlC,OAAO,CAAC+B,QAAR,CAAiBI,aAAjB;MAEA,MAAME,cAAc,GAAGT,OAAO,CAAC5B,OAAR,CAAgB8B,MAAhB,CACnBQ,oCAAA,CAA2BJ,IADR,CAAvB;MAGAlC,OAAO,CAAC+B,QAAR,CAAiBM,cAAjB;MACA;AACZ;AACA;;MACYT,OAAO,CAAC5B,OAAR,CAAgB+B,QAAhB,CAAyB,CAAC,IAAAP,iBAAA,GAAD,CAAzB;IACH,CA7BE;IA8BHe,WAAW,EAAE,MAAMnC,QA9BhB;IA+BHoC,QAAQ,EAAE,MAAMtC,aA/Bb;IAgCHQ,MAAM,EAAE,IAAA+B,sCAAA,EAA8B;MAClCC,MAAM,EAAEtC,QAAQ,CAACM;IADiB,CAA9B,CAhCL;IAmCHL,QAAQ,EAAE,IAAAsC,0CAAA,EAAgC;MACtCD,MAAM,EAAEtC,QAAQ,CAACC;IADqB,CAAhC,CAnCP;IAsCHQ,MAAM,EAAE,IAAA+B,qCAAA,EAA8B;MAClCF,MAAM,EAAEtC,QAAQ,CAACS,MADiB;MAElCb;IAFkC,CAA9B,CAtCL;IA0CHgB,MAAM,EAAE,IAAA6B,qCAAA,EAA8B;MAClCH,MAAM,EAAEtC,QAAQ,CAACY;IADiB,CAA9B,CA1CL;IA6CHG,OAAO,EAAE,IAAA2B,sCAAA,EAA+B;MACpCJ,MAAM,EAAEtC,QAAQ,CAACe,OADmB;MAEpCnB;IAFoC,CAA/B;EA7CN,CAAP;AAkDH,CAzGM"}
@@ -1,4 +1,6 @@
1
1
  import { Field } from "./types";
2
+ import { PluginsContainer } from "@webiny/plugins";
3
+ import { CmsModel } from "@webiny/api-headless-cms/types";
2
4
  interface Result {
3
5
  valuePath: string;
4
6
  reverse: boolean;
@@ -6,8 +8,10 @@ interface Result {
6
8
  field: Field;
7
9
  }
8
10
  interface Params {
11
+ model: CmsModel;
9
12
  sortBy: string;
10
13
  fields: Record<string, Field>;
14
+ plugins: PluginsContainer;
11
15
  }
12
16
  export declare const extractSort: (params: Params) => Result;
13
17
  export {};
@@ -9,10 +9,14 @@ exports.extractSort = void 0;
9
9
 
10
10
  var _error = _interopRequireDefault(require("@webiny/error"));
11
11
 
12
+ var _plugins = require("../../../plugins");
13
+
12
14
  const extractSort = params => {
13
15
  const {
16
+ model,
14
17
  sortBy,
15
- fields
18
+ fields,
19
+ plugins
16
20
  } = params;
17
21
  const result = sortBy.split("_");
18
22
 
@@ -33,8 +37,26 @@ const extractSort = params => {
33
37
 
34
38
  return field.fieldId === fieldId;
35
39
  });
40
+ const plugin = plugins.byType(_plugins.CmsEntryFieldSortingPlugin.type).reverse().find(plugin => {
41
+ return plugin.canUse({
42
+ model,
43
+ field,
44
+ fieldId,
45
+ order,
46
+ sortBy
47
+ });
48
+ });
36
49
 
37
- if (!field) {
50
+ if (plugin) {
51
+ return plugin.createSort({
52
+ model,
53
+ fieldId,
54
+ order,
55
+ sortBy,
56
+ field,
57
+ fields
58
+ });
59
+ } else if (!field) {
38
60
  throw new _error.default("Sorting field does not exist in the content model.", "SORTING_FIELD_ERROR", {
39
61
  fieldId,
40
62
  fields
@@ -1 +1 @@
1
- {"version":3,"names":["extractSort","params","sortBy","fields","result","split","length","WebinyError","fieldId","order","field","Object","values","find","parents","valuePath","createPath","reverse"],"sources":["extractSort.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Field } from \"./types\";\n\ninterface Result {\n valuePath: string;\n reverse: boolean;\n fieldId: string;\n field: Field;\n}\n\ninterface Params {\n sortBy: string;\n fields: Record<string, Field>;\n}\n\nexport const extractSort = (params: Params): Result => {\n const { sortBy, fields } = params;\n const result = sortBy.split(\"_\");\n if (result.length !== 2) {\n throw new WebinyError(\n \"Problem in determining the sorting for the entry items.\",\n \"SORT_EXTRACT_ERROR\",\n {\n sortBy\n }\n );\n }\n const [fieldId, order] = result;\n\n const field = Object.values(fields).find(field => {\n /**\n * We do not support sorting by nested fields.\n */\n if (field.parents.length > 0) {\n return false;\n }\n return field.fieldId === fieldId;\n });\n\n if (!field) {\n throw new WebinyError(\n \"Sorting field does not exist in the content model.\",\n \"SORTING_FIELD_ERROR\",\n {\n fieldId,\n fields\n }\n );\n }\n const valuePath = field.createPath({\n field\n });\n return {\n field,\n fieldId,\n valuePath,\n reverse: order === \"DESC\"\n };\n};\n"],"mappings":";;;;;;;;;AAAA;;AAeO,MAAMA,WAAW,GAAIC,MAAD,IAA4B;EACnD,MAAM;IAAEC,MAAF;IAAUC;EAAV,IAAqBF,MAA3B;EACA,MAAMG,MAAM,GAAGF,MAAM,CAACG,KAAP,CAAa,GAAb,CAAf;;EACA,IAAID,MAAM,CAACE,MAAP,KAAkB,CAAtB,EAAyB;IACrB,MAAM,IAAIC,cAAJ,CACF,yDADE,EAEF,oBAFE,EAGF;MACIL;IADJ,CAHE,CAAN;EAOH;;EACD,MAAM,CAACM,OAAD,EAAUC,KAAV,IAAmBL,MAAzB;EAEA,MAAMM,KAAK,GAAGC,MAAM,CAACC,MAAP,CAAcT,MAAd,EAAsBU,IAAtB,CAA2BH,KAAK,IAAI;IAC9C;AACR;AACA;IACQ,IAAIA,KAAK,CAACI,OAAN,CAAcR,MAAd,GAAuB,CAA3B,EAA8B;MAC1B,OAAO,KAAP;IACH;;IACD,OAAOI,KAAK,CAACF,OAAN,KAAkBA,OAAzB;EACH,CARa,CAAd;;EAUA,IAAI,CAACE,KAAL,EAAY;IACR,MAAM,IAAIH,cAAJ,CACF,oDADE,EAEF,qBAFE,EAGF;MACIC,OADJ;MAEIL;IAFJ,CAHE,CAAN;EAQH;;EACD,MAAMY,SAAS,GAAGL,KAAK,CAACM,UAAN,CAAiB;IAC/BN;EAD+B,CAAjB,CAAlB;EAGA,OAAO;IACHA,KADG;IAEHF,OAFG;IAGHO,SAHG;IAIHE,OAAO,EAAER,KAAK,KAAK;EAJhB,CAAP;AAMH,CA3CM"}
1
+ {"version":3,"names":["extractSort","params","model","sortBy","fields","plugins","result","split","length","WebinyError","fieldId","order","field","Object","values","find","parents","plugin","byType","CmsEntryFieldSortingPlugin","type","reverse","canUse","createSort","valuePath","createPath"],"sources":["extractSort.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Field } from \"./types\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { CmsEntryFieldSortingPlugin } from \"~/plugins\";\nimport { CmsModel } from \"@webiny/api-headless-cms/types\";\n\ninterface Result {\n valuePath: string;\n reverse: boolean;\n fieldId: string;\n field: Field;\n}\n\ninterface Params {\n model: CmsModel;\n sortBy: string;\n fields: Record<string, Field>;\n plugins: PluginsContainer;\n}\n\nexport const extractSort = (params: Params): Result => {\n const { model, sortBy, fields, plugins } = params;\n const result = sortBy.split(\"_\");\n if (result.length !== 2) {\n throw new WebinyError(\n \"Problem in determining the sorting for the entry items.\",\n \"SORT_EXTRACT_ERROR\",\n {\n sortBy\n }\n );\n }\n const [fieldId, order] = result as [string, \"ASC\" | \"DESC\"];\n\n const field = Object.values(fields).find(field => {\n /**\n * We do not support sorting by nested fields.\n */\n if (field.parents.length > 0) {\n return false;\n }\n return field.fieldId === fieldId;\n });\n\n const plugin = plugins\n .byType<CmsEntryFieldSortingPlugin>(CmsEntryFieldSortingPlugin.type)\n .reverse()\n .find(plugin => {\n return plugin.canUse({\n model,\n field,\n fieldId,\n order,\n sortBy\n });\n });\n\n if (plugin) {\n return plugin.createSort({\n model,\n fieldId,\n order,\n sortBy,\n field,\n fields\n });\n } else if (!field) {\n throw new WebinyError(\n \"Sorting field does not exist in the content model.\",\n \"SORTING_FIELD_ERROR\",\n {\n fieldId,\n fields\n }\n );\n }\n const valuePath = field.createPath({\n field\n });\n return {\n field,\n fieldId,\n valuePath,\n reverse: order === \"DESC\"\n };\n};\n"],"mappings":";;;;;;;;;AAAA;;AAGA;;AAiBO,MAAMA,WAAW,GAAIC,MAAD,IAA4B;EACnD,MAAM;IAAEC,KAAF;IAASC,MAAT;IAAiBC,MAAjB;IAAyBC;EAAzB,IAAqCJ,MAA3C;EACA,MAAMK,MAAM,GAAGH,MAAM,CAACI,KAAP,CAAa,GAAb,CAAf;;EACA,IAAID,MAAM,CAACE,MAAP,KAAkB,CAAtB,EAAyB;IACrB,MAAM,IAAIC,cAAJ,CACF,yDADE,EAEF,oBAFE,EAGF;MACIN;IADJ,CAHE,CAAN;EAOH;;EACD,MAAM,CAACO,OAAD,EAAUC,KAAV,IAAmBL,MAAzB;EAEA,MAAMM,KAAK,GAAGC,MAAM,CAACC,MAAP,CAAcV,MAAd,EAAsBW,IAAtB,CAA2BH,KAAK,IAAI;IAC9C;AACR;AACA;IACQ,IAAIA,KAAK,CAACI,OAAN,CAAcR,MAAd,GAAuB,CAA3B,EAA8B;MAC1B,OAAO,KAAP;IACH;;IACD,OAAOI,KAAK,CAACF,OAAN,KAAkBA,OAAzB;EACH,CARa,CAAd;EAUA,MAAMO,MAAM,GAAGZ,OAAO,CACjBa,MADU,CACyBC,mCAAA,CAA2BC,IADpD,EAEVC,OAFU,GAGVN,IAHU,CAGLE,MAAM,IAAI;IACZ,OAAOA,MAAM,CAACK,MAAP,CAAc;MACjBpB,KADiB;MAEjBU,KAFiB;MAGjBF,OAHiB;MAIjBC,KAJiB;MAKjBR;IALiB,CAAd,CAAP;EAOH,CAXU,CAAf;;EAaA,IAAIc,MAAJ,EAAY;IACR,OAAOA,MAAM,CAACM,UAAP,CAAkB;MACrBrB,KADqB;MAErBQ,OAFqB;MAGrBC,KAHqB;MAIrBR,MAJqB;MAKrBS,KALqB;MAMrBR;IANqB,CAAlB,CAAP;EAQH,CATD,MASO,IAAI,CAACQ,KAAL,EAAY;IACf,MAAM,IAAIH,cAAJ,CACF,oDADE,EAEF,qBAFE,EAGF;MACIC,OADJ;MAEIN;IAFJ,CAHE,CAAN;EAQH;;EACD,MAAMoB,SAAS,GAAGZ,KAAK,CAACa,UAAN,CAAiB;IAC/Bb;EAD+B,CAAjB,CAAlB;EAGA,OAAO;IACHA,KADG;IAEHF,OAFG;IAGHc,SAHG;IAIHH,OAAO,EAAEV,KAAK,KAAK;EAJhB,CAAP;AAMH,CAjEM"}
@@ -1 +1 @@
1
- export declare const createFilterCreatePlugins: () => import("../../../../plugins/CmsEntryFieldFilterPlugin").CmsEntryFieldFilterPlugin[];
1
+ export declare const createFilterCreatePlugins: () => import("../../../..").CmsEntryFieldFilterPlugin[];
@@ -1,9 +1,12 @@
1
- import { CmsEntry } from "@webiny/api-headless-cms/types";
1
+ import { CmsEntry, CmsModel } from "@webiny/api-headless-cms/types";
2
2
  import { Field } from "./types";
3
+ import { PluginsContainer } from "@webiny/plugins";
3
4
  interface Params {
5
+ model: CmsModel;
4
6
  items: CmsEntry[];
5
7
  sort?: string[];
6
8
  fields: Record<string, Field>;
9
+ plugins: PluginsContainer;
7
10
  }
8
11
  export declare const sort: (params: Params) => CmsEntry[];
9
12
  export {};
@@ -17,9 +17,11 @@ var _extractSort = require("./extractSort");
17
17
 
18
18
  const sort = params => {
19
19
  const {
20
+ model,
20
21
  items,
21
22
  sort = [],
22
- fields
23
+ fields,
24
+ plugins
23
25
  } = params;
24
26
 
25
27
  if (items.length <= 1) {
@@ -46,8 +48,10 @@ const sort = params => {
46
48
  valuePath,
47
49
  reverse
48
50
  } = (0, _extractSort.extractSort)({
51
+ model,
49
52
  sortBy: firstSort,
50
- fields
53
+ fields,
54
+ plugins
51
55
  });
52
56
  const itemsToSort = items.map(item => {
53
57
  return {
@@ -1 +1 @@
1
- {"version":3,"names":["sort","params","items","fields","length","push","WebinyError","firstSort","fieldId","field","valuePath","reverse","extractSort","sortBy","itemsToSort","map","item","id","value","transform","dotProp","get","sortedItems","lodashSortBy","newItems","s","find","i","sortingBy"],"sources":["sort.ts"],"sourcesContent":["import { CmsEntry } from \"@webiny/api-headless-cms/types\";\nimport WebinyError from \"@webiny/error\";\nimport dotProp from \"dot-prop\";\nimport lodashSortBy from \"lodash/sortBy\";\nimport { extractSort } from \"./extractSort\";\nimport { Field } from \"./types\";\n\ninterface Params {\n items: CmsEntry[];\n sort?: string[];\n fields: Record<string, Field>;\n}\n\ninterface SortedItem {\n id: string;\n value: any;\n}\n\nexport const sort = (params: Params): CmsEntry[] => {\n const { items, sort = [], fields } = params;\n if (items.length <= 1) {\n return items;\n } else if (sort.length === 0) {\n sort.push(\"savedOn_DESC\");\n } else if (sort.length > 1) {\n throw new WebinyError(\n \"Sorting is limited to a single field.\",\n \"SORT_MULTIPLE_FIELDS_ERROR\",\n {\n sort: sort\n }\n );\n }\n const [firstSort] = sort;\n if (!firstSort) {\n throw new WebinyError(\"Empty sort array item.\", \"SORT_EMPTY_ERROR\", {\n sort\n });\n }\n\n const { fieldId, field, valuePath, reverse } = extractSort({\n sortBy: firstSort,\n fields\n });\n\n const itemsToSort = items.map(item => {\n return {\n id: item.id,\n value: field.transform(dotProp.get(item, valuePath))\n };\n });\n const sortedItems: SortedItem[] = lodashSortBy(itemsToSort, \"value\");\n const newItems = sortedItems.map(s => {\n const item = items.find(i => i.id === s.id);\n if (item) {\n return item;\n }\n throw new WebinyError(\n \"Could not find item by given id after the sorting.\",\n \"SORTING_ITEMS_ERROR\",\n {\n id: s.id,\n sortingBy: fieldId,\n reverse\n }\n );\n });\n if (!reverse) {\n return newItems;\n }\n return newItems.reverse();\n};\n"],"mappings":";;;;;;;;;AACA;;AACA;;AACA;;AACA;;AAcO,MAAMA,IAAI,GAAIC,MAAD,IAAgC;EAChD,MAAM;IAAEC,KAAF;IAASF,IAAI,GAAG,EAAhB;IAAoBG;EAApB,IAA+BF,MAArC;;EACA,IAAIC,KAAK,CAACE,MAAN,IAAgB,CAApB,EAAuB;IACnB,OAAOF,KAAP;EACH,CAFD,MAEO,IAAIF,IAAI,CAACI,MAAL,KAAgB,CAApB,EAAuB;IAC1BJ,IAAI,CAACK,IAAL,CAAU,cAAV;EACH,CAFM,MAEA,IAAIL,IAAI,CAACI,MAAL,GAAc,CAAlB,EAAqB;IACxB,MAAM,IAAIE,cAAJ,CACF,uCADE,EAEF,4BAFE,EAGF;MACIN,IAAI,EAAEA;IADV,CAHE,CAAN;EAOH;;EACD,MAAM,CAACO,SAAD,IAAcP,IAApB;;EACA,IAAI,CAACO,SAAL,EAAgB;IACZ,MAAM,IAAID,cAAJ,CAAgB,wBAAhB,EAA0C,kBAA1C,EAA8D;MAChEN;IADgE,CAA9D,CAAN;EAGH;;EAED,MAAM;IAAEQ,OAAF;IAAWC,KAAX;IAAkBC,SAAlB;IAA6BC;EAA7B,IAAyC,IAAAC,wBAAA,EAAY;IACvDC,MAAM,EAAEN,SAD+C;IAEvDJ;EAFuD,CAAZ,CAA/C;EAKA,MAAMW,WAAW,GAAGZ,KAAK,CAACa,GAAN,CAAUC,IAAI,IAAI;IAClC,OAAO;MACHC,EAAE,EAAED,IAAI,CAACC,EADN;MAEHC,KAAK,EAAET,KAAK,CAACU,SAAN,CAAgBC,gBAAA,CAAQC,GAAR,CAAYL,IAAZ,EAAkBN,SAAlB,CAAhB;IAFJ,CAAP;EAIH,CALmB,CAApB;EAMA,MAAMY,WAAyB,GAAG,IAAAC,eAAA,EAAaT,WAAb,EAA0B,OAA1B,CAAlC;EACA,MAAMU,QAAQ,GAAGF,WAAW,CAACP,GAAZ,CAAgBU,CAAC,IAAI;IAClC,MAAMT,IAAI,GAAGd,KAAK,CAACwB,IAAN,CAAWC,CAAC,IAAIA,CAAC,CAACV,EAAF,KAASQ,CAAC,CAACR,EAA3B,CAAb;;IACA,IAAID,IAAJ,EAAU;MACN,OAAOA,IAAP;IACH;;IACD,MAAM,IAAIV,cAAJ,CACF,oDADE,EAEF,qBAFE,EAGF;MACIW,EAAE,EAAEQ,CAAC,CAACR,EADV;MAEIW,SAAS,EAAEpB,OAFf;MAGIG;IAHJ,CAHE,CAAN;EASH,CAdgB,CAAjB;;EAeA,IAAI,CAACA,OAAL,EAAc;IACV,OAAOa,QAAP;EACH;;EACD,OAAOA,QAAQ,CAACb,OAAT,EAAP;AACH,CArDM"}
1
+ {"version":3,"names":["sort","params","model","items","fields","plugins","length","push","WebinyError","firstSort","fieldId","field","valuePath","reverse","extractSort","sortBy","itemsToSort","map","item","id","value","transform","dotProp","get","sortedItems","lodashSortBy","newItems","s","find","i","sortingBy"],"sources":["sort.ts"],"sourcesContent":["import { CmsEntry, CmsModel } from \"@webiny/api-headless-cms/types\";\nimport WebinyError from \"@webiny/error\";\nimport dotProp from \"dot-prop\";\nimport lodashSortBy from \"lodash/sortBy\";\nimport { extractSort } from \"./extractSort\";\nimport { Field } from \"./types\";\nimport { PluginsContainer } from \"@webiny/plugins\";\n\ninterface Params {\n model: CmsModel;\n items: CmsEntry[];\n sort?: string[];\n fields: Record<string, Field>;\n plugins: PluginsContainer;\n}\n\ninterface SortedItem {\n id: string;\n value: any;\n}\n\nexport const sort = (params: Params): CmsEntry[] => {\n const { model, items, sort = [], fields, plugins } = params;\n if (items.length <= 1) {\n return items;\n } else if (sort.length === 0) {\n sort.push(\"savedOn_DESC\");\n } else if (sort.length > 1) {\n throw new WebinyError(\n \"Sorting is limited to a single field.\",\n \"SORT_MULTIPLE_FIELDS_ERROR\",\n {\n sort: sort\n }\n );\n }\n const [firstSort] = sort;\n if (!firstSort) {\n throw new WebinyError(\"Empty sort array item.\", \"SORT_EMPTY_ERROR\", {\n sort\n });\n }\n\n const { fieldId, field, valuePath, reverse } = extractSort({\n model,\n sortBy: firstSort,\n fields,\n plugins\n });\n\n const itemsToSort = items.map(item => {\n return {\n id: item.id,\n value: field.transform(dotProp.get(item, valuePath))\n };\n });\n const sortedItems: SortedItem[] = lodashSortBy(itemsToSort, \"value\");\n const newItems = sortedItems.map(s => {\n const item = items.find(i => i.id === s.id);\n if (item) {\n return item;\n }\n throw new WebinyError(\n \"Could not find item by given id after the sorting.\",\n \"SORTING_ITEMS_ERROR\",\n {\n id: s.id,\n sortingBy: fieldId,\n reverse\n }\n );\n });\n if (!reverse) {\n return newItems;\n }\n return newItems.reverse();\n};\n"],"mappings":";;;;;;;;;AACA;;AACA;;AACA;;AACA;;AAiBO,MAAMA,IAAI,GAAIC,MAAD,IAAgC;EAChD,MAAM;IAAEC,KAAF;IAASC,KAAT;IAAgBH,IAAI,GAAG,EAAvB;IAA2BI,MAA3B;IAAmCC;EAAnC,IAA+CJ,MAArD;;EACA,IAAIE,KAAK,CAACG,MAAN,IAAgB,CAApB,EAAuB;IACnB,OAAOH,KAAP;EACH,CAFD,MAEO,IAAIH,IAAI,CAACM,MAAL,KAAgB,CAApB,EAAuB;IAC1BN,IAAI,CAACO,IAAL,CAAU,cAAV;EACH,CAFM,MAEA,IAAIP,IAAI,CAACM,MAAL,GAAc,CAAlB,EAAqB;IACxB,MAAM,IAAIE,cAAJ,CACF,uCADE,EAEF,4BAFE,EAGF;MACIR,IAAI,EAAEA;IADV,CAHE,CAAN;EAOH;;EACD,MAAM,CAACS,SAAD,IAAcT,IAApB;;EACA,IAAI,CAACS,SAAL,EAAgB;IACZ,MAAM,IAAID,cAAJ,CAAgB,wBAAhB,EAA0C,kBAA1C,EAA8D;MAChER;IADgE,CAA9D,CAAN;EAGH;;EAED,MAAM;IAAEU,OAAF;IAAWC,KAAX;IAAkBC,SAAlB;IAA6BC;EAA7B,IAAyC,IAAAC,wBAAA,EAAY;IACvDZ,KADuD;IAEvDa,MAAM,EAAEN,SAF+C;IAGvDL,MAHuD;IAIvDC;EAJuD,CAAZ,CAA/C;EAOA,MAAMW,WAAW,GAAGb,KAAK,CAACc,GAAN,CAAUC,IAAI,IAAI;IAClC,OAAO;MACHC,EAAE,EAAED,IAAI,CAACC,EADN;MAEHC,KAAK,EAAET,KAAK,CAACU,SAAN,CAAgBC,gBAAA,CAAQC,GAAR,CAAYL,IAAZ,EAAkBN,SAAlB,CAAhB;IAFJ,CAAP;EAIH,CALmB,CAApB;EAMA,MAAMY,WAAyB,GAAG,IAAAC,eAAA,EAAaT,WAAb,EAA0B,OAA1B,CAAlC;EACA,MAAMU,QAAQ,GAAGF,WAAW,CAACP,GAAZ,CAAgBU,CAAC,IAAI;IAClC,MAAMT,IAAI,GAAGf,KAAK,CAACyB,IAAN,CAAWC,CAAC,IAAIA,CAAC,CAACV,EAAF,KAASQ,CAAC,CAACR,EAA3B,CAAb;;IACA,IAAID,IAAJ,EAAU;MACN,OAAOA,IAAP;IACH;;IACD,MAAM,IAAIV,cAAJ,CACF,oDADE,EAEF,qBAFE,EAGF;MACIW,EAAE,EAAEQ,CAAC,CAACR,EADV;MAEIW,SAAS,EAAEpB,OAFf;MAGIG;IAHJ,CAHE,CAAN;EASH,CAdgB,CAAjB;;EAeA,IAAI,CAACA,OAAL,EAAc;IACV,OAAOa,QAAP;EACH;;EACD,OAAOA,QAAQ,CAACb,OAAT,EAAP;AACH,CAvDM"}
@@ -668,6 +668,8 @@ const createEntriesStorageOperations = params => {
668
668
  */
669
669
 
670
670
  const sortedItems = (0, _filtering.sort)({
671
+ model,
672
+ plugins,
671
673
  items: filteredItems,
672
674
  sort: sortBy,
673
675
  fields: modelFields
@@ -1 +1 @@
1
- {"version":3,"names":["createType","createLatestType","createPublishedType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","createEntriesStorageOperations","entity","plugins","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","type","reduce","collection","plugin","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","entry","initialStorageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","getPublishedRevisionByEntryId","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","entryId","version","queryParams","lt","zeroPad","filters","attr","eq","reverse","result","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","publish","initialPublishedStorageEntry","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperations,\n CmsEntryStorageOperationsCreateParams,\n CmsEntryStorageOperationsCreateRevisionFromParams,\n CmsEntryStorageOperationsDeleteParams,\n CmsEntryStorageOperationsDeleteRevisionParams,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryStorageOperationsUpdateParams,\n StorageOperationsCmsModel,\n CONTENT_ENTRY_STATUS,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\ninterface ConvertStorageEntryParams {\n storageEntry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\n}\nconst convertToStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst convertFromStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - create new main entry item\n * - create new or update latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateRevisionFromParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUpdateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n /**\n * We need the latest entry to update it as well if neccessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteEntry = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteParams\n ) => {\n const { entry } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n entry\n }\n );\n }\n };\n\n const deleteRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteRevisionParams\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const getLatestRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n const getPublishedRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisionById = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisions = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n const items = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetByIdsParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getLatestByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPublishedByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPreviousRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const storageEntry = cleanupItem(entity, result);\n if (!storageEntry) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsListParams\n ) => {\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort: sortBy,\n fields,\n search\n } = params;\n const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (storageEntries.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need an object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry;\n })\n );\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = filter({\n items: records,\n where,\n plugins,\n fields: modelFields,\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sort({\n items: filteredItems,\n sort: sortBy,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetParams\n ) => {\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsPublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\n * We need the latest and published entries to see if something needs to be updated along side the publishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (initialLatestStorageEntry && entry.id === initialLatestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (initialPublishedStorageEntry && initialPublishedStorageEntry.id !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry: initialLatestStorageEntry,\n publishedStorageEntry: initialPublishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUnpublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update latest entry status - if entry being unpublished is latest\n */\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\n deleteRevision,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n publish,\n list,\n unpublish\n };\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AAyBA;;AAQA;;AACA;;AAMA;;AAEA;;AACA;;AACA;;AAEA;;AACA;;AAEA,MAAMA,UAAU,GAAG,MAAc;EAC7B,OAAO,WAAP;AACH,CAFD;;AAGA,MAAMC,gBAAgB,GAAG,MAAc;EACnC,OAAQ,GAAED,UAAU,EAAG,IAAvB;AACH,CAFD;;AAGA,MAAME,mBAAmB,GAAG,MAAc;EACtC,OAAQ,GAAEF,UAAU,EAAG,IAAvB;AACH,CAFD;;AAQA,MAAMG,qBAAqB,GAAIC,MAAD,IAAwD;EAClF,MAAM;IAAEC,KAAF;IAASC;EAAT,IAA0BF,MAAhC;EAEA,MAAMG,MAAM,GAAGF,KAAK,CAACG,wBAAN,CAA+B;IAC1CC,MAAM,EAAEJ,KAAK,CAACI,MAD4B;IAE1CF,MAAM,EAAED,YAAY,CAACC;EAFqB,CAA/B,CAAf;EAIA,mEACOD,YADP;IAEIC;EAFJ;AAIH,CAXD;;AAaA,MAAMG,uBAAuB,GAAIN,MAAD,IAAwD;EACpF,MAAM;IAAEC,KAAF;IAASC;EAAT,IAA0BF,MAAhC;EAEA,MAAMG,MAAM,GAAGF,KAAK,CAACM,0BAAN,CAAiC;IAC5CF,MAAM,EAAEJ,KAAK,CAACI,MAD8B;IAE5CF,MAAM,EAAED,YAAY,CAACC;EAFuB,CAAjC,CAAf;EAIA,mEACOD,YADP;IAEIC;EAFJ;AAIH,CAXD;;AAiBO,MAAMK,8BAA8B,GACvCR,MAD0C,IAEd;EAC5B,MAAM;IAAES,MAAF;IAAUC;EAAV,IAAsBV,MAA5B;EAEA,MAAMW,WAAW,GAAG,IAAIC,+BAAJ,CAAuB;IACvCH;EADuC,CAAvB,CAApB;EAIA,MAAMI,uBAAuB,GAAGH,OAAO,CAClCI,MAD2B,CACIC,sCAAA,CAAuBC,IAD3B,EAE3BC,MAF2B,CAEpB,CAACC,UAAD,EAAaC,MAAb,KAAwB;IAC5BD,UAAU,CAACC,MAAM,CAACC,SAAR,CAAV,GAA+BD,MAA/B;IACA,OAAOD,UAAP;EACH,CAL2B,EAKzB,EALyB,CAAhC;;EAOA,MAAMG,8BAA8B,GAChCpB,KADmC,IAEX;IACxB,OAAO,CAACqB,KAAD,EAAQC,KAAR,KAAkB;MACrB,MAAMJ,MAA8B,GAAGN,uBAAuB,CAACS,KAAK,CAACN,IAAP,CAA9D;;MACA,IAAI,CAACG,MAAL,EAAa;QACT,OAAOI,KAAP;MACH;;MACD,OAAOJ,MAAM,CAACK,WAAP,CAAmB;QACtBvB,KADsB;QAEtBqB,KAFsB;QAGtBC,KAHsB;;QAItBE,gBAAgB,CAACL,SAAD,EAA4C;UACxD,OAAOP,uBAAuB,CAACO,SAAD,CAAvB,IAAsCP,uBAAuB,CAAC,GAAD,CAApE;QACH,CANqB;;QAOtBH;MAPsB,CAAnB,CAAP;IASH,CAdD;EAeH,CAlBD;;EAoBA,MAAMgB,MAAM,GAAG,OACXzB,KADW,EAEXD,MAFW,KAGV;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMC,WAAW,GAAGP,KAAK,CAACQ,MAAN,KAAiB,WAArC;IAEA,MAAMC,MAAM,GAAGF,WAAW,GAAG,IAAH,GAAUP,KAAK,CAACS,MAA1C;IAEA,MAAMlC,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQ,MAAMS,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAJR;MAKIe,IAAI,EAAE9C,UAAU,EALpB;MAMI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GADU,EAUVO,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAO,yBAAA,GAJR;MAKIL,IAAI,EAAE7C,gBAAgB,EAL1B;MAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GAVU,CAAd;IAqBA;AACR;AACA;;IACQ,IAAIgC,WAAJ,EAAiB;MACbG,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAS,4BAAA,GAJR;QAKIP,IAAI,EAAE7C,gBAAgB,EAL1B;QAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAgD,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0CADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,oBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B;MAFJ,CAHE,CAAN;IAQH;;IAED,OAAOC,mBAAP;EACH,CAnFD;;EAqFA,MAAM8B,kBAAkB,GAAG,OACvBzD,KADuB,EAEvBD,MAFuB,KAGtB;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBvC,YAAtB,CAHR;MAIIwC,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IANb,GADU,EASVO,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;MAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;MAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IANb,GATU,CAAd;;IAkBA,IAAI;MACA,MAAM,IAAAgD,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6CADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,uBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B,KAFJ;QAGIzB;MAHJ,CAHE,CAAN;IASH;IACD;AACR;AACA;;;IACQ,OAAO0B,mBAAP;EACH,CA9DD;;EAgEA,MAAM+B,MAAM,GAAG,OACX1D,KADW,EAEXD,MAFW,KAGV;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IACA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMC,WAAW,GAAGP,KAAK,CAACQ,MAAN,KAAiB,WAArC;IACA,MAAMC,MAAM,GAAGF,WAAW,GAAG,IAAH,GAAUP,KAAK,CAACS,MAA1C;IAEA,MAAMC,KAAK,GAAG,EAAd;IAEA,MAAMnC,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQS,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBvC,YAAtB,CAJR;MAKIwC,IAAI,EAAE9C,UAAU,EALpB;MAMI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GADJ;;IAYA,IAAIgC,WAAJ,EAAiB;MACbG,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAS,4BAAA,GAJR;QAKIP,IAAI,EAAE5C,mBAAmB,EAL7B;QAMI6C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;MAPb,GADJ;IAWH;IAED;AACR;AACA;;;IACQ,MAAM0D,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIA,kBAAkB,CAAC7B,EAAnB,KAA0BJ,KAAK,CAACI,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAO,yBAAA,GAJR;QAKIL,IAAI,EAAE7C,gBAAgB,EAL1B;QAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,yBADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,cAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B,KAFJ;QAGIiC;MAHJ,CAHE,CAAN;IASH;EACJ,CA1FD;;EA4FA,MAAME,WAAW,GAAG,OAChB7D,KADgB,EAEhBD,MAFgB,KAGf;IACD,MAAM;MAAE2B;IAAF,IAAY3B,MAAlB;IAEA,MAAM+D,cAA8B,GAAG;MACnCtD,MADmC;MAEnCoB,YAAY,EAAE,IAAAC,wBAAA,EAAmB;QAC7BC,EAAE,EAAEJ,KAAK,CAACI,EADmB;QAE7BC,MAAM,EAAE/B,KAAK,CAAC+B,MAFe;QAG7BC,MAAM,EAAEhC,KAAK,CAACgC;MAHe,CAAnB,CAFqB;MAOnC+B,OAAO,EAAE;QACLC,GAAG,EAAE;MADA;IAP0B,CAAvC;IAYA,IAAIC,OAAO,GAAG,EAAd;;IACA,IAAI;MACAA,OAAO,GAAG,MAAM,IAAAC,eAAA,EAASJ,cAAT,CAAhB;IACH,CAFD,CAEE,OAAOV,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,wBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B;MAFJ,CAHE,CAAN;IAQH;;IACD,MAAMU,KAAK,GAAG6B,OAAO,CAACE,GAAR,CAAYC,IAAI,IAAI;MAC9B,OAAO5D,MAAM,CAAC6D,WAAP,CAAmB;QACtB/B,EAAE,EAAE8B,IAAI,CAAC9B,EADa;QAEtBC,EAAE,EAAE6B,IAAI,CAAC7B;MAFa,CAAnB,CAAP;IAIH,CALa,CAAd;;IAOA,IAAI;MACA,MAAM,IAAAU,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,oBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEIxB,YAAY,EAAEkC,cAAc,CAAClC,YAFjC;QAGIF;MAHJ,CAHE,CAAN;IASH;EACJ,CAzDD;;EA2DA,MAAM4C,cAAc,GAAG,OACnBtE,KADmB,EAEnBD,MAFmB,KAGlB;IACD,MAAM;MAAE2B,KAAF;MAAS6C,WAAT;MAAsBZ,kBAAkB,EAAEa;IAA1C,IAAwEzE,MAA9E;IACA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMI,KAAK,GAAG,CACV5B,MAAM,CAAC6D,WAAP,CAAmB;MACf/B,EAAE,EAAEV,YADW;MAEfW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB;IAFW,CAAnB,CADU,CAAd;IAOA,MAAM+C,qBAAqB,GAAG,MAAMC,6BAA6B,CAAC1E,KAAD,EAAQ0B,KAAR,CAAjE;IAEA;AACR;AACA;;IACQ,IAAI+C,qBAAqB,IAAI/C,KAAK,CAACI,EAAN,KAAa2C,qBAAqB,CAAC3C,EAAhE,EAAoE;MAChEM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6D,WAAP,CAAmB;QACf/B,EAAE,EAAEV,YADW;QAEfW,EAAE,EAAE,IAAAS,4BAAA;MAFW,CAAnB,CADJ;IAMH;;IACD,IAAIwB,yBAAJ,EAA+B;MAC3B,MAAMb,kBAAkB,GAAG7D,qBAAqB,CAAC;QAC7CG,YAAY,EAAEuE,yBAD+B;QAE7CxE;MAF6C,CAAD,CAAhD;MAIAoC,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOsB,kBADP;QAEIrB,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBc,kBAAjB;MANb,GADJ;IAUH;;IACD,IAAI;MACA,MAAM,IAAAV,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CAAgBD,EAAE,CAACE,OAAnB,EAA4BF,EAAE,CAACG,IAA/B,EAAqC;QACvCC,KAAK,EAAEJ,EADgC;QAEvC1B,KAFuC;QAGvC6C;MAHuC,CAArC,CAAN;IAKH;EACJ,CA9DD;;EAgEA,MAAMX,0BAA0B,GAAG,OAC/B5D,KAD+B,EAE/BD,MAF+B,KAG9B;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACkD,0BAAZ,CAAuC;MACvD5D,KADuD;MAEvD2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFkD,CAAvC,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAiBA,MAAM0E,6BAA6B,GAAG,OAClC1E,KADkC,EAElCD,MAFkC,KAGjC;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACgE,6BAAZ,CAA0C;MAC1D1E,KAD0D;MAE1D2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFqD,CAA1C,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAkBA,MAAM6E,eAAe,GAAG,OACpB7E,KADoB,EAEpBD,MAFoB,KAGnB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACmE,eAAZ,CAA4B;MAC5C7E,KAD4C;MAE5C2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFuC,CAA5B,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAkBA,MAAM8E,YAAY,GAAG,OACjB9E,KADiB,EAEjBD,MAFiB,KAGhB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACqE,oBAAZ,CAAiC;MACjD/E,KADiD;MAEjD2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAF4C,CAAjC,CAApB;IAKA,OAAOM,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMgF,QAAQ,GAAG,OACbhF,KADa,EAEbD,MAFa,KAGZ;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACmE,eAAZ,CAA4B;MAC5C7E,KAD4C;MAE5C2E,GAAG,EAAE5E,MAAM,CAAC4E;IAFgC,CAA5B,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMiF,cAAc,GAAG,OACnBjF,KADmB,EAEnBD,MAFmB,KAGlB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACkD,0BAAZ,CAAuC;MACvD5D,KADuD;MAEvD2E,GAAG,EAAE5E,MAAM,CAAC4E;IAF2C,CAAvC,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMkF,iBAAiB,GAAG,OACtBlF,KADsB,EAEtBD,MAFsB,KAGrB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACgE,6BAAZ,CAA0C;MAC1D1E,KAD0D;MAE1D2E,GAAG,EAAE5E,MAAM,CAAC4E;IAF8C,CAA1C,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMmF,mBAAmB,GAAG,OACxBnF,KADwB,EAExBD,MAFwB,KAGvB;IACD,MAAM;MAAEqF,OAAF;MAAWC;IAAX,IAAuBtF,MAA7B;IACA,MAAMuF,WAA2B,GAAG;MAChC9E,MADgC;MAEhCoB,YAAY,EAAE,IAAAC,wBAAA,EAAmB;QAC7BG,MAAM,EAAEhC,KAAK,CAACgC,MADe;QAE7BD,MAAM,EAAE/B,KAAK,CAAC+B,MAFe;QAG7BD,EAAE,EAAEsD;MAHyB,CAAnB,CAFkB;MAOhCrB,OAAO,EAAE;QACLwB,EAAE,EAAG,OAAM,IAAAC,gBAAA,EAAQH,OAAR,CAAiB,EADvB;;QAEL;AAChB;AACA;QACgBI,OAAO,EAAE,CACL;UACIC,IAAI,EAAE,MADV;UAEIC,EAAE,EAAEhG,UAAU;QAFlB,CADK,EAKL;UACI+F,IAAI,EAAE,SADV;UAEIH,EAAE,EAAEF;QAFR,CALK,CALJ;QAeLO,OAAO,EAAE;MAfJ;IAPuB,CAApC;;IA0BA,IAAI;MACA,MAAMC,MAAM,GAAG,MAAM,IAAAC,eAAA,EAAmBR,WAAnB,CAArB;MAEA,MAAMrF,YAAY,GAAG,IAAA8F,oBAAA,EAAYvF,MAAZ,EAAoBqF,MAApB,CAArB;;MACA,IAAI,CAAC5F,YAAL,EAAmB;QACf,OAAO,IAAP;MACH;;MACD,OAAOI,uBAAuB,CAAC;QAC3BJ,YAD2B;QAE3BD;MAF2B,CAAD,CAA9B;IAIH,CAXD,CAWE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,gDADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,4BAFT,8DAIKxD,MAJL;QAKEyD,KAAK,EAAEJ,EALT;QAMExB,YAAY,EAAE0D,WAAW,CAAC1D,YAN5B;QAOEmC,OAAO,EAAEuB,WAAW,CAACvB,OAPvB;QAQE/D;MARF,GAAN;IAWH;EACJ,CAvDD;;EAyDA,MAAMgG,IAAI,GAAG,OACThG,KADS,EAETD,MAFS,KAGR;IACD,MAAM;MACFkG,KAAK,EAAEC,YAAY,GAAG,EADpB;MAEFC,KAAK,EAAEC,YAFL;MAGFC,KAHE;MAIFC,IAAI,EAAEC,MAJJ;MAKFnG,MALE;MAMFoG;IANE,IAOFzG,MAPJ;IAQA,MAAMkG,KAAK,GAAGC,YAAY,IAAI,CAAhB,IAAqBA,YAAY,IAAI,KAArC,GAA6C,KAA7C,GAAqDA,YAAnE;IAEA,MAAMnF,IAAI,GAAGqF,YAAY,CAACK,SAAb,GAAyB,GAAzB,GAA+B,GAA5C;IAEA,MAAM3C,cAA8B,GAAG;MACnCtD,MADmC;MAEnCoB,YAAY,EAAE,IAAAe,2BAAA,EAAsB3C,KAAtB,EAA6Be,IAA7B,CAFqB;MAGnCgD,OAAO,EAAE;QACL2C,KAAK,EAAE,MADF;QAEL1C,GAAG,EAAE;MAFA;IAH0B,CAAvC;IAQA,IAAI2C,cAAiC,GAAG,EAAxC;;IACA,IAAI;MACAA,cAAc,GAAG,MAAM,IAAAzC,eAAA,EAA0BJ,cAA1B,CAAvB;IACH,CAFD,CAEE,OAAOV,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CAAgBD,EAAE,CAACE,OAAnB,EAA4B,qBAA5B,EAAmD;QACrDE,KAAK,EAAEJ,EAD8C;QAErDxB,YAAY,EAAEkC,cAAc,CAAClC,YAFwB;QAGrDmC,OAAO,EAAED,cAAc,CAACC;MAH6B,CAAnD,CAAN;IAKH;;IACD,IAAI4C,cAAc,CAACC,MAAf,KAA0B,CAA9B,EAAiC;MAC7B,OAAO;QACHC,YAAY,EAAE,KADX;QAEHC,UAAU,EAAE,CAFT;QAGHC,MAAM,EAAE,IAHL;QAIH3E,KAAK,EAAE;MAJJ,CAAP;IAMH;;IACD,MAAM+D,KAAiC,mCAChCC,YADgC,CAAvC;IAGA,OAAOD,KAAK,CAAC,WAAD,CAAZ;IACA,OAAOA,KAAK,CAAC,QAAD,CAAZ;IACA;AACR;AACA;AACA;;IACQ,MAAMa,WAAW,GAAG,IAAAC,0BAAA,EAAa;MAC7BxG,OAD6B;MAE7BL,MAAM,EAAEJ,KAAK,CAACI;IAFe,CAAb,CAApB;IAKA,MAAMmB,WAAW,GAAGH,8BAA8B,CAACpB,KAAD,CAAlD;IACA;AACR;AACA;AACA;AACA;;IACQ,MAAMiE,OAAO,GAAG,MAAMiD,OAAO,CAACC,GAAR,CAClBR,cAAc,CAACxC,GAAf,CAAmB,MAAMlE,YAAN,IAAsB;MACrC,MAAMyB,KAAK,GAAGrB,uBAAuB,CAAC;QAClCJ,YADkC;QAElCD;MAFkC,CAAD,CAArC;;MAKA,KAAK,MAAMqB,KAAX,IAAoBrB,KAAK,CAACI,MAA1B,EAAkC;QAC9BsB,KAAK,CAACxB,MAAN,CAAamB,KAAK,CAAC+F,OAAnB,IAA8B,MAAM7F,WAAW,CAC3CF,KAD2C,EAE3CK,KAAK,CAACxB,MAAN,CAAamB,KAAK,CAAC+F,OAAnB,CAF2C,CAA/C;MAIH;;MAED,OAAO1F,KAAP;IACH,CAdD,CADkB,CAAtB;IAiBA;AACR;AACA;AACA;;IACQ,MAAM2F,aAAa,GAAG,IAAAC,iBAAA,EAAO;MACzBlF,KAAK,EAAE6B,OADkB;MAEzBkC,KAFyB;MAGzB1F,OAHyB;MAIzBL,MAAM,EAAE4G,WAJiB;MAKzBO,cAAc,EAAE;QACZC,IAAI,EAAEhB,MADM;QAEZpG,MAAM,EAAEA,MAAM,IAAI;MAFN;IALS,CAAP,CAAtB;IAWA,MAAM0G,UAAU,GAAGO,aAAa,CAACT,MAAjC;IAEA;AACR;AACA;AACA;;IACQ,MAAMa,WAAW,GAAG,IAAAnB,eAAA,EAAK;MACrBlE,KAAK,EAAEiF,aADc;MAErBf,IAAI,EAAEC,MAFe;MAGrBnG,MAAM,EAAE4G;IAHa,CAAL,CAApB;IAMA,MAAMU,KAAK,GAAGC,QAAQ,CAAE,IAAAC,oBAAA,EAAavB,KAAb,CAAD,IAAmC,GAApC,CAAR,IAAoD,CAAlE;IACA,MAAMQ,YAAY,GAAGC,UAAU,GAAGY,KAAK,GAAGzB,KAA1C;IACA,MAAM4B,GAAG,GAAG5B,KAAK,GAAGa,UAAU,GAAGY,KAAb,GAAqBzB,KAA7B,GAAqC6B,SAArC,GAAiDJ,KAAK,GAAGzB,KAArE;IACA,MAAM8B,WAAW,GAAGN,WAAW,CAACO,KAAZ,CAAkBN,KAAlB,EAAyBG,GAAzB,CAApB;IACA;AACR;AACA;AACA;;IACQ,MAAMd,MAAM,GAAGD,UAAU,GAAGY,KAAK,GAAGzB,KAArB,GAA6B,IAAAgC,oBAAA,EAAc,GAAEP,KAAK,GAAGzB,KAAM,EAA9B,CAA7B,GAAgE,IAA/E;IACA,OAAO;MACHY,YADG;MAEHC,UAFG;MAGHC,MAHG;MAIH3E,KAAK,EAAE,IAAA8F,qBAAA,EAAa1H,MAAb,EAAqBuH,WAArB;IAJJ,CAAP;EAMH,CAzHD;;EA2HA,MAAMI,GAAG,GAAG,OACRnI,KADQ,EAERD,MAFQ,KAGP;IACD,MAAM;MAAEqC;IAAF,IAAY,MAAM4D,IAAI,CAAChG,KAAD,8DACrBD,MADqB;MAExBkG,KAAK,EAAE;IAFiB,GAA5B;IAIA,OAAO7D,KAAK,CAACwC,KAAN,MAAiB,IAAxB;EACH,CATD;;EAWA,MAAMwD,OAAO,GAAG,OACZpI,KADY,EAEZD,MAFY,KAGX;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA;AACR;AACA;;IACQ,MAAMwC,yBAAyB,GAAG,MAAMZ,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAAlE;IACA,MAAM2G,4BAA4B,GAAG,MAAM3D,6BAA6B,CAAC1E,KAAD,EAAQ0B,KAAR,CAAxE;IAEA,MAAMzB,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;AACA;AACA;;IACQ,MAAMS,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAHR;MAIIe,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GADU,EASVlB,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAS,4BAAA,GAHR;MAIIP,IAAI,EAAE5C,mBAAmB,EAJ7B;MAKI6C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GATU,CAAd;;IAkBA,IAAI8C,yBAAyB,IAAI9C,KAAK,CAACI,EAAN,KAAa0C,yBAAyB,CAAC1C,EAAxE,EAA4E;MACxEM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IACD,IAAI2G,4BAA4B,IAAIA,4BAA4B,CAACvG,EAA7B,KAAoCJ,KAAK,CAACI,EAA9E,EAAkF;MAC9E,MAAM2C,qBAAqB,GAAG3E,qBAAqB,CAAC;QAChDG,YAAY,EAAEoI,4BADkC;QAEhDrI;MAFgD,CAAD,CAAnD;MAIAoC,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOoC,qBADP;QAEInC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBiC,qBAAtB,CAHR;QAIIhC,IAAI,EAAE9C,UAAU,EAJpB;QAKIuC,MAAM,EAAEoG,2BAAA,CAAqBC,WALjC;QAMI7F,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB4B,qBAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAxB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,yCADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,eAFT,EAGF;QACI7B,KADJ;QAEIiC,kBAAkB,EAAEa,yBAFxB;QAGIC,qBAAqB,EAAE4D;MAH3B,CAHE,CAAN;IASH;EACJ,CAjGD;;EAmGA,MAAMG,SAAS,GAAG,OACdxI,KADc,EAEdD,MAFc,KAGb;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6D,WAAP,CAAmB;MACf/B,EAAE,EAAEV,YADW;MAEfW,EAAE,EAAE,IAAAS,4BAAA;IAFW,CAAnB,CADU,EAKVxC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAHR;MAIIe,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GALU,CAAd;IAeA;AACR;AACA;;IACQ,MAAMiC,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIjC,KAAK,CAACI,EAAN,KAAa6B,kBAAkB,CAAC7B,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,6DACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,oCADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,iBAFT,EAGF;QACI7B,KADJ;QAEIzB;MAFJ,CAHE,CAAN;IAQH;EACJ,CA1ED;;EA4EA,OAAO;IACHwB,MADG;IAEHgC,kBAFG;IAGHC,MAHG;IAIH+E,MAAM,EAAE5E,WAJL;IAKHS,cALG;IAMHa,mBANG;IAOHD,iBAPG;IAQHD,cARG;IASHD,QATG;IAUHH,eAVG;IAWHH,6BAXG;IAYHd,0BAZG;IAaHuE,GAbG;IAcHrD,YAdG;IAeHsD,OAfG;IAgBHpC,IAhBG;IAiBHwC;EAjBG,CAAP;AAmBH,CA14BM"}
1
+ {"version":3,"names":["createType","createLatestType","createPublishedType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","createEntriesStorageOperations","entity","plugins","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","type","reduce","collection","plugin","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","entry","initialStorageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","getPublishedRevisionByEntryId","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","entryId","version","queryParams","lt","zeroPad","filters","attr","eq","reverse","result","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","publish","initialPublishedStorageEntry","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperations,\n CmsEntryStorageOperationsCreateParams,\n CmsEntryStorageOperationsCreateRevisionFromParams,\n CmsEntryStorageOperationsDeleteParams,\n CmsEntryStorageOperationsDeleteRevisionParams,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryStorageOperationsUpdateParams,\n StorageOperationsCmsModel,\n CONTENT_ENTRY_STATUS,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\ninterface ConvertStorageEntryParams {\n storageEntry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\n}\nconst convertToStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst convertFromStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - create new main entry item\n * - create new or update latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateRevisionFromParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUpdateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n /**\n * We need the latest entry to update it as well if neccessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteEntry = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteParams\n ) => {\n const { entry } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n entry\n }\n );\n }\n };\n\n const deleteRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteRevisionParams\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const getLatestRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n const getPublishedRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisionById = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisions = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n const items = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetByIdsParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getLatestByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPublishedByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPreviousRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const storageEntry = cleanupItem(entity, result);\n if (!storageEntry) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsListParams\n ) => {\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort: sortBy,\n fields,\n search\n } = params;\n const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (storageEntries.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need an object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry;\n })\n );\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = filter({\n items: records,\n where,\n plugins,\n fields: modelFields,\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sort({\n model,\n plugins,\n items: filteredItems,\n sort: sortBy,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetParams\n ) => {\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsPublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\n * We need the latest and published entries to see if something needs to be updated along side the publishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (initialLatestStorageEntry && entry.id === initialLatestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (initialPublishedStorageEntry && initialPublishedStorageEntry.id !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry: initialLatestStorageEntry,\n publishedStorageEntry: initialPublishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUnpublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update latest entry status - if entry being unpublished is latest\n */\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\n deleteRevision,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n publish,\n list,\n unpublish\n };\n};\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/api-headless-cms-ddb",
3
- "version": "5.34.0",
3
+ "version": "5.34.1-beta.1",
4
4
  "main": "index.js",
5
5
  "keywords": [
6
6
  "@webiny/api-headless-cms",
@@ -22,11 +22,11 @@
22
22
  "license": "MIT",
23
23
  "dependencies": {
24
24
  "@babel/runtime": "7.19.0",
25
- "@webiny/api-headless-cms": "5.34.0",
26
- "@webiny/db-dynamodb": "5.34.0",
27
- "@webiny/error": "5.34.0",
28
- "@webiny/handler-db": "5.34.0",
29
- "@webiny/utils": "5.34.0",
25
+ "@webiny/api-headless-cms": "5.34.1-beta.1",
26
+ "@webiny/db-dynamodb": "5.34.1-beta.1",
27
+ "@webiny/error": "5.34.1-beta.1",
28
+ "@webiny/handler-db": "5.34.1-beta.1",
29
+ "@webiny/utils": "5.34.1-beta.1",
30
30
  "aws-sdk": "2.1230.0",
31
31
  "dataloader": "2.1.0",
32
32
  "dot-prop": "6.0.1",
@@ -39,9 +39,9 @@
39
39
  "@babel/core": "^7.19.3",
40
40
  "@babel/preset-env": "^7.19.4",
41
41
  "@types/jsonpack": "^1.1.0",
42
- "@webiny/cli": "^5.34.0",
43
- "@webiny/plugins": "^5.34.0",
44
- "@webiny/project-utils": "^5.34.0",
42
+ "@webiny/cli": "^5.34.1-beta.1",
43
+ "@webiny/plugins": "^5.34.1-beta.1",
44
+ "@webiny/project-utils": "^5.34.1-beta.1",
45
45
  "jest": "^28.1.0",
46
46
  "jest-dynalite": "^3.2.0",
47
47
  "jest-environment-node": "^27.2.4",
@@ -56,5 +56,5 @@
56
56
  "build": "yarn webiny run build",
57
57
  "watch": "yarn webiny run watch"
58
58
  },
59
- "gitHead": "16af8737377a9ae1dd6ac4ecffec5625726c814e"
59
+ "gitHead": "29b0835bc90440f6463ab03419a68e7fbead6044"
60
60
  }
@@ -0,0 +1,42 @@
1
+ import { Plugin } from "@webiny/plugins";
2
+ import { Field } from "../operations/entry/filtering/types";
3
+ import { CmsModel } from "@webiny/api-headless-cms/types";
4
+ interface CmsEntryFieldSortingPluginCanUseParams {
5
+ model: CmsModel;
6
+ field?: Field;
7
+ fieldId: string;
8
+ order: "ASC" | "DESC";
9
+ /**
10
+ * Combination of fieldId and sortBy
11
+ *
12
+ * example: id_ASC or createdBy_DESC
13
+ */
14
+ sortBy: string;
15
+ }
16
+ interface CmsEntryFieldSortingPluginCreateSortParams {
17
+ model: CmsModel;
18
+ fieldId: string;
19
+ order: "ASC" | "DESC";
20
+ sortBy: string;
21
+ fields: Record<string, Field>;
22
+ field?: Field;
23
+ }
24
+ interface CmsEntryFieldSortingPluginCreateSortResult {
25
+ valuePath: string;
26
+ reverse: boolean;
27
+ fieldId: string;
28
+ field: Field;
29
+ }
30
+ interface CmsEntryFieldSortingPluginConfig {
31
+ createSort: (params: CmsEntryFieldSortingPluginCreateSortParams) => CmsEntryFieldSortingPluginCreateSortResult;
32
+ canUse: (params: CmsEntryFieldSortingPluginCanUseParams) => boolean;
33
+ }
34
+ export declare class CmsEntryFieldSortingPlugin extends Plugin {
35
+ static readonly type: string;
36
+ private readonly config;
37
+ constructor(config: CmsEntryFieldSortingPluginConfig);
38
+ canUse(params: CmsEntryFieldSortingPluginCanUseParams): boolean;
39
+ createSort(params: CmsEntryFieldSortingPluginCreateSortParams): CmsEntryFieldSortingPluginCreateSortResult;
40
+ }
41
+ export declare const createCmsEntryFieldSortingPlugin: (config: CmsEntryFieldSortingPluginConfig) => CmsEntryFieldSortingPlugin;
42
+ export {};
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createCmsEntryFieldSortingPlugin = exports.CmsEntryFieldSortingPlugin = void 0;
9
+
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+
12
+ var _plugins = require("@webiny/plugins");
13
+
14
+ class CmsEntryFieldSortingPlugin extends _plugins.Plugin {
15
+ constructor(config) {
16
+ super();
17
+ (0, _defineProperty2.default)(this, "config", void 0);
18
+ this.config = config;
19
+ }
20
+
21
+ canUse(params) {
22
+ return this.config.canUse(params);
23
+ }
24
+
25
+ createSort(params) {
26
+ return this.config.createSort(params);
27
+ }
28
+
29
+ }
30
+
31
+ exports.CmsEntryFieldSortingPlugin = CmsEntryFieldSortingPlugin;
32
+ (0, _defineProperty2.default)(CmsEntryFieldSortingPlugin, "type", "cms.entry.field.sorting");
33
+
34
+ const createCmsEntryFieldSortingPlugin = config => {
35
+ return new CmsEntryFieldSortingPlugin(config);
36
+ };
37
+
38
+ exports.createCmsEntryFieldSortingPlugin = createCmsEntryFieldSortingPlugin;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["CmsEntryFieldSortingPlugin","Plugin","constructor","config","canUse","params","createSort","createCmsEntryFieldSortingPlugin"],"sources":["CmsEntryFieldSortingPlugin.ts"],"sourcesContent":["import { Plugin } from \"@webiny/plugins\";\nimport { Field } from \"~/operations/entry/filtering/types\";\nimport { CmsModel } from \"@webiny/api-headless-cms/types\";\n\ninterface CmsEntryFieldSortingPluginCanUseParams {\n model: CmsModel;\n field?: Field;\n fieldId: string;\n order: \"ASC\" | \"DESC\";\n /**\n * Combination of fieldId and sortBy\n *\n * example: id_ASC or createdBy_DESC\n */\n sortBy: string;\n}\n\ninterface CmsEntryFieldSortingPluginCreateSortParams {\n model: CmsModel;\n fieldId: string;\n order: \"ASC\" | \"DESC\";\n sortBy: string;\n fields: Record<string, Field>;\n field?: Field;\n}\n\ninterface CmsEntryFieldSortingPluginCreateSortResult {\n valuePath: string;\n reverse: boolean;\n fieldId: string;\n field: Field;\n}\n\ninterface CmsEntryFieldSortingPluginConfig {\n createSort: (\n params: CmsEntryFieldSortingPluginCreateSortParams\n ) => CmsEntryFieldSortingPluginCreateSortResult;\n canUse: (params: CmsEntryFieldSortingPluginCanUseParams) => boolean;\n}\n\nexport class CmsEntryFieldSortingPlugin extends Plugin {\n public static override readonly type: string = \"cms.entry.field.sorting\";\n private readonly config: CmsEntryFieldSortingPluginConfig;\n\n public constructor(config: CmsEntryFieldSortingPluginConfig) {\n super();\n this.config = config;\n }\n\n public canUse(params: CmsEntryFieldSortingPluginCanUseParams): boolean {\n return this.config.canUse(params);\n }\n\n public createSort(\n params: CmsEntryFieldSortingPluginCreateSortParams\n ): CmsEntryFieldSortingPluginCreateSortResult {\n return this.config.createSort(params);\n }\n}\n\nexport const createCmsEntryFieldSortingPlugin = (config: CmsEntryFieldSortingPluginConfig) => {\n return new CmsEntryFieldSortingPlugin(config);\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AAwCO,MAAMA,0BAAN,SAAyCC,eAAzC,CAAgD;EAI5CC,WAAW,CAACC,MAAD,EAA2C;IACzD;IADyD;IAEzD,KAAKA,MAAL,GAAcA,MAAd;EACH;;EAEMC,MAAM,CAACC,MAAD,EAA0D;IACnE,OAAO,KAAKF,MAAL,CAAYC,MAAZ,CAAmBC,MAAnB,CAAP;EACH;;EAEMC,UAAU,CACbD,MADa,EAE6B;IAC1C,OAAO,KAAKF,MAAL,CAAYG,UAAZ,CAAuBD,MAAvB,CAAP;EACH;;AAjBkD;;;8BAA1CL,0B,UACsC,yB;;AAmB5C,MAAMO,gCAAgC,GAAIJ,MAAD,IAA8C;EAC1F,OAAO,IAAIH,0BAAJ,CAA+BG,MAA/B,CAAP;AACH,CAFM"}
@@ -1 +1,3 @@
1
1
  export * from "./CmsEntryFieldFilterPathPlugin";
2
+ export * from "./CmsEntryFieldSortingPlugin";
3
+ export * from "./CmsEntryFieldFilterPlugin";
package/plugins/index.js CHANGED
@@ -15,4 +15,30 @@ Object.keys(_CmsEntryFieldFilterPathPlugin).forEach(function (key) {
15
15
  return _CmsEntryFieldFilterPathPlugin[key];
16
16
  }
17
17
  });
18
+ });
19
+
20
+ var _CmsEntryFieldSortingPlugin = require("./CmsEntryFieldSortingPlugin");
21
+
22
+ Object.keys(_CmsEntryFieldSortingPlugin).forEach(function (key) {
23
+ if (key === "default" || key === "__esModule") return;
24
+ if (key in exports && exports[key] === _CmsEntryFieldSortingPlugin[key]) return;
25
+ Object.defineProperty(exports, key, {
26
+ enumerable: true,
27
+ get: function () {
28
+ return _CmsEntryFieldSortingPlugin[key];
29
+ }
30
+ });
31
+ });
32
+
33
+ var _CmsEntryFieldFilterPlugin = require("./CmsEntryFieldFilterPlugin");
34
+
35
+ Object.keys(_CmsEntryFieldFilterPlugin).forEach(function (key) {
36
+ if (key === "default" || key === "__esModule") return;
37
+ if (key in exports && exports[key] === _CmsEntryFieldFilterPlugin[key]) return;
38
+ Object.defineProperty(exports, key, {
39
+ enumerable: true,
40
+ get: function () {
41
+ return _CmsEntryFieldFilterPlugin[key];
42
+ }
43
+ });
18
44
  });
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./CmsEntryFieldFilterPathPlugin\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./CmsEntryFieldFilterPathPlugin\";\nexport * from \"./CmsEntryFieldSortingPlugin\";\nexport * from \"./CmsEntryFieldFilterPlugin\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}