@huntsman-cancer-institute/cod 17.3.4 → 17.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/attribute-absolute.component.d.ts +1 -0
- package/components/attribute-edit.component.d.ts +1 -0
- package/components/attribute-flex.component.d.ts +1 -0
- package/esm2022/components/attribute-absolute.component.mjs +26 -22
- package/esm2022/components/attribute-default.component.mjs +17 -17
- package/esm2022/components/attribute-edit.component.mjs +264 -260
- package/esm2022/components/attribute-flex.component.mjs +71 -63
- package/fesm2022/huntsman-cancer-institute-cod.mjs +374 -358
- package/fesm2022/huntsman-cancer-institute-cod.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -19,9 +19,13 @@ import * as i8 from "./attribute-edit.component";
|
|
|
19
19
|
export class AttributeFlexComponent extends AttributeBase {
|
|
20
20
|
constructor(attributeService, elementRef, renderer, modalService) {
|
|
21
21
|
super(attributeService, elementRef, renderer, modalService);
|
|
22
|
+
this.hciNgAttributeAbsoluteInputDisplayName = "";
|
|
22
23
|
}
|
|
23
24
|
ngAfterViewInit() {
|
|
24
25
|
this.refresh();
|
|
26
|
+
if (this.attribute && this.attribute.displayName) {
|
|
27
|
+
this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;
|
|
28
|
+
}
|
|
25
29
|
}
|
|
26
30
|
/**
|
|
27
31
|
* Flex needs to extend grid columns because we no longer want to use absolute width. Here we generate percentage
|
|
@@ -71,23 +75,24 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
71
75
|
</div>
|
|
72
76
|
</ng-container>
|
|
73
77
|
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
78
|
+
<!-- String -->
|
|
79
|
+
<ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
|
|
80
|
+
<div #attributeRef
|
|
81
|
+
class="d-flex flex-column cod-type-s">
|
|
82
|
+
<div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
|
|
83
|
+
{{ attribute.displayName }}
|
|
84
|
+
</div>
|
|
85
|
+
<div class="d-flex flex-grow-1">
|
|
86
|
+
<input #inputRef
|
|
87
|
+
type="text"
|
|
88
|
+
[(ngModel)]="attributeValues[0].valueString"
|
|
89
|
+
(ngModelChange)="valueStringChange($event)"
|
|
90
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
91
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
92
|
+
</div>
|
|
93
|
+
</div>
|
|
94
|
+
</ng-container>
|
|
95
|
+
|
|
91
96
|
|
|
92
97
|
<!-- Text -->
|
|
93
98
|
<ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
|
|
@@ -124,7 +129,7 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
124
129
|
[checked]="attributeValues[0].valueString === 'Y'"
|
|
125
130
|
(change)="valueCheckboxChange($event)"
|
|
126
131
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
127
|
-
class="form-control" />
|
|
132
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
128
133
|
</div>
|
|
129
134
|
</div>
|
|
130
135
|
</ng-container>
|
|
@@ -141,8 +146,8 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
141
146
|
type="number"
|
|
142
147
|
[(ngModel)]="attributeValues[0].valueNumeric"
|
|
143
148
|
(ngModelChange)="valueNumericChange($event)"
|
|
144
|
-
|
|
145
|
-
class="form-control" />
|
|
149
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
150
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
146
151
|
</div>
|
|
147
152
|
</div>
|
|
148
153
|
</ng-container>
|
|
@@ -159,8 +164,8 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
159
164
|
type="number"
|
|
160
165
|
[(ngModel)]="attributeValues[0].valueInteger"
|
|
161
166
|
(ngModelChange)="valueIntegerChange($event)"
|
|
162
|
-
|
|
163
|
-
class="form-control" />
|
|
167
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
168
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
164
169
|
</div>
|
|
165
170
|
</div>
|
|
166
171
|
</ng-container>
|
|
@@ -180,7 +185,7 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
180
185
|
(ngModelChange)="valueDateChange($event)"
|
|
181
186
|
[matDatepicker]="valueDate"
|
|
182
187
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
183
|
-
class="form-control">
|
|
188
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
|
|
184
189
|
<mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
|
|
185
190
|
<mat-datepicker #valueDate></mat-datepicker>
|
|
186
191
|
</div>
|
|
@@ -202,7 +207,7 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
202
207
|
[(ngModel)]="attributeValues[0].date"
|
|
203
208
|
(ngModelChange)="valueDateChange($event)"
|
|
204
209
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
205
|
-
[ngxMatDatetimePicker]="dtpicker">
|
|
210
|
+
[ngxMatDatetimePicker]="dtpicker" attr.aria-label="hci-ng-attribute-flex-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}">
|
|
206
211
|
<mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
|
|
207
212
|
<ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
|
|
208
213
|
</div>
|
|
@@ -260,10 +265,11 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
260
265
|
{{attribute.displayName}}
|
|
261
266
|
</div>
|
|
262
267
|
<div class="d-flex flex-grow-1">
|
|
263
|
-
<select
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
268
|
+
<select
|
|
269
|
+
[ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
|
|
270
|
+
(ngModelChange)="valueChoiceChange($event)"
|
|
271
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
272
|
+
class="form-control edit-renderer">
|
|
267
273
|
<option [ngValue]="undefined"></option>
|
|
268
274
|
<option *ngFor="let attributeChoice of attributeChoices"
|
|
269
275
|
[ngValue]="attributeChoice.idAttributeChoice">
|
|
@@ -288,8 +294,8 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
288
294
|
[checked]="attributeChoice.value"
|
|
289
295
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
290
296
|
(change)="valueMultiChoiceChange(attributeChoice)"
|
|
291
|
-
|
|
292
|
-
class="form-control checkbox" />
|
|
297
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
298
|
+
class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
|
|
293
299
|
<div class="cod-label ps-1">
|
|
294
300
|
{{attributeChoice.choice}}
|
|
295
301
|
</div>
|
|
@@ -314,7 +320,7 @@ export class AttributeFlexComponent extends AttributeBase {
|
|
|
314
320
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
315
321
|
(change)="valueMultiDictChange(entry)"
|
|
316
322
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
317
|
-
class="form-control checkbox" />
|
|
323
|
+
class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
|
|
318
324
|
<div class="cod-label ps-1">
|
|
319
325
|
{{entry.display}}
|
|
320
326
|
</div>
|
|
@@ -449,23 +455,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
449
455
|
</div>
|
|
450
456
|
</ng-container>
|
|
451
457
|
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
458
|
+
<!-- String -->
|
|
459
|
+
<ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
|
|
460
|
+
<div #attributeRef
|
|
461
|
+
class="d-flex flex-column cod-type-s">
|
|
462
|
+
<div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
|
|
463
|
+
{{ attribute.displayName }}
|
|
464
|
+
</div>
|
|
465
|
+
<div class="d-flex flex-grow-1">
|
|
466
|
+
<input #inputRef
|
|
467
|
+
type="text"
|
|
468
|
+
[(ngModel)]="attributeValues[0].valueString"
|
|
469
|
+
(ngModelChange)="valueStringChange($event)"
|
|
470
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
471
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
472
|
+
</div>
|
|
473
|
+
</div>
|
|
474
|
+
</ng-container>
|
|
475
|
+
|
|
469
476
|
|
|
470
477
|
<!-- Text -->
|
|
471
478
|
<ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
|
|
@@ -502,7 +509,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
502
509
|
[checked]="attributeValues[0].valueString === 'Y'"
|
|
503
510
|
(change)="valueCheckboxChange($event)"
|
|
504
511
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
505
|
-
class="form-control" />
|
|
512
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
506
513
|
</div>
|
|
507
514
|
</div>
|
|
508
515
|
</ng-container>
|
|
@@ -519,8 +526,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
519
526
|
type="number"
|
|
520
527
|
[(ngModel)]="attributeValues[0].valueNumeric"
|
|
521
528
|
(ngModelChange)="valueNumericChange($event)"
|
|
522
|
-
|
|
523
|
-
class="form-control" />
|
|
529
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
530
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
524
531
|
</div>
|
|
525
532
|
</div>
|
|
526
533
|
</ng-container>
|
|
@@ -537,8 +544,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
537
544
|
type="number"
|
|
538
545
|
[(ngModel)]="attributeValues[0].valueInteger"
|
|
539
546
|
(ngModelChange)="valueIntegerChange($event)"
|
|
540
|
-
|
|
541
|
-
class="form-control" />
|
|
547
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
548
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
|
|
542
549
|
</div>
|
|
543
550
|
</div>
|
|
544
551
|
</ng-container>
|
|
@@ -558,7 +565,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
558
565
|
(ngModelChange)="valueDateChange($event)"
|
|
559
566
|
[matDatepicker]="valueDate"
|
|
560
567
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
561
|
-
class="form-control">
|
|
568
|
+
class="form-control" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
|
|
562
569
|
<mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
|
|
563
570
|
<mat-datepicker #valueDate></mat-datepicker>
|
|
564
571
|
</div>
|
|
@@ -580,7 +587,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
580
587
|
[(ngModel)]="attributeValues[0].date"
|
|
581
588
|
(ngModelChange)="valueDateChange($event)"
|
|
582
589
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
583
|
-
[ngxMatDatetimePicker]="dtpicker">
|
|
590
|
+
[ngxMatDatetimePicker]="dtpicker" attr.aria-label="hci-ng-attribute-flex-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}">
|
|
584
591
|
<mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
|
|
585
592
|
<ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
|
|
586
593
|
</div>
|
|
@@ -638,10 +645,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
638
645
|
{{attribute.displayName}}
|
|
639
646
|
</div>
|
|
640
647
|
<div class="d-flex flex-grow-1">
|
|
641
|
-
<select
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
648
|
+
<select
|
|
649
|
+
[ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
|
|
650
|
+
(ngModelChange)="valueChoiceChange($event)"
|
|
651
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
652
|
+
class="form-control edit-renderer">
|
|
645
653
|
<option [ngValue]="undefined"></option>
|
|
646
654
|
<option *ngFor="let attributeChoice of attributeChoices"
|
|
647
655
|
[ngValue]="attributeChoice.idAttributeChoice">
|
|
@@ -666,8 +674,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
666
674
|
[checked]="attributeChoice.value"
|
|
667
675
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
668
676
|
(change)="valueMultiChoiceChange(attributeChoice)"
|
|
669
|
-
|
|
670
|
-
class="form-control checkbox" />
|
|
677
|
+
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
678
|
+
class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
|
|
671
679
|
<div class="cod-label ps-1">
|
|
672
680
|
{{attributeChoice.choice}}
|
|
673
681
|
</div>
|
|
@@ -692,7 +700,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
692
700
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
693
701
|
(change)="valueMultiDictChange(entry)"
|
|
694
702
|
[disabled]="!editInline || attribute.isCalculated === 'Y'"
|
|
695
|
-
class="form-control checkbox" />
|
|
703
|
+
class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
|
|
696
704
|
<div class="cod-label ps-1">
|
|
697
705
|
{{entry.display}}
|
|
698
706
|
</div>
|
|
@@ -802,4 +810,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
802
810
|
</ng-template>
|
|
803
811
|
`, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"] }]
|
|
804
812
|
}], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
|
|
805
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-flex.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-flex.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAU,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AAGpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;AAI/D;;;;GAIG;AAoZH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAED,eAAe;QACb,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,UAAgC,EAAE,OAAc;QACpE,KAAK,CAAC,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAEjD,IAAI,KAAK,GAAW,CAAC,CAAC;QACtB,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC;QACvB,CAAC;QAED,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,IAAI,YAAY,GAAW,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;YAEnE,KAAK,IAAI,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC3B,IAAI,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,WAAW,KAAK,SAAS,CAAC,WAAW,EAAE,CAAC;oBACzF,MAAM,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC;oBAC9B,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;oBACnC,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;8GApCU,sBAAsB;kGAAtB,sBAAsB,iFAhZvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsXT;;2FA0BU,sBAAsB;kBAnZlC,SAAS;+BACE,oBAAoB,iBACf,iBAAiB,CAAC,IAAI,YAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsXT","sourcesContent":["import {Component, ElementRef, Inject, Renderer2, ViewEncapsulation} from \"@angular/core\";\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\n\r\nimport {AttributeBase} from \"./attribute-base\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * The view for attributes organized in a flex layout.  This will arrange all attributes in a four column layout\r\n * with grids taking up all 12 columns.  The attributes here will fill the this parent component which defines the\r\n * column size.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-flex\",\r\n  encapsulation: ViewEncapsulation.None,\r\n  template: `\r\n    <!-- Line -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LINE'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row cod-type-line\">\r\n        <div class=\"d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0\"></div>\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1 flex-shrink-0\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex cod-line grow mt-auto mb-auto\"></div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Label -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LABEL'\">\r\n      <div #attributeRef\r\n          class=\"d-flex flex-column cod-type-label\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-s\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"text\"\r\n                 [(ngModel)]=\"attributeValues[0].valueString\"\r\n                 (ngModelChange)=\"valueStringChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-txt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <textarea\r\n            #inputRef\r\n            type=\"text\"\r\n            spellcheck=\"spellcheck\"\r\n            lang=\"en\"\r\n            [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n            (change)=\"valueTextChange($event)\"\r\n            [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            class=\"form-control\">\r\n          </textarea>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Checkbox -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-cb\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"checkbox\"\r\n                 [checked]=\"attributeValues[0].valueString === 'Y'\"\r\n                 (change)=\"valueCheckboxChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueNumeric\"\r\n                 (ngModelChange)=\"valueNumericChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-i\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueInteger\"\r\n                 (ngModelChange)=\"valueIntegerChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-d\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n           <input #inputRef\r\n              matInput\r\n              name=\"valueDate\"          \r\n              [(ngModel)]=\"attributeValues[0].valueDate\" \r\n              (ngModelChange)=\"valueDateChange($event)\"\r\n              [matDatepicker]=\"valueDate\"\r\n              [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n              class=\"form-control\">\r\n            <mat-datepicker-toggle  matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n            <mat-datepicker #valueDate></mat-datepicker>  \r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 matInput\r\n                 name=\"valueDateTime\"\r\n                 class=\"form-control\"\r\n                 [(ngModel)]=\"attributeValues[0].date\"\r\n                 (ngModelChange)=\"valueDateChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 [ngxMatDatetimePicker]=\"dtpicker\">\r\n               <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n               <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-b\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Extended Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'EB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-eb\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n            <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                  (ngModelChange)=\"valueChoiceChange($event)\"\r\n        \t\t\t\t  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let attributeChoice of attributeChoices\"\r\n                    [ngValue]=\"attributeChoice.idAttributeChoice\">\r\n              {{ attributeChoice.choice }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"attributeChoice.value\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n\t\t\t\t\t           [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control checkbox\" />\r\n              <div class=\"cod-label ps-1\">\r\n                {{attributeChoice.choice}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <!-- Dictionary: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"entry.checked\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiDictChange(entry)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control checkbox\" />\r\n              <div class=\"cod-label ps-1\">\r\n                {{entry.display}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>    \r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dict\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let entry of dictionaryEntries\"\r\n                    [ngValue]=\"entry.value\">\r\n              {{ entry.display }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n      <div #attributeRef class=\"d-flex flex-column cod-type-ga\">\r\n        <div *ngIf=\"attribute.idAttribute\" class=\"d-flex cod-top-label mr-1\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div *ngIf=\"editInline\" style=\"margin-left: auto;\">\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"addGridRow(editGridModal, attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"removeGridRow(attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">             \r\n          <ag-grid-angular #gridAttribute\r\n              class=\"ag-theme-alpine\"\r\n              (gridReady)=\"this.onGridReady($event)\"\r\n              (modelUpdated)=\"onModelUpdated($event)\"\r\n              (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n              (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n              [gridOptions]=\"this.gridOptions\"\r\n              [rowSelection]=\"'single'\"\r\n              [columnDefs]=\"gridColumns\"\r\n              [rowData]=\"gridData\"\r\n              [style.width]=\"attribute.w + 'px'\"\r\n              [style.height]=\"attribute.h + 'px'\">\r\n          </ag-grid-angular>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <ng-template #editGridModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{attribute.displayName}} Grid Row\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n            <button\r\n              [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Save')\"\r\n            >\r\n              Save\r\n            </button>\r\n\r\n            <button\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Cancel')\"\r\n            >\r\n              Cancel\r\n            </button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n  ,\r\n  styles: [`\r\n  \t.hci-cod button.mat-icon-button.mat-button-base {\r\n      \theight: 20px;\r\n      \twidth: 20px;\r\n      \tline-height: unset;\r\n  \t}\r\n  \t\r\n    .btn-ga {\r\n      padding: 0px;\r\n      height: 18px;\r\n      width: 18px;\r\n    }\r\n    \r\n    .ga-icon {\r\n      font-size: .9em;\r\n      vertical-align: top;\r\n    }\r\n\r\n    .hci-cod .mat-datepicker-toggle-default-icon {\r\n      height: 20px;\r\n      width: 20px;\r\n    }\r\n `]\r\n})\r\nexport class AttributeFlexComponent extends AttributeBase {\r\n\r\n  constructor(attributeService: AttributeService, elementRef: ElementRef, renderer: Renderer2, modalService: NgbModal) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n  }\r\n\r\n  /**\r\n   * Flex needs to extend grid columns because we no longer want to use absolute width.  Here we generate percentage\r\n   * based upon the absolute width, but still use absolute width for the min width.\r\n   *\r\n   * @param {Attribute[]} attributes\r\n   * @param {any[]} columns\r\n   */\r\n  initializeGridColumns(attributes: GraphicalAttribute[], columns: any[]) {\r\n    super.initializeGridColumns(attributes, columns);\r\n\r\n    let width: number = 0;\r\n    for (let attribute of attributes) {\r\n      width += attribute.w;\r\n    }\r\n\r\n    for (let attribute of attributes) {\r\n      let widthPercent: number = Math.floor(100 * (attribute.w / width));\r\n\r\n      for (let column of columns) {\r\n        if (column.externalConfig && column.externalConfig.idAttribute === attribute.idAttribute) {\r\n          column.minWidth = attribute.w;\r\n          column.widthPercent = widthPercent;\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}
|
|
813
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-flex.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-flex.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAU,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AAGpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;AAI/D;;;;GAIG;AAsZH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,YACE,gBAAkC,EAClC,UAAsB,EACtB,QAAmB,EACnB,YAAsB;QAEtB,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;QAP9D,2CAAsC,GAAG,EAAE,CAAC;IAQ5C,CAAC;IAED,eAAe;QACb,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;YACjD,IAAI,CAAC,sCAAsC,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;QAC3E,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,UAAgC,EAAE,OAAc;QACpE,KAAK,CAAC,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAEjD,IAAI,KAAK,GAAW,CAAC,CAAC;QACtB,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC;QACvB,CAAC;QAED,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,IAAI,YAAY,GAAW,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;YAEnE,KAAK,IAAI,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC3B,IAAI,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,WAAW,KAAK,SAAS,CAAC,WAAW,EAAE,CAAC;oBACzF,MAAM,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC;oBAC9B,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;oBACnC,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;8GA5CU,sBAAsB;kGAAtB,sBAAsB,iFAlZvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwXT;;2FA0BU,sBAAsB;kBArZlC,SAAS;+BACE,oBAAoB,iBACf,iBAAiB,CAAC,IAAI,YAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwXT","sourcesContent":["import {Component, ElementRef, Inject, Renderer2, ViewEncapsulation} from \"@angular/core\";\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\n\r\nimport {AttributeBase} from \"./attribute-base\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * The view for attributes organized in a flex layout.  This will arrange all attributes in a four column layout\r\n * with grids taking up all 12 columns.  The attributes here will fill the this parent component which defines the\r\n * column size.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-flex\",\r\n  encapsulation: ViewEncapsulation.None,\r\n  template: `\r\n    <!-- Line -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LINE'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row cod-type-line\">\r\n        <div class=\"d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0\"></div>\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1 flex-shrink-0\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex cod-line grow mt-auto mb-auto\"></div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Label -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LABEL'\">\r\n      <div #attributeRef\r\n          class=\"d-flex flex-column cod-type-label\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n        <!-- String -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column cod-type-s\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n              {{ attribute.displayName }}\r\n            </div>\r\n            <div class=\"d-flex flex-grow-1\">\r\n              <input #inputRef\r\n                     type=\"text\"\r\n                     [(ngModel)]=\"attributeValues[0].valueString\"\r\n                     (ngModelChange)=\"valueStringChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-txt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <textarea\r\n            #inputRef\r\n            type=\"text\"\r\n            spellcheck=\"spellcheck\"\r\n            lang=\"en\"\r\n            [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n            (change)=\"valueTextChange($event)\"\r\n            [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            class=\"form-control\">\r\n          </textarea>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Checkbox -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-cb\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"checkbox\"\r\n                 [checked]=\"attributeValues[0].valueString === 'Y'\"\r\n                 (change)=\"valueCheckboxChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueNumeric\"\r\n                 (ngModelChange)=\"valueNumericChange($event)\"\r\n\t\t\t\t [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-i\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueInteger\"\r\n                 (ngModelChange)=\"valueIntegerChange($event)\"\r\n\t\t\t\t [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-d\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n           <input #inputRef\r\n              matInput\r\n              name=\"valueDate\"          \r\n              [(ngModel)]=\"attributeValues[0].valueDate\" \r\n              (ngModelChange)=\"valueDateChange($event)\"\r\n              [matDatepicker]=\"valueDate\"\r\n              [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n              class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n            <mat-datepicker-toggle  matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n            <mat-datepicker #valueDate></mat-datepicker>  \r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 matInput\r\n                 name=\"valueDateTime\"\r\n                 class=\"form-control\"\r\n                 [(ngModel)]=\"attributeValues[0].date\"\r\n                 (ngModelChange)=\"valueDateChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 [ngxMatDatetimePicker]=\"dtpicker\" attr.aria-label=\"hci-ng-attribute-flex-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n               <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n               <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-b\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Extended Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'EB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-eb\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n            <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select\r\n            [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n            (ngModelChange)=\"valueChoiceChange($event)\"\r\n        \t[disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let attributeChoice of attributeChoices\"\r\n                    [ngValue]=\"attributeChoice.idAttributeChoice\">\r\n              {{ attributeChoice.choice }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"attributeChoice.value\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n\t\t\t\t\t [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{attributeChoice.choice}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <!-- Dictionary: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"entry.checked\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiDictChange(entry)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{entry.display}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>    \r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dict\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let entry of dictionaryEntries\"\r\n                    [ngValue]=\"entry.value\">\r\n              {{ entry.display }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n      <div #attributeRef class=\"d-flex flex-column cod-type-ga\">\r\n        <div *ngIf=\"attribute.idAttribute\" class=\"d-flex cod-top-label mr-1\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div *ngIf=\"editInline\" style=\"margin-left: auto;\">\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"addGridRow(editGridModal, attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"removeGridRow(attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">             \r\n          <ag-grid-angular #gridAttribute\r\n              class=\"ag-theme-alpine\"\r\n              (gridReady)=\"this.onGridReady($event)\"\r\n              (modelUpdated)=\"onModelUpdated($event)\"\r\n              (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n              (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n              [gridOptions]=\"this.gridOptions\"\r\n              [rowSelection]=\"'single'\"\r\n              [columnDefs]=\"gridColumns\"\r\n              [rowData]=\"gridData\"\r\n              [style.width]=\"attribute.w + 'px'\"\r\n              [style.height]=\"attribute.h + 'px'\">\r\n          </ag-grid-angular>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <ng-template #editGridModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{attribute.displayName}} Grid Row\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n            <button\r\n              [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Save')\"\r\n            >\r\n              Save\r\n            </button>\r\n\r\n            <button\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Cancel')\"\r\n            >\r\n              Cancel\r\n            </button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n  ,\r\n  styles: [`\r\n  \t.hci-cod button.mat-icon-button.mat-button-base {\r\n      \theight: 20px;\r\n      \twidth: 20px;\r\n      \tline-height: unset;\r\n  \t}\r\n  \t\r\n    .btn-ga {\r\n      padding: 0px;\r\n      height: 18px;\r\n      width: 18px;\r\n    }\r\n    \r\n    .ga-icon {\r\n      font-size: .9em;\r\n      vertical-align: top;\r\n    }\r\n\r\n    .hci-cod .mat-datepicker-toggle-default-icon {\r\n      height: 20px;\r\n      width: 20px;\r\n    }\r\n `]\r\n})\r\nexport class AttributeFlexComponent extends AttributeBase {\r\n  hciNgAttributeAbsoluteInputDisplayName = \"\";\r\n  constructor(\r\n    attributeService: AttributeService,\r\n    elementRef: ElementRef,\r\n    renderer: Renderer2,\r\n    modalService: NgbModal\r\n  ) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n    if (this.attribute && this.attribute.displayName) {\r\n      this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Flex needs to extend grid columns because we no longer want to use absolute width.  Here we generate percentage\r\n   * based upon the absolute width, but still use absolute width for the min width.\r\n   *\r\n   * @param {Attribute[]} attributes\r\n   * @param {any[]} columns\r\n   */\r\n  initializeGridColumns(attributes: GraphicalAttribute[], columns: any[]) {\r\n    super.initializeGridColumns(attributes, columns);\r\n\r\n    let width: number = 0;\r\n    for (let attribute of attributes) {\r\n      width += attribute.w;\r\n    }\r\n\r\n    for (let attribute of attributes) {\r\n      let widthPercent: number = Math.floor(100 * (attribute.w / width));\r\n\r\n      for (let column of columns) {\r\n        if (column.externalConfig && column.externalConfig.idAttribute === attribute.idAttribute) {\r\n          column.minWidth = attribute.w;\r\n          column.widthPercent = widthPercent;\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}
|