@flexem/fc-gui 3.0.0-alpha.16 → 3.0.0-alpha.160
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/CHANGELOG.md +492 -69
- package/README.md +4 -4
- package/assets/img/alert.svg +18 -18
- package/assets/img/black_first_page.png +0 -0
- package/assets/img/black_last_page.png +0 -0
- package/assets/img/black_next_page.png +0 -0
- package/assets/img/black_previous_page.png +0 -0
- package/assets/img/first_page.svg +19 -19
- package/assets/img/last_page.svg +19 -19
- package/assets/img/next_page.svg +14 -14
- package/assets/img/previous_page.svg +14 -14
- package/bundles/@flexem/fc-gui.umd.js +25472 -20764
- package/bundles/@flexem/fc-gui.umd.js.map +1 -1
- package/bundles/@flexem/fc-gui.umd.min.js +5 -5
- package/bundles/@flexem/fc-gui.umd.min.js.map +1 -1
- package/communication/index.d.ts +1 -1
- package/communication/index.js +1 -1
- package/communication/variable/index.d.ts +5 -5
- package/communication/variable/index.js +4 -4
- package/communication/variable/variable-communicator.d.ts +16 -12
- package/communication/variable/variable-definition.d.ts +10 -10
- package/communication/variable/variable-definition.js +14 -14
- package/communication/variable/variable-state-enum.d.ts +8 -7
- package/communication/variable/variable-state-enum.js +9 -8
- package/communication/variable/variable-state-enum.metadata.json +1 -1
- package/communication/variable/variable-state.d.ts +6 -6
- package/communication/variable/variable-state.js +6 -6
- package/communication/variable/variable-value.d.ts +11 -8
- package/communication/variable/variable-value.js +11 -8
- package/communication/variable/variable-value.metadata.json +1 -1
- package/config/alarm/alarm.store.d.ts +6 -0
- package/config/alarm/alarm.store.js +0 -0
- package/config/alarm/alarm.store.metadata.json +1 -0
- package/config/alarm/get-alarms-args.d.ts +12 -0
- package/config/alarm/get-alarms-args.js +13 -0
- package/config/alarm/get-alarms-args.metadata.json +1 -0
- package/config/alarm/index.d.ts +2 -0
- package/config/alarm/index.js +1 -0
- package/config/alarm/index.metadata.json +1 -0
- package/config/config-store.d.ts +17 -15
- package/config/graph/graph-result.d.ts +9 -9
- package/config/graph/graph-result.js +13 -13
- package/config/graph/graph-store.d.ts +9 -9
- package/config/graph/graph-type.d.ts +4 -4
- package/config/graph/graph-type.js +5 -5
- package/config/graph/graph.d.ts +6 -6
- package/config/graph/graph.js +6 -6
- package/config/gui-feature-config.d.ts +3 -0
- package/config/gui-feature-config.js +3 -0
- package/config/gui-feature-config.metadata.json +1 -0
- package/config/history-data/get-history-data-args.d.ts +22 -22
- package/config/history-data/get-history-data-args.js +21 -21
- package/config/history-data/historical-curve.time-range.d.ts +18 -18
- package/config/history-data/historical-curve.time-range.js +19 -19
- package/config/history-data/history-data-value.d.ts +6 -6
- package/config/history-data/history-data-value.js +6 -6
- package/config/history-data/history-data.model.d.ts +7 -7
- package/config/history-data/history-data.model.js +7 -7
- package/config/history-data/history-data.store.d.ts +10 -10
- package/config/history-data/index.d.ts +4 -4
- package/config/history-data/index.js +3 -3
- package/config/image/image-store.d.ts +6 -6
- package/config/index.d.ts +12 -10
- package/config/index.js +8 -6
- package/config/index.metadata.json +1 -1
- package/config/variable/get-variable-name-args.d.ts +6 -6
- package/config/variable/get-variable-name-args.js +7 -7
- package/config/variable/index.d.ts +2 -2
- package/config/variable/index.js +1 -1
- package/config/variable/variable-store.d.ts +8 -7
- package/config/view/view-store.d.ts +20 -20
- package/config/view/view.model.d.ts +4 -4
- package/config/view/view.model.js +5 -5
- package/core/index.d.ts +1 -1
- package/core/index.js +1 -1
- package/core/stringifying-map.d.ts +11 -11
- package/core/stringifying-map.js +24 -24
- package/core/stringifying-set.d.ts +10 -10
- package/core/stringifying-set.js +21 -21
- package/elements/air-quality/air-quality-element.d.ts +31 -0
- package/elements/air-quality/air-quality-element.js +194 -0
- package/elements/air-quality/air-quality-element.metadata.json +1 -0
- package/elements/alarm/alarm-element.d.ts +69 -0
- package/elements/alarm/alarm-element.js +497 -0
- package/elements/alarm/alarm-element.metadata.json +1 -0
- package/elements/bar-graph-element.d.ts +29 -21
- package/elements/bar-graph-element.js +244 -114
- package/elements/bar-graph-element.metadata.json +1 -1
- package/elements/base/base-element.d.ts +11 -11
- package/elements/base/base-element.js +9 -9
- package/elements/base/conditional-control-element.d.ts +16 -16
- package/elements/base/conditional-control-element.js +87 -87
- package/elements/base/conditional-display-element.d.ts +24 -24
- package/elements/base/conditional-display-element.js +86 -86
- package/elements/base/conditional-dynamic-display-element.d.ts +26 -26
- package/elements/base/conditional-dynamic-display-element.js +142 -142
- package/elements/base/conditional-enable-element.d.ts +21 -21
- package/elements/base/conditional-enable-element.js +100 -100
- package/elements/base/index.d.ts +3 -3
- package/elements/base/index.js +3 -3
- package/elements/base/readable-element.d.ts +20 -15
- package/elements/base/readable-element.js +122 -58
- package/elements/base/readable-element.metadata.json +1 -1
- package/elements/base/state-control-element.d.ts +26 -24
- package/elements/base/state-control-element.js +196 -180
- package/elements/character-display/character-display-element.d.ts +35 -35
- package/elements/character-display/character-display-element.js +312 -311
- package/elements/character-display/character-display-element.metadata.json +1 -1
- package/elements/datetime-display/datetime-display-element.d.ts +22 -21
- package/elements/datetime-display/datetime-display-element.js +140 -132
- package/elements/datetime-display/datetime-display-element.metadata.json +1 -1
- package/elements/datetime-display/time-zone-select-json.d.ts +8 -0
- package/elements/datetime-display/time-zone-select-json.js +558 -0
- package/elements/historical-curve/historical-curve-element-status.d.ts +6 -6
- package/elements/historical-curve/historical-curve-element-status.js +7 -7
- package/elements/historical-curve/historical-curve.element.d.ts +96 -59
- package/elements/historical-curve/historical-curve.element.js +990 -364
- package/elements/historical-curve/historical-curve.element.metadata.json +1 -1
- package/elements/historical-curve/historical-curve.element.option.d.ts +13 -13
- package/elements/historical-curve/historical-curve.time-period.d.ts +4 -4
- package/elements/main-element.d.ts +46 -45
- package/elements/main-element.js +373 -307
- package/elements/main-element.metadata.json +1 -1
- package/elements/meter-element.d.ts +26 -20
- package/elements/meter-element.js +139 -70
- package/elements/meter-element.metadata.json +1 -1
- package/elements/numerical-display/numerical-display-element.d.ts +60 -41
- package/elements/numerical-display/numerical-display-element.js +476 -361
- package/elements/numerical-display/numerical-display-element.metadata.json +1 -1
- package/elements/per-view-variable-communicator.d.ts +20 -17
- package/elements/per-view-variable-communicator.js +59 -45
- package/elements/per-view-variable-communicator.metadata.json +1 -1
- package/elements/pipe/pipe-element.d.ts +19 -19
- package/elements/pipe/pipe-element.js +141 -141
- package/elements/ring-graph/ring-graph-element.d.ts +31 -19
- package/elements/ring-graph/ring-graph-element.js +250 -89
- package/elements/ring-graph/ring-graph-element.metadata.json +1 -1
- package/elements/scroll-alarm/scroll-alarm-element.d.ts +74 -0
- package/elements/scroll-alarm/scroll-alarm-element.js +761 -0
- package/elements/scroll-alarm/scroll-alarm-element.metadata.json +1 -0
- package/elements/shared/graph/graph-state-element.d.ts +28 -27
- package/elements/shared/graph/graph-state-element.js +139 -110
- package/elements/shared/graph/graph-state-element.metadata.json +1 -1
- package/elements/shared/math-utils.d.ts +2 -2
- package/elements/shared/math-utils.js +14 -14
- package/elements/shared/text/text-element.d.ts +22 -8
- package/elements/shared/text/text-element.js +106 -68
- package/elements/shared/text/text-element.metadata.json +1 -1
- package/elements/shared/text/text-state-element.d.ts +58 -23
- package/elements/shared/text/text-state-element.js +286 -136
- package/elements/shared/text/text-state-element.metadata.json +1 -1
- package/elements/shared/text/text-state.model.d.ts +5 -5
- package/elements/shared/text/text-utils.d.ts +5 -5
- package/elements/shared/text/text-utils.js +45 -45
- package/elements/static-elements/hyperlink-element.d.ts +40 -14
- package/elements/static-elements/hyperlink-element.js +197 -48
- package/elements/static-elements/hyperlink-element.metadata.json +1 -1
- package/elements/static-elements/image-element.d.ts +14 -14
- package/elements/static-elements/image-element.js +41 -41
- package/elements/static-elements/text-element.d.ts +42 -16
- package/elements/static-elements/text-element.js +205 -55
- package/elements/static-elements/text-element.metadata.json +1 -1
- package/elements/switch-indicator-light/bit-indicator-light-operator.d.ts +21 -20
- package/elements/switch-indicator-light/bit-indicator-light-operator.js +85 -78
- package/elements/switch-indicator-light/bit-indicator-light-operator.metadata.json +1 -1
- package/elements/switch-indicator-light/bit-switch-operator.d.ts +19 -19
- package/elements/switch-indicator-light/bit-switch-operator.js +107 -107
- package/elements/switch-indicator-light/current-stateId-value.d.ts +6 -6
- package/elements/switch-indicator-light/current-stateId-value.js +8 -8
- package/elements/switch-indicator-light/indicator-light-operator.d.ts +8 -8
- package/elements/switch-indicator-light/switch-indicator-light-element.d.ts +48 -39
- package/elements/switch-indicator-light/switch-indicator-light-element.js +302 -251
- package/elements/switch-indicator-light/switch-indicator-light-element.metadata.json +1 -1
- package/elements/switch-indicator-light/switch-operator.d.ts +6 -6
- package/elements/switch-indicator-light/word-indicator-light-operator.d.ts +19 -18
- package/elements/switch-indicator-light/word-indicator-light-operator.js +72 -65
- package/elements/switch-indicator-light/word-indicator-light-operator.metadata.json +1 -1
- package/elements/switch-indicator-light/word-switch-operator.d.ts +18 -18
- package/elements/switch-indicator-light/word-switch-operator.js +75 -75
- package/elements/table/table-element.d.ts +9 -9
- package/elements/table/table-element.js +6 -6
- package/elements/vector-graphics/ellipse-element.d.ts +9 -9
- package/elements/vector-graphics/ellipse-element.js +6 -6
- package/elements/vector-graphics/poly-line-element.d.ts +12 -12
- package/elements/vector-graphics/poly-line-element.js +19 -19
- package/elements/vector-graphics/polygon-element.d.ts +12 -12
- package/elements/vector-graphics/polygon-element.js +19 -19
- package/elements/vector-graphics/rectangle-element.d.ts +9 -9
- package/elements/vector-graphics/rectangle-element.js +6 -6
- package/elements/vector-graphics/sector-element.d.ts +9 -9
- package/elements/vector-graphics/sector-element.js +6 -6
- package/elements/vector-graphics/straight-line-element.d.ts +12 -12
- package/elements/vector-graphics/straight-line-element.js +19 -19
- package/elements/video/video-element.d.ts +37 -27
- package/elements/video/video-element.js +258 -160
- package/elements/video/video-element.metadata.json +1 -1
- package/elements/view-operation/view-operation.element.d.ts +62 -36
- package/elements/view-operation/view-operation.element.js +348 -194
- package/elements/view-operation/view-operation.element.metadata.json +1 -1
- package/elements/weather/weater-element.d.ts +38 -38
- package/elements/weather/weater-element.js +237 -238
- package/gui/gui-context.d.ts +33 -16
- package/gui/gui-host.d.ts +50 -50
- package/gui/gui-host.js +173 -173
- package/gui/gui-view.d.ts +45 -42
- package/gui/gui-view.js +265 -204
- package/gui/gui-view.metadata.json +1 -1
- package/gui/gui.component.d.ts +45 -42
- package/gui/gui.component.html +3 -3
- package/gui/gui.component.js +240 -227
- package/gui/gui.component.metadata.json +1 -1
- package/gui/interfaces/gui-options.d.ts +6 -6
- package/gui.module.d.ts +2 -2
- package/gui.module.js +78 -78
- package/localization/index.d.ts +2 -2
- package/localization/index.js +2 -2
- package/localization/localization.service.d.ts +62 -51
- package/localization/localization.service.js +61 -50
- package/localization/localization.service.metadata.json +1 -1
- package/localization/localization.service.zh_CN.d.ts +2 -2
- package/localization/localization.service.zh_CN.js +59 -48
- package/localization/localization.service.zh_CN.metadata.json +1 -1
- package/logger/console-logger.service.d.ts +13 -13
- package/logger/console-logger.service.js +38 -38
- package/logger/index.d.ts +2 -2
- package/logger/index.js +2 -2
- package/logger/logger.service.d.ts +14 -14
- package/logger/logger.service.js +2 -2
- package/modal/alert/alert-modal.component.d.ts +10 -10
- package/modal/alert/alert-modal.component.html +11 -11
- package/modal/alert/alert-modal.component.js +38 -38
- package/modal/alert/alert-modal.component.less +59 -59
- package/modal/confirm-operation/confirm-operation-modal.component.d.ts +10 -10
- package/modal/confirm-operation/confirm-operation-modal.component.html +16 -16
- package/modal/confirm-operation/confirm-operation-modal.component.js +41 -41
- package/modal/confirm-operation/confirm-operation-modal.component.less +58 -58
- package/modal/verify-password/verify-password-modal.component.d.ts +18 -18
- package/modal/verify-password/verify-password-modal.component.html +22 -22
- package/modal/verify-password/verify-password-modal.component.js +66 -66
- package/modal/verify-password/verify-password-modal.component.less +65 -65
- package/modal/write-character/write-character-modal-args.d.ts +7 -7
- package/modal/write-character/write-character-modal-args.js +8 -8
- package/modal/write-character/write-character-modal.component.d.ts +25 -25
- package/modal/write-character/write-character-modal.component.html +21 -21
- package/modal/write-character/write-character-modal.component.js +74 -74
- package/modal/write-character/write-character-modal.component.less +49 -49
- package/modal/write-value/write-value-modal-args.d.ts +16 -12
- package/modal/write-value/write-value-modal-args.js +14 -12
- package/modal/write-value/write-value-modal-args.metadata.json +1 -1
- package/modal/write-value/write-value-modal.component.d.ts +60 -54
- package/modal/write-value/write-value-modal.component.html +26 -21
- package/modal/write-value/write-value-modal.component.js +279 -204
- package/modal/write-value/write-value-modal.component.less +56 -56
- package/modal/write-value/write-value-modal.component.metadata.json +1 -1
- package/modal/write-value/write-value-model-result.d.ts +3 -3
- package/model/air-quality/air-quality-info.d.ts +23 -0
- package/model/air-quality/air-quality-info.js +4 -0
- package/model/air-quality/air-quality-info.metadata.json +1 -0
- package/model/air-quality/air-quality.model.d.ts +7 -0
- package/model/air-quality/air-quality.model.js +0 -0
- package/model/air-quality/air-quality.model.metadata.json +1 -0
- package/model/alarm/alarm.model.d.ts +13 -0
- package/model/alarm/alarm.model.js +0 -0
- package/model/alarm/alarm.model.metadata.json +1 -0
- package/model/bar-graph/FontStyleData.d.ts +7 -7
- package/model/bar-graph/bar-graph-direction.d.ts +6 -6
- package/model/bar-graph/bar-graph-direction.js +7 -7
- package/model/bar-graph/bar-graph.d.ts +26 -22
- package/model/base/base-element-model.d.ts +5 -5
- package/model/base/base-element-model.js +2 -2
- package/model/base/conditional-control-model.d.ts +6 -6
- package/model/base/conditional-display-model.d.ts +9 -9
- package/model/base/conditional-dynamic-display-model.d.ts +13 -13
- package/model/base/conditional-enable-model.d.ts +9 -9
- package/model/base/font-setting-model.d.ts +29 -8
- package/model/base/font-setting-model.metadata.json +1 -1
- package/model/base/index.d.ts +7 -7
- package/model/base/index.js +1 -1
- package/model/base/readable-model.d.ts +14 -10
- package/model/base/security-model.d.ts +6 -6
- package/model/character-display/character-display.d.ts +19 -19
- package/model/datetime-display/date-format-type.d.ts +5 -5
- package/model/datetime-display/date-format-type.js +6 -6
- package/model/datetime-display/datetime-display-settings.d.ts +17 -17
- package/model/datetime-display/datetime-display.d.ts +21 -20
- package/model/datetime-display/datetime-separator-type.d.ts +6 -6
- package/model/datetime-display/datetime-separator-type.js +7 -7
- package/model/datetime-display/time-format-type.d.ts +4 -4
- package/model/datetime-display/time-format-type.js +5 -5
- package/model/historical-curve/curve-type.d.ts +5 -5
- package/model/historical-curve/curve-type.js +6 -6
- package/model/historical-curve/historical-curve-axis-settings.d.ts +17 -6
- package/model/historical-curve/historical-curve-axis-settings.js +5 -0
- package/model/historical-curve/historical-curve-axis-settings.metadata.json +1 -1
- package/model/historical-curve/historical-curve-chanel.model.d.ts +22 -14
- package/model/historical-curve/historical-curve.data-settings.d.ts +9 -9
- package/model/historical-curve/historical-curve.display-settings.d.ts +19 -19
- package/model/historical-curve/historical-curve.model.d.ts +8 -8
- package/model/historical-curve/index.d.ts +4 -4
- package/model/hyperlink/hyperlink.model.d.ts +8 -8
- package/model/image/image-fill-type.d.ts +4 -4
- package/model/image/image-fill-type.js +5 -5
- package/model/image/image.d.ts +9 -9
- package/model/index.d.ts +15 -15
- package/model/index.js +8 -8
- package/model/meter/meter.d.ts +17 -13
- package/model/numerical-display/index.d.ts +8 -8
- package/model/numerical-display/index.js +2 -2
- package/model/numerical-display/numerical-display.d.ts +29 -29
- package/model/numerical-display/numerical-operation-settings.d.ts +6 -6
- package/model/numerical-display/numerical-operation-type.d.ts +4 -4
- package/model/numerical-display/numerical-operation-type.js +5 -5
- package/model/numerical-display/numerical-operation.d.ts +19 -11
- package/model/numerical-display/proportional-conversion.d.ts +4 -4
- package/model/numerical-display/type-settings.d.ts +6 -6
- package/model/numerical-display/zoom.d.ts +4 -4
- package/model/pipe/flow-direction-type.d.ts +4 -4
- package/model/pipe/flow-direction-type.js +5 -5
- package/model/pipe/index.d.ts +2 -2
- package/model/pipe/index.js +1 -1
- package/model/pipe/pipe.d.ts +17 -17
- package/model/poly-line/poly-line-model.d.ts +4 -4
- package/model/polygon/polygon-model.d.ts +4 -4
- package/model/ring-graph/ring-graph.model.d.ts +33 -25
- package/model/scroll-alarm/scroll-alarm.model.d.ts +21 -0
- package/model/scroll-alarm/scroll-alarm.model.js +0 -0
- package/model/scroll-alarm/scroll-alarm.model.metadata.json +1 -0
- package/model/settings/background/view-background-fill-type.d.ts +5 -5
- package/model/settings/background/view-background-fill-type.js +6 -6
- package/model/settings/background/view-background.model.d.ts +8 -8
- package/model/settings/index.d.ts +3 -3
- package/model/settings/index.js +2 -2
- package/model/settings/popup/view-popup-backdrop-type.d.ts +4 -4
- package/model/settings/popup/view-popup-backdrop-type.js +5 -5
- package/model/settings/popup/view-popup-location-type.d.ts +4 -4
- package/model/settings/popup/view-popup-location-type.js +5 -5
- package/model/settings/popup/view-popup-setting.model.d.ts +17 -17
- package/model/settings/popup/view-popup-setting.model.js +2 -2
- package/model/settings/view-settings.model.d.ts +6 -6
- package/model/shared/alarm/alarm-range.model.d.ts +6 -6
- package/model/shared/arc.model.d.ts +4 -4
- package/model/shared/binary.d.ts +7 -7
- package/model/shared/binary.js +37 -37
- package/model/shared/condition/bit-condition-item-observer.d.ts +14 -14
- package/model/shared/condition/bit-condition-item-observer.js +53 -53
- package/model/shared/condition/bit-condition-logic.d.ts +4 -4
- package/model/shared/condition/bit-condition-logic.js +5 -5
- package/model/shared/condition/bit-condition-model.d.ts +8 -8
- package/model/shared/condition/bit-condition.d.ts +4 -4
- package/model/shared/condition/condition-control-result-value.d.ts +5 -5
- package/model/shared/condition/condition-helper.d.ts +4 -4
- package/model/shared/condition/condition-helper.js +22 -22
- package/model/shared/condition/condition-item-model.d.ts +10 -10
- package/model/shared/condition/condition-item-observer.d.ts +12 -12
- package/model/shared/condition/condition-item-observer.js +14 -14
- package/model/shared/condition/condition-items-observer.d.ts +5 -5
- package/model/shared/condition/condition-items-result-observer.d.ts +16 -16
- package/model/shared/condition/condition-items-result-observer.js +87 -87
- package/model/shared/condition/condition-model.d.ts +6 -6
- package/model/shared/condition/condition-type.d.ts +4 -4
- package/model/shared/condition/condition-type.js +5 -5
- package/model/shared/condition/convert-condition-model.d.ts +5 -5
- package/model/shared/condition/index.d.ts +11 -11
- package/model/shared/condition/index.js +4 -4
- package/model/shared/condition/relation-condition-result-state.d.ts +6 -6
- package/model/shared/condition/relation-condition-result-state.js +8 -8
- package/model/shared/condition/relation-condition-result.d.ts +8 -8
- package/model/shared/condition/relation-condition-result.js +7 -7
- package/model/shared/condition/relation-type.d.ts +5 -5
- package/model/shared/condition/relation-type.js +6 -6
- package/model/shared/condition/relational-operator.d.ts +8 -8
- package/model/shared/condition/relational-operator.js +9 -9
- package/model/shared/condition/variable-value-logic-model.d.ts +11 -11
- package/model/shared/condition/variable-value-type.d.ts +4 -4
- package/model/shared/condition/variable-value-type.js +5 -5
- package/model/shared/condition/word-condition-item-observer.d.ts +21 -21
- package/model/shared/condition/word-condition-item-observer.js +165 -165
- package/model/shared/condition/word-condition-model.d.ts +8 -8
- package/model/shared/condition/word-condition.d.ts +5 -5
- package/model/shared/data-type/display-data-type.d.ts +5 -5
- package/model/shared/data-type/display-data-type.js +6 -6
- package/model/shared/data-type/fbox-data-type.d.ts +15 -15
- package/model/shared/data-type/fbox-data-type.js +16 -16
- package/model/shared/data-type/fcloud-data-Type.d.ts +8 -8
- package/model/shared/data-type/fcloud-data-Type.js +9 -9
- package/model/shared/dynamic-display/dynamic-behavior-type.d.ts +5 -5
- package/model/shared/dynamic-display/dynamic-behavior-type.js +6 -6
- package/model/shared/dynamic-display/dynamic-display-behavior-model.d.ts +5 -5
- package/model/shared/dynamic-display/dynamic-display-model.d.ts +10 -10
- package/model/shared/dynamic-display/dynamic-display-result-model.d.ts +7 -7
- package/model/shared/dynamic-display/dynamic-display-result-model.js +7 -7
- package/model/shared/dynamic-display/dynamic-display.d.ts +11 -11
- package/model/shared/dynamic-display/dynamic-display.js +35 -35
- package/model/shared/graph/custom-style.d.ts +14 -14
- package/model/shared/graph/graph-setting.d.ts +10 -10
- package/model/shared/index.d.ts +8 -8
- package/model/shared/index.js +3 -3
- package/model/shared/point.model.d.ts +4 -4
- package/model/shared/rotation/rotation-behavior-model.d.ts +4 -4
- package/model/shared/rotation/rotation-behavior.d.ts +9 -9
- package/model/shared/rotation/rotation-behavior.js +101 -101
- package/model/shared/rotation/rotation-direction-type.d.ts +4 -4
- package/model/shared/rotation/rotation-direction-type.js +5 -5
- package/model/shared/rotation/rotation-model.d.ts +14 -14
- package/model/shared/rotation/rotation-observer-model.d.ts +4 -4
- package/model/shared/rotation/rotation-observer.d.ts +11 -11
- package/model/shared/rotation/rotation-observer.js +28 -28
- package/model/shared/scale/scale-mark.model.d.ts +6 -6
- package/model/shared/scale/scale-model.d.ts +20 -20
- package/model/shared/size.model.d.ts +7 -7
- package/model/shared/size.model.js +12 -12
- package/model/shared/state/index.d.ts +1 -1
- package/model/shared/state/index.js +1 -1
- package/model/shared/state/state.d.ts +9 -8
- package/model/shared/state/state.js +10 -9
- package/model/shared/state/state.metadata.json +1 -1
- package/model/shared/text/font.d.ts +10 -10
- package/model/shared/text/index.d.ts +2 -2
- package/model/shared/text/text.d.ts +8 -5
- package/model/shared/translation/translation-behavior-model.d.ts +4 -4
- package/model/shared/translation/translation-behavior.d.ts +12 -12
- package/model/shared/translation/translation-behavior.js +63 -63
- package/model/shared/translation/translation-direction-type.d.ts +4 -4
- package/model/shared/translation/translation-direction-type.js +5 -5
- package/model/shared/translation/translation-model.d.ts +12 -12
- package/model/shared/translation/translation-observer-model.d.ts +4 -4
- package/model/shared/translation/translation-observer.d.ts +10 -10
- package/model/shared/translation/translation-observer.js +27 -27
- package/model/shared/variable/variable-identifier.model.d.ts +5 -5
- package/model/shared/variable/variable-name.model.d.ts +5 -5
- package/model/straight-line/straight-line-model.d.ts +4 -4
- package/model/switch-indicator-light/bit-indicator-light-settings.d.ts +8 -8
- package/model/switch-indicator-light/bit-switch-operation.d.ts +6 -6
- package/model/switch-indicator-light/bit-switch-operation.js +7 -7
- package/model/switch-indicator-light/bit-switch-settings.d.ts +11 -11
- package/model/switch-indicator-light/fault-flicker.d.ts +5 -5
- package/model/switch-indicator-light/flicker.d.ts +5 -5
- package/model/switch-indicator-light/flicker.js +6 -6
- package/model/switch-indicator-light/index.d.ts +14 -14
- package/model/switch-indicator-light/index.js +5 -5
- package/model/switch-indicator-light/indicator-light-fault-flicker.d.ts +5 -5
- package/model/switch-indicator-light/indicator-light-settings.d.ts +7 -7
- package/model/switch-indicator-light/indicator-light-type.d.ts +4 -4
- package/model/switch-indicator-light/indicator-light-type.js +5 -5
- package/model/switch-indicator-light/switch-indicator-light.d.ts +35 -33
- package/model/switch-indicator-light/switch-indicator-state.d.ts +8 -8
- package/model/switch-indicator-light/switch-settings.d.ts +7 -7
- package/model/switch-indicator-light/switch-type.d.ts +4 -4
- package/model/switch-indicator-light/switch-type.js +5 -5
- package/model/switch-indicator-light/word-indicator-light-settings.d.ts +6 -6
- package/model/switch-indicator-light/word-switch-operation.d.ts +5 -5
- package/model/switch-indicator-light/word-switch-operation.js +6 -6
- package/model/switch-indicator-light/word-switch-settings.d.ts +13 -13
- package/model/table/table-model.d.ts +9 -9
- package/model/text/text.model.d.ts +7 -7
- package/model/video/video.model.d.ts +8 -8
- package/model/view-operation/index.d.ts +2 -2
- package/model/view-operation/index.js +1 -1
- package/model/view-operation/view-operation-element.model.d.ts +25 -19
- package/model/view-operation/view-operation-type.d.ts +18 -18
- package/model/view-operation/view-operation-type.js +19 -19
- package/model/weather/weather-info.d.ts +11 -11
- package/model/weather/weather-info.js +2 -2
- package/model/weather/weather.model.d.ts +7 -7
- package/package.json +1 -1
- package/public_api.d.ts +14 -14
- package/public_api.js +12 -11
- package/remote/communication/variable/remote-variable-communicator.d.ts +59 -30
- package/remote/communication/variable/remote-variable-communicator.js +395 -215
- package/remote/communication/variable/remote-variable-communicator.metadata.json +1 -1
- package/remote/communication/variable/remote-variable-protocol.d.ts +18 -13
- package/remote/config/graph/get-released-graph-state-result.d.ts +6 -6
- package/remote/config/graph/get-released-graph-states.d.ts +4 -4
- package/remote/config/graph/graph-state-key.d.ts +6 -6
- package/remote/config/graph/graph-state-result.d.ts +5 -5
- package/remote/config/graph/graph-state.d.ts +4 -4
- package/remote/config/graph/remote-graph-protocol.d.ts +11 -11
- package/remote/config/graph/remote-graph-store.d.ts +16 -16
- package/remote/config/graph/remote-graph-store.js +101 -101
- package/remote/config/image/remote-image-protocol.d.ts +4 -4
- package/remote/config/image/remote-image-store.d.ts +8 -8
- package/remote/config/image/remote-image-store.js +19 -19
- package/remote/config/view/remote-view-protocol.d.ts +8 -8
- package/remote/config/view/remote-view-store.d.ts +13 -13
- package/remote/config/view/remote-view-store.js +39 -39
- package/remote/config/view/view-result.d.ts +4 -4
- package/remote/index.d.ts +14 -14
- package/remote/index.js +4 -4
- package/security/index.d.ts +1 -1
- package/security/security-checker.d.ts +3 -3
- package/service/index.d.ts +8 -4
- package/service/index.js +1 -0
- package/service/index.metadata.json +1 -1
- package/service/language.service.d.ts +37 -0
- package/service/language.service.js +0 -0
- package/service/language.service.metadata.json +1 -0
- package/service/operation-record/create-operation-record-args.d.ts +5 -5
- package/service/operation-record/index.d.ts +3 -3
- package/service/operation-record/operation-record.service.d.ts +4 -4
- package/service/operation-record/variable-option.model.d.ts +5 -5
- package/service/permission-checker.d.ts +3 -3
- package/service/released-variable/index.d.ts +1 -0
- package/service/released-variable/index.js +0 -0
- package/service/released-variable/index.metadata.json +1 -0
- package/service/released-variable/released-variable.service.d.ts +4 -0
- package/service/released-variable/released-variable.service.js +0 -0
- package/service/released-variable/released-variable.service.metadata.json +1 -0
- package/service/system-text-library.service.d.ts +77 -0
- package/service/system-text-library.service.js +29 -0
- package/service/system-text-library.service.metadata.json +1 -0
- package/service/text-library.service.d.ts +49 -0
- package/service/text-library.service.js +0 -0
- package/service/text-library.service.metadata.json +1 -0
- package/service/video/index.d.ts +2 -2
- package/service/video/video-url.d.ts +4 -4
- package/service/video/video.service.d.ts +4 -4
- package/service/weather.service.d.ts +4 -3
- package/settings/display-mode.d.ts +10 -10
- package/settings/display-mode.js +11 -11
- package/settings/global-settings.d.ts +7 -7
- package/settings/global-settings.js +13 -13
- package/settings/index.d.ts +3 -3
- package/settings/index.js +3 -3
- package/settings/view-resize-mode.d.ts +10 -10
- package/settings/view-resize-mode.js +11 -11
- package/shared/config-is-empty-error.d.ts +3 -3
- package/shared/config-is-empty-error.js +7 -7
- package/shared/disposable.d.ts +3 -3
- package/shared/graph-extended-style.d.ts +4 -4
- package/shared/gui-consts.d.ts +33 -30
- package/shared/gui-consts.js +33 -30
- package/shared/gui-consts.metadata.json +1 -1
- package/shared/index.d.ts +5 -5
- package/shared/index.js +3 -3
- package/shared/operation-helper.d.ts +6 -6
- package/shared/operation-helper.js +38 -38
- package/utils/access-permission.d.ts +5 -5
- package/utils/access-permission.js +6 -6
- package/utils/access-permission.service.d.ts +11 -11
- package/utils/access-permission.service.js +30 -30
- package/utils/auto-focus.directive.d.ts +6 -6
- package/utils/auto-focus.directive.js +27 -27
- package/utils/bs-modal-drag.directive.d.ts +7 -7
- package/utils/bs-modal-drag.directive.js +38 -38
- package/utils/data-type/data-type.service.d.ts +57 -57
- package/utils/data-type/data-type.service.js +155 -155
- package/utils/data-type/fbox-data-type.service.d.ts +54 -54
- package/utils/data-type/fbox-data-type.service.js +300 -260
- package/utils/data-type/fcloud-data-type.service.d.ts +55 -55
- package/utils/data-type/fcloud-data-type.service.js +203 -203
- package/utils/fraction-digit.service.d.ts +41 -41
- package/utils/fraction-digit.service.js +133 -133
- package/utils/graph-util.d.ts +5 -5
- package/utils/graph-util.js +19 -19
- package/utils/guid.d.ts +6 -6
- package/utils/guid.js +27 -27
- package/utils/index.d.ts +7 -7
- package/utils/index.js +7 -7
- package/utils/numerical-operation-type.d.ts +4 -4
- package/utils/numerical-operation-type.js +5 -5
- package/utils/numerical-operation.service.d.ts +17 -17
- package/utils/numerical-operation.service.js +201 -177
- package/utils/variable-util.d.ts +5 -5
- package/utils/variable-util.js +11 -11
- package/view/popup-view.service.d.ts +7 -7
- package/view/view.service.d.ts +6 -6
- package/view/view.service.js +20 -20
|
@@ -1,23 +1,58 @@
|
|
|
1
|
-
import { LoggerService } from '../../../logger';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
private readonly
|
|
9
|
-
private
|
|
10
|
-
private readonly
|
|
11
|
-
private
|
|
12
|
-
private
|
|
13
|
-
|
|
14
|
-
private
|
|
15
|
-
private
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
private
|
|
19
|
-
private
|
|
20
|
-
private
|
|
21
|
-
private
|
|
22
|
-
|
|
23
|
-
|
|
1
|
+
import { LoggerService } from '../../../logger';
|
|
2
|
+
import { TextLibrarySetting } from '../../../model/base/font-setting-model';
|
|
3
|
+
import { IndicatorLightFaultFlicker } from '../../../model/switch-indicator-light/indicator-light-fault-flicker';
|
|
4
|
+
import { TextLibraryService, LanguageService } from '../../../service';
|
|
5
|
+
import { TextState } from './text-state.model';
|
|
6
|
+
import { GuiContext } from '../../../gui/gui-context';
|
|
7
|
+
export declare class TextStateElement {
|
|
8
|
+
private readonly textStates;
|
|
9
|
+
private width;
|
|
10
|
+
private readonly height;
|
|
11
|
+
private readonly logger;
|
|
12
|
+
private readonly version?;
|
|
13
|
+
private readonly faultFlickers?;
|
|
14
|
+
private readonly textLibrarySetting?;
|
|
15
|
+
private readonly textLibraryService?;
|
|
16
|
+
private readonly languageService?;
|
|
17
|
+
private readonly guiContext?;
|
|
18
|
+
private readonly allowEmpty;
|
|
19
|
+
private readonly fontStyleCultures?;
|
|
20
|
+
private textElement;
|
|
21
|
+
private _element;
|
|
22
|
+
get Element(): SVGElement;
|
|
23
|
+
private faultFlickerStatus;
|
|
24
|
+
private faultFlickerInterval;
|
|
25
|
+
private currentStateId;
|
|
26
|
+
private languageChangeSubscription?;
|
|
27
|
+
constructor(textStates: TextState[], width: number, height: number, logger: LoggerService, version?: number, faultFlickers?: IndicatorLightFaultFlicker[], textLibrarySetting?: TextLibrarySetting, textLibraryService?: TextLibraryService, languageService?: LanguageService, guiContext?: GuiContext, allowEmpty?: boolean, fontStyleCultures?: {
|
|
28
|
+
[stateId: string]: {
|
|
29
|
+
[languageCode: string]: any;
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
switchToState(stateId: number): void;
|
|
33
|
+
/**
|
|
34
|
+
* 订阅语种变化事件
|
|
35
|
+
* 当设备的语种ID改变时,重新渲染当前状态的文本
|
|
36
|
+
*/
|
|
37
|
+
private subscribeLanguageChange;
|
|
38
|
+
/**
|
|
39
|
+
* 释放资源
|
|
40
|
+
*/
|
|
41
|
+
dispose(): void;
|
|
42
|
+
private getforeignObjectElement;
|
|
43
|
+
private removeForeignObjectlement;
|
|
44
|
+
private doFaultFlicker;
|
|
45
|
+
private clearFlickerInterval;
|
|
46
|
+
/**
|
|
47
|
+
* 获取指定状态在当前语种下的字体样式
|
|
48
|
+
*/
|
|
49
|
+
private getFontForState;
|
|
50
|
+
/**
|
|
51
|
+
* 获取显示文本
|
|
52
|
+
* 支持三种格式:
|
|
53
|
+
* 1. 新格式:textData.cultures 在顶层(与 content 并列)
|
|
54
|
+
* 2. 中间格式:textData.content 为 { cultures: {...} }(已废弃,向下兼容)
|
|
55
|
+
* 3. 旧格式:textData.content 为字符串
|
|
56
|
+
*/
|
|
57
|
+
private getDisplayText;
|
|
58
|
+
}
|
|
@@ -1,136 +1,286 @@
|
|
|
1
|
-
import { Flicker } from '../../../model';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
this.
|
|
6
|
-
this.
|
|
7
|
-
this.
|
|
8
|
-
this.
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
this.
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
if (this.
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
1
|
+
import { Flicker } from '../../../model';
|
|
2
|
+
export class TextStateElement {
|
|
3
|
+
constructor(textStates, width, height, logger, version, faultFlickers, textLibrarySetting, textLibraryService, languageService, guiContext, allowEmpty = false, fontStyleCultures) {
|
|
4
|
+
this.textStates = textStates;
|
|
5
|
+
this.width = width;
|
|
6
|
+
this.height = height;
|
|
7
|
+
this.logger = logger;
|
|
8
|
+
this.version = version;
|
|
9
|
+
this.faultFlickers = faultFlickers;
|
|
10
|
+
this.textLibrarySetting = textLibrarySetting;
|
|
11
|
+
this.textLibraryService = textLibraryService;
|
|
12
|
+
this.languageService = languageService;
|
|
13
|
+
this.guiContext = guiContext;
|
|
14
|
+
this.allowEmpty = allowEmpty;
|
|
15
|
+
this.fontStyleCultures = fontStyleCultures;
|
|
16
|
+
this.faultFlickerStatus = false;
|
|
17
|
+
this.faultFlickerInterval = undefined;
|
|
18
|
+
this._element = document.createElementNS('http://www.w3.org/2000/svg', 'g');
|
|
19
|
+
// 订阅语种变化事件
|
|
20
|
+
this.subscribeLanguageChange();
|
|
21
|
+
}
|
|
22
|
+
get Element() {
|
|
23
|
+
return this._element;
|
|
24
|
+
}
|
|
25
|
+
switchToState(stateId) {
|
|
26
|
+
// 保存当前状态ID,用于语种切换时重新渲染
|
|
27
|
+
this.currentStateId = stateId;
|
|
28
|
+
const textState = this.textStates.find(t => t.id === stateId);
|
|
29
|
+
if (textState === undefined) {
|
|
30
|
+
this.removeForeignObjectlement();
|
|
31
|
+
this.logger.debug(`Can not find text state:${stateId}.`);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
// 获取显示文本(支持文本库)
|
|
35
|
+
const content = this.getDisplayText(stateId, textState.text);
|
|
36
|
+
if (content === '' || content == null) {
|
|
37
|
+
this.removeForeignObjectlement();
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const font = this.getFontForState(stateId, textState.text.font);
|
|
41
|
+
if (!font) {
|
|
42
|
+
this.removeForeignObjectlement();
|
|
43
|
+
this.logger.debug('The font is undefined.');
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const textElement = this.getforeignObjectElement();
|
|
47
|
+
// 设置 text-anchor 和 dominant-baseline
|
|
48
|
+
textElement.setAttribute('text-anchor', 'middle');
|
|
49
|
+
textElement.setAttribute('dominant-baseline', 'middle');
|
|
50
|
+
textElement.setAttribute('pointer-events', 'auto');
|
|
51
|
+
// 拆分换行
|
|
52
|
+
const lines = content.split('\n');
|
|
53
|
+
const fontSize = parseInt(font.fontSize, 10);
|
|
54
|
+
const lineHeight = fontSize + 4;
|
|
55
|
+
// 总高度 = 行数 * 行高
|
|
56
|
+
const totalHeight = lines.length * lineHeight;
|
|
57
|
+
// 调整文本整体垂直居中(通过 dy)
|
|
58
|
+
const startY = (this.height / 2) - (totalHeight / 2) + (lineHeight / 2);
|
|
59
|
+
// 复用已有 tspan,不足则新建,多余则隐藏——避免删除 touch 目标节点导致 touchend 丢失
|
|
60
|
+
const existingTspans = Array.from(textElement.children);
|
|
61
|
+
for (let i = 0; i < lines.length; i++) {
|
|
62
|
+
let tspan = existingTspans[i];
|
|
63
|
+
if (!tspan) {
|
|
64
|
+
tspan = document.createElementNS('http://www.w3.org/2000/svg', 'tspan');
|
|
65
|
+
textElement.appendChild(tspan);
|
|
66
|
+
}
|
|
67
|
+
tspan.setAttribute('display', 'inline');
|
|
68
|
+
tspan.setAttribute('x', (this.width / 2).toString());
|
|
69
|
+
tspan.setAttribute('y', startY + i * lineHeight + 'px');
|
|
70
|
+
tspan.textContent = lines[i].replace(/ /g, '\u00A0');
|
|
71
|
+
tspan.setAttribute('font-size', font.fontSize);
|
|
72
|
+
tspan.setAttribute('fill', font.color);
|
|
73
|
+
tspan.setAttribute('font-family', font.fontFamily);
|
|
74
|
+
tspan.setAttribute('font-weight', font.isBold ? 'bold' : 'normal');
|
|
75
|
+
tspan.setAttribute('font-style', font.isItalic ? 'italic' : 'normal');
|
|
76
|
+
tspan.setAttribute('text-decoration', font.isUnderline ? 'underline' : 'none');
|
|
77
|
+
tspan.setAttribute('text-anchor', 'middle');
|
|
78
|
+
tspan.setAttribute('dominant-baseline', 'middle');
|
|
79
|
+
}
|
|
80
|
+
// 隐藏多余的 tspan(不删除)
|
|
81
|
+
for (let i = lines.length; i < existingTspans.length; i++) {
|
|
82
|
+
existingTspans[i].setAttribute('display', 'none');
|
|
83
|
+
}
|
|
84
|
+
this.doFaultFlicker(textElement, stateId);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* 订阅语种变化事件
|
|
88
|
+
* 当设备的语种ID改变时,重新渲染当前状态的文本
|
|
89
|
+
*/
|
|
90
|
+
subscribeLanguageChange() {
|
|
91
|
+
if (this.guiContext && this.guiContext.languageChanged$) {
|
|
92
|
+
this.languageChangeSubscription = this.guiContext.languageChanged$.subscribe(() => {
|
|
93
|
+
// 如果当前有状态,重新渲染
|
|
94
|
+
if (this.currentStateId !== undefined) {
|
|
95
|
+
this.switchToState(this.currentStateId);
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* 释放资源
|
|
102
|
+
*/
|
|
103
|
+
dispose() {
|
|
104
|
+
// 取消语种变化订阅
|
|
105
|
+
if (this.languageChangeSubscription) {
|
|
106
|
+
this.languageChangeSubscription.unsubscribe();
|
|
107
|
+
this.languageChangeSubscription = undefined;
|
|
108
|
+
}
|
|
109
|
+
// 清除闪烁定时器
|
|
110
|
+
if (this.faultFlickerInterval) {
|
|
111
|
+
clearInterval(this.faultFlickerInterval);
|
|
112
|
+
this.faultFlickerInterval = undefined;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
getforeignObjectElement() {
|
|
116
|
+
if (!this.textElement) {
|
|
117
|
+
this.textElement = document.createElementNS('http://www.w3.org/2000/svg', 'text');
|
|
118
|
+
this.textElement.setAttribute('x', (this.width / 2).toString());
|
|
119
|
+
this.textElement.setAttribute('y', (this.height / 2).toString());
|
|
120
|
+
this.textElement.setAttribute('text-anchor', 'middle');
|
|
121
|
+
this.textElement.setAttribute('dominant-baseline', 'middle');
|
|
122
|
+
this.textElement.setAttribute('pointer-events', 'auto'); // 确保能接收事件
|
|
123
|
+
this._element.appendChild(this.textElement);
|
|
124
|
+
}
|
|
125
|
+
this.textElement.setAttribute('display', 'block');
|
|
126
|
+
return this.textElement;
|
|
127
|
+
}
|
|
128
|
+
removeForeignObjectlement() {
|
|
129
|
+
if (this.textElement) {
|
|
130
|
+
this.textElement.setAttribute('display', 'none');
|
|
131
|
+
this.textElement.textContent = '';
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
doFaultFlicker(textElement, stateId) {
|
|
135
|
+
if (this.version > 3 && this.faultFlickers) {
|
|
136
|
+
this.clearFlickerInterval(textElement);
|
|
137
|
+
const faultFlicker = this.faultFlickers.find(t => t.id === stateId);
|
|
138
|
+
if (faultFlicker && faultFlicker.faultFlicker) {
|
|
139
|
+
if (faultFlicker.faultFlicker.flicker === Flicker.Label) {
|
|
140
|
+
this.faultFlickerInterval = setInterval(() => {
|
|
141
|
+
if (this.faultFlickerStatus) {
|
|
142
|
+
textElement.setAttributeNS(null, 'display', 'block');
|
|
143
|
+
this.faultFlickerStatus = false;
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
textElement.setAttributeNS(null, 'display', 'none');
|
|
147
|
+
this.faultFlickerStatus = true;
|
|
148
|
+
}
|
|
149
|
+
}, faultFlicker.faultFlicker.frequency * 500);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
clearFlickerInterval(textElement) {
|
|
155
|
+
if (this.faultFlickerInterval) {
|
|
156
|
+
clearInterval(this.faultFlickerInterval);
|
|
157
|
+
if (this.faultFlickerStatus) {
|
|
158
|
+
textElement.setAttributeNS(null, 'display', 'block');
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* 获取指定状态在当前语种下的字体样式
|
|
164
|
+
*/
|
|
165
|
+
getFontForState(stateId, defaultFont) {
|
|
166
|
+
if (!this.fontStyleCultures) {
|
|
167
|
+
return defaultFont;
|
|
168
|
+
}
|
|
169
|
+
const stateKey = stateId.toString();
|
|
170
|
+
if (!this.fontStyleCultures[stateKey]) {
|
|
171
|
+
return defaultFont;
|
|
172
|
+
}
|
|
173
|
+
const getTargetLanguage = () => {
|
|
174
|
+
var _a, _b, _c, _d, _e, _f;
|
|
175
|
+
const currentLanguageId = (_c = (_b = (_a = this.guiContext) === null || _a === void 0 ? void 0 : _a.getCurrentLanguageId) === null || _b === void 0 ? void 0 : _b.call(_a)) !== null && _c !== void 0 ? _c : null;
|
|
176
|
+
const defaultLanguage = ((_d = this.languageService) === null || _d === void 0 ? void 0 : _d.getDefaultLanguage()) || 'zh-CN';
|
|
177
|
+
if (currentLanguageId === null || currentLanguageId === undefined) {
|
|
178
|
+
return defaultLanguage;
|
|
179
|
+
}
|
|
180
|
+
return ((_f = (_e = this.guiContext) === null || _e === void 0 ? void 0 : _e.getLanguageCultureById) === null || _f === void 0 ? void 0 : _f.call(_e, currentLanguageId)) || defaultLanguage;
|
|
181
|
+
};
|
|
182
|
+
const targetLanguage = getTargetLanguage();
|
|
183
|
+
if (this.fontStyleCultures[stateKey][targetLanguage]) {
|
|
184
|
+
return this.fontStyleCultures[stateKey][targetLanguage];
|
|
185
|
+
}
|
|
186
|
+
return defaultFont;
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* 获取显示文本
|
|
190
|
+
* 支持三种格式:
|
|
191
|
+
* 1. 新格式:textData.cultures 在顶层(与 content 并列)
|
|
192
|
+
* 2. 中间格式:textData.content 为 { cultures: {...} }(已废弃,向下兼容)
|
|
193
|
+
* 3. 旧格式:textData.content 为字符串
|
|
194
|
+
*/
|
|
195
|
+
getDisplayText(stateId, textData) {
|
|
196
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
197
|
+
const getTargetLanguage = () => {
|
|
198
|
+
var _a, _b, _c, _d, _e, _f;
|
|
199
|
+
const currentLanguageId = (_c = (_b = (_a = this.guiContext) === null || _a === void 0 ? void 0 : _a.getCurrentLanguageId) === null || _b === void 0 ? void 0 : _b.call(_a)) !== null && _c !== void 0 ? _c : null;
|
|
200
|
+
const defaultLanguage = ((_d = this.languageService) === null || _d === void 0 ? void 0 : _d.getDefaultLanguage()) || 'zh-CN';
|
|
201
|
+
if (currentLanguageId === null || currentLanguageId === undefined) {
|
|
202
|
+
return defaultLanguage;
|
|
203
|
+
}
|
|
204
|
+
return ((_f = (_e = this.guiContext) === null || _e === void 0 ? void 0 : _e.getLanguageCultureById) === null || _f === void 0 ? void 0 : _f.call(_e, currentLanguageId)) || defaultLanguage;
|
|
205
|
+
};
|
|
206
|
+
const defaultContent = textData === null || textData === void 0 ? void 0 : textData.content;
|
|
207
|
+
// 新格式:cultures 在 text 顶层
|
|
208
|
+
if (textData && textData.cultures && typeof textData.cultures === 'object') {
|
|
209
|
+
const targetLanguage = getTargetLanguage();
|
|
210
|
+
if (textData.cultures[targetLanguage]) {
|
|
211
|
+
return textData.cultures[targetLanguage];
|
|
212
|
+
}
|
|
213
|
+
else if (this.allowEmpty) {
|
|
214
|
+
return '';
|
|
215
|
+
}
|
|
216
|
+
else {
|
|
217
|
+
const language = ((_c = (_b = (_a = window.abp) === null || _a === void 0 ? void 0 : _a.localization) === null || _b === void 0 ? void 0 : _b.currentLanguage) === null || _c === void 0 ? void 0 : _c.name) || 'zh-Hans';
|
|
218
|
+
const isChinese = language === 'zh-Hans' || language === 'zh';
|
|
219
|
+
return isChinese ? '文本' : 'Text';
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
// 中间格式(兼容):content 为 { cultures: {...} }
|
|
223
|
+
if (defaultContent && typeof defaultContent === 'object' && defaultContent.cultures) {
|
|
224
|
+
const targetLanguage = getTargetLanguage();
|
|
225
|
+
if (defaultContent.cultures[targetLanguage]) {
|
|
226
|
+
return defaultContent.cultures[targetLanguage];
|
|
227
|
+
}
|
|
228
|
+
else if (this.allowEmpty) {
|
|
229
|
+
return '';
|
|
230
|
+
}
|
|
231
|
+
else {
|
|
232
|
+
const language = ((_f = (_e = (_d = window.abp) === null || _d === void 0 ? void 0 : _d.localization) === null || _e === void 0 ? void 0 : _e.currentLanguage) === null || _f === void 0 ? void 0 : _f.name) || 'zh-Hans';
|
|
233
|
+
const isChinese = language === 'zh-Hans' || language === 'zh';
|
|
234
|
+
return isChinese ? '文本' : 'Text';
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
// 检查是否使用文本库
|
|
238
|
+
if (this.textLibrarySetting && this.textLibrarySetting.labelType === 'textLibrary') {
|
|
239
|
+
const textLibraryId = this.textLibrarySetting.selectedTextLibraryItem;
|
|
240
|
+
if (textLibraryId && this.textLibraryService) {
|
|
241
|
+
// 获取文本库数据
|
|
242
|
+
const textLibraryData = this.textLibraryService.getTextLibraryById(typeof textLibraryId === 'string' ? parseInt(textLibraryId, 10) : textLibraryId);
|
|
243
|
+
if (textLibraryData && textLibraryData.data) {
|
|
244
|
+
// 使用状态ID作为value查找对应的文本条目
|
|
245
|
+
const textEntry = textLibraryData.data.find(entry => entry.value === stateId.toString());
|
|
246
|
+
if (textEntry) {
|
|
247
|
+
// 获取当前语种ID
|
|
248
|
+
const currentLanguageId = (_j = (_h = (_g = this.guiContext) === null || _g === void 0 ? void 0 : _g.getCurrentLanguageId) === null || _h === void 0 ? void 0 : _h.call(_g)) !== null && _j !== void 0 ? _j : null;
|
|
249
|
+
// 确定要使用的语种代码(culture)
|
|
250
|
+
let targetLanguage;
|
|
251
|
+
const defaultLanguage = ((_k = this.languageService) === null || _k === void 0 ? void 0 : _k.getDefaultLanguage()) || 'zh-CN';
|
|
252
|
+
if (currentLanguageId === null || currentLanguageId === undefined) {
|
|
253
|
+
// 设备未设置当前语种,使用默认语种
|
|
254
|
+
targetLanguage = defaultLanguage;
|
|
255
|
+
}
|
|
256
|
+
else {
|
|
257
|
+
// 设备已设置当前语种,获取对应的语种代码
|
|
258
|
+
const currentLanguage = (_m = (_l = this.guiContext) === null || _l === void 0 ? void 0 : _l.getLanguageCultureById) === null || _m === void 0 ? void 0 : _m.call(_l, currentLanguageId);
|
|
259
|
+
if (currentLanguage) {
|
|
260
|
+
// 直接使用设备设置的语种,不再fallback
|
|
261
|
+
targetLanguage = currentLanguage;
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
targetLanguage = defaultLanguage;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
// 返回对应语种的文本,如果没有则返回空字符串
|
|
268
|
+
if (textEntry.cultures && textEntry.cultures[targetLanguage]) {
|
|
269
|
+
const text = textEntry.cultures[targetLanguage];
|
|
270
|
+
return text;
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
// 对应语种没有文本,返回空字符串
|
|
274
|
+
return '';
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
// 处理字符串格式的 defaultContent
|
|
281
|
+
if (typeof defaultContent === 'string') {
|
|
282
|
+
return defaultContent;
|
|
283
|
+
}
|
|
284
|
+
return '';
|
|
285
|
+
}
|
|
286
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
[{"__symbolic":"module","version":4,"metadata":{"TextStateElement":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Array","arguments":[{"__symbolic":"reference","module":"./text-state.model","name":"TextState","line":
|
|
1
|
+
[{"__symbolic":"module","version":4,"metadata":{"TextStateElement":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"Array","arguments":[{"__symbolic":"reference","module":"./text-state.model","name":"TextState","line":23,"character":45}]},{"__symbolic":"reference","name":"number"},{"__symbolic":"reference","name":"number"},{"__symbolic":"reference","module":"../../../logger","name":"LoggerService","line":26,"character":33},{"__symbolic":"reference","name":"number"},{"__symbolic":"reference","name":"Array","arguments":[{"__symbolic":"reference","module":"../../../model/switch-indicator-light/indicator-light-fault-flicker","name":"IndicatorLightFaultFlicker","line":28,"character":41}]},{"__symbolic":"reference","module":"../../../model/base/font-setting-model","name":"TextLibrarySetting","line":29,"character":46},{"__symbolic":"reference","module":"../../../service","name":"TextLibraryService","line":30,"character":46},{"__symbolic":"reference","module":"../../../service","name":"LanguageService","line":31,"character":43},{"__symbolic":"reference","module":"../../../gui/gui-context","name":"GuiContext","line":32,"character":38},{"__symbolic":"reference","name":"boolean"},{"__symbolic":"error","message":"Expression form not supported","line":34,"character":45}]}],"switchToState":[{"__symbolic":"method"}],"subscribeLanguageChange":[{"__symbolic":"method"}],"dispose":[{"__symbolic":"method"}],"getforeignObjectElement":[{"__symbolic":"method"}],"removeForeignObjectlement":[{"__symbolic":"method"}],"doFaultFlicker":[{"__symbolic":"method"}],"clearFlickerInterval":[{"__symbolic":"method"}],"getFontForState":[{"__symbolic":"method"}],"getDisplayText":[{"__symbolic":"method"}]}}}}]
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Text } from '../../../model';
|
|
2
|
-
export interface TextState {
|
|
3
|
-
readonly id: number;
|
|
4
|
-
readonly text: Text;
|
|
5
|
-
}
|
|
1
|
+
import { Text } from '../../../model';
|
|
2
|
+
export interface TextState {
|
|
3
|
+
readonly id: number;
|
|
4
|
+
readonly text: Text;
|
|
5
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Font } from '../../../model';
|
|
2
|
-
export declare class TextUtils {
|
|
3
|
-
static setText(textElement: SVGTextElement, content: string, font: Font, width: number, height: number, cursor?: string): void;
|
|
4
|
-
private static alignText;
|
|
5
|
-
}
|
|
1
|
+
import { Font } from '../../../model';
|
|
2
|
+
export declare class TextUtils {
|
|
3
|
+
static setText(textElement: SVGTextElement, content: string, font: Font, width: number, height: number, cursor?: string): void;
|
|
4
|
+
private static alignText;
|
|
5
|
+
}
|
|
@@ -1,45 +1,45 @@
|
|
|
1
|
-
export class TextUtils {
|
|
2
|
-
static setText(textElement, content, font, width, height, cursor = 'hand') {
|
|
3
|
-
this.alignText(textElement, font.textAlign, width, height);
|
|
4
|
-
textElement.setAttribute('cursor', cursor);
|
|
5
|
-
textElement.setAttribute('alignment-baseline', 'central');
|
|
6
|
-
textElement.setAttribute('font-family', font.fontFamily);
|
|
7
|
-
textElement.setAttribute('font-size', font.fontSize + '');
|
|
8
|
-
textElement.setAttribute('fill', font.color);
|
|
9
|
-
if (font.isBold) {
|
|
10
|
-
textElement.setAttribute('font-weight', 'bold');
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
textElement.removeAttribute('font-weight');
|
|
14
|
-
}
|
|
15
|
-
if (font.isItalic) {
|
|
16
|
-
textElement.setAttribute('font-style', 'italic');
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
textElement.removeAttribute('font-style');
|
|
20
|
-
}
|
|
21
|
-
if (font.isUnderline) {
|
|
22
|
-
textElement.setAttribute('text-decoration', 'underline');
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
textElement.removeAttribute('text-decoration');
|
|
26
|
-
}
|
|
27
|
-
textElement.textContent = content;
|
|
28
|
-
}
|
|
29
|
-
static alignText(textElement, align, width, height) {
|
|
30
|
-
switch (align) {
|
|
31
|
-
case 'right':
|
|
32
|
-
textElement.setAttribute('text-anchor', 'end');
|
|
33
|
-
textElement.setAttribute('transform', `translate(${width},${height / 2})`);
|
|
34
|
-
break;
|
|
35
|
-
case 'left':
|
|
36
|
-
textElement.setAttribute('text-anchor', 'start');
|
|
37
|
-
textElement.setAttribute('transform', `translate(0,${height / 2})`);
|
|
38
|
-
break;
|
|
39
|
-
default:
|
|
40
|
-
textElement.setAttribute('text-anchor', 'middle');
|
|
41
|
-
textElement.setAttribute('transform', `translate(${width / 2},${height / 2})`);
|
|
42
|
-
break;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
1
|
+
export class TextUtils {
|
|
2
|
+
static setText(textElement, content, font, width, height, cursor = 'hand') {
|
|
3
|
+
this.alignText(textElement, font.textAlign, width, height);
|
|
4
|
+
textElement.setAttribute('cursor', cursor);
|
|
5
|
+
textElement.setAttribute('alignment-baseline', 'central');
|
|
6
|
+
textElement.setAttribute('font-family', font.fontFamily);
|
|
7
|
+
textElement.setAttribute('font-size', font.fontSize + '');
|
|
8
|
+
textElement.setAttribute('fill', font.color);
|
|
9
|
+
if (font.isBold) {
|
|
10
|
+
textElement.setAttribute('font-weight', 'bold');
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
textElement.removeAttribute('font-weight');
|
|
14
|
+
}
|
|
15
|
+
if (font.isItalic) {
|
|
16
|
+
textElement.setAttribute('font-style', 'italic');
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
textElement.removeAttribute('font-style');
|
|
20
|
+
}
|
|
21
|
+
if (font.isUnderline) {
|
|
22
|
+
textElement.setAttribute('text-decoration', 'underline');
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
textElement.removeAttribute('text-decoration');
|
|
26
|
+
}
|
|
27
|
+
textElement.textContent = content;
|
|
28
|
+
}
|
|
29
|
+
static alignText(textElement, align, width, height) {
|
|
30
|
+
switch (align) {
|
|
31
|
+
case 'right':
|
|
32
|
+
textElement.setAttribute('text-anchor', 'end');
|
|
33
|
+
textElement.setAttribute('transform', `translate(${width},${height / 2})`);
|
|
34
|
+
break;
|
|
35
|
+
case 'left':
|
|
36
|
+
textElement.setAttribute('text-anchor', 'start');
|
|
37
|
+
textElement.setAttribute('transform', `translate(0,${height / 2})`);
|
|
38
|
+
break;
|
|
39
|
+
default:
|
|
40
|
+
textElement.setAttribute('text-anchor', 'middle');
|
|
41
|
+
textElement.setAttribute('transform', `translate(${width / 2},${height / 2})`);
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|