@huntsman-cancer-institute/cod 17.0.5 → 17.0.7

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.
@@ -229,8 +229,8 @@ export class AttributeEditComponent extends AttributeBase {
229
229
  [checked]="attributeChoice.value"
230
230
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
231
231
  (change)="valueMultiChoiceChange(attributeChoice)"
232
- class="form-control checkbox mt-auto mb-auto mr-2" />
233
- <div class="cod-label pl-1">
232
+ class="form-control checkbox mt-auto mb-auto me-2" />
233
+ <div class="cod-label ps-1">
234
234
  {{attributeChoice.choice}}
235
235
  </div>
236
236
  </div>
@@ -255,7 +255,7 @@ export class AttributeEditComponent extends AttributeBase {
255
255
  (change)="valueMultiDictChange(entry)"
256
256
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
257
257
  class="form-control checkbox" />
258
- <div class="cod-label pl-1">
258
+ <div class="cod-label ps-1">
259
259
  {{entry.display}}
260
260
  </div>
261
261
  </div>
@@ -553,8 +553,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
553
553
  [checked]="attributeChoice.value"
554
554
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
555
555
  (change)="valueMultiChoiceChange(attributeChoice)"
556
- class="form-control checkbox mt-auto mb-auto mr-2" />
557
- <div class="cod-label pl-1">
556
+ class="form-control checkbox mt-auto mb-auto me-2" />
557
+ <div class="cod-label ps-1">
558
558
  {{attributeChoice.choice}}
559
559
  </div>
560
560
  </div>
@@ -579,7 +579,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
579
579
  (change)="valueMultiDictChange(entry)"
580
580
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
581
581
  class="form-control checkbox" />
582
- <div class="cod-label pl-1">
582
+ <div class="cod-label ps-1">
583
583
  {{entry.display}}
584
584
  </div>
585
585
  </div>
@@ -669,4 +669,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
669
669
  </ng-template>
670
670
  `, 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"] }]
671
671
  }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
672
- //# 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,EAMV,SAAS,EAEV,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;;;;;;;;;AAO/D;;;GAGG;AA4VH,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,iFAzVvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT,6qWAyBU,sBAAsB;;2FAAtB,sBAAsB;kBA3VlC,SAAS;+BACE,oBAAoB,YACpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  InjectionToken,\r\n  Input,\r\n  isDevMode,\r\n  QueryList,\r\n  Renderer2,\r\n  ViewChildren\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\nimport {AttributeLongText} from \"../model/attribute-long-text.entity\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {AttributeValue} from \"../model/attribute-value.entity\";\r\nimport {AttributeChoice} from \"../model/attribute-choice.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.  This is different from the flex attribute\r\n * because components such as the grid need extra configuration for editing.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-edit\",\r\n  template: `\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          <input #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          />\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 [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 mr-2\" />\r\n              <div class=\"cod-label pl-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 pl-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    .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\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"]}
672
+ //# 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,EAMV,SAAS,EAEV,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;;;;;;;;;AAO/D;;;GAGG;AA4VH,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,iFAzVvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT,6qWAyBU,sBAAsB;;2FAAtB,sBAAsB;kBA3VlC,SAAS;+BACE,oBAAoB,YACpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  InjectionToken,\r\n  Input,\r\n  isDevMode,\r\n  QueryList,\r\n  Renderer2,\r\n  ViewChildren\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\nimport {AttributeLongText} from \"../model/attribute-long-text.entity\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {AttributeValue} from \"../model/attribute-value.entity\";\r\nimport {AttributeChoice} from \"../model/attribute-choice.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.  This is different from the flex attribute\r\n * because components such as the grid need extra configuration for editing.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-edit\",\r\n  template: `\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          <input #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          />\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 [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    .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\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"]}
@@ -53,8 +53,8 @@ export class AttributeFlexComponent extends AttributeBase {
53
53
  <ng-container *ngIf="attribute.codeAttributeDataType === 'LINE'">
54
54
  <div #attributeRef
55
55
  class="d-flex flex-row cod-type-line">
56
- <div class="d-flex cod-line mr-1 mt-auto mb-auto flex-shrink-0"></div>
57
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1 flex-shrink-0">
56
+ <div class="d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0"></div>
57
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1 flex-shrink-0">
58
58
  {{attribute.displayName}}
59
59
  </div>
60
60
  <div class="d-flex cod-line grow mt-auto mb-auto"></div>
@@ -65,7 +65,7 @@ export class AttributeFlexComponent extends AttributeBase {
65
65
  <ng-container *ngIf="attribute.codeAttributeDataType === 'LABEL'">
66
66
  <div #attributeRef
67
67
  class="d-flex flex-column cod-type-label">
68
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
68
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
69
69
  {{attribute.displayName}}
70
70
  </div>
71
71
  </div>
@@ -75,7 +75,7 @@ export class AttributeFlexComponent extends AttributeBase {
75
75
  <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
76
76
  <div #attributeRef
77
77
  class="d-flex flex-column cod-type-s">
78
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
78
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
79
79
  {{attribute.displayName}}
80
80
  </div>
81
81
  <div class="d-flex flex-grow-1">
@@ -93,7 +93,7 @@ export class AttributeFlexComponent extends AttributeBase {
93
93
  <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
94
94
  <div #attributeRef
95
95
  class="d-flex flex-column cod-type-txt">
96
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
96
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
97
97
  {{attribute.displayName}}
98
98
  </div>
99
99
  <div class="d-flex flex-grow-1">
@@ -115,7 +115,7 @@ export class AttributeFlexComponent extends AttributeBase {
115
115
  <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
116
116
  <div #attributeRef
117
117
  class="d-flex flex-column cod-type-cb">
118
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
118
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
119
119
  {{attribute.displayName}}
120
120
  </div>
121
121
  <div class="d-flex flex-grow-1">
@@ -133,7 +133,7 @@ export class AttributeFlexComponent extends AttributeBase {
133
133
  <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
134
134
  <div #attributeRef
135
135
  class="d-flex flex-column cod-type-n">
136
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
136
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
137
137
  {{attribute.displayName}}
138
138
  </div>
139
139
  <div class="d-flex flex-grow-1">
@@ -151,7 +151,7 @@ export class AttributeFlexComponent extends AttributeBase {
151
151
  <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
152
152
  <div #attributeRef
153
153
  class="d-flex flex-column cod-type-i">
154
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
154
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
155
155
  {{attribute.displayName}}
156
156
  </div>
157
157
  <div class="d-flex flex-grow-1">
@@ -169,7 +169,7 @@ export class AttributeFlexComponent extends AttributeBase {
169
169
  <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
170
170
  <div #attributeRef
171
171
  class="d-flex flex-column cod-type-d">
172
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
172
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
173
173
  {{attribute.displayName}}
174
174
  </div>
175
175
  <div class="d-flex flex-grow-1">
@@ -191,7 +191,7 @@ export class AttributeFlexComponent extends AttributeBase {
191
191
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
192
192
  <div #attributeRef
193
193
  class="d-flex flex-column cod-type-dt">
194
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
194
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
195
195
  {{attribute.displayName}}
196
196
  </div>
197
197
  <div class="d-flex flex-grow-1">
@@ -213,7 +213,7 @@ export class AttributeFlexComponent extends AttributeBase {
213
213
  <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
214
214
  <div #attributeRef
215
215
  class="d-flex flex-column cod-type-b">
216
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
216
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
217
217
  {{attribute.displayName}}
218
218
  </div>
219
219
  <div class="d-flex flex-grow-1">
@@ -234,7 +234,7 @@ export class AttributeFlexComponent extends AttributeBase {
234
234
  <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
235
235
  <div #attributeRef
236
236
  class="d-flex flex-column cod-type-eb">
237
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
237
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
238
238
  {{attribute.displayName}}
239
239
  </div>
240
240
  <div class="d-flex flex-grow-1">
@@ -256,7 +256,7 @@ export class AttributeFlexComponent extends AttributeBase {
256
256
  <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
257
257
  <div #attributeRef
258
258
  class="d-flex flex-column cod-type-ac-n">
259
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
259
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
260
260
  {{attribute.displayName}}
261
261
  </div>
262
262
  <div class="d-flex flex-grow-1">
@@ -278,7 +278,7 @@ export class AttributeFlexComponent extends AttributeBase {
278
278
  <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
279
279
  <div #attributeRef
280
280
  class="d-flex flex-column cod-type-ac-y">
281
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
281
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
282
282
  {{attribute.displayName}}
283
283
  </div>
284
284
  <div class="d-flex flex-grow-1 flex-column y-auto" style="max-height: 125px; row-gap: 5px">
@@ -290,7 +290,7 @@ export class AttributeFlexComponent extends AttributeBase {
290
290
  (change)="valueMultiChoiceChange(attributeChoice)"
291
291
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
292
292
  class="form-control checkbox" />
293
- <div class="cod-label pl-1">
293
+ <div class="cod-label ps-1">
294
294
  {{attributeChoice.choice}}
295
295
  </div>
296
296
  </div>
@@ -303,7 +303,7 @@ export class AttributeFlexComponent extends AttributeBase {
303
303
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
304
304
  <div #attributeRef
305
305
  class="d-flex flex-column cod-type-ac-y">
306
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
306
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
307
307
  {{attribute.displayName}}
308
308
  </div>
309
309
  <div class="d-flex flex-grow-1 flex-column y-auto" style="max-height: 125px; row-gap: 5px">
@@ -315,7 +315,7 @@ export class AttributeFlexComponent extends AttributeBase {
315
315
  (change)="valueMultiDictChange(entry)"
316
316
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
317
317
  class="form-control checkbox" />
318
- <div class="cod-label pl-1">
318
+ <div class="cod-label ps-1">
319
319
  {{entry.display}}
320
320
  </div>
321
321
  </div>
@@ -328,7 +328,7 @@ export class AttributeFlexComponent extends AttributeBase {
328
328
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
329
329
  <div #attributeRef
330
330
  class="d-flex flex-column cod-type-dict">
331
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
331
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
332
332
  {{attribute.displayName}}
333
333
  </div>
334
334
  <div class="d-flex flex-grow-1">
@@ -350,7 +350,7 @@ 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 mr-1">
353
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
354
354
  <div>
355
355
  {{attribute.displayName}}
356
356
  </div>
@@ -411,8 +411,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
411
411
  <ng-container *ngIf="attribute.codeAttributeDataType === 'LINE'">
412
412
  <div #attributeRef
413
413
  class="d-flex flex-row cod-type-line">
414
- <div class="d-flex cod-line mr-1 mt-auto mb-auto flex-shrink-0"></div>
415
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1 flex-shrink-0">
414
+ <div class="d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0"></div>
415
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1 flex-shrink-0">
416
416
  {{attribute.displayName}}
417
417
  </div>
418
418
  <div class="d-flex cod-line grow mt-auto mb-auto"></div>
@@ -423,7 +423,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
423
423
  <ng-container *ngIf="attribute.codeAttributeDataType === 'LABEL'">
424
424
  <div #attributeRef
425
425
  class="d-flex flex-column cod-type-label">
426
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
426
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
427
427
  {{attribute.displayName}}
428
428
  </div>
429
429
  </div>
@@ -433,7 +433,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
433
433
  <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
434
434
  <div #attributeRef
435
435
  class="d-flex flex-column cod-type-s">
436
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
436
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
437
437
  {{attribute.displayName}}
438
438
  </div>
439
439
  <div class="d-flex flex-grow-1">
@@ -451,7 +451,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
451
451
  <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
452
452
  <div #attributeRef
453
453
  class="d-flex flex-column cod-type-txt">
454
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
454
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
455
455
  {{attribute.displayName}}
456
456
  </div>
457
457
  <div class="d-flex flex-grow-1">
@@ -473,7 +473,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
473
473
  <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
474
474
  <div #attributeRef
475
475
  class="d-flex flex-column cod-type-cb">
476
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
476
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
477
477
  {{attribute.displayName}}
478
478
  </div>
479
479
  <div class="d-flex flex-grow-1">
@@ -491,7 +491,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
491
491
  <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
492
492
  <div #attributeRef
493
493
  class="d-flex flex-column cod-type-n">
494
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
494
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
495
495
  {{attribute.displayName}}
496
496
  </div>
497
497
  <div class="d-flex flex-grow-1">
@@ -509,7 +509,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
509
509
  <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
510
510
  <div #attributeRef
511
511
  class="d-flex flex-column cod-type-i">
512
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
512
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
513
513
  {{attribute.displayName}}
514
514
  </div>
515
515
  <div class="d-flex flex-grow-1">
@@ -527,7 +527,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
527
527
  <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
528
528
  <div #attributeRef
529
529
  class="d-flex flex-column cod-type-d">
530
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
530
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
531
531
  {{attribute.displayName}}
532
532
  </div>
533
533
  <div class="d-flex flex-grow-1">
@@ -549,7 +549,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
549
549
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
550
550
  <div #attributeRef
551
551
  class="d-flex flex-column cod-type-dt">
552
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
552
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
553
553
  {{attribute.displayName}}
554
554
  </div>
555
555
  <div class="d-flex flex-grow-1">
@@ -571,7 +571,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
571
571
  <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
572
572
  <div #attributeRef
573
573
  class="d-flex flex-column cod-type-b">
574
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
574
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
575
575
  {{attribute.displayName}}
576
576
  </div>
577
577
  <div class="d-flex flex-grow-1">
@@ -592,7 +592,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
592
592
  <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
593
593
  <div #attributeRef
594
594
  class="d-flex flex-column cod-type-eb">
595
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
595
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
596
596
  {{attribute.displayName}}
597
597
  </div>
598
598
  <div class="d-flex flex-grow-1">
@@ -614,7 +614,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
614
614
  <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
615
615
  <div #attributeRef
616
616
  class="d-flex flex-column cod-type-ac-n">
617
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
617
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
618
618
  {{attribute.displayName}}
619
619
  </div>
620
620
  <div class="d-flex flex-grow-1">
@@ -636,7 +636,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
636
636
  <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
637
637
  <div #attributeRef
638
638
  class="d-flex flex-column cod-type-ac-y">
639
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
639
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
640
640
  {{attribute.displayName}}
641
641
  </div>
642
642
  <div class="d-flex flex-grow-1 flex-column y-auto" style="max-height: 125px; row-gap: 5px">
@@ -648,7 +648,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
648
648
  (change)="valueMultiChoiceChange(attributeChoice)"
649
649
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
650
650
  class="form-control checkbox" />
651
- <div class="cod-label pl-1">
651
+ <div class="cod-label ps-1">
652
652
  {{attributeChoice.choice}}
653
653
  </div>
654
654
  </div>
@@ -661,7 +661,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
661
661
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
662
662
  <div #attributeRef
663
663
  class="d-flex flex-column cod-type-ac-y">
664
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
664
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
665
665
  {{attribute.displayName}}
666
666
  </div>
667
667
  <div class="d-flex flex-grow-1 flex-column y-auto" style="max-height: 125px; row-gap: 5px">
@@ -673,7 +673,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
673
673
  (change)="valueMultiDictChange(entry)"
674
674
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
675
675
  class="form-control checkbox" />
676
- <div class="cod-label pl-1">
676
+ <div class="cod-label ps-1">
677
677
  {{entry.display}}
678
678
  </div>
679
679
  </div>
@@ -686,7 +686,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
686
686
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
687
687
  <div #attributeRef
688
688
  class="d-flex flex-column cod-type-dict">
689
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
689
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
690
690
  {{attribute.displayName}}
691
691
  </div>
692
692
  <div class="d-flex flex-grow-1">
@@ -708,7 +708,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
708
708
  <!-- Grid -->
709
709
  <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
710
710
  <div #attributeRef class="d-flex flex-column cod-type-ga">
711
- <div *ngIf="attribute.displayName" class="d-flex cod-top-label mr-1">
711
+ <div *ngIf="attribute.displayName" class="d-flex cod-top-label me-1">
712
712
  <div>
713
713
  {{attribute.displayName}}
714
714
  </div>
@@ -762,4 +762,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
762
762
  </ng-template>
763
763
  `, 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
764
  }], 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 mr-1 mt-auto mb-auto flex-shrink-0\"></div>\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 mr-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 pl-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 mr-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 pl-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 mr-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 mr-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"]}
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"]}