@huntsman-cancer-institute/cod 16.0.1 → 17.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/cod.module.d.ts +30 -31
  2. package/components/attribute-absolute.component.d.ts +28 -28
  3. package/components/attribute-base.d.ts +135 -135
  4. package/components/attribute-container.component.d.ts +50 -50
  5. package/components/attribute-default.component.d.ts +20 -20
  6. package/components/attribute-edit.component.d.ts +15 -15
  7. package/components/attribute-flex.component.d.ts +25 -25
  8. package/date/date-util.d.ts +9 -9
  9. package/esm2022/cod.module.mjs +114 -119
  10. package/esm2022/components/attribute-absolute.component.mjs +104 -104
  11. package/esm2022/components/attribute-base.mjs +564 -564
  12. package/esm2022/components/attribute-container.component.mjs +155 -155
  13. package/esm2022/components/attribute-default.component.mjs +63 -63
  14. package/esm2022/components/attribute-edit.component.mjs +33 -33
  15. package/esm2022/components/attribute-flex.component.mjs +58 -58
  16. package/esm2022/date/date-util.mjs +59 -59
  17. package/esm2022/huntsman-cancer-institute-cod.mjs +4 -4
  18. package/esm2022/index.mjs +20 -21
  19. package/esm2022/model/attribute-choice.entity.mjs +1 -1
  20. package/esm2022/model/attribute-configuration.dto.mjs +1 -1
  21. package/esm2022/model/attribute-configuration.entity.mjs +1 -1
  22. package/esm2022/model/attribute-container.entity.mjs +1 -1
  23. package/esm2022/model/attribute-dictionary.entity.mjs +1 -1
  24. package/esm2022/model/attribute-long-text.entity.mjs +1 -1
  25. package/esm2022/model/attribute-value-grid-row.entity.mjs +1 -1
  26. package/esm2022/model/attribute-value-set.entity.mjs +1 -1
  27. package/esm2022/model/attribute-value.entity.mjs +2 -2
  28. package/esm2022/model/attribute.entity.mjs +1 -1
  29. package/esm2022/model/dictionary-entries.dto.mjs +2 -2
  30. package/esm2022/model/extractable-field-status.entity.mjs +1 -1
  31. package/esm2022/model/graphical-attribute.entity.mjs +1 -1
  32. package/esm2022/model/pre-eval.dto.mjs +2 -2
  33. package/esm2022/pipes/is-group-attribute.pipe.mjs +32 -32
  34. package/esm2022/services/attribute.service.mjs +1211 -1211
  35. package/fesm2022/huntsman-cancer-institute-cod.mjs +2289 -2542
  36. package/fesm2022/huntsman-cancer-institute-cod.mjs.map +1 -1
  37. package/index.d.ts +26 -27
  38. package/model/attribute-choice.entity.d.ts +16 -16
  39. package/model/attribute-configuration.dto.d.ts +13 -13
  40. package/model/attribute-configuration.entity.d.ts +12 -12
  41. package/model/attribute-container.entity.d.ts +9 -9
  42. package/model/attribute-dictionary.entity.d.ts +12 -12
  43. package/model/attribute-long-text.entity.d.ts +4 -4
  44. package/model/attribute-value-grid-row.entity.d.ts +7 -7
  45. package/model/attribute-value-set.entity.d.ts +11 -11
  46. package/model/attribute-value.entity.d.ts +28 -28
  47. package/model/attribute.entity.d.ts +26 -26
  48. package/model/dictionary-entries.dto.d.ts +6 -6
  49. package/model/extractable-field-status.entity.d.ts +8 -8
  50. package/model/graphical-attribute.entity.d.ts +13 -13
  51. package/model/pre-eval.dto.d.ts +5 -5
  52. package/package.json +16 -8
  53. package/pipes/is-group-attribute.pipe.d.ts +13 -13
  54. package/services/attribute.service.d.ts +263 -263
  55. package/components/attribute-configuration.component.d.ts +0 -52
  56. package/esm2022/components/attribute-configuration.component.mjs +0 -263
@@ -1,97 +1,97 @@
1
- import { Component, ElementRef, Renderer2, ViewChild, ViewEncapsulation } from "@angular/core";
2
- import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
3
- import { AttributeBase } from "./attribute-base";
4
- import { AttributeService } from "../services/attribute.service";
5
- import { NativeSelectComponent } from "@huntsman-cancer-institute/input";
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "../services/attribute.service";
8
- import * as i2 from "@ng-bootstrap/ng-bootstrap";
9
- import * as i3 from "ag-grid-angular";
10
- import * as i4 from "@angular/common";
11
- import * as i5 from "@angular/forms";
12
- import * as i6 from "@angular/material/datepicker";
13
- import * as i7 from "@angular-material-components/datetime-picker";
14
- import * as i8 from "./attribute-edit.component";
15
- /**
16
- * The attribute for absolute positioning. This component has its width, height, x and y positioning set based upon
17
- * the attribute definition.
18
- */
19
- export class AttributeAbsoluteComponent extends AttributeBase {
20
- constructor(attributeService, elementRef, renderer, modalService) {
21
- super(attributeService, elementRef, renderer, modalService);
22
- }
23
- ngOnInit() {
24
- super.ngOnInit();
25
- if (this.editInline) {
26
- this.renderer.listen(this.elementRef.nativeElement, "mousemove", (event) => this.onMouseMove(event));
27
- }
28
- }
29
- ngAfterViewInit() {
30
- this.refresh();
31
- }
32
- /**
33
- * In the absolute case, upon refresh reset the position and size of the attribute.
34
- */
35
- refresh() {
36
- super.refresh();
37
- this.renderer.setStyle(this.elementRef.nativeElement, "position", "absolute");
38
- if (this.attribute.tabOrder !== undefined) {
39
- this.renderer.setStyle(this.elementRef.nativeElement, "z-index", 10 + this.attribute.tabOrder);
40
- }
41
- if (this.attribute.x !== undefined) {
42
- this.renderer.setStyle(this.elementRef.nativeElement, "left", this.attribute.x + "px");
43
- }
44
- if (this.attribute.y !== undefined) {
45
- if (this.attribute.codeAttributeDataType.toUpperCase() === "LINE") {
46
- // It appears the legacy metabuilder offset lines by 8 pixels
47
- this.renderer.setStyle(this.elementRef.nativeElement, "top", (this.attribute.y - 8) + "px");
48
- }
49
- else {
50
- this.renderer.setStyle(this.elementRef.nativeElement, "top", this.attribute.y + "px");
51
- }
52
- }
53
- // Checkboxes don't need a width, the select border should be the size of its label
54
- if (this.attribute.w !== undefined && this.attribute.codeAttributeDataType.toUpperCase() !== "CB") {
55
- this.renderer.setStyle(this.elementRef.nativeElement, "width", this.attribute.w + "px");
56
- }
57
- if (this.attribute.codeAttributeDataType === "LINE") {
58
- this.renderer.setStyle(this.elementRef.nativeElement, "height", "16px");
59
- }
60
- else if (this.attribute.h !== undefined) {
61
- if (!this.editInline) {
62
- this.renderer.setStyle(this.elementRef.nativeElement, "height", this.attribute.h + "px");
63
- }
64
- if (this.inputRef && this.inputRef.nativeElement) {
65
- this.renderer.setStyle(this.inputRef.nativeElement, "height", this.attribute.h + "px");
66
- }
67
- if (this.nativeSelectRef) {
68
- this.nativeSelectRef.setHeight(this.attribute.h);
69
- }
70
- }
71
- }
72
- /**
73
- * Add cursor styling when the mouse is over the selected attribute.
74
- *
75
- * @param {MouseEvent} event
76
- */
77
- onMouseMove(event) {
78
- if (this.elementRef.nativeElement.classList.contains("selected")) {
79
- let sx = this.elementRef.nativeElement.getBoundingClientRect().left;
80
- let sy = this.elementRef.nativeElement.getBoundingClientRect().top;
81
- if (Math.abs(event.clientX - (sx + this.elementRef.nativeElement.offsetWidth)) <= 10) {
82
- this.renderer.addClass(this.elementRef.nativeElement, "e-resize");
83
- return;
84
- }
85
- else if (Math.abs(event.clientY - (sy + this.elementRef.nativeElement.offsetHeight)) <= 6) {
86
- this.renderer.addClass(this.elementRef.nativeElement, "n-resize");
87
- return;
88
- }
89
- }
90
- this.renderer.removeClass(this.elementRef.nativeElement, "e-resize");
91
- this.renderer.removeClass(this.elementRef.nativeElement, "n-resize");
92
- }
93
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeAbsoluteComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
94
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AttributeAbsoluteComponent, selector: "hci-attribute-absolute", viewQueries: [{ propertyName: "nativeSelectComponent", first: true, predicate: ["nativeSelectRef"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
1
+ import { Component, ElementRef, Renderer2, ViewChild, ViewEncapsulation } from "@angular/core";
2
+ import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
3
+ import { AttributeBase } from "./attribute-base";
4
+ import { AttributeService } from "../services/attribute.service";
5
+ import { NativeSelectComponent } from "@huntsman-cancer-institute/input";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../services/attribute.service";
8
+ import * as i2 from "@ng-bootstrap/ng-bootstrap";
9
+ import * as i3 from "ag-grid-angular";
10
+ import * as i4 from "@angular/common";
11
+ import * as i5 from "@angular/forms";
12
+ import * as i6 from "@angular/material/datepicker";
13
+ import * as i7 from "@angular-material-components/datetime-picker";
14
+ import * as i8 from "./attribute-edit.component";
15
+ /**
16
+ * The attribute for absolute positioning. This component has its width, height, x and y positioning set based upon
17
+ * the attribute definition.
18
+ */
19
+ export class AttributeAbsoluteComponent extends AttributeBase {
20
+ constructor(attributeService, elementRef, renderer, modalService) {
21
+ super(attributeService, elementRef, renderer, modalService);
22
+ }
23
+ ngOnInit() {
24
+ super.ngOnInit();
25
+ if (this.editInline) {
26
+ this.renderer.listen(this.elementRef.nativeElement, "mousemove", (event) => this.onMouseMove(event));
27
+ }
28
+ }
29
+ ngAfterViewInit() {
30
+ this.refresh();
31
+ }
32
+ /**
33
+ * In the absolute case, upon refresh reset the position and size of the attribute.
34
+ */
35
+ refresh() {
36
+ super.refresh();
37
+ this.renderer.setStyle(this.elementRef.nativeElement, "position", "absolute");
38
+ if (this.attribute.tabOrder !== undefined) {
39
+ this.renderer.setStyle(this.elementRef.nativeElement, "z-index", 10 + this.attribute.tabOrder);
40
+ }
41
+ if (this.attribute.x !== undefined) {
42
+ this.renderer.setStyle(this.elementRef.nativeElement, "left", this.attribute.x + "px");
43
+ }
44
+ if (this.attribute.y !== undefined) {
45
+ if (this.attribute.codeAttributeDataType.toUpperCase() === "LINE") {
46
+ // It appears the legacy metabuilder offset lines by 8 pixels
47
+ this.renderer.setStyle(this.elementRef.nativeElement, "top", (this.attribute.y - 8) + "px");
48
+ }
49
+ else {
50
+ this.renderer.setStyle(this.elementRef.nativeElement, "top", this.attribute.y + "px");
51
+ }
52
+ }
53
+ // Checkboxes don't need a width, the select border should be the size of its label
54
+ if (this.attribute.w !== undefined && this.attribute.codeAttributeDataType.toUpperCase() !== "CB") {
55
+ this.renderer.setStyle(this.elementRef.nativeElement, "width", this.attribute.w + "px");
56
+ }
57
+ if (this.attribute.codeAttributeDataType === "LINE") {
58
+ this.renderer.setStyle(this.elementRef.nativeElement, "height", "16px");
59
+ }
60
+ else if (this.attribute.h !== undefined) {
61
+ if (!this.editInline) {
62
+ this.renderer.setStyle(this.elementRef.nativeElement, "height", this.attribute.h + "px");
63
+ }
64
+ if (this.inputRef && this.inputRef.nativeElement) {
65
+ this.renderer.setStyle(this.inputRef.nativeElement, "height", this.attribute.h + "px");
66
+ }
67
+ if (this.nativeSelectRef) {
68
+ this.nativeSelectRef.setHeight(this.attribute.h);
69
+ }
70
+ }
71
+ }
72
+ /**
73
+ * Add cursor styling when the mouse is over the selected attribute.
74
+ *
75
+ * @param {MouseEvent} event
76
+ */
77
+ onMouseMove(event) {
78
+ if (this.elementRef.nativeElement.classList.contains("selected")) {
79
+ let sx = this.elementRef.nativeElement.getBoundingClientRect().left;
80
+ let sy = this.elementRef.nativeElement.getBoundingClientRect().top;
81
+ if (Math.abs(event.clientX - (sx + this.elementRef.nativeElement.offsetWidth)) <= 10) {
82
+ this.renderer.addClass(this.elementRef.nativeElement, "e-resize");
83
+ return;
84
+ }
85
+ else if (Math.abs(event.clientY - (sy + this.elementRef.nativeElement.offsetHeight)) <= 6) {
86
+ this.renderer.addClass(this.elementRef.nativeElement, "n-resize");
87
+ return;
88
+ }
89
+ }
90
+ this.renderer.removeClass(this.elementRef.nativeElement, "e-resize");
91
+ this.renderer.removeClass(this.elementRef.nativeElement, "n-resize");
92
+ }
93
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeAbsoluteComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
94
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AttributeAbsoluteComponent, selector: "hci-attribute-absolute", viewQueries: [{ propertyName: "nativeSelectComponent", first: true, predicate: ["nativeSelectRef"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
95
95
  <div class="drag-select" style=""></div>
96
96
 
97
97
  <!-- Line -->
@@ -462,10 +462,10 @@ export class AttributeAbsoluteComponent extends AttributeBase {
462
462
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
463
463
  </div>
464
464
  </ng-template>
465
- `, 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 }); }
466
- }
467
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeAbsoluteComponent, decorators: [{
468
- type: Component,
465
+ `, 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 }); }
466
+ }
467
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeAbsoluteComponent, decorators: [{
468
+ type: Component,
469
469
  args: [{ selector: "hci-attribute-absolute", encapsulation: ViewEncapsulation.None, template: `
470
470
  <div class="drag-select" style=""></div>
471
471
 
@@ -837,9 +837,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
837
837
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
838
838
  </div>
839
839
  </ng-template>
840
- `, 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"] }]
841
- }], ctorParameters: function () { return [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }]; }, propDecorators: { nativeSelectComponent: [{
842
- type: ViewChild,
843
- args: ["nativeSelectRef", { static: true }]
844
- }] } });
845
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-absolute.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-absolute.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component,\r\n  ElementRef,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\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 {NativeSelectComponent} from \"@huntsman-cancer-institute/input\";\r\n\r\n/**\r\n * The attribute for absolute positioning.  This component has its width, height, x and y positioning set based upon\r\n * the attribute definition.\r\n */\r\n@Component(\r\n  {\r\n    selector: \"hci-attribute-absolute\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    template:\r\n      `\r\n        <div class=\"drag-select\" style=\"\"></div>\r\n\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 i-height\">\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 mr-1 cod-label 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 #inputRef #attributeRef\r\n               class=\"d-flex flex-column\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-label mt-auto mb-auto\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div *ngIf=\"(attribute.h <= 25)\" class=\"d-flex flex-grow-1\">\r\n              <input\r\n                #inputRef\r\n                type=\"text\"\r\n                [ngModel]=\"attributeValues[0].valueString\"\r\n                (ngModelChange)=\"valueStringChange($event)\"\r\n                [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                class=\"form-control\"/>\r\n            </div>\r\n            <div *ngIf=\"(attribute.h > 25)\" 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].valueString\"\r\n                (ngModelChange)=\"valueStringChange($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        <!-- Text -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column cod-type-txt i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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            (ngModelChange)=\"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-row cod-type-cb i-height align-items-center\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-right-label\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div #inputRef class=\"d-flex flex-grow-1 align-items-center mr-1\">\r\n              <input 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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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                     [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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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                     [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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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'\">Yes</option>\r\n                <option [ngValue]=\"'N'\">No</option>\r\n                <option [ngValue]=\"'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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                      (ngModelChange)=\"valueChoiceChange($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 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 i-height\"\r\n               style=\"height: inherit;\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column y-auto\" style=\"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                         [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 i-height\"\r\n               style=\"height: inherit;\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column y-auto\" style=\"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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              <div>\r\n                {{attribute.displayName}}\r\n              </div>\r\n              <div *ngIf=\"editInline\" style=\"margin-left: auto;\" class=\"pl-2 pb-2\">\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 #gridComponent\r\n                               class=\"ag-theme-balham\"\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      `\r\n        .hci-cod button.mat-icon-button.mat-button-base {\r\n          height: 20px;\r\n          width: 20px;\r\n          line-height: unset;\r\n        }\r\n\r\n        .btn-ga {\r\n          padding: 0px;\r\n          height: 18px;\r\n          width: 18px;\r\n        }\r\n\r\n        .ga-icon {\r\n          font-size: .9em;\r\n          vertical-align: top;\r\n        }\r\n\r\n        .hci-cod .mat-datepicker-toggle-default-icon {\r\n          height: 20px;\r\n          width: 20px;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class AttributeAbsoluteComponent extends AttributeBase {\r\n\r\n  @ViewChild(\"nativeSelectRef\", {static: true})\r\n  nativeSelectComponent: NativeSelectComponent;\r\n\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  ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if (this.editInline) {\r\n      this.renderer.listen(this.elementRef.nativeElement, \"mousemove\", (event) => this.onMouseMove(event));\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n  }\r\n\r\n  /**\r\n   * In the absolute case, upon refresh reset the position and size of the attribute.\r\n   */\r\n  refresh(): void {\r\n    super.refresh();\r\n\r\n    this.renderer.setStyle(this.elementRef.nativeElement, \"position\", \"absolute\");\r\n\r\n    if (this.attribute.tabOrder !== undefined) {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"z-index\", 10 + this.attribute.tabOrder);\r\n    }\r\n\r\n    if (this.attribute.x !== undefined) {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"left\", this.attribute.x + \"px\");\r\n    }\r\n    if (this.attribute.y !== undefined) {\r\n      if (this.attribute.codeAttributeDataType.toUpperCase() === \"LINE\") {\r\n        // It appears the legacy metabuilder offset lines by 8 pixels\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"top\", (this.attribute.y - 8) + \"px\");\r\n      } else {\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"top\", this.attribute.y + \"px\");\r\n      }\r\n    }\r\n\r\n    // Checkboxes don't need a width, the select border should be the size of its label\r\n    if (this.attribute.w !== undefined && this.attribute.codeAttributeDataType.toUpperCase() !== \"CB\") {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"width\", this.attribute.w + \"px\");\r\n    }\r\n\r\n    if (this.attribute.codeAttributeDataType === \"LINE\") {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"height\", \"16px\");\r\n    } else if (this.attribute.h !== undefined) {\r\n      if (!this.editInline) {\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"height\", this.attribute.h + \"px\");\r\n      }\r\n      if (this.inputRef && this.inputRef.nativeElement) {\r\n        this.renderer.setStyle(this.inputRef.nativeElement, \"height\", this.attribute.h + \"px\");\r\n      }\r\n      if (this.nativeSelectRef) {\r\n        this.nativeSelectRef.setHeight(this.attribute.h);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Add cursor styling when the mouse is over the selected attribute.\r\n   *\r\n   * @param {MouseEvent} event\r\n   */\r\n  onMouseMove(event: MouseEvent): void {\r\n    if (this.elementRef.nativeElement.classList.contains(\"selected\")) {\r\n      let sx: number = this.elementRef.nativeElement.getBoundingClientRect().left;\r\n      let sy: number = this.elementRef.nativeElement.getBoundingClientRect().top;\r\n\r\n      if (Math.abs(event.clientX - (sx + this.elementRef.nativeElement.offsetWidth)) <= 10) {\r\n        this.renderer.addClass(this.elementRef.nativeElement, \"e-resize\");\r\n        return;\r\n      } else if (Math.abs(event.clientY - (sy + this.elementRef.nativeElement.offsetHeight)) <= 6) {\r\n        this.renderer.addClass(this.elementRef.nativeElement, \"n-resize\");\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.renderer.removeClass(this.elementRef.nativeElement, \"e-resize\");\r\n    this.renderer.removeClass(this.elementRef.nativeElement, \"n-resize\");\r\n  }\r\n}\r\n"]}
840
+ `, 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"] }]
841
+ }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }], propDecorators: { nativeSelectComponent: [{
842
+ type: ViewChild,
843
+ args: ["nativeSelectRef", { static: true }]
844
+ }] } });
845
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-absolute.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-absolute.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component,\r\n  ElementRef,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\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 {NativeSelectComponent} from \"@huntsman-cancer-institute/input\";\r\n\r\n/**\r\n * The attribute for absolute positioning.  This component has its width, height, x and y positioning set based upon\r\n * the attribute definition.\r\n */\r\n@Component(\r\n  {\r\n    selector: \"hci-attribute-absolute\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    template:\r\n      `\r\n        <div class=\"drag-select\" style=\"\"></div>\r\n\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 i-height\">\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 mr-1 cod-label 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 #inputRef #attributeRef\r\n               class=\"d-flex flex-column\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-label mt-auto mb-auto\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div *ngIf=\"(attribute.h <= 25)\" class=\"d-flex flex-grow-1\">\r\n              <input\r\n                #inputRef\r\n                type=\"text\"\r\n                [ngModel]=\"attributeValues[0].valueString\"\r\n                (ngModelChange)=\"valueStringChange($event)\"\r\n                [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                class=\"form-control\"/>\r\n            </div>\r\n            <div *ngIf=\"(attribute.h > 25)\" 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].valueString\"\r\n                (ngModelChange)=\"valueStringChange($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        <!-- Text -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column cod-type-txt i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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            (ngModelChange)=\"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-row cod-type-cb i-height align-items-center\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-right-label\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div #inputRef class=\"d-flex flex-grow-1 align-items-center mr-1\">\r\n              <input 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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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                     [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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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                     [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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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'\">Yes</option>\r\n                <option [ngValue]=\"'N'\">No</option>\r\n                <option [ngValue]=\"'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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                      (ngModelChange)=\"valueChoiceChange($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 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 i-height\"\r\n               style=\"height: inherit;\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column y-auto\" style=\"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                         [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 i-height\"\r\n               style=\"height: inherit;\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column y-auto\" style=\"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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\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 i-height\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex cod-top-label mr-1\" [style.width]=\"'max-content'\">\r\n              <div>\r\n                {{attribute.displayName}}\r\n              </div>\r\n              <div *ngIf=\"editInline\" style=\"margin-left: auto;\" class=\"pl-2 pb-2\">\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 #gridComponent\r\n                               class=\"ag-theme-balham\"\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      `\r\n        .hci-cod button.mat-icon-button.mat-button-base {\r\n          height: 20px;\r\n          width: 20px;\r\n          line-height: unset;\r\n        }\r\n\r\n        .btn-ga {\r\n          padding: 0px;\r\n          height: 18px;\r\n          width: 18px;\r\n        }\r\n\r\n        .ga-icon {\r\n          font-size: .9em;\r\n          vertical-align: top;\r\n        }\r\n\r\n        .hci-cod .mat-datepicker-toggle-default-icon {\r\n          height: 20px;\r\n          width: 20px;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class AttributeAbsoluteComponent extends AttributeBase {\r\n\r\n  @ViewChild(\"nativeSelectRef\", {static: true})\r\n  nativeSelectComponent: NativeSelectComponent;\r\n\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  ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if (this.editInline) {\r\n      this.renderer.listen(this.elementRef.nativeElement, \"mousemove\", (event) => this.onMouseMove(event));\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.refresh();\r\n  }\r\n\r\n  /**\r\n   * In the absolute case, upon refresh reset the position and size of the attribute.\r\n   */\r\n  refresh(): void {\r\n    super.refresh();\r\n\r\n    this.renderer.setStyle(this.elementRef.nativeElement, \"position\", \"absolute\");\r\n\r\n    if (this.attribute.tabOrder !== undefined) {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"z-index\", 10 + this.attribute.tabOrder);\r\n    }\r\n\r\n    if (this.attribute.x !== undefined) {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"left\", this.attribute.x + \"px\");\r\n    }\r\n    if (this.attribute.y !== undefined) {\r\n      if (this.attribute.codeAttributeDataType.toUpperCase() === \"LINE\") {\r\n        // It appears the legacy metabuilder offset lines by 8 pixels\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"top\", (this.attribute.y - 8) + \"px\");\r\n      } else {\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"top\", this.attribute.y + \"px\");\r\n      }\r\n    }\r\n\r\n    // Checkboxes don't need a width, the select border should be the size of its label\r\n    if (this.attribute.w !== undefined && this.attribute.codeAttributeDataType.toUpperCase() !== \"CB\") {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"width\", this.attribute.w + \"px\");\r\n    }\r\n\r\n    if (this.attribute.codeAttributeDataType === \"LINE\") {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, \"height\", \"16px\");\r\n    } else if (this.attribute.h !== undefined) {\r\n      if (!this.editInline) {\r\n        this.renderer.setStyle(this.elementRef.nativeElement, \"height\", this.attribute.h + \"px\");\r\n      }\r\n      if (this.inputRef && this.inputRef.nativeElement) {\r\n        this.renderer.setStyle(this.inputRef.nativeElement, \"height\", this.attribute.h + \"px\");\r\n      }\r\n      if (this.nativeSelectRef) {\r\n        this.nativeSelectRef.setHeight(this.attribute.h);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Add cursor styling when the mouse is over the selected attribute.\r\n   *\r\n   * @param {MouseEvent} event\r\n   */\r\n  onMouseMove(event: MouseEvent): void {\r\n    if (this.elementRef.nativeElement.classList.contains(\"selected\")) {\r\n      let sx: number = this.elementRef.nativeElement.getBoundingClientRect().left;\r\n      let sy: number = this.elementRef.nativeElement.getBoundingClientRect().top;\r\n\r\n      if (Math.abs(event.clientX - (sx + this.elementRef.nativeElement.offsetWidth)) <= 10) {\r\n        this.renderer.addClass(this.elementRef.nativeElement, \"e-resize\");\r\n        return;\r\n      } else if (Math.abs(event.clientY - (sy + this.elementRef.nativeElement.offsetHeight)) <= 6) {\r\n        this.renderer.addClass(this.elementRef.nativeElement, \"n-resize\");\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.renderer.removeClass(this.elementRef.nativeElement, \"e-resize\");\r\n    this.renderer.removeClass(this.elementRef.nativeElement, \"n-resize\");\r\n  }\r\n}\r\n"]}