@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.
@@ -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
- <!-- String -->
75
- <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
76
- <div #attributeRef
77
- class="d-flex flex-column cod-type-s">
78
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
79
- {{attribute.displayName}}
80
- </div>
81
- <div class="d-flex flex-grow-1">
82
- <input #inputRef
83
- type="text"
84
- [(ngModel)]="attributeValues[0].valueString"
85
- (ngModelChange)="valueStringChange($event)"
86
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
87
- class="form-control" />
88
- </div>
89
- </div>
90
- </ng-container>
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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 [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
264
- (ngModelChange)="valueChoiceChange($event)"
265
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
266
- class="form-control edit-renderer">
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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
- <!-- String -->
453
- <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
454
- <div #attributeRef
455
- class="d-flex flex-column cod-type-s">
456
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
457
- {{attribute.displayName}}
458
- </div>
459
- <div class="d-flex flex-grow-1">
460
- <input #inputRef
461
- type="text"
462
- [(ngModel)]="attributeValues[0].valueString"
463
- (ngModelChange)="valueStringChange($event)"
464
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
465
- class="form-control" />
466
- </div>
467
- </div>
468
- </ng-container>
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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 [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
642
- (ngModelChange)="valueChoiceChange($event)"
643
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
644
- class="form-control edit-renderer">
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
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
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"]}