@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,124 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { AGGREGATION_VALUES } from '@c8y/ngx-components';
|
|
3
|
+
import { TIME_RANGE_INTERVAL_UNITS_VALUES } from '@c8y/ngx-components/datapoints-export-selector';
|
|
4
|
+
import { INTERVALS } from '@c8y/ngx-components/interval-picker';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class DatapointsTableConfigService {
|
|
7
|
+
/**
|
|
8
|
+
* Determines the interval between two dates.
|
|
9
|
+
*
|
|
10
|
+
* @param dateFrom - The starting date in ISO 8601 string format.
|
|
11
|
+
* @param dateTo - The ending date in ISO 8601 string format.
|
|
12
|
+
* @returns The time range interval unit.
|
|
13
|
+
*/
|
|
14
|
+
// TODO same method is in datapoints export component. Consider moving it to a shared service, or reuse it here
|
|
15
|
+
// when DPT will be integrating with MTM-59689.
|
|
16
|
+
// Integration task: MTM-60221
|
|
17
|
+
// tests are already added in MTM-60217
|
|
18
|
+
determineInterval(dateFrom, dateTo) {
|
|
19
|
+
const from = new Date(dateFrom);
|
|
20
|
+
const to = new Date(dateTo);
|
|
21
|
+
const differenceInMilliseconds = to.getTime() - from.getTime();
|
|
22
|
+
const [minutes, hours, days, weeks, months, custom] = INTERVALS;
|
|
23
|
+
const intervals = [
|
|
24
|
+
{ value: minutes.timespanInMs, id: minutes.id }, // milliseconds in one minute
|
|
25
|
+
{ value: hours.timespanInMs, id: hours.id }, // milliseconds in one hour
|
|
26
|
+
{ value: days.timespanInMs, id: days.id }, // milliseconds in one day
|
|
27
|
+
{ value: weeks.timespanInMs, id: weeks.id }, // milliseconds in one week
|
|
28
|
+
{ value: months.timespanInMs, id: months.id } // approximation for milliseconds in one month
|
|
29
|
+
];
|
|
30
|
+
const interval = intervals.find(interval => differenceInMilliseconds <= interval.value);
|
|
31
|
+
return interval ? interval.id : custom.id;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Updates the disabled state of aggregation options based on the current value of the time interval form control.
|
|
35
|
+
*
|
|
36
|
+
* This method:
|
|
37
|
+
* - Retrieves the current date range from the form controls.
|
|
38
|
+
* - Determines the current time interval based on the date range.
|
|
39
|
+
* - Sets the disabled state for each aggregation option based on predefined conditions.
|
|
40
|
+
*
|
|
41
|
+
* The disabled state is stored in the `disabledAggregationOptions` object,
|
|
42
|
+
* where the key is the aggregation value and the value is a boolean indicating whether the option should be disabled.
|
|
43
|
+
*
|
|
44
|
+
* The `disabledConditions` object defines the conditions under which each aggregation option should be disabled.
|
|
45
|
+
*
|
|
46
|
+
* @param dateFrom - The starting date of the range.
|
|
47
|
+
* @param dateTo - The ending date of the range.
|
|
48
|
+
* @param aggregationValuesArr - An array of aggregation options.
|
|
49
|
+
* @returns An object containing the disabled state of each aggregation option.
|
|
50
|
+
*/
|
|
51
|
+
// TODO similar method is in datapoints export component. Consider moving it to a shared service when DPT will be integrating with MTM-59689.
|
|
52
|
+
// Integration task: MTM-60221
|
|
53
|
+
// tests are already added in MTM-60217
|
|
54
|
+
updateDisabledStateOfAggregationOptionEntries(dateFrom, dateTo, aggregationValuesArr) {
|
|
55
|
+
const currentInterval = this.determineInterval(dateFrom, dateTo);
|
|
56
|
+
const disabledConditions = {
|
|
57
|
+
[AGGREGATION_VALUES.daily]: [
|
|
58
|
+
TIME_RANGE_INTERVAL_UNITS_VALUES.minutes,
|
|
59
|
+
TIME_RANGE_INTERVAL_UNITS_VALUES.hours,
|
|
60
|
+
TIME_RANGE_INTERVAL_UNITS_VALUES.days
|
|
61
|
+
],
|
|
62
|
+
[AGGREGATION_VALUES.hourly]: [
|
|
63
|
+
TIME_RANGE_INTERVAL_UNITS_VALUES.minutes,
|
|
64
|
+
TIME_RANGE_INTERVAL_UNITS_VALUES.hours
|
|
65
|
+
],
|
|
66
|
+
[AGGREGATION_VALUES.minutely]: [TIME_RANGE_INTERVAL_UNITS_VALUES.minutes]
|
|
67
|
+
};
|
|
68
|
+
const disabledAggregationOptions = {};
|
|
69
|
+
for (const aggregationValue of aggregationValuesArr) {
|
|
70
|
+
disabledAggregationOptions[aggregationValue] =
|
|
71
|
+
disabledConditions[aggregationValue]?.includes(currentInterval) ?? false;
|
|
72
|
+
}
|
|
73
|
+
return disabledAggregationOptions;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Determines the new aggregation value based on the current value and disabled options.
|
|
77
|
+
*
|
|
78
|
+
* Goal is to switch to the next available aggregation option if the current one is disabled.
|
|
79
|
+
* - If the current option is disabled, sets the control to the first available (non-disabled) option based on the following order:
|
|
80
|
+
* - If the current value is `DAILY`, it switches to `HOURLY` if it's not disabled, otherwise to `MINUTELY` if `HOURLY` is also disabled.
|
|
81
|
+
* - If the current value is `HOURLY`, it switches to `MINUTELY` if it's not disabled.
|
|
82
|
+
* - If all options are disabled, it sets the value to `NONE`.
|
|
83
|
+
*
|
|
84
|
+
* @param currentValue - The current aggregation option.
|
|
85
|
+
* @param disabledOptions - An object containing disabled options.
|
|
86
|
+
* @returns The new aggregation option.
|
|
87
|
+
*/
|
|
88
|
+
determineNewAggregationValue(currentValue, disabledOptions) {
|
|
89
|
+
const { daily, hourly, minutely, none } = AGGREGATION_VALUES;
|
|
90
|
+
if (!disabledOptions[currentValue]) {
|
|
91
|
+
return currentValue; // Return the current value if it's not disabled
|
|
92
|
+
}
|
|
93
|
+
if (currentValue === daily) {
|
|
94
|
+
return !disabledOptions[hourly] ? hourly : !disabledOptions[minutely] ? minutely : none;
|
|
95
|
+
}
|
|
96
|
+
if (currentValue === hourly) {
|
|
97
|
+
return !disabledOptions[minutely] ? minutely : none;
|
|
98
|
+
}
|
|
99
|
+
return none; // Fallback to 'none' if all else fails
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Determines the aggregation value based on the provided interval.
|
|
103
|
+
*
|
|
104
|
+
* @param interval - The time range interval.
|
|
105
|
+
* @returns The corresponding aggregation value.
|
|
106
|
+
*/
|
|
107
|
+
determineAggregationValue(interval) {
|
|
108
|
+
const aggregationMap = {
|
|
109
|
+
[TIME_RANGE_INTERVAL_UNITS_VALUES.minutes]: AGGREGATION_VALUES.none,
|
|
110
|
+
[TIME_RANGE_INTERVAL_UNITS_VALUES.hours]: AGGREGATION_VALUES.minutely,
|
|
111
|
+
[TIME_RANGE_INTERVAL_UNITS_VALUES.days]: AGGREGATION_VALUES.hourly
|
|
112
|
+
};
|
|
113
|
+
return aggregationMap[interval] || AGGREGATION_VALUES.daily;
|
|
114
|
+
}
|
|
115
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsTableConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
116
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsTableConfigService, providedIn: 'root' }); }
|
|
117
|
+
}
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsTableConfigService, decorators: [{
|
|
119
|
+
type: Injectable,
|
|
120
|
+
args: [{
|
|
121
|
+
providedIn: 'root'
|
|
122
|
+
}]
|
|
123
|
+
}] });
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-table-config.service.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  AGGREGATION_VALUES,\n  AggregationOption,\n  AggregationOptionStatus\n} from '@c8y/ngx-components';\nimport {\n  TIME_RANGE_INTERVAL_UNITS_VALUES,\n  TimeRangeInterval\n} from '@c8y/ngx-components/datapoints-export-selector';\nimport { INTERVALS } from '@c8y/ngx-components/interval-picker';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DatapointsTableConfigService {\n  /**\n   * Determines the interval between two dates.\n   *\n   * @param dateFrom - The starting date in ISO 8601 string format.\n   * @param dateTo - The ending date in ISO 8601 string format.\n   * @returns The time range interval unit.\n   */\n  // TODO same method is in datapoints export component. Consider moving it to a shared service, or reuse it here\n  // when DPT will be integrating with MTM-59689.\n  // Integration task: MTM-60221\n  // tests are already added in MTM-60217\n  determineInterval(dateFrom: string, dateTo: string): TimeRangeInterval {\n    const from = new Date(dateFrom);\n    const to = new Date(dateTo);\n    const differenceInMilliseconds = to.getTime() - from.getTime();\n\n    const [minutes, hours, days, weeks, months, custom] = INTERVALS;\n\n    const intervals = [\n      { value: minutes.timespanInMs, id: minutes.id }, // milliseconds in one minute\n      { value: hours.timespanInMs, id: hours.id }, // milliseconds in one hour\n      { value: days.timespanInMs, id: days.id }, // milliseconds in one day\n      { value: weeks.timespanInMs, id: weeks.id }, // milliseconds in one week\n      { value: months.timespanInMs, id: months.id } // approximation for milliseconds in one month\n    ];\n\n    const interval = intervals.find(interval => differenceInMilliseconds <= interval.value);\n\n    return interval ? interval.id : custom.id;\n  }\n\n  /**\n   * Updates the disabled state of aggregation options based on the current value of the time interval form control.\n   *\n   * This method:\n   * - Retrieves the current date range from the form controls.\n   * - Determines the current time interval based on the date range.\n   * - Sets the disabled state for each aggregation option based on predefined conditions.\n   *\n   * The disabled state is stored in the `disabledAggregationOptions` object,\n   * where the key is the aggregation value and the value is a boolean indicating whether the option should be disabled.\n   *\n   * The `disabledConditions` object defines the conditions under which each aggregation option should be disabled.\n   *\n   * @param dateFrom - The starting date of the range.\n   * @param dateTo - The ending date of the range.\n   * @param aggregationValuesArr - An array of aggregation options.\n   * @returns An object containing the disabled state of each aggregation option.\n   */\n  // TODO similar method is in datapoints export component. Consider moving it to a shared service when DPT will be integrating with MTM-59689.\n  // Integration task: MTM-60221\n  // tests are already added in MTM-60217\n  updateDisabledStateOfAggregationOptionEntries(\n    dateFrom: string,\n    dateTo: string,\n    aggregationValuesArr: readonly AggregationOption[]\n  ): AggregationOptionStatus {\n    const currentInterval = this.determineInterval(dateFrom, dateTo);\n\n    const disabledConditions = {\n      [AGGREGATION_VALUES.daily]: [\n        TIME_RANGE_INTERVAL_UNITS_VALUES.minutes,\n        TIME_RANGE_INTERVAL_UNITS_VALUES.hours,\n        TIME_RANGE_INTERVAL_UNITS_VALUES.days\n      ],\n      [AGGREGATION_VALUES.hourly]: [\n        TIME_RANGE_INTERVAL_UNITS_VALUES.minutes,\n        TIME_RANGE_INTERVAL_UNITS_VALUES.hours\n      ],\n      [AGGREGATION_VALUES.minutely]: [TIME_RANGE_INTERVAL_UNITS_VALUES.minutes]\n    };\n\n    const disabledAggregationOptions = {};\n\n    for (const aggregationValue of aggregationValuesArr) {\n      disabledAggregationOptions[aggregationValue] =\n        disabledConditions[aggregationValue]?.includes(currentInterval) ?? false;\n    }\n\n    return disabledAggregationOptions;\n  }\n\n  /**\n   * Determines the new aggregation value based on the current value and disabled options.\n   *\n   * Goal is to switch to the next available aggregation option if the current one is disabled.\n   * - If the current option is disabled, sets the control to the first available (non-disabled) option based on the following order:\n   *   - If the current value is `DAILY`, it switches to `HOURLY` if it's not disabled, otherwise to `MINUTELY` if `HOURLY` is also disabled.\n   *   - If the current value is `HOURLY`, it switches to `MINUTELY` if it's not disabled.\n   *   - If all options are disabled, it sets the value to `NONE`.\n   *\n   * @param currentValue - The current aggregation option.\n   * @param disabledOptions - An object containing disabled options.\n   * @returns The new aggregation option.\n   */\n  determineNewAggregationValue(\n    currentValue: AggregationOption,\n    disabledOptions: AggregationOptionStatus\n  ): AggregationOption {\n    const { daily, hourly, minutely, none } = AGGREGATION_VALUES;\n\n    if (!disabledOptions[currentValue]) {\n      return currentValue; // Return the current value if it's not disabled\n    }\n\n    if (currentValue === daily) {\n      return !disabledOptions[hourly] ? hourly : !disabledOptions[minutely] ? minutely : none;\n    }\n\n    if (currentValue === hourly) {\n      return !disabledOptions[minutely] ? minutely : none;\n    }\n\n    return none; // Fallback to 'none' if all else fails\n  }\n\n  /**\n   * Determines the aggregation value based on the provided interval.\n   *\n   * @param interval - The time range interval.\n   * @returns The corresponding aggregation value.\n   */\n  determineAggregationValue(interval: TimeRangeInterval): AggregationOption {\n    const aggregationMap = {\n      [TIME_RANGE_INTERVAL_UNITS_VALUES.minutes]: AGGREGATION_VALUES.none,\n      [TIME_RANGE_INTERVAL_UNITS_VALUES.hours]: AGGREGATION_VALUES.minutely,\n      [TIME_RANGE_INTERVAL_UNITS_VALUES.days]: AGGREGATION_VALUES.hourly\n    };\n\n    return aggregationMap[interval] || AGGREGATION_VALUES.daily;\n  }\n}\n"]}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { aggregationType as AggregationTypeEnum } from '@c8y/client';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* A pipe that adjusts the aggregated time range based on the aggregation type.
|
|
6
|
+
*
|
|
7
|
+
* ```html
|
|
8
|
+
* '9:00' | adjustAggregatedTimeRange: config.aggregation (e.g.:HOURLY)
|
|
9
|
+
* ```
|
|
10
|
+
* The output will be '9:00-10:00'.
|
|
11
|
+
*/
|
|
12
|
+
export class AdjustAggregatedTimeRangePipe {
|
|
13
|
+
/**
|
|
14
|
+
* Transforms the input time based on the aggregation type.
|
|
15
|
+
* @param inputTime The input time string.
|
|
16
|
+
* @param aggregationType The type of aggregation (optional).
|
|
17
|
+
* @returns The transformed time string.
|
|
18
|
+
*/
|
|
19
|
+
transform(inputTime, aggregationType) {
|
|
20
|
+
if (!aggregationType) {
|
|
21
|
+
return inputTime;
|
|
22
|
+
}
|
|
23
|
+
if (aggregationType === AggregationTypeEnum.DAILY) {
|
|
24
|
+
return '';
|
|
25
|
+
}
|
|
26
|
+
const date = this.createDateFromInput(inputTime);
|
|
27
|
+
const isTwelveHoursFormat = this.isTwelveHoursFormat(inputTime);
|
|
28
|
+
switch (aggregationType) {
|
|
29
|
+
case AggregationTypeEnum.HOURLY:
|
|
30
|
+
return this.getHourlyTimeRange(date, isTwelveHoursFormat);
|
|
31
|
+
case AggregationTypeEnum.MINUTELY:
|
|
32
|
+
return this.getMinutelyTimeRange(date, isTwelveHoursFormat);
|
|
33
|
+
default:
|
|
34
|
+
throw new Error('Unsupported aggregation type');
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Creates a date object from the input time string.
|
|
39
|
+
* @param inputTime The input time string.
|
|
40
|
+
* @returns The created Date object.
|
|
41
|
+
*/
|
|
42
|
+
createDateFromInput(inputTime) {
|
|
43
|
+
const defaultDate = '1970-01-01 ';
|
|
44
|
+
const isPM = /PM/i.test(inputTime);
|
|
45
|
+
const cleanedTime = inputTime.replace(/AM|PM/i, '').trim();
|
|
46
|
+
this.validateTimeFormat(cleanedTime, inputTime);
|
|
47
|
+
const dateTimeString = `${defaultDate}${cleanedTime}`;
|
|
48
|
+
const date = new Date(dateTimeString);
|
|
49
|
+
if (isNaN(date.getTime())) {
|
|
50
|
+
throw new Error('Invalid input time');
|
|
51
|
+
}
|
|
52
|
+
return this.adjustForPMTime(date, isPM);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Validates if the time string matches the required format and has valid values.
|
|
56
|
+
* @param time The time string to validate.
|
|
57
|
+
* @param originalInput The original input string (including AM/PM if present).
|
|
58
|
+
* @throws Error if the time format is invalid or values are out of range.
|
|
59
|
+
*/
|
|
60
|
+
validateTimeFormat(time, originalInput) {
|
|
61
|
+
const parts = time.split(':');
|
|
62
|
+
this.validateTimeParts(parts);
|
|
63
|
+
const [hoursStr, minutesStr, secondsStr] = parts;
|
|
64
|
+
this.validateTimeDigits(hoursStr, minutesStr, secondsStr);
|
|
65
|
+
const { hours, minutes, seconds } = this.parseTimeComponents(hoursStr, minutesStr, secondsStr);
|
|
66
|
+
this.validateTimeRanges(hours, minutes, seconds);
|
|
67
|
+
this.validateTimeFormat24Hour(hours, originalInput);
|
|
68
|
+
}
|
|
69
|
+
validateTimeParts(parts) {
|
|
70
|
+
if (parts.length < 2 || parts.length > 3) {
|
|
71
|
+
throw new Error('Invalid input time');
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
validateTimeDigits(hoursStr, minutesStr, secondsStr) {
|
|
75
|
+
if (!this.isValidNumberString(hoursStr) ||
|
|
76
|
+
!this.isValidNumberString(minutesStr) ||
|
|
77
|
+
(secondsStr !== undefined && !this.isValidNumberString(secondsStr))) {
|
|
78
|
+
throw new Error('Invalid input time');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
parseTimeComponents(hoursStr, minutesStr, secondsStr) {
|
|
82
|
+
return {
|
|
83
|
+
hours: Number(hoursStr),
|
|
84
|
+
minutes: Number(minutesStr),
|
|
85
|
+
seconds: secondsStr ? Number(secondsStr) : 0
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
validateTimeRanges(hours, minutes, seconds) {
|
|
89
|
+
if (hours > 23 || hours < 0 || minutes > 59 || minutes < 0 || seconds > 59 || seconds < 0) {
|
|
90
|
+
throw new Error('Invalid input time');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
validateTimeFormat24Hour(hours, originalInput) {
|
|
94
|
+
if (hours > 12 && this.hasAmPm(originalInput)) {
|
|
95
|
+
throw new Error('Invalid input time');
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Checks if string contains only digits and is 1-2 characters long.
|
|
100
|
+
* @param value String to check
|
|
101
|
+
* @returns boolean indicating if string is valid
|
|
102
|
+
*/
|
|
103
|
+
isValidNumberString(value) {
|
|
104
|
+
return (value.length > 0 &&
|
|
105
|
+
value.length <= 2 &&
|
|
106
|
+
value.split('').every(char => char >= '0' && char <= '9'));
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Checks if the input time has AM/PM markers.
|
|
110
|
+
* @param input The input time string to check.
|
|
111
|
+
* @returns boolean indicating if the input contains AM/PM.
|
|
112
|
+
*/
|
|
113
|
+
hasAmPm(input) {
|
|
114
|
+
return /AM|PM/i.test(input);
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Adjusts the date for PM times by adding 12 hours when necessary.
|
|
118
|
+
* @param date The date object to adjust.
|
|
119
|
+
* @param isPM Boolean indicating if the time is PM.
|
|
120
|
+
* @returns The adjusted Date object.
|
|
121
|
+
*/
|
|
122
|
+
adjustForPMTime(date, isPM) {
|
|
123
|
+
const hours = date.getHours();
|
|
124
|
+
if (isPM && hours < 12) {
|
|
125
|
+
date.setHours(hours + 12);
|
|
126
|
+
}
|
|
127
|
+
else if (!isPM && hours === 12) {
|
|
128
|
+
date.setHours(0);
|
|
129
|
+
}
|
|
130
|
+
return date;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Checks if the input time is in twelve hours format.
|
|
134
|
+
* @param inputTime The input time string.
|
|
135
|
+
* @returns True if the input time is in twelve hours format, false otherwise.
|
|
136
|
+
*/
|
|
137
|
+
isTwelveHoursFormat(inputTime) {
|
|
138
|
+
return /AM|PM/i.test(inputTime);
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Gets the hourly time range for the given date.
|
|
142
|
+
* @param date The date object.
|
|
143
|
+
* @param twelveHoursFormat Indicates whether to use twelve hours format.
|
|
144
|
+
* @returns The hourly time range string.
|
|
145
|
+
*/
|
|
146
|
+
getHourlyTimeRange(date, twelveHoursFormat) {
|
|
147
|
+
const nextHour = new Date(date.getTime());
|
|
148
|
+
nextHour.setHours(date.getHours() + 1);
|
|
149
|
+
return `${this.formatTime(date, twelveHoursFormat, true)}-${this.formatTime(nextHour, twelveHoursFormat, true)}`;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Gets the minutely time range for the given date.
|
|
153
|
+
* @param date The date object.
|
|
154
|
+
* @param twelveHoursFormat Indicates whether to use twelve hours format.
|
|
155
|
+
* @returns The minutely time range string.
|
|
156
|
+
*/
|
|
157
|
+
getMinutelyTimeRange(date, twelveHoursFormat) {
|
|
158
|
+
const nextMinute = new Date(date.getTime());
|
|
159
|
+
nextMinute.setMinutes(date.getMinutes() + 1);
|
|
160
|
+
return `${this.formatTime(date, twelveHoursFormat, false)}-${this.formatTime(nextMinute, twelveHoursFormat, false)}`;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Formats the given date into a time string.
|
|
164
|
+
* @param date The date to format.
|
|
165
|
+
* @param usePeriod Indicates whether to include the period (AM/PM) in the formatted time.
|
|
166
|
+
* @param useHourOnly Indicates whether to include only the hour part in the formatted time.
|
|
167
|
+
* @returns The formatted time string.
|
|
168
|
+
*/
|
|
169
|
+
formatTime(date, usePeriod, useHourOnly) {
|
|
170
|
+
const hours = date.getHours();
|
|
171
|
+
const minutes = date.getMinutes().toString().padStart(2, '0');
|
|
172
|
+
if (usePeriod) {
|
|
173
|
+
const period = hours >= 12 ? 'PM' : 'AM';
|
|
174
|
+
const formattedHours = hours % 12 === 0 ? 12 : hours % 12;
|
|
175
|
+
return `${formattedHours}:${useHourOnly ? '00' : minutes} ${period}`;
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
return `${hours.toString().padStart(2, '0')}:${useHourOnly ? '00' : minutes}`;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AdjustAggregatedTimeRangePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
182
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: AdjustAggregatedTimeRangePipe, isStandalone: true, name: "adjustAggregatedTimeRange" }); }
|
|
183
|
+
}
|
|
184
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AdjustAggregatedTimeRangePipe, decorators: [{
|
|
185
|
+
type: Pipe,
|
|
186
|
+
args: [{
|
|
187
|
+
name: 'adjustAggregatedTimeRange',
|
|
188
|
+
standalone: true
|
|
189
|
+
}]
|
|
190
|
+
}] });
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adjust-aggregated-time-range.pipe.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/adjust-aggregated-time-range.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { aggregationType as AggregationTypeEnum } from '@c8y/client';\nimport { AggregationOption } from '@c8y/ngx-components';\n\n/**\n * A pipe that adjusts the aggregated time range based on the aggregation type.\n *\n * ```html\n * '9:00' | adjustAggregatedTimeRange: config.aggregation (e.g.:HOURLY)\n * ```\n * The output will be '9:00-10:00'.\n */\n@Pipe({\n  name: 'adjustAggregatedTimeRange',\n  standalone: true\n})\nexport class AdjustAggregatedTimeRangePipe implements PipeTransform {\n  /**\n   * Transforms the input time based on the aggregation type.\n   * @param inputTime The input time string.\n   * @param aggregationType The type of aggregation (optional).\n   * @returns The transformed time string.\n   */\n  transform(inputTime: string, aggregationType?: AggregationOption): string {\n    if (!aggregationType) {\n      return inputTime;\n    }\n\n    if (aggregationType === AggregationTypeEnum.DAILY) {\n      return '';\n    }\n\n    const date = this.createDateFromInput(inputTime);\n    const isTwelveHoursFormat = this.isTwelveHoursFormat(inputTime);\n\n    switch (aggregationType) {\n      case AggregationTypeEnum.HOURLY:\n        return this.getHourlyTimeRange(date, isTwelveHoursFormat);\n      case AggregationTypeEnum.MINUTELY:\n        return this.getMinutelyTimeRange(date, isTwelveHoursFormat);\n      default:\n        throw new Error('Unsupported aggregation type');\n    }\n  }\n\n  /**\n   * Creates a date object from the input time string.\n   * @param inputTime The input time string.\n   * @returns The created Date object.\n   */\n  private createDateFromInput(inputTime: string): Date {\n    const defaultDate = '1970-01-01 ';\n    const isPM = /PM/i.test(inputTime);\n    const cleanedTime = inputTime.replace(/AM|PM/i, '').trim();\n\n    this.validateTimeFormat(cleanedTime, inputTime);\n\n    const dateTimeString = `${defaultDate}${cleanedTime}`;\n    const date = new Date(dateTimeString);\n\n    if (isNaN(date.getTime())) {\n      throw new Error('Invalid input time');\n    }\n\n    return this.adjustForPMTime(date, isPM);\n  }\n\n  /**\n   * Validates if the time string matches the required format and has valid values.\n   * @param time The time string to validate.\n   * @param originalInput The original input string (including AM/PM if present).\n   * @throws Error if the time format is invalid or values are out of range.\n   */\n  private validateTimeFormat(time: string, originalInput: string): void {\n    const parts = time.split(':');\n    this.validateTimeParts(parts);\n\n    const [hoursStr, minutesStr, secondsStr] = parts;\n    this.validateTimeDigits(hoursStr, minutesStr, secondsStr);\n\n    const { hours, minutes, seconds } = this.parseTimeComponents(hoursStr, minutesStr, secondsStr);\n    this.validateTimeRanges(hours, minutes, seconds);\n    this.validateTimeFormat24Hour(hours, originalInput);\n  }\n\n  private validateTimeParts(parts: string[]): void {\n    if (parts.length < 2 || parts.length > 3) {\n      throw new Error('Invalid input time');\n    }\n  }\n\n  private validateTimeDigits(hoursStr: string, minutesStr: string, secondsStr?: string): void {\n    if (\n      !this.isValidNumberString(hoursStr) ||\n      !this.isValidNumberString(minutesStr) ||\n      (secondsStr !== undefined && !this.isValidNumberString(secondsStr))\n    ) {\n      throw new Error('Invalid input time');\n    }\n  }\n\n  private parseTimeComponents(hoursStr: string, minutesStr: string, secondsStr?: string) {\n    return {\n      hours: Number(hoursStr),\n      minutes: Number(minutesStr),\n      seconds: secondsStr ? Number(secondsStr) : 0\n    };\n  }\n\n  private validateTimeRanges(hours: number, minutes: number, seconds: number): void {\n    if (hours > 23 || hours < 0 || minutes > 59 || minutes < 0 || seconds > 59 || seconds < 0) {\n      throw new Error('Invalid input time');\n    }\n  }\n\n  private validateTimeFormat24Hour(hours: number, originalInput: string): void {\n    if (hours > 12 && this.hasAmPm(originalInput)) {\n      throw new Error('Invalid input time');\n    }\n  }\n\n  /**\n   * Checks if string contains only digits and is 1-2 characters long.\n   * @param value String to check\n   * @returns boolean indicating if string is valid\n   */\n  private isValidNumberString(value: string): boolean {\n    return (\n      value.length > 0 &&\n      value.length <= 2 &&\n      value.split('').every(char => char >= '0' && char <= '9')\n    );\n  }\n\n  /**\n   * Checks if the input time has AM/PM markers.\n   * @param input The input time string to check.\n   * @returns boolean indicating if the input contains AM/PM.\n   */\n  private hasAmPm(input: string): boolean {\n    return /AM|PM/i.test(input);\n  }\n\n  /**\n   * Adjusts the date for PM times by adding 12 hours when necessary.\n   * @param date The date object to adjust.\n   * @param isPM Boolean indicating if the time is PM.\n   * @returns The adjusted Date object.\n   */\n  private adjustForPMTime(date: Date, isPM: boolean): Date {\n    const hours = date.getHours();\n    if (isPM && hours < 12) {\n      date.setHours(hours + 12);\n    } else if (!isPM && hours === 12) {\n      date.setHours(0);\n    }\n    return date;\n  }\n\n  /**\n   * Checks if the input time is in twelve hours format.\n   * @param inputTime The input time string.\n   * @returns True if the input time is in twelve hours format, false otherwise.\n   */\n  private isTwelveHoursFormat(inputTime: string): boolean {\n    return /AM|PM/i.test(inputTime);\n  }\n\n  /**\n   * Gets the hourly time range for the given date.\n   * @param date The date object.\n   * @param twelveHoursFormat Indicates whether to use twelve hours format.\n   * @returns The hourly time range string.\n   */\n  private getHourlyTimeRange(date: Date, twelveHoursFormat: boolean): string {\n    const nextHour = new Date(date.getTime());\n    nextHour.setHours(date.getHours() + 1);\n    return `${this.formatTime(date, twelveHoursFormat, true)}-${this.formatTime(nextHour, twelveHoursFormat, true)}`;\n  }\n\n  /**\n   * Gets the minutely time range for the given date.\n   * @param date The date object.\n   * @param twelveHoursFormat Indicates whether to use twelve hours format.\n   * @returns The minutely time range string.\n   */\n  private getMinutelyTimeRange(date: Date, twelveHoursFormat: boolean): string {\n    const nextMinute = new Date(date.getTime());\n    nextMinute.setMinutes(date.getMinutes() + 1);\n    return `${this.formatTime(date, twelveHoursFormat, false)}-${this.formatTime(nextMinute, twelveHoursFormat, false)}`;\n  }\n\n  /**\n   * Formats the given date into a time string.\n   * @param date The date to format.\n   * @param usePeriod Indicates whether to include the period (AM/PM) in the formatted time.\n   * @param useHourOnly Indicates whether to include only the hour part in the formatted time.\n   * @returns The formatted time string.\n   */\n  private formatTime(date: Date, usePeriod: boolean, useHourOnly: boolean): string {\n    const hours = date.getHours();\n    const minutes = date.getMinutes().toString().padStart(2, '0');\n    if (usePeriod) {\n      const period = hours >= 12 ? 'PM' : 'AM';\n      const formattedHours = hours % 12 === 0 ? 12 : hours % 12;\n      return `${formattedHours}:${useHourOnly ? '00' : minutes} ${period}`;\n    } else {\n      return `${hours.toString().padStart(2, '0')}:${useHourOnly ? '00' : minutes}`;\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Applies CSS classes based on the value's range.
|
|
5
|
+
*/
|
|
6
|
+
export class ApplyRangeClassPipe {
|
|
7
|
+
/**
|
|
8
|
+
* Transforms the input value based on the specified ranges.
|
|
9
|
+
*
|
|
10
|
+
* @param value - Initial value used to determine the CSS class.
|
|
11
|
+
* @param ranges - An object containing the min and max range values for yellow and red colors.
|
|
12
|
+
* @returns The CSS class to be applied.
|
|
13
|
+
*/
|
|
14
|
+
transform(value, ranges) {
|
|
15
|
+
if (value == null) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
if (value >= ranges.yellowRangeMin && value < ranges.yellowRangeMax) {
|
|
19
|
+
return 'text-warning';
|
|
20
|
+
}
|
|
21
|
+
else if (value >= ranges.redRangeMin && value <= ranges.redRangeMax) {
|
|
22
|
+
return 'text-danger';
|
|
23
|
+
}
|
|
24
|
+
return 'default';
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplyRangeClassPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
27
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: ApplyRangeClassPipe, isStandalone: true, name: "applyRangeClass" }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplyRangeClassPipe, decorators: [{
|
|
30
|
+
type: Pipe,
|
|
31
|
+
args: [{
|
|
32
|
+
name: 'applyRangeClass',
|
|
33
|
+
standalone: true
|
|
34
|
+
}]
|
|
35
|
+
}] });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbHktcmFuZ2UtY2xhc3MucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3dpZGdldHMvaW1wbGVtZW50YXRpb25zL2RhdGFwb2ludHMtdGFibGUvZGF0YXBvaW50cy10YWJsZS12aWV3L2FwcGx5LXJhbmdlLWNsYXNzLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBR3BEOztHQUVHO0FBS0gsTUFBTSxPQUFPLG1CQUFtQjtJQUM5Qjs7Ozs7O09BTUc7SUFDSCxTQUFTLENBQUMsS0FBYSxFQUFFLE1BQTRCO1FBQ25ELElBQUksS0FBSyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2xCLE9BQU87UUFDVCxDQUFDO1FBRUQsSUFBSSxLQUFLLElBQUksTUFBTSxDQUFDLGNBQWMsSUFBSSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3BFLE9BQU8sY0FBYyxDQUFDO1FBQ3hCLENBQUM7YUFBTSxJQUFJLEtBQUssSUFBSSxNQUFNLENBQUMsV0FBVyxJQUFJLEtBQUssSUFBSSxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDdEUsT0FBTyxhQUFhLENBQUM7UUFDdkIsQ0FBQztRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7OEdBbkJVLG1CQUFtQjs0R0FBbkIsbUJBQW1COzsyRkFBbkIsbUJBQW1CO2tCQUovQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxpQkFBaUI7b0JBQ3ZCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbG9yUmFuZ2VCb3VuZGFyaWVzIH0gZnJvbSAnLi4vZGF0YXBvaW50cy10YWJsZS13aWRnZXQubW9kZWwnO1xuXG4vKipcbiAqIEFwcGxpZXMgQ1NTIGNsYXNzZXMgYmFzZWQgb24gdGhlIHZhbHVlJ3MgcmFuZ2UuXG4gKi9cbkBQaXBlKHtcbiAgbmFtZTogJ2FwcGx5UmFuZ2VDbGFzcycsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgQXBwbHlSYW5nZUNsYXNzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAvKipcbiAgICogVHJhbnNmb3JtcyB0aGUgaW5wdXQgdmFsdWUgYmFzZWQgb24gdGhlIHNwZWNpZmllZCByYW5nZXMuXG4gICAqXG4gICAqIEBwYXJhbSB2YWx1ZSAtIEluaXRpYWwgdmFsdWUgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENTUyBjbGFzcy5cbiAgICogQHBhcmFtIHJhbmdlcyAtIEFuIG9iamVjdCBjb250YWluaW5nIHRoZSBtaW4gYW5kIG1heCByYW5nZSB2YWx1ZXMgZm9yIHllbGxvdyBhbmQgcmVkIGNvbG9ycy5cbiAgICogQHJldHVybnMgVGhlIENTUyBjbGFzcyB0byBiZSBhcHBsaWVkLlxuICAgKi9cbiAgdHJhbnNmb3JtKHZhbHVlOiBudW1iZXIsIHJhbmdlczogQ29sb3JSYW5nZUJvdW5kYXJpZXMpOiBzdHJpbmcge1xuICAgIGlmICh2YWx1ZSA9PSBudWxsKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKHZhbHVlID49IHJhbmdlcy55ZWxsb3dSYW5nZU1pbiAmJiB2YWx1ZSA8IHJhbmdlcy55ZWxsb3dSYW5nZU1heCkge1xuICAgICAgcmV0dXJuICd0ZXh0LXdhcm5pbmcnO1xuICAgIH0gZWxzZSBpZiAodmFsdWUgPj0gcmFuZ2VzLnJlZFJhbmdlTWluICYmIHZhbHVlIDw9IHJhbmdlcy5yZWRSYW5nZU1heCkge1xuICAgICAgcmV0dXJuICd0ZXh0LWRhbmdlcic7XG4gICAgfVxuICAgIHJldHVybiAnZGVmYXVsdCc7XG4gIH1cbn1cbiJdfQ==
|
package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/column-title.pipe.mjs
ADDED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
3
|
+
import { RENDER_TYPES_LABELS } from '../datapoints-table-widget.model';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@ngx-translate/core";
|
|
6
|
+
/**
|
|
7
|
+
* Creates a column header title message.
|
|
8
|
+
*
|
|
9
|
+
* ```html
|
|
10
|
+
* title="{{ header | columnTitle }}"
|
|
11
|
+
* ```
|
|
12
|
+
* The output will be e.g.: 'c8y_Temperature → T [T] (Area)'.
|
|
13
|
+
*/
|
|
14
|
+
export class ColumnTitlePipe {
|
|
15
|
+
constructor(translateService) {
|
|
16
|
+
this.translateService = translateService;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Transforms the column header into a formatted string with label and optionally unit and render type.
|
|
20
|
+
*
|
|
21
|
+
* @param columnHeader - The column header object.
|
|
22
|
+
* @returns The formatted string with label, unit, and render type.
|
|
23
|
+
*/
|
|
24
|
+
transform(columnHeader) {
|
|
25
|
+
const label = columnHeader.label.trim();
|
|
26
|
+
const unit = columnHeader.unit ? `[${columnHeader.unit.trim()}]` : '';
|
|
27
|
+
const renderType = columnHeader.renderType
|
|
28
|
+
? this.translateService.instant(RENDER_TYPES_LABELS[columnHeader.renderType])
|
|
29
|
+
: '';
|
|
30
|
+
if (!renderType) {
|
|
31
|
+
return `${label} ${unit}`.trim();
|
|
32
|
+
}
|
|
33
|
+
return `${label} ${unit} (${renderType})`.trim();
|
|
34
|
+
}
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ColumnTitlePipe, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
36
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: ColumnTitlePipe, isStandalone: true, name: "columnTitle" }); }
|
|
37
|
+
}
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ColumnTitlePipe, decorators: [{
|
|
39
|
+
type: Pipe,
|
|
40
|
+
args: [{
|
|
41
|
+
name: 'columnTitle',
|
|
42
|
+
standalone: true
|
|
43
|
+
}]
|
|
44
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLXRpdGxlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi93aWRnZXRzL2ltcGxlbWVudGF0aW9ucy9kYXRhcG9pbnRzLXRhYmxlL2RhdGFwb2ludHMtdGFibGUtdmlldy9jb2x1bW4tdGl0bGUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQXFCLG1CQUFtQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7OztBQUUxRjs7Ozs7OztHQU9HO0FBS0gsTUFBTSxPQUFPLGVBQWU7SUFDMUIsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLFlBQStCO1FBQ3ZDLE1BQU0sS0FBSyxHQUFHLFlBQVksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDeEMsTUFBTSxJQUFJLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN0RSxNQUFNLFVBQVUsR0FBRyxZQUFZLENBQUMsVUFBVTtZQUN4QyxDQUFDLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDN0UsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUVQLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNoQixPQUFPLEdBQUcsS0FBSyxJQUFJLElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ25DLENBQUM7UUFFRCxPQUFPLEdBQUcsS0FBSyxJQUFJLElBQUksS0FBSyxVQUFVLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNuRCxDQUFDOzhHQXJCVSxlQUFlOzRHQUFmLGVBQWU7OzJGQUFmLGVBQWU7a0JBSjNCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLGFBQWE7b0JBQ25CLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFRhYmxlQ29sdW1uSGVhZGVyLCBSRU5ERVJfVFlQRVNfTEFCRUxTIH0gZnJvbSAnLi4vZGF0YXBvaW50cy10YWJsZS13aWRnZXQubW9kZWwnO1xuXG4vKipcbiAqIENyZWF0ZXMgYSBjb2x1bW4gaGVhZGVyIHRpdGxlIG1lc3NhZ2UuXG4gKlxuICogYGBgaHRtbFxuICogdGl0bGU9XCJ7eyBoZWFkZXIgfCBjb2x1bW5UaXRsZSB9fVwiXG4gKiBgYGBcbiAqIFRoZSBvdXRwdXQgd2lsbCBiZSBlLmcuOiAnYzh5X1RlbXBlcmF0dXJlIOKGkiBUIFtUXSAoQXJlYSknLlxuICovXG5AUGlwZSh7XG4gIG5hbWU6ICdjb2x1bW5UaXRsZScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgQ29sdW1uVGl0bGVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge31cblxuICAvKipcbiAgICogVHJhbnNmb3JtcyB0aGUgY29sdW1uIGhlYWRlciBpbnRvIGEgZm9ybWF0dGVkIHN0cmluZyB3aXRoIGxhYmVsIGFuZCBvcHRpb25hbGx5IHVuaXQgYW5kIHJlbmRlciB0eXBlLlxuICAgKlxuICAgKiBAcGFyYW0gY29sdW1uSGVhZGVyIC0gVGhlIGNvbHVtbiBoZWFkZXIgb2JqZWN0LlxuICAgKiBAcmV0dXJucyBUaGUgZm9ybWF0dGVkIHN0cmluZyB3aXRoIGxhYmVsLCB1bml0LCBhbmQgcmVuZGVyIHR5cGUuXG4gICAqL1xuICB0cmFuc2Zvcm0oY29sdW1uSGVhZGVyOiBUYWJsZUNvbHVtbkhlYWRlcik6IHN0cmluZyB7XG4gICAgY29uc3QgbGFiZWwgPSBjb2x1bW5IZWFkZXIubGFiZWwudHJpbSgpO1xuICAgIGNvbnN0IHVuaXQgPSBjb2x1bW5IZWFkZXIudW5pdCA/IGBbJHtjb2x1bW5IZWFkZXIudW5pdC50cmltKCl9XWAgOiAnJztcbiAgICBjb25zdCByZW5kZXJUeXBlID0gY29sdW1uSGVhZGVyLnJlbmRlclR5cGVcbiAgICAgID8gdGhpcy50cmFuc2xhdGVTZXJ2aWNlLmluc3RhbnQoUkVOREVSX1RZUEVTX0xBQkVMU1tjb2x1bW5IZWFkZXIucmVuZGVyVHlwZV0pXG4gICAgICA6ICcnO1xuXG4gICAgaWYgKCFyZW5kZXJUeXBlKSB7XG4gICAgICByZXR1cm4gYCR7bGFiZWx9ICR7dW5pdH1gLnRyaW0oKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYCR7bGFiZWx9ICR7dW5pdH0gKCR7cmVuZGVyVHlwZX0pYC50cmltKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Component, EventEmitter, Injector, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { CommonModule, CountdownIntervalComponent, CountdownIntervalModule, IntervalBasedReload, ListGroupModule, gettext } from '@c8y/ngx-components';
|
|
3
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { TooltipModule } from 'ngx-bootstrap/tooltip';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@ngx-translate/core";
|
|
7
|
+
import * as i2 from "@c8y/ngx-components";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "ngx-bootstrap/tooltip";
|
|
10
|
+
export class DatapointsReloadComponent extends IntervalBasedReload {
|
|
11
|
+
constructor(cdRef, injector, translateService) {
|
|
12
|
+
super();
|
|
13
|
+
this.cdRef = cdRef;
|
|
14
|
+
this.injector = injector;
|
|
15
|
+
this.translateService = translateService;
|
|
16
|
+
/**
|
|
17
|
+
* @inheritdoc
|
|
18
|
+
*/
|
|
19
|
+
this.onCountdownEnded = new EventEmitter();
|
|
20
|
+
/**
|
|
21
|
+
* @inheritdoc
|
|
22
|
+
*/
|
|
23
|
+
this.manuallyDisabledCountdown = false;
|
|
24
|
+
}
|
|
25
|
+
ngOnChanges(changes) {
|
|
26
|
+
if (this.isDisabled && this.isAutoRefreshEnabled) {
|
|
27
|
+
this.isIntervalRefreshToggleOn = false;
|
|
28
|
+
this.disableCountdown();
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (this.isExportModalOpen && this.canDisableCountdownWhenModalIsOpen()) {
|
|
32
|
+
this.isIntervalRefreshToggleOn = !this.isIntervalRefreshToggleOn;
|
|
33
|
+
this.disableCountdown();
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
if (this.canStartCountdown(changes)) {
|
|
37
|
+
this.isIntervalRefreshToggleOn = true;
|
|
38
|
+
this.startCountdown(this.injector);
|
|
39
|
+
}
|
|
40
|
+
if (this.canHandleScrolling()) {
|
|
41
|
+
this.handleScrolling();
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* @inheritdoc
|
|
47
|
+
*/
|
|
48
|
+
countdownEnded() {
|
|
49
|
+
/**
|
|
50
|
+
* @inheritdoc
|
|
51
|
+
*/
|
|
52
|
+
this.autoRefreshList();
|
|
53
|
+
}
|
|
54
|
+
reload() {
|
|
55
|
+
/**
|
|
56
|
+
* @inheritdoc
|
|
57
|
+
*/
|
|
58
|
+
this.autoRefreshList();
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* @inheritdoc
|
|
62
|
+
*/
|
|
63
|
+
enableCountdown() {
|
|
64
|
+
this.hideCountdown = false;
|
|
65
|
+
// Prevents the countdown from getting stuck on an initial value.
|
|
66
|
+
this.cdRef.detectChanges();
|
|
67
|
+
this.startCountdown(this.injector);
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* @inheritdoc
|
|
71
|
+
*/
|
|
72
|
+
updateCountdownButtonTooltipText() {
|
|
73
|
+
this.toggleCountdownButtonTooltipText = this.isIntervalRefreshToggleOn
|
|
74
|
+
? this.translateService.instant(gettext('Disable auto refresh'))
|
|
75
|
+
: this.translateService.instant(gettext('Enable auto refresh'));
|
|
76
|
+
}
|
|
77
|
+
canStartCountdown(changes) {
|
|
78
|
+
const { isAutoRefreshEnabled, refreshInterval } = changes;
|
|
79
|
+
return ((isAutoRefreshEnabled || refreshInterval) &&
|
|
80
|
+
(this.isAutoRefreshEnabled || !!this.refreshInterval));
|
|
81
|
+
}
|
|
82
|
+
canHandleScrolling() {
|
|
83
|
+
return !this.manuallyDisabledCountdown && this.isAutoRefreshEnabled;
|
|
84
|
+
}
|
|
85
|
+
canDisableCountdownWhenModalIsOpen() {
|
|
86
|
+
return (this.isAutoRefreshEnabled &&
|
|
87
|
+
!!this.refreshInterval &&
|
|
88
|
+
!this.manuallyDisabledCountdown &&
|
|
89
|
+
!this.isScrolling &&
|
|
90
|
+
!this.hideCountdown);
|
|
91
|
+
}
|
|
92
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
93
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsReloadComponent, isStandalone: true, selector: "c8y-datapoints-reload", inputs: { isAutoRefreshEnabled: "isAutoRefreshEnabled", isDisabled: "isDisabled", isLoading: "isLoading", isScrolling: "isScrolling", isExportModalOpen: "isExportModalOpen", refreshInterval: "refreshInterval" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex a-i-center p-t-4 p-b-4\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isLoading()\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading() }\"\n ></i>\n </button>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: CountdownIntervalModule }, { kind: "component", type: i2.CountdownIntervalComponent, selector: "c8y-countdown-interval", inputs: ["countdownInterval"], outputs: ["countdownEnded"] }, { kind: "ngmodule", type: ListGroupModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }] }); }
|
|
94
|
+
}
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, decorators: [{
|
|
96
|
+
type: Component,
|
|
97
|
+
args: [{ selector: 'c8y-datapoints-reload', standalone: true, imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule], template: "<div class=\"d-flex a-i-center p-t-4 p-b-4\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isLoading()\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading() }\"\n ></i>\n </button>\n </div>\n </div>\n</div>\n" }]
|
|
98
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.TranslateService }], propDecorators: { countdownIntervalComponent: [{
|
|
99
|
+
type: ViewChild,
|
|
100
|
+
args: [CountdownIntervalComponent, { static: false }]
|
|
101
|
+
}], isAutoRefreshEnabled: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], isDisabled: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], isLoading: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], isScrolling: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], isExportModalOpen: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], refreshInterval: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], onCountdownEnded: [{
|
|
114
|
+
type: Output
|
|
115
|
+
}] } });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-reload.component.js","sourceRoot":"","sources":["../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.ts","../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  Signal,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  CommonModule,\n  CountdownIntervalComponent,\n  CountdownIntervalModule,\n  IntervalBasedReload,\n  ListGroupModule,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\n\n@Component({\n  selector: 'c8y-datapoints-reload',\n  templateUrl: './datapoints-reload.component.html',\n  standalone: true,\n  imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule]\n})\nexport class DatapointsReloadComponent extends IntervalBasedReload implements OnChanges {\n  @ViewChild(CountdownIntervalComponent, { static: false })\n  countdownIntervalComponent: CountdownIntervalComponent;\n  /**\n   * @inheritdoc\n   */\n  @Input() isAutoRefreshEnabled: boolean;\n\n  @Input() isDisabled: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() isLoading: Signal<boolean>;\n\n  @Input() isScrolling: boolean;\n\n  @Input() isExportModalOpen: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() refreshInterval: number;\n  /**\n   * @inheritdoc\n   */\n  @Output() onCountdownEnded = new EventEmitter<void>();\n  /**\n   * @inheritdoc\n   */\n  isIntervalRefreshToggleOn: boolean;\n\n  toggleCountdownButtonTooltipText: string;\n  /**\n   * @inheritdoc\n   */\n  protected manuallyDisabledCountdown = false;\n  /**\n   * @inheritdoc\n   */\n  protected hideCountdown: boolean;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private injector: Injector,\n    private translateService: TranslateService\n  ) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isDisabled && this.isAutoRefreshEnabled) {\n      this.isIntervalRefreshToggleOn = false;\n      this.disableCountdown();\n      return;\n    }\n\n    if (this.isExportModalOpen && this.canDisableCountdownWhenModalIsOpen()) {\n      this.isIntervalRefreshToggleOn = !this.isIntervalRefreshToggleOn;\n      this.disableCountdown();\n    } else {\n      if (this.canStartCountdown(changes)) {\n        this.isIntervalRefreshToggleOn = true;\n        this.startCountdown(this.injector);\n      }\n\n      if (this.canHandleScrolling()) {\n        this.handleScrolling();\n      }\n    }\n  }\n\n  /**\n   * @inheritdoc\n   */\n  countdownEnded(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  reload(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  enableCountdown(): void {\n    this.hideCountdown = false;\n    // Prevents the countdown from getting stuck on an initial value.\n    this.cdRef.detectChanges();\n    this.startCountdown(this.injector);\n  }\n\n  /**\n   * @inheritdoc\n   */\n  protected updateCountdownButtonTooltipText(): void {\n    this.toggleCountdownButtonTooltipText = this.isIntervalRefreshToggleOn\n      ? this.translateService.instant(gettext('Disable auto refresh'))\n      : this.translateService.instant(gettext('Enable auto refresh'));\n  }\n\n  private canStartCountdown(changes: SimpleChanges): boolean {\n    const { isAutoRefreshEnabled, refreshInterval } = changes;\n    return (\n      (isAutoRefreshEnabled || refreshInterval) &&\n      (this.isAutoRefreshEnabled || !!this.refreshInterval)\n    );\n  }\n\n  private canHandleScrolling(): boolean {\n    return !this.manuallyDisabledCountdown && this.isAutoRefreshEnabled;\n  }\n\n  private canDisableCountdownWhenModalIsOpen(): boolean {\n    return (\n      this.isAutoRefreshEnabled &&\n      !!this.refreshInterval &&\n      !this.manuallyDisabledCountdown &&\n      !this.isScrolling &&\n      !this.hideCountdown\n    );\n  }\n}\n","<div class=\"d-flex a-i-center p-t-4 p-b-4\">\n  <label\n    class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n    title=\" {{ 'Auto refresh' | translate }}\"\n    *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n  >\n    {{ 'Auto refresh' | translate }}\n  </label>\n  <div class=\"input-group\">\n    <label\n      class=\"toggle-countdown\"\n      [class.toggle-countdown-disabled]=\"isDisabled\"\n      [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n      [tooltip]=\"toggleCountdownButtonTooltipText\"\n      placement=\"bottom\"\n      *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n      [adaptivePosition]=\"false\"\n      [container]=\"'body'\"\n      [delay]=\"500\"\n    >\n      <input\n        type=\"checkbox\"\n        [checked]=\"isIntervalRefreshToggleOn\"\n        [disabled]=\"isDisabled\"\n        data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n        (click)=\"onToggleCountdownButtonState($event)\"\n      />\n\n      <c8y-countdown-interval\n        *ngIf=\"isIntervalRefreshToggleOn\"\n        [countdownInterval]=\"refreshInterval\"\n        (countdownEnded)=\"countdownEnded()\"\n      ></c8y-countdown-interval>\n      <i\n        c8yIcon=\"pause\"\n        *ngIf=\"!isIntervalRefreshToggleOn\"\n      ></i>\n    </label>\n\n    <div class=\"input-group-btn\">\n      <button\n        class=\"btn btn-default\"\n        [attr.aria-label]=\"'Refresh' | translate\"\n        [tooltip]=\"'Refresh' | translate\"\n        placement=\"bottom\"\n        type=\"button\"\n        [adaptivePosition]=\"false\"\n        [container]=\"'body'\"\n        [delay]=\"500\"\n        [disabled]=\"isLoading()\"\n        (click)=\"reload()\"\n        data-cy=\"c8y-data-points-table-widget--reload-button\"\n      >\n        <i\n          c8yIcon=\"refresh\"\n          [ngClass]=\"{ 'icon-spin': isLoading() }\"\n        ></i>\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|