@c8y/ngx-components 1021.13.3 → 1021.21.0
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/alarms/alarms-list.component.d.ts +2 -17
- package/alarms/alarms-list.component.d.ts.map +1 -1
- package/alarms/alarms-view.service.d.ts +1 -0
- package/alarms/alarms-view.service.d.ts.map +1 -1
- package/alarms/alarms.model.d.ts +30 -0
- package/alarms/alarms.model.d.ts.map +1 -1
- package/context-dashboard/context-dashboard.model.d.ts +1 -0
- package/context-dashboard/context-dashboard.model.d.ts.map +1 -1
- package/context-dashboard/context-dashboard.service.d.ts +7 -5
- package/context-dashboard/context-dashboard.service.d.ts.map +1 -1
- package/context-dashboard/dashboard-detail.component.d.ts +4 -7
- package/context-dashboard/dashboard-detail.component.d.ts.map +1 -1
- package/context-dashboard/dashboard-detail.service.d.ts +4 -4
- package/context-dashboard/dashboard-detail.service.d.ts.map +1 -1
- package/context-dashboard/dashboard-settings/dashboard-general-settings.component.d.ts +2 -2
- package/context-dashboard/dashboard-settings/dashboard-general-settings.component.d.ts.map +1 -1
- package/context-dashboard/dashboard-settings/typed-dashboard-settings.component.d.ts +19 -6
- package/context-dashboard/dashboard-settings/typed-dashboard-settings.component.d.ts.map +1 -1
- package/core/action-bar/action-bar-item.component.d.ts +1 -1
- package/core/action-bar/action-bar-item.component.d.ts.map +1 -1
- package/core/action-bar/action-bar.module.d.ts +6 -6
- package/core/action-bar/action-bar.module.d.ts.map +1 -1
- package/core/bootstrap/bootstrap.component.d.ts +3 -1
- package/core/bootstrap/bootstrap.component.d.ts.map +1 -1
- package/core/common/aggregation/aggregation.model.d.ts +39 -0
- package/core/common/aggregation/aggregation.model.d.ts.map +1 -0
- package/core/common/aggregation/aggregation.service.d.ts +17 -0
- package/core/common/aggregation/aggregation.service.d.ts.map +1 -0
- package/core/common/index.d.ts +4 -0
- package/core/common/index.d.ts.map +1 -1
- package/core/common/inter-app.service.d.ts +48 -0
- package/core/common/inter-app.service.d.ts.map +1 -0
- package/core/common/interval-based-reload.abstract.d.ts +120 -0
- package/core/common/interval-based-reload.abstract.d.ts.map +1 -0
- package/core/dashboard/dashboard.module.d.ts +24 -18
- package/core/dashboard/dashboard.module.d.ts.map +1 -1
- package/core/dashboard/index.d.ts +3 -0
- package/core/dashboard/index.d.ts.map +1 -1
- package/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.d.ts +31 -0
- package/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/auto-refresh-select-control.component.d.ts +17 -0
- package/core/dashboard/widget-auto-refresh-context/auto-refresh-select-control.component.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/global-refresh-loading.operator.d.ts +4 -0
- package/core/dashboard/widget-auto-refresh-context/global-refresh-loading.operator.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/index.d.ts +8 -0
- package/core/dashboard/widget-auto-refresh-context/index.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context-icon-bar.component.d.ts +7 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context-icon-bar.component.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.d.ts +29 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.model.d.ts +15 -0
- package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.model.d.ts.map +1 -0
- package/core/dashboard/widget-auto-refresh-context/widget-global-auto-refresh.service.d.ts +169 -0
- package/core/dashboard/widget-auto-refresh-context/widget-global-auto-refresh.service.d.ts.map +1 -0
- package/core/dashboard/widgets-dashboard.component.d.ts +6 -3
- package/core/dashboard/widgets-dashboard.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.d.ts +2 -2
- package/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.d.ts +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context-query.service.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts +11 -8
- package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context.model.d.ts +6 -12
- package/core/dashboard/wiget-time-context/widget-time-context.model.d.ts.map +1 -1
- package/core/header/header.module.d.ts +18 -18
- package/core/header/header.module.d.ts.map +1 -1
- package/core/header/title/title.component.d.ts +1 -1
- package/core/header/title/title.component.d.ts.map +1 -1
- package/core/i18n/cached-locale-dictionary.service.d.ts +5 -1
- package/core/i18n/cached-locale-dictionary.service.d.ts.map +1 -1
- package/core/i18n/i18n.module.d.ts +0 -4
- package/core/i18n/i18n.module.d.ts.map +1 -1
- package/core/i18n/index.d.ts +2 -1
- package/core/i18n/index.d.ts.map +1 -1
- package/core/i18n/translation-loader.service.d.ts +50 -0
- package/core/i18n/translation-loader.service.d.ts.map +1 -0
- package/core/i18n/translation-utils.d.ts +14 -0
- package/core/i18n/translation-utils.d.ts.map +1 -0
- package/core/plugins/plugins-resolve.service.d.ts +7 -10
- package/core/plugins/plugins-resolve.service.d.ts.map +1 -1
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form-validation.service.d.ts +2 -1
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form-validation.service.d.ts.map +1 -1
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.d.ts +11 -2
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selection.model.d.ts +6 -0
- package/datapoint-selector/datapoint-selection.model.d.ts.map +1 -1
- package/datapoints-export-selector/c8y-ngx-components-datapoints-export-selector.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts +117 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-processing.service.d.ts +90 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-processing.service.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts +160 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.d.ts +89 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-preview/datapoints-export-selector-preview.component.d.ts +11 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-preview/datapoints-export-selector-preview.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-data-scope/datapoints-exports-selector-data-scope.component.d.ts +27 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-data-scope/datapoints-exports-selector-data-scope.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-file-types/datapoints-exports-selector-file-types.component.d.ts +12 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-file-types/datapoints-exports-selector-file-types.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-time-range/datapoints-exports-selector-time-range.component.d.ts +22 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-time-range/datapoints-exports-selector-time-range.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/csv-generator.d.ts +3 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/csv-generator.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/excel-generator.d.ts +9 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/excel-generator.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/utils.service.d.ts +56 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/utils.service.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-modal.component.d.ts +21 -0
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-modal.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector.component.d.ts +14 -0
- package/datapoints-export-selector/datapoints-export-selector.component.d.ts.map +1 -0
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts +232 -0
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts.map +1 -0
- package/datapoints-export-selector/index.d.ts +15 -0
- package/datapoints-export-selector/index.d.ts.map +1 -0
- package/device-list/device-list.module.d.ts +4 -2
- package/device-list/device-list.module.d.ts.map +1 -1
- package/esm2022/alarms/alarms-list.component.mjs +5 -16
- package/esm2022/alarms/alarms-view.service.mjs +2 -1
- package/esm2022/alarms/alarms.model.mjs +1 -1
- package/esm2022/context-dashboard/context-dashboard.component.mjs +4 -4
- package/esm2022/context-dashboard/context-dashboard.model.mjs +1 -1
- package/esm2022/context-dashboard/context-dashboard.service.mjs +47 -21
- package/esm2022/context-dashboard/dashboard-detail.component.mjs +8 -16
- package/esm2022/context-dashboard/dashboard-detail.service.mjs +13 -6
- package/esm2022/context-dashboard/dashboard-settings/dashboard-general-settings.component.mjs +3 -3
- package/esm2022/context-dashboard/dashboard-settings/typed-dashboard-settings.component.mjs +32 -11
- package/esm2022/core/action-bar/action-bar-item.component.mjs +3 -3
- package/esm2022/core/action-bar/action-bar.module.mjs +16 -5
- package/esm2022/core/bootstrap/bootstrap.component.mjs +21 -16
- package/esm2022/core/common/aggregation/aggregation.model.mjs +46 -0
- package/esm2022/core/common/aggregation/aggregation.service.mjs +34 -0
- package/esm2022/core/common/humanize-app-name.model.mjs +2 -2
- package/esm2022/core/common/humanize-app-name.pipe.mjs +2 -2
- package/esm2022/core/common/index.mjs +5 -1
- package/esm2022/core/common/inter-app.service.mjs +76 -0
- package/esm2022/core/common/interval-based-reload.abstract.mjs +110 -0
- package/esm2022/core/countdown-interval/countdown-interval.component.mjs +3 -3
- package/esm2022/core/dashboard/dashboard-child.component.mjs +6 -5
- package/esm2022/core/dashboard/dashboard.module.mjs +18 -1
- package/esm2022/core/dashboard/index.mjs +4 -1
- package/esm2022/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.mjs +101 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/auto-refresh-select-control.component.mjs +50 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/global-refresh-loading.operator.mjs +7 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/index.mjs +8 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context-icon-bar.component.mjs +18 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.mjs +127 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.model.mjs +5 -0
- package/esm2022/core/dashboard/widget-auto-refresh-context/widget-global-auto-refresh.service.mjs +233 -0
- package/esm2022/core/dashboard/widgets-dashboard.component.mjs +35 -30
- package/esm2022/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.mjs +4 -4
- package/esm2022/core/dashboard/wiget-time-context/realtime-control/realtime-control.component.mjs +2 -2
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.mjs +5 -5
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context-query.service.mjs +7 -4
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context.component.mjs +37 -37
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context.model.mjs +1 -28
- package/esm2022/core/date-time-picker/date-time-picker.component.mjs +3 -3
- package/esm2022/core/header/header.module.mjs +7 -5
- package/esm2022/core/header/title/title.component.mjs +3 -3
- package/esm2022/core/i18n/cached-locale-dictionary.service.mjs +1 -1
- package/esm2022/core/i18n/i18n.module.mjs +7 -14
- package/esm2022/core/i18n/index.mjs +3 -2
- package/esm2022/core/i18n/translate.parser.mjs +2 -2
- package/esm2022/core/i18n/translation-loader.service.mjs +132 -0
- package/esm2022/core/i18n/translation-utils.mjs +24 -0
- package/esm2022/core/plugins/plugins-resolve.service.mjs +12 -37
- package/esm2022/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form-validation.service.mjs +13 -6
- package/esm2022/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.mjs +22 -5
- package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs +3 -3
- package/esm2022/datapoint-selector/datapoint-selection.model.mjs +1 -1
- package/esm2022/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.mjs +3 -3
- package/esm2022/datapoints-export-selector/c8y-ngx-components-datapoints-export-selector.mjs +5 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.mjs +407 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-processing.service.mjs +207 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.mjs +467 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.mjs +187 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-preview/datapoints-export-selector-preview.component.mjs +27 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-data-scope/datapoints-exports-selector-data-scope.component.mjs +41 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-file-types/datapoints-exports-selector-file-types.component.mjs +23 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-time-range/datapoints-exports-selector-time-range.component.mjs +42 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/csv-generator.mjs +120 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/excel-generator.mjs +282 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/utils.service.mjs +76 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-modal.component.mjs +46 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector.component.mjs +42 -0
- package/esm2022/datapoints-export-selector/datapoints-export-selector.model.mjs +43 -0
- package/esm2022/datapoints-export-selector/index.mjs +15 -0
- package/esm2022/device-list/add-smart-group.component.mjs +4 -3
- package/esm2022/device-list/device-list.module.mjs +22 -4
- package/esm2022/map/cluster-map.component.mjs +41 -13
- package/esm2022/map/map-status.component.mjs +6 -5
- package/esm2022/map/map.component.mjs +9 -5
- package/esm2022/map/map.model.mjs +1 -1
- package/esm2022/translation-editor/c8y-ngx-components-translation-editor.mjs +5 -0
- package/esm2022/translation-editor/data/c8y-ngx-components-translation-editor-data.mjs +5 -0
- package/esm2022/translation-editor/data/index.mjs +2 -0
- package/esm2022/translation-editor/data/translation-store.service.mjs +175 -0
- package/esm2022/translation-editor/index.mjs +10 -0
- package/esm2022/translation-editor/lazy/add-translation-modal/add-translation-modal.component.mjs +70 -0
- package/esm2022/translation-editor/lazy/c8y-ngx-components-translation-editor-lazy.mjs +5 -0
- package/esm2022/translation-editor/lazy/index.mjs +2 -0
- package/esm2022/translation-editor/lazy/manage-translation-cell-renderer/manage-translation-cell-renderer.component.mjs +53 -0
- package/esm2022/translation-editor/lazy/translation-editor/translation-editor.component.mjs +124 -0
- package/esm2022/translation-editor/translation-editor-naviagtor-factory.service.mjs +31 -0
- package/esm2022/widgets/cockpit/index.mjs +4 -2
- package/esm2022/widgets/cockpit-exports/index.mjs +8 -1
- package/esm2022/widgets/definitions/alarms/alarm-list/index.mjs +6 -2
- package/esm2022/widgets/definitions/alarms/all-critical-alarms/index.mjs +6 -2
- package/esm2022/widgets/definitions/alarms/recent-alarms/index.mjs +6 -2
- package/esm2022/widgets/definitions/datapoints-table/c8y-ngx-components-widgets-definitions-datapoints-table.mjs +5 -0
- package/esm2022/widgets/definitions/datapoints-table/index.mjs +34 -0
- package/esm2022/widgets/definitions/index.mjs +2 -1
- package/esm2022/widgets/definitions/map/index.mjs +4 -2
- package/esm2022/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.mjs +29 -15
- package/esm2022/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.mjs +57 -25
- package/esm2022/widgets/implementations/alarms/alarm-list-widget.model.mjs +2 -1
- package/esm2022/widgets/implementations/alarms/alarm-widget-alarms-reload.component.mjs +19 -21
- package/esm2022/widgets/implementations/datapoints-table/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +5 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.mjs +383 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.mjs +124 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/adjust-aggregated-time-range.pipe.mjs +191 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/apply-range-class.pipe.mjs +36 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/column-title.pipe.mjs +45 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +116 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/datapoints-table.component.mjs +116 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/dynamic-column.directive.mjs +43 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.mjs +282 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.mjs +430 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/virtual-scroll-listener.directive.mjs +75 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-widget.model.mjs +76 -0
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table.service.mjs +52 -0
- package/esm2022/widgets/implementations/datapoints-table/date-range-picker.component.mjs +68 -0
- package/esm2022/widgets/implementations/datapoints-table/index.mjs +10 -0
- package/esm2022/widgets/implementations/map/map-widget-config.component.mjs +19 -11
- package/esm2022/widgets/implementations/map/map-widget.component.mjs +20 -2
- package/esm2022/widgets/implementations/map/map-widget.model.mjs +1 -1
- package/fesm2022/c8y-ngx-components-alarms.mjs +5 -15
- package/fesm2022/c8y-ngx-components-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs +135 -91
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +37 -13
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs +1928 -0
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-device-list.mjs +24 -5
- package/fesm2022/c8y-ngx-components-device-list.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-map.mjs +52 -19
- package/fesm2022/c8y-ngx-components-map.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-translation-editor-data.mjs +181 -0
- package/fesm2022/c8y-ngx-components-translation-editor-data.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-translation-editor-lazy.mjs +236 -0
- package/fesm2022/c8y-ngx-components-translation-editor-lazy.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-translation-editor.mjs +46 -0
- package/fesm2022/c8y-ngx-components-translation-editor.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs +7 -0
- package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs +3 -1
- package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-alarm-list.mjs +5 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-alarm-list.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-all-critical-alarms.mjs +5 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-all-critical-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-recent-alarms.mjs +5 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-recent-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs +41 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions-map.mjs +3 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-map.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions.mjs +1 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +101 -58
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +1967 -0
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-widgets-implementations-map.mjs +37 -11
- package/fesm2022/c8y-ngx-components-widgets-implementations-map.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +5080 -4272
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/locales/de.po +289 -18
- package/locales/en.po +12 -0
- package/locales/en_US.po +3 -0
- package/locales/es.po +253 -18
- package/locales/fr.po +253 -18
- package/locales/ja_JP.po +282 -18
- package/locales/locales.pot +257 -18
- package/locales/nl.po +253 -18
- package/locales/pl.po +253 -18
- package/locales/pt_BR.po +253 -18
- package/map/cluster-map.component.d.ts +8 -3
- package/map/cluster-map.component.d.ts.map +1 -1
- package/map/map-status.component.d.ts +0 -3
- package/map/map-status.component.d.ts.map +1 -1
- package/map/map.component.d.ts +4 -2
- package/map/map.component.d.ts.map +1 -1
- package/map/map.model.d.ts +2 -1
- package/map/map.model.d.ts.map +1 -1
- package/package.json +1 -1
- package/translation-editor/c8y-ngx-components-translation-editor.d.ts.map +1 -0
- package/translation-editor/data/c8y-ngx-components-translation-editor-data.d.ts.map +1 -0
- package/translation-editor/data/index.d.ts +2 -0
- package/translation-editor/data/index.d.ts.map +1 -0
- package/translation-editor/data/translation-store.service.d.ts +61 -0
- package/translation-editor/data/translation-store.service.d.ts.map +1 -0
- package/translation-editor/index.d.ts +2 -0
- package/translation-editor/index.d.ts.map +1 -0
- package/translation-editor/lazy/add-translation-modal/add-translation-modal.component.d.ts +30 -0
- package/translation-editor/lazy/add-translation-modal/add-translation-modal.component.d.ts.map +1 -0
- package/translation-editor/lazy/c8y-ngx-components-translation-editor-lazy.d.ts.map +1 -0
- package/translation-editor/lazy/index.d.ts +2 -0
- package/translation-editor/lazy/index.d.ts.map +1 -0
- package/translation-editor/lazy/manage-translation-cell-renderer/manage-translation-cell-renderer.component.d.ts +22 -0
- package/translation-editor/lazy/manage-translation-cell-renderer/manage-translation-cell-renderer.component.d.ts.map +1 -0
- package/translation-editor/lazy/translation-editor/translation-editor.component.d.ts +34 -0
- package/translation-editor/lazy/translation-editor/translation-editor.component.d.ts.map +1 -0
- package/translation-editor/translation-editor-naviagtor-factory.service.d.ts +11 -0
- package/translation-editor/translation-editor-naviagtor-factory.service.d.ts.map +1 -0
- package/widgets/cockpit/index.d.ts +13 -0
- package/widgets/cockpit/index.d.ts.map +1 -1
- package/widgets/cockpit-exports/index.d.ts +6 -0
- package/widgets/cockpit-exports/index.d.ts.map +1 -1
- package/widgets/definitions/alarms/alarm-list/index.d.ts +2 -0
- package/widgets/definitions/alarms/alarm-list/index.d.ts.map +1 -1
- package/widgets/definitions/alarms/all-critical-alarms/index.d.ts +2 -0
- package/widgets/definitions/alarms/all-critical-alarms/index.d.ts.map +1 -1
- package/widgets/definitions/alarms/recent-alarms/index.d.ts +2 -0
- package/widgets/definitions/alarms/recent-alarms/index.d.ts.map +1 -1
- package/widgets/definitions/datapoints-table/c8y-ngx-components-widgets-definitions-datapoints-table.d.ts.map +1 -0
- package/widgets/definitions/datapoints-table/index.d.ts +14 -0
- package/widgets/definitions/datapoints-table/index.d.ts.map +1 -0
- package/widgets/definitions/index.d.ts +1 -0
- package/widgets/definitions/index.d.ts.map +1 -1
- package/widgets/definitions/map/index.d.ts +2 -1
- package/widgets/definitions/map/index.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.d.ts +5 -9
- package/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.d.ts +17 -10
- package/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget.model.d.ts +5 -1
- package/widgets/implementations/alarms/alarm-list-widget.model.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts +5 -11
- package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/c8y-ngx-components-widgets-implementations-datapoints-table.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts +129 -0
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.d.ts +56 -0
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/adjust-aggregated-time-range.pipe.d.ts +88 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/adjust-aggregated-time-range.pipe.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/apply-range-class.pipe.d.ts +19 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/apply-range-class.pipe.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/column-title.pipe.d.ts +26 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/column-title.pipe.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts +63 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/datapoints-table.component.d.ts +38 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/datapoints-table.component.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/dynamic-column.directive.d.ts +13 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/dynamic-column.directive.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts +123 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.d.ts +196 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/virtual-scroll-listener.directive.d.ts +41 -0
- package/widgets/implementations/datapoints-table/datapoints-table-view/virtual-scroll-listener.directive.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts +175 -0
- package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/datapoints-table.service.d.ts +12 -0
- package/widgets/implementations/datapoints-table/datapoints-table.service.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/date-range-picker.component.d.ts +34 -0
- package/widgets/implementations/datapoints-table/date-range-picker.component.d.ts.map +1 -0
- package/widgets/implementations/datapoints-table/index.d.ts +10 -0
- package/widgets/implementations/datapoints-table/index.d.ts.map +1 -0
- package/widgets/implementations/map/map-widget-config.component.d.ts +4 -4
- package/widgets/implementations/map/map-widget-config.component.d.ts.map +1 -1
- package/widgets/implementations/map/map-widget.component.d.ts +8 -3
- package/widgets/implementations/map/map-widget.component.d.ts.map +1 -1
- package/widgets/implementations/map/map-widget.model.d.ts +4 -3
- package/widgets/implementations/map/map-widget.model.d.ts.map +1 -1
- package/core/i18n/translate.loader.d.ts +0 -31
- package/core/i18n/translate.loader.d.ts.map +0 -1
- package/esm2022/core/i18n/translate.loader.mjs +0 -71
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { gettext } from '@c8y/ngx-components';
|
|
2
|
+
class CSVDataTransformer {
|
|
3
|
+
transformToMergedFormat(exportData) {
|
|
4
|
+
const timeSeries = new Map();
|
|
5
|
+
const uniqueColumnIdentifiers = new Set();
|
|
6
|
+
exportData.forEach(({ time, device_name, fragment_series, unit, value_min, value_max, source }) => {
|
|
7
|
+
const measurementIdentifier = this.createMeasurementIdentifier(device_name, fragment_series, unit, source);
|
|
8
|
+
if (!timeSeries.has(time)) {
|
|
9
|
+
timeSeries.set(time, {});
|
|
10
|
+
}
|
|
11
|
+
const timeEntry = timeSeries.get(time);
|
|
12
|
+
if (timeEntry) {
|
|
13
|
+
const minKey = this.formatMinKey(measurementIdentifier);
|
|
14
|
+
const maxKey = this.formatMaxKey(measurementIdentifier);
|
|
15
|
+
timeEntry[minKey] = value_min;
|
|
16
|
+
timeEntry[maxKey] = value_max;
|
|
17
|
+
uniqueColumnIdentifiers.add(minKey);
|
|
18
|
+
uniqueColumnIdentifiers.add(maxKey);
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
return {
|
|
22
|
+
timeSeries,
|
|
23
|
+
uniqueColumnIdentifiers: Array.from(uniqueColumnIdentifiers)
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
createMeasurementIdentifier(deviceName, fragmentSeries, unit, source) {
|
|
27
|
+
return unit
|
|
28
|
+
? `(${source}) ${deviceName} -> ${fragmentSeries} [${unit}]`
|
|
29
|
+
: `(${source}) ${deviceName} -> ${fragmentSeries}`;
|
|
30
|
+
}
|
|
31
|
+
formatMinKey(baseKey) {
|
|
32
|
+
return `${baseKey} (min)`;
|
|
33
|
+
}
|
|
34
|
+
formatMaxKey(baseKey) {
|
|
35
|
+
return `${baseKey} (max)`;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
class CSVFileCreator {
|
|
39
|
+
async createFile(content, mimeType) {
|
|
40
|
+
return new Blob([content], { type: mimeType });
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
class CSVGenerator {
|
|
44
|
+
static getLabel() {
|
|
45
|
+
return gettext('Comma-separated value');
|
|
46
|
+
}
|
|
47
|
+
static getTitle() {
|
|
48
|
+
return 'CSV';
|
|
49
|
+
}
|
|
50
|
+
static getType() {
|
|
51
|
+
return 'csv';
|
|
52
|
+
}
|
|
53
|
+
static getIcon() {
|
|
54
|
+
return 'table';
|
|
55
|
+
}
|
|
56
|
+
static getFileExtension() {
|
|
57
|
+
return 'csv';
|
|
58
|
+
}
|
|
59
|
+
static getAcceptType() {
|
|
60
|
+
return 'text/csv';
|
|
61
|
+
}
|
|
62
|
+
static getMimeType() {
|
|
63
|
+
return 'text/csv';
|
|
64
|
+
}
|
|
65
|
+
static getZipName() {
|
|
66
|
+
return 'export_csv.zip';
|
|
67
|
+
}
|
|
68
|
+
static async convertToMergedCSV(exportData, mergedExportDetails) {
|
|
69
|
+
const instance = CSVGenerator.getInstance();
|
|
70
|
+
const { timeSeries, uniqueColumnIdentifiers } = instance.dataTransformer.transformToMergedFormat(exportData);
|
|
71
|
+
const rows = [
|
|
72
|
+
instance.createMergedFileHeaderRow(uniqueColumnIdentifiers, mergedExportDetails),
|
|
73
|
+
...instance.createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers)
|
|
74
|
+
];
|
|
75
|
+
const csvContent = rows.map(row => row.join(',')).join('\n');
|
|
76
|
+
return instance.fileCreator.createFile(csvContent, CSVGenerator.getMimeType());
|
|
77
|
+
}
|
|
78
|
+
static getInstance() {
|
|
79
|
+
if (!CSVGenerator.instance) {
|
|
80
|
+
CSVGenerator.instance = new CSVGenerator();
|
|
81
|
+
}
|
|
82
|
+
return CSVGenerator.instance;
|
|
83
|
+
}
|
|
84
|
+
constructor() {
|
|
85
|
+
this.dataTransformer = new CSVDataTransformer();
|
|
86
|
+
this.fileCreator = new CSVFileCreator();
|
|
87
|
+
}
|
|
88
|
+
createMergedFileHeaderRow(uniqueColumnIdentifiers, details) {
|
|
89
|
+
const time = details ? `time => from ${details.dateFrom} to ${details.dateTo}` : 'time';
|
|
90
|
+
return [time, ...uniqueColumnIdentifiers];
|
|
91
|
+
}
|
|
92
|
+
createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers) {
|
|
93
|
+
return Array.from(timeSeries.entries())
|
|
94
|
+
.filter(([time, values]) => this.isValidEntry(time, values))
|
|
95
|
+
.map(([time, values]) => this.createDataRow(time, values, uniqueColumnIdentifiers));
|
|
96
|
+
}
|
|
97
|
+
isValidEntry(time, values) {
|
|
98
|
+
return time !== null && Object.values(values).some(value => value != null);
|
|
99
|
+
}
|
|
100
|
+
createDataRow(time, values, uniqueColumnIdentifiers) {
|
|
101
|
+
const row = [time];
|
|
102
|
+
uniqueColumnIdentifiers.forEach(key => {
|
|
103
|
+
const value = values[key];
|
|
104
|
+
row.push(value?.toString() || '');
|
|
105
|
+
});
|
|
106
|
+
return row;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
export const CSVGeneratorAdapter = {
|
|
110
|
+
getLabel: CSVGenerator.getLabel.bind(CSVGenerator),
|
|
111
|
+
getIcon: CSVGenerator.getIcon.bind(CSVGenerator),
|
|
112
|
+
getFileExtension: CSVGenerator.getFileExtension.bind(CSVGenerator),
|
|
113
|
+
getMimeType: CSVGenerator.getMimeType.bind(CSVGenerator),
|
|
114
|
+
generateMerged: CSVGenerator.convertToMergedCSV.bind(CSVGenerator),
|
|
115
|
+
getType: CSVGenerator.getType.bind(CSVGenerator),
|
|
116
|
+
getTitle: CSVGenerator.getTitle.bind(CSVGenerator),
|
|
117
|
+
getZipName: CSVGenerator.getZipName.bind(CSVGenerator),
|
|
118
|
+
getAcceptType: CSVGenerator.getAcceptType.bind(CSVGenerator)
|
|
119
|
+
};
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"csv-generator.js","sourceRoot":"","sources":["../../../../../../datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/csv-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { gettext } from '@c8y/ngx-components';\nimport {\n  ExportData,\n  FileGenerator,\n  IDataTransformer,\n  MergedExportDetails,\n  TimeSeriesColumnData\n} from '../../../datapoints-export-selector.model';\n\ninterface ICsvFileCreator {\n  createFile(content: string, mimeType: string): Promise<Blob>;\n}\n\nclass CSVDataTransformer implements IDataTransformer {\n  transformToMergedFormat(exportData: ExportData[]): TimeSeriesColumnData {\n    const timeSeries = new Map<string, Record<string, number>>();\n    const uniqueColumnIdentifiers = new Set<string>();\n\n    exportData.forEach(\n      ({ time, device_name, fragment_series, unit, value_min, value_max, source }) => {\n        const measurementIdentifier = this.createMeasurementIdentifier(\n          device_name,\n          fragment_series,\n          unit,\n          source\n        );\n\n        if (!timeSeries.has(time)) {\n          timeSeries.set(time, {});\n        }\n\n        const timeEntry = timeSeries.get(time);\n        if (timeEntry) {\n          const minKey = this.formatMinKey(measurementIdentifier);\n          const maxKey = this.formatMaxKey(measurementIdentifier);\n\n          timeEntry[minKey] = value_min;\n          timeEntry[maxKey] = value_max;\n\n          uniqueColumnIdentifiers.add(minKey);\n          uniqueColumnIdentifiers.add(maxKey);\n        }\n      }\n    );\n\n    return {\n      timeSeries,\n      uniqueColumnIdentifiers: Array.from(uniqueColumnIdentifiers)\n    };\n  }\n\n  private createMeasurementIdentifier(\n    deviceName: string,\n    fragmentSeries: string,\n    unit: string,\n    source: string | number\n  ): string {\n    return unit\n      ? `(${source}) ${deviceName} -> ${fragmentSeries} [${unit}]`\n      : `(${source}) ${deviceName} -> ${fragmentSeries}`;\n  }\n\n  private formatMinKey(baseKey: string): string {\n    return `${baseKey} (min)`;\n  }\n\n  private formatMaxKey(baseKey: string): string {\n    return `${baseKey} (max)`;\n  }\n}\n\nclass CSVFileCreator implements ICsvFileCreator {\n  async createFile(content: string, mimeType: string): Promise<Blob> {\n    return new Blob([content], { type: mimeType });\n  }\n}\n\nclass CSVGenerator {\n  static getLabel(): string {\n    return gettext('Comma-separated value');\n  }\n\n  static getTitle(): string {\n    return 'CSV';\n  }\n\n  static getType(): string {\n    return 'csv';\n  }\n\n  static getIcon(): string {\n    return 'table';\n  }\n\n  static getFileExtension(): string {\n    return 'csv';\n  }\n\n  static getAcceptType(): string {\n    return 'text/csv';\n  }\n\n  static getMimeType(): string {\n    return 'text/csv';\n  }\n\n  static getZipName(): string {\n    return 'export_csv.zip';\n  }\n\n  static async convertToMergedCSV(\n    exportData: ExportData[],\n    mergedExportDetails: MergedExportDetails\n  ): Promise<Blob> {\n    const instance = CSVGenerator.getInstance();\n    const { timeSeries, uniqueColumnIdentifiers } =\n      instance.dataTransformer.transformToMergedFormat(exportData);\n\n    const rows = [\n      instance.createMergedFileHeaderRow(uniqueColumnIdentifiers, mergedExportDetails),\n      ...instance.createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers)\n    ];\n\n    const csvContent = rows.map(row => row.join(',')).join('\\n');\n    return instance.fileCreator.createFile(csvContent, CSVGenerator.getMimeType());\n  }\n  private static instance: CSVGenerator;\n\n  private static getInstance(): CSVGenerator {\n    if (!CSVGenerator.instance) {\n      CSVGenerator.instance = new CSVGenerator();\n    }\n    return CSVGenerator.instance;\n  }\n  private dataTransformer: IDataTransformer;\n  private fileCreator: ICsvFileCreator;\n\n  private constructor() {\n    this.dataTransformer = new CSVDataTransformer();\n    this.fileCreator = new CSVFileCreator();\n  }\n\n  private createMergedFileHeaderRow(\n    uniqueColumnIdentifiers: string[],\n    details?: MergedExportDetails\n  ): string[] {\n    const time = details ? `time => from ${details.dateFrom} to ${details.dateTo}` : 'time';\n    return [time, ...uniqueColumnIdentifiers];\n  }\n\n  private createMergedFileDataRows(\n    timeSeries: Map<string, Record<string, number>>,\n    uniqueColumnIdentifiers: string[]\n  ): string[][] {\n    return Array.from(timeSeries.entries())\n      .filter(([time, values]) => this.isValidEntry(time, values))\n      .map(([time, values]) => this.createDataRow(time, values, uniqueColumnIdentifiers));\n  }\n\n  private isValidEntry(time: string, values: Record<string, number>): boolean {\n    return time !== null && Object.values(values).some(value => value != null);\n  }\n\n  private createDataRow(\n    time: string,\n    values: Record<string, number>,\n    uniqueColumnIdentifiers: string[]\n  ): string[] {\n    const row = [time];\n    uniqueColumnIdentifiers.forEach(key => {\n      const value = values[key];\n      row.push(value?.toString() || '');\n    });\n    return row;\n  }\n}\n\nexport const CSVGeneratorAdapter: FileGenerator = {\n  getLabel: CSVGenerator.getLabel.bind(CSVGenerator),\n  getIcon: CSVGenerator.getIcon.bind(CSVGenerator),\n  getFileExtension: CSVGenerator.getFileExtension.bind(CSVGenerator),\n  getMimeType: CSVGenerator.getMimeType.bind(CSVGenerator),\n  generateMerged: CSVGenerator.convertToMergedCSV.bind(CSVGenerator),\n  getType: CSVGenerator.getType.bind(CSVGenerator),\n  getTitle: CSVGenerator.getTitle.bind(CSVGenerator),\n  getZipName: CSVGenerator.getZipName.bind(CSVGenerator),\n  getAcceptType: CSVGenerator.getAcceptType.bind(CSVGenerator)\n};\n"]}
|
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
import { gettext } from '@c8y/ngx-components';
|
|
2
|
+
import JSZip from 'jszip';
|
|
3
|
+
import { isEmpty, isNil, isNumber } from 'lodash-es';
|
|
4
|
+
import { FILE_COMPRESSION_TYPES_VALUES } from '../../../datapoints-export-selector.model';
|
|
5
|
+
// Utility functions
|
|
6
|
+
class XmlUtils {
|
|
7
|
+
static escapeXml(unsafe) {
|
|
8
|
+
return unsafe.replace(/[<>&'"]/g, c => {
|
|
9
|
+
switch (c) {
|
|
10
|
+
case '<':
|
|
11
|
+
return '<';
|
|
12
|
+
case '>':
|
|
13
|
+
return '>';
|
|
14
|
+
case '&':
|
|
15
|
+
return '&';
|
|
16
|
+
case "'":
|
|
17
|
+
return ''';
|
|
18
|
+
case '"':
|
|
19
|
+
return '"';
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export class ExcelDataTransformer {
|
|
25
|
+
transformToMergedFormat(exportData) {
|
|
26
|
+
const timeSeries = new Map();
|
|
27
|
+
const uniqueColumnIdentifiers = new Set();
|
|
28
|
+
exportData.forEach(({ time, device_name, fragment_series, unit, value_min, value_max, source }) => {
|
|
29
|
+
const measurementIdentifier = this.createMeasurementIdentifier(device_name, fragment_series, unit, source);
|
|
30
|
+
if (!timeSeries.has(time)) {
|
|
31
|
+
timeSeries.set(time, {});
|
|
32
|
+
}
|
|
33
|
+
const timeEntry = timeSeries.get(time);
|
|
34
|
+
if (timeEntry) {
|
|
35
|
+
const minKey = this.formatMinKey(measurementIdentifier);
|
|
36
|
+
const maxKey = this.formatMaxKey(measurementIdentifier);
|
|
37
|
+
timeEntry[minKey] = value_min;
|
|
38
|
+
timeEntry[maxKey] = value_max;
|
|
39
|
+
uniqueColumnIdentifiers.add(minKey);
|
|
40
|
+
uniqueColumnIdentifiers.add(maxKey);
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
return {
|
|
44
|
+
timeSeries,
|
|
45
|
+
uniqueColumnIdentifiers: Array.from(uniqueColumnIdentifiers)
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
createMeasurementIdentifier(deviceName, fragmentSeries, unit, source) {
|
|
49
|
+
return unit
|
|
50
|
+
? `(${source}) ${deviceName} -> ${fragmentSeries} [${unit}]`
|
|
51
|
+
: `(${source}) ${deviceName} -> ${fragmentSeries}`;
|
|
52
|
+
}
|
|
53
|
+
formatMinKey(baseKey) {
|
|
54
|
+
return `${baseKey} (min)`;
|
|
55
|
+
}
|
|
56
|
+
formatMaxKey(baseKey) {
|
|
57
|
+
return `${baseKey} (max)`;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
class ExcelXmlGenerator {
|
|
61
|
+
constructor() {
|
|
62
|
+
this.columnWidths = {
|
|
63
|
+
time: 25,
|
|
64
|
+
source: 10,
|
|
65
|
+
device_name: 20,
|
|
66
|
+
'fragment.series': 20,
|
|
67
|
+
value_min: 15,
|
|
68
|
+
value_max: 15,
|
|
69
|
+
unit: 5
|
|
70
|
+
};
|
|
71
|
+
this.defaultWidth = 30;
|
|
72
|
+
this.RELS_XML = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n' +
|
|
73
|
+
'<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">\n' +
|
|
74
|
+
' <Relationship Id="rId1" Target="xl/workbook.xml" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument"/>\n' +
|
|
75
|
+
' <Relationship Id="rId2" Target="docProps/app.xml" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties"/>\n' +
|
|
76
|
+
' <Relationship Id="rId3" Target="docProps/core.xml" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties"/>\n' +
|
|
77
|
+
'</Relationships>';
|
|
78
|
+
this.CONTENT_TYPES_XML = '<?xml version="1.0" encoding="UTF-8" standalone="no"?>\n' +
|
|
79
|
+
'<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types">\n' +
|
|
80
|
+
' <Default ContentType="application/vnd.openxmlformats-package.relationships+xml" Extension="rels"/>\n' +
|
|
81
|
+
' <Default ContentType="application/xml" Extension="xml"/>\n' +
|
|
82
|
+
' <Override ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml" PartName="/docProps/app.xml"/>\n' +
|
|
83
|
+
' <Override ContentType="application/vnd.openxmlformats-package.core-properties+xml" PartName="/docProps/core.xml"/>\n' +
|
|
84
|
+
' <Override ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml" PartName="/xl/sharedStrings.xml"/>\n' +
|
|
85
|
+
' <Override ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml" PartName="/xl/workbook.xml"/>\n' +
|
|
86
|
+
' <Override ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml" PartName="/xl/worksheets/sheet1.xml"/>\n' +
|
|
87
|
+
'</Types>';
|
|
88
|
+
this.WORKBOOK_RELS_XML = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n' +
|
|
89
|
+
'<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">\n' +
|
|
90
|
+
' <Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings" Target="sharedStrings.xml"/>\n' +
|
|
91
|
+
' <Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet" Target="worksheets/sheet1.xml"/>\n' +
|
|
92
|
+
'</Relationships>';
|
|
93
|
+
this.SHARED_STRINGS_XML = '<?xml version="1.0" encoding="UTF-8"?>\n' +
|
|
94
|
+
'<sst count="0" uniqueCount="0" xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main"/>';
|
|
95
|
+
}
|
|
96
|
+
generateWorkbookXml(sheetName = 'Measurements') {
|
|
97
|
+
return ('<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n' +
|
|
98
|
+
`<workbook xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships"><sheets><sheet name='${sheetName}' r:id="rId3" sheetId="1"/></sheets></workbook>`);
|
|
99
|
+
}
|
|
100
|
+
generateSheetXml(data) {
|
|
101
|
+
const headers = data[0];
|
|
102
|
+
const colsXml = this.generateColsXml(headers);
|
|
103
|
+
const rowsXml = this.generateRowsXml(data);
|
|
104
|
+
return `<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
|
105
|
+
<worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships">
|
|
106
|
+
<cols>${colsXml}</cols>
|
|
107
|
+
<sheetData>${rowsXml}</sheetData>
|
|
108
|
+
</worksheet>`;
|
|
109
|
+
}
|
|
110
|
+
generateAppXml(name) {
|
|
111
|
+
return ('<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n' +
|
|
112
|
+
'<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes">\n' +
|
|
113
|
+
` <Application>${name}</Application>\n` +
|
|
114
|
+
' <DocSecurity>0</DocSecurity>\n' +
|
|
115
|
+
' <ScaleCrop>false</ScaleCrop>\n' +
|
|
116
|
+
' <HeadingPairs>\n' +
|
|
117
|
+
' <vt:vector size="2" baseType="variant">\n' +
|
|
118
|
+
' <vt:variant>\n' +
|
|
119
|
+
' <vt:lpstr>Worksheets</vt:lpstr>\n' +
|
|
120
|
+
' </vt:variant>\n' +
|
|
121
|
+
' <vt:variant>\n' +
|
|
122
|
+
' <vt:i4>1</vt:i4>\n' +
|
|
123
|
+
' </vt:variant>\n' +
|
|
124
|
+
' </vt:vector>\n' +
|
|
125
|
+
' </HeadingPairs>\n' +
|
|
126
|
+
' <TitlesOfParts>\n' +
|
|
127
|
+
' <vt:vector size="1" baseType="lpstr">\n' +
|
|
128
|
+
' <vt:lpstr>Sheet1</vt:lpstr>\n' +
|
|
129
|
+
' </vt:vector>\n' +
|
|
130
|
+
' </TitlesOfParts>\n' +
|
|
131
|
+
' <Company></Company>\n' +
|
|
132
|
+
' <LinksUpToDate>false</LinksUpToDate>\n' +
|
|
133
|
+
' <SharedDoc>false</SharedDoc>\n' +
|
|
134
|
+
' <HyperlinksChanged>false</HyperlinksChanged>\n' +
|
|
135
|
+
' <AppVersion>16.0300</AppVersion>\n' +
|
|
136
|
+
'</Properties>');
|
|
137
|
+
}
|
|
138
|
+
generateCoreXml(name) {
|
|
139
|
+
const now = new Date().toISOString();
|
|
140
|
+
return ('<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n' +
|
|
141
|
+
'<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">\n' +
|
|
142
|
+
` <dc:creator>${name}</dc:creator>\n` +
|
|
143
|
+
` <cp:lastModifiedBy>${name}</cp:lastModifiedBy>\n` +
|
|
144
|
+
` <dcterms:created xsi:type="dcterms:W3CDTF">${now}</dcterms:created>\n` +
|
|
145
|
+
` <dcterms:modified xsi:type="dcterms:W3CDTF">${now}</dcterms:modified>\n` +
|
|
146
|
+
'</cp:coreProperties>');
|
|
147
|
+
}
|
|
148
|
+
generateColsXml(headers) {
|
|
149
|
+
return headers
|
|
150
|
+
.map((header, index) => {
|
|
151
|
+
const width = this.columnWidths[header] || this.defaultWidth;
|
|
152
|
+
return `<col min="${index + 1}" max="${index + 1}" width="${width}" customWidth="1"/>`;
|
|
153
|
+
})
|
|
154
|
+
.join('');
|
|
155
|
+
}
|
|
156
|
+
generateRowsXml(data) {
|
|
157
|
+
return data
|
|
158
|
+
.map(row => `<row>${row
|
|
159
|
+
.map(cell => {
|
|
160
|
+
if (isNil(cell) || isEmpty(cell)) {
|
|
161
|
+
return `<c t="inlineStr"><is><t></t></is></c>`; // String cell
|
|
162
|
+
}
|
|
163
|
+
else if (isNumber(Number(cell)) && !isNaN(Number(cell))) {
|
|
164
|
+
return `<c t="n"><v>${Number(cell)}</v></c>`; // Number cell
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
return `<c t="inlineStr"><is><t>${XmlUtils.escapeXml(cell)}</t></is></c>`; // String cell
|
|
168
|
+
}
|
|
169
|
+
})
|
|
170
|
+
.join('')}</row>`)
|
|
171
|
+
.join('');
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
class ZipFileCreator {
|
|
175
|
+
async createZipFile(contents, compressionType, compressionLevel) {
|
|
176
|
+
const zip = new JSZip();
|
|
177
|
+
const blob = 'blob';
|
|
178
|
+
contents.forEach((content, filename) => {
|
|
179
|
+
zip.file(filename, content);
|
|
180
|
+
});
|
|
181
|
+
const options = { type: blob };
|
|
182
|
+
if (compressionType !== FILE_COMPRESSION_TYPES_VALUES.store) {
|
|
183
|
+
options.compression = compressionType;
|
|
184
|
+
options.compressionOptions = { level: compressionLevel };
|
|
185
|
+
}
|
|
186
|
+
return (await zip.generateAsync(options));
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
class ExcelGenerator {
|
|
190
|
+
static getLabel() {
|
|
191
|
+
return gettext('Microsoft Excel');
|
|
192
|
+
}
|
|
193
|
+
static getTitle() {
|
|
194
|
+
return 'Excel';
|
|
195
|
+
}
|
|
196
|
+
static getType() {
|
|
197
|
+
return 'excel';
|
|
198
|
+
}
|
|
199
|
+
static getIcon() {
|
|
200
|
+
return 'excel';
|
|
201
|
+
}
|
|
202
|
+
static getFileExtension() {
|
|
203
|
+
return 'xlsx';
|
|
204
|
+
}
|
|
205
|
+
static getAcceptType() {
|
|
206
|
+
return 'application/vnd.ms-excel';
|
|
207
|
+
}
|
|
208
|
+
static getMimeType() {
|
|
209
|
+
return 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
|
|
210
|
+
}
|
|
211
|
+
static getZipName() {
|
|
212
|
+
return 'export_excel.zip';
|
|
213
|
+
}
|
|
214
|
+
static async convertToMergedExcel(exportData, mergedExportDetails) {
|
|
215
|
+
const instance = ExcelGenerator.getInstance();
|
|
216
|
+
const { timeSeries, uniqueColumnIdentifiers } = instance.dataTransformer.transformToMergedFormat(exportData);
|
|
217
|
+
const rows = [
|
|
218
|
+
instance.createMergedFileHeaderRow(uniqueColumnIdentifiers, mergedExportDetails),
|
|
219
|
+
...instance.createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers)
|
|
220
|
+
];
|
|
221
|
+
return instance.createExcelFile(rows, mergedExportDetails);
|
|
222
|
+
}
|
|
223
|
+
static getInstance() {
|
|
224
|
+
if (!ExcelGenerator.instance) {
|
|
225
|
+
ExcelGenerator.instance = new ExcelGenerator();
|
|
226
|
+
}
|
|
227
|
+
return ExcelGenerator.instance;
|
|
228
|
+
}
|
|
229
|
+
constructor() {
|
|
230
|
+
this.dataTransformer = new ExcelDataTransformer();
|
|
231
|
+
this.xmlGenerator = new ExcelXmlGenerator();
|
|
232
|
+
this.fileCreator = new ZipFileCreator();
|
|
233
|
+
}
|
|
234
|
+
async createExcelFile(data, details) {
|
|
235
|
+
const contents = new Map([
|
|
236
|
+
['[Content_Types].xml', this.xmlGenerator.CONTENT_TYPES_XML],
|
|
237
|
+
['_rels/.rels', this.xmlGenerator.RELS_XML],
|
|
238
|
+
[
|
|
239
|
+
'xl/workbook.xml',
|
|
240
|
+
this.xmlGenerator.generateWorkbookXml(details?.aggregation ? details?.aggregation : 'NO AGGREGATION')
|
|
241
|
+
],
|
|
242
|
+
['xl/worksheets/sheet1.xml', this.xmlGenerator.generateSheetXml(data)],
|
|
243
|
+
['xl/sharedStrings.xml', this.xmlGenerator.SHARED_STRINGS_XML],
|
|
244
|
+
['docProps/app.xml', this.xmlGenerator.generateAppXml('Custom Script')],
|
|
245
|
+
['docProps/core.xml', this.xmlGenerator.generateCoreXml('Custom Script')],
|
|
246
|
+
['xl/_rels/workbook.xml.rels', this.xmlGenerator.WORKBOOK_RELS_XML]
|
|
247
|
+
]);
|
|
248
|
+
return this.fileCreator.createZipFile(contents, FILE_COMPRESSION_TYPES_VALUES.deflate, 9);
|
|
249
|
+
}
|
|
250
|
+
createMergedFileHeaderRow(uniqueColumnIdentifiers, details) {
|
|
251
|
+
const time = details ? `time => from ${details.dateFrom} to ${details.dateTo}` : 'time';
|
|
252
|
+
return [time, ...uniqueColumnIdentifiers];
|
|
253
|
+
}
|
|
254
|
+
createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers) {
|
|
255
|
+
return Array.from(timeSeries.entries())
|
|
256
|
+
.filter(([time, values]) => this.isValidEntry(time, values))
|
|
257
|
+
.map(([time, values]) => this.createDataRow(time, values, uniqueColumnIdentifiers));
|
|
258
|
+
}
|
|
259
|
+
isValidEntry(time, values) {
|
|
260
|
+
return (time !== null && Object.values(values).some(value => value !== null && value !== undefined));
|
|
261
|
+
}
|
|
262
|
+
createDataRow(time, values, uniqueColumnIdentifiers) {
|
|
263
|
+
const row = [time];
|
|
264
|
+
uniqueColumnIdentifiers.forEach(key => {
|
|
265
|
+
const value = values[key];
|
|
266
|
+
row.push(value !== undefined && value !== null ? value.toString() : '');
|
|
267
|
+
});
|
|
268
|
+
return row;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
export const ExcelGeneratorAdapter = {
|
|
272
|
+
getLabel: ExcelGenerator.getLabel.bind(ExcelGenerator),
|
|
273
|
+
getIcon: ExcelGenerator.getIcon.bind(ExcelGenerator),
|
|
274
|
+
getFileExtension: ExcelGenerator.getFileExtension.bind(ExcelGenerator),
|
|
275
|
+
getMimeType: ExcelGenerator.getMimeType.bind(ExcelGenerator),
|
|
276
|
+
generateMerged: ExcelGenerator.convertToMergedExcel.bind(ExcelGenerator),
|
|
277
|
+
getType: ExcelGenerator.getType.bind(ExcelGenerator),
|
|
278
|
+
getTitle: ExcelGenerator.getTitle.bind(ExcelGenerator),
|
|
279
|
+
getZipName: ExcelGenerator.getZipName.bind(ExcelGenerator),
|
|
280
|
+
getAcceptType: ExcelGenerator.getAcceptType.bind(ExcelGenerator)
|
|
281
|
+
};
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-generator.js","sourceRoot":"","sources":["../../../../../../datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/generators/excel-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { gettext } from '@c8y/ngx-components';\nimport JSZip from 'jszip';\nimport { isEmpty, isNil, isNumber } from 'lodash-es';\nimport {\n  ExportData,\n  FILE_COMPRESSION_TYPES_VALUES,\n  FileCompressionTypes,\n  FileGenerator,\n  IDataTransformer,\n  MergedExportDetails,\n  TimeSeriesColumnData\n} from '../../../datapoints-export-selector.model';\n\ninterface IXmlGenerator {\n  RELS_XML: string;\n  CONTENT_TYPES_XML: string;\n  WORKBOOK_RELS_XML: string;\n  SHARED_STRINGS_XML: string;\n  generateWorkbookXml(sheetName?: string): string;\n  generateSheetXml(data: string[][]): string;\n  generateAppXml(name: string): string;\n  generateCoreXml(name: string): string;\n}\n\ninterface IXmlFileCreator {\n  createZipFile(\n    contents: Map<string, string>,\n    compressionType: FileCompressionTypes,\n    compressionLevel: number\n  ): Promise<Blob>;\n}\n\n// Utility functions\nclass XmlUtils {\n  static escapeXml(unsafe: string): string {\n    return unsafe.replace(/[<>&'\"]/g, c => {\n      switch (c) {\n        case '<':\n          return '&lt;';\n        case '>':\n          return '&gt;';\n        case '&':\n          return '&amp;';\n        case \"'\":\n          return '&apos;';\n        case '\"':\n          return '&quot;';\n      }\n    });\n  }\n}\n\nexport class ExcelDataTransformer implements IDataTransformer {\n  transformToMergedFormat(exportData: ExportData[]): TimeSeriesColumnData {\n    const timeSeries = new Map<string, Record<string, number>>();\n    const uniqueColumnIdentifiers = new Set<string>();\n\n    exportData.forEach(\n      ({ time, device_name, fragment_series, unit, value_min, value_max, source }) => {\n        const measurementIdentifier = this.createMeasurementIdentifier(\n          device_name,\n          fragment_series,\n          unit,\n          source\n        );\n\n        if (!timeSeries.has(time)) {\n          timeSeries.set(time, {});\n        }\n\n        const timeEntry = timeSeries.get(time);\n        if (timeEntry) {\n          const minKey = this.formatMinKey(measurementIdentifier);\n          const maxKey = this.formatMaxKey(measurementIdentifier);\n\n          timeEntry[minKey] = value_min;\n          timeEntry[maxKey] = value_max;\n\n          uniqueColumnIdentifiers.add(minKey);\n          uniqueColumnIdentifiers.add(maxKey);\n        }\n      }\n    );\n\n    return {\n      timeSeries,\n      uniqueColumnIdentifiers: Array.from(uniqueColumnIdentifiers)\n    };\n  }\n\n  private createMeasurementIdentifier(\n    deviceName: string,\n    fragmentSeries: string,\n    unit: string,\n    source: string | number\n  ): string {\n    return unit\n      ? `(${source}) ${deviceName} -> ${fragmentSeries} [${unit}]`\n      : `(${source}) ${deviceName} -> ${fragmentSeries}`;\n  }\n\n  private formatMinKey(baseKey: string): string {\n    return `${baseKey} (min)`;\n  }\n\n  private formatMaxKey(baseKey: string): string {\n    return `${baseKey} (max)`;\n  }\n}\n\nclass ExcelXmlGenerator implements IXmlGenerator {\n  private columnWidths = {\n    time: 25,\n    source: 10,\n    device_name: 20,\n    'fragment.series': 20,\n    value_min: 15,\n    value_max: 15,\n    unit: 5\n  };\n  private defaultWidth = 30;\n\n  readonly RELS_XML =\n    '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n' +\n    '<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">\\n' +\n    '  <Relationship Id=\"rId1\" Target=\"xl/workbook.xml\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\"/>\\n' +\n    '  <Relationship Id=\"rId2\" Target=\"docProps/app.xml\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties\"/>\\n' +\n    '  <Relationship Id=\"rId3\" Target=\"docProps/core.xml\" Type=\"http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties\"/>\\n' +\n    '</Relationships>';\n\n  readonly CONTENT_TYPES_XML =\n    '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\\n' +\n    '<Types xmlns=\"http://schemas.openxmlformats.org/package/2006/content-types\">\\n' +\n    '  <Default ContentType=\"application/vnd.openxmlformats-package.relationships+xml\" Extension=\"rels\"/>\\n' +\n    '  <Default ContentType=\"application/xml\" Extension=\"xml\"/>\\n' +\n    '  <Override ContentType=\"application/vnd.openxmlformats-officedocument.extended-properties+xml\" PartName=\"/docProps/app.xml\"/>\\n' +\n    '  <Override ContentType=\"application/vnd.openxmlformats-package.core-properties+xml\" PartName=\"/docProps/core.xml\"/>\\n' +\n    '  <Override ContentType=\"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\" PartName=\"/xl/sharedStrings.xml\"/>\\n' +\n    '  <Override ContentType=\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\" PartName=\"/xl/workbook.xml\"/>\\n' +\n    '  <Override ContentType=\"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\" PartName=\"/xl/worksheets/sheet1.xml\"/>\\n' +\n    '</Types>';\n\n  readonly WORKBOOK_RELS_XML =\n    '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n' +\n    '<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">\\n' +\n    '  <Relationship Id=\"rId1\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings\" Target=\"sharedStrings.xml\"/>\\n' +\n    '  <Relationship Id=\"rId3\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet\" Target=\"worksheets/sheet1.xml\"/>\\n' +\n    '</Relationships>';\n\n  readonly SHARED_STRINGS_XML =\n    '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n    '<sst count=\"0\" uniqueCount=\"0\" xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\"/>';\n\n  generateWorkbookXml(sheetName = 'Measurements'): string {\n    return (\n      '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n' +\n      `<workbook xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" xmlns:r=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships\"><sheets><sheet name='${sheetName}' r:id=\"rId3\" sheetId=\"1\"/></sheets></workbook>`\n    );\n  }\n\n  generateSheetXml(data: string[][]): string {\n    const headers = data[0];\n    const colsXml = this.generateColsXml(headers);\n    const rowsXml = this.generateRowsXml(data);\n\n    return `<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\n      <worksheet xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" xmlns:r=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships\">\n        <cols>${colsXml}</cols>\n        <sheetData>${rowsXml}</sheetData>\n      </worksheet>`;\n  }\n\n  generateAppXml(name: string): string {\n    return (\n      '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n' +\n      '<Properties xmlns=\"http://schemas.openxmlformats.org/officeDocument/2006/extended-properties\" xmlns:vt=\"http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes\">\\n' +\n      `  <Application>${name}</Application>\\n` +\n      '  <DocSecurity>0</DocSecurity>\\n' +\n      '  <ScaleCrop>false</ScaleCrop>\\n' +\n      '  <HeadingPairs>\\n' +\n      '    <vt:vector size=\"2\" baseType=\"variant\">\\n' +\n      '      <vt:variant>\\n' +\n      '        <vt:lpstr>Worksheets</vt:lpstr>\\n' +\n      '      </vt:variant>\\n' +\n      '      <vt:variant>\\n' +\n      '        <vt:i4>1</vt:i4>\\n' +\n      '      </vt:variant>\\n' +\n      '    </vt:vector>\\n' +\n      '  </HeadingPairs>\\n' +\n      '  <TitlesOfParts>\\n' +\n      '    <vt:vector size=\"1\" baseType=\"lpstr\">\\n' +\n      '      <vt:lpstr>Sheet1</vt:lpstr>\\n' +\n      '    </vt:vector>\\n' +\n      '  </TitlesOfParts>\\n' +\n      '  <Company></Company>\\n' +\n      '  <LinksUpToDate>false</LinksUpToDate>\\n' +\n      '  <SharedDoc>false</SharedDoc>\\n' +\n      '  <HyperlinksChanged>false</HyperlinksChanged>\\n' +\n      '  <AppVersion>16.0300</AppVersion>\\n' +\n      '</Properties>'\n    );\n  }\n\n  generateCoreXml(name: string): string {\n    const now = new Date().toISOString();\n    return (\n      '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n' +\n      '<cp:coreProperties xmlns:cp=\"http://schemas.openxmlformats.org/package/2006/metadata/core-properties\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:dcterms=\"http://purl.org/dc/terms/\" xmlns:dcmitype=\"http://purl.org/dc/dcmitype/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\">\\n' +\n      `  <dc:creator>${name}</dc:creator>\\n` +\n      `  <cp:lastModifiedBy>${name}</cp:lastModifiedBy>\\n` +\n      `  <dcterms:created xsi:type=\"dcterms:W3CDTF\">${now}</dcterms:created>\\n` +\n      `  <dcterms:modified xsi:type=\"dcterms:W3CDTF\">${now}</dcterms:modified>\\n` +\n      '</cp:coreProperties>'\n    );\n  }\n\n  private generateColsXml(headers: string[]): string {\n    return headers\n      .map((header, index) => {\n        const width = this.columnWidths[header] || this.defaultWidth;\n        return `<col min=\"${index + 1}\" max=\"${index + 1}\" width=\"${width}\" customWidth=\"1\"/>`;\n      })\n      .join('');\n  }\n\n  private generateRowsXml(data: string[][]): string {\n    return data\n      .map(\n        row =>\n          `<row>${row\n            .map(cell => {\n              if (isNil(cell) || isEmpty(cell)) {\n                return `<c t=\"inlineStr\"><is><t></t></is></c>`; // String cell\n              } else if (isNumber(Number(cell)) && !isNaN(Number(cell))) {\n                return `<c t=\"n\"><v>${Number(cell)}</v></c>`; // Number cell\n              } else {\n                return `<c t=\"inlineStr\"><is><t>${XmlUtils.escapeXml(cell)}</t></is></c>`; // String cell\n              }\n            })\n            .join('')}</row>`\n      )\n      .join('');\n  }\n}\n\nclass ZipFileCreator implements IXmlFileCreator {\n  async createZipFile(\n    contents: Map<string, string>,\n    compressionType: FileCompressionTypes,\n    compressionLevel: number\n  ): Promise<Blob> {\n    const zip = new JSZip();\n    const blob = 'blob';\n\n    contents.forEach((content, filename) => {\n      zip.file(filename, content);\n    });\n\n    const options: JSZip.JSZipGeneratorOptions = { type: blob };\n    if (compressionType !== FILE_COMPRESSION_TYPES_VALUES.store) {\n      options.compression = compressionType;\n      options.compressionOptions = { level: compressionLevel };\n    }\n\n    return (await zip.generateAsync(options)) as Blob;\n  }\n}\n\nclass ExcelGenerator {\n  static getLabel(): string {\n    return gettext('Microsoft Excel');\n  }\n\n  static getTitle(): string {\n    return 'Excel';\n  }\n\n  static getType(): string {\n    return 'excel';\n  }\n\n  static getIcon(): string {\n    return 'excel';\n  }\n\n  static getFileExtension(): string {\n    return 'xlsx';\n  }\n\n  static getAcceptType(): string {\n    return 'application/vnd.ms-excel';\n  }\n\n  static getMimeType(): string {\n    return 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';\n  }\n\n  static getZipName(): string {\n    return 'export_excel.zip';\n  }\n\n  static async convertToMergedExcel(\n    exportData: ExportData[],\n    mergedExportDetails: MergedExportDetails\n  ): Promise<Blob> {\n    const instance = ExcelGenerator.getInstance();\n    const { timeSeries, uniqueColumnIdentifiers } =\n      instance.dataTransformer.transformToMergedFormat(exportData);\n\n    const rows = [\n      instance.createMergedFileHeaderRow(uniqueColumnIdentifiers, mergedExportDetails),\n      ...instance.createMergedFileDataRows(timeSeries, uniqueColumnIdentifiers)\n    ];\n\n    return instance.createExcelFile(rows, mergedExportDetails);\n  }\n\n  private static getInstance(): ExcelGenerator {\n    if (!ExcelGenerator.instance) {\n      ExcelGenerator.instance = new ExcelGenerator();\n    }\n    return ExcelGenerator.instance;\n  }\n\n  private static instance: ExcelGenerator;\n  private dataTransformer: IDataTransformer;\n  private xmlGenerator: IXmlGenerator;\n  private fileCreator: IXmlFileCreator;\n\n  private constructor() {\n    this.dataTransformer = new ExcelDataTransformer();\n    this.xmlGenerator = new ExcelXmlGenerator();\n    this.fileCreator = new ZipFileCreator();\n  }\n\n  private async createExcelFile(data: string[][], details?: MergedExportDetails): Promise<Blob> {\n    const contents = new Map<string, string>([\n      ['[Content_Types].xml', this.xmlGenerator.CONTENT_TYPES_XML],\n      ['_rels/.rels', this.xmlGenerator.RELS_XML],\n      [\n        'xl/workbook.xml',\n        this.xmlGenerator.generateWorkbookXml(\n          details?.aggregation ? details?.aggregation : 'NO AGGREGATION'\n        )\n      ],\n      ['xl/worksheets/sheet1.xml', this.xmlGenerator.generateSheetXml(data)],\n      ['xl/sharedStrings.xml', this.xmlGenerator.SHARED_STRINGS_XML],\n      ['docProps/app.xml', this.xmlGenerator.generateAppXml('Custom Script')],\n      ['docProps/core.xml', this.xmlGenerator.generateCoreXml('Custom Script')],\n      ['xl/_rels/workbook.xml.rels', this.xmlGenerator.WORKBOOK_RELS_XML]\n    ]);\n\n    return this.fileCreator.createZipFile(contents, FILE_COMPRESSION_TYPES_VALUES.deflate, 9);\n  }\n\n  private createMergedFileHeaderRow(\n    uniqueColumnIdentifiers: string[],\n    details?: MergedExportDetails\n  ): string[] {\n    const time = details ? `time => from ${details.dateFrom} to ${details.dateTo}` : 'time';\n    return [time, ...uniqueColumnIdentifiers];\n  }\n\n  private createMergedFileDataRows(\n    timeSeries: Map<string, Record<string, number>>,\n    uniqueColumnIdentifiers: string[]\n  ): string[][] {\n    return Array.from(timeSeries.entries())\n      .filter(([time, values]) => this.isValidEntry(time, values))\n      .map(([time, values]) => this.createDataRow(time, values, uniqueColumnIdentifiers));\n  }\n\n  private isValidEntry(time: string, values: Record<string, number>): boolean {\n    return (\n      time !== null && Object.values(values).some(value => value !== null && value !== undefined)\n    );\n  }\n\n  private createDataRow(\n    time: string,\n    values: Record<string, number>,\n    uniqueColumnIdentifiers: string[]\n  ): string[] {\n    const row = [time];\n    uniqueColumnIdentifiers.forEach(key => {\n      const value = values[key];\n      row.push(value !== undefined && value !== null ? value.toString() : '');\n    });\n    return row;\n  }\n}\n\nexport const ExcelGeneratorAdapter: FileGenerator = {\n  getLabel: ExcelGenerator.getLabel.bind(ExcelGenerator),\n  getIcon: ExcelGenerator.getIcon.bind(ExcelGenerator),\n  getFileExtension: ExcelGenerator.getFileExtension.bind(ExcelGenerator),\n  getMimeType: ExcelGenerator.getMimeType.bind(ExcelGenerator),\n  generateMerged: ExcelGenerator.convertToMergedExcel.bind(ExcelGenerator),\n  getType: ExcelGenerator.getType.bind(ExcelGenerator),\n  getTitle: ExcelGenerator.getTitle.bind(ExcelGenerator),\n  getZipName: ExcelGenerator.getZipName.bind(ExcelGenerator),\n  getAcceptType: ExcelGenerator.getAcceptType.bind(ExcelGenerator)\n};\n"]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class UtilsService {
|
|
4
|
+
transformDataStructure(data) {
|
|
5
|
+
const result = {};
|
|
6
|
+
data.forEach(sourceItem => {
|
|
7
|
+
const { source: sourceId, data: sourceData } = sourceItem;
|
|
8
|
+
result[sourceId] = {};
|
|
9
|
+
sourceData.series.forEach((seriesInfo, index) => {
|
|
10
|
+
const { type, name, unit } = seriesInfo;
|
|
11
|
+
/**
|
|
12
|
+
* Unique key to distinguish between different series from same source,
|
|
13
|
+
* e.g.: c8y_Acceleration.accelerationX, c8y_Acceleration.accelerationY, c8y_Acceleration.accelerationZ
|
|
14
|
+
*/
|
|
15
|
+
const seriesKey = `${type}.${name}`;
|
|
16
|
+
result[sourceId][seriesKey] = {
|
|
17
|
+
values: {},
|
|
18
|
+
seriesDetails: { name, unit, type }
|
|
19
|
+
};
|
|
20
|
+
let hasValues = false;
|
|
21
|
+
Object.entries(sourceData.values).forEach(([timestamp, measurements]) => {
|
|
22
|
+
if (!measurements) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const measurement = measurements[index];
|
|
26
|
+
if (measurement !== null && measurement !== undefined) {
|
|
27
|
+
result[sourceId][seriesKey].values[timestamp] = measurement;
|
|
28
|
+
hasValues = true;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
if (!hasValues) {
|
|
32
|
+
result[sourceId][seriesKey].values = null;
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Formats a date range into a specific string format, handling UTC dates correctly.
|
|
40
|
+
*
|
|
41
|
+
* @param fromDate - The start date in ISO format (e.g., "2023-12-04T12:40:00.000Z")
|
|
42
|
+
* @param toDate - The end date in ISO format (e.g., "2023-12-06T23:50:00.000Z")
|
|
43
|
+
* @returns A string representing the date range in the format "ddmmmyyhhmm-ddmmmyyhhmm"
|
|
44
|
+
* where d=day, m=month, y=year, h=hour, m=minute
|
|
45
|
+
*
|
|
46
|
+
* Example
|
|
47
|
+
* ```typescript
|
|
48
|
+
* const fromDate = "2023-12-04T12:40:00.000Z";
|
|
49
|
+
* const toDate = "2023-12-06T23:50:00.000Z";
|
|
50
|
+
* const formattedRange = getFormattedDateRange(fromDate, toDate);
|
|
51
|
+
* console.log(formattedRange); // Output: "04dec231240-06dec232350"
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
getFormattedDateRange(fromDate, toDate) {
|
|
55
|
+
const formatDate = (dateString) => {
|
|
56
|
+
const date = new Date(dateString);
|
|
57
|
+
if (isNaN(date.getTime())) {
|
|
58
|
+
throw new Error(`Invalid date string: ${dateString}`);
|
|
59
|
+
}
|
|
60
|
+
const day = date.getUTCDate().toString().padStart(2, '0');
|
|
61
|
+
const month = date.toLocaleString('en', { month: 'short', timeZone: 'UTC' }).toLowerCase();
|
|
62
|
+
const hours = date.getUTCHours().toString().padStart(2, '0');
|
|
63
|
+
const minutes = date.getUTCMinutes().toString().padStart(2, '0');
|
|
64
|
+
const seconds = date.getUTCSeconds().toString().padStart(2, '0');
|
|
65
|
+
return `${day}${month}${hours}${minutes}${seconds}`;
|
|
66
|
+
};
|
|
67
|
+
return `${formatDate(fromDate)}-${formatDate(toDate)}`;
|
|
68
|
+
}
|
|
69
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: UtilsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
70
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: UtilsService, providedIn: 'root' }); }
|
|
71
|
+
}
|
|
72
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: UtilsService, decorators: [{
|
|
73
|
+
type: Injectable,
|
|
74
|
+
args: [{ providedIn: 'root' }]
|
|
75
|
+
}] });
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.service.js","sourceRoot":"","sources":["../../../../../datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/utils.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type Measurement = number | { min: number; max: number };\n\nexport interface SeriesInfo {\n  unit: string | null | undefined;\n  name: string;\n  type: string | null | undefined;\n}\n\nexport interface SourceData {\n  series: SeriesInfo[];\n  values: {\n    [timestamp: string]: (Measurement | null)[] | undefined;\n  };\n  truncated: boolean;\n}\n\nexport interface SourceItem {\n  source: string | number;\n  data: SourceData;\n}\n\nexport interface TransformedSeries {\n  values: { [timestamp: string]: Measurement } | null;\n  seriesDetails: SeriesInfo;\n}\n\nexport interface TransformedSource {\n  [seriesType: string]: TransformedSeries;\n}\n\nexport interface TransformedData {\n  [sourceId: string]: TransformedSource;\n}\n\n@Injectable({ providedIn: 'root' })\nexport class UtilsService {\n  transformDataStructure(data: SourceItem[]): TransformedData {\n    const result: TransformedData = {};\n\n    data.forEach(sourceItem => {\n      const { source: sourceId, data: sourceData } = sourceItem;\n      result[sourceId] = {};\n\n      sourceData.series.forEach((seriesInfo, index) => {\n        const { type, name, unit } = seriesInfo;\n        /**\n         * Unique key to distinguish between different series from same source,\n         * e.g.: c8y_Acceleration.accelerationX, c8y_Acceleration.accelerationY, c8y_Acceleration.accelerationZ\n         */\n        const seriesKey = `${type}.${name}`;\n\n        result[sourceId][seriesKey] = {\n          values: {},\n          seriesDetails: { name, unit, type }\n        };\n\n        let hasValues = false;\n        Object.entries(sourceData.values).forEach(([timestamp, measurements]) => {\n          if (!measurements) {\n            return;\n          }\n          const measurement = measurements[index];\n\n          if (measurement !== null && measurement !== undefined) {\n            result[sourceId][seriesKey].values[timestamp] = measurement;\n            hasValues = true;\n          }\n        });\n\n        if (!hasValues) {\n          result[sourceId][seriesKey].values = null;\n        }\n      });\n    });\n\n    return result;\n  }\n\n  /**\n   * Formats a date range into a specific string format, handling UTC dates correctly.\n   *\n   * @param fromDate - The start date in ISO format (e.g., \"2023-12-04T12:40:00.000Z\")\n   * @param toDate - The end date in ISO format (e.g., \"2023-12-06T23:50:00.000Z\")\n   * @returns A string representing the date range in the format \"ddmmmyyhhmm-ddmmmyyhhmm\"\n   *          where d=day, m=month, y=year, h=hour, m=minute\n   *\n   * Example\n   * ```typescript\n   * const fromDate = \"2023-12-04T12:40:00.000Z\";\n   * const toDate = \"2023-12-06T23:50:00.000Z\";\n   * const formattedRange = getFormattedDateRange(fromDate, toDate);\n   * console.log(formattedRange); // Output: \"04dec231240-06dec232350\"\n   * ```\n   */\n  getFormattedDateRange(fromDate: string, toDate: string): string {\n    const formatDate = (dateString: string): string => {\n      const date = new Date(dateString);\n      if (isNaN(date.getTime())) {\n        throw new Error(`Invalid date string: ${dateString}`);\n      }\n      const day = date.getUTCDate().toString().padStart(2, '0');\n      const month = date.toLocaleString('en', { month: 'short', timeZone: 'UTC' }).toLowerCase();\n      const hours = date.getUTCHours().toString().padStart(2, '0');\n      const minutes = date.getUTCMinutes().toString().padStart(2, '0');\n      const seconds = date.getUTCSeconds().toString().padStart(2, '0');\n      return `${day}${month}${hours}${minutes}${seconds}`;\n    };\n\n    return `${formatDate(fromDate)}-${formatDate(toDate)}`;\n  }\n}\n"]}
|