@flexem/fc-gui 3.0.0-alpha.8.1 → 3.0.0-alpha.81

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.
Files changed (214) hide show
  1. package/CHANGELOG.md +342 -0
  2. package/bundles/@flexem/fc-gui.umd.js +18575 -17008
  3. package/bundles/@flexem/fc-gui.umd.js.map +1 -1
  4. package/bundles/@flexem/fc-gui.umd.min.js +5 -5
  5. package/bundles/@flexem/fc-gui.umd.min.js.map +1 -1
  6. package/communication/variable/variable-communicator.d.ts +3 -2
  7. package/config/alarm/alarm.store.d.ts +6 -0
  8. package/config/alarm/alarm.store.js +0 -0
  9. package/config/alarm/alarm.store.metadata.json +1 -0
  10. package/config/alarm/get-alarms-args.d.ts +9 -0
  11. package/config/alarm/get-alarms-args.js +9 -0
  12. package/config/alarm/get-alarms-args.metadata.json +1 -0
  13. package/config/alarm/index.d.ts +2 -0
  14. package/config/alarm/index.js +1 -0
  15. package/config/alarm/index.metadata.json +1 -0
  16. package/config/config-store.d.ts +2 -0
  17. package/config/index.d.ts +1 -0
  18. package/config/index.js +1 -0
  19. package/config/index.metadata.json +1 -1
  20. package/elements/air-quality/air-quality-element.d.ts +31 -0
  21. package/elements/air-quality/air-quality-element.js +194 -0
  22. package/elements/air-quality/air-quality-element.metadata.json +1 -0
  23. package/elements/alarm/alarm-element.d.ts +44 -0
  24. package/elements/alarm/alarm-element.js +382 -0
  25. package/elements/alarm/alarm-element.metadata.json +1 -0
  26. package/elements/bar-graph-element.d.ts +8 -2
  27. package/elements/bar-graph-element.js +72 -6
  28. package/elements/bar-graph-element.metadata.json +1 -1
  29. package/elements/base/base-element.d.ts +2 -1
  30. package/elements/base/base-element.js +2 -1
  31. package/elements/base/base-element.metadata.json +1 -1
  32. package/elements/base/conditional-control-element.d.ts +1 -1
  33. package/elements/base/conditional-control-element.js +3 -3
  34. package/elements/base/conditional-control-element.metadata.json +1 -1
  35. package/elements/base/conditional-display-element.d.ts +1 -1
  36. package/elements/base/conditional-display-element.js +4 -4
  37. package/elements/base/conditional-display-element.metadata.json +1 -1
  38. package/elements/base/conditional-dynamic-display-element.d.ts +1 -1
  39. package/elements/base/conditional-dynamic-display-element.js +3 -3
  40. package/elements/base/conditional-dynamic-display-element.metadata.json +1 -1
  41. package/elements/base/conditional-enable-element.d.ts +1 -1
  42. package/elements/base/conditional-enable-element.js +4 -4
  43. package/elements/base/conditional-enable-element.metadata.json +1 -1
  44. package/elements/base/readable-element.d.ts +7 -2
  45. package/elements/base/readable-element.js +33 -4
  46. package/elements/base/readable-element.metadata.json +1 -1
  47. package/elements/base/state-control-element.d.ts +1 -1
  48. package/elements/base/state-control-element.js +2 -2
  49. package/elements/base/state-control-element.metadata.json +1 -1
  50. package/elements/character-display/character-display-element.d.ts +1 -1
  51. package/elements/character-display/character-display-element.js +2 -2
  52. package/elements/character-display/character-display-element.metadata.json +1 -1
  53. package/elements/datetime-display/datetime-display-element.d.ts +1 -1
  54. package/elements/datetime-display/datetime-display-element.js +2 -2
  55. package/elements/datetime-display/datetime-display-element.metadata.json +1 -1
  56. package/elements/historical-curve/historical-curve.element.d.ts +1 -1
  57. package/elements/historical-curve/historical-curve.element.js +104 -15
  58. package/elements/historical-curve/historical-curve.element.metadata.json +1 -1
  59. package/elements/main-element.d.ts +2 -1
  60. package/elements/main-element.js +48 -26
  61. package/elements/main-element.metadata.json +1 -1
  62. package/elements/meter-element.d.ts +8 -2
  63. package/elements/meter-element.js +78 -9
  64. package/elements/meter-element.metadata.json +1 -1
  65. package/elements/numerical-display/numerical-display-element.d.ts +8 -2
  66. package/elements/numerical-display/numerical-display-element.js +50 -12
  67. package/elements/numerical-display/numerical-display-element.metadata.json +1 -1
  68. package/elements/per-view-variable-communicator.d.ts +4 -2
  69. package/elements/per-view-variable-communicator.js +12 -4
  70. package/elements/per-view-variable-communicator.metadata.json +1 -1
  71. package/elements/pipe/pipe-element.d.ts +1 -1
  72. package/elements/pipe/pipe-element.js +2 -2
  73. package/elements/pipe/pipe-element.metadata.json +1 -1
  74. package/elements/ring-graph/ring-graph-element.d.ts +11 -2
  75. package/elements/ring-graph/ring-graph-element.js +108 -5
  76. package/elements/ring-graph/ring-graph-element.metadata.json +1 -1
  77. package/elements/shared/graph/graph-state-element.js +0 -3
  78. package/elements/shared/text/text-element.js +13 -2
  79. package/elements/shared/text/text-state-element.js +1 -1
  80. package/elements/static-elements/hyperlink-element.d.ts +1 -1
  81. package/elements/static-elements/hyperlink-element.js +2 -2
  82. package/elements/static-elements/hyperlink-element.metadata.json +1 -1
  83. package/elements/static-elements/image-element.d.ts +1 -1
  84. package/elements/static-elements/image-element.js +2 -2
  85. package/elements/static-elements/image-element.metadata.json +1 -1
  86. package/elements/static-elements/text-element.d.ts +1 -1
  87. package/elements/static-elements/text-element.js +2 -2
  88. package/elements/static-elements/text-element.metadata.json +1 -1
  89. package/elements/switch-indicator-light/bit-indicator-light-operator.d.ts +1 -1
  90. package/elements/switch-indicator-light/bit-indicator-light-operator.js +4 -4
  91. package/elements/switch-indicator-light/bit-switch-operator.d.ts +3 -1
  92. package/elements/switch-indicator-light/bit-switch-operator.js +22 -2
  93. package/elements/switch-indicator-light/bit-switch-operator.metadata.json +1 -1
  94. package/elements/switch-indicator-light/indicator-light-operator.d.ts +1 -1
  95. package/elements/switch-indicator-light/switch-indicator-light-element.d.ts +9 -1
  96. package/elements/switch-indicator-light/switch-indicator-light-element.js +98 -28
  97. package/elements/switch-indicator-light/switch-indicator-light-element.metadata.json +1 -1
  98. package/elements/switch-indicator-light/switch-operator.d.ts +1 -0
  99. package/elements/switch-indicator-light/word-indicator-light-operator.d.ts +1 -1
  100. package/elements/switch-indicator-light/word-indicator-light-operator.js +5 -5
  101. package/elements/switch-indicator-light/word-switch-operator.d.ts +3 -1
  102. package/elements/switch-indicator-light/word-switch-operator.js +9 -2
  103. package/elements/switch-indicator-light/word-switch-operator.metadata.json +1 -1
  104. package/elements/table/table-element.d.ts +1 -1
  105. package/elements/table/table-element.js +2 -2
  106. package/elements/table/table-element.metadata.json +1 -1
  107. package/elements/vector-graphics/ellipse-element.d.ts +1 -1
  108. package/elements/vector-graphics/ellipse-element.js +2 -2
  109. package/elements/vector-graphics/ellipse-element.metadata.json +1 -1
  110. package/elements/vector-graphics/poly-line-element.d.ts +1 -1
  111. package/elements/vector-graphics/poly-line-element.js +2 -2
  112. package/elements/vector-graphics/poly-line-element.metadata.json +1 -1
  113. package/elements/vector-graphics/polygon-element.d.ts +1 -1
  114. package/elements/vector-graphics/polygon-element.js +2 -2
  115. package/elements/vector-graphics/polygon-element.metadata.json +1 -1
  116. package/elements/vector-graphics/rectangle-element.d.ts +1 -1
  117. package/elements/vector-graphics/rectangle-element.js +2 -2
  118. package/elements/vector-graphics/rectangle-element.metadata.json +1 -1
  119. package/elements/vector-graphics/sector-element.d.ts +1 -1
  120. package/elements/vector-graphics/sector-element.js +2 -2
  121. package/elements/vector-graphics/sector-element.metadata.json +1 -1
  122. package/elements/vector-graphics/straight-line-element.d.ts +1 -1
  123. package/elements/vector-graphics/straight-line-element.js +2 -2
  124. package/elements/vector-graphics/straight-line-element.metadata.json +1 -1
  125. package/elements/video/video-element.d.ts +5 -2
  126. package/elements/video/video-element.js +92 -81
  127. package/elements/video/video-element.metadata.json +1 -1
  128. package/elements/view-operation/view-operation.element.d.ts +1 -1
  129. package/elements/view-operation/view-operation.element.js +2 -2
  130. package/elements/view-operation/view-operation.element.metadata.json +1 -1
  131. package/elements/weather/weater-element.d.ts +1 -1
  132. package/elements/weather/weater-element.js +2 -3
  133. package/elements/weather/weater-element.metadata.json +1 -1
  134. package/gui/gui-context.d.ts +2 -1
  135. package/gui/gui-host.d.ts +1 -1
  136. package/gui/gui-view.d.ts +1 -0
  137. package/gui/gui-view.js +3 -2
  138. package/gui/gui-view.metadata.json +1 -1
  139. package/gui/gui.component.d.ts +3 -0
  140. package/gui/gui.component.js +15 -2
  141. package/gui/gui.component.metadata.json +1 -1
  142. package/localization/localization.service.d.ts +7 -0
  143. package/localization/localization.service.js +8 -1
  144. package/localization/localization.service.metadata.json +1 -1
  145. package/localization/localization.service.zh_CN.js +8 -1
  146. package/localization/localization.service.zh_CN.metadata.json +1 -1
  147. package/modal/write-value/write-value-modal-args.d.ts +4 -1
  148. package/modal/write-value/write-value-modal-args.js +3 -1
  149. package/modal/write-value/write-value-modal-args.metadata.json +1 -1
  150. package/modal/write-value/write-value-modal.component.d.ts +9 -7
  151. package/modal/write-value/write-value-modal.component.html +5 -2
  152. package/modal/write-value/write-value-modal.component.js +39 -22
  153. package/modal/write-value/write-value-modal.component.metadata.json +1 -1
  154. package/model/air-quality/air-quality-info.d.ts +23 -0
  155. package/model/air-quality/air-quality-info.js +4 -0
  156. package/model/air-quality/air-quality-info.metadata.json +1 -0
  157. package/model/air-quality/air-quality.model.d.ts +7 -0
  158. package/model/air-quality/air-quality.model.js +0 -0
  159. package/model/air-quality/air-quality.model.metadata.json +1 -0
  160. package/model/alarm/alarm.model.d.ts +13 -0
  161. package/model/alarm/alarm.model.js +0 -0
  162. package/model/alarm/alarm.model.metadata.json +1 -0
  163. package/model/bar-graph/bar-graph.d.ts +4 -0
  164. package/model/base/readable-model.d.ts +4 -0
  165. package/model/historical-curve/historical-curve-axis-settings.d.ts +7 -0
  166. package/model/historical-curve/historical-curve-axis-settings.js +5 -0
  167. package/model/historical-curve/historical-curve-axis-settings.metadata.json +1 -1
  168. package/model/meter/meter.d.ts +4 -0
  169. package/model/numerical-display/numerical-display.d.ts +1 -0
  170. package/model/ring-graph/ring-graph.model.d.ts +8 -0
  171. package/model/shared/condition/bit-condition-item-observer.d.ts +1 -1
  172. package/model/shared/condition/bit-condition-item-observer.js +4 -4
  173. package/model/shared/condition/condition-items-result-observer.d.ts +1 -1
  174. package/model/shared/condition/condition-items-result-observer.js +3 -3
  175. package/model/shared/condition/word-condition-item-observer.d.ts +1 -1
  176. package/model/shared/condition/word-condition-item-observer.js +11 -11
  177. package/model/shared/dynamic-display/dynamic-display.d.ts +1 -1
  178. package/model/shared/dynamic-display/dynamic-display.js +4 -4
  179. package/model/shared/dynamic-display/dynamic-display.metadata.json +1 -1
  180. package/model/shared/rotation/rotation-behavior.d.ts +1 -1
  181. package/model/shared/rotation/rotation-behavior.js +2 -2
  182. package/model/shared/rotation/rotation-behavior.metadata.json +1 -1
  183. package/model/shared/rotation/rotation-observer.d.ts +2 -1
  184. package/model/shared/rotation/rotation-observer.js +3 -2
  185. package/model/shared/rotation/rotation-observer.metadata.json +1 -1
  186. package/model/shared/translation/translation-behavior.d.ts +1 -1
  187. package/model/shared/translation/translation-behavior.js +3 -3
  188. package/model/shared/translation/translation-behavior.metadata.json +1 -1
  189. package/model/shared/translation/translation-observer.d.ts +1 -1
  190. package/model/shared/translation/translation-observer.js +2 -2
  191. package/model/shared/translation/translation-observer.metadata.json +1 -1
  192. package/model/switch-indicator-light/bit-switch-operation.d.ts +2 -1
  193. package/model/switch-indicator-light/bit-switch-operation.js +1 -0
  194. package/model/switch-indicator-light/bit-switch-operation.metadata.json +1 -1
  195. package/package.json +1 -1
  196. package/remote/communication/variable/remote-variable-communicator.d.ts +7 -2
  197. package/remote/communication/variable/remote-variable-communicator.js +38 -9
  198. package/remote/communication/variable/remote-variable-communicator.metadata.json +1 -1
  199. package/remote/communication/variable/remote-variable-protocol.d.ts +5 -2
  200. package/service/index.d.ts +1 -0
  201. package/service/index.metadata.json +1 -1
  202. package/service/released-variable/index.d.ts +1 -0
  203. package/service/released-variable/index.js +0 -0
  204. package/service/released-variable/index.metadata.json +1 -0
  205. package/service/released-variable/released-variable.service.d.ts +4 -0
  206. package/service/released-variable/released-variable.service.js +0 -0
  207. package/service/released-variable/released-variable.service.metadata.json +1 -0
  208. package/service/weather.service.d.ts +1 -0
  209. package/shared/gui-consts.d.ts +2 -0
  210. package/shared/gui-consts.js +2 -0
  211. package/shared/gui-consts.metadata.json +1 -1
  212. package/utils/data-type/data-type.service.d.ts +4 -7
  213. package/utils/data-type/data-type.service.js +29 -17
  214. package/utils/numerical-operation.service.js +2 -2
@@ -16,7 +16,7 @@ export declare abstract class ConditionalDynamicDisplayElement extends Condition
16
16
  protected rotatedHor: number;
17
17
  protected rotatedVer: number;
18
18
  protected transform: string;
19
- constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore);
19
+ constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, signalRAppId: string);
20
20
  protected initDynamicBehavior(): void;
21
21
  protected getActualSize(): Size;
22
22
  protected getActualLocation(): Point;
@@ -3,8 +3,8 @@ import { DynamicDisplay } from '../../model/shared/dynamic-display/dynamic-displ
3
3
  import { ConditionalDisplayElement } from './conditional-display-element';
4
4
  import { GuiConsts } from '../../shared';
5
5
  export class ConditionalDynamicDisplayElement extends ConditionalDisplayElement {
6
- constructor(element, permissionChecker, variableCommunicator, variableStore) {
7
- super(element, permissionChecker, variableCommunicator, variableStore);
6
+ constructor(element, permissionChecker, variableCommunicator, variableStore, signalRAppId) {
7
+ super(element, permissionChecker, variableCommunicator, variableStore, signalRAppId);
8
8
  this.variableCommunicator = variableCommunicator;
9
9
  this.variableStore = variableStore;
10
10
  this.initDynamicBehavior();
@@ -16,7 +16,7 @@ export class ConditionalDynamicDisplayElement extends ConditionalDisplayElement
16
16
  const strokeWidth = this.model.strokeWidth ? this.model.strokeWidth : 0;
17
17
  this.hor = location.x - Number(strokeWidth) / 2;
18
18
  this.ver = location.y - Number(strokeWidth) / 2;
19
- const behavior = new DynamicDisplay(this.model.dynamicSetting, this.variableCommunicator, this.variableStore, location);
19
+ const behavior = new DynamicDisplay(this.model.dynamicSetting, this.variableCommunicator, this.variableStore, location, this.signalRAppId);
20
20
  behavior.doBehavior.subscribe(result => {
21
21
  if (this.model.angle) {
22
22
  this.ang = Number(this.model.angle);
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"ConditionalDynamicDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-display-element","name":"ConditionalDisplayElement","line":10,"character":63},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":23,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service/permission-checker","name":"PermissionChecker","line":23,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":24,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":25,"character":42}]}],"initDynamicBehavior":[{"__symbolic":"method"}],"getActualSize":[{"__symbolic":"method"}],"getActualLocation":[{"__symbolic":"method"}],"isBold":[{"__symbolic":"method"}],"isItalic":[{"__symbolic":"method"}],"fontFamily":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"ConditionalDynamicDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-display-element","name":"ConditionalDisplayElement","line":10,"character":63},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":23,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service/permission-checker","name":"PermissionChecker","line":23,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":24,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":25,"character":42},{"__symbolic":"reference","name":"string"}]}],"initDynamicBehavior":[{"__symbolic":"method"}],"getActualSize":[{"__symbolic":"method"}],"getActualLocation":[{"__symbolic":"method"}],"isBold":[{"__symbolic":"method"}],"isItalic":[{"__symbolic":"method"}],"fontFamily":[{"__symbolic":"method"}]}}}}]
@@ -12,7 +12,7 @@ export declare abstract class ConditionalEnableElement extends StateControlEleme
12
12
  protected abstract readonly model: ConditionalEnableModel;
13
13
  isGrantedPermission: boolean;
14
14
  isInitialized: boolean;
15
- constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization);
15
+ constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization, signalRAppId: string);
16
16
  private initialize;
17
17
  private updateEnableStateByConditionAndPermission;
18
18
  private updateEnableStateByCondition;
@@ -1,8 +1,8 @@
1
1
  import { ConditionItemsResultObserver } from '../../model';
2
2
  import { StateControlElement } from './state-control-element';
3
3
  export class ConditionalEnableElement extends StateControlElement {
4
- constructor(element, permissionChecker, variableCommunicator, variableStore, localization) {
5
- super(element, permissionChecker, variableCommunicator, variableStore, localization);
4
+ constructor(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId) {
5
+ super(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId);
6
6
  this.permissionChecker = permissionChecker;
7
7
  this.variableCommunicator = variableCommunicator;
8
8
  this.variableStore = variableStore;
@@ -68,7 +68,7 @@ export class ConditionalEnableElement extends StateControlElement {
68
68
  this.isInitialized = true;
69
69
  this.changeStates();
70
70
  });
71
- enableConditionResult.requestData();
71
+ enableConditionResult.requestData(this.signalRAppId);
72
72
  }
73
73
  updateEnableStateByCondition() {
74
74
  if (null == this.model.enableItems || !this.model.enableItems.length) {
@@ -81,7 +81,7 @@ export class ConditionalEnableElement extends StateControlElement {
81
81
  this.isInitialized = true;
82
82
  this.changeStates();
83
83
  });
84
- enableConditionResult.requestData();
84
+ enableConditionResult.requestData(this.signalRAppId);
85
85
  }
86
86
  updateEnableStateByPermission() {
87
87
  let isEnable = false;
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"ConditionalEnableElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./state-control-element","name":"StateControlElement","line":7,"character":55},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":14,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":15,"character":46},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":16,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":17,"character":42},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":18,"character":41}]}],"initialize":[{"__symbolic":"method"}],"updateEnableStateByConditionAndPermission":[{"__symbolic":"method"}],"updateEnableStateByCondition":[{"__symbolic":"method"}],"updateEnableStateByPermission":[{"__symbolic":"method"}],"setEnableByConditionOrPermission":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"ConditionalEnableElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./state-control-element","name":"StateControlElement","line":7,"character":55},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":14,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":15,"character":46},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":16,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":17,"character":42},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":18,"character":41},{"__symbolic":"reference","name":"string"}]}],"initialize":[{"__symbolic":"method"}],"updateEnableStateByConditionAndPermission":[{"__symbolic":"method"}],"updateEnableStateByCondition":[{"__symbolic":"method"}],"updateEnableStateByPermission":[{"__symbolic":"method"}],"setEnableByConditionOrPermission":[{"__symbolic":"method"}]}}}}]
@@ -6,10 +6,15 @@ import { Localization } from '../../localization';
6
6
  import { VariableStore } from '../../config';
7
7
  export declare abstract class ReadableElement extends ConditionalEnableElement {
8
8
  protected abstract model: ReadableModel;
9
- constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization);
9
+ constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization, signalRAppId: string);
10
10
  init(variableName: string): void;
11
11
  get readVariableName(): string;
12
- protected abstract updateVariableValue(value: any): void;
12
+ get minVariableName(): string;
13
+ get minValueType(): any;
14
+ get maxVariableName(): string;
15
+ get maxValueType(): any;
16
+ private getVariableName;
17
+ protected abstract updateVariableValue(value: any, variableName: any): void;
13
18
  reportStateChanged(variableState: VariableState): void;
14
19
  reportValueChanged(value: VariableValue): void;
15
20
  }
@@ -4,8 +4,8 @@ import { ConditionalEnableElement } from './conditional-enable-element';
4
4
  import { forEach } from 'lodash';
5
5
  import { VariableUtil } from '../../utils/variable-util';
6
6
  export class ReadableElement extends ConditionalEnableElement {
7
- constructor(element, permissionChecker, variableCommunicator, variableStore, localization) {
8
- super(element, permissionChecker, variableCommunicator, variableStore, localization);
7
+ constructor(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId) {
8
+ super(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId);
9
9
  }
10
10
  init(variableName) {
11
11
  if (variableName) {
@@ -36,6 +36,33 @@ export class ReadableElement extends ConditionalEnableElement {
36
36
  return VariableUtil.getConvertedVariableName(this.variableStore, variable);
37
37
  }
38
38
  }
39
+ get minVariableName() {
40
+ if (!this.model.minValueType) {
41
+ return undefined;
42
+ }
43
+ return this.getVariableName(this.model.minVariable);
44
+ }
45
+ get minValueType() {
46
+ return this.model.minValueType;
47
+ }
48
+ get maxVariableName() {
49
+ if (!this.model.maxValueType) {
50
+ return undefined;
51
+ }
52
+ return this.getVariableName(this.model.maxVariable);
53
+ }
54
+ get maxValueType() {
55
+ return this.model.maxValueType;
56
+ }
57
+ getVariableName(variable) {
58
+ if (!this.model) {
59
+ throw new Error('Model cannot be null');
60
+ }
61
+ if (!variable) {
62
+ return undefined;
63
+ }
64
+ return VariableUtil.getConvertedVariableName(this.variableStore, variable);
65
+ }
39
66
  reportStateChanged(variableState) {
40
67
  forEach(this.elementStates, elementState => {
41
68
  if (elementState.variableName === variableState.variableName) {
@@ -51,8 +78,10 @@ export class ReadableElement extends ConditionalEnableElement {
51
78
  this.changeStates();
52
79
  }
53
80
  });
54
- if (this.state === State.Normal || this.state === State.Disable) {
55
- this.updateVariableValue(value.value);
81
+ if (this.state === State.Normal || this.state === State.Disable
82
+ || value.variableName === this.minVariableName
83
+ || value.variableName === this.maxVariableName) {
84
+ this.updateVariableValue(value.value, value.variableName);
56
85
  }
57
86
  }
58
87
  }
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"ReadableElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-enable-element","name":"ConditionalEnableElement","line":9,"character":46},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":13,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":13,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":13,"character":98},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":14,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":14,"character":52}]}],"init":[{"__symbolic":"method"}],"updateVariableValue":[{"__symbolic":"method"}],"reportStateChanged":[{"__symbolic":"method"}],"reportValueChanged":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"ReadableElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-enable-element","name":"ConditionalEnableElement","line":9,"character":46},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":13,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":13,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":13,"character":98},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":14,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":14,"character":52},{"__symbolic":"reference","name":"string"}]}],"init":[{"__symbolic":"method"}],"getVariableName":[{"__symbolic":"method"}],"updateVariableValue":[{"__symbolic":"method"}],"reportStateChanged":[{"__symbolic":"method"}],"reportValueChanged":[{"__symbolic":"method"}]}}}}]
@@ -11,7 +11,7 @@ export declare abstract class StateControlElement extends ConditionalDynamicDisp
11
11
  state: State;
12
12
  private currentRect;
13
13
  preState: State;
14
- constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization);
14
+ constructor(element: HTMLElement, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, localization: Localization, signalRAppId: string);
15
15
  initState(): void;
16
16
  updateElementStates(newElementStates: VariableState[]): void;
17
17
  addElementState(newElementState: VariableState): void;
@@ -3,8 +3,8 @@ import { VariableStateEnum } from '../../communication';
3
3
  import { ConditionalDynamicDisplayElement } from './conditional-dynamic-display-element';
4
4
  import { State } from '../../model';
5
5
  export class StateControlElement extends ConditionalDynamicDisplayElement {
6
- constructor(element, permissionChecker, variableCommunicator, variableStore, localization) {
7
- super(element, permissionChecker, variableCommunicator, variableStore);
6
+ constructor(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId) {
7
+ super(element, permissionChecker, variableCommunicator, variableStore, signalRAppId);
8
8
  this.localization = localization;
9
9
  this.isEnable = true;
10
10
  this.elementStates = [];
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"StateControlElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-dynamic-display-element","name":"ConditionalDynamicDisplayElement","line":8,"character":50},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":16,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":16,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":16,"character":98},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":17,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":17,"character":71}]}],"initState":[{"__symbolic":"method"}],"updateElementStates":[{"__symbolic":"method"}],"addElementState":[{"__symbolic":"method"}],"changeStates":[{"__symbolic":"method"}],"getState":[{"__symbolic":"method"}],"changeState":[{"__symbolic":"method"}],"loadStateData":[{"__symbolic":"method"}],"setState":[{"__symbolic":"method"}],"clearTip":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"StateControlElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"./conditional-dynamic-display-element","name":"ConditionalDynamicDisplayElement","line":8,"character":50},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":16,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":16,"character":57},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":16,"character":98},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":17,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":17,"character":71},{"__symbolic":"reference","name":"string"}]}],"initState":[{"__symbolic":"method"}],"updateElementStates":[{"__symbolic":"method"}],"addElementState":[{"__symbolic":"method"}],"changeStates":[{"__symbolic":"method"}],"getState":[{"__symbolic":"method"}],"changeState":[{"__symbolic":"method"}],"loadStateData":[{"__symbolic":"method"}],"setState":[{"__symbolic":"method"}],"clearTip":[{"__symbolic":"method"}]}}}}]
@@ -17,7 +17,7 @@ export declare class CharacterDisplayElement extends ReadableElement {
17
17
  private displayValue;
18
18
  private graphs;
19
19
  private readonly logger;
20
- constructor(element: HTMLElement, injector: Injector, modalService: BsModalService, variableCommunicator: VariableCommunicator, graphStore: GraphStore, permissionChecker: PermissionChecker, operationRecordService: OperationRecordService, securityChecker: SecurityChecker, variableStore: VariableStore, localization: Localization);
20
+ constructor(element: HTMLElement, injector: Injector, modalService: BsModalService, variableCommunicator: VariableCommunicator, graphStore: GraphStore, permissionChecker: PermissionChecker, operationRecordService: OperationRecordService, securityChecker: SecurityChecker, variableStore: VariableStore, localization: Localization, signalRAppId: string);
21
21
  get readVariableName(): string;
22
22
  get writeVariableName(): string;
23
23
  protected updateVariableValue(value: string): void;
@@ -11,8 +11,8 @@ import { VerifyPasswordModalComponent } from '../../modal/verify-password/verify
11
11
  import { VariableUtil } from '../../utils/variable-util';
12
12
  import { TextElementModal } from '../shared/text/text-element';
13
13
  export class CharacterDisplayElement extends ReadableElement {
14
- constructor(element, injector, modalService, variableCommunicator, graphStore, permissionChecker, operationRecordService, securityChecker, variableStore, localization) {
15
- super(element, permissionChecker, variableCommunicator, variableStore, localization);
14
+ constructor(element, injector, modalService, variableCommunicator, graphStore, permissionChecker, operationRecordService, securityChecker, variableStore, localization, signalRAppId) {
15
+ super(element, permissionChecker, variableCommunicator, variableStore, localization, signalRAppId);
16
16
  this.modalService = modalService;
17
17
  this.graphStore = graphStore;
18
18
  this.operationRecordService = operationRecordService;
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"CharacterDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/readable-element","name":"ReadableElement","line":19,"character":45},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":28,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":48},{"__symbolic":"reference","module":"ngx-bootstrap/modal","name":"BsModalService","line":29,"character":39},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":30,"character":30},{"__symbolic":"reference","module":"../../config","name":"GraphStore","line":31,"character":37},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":32,"character":27},{"__symbolic":"reference","module":"../../service","name":"OperationRecordService","line":33,"character":49},{"__symbolic":"reference","module":"../../security","name":"SecurityChecker","line":34,"character":42},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":35,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":36,"character":22}]}],"updateVariableValue":[{"__symbolic":"method"}],"changeStates":[{"__symbolic":"method"}],"updateDisplayValue":[{"__symbolic":"method"}],"getVariableValueText":[{"__symbolic":"method"}],"characterDisplayText":[{"__symbolic":"method"}],"initElement":[{"__symbolic":"method"}],"initVariableText":[{"__symbolic":"method"}],"initClickEvent":[{"__symbolic":"method"}],"checkElementPassword":[{"__symbolic":"method"}],"doWriteCharacterValue":[{"__symbolic":"method"}],"recordOperation":[{"__symbolic":"method"}],"changeGraph":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"CharacterDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/readable-element","name":"ReadableElement","line":19,"character":45},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":28,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":48},{"__symbolic":"reference","module":"ngx-bootstrap/modal","name":"BsModalService","line":29,"character":39},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":30,"character":30},{"__symbolic":"reference","module":"../../config","name":"GraphStore","line":31,"character":37},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":32,"character":27},{"__symbolic":"reference","module":"../../service","name":"OperationRecordService","line":33,"character":49},{"__symbolic":"reference","module":"../../security","name":"SecurityChecker","line":34,"character":42},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":35,"character":23},{"__symbolic":"reference","module":"../../localization","name":"Localization","line":36,"character":22},{"__symbolic":"reference","name":"string"}]}],"updateVariableValue":[{"__symbolic":"method"}],"changeStates":[{"__symbolic":"method"}],"updateDisplayValue":[{"__symbolic":"method"}],"getVariableValueText":[{"__symbolic":"method"}],"characterDisplayText":[{"__symbolic":"method"}],"initElement":[{"__symbolic":"method"}],"initVariableText":[{"__symbolic":"method"}],"initClickEvent":[{"__symbolic":"method"}],"checkElementPassword":[{"__symbolic":"method"}],"doWriteCharacterValue":[{"__symbolic":"method"}],"recordOperation":[{"__symbolic":"method"}],"changeGraph":[{"__symbolic":"method"}]}}}}]
@@ -13,7 +13,7 @@ export declare class DatetimeDisplayElement extends ConditionalDisplayElement {
13
13
  protected readonly model: DatetimeDisplay;
14
14
  protected readonly logger: LoggerService;
15
15
  private readonly $dateTimeText;
16
- constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, graphStore: GraphStore);
16
+ constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, graphStore: GraphStore, signalRAppId: string);
17
17
  private getAndSetCurrentTime;
18
18
  private getDatetimeFormat;
19
19
  private initGraph;
@@ -6,8 +6,8 @@ import { ConditionalDisplayElement } from '../base/conditional-display-element';
6
6
  import { GraphStateElement } from '../shared/graph/graph-state-element';
7
7
  import { LOGGER_SERVICE_TOKEN } from '../../logger';
8
8
  export class DatetimeDisplayElement extends ConditionalDisplayElement {
9
- constructor(element, injector, permissionChecker, variableCommunicator, variableStore, graphStore) {
10
- super(element, permissionChecker, variableCommunicator, variableStore);
9
+ constructor(element, injector, permissionChecker, variableCommunicator, variableStore, graphStore, signalRAppId) {
10
+ super(element, permissionChecker, variableCommunicator, variableStore, signalRAppId);
11
11
  this.permissionChecker = permissionChecker;
12
12
  this.variableCommunicator = variableCommunicator;
13
13
  this.variableStore = variableStore;
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"DatetimeDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":14,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":21,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":21,"character":48},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":22,"character":46},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":23,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":24,"character":42},{"__symbolic":"reference","module":"../../config","name":"GraphStore","line":25,"character":37}]}],"getAndSetCurrentTime":[{"__symbolic":"method"}],"getDatetimeFormat":[{"__symbolic":"method"}],"initGraph":[{"__symbolic":"method"}],"getFormat":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"DatetimeDisplayElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":14,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":21,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":21,"character":48},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":22,"character":46},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":23,"character":49},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":24,"character":42},{"__symbolic":"reference","module":"../../config","name":"GraphStore","line":25,"character":37},{"__symbolic":"reference","name":"string"}]}],"getAndSetCurrentTime":[{"__symbolic":"method"}],"getDatetimeFormat":[{"__symbolic":"method"}],"initGraph":[{"__symbolic":"method"}],"getFormat":[{"__symbolic":"method"}]}}}}]
@@ -32,7 +32,7 @@ export declare class HistoricalCurveElement extends ConditionalDisplayElement {
32
32
  private elementStatus;
33
33
  private chartElement;
34
34
  private isMobileMode;
35
- constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, historyDataStore: HistoryDataStore);
35
+ constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, historyDataStore: HistoryDataStore, signalRAppId: string);
36
36
  dispose(): void;
37
37
  private getValidTimePeriods;
38
38
  private updateTimeRange;
@@ -10,9 +10,10 @@ import { HistoricalCurveElementStatus } from './historical-curve-element-status'
10
10
  import { LOGGER_SERVICE_TOKEN } from '../../logger';
11
11
  import { GlobalSettings, DisplayMode } from '../../settings';
12
12
  import { CurveType } from '../../model/historical-curve/curve-type';
13
+ import { AxisRangeType } from '../../model/historical-curve/historical-curve-axis-settings';
13
14
  export class HistoricalCurveElement extends ConditionalDisplayElement {
14
- constructor(element, injector, permissionChecker, variableCommunicator, variableStore, historyDataStore) {
15
- super(element, permissionChecker, variableCommunicator, variableStore);
15
+ constructor(element, injector, permissionChecker, variableCommunicator, variableStore, historyDataStore, signalRAppId) {
16
+ super(element, permissionChecker, variableCommunicator, variableStore, signalRAppId);
16
17
  this.historyDataStore = historyDataStore;
17
18
  this.displayOption = {
18
19
  dataLimit: 500,
@@ -21,7 +22,7 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
21
22
  marginRight: 20,
22
23
  mobileMinWidth: 450,
23
24
  operationAreaHeight: 32,
24
- operationAreaMarginTop: 10,
25
+ operationAreaMarginTop: 25,
25
26
  operationSelectFontSize: '16px',
26
27
  operationButtonWidth: 24,
27
28
  operationButtonHeight: 24,
@@ -38,7 +39,7 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
38
39
  }, this.model.displaySetting.refreshInterval * 1000);
39
40
  this.isMobileMode = DisplayMode.Mobile === injector.get(GlobalSettings).displayMode;
40
41
  if (this.isMobileMode) {
41
- this.displayOption.operationAreaMarginTop = 20;
42
+ this.displayOption.operationAreaMarginTop = 35;
42
43
  if (this.model.displaySetting.size.width >= this.displayOption.mobileMinWidth) {
43
44
  this.displayOption.operationAreaHeight = 68;
44
45
  this.displayOption.operationSelectFontSize = '24px';
@@ -58,7 +59,9 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
58
59
  }
59
60
  getValidTimePeriods() {
60
61
  const timePeriods = new Array();
62
+ timePeriods.push({ key: 6, name: this.localization.lastThirtyMinutes });
61
63
  timePeriods.push({ key: 1, name: this.localization.lastOneHour });
64
+ timePeriods.push({ key: 7, name: this.localization.lastEightHour });
62
65
  timePeriods.push({ key: 2, name: this.localization.lastTwentyFourHours });
63
66
  timePeriods.push({ key: 3, name: this.localization.lastSevenDays });
64
67
  timePeriods.push({ key: 4, name: this.localization.lastThirtyDays });
@@ -84,6 +87,12 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
84
87
  case 5:
85
88
  this.startTime = moment().subtract(1, 'years');
86
89
  break;
90
+ case 6:
91
+ this.startTime = moment().subtract(30, 'minutes');
92
+ break;
93
+ case 7:
94
+ this.startTime = moment().subtract(8, 'hours');
95
+ break;
87
96
  default:
88
97
  this.startTime = moment().subtract(1, 'days');
89
98
  }
@@ -144,6 +153,9 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
144
153
  const chart = nv.models.lineChart().showLegend(true)
145
154
  .margin({ top: 0, bottom: 0, left: this.displayOption.marginLeft, right: this.displayOption.marginRight })
146
155
  .noData(this.localization.chartNoData);
156
+ if (this.model.displaySetting.axisSetting.yAxisRangeType === AxisRangeType.Custom) {
157
+ chart.yDomain([this.model.displaySetting.axisSetting.yAxisMin, this.model.displaySetting.axisSetting.yAxisMax]);
158
+ }
147
159
  if (!this.isMobileMode) {
148
160
  chart.focusEnable(true);
149
161
  chart.focus.margin({ top: 10, right: 0, bottom: 0, left: 0 });
@@ -151,10 +163,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
151
163
  chart.focus.showXAxis(false);
152
164
  }
153
165
  this.renderCommonProperty(chart, chartWidth, chartHeight, data);
154
- // if in Mobile mode and width is less than the min width, then hide operation area
155
- if (this.isMobileMode && this.model.displaySetting.size.width < this.displayOption.mobileMinWidth) {
156
- return chart;
157
- }
158
166
  this.renderOperationArea(chartWidth, chartHeight);
159
167
  return chart;
160
168
  }
@@ -172,16 +180,15 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
172
180
  chart.multibar.stacked(true);
173
181
  chart.multibar2.stacked(true);
174
182
  }
183
+ if (this.model.displaySetting.axisSetting.yAxisRangeType === AxisRangeType.Custom) {
184
+ chart.yDomain([this.model.displaySetting.axisSetting.yAxisMin, this.model.displaySetting.axisSetting.yAxisMax]);
185
+ }
175
186
  if (!this.isMobileMode) {
176
187
  chart.focusEnable(true);
177
188
  chart.focusShowAxisX(false);
178
189
  }
179
190
  chart.xAxis.tickFormat(d => this.timeFormat(d, '%x %X'));
180
191
  this.renderCommonProperty(chart, chartWidth, chartHeight, data);
181
- // if in Mobile mode and width is less than the min width, then hide operation area
182
- if (this.isMobileMode && this.model.displaySetting.size.width < this.displayOption.mobileMinWidth) {
183
- return chart;
184
- }
185
192
  this.renderOperationArea(chartWidth, chartHeight);
186
193
  const focusContext = this.rootElement.select('.nv-context');
187
194
  focusContext.select('.nv-barsWrap.nvd3-svg').attr('transform', 'translate(0,30)');
@@ -196,9 +203,15 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
196
203
  return chart;
197
204
  }
198
205
  renderCommonProperty(chart, chartWidth, chartHeight, data) {
206
+ var _a, _b;
199
207
  chart.tooltip.headerFormatter(d => this.timeFormat(d, '%x %X'));
200
208
  if (this.model.displaySetting.showAxis) {
201
- chart.xAxis.showMaxMin(true).tickFormat(d => this.timeFormat(d, '%X'));
209
+ chart.xAxis.showMaxMin(true).tickFormat(d => {
210
+ if (this.currentTimePeriod === 3 || this.currentTimePeriod === 4 || this.currentTimePeriod === 5) {
211
+ return this.timeFormat(d, '%y-%m-%d');
212
+ }
213
+ return this.timeFormat(Number(d), '%X');
214
+ });
202
215
  if (this.model.displaySetting.axisSetting) {
203
216
  if (this.model.displaySetting.axisSetting.showAxisLabel && this.model.displaySetting.axisSetting.axisLabelFont) {
204
217
  chart.xAxis.fontSize(this.model.displaySetting.axisSetting.axisLabelFont.fontSize);
@@ -223,15 +236,91 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
223
236
  chart.update();
224
237
  this.rootElement.selectAll('.nv-noData').attr('x', chartWidth / 2).attr('y', chartHeight / 2 + this.displayOption.operationAreaHeight);
225
238
  });
239
+ const fontSize = (_b = (_a = this.model.displaySetting.axisSetting) === null || _a === void 0 ? void 0 : _a.axisLabelFont) === null || _b === void 0 ? void 0 : _b.fontSize;
226
240
  this.rootElement.selectAll('.domain').style('stroke-opacity', 1);
227
241
  if (this.model.displaySetting.showAxis && this.model.displaySetting.axisSetting) {
228
242
  const axisColor = this.model.displaySetting.axisSetting.axisColor;
229
243
  this.rootElement.selectAll('.domain').style('stroke', axisColor);
230
- if (this.model.displaySetting.axisSetting.showAxisLabel) {
231
- const fontSize = this.model.displaySetting.axisSetting.axisLabelFont.fontSize;
244
+ if (fontSize && this.model.displaySetting.axisSetting.showAxisLabel) {
232
245
  this.rootElement.selectAll('.nv-axisMaxMin').select('text').style('font-size', fontSize);
233
246
  }
234
247
  }
248
+ if (fontSize && this.currentTimePeriod === 3 || this.currentTimePeriod === 4 || this.currentTimePeriod === 5) {
249
+ const self = this;
250
+ this.rootElement
251
+ .selectAll('.nv-x')
252
+ .selectAll('.tick')
253
+ .selectAll('text')
254
+ .data(function (d) {
255
+ return [self.timeFormat(Number(d), '%y-%m-%d'), self.timeFormat(Number(d), '%H:%M:%S')];
256
+ })
257
+ .enter()
258
+ .append('text')
259
+ .attr('class', 'full-date')
260
+ .attr('x', 0)
261
+ .attr('y', 0)
262
+ .attr('dy', '2.3em')
263
+ .style('text-anchor', 'middle')
264
+ .style('font-size', fontSize)
265
+ .text((d) => d);
266
+ this.rootElement
267
+ .selectAll('.nv-axisMaxMin-x')
268
+ .selectAll('text')
269
+ .data(function (d) {
270
+ return [self.timeFormat(Number(d), '%y-%m-%d'), self.timeFormat(Number(d), '%H:%M:%S')];
271
+ })
272
+ .enter()
273
+ .append('text')
274
+ .attr('class', 'full-date')
275
+ .attr('x', 0)
276
+ .attr('y', 0)
277
+ .attr('dy', '2.3em')
278
+ .style('text-anchor', 'middle')
279
+ .style('font-size', fontSize)
280
+ .text((d) => d);
281
+ const focusWrap = this.rootElement.selectAll('.nv-focusWrap');
282
+ if (focusWrap.size()) {
283
+ let h = focusWrap.attr('transform');
284
+ if (h && h.length && h.indexOf(',') !== -1) {
285
+ h = h.slice(0, -1).split(',')[1];
286
+ this.rootElement
287
+ .selectAll('.nv-focusWrap')
288
+ .attr('transform', `translate(0,${Number(h) + 15})`);
289
+ }
290
+ }
291
+ const resizeObserver = new window.MutationObserver(() => {
292
+ this.rootElement
293
+ .selectAll('.nv-x')
294
+ .selectAll('.tick')
295
+ .selectAll('.full-date')
296
+ .remove();
297
+ this.rootElement
298
+ .selectAll('.nv-x')
299
+ .selectAll('.tick')
300
+ .selectAll('text')
301
+ .data(function (d) {
302
+ return [self.timeFormat(Number(d), '%y-%m-%d'), self.timeFormat(Number(d), '%H:%M:%S')];
303
+ })
304
+ .enter()
305
+ .append('text')
306
+ .attr('class', 'full-date')
307
+ .attr('x', 0)
308
+ .attr('y', 0)
309
+ .attr('dy', '2.3em')
310
+ .style('text-anchor', 'middle')
311
+ .style('font-size', fontSize)
312
+ .text((d) => d);
313
+ });
314
+ const extent = document.getElementsByClassName('extent');
315
+ if (extent.length) {
316
+ resizeObserver.observe(extent[0], { attributes: true });
317
+ }
318
+ }
319
+ else {
320
+ this.rootElement
321
+ .selectAll('.full-date')
322
+ .remove();
323
+ }
235
324
  }
236
325
  renderOperationArea(chartWidth, chartHeight) {
237
326
  const operationArea = this.rootElement.append('g').attr('transform', `translate(0,${chartHeight + this.displayOption.operationAreaMarginTop})`)
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"HistoricalCurveElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":20,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":62,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":63,"character":18},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":64,"character":27},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":65,"character":30},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":66,"character":23},{"__symbolic":"reference","module":"../../config","name":"HistoryDataStore","line":67,"character":43}]}],"dispose":[{"__symbolic":"method"}],"getValidTimePeriods":[{"__symbolic":"method"}],"updateTimeRange":[{"__symbolic":"method"}],"updateQueryTimeRange":[{"__symbolic":"method"}],"reRenderElement":[{"__symbolic":"method"}],"renderElement":[{"__symbolic":"method"}],"renderChart":[{"__symbolic":"method"}],"getLineChart":[{"__symbolic":"method"}],"getMultiBarWithFocusChart":[{"__symbolic":"method"}],"renderCommonProperty":[{"__symbolic":"method"}],"renderOperationArea":[{"__symbolic":"method"}],"timeFormat":[{"__symbolic":"method"}],"loadFirstPage":[{"__symbolic":"method"}],"loadNextPage":[{"__symbolic":"method"}],"loadPreviousPage":[{"__symbolic":"method"}],"loadLastPage":[{"__symbolic":"method"}],"initElementStatus":[{"__symbolic":"method"}],"updateElementStatus":[{"__symbolic":"method"}],"setStatusAsUnbound":[{"__symbolic":"method"}],"setStatusAsLoading":[{"__symbolic":"method"}],"setStatusAsLoadFailed":[{"__symbolic":"method"}],"renderStatus":[{"__symbolic":"method"}],"clearStatus":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"HistoricalCurveElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":21,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":63,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":64,"character":18},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":65,"character":27},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":66,"character":30},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":67,"character":23},{"__symbolic":"reference","module":"../../config","name":"HistoryDataStore","line":68,"character":43},{"__symbolic":"reference","name":"string"}]}],"dispose":[{"__symbolic":"method"}],"getValidTimePeriods":[{"__symbolic":"method"}],"updateTimeRange":[{"__symbolic":"method"}],"updateQueryTimeRange":[{"__symbolic":"method"}],"reRenderElement":[{"__symbolic":"method"}],"renderElement":[{"__symbolic":"method"}],"renderChart":[{"__symbolic":"method"}],"getLineChart":[{"__symbolic":"method"}],"getMultiBarWithFocusChart":[{"__symbolic":"method"}],"renderCommonProperty":[{"__symbolic":"method"}],"renderOperationArea":[{"__symbolic":"method"}],"timeFormat":[{"__symbolic":"method"}],"loadFirstPage":[{"__symbolic":"method"}],"loadNextPage":[{"__symbolic":"method"}],"loadPreviousPage":[{"__symbolic":"method"}],"loadLastPage":[{"__symbolic":"method"}],"initElementStatus":[{"__symbolic":"method"}],"updateElementStatus":[{"__symbolic":"method"}],"setStatusAsUnbound":[{"__symbolic":"method"}],"setStatusAsLoading":[{"__symbolic":"method"}],"setStatusAsLoadFailed":[{"__symbolic":"method"}],"renderStatus":[{"__symbolic":"method"}],"clearStatus":[{"__symbolic":"method"}]}}}}]
@@ -11,6 +11,7 @@ export declare class MainElement {
11
11
  private readonly context;
12
12
  private readonly variableCommunicator;
13
13
  private readonly popupViewService;
14
+ private readonly signalRAppId;
14
15
  private readonly elements;
15
16
  private root;
16
17
  private isLoaded;
@@ -20,7 +21,7 @@ export declare class MainElement {
20
21
  oldSize: Size;
21
22
  private hostContainerId;
22
23
  get rootElement(): HTMLElement;
23
- constructor(injector: Injector, bsModalService: BsModalService, context: GuiContext, variableCommunicator: VariableCommunicator, popupViewService: PopupViewService);
24
+ constructor(injector: Injector, bsModalService: BsModalService, context: GuiContext, variableCommunicator: VariableCommunicator, popupViewService: PopupViewService, signalRAppId: any);
24
25
  load(data: string, overflowVisible: boolean, guiOptions: GuiOptions): void;
25
26
  /**
26
27
  * 保证在显示区域内显示画面所有内容,等比缩放画面大小以铺满整个显示区域