@provoly/dashboard 1.4.4 → 1.4.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/filters/date/date-filter.component.mjs +21 -42
- package/esm2022/lib/core/model/filter.interface.mjs +1 -1
- package/esm2022/lib/core/store/search/search.service.mjs +10 -2
- package/esm2022/lib/core/toolbox/toolbox-menu.service.mjs +1 -1
- package/esm2022/lib/dashboard/components/widgets/widget-instanciator/widget-factory.service.mjs +5 -2
- package/esm2022/lib/dashboard/date-utils.mjs +21 -1
- package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +3 -2
- package/esm2022/lib/dashboard/widget-loader.function.mjs +15 -4
- package/esm2022/notification/components/notification/content/notification-content.component.mjs +3 -3
- package/esm2022/widgets/widget-analytic/component/widget-analytic.component.mjs +5 -2
- package/fesm2022/provoly-dashboard-filters-date.mjs +20 -41
- package/fesm2022/provoly-dashboard-filters-date.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-notification.mjs +2 -2
- package/fesm2022/provoly-dashboard-notification.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs +4 -1
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +68 -26
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/filters/date/date-filter.component.d.ts +2 -8
- package/lib/core/model/filter.interface.d.ts +1 -0
- package/lib/dashboard/components/widgets/widget-instanciator/widget-factory.service.d.ts +3 -0
- package/lib/dashboard/date-utils.d.ts +13 -0
- package/package.json +1 -1
- package/widgets/widget-analytic/component/widget-analytic.component.d.ts +1 -1
|
@@ -76,7 +76,8 @@ const datasourceFilters = createSelector(feature, (state) => state?.manifests.ma
|
|
|
76
76
|
? state?.manifests.manifest.filters.reduce((obj, filter) => (filter.attributes.forEach((attribute) => (obj[attribute.datasource] || (obj[attribute.datasource] = [])).push({
|
|
77
77
|
attribute: attribute.id,
|
|
78
78
|
operator: filter.operator ?? '',
|
|
79
|
-
value: filter.value
|
|
79
|
+
value: filter.value,
|
|
80
|
+
type: filter.type
|
|
80
81
|
})),
|
|
81
82
|
obj), {})
|
|
82
83
|
: {});
|
|
@@ -129,4 +130,4 @@ export const DashboardSelectors = {
|
|
|
129
130
|
capabilities,
|
|
130
131
|
layerGroups
|
|
131
132
|
};
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.selectors.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/dashboard.selectors.ts"],"names":[],"mappings":"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","sourcesContent":["import { createFeatureSelector, createSelector, MemoizedSelector } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { Filter, FilterContext } from '../../core/model/filter.interface';\nimport { Item } from '../../core/model/item.interface';\nimport {\n  DashboardGridLayout,\n  DashboardManifest,\n  GlobalManifest,\n  WidgetLayout,\n  WidgetManifest\n} from '../../core/model/manifest.interface';\nimport { ResultOrder } from '../../core/model/result-order.interface';\nimport { ResultSet, ResultSets } from '../../core/model/result-set.interface';\nimport { DashboardCellParams } from './dashboard.actions';\nimport { DashboardState } from './dashboard.reducers';\nimport { BASE_DISPLAY_OPTIONS } from '../../core/model/display-options.interface';\n\nconst NEW_WINDOW_TARGET = -1;\n\nconst feature = createFeatureSelector<DashboardState>('@pry/dashboard');\nconst manifests = createSelector(feature, (state: DashboardState) => state?.manifests);\nconst rank = createSelector(manifests, (manifests) => manifests?.tenants.indexOf(manifests.sender));\nconst currentManifestId = createSelector(manifests, (manifests) => manifests.currentId);\nconst globalManifest = createSelector(\n  manifests,\n  // @ts-ignore\n  (manifests) => ({ windows: [], ...manifests?.manifest }) ?? ({ windows: [] } as GlobalManifest)\n);\nconst staticManifest = createSelector(\n  manifests,\n  // @ts-ignore\n  (manifests) => ({ windows: [], ...manifests?.staticManifest }) ?? ({ windows: [] } as GlobalManifest)\n);\nconst loading = createSelector(manifests, (manifests) => !!manifests?.loading);\nconst refreshRates = createSelector(globalManifest, (manifests) => manifests.refreshRates ?? {});\nconst windowManifest = createSelector(\n  globalManifest,\n  rank,\n  (manifest, rank) => manifest.windows[rank] ?? <DashboardManifest>{ widgets: [] }\n);\nconst gridLayout = createSelector(\n  windowManifest,\n  (manifest) => ((manifest.grid ?? {}).layout ?? DashboardGridLayout.MANUAL) as string\n);\nconst memoizeWidgetManifest = {} as any;\nconst widgetManifest = (index: number) => {\n  if (!memoizeWidgetManifest[index]) {\n    memoizeWidgetManifest[index] = createSelector(\n      windowManifest,\n      (windowManifest: DashboardManifest) =>\n        windowManifest.widgets[index] ??\n        ({\n          type: 'placeholder',\n          layout: { x: 1, y: 1, width: 1, height: 1 }\n        } as WidgetManifest)\n    );\n  }\n  return memoizeWidgetManifest[index] as MemoizedSelector<DashboardManifest, WidgetManifest>;\n};\nconst manifestsList = createSelector(manifests, (manifests) => manifests.list);\nconst tenants = createSelector(manifests, (manifests) => manifests.tenants ?? <string[]>[]);\nconst targetTenantsIndexes = createSelector(manifests, rank, (manifests, rank) => [\n  NEW_WINDOW_TARGET,\n  ...(manifests.tenants ?? ([] as string[])).map((ten, idx) => idx).filter((idx) => idx !== rank)\n]);\nconst results = createSelector(feature, (state: DashboardState) => state?.results);\n\nconst resultSets = createSelector(results, (results) => results.resultSets ?? ({} as ResultSets));\nconst resultSetsParams = createSelector(\n  results,\n  (results) => results.resultSetsParams ?? ({} as { [id: string]: string | undefined })\n);\nconst namedQueriesNames = createSelector(resultSets, (state: ResultSets) => Object.keys(state) ?? <string[]>[]);\nconst availableNamedQueries = createSelector(results, (results) => {\n  return [...new Set([...results.availableDatasourceNames, ...Object.keys(results.resultSets)])];\n});\nconst defaultDatasourceNames = createSelector(results, (results) => results.defaultDatasource ?? 'current');\nconst selectedItemIds = createSelector(results, (results) => results.selectedItems ?? ([] as string[]));\nconst objectDetails = createSelector(results, (results) => results.objectDetails ?? ({} as { [id: string]: Item }));\nconst quickOrder = createSelector(results, (results) => results.quickOrder ?? ({} as { [id: string]: ResultOrder }));\nconst allItems = createSelector(results, (results) =>\n  Object.keys(results.resultSets)\n    .map((rsKey) =>\n      Object.keys(results.resultSets[rsKey].items)\n        .map((classKey) => (results.resultSets[rsKey] as ResultSet).items[classKey])\n        .reduce((p, c) => [...p, ...c], [])\n    )\n    .reduce((p, c) => [...p, ...c], [])\n);\nconst getItemsByIds = (ids: string[]) =>\n  createSelector(allItems, (items) => items.filter((item) => ids.includes(item.id)));\nconst selectedItems = createSelector(\n  selectedItemIds,\n  allItems,\n  (itemNames, allItems) => itemNames.map((name) => allItems.find((it) => it.id === name)) ?? ([] as Item[])\n);\nconst dashboard = createSelector(feature, (state: DashboardState) => state?.dashboard ?? {});\nconst dashboardCellParams = createSelector(dashboard, (dashboard) => dashboard.params ?? <DashboardCellParams>{});\nconst dashboardEditionMode = createSelector(dashboard, (dashboard) => dashboard.editionMode ?? false);\nconst namedQueriesUses = createSelector(globalManifest, (manifest) =>\n  manifest.windows\n    .map((window, idx) => ({ windowIndex: idx, widgets: window.widgets }))\n    .map(({ windowIndex, widgets }) =>\n      (widgets ?? []).map((widget) =>\n        (Array.isArray(widget.datasource) ? widget.datasource : [widget.datasource])\n          .filter((rsName) => rsName !== undefined)\n          .map((rsName) => ({\n            rsName,\n            windowIndex,\n            type: widget.type,\n            layout: widget.layout\n          }))\n      )\n    )\n    .reduce((p, c) => [...p, ...c], [])\n    .reduce((p, c) => [...p, ...c], [])\n    .reduce(\n      (p, c) => ({ ...p, [c.rsName ?? '']: [...(p[c.rsName ?? ''] || []), { ...c }] }),\n      {} as { [key: string]: { windowIndex: number; type: string; layout: WidgetLayout; rsName?: string }[] }\n    )\n);\nconst presentation = createSelector(feature, (state: DashboardState) => state?.presentation);\nconst isCurrentPresentationModified = createSelector(\n  presentation,\n  globalManifest,\n  (state, global) => !equal(global, state.initial)\n);\nconst currentManifest = createSelector(feature, (state: DashboardState) => state?.presentation.current);\n\nconst filters = createSelector(feature, (state: DashboardState) => state?.manifests.manifest.filters ?? []);\nconst datasourceFilters = createSelector(feature, (state: DashboardState) =>\n  state?.manifests.manifest.filters\n    ? state?.manifests.manifest.filters.reduce(\n        (obj: { [datasourceId: string]: FilterContext[] }, filter: Filter) => (\n          filter.attributes.forEach((attribute) =>\n            (obj[attribute.datasource] || (obj[attribute.datasource] = [])).push({\n              attribute: attribute.id,\n              operator: filter.operator ?? '',\n              value: filter.value\n            })\n          ),\n          obj\n        ),\n        {}\n      )\n    : {}\n);\n\nconst memoizeFeatures = {} as { [key: string]: any };\nconst wmsFeatures = (componentId: string) => {\n  if (!memoizeFeatures[componentId]) {\n    memoizeFeatures[componentId] = createSelector(\n      feature,\n      (state: DashboardState) => state.wmsFeatures[componentId] ?? []\n    );\n  }\n  return memoizeFeatures[componentId] as MemoizedSelector<object, any[], (s1: DashboardState) => any[]>;\n};\n\nconst displayOptions = createSelector(feature, (state: DashboardState) => state?.display ?? BASE_DISPLAY_OPTIONS);\nconst capabilities = createSelector(feature, (state: DashboardState) => state?.capabilities);\nconst layerGroups = createSelector(feature, (state: DashboardState) => state?.manifests.manifest.layerGroups ?? []);\n\nexport const DashboardSelectors = {\n  feature,\n  rank,\n  currentManifestId,\n  globalManifest,\n  refreshRates,\n  windowManifest,\n  widgetManifest,\n  manifestsList,\n  gridLayout,\n  tenants,\n  resultSets,\n  resultSetsParams,\n  namedQueriesNames,\n  namedQueriesUses,\n  availableNamedQueries,\n  defaultDatasourceNames,\n  selectedItemIds,\n  allItems,\n  getItemsByIds,\n  selectedItems,\n  objectDetails,\n  targetTenantsIndexes,\n  dashboard,\n  dashboardCellParams,\n  dashboardEditionMode,\n  staticManifest,\n  loading,\n  quickOrder,\n  presentation,\n  currentManifest,\n  filters,\n  isCurrentPresentationModified,\n  datasourceFilters,\n  wmsFeatures,\n  displayOptions,\n  capabilities,\n  layerGroups\n};\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.selectors.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/dashboard.selectors.ts"],"names":[],"mappings":"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","sourcesContent":["import { createFeatureSelector, createSelector, MemoizedSelector } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { Filter, FilterContext } from '../../core/model/filter.interface';\nimport { Item } from '../../core/model/item.interface';\nimport {\n  DashboardGridLayout,\n  DashboardManifest,\n  GlobalManifest,\n  WidgetLayout,\n  WidgetManifest\n} from '../../core/model/manifest.interface';\nimport { ResultOrder } from '../../core/model/result-order.interface';\nimport { ResultSet, ResultSets } from '../../core/model/result-set.interface';\nimport { DashboardCellParams } from './dashboard.actions';\nimport { DashboardState } from './dashboard.reducers';\nimport { BASE_DISPLAY_OPTIONS } from '../../core/model/display-options.interface';\n\nconst NEW_WINDOW_TARGET = -1;\n\nconst feature = createFeatureSelector<DashboardState>('@pry/dashboard');\nconst manifests = createSelector(feature, (state: DashboardState) => state?.manifests);\nconst rank = createSelector(manifests, (manifests) => manifests?.tenants.indexOf(manifests.sender));\nconst currentManifestId = createSelector(manifests, (manifests) => manifests.currentId);\nconst globalManifest = createSelector(\n  manifests,\n  // @ts-ignore\n  (manifests) => ({ windows: [], ...manifests?.manifest }) ?? ({ windows: [] } as GlobalManifest)\n);\nconst staticManifest = createSelector(\n  manifests,\n  // @ts-ignore\n  (manifests) => ({ windows: [], ...manifests?.staticManifest }) ?? ({ windows: [] } as GlobalManifest)\n);\nconst loading = createSelector(manifests, (manifests) => !!manifests?.loading);\nconst refreshRates = createSelector(globalManifest, (manifests) => manifests.refreshRates ?? {});\nconst windowManifest = createSelector(\n  globalManifest,\n  rank,\n  (manifest, rank) => manifest.windows[rank] ?? <DashboardManifest>{ widgets: [] }\n);\nconst gridLayout = createSelector(\n  windowManifest,\n  (manifest) => ((manifest.grid ?? {}).layout ?? DashboardGridLayout.MANUAL) as string\n);\nconst memoizeWidgetManifest = {} as any;\nconst widgetManifest = (index: number) => {\n  if (!memoizeWidgetManifest[index]) {\n    memoizeWidgetManifest[index] = createSelector(\n      windowManifest,\n      (windowManifest: DashboardManifest) =>\n        windowManifest.widgets[index] ??\n        ({\n          type: 'placeholder',\n          layout: { x: 1, y: 1, width: 1, height: 1 }\n        } as WidgetManifest)\n    );\n  }\n  return memoizeWidgetManifest[index] as MemoizedSelector<DashboardManifest, WidgetManifest>;\n};\nconst manifestsList = createSelector(manifests, (manifests) => manifests.list);\nconst tenants = createSelector(manifests, (manifests) => manifests.tenants ?? <string[]>[]);\nconst targetTenantsIndexes = createSelector(manifests, rank, (manifests, rank) => [\n  NEW_WINDOW_TARGET,\n  ...(manifests.tenants ?? ([] as string[])).map((ten, idx) => idx).filter((idx) => idx !== rank)\n]);\nconst results = createSelector(feature, (state: DashboardState) => state?.results);\n\nconst resultSets = createSelector(results, (results) => results.resultSets ?? ({} as ResultSets));\nconst resultSetsParams = createSelector(\n  results,\n  (results) => results.resultSetsParams ?? ({} as { [id: string]: string | undefined })\n);\nconst namedQueriesNames = createSelector(resultSets, (state: ResultSets) => Object.keys(state) ?? <string[]>[]);\nconst availableNamedQueries = createSelector(results, (results) => {\n  return [...new Set([...results.availableDatasourceNames, ...Object.keys(results.resultSets)])];\n});\nconst defaultDatasourceNames = createSelector(results, (results) => results.defaultDatasource ?? 'current');\nconst selectedItemIds = createSelector(results, (results) => results.selectedItems ?? ([] as string[]));\nconst objectDetails = createSelector(results, (results) => results.objectDetails ?? ({} as { [id: string]: Item }));\nconst quickOrder = createSelector(results, (results) => results.quickOrder ?? ({} as { [id: string]: ResultOrder }));\nconst allItems = createSelector(results, (results) =>\n  Object.keys(results.resultSets)\n    .map((rsKey) =>\n      Object.keys(results.resultSets[rsKey].items)\n        .map((classKey) => (results.resultSets[rsKey] as ResultSet).items[classKey])\n        .reduce((p, c) => [...p, ...c], [])\n    )\n    .reduce((p, c) => [...p, ...c], [])\n);\nconst getItemsByIds = (ids: string[]) =>\n  createSelector(allItems, (items) => items.filter((item) => ids.includes(item.id)));\nconst selectedItems = createSelector(\n  selectedItemIds,\n  allItems,\n  (itemNames, allItems) => itemNames.map((name) => allItems.find((it) => it.id === name)) ?? ([] as Item[])\n);\nconst dashboard = createSelector(feature, (state: DashboardState) => state?.dashboard ?? {});\nconst dashboardCellParams = createSelector(dashboard, (dashboard) => dashboard.params ?? <DashboardCellParams>{});\nconst dashboardEditionMode = createSelector(dashboard, (dashboard) => dashboard.editionMode ?? false);\nconst namedQueriesUses = createSelector(globalManifest, (manifest) =>\n  manifest.windows\n    .map((window, idx) => ({ windowIndex: idx, widgets: window.widgets }))\n    .map(({ windowIndex, widgets }) =>\n      (widgets ?? []).map((widget) =>\n        (Array.isArray(widget.datasource) ? widget.datasource : [widget.datasource])\n          .filter((rsName) => rsName !== undefined)\n          .map((rsName) => ({\n            rsName,\n            windowIndex,\n            type: widget.type,\n            layout: widget.layout\n          }))\n      )\n    )\n    .reduce((p, c) => [...p, ...c], [])\n    .reduce((p, c) => [...p, ...c], [])\n    .reduce(\n      (p, c) => ({ ...p, [c.rsName ?? '']: [...(p[c.rsName ?? ''] || []), { ...c }] }),\n      {} as { [key: string]: { windowIndex: number; type: string; layout: WidgetLayout; rsName?: string }[] }\n    )\n);\nconst presentation = createSelector(feature, (state: DashboardState) => state?.presentation);\nconst isCurrentPresentationModified = createSelector(\n  presentation,\n  globalManifest,\n  (state, global) => !equal(global, state.initial)\n);\nconst currentManifest = createSelector(feature, (state: DashboardState) => state?.presentation.current);\n\nconst filters = createSelector(feature, (state: DashboardState) => state?.manifests.manifest.filters ?? []);\nconst datasourceFilters = createSelector(feature, (state: DashboardState) =>\n  state?.manifests.manifest.filters\n    ? state?.manifests.manifest.filters.reduce(\n        (obj: { [datasourceId: string]: FilterContext[] }, filter: Filter) => (\n          filter.attributes.forEach((attribute) =>\n            (obj[attribute.datasource] || (obj[attribute.datasource] = [])).push({\n              attribute: attribute.id,\n              operator: filter.operator ?? '',\n              value: filter.value,\n              type: filter.type\n            })\n          ),\n          obj\n        ),\n        {}\n      )\n    : {}\n);\n\nconst memoizeFeatures = {} as { [key: string]: any };\nconst wmsFeatures = (componentId: string) => {\n  if (!memoizeFeatures[componentId]) {\n    memoizeFeatures[componentId] = createSelector(\n      feature,\n      (state: DashboardState) => state.wmsFeatures[componentId] ?? []\n    );\n  }\n  return memoizeFeatures[componentId] as MemoizedSelector<object, any[], (s1: DashboardState) => any[]>;\n};\n\nconst displayOptions = createSelector(feature, (state: DashboardState) => state?.display ?? BASE_DISPLAY_OPTIONS);\nconst capabilities = createSelector(feature, (state: DashboardState) => state?.capabilities);\nconst layerGroups = createSelector(feature, (state: DashboardState) => state?.manifests.manifest.layerGroups ?? []);\n\nexport const DashboardSelectors = {\n  feature,\n  rank,\n  currentManifestId,\n  globalManifest,\n  refreshRates,\n  windowManifest,\n  widgetManifest,\n  manifestsList,\n  gridLayout,\n  tenants,\n  resultSets,\n  resultSetsParams,\n  namedQueriesNames,\n  namedQueriesUses,\n  availableNamedQueries,\n  defaultDatasourceNames,\n  selectedItemIds,\n  allItems,\n  getItemsByIds,\n  selectedItems,\n  objectDetails,\n  targetTenantsIndexes,\n  dashboard,\n  dashboardCellParams,\n  dashboardEditionMode,\n  staticManifest,\n  loading,\n  quickOrder,\n  presentation,\n  currentManifest,\n  filters,\n  isCurrentPresentationModified,\n  datasourceFilters,\n  wmsFeatures,\n  displayOptions,\n  capabilities,\n  layerGroups\n};\n"]}
|
|
@@ -1,16 +1,27 @@
|
|
|
1
1
|
import { createNgModule, Injector } from '@angular/core';
|
|
2
2
|
import { WidgetPlaceholderComponent } from './components/widgets/widget-placeholder/widget-placeholder.component';
|
|
3
3
|
const moduleRefCache = {};
|
|
4
|
+
const standaloneRefCache = {};
|
|
4
5
|
export function widgetLoader(module, prop) {
|
|
5
6
|
return (injector) => {
|
|
7
|
+
const standalone = prop.endsWith('Component');
|
|
6
8
|
if (!!moduleRefCache[prop]) {
|
|
7
9
|
return moduleRefCache[prop].getComponent();
|
|
8
10
|
}
|
|
11
|
+
else if (!!standaloneRefCache[prop]) {
|
|
12
|
+
return standaloneRefCache[prop];
|
|
13
|
+
}
|
|
9
14
|
else {
|
|
10
15
|
if (!!module[prop]) {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
16
|
+
if (!standalone) {
|
|
17
|
+
const moduleRef = createNgModule(module[prop], Injector.create({ parent: injector, providers: [] }));
|
|
18
|
+
moduleRefCache[prop] = moduleRef.instance;
|
|
19
|
+
return moduleRefCache[prop].getComponent();
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
standaloneRefCache[prop] = module[prop];
|
|
23
|
+
return standaloneRefCache[prop];
|
|
24
|
+
}
|
|
14
25
|
}
|
|
15
26
|
else {
|
|
16
27
|
console.error(`module has no property ${prop}`, module);
|
|
@@ -19,4 +30,4 @@ export function widgetLoader(module, prop) {
|
|
|
19
30
|
}
|
|
20
31
|
};
|
|
21
32
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWxvYWRlci5mdW5jdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9kYXNoYm9hcmQvd2lkZ2V0LWxvYWRlci5mdW5jdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQztBQUlsSCxNQUFNLGNBQWMsR0FBRyxFQUFnRCxDQUFDO0FBQ3hFLE1BQU0sa0JBQWtCLEdBQUcsRUFBbUQsQ0FBQztBQUUvRSxNQUFNLFVBQVUsWUFBWSxDQUFDLE1BQVcsRUFBRSxJQUFZO0lBQ3BELE9BQU8sQ0FBQyxRQUFrQixFQUFFLEVBQUU7UUFDNUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUMzQixPQUFPLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxZQUFZLEVBQTBDLENBQUM7UUFDckYsQ0FBQzthQUFNLElBQUksQ0FBQyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDdEMsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQXlDLENBQUM7UUFDMUUsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztnQkFDbkIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUNoQixNQUFNLFNBQVMsR0FBRyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7b0JBQ3JHLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxTQUFTLENBQUMsUUFBNEIsQ0FBQztvQkFDOUQsT0FBTyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsWUFBWSxFQUEwQyxDQUFDO2dCQUNyRixDQUFDO3FCQUFNLENBQUM7b0JBQ04sa0JBQWtCLENBQUMsSUFBSSxDQUFDLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUN4QyxPQUFPLGtCQUFrQixDQUFDLElBQUksQ0FBeUMsQ0FBQztnQkFDMUUsQ0FBQztZQUNILENBQUM7aUJBQU0sQ0FBQztnQkFDTixPQUFPLENBQUMsS0FBSyxDQUFDLDBCQUEwQixJQUFJLEVBQUUsRUFBRSxNQUFNLENBQUMsQ0FBQztnQkFDeEQsT0FBTywwQkFBMEIsQ0FBQztZQUNwQyxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVOZ01vZHVsZSwgSW5qZWN0b3IsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFdpZGdldFBsYWNlaG9sZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3dpZGdldHMvd2lkZ2V0LXBsYWNlaG9sZGVyL3dpZGdldC1wbGFjZWhvbGRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFzZVdpZGdldE1vZHVsZSB9IGZyb20gJy4vYmFzZS13aWRnZXQubW9kdWxlJztcbmltcG9ydCB7IEJhc2VXaWRnZXRDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvd2lkZ2V0cy9iYXNlLXdpZGdldC5jb21wb25lbnQnO1xuXG5jb25zdCBtb2R1bGVSZWZDYWNoZSA9IHt9IGFzIHsgW21vZHVsZU5hbWU6IHN0cmluZ106IEJhc2VXaWRnZXRNb2R1bGUgfTtcbmNvbnN0IHN0YW5kYWxvbmVSZWZDYWNoZSA9IHt9IGFzIHsgW21vZHVsZU5hbWU6IHN0cmluZ106IEJhc2VXaWRnZXRDb21wb25lbnQgfTtcblxuZXhwb3J0IGZ1bmN0aW9uIHdpZGdldExvYWRlcihtb2R1bGU6IGFueSwgcHJvcDogc3RyaW5nKTogKGluamVjdG9yOiBJbmplY3RvcikgPT4gVHlwZTxCYXNlV2lkZ2V0Q29tcG9uZW50PiB7XG4gIHJldHVybiAoaW5qZWN0b3I6IEluamVjdG9yKSA9PiB7XG4gICAgY29uc3Qgc3RhbmRhbG9uZSA9IHByb3AuZW5kc1dpdGgoJ0NvbXBvbmVudCcpO1xuICAgIGlmICghIW1vZHVsZVJlZkNhY2hlW3Byb3BdKSB7XG4gICAgICByZXR1cm4gbW9kdWxlUmVmQ2FjaGVbcHJvcF0uZ2V0Q29tcG9uZW50KCkgYXMgdW5rbm93biBhcyBUeXBlPEJhc2VXaWRnZXRDb21wb25lbnQ+O1xuICAgIH0gZWxzZSBpZiAoISFzdGFuZGFsb25lUmVmQ2FjaGVbcHJvcF0pIHtcbiAgICAgIHJldHVybiBzdGFuZGFsb25lUmVmQ2FjaGVbcHJvcF0gYXMgdW5rbm93biBhcyBUeXBlPEJhc2VXaWRnZXRDb21wb25lbnQ+O1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoISFtb2R1bGVbcHJvcF0pIHtcbiAgICAgICAgaWYgKCFzdGFuZGFsb25lKSB7XG4gICAgICAgICAgY29uc3QgbW9kdWxlUmVmID0gY3JlYXRlTmdNb2R1bGUobW9kdWxlW3Byb3BdLCBJbmplY3Rvci5jcmVhdGUoeyBwYXJlbnQ6IGluamVjdG9yLCBwcm92aWRlcnM6IFtdIH0pKTtcbiAgICAgICAgICBtb2R1bGVSZWZDYWNoZVtwcm9wXSA9IG1vZHVsZVJlZi5pbnN0YW5jZSBhcyBCYXNlV2lkZ2V0TW9kdWxlO1xuICAgICAgICAgIHJldHVybiBtb2R1bGVSZWZDYWNoZVtwcm9wXS5nZXRDb21wb25lbnQoKSBhcyB1bmtub3duIGFzIFR5cGU8QmFzZVdpZGdldENvbXBvbmVudD47XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc3RhbmRhbG9uZVJlZkNhY2hlW3Byb3BdID0gbW9kdWxlW3Byb3BdO1xuICAgICAgICAgIHJldHVybiBzdGFuZGFsb25lUmVmQ2FjaGVbcHJvcF0gYXMgdW5rbm93biBhcyBUeXBlPEJhc2VXaWRnZXRDb21wb25lbnQ+O1xuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zb2xlLmVycm9yKGBtb2R1bGUgaGFzIG5vIHByb3BlcnR5ICR7cHJvcH1gLCBtb2R1bGUpO1xuICAgICAgICByZXR1cm4gV2lkZ2V0UGxhY2Vob2xkZXJDb21wb25lbnQ7XG4gICAgICB9XG4gICAgfVxuICB9O1xufVxuIl19
|
package/esm2022/notification/components/notification/content/notification-content.component.mjs
CHANGED
|
@@ -52,11 +52,11 @@ export class PryNotificationContentComponent {
|
|
|
52
52
|
return this.i18nService.instant(translationBase + title) !== translationBase + title;
|
|
53
53
|
}
|
|
54
54
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PryNotificationContentComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i3.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
55
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: PryNotificationContentComponent, selector: "pry-notification-content", outputs: { closed: "closed" }, host: { listeners: { "window:resize": "ngDoCheck()" } }, viewQueries: [{ propertyName: "caret", first: true, predicate: ["caret"], descendants: true }, { propertyName: "button", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<div\n class=\"m-notifications-list\"\n id=\"notifications_list\"\n aria-labelledby=\"read_notifications\"\n aria-hidden=\"false\"\n #caret\n (keydown.escape)=\"closeToEscape()\"\n>\n <span class=\"caret-top\" [style.left.px]=\"left\"></span>\n <div class=\"m-notifications-list__header\">\n <h2 class=\"a-h2\">{{ '@pry.notif.label' | i18n }}</h2>\n <p class=\"a-p none\" *ngIf=\"(notifications$ | async)?.length === 0; else notification\">\n {{ '@pry.notif.noNotifications' | i18n }}\n </p>\n <ng-template #notification>\n <div class=\"m-btn-group\">\n <button type=\"button\" #button class=\"a-btn a-btn--primary\" (click)=\"deleteAll()\">\n {{ '@pry.notif.deleteAll' | i18n
|
|
55
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: PryNotificationContentComponent, selector: "pry-notification-content", outputs: { closed: "closed" }, host: { listeners: { "window:resize": "ngDoCheck()" } }, viewQueries: [{ propertyName: "caret", first: true, predicate: ["caret"], descendants: true }, { propertyName: "button", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<div\n class=\"m-notifications-list\"\n id=\"notifications_list\"\n aria-labelledby=\"read_notifications\"\n aria-hidden=\"false\"\n #caret\n (keydown.escape)=\"closeToEscape()\"\n>\n <span class=\"caret-top\" [style.left.px]=\"left\"></span>\n <div class=\"m-notifications-list__header\">\n <h2 class=\"a-h2\">{{ '@pry.notif.label' | i18n }}</h2>\n <p class=\"a-p none\" *ngIf=\"(notifications$ | async)?.length === 0; else notification\">\n {{ '@pry.notif.noNotifications' | i18n }}\n </p>\n <ng-template #notification>\n <div class=\"m-btn-group\">\n <button type=\"button\" #button class=\"a-btn a-btn--primary\" (click)=\"deleteAll()\">\n {{ '@pry.notif.deleteAll' | i18n: { count: (notifications$ | async)?.length } }}\n </button>\n </div>\n </ng-template>\n </div>\n <div class=\"m-notifications-list__content\">\n <ul class=\"m-notifications-list__items\">\n <li class=\"m-notifications-list__items__li\" *ngFor=\"let notification of notifications$ | async; let last = last\">\n <div class=\"m-notifications-list__items__li__txt\">\n <h3 class=\"a-h3\">\n {{\n hasTranslation(notification.text.code, '@pry.notif.title.')\n ? ('@pry.notif.title.' + notification.text.code | i18n: notification.text.param)\n : notification.text.title\n }}\n <span>{{ notification.creationDate | date: \"dd/MM' 'H':'mm\" }}</span>\n </h3>\n <p class=\"a-p desc\">\n {{\n hasTranslation(notification.text.code, '@pry.notif.title.')\n ? ('@pry.notif.message.' + notification.text.code | i18n: notification.text.param)\n : notification.text.code\n }}\n </p>\n <a *ngIf=\"!!notification.link\" (click)=\"goTo(notification)\">\n {{ '@pry.notif.link' | i18n }}\n </a>\n </div>\n <button\n class=\"a-btn a-btn--delete\"\n (click)=\"delete(notification)\"\n (keydown.tab)=\"last ? closeToEscape() : null\"\n title=\"{{ '@pry.notif.delete' | i18n }}\"\n >\n <pry-icon [height]=\"20\" [width]=\"20\" iconSvg=\"close\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.notif.delete' | i18n }}</span>\n </button>\n </li>\n </ul>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.DatePipe, name: "date" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
|
|
56
56
|
}
|
|
57
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PryNotificationContentComponent, decorators: [{
|
|
58
58
|
type: Component,
|
|
59
|
-
args: [{ selector: 'pry-notification-content', template: "<div\n class=\"m-notifications-list\"\n id=\"notifications_list\"\n aria-labelledby=\"read_notifications\"\n aria-hidden=\"false\"\n #caret\n (keydown.escape)=\"closeToEscape()\"\n>\n <span class=\"caret-top\" [style.left.px]=\"left\"></span>\n <div class=\"m-notifications-list__header\">\n <h2 class=\"a-h2\">{{ '@pry.notif.label' | i18n }}</h2>\n <p class=\"a-p none\" *ngIf=\"(notifications$ | async)?.length === 0; else notification\">\n {{ '@pry.notif.noNotifications' | i18n }}\n </p>\n <ng-template #notification>\n <div class=\"m-btn-group\">\n <button type=\"button\" #button class=\"a-btn a-btn--primary\" (click)=\"deleteAll()\">\n {{ '@pry.notif.deleteAll' | i18n
|
|
59
|
+
args: [{ selector: 'pry-notification-content', template: "<div\n class=\"m-notifications-list\"\n id=\"notifications_list\"\n aria-labelledby=\"read_notifications\"\n aria-hidden=\"false\"\n #caret\n (keydown.escape)=\"closeToEscape()\"\n>\n <span class=\"caret-top\" [style.left.px]=\"left\"></span>\n <div class=\"m-notifications-list__header\">\n <h2 class=\"a-h2\">{{ '@pry.notif.label' | i18n }}</h2>\n <p class=\"a-p none\" *ngIf=\"(notifications$ | async)?.length === 0; else notification\">\n {{ '@pry.notif.noNotifications' | i18n }}\n </p>\n <ng-template #notification>\n <div class=\"m-btn-group\">\n <button type=\"button\" #button class=\"a-btn a-btn--primary\" (click)=\"deleteAll()\">\n {{ '@pry.notif.deleteAll' | i18n: { count: (notifications$ | async)?.length } }}\n </button>\n </div>\n </ng-template>\n </div>\n <div class=\"m-notifications-list__content\">\n <ul class=\"m-notifications-list__items\">\n <li class=\"m-notifications-list__items__li\" *ngFor=\"let notification of notifications$ | async; let last = last\">\n <div class=\"m-notifications-list__items__li__txt\">\n <h3 class=\"a-h3\">\n {{\n hasTranslation(notification.text.code, '@pry.notif.title.')\n ? ('@pry.notif.title.' + notification.text.code | i18n: notification.text.param)\n : notification.text.title\n }}\n <span>{{ notification.creationDate | date: \"dd/MM' 'H':'mm\" }}</span>\n </h3>\n <p class=\"a-p desc\">\n {{\n hasTranslation(notification.text.code, '@pry.notif.title.')\n ? ('@pry.notif.message.' + notification.text.code | i18n: notification.text.param)\n : notification.text.code\n }}\n </p>\n <a *ngIf=\"!!notification.link\" (click)=\"goTo(notification)\">\n {{ '@pry.notif.link' | i18n }}\n </a>\n </div>\n <button\n class=\"a-btn a-btn--delete\"\n (click)=\"delete(notification)\"\n (keydown.tab)=\"last ? closeToEscape() : null\"\n title=\"{{ '@pry.notif.delete' | i18n }}\"\n >\n <pry-icon [height]=\"20\" [width]=\"20\" iconSvg=\"close\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.notif.delete' | i18n }}</span>\n </button>\n </li>\n </ul>\n </div>\n</div>\n" }]
|
|
60
60
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i3.PryI18nService }], propDecorators: { closed: [{
|
|
61
61
|
type: Output
|
|
62
62
|
}], caret: [{
|
|
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
69
69
|
type: HostListener,
|
|
70
70
|
args: ['window:resize']
|
|
71
71
|
}] } });
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-content.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/notification/components/notification/content/notification-content.component.ts","../../../../../../../../projects/provoly/dashboard/notification/components/notification/content/notification-content.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAGT,YAAY,EACZ,YAAY,EACZ,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AAKvB,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;;;;;;AAM9E,MAAM,OAAO,+BAA+B;IAQ1C,YACY,KAAY,EACd,MAAc,EACd,WAA2B;QAFzB,UAAK,GAAL,KAAK,CAAO;QACd,WAAM,GAAN,MAAM,CAAQ;QACd,gBAAW,GAAX,WAAW,CAAgB;QAVrC,SAAI,GAAY,KAAK,CAAC;QAEZ,WAAM,GAAG,IAAI,YAAY,EAAW,CAAC;QAG/C,SAAI,GAAW,CAAC,CAAC;QAOf,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK;aAC7B,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC;aAClC,IAAI,CACH,GAAG,CAAC,CAAC,aAAgC,EAAE,EAAE,CACvC,CAAC,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAC9E,CACF,CAAC;IACN,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;QACrC,CAAC;IACH,CAAC;IAGD,SAAS;QACP,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,GAAG,EAAE,CAAC;QACxD,CAAC;IACH,CAAC;IAED,MAAM,CAAC,YAA6B;QAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAED,SAAS;QACP,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,CAAC,YAA6B;QAChC,MAAM,IAAI,GAAG,YAAY,CAAC,IAAI,IAAI,EAAE,CAAC;QACrC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5B,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QAC9B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAED,cAAc,CAAC,KAAa,EAAE,eAAuB;QACnD,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,eAAe,GAAG,KAAK,CAAC,KAAK,eAAe,GAAG,KAAK,CAAC;IACvF,CAAC;8GA3DU,+BAA+B;kGAA/B,+BAA+B,2UCtB5C,w3EA0DA;;2FDpCa,+BAA+B;kBAJ3C,SAAS;+BACE,0BAA0B;4HAM1B,MAAM;sBAAf,MAAM;gBACa,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBACG,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAwBnB,SAAS;sBADR,YAAY;uBAAC,eAAe","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport { PryI18nService, PryNotification } from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { NotificationActions } from '../../../store/notification.actions';\nimport { NotificationSelectors } from '../../../store/notification.selectors';\n\n@Component({\n  selector: 'pry-notification-content',\n  templateUrl: './notification-content.component.html'\n})\nexport class PryNotificationContentComponent implements DoCheck, AfterViewInit {\n  open: boolean = false;\n  notifications$: Observable<PryNotification[]>;\n  @Output() closed = new EventEmitter<boolean>();\n  @ViewChild('caret') caret!: ElementRef;\n  @ViewChild('button') button!: ElementRef<HTMLButtonElement>;\n  left: number = 0;\n\n  constructor(\n    protected store: Store,\n    private router: Router,\n    private i18nService: PryI18nService\n  ) {\n    this.notifications$ = this.store\n      .select(NotificationSelectors.list)\n      .pipe(\n        map((notifications: PryNotification[]) =>\n          [...notifications].sort((a, b) => (a.creationDate < b.creationDate ? 1 : -1))\n        )\n      );\n  }\n\n  ngAfterViewInit() {\n    if (!this.open) {\n      this.button?.nativeElement.focus();\n    }\n  }\n\n  @HostListener('window:resize')\n  ngDoCheck() {\n    if (this.caret) {\n      this.left = this.caret.nativeElement.offsetWidth - 48;\n    }\n  }\n\n  delete(notification: PryNotification) {\n    this.store.dispatch(NotificationActions.delete({ id: notification.id }));\n  }\n\n  deleteAll() {\n    this.store.dispatch(NotificationActions.deleteAll());\n  }\n\n  goTo(notification: PryNotification) {\n    const link = notification.link ?? '';\n    if (link.startsWith('http')) {\n      window.location.href = link;\n    } else {\n      this.router.navigateByUrl(notification.link ?? '');\n    }\n    this.closed.next(true);\n  }\n\n  closeToEscape() {\n    this.closed.next(true);\n  }\n\n  hasTranslation(title: string, translationBase: string) {\n    return this.i18nService.instant(translationBase + title) !== translationBase + title;\n  }\n}\n","<div\n  class=\"m-notifications-list\"\n  id=\"notifications_list\"\n  aria-labelledby=\"read_notifications\"\n  aria-hidden=\"false\"\n  #caret\n  (keydown.escape)=\"closeToEscape()\"\n>\n  <span class=\"caret-top\" [style.left.px]=\"left\"></span>\n  <div class=\"m-notifications-list__header\">\n    <h2 class=\"a-h2\">{{ '@pry.notif.label' | i18n }}</h2>\n    <p class=\"a-p none\" *ngIf=\"(notifications$ | async)?.length === 0; else notification\">\n      {{ '@pry.notif.noNotifications' | i18n }}\n    </p>\n    <ng-template #notification>\n      <div class=\"m-btn-group\">\n        <button type=\"button\" #button class=\"a-btn a-btn--primary\" (click)=\"deleteAll()\">\n          {{ '@pry.notif.deleteAll' | i18n: { count: (notifications$ | async)?.length } }}\n        </button>\n      </div>\n    </ng-template>\n  </div>\n  <div class=\"m-notifications-list__content\">\n    <ul class=\"m-notifications-list__items\">\n      <li class=\"m-notifications-list__items__li\" *ngFor=\"let notification of notifications$ | async; let last = last\">\n        <div class=\"m-notifications-list__items__li__txt\">\n          <h3 class=\"a-h3\">\n            {{\n              hasTranslation(notification.text.code, '@pry.notif.title.')\n                ? ('@pry.notif.title.' + notification.text.code | i18n: notification.text.param)\n                : notification.text.title\n            }}\n            <span>{{ notification.creationDate | date: \"dd/MM'&nbsp;&nbsp;&nbsp;'H':'mm\" }}</span>\n          </h3>\n          <p class=\"a-p desc\">\n            {{\n              hasTranslation(notification.text.code, '@pry.notif.title.')\n                ? ('@pry.notif.message.' + notification.text.code | i18n: notification.text.param)\n                : notification.text.code\n            }}\n          </p>\n          <a *ngIf=\"!!notification.link\" (click)=\"goTo(notification)\">\n            {{ '@pry.notif.link' | i18n }}\n          </a>\n        </div>\n        <button\n          class=\"a-btn a-btn--delete\"\n          (click)=\"delete(notification)\"\n          (keydown.tab)=\"last ? closeToEscape() : null\"\n          title=\"{{ '@pry.notif.delete' | i18n }}\"\n        >\n          <pry-icon [height]=\"20\" [width]=\"20\" iconSvg=\"close\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.notif.delete' | i18n }}</span>\n        </button>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
|
|
@@ -78,6 +78,9 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
78
78
|
this.valuePropField$ = combineLatest([this.availableProperties$, this.options$]).pipe(map(([attributes, options]) => attributes.find((attr) => attr.technicalName === options.valueProp)?.field));
|
|
79
79
|
}
|
|
80
80
|
matchAttributeValue(item, prop, comparisonValue) {
|
|
81
|
+
if (prop === 'level' && !('level' in item.attributes)) {
|
|
82
|
+
return comparisonValue === '1';
|
|
83
|
+
}
|
|
81
84
|
return comparisonValue && prop ? item.attributes[prop].value == comparisonValue : true;
|
|
82
85
|
}
|
|
83
86
|
createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, level) {
|
|
@@ -110,7 +113,7 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
110
113
|
.map((items) => items
|
|
111
114
|
.filter((item) => level && 'level' in item.attributes
|
|
112
115
|
? [level, '' + level].includes(item.attributes['level'].value)
|
|
113
|
-
:
|
|
116
|
+
: level === undefined || level === 1)
|
|
114
117
|
.map((item) => item.attributes[property]?.value + ''))
|
|
115
118
|
.flat()
|
|
116
119
|
.flat();
|
|
@@ -168,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
168
171
|
type: Component,
|
|
169
172
|
args: [{ selector: 'pry-widget-analytic', template: "<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n @if (displayHeader$ | async) {\n <pry-widget-header\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n #header\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"o-settings__fields\">\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'primaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.primaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"primaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'secondaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.secondaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"secondaryProp\"\n [clearable]=\"true\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'verticalProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.verticalProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"verticalProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'valueProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.valueProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"valueProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n {{ '@pry.widget.analytic.colorConfig' | i18n }}\n </pry-checkbox>\n @if (optionsCopy.colorConfig) {\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.colorConfig.prop\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"colorProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n <div\n class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n cdkDropListOrientation=\"horizontal\"\n >\n @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n <pry-color-picker\n [ngModel]=\"color\"\n (ngModelChange)=\"modifyColorScheme($event, i)\"\n ></pry-color-picker>\n <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n </button>\n <div *cdkDragPreview>\n <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n </div>\n </div>\n }\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n (click)=\"modifyColorScheme()\"\n >\n <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n </button>\n </div>\n </div>\n }\n </div>\n </div>\n </pry-settings>\n </pry-widget-header>\n }\n <div class=\"o-widget__analytic__table\">\n <table [style.height.px]=\"height$ | async\">\n <thead>\n <tr class=\"primary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ primary }}\n </th>\n }\n </tr>\n @if (optionsCopy.secondaryProp) {\n <tr class=\"secondary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <th>{{ secondary }}</th>\n }\n }\n </tr>\n }\n </thead>\n @if (this.valuePropField$ | async; as field) {\n <tbody>\n @for (line of lines$ | async; track line.name) {\n <tr>\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @if (optionsCopy.secondaryProp) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig\n ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] }\n : {}\n \"\n >\n {{ line.value[primary][secondary] | dataFormat: field }}\n </td>\n }\n } @else {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n \"\n >\n {{ line.value[primary] | dataFormat: field }}\n </td>\n }\n }\n </tr>\n }\n </tbody>\n <tfoot>\n @for (line of totals$ | async; track line.name) {\n <tr class=\"partial-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td>\n {{ line.value[primary][secondary] | dataFormat: field }}\n </td>\n }\n }\n </tr>\n }\n @for (line of grandTotals$ | async; track line.name) {\n <tr class=\"grand-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ line.value[primary] | dataFormat: field }}\n </td>\n }\n </tr>\n }\n </tfoot>\n }\n </table>\n </div>\n</div>\n" }]
|
|
170
173
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i0.ElementRef }] });
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-analytic.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport {\n  AnalyticWidgetOptions,\n  Attribute,\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  DataWidgetComponent,\n  Field,\n  Item,\n  ResultSet,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, startWith } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { filter } from 'rxjs/operators';\nimport { CdkDragDrop } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'pry-widget-analytic',\n  templateUrl: './widget-analytic.component.html'\n})\nexport class WidgetAnalyticComponent extends DataWidgetComponent {\n  optionsCopy: AnalyticWidgetOptions = { primaryProp: '', secondaryProp: '', verticalProp: '', valueProp: '' };\n  options$: Observable<AnalyticWidgetOptions>;\n\n  primaryProperty$: Observable<string[]>;\n  secondaryProperty$: Observable<string[]>;\n  verticalProperty$: Observable<string[]>;\n  totalProperty$: Observable<string[]>;\n  grandTotalProperty$: Observable<string[]>;\n  lines$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } | any } }[]>;\n  totals$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  grandTotals$: Observable<{ name: any; value: { [p: string]: any } }[]>;\n  colorMap$: Observable<{ [vertical: string]: { [primary: string]: string | undefined } }>;\n  height$: Observable<number>;\n  classes$: Observable<Class[]>;\n  availableProperties$: Observable<Attribute[]>;\n  valuePropField$: Observable<Field | undefined>;\n\n  change($event: string, prop: 'primaryProp' | 'secondaryProp' | 'valueProp' | 'verticalProp') {\n    this.optionsCopy[prop] = $event;\n  }\n\n  changeColorConfig($event: string | string[], prop: 'prop' | 'colors') {\n    switch (prop) {\n      case 'prop': {\n        this.optionsCopy.colorConfig!.prop = $event as string;\n        break;\n      }\n      case 'colors': {\n        this.optionsCopy.colorConfig!.colors = $event as string[];\n        break;\n      }\n    }\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => (manifest.options ?? {}) as AnalyticWidgetOptions));\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.height$ = combineLatest([this.widgetSize$, this.displayHeader$]).pipe(\n      map(([size, header]) => size.height - (header ? WIDGET_HEADER_HEIGHT.value : 0))\n    );\n    this.subscriptions.add(\n      this.options$.subscribe((options) => {\n        this.optionsCopy = JSON.parse(JSON.stringify(options));\n      })\n    );\n    this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.primaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp))\n    );\n    this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.secondaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp!, 1))\n    );\n    this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.verticalProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1))\n    );\n    this.totalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 2))\n    );\n    this.grandTotalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 3))\n    );\n\n    this.lines$ = combineLatest([\n      this.options$,\n      this.primaryProperty$.pipe(startWith([])),\n      this.secondaryProperty$.pipe(startWith(undefined)),\n      this.verticalProperty$.pipe(startWith([])),\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 1)\n      )\n    );\n\n    this.totals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.secondaryProperty$,\n      this.totalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 2)\n      )\n    );\n\n    this.grandTotals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.grandTotalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, undefined, rs, options, 3)\n      )\n    );\n\n    this.colorMap$ = combineLatest([\n      this.options$,\n      this.resultSet$,\n      this.verticalProperty$,\n      this.primaryProperty$\n    ]).pipe(\n      filter(([options]) => !!options.colorConfig),\n      map(([options, rs, vertical, primary]) => this.createColorMap(vertical, primary, rs, options))\n    );\n\n    this.availableProperties$ = combineLatest([this.classes$, this.resultSet$]).pipe(\n      map(([classes, rs]) => {\n        const presentClassesId = Object.keys(rs.items);\n        const presentClasses = presentClassesId\n          .map((classId) => classes.find((cl) => cl.id === classId))\n          .filter((cl) => !!cl) as Class[];\n        return presentClasses.map((cl) => cl.attributes).flat();\n      })\n    );\n\n    this.valuePropField$ = combineLatest([this.availableProperties$, this.options$]).pipe(\n      map(([attributes, options]) =>\n        attributes.find((attr) => attr.technicalName === options.valueProp)?.field)\n    );\n  }\n\n  private matchAttributeValue(item: Item, prop?: string, comparisonValue?: string) {\n    return comparisonValue && prop ? (item.attributes[prop] as AttributeSimpleValue).value == comparisonValue : true;\n  }\n\n  private createValueMap(\n    verticalProps: string[],\n    primaryProps: string[],\n    secondaryProps: string[] | undefined,\n    rs: ResultSet,\n    options: AnalyticWidgetOptions,\n    level?: number\n  ) {\n    return verticalProps.map((vertical) => {\n      const value = {} as { [key: string]: { [key: string]: any } | any };\n      primaryProps.forEach((primary) => {\n        (secondaryProps ?? [undefined]).forEach((secondary) => {\n          const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n            (item) =>\n              this.matchAttributeValue(item, options.primaryProp, primary) &&\n              this.matchAttributeValue(item, options.secondaryProp, secondary) &&\n              this.matchAttributeValue(item, options.verticalProp, vertical) &&\n              this.matchAttributeValue(item, 'level', level + '')\n          );\n          if (!!matchingItem) {\n            if (!!secondary) {\n              if (!value[primary]) {\n                value[primary] = {};\n              }\n              value[primary][secondary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue).value;\n            } else {\n              value[primary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue)?.value;\n            }\n          }\n        });\n      });\n      return { name: vertical, value };\n    });\n  }\n\n  getPropertyLabelsForLevel(rs: ResultSet, property: string, level?: number) {\n    const values = Object.values(rs.items)\n      .map((items) =>\n        items\n          .filter((item) =>\n            level && 'level' in item.attributes\n              ? [level, '' + level].includes(\n                  (item.attributes['level'] as AttributeSimpleValue).value as string | number\n                )\n              : true\n          )\n          .map((item) => (item.attributes[property] as AttributeSimpleValue)?.value + '')\n      )\n      .flat()\n      .flat();\n    return [...new Set(values)];\n  }\n\n  createColorMap(verticalProps: string[], primaryProps: string[], rs: ResultSet, options: AnalyticWidgetOptions) {\n    return options.colorConfig\n      ? Object.fromEntries(\n          verticalProps.map((vertical) => [\n            vertical,\n            Object.fromEntries(\n              primaryProps.map((primary) => {\n                const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n                  (item) =>\n                    this.matchAttributeValue(item, options.primaryProp, primary) &&\n                    this.matchAttributeValue(item, options.verticalProp, vertical)\n                );\n\n                return [\n                  primary,\n                  matchingItem && (matchingItem.attributes[options.valueProp] as AttributeSimpleValue).value !== 0\n                    ? options.colorConfig?.colors[\n                        ((matchingItem.attributes[options.colorConfig!.prop] as AttributeSimpleValue).value as number) -\n                          1\n                      ]\n                    : '#FFFFFF'\n                ];\n              })\n            )\n          ])\n        )\n      : {};\n  }\n\n  toggleColorConfig($event: boolean) {\n    if ($event !== !!this.optionsCopy.colorConfig) {\n      if (!this.optionsCopy.colorConfig) {\n        this.optionsCopy.colorConfig = { prop: '', colors: [] };\n      } else {\n        this.optionsCopy.colorConfig = undefined;\n      }\n    }\n  }\n\n  modifyColorScheme($event?: string, index?: number) {\n    $event && index !== undefined\n      ? (this.optionsCopy.colorConfig!.colors[index] = $event)\n      : this.optionsCopy.colorConfig!.colors.push('#FFFFFF');\n  }\n\n  removeColor(index: number) {\n    this.optionsCopy.colorConfig!.colors.splice(index, 1);\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    this.optionsCopy.colorConfig!.colors.splice(\n      event.currentIndex,\n      0,\n      this.optionsCopy.colorConfig!.colors.splice(event.previousIndex, 1)[0]\n    );\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: { ...this.manifest, options: this.optionsCopy }\n    });\n  }\n}\n","<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n  @if (displayHeader$ | async) {\n    <pry-widget-header\n      [widgetIndex]=\"widgetIndex\"\n      [manifest]=\"manifest\"\n      (manifestModified)=\"manifestModified.emit($event)\"\n      #header\n      [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n      [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n    >\n      <pry-settings\n        (saveTriggered)=\"emitManifest()\"\n        (changeTitle)=\"changeWidgetTitle($event)\"\n        [headerPresent]=\"displayHeader$ | async\"\n        [widgetIndex]=\"widgetIndex\"\n        [header]=\"header\"\n        [open$]=\"open$\"\n        class=\"o-settings\"\n      >\n        <div class=\"o-settings__fields\">\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'primaryProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.primaryProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"primaryProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'secondaryProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.secondaryProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"secondaryProp\"\n              [clearable]=\"true\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'verticalProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.verticalProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"verticalProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'valueProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.valueProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"valueProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n              {{ '@pry.widget.analytic.colorConfig' | i18n }}\n            </pry-checkbox>\n            @if (optionsCopy.colorConfig) {\n              <div class=\"m-form-label-field\">\n                <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n                <pry-select\n                  (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n                  [items]=\"availableProperties$ | async\"\n                  [ngModel]=\"optionsCopy.colorConfig.prop\"\n                  bindLabel=\"name\"\n                  bindValue=\"name\"\n                  id=\"colorProp\"\n                ></pry-select>\n              </div>\n              <div class=\"m-form-label-field\">\n                <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n                <div\n                  class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n                  cdkDropList\n                  (cdkDropListDropped)=\"drop($event)\"\n                  cdkDropListOrientation=\"horizontal\"\n                >\n                  @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n                    <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n                      <pry-color-picker\n                        [ngModel]=\"color\"\n                        (ngModelChange)=\"modifyColorScheme($event, i)\"\n                      ></pry-color-picker>\n                      <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n                        <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n                      </button>\n                      <div *cdkDragPreview>\n                        <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n                      </div>\n                    </div>\n                  }\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n                    (click)=\"modifyColorScheme()\"\n                  >\n                    <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n                  </button>\n                </div>\n              </div>\n            }\n          </div>\n        </div>\n      </pry-settings>\n    </pry-widget-header>\n  }\n  <div class=\"o-widget__analytic__table\">\n    <table [style.height.px]=\"height$ | async\">\n      <thead>\n        <tr class=\"primary-header\">\n          <th></th>\n          @for (primary of primaryProperty$ | async; track primary) {\n            <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n              {{ primary }}\n            </th>\n          }\n        </tr>\n        @if (optionsCopy.secondaryProp) {\n          <tr class=\"secondary-header\">\n            <th></th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <th>{{ secondary }}</th>\n              }\n            }\n          </tr>\n        }\n      </thead>\n      @if (this.valuePropField$ | async; as field) {\n        <tbody>\n          @for (line of lines$ | async; track line.name) {\n            <tr>\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                @if (optionsCopy.secondaryProp) {\n                  @for (secondary of secondaryProperty$ | async; track secondary) {\n                    <td\n                      [ngStyle]=\"\n                        optionsCopy.colorConfig\n                          ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] }\n                          : {}\n                      \"\n                    >\n                      {{ line.value[primary][secondary] | dataFormat: field }}\n                    </td>\n                  }\n                } @else {\n                  <td\n                    [ngStyle]=\"\n                      optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n                    \"\n                  >\n                    {{ line.value[primary] | dataFormat: field }}\n                  </td>\n                }\n              }\n            </tr>\n          }\n        </tbody>\n        <tfoot>\n          @for (line of totals$ | async; track line.name) {\n            <tr class=\"partial-total\">\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                @for (secondary of secondaryProperty$ | async; track secondary) {\n                  <td>\n                    {{ line.value[primary][secondary] | dataFormat: field }}\n                  </td>\n                }\n              }\n            </tr>\n          }\n          @for (line of grandTotals$ | async; track line.name) {\n            <tr class=\"grand-total\">\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n                  {{ line.value[primary] | dataFormat: field }}\n                </td>\n              }\n            </tr>\n          }\n        </tfoot>\n      }\n    </table>\n  </div>\n</div>\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-analytic.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport {\n  AnalyticWidgetOptions,\n  Attribute,\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  DataWidgetComponent,\n  Field,\n  Item,\n  ResultSet,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, startWith } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { filter } from 'rxjs/operators';\nimport { CdkDragDrop } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'pry-widget-analytic',\n  templateUrl: './widget-analytic.component.html'\n})\nexport class WidgetAnalyticComponent extends DataWidgetComponent {\n  optionsCopy: AnalyticWidgetOptions = { primaryProp: '', secondaryProp: '', verticalProp: '', valueProp: '' };\n  options$: Observable<AnalyticWidgetOptions>;\n\n  primaryProperty$: Observable<string[]>;\n  secondaryProperty$: Observable<string[]>;\n  verticalProperty$: Observable<string[]>;\n  totalProperty$: Observable<string[]>;\n  grandTotalProperty$: Observable<string[]>;\n  lines$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } | any } }[]>;\n  totals$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  grandTotals$: Observable<{ name: any; value: { [p: string]: any } }[]>;\n  colorMap$: Observable<{ [vertical: string]: { [primary: string]: string | undefined } }>;\n  height$: Observable<number>;\n  classes$: Observable<Class[]>;\n  availableProperties$: Observable<Attribute[]>;\n  valuePropField$: Observable<Field | undefined>;\n\n  change($event: string, prop: 'primaryProp' | 'secondaryProp' | 'valueProp' | 'verticalProp') {\n    this.optionsCopy[prop] = $event;\n  }\n\n  changeColorConfig($event: string | string[], prop: 'prop' | 'colors') {\n    switch (prop) {\n      case 'prop': {\n        this.optionsCopy.colorConfig!.prop = $event as string;\n        break;\n      }\n      case 'colors': {\n        this.optionsCopy.colorConfig!.colors = $event as string[];\n        break;\n      }\n    }\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => (manifest.options ?? {}) as AnalyticWidgetOptions));\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.height$ = combineLatest([this.widgetSize$, this.displayHeader$]).pipe(\n      map(([size, header]) => size.height - (header ? WIDGET_HEADER_HEIGHT.value : 0))\n    );\n    this.subscriptions.add(\n      this.options$.subscribe((options) => {\n        this.optionsCopy = JSON.parse(JSON.stringify(options));\n      })\n    );\n    this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.primaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp))\n    );\n    this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.secondaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp!, 1))\n    );\n    this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.verticalProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1))\n    );\n    this.totalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 2))\n    );\n    this.grandTotalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 3))\n    );\n\n    this.lines$ = combineLatest([\n      this.options$,\n      this.primaryProperty$.pipe(startWith([])),\n      this.secondaryProperty$.pipe(startWith(undefined)),\n      this.verticalProperty$.pipe(startWith([])),\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 1)\n      )\n    );\n\n    this.totals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.secondaryProperty$,\n      this.totalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 2)\n      )\n    );\n\n    this.grandTotals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.grandTotalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, undefined, rs, options, 3)\n      )\n    );\n\n    this.colorMap$ = combineLatest([\n      this.options$,\n      this.resultSet$,\n      this.verticalProperty$,\n      this.primaryProperty$\n    ]).pipe(\n      filter(([options]) => !!options.colorConfig),\n      map(([options, rs, vertical, primary]) => this.createColorMap(vertical, primary, rs, options))\n    );\n\n    this.availableProperties$ = combineLatest([this.classes$, this.resultSet$]).pipe(\n      map(([classes, rs]) => {\n        const presentClassesId = Object.keys(rs.items);\n        const presentClasses = presentClassesId\n          .map((classId) => classes.find((cl) => cl.id === classId))\n          .filter((cl) => !!cl) as Class[];\n        return presentClasses.map((cl) => cl.attributes).flat();\n      })\n    );\n\n    this.valuePropField$ = combineLatest([this.availableProperties$, this.options$]).pipe(\n      map(([attributes, options]) => attributes.find((attr) => attr.technicalName === options.valueProp)?.field)\n    );\n  }\n\n  private matchAttributeValue(item: Item, prop?: string, comparisonValue?: string) {\n    if (prop === 'level' && !('level' in item.attributes)) {\n      return comparisonValue === '1';\n    }\n    return comparisonValue && prop ? (item.attributes[prop] as AttributeSimpleValue).value == comparisonValue : true;\n  }\n\n  private createValueMap(\n    verticalProps: string[],\n    primaryProps: string[],\n    secondaryProps: string[] | undefined,\n    rs: ResultSet,\n    options: AnalyticWidgetOptions,\n    level?: number\n  ) {\n    return verticalProps.map((vertical) => {\n      const value = {} as { [key: string]: { [key: string]: any } | any };\n      primaryProps.forEach((primary) => {\n        (secondaryProps ?? [undefined]).forEach((secondary) => {\n          const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n            (item) =>\n              this.matchAttributeValue(item, options.primaryProp, primary) &&\n              this.matchAttributeValue(item, options.secondaryProp, secondary) &&\n              this.matchAttributeValue(item, options.verticalProp, vertical) &&\n              this.matchAttributeValue(item, 'level', level + '')\n          );\n          if (!!matchingItem) {\n            if (!!secondary) {\n              if (!value[primary]) {\n                value[primary] = {};\n              }\n              value[primary][secondary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue).value;\n            } else {\n              value[primary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue)?.value;\n            }\n          }\n        });\n      });\n      return { name: vertical, value };\n    });\n  }\n\n  private getPropertyLabelsForLevel(rs: ResultSet, property: string, level?: number) {\n    const values = Object.values(rs.items)\n      .map((items) =>\n        items\n          .filter((item) =>\n            level && 'level' in item.attributes\n              ? [level, '' + level].includes(\n                  (item.attributes['level'] as AttributeSimpleValue).value as string | number\n                )\n              : level === undefined || level === 1\n          )\n          .map((item) => (item.attributes[property] as AttributeSimpleValue)?.value + '')\n      )\n      .flat()\n      .flat();\n    return [...new Set(values)];\n  }\n\n  createColorMap(verticalProps: string[], primaryProps: string[], rs: ResultSet, options: AnalyticWidgetOptions) {\n    return options.colorConfig\n      ? Object.fromEntries(\n          verticalProps.map((vertical) => [\n            vertical,\n            Object.fromEntries(\n              primaryProps.map((primary) => {\n                const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n                  (item) =>\n                    this.matchAttributeValue(item, options.primaryProp, primary) &&\n                    this.matchAttributeValue(item, options.verticalProp, vertical)\n                );\n\n                return [\n                  primary,\n                  matchingItem && (matchingItem.attributes[options.valueProp] as AttributeSimpleValue).value !== 0\n                    ? options.colorConfig?.colors[\n                        ((matchingItem.attributes[options.colorConfig!.prop] as AttributeSimpleValue).value as number) -\n                          1\n                      ]\n                    : '#FFFFFF'\n                ];\n              })\n            )\n          ])\n        )\n      : {};\n  }\n\n  toggleColorConfig($event: boolean) {\n    if ($event !== !!this.optionsCopy.colorConfig) {\n      if (!this.optionsCopy.colorConfig) {\n        this.optionsCopy.colorConfig = { prop: '', colors: [] };\n      } else {\n        this.optionsCopy.colorConfig = undefined;\n      }\n    }\n  }\n\n  modifyColorScheme($event?: string, index?: number) {\n    $event && index !== undefined\n      ? (this.optionsCopy.colorConfig!.colors[index] = $event)\n      : this.optionsCopy.colorConfig!.colors.push('#FFFFFF');\n  }\n\n  removeColor(index: number) {\n    this.optionsCopy.colorConfig!.colors.splice(index, 1);\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    this.optionsCopy.colorConfig!.colors.splice(\n      event.currentIndex,\n      0,\n      this.optionsCopy.colorConfig!.colors.splice(event.previousIndex, 1)[0]\n    );\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: { ...this.manifest, options: this.optionsCopy }\n    });\n  }\n}\n","<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n  @if (displayHeader$ | async) {\n    <pry-widget-header\n      [widgetIndex]=\"widgetIndex\"\n      [manifest]=\"manifest\"\n      (manifestModified)=\"manifestModified.emit($event)\"\n      #header\n      [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n      [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n    >\n      <pry-settings\n        (saveTriggered)=\"emitManifest()\"\n        (changeTitle)=\"changeWidgetTitle($event)\"\n        [headerPresent]=\"displayHeader$ | async\"\n        [widgetIndex]=\"widgetIndex\"\n        [header]=\"header\"\n        [open$]=\"open$\"\n        class=\"o-settings\"\n      >\n        <div class=\"o-settings__fields\">\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'primaryProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.primaryProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"primaryProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'secondaryProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.secondaryProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"secondaryProp\"\n              [clearable]=\"true\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'verticalProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.verticalProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"verticalProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n            <pry-select\n              (ngModelChange)=\"change($event, 'valueProp')\"\n              [items]=\"availableProperties$ | async\"\n              [ngModel]=\"optionsCopy.valueProp\"\n              bindLabel=\"name\"\n              bindValue=\"name\"\n              id=\"valueProp\"\n            ></pry-select>\n          </div>\n          <div class=\"m-form-label-field\">\n            <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n              {{ '@pry.widget.analytic.colorConfig' | i18n }}\n            </pry-checkbox>\n            @if (optionsCopy.colorConfig) {\n              <div class=\"m-form-label-field\">\n                <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n                <pry-select\n                  (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n                  [items]=\"availableProperties$ | async\"\n                  [ngModel]=\"optionsCopy.colorConfig.prop\"\n                  bindLabel=\"name\"\n                  bindValue=\"name\"\n                  id=\"colorProp\"\n                ></pry-select>\n              </div>\n              <div class=\"m-form-label-field\">\n                <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n                <div\n                  class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n                  cdkDropList\n                  (cdkDropListDropped)=\"drop($event)\"\n                  cdkDropListOrientation=\"horizontal\"\n                >\n                  @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n                    <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n                      <pry-color-picker\n                        [ngModel]=\"color\"\n                        (ngModelChange)=\"modifyColorScheme($event, i)\"\n                      ></pry-color-picker>\n                      <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n                        <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n                      </button>\n                      <div *cdkDragPreview>\n                        <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n                      </div>\n                    </div>\n                  }\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n                    (click)=\"modifyColorScheme()\"\n                  >\n                    <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n                  </button>\n                </div>\n              </div>\n            }\n          </div>\n        </div>\n      </pry-settings>\n    </pry-widget-header>\n  }\n  <div class=\"o-widget__analytic__table\">\n    <table [style.height.px]=\"height$ | async\">\n      <thead>\n        <tr class=\"primary-header\">\n          <th></th>\n          @for (primary of primaryProperty$ | async; track primary) {\n            <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n              {{ primary }}\n            </th>\n          }\n        </tr>\n        @if (optionsCopy.secondaryProp) {\n          <tr class=\"secondary-header\">\n            <th></th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <th>{{ secondary }}</th>\n              }\n            }\n          </tr>\n        }\n      </thead>\n      @if (this.valuePropField$ | async; as field) {\n        <tbody>\n          @for (line of lines$ | async; track line.name) {\n            <tr>\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                @if (optionsCopy.secondaryProp) {\n                  @for (secondary of secondaryProperty$ | async; track secondary) {\n                    <td\n                      [ngStyle]=\"\n                        optionsCopy.colorConfig\n                          ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] }\n                          : {}\n                      \"\n                    >\n                      {{ line.value[primary][secondary] | dataFormat: field }}\n                    </td>\n                  }\n                } @else {\n                  <td\n                    [ngStyle]=\"\n                      optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n                    \"\n                  >\n                    {{ line.value[primary] | dataFormat: field }}\n                  </td>\n                }\n              }\n            </tr>\n          }\n        </tbody>\n        <tfoot>\n          @for (line of totals$ | async; track line.name) {\n            <tr class=\"partial-total\">\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                @for (secondary of secondaryProperty$ | async; track secondary) {\n                  <td>\n                    {{ line.value[primary][secondary] | dataFormat: field }}\n                  </td>\n                }\n              }\n            </tr>\n          }\n          @for (line of grandTotals$ | async; track line.name) {\n            <tr class=\"grand-total\">\n              <th>{{ line.name }}</th>\n              @for (primary of primaryProperty$ | async; track primary) {\n                <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n                  {{ line.value[primary] | dataFormat: field }}\n                </td>\n              }\n            </tr>\n          }\n        </tfoot>\n      }\n    </table>\n  </div>\n</div>\n"]}
|