@huntsman-cancer-institute/cod 17.9.6 → 17.10.1

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.
@@ -41,7 +41,8 @@ export class AttributeEditComponent extends AttributeBase {
41
41
  type="text"
42
42
  [ngModel]="attributeValues[0].valueString"
43
43
  (ngModelChange)="valueStringChange($event)"
44
- [disabled]="!editInline || attribute.isCalculated === 'Y'" attr.aria-label="hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"
44
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
45
+ attr.aria-label="hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"
45
46
  />
46
47
  </div>
47
48
 
@@ -53,7 +54,7 @@ export class AttributeEditComponent extends AttributeBase {
53
54
  lang="en"
54
55
  [ngModel]="attributeValues[0].valueString"
55
56
  (ngModelChange)="valueStringChange($event)"
56
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
57
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
57
58
  style="width: 500px; height: 125px; resize: none;"
58
59
  >
59
60
  </textarea>
@@ -78,7 +79,7 @@ export class AttributeEditComponent extends AttributeBase {
78
79
  lang="en"
79
80
  [ngModel]="attributeValues[0].valueLongText.textData"
80
81
  (ngModelChange)="valueTextChange($event)"
81
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
82
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
82
83
  style="width: 500px; height: 125px; resize: none;"
83
84
  >
84
85
  </textarea>
@@ -98,7 +99,9 @@ export class AttributeEditComponent extends AttributeBase {
98
99
  <input #inputRef
99
100
  type="number"
100
101
  [ngModel]="attributeValues[0].valueNumeric"
101
- (ngModelChange)="valueNumericChange($event)" attr.aria-label="hci-ng-attribute-edit-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
102
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
103
+ (ngModelChange)="valueNumericChange($event)"
104
+ attr.aria-label="hci-ng-attribute-edit-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
102
105
  </div>
103
106
  </div>
104
107
  </ng-container>
@@ -114,7 +117,9 @@ export class AttributeEditComponent extends AttributeBase {
114
117
  <input #inputRef
115
118
  type="number"
116
119
  [ngModel]="attributeValues[0].valueInteger"
117
- (ngModelChange)="valueIntegerChange($event)" attr.aria-label="hci-ng-attribute-edit-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
120
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
121
+ (ngModelChange)="valueIntegerChange($event)"
122
+ attr.aria-label="hci-ng-attribute-edit-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
118
123
  </div>
119
124
  </div>
120
125
  </ng-container>
@@ -133,7 +138,8 @@ export class AttributeEditComponent extends AttributeBase {
133
138
  [(ngModel)]="attributeValues[0].valueDate"
134
139
  (ngModelChange)="valueDateChange($event)"
135
140
  [matDatepicker]="valueDate"
136
- [disabled]="!editInline || attribute.isCalculated === 'Y'" attr.aria-label="hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}"
141
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
142
+ attr.aria-label="hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}"
137
143
  >
138
144
  <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
139
145
  <mat-datepicker #valueDate></mat-datepicker>
@@ -154,7 +160,7 @@ export class AttributeEditComponent extends AttributeBase {
154
160
  name="valueDateTime"
155
161
  [(ngModel)]="attributeValues[0].date"
156
162
  (ngModelChange)="valueDateChange($event)"
157
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
163
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
158
164
  [ngxMatDatetimePicker]="dtpicker" attr.aria-label="hci-ng-attribute-edit-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}">
159
165
  <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
160
166
  <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
@@ -174,7 +180,7 @@ export class AttributeEditComponent extends AttributeBase {
174
180
  type="checkbox"
175
181
  [checked]="attributeValues[0].valueString === 'Y'"
176
182
  (change)="valueCheckboxChange($event)"
177
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
183
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
178
184
  class="form-control" attr.aria-label="hci-ng-attribute-edit-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
179
185
  </div>
180
186
  </div>
@@ -189,6 +195,7 @@ export class AttributeEditComponent extends AttributeBase {
189
195
  </div>
190
196
  <div class="d-flex col-md-6">
191
197
  <select [ngModel]="attributeValues[0].valueString"
198
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
192
199
  (ngModelChange)="valueStringChange($event)"
193
200
  class="edit-renderer">
194
201
  <option [ngValue]="undefined"></option>
@@ -208,6 +215,7 @@ export class AttributeEditComponent extends AttributeBase {
208
215
  </div>
209
216
  <div class="d-flex col-md-6">
210
217
  <select [ngModel]="attributeValues[0].valueString"
218
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
211
219
  (ngModelChange)="valueStringChange($event)"
212
220
  class="edit-renderer">
213
221
  <option [ngValue]="undefined"></option>
@@ -229,6 +237,7 @@ export class AttributeEditComponent extends AttributeBase {
229
237
  <div class="d-flex col-md-6">
230
238
  <select
231
239
  [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
240
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
232
241
  (ngModelChange)="valueChoiceChange($event)"
233
242
  class="edit-renderer">
234
243
  <option [ngValue]="undefined"></option>
@@ -253,7 +262,7 @@ export class AttributeEditComponent extends AttributeBase {
253
262
  <div class="d-flex">
254
263
  <input type="checkbox"
255
264
  [checked]="attributeChoice.value"
256
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
265
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
257
266
  (change)="valueMultiChoiceChange(attributeChoice)"
258
267
  class="form-control checkbox mt-auto mb-auto me-2" attr.aria-label="hci-ng-attribute-edit-input-choice-multiple-{{attributeChoice.choice}}"/>
259
268
  <div class="cod-label ps-1">
@@ -277,9 +286,8 @@ export class AttributeEditComponent extends AttributeBase {
277
286
  <div class="d-flex">
278
287
  <input type="checkbox"
279
288
  [checked]="entry.checked"
280
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
289
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
281
290
  (change)="valueMultiDictChange(entry)"
282
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
283
291
  class="form-control checkbox" attr.aria-label="hci-ng-attribute-edit-input-dictionary-choice-{{entry.display}}"/>
284
292
  <div class="cod-label ps-1">
285
293
  {{entry.display}}
@@ -301,7 +309,7 @@ export class AttributeEditComponent extends AttributeBase {
301
309
  <select #inputRef
302
310
  [ngModel]="attributeValues[0].valueIdDictionary"
303
311
  (ngModelChange)="valueDictChange($event)"
304
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
312
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
305
313
  class="form-control edit-renderer">
306
314
  <option [ngValue]="undefined"></option>
307
315
  <option *ngFor="let entry of dictionaryEntries"
@@ -387,7 +395,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
387
395
  type="text"
388
396
  [ngModel]="attributeValues[0].valueString"
389
397
  (ngModelChange)="valueStringChange($event)"
390
- [disabled]="!editInline || attribute.isCalculated === 'Y'" attr.aria-label="hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"
398
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
399
+ attr.aria-label="hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"
391
400
  />
392
401
  </div>
393
402
 
@@ -399,7 +408,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
399
408
  lang="en"
400
409
  [ngModel]="attributeValues[0].valueString"
401
410
  (ngModelChange)="valueStringChange($event)"
402
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
411
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
403
412
  style="width: 500px; height: 125px; resize: none;"
404
413
  >
405
414
  </textarea>
@@ -424,7 +433,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
424
433
  lang="en"
425
434
  [ngModel]="attributeValues[0].valueLongText.textData"
426
435
  (ngModelChange)="valueTextChange($event)"
427
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
436
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
428
437
  style="width: 500px; height: 125px; resize: none;"
429
438
  >
430
439
  </textarea>
@@ -444,7 +453,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
444
453
  <input #inputRef
445
454
  type="number"
446
455
  [ngModel]="attributeValues[0].valueNumeric"
447
- (ngModelChange)="valueNumericChange($event)" attr.aria-label="hci-ng-attribute-edit-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
456
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
457
+ (ngModelChange)="valueNumericChange($event)"
458
+ attr.aria-label="hci-ng-attribute-edit-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
448
459
  </div>
449
460
  </div>
450
461
  </ng-container>
@@ -460,7 +471,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
460
471
  <input #inputRef
461
472
  type="number"
462
473
  [ngModel]="attributeValues[0].valueInteger"
463
- (ngModelChange)="valueIntegerChange($event)" attr.aria-label="hci-ng-attribute-edit-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
474
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
475
+ (ngModelChange)="valueIntegerChange($event)"
476
+ attr.aria-label="hci-ng-attribute-edit-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
464
477
  </div>
465
478
  </div>
466
479
  </ng-container>
@@ -479,7 +492,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
479
492
  [(ngModel)]="attributeValues[0].valueDate"
480
493
  (ngModelChange)="valueDateChange($event)"
481
494
  [matDatepicker]="valueDate"
482
- [disabled]="!editInline || attribute.isCalculated === 'Y'" attr.aria-label="hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}"
495
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
496
+ attr.aria-label="hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}"
483
497
  >
484
498
  <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
485
499
  <mat-datepicker #valueDate></mat-datepicker>
@@ -500,7 +514,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
500
514
  name="valueDateTime"
501
515
  [(ngModel)]="attributeValues[0].date"
502
516
  (ngModelChange)="valueDateChange($event)"
503
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
517
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
504
518
  [ngxMatDatetimePicker]="dtpicker" attr.aria-label="hci-ng-attribute-edit-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}">
505
519
  <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
506
520
  <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
@@ -520,7 +534,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
520
534
  type="checkbox"
521
535
  [checked]="attributeValues[0].valueString === 'Y'"
522
536
  (change)="valueCheckboxChange($event)"
523
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
537
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
524
538
  class="form-control" attr.aria-label="hci-ng-attribute-edit-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
525
539
  </div>
526
540
  </div>
@@ -535,6 +549,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
535
549
  </div>
536
550
  <div class="d-flex col-md-6">
537
551
  <select [ngModel]="attributeValues[0].valueString"
552
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
538
553
  (ngModelChange)="valueStringChange($event)"
539
554
  class="edit-renderer">
540
555
  <option [ngValue]="undefined"></option>
@@ -554,6 +569,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
554
569
  </div>
555
570
  <div class="d-flex col-md-6">
556
571
  <select [ngModel]="attributeValues[0].valueString"
572
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
557
573
  (ngModelChange)="valueStringChange($event)"
558
574
  class="edit-renderer">
559
575
  <option [ngValue]="undefined"></option>
@@ -575,6 +591,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
575
591
  <div class="d-flex col-md-6">
576
592
  <select
577
593
  [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
594
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
578
595
  (ngModelChange)="valueChoiceChange($event)"
579
596
  class="edit-renderer">
580
597
  <option [ngValue]="undefined"></option>
@@ -599,7 +616,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
599
616
  <div class="d-flex">
600
617
  <input type="checkbox"
601
618
  [checked]="attributeChoice.value"
602
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
619
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
603
620
  (change)="valueMultiChoiceChange(attributeChoice)"
604
621
  class="form-control checkbox mt-auto mb-auto me-2" attr.aria-label="hci-ng-attribute-edit-input-choice-multiple-{{attributeChoice.choice}}"/>
605
622
  <div class="cod-label ps-1">
@@ -623,9 +640,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
623
640
  <div class="d-flex">
624
641
  <input type="checkbox"
625
642
  [checked]="entry.checked"
626
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
643
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
627
644
  (change)="valueMultiDictChange(entry)"
628
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
629
645
  class="form-control checkbox" attr.aria-label="hci-ng-attribute-edit-input-dictionary-choice-{{entry.display}}"/>
630
646
  <div class="cod-label ps-1">
631
647
  {{entry.display}}
@@ -647,7 +663,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
647
663
  <select #inputRef
648
664
  [ngModel]="attributeValues[0].valueIdDictionary"
649
665
  (ngModelChange)="valueDictChange($event)"
650
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
666
+ [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
651
667
  class="form-control edit-renderer">
652
668
  <option [ngValue]="undefined"></option>
653
669
  <option *ngFor="let entry of dictionaryEntries"
@@ -717,4 +733,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
717
733
  </ng-template>
718
734
  `, 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"] }]
719
735
  }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
720
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-edit.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-edit.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,SAAS,EACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;AAE/D;;;GAGG;AAuXH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,iEAAiE;IAEjE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;QAJ9D,2CAAsC,GAAG,EAAE,CAAC;IAK5C,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;QACb,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;+GAbU,sBAAsB;mGAAtB,sBAAsB,iFAlX7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsVH,6qWA4BU,sBAAsB;;4FAAtB,sBAAsB;kBAtXlC,SAAS;+BAEI,oBAAoB,YAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsVH","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Renderer2\r\n} from '@angular/core';\r\n\r\nimport {NgbModal} from '@ng-bootstrap/ng-bootstrap';\r\nimport {AttributeBase} from './attribute-base';\r\nimport {AttributeService} from '../services/attribute.service';\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.\r\n * This is different from the flex attribute because components such as the grid need extra configuration for editing.\r\n */\r\n@Component(\r\n  {\r\n    selector: 'hci-attribute-edit',\r\n    template:\r\n      `\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n        <div #attributeRef\r\n             class=\"d-flex flex-row\">\r\n          <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n           {{attribute.displayName}}\r\n          </div>\r\n\r\n            <div *ngIf=\"(attribute.h == undefined || (attribute.h && attribute.h <= 25))\" class=\"d-flex col-md-6\">\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'\" attr.aria-label=\"hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}\"\r\n              />\r\n            </div>\r\n\r\n            <div *ngIf=\"(attribute.h && attribute.h > 25)\" class=\"d-flex col-md-6\">\r\n              <textarea\r\n                #inputRef\r\n                type=\"text\"\r\n                spellcheck=\"spellcheck\"\r\n                lang=\"en\"\r\n                [ngModel]=\"attributeValues[0].valueString\"\r\n                (ngModelChange)=\"valueStringChange($event)\"\r\n                [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                style=\"width: 500px; height: 125px; resize: none;\"\r\n              >\r\n              </textarea>\r\n            </div>\r\n\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-row\">\r\n        <div class=\"d-flex col-md-6\">\r\n            {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n\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                 (ngModelChange)=\"valueTextChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            style=\"width: 500px; height: 125px; resize: none;\"\r\n          >\r\n          </textarea>\r\n\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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueNumeric\"\r\n                     (ngModelChange)=\"valueNumericChange($event)\" attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueInteger\"\r\n                     (ngModelChange)=\"valueIntegerChange($event)\" attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\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'\" attr.aria-label=\"hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}\"\r\n              >\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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     matInput\r\n                     name=\"valueDateTime\"\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-edit-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        <!-- Checkbox -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\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-edit-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n              <select\r\n                [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                  (ngModelChange)=\"valueChoiceChange($event)\"\r\n                  class=\"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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n                <div class=\"d-flex\">\r\n                  <input type=\"checkbox\"\r\n                         [checked]=\"attributeChoice.value\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                         (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                         class=\"form-control checkbox mt-auto mb-auto me-2\" attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n                <div class=\"d-flex\">\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-edit-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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\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\r\n           class=\"d-flex flex-column\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-12\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div style=\"margin-left: auto;\">\r\n            <button class=\"btn-ga\" (click)=\"addGridRow(editGridModal, attribute.idAttribute)\">\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 class=\"btn-ga\" (click)=\"removeGridRow(attribute.idAttribute)\">\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 col-md-12\">\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 class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n        <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n    styles: [\r\n      `\r\n    .hci-cod button.mat-icon-button.mat-button-base {\r\n        height: 20px;\r\n        width: 20px;\r\n        line-height: unset;\r\n    }\r\n\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\n  }\r\n)\r\nexport class AttributeEditComponent extends AttributeBase {\r\n  hciNgAttributeAbsoluteInputDisplayName = \"\";\r\n  // dictionaryEndpoint = this.attributeService.dictionaryEndpoint;\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  init(): void {\r\n    super.init();\r\n    if (this.attribute && this.attribute.displayName) {\r\n      this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;\r\n    }\r\n  }\r\n}\r\n"]}
736
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-edit.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-edit.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,SAAS,EACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;AAE/D;;;GAGG;AA+XH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,iEAAiE;IAEjE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;QAJ9D,2CAAsC,GAAG,EAAE,CAAC;IAK5C,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;QACb,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;+GAbU,sBAAsB;mGAAtB,sBAAsB,iFA1X7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8VH,6qWA4BU,sBAAsB;;4FAAtB,sBAAsB;kBA9XlC,SAAS;+BAEI,oBAAoB,YAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8VH","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Renderer2\r\n} from '@angular/core';\r\n\r\nimport {NgbModal} from '@ng-bootstrap/ng-bootstrap';\r\nimport {AttributeBase} from './attribute-base';\r\nimport {AttributeService} from '../services/attribute.service';\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.\r\n * This is different from the flex attribute because components such as the grid need extra configuration for editing.\r\n */\r\n@Component(\r\n  {\r\n    selector: 'hci-attribute-edit',\r\n    template:\r\n      `\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n        <div #attributeRef\r\n             class=\"d-flex flex-row\">\r\n          <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n           {{attribute.displayName}}\r\n          </div>\r\n\r\n            <div *ngIf=\"(attribute.h == undefined || (attribute.h && attribute.h <= 25))\" class=\"d-flex col-md-6\">\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' || attribute.isActive === 'N'\" \r\n                     attr.aria-label=\"hci-ng-attribute-edit-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}\"\r\n              />\r\n            </div>\r\n\r\n            <div *ngIf=\"(attribute.h && attribute.h > 25)\" class=\"d-flex col-md-6\">\r\n              <textarea\r\n                #inputRef\r\n                type=\"text\"\r\n                spellcheck=\"spellcheck\"\r\n                lang=\"en\"\r\n                [ngModel]=\"attributeValues[0].valueString\"\r\n                (ngModelChange)=\"valueStringChange($event)\"\r\n                [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                style=\"width: 500px; height: 125px; resize: none;\"\r\n              >\r\n              </textarea>\r\n            </div>\r\n\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-row\">\r\n        <div class=\"d-flex col-md-6\">\r\n            {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n\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                 (ngModelChange)=\"valueTextChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n            style=\"width: 500px; height: 125px; resize: none;\"\r\n          >\r\n          </textarea>\r\n\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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueNumeric\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     (ngModelChange)=\"valueNumericChange($event)\" \r\n                     attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueInteger\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     (ngModelChange)=\"valueIntegerChange($event)\" \r\n                     attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\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' || attribute.isActive === 'N'\" \r\n                     attr.aria-label=\"hci-ng-attribute-edit-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}\"\r\n              >\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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     matInput\r\n                     name=\"valueDateTime\"\r\n                     [(ngModel)]=\"attributeValues[0].date\"\r\n                     (ngModelChange)=\"valueDateChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     [ngxMatDatetimePicker]=\"dtpicker\" attr.aria-label=\"hci-ng-attribute-edit-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        <!-- Checkbox -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\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' || attribute.isActive === 'N'\"\r\n                     class=\"form-control\" attr.aria-label=\"hci-ng-attribute-edit-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n              <select\r\n                [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  (ngModelChange)=\"valueChoiceChange($event)\"\r\n                  class=\"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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n                <div class=\"d-flex\">\r\n                  <input type=\"checkbox\"\r\n                         [checked]=\"attributeChoice.value\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                         (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                         class=\"form-control checkbox mt-auto mb-auto me-2\" attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n                <div class=\"d-flex\">\r\n                  <input type=\"checkbox\"\r\n                         [checked]=\"entry.checked\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                         (change)=\"valueMultiDictChange(entry)\"\r\n                         class=\"form-control checkbox\" attr.aria-label=\"hci-ng-attribute-edit-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-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\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\r\n           class=\"d-flex flex-column\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-12\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div style=\"margin-left: auto;\">\r\n            <button class=\"btn-ga\" (click)=\"addGridRow(editGridModal, attribute.idAttribute)\">\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 class=\"btn-ga\" (click)=\"removeGridRow(attribute.idAttribute)\">\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 col-md-12\">\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 class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n        <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n    styles: [\r\n      `\r\n    .hci-cod button.mat-icon-button.mat-button-base {\r\n        height: 20px;\r\n        width: 20px;\r\n        line-height: unset;\r\n    }\r\n\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\n  }\r\n)\r\nexport class AttributeEditComponent extends AttributeBase {\r\n  hciNgAttributeAbsoluteInputDisplayName = \"\";\r\n  // dictionaryEndpoint = this.attributeService.dictionaryEndpoint;\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  init(): void {\r\n    super.init();\r\n    if (this.attribute && this.attribute.displayName) {\r\n      this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;\r\n    }\r\n  }\r\n}\r\n"]}