ato-water-lib 0.0.40 → 0.0.42

Sign up to get free protection for your applications and to get access to all the features.
@@ -2,7 +2,7 @@ import { Component, EventEmitter, HostListener, Input, Output, ViewChild, } from
2
2
  import * as go from 'gojs';
3
3
  import _ from 'lodash';
4
4
  import { AtoGoJSBase64 } from '../../constants/base64.const';
5
- import { ATO_ASSET_LAYERS, ATO_COMPONENTS_GROUP_DATA } from '../../constants/components-group-const';
5
+ import { ATO_ASSET_LAYERS, ATO_COMPONENTS_GROUP_DATA, } from '../../constants/components-group-const';
6
6
  import { AtoGojsEditorModel } from '../../models/gojs-editor.model';
7
7
  import { AtoAssetParamsViewComponent } from '../asset-params-view/asset-params-view.component';
8
8
  import { AtoFlowDiagramLibComponent } from '../flow-diagram-lib/flow-diagram-lib.component';
@@ -42,8 +42,7 @@ export class AssetFlowComponent {
42
42
  }, 1000);
43
43
  }
44
44
  checkResponsiveView() {
45
- if (this?.systemType ===
46
- AtoGojsEditorModel.ENUM_TYPES.COOLING_TOWER) {
45
+ if (this?.systemType === AtoGojsEditorModel.ENUM_TYPES.COOLING_TOWER) {
47
46
  this.isResponsiveView = window.innerWidth < 1024;
48
47
  }
49
48
  else {
@@ -55,7 +54,7 @@ export class AssetFlowComponent {
55
54
  this.flowData = AssetFlowComponent.getDefaultFlowData({
56
55
  systemType: this.systemType,
57
56
  isUseBase64: this.isUseBase64,
58
- assetLayer: this.assetLayer
57
+ assetLayer: this.assetLayer,
59
58
  });
60
59
  }
61
60
  _.forEach(this.flowData?.nodeDataArray, (node) => {
@@ -80,9 +79,14 @@ export class AssetFlowComponent {
80
79
  // Reponsive
81
80
  _.forEach(flowData?.nodeDataArray, (node) => {
82
81
  node = _.merge(node, node[`extendedData${window.innerWidth < 1024 ? 'Responsive' : ''}`]);
82
+ if (node?.assetLayers) {
83
+ node.visible =
84
+ node?.assetLayers ===
85
+ (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW);
86
+ }
83
87
  });
84
88
  // assetLayer
85
- flowData.nodeDataArray = _.filter(flowData.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW)));
89
+ // flowData.nodeDataArray = _.filter(flowData.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW)))
86
90
  if (defaultData?.isUseBase64) {
87
91
  const itemImageTemp = flowData?.nodeDataArray?.find((x) => x?.type === 'Image Template');
88
92
  if (itemImageTemp) {
@@ -93,9 +97,9 @@ export class AssetFlowComponent {
93
97
  }
94
98
  setFlowData(data) {
95
99
  // const layer = data?.assetLayer ?? this?.assetLayer ?? ATO_ASSET_LAYERS.FLOW;
96
- _.forEach(data.nodeDataArray, node => {
100
+ _.forEach(data.nodeDataArray, (node) => {
97
101
  if (node?.assetLayers) {
98
- node.visible = node?.assetLayers === this.assetLayer;
102
+ node.visible = node?.assetLayers === data.assetLayer;
99
103
  }
100
104
  });
101
105
  this.flowData = {
@@ -105,9 +109,10 @@ export class AssetFlowComponent {
105
109
  this.updateDataTableAssetParams(data);
106
110
  }
107
111
  updateDataTableAssetParams(data) {
108
- this.dataTableAssetParams = _.forEach(this.flowData?.nodeDataArray?.filter((e) => e?.type === AtoGojsEditorModel.ENUM_TEMPLATES.PARAM_TABLE && e?.assetLayers === data?.assetLayer), x => {
112
+ this.dataTableAssetParams = _.forEach(this.flowData?.nodeDataArray?.filter((e) => e?.type === AtoGojsEditorModel.ENUM_TEMPLATES.PARAM_TABLE &&
113
+ e?.assetLayers === data?.assetLayer), (x) => {
109
114
  if (!data?.isRefresh) {
110
- x.isCollapsed = this.assetParamsViewTemp?.data?.find(y => y?.key === x?.key)?.isCollapsed;
115
+ x.isCollapsed = this.assetParamsViewTemp?.data?.find((y) => y?.key === x?.key)?.isCollapsed;
111
116
  }
112
117
  });
113
118
  }
@@ -143,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
143
148
  type: HostListener,
144
149
  args: ['window:resize', ['$event']]
145
150
  }] } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-flow.component.js","sourceRoot":"","sources":["../../../../../../projects/ato-water-lib/src/lib/components/asset-flow/asset-flow.component.ts","../../../../../../projects/ato-water-lib/src/lib/components/asset-flow/asset-flow.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport * as go from 'gojs';\nimport _ from 'lodash';\nimport { AtoGoJSBase64 } from '../../constants/base64.const';\nimport { ATO_ASSET_LAYERS, ATO_COMPONENTS_GROUP_DATA } from '../../constants/components-group-const';\nimport { AtoDefaultFlowData } from '../../models/ato-asset-flow.model';\nimport { AtoGoJSData } from '../../models/gojs-data.model';\nimport { AtoGojsEditorModel } from '../../models/gojs-editor.model';\nimport { AtoAssetParamsViewComponent } from '../asset-params-view/asset-params-view.component';\nimport { AtoFlowDiagramLibComponent } from '../flow-diagram-lib/flow-diagram-lib.component';\n\n@Component({\n  selector: 'ato-asset-flow',\n  templateUrl: './asset-flow.component.html',\n  styleUrls: ['./asset-flow.component.scss'],\n})\nexport class AssetFlowComponent implements OnInit {\n  @Input() assetLayer: ATO_ASSET_LAYERS;\n  @ViewChild(AtoFlowDiagramLibComponent)\n  gjFlowDiagramTemp: AtoFlowDiagramLibComponent;\n  @ViewChild(AtoAssetParamsViewComponent)\n  assetParamsViewTemp: AtoAssetParamsViewComponent;\n  @Input() selectedComponent: any;\n  @Input() systemType: AtoGojsEditorModel.ENUM_TYPES;\n  @Output() onClickParamOfTableEvent: EventEmitter<any> =\n    new EventEmitter<any>();\n  @Input() isUseBase64 = false;\n  $ = go.GraphObject.make;\n  options = {\n    layout: this.$(go.LayeredDigraphLayout, {\n      // direction: 0,\n    }),\n    // isReadOnly: true,\n  };\n\n  private _flowData: any;\n  @Input() set flowData(v: AtoGoJSData) {\n    this._flowData = v;\n    this.updateDataTableAssetParams({...v, assetLayer: this.assetLayer});\n  }\n  get flowData(): AtoGoJSData {\n    return this._flowData;\n}\n\n  // Reponsive\n  dataTableAssetParams: any[];\n  @Input() isResponsiveView = false;\n  @Input() getFlowDataCallBack: Function;\n\n  timeoutResizeWindow;\n  @HostListener('window:resize', ['$event'])\n  onResize(event: Event): void {\n    // Now only Support Cooling Tower Responsive\n    if (this.timeoutResizeWindow) {\n      clearTimeout(this.timeoutResizeWindow);\n    }\n    this.timeoutResizeWindow = setTimeout(() => {\n      this.checkResponsiveView();\n      this.updateLocationReponsive();\n    }, 1000);\n  }\n\n  checkResponsiveView() {\n    if (\n      this?.systemType ===\n      AtoGojsEditorModel.ENUM_TYPES.COOLING_TOWER\n    ) {\n      this.isResponsiveView = window.innerWidth < 1024;\n    } else {\n      this.isResponsiveView = false;\n    }\n  }\n\n  updateLocationReponsive() {\n    if (!this.flowData?.nodeDataArray) {\n      this.flowData = AssetFlowComponent.getDefaultFlowData({\n        systemType: this.systemType, \n        isUseBase64: this.isUseBase64,\n        assetLayer: this.assetLayer\n      });\n    }\n    _.forEach(\n      this.flowData?.nodeDataArray,\n      (node: any) => {\n        node = _.merge(node, node[`extendedData${this.isResponsiveView ? 'Responsive' : ''}`]);\n      }\n    );\n    this.setFlowData(_.cloneDeep(this.flowData));\n  }\n\n  ngOnInit() {\n    this.checkResponsiveView();\n    this.updateLocationReponsive();\n  }\n  onClickParamOfTable($event: any) {\n    this.onClickParamOfTableEvent.emit($event);\n  }\n\n  static getDefaultFlowData(defaultData: AtoDefaultFlowData) {\n    const flowData = {\n      ...defaultData,\n      ..._.cloneDeep(ATO_COMPONENTS_GROUP_DATA)[\n        defaultData?.systemType\n      ],\n      linkFromPortIdProperty: 'fromPort',\n      linkToPortIdProperty: 'toPort',\n    };\n    // Reponsive\n    _.forEach(\n      flowData?.nodeDataArray,\n      (node: any) => {\n        node = _.merge(node, node[`extendedData${window.innerWidth < 1024 ? 'Responsive' : ''}`]);\n      }\n    );\n    // assetLayer\n    flowData.nodeDataArray = _.filter(flowData.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW)))\n    if (defaultData?.isUseBase64) {\n      const itemImageTemp = (flowData as AtoGoJSData)?.nodeDataArray?.find(\n        (x) => x?.type === 'Image Template'\n      );\n      if (itemImageTemp) {\n        itemImageTemp.source = AtoGoJSBase64[defaultData?.systemType];\n      }\n    }\n    return flowData;\n  }\n\n  setFlowData(data: AtoGoJSData) {\n    // const layer = data?.assetLayer ?? this?.assetLayer ?? ATO_ASSET_LAYERS.FLOW;\n    _.forEach(data.nodeDataArray, node => {\n      if (node?.assetLayers) {\n          node.visible = node?.assetLayers === this.assetLayer;\n      }\n    })\n    this.flowData = { \n      ...data,\n      // nodeDataArray: _.filter(data.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === data?.assetLayer))\n    };\n    this.updateDataTableAssetParams(data);\n  }\n\n  updateDataTableAssetParams(data: AtoGoJSData) {\n    this.dataTableAssetParams = _.forEach(\n      this.flowData?.nodeDataArray?.filter(\n        (e) => e?.type === AtoGojsEditorModel.ENUM_TEMPLATES.PARAM_TABLE && e?.assetLayers === data?.assetLayer\n      ), x => {\n        if (!data?.isRefresh) {\n          x.isCollapsed = this.assetParamsViewTemp?.data?.find(y => y?.key === x?.key)?.isCollapsed;\n        }\n      }\n    );\n  }\n}\n","<div class=\"h-100 d-flex flex-column flex-gap-3 flex-grow-1 overflow-auto px-3 pb-3\">\n  <div class=\"h-100 d-flex flex-column\" atoLoading [appLoading]=\"flowData === null\">\n    <ato-flow-diagram-lib\n      *ngIf=\"flowData !== null\"\n      #gjFlowDiagramTemp\n      [data]=\"flowData\"\n      [initialOptions]=\"options\"\n      (onClikParamOfTable)=\"onClickParamOfTable($event)\"\n      [class]=\"!!isResponsiveView ? 'diagram-responsive-view' : 'flex-grow-1'\"\n    ></ato-flow-diagram-lib>\n    <div class=\"mt-2\" *ngIf=\"isResponsiveView\">\n      <ato-asset-params-view\n        #assetParamsViewTemp\n        [data]=\"dataTableAssetParams\"\n        [isEditView]=\"true\"\n        (clickParamTableRow)=\"onClickParamOfTable($event)\"\n      ></ato-asset-params-view>\n    </div>\n  </div>\n</div>\n\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-flow.component.js","sourceRoot":"","sources":["../../../../../../projects/ato-water-lib/src/lib/components/asset-flow/asset-flow.component.ts","../../../../../../projects/ato-water-lib/src/lib/components/asset-flow/asset-flow.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport * as go from 'gojs';\nimport _ from 'lodash';\nimport { AtoGoJSBase64 } from '../../constants/base64.const';\nimport {\n  ATO_ASSET_LAYERS,\n  ATO_COMPONENTS_GROUP_DATA,\n} from '../../constants/components-group-const';\nimport { AtoDefaultFlowData } from '../../models/ato-asset-flow.model';\nimport { AtoGoJSData } from '../../models/gojs-data.model';\nimport { AtoGojsEditorModel } from '../../models/gojs-editor.model';\nimport { AtoAssetParamsViewComponent } from '../asset-params-view/asset-params-view.component';\nimport { AtoFlowDiagramLibComponent } from '../flow-diagram-lib/flow-diagram-lib.component';\n\n@Component({\n  selector: 'ato-asset-flow',\n  templateUrl: './asset-flow.component.html',\n  styleUrls: ['./asset-flow.component.scss'],\n})\nexport class AssetFlowComponent implements OnInit {\n  @Input() assetLayer: ATO_ASSET_LAYERS;\n  @ViewChild(AtoFlowDiagramLibComponent)\n  gjFlowDiagramTemp: AtoFlowDiagramLibComponent;\n  @ViewChild(AtoAssetParamsViewComponent)\n  assetParamsViewTemp: AtoAssetParamsViewComponent;\n  @Input() selectedComponent: any;\n  @Input() systemType: AtoGojsEditorModel.ENUM_TYPES;\n  @Output() onClickParamOfTableEvent: EventEmitter<any> =\n    new EventEmitter<any>();\n  @Input() isUseBase64 = false;\n  $ = go.GraphObject.make;\n  options = {\n    layout: this.$(go.LayeredDigraphLayout, {\n      // direction: 0,\n    }),\n    // isReadOnly: true,\n  };\n\n  private _flowData: any;\n  @Input() set flowData(v: AtoGoJSData) {\n    this._flowData = v;\n    this.updateDataTableAssetParams({ ...v, assetLayer: this.assetLayer });\n  }\n  get flowData(): AtoGoJSData {\n    return this._flowData;\n  }\n\n  // Reponsive\n  dataTableAssetParams: any[];\n  @Input() isResponsiveView = false;\n  @Input() getFlowDataCallBack: Function;\n\n  timeoutResizeWindow;\n  @HostListener('window:resize', ['$event'])\n  onResize(event: Event): void {\n    // Now only Support Cooling Tower Responsive\n    if (this.timeoutResizeWindow) {\n      clearTimeout(this.timeoutResizeWindow);\n    }\n    this.timeoutResizeWindow = setTimeout(() => {\n      this.checkResponsiveView();\n      this.updateLocationReponsive();\n    }, 1000);\n  }\n\n  checkResponsiveView() {\n    if (this?.systemType === AtoGojsEditorModel.ENUM_TYPES.COOLING_TOWER) {\n      this.isResponsiveView = window.innerWidth < 1024;\n    } else {\n      this.isResponsiveView = false;\n    }\n  }\n\n  updateLocationReponsive() {\n    if (!this.flowData?.nodeDataArray) {\n      this.flowData = AssetFlowComponent.getDefaultFlowData({\n        systemType: this.systemType,\n        isUseBase64: this.isUseBase64,\n        assetLayer: this.assetLayer,\n      });\n    }\n    _.forEach(this.flowData?.nodeDataArray, (node: any) => {\n      node = _.merge(\n        node,\n        node[`extendedData${this.isResponsiveView ? 'Responsive' : ''}`]\n      );\n    });\n    this.setFlowData(_.cloneDeep(this.flowData));\n  }\n\n  ngOnInit() {\n    this.checkResponsiveView();\n    this.updateLocationReponsive();\n  }\n  onClickParamOfTable($event: any) {\n    this.onClickParamOfTableEvent.emit($event);\n  }\n\n  static getDefaultFlowData(defaultData: AtoDefaultFlowData) {\n    const flowData = {\n      ...defaultData,\n      ..._.cloneDeep(ATO_COMPONENTS_GROUP_DATA)[defaultData?.systemType],\n      linkFromPortIdProperty: 'fromPort',\n      linkToPortIdProperty: 'toPort',\n    };\n    // Reponsive\n    _.forEach(flowData?.nodeDataArray, (node: any) => {\n      node = _.merge(\n        node,\n        node[`extendedData${window.innerWidth < 1024 ? 'Responsive' : ''}`]\n      );\n      if (node?.assetLayers) {\n        node.visible =\n          node?.assetLayers ===\n          (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW);\n      }\n    });\n    // assetLayer\n    // flowData.nodeDataArray = _.filter(flowData.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === (defaultData?.assetLayer ?? ATO_ASSET_LAYERS.FLOW)))\n    if (defaultData?.isUseBase64) {\n      const itemImageTemp = (flowData as AtoGoJSData)?.nodeDataArray?.find(\n        (x) => x?.type === 'Image Template'\n      );\n      if (itemImageTemp) {\n        itemImageTemp.source = AtoGoJSBase64[defaultData?.systemType];\n      }\n    }\n    return flowData;\n  }\n\n  setFlowData(data: AtoGoJSData) {\n    // const layer = data?.assetLayer ?? this?.assetLayer ?? ATO_ASSET_LAYERS.FLOW;\n    _.forEach(data.nodeDataArray, (node) => {\n      if (node?.assetLayers) {\n        node.visible = node?.assetLayers === data.assetLayer;\n      }\n    });\n    this.flowData = {\n      ...data,\n      // nodeDataArray: _.filter(data.nodeDataArray, x => !x?.assetLayers || (x?.assetLayers && x?.assetLayers === data?.assetLayer))\n    };\n    this.updateDataTableAssetParams(data);\n  }\n\n  updateDataTableAssetParams(data: AtoGoJSData) {\n    this.dataTableAssetParams = _.forEach(\n      this.flowData?.nodeDataArray?.filter(\n        (e) =>\n          e?.type === AtoGojsEditorModel.ENUM_TEMPLATES.PARAM_TABLE &&\n          e?.assetLayers === data?.assetLayer\n      ),\n      (x) => {\n        if (!data?.isRefresh) {\n          x.isCollapsed = this.assetParamsViewTemp?.data?.find(\n            (y) => y?.key === x?.key\n          )?.isCollapsed;\n        }\n      }\n    );\n  }\n}\n","<div class=\"h-100 d-flex flex-column flex-gap-3 flex-grow-1 overflow-auto px-3 pb-3\">\n  <div class=\"h-100 d-flex flex-column\" atoLoading [appLoading]=\"flowData === null\">\n    <ato-flow-diagram-lib\n      *ngIf=\"flowData !== null\"\n      #gjFlowDiagramTemp\n      [data]=\"flowData\"\n      [initialOptions]=\"options\"\n      (onClikParamOfTable)=\"onClickParamOfTable($event)\"\n      [class]=\"!!isResponsiveView ? 'diagram-responsive-view' : 'flex-grow-1'\"\n    ></ato-flow-diagram-lib>\n    <div class=\"mt-2\" *ngIf=\"isResponsiveView\">\n      <ato-asset-params-view\n        #assetParamsViewTemp\n        [data]=\"dataTableAssetParams\"\n        [isEditView]=\"true\"\n        (clickParamTableRow)=\"onClickParamOfTable($event)\"\n      ></ato-asset-params-view>\n    </div>\n  </div>\n</div>\n\n"]}