@provoly/dashboard 1.1.7 → 1.1.8

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,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL21vZGVsL2ZpbHRlci5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyIHtcbiAgaWQ6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG4gIGF0dHJpYnV0ZXM6IHsgaWQ6IHN0cmluZzsgY3VzdG9tSWQ/OiBzdHJpbmc7IHRlY2huaWNhbE5hbWU6IHN0cmluZzsgbGFiZWw6IHN0cmluZzsgZGF0YXNvdXJjZTogc3RyaW5nIH1bXTtcbiAgb3BlcmF0b3I/OiBzdHJpbmc7XG4gIHZhbHVlPzogc3RyaW5nIHwgbnVtYmVyO1xuICBwb3NzaWJsZVZhbHVlcz86IHN0cmluZzsgLy8gb25seSB1c2VkIGluIGxpc3QtZmlsdGVyXG4gIGhhc0RhdGVSYW5nZT86IGJvb2xlYW47XG4gIGxpbWl0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlckNvbnRleHQge1xuICBhdHRyaWJ1dGU6IHN0cmluZztcbiAgb3BlcmF0b3I6IHN0cmluZztcbiAgdmFsdWU6IHN0cmluZyB8IG51bWJlciB8IHN0cmluZ1tdIHwgbnVtYmVyW10gfCB1bmRlZmluZWQ7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL21vZGVsL2ZpbHRlci5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyIHtcbiAgaWQ6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG4gIGF0dHJpYnV0ZXM6IHsgaWQ6IHN0cmluZzsgY3VzdG9tSWQ/OiBzdHJpbmc7IHRlY2huaWNhbE5hbWU6IHN0cmluZzsgbGFiZWw6IHN0cmluZzsgZGF0YXNvdXJjZTogc3RyaW5nIH1bXTtcbiAgb3BlcmF0b3I/OiBzdHJpbmc7XG4gIHZhbHVlPzogc3RyaW5nIHwgbnVtYmVyIHwgc3RyaW5nW10gfCBudW1iZXJbXTtcbiAgcG9zc2libGVWYWx1ZXM/OiBzdHJpbmc7IC8vIG9ubHkgdXNlZCBpbiBsaXN0LWZpbHRlclxuICBoYXNEYXRlUmFuZ2U/OiBib29sZWFuO1xuICBsaW1pdD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJDb250ZXh0IHtcbiAgYXR0cmlidXRlOiBzdHJpbmc7XG4gIG9wZXJhdG9yOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXIgfCBzdHJpbmdbXSB8IG51bWJlcltdIHwgdW5kZWZpbmVkO1xufVxuIl19
@@ -126,52 +126,57 @@ export class AggregationUtils {
126
126
  static doesItemValuePassFilter(item, attribute, operator, filterValue) {
127
127
  let value = AggregationUtils.getValueFromAttribute(item, attribute)?.value;
128
128
  let date1, date2;
129
- switch (operator) {
130
- case 'EQUALS':
131
- return value === filterValue;
132
- case 'NOT_EQUALS':
133
- return value !== filterValue;
134
- case 'CONTAINS':
135
- return value.includes(filterValue);
136
- case 'START_WITH':
137
- return value.startsWith(filterValue);
138
- case 'END_WITH':
139
- return value.endsWith(filterValue);
140
- case 'GREATER_THAN':
141
- if (typeof filterValue === 'number') {
142
- return value > filterValue;
143
- }
144
- else if (typeof filterValue === 'string') {
145
- return new Date(value) > new Date(filterValue);
146
- }
147
- else {
148
- return false;
149
- }
150
- case 'LOWER_THAN':
151
- if (typeof filterValue === 'number') {
152
- return value < filterValue;
153
- }
154
- else if (typeof filterValue === 'string') {
155
- return new Date(value) < new Date(filterValue);
156
- }
157
- else {
158
- return false;
159
- }
160
- case 'INSIDE':
161
- [date1, date2] = [
162
- new Date(filterValue.split(',')[0]),
163
- new Date(filterValue.split(',')[1])
164
- ];
165
- return new Date(value) > new Date(date1) && new Date(value) < new Date(date2);
166
- case 'OUTSIDE':
167
- [date1, date2] = [
168
- new Date(filterValue.split(',')[0]),
169
- new Date(filterValue.split(',')[1])
170
- ];
171
- return new Date(value) < new Date(date1) && new Date(value) > new Date(date2);
172
- default:
173
- return true;
174
- }
129
+ let filterPossibleValues = Array.isArray(filterValue) ? filterValue : [filterValue];
130
+ return filterPossibleValues
131
+ .map((possibleFilterValue) => {
132
+ switch (operator) {
133
+ case 'EQUALS':
134
+ return value === filterValue;
135
+ case 'NOT_EQUALS':
136
+ return value !== filterValue;
137
+ case 'CONTAINS':
138
+ return value.includes(filterValue);
139
+ case 'START_WITH':
140
+ return value.startsWith(filterValue);
141
+ case 'END_WITH':
142
+ return value.endsWith(filterValue);
143
+ case 'GREATER_THAN':
144
+ if (typeof filterValue === 'number') {
145
+ return value > filterValue;
146
+ }
147
+ else if (typeof filterValue === 'string') {
148
+ return new Date(value) > new Date(filterValue);
149
+ }
150
+ else {
151
+ return false;
152
+ }
153
+ case 'LOWER_THAN':
154
+ if (typeof filterValue === 'number') {
155
+ return value < filterValue;
156
+ }
157
+ else if (typeof filterValue === 'string') {
158
+ return new Date(value) < new Date(filterValue);
159
+ }
160
+ else {
161
+ return false;
162
+ }
163
+ case 'INSIDE':
164
+ [date1, date2] = [
165
+ new Date(filterValue.split(',')[0]),
166
+ new Date(filterValue.split(',')[1])
167
+ ];
168
+ return new Date(value) > new Date(date1) && new Date(value) < new Date(date2);
169
+ case 'OUTSIDE':
170
+ [date1, date2] = [
171
+ new Date(filterValue.split(',')[0]),
172
+ new Date(filterValue.split(',')[1])
173
+ ];
174
+ return new Date(value) < new Date(date1) && new Date(value) > new Date(date2);
175
+ default:
176
+ return true;
177
+ }
178
+ })
179
+ .reduce((p, c) => p || c);
175
180
  }
176
181
  }
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aggregation-utils.class.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/store/aggregation/frontend-aggregation/aggregation-utils.class.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChartAggregatedWidgetOptions,\n  Operation,\n  TimeInterval\n} from '../../../model/widget-aggregated-chart-manifest.interface';\nimport { Class } from '../../class/class.interface';\nimport { Item, ValueType } from '../../../model/item.interface';\nimport { ResultSets } from '../../../model/result-set.interface';\nimport { ResultsetUtils } from '../../../../dashboard/resultset-utils';\nimport { ItemUtils } from '../../../../dashboard/item-utils';\nimport { Filter } from '../../../model/filter.interface';\n\nexport class AggregationUtils {\n  static getAxisAttribute(classes: Class[], options: ChartAggregatedWidgetOptions, axis: 'ordinate' | 'abscissa') {\n    return classes\n      .map((clazz) => clazz.attributes.find((attr) => attr.id === options[axis].attribute))\n      .find((attr) => !!attr)?.name;\n  }\n\n  static getChartDatasourceResultSet(datasources: string[], resultSets: ResultSets) {\n    return datasources\n      .filter((rsName) => rsName in resultSets)\n      .map((rsName) => resultSets[rsName])\n      .reduce((rs1, rs2) => ResultsetUtils.mergeResultSets(rs1, rs2), {\n        items: {},\n        relations: [],\n        merged: datasources.filter((rsName) => rsName in resultSets).length\n      });\n  }\n\n  static getAggregatedValue(\n    operation: Operation,\n    groupedItems: { [key: string | number]: Item[] },\n    abscissaAttribute: keyof typeof groupedItems,\n    ordinateAttribute: string\n  ): number | ValueType {\n    return this.getAggregatedValueForOperation(\n      operation,\n      groupedItems[abscissaAttribute].map((item) => this.getValueFromAttribute(item, ordinateAttribute).value as number)\n    );\n  }\n\n  static getValueFromAttribute(item: Item, attribute: string) {\n    let value = ItemUtils.getAttributeValue(item, attribute);\n    return Array.isArray(value) ? value[0] : value;\n  }\n\n  static getAggregatedValueForOperation(operation: Operation, values: number[]): number | ValueType {\n    switch (operation) {\n      case Operation.COUNT:\n        return values.length;\n      case Operation.SUM:\n        return values.reduce((acc, val) => acc + val, 0);\n      case Operation.DISTINCT:\n        return [...new Set(values)].length;\n      case Operation.AVERAGE:\n        return values.reduce((acc, val) => acc + val, 0) / values.length;\n      case Operation.MEDIAN:\n        return this.getQuartile(values, 0.5);\n      case Operation.Q1:\n        return this.getQuartile(values, 0.25);\n      case Operation.Q3:\n        return this.getQuartile(values, 0.75);\n      case Operation.MIN:\n        return Math.min(...values);\n      case Operation.MAX:\n        return Math.max(...values);\n      default:\n        return -1;\n    }\n  }\n\n  static getQuartile(values: number[], q: number) {\n    if (values.length === 0) return 0;\n    values.sort((a: number, b: number) => a - b);\n\n    let pos = (values.length - 1) * q;\n    if (pos % 1 === 0) {\n      return values[pos];\n    }\n\n    pos = Math.floor(pos);\n    return values[pos + 1] !== undefined ? (values[pos] + values[pos + 1]) / 2 : values[pos];\n  }\n\n  static formatByLimit(\n    data: { key: ValueType; value: ValueType }[],\n    interval: number | TimeInterval,\n    operation: Operation\n  ) {\n    return typeof interval === 'number' ? data : this.formatDataByTimeLimit(data, interval, operation);\n  }\n\n  static formatDataByTimeLimit(\n    data: { key: ValueType; value: ValueType }[],\n    interval: TimeInterval,\n    operation: Operation\n  ) {\n    let distinctValues: { key: ValueType; values: ValueType[] }[] = [];\n    data\n      .map((obj) => ({ ...obj, key: this.getKeyValueForTimeInterval(obj.key, interval) }))\n      .forEach((obj) => {\n        const isNotDistinct = distinctValues.find((distinct) => obj.key === distinct.key);\n        if (!!isNotDistinct) {\n          isNotDistinct.values.push(obj.value);\n        } else {\n          distinctValues.push({ key: obj.key, values: [] });\n        }\n      });\n    return distinctValues.map((obj) => ({\n      ...obj,\n      value: AggregationUtils.getAggregatedValueForOperation(operation, obj.values as number[])\n    }));\n  }\n\n  static getKeyValueForTimeInterval(key: ValueType, interval: TimeInterval): string {\n    const date = new Date(key as string);\n    switch (interval) {\n      case 'second':\n        return new Date(\n          date.getFullYear(),\n          date.getMonth(),\n          date.getDate(),\n          date.getHours(),\n          date.getMinutes(),\n          date.getSeconds()\n        ).toISOString();\n      case 'minute':\n        return new Date(\n          date.getFullYear(),\n          date.getMonth(),\n          date.getDate(),\n          date.getHours(),\n          date.getMinutes()\n        ).toISOString();\n      case 'hour':\n        return new Date(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours()).toISOString();\n      case 'day':\n        return new Date(date.getFullYear(), date.getMonth(), date.getDate()).toISOString();\n      case 'week':\n        const daysToSubtract = (7 + date.getUTCDay()) % 7;\n        date.setUTCDate(date.getUTCDate() - daysToSubtract);\n        return date.toISOString();\n      case 'quarter':\n        const quarterStartMonths = [0, 3, 6, 9]; // January, April, July, October\n        const quarter = Math.floor(date.getUTCMonth() / 3);\n        const year = date.getUTCFullYear();\n\n        const startOfQuarter = new Date(Date.UTC(year, quarterStartMonths[quarter], 1, 0, 0, 0, 0));\n        return startOfQuarter.toISOString();\n      case 'year':\n        return new Date(new Date(key as string).getFullYear(), 0, 1).toISOString();\n      default:\n        return date.toISOString();\n    }\n  }\n\n  static filterItems(items: Item[], filters: Filter[]) {\n    let filtersByAttribute = filters\n      .map((filter) =>\n        filter.attributes.map((attribute) => ({\n          ...filter,\n          attribute: attribute.id,\n          attributes: undefined\n        }))\n      )\n      .flat();\n\n    return filters.length > 0\n      ? [\n          ...new Set(\n            filtersByAttribute\n              .map((filter) =>\n                items.filter((item) =>\n                  this.doesItemValuePassFilter(item, filter.attribute, filter.operator, filter.value)\n                )\n              )\n              .flat()\n          )\n        ]\n      : items;\n  }\n\n  static doesItemValuePassFilter(\n    item: Item,\n    attribute: string,\n    operator: string | undefined,\n    filterValue: string | number | undefined\n  ): boolean {\n    let value = AggregationUtils.getValueFromAttribute(item, attribute)?.value as string | number;\n    let date1: Date, date2: Date;\n\n    switch (operator) {\n      case 'EQUALS':\n        return value === filterValue;\n      case 'NOT_EQUALS':\n        return value !== filterValue;\n      case 'CONTAINS':\n        return (value as string).includes(filterValue as string);\n      case 'START_WITH':\n        return (value as string).startsWith(filterValue as string);\n      case 'END_WITH':\n        return (value as string).endsWith(filterValue as string);\n      case 'GREATER_THAN':\n        if (typeof filterValue === 'number') {\n          return (value as number) > filterValue;\n        } else if (typeof filterValue === 'string') {\n          return new Date(value) > new Date(filterValue);\n        } else {\n          return false;\n        }\n      case 'LOWER_THAN':\n        if (typeof filterValue === 'number') {\n          return (value as number) < filterValue;\n        } else if (typeof filterValue === 'string') {\n          return new Date(value) < new Date(filterValue);\n        } else {\n          return false;\n        }\n      case 'INSIDE':\n        [date1, date2] = [\n          new Date((filterValue as string).split(',')[0]),\n          new Date((filterValue as string).split(',')[1])\n        ];\n        return new Date(value) > new Date(date1) && new Date(value) < new Date(date2);\n      case 'OUTSIDE':\n        [date1, date2] = [\n          new Date((filterValue as string).split(',')[0]),\n          new Date((filterValue as string).split(',')[1])\n        ];\n        return new Date(value) < new Date(date1) && new Date(value) > new Date(date2);\n      default:\n        return true;\n    }\n  }\n}\n"]}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aggregation-utils.class.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/store/aggregation/frontend-aggregation/aggregation-utils.class.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChartAggregatedWidgetOptions,\n  Operation,\n  TimeInterval\n} from '../../../model/widget-aggregated-chart-manifest.interface';\nimport { Class } from '../../class/class.interface';\nimport { Item, ValueType } from '../../../model/item.interface';\nimport { ResultSets } from '../../../model/result-set.interface';\nimport { ResultsetUtils } from '../../../../dashboard/resultset-utils';\nimport { ItemUtils } from '../../../../dashboard/item-utils';\nimport { Filter } from '../../../model/filter.interface';\n\nexport class AggregationUtils {\n  static getAxisAttribute(classes: Class[], options: ChartAggregatedWidgetOptions, axis: 'ordinate' | 'abscissa') {\n    return classes\n      .map((clazz) => clazz.attributes.find((attr) => attr.id === options[axis].attribute))\n      .find((attr) => !!attr)?.name;\n  }\n\n  static getChartDatasourceResultSet(datasources: string[], resultSets: ResultSets) {\n    return datasources\n      .filter((rsName) => rsName in resultSets)\n      .map((rsName) => resultSets[rsName])\n      .reduce((rs1, rs2) => ResultsetUtils.mergeResultSets(rs1, rs2), {\n        items: {},\n        relations: [],\n        merged: datasources.filter((rsName) => rsName in resultSets).length\n      });\n  }\n\n  static getAggregatedValue(\n    operation: Operation,\n    groupedItems: { [key: string | number]: Item[] },\n    abscissaAttribute: keyof typeof groupedItems,\n    ordinateAttribute: string\n  ): number | ValueType {\n    return this.getAggregatedValueForOperation(\n      operation,\n      groupedItems[abscissaAttribute].map((item) => this.getValueFromAttribute(item, ordinateAttribute).value as number)\n    );\n  }\n\n  static getValueFromAttribute(item: Item, attribute: string) {\n    let value = ItemUtils.getAttributeValue(item, attribute);\n    return Array.isArray(value) ? value[0] : value;\n  }\n\n  static getAggregatedValueForOperation(operation: Operation, values: number[]): number | ValueType {\n    switch (operation) {\n      case Operation.COUNT:\n        return values.length;\n      case Operation.SUM:\n        return values.reduce((acc, val) => acc + val, 0);\n      case Operation.DISTINCT:\n        return [...new Set(values)].length;\n      case Operation.AVERAGE:\n        return values.reduce((acc, val) => acc + val, 0) / values.length;\n      case Operation.MEDIAN:\n        return this.getQuartile(values, 0.5);\n      case Operation.Q1:\n        return this.getQuartile(values, 0.25);\n      case Operation.Q3:\n        return this.getQuartile(values, 0.75);\n      case Operation.MIN:\n        return Math.min(...values);\n      case Operation.MAX:\n        return Math.max(...values);\n      default:\n        return -1;\n    }\n  }\n\n  static getQuartile(values: number[], q: number) {\n    if (values.length === 0) return 0;\n    values.sort((a: number, b: number) => a - b);\n\n    let pos = (values.length - 1) * q;\n    if (pos % 1 === 0) {\n      return values[pos];\n    }\n\n    pos = Math.floor(pos);\n    return values[pos + 1] !== undefined ? (values[pos] + values[pos + 1]) / 2 : values[pos];\n  }\n\n  static formatByLimit(\n    data: { key: ValueType; value: ValueType }[],\n    interval: number | TimeInterval,\n    operation: Operation\n  ) {\n    return typeof interval === 'number' ? data : this.formatDataByTimeLimit(data, interval, operation);\n  }\n\n  static formatDataByTimeLimit(\n    data: { key: ValueType; value: ValueType }[],\n    interval: TimeInterval,\n    operation: Operation\n  ) {\n    let distinctValues: { key: ValueType; values: ValueType[] }[] = [];\n    data\n      .map((obj) => ({ ...obj, key: this.getKeyValueForTimeInterval(obj.key, interval) }))\n      .forEach((obj) => {\n        const isNotDistinct = distinctValues.find((distinct) => obj.key === distinct.key);\n        if (!!isNotDistinct) {\n          isNotDistinct.values.push(obj.value);\n        } else {\n          distinctValues.push({ key: obj.key, values: [] });\n        }\n      });\n    return distinctValues.map((obj) => ({\n      ...obj,\n      value: AggregationUtils.getAggregatedValueForOperation(operation, obj.values as number[])\n    }));\n  }\n\n  static getKeyValueForTimeInterval(key: ValueType, interval: TimeInterval): string {\n    const date = new Date(key as string);\n    switch (interval) {\n      case 'second':\n        return new Date(\n          date.getFullYear(),\n          date.getMonth(),\n          date.getDate(),\n          date.getHours(),\n          date.getMinutes(),\n          date.getSeconds()\n        ).toISOString();\n      case 'minute':\n        return new Date(\n          date.getFullYear(),\n          date.getMonth(),\n          date.getDate(),\n          date.getHours(),\n          date.getMinutes()\n        ).toISOString();\n      case 'hour':\n        return new Date(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours()).toISOString();\n      case 'day':\n        return new Date(date.getFullYear(), date.getMonth(), date.getDate()).toISOString();\n      case 'week':\n        const daysToSubtract = (7 + date.getUTCDay()) % 7;\n        date.setUTCDate(date.getUTCDate() - daysToSubtract);\n        return date.toISOString();\n      case 'quarter':\n        const quarterStartMonths = [0, 3, 6, 9]; // January, April, July, October\n        const quarter = Math.floor(date.getUTCMonth() / 3);\n        const year = date.getUTCFullYear();\n\n        const startOfQuarter = new Date(Date.UTC(year, quarterStartMonths[quarter], 1, 0, 0, 0, 0));\n        return startOfQuarter.toISOString();\n      case 'year':\n        return new Date(new Date(key as string).getFullYear(), 0, 1).toISOString();\n      default:\n        return date.toISOString();\n    }\n  }\n\n  static filterItems(items: Item[], filters: Filter[]) {\n    let filtersByAttribute = filters\n      .map((filter) =>\n        filter.attributes.map((attribute) => ({\n          ...filter,\n          attribute: attribute.id,\n          attributes: undefined\n        }))\n      )\n      .flat();\n\n    return filters.length > 0\n      ? [\n          ...new Set(\n            filtersByAttribute\n              .map((filter) =>\n                items.filter((item) =>\n                  this.doesItemValuePassFilter(item, filter.attribute, filter.operator, filter.value)\n                )\n              )\n              .flat()\n          )\n        ]\n      : items;\n  }\n\n  static doesItemValuePassFilter(\n    item: Item,\n    attribute: string,\n    operator: string | undefined,\n    filterValue: string | number | string[] | number[] | undefined\n  ): boolean {\n    let value = AggregationUtils.getValueFromAttribute(item, attribute)?.value as string | number;\n    let date1: Date, date2: Date;\n\n    let filterPossibleValues = Array.isArray(filterValue) ? filterValue : ([filterValue] as string[] | number[]);\n\n    return filterPossibleValues\n      .map((possibleFilterValue) => {\n        switch (operator) {\n          case 'EQUALS':\n            return value === filterValue;\n          case 'NOT_EQUALS':\n            return value !== filterValue;\n          case 'CONTAINS':\n            return (value as string).includes(filterValue as string);\n          case 'START_WITH':\n            return (value as string).startsWith(filterValue as string);\n          case 'END_WITH':\n            return (value as string).endsWith(filterValue as string);\n          case 'GREATER_THAN':\n            if (typeof filterValue === 'number') {\n              return (value as number) > filterValue;\n            } else if (typeof filterValue === 'string') {\n              return new Date(value) > new Date(filterValue);\n            } else {\n              return false;\n            }\n          case 'LOWER_THAN':\n            if (typeof filterValue === 'number') {\n              return (value as number) < filterValue;\n            } else if (typeof filterValue === 'string') {\n              return new Date(value) < new Date(filterValue);\n            } else {\n              return false;\n            }\n          case 'INSIDE':\n            [date1, date2] = [\n              new Date((filterValue as string).split(',')[0]),\n              new Date((filterValue as string).split(',')[1])\n            ];\n            return new Date(value) > new Date(date1) && new Date(value) < new Date(date2);\n          case 'OUTSIDE':\n            [date1, date2] = [\n              new Date((filterValue as string).split(',')[0]),\n              new Date((filterValue as string).split(',')[1])\n            ];\n            return new Date(value) < new Date(date1) && new Date(value) > new Date(date2);\n          default:\n            return true;\n        }\n      })\n      .reduce((p, c) => p || c);\n  }\n}\n"]}
@@ -12,7 +12,7 @@ export class CqlUtils {
12
12
  const attributeName = attribute?.technicalName;
13
13
  return this.getConditionsForValue(attributeName, cond, field, datasourceId);
14
14
  })
15
- .filter((conds) => conds.length > 0)
15
+ .filter((conds) => !!conds && conds.length > 0)
16
16
  .join(' AND ');
17
17
  }
18
18
  static getConditionsForValue(attributeName, cond, field, datasourceId) {
@@ -68,4 +68,4 @@ export class CqlUtils {
68
68
  return conditions.length > 1 ? '( ' + conditions.join(' OR ') + ' )' : conditions[0];
69
69
  }
70
70
  }
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cql-utils.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/utils/cql-utils.class.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+B,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEjF,MAAM,OAAO,QAAQ;IACnB,MAAM,CAAC,eAAe,CACpB,YAAoB,EACpB,OAAyC,EACzC,OAAgB,EAChB,MAAe;QAEf,IAAI,CAAC,OAAO,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9F,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QAE5E,OAAO,OAAO,CAAC,YAAY,CAAC;aACzB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,SAAS,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC;YACjF,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,SAAS,EAAE,KAAK,CAAC,CAAC;YAC5D,MAAM,aAAa,GAAG,SAAS,EAAE,aAAa,CAAC;YAE/C,OAAO,IAAI,CAAC,qBAAqB,CAAC,aAAa,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;QAC9E,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;aACnC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,qBAAqB,CAC1B,aAAiC,EACjC,IAAmB,EACnB,KAAwB,EACxB,YAAoB;QAEpB,IAAI,UAAU,GAAa,EAAE,CAAC;QAE9B,MAAM,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAwB,CAAC;QAE9F,IAAI,aAAa,EAAE,CAAC;YAClB,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACvB,IAAI,KAAK,IAAI,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC7D,MAAM,cAAc,GAAG,GAAG,KAAK,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;oBACtD,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACtB,KAAK,QAAQ;4BACX,IAAI,CAAC,KAAK,IAAI,cAAc,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC;gCACnD,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,KAAK,cAAc,GAAG,CAAC,CAAC;4BAC1D,CAAC;iCAAM,CAAC;gCACN,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,IAAI,KAAK,EAAE,CAAC,CAAC;4BAC/C,CAAC;4BACD,MAAM;wBACR,KAAK,UAAU;4BACb,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,WAAW,cAAc,IAAI,CAAC,CAAC;4BAC/D,MAAM;wBACR,KAAK,YAAY;4BACf,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,UAAU,cAAc,IAAI,CAAC,CAAC;4BAC9D,MAAM;wBACR,KAAK,UAAU;4BACb,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,WAAW,cAAc,GAAG,CAAC,CAAC;4BAC9D,MAAM;wBACR,KAAK,cAAc;4BACjB,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,IAAI,KAAK,EAAE,CAAC,CAAC;4BAC7C,MAAM;wBACR,KAAK,YAAY;4BACf,UAAU,CAAC,IAAI,CAAC,GAAG,aAAa,IAAI,KAAK,EAAE,CAAC,CAAC;4BAC7C,MAAM;wBACR,KAAK,SAAS;4BACZ,MAAM,MAAM,GAAI,KAAgB,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;4BAC7C,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gCAChC,UAAU,CAAC,IAAI,CAAC,KAAK,aAAa,IAAI,MAAM,CAAC,CAAC,CAAC,QAAQ,aAAa,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;4BACzF,CAAC;4BACD,MAAM;wBACR,KAAK,QAAQ;4BACX,MAAM,MAAM,GAAI,KAAgB,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;4BAC7C,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gCAChC,UAAU,CAAC,IAAI,CAAC,KAAK,aAAa,IAAI,MAAM,CAAC,CAAC,CAAC,QAAQ,aAAa,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;4BACzF,CAAC;4BACD,MAAM;oBACV,CAAC;gBACH,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CACV,uCAAuC,YAAY,YAAY,IAAI,CAAC,SAAS,iCAAiC,CAC/G,CAAC;QACJ,CAAC;QAED,OAAO,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACvF,CAAC;CACF","sourcesContent":["import { Class, Field, FilterContext, TextFieldTypes } from '@provoly/dashboard';\n\nexport class CqlUtils {\n  static getCQLParamsFor(\n    datasourceId: string,\n    filters: { [p: string]: FilterContext[] },\n    classes: Class[],\n    fields: Field[]\n  ): string | null {\n    if (!filters || !datasourceId || !filters[datasourceId] || filters[datasourceId].length === 0) {\n      return null;\n    }\n\n    const attributesReference = classes.map((clazz) => clazz.attributes).flat();\n\n    return filters[datasourceId]\n      .map((cond) => {\n        const attribute = attributesReference.find((attr) => attr.id === cond.attribute);\n        const field = fields.find((f) => f.id === attribute?.field);\n        const attributeName = attribute?.technicalName;\n\n        return this.getConditionsForValue(attributeName, cond, field, datasourceId);\n      })\n      .filter((conds) => conds.length > 0)\n      .join(' AND ');\n  }\n\n  static getConditionsForValue(\n    attributeName: string | undefined,\n    cond: FilterContext,\n    field: Field | undefined,\n    datasourceId: string\n  ) {\n    let conditions: string[] = [];\n\n    const values = (Array.isArray(cond.value) ? cond.value : [cond.value]) as string[] | number[];\n\n    if (attributeName) {\n      values.forEach((value) => {\n        if (value && (typeof value !== 'string' || value.length > 0)) {\n          const quoteSafeValue = `${value}`.replace(/'/g, \"''\");\n          switch (cond.operator) {\n            case 'EQUALS':\n              if (!field || TextFieldTypes.includes(field?.type)) {\n                conditions.push(`${attributeName}='${quoteSafeValue}'`);\n              } else {\n                conditions.push(`${attributeName}=${value}`);\n              }\n              break;\n            case 'CONTAINS':\n              conditions.push(`${attributeName} LIKE '%${quoteSafeValue}%'`);\n              break;\n            case 'START_WITH':\n              conditions.push(`${attributeName} LIKE '${quoteSafeValue}%'`);\n              break;\n            case 'END_WITH':\n              conditions.push(`${attributeName} LIKE '%${quoteSafeValue}'`);\n              break;\n            case 'GREATER_THAN':\n              conditions.push(`${attributeName}>${value}`);\n              break;\n            case 'LOWER_THAN':\n              conditions.push(`${attributeName}<${value}`);\n              break;\n            case 'OUTSIDE':\n              const splitI = (value as string)?.split(',');\n              if (splitI && splitI.length > 1) {\n                conditions.push(`( ${attributeName}<${splitI[0]} AND ${attributeName}>${splitI[1]} )`);\n              }\n              break;\n            case 'INSIDE':\n              const splitO = (value as string)?.split(',');\n              if (splitO && splitO.length > 1) {\n                conditions.push(`( ${attributeName}>${splitO[0]} AND ${attributeName}<${splitO[1]} )`);\n              }\n              break;\n          }\n        }\n      });\n    } else {\n      console.warn(\n        `Cannot add cql filter on datasource ${datasourceId} because ${cond.attribute} attribute not found in classes`\n      );\n    }\n\n    return conditions.length > 1 ? '( ' + conditions.join(' OR ') + ' )' : conditions[0];\n  }\n}\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cql-utils.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/utils/cql-utils.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Class, Field, FilterContext, TextFieldTypes } from '@provoly/dashboard';\n\nexport class CqlUtils {\n  static getCQLParamsFor(\n    datasourceId: string,\n    filters: { [p: string]: FilterContext[] },\n    classes: Class[],\n    fields: Field[]\n  ): string | null {\n    if (!filters || !datasourceId || !filters[datasourceId] || filters[datasourceId].length === 0) {\n      return null;\n    }\n\n    const attributesReference = classes.map((clazz) => clazz.attributes).flat();\n\n    return filters[datasourceId]\n      .map((cond) => {\n        const attribute = attributesReference.find((attr) => attr.id === cond.attribute);\n        const field = fields.find((f) => f.id === attribute?.field);\n        const attributeName = attribute?.technicalName;\n\n        return this.getConditionsForValue(attributeName, cond, field, datasourceId);\n      })\n      .filter((conds) => !!conds && conds.length > 0)\n      .join(' AND ');\n  }\n\n  static getConditionsForValue(\n    attributeName: string | undefined,\n    cond: FilterContext,\n    field: Field | undefined,\n    datasourceId: string\n  ) {\n    let conditions: string[] = [];\n\n    const values = (Array.isArray(cond.value) ? cond.value : [cond.value]) as string[] | number[];\n\n    if (attributeName) {\n      values.forEach((value) => {\n        if (value && (typeof value !== 'string' || value.length > 0)) {\n          const quoteSafeValue = `${value}`.replace(/'/g, \"''\");\n          switch (cond.operator) {\n            case 'EQUALS':\n              if (!field || TextFieldTypes.includes(field?.type)) {\n                conditions.push(`${attributeName}='${quoteSafeValue}'`);\n              } else {\n                conditions.push(`${attributeName}=${value}`);\n              }\n              break;\n            case 'CONTAINS':\n              conditions.push(`${attributeName} LIKE '%${quoteSafeValue}%'`);\n              break;\n            case 'START_WITH':\n              conditions.push(`${attributeName} LIKE '${quoteSafeValue}%'`);\n              break;\n            case 'END_WITH':\n              conditions.push(`${attributeName} LIKE '%${quoteSafeValue}'`);\n              break;\n            case 'GREATER_THAN':\n              conditions.push(`${attributeName}>${value}`);\n              break;\n            case 'LOWER_THAN':\n              conditions.push(`${attributeName}<${value}`);\n              break;\n            case 'OUTSIDE':\n              const splitI = (value as string)?.split(',');\n              if (splitI && splitI.length > 1) {\n                conditions.push(`( ${attributeName}<${splitI[0]} AND ${attributeName}>${splitI[1]} )`);\n              }\n              break;\n            case 'INSIDE':\n              const splitO = (value as string)?.split(',');\n              if (splitO && splitO.length > 1) {\n                conditions.push(`( ${attributeName}>${splitO[0]} AND ${attributeName}<${splitO[1]} )`);\n              }\n              break;\n          }\n        }\n      });\n    } else {\n      console.warn(\n        `Cannot add cql filter on datasource ${datasourceId} because ${cond.attribute} attribute not found in classes`\n      );\n    }\n\n    return conditions.length > 1 ? '( ' + conditions.join(' OR ') + ' )' : conditions[0];\n  }\n}\n"]}
@@ -283,7 +283,7 @@ class CqlUtils {
283
283
  const attributeName = attribute?.technicalName;
284
284
  return this.getConditionsForValue(attributeName, cond, field, datasourceId);
285
285
  })
286
- .filter((conds) => conds.length > 0)
286
+ .filter((conds) => !!conds && conds.length > 0)
287
287
  .join(' AND ');
288
288
  }
289
289
  static getConditionsForValue(attributeName, cond, field, datasourceId) {