@huntsman-cancer-institute/cod 17.10.4 → 17.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -88,7 +88,7 @@ export class AttributeFlexComponent extends AttributeBase {
88
88
  [(ngModel)]="attributeValues[0].valueString"
89
89
  (ngModelChange)="valueStringChange($event)"
90
90
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
91
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
91
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
92
92
  </div>
93
93
  </div>
94
94
  </ng-container>
@@ -110,7 +110,7 @@ export class AttributeFlexComponent extends AttributeBase {
110
110
  [ngModel]="attributeValues[0].valueLongText.textData"
111
111
  (change)="valueTextChange($event)"
112
112
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
113
- class="form-control">
113
+ class="form-control custom-input-text">
114
114
  </textarea>
115
115
  </div>
116
116
  </div>
@@ -129,7 +129,7 @@ export class AttributeFlexComponent extends AttributeBase {
129
129
  [checked]="attributeValues[0].valueString === 'Y'"
130
130
  (change)="valueCheckboxChange($event)"
131
131
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
132
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
132
+ class="form-check-input m-0" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
133
133
  </div>
134
134
  </div>
135
135
  </ng-container>
@@ -147,7 +147,7 @@ export class AttributeFlexComponent extends AttributeBase {
147
147
  [(ngModel)]="attributeValues[0].valueNumeric"
148
148
  (ngModelChange)="valueNumericChange($event)"
149
149
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
150
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
150
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
151
151
  </div>
152
152
  </div>
153
153
  </ng-container>
@@ -165,7 +165,7 @@ export class AttributeFlexComponent extends AttributeBase {
165
165
  [(ngModel)]="attributeValues[0].valueInteger"
166
166
  (ngModelChange)="valueIntegerChange($event)"
167
167
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
168
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
168
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
169
169
  </div>
170
170
  </div>
171
171
  </ng-container>
@@ -180,14 +180,14 @@ export class AttributeFlexComponent extends AttributeBase {
180
180
  <div class="d-flex flex-grow-1">
181
181
  <input #inputRef
182
182
  matInput
183
- name="valueDate"
184
- [(ngModel)]="attributeValues[0].valueDate"
183
+ name="valueDate"
184
+ [(ngModel)]="attributeValues[0].valueDate"
185
185
  (ngModelChange)="valueDateChange($event)"
186
186
  [matDatepicker]="valueDate"
187
187
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
188
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
188
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
189
189
  <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
190
- <mat-datepicker #valueDate></mat-datepicker>
190
+ <mat-datepicker #valueDate></mat-datepicker>
191
191
  </div>
192
192
  </div>
193
193
  </ng-container>
@@ -203,7 +203,7 @@ export class AttributeFlexComponent extends AttributeBase {
203
203
  <input #inputRef
204
204
  matInput
205
205
  name="valueDateTime"
206
- class="form-control"
206
+ class="form-control custom-input-text"
207
207
  [(ngModel)]="attributeValues[0].date"
208
208
  (ngModelChange)="valueDateChange($event)"
209
209
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
@@ -226,7 +226,7 @@ export class AttributeFlexComponent extends AttributeBase {
226
226
  [ngModel]="attributeValues[0].valueString"
227
227
  (ngModelChange)="valueStringChange($event)"
228
228
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
229
- class="form-control edit-renderer">
229
+ class="form-select edit-renderer custom-caret">
230
230
  <option [ngValue]="undefined"></option>
231
231
  <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
232
232
  <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
@@ -247,7 +247,7 @@ export class AttributeFlexComponent extends AttributeBase {
247
247
  [ngModel]="attributeValues[0].valueString"
248
248
  (ngModelChange)="valueStringChange($event)"
249
249
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
250
- class="form-control edit-renderer">
250
+ class="form-select edit-renderer custom-caret">
251
251
  <option [ngValue]="undefined"></option>
252
252
  <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
253
253
  <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
@@ -269,7 +269,7 @@ export class AttributeFlexComponent extends AttributeBase {
269
269
  [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
270
270
  (ngModelChange)="valueChoiceChange($event)"
271
271
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
272
- class="form-control edit-renderer">
272
+ class="form-select edit-renderer custom-caret">
273
273
  <option [ngValue]="undefined"></option>
274
274
  <option *ngFor="let attributeChoice of attributeChoices"
275
275
  [ngValue]="attributeChoice.idAttributeChoice">
@@ -294,7 +294,7 @@ export class AttributeFlexComponent extends AttributeBase {
294
294
  [checked]="attributeChoice.value"
295
295
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
296
296
  (change)="valueMultiChoiceChange(attributeChoice)"
297
- class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
297
+ class="form-check-input m-0 checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
298
298
  <div class="cod-label ps-1">
299
299
  {{attributeChoice.choice}}
300
300
  </div>
@@ -303,7 +303,7 @@ export class AttributeFlexComponent extends AttributeBase {
303
303
  </div>
304
304
  </div>
305
305
  </ng-container>
306
-
306
+
307
307
  <!-- Dictionary: Multi -->
308
308
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
309
309
  <div #attributeRef
@@ -318,7 +318,7 @@ export class AttributeFlexComponent extends AttributeBase {
318
318
  [checked]="entry.checked"
319
319
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
320
320
  (change)="valueMultiDictChange(entry)"
321
- class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
321
+ class="form-check-input m-0 checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
322
322
  <div class="cod-label ps-1">
323
323
  {{entry.display}}
324
324
  </div>
@@ -326,7 +326,7 @@ export class AttributeFlexComponent extends AttributeBase {
326
326
  </ng-container>
327
327
  </div>
328
328
  </div>
329
- </ng-container>
329
+ </ng-container>
330
330
 
331
331
  <!-- Dictionary -->
332
332
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
@@ -340,7 +340,7 @@ export class AttributeFlexComponent extends AttributeBase {
340
340
  [ngModel]="attributeValues[0].valueIdDictionary"
341
341
  (ngModelChange)="valueDictChange($event)"
342
342
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
343
- class="form-control edit-renderer">
343
+ class="form-select edit-renderer custom-caret">
344
344
  <option [ngValue]="undefined"></option>
345
345
  <option *ngFor="let entry of dictionaryEntries"
346
346
  [ngValue]="entry.value">
@@ -361,7 +361,7 @@ export class AttributeFlexComponent extends AttributeBase {
361
361
  <div *ngIf="editInline" style="margin-left: auto;">
362
362
  <button
363
363
  class="btn-ga"
364
- [disabled]="(!this.attributeService.editButtonsEnabled)"
364
+ [disabled]="(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'"
365
365
  (click)="addGridRow(editGridModal, attribute.idAttribute)"
366
366
  >
367
367
  <span class="ga-icon">
@@ -370,7 +370,7 @@ export class AttributeFlexComponent extends AttributeBase {
370
370
  </button>
371
371
  <button
372
372
  class="btn-ga"
373
- [disabled]="(!this.attributeService.editButtonsEnabled)"
373
+ [disabled]="(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'"
374
374
  (click)="removeGridRow(attribute.idAttribute)"
375
375
  >
376
376
  <span class="ga-icon">
@@ -379,7 +379,7 @@ export class AttributeFlexComponent extends AttributeBase {
379
379
  </button>
380
380
  </div>
381
381
  </div>
382
- <div class="d-flex flex-grow-1">
382
+ <div class="d-flex flex-grow-1">
383
383
  <ag-grid-angular #gridAttribute
384
384
  class="ag-theme-alpine"
385
385
  (gridReady)="this.onGridReady($event)"
@@ -396,7 +396,7 @@ export class AttributeFlexComponent extends AttributeBase {
396
396
  </div>
397
397
  </div>
398
398
  </ng-container>
399
-
399
+
400
400
  <ng-template #editGridModal let-close="close">
401
401
  <div class="modal-header">
402
402
  {{attribute.displayName}} Grid Row
@@ -426,7 +426,7 @@ export class AttributeFlexComponent extends AttributeBase {
426
426
  </button>
427
427
  </div>
428
428
  </ng-template>
429
- `, isInline: true, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i7.NgxMatDatetimepicker, selector: "ngx-mat-datetime-picker", exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i7.NgxMatDatepickerInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "min", "max", "matDatepickerFilter"], exportAs: ["ngxMatDatepickerInput"] }, { kind: "component", type: i8.AttributeEditComponent, selector: "hci-attribute-edit" }], encapsulation: i0.ViewEncapsulation.None }); }
429
+ `, isInline: true, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}.form-select.custom-caret{background-size:.46rem;background-position:right .3rem center;color:var(--bluewarm-darkest)}.cod-type-s .custom-input-text,.cod-type-txt .custom-input-text,.cod-type-n .custom-input-text,.cod-type-i .custom-input-text,.cod-type-d .custom-input-text,.cod-type-dt .custom-input-text{color:var(--bluewarm-darkest)}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i7.NgxMatDatetimepicker, selector: "ngx-mat-datetime-picker", exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i7.NgxMatDatepickerInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "min", "max", "matDatepickerFilter"], exportAs: ["ngxMatDatepickerInput"] }, { kind: "component", type: i8.AttributeEditComponent, selector: "hci-attribute-edit" }], encapsulation: i0.ViewEncapsulation.None }); }
430
430
  }
431
431
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AttributeFlexComponent, decorators: [{
432
432
  type: Component,
@@ -466,7 +466,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
466
466
  [(ngModel)]="attributeValues[0].valueString"
467
467
  (ngModelChange)="valueStringChange($event)"
468
468
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
469
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
469
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
470
470
  </div>
471
471
  </div>
472
472
  </ng-container>
@@ -488,7 +488,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
488
488
  [ngModel]="attributeValues[0].valueLongText.textData"
489
489
  (change)="valueTextChange($event)"
490
490
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
491
- class="form-control">
491
+ class="form-control custom-input-text">
492
492
  </textarea>
493
493
  </div>
494
494
  </div>
@@ -507,7 +507,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
507
507
  [checked]="attributeValues[0].valueString === 'Y'"
508
508
  (change)="valueCheckboxChange($event)"
509
509
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
510
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
510
+ class="form-check-input m-0" attr.aria-label="hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
511
511
  </div>
512
512
  </div>
513
513
  </ng-container>
@@ -525,7 +525,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
525
525
  [(ngModel)]="attributeValues[0].valueNumeric"
526
526
  (ngModelChange)="valueNumericChange($event)"
527
527
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
528
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
528
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
529
529
  </div>
530
530
  </div>
531
531
  </ng-container>
@@ -543,7 +543,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
543
543
  [(ngModel)]="attributeValues[0].valueInteger"
544
544
  (ngModelChange)="valueIntegerChange($event)"
545
545
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
546
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
546
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}"/>
547
547
  </div>
548
548
  </div>
549
549
  </ng-container>
@@ -558,14 +558,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
558
558
  <div class="d-flex flex-grow-1">
559
559
  <input #inputRef
560
560
  matInput
561
- name="valueDate"
562
- [(ngModel)]="attributeValues[0].valueDate"
561
+ name="valueDate"
562
+ [(ngModel)]="attributeValues[0].valueDate"
563
563
  (ngModelChange)="valueDateChange($event)"
564
564
  [matDatepicker]="valueDate"
565
565
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
566
- class="form-control" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
566
+ class="form-control custom-input-text" attr.aria-label="hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}">
567
567
  <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
568
- <mat-datepicker #valueDate></mat-datepicker>
568
+ <mat-datepicker #valueDate></mat-datepicker>
569
569
  </div>
570
570
  </div>
571
571
  </ng-container>
@@ -581,7 +581,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
581
581
  <input #inputRef
582
582
  matInput
583
583
  name="valueDateTime"
584
- class="form-control"
584
+ class="form-control custom-input-text"
585
585
  [(ngModel)]="attributeValues[0].date"
586
586
  (ngModelChange)="valueDateChange($event)"
587
587
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
@@ -604,7 +604,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
604
604
  [ngModel]="attributeValues[0].valueString"
605
605
  (ngModelChange)="valueStringChange($event)"
606
606
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
607
- class="form-control edit-renderer">
607
+ class="form-select edit-renderer custom-caret">
608
608
  <option [ngValue]="undefined"></option>
609
609
  <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
610
610
  <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
@@ -625,7 +625,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
625
625
  [ngModel]="attributeValues[0].valueString"
626
626
  (ngModelChange)="valueStringChange($event)"
627
627
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
628
- class="form-control edit-renderer">
628
+ class="form-select edit-renderer custom-caret">
629
629
  <option [ngValue]="undefined"></option>
630
630
  <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
631
631
  <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
@@ -647,7 +647,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
647
647
  [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
648
648
  (ngModelChange)="valueChoiceChange($event)"
649
649
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
650
- class="form-control edit-renderer">
650
+ class="form-select edit-renderer custom-caret">
651
651
  <option [ngValue]="undefined"></option>
652
652
  <option *ngFor="let attributeChoice of attributeChoices"
653
653
  [ngValue]="attributeChoice.idAttributeChoice">
@@ -672,7 +672,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
672
672
  [checked]="attributeChoice.value"
673
673
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
674
674
  (change)="valueMultiChoiceChange(attributeChoice)"
675
- class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
675
+ class="form-check-input m-0 checkbox" attr.aria-label="hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}"/>
676
676
  <div class="cod-label ps-1">
677
677
  {{attributeChoice.choice}}
678
678
  </div>
@@ -681,7 +681,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
681
681
  </div>
682
682
  </div>
683
683
  </ng-container>
684
-
684
+
685
685
  <!-- Dictionary: Multi -->
686
686
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
687
687
  <div #attributeRef
@@ -696,7 +696,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
696
696
  [checked]="entry.checked"
697
697
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
698
698
  (change)="valueMultiDictChange(entry)"
699
- class="form-control checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
699
+ class="form-check-input m-0 checkbox" attr.aria-label="hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}"/>
700
700
  <div class="cod-label ps-1">
701
701
  {{entry.display}}
702
702
  </div>
@@ -704,7 +704,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
704
704
  </ng-container>
705
705
  </div>
706
706
  </div>
707
- </ng-container>
707
+ </ng-container>
708
708
 
709
709
  <!-- Dictionary -->
710
710
  <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
@@ -718,7 +718,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
718
718
  [ngModel]="attributeValues[0].valueIdDictionary"
719
719
  (ngModelChange)="valueDictChange($event)"
720
720
  [disabled]="!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'"
721
- class="form-control edit-renderer">
721
+ class="form-select edit-renderer custom-caret">
722
722
  <option [ngValue]="undefined"></option>
723
723
  <option *ngFor="let entry of dictionaryEntries"
724
724
  [ngValue]="entry.value">
@@ -739,7 +739,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
739
739
  <div *ngIf="editInline" style="margin-left: auto;">
740
740
  <button
741
741
  class="btn-ga"
742
- [disabled]="(!this.attributeService.editButtonsEnabled)"
742
+ [disabled]="(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'"
743
743
  (click)="addGridRow(editGridModal, attribute.idAttribute)"
744
744
  >
745
745
  <span class="ga-icon">
@@ -748,7 +748,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
748
748
  </button>
749
749
  <button
750
750
  class="btn-ga"
751
- [disabled]="(!this.attributeService.editButtonsEnabled)"
751
+ [disabled]="(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'"
752
752
  (click)="removeGridRow(attribute.idAttribute)"
753
753
  >
754
754
  <span class="ga-icon">
@@ -757,7 +757,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
757
757
  </button>
758
758
  </div>
759
759
  </div>
760
- <div class="d-flex flex-grow-1">
760
+ <div class="d-flex flex-grow-1">
761
761
  <ag-grid-angular #gridAttribute
762
762
  class="ag-theme-alpine"
763
763
  (gridReady)="this.onGridReady($event)"
@@ -774,7 +774,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
774
774
  </div>
775
775
  </div>
776
776
  </ng-container>
777
-
777
+
778
778
  <ng-template #editGridModal let-close="close">
779
779
  <div class="modal-header">
780
780
  {{attribute.displayName}} Grid Row
@@ -804,6 +804,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
804
804
  </button>
805
805
  </div>
806
806
  </ng-template>
807
- `, 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"] }]
807
+ `, 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}.form-select.custom-caret{background-size:.46rem;background-position:right .3rem center;color:var(--bluewarm-darkest)}.cod-type-s .custom-input-text,.cod-type-txt .custom-input-text,.cod-type-n .custom-input-text,.cod-type-i .custom-input-text,.cod-type-d .custom-input-text,.cod-type-dt .custom-input-text{color:var(--bluewarm-darkest)}\n"] }]
808
808
  }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }] });
809
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-flex.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-flex.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAU,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AAGpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;AAI/D;;;;GAIG;AAoZH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,YACE,gBAAkC,EAClC,UAAsB,EACtB,QAAmB,EACnB,YAAsB;QAEtB,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;QAP9D,2CAAsC,GAAG,EAAE,CAAC;IAQ5C,CAAC;IAED,eAAe;QACb,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;YACjD,IAAI,CAAC,sCAAsC,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;QAC3E,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,UAAgC,EAAE,OAAc;QACpE,KAAK,CAAC,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAEjD,IAAI,KAAK,GAAW,CAAC,CAAC;QACtB,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC;QACvB,CAAC;QAED,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YACjC,IAAI,YAAY,GAAW,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;YAEnE,KAAK,IAAI,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC3B,IAAI,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,WAAW,KAAK,SAAS,CAAC,WAAW,EAAE,CAAC;oBACzF,MAAM,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC;oBAC9B,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;oBACnC,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;+GA5CU,sBAAsB;mGAAtB,sBAAsB,iFAhZvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsXT;;4FA0BU,sBAAsB;kBAnZlC,SAAS;+BACE,oBAAoB,iBACf,iBAAiB,CAAC,IAAI,YAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsXT","sourcesContent":["import {Component, ElementRef, Inject, Renderer2, ViewEncapsulation} from \"@angular/core\";\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\n\r\nimport {AttributeBase} from \"./attribute-base\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * The view for attributes organized in a flex layout.  This will arrange all attributes in a four column layout\r\n * with grids taking up all 12 columns.  The attributes here will fill the this parent component which defines the\r\n * column size.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-flex\",\r\n  encapsulation: ViewEncapsulation.None,\r\n  template: `\r\n    <!-- Line -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LINE'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row cod-type-line\">\r\n        <div class=\"d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0\"></div>\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1 flex-shrink-0\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex cod-line grow mt-auto mb-auto\"></div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Label -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LABEL'\">\r\n      <div #attributeRef\r\n          class=\"d-flex flex-column cod-type-label\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n        <!-- String -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column cod-type-s\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n              {{ attribute.displayName }}\r\n            </div>\r\n            <div class=\"d-flex flex-grow-1\">\r\n              <input #inputRef\r\n                     type=\"text\"\r\n                     [(ngModel)]=\"attributeValues[0].valueString\"\r\n                     (ngModelChange)=\"valueStringChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-txt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <textarea\r\n            #inputRef\r\n            type=\"text\"\r\n            spellcheck=\"spellcheck\"\r\n            lang=\"en\"\r\n            [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n            (change)=\"valueTextChange($event)\"\r\n            [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\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' || attribute.isActive === 'N'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueNumeric\"\r\n                 (ngModelChange)=\"valueNumericChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-i\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueInteger\"\r\n                 (ngModelChange)=\"valueIntegerChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-d\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n           <input #inputRef\r\n              matInput\r\n              name=\"valueDate\"          \r\n              [(ngModel)]=\"attributeValues[0].valueDate\" \r\n              (ngModelChange)=\"valueDateChange($event)\"\r\n              [matDatepicker]=\"valueDate\"\r\n              [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n              class=\"form-control\" attr.aria-label=\"hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n            <mat-datepicker-toggle  matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n            <mat-datepicker #valueDate></mat-datepicker>  \r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 matInput\r\n                 name=\"valueDateTime\"\r\n                 class=\"form-control\"\r\n                 [(ngModel)]=\"attributeValues[0].date\"\r\n                 (ngModelChange)=\"valueDateChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 [ngxMatDatetimePicker]=\"dtpicker\" attr.aria-label=\"hci-ng-attribute-flex-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n               <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n               <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-b\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\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' || attribute.isActive === 'N'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n            <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select\r\n            [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n            (ngModelChange)=\"valueChoiceChange($event)\"\r\n        \t  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\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' || attribute.isActive === 'N'\"\r\n                     (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                     class=\"form-control checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{attributeChoice.choice}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <!-- Dictionary: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"entry.checked\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     (change)=\"valueMultiDictChange(entry)\"\r\n                     class=\"form-control checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{entry.display}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>    \r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dict\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let entry of dictionaryEntries\"\r\n                    [ngValue]=\"entry.value\">\r\n              {{ entry.display }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n      <div #attributeRef class=\"d-flex flex-column cod-type-ga\">\r\n        <div *ngIf=\"attribute.idAttribute\" class=\"d-flex cod-top-label mr-1\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div *ngIf=\"editInline\" style=\"margin-left: auto;\">\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"addGridRow(editGridModal, attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n                  (click)=\"removeGridRow(attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">             \r\n          <ag-grid-angular #gridAttribute\r\n              class=\"ag-theme-alpine\"\r\n              (gridReady)=\"this.onGridReady($event)\"\r\n              (modelUpdated)=\"onModelUpdated($event)\"\r\n              (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n              (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n              [gridOptions]=\"this.gridOptions\"\r\n              [rowSelection]=\"'single'\"\r\n              [columnDefs]=\"gridColumns\"\r\n              [rowData]=\"gridData\"\r\n              [style.width]=\"attribute.w + 'px'\"\r\n              [style.height]=\"attribute.h + 'px'\">\r\n          </ag-grid-angular>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <ng-template #editGridModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{attribute.displayName}} Grid Row\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n            <button\r\n              [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Save')\"\r\n            >\r\n              Save\r\n            </button>\r\n\r\n            <button\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Cancel')\"\r\n            >\r\n              Cancel\r\n            </button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n  ,\r\n  styles: [`\r\n  \t.hci-cod button.mat-icon-button.mat-button-base {\r\n      \theight: 20px;\r\n      \twidth: 20px;\r\n      \tline-height: unset;\r\n  \t}\r\n  \t\r\n    .btn-ga {\r\n      padding: 0px;\r\n      height: 18px;\r\n      width: 18px;\r\n    }\r\n    \r\n    .ga-icon {\r\n      font-size: .9em;\r\n      vertical-align: top;\r\n    }\r\n\r\n    .hci-cod .mat-datepicker-toggle-default-icon {\r\n      height: 20px;\r\n      width: 20px;\r\n    }\r\n `]\r\n})\r\nexport class AttributeFlexComponent extends AttributeBase {\r\n  hciNgAttributeAbsoluteInputDisplayName = \"\";\r\n  constructor(\r\n    attributeService: AttributeService,\r\n    elementRef: ElementRef,\r\n    renderer: Renderer2,\r\n    modalService: NgbModal\r\n  ) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n    if (this.attribute && this.attribute.displayName) {\r\n      this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Flex needs to extend grid columns because we no longer want to use absolute width.  Here we generate percentage\r\n   * based upon the absolute width, but still use absolute width for the min width.\r\n   *\r\n   * @param {Attribute[]} attributes\r\n   * @param {any[]} columns\r\n   */\r\n  initializeGridColumns(attributes: GraphicalAttribute[], columns: any[]) {\r\n    super.initializeGridColumns(attributes, columns);\r\n\r\n    let width: number = 0;\r\n    for (let attribute of attributes) {\r\n      width += attribute.w;\r\n    }\r\n\r\n    for (let attribute of attributes) {\r\n      let widthPercent: number = Math.floor(100 * (attribute.w / width));\r\n\r\n      for (let column of columns) {\r\n        if (column.externalConfig && column.externalConfig.idAttribute === attribute.idAttribute) {\r\n          column.minWidth = attribute.w;\r\n          column.widthPercent = widthPercent;\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}
809
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-flex.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-flex.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Inject, Renderer2, ViewEncapsulation} from \"@angular/core\";\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\n\r\nimport {AttributeBase} from \"./attribute-base\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * The view for attributes organized in a flex layout.  This will arrange all attributes in a four column layout\r\n * with grids taking up all 12 columns.  The attributes here will fill the this parent component which defines the\r\n * column size.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-flex\",\r\n  encapsulation: ViewEncapsulation.None,\r\n  template: `\r\n    <!-- Line -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LINE'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row cod-type-line\">\r\n        <div class=\"d-flex cod-line me-1 mt-auto mb-auto flex-shrink-0\"></div>\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1 flex-shrink-0\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex cod-line grow mt-auto mb-auto\"></div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Label -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'LABEL'\">\r\n      <div #attributeRef\r\n          class=\"d-flex flex-column cod-type-label\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n        <!-- String -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column cod-type-s\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n              {{ attribute.displayName }}\r\n            </div>\r\n            <div class=\"d-flex flex-grow-1\">\r\n              <input #inputRef\r\n                     type=\"text\"\r\n                     [(ngModel)]=\"attributeValues[0].valueString\"\r\n                     (ngModelChange)=\"valueStringChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     class=\"form-control custom-input-text\" attr.aria-label=\"hci-ng-attribute-flex-input-string-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-txt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <textarea\r\n            #inputRef\r\n            type=\"text\"\r\n            spellcheck=\"spellcheck\"\r\n            lang=\"en\"\r\n            [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n            (change)=\"valueTextChange($event)\"\r\n            [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n            class=\"form-control custom-input-text\">\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' || attribute.isActive === 'N'\"\r\n                 class=\"form-check-input m-0\" attr.aria-label=\"hci-ng-attribute-flex-input-checkbox-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueNumeric\"\r\n                 (ngModelChange)=\"valueNumericChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 class=\"form-control custom-input-text\" attr.aria-label=\"hci-ng-attribute-flex-input-numeric-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-i\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [(ngModel)]=\"attributeValues[0].valueInteger\"\r\n                 (ngModelChange)=\"valueIntegerChange($event)\"\r\n\t\t\t\t         [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 class=\"form-control custom-input-text\" attr.aria-label=\"hci-ng-attribute-flex-input-integer-{{hciNgAttributeAbsoluteInputDisplayName}}\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-d\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n           <input #inputRef\r\n              matInput\r\n              name=\"valueDate\"\r\n              [(ngModel)]=\"attributeValues[0].valueDate\"\r\n              (ngModelChange)=\"valueDateChange($event)\"\r\n              [matDatepicker]=\"valueDate\"\r\n              [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n              class=\"form-control custom-input-text\" attr.aria-label=\"hci-ng-attribute-flex-input-date-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n            <mat-datepicker-toggle  matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n            <mat-datepicker #valueDate></mat-datepicker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dt\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <input #inputRef\r\n                 matInput\r\n                 name=\"valueDateTime\"\r\n                 class=\"form-control custom-input-text\"\r\n                 [(ngModel)]=\"attributeValues[0].date\"\r\n                 (ngModelChange)=\"valueDateChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                 [ngxMatDatetimePicker]=\"dtpicker\" attr.aria-label=\"hci-ng-attribute-flex-input-date-time-{{hciNgAttributeAbsoluteInputDisplayName}}\">\r\n               <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n               <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-b\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  class=\"form-select edit-renderer custom-caret\">\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' || attribute.isActive === 'N'\"\r\n                  class=\"form-select edit-renderer custom-caret\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n            <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-n\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select\r\n            [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n            (ngModelChange)=\"valueChoiceChange($event)\"\r\n        \t  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n            class=\"form-select edit-renderer custom-caret\">\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' || attribute.isActive === 'N'\"\r\n                     (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                     class=\"form-check-input m-0 checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-choice-multiple-{{attributeChoice.choice}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{attributeChoice.choice}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Dictionary: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-ac-y\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1 flex-column y-auto\" style=\"max-height: 125px; row-gap: 5px\">\r\n          <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n            <div class=\"d-flex flex-shrink-0\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"entry.checked\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                     (change)=\"valueMultiDictChange(entry)\"\r\n                     class=\"form-check-input m-0 checkbox\" attr.aria-label=\"hci-ng-attribute-flex-input-dictionary-choice-{{entry.display}}\"/>\r\n              <div class=\"cod-label ps-1\">\r\n                {{entry.display}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column cod-type-dict\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label me-1\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y' || attribute.isActive === 'N'\"\r\n                  class=\"form-select edit-renderer custom-caret\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let entry of dictionaryEntries\"\r\n                    [ngValue]=\"entry.value\">\r\n              {{ entry.display }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n      <div #attributeRef class=\"d-flex flex-column cod-type-ga\">\r\n        <div *ngIf=\"attribute.idAttribute\" class=\"d-flex cod-top-label mr-1\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div *ngIf=\"editInline\" style=\"margin-left: auto;\">\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'\"\r\n                  (click)=\"addGridRow(editGridModal, attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n                <button\r\n                  class=\"btn-ga\"\r\n                  [disabled]=\"(!this.attributeService.editButtonsEnabled) || attribute.isActive === 'N'\"\r\n                  (click)=\"removeGridRow(attribute.idAttribute)\"\r\n                >\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n        <div class=\"d-flex flex-grow-1\">\r\n          <ag-grid-angular #gridAttribute\r\n              class=\"ag-theme-alpine\"\r\n              (gridReady)=\"this.onGridReady($event)\"\r\n              (modelUpdated)=\"onModelUpdated($event)\"\r\n              (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n              (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n              [gridOptions]=\"this.gridOptions\"\r\n              [rowSelection]=\"'single'\"\r\n              [columnDefs]=\"gridColumns\"\r\n              [rowData]=\"gridData\"\r\n              [style.width]=\"attribute.w + 'px'\"\r\n              [style.height]=\"attribute.h + 'px'\">\r\n          </ag-grid-angular>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <ng-template #editGridModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{attribute.displayName}} Grid Row\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n            <button\r\n              [disabled]=\"(!this.attributeService.editButtonsEnabled)\"\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Save')\"\r\n            >\r\n              Save\r\n            </button>\r\n\r\n            <button\r\n              class=\"btn btn-primary\"\r\n              (click)=\"close('Cancel')\"\r\n            >\r\n              Cancel\r\n            </button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n  ,\r\n  styles: [`\r\n  \t.hci-cod button.mat-icon-button.mat-button-base {\r\n      \theight: 20px;\r\n      \twidth: 20px;\r\n      \tline-height: unset;\r\n  \t}\r\n\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    .form-select.custom-caret {\r\n      background-size: 0.46rem;\r\n      background-position: right 0.3rem center;\r\n      color: var(--bluewarm-darkest);\r\n    }\r\n\r\n    .cod-type-s .custom-input-text, .cod-type-txt .custom-input-text,\r\n    .cod-type-n .custom-input-text, .cod-type-i .custom-input-text,\r\n    .cod-type-d .custom-input-text, .cod-type-dt .custom-input-text {\r\n      color: var(--bluewarm-darkest);\r\n    }\r\n `]\r\n})\r\nexport class AttributeFlexComponent extends AttributeBase {\r\n  hciNgAttributeAbsoluteInputDisplayName = \"\";\r\n  constructor(\r\n    attributeService: AttributeService,\r\n    elementRef: ElementRef,\r\n    renderer: Renderer2,\r\n    modalService: NgbModal\r\n  ) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n    if (this.attribute && this.attribute.displayName) {\r\n      this.hciNgAttributeAbsoluteInputDisplayName = this.attribute.displayName;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Flex needs to extend grid columns because we no longer want to use absolute width.  Here we generate percentage\r\n   * based upon the absolute width, but still use absolute width for the min width.\r\n   *\r\n   * @param {Attribute[]} attributes\r\n   * @param {any[]} columns\r\n   */\r\n  initializeGridColumns(attributes: GraphicalAttribute[], columns: any[]) {\r\n    super.initializeGridColumns(attributes, columns);\r\n\r\n    let width: number = 0;\r\n    for (let attribute of attributes) {\r\n      width += attribute.w;\r\n    }\r\n\r\n    for (let attribute of attributes) {\r\n      let widthPercent: number = Math.floor(100 * (attribute.w / width));\r\n\r\n      for (let column of columns) {\r\n        if (column.externalConfig && column.externalConfig.idAttribute === attribute.idAttribute) {\r\n          column.minWidth = attribute.w;\r\n          column.widthPercent = widthPercent;\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}