@pega/lists-core-utils 9.0.0-build.14.1 → 9.0.0-build.14.10

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.
@@ -1 +1 @@
1
- {"version":3,"file":"PrepareDatapageQuery.d.ts","sourceRoot":"","sources":["../../stateConversion/PrepareDatapageQuery.js"],"names":[],"mappings":"AAwjBA;;;;;;;;;;GAUG;AACH,qDATW,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,aACjB,OAAO,qBACP,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,kBACrC,MAAM,EAAE,kBACR,OAAO,yBACP,OAAO,GACL,YAAY,CAAC,gBAAgB,CAkEzC;AAED;;;;;;GAMG;AACH,sDALW,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,iBAEf,YAAY,CAAC,cAAc,CAsDvC;AA3qBM,wCAHI,YAAY,CAAC,QAAQ,EAAE,GACrB,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC,CAQ9C;AAQM,oCAJI,YAAY,CAAC,QAAQ,EAAE,YACvB,MAAM,GACJ,YAAY,CAAC,QAAQ,GAAG,SAAS,CAK7C;AAUM,yCANI,MAAM,cACN,MAAM,YACN,MAAM,QACN,YAAY,CAAC,IAAI,GACf,YAAY,CAAC,IAAI,CAkB7B;AAOM,yDAHI,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,GACjD;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,EAAE,CAmBlC;AA0DM,uDAHI,YAAY,CAAC,QAAQ,EAAE,GACrB,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,OAAO,+CAA+C,EAAE,aAAa,CAAC,CAAC,CAIhJ;AAcM,uCATI,YAAY,CAAC,QAAQ,EAAE,uFACvB,kBAAkB,GAMhB,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,OAAO,+CAA+C,EAAE,aAAa,CAAC,CAAC,CA2BhJ;AAWM,6CAPI,YAAY,CAAC,KAAK,CAAC,cAAc,CAAC,WAClC,YAAY,CAAC,KAAK,cAClB,YAAY,CAAC,QAAQ,EAAE,YACvB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,aAC5B,OAAO,GACL;IAAE,MAAM,EAAE,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;IAAC,YAAY,EAAE,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAA;CAAE,CA4DlJ;AAEM;;;EAmBN;AAgEM,6CALI,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,kBACjB,OAAO,GACL,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAuF9D;AAQM,mDAJI,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,GACf,UAAU,CAAC,cAAc,sCAAsC,EAAE,kBAAkB,CAAC,CA8BhG;AASM,mDALI,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,aAClD,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC,WAClC,YAAY,CAAC,KAAK,EAAE,GAClB,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CA4DpE;AAyBM,yCALI,MAAM,aACN,MAAM,iBACN,YAAY,CAAC,KAAK,CAAC,cAAc,CAAC,GAChC,YAAY,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAcnD;;;;iCA/ZY;IAAC,gBAAgB,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,cAAc,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC;IAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAAC,OAAO,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;CAAE;6BAhJlL,UAAU"}
1
+ {"version":3,"file":"PrepareDatapageQuery.d.ts","sourceRoot":"","sources":["../../stateConversion/PrepareDatapageQuery.js"],"names":[],"mappings":"AAyjBA;;;;;;;;;;GAUG;AACH,qDATW,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,aACjB,OAAO,qBACP,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,kBACrC,MAAM,EAAE,kBACR,OAAO,yBACP,OAAO,GACL,YAAY,CAAC,gBAAgB,CAkEzC;AAED;;;;;;GAMG;AACH,sDALW,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,iBAEf,YAAY,CAAC,cAAc,CAsDvC;AA3qBM,wCAHI,YAAY,CAAC,QAAQ,EAAE,GACrB,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC,CAQ9C;AAQM,oCAJI,YAAY,CAAC,QAAQ,EAAE,YACvB,MAAM,GACJ,YAAY,CAAC,QAAQ,GAAG,SAAS,CAK7C;AAUM,yCANI,MAAM,cACN,MAAM,YACN,MAAM,QACN,YAAY,CAAC,IAAI,GACf,YAAY,CAAC,IAAI,CAkB7B;AAOM,yDAHI,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,GACjD;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,EAAE,CAmBlC;AA0DM,uDAHI,YAAY,CAAC,QAAQ,EAAE,GACrB,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,OAAO,+CAA+C,EAAE,aAAa,CAAC,CAAC,CAIhJ;AAcM,uCATI,YAAY,CAAC,QAAQ,EAAE,uFACvB,kBAAkB,GAMhB,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,OAAO,+CAA+C,EAAE,aAAa,CAAC,CAAC,CA2BhJ;AAWM,6CAPI,YAAY,CAAC,KAAK,CAAC,cAAc,CAAC,WAClC,YAAY,CAAC,KAAK,cAClB,YAAY,CAAC,QAAQ,EAAE,YACvB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,aAC5B,OAAO,GACL;IAAE,MAAM,EAAE,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;IAAC,YAAY,EAAE,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAA;CAAE,CA4DlJ;AAEM;;;EAmBN;AAgEM,6CALI,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,kBACjB,OAAO,GACL,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAuF9D;AAQM,mDAJI,YAAY,CAAC,KAAK,QAClB,YAAY,CAAC,IAAI,GACf,UAAU,CAAC,cAAc,sCAAsC,EAAE,kBAAkB,CAAC,CA8BhG;AASM,mDALI,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,aAClD,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC,WAClC,YAAY,CAAC,KAAK,EAAE,GAClB,WAAW,CAAC,YAAY,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CA4DpE;AAyBM,yCALI,MAAM,aACN,MAAM,iBACN,YAAY,CAAC,KAAK,CAAC,cAAc,CAAC,GAChC,YAAY,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAcnD;;;;iCA/ZY;IAAC,gBAAgB,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,cAAc,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC;IAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAAC,OAAO,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;CAAE;6BAjJlL,UAAU"}
@@ -3,7 +3,7 @@ import { splitConditionTree, transformComplexCondition } from '@pega/cosmos-reac
3
3
  // eslint-disable-next-line no-unused-vars
4
4
  import { DataApiTypes } from '../types';
5
5
  import { getFormattedFields } from '../dataApi/utils';
6
- import { appendExternalFiltersToFilterExpression, getGroupFromKey, isExternalFiltersExists } from './utils';
6
+ import { appendExternalFiltersToFilterExpression, getGroupFromKey, isExternalFiltersExists, buildAggOrCalcId } from './utils';
7
7
  /**
8
8
  * This method builds a {@link DataApiTypes.FieldDef fields} Map which will be used to get the field based on {@link DataApiTypes.FieldDef.id fieldDef id}
9
9
  * @param {DataApiTypes.FieldDef[]} fieldDefs
@@ -167,7 +167,7 @@ export const buildSortInfo = (sortingOrder, groups, fieldDefs, itemKey, isClient
167
167
  const field = fieldsMap.get(obj.columnId);
168
168
  // Set up a calculation when grouping by a dateFunction
169
169
  if (obj.dateFunction) {
170
- const calcId = `sortBy${field.name.replace(/[-_:]/g, '')}${obj.dateFunction}`;
170
+ const calcId = `sortBy${buildAggOrCalcId(field.name, obj.dateFunction)}`;
171
171
  calculations[calcId] = {
172
172
  function: obj.dateFunction,
173
173
  parameters: [{ field: field.name }]
@@ -1 +1 @@
1
- {"version":3,"file":"PrepareDatapageQuery.js","sourceRoot":"","sources":["../../stateConversion/PrepareDatapageQuery.js"],"names":[],"mappings":"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","sourcesContent":["import {\n splitConditionTree,\n transformComplexCondition\n} from '@pega/cosmos-react-condition-builder';\n\n// This should be converted to \"import type\" once this file is TS.\n// eslint-disable-next-line no-unused-vars\nimport { DataApiTypes } from '../types';\nimport { getFormattedFields } from '../dataApi/utils';\n\nimport {\n appendExternalFiltersToFilterExpression,\n getGroupFromKey,\n isExternalFiltersExists\n} from './utils';\n\n/**\n * This method builds a {@link DataApiTypes.FieldDef fields} Map which will be used to get the field based on {@link DataApiTypes.FieldDef.id fieldDef id}\n * @param {DataApiTypes.FieldDef[]} fieldDefs\n * @returns {Map<string, DataApiTypes.FieldDef>} fields map - key is {@link DataApiTypes.FieldDef.id fieldDef id} and value is {@link DataApiTypes.FieldDef field} object\n */\nexport const getFieldsMap = fieldDefs => {\n const fieldsMap = new Map();\n fieldDefs.forEach(element => {\n fieldsMap.set(element.id, element);\n });\n return fieldsMap;\n};\n\n/**\n * This method used to fetch the FieldDef for a given {@link columnId} from given {@link fieldDefs} array\n * @param {DataApiTypes.FieldDef[]} fieldDefs An array of {@link DataApiTypes.FieldDef fieldDefs} from which a fieldDef need to be filtered.\n * @param {string} columnId A unique {@link DataApiTypes.FieldDef.id fieldId}\n * @returns {DataApiTypes.FieldDef | undefined} FieldDef for a given columnId\n */\nexport const getField = (fieldDefs, columnId) => {\n const fieldsMap = getFieldsMap(fieldDefs);\n return fieldsMap.get(columnId);\n};\n\n/**\n * Returns the correct set of data from bigger set based on the indexes\n * @param {number} newStartIndex newStartIndex\n * @param {number} startIndex existing startIndex\n * @param {number} endIndex endIndex\n * @param {DataApiTypes.Data} data full data\n * @returns {DataApiTypes.Data} sliced data\n */\nexport const sliceData = (newStartIndex, startIndex, endIndex, data) => {\n const slicedData = [];\n if (data && data.length > 0) {\n let index = 0;\n while (newStartIndex <= endIndex) {\n if (newStartIndex >= startIndex) {\n const obj = data[index];\n if (obj) {\n slicedData.push(obj);\n }\n }\n index += 1;\n newStartIndex += 1;\n }\n }\n return slicedData;\n};\n\n/**\n * It returns all the fields that are used in the given {@link filterExpression}\n * @param {NonNullable<DataApiTypes.State['filterExpression']>} filterExpression\n * @returns {{ columnId: string }[]} Fields which are part of {@link filterExpression}\n */\nexport const getFieldListFromFilter = filterExpression => {\n const splitFilter = splitConditionTree(filterExpression);\n const arrFilter = Object.values(splitFilter.conditions);\n\n const filterReferences = [];\n\n // Add in any field references\n arrFilter.forEach(item => {\n if (item.lhs?.field) {\n filterReferences.push({ columnId: item.lhs.field });\n }\n if (item.rhs?.field) {\n filterReferences.push({ columnId: item.rhs.field });\n }\n });\n\n return filterReferences;\n};\n\n/**\n * Checks if a field is visible by determining if it is not part of the hidden columns in the given state.\n *\n * @param {string} fieldName - The name of the field to check.\n * @param {Object} stateFromTable - The state object containing the `hiddenColumns` array.\n * @param {string[]} [stateFromTable.hiddenColumns] - An array of column names that are hidden.\n * @returns {boolean} - Returns `true` if the field is visible (not hidden), otherwise `false`.\n */\n\nconst isFieldVisible = (fieldName, stateFromTable) => {\n return !stateFromTable?.hiddenColumns?.includes(fieldName);\n};\n\n/**\n * Extracts referred fields from the table state, including grouped columns, custom columns, and conditional style formats.\n * @param {Object} stateFromTable - The state object containing table configuration.\n * @returns {string[]} - An array of referred field names (like groups , condition style and custom fields).\n */\nconst getReferredFields = stateFromTable => {\n let groupedColumns = [];\n let customColumnsSource = [];\n let conditionStyleFormatColumns = [];\n\n if (stateFromTable?.groups) {\n groupedColumns = stateFromTable.groups.map(group => group.columnId);\n }\n\n if (stateFromTable?.customFields) {\n customColumnsSource = stateFromTable.customFields.reduce((sources, customField) => {\n return sources.concat(customField.expression.filter(f => typeof f === 'string'));\n }, []);\n }\n\n if (stateFromTable?.conditionalStyleFormats) {\n conditionStyleFormatColumns = stateFromTable.conditionalStyleFormats\n .filter(styleFormat => isFieldVisible(styleFormat.fieldName, stateFromTable))\n .flatMap(styleFormat =>\n getFieldListFromFilter(styleFormat.condition).map(condition => condition.columnId)\n );\n }\n\n return [...new Set([...groupedColumns, ...customColumnsSource, ...conditionStyleFormatColumns])];\n};\n\nconst getOptimizedFieldDefs = (fieldDefs, stateFromTable) => {\n const referredFields = getReferredFields(stateFromTable);\n return fieldDefs.filter(\n field => isFieldVisible(field.name, stateFromTable) || referredFields.includes(field.name)\n );\n};\n\n/**\n * Builds select array from the given field definitions.\n * @param {DataApiTypes.FieldDef[]} explicitFieldDefs - An array of field definitions which should be part of select.\n * @returns {Array<Extract<DataApiTypes.DataViewsQuery['select'][number], import('../stateConversion/PrepareDatapageQuery.types').FieldFragment>>} An array of objects, each containing the field name.\n */\nexport const buildExplicitSelect = explicitFieldDefs => {\n return explicitFieldDefs.map(field => ({ field: field.name }));\n};\n\n/**\n * @typedef {{patchQueryFields?: DataApiTypes.Meta['patchQueryFields'], compositeKeys?: string[], stateFromTable?: DataApiTypes.State, optimizeSelectFields?: boolean, itemKey?: DataApiTypes.Meta['itemKey'] }} BuildSelectOptions\n * It prepares {@link DataApiTypes.DataViewsQuery.select select} clause for a query by considering fieldDefs, patchQueryFields and compositeKeys/itemKey.\n * @param {DataApiTypes.FieldDef[]} fieldDefs Set of fields which should be evaluated to be part of select clause.\n * @param {BuildSelectOptions} options Options object containing additional parameters.\n * @param {DataApiTypes.Meta['patchQueryFields']} [options.patchQueryFields] A set of extra fields which should be included in select clause.\n * @param {string[]} [options.compositeKeys] A set of primary keys which should be included in select clause.This will be considered only if {@link itemKey} is not provided.\n * @param {DataApiTypes.State} [options.stateFromTable] RS state.\n * @param {boolean} [options.optimizeSelectFields] If set to true, buildSelect will include a subset of {@link fieldDefs} which are visible or referred.\n * @param {DataApiTypes.Meta['itemKey']} [options.itemKey] {@link DataApiTypes.Meta.itemKey itemKey} Unique key to be included in select. This will be considered only if {@link compositeKeys} is not provided.\n * @returns {Array<Extract<DataApiTypes.DataViewsQuery['select'][number], import('../stateConversion/PrepareDatapageQuery.types').FieldFragment>>} a select clause of type {@link FieldFragment}\n */\nexport const buildSelect = (\n fieldDefs,\n {\n patchQueryFields = [],\n compositeKeys = [],\n stateFromTable = {},\n optimizeSelectFields = false,\n itemKey\n } = {}\n) => {\n // Filter fieldDefs(only referred and visible fields) if optimizeSelectFields is true.\n if (optimizeSelectFields) {\n fieldDefs = getOptimizedFieldDefs(fieldDefs, stateFromTable);\n }\n const fieldDefsSelectFields = fieldDefs.map(field => field.name);\n let uniqueKeysSelectFields = [];\n if (compositeKeys.length) {\n uniqueKeysSelectFields = compositeKeys;\n } else if (itemKey) {\n uniqueKeysSelectFields = [itemKey];\n }\n\n return Array.from(\n new Set([...fieldDefsSelectFields, ...patchQueryFields, ...uniqueKeysSelectFields])\n ).map(field => ({ field }));\n};\n\n/**\n * It prepares {@link DataApiTypes.DataViewsQuery.sortBy sortBy} clause and {@link DataApiTypes.DataViewsQuery.calculations calculations} clause(for date type fields) for a query.\n * @param {DataApiTypes.State['sortingOrder']} [sortingOrder] Sorting information\n * @param {DataApiTypes.Group} [groups] grouping information\n * @param {DataApiTypes.FieldDef[]} [fieldDefs] Set of fields\n * @param {DataApiTypes.Meta['itemKey']} [itemKey] {@link DataApiTypes.Meta.itemKey itemKey}\n * @param {boolean} [isClient] A flag to know if the sorting info is required client side query\n * @returns {{ sortBy: NonNullable<DataApiTypes.DataViewsQuery['sortBy']>, calculations: NonNullable<DataApiTypes.DataViewsQuery['calculations']> }} {@link DataApiTypes.DataViewsQuery.sortBy sortBy} clause and {@link DataApiTypes.DataViewsQuery.calculations calculations} clause(for date type fields)\n */\nexport const buildSortInfo = (sortingOrder, groups, fieldDefs, itemKey, isClient) => {\n const fieldsMap = getFieldsMap(fieldDefs);\n const sortBy = [];\n const calculations = {};\n const sortedSet = new Set();\n if (groups) {\n // Sort by any groups before applying other sort options\n // Otherwise, the rows can appear in the wrong groups\n groups.forEach(obj => {\n // get field object corresponding to the columnId\n const field = fieldsMap.get(obj.columnId);\n\n // Set up a calculation when grouping by a dateFunction\n if (obj.dateFunction) {\n const calcId = `sortBy${field.name.replace(/[-_:]/g, '')}${obj.dateFunction}`;\n calculations[calcId] = {\n function: obj.dateFunction,\n parameters: [{ field: field.name }]\n };\n if (obj.dateFunction === 'DAYS_OF_WEEK') {\n // Currently, the cosmos control always assumes Monday as the start of week.\n // Specify the same to the API\n calculations[calcId].parameters.push({ value: '2' });\n }\n sortBy.push({\n calculation: calcId,\n type: obj.order.toUpperCase()\n });\n } else {\n sortBy.push({\n field: field.name,\n type: obj.order.toUpperCase()\n });\n sortedSet.add(field.id);\n }\n });\n }\n\n // Add remaining sorts\n if (sortingOrder) {\n sortingOrder.forEach(obj => {\n if (!sortedSet.has(obj.columnId)) {\n const field = fieldsMap.get(obj.columnId);\n sortBy.push({\n field: field.name,\n type: obj.order.toUpperCase()\n });\n sortedSet.add(field.id);\n }\n });\n } else if (!isClient && groups && groups.length > 0 && itemKey && !sortedSet.has(itemKey)) {\n sortBy.push({\n field: itemKey,\n type: 'ASC'\n });\n }\n\n return { sortBy, calculations: Object.keys(calculations).length > 0 ? calculations : undefined };\n};\n\nexport const calculatePageMetrics = (sIndex, eIndex) => {\n let n = eIndex - sIndex + 1;\n let pageSize = 1;\n\n if (n > 1) {\n let sRemainder = sIndex % n;\n let eRemainder = eIndex % n;\n\n while (eRemainder < sRemainder) {\n n += 1;\n sRemainder = sIndex % n;\n eRemainder = eIndex % n;\n }\n\n pageSize = n;\n }\n\n const pageNumber = Math.floor(sIndex / pageSize) + 1;\n return { pageNumber, pageSize };\n};\nconst getSearchFilters = (searchObj, contains) => {\n const { fields, query } = searchObj;\n return fields.map(field => ({\n condition: {\n comparator: contains,\n lhs: { field },\n rhs: { value: query }\n }\n }));\n};\n\n/**\n * Transforms a LeafCondition from the ConditionBuilder to the structure expected by the DataViews API\n * NOTE: Mutates the condition in-place\n */\nconst transformConditionForDataApi = (condition, conditionKey, meta, calculations) => {\n const field = meta.fieldDefs.find(f => f.name === condition.lhs.field);\n\n // Note: Workaround to include ignoreCase prop. It should eventually be coming from condition builder\n // Note: excluding pzInsKey as a workaround for BUG-606364\n // filter condition might be on a field which is not part of fieldDefs. This can be possible in case of external filters.\n if (field && field.type === 'text' && field.name !== 'pzInsKey') {\n condition.ignoreCase = true;\n }\n\n // Transform rhs date functions as calculations\n if (condition.rhs?.dateFunction) {\n const calculationId = `${conditionKey}_date_function_${Date.now()}`; // Using `Date.now()` to avoid any rare conflicts\n const lhsFieldName = condition.lhs.field;\n const { dateFunction } = condition.rhs;\n\n // Set up a new calculation on the query\n calculations[calculationId] = {\n function: dateFunction,\n parameters: [{ field: lhsFieldName }]\n };\n if (dateFunction === 'DAYS_OF_WEEK') {\n // Currently, the cosmos control always assumes Monday as the start of week.\n // Specify the same to the API\n calculations[calculationId].parameters.push({ value: '2' });\n }\n\n // Refer the calculation from the condition\n condition.lhs = { calculation: calculationId };\n condition.rhs.value = condition.rhs.value.toString();\n delete condition.rhs.dateFunction;\n }\n\n if (field && field.type === 'time' && condition.rhs && typeof condition.rhs.value === 'number') {\n const date = new Date(condition.rhs.value);\n condition.rhs = {\n value: `${String(date.getUTCHours()).padStart(2, '0')}:${String(date.getUTCMinutes()).padStart(2, '0')}:${String(date.getUTCSeconds()).padStart(2, '0')}`\n };\n }\n};\n\n/**\n * It prepares the {@link DataApiTypes.DataViewsQuery.filter filter} clause in the query.\n * @param {DataApiTypes.State} stateFromTable A state object to get current {@link DataApiTypes.State.filterExpression filterExpression}, {@link DataApiTypes.State.groupFilters groupFilters}, {@link DataApiTypes.State.search search}, {@link DataApiTypes.State.groups groups}, {@link DataApiTypes.State.externalState externalState} filters\n * @param {DataApiTypes.Meta} meta A metadata object to extract fieldDefs\n * @param {boolean} [includeGroups] Set to true if group filters need to be included\n * @returns {NonNullable<DataApiTypes.DataViewsQuery['filter']>} {@link DataApiTypes.DataViewsQuery.filter filter}\n */\nexport const buildFilters = (stateFromTable, meta, includeGroups = false) => {\n const { filterExpression, groupFilters, search, groups } = stateFromTable;\n const searchQuery = search?.query;\n const {\n fieldDefs,\n comparatorMap: { contains, equals, isNull }\n } = meta;\n let finalFilters = filterExpression;\n const { externalFilters } = meta;\n if (isExternalFiltersExists(externalFilters, stateFromTable)) {\n finalFilters = appendExternalFiltersToFilterExpression(\n externalFilters,\n finalFilters,\n stateFromTable\n );\n }\n\n if (finalFilters) {\n finalFilters = transformComplexCondition(finalFilters, getFormattedFields(fieldDefs));\n }\n\n // Append search filters\n if (searchQuery) {\n const filters = getSearchFilters(search, contains);\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, { OR: filters }] };\n } else {\n finalFilters = { OR: filters };\n }\n }\n\n // Append group filters\n if (includeGroups && groupFilters && groupFilters.length > 0) {\n let finalGroupFilters = [];\n const fieldsMap = getFieldsMap(fieldDefs);\n groupFilters.forEach(obj => {\n const { filters } = obj;\n const newGroupFilters = [];\n Object.entries(filters).forEach(([groupBy, value]) => {\n const { columnId, dateFunction } = getGroupFromKey(groupBy, groups);\n const field = fieldsMap.get(columnId);\n\n const condition = { lhs: { field: field.name } };\n if (value === null || value === undefined) {\n condition.comparator = isNull;\n } else {\n condition.comparator = equals;\n condition.rhs = { value, dateFunction };\n }\n\n newGroupFilters.push({ condition });\n });\n finalGroupFilters.push({ AND: newGroupFilters });\n });\n\n let groupFiltersLogic;\n if (finalGroupFilters.length === 1) {\n finalGroupFilters = [].concat(finalGroupFilters[0].AND);\n groupFiltersLogic = { AND: finalGroupFilters };\n } else {\n groupFiltersLogic = { OR: finalGroupFilters };\n }\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, groupFiltersLogic] };\n } else {\n finalFilters = groupFiltersLogic;\n }\n }\n\n // Transform the ConditionBuilder structure to the DataViews structure\n const calculations = {}; // Any calculations resulting from date functions\n if (finalFilters) {\n finalFilters = JSON.parse(JSON.stringify(finalFilters)); // Cloning to avoid editing the original objects\n finalFilters = splitConditionTree(finalFilters, 'T');\n Object.entries(finalFilters.conditions).forEach(([key, condition]) => {\n transformConditionForDataApi(condition, key, meta, calculations);\n });\n }\n\n return {\n filterTree: finalFilters,\n calculations: Object.keys(calculations).length > 0 ? calculations : undefined // Don't return empty objects to avoid any API validation errors\n };\n};\n\n/**\n * It prepares the client filters\n * @param {DataApiTypes.State} stateFromTable A state object to get current {@link DataApiTypes.State.filterExpression filterExpression}, {@link DataApiTypes.State.search search}, {@link DataApiTypes.State.externalState externalState} filters\n * @param {DataApiTypes.Meta} meta A metadata object to extract fieldDefs\n * @returns {ReturnType<typeof import('@pega/cosmos-react-condition-builder').splitConditionTree>}\n */\nexport const buildClientFilters = (stateFromTable, meta) => {\n const { filterExpression, search } = stateFromTable;\n const searchQuery = search?.query;\n const {\n comparatorMap: { contains }\n } = meta;\n\n // Append search filters\n let finalFilters = filterExpression;\n const { externalFilters } = meta;\n if (isExternalFiltersExists(externalFilters, stateFromTable)) {\n finalFilters = appendExternalFiltersToFilterExpression(\n externalFilters,\n finalFilters,\n stateFromTable\n );\n }\n if (searchQuery) {\n const filters = getSearchFilters(search, contains);\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, { OR: filters }] };\n } else {\n finalFilters = { OR: filters };\n }\n }\n\n return finalFilters ? splitConditionTree(finalFilters) : finalFilters;\n};\n\n/**\n * It build {@link DataApiTypes.DataViewsQuery.aggregations aggregations} clause in query.\n * @param {NonNullable<DataApiTypes.State['aggregationInfo']>} aggregationInfo Current aggregations applied in the state\n * @param {Map<string, DataApiTypes.FieldDef>} fieldsMap A map with key {@link DataApiTypes.FieldDef.id fieldDef id} and value {@link DataApiTypes.FieldDef field} object\n * @param {DataApiTypes.Group[]} [groups] grouping information\n * @returns {NonNullable<DataApiTypes.DataViewsQuery['aggregations']>} {@link DataApiTypes.DataViewsQuery.aggregations aggregations}\n */\nexport const buildAggregations = (aggregationInfo, fieldsMap, groups) => {\n const aggregations = {};\n aggregationInfo.forEach(element => {\n const { columnId, type } = element;\n const field = fieldsMap.get(columnId);\n\n const summaryFunction = type.toUpperCase();\n\n // build aggregations\n const agg = `${columnId}${summaryFunction}`;\n aggregations[agg] = {\n field: field.name,\n summaryFunction\n };\n });\n\n // Add aggregations for grouped additional fields.\n groups?.forEach(group => {\n group.additionalFields?.forEach(additionalField => {\n const { id: fieldId, aggregation } = additionalField;\n const field = fieldsMap.get(fieldId);\n if (!field) {\n return;\n }\n\n // TODO: Handle for date functions for Date type fields.\n // If field type is number and aggregation is defined then add that aggregation.\n if (aggregation && field.type === 'number') {\n const aggregate = `${field.name}${aggregation.toUpperCase()}`;\n if (!aggregations[aggregate]) {\n aggregations[aggregate] = {\n field: field.name,\n summaryFunction: aggregation.toUpperCase()\n };\n }\n } else {\n // Else add MAX and distinctCOUNT aggregation.\n const maxAggregate = `${field.name}MAX`;\n const countAggregate = `${field.name}distinctCOUNT`;\n\n if (!aggregations[maxAggregate]) {\n aggregations[maxAggregate] = {\n field: field.name,\n summaryFunction: 'MAX'\n };\n }\n\n if (!aggregations[countAggregate]) {\n aggregations[countAggregate] = {\n field: field.name,\n summaryFunction: 'distinctCOUNT'\n };\n }\n }\n });\n });\n\n return aggregations;\n};\n\n// without grouping, startIndex and endIndex are both inclusive\nfunction prepareGroupDataIndexes(groupFilters, sIndex, eIndex) {\n let startIndex = sIndex;\n let endIndex = eIndex;\n if (groupFilters && groupFilters.length > 0) {\n startIndex = groupFilters[0].groupFrom;\n endIndex = 0;\n groupFilters.forEach(filter => {\n endIndex += filter.groupTo;\n });\n // with grouping, initially endIndex is not inclusive. So, update endIndex to keep the correct count of requested records\n endIndex -= 1;\n }\n return [startIndex, endIndex];\n}\n\n/**\n * It returns the paging information that will be used in query and parsing response data from API\n * @param {number} [startIndex] pagination startIndex\n * @param {number} [endIndex] pagination endIndex\n * @param {DataApiTypes.State['groupFilters']} [groupFilters] An array of {@link DataApiTypes.State.groupFilters GroupFilter}\n * @returns {DataApiTypes.DataViewsRequest['paging']} {@link DataApiTypes.DataViewsRequest.paging paging}\n */\nexport const buildPaging = (startIndex, endIndex, groupFilters) => {\n const [sIndex, eIndex] = prepareGroupDataIndexes(groupFilters, startIndex, endIndex);\n const { pageNumber, pageSize } = calculatePageMetrics(sIndex, eIndex);\n // When sIndex is 0, the starting index of new data should be considered from 0 only.\n const newStartIndex = sIndex === 0 ? 0 : pageSize * pageNumber - pageSize;\n return {\n pageNumber,\n pageSize,\n newStartIndex,\n startIndex: sIndex,\n endIndex: eIndex\n };\n};\n\n/**\n * It prepares {@link DataApiTypes.DataViewsRequest dataViewsRequest} that can be used to interact with pega-ui-lists-data-apis or data view api's\n * @param {DataApiTypes.State} stateFromTable Current state object\n * @param {DataApiTypes.Meta} meta Metadata structure\n * @param {boolean} [isClient] The query is being prepared to interact with pega-ui-lists-data-apis or data view api's\n * @param {DataApiTypes.Meta['patchQueryFields']} [patchQueryFields] A set of extra fields that should be appended in query\n * @param {string[]} [compositeKeys] A set of primary fields that should be appended in query\n * @param {boolean} [includeGroups] Groups should be included or not in the query\n * @param {boolean} [optimizeSelectFields] Whether the query should be optimized to only include fields that are visible(means it should not be part of {@link DataApiTypes.State.hiddenColumns hidden}) or which are part of {@link DataApiTypes.State.groups groups}, {@link DataApiTypes.State.filterExpression filters}, {@link DataApiTypes.State.sortingOrder sort}\n * @returns {DataApiTypes.DataViewsRequest} {@link DataApiTypes.DataViewsRequest dataViewsRequest}\n */\nexport function prepareDatapageQuery(\n stateFromTable,\n meta,\n isClient = false,\n patchQueryFields = [],\n compositeKeys = [],\n includeGroups = true,\n optimizeSelectFields = false\n) {\n const {\n paginationOptions: {\n rootVirtualiser: { startIndex, endIndex }\n },\n sortingOrder,\n groups,\n groupFilters\n } = stateFromTable;\n\n const { fieldDefs, itemKey } = meta;\n const paging = buildPaging(startIndex, endIndex, groupFilters);\n\n /* In case of WorkLink patch query with pyID and in association patch pzInsKey, pyID */\n const select = buildSelect(fieldDefs, {\n patchQueryFields,\n compositeKeys,\n stateFromTable,\n optimizeSelectFields,\n itemKey\n });\n\n const { sortBy, calculations: sortCalculations } = buildSortInfo(\n sortingOrder,\n groups,\n fieldDefs,\n itemKey,\n isClient\n );\n\n let query;\n if (select && select.length > 0) {\n query = {};\n query.select = select;\n if (sortBy && sortBy.length > 0) {\n query.sortBy = sortBy;\n }\n const { filterTree, calculations: filterCalculations } = buildFilters(\n stateFromTable,\n meta,\n includeGroups\n );\n if (filterTree && Object.keys(filterTree).length > 0) {\n query.filter = {\n logic: filterTree.logic,\n filterConditions: filterTree.conditions\n };\n }\n if (sortCalculations || filterCalculations) {\n query.calculations = { ...sortCalculations, ...filterCalculations };\n }\n query = { query, paging };\n }\n\n // console.log(query);\n return query;\n}\n\n/**\n * It prepares clientApi query used to interact with pega-ui-list-data-apis.\n * @param {DataApiTypes.State} stateFromTable Current state object\n * @param {DataApiTypes.Meta} meta Metadata structure\n * @param {boolean} [options.optimizeSelectFields] Whether to optimize select fields. Defaults to `meta?.isAnalyticsTable && meta?.isListViewOrListPage`.\n * @returns {DataApiTypes.ClientApiQuery} {@link DataApiTypes.ClientApiQuery clientApiQuery}\n */\nexport function prepareClientApiQuery(stateFromTable, meta, options = {}) {\n const { groupFilters, groups, aggregationInfo } = stateFromTable;\n\n const optimizeSelectFields =\n options.optimizeSelectFields ?? (meta?.isAnalyticsTable && meta?.isListViewOrListPage);\n\n const queryState = prepareDatapageQuery(\n stateFromTable,\n meta,\n true,\n [],\n [],\n true,\n optimizeSelectFields\n );\n if (groups) {\n const groupBy = [];\n groups.forEach(group => {\n groupBy.push({\n field: group.columnId,\n dateFunction: group.dateFunction,\n sortType: group.order\n });\n });\n queryState.query.groupBy = groupBy;\n }\n if (queryState.query.filter && Object.keys(queryState.query.filter).length > 0) {\n // Reconstruct without group filters. Also don't transform for the API, since the filters need to be passed to evaluateCondition\n queryState.query.filter = {};\n const filterTree = buildClientFilters(stateFromTable, meta);\n if (filterTree && Object.keys(filterTree).length > 0) {\n queryState.query.filter = {\n logic: filterTree.logic,\n filterConditions: filterTree.conditions\n };\n }\n }\n\n if (groupFilters && groupFilters.length > 0) {\n queryState.query.groupFilters = groupFilters;\n }\n\n if ((aggregationInfo && aggregationInfo.length > 0) || options.includeGroupAdditionalFields) {\n const fieldsMap = getFieldsMap(meta.fieldDefs);\n queryState.query.aggregations = buildAggregations(\n aggregationInfo,\n fieldsMap,\n options.includeGroupAdditionalFields ? groups : []\n );\n }\n\n return queryState;\n}\n"]}
1
+ {"version":3,"file":"PrepareDatapageQuery.js","sourceRoot":"","sources":["../../stateConversion/PrepareDatapageQuery.js"],"names":[],"mappings":"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","sourcesContent":["import {\n splitConditionTree,\n transformComplexCondition\n} from '@pega/cosmos-react-condition-builder';\n\n// This should be converted to \"import type\" once this file is TS.\n// eslint-disable-next-line no-unused-vars\nimport { DataApiTypes } from '../types';\nimport { getFormattedFields } from '../dataApi/utils';\n\nimport {\n appendExternalFiltersToFilterExpression,\n getGroupFromKey,\n isExternalFiltersExists,\n buildAggOrCalcId\n} from './utils';\n\n/**\n * This method builds a {@link DataApiTypes.FieldDef fields} Map which will be used to get the field based on {@link DataApiTypes.FieldDef.id fieldDef id}\n * @param {DataApiTypes.FieldDef[]} fieldDefs\n * @returns {Map<string, DataApiTypes.FieldDef>} fields map - key is {@link DataApiTypes.FieldDef.id fieldDef id} and value is {@link DataApiTypes.FieldDef field} object\n */\nexport const getFieldsMap = fieldDefs => {\n const fieldsMap = new Map();\n fieldDefs.forEach(element => {\n fieldsMap.set(element.id, element);\n });\n return fieldsMap;\n};\n\n/**\n * This method used to fetch the FieldDef for a given {@link columnId} from given {@link fieldDefs} array\n * @param {DataApiTypes.FieldDef[]} fieldDefs An array of {@link DataApiTypes.FieldDef fieldDefs} from which a fieldDef need to be filtered.\n * @param {string} columnId A unique {@link DataApiTypes.FieldDef.id fieldId}\n * @returns {DataApiTypes.FieldDef | undefined} FieldDef for a given columnId\n */\nexport const getField = (fieldDefs, columnId) => {\n const fieldsMap = getFieldsMap(fieldDefs);\n return fieldsMap.get(columnId);\n};\n\n/**\n * Returns the correct set of data from bigger set based on the indexes\n * @param {number} newStartIndex newStartIndex\n * @param {number} startIndex existing startIndex\n * @param {number} endIndex endIndex\n * @param {DataApiTypes.Data} data full data\n * @returns {DataApiTypes.Data} sliced data\n */\nexport const sliceData = (newStartIndex, startIndex, endIndex, data) => {\n const slicedData = [];\n if (data && data.length > 0) {\n let index = 0;\n while (newStartIndex <= endIndex) {\n if (newStartIndex >= startIndex) {\n const obj = data[index];\n if (obj) {\n slicedData.push(obj);\n }\n }\n index += 1;\n newStartIndex += 1;\n }\n }\n return slicedData;\n};\n\n/**\n * It returns all the fields that are used in the given {@link filterExpression}\n * @param {NonNullable<DataApiTypes.State['filterExpression']>} filterExpression\n * @returns {{ columnId: string }[]} Fields which are part of {@link filterExpression}\n */\nexport const getFieldListFromFilter = filterExpression => {\n const splitFilter = splitConditionTree(filterExpression);\n const arrFilter = Object.values(splitFilter.conditions);\n\n const filterReferences = [];\n\n // Add in any field references\n arrFilter.forEach(item => {\n if (item.lhs?.field) {\n filterReferences.push({ columnId: item.lhs.field });\n }\n if (item.rhs?.field) {\n filterReferences.push({ columnId: item.rhs.field });\n }\n });\n\n return filterReferences;\n};\n\n/**\n * Checks if a field is visible by determining if it is not part of the hidden columns in the given state.\n *\n * @param {string} fieldName - The name of the field to check.\n * @param {Object} stateFromTable - The state object containing the `hiddenColumns` array.\n * @param {string[]} [stateFromTable.hiddenColumns] - An array of column names that are hidden.\n * @returns {boolean} - Returns `true` if the field is visible (not hidden), otherwise `false`.\n */\n\nconst isFieldVisible = (fieldName, stateFromTable) => {\n return !stateFromTable?.hiddenColumns?.includes(fieldName);\n};\n\n/**\n * Extracts referred fields from the table state, including grouped columns, custom columns, and conditional style formats.\n * @param {Object} stateFromTable - The state object containing table configuration.\n * @returns {string[]} - An array of referred field names (like groups , condition style and custom fields).\n */\nconst getReferredFields = stateFromTable => {\n let groupedColumns = [];\n let customColumnsSource = [];\n let conditionStyleFormatColumns = [];\n\n if (stateFromTable?.groups) {\n groupedColumns = stateFromTable.groups.map(group => group.columnId);\n }\n\n if (stateFromTable?.customFields) {\n customColumnsSource = stateFromTable.customFields.reduce((sources, customField) => {\n return sources.concat(customField.expression.filter(f => typeof f === 'string'));\n }, []);\n }\n\n if (stateFromTable?.conditionalStyleFormats) {\n conditionStyleFormatColumns = stateFromTable.conditionalStyleFormats\n .filter(styleFormat => isFieldVisible(styleFormat.fieldName, stateFromTable))\n .flatMap(styleFormat =>\n getFieldListFromFilter(styleFormat.condition).map(condition => condition.columnId)\n );\n }\n\n return [...new Set([...groupedColumns, ...customColumnsSource, ...conditionStyleFormatColumns])];\n};\n\nconst getOptimizedFieldDefs = (fieldDefs, stateFromTable) => {\n const referredFields = getReferredFields(stateFromTable);\n return fieldDefs.filter(\n field => isFieldVisible(field.name, stateFromTable) || referredFields.includes(field.name)\n );\n};\n\n/**\n * Builds select array from the given field definitions.\n * @param {DataApiTypes.FieldDef[]} explicitFieldDefs - An array of field definitions which should be part of select.\n * @returns {Array<Extract<DataApiTypes.DataViewsQuery['select'][number], import('../stateConversion/PrepareDatapageQuery.types').FieldFragment>>} An array of objects, each containing the field name.\n */\nexport const buildExplicitSelect = explicitFieldDefs => {\n return explicitFieldDefs.map(field => ({ field: field.name }));\n};\n\n/**\n * @typedef {{patchQueryFields?: DataApiTypes.Meta['patchQueryFields'], compositeKeys?: string[], stateFromTable?: DataApiTypes.State, optimizeSelectFields?: boolean, itemKey?: DataApiTypes.Meta['itemKey'] }} BuildSelectOptions\n * It prepares {@link DataApiTypes.DataViewsQuery.select select} clause for a query by considering fieldDefs, patchQueryFields and compositeKeys/itemKey.\n * @param {DataApiTypes.FieldDef[]} fieldDefs Set of fields which should be evaluated to be part of select clause.\n * @param {BuildSelectOptions} options Options object containing additional parameters.\n * @param {DataApiTypes.Meta['patchQueryFields']} [options.patchQueryFields] A set of extra fields which should be included in select clause.\n * @param {string[]} [options.compositeKeys] A set of primary keys which should be included in select clause.This will be considered only if {@link itemKey} is not provided.\n * @param {DataApiTypes.State} [options.stateFromTable] RS state.\n * @param {boolean} [options.optimizeSelectFields] If set to true, buildSelect will include a subset of {@link fieldDefs} which are visible or referred.\n * @param {DataApiTypes.Meta['itemKey']} [options.itemKey] {@link DataApiTypes.Meta.itemKey itemKey} Unique key to be included in select. This will be considered only if {@link compositeKeys} is not provided.\n * @returns {Array<Extract<DataApiTypes.DataViewsQuery['select'][number], import('../stateConversion/PrepareDatapageQuery.types').FieldFragment>>} a select clause of type {@link FieldFragment}\n */\nexport const buildSelect = (\n fieldDefs,\n {\n patchQueryFields = [],\n compositeKeys = [],\n stateFromTable = {},\n optimizeSelectFields = false,\n itemKey\n } = {}\n) => {\n // Filter fieldDefs(only referred and visible fields) if optimizeSelectFields is true.\n if (optimizeSelectFields) {\n fieldDefs = getOptimizedFieldDefs(fieldDefs, stateFromTable);\n }\n const fieldDefsSelectFields = fieldDefs.map(field => field.name);\n let uniqueKeysSelectFields = [];\n if (compositeKeys.length) {\n uniqueKeysSelectFields = compositeKeys;\n } else if (itemKey) {\n uniqueKeysSelectFields = [itemKey];\n }\n\n return Array.from(\n new Set([...fieldDefsSelectFields, ...patchQueryFields, ...uniqueKeysSelectFields])\n ).map(field => ({ field }));\n};\n\n/**\n * It prepares {@link DataApiTypes.DataViewsQuery.sortBy sortBy} clause and {@link DataApiTypes.DataViewsQuery.calculations calculations} clause(for date type fields) for a query.\n * @param {DataApiTypes.State['sortingOrder']} [sortingOrder] Sorting information\n * @param {DataApiTypes.Group} [groups] grouping information\n * @param {DataApiTypes.FieldDef[]} [fieldDefs] Set of fields\n * @param {DataApiTypes.Meta['itemKey']} [itemKey] {@link DataApiTypes.Meta.itemKey itemKey}\n * @param {boolean} [isClient] A flag to know if the sorting info is required client side query\n * @returns {{ sortBy: NonNullable<DataApiTypes.DataViewsQuery['sortBy']>, calculations: NonNullable<DataApiTypes.DataViewsQuery['calculations']> }} {@link DataApiTypes.DataViewsQuery.sortBy sortBy} clause and {@link DataApiTypes.DataViewsQuery.calculations calculations} clause(for date type fields)\n */\nexport const buildSortInfo = (sortingOrder, groups, fieldDefs, itemKey, isClient) => {\n const fieldsMap = getFieldsMap(fieldDefs);\n const sortBy = [];\n const calculations = {};\n const sortedSet = new Set();\n if (groups) {\n // Sort by any groups before applying other sort options\n // Otherwise, the rows can appear in the wrong groups\n groups.forEach(obj => {\n // get field object corresponding to the columnId\n const field = fieldsMap.get(obj.columnId);\n\n // Set up a calculation when grouping by a dateFunction\n if (obj.dateFunction) {\n const calcId = `sortBy${buildAggOrCalcId(field.name, obj.dateFunction)}`;\n calculations[calcId] = {\n function: obj.dateFunction,\n parameters: [{ field: field.name }]\n };\n if (obj.dateFunction === 'DAYS_OF_WEEK') {\n // Currently, the cosmos control always assumes Monday as the start of week.\n // Specify the same to the API\n calculations[calcId].parameters.push({ value: '2' });\n }\n sortBy.push({\n calculation: calcId,\n type: obj.order.toUpperCase()\n });\n } else {\n sortBy.push({\n field: field.name,\n type: obj.order.toUpperCase()\n });\n sortedSet.add(field.id);\n }\n });\n }\n\n // Add remaining sorts\n if (sortingOrder) {\n sortingOrder.forEach(obj => {\n if (!sortedSet.has(obj.columnId)) {\n const field = fieldsMap.get(obj.columnId);\n sortBy.push({\n field: field.name,\n type: obj.order.toUpperCase()\n });\n sortedSet.add(field.id);\n }\n });\n } else if (!isClient && groups && groups.length > 0 && itemKey && !sortedSet.has(itemKey)) {\n sortBy.push({\n field: itemKey,\n type: 'ASC'\n });\n }\n\n return { sortBy, calculations: Object.keys(calculations).length > 0 ? calculations : undefined };\n};\n\nexport const calculatePageMetrics = (sIndex, eIndex) => {\n let n = eIndex - sIndex + 1;\n let pageSize = 1;\n\n if (n > 1) {\n let sRemainder = sIndex % n;\n let eRemainder = eIndex % n;\n\n while (eRemainder < sRemainder) {\n n += 1;\n sRemainder = sIndex % n;\n eRemainder = eIndex % n;\n }\n\n pageSize = n;\n }\n\n const pageNumber = Math.floor(sIndex / pageSize) + 1;\n return { pageNumber, pageSize };\n};\nconst getSearchFilters = (searchObj, contains) => {\n const { fields, query } = searchObj;\n return fields.map(field => ({\n condition: {\n comparator: contains,\n lhs: { field },\n rhs: { value: query }\n }\n }));\n};\n\n/**\n * Transforms a LeafCondition from the ConditionBuilder to the structure expected by the DataViews API\n * NOTE: Mutates the condition in-place\n */\nconst transformConditionForDataApi = (condition, conditionKey, meta, calculations) => {\n const field = meta.fieldDefs.find(f => f.name === condition.lhs.field);\n\n // Note: Workaround to include ignoreCase prop. It should eventually be coming from condition builder\n // Note: excluding pzInsKey as a workaround for BUG-606364\n // filter condition might be on a field which is not part of fieldDefs. This can be possible in case of external filters.\n if (field && field.type === 'text' && field.name !== 'pzInsKey') {\n condition.ignoreCase = true;\n }\n\n // Transform rhs date functions as calculations\n if (condition.rhs?.dateFunction) {\n const calculationId = `${conditionKey}_date_function_${Date.now()}`; // Using `Date.now()` to avoid any rare conflicts\n const lhsFieldName = condition.lhs.field;\n const { dateFunction } = condition.rhs;\n\n // Set up a new calculation on the query\n calculations[calculationId] = {\n function: dateFunction,\n parameters: [{ field: lhsFieldName }]\n };\n if (dateFunction === 'DAYS_OF_WEEK') {\n // Currently, the cosmos control always assumes Monday as the start of week.\n // Specify the same to the API\n calculations[calculationId].parameters.push({ value: '2' });\n }\n\n // Refer the calculation from the condition\n condition.lhs = { calculation: calculationId };\n condition.rhs.value = condition.rhs.value.toString();\n delete condition.rhs.dateFunction;\n }\n\n if (field && field.type === 'time' && condition.rhs && typeof condition.rhs.value === 'number') {\n const date = new Date(condition.rhs.value);\n condition.rhs = {\n value: `${String(date.getUTCHours()).padStart(2, '0')}:${String(date.getUTCMinutes()).padStart(2, '0')}:${String(date.getUTCSeconds()).padStart(2, '0')}`\n };\n }\n};\n\n/**\n * It prepares the {@link DataApiTypes.DataViewsQuery.filter filter} clause in the query.\n * @param {DataApiTypes.State} stateFromTable A state object to get current {@link DataApiTypes.State.filterExpression filterExpression}, {@link DataApiTypes.State.groupFilters groupFilters}, {@link DataApiTypes.State.search search}, {@link DataApiTypes.State.groups groups}, {@link DataApiTypes.State.externalState externalState} filters\n * @param {DataApiTypes.Meta} meta A metadata object to extract fieldDefs\n * @param {boolean} [includeGroups] Set to true if group filters need to be included\n * @returns {NonNullable<DataApiTypes.DataViewsQuery['filter']>} {@link DataApiTypes.DataViewsQuery.filter filter}\n */\nexport const buildFilters = (stateFromTable, meta, includeGroups = false) => {\n const { filterExpression, groupFilters, search, groups } = stateFromTable;\n const searchQuery = search?.query;\n const {\n fieldDefs,\n comparatorMap: { contains, equals, isNull }\n } = meta;\n let finalFilters = filterExpression;\n const { externalFilters } = meta;\n if (isExternalFiltersExists(externalFilters, stateFromTable)) {\n finalFilters = appendExternalFiltersToFilterExpression(\n externalFilters,\n finalFilters,\n stateFromTable\n );\n }\n\n if (finalFilters) {\n finalFilters = transformComplexCondition(finalFilters, getFormattedFields(fieldDefs));\n }\n\n // Append search filters\n if (searchQuery) {\n const filters = getSearchFilters(search, contains);\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, { OR: filters }] };\n } else {\n finalFilters = { OR: filters };\n }\n }\n\n // Append group filters\n if (includeGroups && groupFilters && groupFilters.length > 0) {\n let finalGroupFilters = [];\n const fieldsMap = getFieldsMap(fieldDefs);\n groupFilters.forEach(obj => {\n const { filters } = obj;\n const newGroupFilters = [];\n Object.entries(filters).forEach(([groupBy, value]) => {\n const { columnId, dateFunction } = getGroupFromKey(groupBy, groups);\n const field = fieldsMap.get(columnId);\n\n const condition = { lhs: { field: field.name } };\n if (value === null || value === undefined) {\n condition.comparator = isNull;\n } else {\n condition.comparator = equals;\n condition.rhs = { value, dateFunction };\n }\n\n newGroupFilters.push({ condition });\n });\n finalGroupFilters.push({ AND: newGroupFilters });\n });\n\n let groupFiltersLogic;\n if (finalGroupFilters.length === 1) {\n finalGroupFilters = [].concat(finalGroupFilters[0].AND);\n groupFiltersLogic = { AND: finalGroupFilters };\n } else {\n groupFiltersLogic = { OR: finalGroupFilters };\n }\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, groupFiltersLogic] };\n } else {\n finalFilters = groupFiltersLogic;\n }\n }\n\n // Transform the ConditionBuilder structure to the DataViews structure\n const calculations = {}; // Any calculations resulting from date functions\n if (finalFilters) {\n finalFilters = JSON.parse(JSON.stringify(finalFilters)); // Cloning to avoid editing the original objects\n finalFilters = splitConditionTree(finalFilters, 'T');\n Object.entries(finalFilters.conditions).forEach(([key, condition]) => {\n transformConditionForDataApi(condition, key, meta, calculations);\n });\n }\n\n return {\n filterTree: finalFilters,\n calculations: Object.keys(calculations).length > 0 ? calculations : undefined // Don't return empty objects to avoid any API validation errors\n };\n};\n\n/**\n * It prepares the client filters\n * @param {DataApiTypes.State} stateFromTable A state object to get current {@link DataApiTypes.State.filterExpression filterExpression}, {@link DataApiTypes.State.search search}, {@link DataApiTypes.State.externalState externalState} filters\n * @param {DataApiTypes.Meta} meta A metadata object to extract fieldDefs\n * @returns {ReturnType<typeof import('@pega/cosmos-react-condition-builder').splitConditionTree>}\n */\nexport const buildClientFilters = (stateFromTable, meta) => {\n const { filterExpression, search } = stateFromTable;\n const searchQuery = search?.query;\n const {\n comparatorMap: { contains }\n } = meta;\n\n // Append search filters\n let finalFilters = filterExpression;\n const { externalFilters } = meta;\n if (isExternalFiltersExists(externalFilters, stateFromTable)) {\n finalFilters = appendExternalFiltersToFilterExpression(\n externalFilters,\n finalFilters,\n stateFromTable\n );\n }\n if (searchQuery) {\n const filters = getSearchFilters(search, contains);\n\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, { OR: filters }] };\n } else {\n finalFilters = { OR: filters };\n }\n }\n\n return finalFilters ? splitConditionTree(finalFilters) : finalFilters;\n};\n\n/**\n * It build {@link DataApiTypes.DataViewsQuery.aggregations aggregations} clause in query.\n * @param {NonNullable<DataApiTypes.State['aggregationInfo']>} aggregationInfo Current aggregations applied in the state\n * @param {Map<string, DataApiTypes.FieldDef>} fieldsMap A map with key {@link DataApiTypes.FieldDef.id fieldDef id} and value {@link DataApiTypes.FieldDef field} object\n * @param {DataApiTypes.Group[]} [groups] grouping information\n * @returns {NonNullable<DataApiTypes.DataViewsQuery['aggregations']>} {@link DataApiTypes.DataViewsQuery.aggregations aggregations}\n */\nexport const buildAggregations = (aggregationInfo, fieldsMap, groups) => {\n const aggregations = {};\n aggregationInfo.forEach(element => {\n const { columnId, type } = element;\n const field = fieldsMap.get(columnId);\n\n const summaryFunction = type.toUpperCase();\n\n // build aggregations\n const agg = `${columnId}${summaryFunction}`;\n aggregations[agg] = {\n field: field.name,\n summaryFunction\n };\n });\n\n // Add aggregations for grouped additional fields.\n groups?.forEach(group => {\n group.additionalFields?.forEach(additionalField => {\n const { id: fieldId, aggregation } = additionalField;\n const field = fieldsMap.get(fieldId);\n if (!field) {\n return;\n }\n\n // TODO: Handle for date functions for Date type fields.\n // If field type is number and aggregation is defined then add that aggregation.\n if (aggregation && field.type === 'number') {\n const aggregate = `${field.name}${aggregation.toUpperCase()}`;\n if (!aggregations[aggregate]) {\n aggregations[aggregate] = {\n field: field.name,\n summaryFunction: aggregation.toUpperCase()\n };\n }\n } else {\n // Else add MAX and distinctCOUNT aggregation.\n const maxAggregate = `${field.name}MAX`;\n const countAggregate = `${field.name}distinctCOUNT`;\n\n if (!aggregations[maxAggregate]) {\n aggregations[maxAggregate] = {\n field: field.name,\n summaryFunction: 'MAX'\n };\n }\n\n if (!aggregations[countAggregate]) {\n aggregations[countAggregate] = {\n field: field.name,\n summaryFunction: 'distinctCOUNT'\n };\n }\n }\n });\n });\n\n return aggregations;\n};\n\n// without grouping, startIndex and endIndex are both inclusive\nfunction prepareGroupDataIndexes(groupFilters, sIndex, eIndex) {\n let startIndex = sIndex;\n let endIndex = eIndex;\n if (groupFilters && groupFilters.length > 0) {\n startIndex = groupFilters[0].groupFrom;\n endIndex = 0;\n groupFilters.forEach(filter => {\n endIndex += filter.groupTo;\n });\n // with grouping, initially endIndex is not inclusive. So, update endIndex to keep the correct count of requested records\n endIndex -= 1;\n }\n return [startIndex, endIndex];\n}\n\n/**\n * It returns the paging information that will be used in query and parsing response data from API\n * @param {number} [startIndex] pagination startIndex\n * @param {number} [endIndex] pagination endIndex\n * @param {DataApiTypes.State['groupFilters']} [groupFilters] An array of {@link DataApiTypes.State.groupFilters GroupFilter}\n * @returns {DataApiTypes.DataViewsRequest['paging']} {@link DataApiTypes.DataViewsRequest.paging paging}\n */\nexport const buildPaging = (startIndex, endIndex, groupFilters) => {\n const [sIndex, eIndex] = prepareGroupDataIndexes(groupFilters, startIndex, endIndex);\n const { pageNumber, pageSize } = calculatePageMetrics(sIndex, eIndex);\n // When sIndex is 0, the starting index of new data should be considered from 0 only.\n const newStartIndex = sIndex === 0 ? 0 : pageSize * pageNumber - pageSize;\n return {\n pageNumber,\n pageSize,\n newStartIndex,\n startIndex: sIndex,\n endIndex: eIndex\n };\n};\n\n/**\n * It prepares {@link DataApiTypes.DataViewsRequest dataViewsRequest} that can be used to interact with pega-ui-lists-data-apis or data view api's\n * @param {DataApiTypes.State} stateFromTable Current state object\n * @param {DataApiTypes.Meta} meta Metadata structure\n * @param {boolean} [isClient] The query is being prepared to interact with pega-ui-lists-data-apis or data view api's\n * @param {DataApiTypes.Meta['patchQueryFields']} [patchQueryFields] A set of extra fields that should be appended in query\n * @param {string[]} [compositeKeys] A set of primary fields that should be appended in query\n * @param {boolean} [includeGroups] Groups should be included or not in the query\n * @param {boolean} [optimizeSelectFields] Whether the query should be optimized to only include fields that are visible(means it should not be part of {@link DataApiTypes.State.hiddenColumns hidden}) or which are part of {@link DataApiTypes.State.groups groups}, {@link DataApiTypes.State.filterExpression filters}, {@link DataApiTypes.State.sortingOrder sort}\n * @returns {DataApiTypes.DataViewsRequest} {@link DataApiTypes.DataViewsRequest dataViewsRequest}\n */\nexport function prepareDatapageQuery(\n stateFromTable,\n meta,\n isClient = false,\n patchQueryFields = [],\n compositeKeys = [],\n includeGroups = true,\n optimizeSelectFields = false\n) {\n const {\n paginationOptions: {\n rootVirtualiser: { startIndex, endIndex }\n },\n sortingOrder,\n groups,\n groupFilters\n } = stateFromTable;\n\n const { fieldDefs, itemKey } = meta;\n const paging = buildPaging(startIndex, endIndex, groupFilters);\n\n /* In case of WorkLink patch query with pyID and in association patch pzInsKey, pyID */\n const select = buildSelect(fieldDefs, {\n patchQueryFields,\n compositeKeys,\n stateFromTable,\n optimizeSelectFields,\n itemKey\n });\n\n const { sortBy, calculations: sortCalculations } = buildSortInfo(\n sortingOrder,\n groups,\n fieldDefs,\n itemKey,\n isClient\n );\n\n let query;\n if (select && select.length > 0) {\n query = {};\n query.select = select;\n if (sortBy && sortBy.length > 0) {\n query.sortBy = sortBy;\n }\n const { filterTree, calculations: filterCalculations } = buildFilters(\n stateFromTable,\n meta,\n includeGroups\n );\n if (filterTree && Object.keys(filterTree).length > 0) {\n query.filter = {\n logic: filterTree.logic,\n filterConditions: filterTree.conditions\n };\n }\n if (sortCalculations || filterCalculations) {\n query.calculations = { ...sortCalculations, ...filterCalculations };\n }\n query = { query, paging };\n }\n\n // console.log(query);\n return query;\n}\n\n/**\n * It prepares clientApi query used to interact with pega-ui-list-data-apis.\n * @param {DataApiTypes.State} stateFromTable Current state object\n * @param {DataApiTypes.Meta} meta Metadata structure\n * @param {boolean} [options.optimizeSelectFields] Whether to optimize select fields. Defaults to `meta?.isAnalyticsTable && meta?.isListViewOrListPage`.\n * @returns {DataApiTypes.ClientApiQuery} {@link DataApiTypes.ClientApiQuery clientApiQuery}\n */\nexport function prepareClientApiQuery(stateFromTable, meta, options = {}) {\n const { groupFilters, groups, aggregationInfo } = stateFromTable;\n\n const optimizeSelectFields =\n options.optimizeSelectFields ?? (meta?.isAnalyticsTable && meta?.isListViewOrListPage);\n\n const queryState = prepareDatapageQuery(\n stateFromTable,\n meta,\n true,\n [],\n [],\n true,\n optimizeSelectFields\n );\n if (groups) {\n const groupBy = [];\n groups.forEach(group => {\n groupBy.push({\n field: group.columnId,\n dateFunction: group.dateFunction,\n sortType: group.order\n });\n });\n queryState.query.groupBy = groupBy;\n }\n if (queryState.query.filter && Object.keys(queryState.query.filter).length > 0) {\n // Reconstruct without group filters. Also don't transform for the API, since the filters need to be passed to evaluateCondition\n queryState.query.filter = {};\n const filterTree = buildClientFilters(stateFromTable, meta);\n if (filterTree && Object.keys(filterTree).length > 0) {\n queryState.query.filter = {\n logic: filterTree.logic,\n filterConditions: filterTree.conditions\n };\n }\n }\n\n if (groupFilters && groupFilters.length > 0) {\n queryState.query.groupFilters = groupFilters;\n }\n\n if ((aggregationInfo && aggregationInfo.length > 0) || options.includeGroupAdditionalFields) {\n const fieldsMap = getFieldsMap(meta.fieldDefs);\n queryState.query.aggregations = buildAggregations(\n aggregationInfo,\n fieldsMap,\n options.includeGroupAdditionalFields ? groups : []\n );\n }\n\n return queryState;\n}\n"]}
@@ -8,5 +8,6 @@ export function getGroupFromKey(groupBy: string, groups: DataApiTypes.Group[]):
8
8
  export const dateFuncsWithNumericValues: ["MONTHS_OF_YEAR", "DAYS_OF_MONTH", "DAYS_OF_WEEK", "HOURS_OF_DAY"];
9
9
  export function appendExternalFiltersToFilterExpression(externalFiltersStateKey: any, finalFilters: any, stateFromTable: any): any;
10
10
  export function isExternalFiltersExists(externalFilters: any, stateFromTable: any): any;
11
+ export function buildAggOrCalcId(columnId: any, functionName: any): string;
11
12
  import { DataApiTypes } from '../types';
12
13
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../stateConversion/utils.js"],"names":[],"mappings":"AAWO,mCAHI,YAAY,CAAC,KAAK,GAChB,MAAM,CAWlB;AAQM,yCAJI,MAAM,UACN,YAAY,CAAC,KAAK,EAAE,GAClB,YAAY,CAAC,KAAK,GAAG,SAAS,CAM1C;AAED;;;;GAIG;AACH,yCAFU,CAAC,gBAAgB,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,CAAC,CAO3E;AAEK,mIAWN;AAEM,wFAMN;6BA/D4B,UAAU"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../stateConversion/utils.js"],"names":[],"mappings":"AAWO,mCAHI,YAAY,CAAC,KAAK,GAChB,MAAM,CAWlB;AAQM,yCAJI,MAAM,UACN,YAAY,CAAC,KAAK,EAAE,GAClB,YAAY,CAAC,KAAK,GAAG,SAAS,CAM1C;AAED;;;;GAIG;AACH,yCAFU,CAAC,gBAAgB,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,CAAC,CAO3E;AAEK,mIAWN;AAEM,wFAMN;AAGM,2EAKN;6BAvE4B,UAAU"}
@@ -52,4 +52,11 @@ export const isExternalFiltersExists = (externalFilters, stateFromTable) => {
52
52
  stateFromTable.externalState?.[externalFilters] &&
53
53
  Object.keys(stateFromTable.externalState?.[externalFilters]).length > 0);
54
54
  };
55
+ // Builds a uniquely identifyable aggregation/calculation ID for sending to the server.
56
+ export const buildAggOrCalcId = (columnId, functionName) => {
57
+ // Server does not support agg/calc ID's containing special chars, but Association ID's can contain - and _
58
+ // AND the data_views API uses : to separate the assoc ID and the field ID
59
+ // EmbeddedFields starts with !P! or !PL!, so ! should be removed as it is a special chars
60
+ return `${columnId.replace(/[-_!:]/g, '')}${functionName}`;
61
+ };
55
62
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../stateConversion/utils.js"],"names":[],"mappings":"AAAA,kEAAkE;AAClE,0CAA0C;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,MAAM,gBAAgB,GAAG,IAAI,CAAC,CAAC,2BAA2B;AAE1D;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;IACjC,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;QACvB,OAAO,GAAG,KAAK,CAAC,QAAQ,GAAG,gBAAgB,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;IACrE,CAAC;IAED,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,OAAO,GAAG,KAAK,CAAC,QAAQ,GAAG,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,GAAG,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC;IACzH,CAAC;IACD,OAAO,KAAK,CAAC,QAAQ,CAAC;AACxB,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;IACjD,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;QACzB,OAAO,WAAW,CAAC,KAAK,CAAC,KAAK,OAAO,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAG;IACxC,gBAAgB;IAChB,eAAe;IACf,cAAc;IACd,cAAc;CACf,CAAC;AAEF,MAAM,CAAC,MAAM,uCAAuC,GAAG,CACrD,uBAAuB,EACvB,YAAY,EACZ,cAAc,EACd,EAAE;IACF,IAAI,YAAY,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACzD,YAAY,GAAG,EAAE,GAAG,EAAE,CAAC,YAAY,EAAE,cAAc,CAAC,aAAa,EAAE,CAAC,uBAAuB,CAAC,CAAC,EAAE,CAAC;IAClG,CAAC;SAAM,CAAC;QACN,YAAY,GAAG,cAAc,CAAC,aAAa,EAAE,CAAC,uBAAuB,CAAC,CAAC;IACzE,CAAC;IACD,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,eAAe,EAAE,cAAc,EAAE,EAAE;IACzE,OAAO,CACL,eAAe;QACf,cAAc,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CACxE,CAAC;AACJ,CAAC,CAAC","sourcesContent":["// This should be converted to \"import type\" once this file is TS.\n// eslint-disable-next-line no-unused-vars\nimport { DataApiTypes } from '../types';\n\nconst groupBySeparator = '||'; // To avoid any ambiguities\n\n/**\n * Returns a unique key for a given group to use as `groupBy`\n * @param {DataApiTypes.Group} group\n * @returns {string}\n */\nexport const getGroupKey = group => {\n if (group.dateFunction) {\n return `${group.columnId}${groupBySeparator}${group.dateFunction}`;\n }\n\n if (group.customFunction) {\n return `${group.columnId}${groupBySeparator}${group.customFunction.type}${groupBySeparator}${group.customFunction.id}`;\n }\n return group.columnId;\n};\n\n/**\n * Returns group info from groups based on `groupBy` key\n * @param {string} groupBy - unique key for a given group\n * @param {DataApiTypes.Group[]} groups - groups info from table state\n * @returns {DataApiTypes.Group | undefined} - matched group\n */\nexport const getGroupFromKey = (groupBy, groups) => {\n return groups.find(group => {\n return getGroupKey(group) === groupBy;\n });\n};\n\n/**\n * Date-Functions with numbers as values.\n * They need some additional handling since the DataViews API returns everything as a string.\n * @type {['MONTHS_OF_YEAR', 'DAYS_OF_MONTH', 'DAYS_OF_WEEK', 'HOURS_OF_DAY']}\n */\nexport const dateFuncsWithNumericValues = [\n 'MONTHS_OF_YEAR',\n 'DAYS_OF_MONTH',\n 'DAYS_OF_WEEK',\n 'HOURS_OF_DAY'\n];\n\nexport const appendExternalFiltersToFilterExpression = (\n externalFiltersStateKey,\n finalFilters,\n stateFromTable\n) => {\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, stateFromTable.externalState?.[externalFiltersStateKey]] };\n } else {\n finalFilters = stateFromTable.externalState?.[externalFiltersStateKey];\n }\n return finalFilters;\n};\n\nexport const isExternalFiltersExists = (externalFilters, stateFromTable) => {\n return (\n externalFilters &&\n stateFromTable.externalState?.[externalFilters] &&\n Object.keys(stateFromTable.externalState?.[externalFilters]).length > 0\n );\n};\n"]}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../stateConversion/utils.js"],"names":[],"mappings":"AAAA,kEAAkE;AAClE,0CAA0C;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,MAAM,gBAAgB,GAAG,IAAI,CAAC,CAAC,2BAA2B;AAE1D;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;IACjC,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;QACvB,OAAO,GAAG,KAAK,CAAC,QAAQ,GAAG,gBAAgB,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;IACrE,CAAC;IAED,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,OAAO,GAAG,KAAK,CAAC,QAAQ,GAAG,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,GAAG,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC;IACzH,CAAC;IACD,OAAO,KAAK,CAAC,QAAQ,CAAC;AACxB,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;IACjD,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;QACzB,OAAO,WAAW,CAAC,KAAK,CAAC,KAAK,OAAO,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAG;IACxC,gBAAgB;IAChB,eAAe;IACf,cAAc;IACd,cAAc;CACf,CAAC;AAEF,MAAM,CAAC,MAAM,uCAAuC,GAAG,CACrD,uBAAuB,EACvB,YAAY,EACZ,cAAc,EACd,EAAE;IACF,IAAI,YAAY,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACzD,YAAY,GAAG,EAAE,GAAG,EAAE,CAAC,YAAY,EAAE,cAAc,CAAC,aAAa,EAAE,CAAC,uBAAuB,CAAC,CAAC,EAAE,CAAC;IAClG,CAAC;SAAM,CAAC;QACN,YAAY,GAAG,cAAc,CAAC,aAAa,EAAE,CAAC,uBAAuB,CAAC,CAAC;IACzE,CAAC;IACD,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,eAAe,EAAE,cAAc,EAAE,EAAE;IACzE,OAAO,CACL,eAAe;QACf,cAAc,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CACxE,CAAC;AACJ,CAAC,CAAC;AAEF,uFAAuF;AACvF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,QAAQ,EAAE,YAAY,EAAE,EAAE;IACzD,2GAA2G;IAC3G,0EAA0E;IAC1E,0FAA0F;IAC1F,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC;AAC7D,CAAC,CAAC","sourcesContent":["// This should be converted to \"import type\" once this file is TS.\n// eslint-disable-next-line no-unused-vars\nimport { DataApiTypes } from '../types';\n\nconst groupBySeparator = '||'; // To avoid any ambiguities\n\n/**\n * Returns a unique key for a given group to use as `groupBy`\n * @param {DataApiTypes.Group} group\n * @returns {string}\n */\nexport const getGroupKey = group => {\n if (group.dateFunction) {\n return `${group.columnId}${groupBySeparator}${group.dateFunction}`;\n }\n\n if (group.customFunction) {\n return `${group.columnId}${groupBySeparator}${group.customFunction.type}${groupBySeparator}${group.customFunction.id}`;\n }\n return group.columnId;\n};\n\n/**\n * Returns group info from groups based on `groupBy` key\n * @param {string} groupBy - unique key for a given group\n * @param {DataApiTypes.Group[]} groups - groups info from table state\n * @returns {DataApiTypes.Group | undefined} - matched group\n */\nexport const getGroupFromKey = (groupBy, groups) => {\n return groups.find(group => {\n return getGroupKey(group) === groupBy;\n });\n};\n\n/**\n * Date-Functions with numbers as values.\n * They need some additional handling since the DataViews API returns everything as a string.\n * @type {['MONTHS_OF_YEAR', 'DAYS_OF_MONTH', 'DAYS_OF_WEEK', 'HOURS_OF_DAY']}\n */\nexport const dateFuncsWithNumericValues = [\n 'MONTHS_OF_YEAR',\n 'DAYS_OF_MONTH',\n 'DAYS_OF_WEEK',\n 'HOURS_OF_DAY'\n];\n\nexport const appendExternalFiltersToFilterExpression = (\n externalFiltersStateKey,\n finalFilters,\n stateFromTable\n) => {\n if (finalFilters && Object.keys(finalFilters).length > 0) {\n finalFilters = { AND: [finalFilters, stateFromTable.externalState?.[externalFiltersStateKey]] };\n } else {\n finalFilters = stateFromTable.externalState?.[externalFiltersStateKey];\n }\n return finalFilters;\n};\n\nexport const isExternalFiltersExists = (externalFilters, stateFromTable) => {\n return (\n externalFilters &&\n stateFromTable.externalState?.[externalFilters] &&\n Object.keys(stateFromTable.externalState?.[externalFilters]).length > 0\n );\n};\n\n// Builds a uniquely identifyable aggregation/calculation ID for sending to the server.\nexport const buildAggOrCalcId = (columnId, functionName) => {\n // Server does not support agg/calc ID's containing special chars, but Association ID's can contain - and _\n // AND the data_views API uses : to separate the assoc ID and the field ID\n // EmbeddedFields starts with !P! or !PL!, so ! should be removed as it is a special chars\n return `${columnId.replace(/[-_!:]/g, '')}${functionName}`;\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pega/lists-core-utils",
3
- "version": "9.0.0-build.14.1",
3
+ "version": "9.0.0-build.14.10",
4
4
  "description": "Data api for data operations like sort, filter, grouping etc. and query builder api's to build Data views api query",
5
5
  "license": "SEE LICENSE IN LICENSE",
6
6
  "author": "Pegasystems",
@@ -14,14 +14,14 @@
14
14
  "build": "tsc -b tsconfig.build.json"
15
15
  },
16
16
  "dependencies": {
17
- "@pega/cosmos-react-condition-builder": "9.0.0-build.14.1",
18
- "@pega/cosmos-react-core": "9.0.0-build.14.1",
17
+ "@pega/cosmos-react-condition-builder": "9.0.0-build.14.10",
18
+ "@pega/cosmos-react-core": "9.0.0-build.14.10",
19
19
  "@types/lodash.get": "^4.4.9",
20
20
  "dayjs": "^1.11.13",
21
21
  "lodash.get": "^4.4.2",
22
- "pega-repeating-structures-core": "npm:@pega/lists-core@9.0.0-build.14.1"
22
+ "pega-repeating-structures-core": "npm:@pega/lists-core@9.0.0-build.14.10"
23
23
  },
24
24
  "devDependencies": {
25
- "typescript": "~5.8.3"
25
+ "typescript": "~5.9.3"
26
26
  }
27
27
  }