@huntsman-cancer-institute/cod 17.2.6 → 17.3.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.
@@ -31,7 +31,8 @@ export class AttributeEditComponent extends AttributeBase {
31
31
  <div *ngIf="attribute.displayName" class="d-flex col-md-6">
32
32
  {{attribute.displayName}}
33
33
  </div>
34
- <div class="d-flex col-md-6">
34
+
35
+ <div *ngIf="(attribute.h == undefined || (attribute.h && attribute.h <= 25))" class="d-flex col-md-6">
35
36
  <input #inputRef
36
37
  type="text"
37
38
  [ngModel]="attributeValues[0].valueString"
@@ -39,6 +40,21 @@ export class AttributeEditComponent extends AttributeBase {
39
40
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
40
41
  />
41
42
  </div>
43
+
44
+ <div *ngIf="(attribute.h && attribute.h > 25)" class="d-flex col-md-6">
45
+ <textarea
46
+ #inputRef
47
+ type="text"
48
+ spellcheck="spellcheck"
49
+ lang="en"
50
+ [ngModel]="attributeValues[0].valueString"
51
+ (ngModelChange)="valueStringChange($event)"
52
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
53
+ style="width: 500px; height: 125px; resize: none;"
54
+ >
55
+ </textarea>
56
+ </div>
57
+
42
58
  </div>
43
59
  </ng-container>
44
60
 
@@ -361,7 +377,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
361
377
  <div *ngIf="attribute.displayName" class="d-flex col-md-6">
362
378
  {{attribute.displayName}}
363
379
  </div>
364
- <div class="d-flex col-md-6">
380
+
381
+ <div *ngIf="(attribute.h == undefined || (attribute.h && attribute.h <= 25))" class="d-flex col-md-6">
365
382
  <input #inputRef
366
383
  type="text"
367
384
  [ngModel]="attributeValues[0].valueString"
@@ -369,6 +386,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
369
386
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
370
387
  />
371
388
  </div>
389
+
390
+ <div *ngIf="(attribute.h && attribute.h > 25)" class="d-flex col-md-6">
391
+ <textarea
392
+ #inputRef
393
+ type="text"
394
+ spellcheck="spellcheck"
395
+ lang="en"
396
+ [ngModel]="attributeValues[0].valueString"
397
+ (ngModelChange)="valueStringChange($event)"
398
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
399
+ style="width: 500px; height: 125px; resize: none;"
400
+ >
401
+ </textarea>
402
+ </div>
403
+
372
404
  </div>
373
405
  </ng-container>
374
406
 
@@ -681,4 +713,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
681
713
  </ng-template>
682
714
  `, 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"] }]
683
715
  }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
684
- //# 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;AAuWH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,gEAAgE;IAEhE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;8GAVU,sBAAsB;kGAAtB,sBAAsB,iFAlW7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsUH,6qWA4BU,sBAAsB;;2FAAtB,sBAAsB;kBAtWlC,SAAS;+BAEI,oBAAoB,YAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsUH","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          <div 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'\"\r\n            />\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-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)\"/>\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)\" />\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'\"\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\">\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\" />\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\" />\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\" />\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\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  }\r\n}\r\n"]}
716
+ //# 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,gEAAgE;IAEhE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;8GAVU,sBAAsB;kGAAtB,sBAAsB,iFAlX7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsVH,6qWA4BU,sBAAsB;;2FAAtB,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'\"\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)\"/>\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)\" />\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'\"\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\">\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\" />\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\" />\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\" />\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\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  }\r\n}\r\n"]}
@@ -350,17 +350,25 @@ export class AttributeFlexComponent extends AttributeBase {
350
350
  <!-- Grid -->
351
351
  <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
352
352
  <div #attributeRef class="d-flex flex-column cod-type-ga">
353
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
353
+ <div *ngIf="attribute.idAttribute" class="d-flex cod-top-label mr-1">
354
354
  <div>
355
355
  {{attribute.displayName}}
356
356
  </div>
357
357
  <div *ngIf="editInline" style="margin-left: auto;">
358
- <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
358
+ <button
359
+ class="btn-ga"
360
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
361
+ (click)="addGridRow(editGridModal, attribute.idAttribute)"
362
+ >
359
363
  <span class="ga-icon">
360
364
  <i class="fas fa-plus fa-xs"></i>
361
365
  </span>
362
366
  </button>
363
- <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
367
+ <button
368
+ class="btn-ga"
369
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
370
+ (click)="removeGridRow(attribute.idAttribute)"
371
+ >
364
372
  <span class="ga-icon">
365
373
  <i class="fas fa-minus fa-xs"></i>
366
374
  </span>
@@ -398,8 +406,20 @@ export class AttributeFlexComponent extends AttributeBase {
398
406
  </ng-container>
399
407
  </div>
400
408
  <div class="modal-footer">
401
- <button class="btn btn-primary" (click)="close('Save')">Save</button>
402
- <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
409
+ <button
410
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
411
+ class="btn btn-primary"
412
+ (click)="close('Save')"
413
+ >
414
+ Save
415
+ </button>
416
+
417
+ <button
418
+ class="btn btn-primary"
419
+ (click)="close('Cancel')"
420
+ >
421
+ Cancel
422
+ </button>
403
423
  </div>
404
424
  </ng-template>
405
425
  `, isInline: true, 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"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i7.NgxMatDatetimepicker, selector: "ngx-mat-datetime-picker", exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i7.NgxMatDatepickerInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "min", "max", "matDatepickerFilter"], exportAs: ["ngxMatDatepickerInput"] }, { kind: "component", type: i8.AttributeEditComponent, selector: "hci-attribute-edit" }], encapsulation: i0.ViewEncapsulation.None }); }
@@ -708,17 +728,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
708
728
  <!-- Grid -->
709
729
  <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
710
730
  <div #attributeRef class="d-flex flex-column cod-type-ga">
711
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
731
+ <div *ngIf="attribute.idAttribute" class="d-flex cod-top-label mr-1">
712
732
  <div>
713
733
  {{attribute.displayName}}
714
734
  </div>
715
735
  <div *ngIf="editInline" style="margin-left: auto;">
716
- <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
736
+ <button
737
+ class="btn-ga"
738
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
739
+ (click)="addGridRow(editGridModal, attribute.idAttribute)"
740
+ >
717
741
  <span class="ga-icon">
718
742
  <i class="fas fa-plus fa-xs"></i>
719
743
  </span>
720
744
  </button>
721
- <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
745
+ <button
746
+ class="btn-ga"
747
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
748
+ (click)="removeGridRow(attribute.idAttribute)"
749
+ >
722
750
  <span class="ga-icon">
723
751
  <i class="fas fa-minus fa-xs"></i>
724
752
  </span>
@@ -756,10 +784,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
756
784
  </ng-container>
757
785
  </div>
758
786
  <div class="modal-footer">
759
- <button class="btn btn-primary" (click)="close('Save')">Save</button>
760
- <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
787
+ <button
788
+ [disabled]="(!this.attributeService.editButtonsEnabled)"
789
+ class="btn btn-primary"
790
+ (click)="close('Save')"
791
+ >
792
+ Save
793
+ </button>
794
+
795
+ <button
796
+ class="btn btn-primary"
797
+ (click)="close('Cancel')"
798
+ >
799
+ Cancel
800
+ </button>
761
801
  </div>
762
802
  </ng-template>
763
803
  `, 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"] }]
764
804
  }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
765
- //# 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;AAgYH,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,iFA5XvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkWT;;2FA0BU,sBAAsB;kBA/XlC,SAAS;+BACE,oBAAoB,iBACf,iBAAiB,CAAC,IAAI,YAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkWT","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.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div *ngIf=\"editInline\" 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 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 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  ,\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"]}
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"]}