@huntsman-cancer-institute/dictionary-editor 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.
- package/components/detail.component.d.ts +90 -90
- package/components/home.component.d.ts +13 -13
- package/components/new-row.component.d.ts +20 -20
- package/dictionary-editor.component.d.ts +43 -43
- package/dictionary-editor.module.d.ts +24 -24
- package/dictionary-editor.routes.d.ts +4 -4
- package/esm2022/components/detail.component.mjs +606 -606
- package/esm2022/components/home.component.mjs +28 -28
- package/esm2022/components/new-row.component.mjs +81 -81
- package/esm2022/dictionary-editor.component.mjs +169 -169
- package/esm2022/dictionary-editor.module.mjs +76 -76
- package/esm2022/dictionary-editor.routes.mjs +14 -14
- package/esm2022/grid-editors/ag-grid-date-cell-editor.component.mjs +30 -30
- package/esm2022/grid-editors/ag-grid-editor.module.mjs +55 -55
- package/esm2022/grid-editors/datepicker.component.mjs +93 -93
- package/esm2022/grid-editors/select.editor.mjs +142 -142
- package/esm2022/grid-renderers/ag-grid-renderer.module.mjs +36 -36
- package/esm2022/grid-renderers/cell-renderer-validation.mjs +345 -345
- package/esm2022/grid-renderers/date.renderer.mjs +68 -68
- package/esm2022/grid-renderers/select.renderer.mjs +95 -95
- package/esm2022/huntsman-cancer-institute-dictionary-editor.mjs +4 -4
- package/esm2022/index.mjs +4 -4
- package/fesm2022/huntsman-cancer-institute-dictionary-editor.mjs +1718 -1718
- package/fesm2022/huntsman-cancer-institute-dictionary-editor.mjs.map +1 -1
- package/grid-editors/ag-grid-date-cell-editor.component.d.ts +11 -11
- package/grid-editors/ag-grid-editor.module.d.ts +15 -15
- package/grid-editors/datepicker.component.d.ts +16 -16
- package/grid-editors/select.editor.d.ts +30 -30
- package/grid-renderers/ag-grid-renderer.module.d.ts +10 -10
- package/grid-renderers/cell-renderer-validation.d.ts +69 -69
- package/grid-renderers/date.renderer.d.ts +15 -15
- package/grid-renderers/select.renderer.d.ts +17 -17
- package/index.d.ts +4 -4
- package/package.json +9 -12
|
@@ -1,583 +1,583 @@
|
|
|
1
|
-
import { Component, Inject, isDevMode, HostBinding } from "@angular/core";
|
|
2
|
-
import { ActivatedRoute } from "@angular/router";
|
|
3
|
-
import { BehaviorSubject } from "rxjs";
|
|
4
|
-
import { finalize, map } from "rxjs/operators";
|
|
5
|
-
import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
|
|
6
|
-
import { DictionaryService, DICTIONARY_ENDPOINT } from "@huntsman-cancer-institute/dictionary-service";
|
|
7
|
-
import { SelectRenderer } from "../grid-renderers/select.renderer";
|
|
8
|
-
import { SelectEditor } from "../grid-editors/select.editor";
|
|
9
|
-
import { NewRowComponent } from "./new-row.component";
|
|
10
|
-
import { isNullOrUndefined } from "util";
|
|
11
|
-
import { DateRenderer } from "../grid-renderers/date.renderer";
|
|
12
|
-
import { AgGridDateCellEditorComponent } from "../grid-editors/ag-grid-date-cell-editor.component";
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@angular/router";
|
|
15
|
-
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
16
|
-
import * as i3 from "@huntsman-cancer-institute/dictionary-service";
|
|
17
|
-
import * as i4 from "@huntsman-cancer-institute/misc";
|
|
18
|
-
import * as i5 from "ag-grid-angular";
|
|
19
|
-
/**
|
|
20
|
-
* When a dictionary is selected this component is shown. There is a top grid which for its data shows all the columns
|
|
21
|
-
* for the dictionary. Currently, keep this for reference only and have non-editable.
|
|
22
|
-
* The bottom grid will show those columns as actual columns and its data are all the dictionary values. Rows can be
|
|
23
|
-
* added. For deleting, need to make sure the id is not used anywhere. For editing, need to make sure the code or anything
|
|
24
|
-
* else isn't being referenced.
|
|
25
|
-
*
|
|
26
|
-
* @since 1.0.0
|
|
27
|
-
*/
|
|
28
|
-
export class DictionaryEditorDetailComponent {
|
|
29
|
-
constructor(route, modalService, dictionaryService, dictionaryEndpoint) {
|
|
30
|
-
this.route = route;
|
|
31
|
-
this.modalService = modalService;
|
|
32
|
-
this.dictionaryService = dictionaryService;
|
|
33
|
-
this.dictionaryEndpoint = dictionaryEndpoint;
|
|
34
|
-
this.classList = "outlet-column y-auto";
|
|
35
|
-
this.dictionaryEntries = [];
|
|
36
|
-
this.selectedRows = [];
|
|
37
|
-
this.loadingSubjects = [];
|
|
38
|
-
this.metaGridOptions = {
|
|
39
|
-
rowStyle: {
|
|
40
|
-
"font-family": "Prompt, sans-serif"
|
|
41
|
-
},
|
|
42
|
-
enableCellTextSelection: true,
|
|
43
|
-
ensureDomOrder: true
|
|
44
|
-
};
|
|
45
|
-
this.gridOptions = {
|
|
46
|
-
context: {
|
|
47
|
-
componentParent: this
|
|
48
|
-
},
|
|
49
|
-
onGridReady: DictionaryEditorDetailComponent.onSamplesGridReady,
|
|
50
|
-
onGridSizeChanged: DictionaryEditorDetailComponent.onGridSizeChanged,
|
|
51
|
-
suppressHorizontalScroll: false,
|
|
52
|
-
selectionMode: "multiple",
|
|
53
|
-
stopEditingWhenGridLosesFocus: true,
|
|
54
|
-
enableSorting: true,
|
|
55
|
-
enableFilter: true
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Based on the route class name, make the call to fetch the dictionary data. Since this component is route based,
|
|
60
|
-
* when the dictionary class in the route changes, this component is reloaded.
|
|
61
|
-
*/
|
|
62
|
-
ngOnInit() {
|
|
63
|
-
this.boundNewRowPostCall = this.newRowPost.bind(this);
|
|
64
|
-
this.loadingSubjects.push(new BehaviorSubject(false));
|
|
65
|
-
this.loadingSubjects.push(new BehaviorSubject(false));
|
|
66
|
-
this.route.params.subscribe(params => {
|
|
67
|
-
let className = params["className"];
|
|
68
|
-
this.getDictionary(className);
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
openModal(modal) {
|
|
72
|
-
this.modalService.open(modal, { windowClass: "modal-xl" }).result.then((result) => {
|
|
73
|
-
}, (reason) => {
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
ngAfterViewInit() {
|
|
77
|
-
this.gridOptions.api.sizeColumnsToFit();
|
|
78
|
-
}
|
|
79
|
-
columnDefMeta() {
|
|
80
|
-
return [
|
|
81
|
-
{ field: "name", headerName: "Name", width: 175, sortable: true, resizable: true, editable: false },
|
|
82
|
-
{ field: "description", headerName: "Description", width: 250, sortable: true, resizable: true, editable: false },
|
|
83
|
-
{ field: "id", headerName: "Id", width: 60, sortable: true, resizable: true, editable: false },
|
|
84
|
-
{ field: "type", headerName: "Type", sortable: true, resizable: true, editable: false },
|
|
85
|
-
{ field: "protectionType", headerName: "ProtectionType", sortable: true, resizable: true, editable: false },
|
|
86
|
-
{ field: "filterDictionaryClass", headerName: "FilterDictionaryClass", width: 180, sortable: true, resizable: true, editable: false },
|
|
87
|
-
{ field: "notNull", headerName: "NotNull", sortable: true, resizable: true, editable: false },
|
|
88
|
-
{ field: "integer", headerName: "Integer", width: 75, sortable: true, resizable: true, editable: false },
|
|
89
|
-
{ field: "min", headerName: "Min", width: 60, sortable: true, resizable: true, editable: false },
|
|
90
|
-
{ field: "max", headerName: "Max", width: 60, sortable: true, resizable: true, editable: false },
|
|
91
|
-
{ field: "fraction", headerName: "Fraction", sortable: true, resizable: true, editable: false },
|
|
92
|
-
{ field: "dictionaryTooltip", headerName: "DictionaryTooltip", width: 200, sortable: true, resizable: true, editable: false },
|
|
93
|
-
{ field: "dictionaryDisplay", headerName: "DictionaryDisplay", width: 175, sortable: true, resizable: true, editable: false },
|
|
94
|
-
{ field: "filterable", headerName: "Filterable", sortable: true, resizable: true, editable: false },
|
|
95
|
-
{ field: "displayName", headerName: "DisplayName", width: 175, sortable: true, resizable: true, editable: false },
|
|
96
|
-
{ field: "displayOrder", headerName: "DisplayOrder", width: 60, sortable: true, resizable: true, editable: false },
|
|
97
|
-
{ field: "cellStyle", headerName: "CellStyle", sortable: true, resizable: true, editable: false },
|
|
98
|
-
]; // the widths for the last 2 could be wrong.
|
|
99
|
-
}
|
|
100
|
-
onMetaGridReady(params) {
|
|
101
|
-
this.gridApiMeta = params.api;
|
|
102
|
-
this.gridApiMeta.setColumnDefs(this.columnDefMeta());
|
|
103
|
-
this.gridApiMeta.setRowData(this.dictionary?.fields);
|
|
104
|
-
// this.gridApiMeta.sizeColumnsToFit();
|
|
105
|
-
}
|
|
106
|
-
openAreYouSureModal(modal) {
|
|
107
|
-
this.modalService.open(modal).result.then((result) => {
|
|
108
|
-
if (result === "Delete") {
|
|
109
|
-
this.deleteDictionaryEntries();
|
|
110
|
-
}
|
|
111
|
-
}, (reason) => {
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* Fetch the dictionary metadata and dictionary entries based upon the dictionary class name.
|
|
116
|
-
*
|
|
117
|
-
* @param {string} className
|
|
118
|
-
*/
|
|
119
|
-
getDictionary(className) {
|
|
120
|
-
// When Selecting A New Dictionary, Navigate To First Page
|
|
121
|
-
if (this.gridOptions && this.gridOptions.api) {
|
|
122
|
-
this.gridOptions.api.paginationGoToFirstPage();
|
|
123
|
-
}
|
|
124
|
-
this.className = className;
|
|
125
|
-
this.dataColumns = undefined;
|
|
126
|
-
this.loadingSubjects[0].next(true);
|
|
127
|
-
this.dictionaryService.getDictionary(className)
|
|
128
|
-
.pipe(finalize(() => {
|
|
129
|
-
this.loadingSubjects[0].next(false);
|
|
130
|
-
})).subscribe((dictionary) => {
|
|
131
|
-
this.setUpDictionaryGrid(dictionary);
|
|
132
|
-
this.loadingSubjects[0].next(false);
|
|
133
|
-
});
|
|
134
|
-
this.getDictionaryEntries();
|
|
135
|
-
}
|
|
136
|
-
getDictionaryEntries() {
|
|
137
|
-
this.loadingSubjects[1].next(true);
|
|
138
|
-
this.dictionaryService.getDictionaryEntries(this.className)
|
|
139
|
-
.pipe(finalize(() => {
|
|
140
|
-
this.loadingSubjects[1].next(false);
|
|
141
|
-
})).subscribe((dictionaryEntries) => {
|
|
142
|
-
this.dictionaryEntries = dictionaryEntries;
|
|
143
|
-
this.gridOptions.api.setRowData(dictionaryEntries);
|
|
144
|
-
this.gridOptions.api.sizeColumnsToFit();
|
|
145
|
-
this.loadingSubjects[1].next(false);
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Set the dictionary metadata. This is used to build the columns for the dictionary entries. The names, validation,
|
|
150
|
-
* and filter classes build the column definition.
|
|
151
|
-
*
|
|
152
|
-
* @param dictionary
|
|
153
|
-
*/
|
|
154
|
-
setUpDictionaryGrid(dictionary) {
|
|
155
|
-
if (isDevMode()) {
|
|
156
|
-
console.debug("DictionaryEditorDetailComponent.setDictionary");
|
|
157
|
-
console.debug(dictionary);
|
|
158
|
-
}
|
|
159
|
-
this.dictionary = dictionary;
|
|
160
|
-
this.secondaryDictionaryEntries = [];
|
|
161
|
-
let dictionaryClassNames = [];
|
|
162
|
-
for (let field of dictionary.fields) {
|
|
163
|
-
if (field.filterDictionaryClass) {
|
|
164
|
-
dictionaryClassNames.push(field.filterDictionaryClass);
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
this.getSecondaryDictionaries(dictionaryClassNames);
|
|
168
|
-
}
|
|
169
|
-
getSecondaryDictionaries(dictionaryNames) {
|
|
170
|
-
if (dictionaryNames.length == 0) {
|
|
171
|
-
this.finishColumnSetup();
|
|
172
|
-
}
|
|
173
|
-
else {
|
|
174
|
-
let dictionaryName = dictionaryNames.pop();
|
|
175
|
-
this.dictionaryService.getDictionaryDropdownEntries(dictionaryName).subscribe((response) => {
|
|
176
|
-
this.secondaryDictionaryEntries.push({ dictionaryName: dictionaryName, entries: response });
|
|
177
|
-
this.getSecondaryDictionaries(dictionaryNames);
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
finishColumnSetup() {
|
|
182
|
-
this.displayName = this.dictionary.displayName;
|
|
183
|
-
// This establishes the readOnly functionality
|
|
184
|
-
let cols = [];
|
|
185
|
-
// Process Columns And Create Column Definition
|
|
186
|
-
for (let field of this.dictionary.fields) {
|
|
187
|
-
if (field.id && (isNullOrUndefined(field.code) || field.code == false)) {
|
|
188
|
-
continue;
|
|
189
|
-
}
|
|
190
|
-
let col;
|
|
191
|
-
if (field.filterDictionaryClass) {
|
|
192
|
-
// this is a dropdown of another dictionary
|
|
193
|
-
let options = this.secondaryDictionaryEntries.find((a) => {
|
|
194
|
-
return a.dictionaryName === field.filterDictionaryClass;
|
|
195
|
-
});
|
|
196
|
-
col = {
|
|
197
|
-
field: field.name,
|
|
198
|
-
headerName: field.displayName,
|
|
199
|
-
editable: this.isEditable.bind(this),
|
|
200
|
-
cellRendererFramework: SelectRenderer,
|
|
201
|
-
cellEditorFramework: SelectEditor,
|
|
202
|
-
selectOptionsDisplayField: "display",
|
|
203
|
-
selectOptionsValueField: "id",
|
|
204
|
-
sortable: true,
|
|
205
|
-
resizable: true,
|
|
206
|
-
filter: true,
|
|
207
|
-
filterValueGetter: this.comboFilterValueGetter,
|
|
208
|
-
selectOptions: [],
|
|
209
|
-
comparator: (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
210
|
-
return 0;
|
|
211
|
-
}
|
|
212
|
-
};
|
|
213
|
-
if (options && options.entries) {
|
|
214
|
-
col.selectOptions = options.entries.sort((optionA, optionB) => {
|
|
215
|
-
if (optionA && !optionB) {
|
|
216
|
-
return 1;
|
|
217
|
-
}
|
|
218
|
-
if (optionB && !optionA) {
|
|
219
|
-
return -1;
|
|
220
|
-
}
|
|
221
|
-
if (!optionA && !optionB) {
|
|
222
|
-
return 0;
|
|
223
|
-
}
|
|
224
|
-
if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {
|
|
225
|
-
return 1;
|
|
226
|
-
}
|
|
227
|
-
else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {
|
|
228
|
-
return -1;
|
|
229
|
-
}
|
|
230
|
-
else {
|
|
231
|
-
return 0;
|
|
232
|
-
}
|
|
233
|
-
});
|
|
234
|
-
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
235
|
-
if (!options.entries) {
|
|
236
|
-
return 0;
|
|
237
|
-
}
|
|
238
|
-
if (valueA && !valueB) {
|
|
239
|
-
return 1;
|
|
240
|
-
}
|
|
241
|
-
if (valueB && !valueA) {
|
|
242
|
-
return -1;
|
|
243
|
-
}
|
|
244
|
-
if (!valueA && !valueB) {
|
|
245
|
-
return 0;
|
|
246
|
-
}
|
|
247
|
-
let optionA = options.entries.find((entry) => ("" + entry.id === "" + valueA));
|
|
248
|
-
let optionB = options.entries.find((entry) => ("" + entry.id === "" + valueB));
|
|
249
|
-
if (optionA && !optionB) {
|
|
250
|
-
return 1;
|
|
251
|
-
}
|
|
252
|
-
if (optionB && !optionA) {
|
|
253
|
-
return -1;
|
|
254
|
-
}
|
|
255
|
-
if (!optionA && !optionB) {
|
|
256
|
-
return 0;
|
|
257
|
-
}
|
|
258
|
-
if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {
|
|
259
|
-
return 1;
|
|
260
|
-
}
|
|
261
|
-
else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {
|
|
262
|
-
return -1;
|
|
263
|
-
}
|
|
264
|
-
else {
|
|
265
|
-
return 0;
|
|
266
|
-
}
|
|
267
|
-
};
|
|
268
|
-
}
|
|
269
|
-
col.cellStyle = params => {
|
|
270
|
-
let column = {};
|
|
271
|
-
for (let field of params.context.componentParent.dictionary.fields) {
|
|
272
|
-
if (params.colDef.field == field.name) {
|
|
273
|
-
column = field;
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
277
|
-
if (params.context.readOnly || column.readOnly ||
|
|
278
|
-
column.protectionType == "Read Only") {
|
|
279
|
-
return { color: "#8a9499" };
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
else {
|
|
283
|
-
if (params.context.readOnly || column.readOnly ||
|
|
284
|
-
column.protectionType == "Read Only" || column.createOnly ||
|
|
285
|
-
column.protectionType == "Create Only" || column.code) {
|
|
286
|
-
return { color: "#8a9499" };
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
};
|
|
290
|
-
col.displayOrder = field.displayOrder;
|
|
291
|
-
col.dictionaryDisplay = field.dictionaryDisplay;
|
|
292
|
-
col.dictionaryTooltip = field.dictionaryTooltip;
|
|
293
|
-
// Set default filter as compare by text/number
|
|
294
|
-
// col.filterRenderer = CompareFilterRenderer;
|
|
295
|
-
}
|
|
296
|
-
else if (field.type && field.type == "Date") {
|
|
297
|
-
//date value
|
|
298
|
-
col = {
|
|
299
|
-
field: field.name,
|
|
300
|
-
headerName: field.displayName,
|
|
301
|
-
cellRendererFramework: DateRenderer,
|
|
302
|
-
cellEditorFramework: AgGridDateCellEditorComponent,
|
|
303
|
-
editable: this.isEditable.bind(this),
|
|
304
|
-
sortable: true,
|
|
305
|
-
resizable: true,
|
|
306
|
-
filter: true,
|
|
307
|
-
dictionaryDisplay: field.dictionaryDisplay
|
|
308
|
-
};
|
|
309
|
-
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
310
|
-
let num = this.dateComparator(valueA, valueB);
|
|
311
|
-
return isInverted ? -1 * num : num; //don't have to do anything with inverted?
|
|
312
|
-
};
|
|
313
|
-
col.cellStyle = params => {
|
|
314
|
-
var column = {};
|
|
315
|
-
for (let field of params.context.componentParent.dictionary.fields) {
|
|
316
|
-
if (params.colDef.field == field.name) {
|
|
317
|
-
column = field;
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
321
|
-
if (params.context.readOnly || column.readOnly ||
|
|
322
|
-
column.protectionType == "Read Only") {
|
|
323
|
-
return { color: "#8a9499" };
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
else {
|
|
327
|
-
if (params.context.readOnly || column.readOnly ||
|
|
328
|
-
column.protectionType == "Read Only" || column.createOnly ||
|
|
329
|
-
column.protectionType == "Create Only" || column.code) {
|
|
330
|
-
return { color: "#8a9499" };
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
};
|
|
334
|
-
col.displayOrder = field.displayOrder;
|
|
335
|
-
}
|
|
336
|
-
else {
|
|
337
|
-
// this is a string value
|
|
338
|
-
col = {
|
|
339
|
-
field: field.name,
|
|
340
|
-
headerName: field.displayName,
|
|
341
|
-
editable: this.isEditable.bind(this),
|
|
342
|
-
sortable: true,
|
|
343
|
-
resizable: true,
|
|
344
|
-
filter: true,
|
|
345
|
-
dictionaryDisplay: field.dictionaryDisplay
|
|
346
|
-
};
|
|
347
|
-
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
348
|
-
if (valueA && !valueB) {
|
|
349
|
-
return 1;
|
|
350
|
-
}
|
|
351
|
-
if (valueB && !valueA) {
|
|
352
|
-
return -1;
|
|
353
|
-
}
|
|
354
|
-
if (!valueA && !valueB) {
|
|
355
|
-
return 0;
|
|
356
|
-
}
|
|
357
|
-
if (valueA.toLowerCase() > valueB.toLowerCase()) {
|
|
358
|
-
return 1;
|
|
359
|
-
}
|
|
360
|
-
else if ((valueB.toLowerCase() > valueA.toLowerCase())) {
|
|
361
|
-
return -1;
|
|
362
|
-
}
|
|
363
|
-
else {
|
|
364
|
-
return 0;
|
|
365
|
-
}
|
|
366
|
-
};
|
|
367
|
-
col.cellStyle = params => {
|
|
368
|
-
var column = {};
|
|
369
|
-
for (let field of params.context.componentParent.dictionary.fields) {
|
|
370
|
-
if (params.colDef.field == field.name) {
|
|
371
|
-
column = field;
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
375
|
-
if (params.context.readOnly || column.readOnly ||
|
|
376
|
-
column.protectionType == "Read Only") {
|
|
377
|
-
return { color: "#8a9499" };
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
else {
|
|
381
|
-
if (params.context.readOnly || column.readOnly ||
|
|
382
|
-
column.protectionType == "Read Only" || column.createOnly ||
|
|
383
|
-
column.protectionType == "Create Only" || column.code) {
|
|
384
|
-
return { color: "#8a9499" };
|
|
385
|
-
}
|
|
386
|
-
}
|
|
387
|
-
};
|
|
388
|
-
col.displayOrder = field.displayOrder;
|
|
389
|
-
// Set default filter as compare by text/number
|
|
390
|
-
// col.filterRenderer = CompareFilterRenderer;
|
|
391
|
-
}
|
|
392
|
-
cols.push(col);
|
|
393
|
-
}
|
|
394
|
-
// Now we need to sort the columns
|
|
395
|
-
if (!this.dictionary.fields[0].hasOwnProperty("displayOrder")) {
|
|
396
|
-
// default case, no displayOrder
|
|
397
|
-
cols = cols.sort((a, b) => {
|
|
398
|
-
if (!a.headerName && b.headerName) {
|
|
399
|
-
return 1;
|
|
400
|
-
}
|
|
401
|
-
else if (!b.headerName && a.headerName) {
|
|
402
|
-
return -1;
|
|
403
|
-
}
|
|
404
|
-
else if (a.dictionaryDisplay === true && b.dictionaryDisplay === false) {
|
|
405
|
-
return -1;
|
|
406
|
-
}
|
|
407
|
-
else if (b.dictionaryDisplay === true && a.dictionaryDisplay === false) {
|
|
408
|
-
return 1;
|
|
409
|
-
}
|
|
410
|
-
else if (a.dictionaryTooltip === true && b.dictionaryTooltip === false) {
|
|
411
|
-
return -1;
|
|
412
|
-
}
|
|
413
|
-
else if (b.dictionaryTooltip === true && a.dictionaryTooltip === false) {
|
|
414
|
-
return 1;
|
|
415
|
-
}
|
|
416
|
-
else {
|
|
417
|
-
return 0;
|
|
418
|
-
}
|
|
419
|
-
});
|
|
420
|
-
}
|
|
421
|
-
else {
|
|
422
|
-
// DisplayOrder case
|
|
423
|
-
// I think this works? Check later
|
|
424
|
-
cols = cols.sort((a, b) => {
|
|
425
|
-
if (!a.headerName && b.headerName) {
|
|
426
|
-
return 1;
|
|
427
|
-
}
|
|
428
|
-
else if (!b.headerName && a.headerName) {
|
|
429
|
-
return -1;
|
|
430
|
-
}
|
|
431
|
-
else {
|
|
432
|
-
return a.displayOrder - b.displayOrder;
|
|
433
|
-
}
|
|
434
|
-
});
|
|
435
|
-
}
|
|
436
|
-
// After Columns Have Been Sorted
|
|
437
|
-
// Dictionary Grid Will Sort The Grid Ascending Order By First Column
|
|
438
|
-
if (cols && cols.length != 0) {
|
|
439
|
-
cols[0].sort = "asc";
|
|
440
|
-
}
|
|
441
|
-
this.dataColumns = cols;
|
|
442
|
-
if (Array.isArray(this.dataColumns) && this.gridOptions && this.gridOptions.api) {
|
|
443
|
-
this.gridOptions.api.setColumnDefs(this.dataColumns);
|
|
444
|
-
this.gridOptions.api.sizeColumnsToFit();
|
|
445
|
-
}
|
|
446
|
-
}
|
|
447
|
-
isEditable(params) {
|
|
448
|
-
let isEditable;
|
|
449
|
-
let column = {};
|
|
450
|
-
for (let field of this.dictionary.fields) {
|
|
451
|
-
if (params.colDef.field == field.name) {
|
|
452
|
-
column = field;
|
|
453
|
-
}
|
|
454
|
-
}
|
|
455
|
-
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
456
|
-
// console.log("new editable?");
|
|
457
|
-
isEditable = !(this.dictionary.readOnly || column.readOnly ||
|
|
458
|
-
column.protectionType == "Read Only");
|
|
459
|
-
}
|
|
460
|
-
else {
|
|
461
|
-
// console.log("edit editable?");
|
|
462
|
-
isEditable = !(this.dictionary.readOnly || column.readOnly ||
|
|
463
|
-
column.protectionType == "Read Only" || column.createOnly ||
|
|
464
|
-
column.protectionType == "Create Only" || column.code);
|
|
465
|
-
}
|
|
466
|
-
return isEditable;
|
|
467
|
-
}
|
|
468
|
-
deleteDictionaryEntries() {
|
|
469
|
-
let deleteRows = this.gridOptions.api.getSelectedRows();
|
|
470
|
-
for (let deleteId of this.selectedRows) {
|
|
471
|
-
for (let entry of this.dictionaryEntries) {
|
|
472
|
-
if (entry[this.idColumn] === deleteId) {
|
|
473
|
-
deleteRows.push(entry);
|
|
474
|
-
break;
|
|
475
|
-
}
|
|
476
|
-
}
|
|
477
|
-
}
|
|
478
|
-
this.dictionaryService.deleteDictionaryEntries(this.className, deleteRows).subscribe((response) => {
|
|
479
|
-
this.getDictionaryEntries();
|
|
480
|
-
});
|
|
481
|
-
}
|
|
482
|
-
updateDictionary(event) {
|
|
483
|
-
// Important to note this will not update cells to the demo but will when imported to CORE or other applications.
|
|
484
|
-
this.dictionaryService.updateDictionaryEntries(this.className, [event.data]).subscribe((data) => {
|
|
485
|
-
this.getDictionaryEntries();
|
|
486
|
-
});
|
|
487
|
-
}
|
|
488
|
-
setSelectedEntries() {
|
|
489
|
-
this.selectedRows = this.gridOptions.api.getSelectedRows();
|
|
490
|
-
}
|
|
491
|
-
newRowPost(data) {
|
|
492
|
-
return this.dictionaryService.addDictionaryEntries(this.className, [data])
|
|
493
|
-
.pipe(map((data) => {
|
|
494
|
-
if (data && data.length === 1) {
|
|
495
|
-
return data[0];
|
|
496
|
-
}
|
|
497
|
-
else {
|
|
498
|
-
return data;
|
|
499
|
-
}
|
|
500
|
-
}));
|
|
501
|
-
}
|
|
502
|
-
static onSamplesGridReady(event) {
|
|
503
|
-
event.api.sizeColumnsToFit();
|
|
504
|
-
}
|
|
505
|
-
static onGridSizeChanged(event) {
|
|
506
|
-
if (event && event.api) {
|
|
507
|
-
event.api.sizeColumnsToFit();
|
|
508
|
-
}
|
|
509
|
-
}
|
|
510
|
-
get disableAddRow() {
|
|
511
|
-
if (!this.dictionary) {
|
|
512
|
-
return true;
|
|
513
|
-
}
|
|
514
|
-
return this.dictionary.readOnly && this.dictionary.readOnly === true;
|
|
515
|
-
}
|
|
516
|
-
get disableDelete() {
|
|
517
|
-
if (!this.dictionary) {
|
|
518
|
-
return true;
|
|
519
|
-
}
|
|
520
|
-
if (this.dictionary.readOnly && this.dictionary.readOnly === true) {
|
|
521
|
-
return true;
|
|
522
|
-
}
|
|
523
|
-
if (this.gridOptions && this.gridOptions.api && this.gridOptions.api.getSelectedRows()) {
|
|
524
|
-
return this.gridOptions.api.getSelectedRows().length === 0;
|
|
525
|
-
}
|
|
526
|
-
else {
|
|
527
|
-
return true;
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
comboFilterValueGetter(params) {
|
|
531
|
-
let value = params.data[params.colDef.field];
|
|
532
|
-
if (value) {
|
|
533
|
-
let option = params.colDef.selectOptions.find((entry) => (entry[params.colDef.selectOptionsValueField] === value));
|
|
534
|
-
return option ? option[params.colDef.selectOptionsDisplayField] : "";
|
|
535
|
-
}
|
|
536
|
-
return "";
|
|
537
|
-
}
|
|
538
|
-
onClickAddRow() {
|
|
539
|
-
const modalRef = this.modalService.open(NewRowComponent, {
|
|
540
|
-
size: "lg",
|
|
541
|
-
keyboard: false,
|
|
542
|
-
backdrop: "static",
|
|
543
|
-
centered: true,
|
|
544
|
-
});
|
|
545
|
-
modalRef.componentInstance.colDefs = this.dataColumns;
|
|
546
|
-
modalRef.componentInstance.dictionary = this.dictionary;
|
|
547
|
-
if (!this.newRowSubscription) {
|
|
548
|
-
// tell other ag-grid to add row to it
|
|
549
|
-
this.newRowSubscription = modalRef.componentInstance.newRowSubject.subscribe((theNewRow) => {
|
|
550
|
-
this.dictionaryEntries = theNewRow.concat(this.dictionaryEntries);
|
|
551
|
-
this.gridOptions.api.setRowData(this.dictionaryEntries);
|
|
552
|
-
this.newRowSubscription = null;
|
|
553
|
-
// Important to note this will not add rows to the demo but will when imported to CORE or other applications.
|
|
554
|
-
this.newRowPost(theNewRow[0]).subscribe(() => {
|
|
555
|
-
this.getDictionaryEntries();
|
|
556
|
-
});
|
|
557
|
-
});
|
|
558
|
-
}
|
|
559
|
-
}
|
|
560
|
-
/**
|
|
561
|
-
* Comparater To Compare 2 Dates
|
|
562
|
-
* @param date1 Date 1
|
|
563
|
-
* @param date2 Date 2
|
|
564
|
-
*/
|
|
565
|
-
dateComparator(date1, date2) {
|
|
566
|
-
let date1Number = monthToComparableNumber(date1);
|
|
567
|
-
let date2Number = monthToComparableNumber(date2);
|
|
568
|
-
if (date1Number === null && date2Number === null) {
|
|
569
|
-
return 0;
|
|
570
|
-
}
|
|
571
|
-
if (date1Number === null) {
|
|
572
|
-
return -1;
|
|
573
|
-
}
|
|
574
|
-
if (date2Number === null) {
|
|
575
|
-
return 1;
|
|
576
|
-
}
|
|
577
|
-
return date1Number - date2Number;
|
|
578
|
-
}
|
|
579
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
580
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
1
|
+
import { Component, Inject, isDevMode, HostBinding } from "@angular/core";
|
|
2
|
+
import { ActivatedRoute } from "@angular/router";
|
|
3
|
+
import { BehaviorSubject } from "rxjs";
|
|
4
|
+
import { finalize, map } from "rxjs/operators";
|
|
5
|
+
import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
|
|
6
|
+
import { DictionaryService, DICTIONARY_ENDPOINT } from "@huntsman-cancer-institute/dictionary-service";
|
|
7
|
+
import { SelectRenderer } from "../grid-renderers/select.renderer";
|
|
8
|
+
import { SelectEditor } from "../grid-editors/select.editor";
|
|
9
|
+
import { NewRowComponent } from "./new-row.component";
|
|
10
|
+
import { isNullOrUndefined } from "util";
|
|
11
|
+
import { DateRenderer } from "../grid-renderers/date.renderer";
|
|
12
|
+
import { AgGridDateCellEditorComponent } from "../grid-editors/ag-grid-date-cell-editor.component";
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "@angular/router";
|
|
15
|
+
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
16
|
+
import * as i3 from "@huntsman-cancer-institute/dictionary-service";
|
|
17
|
+
import * as i4 from "@huntsman-cancer-institute/misc";
|
|
18
|
+
import * as i5 from "ag-grid-angular";
|
|
19
|
+
/**
|
|
20
|
+
* When a dictionary is selected this component is shown. There is a top grid which for its data shows all the columns
|
|
21
|
+
* for the dictionary. Currently, keep this for reference only and have non-editable.
|
|
22
|
+
* The bottom grid will show those columns as actual columns and its data are all the dictionary values. Rows can be
|
|
23
|
+
* added. For deleting, need to make sure the id is not used anywhere. For editing, need to make sure the code or anything
|
|
24
|
+
* else isn't being referenced.
|
|
25
|
+
*
|
|
26
|
+
* @since 1.0.0
|
|
27
|
+
*/
|
|
28
|
+
export class DictionaryEditorDetailComponent {
|
|
29
|
+
constructor(route, modalService, dictionaryService, dictionaryEndpoint) {
|
|
30
|
+
this.route = route;
|
|
31
|
+
this.modalService = modalService;
|
|
32
|
+
this.dictionaryService = dictionaryService;
|
|
33
|
+
this.dictionaryEndpoint = dictionaryEndpoint;
|
|
34
|
+
this.classList = "outlet-column y-auto";
|
|
35
|
+
this.dictionaryEntries = [];
|
|
36
|
+
this.selectedRows = [];
|
|
37
|
+
this.loadingSubjects = [];
|
|
38
|
+
this.metaGridOptions = {
|
|
39
|
+
rowStyle: {
|
|
40
|
+
"font-family": "Prompt, sans-serif"
|
|
41
|
+
},
|
|
42
|
+
enableCellTextSelection: true,
|
|
43
|
+
ensureDomOrder: true
|
|
44
|
+
};
|
|
45
|
+
this.gridOptions = {
|
|
46
|
+
context: {
|
|
47
|
+
componentParent: this
|
|
48
|
+
},
|
|
49
|
+
onGridReady: DictionaryEditorDetailComponent.onSamplesGridReady,
|
|
50
|
+
onGridSizeChanged: DictionaryEditorDetailComponent.onGridSizeChanged,
|
|
51
|
+
suppressHorizontalScroll: false,
|
|
52
|
+
selectionMode: "multiple",
|
|
53
|
+
stopEditingWhenGridLosesFocus: true,
|
|
54
|
+
enableSorting: true,
|
|
55
|
+
enableFilter: true
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Based on the route class name, make the call to fetch the dictionary data. Since this component is route based,
|
|
60
|
+
* when the dictionary class in the route changes, this component is reloaded.
|
|
61
|
+
*/
|
|
62
|
+
ngOnInit() {
|
|
63
|
+
this.boundNewRowPostCall = this.newRowPost.bind(this);
|
|
64
|
+
this.loadingSubjects.push(new BehaviorSubject(false));
|
|
65
|
+
this.loadingSubjects.push(new BehaviorSubject(false));
|
|
66
|
+
this.route.params.subscribe(params => {
|
|
67
|
+
let className = params["className"];
|
|
68
|
+
this.getDictionary(className);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
openModal(modal) {
|
|
72
|
+
this.modalService.open(modal, { windowClass: "modal-xl" }).result.then((result) => {
|
|
73
|
+
}, (reason) => {
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
ngAfterViewInit() {
|
|
77
|
+
this.gridOptions.api.sizeColumnsToFit();
|
|
78
|
+
}
|
|
79
|
+
columnDefMeta() {
|
|
80
|
+
return [
|
|
81
|
+
{ field: "name", headerName: "Name", width: 175, sortable: true, resizable: true, editable: false },
|
|
82
|
+
{ field: "description", headerName: "Description", width: 250, sortable: true, resizable: true, editable: false },
|
|
83
|
+
{ field: "id", headerName: "Id", width: 60, sortable: true, resizable: true, editable: false },
|
|
84
|
+
{ field: "type", headerName: "Type", sortable: true, resizable: true, editable: false },
|
|
85
|
+
{ field: "protectionType", headerName: "ProtectionType", sortable: true, resizable: true, editable: false },
|
|
86
|
+
{ field: "filterDictionaryClass", headerName: "FilterDictionaryClass", width: 180, sortable: true, resizable: true, editable: false },
|
|
87
|
+
{ field: "notNull", headerName: "NotNull", sortable: true, resizable: true, editable: false },
|
|
88
|
+
{ field: "integer", headerName: "Integer", width: 75, sortable: true, resizable: true, editable: false },
|
|
89
|
+
{ field: "min", headerName: "Min", width: 60, sortable: true, resizable: true, editable: false },
|
|
90
|
+
{ field: "max", headerName: "Max", width: 60, sortable: true, resizable: true, editable: false },
|
|
91
|
+
{ field: "fraction", headerName: "Fraction", sortable: true, resizable: true, editable: false },
|
|
92
|
+
{ field: "dictionaryTooltip", headerName: "DictionaryTooltip", width: 200, sortable: true, resizable: true, editable: false },
|
|
93
|
+
{ field: "dictionaryDisplay", headerName: "DictionaryDisplay", width: 175, sortable: true, resizable: true, editable: false },
|
|
94
|
+
{ field: "filterable", headerName: "Filterable", sortable: true, resizable: true, editable: false },
|
|
95
|
+
{ field: "displayName", headerName: "DisplayName", width: 175, sortable: true, resizable: true, editable: false },
|
|
96
|
+
{ field: "displayOrder", headerName: "DisplayOrder", width: 60, sortable: true, resizable: true, editable: false },
|
|
97
|
+
{ field: "cellStyle", headerName: "CellStyle", sortable: true, resizable: true, editable: false },
|
|
98
|
+
]; // the widths for the last 2 could be wrong.
|
|
99
|
+
}
|
|
100
|
+
onMetaGridReady(params) {
|
|
101
|
+
this.gridApiMeta = params.api;
|
|
102
|
+
this.gridApiMeta.setColumnDefs(this.columnDefMeta());
|
|
103
|
+
this.gridApiMeta.setRowData(this.dictionary?.fields);
|
|
104
|
+
// this.gridApiMeta.sizeColumnsToFit();
|
|
105
|
+
}
|
|
106
|
+
openAreYouSureModal(modal) {
|
|
107
|
+
this.modalService.open(modal).result.then((result) => {
|
|
108
|
+
if (result === "Delete") {
|
|
109
|
+
this.deleteDictionaryEntries();
|
|
110
|
+
}
|
|
111
|
+
}, (reason) => {
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Fetch the dictionary metadata and dictionary entries based upon the dictionary class name.
|
|
116
|
+
*
|
|
117
|
+
* @param {string} className
|
|
118
|
+
*/
|
|
119
|
+
getDictionary(className) {
|
|
120
|
+
// When Selecting A New Dictionary, Navigate To First Page
|
|
121
|
+
if (this.gridOptions && this.gridOptions.api) {
|
|
122
|
+
this.gridOptions.api.paginationGoToFirstPage();
|
|
123
|
+
}
|
|
124
|
+
this.className = className;
|
|
125
|
+
this.dataColumns = undefined;
|
|
126
|
+
this.loadingSubjects[0].next(true);
|
|
127
|
+
this.dictionaryService.getDictionary(className)
|
|
128
|
+
.pipe(finalize(() => {
|
|
129
|
+
this.loadingSubjects[0].next(false);
|
|
130
|
+
})).subscribe((dictionary) => {
|
|
131
|
+
this.setUpDictionaryGrid(dictionary);
|
|
132
|
+
this.loadingSubjects[0].next(false);
|
|
133
|
+
});
|
|
134
|
+
this.getDictionaryEntries();
|
|
135
|
+
}
|
|
136
|
+
getDictionaryEntries() {
|
|
137
|
+
this.loadingSubjects[1].next(true);
|
|
138
|
+
this.dictionaryService.getDictionaryEntries(this.className)
|
|
139
|
+
.pipe(finalize(() => {
|
|
140
|
+
this.loadingSubjects[1].next(false);
|
|
141
|
+
})).subscribe((dictionaryEntries) => {
|
|
142
|
+
this.dictionaryEntries = dictionaryEntries;
|
|
143
|
+
this.gridOptions.api.setRowData(dictionaryEntries);
|
|
144
|
+
this.gridOptions.api.sizeColumnsToFit();
|
|
145
|
+
this.loadingSubjects[1].next(false);
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Set the dictionary metadata. This is used to build the columns for the dictionary entries. The names, validation,
|
|
150
|
+
* and filter classes build the column definition.
|
|
151
|
+
*
|
|
152
|
+
* @param dictionary
|
|
153
|
+
*/
|
|
154
|
+
setUpDictionaryGrid(dictionary) {
|
|
155
|
+
if (isDevMode()) {
|
|
156
|
+
console.debug("DictionaryEditorDetailComponent.setDictionary");
|
|
157
|
+
console.debug(dictionary);
|
|
158
|
+
}
|
|
159
|
+
this.dictionary = dictionary;
|
|
160
|
+
this.secondaryDictionaryEntries = [];
|
|
161
|
+
let dictionaryClassNames = [];
|
|
162
|
+
for (let field of dictionary.fields) {
|
|
163
|
+
if (field.filterDictionaryClass) {
|
|
164
|
+
dictionaryClassNames.push(field.filterDictionaryClass);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
this.getSecondaryDictionaries(dictionaryClassNames);
|
|
168
|
+
}
|
|
169
|
+
getSecondaryDictionaries(dictionaryNames) {
|
|
170
|
+
if (dictionaryNames.length == 0) {
|
|
171
|
+
this.finishColumnSetup();
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
let dictionaryName = dictionaryNames.pop();
|
|
175
|
+
this.dictionaryService.getDictionaryDropdownEntries(dictionaryName).subscribe((response) => {
|
|
176
|
+
this.secondaryDictionaryEntries.push({ dictionaryName: dictionaryName, entries: response });
|
|
177
|
+
this.getSecondaryDictionaries(dictionaryNames);
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
finishColumnSetup() {
|
|
182
|
+
this.displayName = this.dictionary.displayName;
|
|
183
|
+
// This establishes the readOnly functionality
|
|
184
|
+
let cols = [];
|
|
185
|
+
// Process Columns And Create Column Definition
|
|
186
|
+
for (let field of this.dictionary.fields) {
|
|
187
|
+
if (field.id && (isNullOrUndefined(field.code) || field.code == false)) {
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
let col;
|
|
191
|
+
if (field.filterDictionaryClass) {
|
|
192
|
+
// this is a dropdown of another dictionary
|
|
193
|
+
let options = this.secondaryDictionaryEntries.find((a) => {
|
|
194
|
+
return a.dictionaryName === field.filterDictionaryClass;
|
|
195
|
+
});
|
|
196
|
+
col = {
|
|
197
|
+
field: field.name,
|
|
198
|
+
headerName: field.displayName,
|
|
199
|
+
editable: this.isEditable.bind(this),
|
|
200
|
+
cellRendererFramework: SelectRenderer,
|
|
201
|
+
cellEditorFramework: SelectEditor,
|
|
202
|
+
selectOptionsDisplayField: "display",
|
|
203
|
+
selectOptionsValueField: "id",
|
|
204
|
+
sortable: true,
|
|
205
|
+
resizable: true,
|
|
206
|
+
filter: true,
|
|
207
|
+
filterValueGetter: this.comboFilterValueGetter,
|
|
208
|
+
selectOptions: [],
|
|
209
|
+
comparator: (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
210
|
+
return 0;
|
|
211
|
+
}
|
|
212
|
+
};
|
|
213
|
+
if (options && options.entries) {
|
|
214
|
+
col.selectOptions = options.entries.sort((optionA, optionB) => {
|
|
215
|
+
if (optionA && !optionB) {
|
|
216
|
+
return 1;
|
|
217
|
+
}
|
|
218
|
+
if (optionB && !optionA) {
|
|
219
|
+
return -1;
|
|
220
|
+
}
|
|
221
|
+
if (!optionA && !optionB) {
|
|
222
|
+
return 0;
|
|
223
|
+
}
|
|
224
|
+
if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {
|
|
225
|
+
return 1;
|
|
226
|
+
}
|
|
227
|
+
else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {
|
|
228
|
+
return -1;
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
return 0;
|
|
232
|
+
}
|
|
233
|
+
});
|
|
234
|
+
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
235
|
+
if (!options.entries) {
|
|
236
|
+
return 0;
|
|
237
|
+
}
|
|
238
|
+
if (valueA && !valueB) {
|
|
239
|
+
return 1;
|
|
240
|
+
}
|
|
241
|
+
if (valueB && !valueA) {
|
|
242
|
+
return -1;
|
|
243
|
+
}
|
|
244
|
+
if (!valueA && !valueB) {
|
|
245
|
+
return 0;
|
|
246
|
+
}
|
|
247
|
+
let optionA = options.entries.find((entry) => ("" + entry.id === "" + valueA));
|
|
248
|
+
let optionB = options.entries.find((entry) => ("" + entry.id === "" + valueB));
|
|
249
|
+
if (optionA && !optionB) {
|
|
250
|
+
return 1;
|
|
251
|
+
}
|
|
252
|
+
if (optionB && !optionA) {
|
|
253
|
+
return -1;
|
|
254
|
+
}
|
|
255
|
+
if (!optionA && !optionB) {
|
|
256
|
+
return 0;
|
|
257
|
+
}
|
|
258
|
+
if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {
|
|
259
|
+
return 1;
|
|
260
|
+
}
|
|
261
|
+
else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {
|
|
262
|
+
return -1;
|
|
263
|
+
}
|
|
264
|
+
else {
|
|
265
|
+
return 0;
|
|
266
|
+
}
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
col.cellStyle = params => {
|
|
270
|
+
let column = {};
|
|
271
|
+
for (let field of params.context.componentParent.dictionary.fields) {
|
|
272
|
+
if (params.colDef.field == field.name) {
|
|
273
|
+
column = field;
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
277
|
+
if (params.context.readOnly || column.readOnly ||
|
|
278
|
+
column.protectionType == "Read Only") {
|
|
279
|
+
return { color: "#8a9499" };
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
else {
|
|
283
|
+
if (params.context.readOnly || column.readOnly ||
|
|
284
|
+
column.protectionType == "Read Only" || column.createOnly ||
|
|
285
|
+
column.protectionType == "Create Only" || column.code) {
|
|
286
|
+
return { color: "#8a9499" };
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
};
|
|
290
|
+
col.displayOrder = field.displayOrder;
|
|
291
|
+
col.dictionaryDisplay = field.dictionaryDisplay;
|
|
292
|
+
col.dictionaryTooltip = field.dictionaryTooltip;
|
|
293
|
+
// Set default filter as compare by text/number
|
|
294
|
+
// col.filterRenderer = CompareFilterRenderer;
|
|
295
|
+
}
|
|
296
|
+
else if (field.type && field.type == "Date") {
|
|
297
|
+
//date value
|
|
298
|
+
col = {
|
|
299
|
+
field: field.name,
|
|
300
|
+
headerName: field.displayName,
|
|
301
|
+
cellRendererFramework: DateRenderer,
|
|
302
|
+
cellEditorFramework: AgGridDateCellEditorComponent,
|
|
303
|
+
editable: this.isEditable.bind(this),
|
|
304
|
+
sortable: true,
|
|
305
|
+
resizable: true,
|
|
306
|
+
filter: true,
|
|
307
|
+
dictionaryDisplay: field.dictionaryDisplay
|
|
308
|
+
};
|
|
309
|
+
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
310
|
+
let num = this.dateComparator(valueA, valueB);
|
|
311
|
+
return isInverted ? -1 * num : num; //don't have to do anything with inverted?
|
|
312
|
+
};
|
|
313
|
+
col.cellStyle = params => {
|
|
314
|
+
var column = {};
|
|
315
|
+
for (let field of params.context.componentParent.dictionary.fields) {
|
|
316
|
+
if (params.colDef.field == field.name) {
|
|
317
|
+
column = field;
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
321
|
+
if (params.context.readOnly || column.readOnly ||
|
|
322
|
+
column.protectionType == "Read Only") {
|
|
323
|
+
return { color: "#8a9499" };
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
else {
|
|
327
|
+
if (params.context.readOnly || column.readOnly ||
|
|
328
|
+
column.protectionType == "Read Only" || column.createOnly ||
|
|
329
|
+
column.protectionType == "Create Only" || column.code) {
|
|
330
|
+
return { color: "#8a9499" };
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
};
|
|
334
|
+
col.displayOrder = field.displayOrder;
|
|
335
|
+
}
|
|
336
|
+
else {
|
|
337
|
+
// this is a string value
|
|
338
|
+
col = {
|
|
339
|
+
field: field.name,
|
|
340
|
+
headerName: field.displayName,
|
|
341
|
+
editable: this.isEditable.bind(this),
|
|
342
|
+
sortable: true,
|
|
343
|
+
resizable: true,
|
|
344
|
+
filter: true,
|
|
345
|
+
dictionaryDisplay: field.dictionaryDisplay
|
|
346
|
+
};
|
|
347
|
+
col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {
|
|
348
|
+
if (valueA && !valueB) {
|
|
349
|
+
return 1;
|
|
350
|
+
}
|
|
351
|
+
if (valueB && !valueA) {
|
|
352
|
+
return -1;
|
|
353
|
+
}
|
|
354
|
+
if (!valueA && !valueB) {
|
|
355
|
+
return 0;
|
|
356
|
+
}
|
|
357
|
+
if (valueA.toLowerCase() > valueB.toLowerCase()) {
|
|
358
|
+
return 1;
|
|
359
|
+
}
|
|
360
|
+
else if ((valueB.toLowerCase() > valueA.toLowerCase())) {
|
|
361
|
+
return -1;
|
|
362
|
+
}
|
|
363
|
+
else {
|
|
364
|
+
return 0;
|
|
365
|
+
}
|
|
366
|
+
};
|
|
367
|
+
col.cellStyle = params => {
|
|
368
|
+
var column = {};
|
|
369
|
+
for (let field of params.context.componentParent.dictionary.fields) {
|
|
370
|
+
if (params.colDef.field == field.name) {
|
|
371
|
+
column = field;
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
375
|
+
if (params.context.readOnly || column.readOnly ||
|
|
376
|
+
column.protectionType == "Read Only") {
|
|
377
|
+
return { color: "#8a9499" };
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
else {
|
|
381
|
+
if (params.context.readOnly || column.readOnly ||
|
|
382
|
+
column.protectionType == "Read Only" || column.createOnly ||
|
|
383
|
+
column.protectionType == "Create Only" || column.code) {
|
|
384
|
+
return { color: "#8a9499" };
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
};
|
|
388
|
+
col.displayOrder = field.displayOrder;
|
|
389
|
+
// Set default filter as compare by text/number
|
|
390
|
+
// col.filterRenderer = CompareFilterRenderer;
|
|
391
|
+
}
|
|
392
|
+
cols.push(col);
|
|
393
|
+
}
|
|
394
|
+
// Now we need to sort the columns
|
|
395
|
+
if (!this.dictionary.fields[0].hasOwnProperty("displayOrder")) {
|
|
396
|
+
// default case, no displayOrder
|
|
397
|
+
cols = cols.sort((a, b) => {
|
|
398
|
+
if (!a.headerName && b.headerName) {
|
|
399
|
+
return 1;
|
|
400
|
+
}
|
|
401
|
+
else if (!b.headerName && a.headerName) {
|
|
402
|
+
return -1;
|
|
403
|
+
}
|
|
404
|
+
else if (a.dictionaryDisplay === true && b.dictionaryDisplay === false) {
|
|
405
|
+
return -1;
|
|
406
|
+
}
|
|
407
|
+
else if (b.dictionaryDisplay === true && a.dictionaryDisplay === false) {
|
|
408
|
+
return 1;
|
|
409
|
+
}
|
|
410
|
+
else if (a.dictionaryTooltip === true && b.dictionaryTooltip === false) {
|
|
411
|
+
return -1;
|
|
412
|
+
}
|
|
413
|
+
else if (b.dictionaryTooltip === true && a.dictionaryTooltip === false) {
|
|
414
|
+
return 1;
|
|
415
|
+
}
|
|
416
|
+
else {
|
|
417
|
+
return 0;
|
|
418
|
+
}
|
|
419
|
+
});
|
|
420
|
+
}
|
|
421
|
+
else {
|
|
422
|
+
// DisplayOrder case
|
|
423
|
+
// I think this works? Check later
|
|
424
|
+
cols = cols.sort((a, b) => {
|
|
425
|
+
if (!a.headerName && b.headerName) {
|
|
426
|
+
return 1;
|
|
427
|
+
}
|
|
428
|
+
else if (!b.headerName && a.headerName) {
|
|
429
|
+
return -1;
|
|
430
|
+
}
|
|
431
|
+
else {
|
|
432
|
+
return a.displayOrder - b.displayOrder;
|
|
433
|
+
}
|
|
434
|
+
});
|
|
435
|
+
}
|
|
436
|
+
// After Columns Have Been Sorted
|
|
437
|
+
// Dictionary Grid Will Sort The Grid Ascending Order By First Column
|
|
438
|
+
if (cols && cols.length != 0) {
|
|
439
|
+
cols[0].sort = "asc";
|
|
440
|
+
}
|
|
441
|
+
this.dataColumns = cols;
|
|
442
|
+
if (Array.isArray(this.dataColumns) && this.gridOptions && this.gridOptions.api) {
|
|
443
|
+
this.gridOptions.api.setColumnDefs(this.dataColumns);
|
|
444
|
+
this.gridOptions.api.sizeColumnsToFit();
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
isEditable(params) {
|
|
448
|
+
let isEditable;
|
|
449
|
+
let column = {};
|
|
450
|
+
for (let field of this.dictionary.fields) {
|
|
451
|
+
if (params.colDef.field == field.name) {
|
|
452
|
+
column = field;
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
if (params.data.editOrNew && params.data.editOrNew == "new") {
|
|
456
|
+
// console.log("new editable?");
|
|
457
|
+
isEditable = !(this.dictionary.readOnly || column.readOnly ||
|
|
458
|
+
column.protectionType == "Read Only");
|
|
459
|
+
}
|
|
460
|
+
else {
|
|
461
|
+
// console.log("edit editable?");
|
|
462
|
+
isEditable = !(this.dictionary.readOnly || column.readOnly ||
|
|
463
|
+
column.protectionType == "Read Only" || column.createOnly ||
|
|
464
|
+
column.protectionType == "Create Only" || column.code);
|
|
465
|
+
}
|
|
466
|
+
return isEditable;
|
|
467
|
+
}
|
|
468
|
+
deleteDictionaryEntries() {
|
|
469
|
+
let deleteRows = this.gridOptions.api.getSelectedRows();
|
|
470
|
+
for (let deleteId of this.selectedRows) {
|
|
471
|
+
for (let entry of this.dictionaryEntries) {
|
|
472
|
+
if (entry[this.idColumn] === deleteId) {
|
|
473
|
+
deleteRows.push(entry);
|
|
474
|
+
break;
|
|
475
|
+
}
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
this.dictionaryService.deleteDictionaryEntries(this.className, deleteRows).subscribe((response) => {
|
|
479
|
+
this.getDictionaryEntries();
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
updateDictionary(event) {
|
|
483
|
+
// Important to note this will not update cells to the demo but will when imported to CORE or other applications.
|
|
484
|
+
this.dictionaryService.updateDictionaryEntries(this.className, [event.data]).subscribe((data) => {
|
|
485
|
+
this.getDictionaryEntries();
|
|
486
|
+
});
|
|
487
|
+
}
|
|
488
|
+
setSelectedEntries() {
|
|
489
|
+
this.selectedRows = this.gridOptions.api.getSelectedRows();
|
|
490
|
+
}
|
|
491
|
+
newRowPost(data) {
|
|
492
|
+
return this.dictionaryService.addDictionaryEntries(this.className, [data])
|
|
493
|
+
.pipe(map((data) => {
|
|
494
|
+
if (data && data.length === 1) {
|
|
495
|
+
return data[0];
|
|
496
|
+
}
|
|
497
|
+
else {
|
|
498
|
+
return data;
|
|
499
|
+
}
|
|
500
|
+
}));
|
|
501
|
+
}
|
|
502
|
+
static onSamplesGridReady(event) {
|
|
503
|
+
event.api.sizeColumnsToFit();
|
|
504
|
+
}
|
|
505
|
+
static onGridSizeChanged(event) {
|
|
506
|
+
if (event && event.api) {
|
|
507
|
+
event.api.sizeColumnsToFit();
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
get disableAddRow() {
|
|
511
|
+
if (!this.dictionary) {
|
|
512
|
+
return true;
|
|
513
|
+
}
|
|
514
|
+
return this.dictionary.readOnly && this.dictionary.readOnly === true;
|
|
515
|
+
}
|
|
516
|
+
get disableDelete() {
|
|
517
|
+
if (!this.dictionary) {
|
|
518
|
+
return true;
|
|
519
|
+
}
|
|
520
|
+
if (this.dictionary.readOnly && this.dictionary.readOnly === true) {
|
|
521
|
+
return true;
|
|
522
|
+
}
|
|
523
|
+
if (this.gridOptions && this.gridOptions.api && this.gridOptions.api.getSelectedRows()) {
|
|
524
|
+
return this.gridOptions.api.getSelectedRows().length === 0;
|
|
525
|
+
}
|
|
526
|
+
else {
|
|
527
|
+
return true;
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
comboFilterValueGetter(params) {
|
|
531
|
+
let value = params.data[params.colDef.field];
|
|
532
|
+
if (value) {
|
|
533
|
+
let option = params.colDef.selectOptions.find((entry) => (entry[params.colDef.selectOptionsValueField] === value));
|
|
534
|
+
return option ? option[params.colDef.selectOptionsDisplayField] : "";
|
|
535
|
+
}
|
|
536
|
+
return "";
|
|
537
|
+
}
|
|
538
|
+
onClickAddRow() {
|
|
539
|
+
const modalRef = this.modalService.open(NewRowComponent, {
|
|
540
|
+
size: "lg",
|
|
541
|
+
keyboard: false,
|
|
542
|
+
backdrop: "static",
|
|
543
|
+
centered: true,
|
|
544
|
+
});
|
|
545
|
+
modalRef.componentInstance.colDefs = this.dataColumns;
|
|
546
|
+
modalRef.componentInstance.dictionary = this.dictionary;
|
|
547
|
+
if (!this.newRowSubscription) {
|
|
548
|
+
// tell other ag-grid to add row to it
|
|
549
|
+
this.newRowSubscription = modalRef.componentInstance.newRowSubject.subscribe((theNewRow) => {
|
|
550
|
+
this.dictionaryEntries = theNewRow.concat(this.dictionaryEntries);
|
|
551
|
+
this.gridOptions.api.setRowData(this.dictionaryEntries);
|
|
552
|
+
this.newRowSubscription = null;
|
|
553
|
+
// Important to note this will not add rows to the demo but will when imported to CORE or other applications.
|
|
554
|
+
this.newRowPost(theNewRow[0]).subscribe(() => {
|
|
555
|
+
this.getDictionaryEntries();
|
|
556
|
+
});
|
|
557
|
+
});
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
/**
|
|
561
|
+
* Comparater To Compare 2 Dates
|
|
562
|
+
* @param date1 Date 1
|
|
563
|
+
* @param date2 Date 2
|
|
564
|
+
*/
|
|
565
|
+
dateComparator(date1, date2) {
|
|
566
|
+
let date1Number = monthToComparableNumber(date1);
|
|
567
|
+
let date2Number = monthToComparableNumber(date2);
|
|
568
|
+
if (date1Number === null && date2Number === null) {
|
|
569
|
+
return 0;
|
|
570
|
+
}
|
|
571
|
+
if (date1Number === null) {
|
|
572
|
+
return -1;
|
|
573
|
+
}
|
|
574
|
+
if (date2Number === null) {
|
|
575
|
+
return 1;
|
|
576
|
+
}
|
|
577
|
+
return date1Number - date2Number;
|
|
578
|
+
}
|
|
579
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DictionaryEditorDetailComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.NgbModal }, { token: i3.DictionaryService }, { token: DICTIONARY_ENDPOINT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
580
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: DictionaryEditorDetailComponent, selector: "hci-dictionary-editor-detail", host: { properties: { "class": "this.classList" } }, ngImport: i0, template: `
|
|
581
581
|
<div class="d-flex flex-column hci-dictionary-detail-body"
|
|
582
582
|
>
|
|
583
583
|
<hci-busy [busySubjects]="loadingSubjects"></hci-busy>
|
|
@@ -661,10 +661,10 @@ export class DictionaryEditorDetailComponent {
|
|
|
661
661
|
</div>
|
|
662
662
|
</ng-template>
|
|
663
663
|
</div>
|
|
664
|
-
`, isInline: true, styles: [".full-height{height:100%}.full-width{width:100%}.ag-theme-balham{font-family:Prompt;font-weight:500}.active-color{float:right;font-size:15px;color:var(--bluewarm-dark)}.deactivated-color{float:right;font-size:15px;color:var(--greywarm-medlight)}.dictionary-info-section{padding-top:10px}.dictionary-title{float:left;font-size:16px;padding-left:10px;padding-right:10px;padding-top:5px}.metadata-button{color:var(--white-lightest);float:left;font-size:15px}:host::ng-deep .ag-header-cell{background-color:var(--bluewarmvividfade-lightest);border:lightgray solid thin}:host::ng-deep .ag-cell{border-right:lightgray solid thin;border-left:lightgray solid thin}:host::ng-deep .ag-row{border-bottom:0;border-top:0}:host::ng-deep .ag-row-even{background-color:var(--white-medium)}.hci-dictionary-detail-body{height:100%;width:100%;background:linear-gradient(0deg,var(--white-lightest) 30%,var(--bluewarmvividfade-lighter) 100%)!important}.hci-dictoinary-display-grid{padding-right:5px;padding-left:5px;box-shadow:#00000059 0 5px 15px}:host::ng-deep .ag-row-hover{color:#666!important;background-color:var(--bluewarmvividfade-lighter)!important}:host::ng-deep .ag-row-selected .ag-cell{color:var(--white-lightest)!important}:host::ng-deep .ag-row-selected{color:var(--white-darker)!important;background-color:var(--bluewarmvivid-lighter)!important}\n"], dependencies: [{ kind: "component", type: i4.BusyComponent, selector: "hci-busy", inputs: ["busy", "busySubjects", "getBusySubjects", "parentSelector", "rootClass", "icon", "iconSize", "showIcon", "mxAuto", "myAuto", "text", "template", "config"] }, { kind: "component", type: i5.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"] }] }); }
|
|
665
|
-
}
|
|
666
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
667
|
-
type: Component,
|
|
664
|
+
`, isInline: true, styles: [".full-height{height:100%}.full-width{width:100%}.ag-theme-balham{font-family:Prompt;font-weight:500}.active-color{float:right;font-size:15px;color:var(--bluewarm-dark)}.deactivated-color{float:right;font-size:15px;color:var(--greywarm-medlight)}.dictionary-info-section{padding-top:10px}.dictionary-title{float:left;font-size:16px;padding-left:10px;padding-right:10px;padding-top:5px}.metadata-button{color:var(--white-lightest);float:left;font-size:15px}:host::ng-deep .ag-header-cell{background-color:var(--bluewarmvividfade-lightest);border:lightgray solid thin}:host::ng-deep .ag-cell{border-right:lightgray solid thin;border-left:lightgray solid thin}:host::ng-deep .ag-row{border-bottom:0;border-top:0}:host::ng-deep .ag-row-even{background-color:var(--white-medium)}.hci-dictionary-detail-body{height:100%;width:100%;background:linear-gradient(0deg,var(--white-lightest) 30%,var(--bluewarmvividfade-lighter) 100%)!important}.hci-dictoinary-display-grid{padding-right:5px;padding-left:5px;box-shadow:#00000059 0 5px 15px}:host::ng-deep .ag-row-hover{color:#666!important;background-color:var(--bluewarmvividfade-lighter)!important}:host::ng-deep .ag-row-selected .ag-cell{color:var(--white-lightest)!important}:host::ng-deep .ag-row-selected{color:var(--white-darker)!important;background-color:var(--bluewarmvivid-lighter)!important}\n"], dependencies: [{ kind: "component", type: i4.BusyComponent, selector: "hci-busy", inputs: ["busy", "busySubjects", "getBusySubjects", "parentSelector", "rootClass", "icon", "iconSize", "showIcon", "mxAuto", "myAuto", "text", "template", "config"] }, { kind: "component", type: i5.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"] }] }); }
|
|
665
|
+
}
|
|
666
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DictionaryEditorDetailComponent, decorators: [{
|
|
667
|
+
type: Component,
|
|
668
668
|
args: [{ selector: "hci-dictionary-editor-detail", template: `
|
|
669
669
|
<div class="d-flex flex-column hci-dictionary-detail-body"
|
|
670
670
|
>
|
|
@@ -749,25 +749,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
749
749
|
</div>
|
|
750
750
|
</ng-template>
|
|
751
751
|
</div>
|
|
752
|
-
`, styles: [".full-height{height:100%}.full-width{width:100%}.ag-theme-balham{font-family:Prompt;font-weight:500}.active-color{float:right;font-size:15px;color:var(--bluewarm-dark)}.deactivated-color{float:right;font-size:15px;color:var(--greywarm-medlight)}.dictionary-info-section{padding-top:10px}.dictionary-title{float:left;font-size:16px;padding-left:10px;padding-right:10px;padding-top:5px}.metadata-button{color:var(--white-lightest);float:left;font-size:15px}:host::ng-deep .ag-header-cell{background-color:var(--bluewarmvividfade-lightest);border:lightgray solid thin}:host::ng-deep .ag-cell{border-right:lightgray solid thin;border-left:lightgray solid thin}:host::ng-deep .ag-row{border-bottom:0;border-top:0}:host::ng-deep .ag-row-even{background-color:var(--white-medium)}.hci-dictionary-detail-body{height:100%;width:100%;background:linear-gradient(0deg,var(--white-lightest) 30%,var(--bluewarmvividfade-lighter) 100%)!important}.hci-dictoinary-display-grid{padding-right:5px;padding-left:5px;box-shadow:#00000059 0 5px 15px}:host::ng-deep .ag-row-hover{color:#666!important;background-color:var(--bluewarmvividfade-lighter)!important}:host::ng-deep .ag-row-selected .ag-cell{color:var(--white-lightest)!important}:host::ng-deep .ag-row-selected{color:var(--white-darker)!important;background-color:var(--bluewarmvivid-lighter)!important}\n"] }]
|
|
753
|
-
}], ctorParameters:
|
|
754
|
-
type: Inject,
|
|
755
|
-
args: [DICTIONARY_ENDPOINT]
|
|
756
|
-
}] }]
|
|
757
|
-
type: HostBinding,
|
|
758
|
-
args: ["class"]
|
|
759
|
-
}] } });
|
|
760
|
-
/**
|
|
761
|
-
* Extracts Date And Turn To A Numerical Value For Comparing Purposes
|
|
762
|
-
* @param date The date to comparable number
|
|
763
|
-
*/
|
|
764
|
-
function monthToComparableNumber(date) {
|
|
765
|
-
if (date === undefined || date === null || date.length !== 10) {
|
|
766
|
-
return null;
|
|
767
|
-
}
|
|
768
|
-
let yearNumber = date.substring(0, 4);
|
|
769
|
-
let monthNumber = date.substring(5, 7);
|
|
770
|
-
let dayNumber = date.substring(8, 10);
|
|
771
|
-
return yearNumber * 10000 + monthNumber * 100 + dayNumber;
|
|
772
|
-
}
|
|
773
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detail.component.js","sourceRoot":"","sources":["../../../../projects/dictionary-editor/src/components/detail.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, isDevMode, ViewChild, HostBinding, TemplateRef} from \"@angular/core\";\r\nimport {ActivatedRoute} from \"@angular/router\";\r\n\r\nimport {BehaviorSubject, Observable} from \"rxjs\";\r\nimport {finalize, map} from \"rxjs/operators\";\r\nimport {NgbModal, NgbModalRef} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {DictionaryService, DICTIONARY_ENDPOINT} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\nimport {\r\n  ColumnApi,\r\n  GridOptions,\r\n  GridReadyEvent,\r\n  GridApi\r\n} from \"ag-grid-community\";\r\nimport {SelectRenderer} from \"../grid-renderers/select.renderer\";\r\nimport {SelectEditor} from \"../grid-editors/select.editor\";\r\nimport {NewRowComponent} from \"./new-row.component\";\r\nimport {isNullOrUndefined} from \"util\";\r\nimport {DateRenderer} from \"../grid-renderers/date.renderer\";\r\nimport {AgGridDateCellEditorComponent} from \"../grid-editors/ag-grid-date-cell-editor.component\";\r\n\r\n/**\r\n * When a dictionary is selected this component is shown.  There is a top grid which for its data shows all the columns\r\n * for the dictionary. Currently, keep this for reference only and have non-editable.\r\n * The bottom grid will show those columns as actual columns and its data are all the dictionary values.  Rows can be\r\n * added.  For deleting, need to make sure the id is not used anywhere.  For editing, need to make sure the code or anything\r\n * else isn't being referenced.\r\n *\r\n * @since 1.0.0\r\n */\r\n@Component(\r\n  {\r\n    selector: \"hci-dictionary-editor-detail\",\r\n    template:\r\n      `\r\n        <div class=\"d-flex flex-column hci-dictionary-detail-body\"\r\n        >\r\n          <hci-busy [busySubjects]=\"loadingSubjects\"></hci-busy>\r\n\r\n          <!-- Dictionary Title And Metadata -->\r\n          <div class=\"dictionary-info-section\">\r\n            <span class=\"dictionary-title\">\r\n              {{displayName}}\r\n            </span>\r\n            <button class=\"btn btn-primary metadata-button\"\r\n                    (click)=\"openModal(metaDataModal)\">\r\n              View Meta Data\r\n            </button>\r\n          </div>\r\n\r\n          <!-- Dictionary Edit Buttons -->\r\n          <div>\r\n            <button [class]=\"disableDelete? 'deactivated-color': 'active-color'\"\r\n                    [disabled]=\"disableDelete\"\r\n                    (click)=\"openAreYouSureModal(areYouSureModal)\">\r\n              <i class=\"fas fa-minus\"></i>\r\n            </button>\r\n            <button style=\"color: var(--bluewarm-dark); float: right; font-size: 15px;\"\r\n                    [disabled]=\"disableAddRow\"\r\n                    (click)=\"onClickAddRow()\">\r\n              <i class=\"fas fa-plus\"></i>\r\n            </button>\r\n          </div>\r\n\r\n          <!-- Dictionary Display Grid -->\r\n          <div class=\"d-flex flex-column flex-grow-1\">\r\n            <ag-grid-angular id=\"dictionary-grid-display\"\r\n                             #dataGrid\r\n                             class=\"ag-theme-balham full-height full-width hci-dictoinary-display-grid\"\r\n                             [rowData]=\"dictionaryEntries\"\r\n                             [rowSelection]=\"'multiple'\"\r\n                             [singleClickEdit]=\"'true'\"\r\n                             [pagination]=\"'true'\"\r\n                             [paginationAutoPageSize]=\"'true'\"\r\n                             [gridOptions]=\"gridOptions\"\r\n                             (cellValueChanged)=\"updateDictionary($event)\"\r\n            >\r\n            </ag-grid-angular>\r\n          </div>\r\n\r\n          <!-- Dictionary Metadata Popup -->\r\n          <ng-template #metaDataModal let-close=\"close\">\r\n            <div style=\"width:1000px\">\r\n              <div class=\"modal-header\">\r\n                Meta Data for {{className}}\r\n              </div>\r\n              <div class=\"d-flex flex-column modal-body\"\r\n                   style=\"border: 1px solid #ced4da; width: 100%;\">\r\n                <ag-grid-angular #metaGrid\r\n                                 class=\"ag-theme-balham full-width\"\r\n                                 style=\"height: 250px;\"\r\n                                 (gridReady)=\"this.onMetaGridReady($event)\"\r\n                                 [gridOptions]=\"this.metaGridOptions\"\r\n                                 [rowSelection]=\"'single'\"\r\n                                 [frameworkComponents]=\"frameworkComponents\"\r\n                                 [rowData]=\"dictionary?.fields\">\r\n                </ag-grid-angular>\r\n              </div>\r\n              <div class=\"modal-footer\">\r\n                <button class=\"btn btn-primary\" (click)=\"close('Close')\">Close</button>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n\r\n          <!-- Dictionary Delete Comfirmation Popup -->\r\n          <ng-template #areYouSureModal let-close=\"close\">\r\n            <div class=\"modal-header\">\r\n              Confirmation\r\n            </div>\r\n            <div class=\"modal-body d-flex\">\r\n              Are you sure?\r\n            </div>\r\n            <div class=\"modal-footer\">\r\n              <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n              <button class=\"btn btn-primary btn-red\" (click)=\"close('Delete')\">Delete</button>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      `,\r\n    styles: [\r\n      `\r\n        .full-height {\r\n          height: 100%;\r\n        }\r\n\r\n        .full-width {\r\n          width: 100%;\r\n        }\r\n\r\n        .ag-theme-balham {\r\n          font-family: \"Prompt\";\r\n          font-weight: 500;\r\n        }\r\n\r\n        .active-color {\r\n          float: right;\r\n          font-size: 15px;\r\n          color: var(--bluewarm-dark);\r\n        }\r\n\r\n        .deactivated-color {\r\n          float: right;\r\n          font-size: 15px;\r\n          color: var(--greywarm-medlight);\r\n        }\r\n\r\n        .dictionary-info-section {\r\n          padding-top: 10px;\r\n        }\r\n\r\n        .dictionary-title {\r\n          float: left;\r\n          font-size: 16px;\r\n          padding-left: 10px;\r\n          padding-right: 10px;\r\n          padding-top: 5px;\r\n        }\r\n\r\n        .metadata-button {\r\n          color: var(--white-lightest);\r\n          float: left;\r\n          font-size: 15px;\r\n        }\r\n\r\n        :host::ng-deep .ag-header-cell {\r\n          background-color: var(--bluewarmvividfade-lightest);\r\n          border: lightgray solid thin;\r\n        }\r\n\r\n        :host::ng-deep .ag-cell {\r\n          border-right: lightgray solid thin;\r\n          border-left: lightgray solid thin;\r\n        }\r\n\r\n        :host::ng-deep .ag-row {\r\n          border-bottom: 0;\r\n          border-top: 0;\r\n        }\r\n\r\n        :host::ng-deep .ag-row-even {\r\n          background-color: var(--white-medium);\r\n        }\r\n\r\n        .hci-dictionary-detail-body {\r\n          height: 100%;\r\n          width: 100%;\r\n          background: linear-gradient(0deg, var(--white-lightest) 30%, var(--bluewarmvividfade-lighter) 100%) !important;\r\n        }\r\n\r\n        .hci-dictoinary-display-grid {\r\n          padding-right: 5px;\r\n          padding-left: 5px;\r\n          box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Row Hover CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-hover {\r\n          color: #666 !important;\r\n          background-color: var(--bluewarmvividfade-lighter) !important;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Cell Selected CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-selected .ag-cell {\r\n          color: var(--white-lightest) !important;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Row Selected CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-selected {\r\n          color: var(--white-darker) !important;\r\n          background-color: var(--bluewarmvivid-lighter) !important;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class DictionaryEditorDetailComponent {\r\n\r\n  @HostBinding(\"class\") classList: string = \"outlet-column y-auto\";\r\n\r\n  private secondaryDictionaryEntries: any;\r\n  className: string;\r\n  displayName: any;\r\n  dictionary: any;\r\n  dictionaryEntries: any[] = [];\r\n  dataColumns: any[];\r\n\r\n  idColumn: string;\r\n  selectedRows: any[] = [];\r\n  loadingSubjects: BehaviorSubject<boolean>[] = [];\r\n\r\n  boundNewRowPostCall: (data: any) => Observable<any>;\r\n  gridOptions: GridOptions;\r\n  newRowSubscription: any;\r\n\r\n  metaGridOptions = {\r\n    rowStyle: {\r\n      \"font-family\": \"Prompt, sans-serif\"\r\n    },\r\n    enableCellTextSelection: true,\r\n    ensureDomOrder: true\r\n  };\r\n  frameworkComponents: any;\r\n  public gridApiMeta: GridApi;\r\n\r\n\r\n  constructor(\r\n    private route: ActivatedRoute,\r\n    private modalService: NgbModal,\r\n    private dictionaryService: DictionaryService,\r\n    @Inject(DICTIONARY_ENDPOINT) private dictionaryEndpoint: string\r\n  ) {\r\n\r\n    this.gridOptions = <GridOptions>{\r\n      context: {\r\n        componentParent: this\r\n      },\r\n      onGridReady: DictionaryEditorDetailComponent.onSamplesGridReady,\r\n      onGridSizeChanged: DictionaryEditorDetailComponent.onGridSizeChanged,\r\n      suppressHorizontalScroll: false,\r\n      selectionMode: \"multiple\",\r\n      stopEditingWhenGridLosesFocus: true,\r\n      enableSorting: true,\r\n      enableFilter: true\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Based on the route class name, make the call to fetch the dictionary data.  Since this component is route based,\r\n   * when the dictionary class in the route changes, this component is reloaded.\r\n   */\r\n  ngOnInit() {\r\n\r\n    this.boundNewRowPostCall = this.newRowPost.bind(this);\r\n\r\n    this.loadingSubjects.push(new BehaviorSubject<boolean>(false));\r\n    this.loadingSubjects.push(new BehaviorSubject<boolean>(false));\r\n\r\n    this.route.params.subscribe(\r\n      params => {\r\n        let className: string = params[\"className\"];\r\n\r\n        this.getDictionary(className);\r\n      }\r\n    );\r\n  }\r\n\r\n  openModal(modal: TemplateRef<any>): void {\r\n\r\n    this.modalService.open(modal, {windowClass: \"modal-xl\"}).result.then(\r\n      (result) => {\r\n      },\r\n      (reason) => {\r\n      }\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n    this.gridOptions.api.sizeColumnsToFit();\r\n  }\r\n\r\n  public columnDefMeta() : any[] {\r\n\r\n    return [\r\n      {field: \"name\", headerName: \"Name\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"description\", headerName: \"Description\", width: 250, sortable: true, resizable: true, editable: false},\r\n      {field: \"id\", headerName: \"Id\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"type\", headerName: \"Type\", sortable: true, resizable: true, editable: false},\r\n      {field: \"protectionType\", headerName: \"ProtectionType\", sortable: true, resizable: true, editable: false},\r\n      {field: \"filterDictionaryClass\", headerName: \"FilterDictionaryClass\", width: 180, sortable: true, resizable: true, editable: false},\r\n      {field: \"notNull\", headerName: \"NotNull\", sortable: true, resizable: true, editable: false},\r\n      {field: \"integer\", headerName: \"Integer\", width: 75, sortable: true, resizable: true, editable: false},\r\n      {field: \"min\", headerName: \"Min\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"max\", headerName: \"Max\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"fraction\", headerName: \"Fraction\", sortable: true, resizable: true, editable: false},\r\n      {field: \"dictionaryTooltip\", headerName: \"DictionaryTooltip\", width: 200, sortable: true, resizable: true, editable: false},\r\n      {field: \"dictionaryDisplay\", headerName: \"DictionaryDisplay\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"filterable\", headerName: \"Filterable\", sortable: true, resizable: true, editable: false},\r\n      {field: \"displayName\", headerName: \"DisplayName\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"displayOrder\", headerName: \"DisplayOrder\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"cellStyle\", headerName: \"CellStyle\", sortable: true, resizable: true, editable: false},\r\n    ]; // the widths for the last 2 could be wrong.\r\n\r\n  }\r\n\r\n  onMetaGridReady(params : any) {\r\n\r\n    this.gridApiMeta = params.api;\r\n    this.gridApiMeta.setColumnDefs(this.columnDefMeta());\r\n    this.gridApiMeta.setRowData(this.dictionary?.fields);\r\n    // this.gridApiMeta.sizeColumnsToFit();\r\n\r\n  }\r\n\r\n  openAreYouSureModal(modal: TemplateRef<any>): void {\r\n\r\n    this.modalService.open(modal).result.then(\r\n      (result) => {\r\n        if (result === \"Delete\") {\r\n          this.deleteDictionaryEntries();\r\n        }\r\n      },\r\n      (reason) => {\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Fetch the dictionary metadata and dictionary entries based upon the dictionary class name.\r\n   *\r\n   * @param {string} className\r\n   */\r\n  getDictionary(className: string) {\r\n\r\n    // When Selecting A New Dictionary, Navigate To First Page\r\n    if (this.gridOptions && this.gridOptions.api) {\r\n      this.gridOptions.api.paginationGoToFirstPage();\r\n    }\r\n\r\n    this.className = className;\r\n    this.dataColumns = undefined;\r\n    this.loadingSubjects[0].next(true);\r\n\r\n    this.dictionaryService.getDictionary(className)\r\n      .pipe(\r\n        finalize(\r\n          () => {\r\n            this.loadingSubjects[0].next(false);\r\n          }\r\n        )\r\n      ).subscribe(\r\n      (dictionary: Object) => {\r\n        this.setUpDictionaryGrid(dictionary);\r\n        this.loadingSubjects[0].next(false);\r\n      }\r\n    );\r\n\r\n    this.getDictionaryEntries();\r\n  }\r\n\r\n  getDictionaryEntries(): void {\r\n\r\n    this.loadingSubjects[1].next(true);\r\n\r\n    this.dictionaryService.getDictionaryEntries(this.className)\r\n      .pipe(\r\n        finalize(\r\n          () => {\r\n            this.loadingSubjects[1].next(false);\r\n          }\r\n        )\r\n      ).subscribe(\r\n      (dictionaryEntries: Object[]) => {\r\n        this.dictionaryEntries = dictionaryEntries;\r\n        this.gridOptions.api.setRowData(dictionaryEntries);\r\n        this.gridOptions.api.sizeColumnsToFit();\r\n        this.loadingSubjects[1].next(false);\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set the dictionary metadata.  This is used to build the columns for the dictionary entries.  The names, validation,\r\n   * and filter classes build the column definition.\r\n   *\r\n   * @param dictionary\r\n   */\r\n  private setUpDictionaryGrid(dictionary: any): void {\r\n\r\n    if (isDevMode()) {\r\n      console.debug(\"DictionaryEditorDetailComponent.setDictionary\");\r\n      console.debug(dictionary);\r\n    }\r\n\r\n    this.dictionary = dictionary;\r\n    this.secondaryDictionaryEntries = [];\r\n    let dictionaryClassNames = [];\r\n\r\n    for (let field of dictionary.fields) {\r\n      if (field.filterDictionaryClass) {\r\n        dictionaryClassNames.push(field.filterDictionaryClass);\r\n      }\r\n    }\r\n\r\n    this.getSecondaryDictionaries(dictionaryClassNames);\r\n  }\r\n\r\n  private getSecondaryDictionaries(dictionaryNames: string[]) {\r\n\r\n    if (dictionaryNames.length == 0) {\r\n      this.finishColumnSetup();\r\n    } else {\r\n      let dictionaryName = dictionaryNames.pop();\r\n\r\n      this.dictionaryService.getDictionaryDropdownEntries(dictionaryName).subscribe(\r\n        (response: any) => {\r\n          this.secondaryDictionaryEntries.push({dictionaryName: dictionaryName, entries: response});\r\n          this.getSecondaryDictionaries(dictionaryNames);\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  private finishColumnSetup() {\r\n\r\n    this.displayName = this.dictionary.displayName;\r\n\r\n    // This establishes the readOnly functionality\r\n    let cols: any[] = [];\r\n\r\n    // Process Columns And Create Column Definition\r\n    for (let field of this.dictionary.fields) {\r\n      if (field.id && (isNullOrUndefined(field.code) || field.code == false)) {\r\n        continue;\r\n      }\r\n\r\n      let col: any;\r\n\r\n      if (field.filterDictionaryClass) {\r\n        // this is a dropdown of another dictionary\r\n        let options = this.secondaryDictionaryEntries.find(\r\n          (a: any) => {\r\n            return a.dictionaryName === field.filterDictionaryClass;\r\n          }\r\n        );\r\n\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          editable: this.isEditable.bind(this),\r\n          cellRendererFramework: SelectRenderer,\r\n          cellEditorFramework: SelectEditor,\r\n          selectOptionsDisplayField: \"display\",\r\n          selectOptionsValueField: \"id\",\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          filterValueGetter: this.comboFilterValueGetter,\r\n          selectOptions: [],\r\n          comparator: (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n            return 0;\r\n          }\r\n        };\r\n\r\n        if (options && options.entries) {\r\n          col.selectOptions = options.entries.sort(\r\n            (optionA, optionB) => {\r\n              if (optionA && !optionB) {\r\n                return 1;\r\n              }\r\n\r\n              if (optionB && !optionA) {\r\n                return -1;\r\n              }\r\n\r\n              if (!optionA && !optionB) {\r\n                return 0;\r\n              }\r\n\r\n              if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {\r\n                return 1;\r\n              } else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {\r\n                return -1;\r\n              } else {\r\n                return 0;\r\n              }\r\n            }\r\n          );\r\n\r\n          col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n            if (!options.entries) {\r\n              return 0;\r\n            }\r\n\r\n            if (valueA && !valueB) {\r\n              return 1;\r\n            }\r\n\r\n            if (valueB && !valueA) {\r\n              return -1;\r\n            }\r\n\r\n            if (!valueA && !valueB) {\r\n              return 0;\r\n            }\r\n\r\n            let optionA = options.entries.find((entry) => (\"\" + entry.id === \"\" + valueA));\r\n            let optionB = options.entries.find((entry) => (\"\" + entry.id === \"\" + valueB));\r\n\r\n            if (optionA && !optionB) {\r\n              return 1;\r\n            }\r\n\r\n            if (optionB && !optionA) {\r\n              return -1;\r\n            }\r\n\r\n            if (!optionA && !optionB) {\r\n              return 0;\r\n            }\r\n\r\n            if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {\r\n              return 1;\r\n            } else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {\r\n              return -1;\r\n            } else {\r\n              return 0;\r\n            }\r\n          };\r\n        }\r\n\r\n        col.cellStyle = params => {\r\n          let column: any = {};\r\n\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n        col.dictionaryDisplay = field.dictionaryDisplay;\r\n        col.dictionaryTooltip = field.dictionaryTooltip;\r\n\r\n        // Set default filter as compare by text/number\r\n        // col.filterRenderer = CompareFilterRenderer;\r\n      } else if (field.type && field.type == \"Date\") {\r\n        //date value\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          cellRendererFramework: DateRenderer,\r\n          cellEditorFramework: AgGridDateCellEditorComponent,\r\n          editable: this.isEditable.bind(this),\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          dictionaryDisplay: field.dictionaryDisplay\r\n        };\r\n\r\n        col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n          let num = this.dateComparator(valueA, valueB);\r\n          return isInverted ? -1 * num : num; //don't have to do anything with inverted?\r\n        };\r\n\r\n        col.cellStyle = params => {\r\n          var column: any = {};\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n      } else {\r\n        // this is a string value\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          editable: this.isEditable.bind(this),\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          dictionaryDisplay: field.dictionaryDisplay\r\n        };\r\n\r\n        col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n          if (valueA && !valueB) {\r\n            return 1;\r\n          }\r\n\r\n          if (valueB && !valueA) {\r\n            return -1;\r\n          }\r\n\r\n          if (!valueA && !valueB) {\r\n            return 0;\r\n          }\r\n\r\n          if (valueA.toLowerCase() > valueB.toLowerCase()) {\r\n            return 1;\r\n          } else if ((valueB.toLowerCase() > valueA.toLowerCase())) {\r\n            return -1;\r\n          } else {\r\n            return 0;\r\n          }\r\n        };\r\n\r\n        col.cellStyle = params => {\r\n          var column: any = {};\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n        // Set default filter as compare by text/number\r\n        // col.filterRenderer = CompareFilterRenderer;\r\n      }\r\n\r\n      cols.push(col);\r\n    }\r\n\r\n    // Now we need to sort the columns\r\n    if (!this.dictionary.fields[0].hasOwnProperty(\"displayOrder\")) {\r\n      // default case, no displayOrder\r\n      cols = cols.sort(\r\n        (a, b) => {\r\n          if (!a.headerName && b.headerName) {\r\n            return 1;\r\n          } else if (!b.headerName && a.headerName) {\r\n            return -1;\r\n          } else if (a.dictionaryDisplay === true && b.dictionaryDisplay === false) {\r\n            return -1;\r\n          } else if (b.dictionaryDisplay === true && a.dictionaryDisplay === false) {\r\n            return 1;\r\n          } else if (a.dictionaryTooltip === true && b.dictionaryTooltip === false) {\r\n            return -1;\r\n          } else if (b.dictionaryTooltip === true && a.dictionaryTooltip === false) {\r\n            return 1;\r\n          } else {\r\n            return 0;\r\n          }\r\n        }\r\n      );\r\n\r\n    } else {\r\n      // DisplayOrder case\r\n      // I think this works? Check later\r\n      cols = cols.sort(\r\n        (a, b) => {\r\n          if (!a.headerName && b.headerName) {\r\n            return 1;\r\n          } else if (!b.headerName && a.headerName) {\r\n            return -1;\r\n          } else {\r\n            return a.displayOrder - b.displayOrder;\r\n          }\r\n        }\r\n      );\r\n    }\r\n\r\n    // After Columns Have Been Sorted\r\n    // Dictionary Grid Will Sort The Grid Ascending Order By First Column\r\n    if(cols  && cols.length != 0) {\r\n      cols[0].sort = \"asc\";\r\n    }\r\n\r\n    this.dataColumns = cols;\r\n    if (Array.isArray(this.dataColumns) && this.gridOptions && this.gridOptions.api) {\r\n      this.gridOptions.api.setColumnDefs(this.dataColumns);\r\n      this.gridOptions.api.sizeColumnsToFit();\r\n    }\r\n  }\r\n\r\n  isEditable(params): boolean {\r\n\r\n    let isEditable: boolean;\r\n\r\n    let column: any = {};\r\n    for (let field of this.dictionary.fields) {\r\n      if (params.colDef.field == field.name) {\r\n        column = field;\r\n      }\r\n    }\r\n\r\n    if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n      // console.log(\"new editable?\");\r\n      isEditable = !(this.dictionary.readOnly || column.readOnly ||\r\n        column.protectionType == \"Read Only\");\r\n    } else {\r\n      // console.log(\"edit editable?\");\r\n      isEditable = !(this.dictionary.readOnly || column.readOnly ||\r\n        column.protectionType == \"Read Only\" || column.createOnly ||\r\n        column.protectionType == \"Create Only\" || column.code);\r\n    }\r\n\r\n    return isEditable;\r\n  }\r\n\r\n  deleteDictionaryEntries(): void {\r\n\r\n    let deleteRows: any[] = this.gridOptions.api.getSelectedRows();\r\n\r\n    for (let deleteId of this.selectedRows) {\r\n      for (let entry of this.dictionaryEntries) {\r\n        if (entry[this.idColumn] === deleteId) {\r\n          deleteRows.push(entry);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.dictionaryService.deleteDictionaryEntries(this.className, deleteRows).subscribe(\r\n      (response: any) => {\r\n        this.getDictionaryEntries();\r\n      }\r\n    );\r\n  }\r\n\r\n  updateDictionary(event: any): void {\r\n\r\n    // Important to note this will not update cells to the demo but will when imported to CORE or other applications.\r\n    this.dictionaryService.updateDictionaryEntries(this.className, [event.data]).subscribe(\r\n      (data: any[]) => {\r\n        this.getDictionaryEntries();\r\n      }\r\n    );\r\n  }\r\n\r\n  setSelectedEntries(): void {\r\n\r\n    this.selectedRows = this.gridOptions.api.getSelectedRows();\r\n  }\r\n\r\n  newRowPost(data: any): Observable<any> {\r\n\r\n    return this.dictionaryService.addDictionaryEntries(this.className, [data])\r\n      .pipe(\r\n        map(\r\n          (data: Object[]) => {\r\n            if (data && data.length === 1) {\r\n              return <any>data[0];\r\n            } else {\r\n              return data;\r\n            }\r\n          }\r\n        )\r\n      );\r\n  }\r\n\r\n  public static onSamplesGridReady(event: GridReadyEvent): void {\r\n\r\n    event.api.sizeColumnsToFit();\r\n  }\r\n\r\n  public static onGridSizeChanged(event: any) {\r\n\r\n    if (event && event.api) {\r\n      event.api.sizeColumnsToFit();\r\n    }\r\n  }\r\n\r\n  public get disableAddRow(): boolean {\r\n\r\n    if (!this.dictionary) {\r\n      return true;\r\n    }\r\n\r\n    return this.dictionary.readOnly && this.dictionary.readOnly === true;\r\n  }\r\n\r\n  public get disableDelete(): boolean {\r\n\r\n    if (!this.dictionary) {\r\n      return true;\r\n    }\r\n\r\n    if (this.dictionary.readOnly && this.dictionary.readOnly === true) {\r\n      return true;\r\n    }\r\n\r\n    if (this.gridOptions && this.gridOptions.api && this.gridOptions.api.getSelectedRows()) {\r\n      return this.gridOptions.api.getSelectedRows().length === 0;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  private comboFilterValueGetter(params): any {\r\n\r\n    let value = params.data[params.colDef.field];\r\n\r\n    if (value) {\r\n      let option = ((params.colDef as any).selectOptions as any[]).find((entry) => (entry[params.colDef.selectOptionsValueField] === value));\r\n      return option ? option[params.colDef.selectOptionsDisplayField] : \"\";\r\n    }\r\n\r\n    return \"\";\r\n  }\r\n\r\n  onClickAddRow() {\r\n\r\n    const modalRef = this.modalService.open(NewRowComponent,\r\n      {\r\n        size: \"lg\",\r\n        keyboard: false,\r\n        backdrop: \"static\",\r\n        centered: true,\r\n      }\r\n    );\r\n\r\n    modalRef.componentInstance.colDefs = this.dataColumns;\r\n    modalRef.componentInstance.dictionary = this.dictionary;\r\n\r\n    if (!this.newRowSubscription) {\r\n      // tell other ag-grid to add row to it\r\n      this.newRowSubscription = modalRef.componentInstance.newRowSubject.subscribe(\r\n        (theNewRow: any[]) => {\r\n          this.dictionaryEntries = theNewRow.concat(this.dictionaryEntries);\r\n          this.gridOptions.api.setRowData(this.dictionaryEntries);\r\n          this.newRowSubscription = null;\r\n\r\n          // Important to note this will not add rows to the demo but will when imported to CORE or other applications.\r\n          this.newRowPost(theNewRow[0]).subscribe(\r\n            () => {\r\n              this.getDictionaryEntries();\r\n            }\r\n          );\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Comparater To Compare 2 Dates\r\n   * @param date1 Date 1\r\n   * @param date2 Date 2\r\n   */\r\n  dateComparator(date1, date2) {\r\n\r\n    let date1Number = monthToComparableNumber(date1);\r\n    let date2Number = monthToComparableNumber(date2);\r\n\r\n    if (date1Number === null && date2Number === null) {\r\n      return 0;\r\n    }\r\n\r\n    if (date1Number === null) {\r\n      return -1;\r\n    }\r\n\r\n    if (date2Number === null) {\r\n      return 1;\r\n    }\r\n\r\n    return date1Number - date2Number;\r\n  }\r\n}\r\n\r\n/**\r\n * Extracts Date And Turn To A Numerical Value For Comparing Purposes\r\n * @param date The date to comparable number\r\n */\r\nfunction monthToComparableNumber(date) {\r\n\r\n  if (date === undefined || date === null || date.length !== 10) {\r\n    return null;\r\n  }\r\n\r\n  let yearNumber = date.substring(0, 4);\r\n  let monthNumber = date.substring(5, 7);\r\n  let dayNumber = date.substring(8, 10);\r\n\r\n  return yearNumber * 10000 + monthNumber * 100 + dayNumber;\r\n}\r\n"]}
|
|
752
|
+
`, styles: [".full-height{height:100%}.full-width{width:100%}.ag-theme-balham{font-family:Prompt;font-weight:500}.active-color{float:right;font-size:15px;color:var(--bluewarm-dark)}.deactivated-color{float:right;font-size:15px;color:var(--greywarm-medlight)}.dictionary-info-section{padding-top:10px}.dictionary-title{float:left;font-size:16px;padding-left:10px;padding-right:10px;padding-top:5px}.metadata-button{color:var(--white-lightest);float:left;font-size:15px}:host::ng-deep .ag-header-cell{background-color:var(--bluewarmvividfade-lightest);border:lightgray solid thin}:host::ng-deep .ag-cell{border-right:lightgray solid thin;border-left:lightgray solid thin}:host::ng-deep .ag-row{border-bottom:0;border-top:0}:host::ng-deep .ag-row-even{background-color:var(--white-medium)}.hci-dictionary-detail-body{height:100%;width:100%;background:linear-gradient(0deg,var(--white-lightest) 30%,var(--bluewarmvividfade-lighter) 100%)!important}.hci-dictoinary-display-grid{padding-right:5px;padding-left:5px;box-shadow:#00000059 0 5px 15px}:host::ng-deep .ag-row-hover{color:#666!important;background-color:var(--bluewarmvividfade-lighter)!important}:host::ng-deep .ag-row-selected .ag-cell{color:var(--white-lightest)!important}:host::ng-deep .ag-row-selected{color:var(--white-darker)!important;background-color:var(--bluewarmvivid-lighter)!important}\n"] }]
|
|
753
|
+
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.NgbModal }, { type: i3.DictionaryService }, { type: undefined, decorators: [{
|
|
754
|
+
type: Inject,
|
|
755
|
+
args: [DICTIONARY_ENDPOINT]
|
|
756
|
+
}] }], propDecorators: { classList: [{
|
|
757
|
+
type: HostBinding,
|
|
758
|
+
args: ["class"]
|
|
759
|
+
}] } });
|
|
760
|
+
/**
|
|
761
|
+
* Extracts Date And Turn To A Numerical Value For Comparing Purposes
|
|
762
|
+
* @param date The date to comparable number
|
|
763
|
+
*/
|
|
764
|
+
function monthToComparableNumber(date) {
|
|
765
|
+
if (date === undefined || date === null || date.length !== 10) {
|
|
766
|
+
return null;
|
|
767
|
+
}
|
|
768
|
+
let yearNumber = date.substring(0, 4);
|
|
769
|
+
let monthNumber = date.substring(5, 7);
|
|
770
|
+
let dayNumber = date.substring(8, 10);
|
|
771
|
+
return yearNumber * 10000 + monthNumber * 100 + dayNumber;
|
|
772
|
+
}
|
|
773
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detail.component.js","sourceRoot":"","sources":["../../../../projects/dictionary-editor/src/components/detail.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, isDevMode, ViewChild, HostBinding, TemplateRef} from \"@angular/core\";\r\nimport {ActivatedRoute} from \"@angular/router\";\r\n\r\nimport {BehaviorSubject, Observable} from \"rxjs\";\r\nimport {finalize, map} from \"rxjs/operators\";\r\nimport {NgbModal, NgbModalRef} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {DictionaryService, DICTIONARY_ENDPOINT} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\nimport {\r\n  ColumnApi,\r\n  GridOptions,\r\n  GridReadyEvent,\r\n  GridApi\r\n} from \"ag-grid-community\";\r\nimport {SelectRenderer} from \"../grid-renderers/select.renderer\";\r\nimport {SelectEditor} from \"../grid-editors/select.editor\";\r\nimport {NewRowComponent} from \"./new-row.component\";\r\nimport {isNullOrUndefined} from \"util\";\r\nimport {DateRenderer} from \"../grid-renderers/date.renderer\";\r\nimport {AgGridDateCellEditorComponent} from \"../grid-editors/ag-grid-date-cell-editor.component\";\r\n\r\n/**\r\n * When a dictionary is selected this component is shown.  There is a top grid which for its data shows all the columns\r\n * for the dictionary. Currently, keep this for reference only and have non-editable.\r\n * The bottom grid will show those columns as actual columns and its data are all the dictionary values.  Rows can be\r\n * added.  For deleting, need to make sure the id is not used anywhere.  For editing, need to make sure the code or anything\r\n * else isn't being referenced.\r\n *\r\n * @since 1.0.0\r\n */\r\n@Component(\r\n  {\r\n    selector: \"hci-dictionary-editor-detail\",\r\n    template:\r\n      `\r\n        <div class=\"d-flex flex-column hci-dictionary-detail-body\"\r\n        >\r\n          <hci-busy [busySubjects]=\"loadingSubjects\"></hci-busy>\r\n\r\n          <!-- Dictionary Title And Metadata -->\r\n          <div class=\"dictionary-info-section\">\r\n            <span class=\"dictionary-title\">\r\n              {{displayName}}\r\n            </span>\r\n            <button class=\"btn btn-primary metadata-button\"\r\n                    (click)=\"openModal(metaDataModal)\">\r\n              View Meta Data\r\n            </button>\r\n          </div>\r\n\r\n          <!-- Dictionary Edit Buttons -->\r\n          <div>\r\n            <button [class]=\"disableDelete? 'deactivated-color': 'active-color'\"\r\n                    [disabled]=\"disableDelete\"\r\n                    (click)=\"openAreYouSureModal(areYouSureModal)\">\r\n              <i class=\"fas fa-minus\"></i>\r\n            </button>\r\n            <button style=\"color: var(--bluewarm-dark); float: right; font-size: 15px;\"\r\n                    [disabled]=\"disableAddRow\"\r\n                    (click)=\"onClickAddRow()\">\r\n              <i class=\"fas fa-plus\"></i>\r\n            </button>\r\n          </div>\r\n\r\n          <!-- Dictionary Display Grid -->\r\n          <div class=\"d-flex flex-column flex-grow-1\">\r\n            <ag-grid-angular id=\"dictionary-grid-display\"\r\n                             #dataGrid\r\n                             class=\"ag-theme-balham full-height full-width hci-dictoinary-display-grid\"\r\n                             [rowData]=\"dictionaryEntries\"\r\n                             [rowSelection]=\"'multiple'\"\r\n                             [singleClickEdit]=\"'true'\"\r\n                             [pagination]=\"'true'\"\r\n                             [paginationAutoPageSize]=\"'true'\"\r\n                             [gridOptions]=\"gridOptions\"\r\n                             (cellValueChanged)=\"updateDictionary($event)\"\r\n            >\r\n            </ag-grid-angular>\r\n          </div>\r\n\r\n          <!-- Dictionary Metadata Popup -->\r\n          <ng-template #metaDataModal let-close=\"close\">\r\n            <div style=\"width:1000px\">\r\n              <div class=\"modal-header\">\r\n                Meta Data for {{className}}\r\n              </div>\r\n              <div class=\"d-flex flex-column modal-body\"\r\n                   style=\"border: 1px solid #ced4da; width: 100%;\">\r\n                <ag-grid-angular #metaGrid\r\n                                 class=\"ag-theme-balham full-width\"\r\n                                 style=\"height: 250px;\"\r\n                                 (gridReady)=\"this.onMetaGridReady($event)\"\r\n                                 [gridOptions]=\"this.metaGridOptions\"\r\n                                 [rowSelection]=\"'single'\"\r\n                                 [frameworkComponents]=\"frameworkComponents\"\r\n                                 [rowData]=\"dictionary?.fields\">\r\n                </ag-grid-angular>\r\n              </div>\r\n              <div class=\"modal-footer\">\r\n                <button class=\"btn btn-primary\" (click)=\"close('Close')\">Close</button>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n\r\n          <!-- Dictionary Delete Comfirmation Popup -->\r\n          <ng-template #areYouSureModal let-close=\"close\">\r\n            <div class=\"modal-header\">\r\n              Confirmation\r\n            </div>\r\n            <div class=\"modal-body d-flex\">\r\n              Are you sure?\r\n            </div>\r\n            <div class=\"modal-footer\">\r\n              <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n              <button class=\"btn btn-primary btn-red\" (click)=\"close('Delete')\">Delete</button>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      `,\r\n    styles: [\r\n      `\r\n        .full-height {\r\n          height: 100%;\r\n        }\r\n\r\n        .full-width {\r\n          width: 100%;\r\n        }\r\n\r\n        .ag-theme-balham {\r\n          font-family: \"Prompt\";\r\n          font-weight: 500;\r\n        }\r\n\r\n        .active-color {\r\n          float: right;\r\n          font-size: 15px;\r\n          color: var(--bluewarm-dark);\r\n        }\r\n\r\n        .deactivated-color {\r\n          float: right;\r\n          font-size: 15px;\r\n          color: var(--greywarm-medlight);\r\n        }\r\n\r\n        .dictionary-info-section {\r\n          padding-top: 10px;\r\n        }\r\n\r\n        .dictionary-title {\r\n          float: left;\r\n          font-size: 16px;\r\n          padding-left: 10px;\r\n          padding-right: 10px;\r\n          padding-top: 5px;\r\n        }\r\n\r\n        .metadata-button {\r\n          color: var(--white-lightest);\r\n          float: left;\r\n          font-size: 15px;\r\n        }\r\n\r\n        :host::ng-deep .ag-header-cell {\r\n          background-color: var(--bluewarmvividfade-lightest);\r\n          border: lightgray solid thin;\r\n        }\r\n\r\n        :host::ng-deep .ag-cell {\r\n          border-right: lightgray solid thin;\r\n          border-left: lightgray solid thin;\r\n        }\r\n\r\n        :host::ng-deep .ag-row {\r\n          border-bottom: 0;\r\n          border-top: 0;\r\n        }\r\n\r\n        :host::ng-deep .ag-row-even {\r\n          background-color: var(--white-medium);\r\n        }\r\n\r\n        .hci-dictionary-detail-body {\r\n          height: 100%;\r\n          width: 100%;\r\n          background: linear-gradient(0deg, var(--white-lightest) 30%, var(--bluewarmvividfade-lighter) 100%) !important;\r\n        }\r\n\r\n        .hci-dictoinary-display-grid {\r\n          padding-right: 5px;\r\n          padding-left: 5px;\r\n          box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Row Hover CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-hover {\r\n          color: #666 !important;\r\n          background-color: var(--bluewarmvividfade-lighter) !important;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Cell Selected CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-selected .ag-cell {\r\n          color: var(--white-lightest) !important;\r\n        }\r\n\r\n        /********************************************************************\r\n        * Dictionary Row Selected CSS\r\n        ********************************************************************/\r\n        :host::ng-deep .ag-row-selected {\r\n          color: var(--white-darker) !important;\r\n          background-color: var(--bluewarmvivid-lighter) !important;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class DictionaryEditorDetailComponent {\r\n\r\n  @HostBinding(\"class\") classList: string = \"outlet-column y-auto\";\r\n\r\n  private secondaryDictionaryEntries: any;\r\n  className: string;\r\n  displayName: any;\r\n  dictionary: any;\r\n  dictionaryEntries: any[] = [];\r\n  dataColumns: any[];\r\n\r\n  idColumn: string;\r\n  selectedRows: any[] = [];\r\n  loadingSubjects: BehaviorSubject<boolean>[] = [];\r\n\r\n  boundNewRowPostCall: (data: any) => Observable<any>;\r\n  gridOptions: GridOptions;\r\n  newRowSubscription: any;\r\n\r\n  metaGridOptions = {\r\n    rowStyle: {\r\n      \"font-family\": \"Prompt, sans-serif\"\r\n    },\r\n    enableCellTextSelection: true,\r\n    ensureDomOrder: true\r\n  };\r\n  frameworkComponents: any;\r\n  public gridApiMeta: GridApi;\r\n\r\n\r\n  constructor(\r\n    private route: ActivatedRoute,\r\n    private modalService: NgbModal,\r\n    private dictionaryService: DictionaryService,\r\n    @Inject(DICTIONARY_ENDPOINT) private dictionaryEndpoint: string\r\n  ) {\r\n\r\n    this.gridOptions = <GridOptions>{\r\n      context: {\r\n        componentParent: this\r\n      },\r\n      onGridReady: DictionaryEditorDetailComponent.onSamplesGridReady,\r\n      onGridSizeChanged: DictionaryEditorDetailComponent.onGridSizeChanged,\r\n      suppressHorizontalScroll: false,\r\n      selectionMode: \"multiple\",\r\n      stopEditingWhenGridLosesFocus: true,\r\n      enableSorting: true,\r\n      enableFilter: true\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Based on the route class name, make the call to fetch the dictionary data.  Since this component is route based,\r\n   * when the dictionary class in the route changes, this component is reloaded.\r\n   */\r\n  ngOnInit() {\r\n\r\n    this.boundNewRowPostCall = this.newRowPost.bind(this);\r\n\r\n    this.loadingSubjects.push(new BehaviorSubject<boolean>(false));\r\n    this.loadingSubjects.push(new BehaviorSubject<boolean>(false));\r\n\r\n    this.route.params.subscribe(\r\n      params => {\r\n        let className: string = params[\"className\"];\r\n\r\n        this.getDictionary(className);\r\n      }\r\n    );\r\n  }\r\n\r\n  openModal(modal: TemplateRef<any>): void {\r\n\r\n    this.modalService.open(modal, {windowClass: \"modal-xl\"}).result.then(\r\n      (result) => {\r\n      },\r\n      (reason) => {\r\n      }\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n    this.gridOptions.api.sizeColumnsToFit();\r\n  }\r\n\r\n  public columnDefMeta() : any[] {\r\n\r\n    return [\r\n      {field: \"name\", headerName: \"Name\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"description\", headerName: \"Description\", width: 250, sortable: true, resizable: true, editable: false},\r\n      {field: \"id\", headerName: \"Id\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"type\", headerName: \"Type\", sortable: true, resizable: true, editable: false},\r\n      {field: \"protectionType\", headerName: \"ProtectionType\", sortable: true, resizable: true, editable: false},\r\n      {field: \"filterDictionaryClass\", headerName: \"FilterDictionaryClass\", width: 180, sortable: true, resizable: true, editable: false},\r\n      {field: \"notNull\", headerName: \"NotNull\", sortable: true, resizable: true, editable: false},\r\n      {field: \"integer\", headerName: \"Integer\", width: 75, sortable: true, resizable: true, editable: false},\r\n      {field: \"min\", headerName: \"Min\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"max\", headerName: \"Max\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"fraction\", headerName: \"Fraction\", sortable: true, resizable: true, editable: false},\r\n      {field: \"dictionaryTooltip\", headerName: \"DictionaryTooltip\", width: 200, sortable: true, resizable: true, editable: false},\r\n      {field: \"dictionaryDisplay\", headerName: \"DictionaryDisplay\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"filterable\", headerName: \"Filterable\", sortable: true, resizable: true, editable: false},\r\n      {field: \"displayName\", headerName: \"DisplayName\", width: 175, sortable: true, resizable: true, editable: false},\r\n      {field: \"displayOrder\", headerName: \"DisplayOrder\", width: 60, sortable: true, resizable: true, editable: false},\r\n      {field: \"cellStyle\", headerName: \"CellStyle\", sortable: true, resizable: true, editable: false},\r\n    ]; // the widths for the last 2 could be wrong.\r\n\r\n  }\r\n\r\n  onMetaGridReady(params : any) {\r\n\r\n    this.gridApiMeta = params.api;\r\n    this.gridApiMeta.setColumnDefs(this.columnDefMeta());\r\n    this.gridApiMeta.setRowData(this.dictionary?.fields);\r\n    // this.gridApiMeta.sizeColumnsToFit();\r\n\r\n  }\r\n\r\n  openAreYouSureModal(modal: TemplateRef<any>): void {\r\n\r\n    this.modalService.open(modal).result.then(\r\n      (result) => {\r\n        if (result === \"Delete\") {\r\n          this.deleteDictionaryEntries();\r\n        }\r\n      },\r\n      (reason) => {\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Fetch the dictionary metadata and dictionary entries based upon the dictionary class name.\r\n   *\r\n   * @param {string} className\r\n   */\r\n  getDictionary(className: string) {\r\n\r\n    // When Selecting A New Dictionary, Navigate To First Page\r\n    if (this.gridOptions && this.gridOptions.api) {\r\n      this.gridOptions.api.paginationGoToFirstPage();\r\n    }\r\n\r\n    this.className = className;\r\n    this.dataColumns = undefined;\r\n    this.loadingSubjects[0].next(true);\r\n\r\n    this.dictionaryService.getDictionary(className)\r\n      .pipe(\r\n        finalize(\r\n          () => {\r\n            this.loadingSubjects[0].next(false);\r\n          }\r\n        )\r\n      ).subscribe(\r\n      (dictionary: Object) => {\r\n        this.setUpDictionaryGrid(dictionary);\r\n        this.loadingSubjects[0].next(false);\r\n      }\r\n    );\r\n\r\n    this.getDictionaryEntries();\r\n  }\r\n\r\n  getDictionaryEntries(): void {\r\n\r\n    this.loadingSubjects[1].next(true);\r\n\r\n    this.dictionaryService.getDictionaryEntries(this.className)\r\n      .pipe(\r\n        finalize(\r\n          () => {\r\n            this.loadingSubjects[1].next(false);\r\n          }\r\n        )\r\n      ).subscribe(\r\n      (dictionaryEntries: Object[]) => {\r\n        this.dictionaryEntries = dictionaryEntries;\r\n        this.gridOptions.api.setRowData(dictionaryEntries);\r\n        this.gridOptions.api.sizeColumnsToFit();\r\n        this.loadingSubjects[1].next(false);\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set the dictionary metadata.  This is used to build the columns for the dictionary entries.  The names, validation,\r\n   * and filter classes build the column definition.\r\n   *\r\n   * @param dictionary\r\n   */\r\n  private setUpDictionaryGrid(dictionary: any): void {\r\n\r\n    if (isDevMode()) {\r\n      console.debug(\"DictionaryEditorDetailComponent.setDictionary\");\r\n      console.debug(dictionary);\r\n    }\r\n\r\n    this.dictionary = dictionary;\r\n    this.secondaryDictionaryEntries = [];\r\n    let dictionaryClassNames = [];\r\n\r\n    for (let field of dictionary.fields) {\r\n      if (field.filterDictionaryClass) {\r\n        dictionaryClassNames.push(field.filterDictionaryClass);\r\n      }\r\n    }\r\n\r\n    this.getSecondaryDictionaries(dictionaryClassNames);\r\n  }\r\n\r\n  private getSecondaryDictionaries(dictionaryNames: string[]) {\r\n\r\n    if (dictionaryNames.length == 0) {\r\n      this.finishColumnSetup();\r\n    } else {\r\n      let dictionaryName = dictionaryNames.pop();\r\n\r\n      this.dictionaryService.getDictionaryDropdownEntries(dictionaryName).subscribe(\r\n        (response: any) => {\r\n          this.secondaryDictionaryEntries.push({dictionaryName: dictionaryName, entries: response});\r\n          this.getSecondaryDictionaries(dictionaryNames);\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  private finishColumnSetup() {\r\n\r\n    this.displayName = this.dictionary.displayName;\r\n\r\n    // This establishes the readOnly functionality\r\n    let cols: any[] = [];\r\n\r\n    // Process Columns And Create Column Definition\r\n    for (let field of this.dictionary.fields) {\r\n      if (field.id && (isNullOrUndefined(field.code) || field.code == false)) {\r\n        continue;\r\n      }\r\n\r\n      let col: any;\r\n\r\n      if (field.filterDictionaryClass) {\r\n        // this is a dropdown of another dictionary\r\n        let options = this.secondaryDictionaryEntries.find(\r\n          (a: any) => {\r\n            return a.dictionaryName === field.filterDictionaryClass;\r\n          }\r\n        );\r\n\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          editable: this.isEditable.bind(this),\r\n          cellRendererFramework: SelectRenderer,\r\n          cellEditorFramework: SelectEditor,\r\n          selectOptionsDisplayField: \"display\",\r\n          selectOptionsValueField: \"id\",\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          filterValueGetter: this.comboFilterValueGetter,\r\n          selectOptions: [],\r\n          comparator: (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n            return 0;\r\n          }\r\n        };\r\n\r\n        if (options && options.entries) {\r\n          col.selectOptions = options.entries.sort(\r\n            (optionA, optionB) => {\r\n              if (optionA && !optionB) {\r\n                return 1;\r\n              }\r\n\r\n              if (optionB && !optionA) {\r\n                return -1;\r\n              }\r\n\r\n              if (!optionA && !optionB) {\r\n                return 0;\r\n              }\r\n\r\n              if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {\r\n                return 1;\r\n              } else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {\r\n                return -1;\r\n              } else {\r\n                return 0;\r\n              }\r\n            }\r\n          );\r\n\r\n          col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n            if (!options.entries) {\r\n              return 0;\r\n            }\r\n\r\n            if (valueA && !valueB) {\r\n              return 1;\r\n            }\r\n\r\n            if (valueB && !valueA) {\r\n              return -1;\r\n            }\r\n\r\n            if (!valueA && !valueB) {\r\n              return 0;\r\n            }\r\n\r\n            let optionA = options.entries.find((entry) => (\"\" + entry.id === \"\" + valueA));\r\n            let optionB = options.entries.find((entry) => (\"\" + entry.id === \"\" + valueB));\r\n\r\n            if (optionA && !optionB) {\r\n              return 1;\r\n            }\r\n\r\n            if (optionB && !optionA) {\r\n              return -1;\r\n            }\r\n\r\n            if (!optionA && !optionB) {\r\n              return 0;\r\n            }\r\n\r\n            if (optionA.display.toLowerCase() > optionB.display.toLowerCase()) {\r\n              return 1;\r\n            } else if ((optionB.display.toLowerCase() > optionA.display.toLowerCase())) {\r\n              return -1;\r\n            } else {\r\n              return 0;\r\n            }\r\n          };\r\n        }\r\n\r\n        col.cellStyle = params => {\r\n          let column: any = {};\r\n\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n        col.dictionaryDisplay = field.dictionaryDisplay;\r\n        col.dictionaryTooltip = field.dictionaryTooltip;\r\n\r\n        // Set default filter as compare by text/number\r\n        // col.filterRenderer = CompareFilterRenderer;\r\n      } else if (field.type && field.type == \"Date\") {\r\n        //date value\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          cellRendererFramework: DateRenderer,\r\n          cellEditorFramework: AgGridDateCellEditorComponent,\r\n          editable: this.isEditable.bind(this),\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          dictionaryDisplay: field.dictionaryDisplay\r\n        };\r\n\r\n        col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n          let num = this.dateComparator(valueA, valueB);\r\n          return isInverted ? -1 * num : num; //don't have to do anything with inverted?\r\n        };\r\n\r\n        col.cellStyle = params => {\r\n          var column: any = {};\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n      } else {\r\n        // this is a string value\r\n        col = {\r\n          field: field.name,\r\n          headerName: field.displayName,\r\n          editable: this.isEditable.bind(this),\r\n          sortable: true,\r\n          resizable: true,\r\n          filter: true,\r\n          dictionaryDisplay: field.dictionaryDisplay\r\n        };\r\n\r\n        col.comparator = (valueA, valueB, nodeA, nodeB, isInverted) => {\r\n          if (valueA && !valueB) {\r\n            return 1;\r\n          }\r\n\r\n          if (valueB && !valueA) {\r\n            return -1;\r\n          }\r\n\r\n          if (!valueA && !valueB) {\r\n            return 0;\r\n          }\r\n\r\n          if (valueA.toLowerCase() > valueB.toLowerCase()) {\r\n            return 1;\r\n          } else if ((valueB.toLowerCase() > valueA.toLowerCase())) {\r\n            return -1;\r\n          } else {\r\n            return 0;\r\n          }\r\n        };\r\n\r\n        col.cellStyle = params => {\r\n          var column: any = {};\r\n          for (let field of params.context.componentParent.dictionary.fields) {\r\n            if (params.colDef.field == field.name) {\r\n              column = field;\r\n            }\r\n          }\r\n          if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\") {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          } else {\r\n            if (params.context.readOnly || column.readOnly ||\r\n              column.protectionType == \"Read Only\" || column.createOnly ||\r\n              column.protectionType == \"Create Only\" || column.code) {\r\n              return {color: \"#8a9499\"};\r\n            }\r\n          }\r\n        };\r\n\r\n        col.displayOrder = field.displayOrder;\r\n        // Set default filter as compare by text/number\r\n        // col.filterRenderer = CompareFilterRenderer;\r\n      }\r\n\r\n      cols.push(col);\r\n    }\r\n\r\n    // Now we need to sort the columns\r\n    if (!this.dictionary.fields[0].hasOwnProperty(\"displayOrder\")) {\r\n      // default case, no displayOrder\r\n      cols = cols.sort(\r\n        (a, b) => {\r\n          if (!a.headerName && b.headerName) {\r\n            return 1;\r\n          } else if (!b.headerName && a.headerName) {\r\n            return -1;\r\n          } else if (a.dictionaryDisplay === true && b.dictionaryDisplay === false) {\r\n            return -1;\r\n          } else if (b.dictionaryDisplay === true && a.dictionaryDisplay === false) {\r\n            return 1;\r\n          } else if (a.dictionaryTooltip === true && b.dictionaryTooltip === false) {\r\n            return -1;\r\n          } else if (b.dictionaryTooltip === true && a.dictionaryTooltip === false) {\r\n            return 1;\r\n          } else {\r\n            return 0;\r\n          }\r\n        }\r\n      );\r\n\r\n    } else {\r\n      // DisplayOrder case\r\n      // I think this works? Check later\r\n      cols = cols.sort(\r\n        (a, b) => {\r\n          if (!a.headerName && b.headerName) {\r\n            return 1;\r\n          } else if (!b.headerName && a.headerName) {\r\n            return -1;\r\n          } else {\r\n            return a.displayOrder - b.displayOrder;\r\n          }\r\n        }\r\n      );\r\n    }\r\n\r\n    // After Columns Have Been Sorted\r\n    // Dictionary Grid Will Sort The Grid Ascending Order By First Column\r\n    if(cols  && cols.length != 0) {\r\n      cols[0].sort = \"asc\";\r\n    }\r\n\r\n    this.dataColumns = cols;\r\n    if (Array.isArray(this.dataColumns) && this.gridOptions && this.gridOptions.api) {\r\n      this.gridOptions.api.setColumnDefs(this.dataColumns);\r\n      this.gridOptions.api.sizeColumnsToFit();\r\n    }\r\n  }\r\n\r\n  isEditable(params): boolean {\r\n\r\n    let isEditable: boolean;\r\n\r\n    let column: any = {};\r\n    for (let field of this.dictionary.fields) {\r\n      if (params.colDef.field == field.name) {\r\n        column = field;\r\n      }\r\n    }\r\n\r\n    if (params.data.editOrNew && params.data.editOrNew == \"new\") {\r\n      // console.log(\"new editable?\");\r\n      isEditable = !(this.dictionary.readOnly || column.readOnly ||\r\n        column.protectionType == \"Read Only\");\r\n    } else {\r\n      // console.log(\"edit editable?\");\r\n      isEditable = !(this.dictionary.readOnly || column.readOnly ||\r\n        column.protectionType == \"Read Only\" || column.createOnly ||\r\n        column.protectionType == \"Create Only\" || column.code);\r\n    }\r\n\r\n    return isEditable;\r\n  }\r\n\r\n  deleteDictionaryEntries(): void {\r\n\r\n    let deleteRows: any[] = this.gridOptions.api.getSelectedRows();\r\n\r\n    for (let deleteId of this.selectedRows) {\r\n      for (let entry of this.dictionaryEntries) {\r\n        if (entry[this.idColumn] === deleteId) {\r\n          deleteRows.push(entry);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.dictionaryService.deleteDictionaryEntries(this.className, deleteRows).subscribe(\r\n      (response: any) => {\r\n        this.getDictionaryEntries();\r\n      }\r\n    );\r\n  }\r\n\r\n  updateDictionary(event: any): void {\r\n\r\n    // Important to note this will not update cells to the demo but will when imported to CORE or other applications.\r\n    this.dictionaryService.updateDictionaryEntries(this.className, [event.data]).subscribe(\r\n      (data: any[]) => {\r\n        this.getDictionaryEntries();\r\n      }\r\n    );\r\n  }\r\n\r\n  setSelectedEntries(): void {\r\n\r\n    this.selectedRows = this.gridOptions.api.getSelectedRows();\r\n  }\r\n\r\n  newRowPost(data: any): Observable<any> {\r\n\r\n    return this.dictionaryService.addDictionaryEntries(this.className, [data])\r\n      .pipe(\r\n        map(\r\n          (data: Object[]) => {\r\n            if (data && data.length === 1) {\r\n              return <any>data[0];\r\n            } else {\r\n              return data;\r\n            }\r\n          }\r\n        )\r\n      );\r\n  }\r\n\r\n  public static onSamplesGridReady(event: GridReadyEvent): void {\r\n\r\n    event.api.sizeColumnsToFit();\r\n  }\r\n\r\n  public static onGridSizeChanged(event: any) {\r\n\r\n    if (event && event.api) {\r\n      event.api.sizeColumnsToFit();\r\n    }\r\n  }\r\n\r\n  public get disableAddRow(): boolean {\r\n\r\n    if (!this.dictionary) {\r\n      return true;\r\n    }\r\n\r\n    return this.dictionary.readOnly && this.dictionary.readOnly === true;\r\n  }\r\n\r\n  public get disableDelete(): boolean {\r\n\r\n    if (!this.dictionary) {\r\n      return true;\r\n    }\r\n\r\n    if (this.dictionary.readOnly && this.dictionary.readOnly === true) {\r\n      return true;\r\n    }\r\n\r\n    if (this.gridOptions && this.gridOptions.api && this.gridOptions.api.getSelectedRows()) {\r\n      return this.gridOptions.api.getSelectedRows().length === 0;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  private comboFilterValueGetter(params): any {\r\n\r\n    let value = params.data[params.colDef.field];\r\n\r\n    if (value) {\r\n      let option = ((params.colDef as any).selectOptions as any[]).find((entry) => (entry[params.colDef.selectOptionsValueField] === value));\r\n      return option ? option[params.colDef.selectOptionsDisplayField] : \"\";\r\n    }\r\n\r\n    return \"\";\r\n  }\r\n\r\n  onClickAddRow() {\r\n\r\n    const modalRef = this.modalService.open(NewRowComponent,\r\n      {\r\n        size: \"lg\",\r\n        keyboard: false,\r\n        backdrop: \"static\",\r\n        centered: true,\r\n      }\r\n    );\r\n\r\n    modalRef.componentInstance.colDefs = this.dataColumns;\r\n    modalRef.componentInstance.dictionary = this.dictionary;\r\n\r\n    if (!this.newRowSubscription) {\r\n      // tell other ag-grid to add row to it\r\n      this.newRowSubscription = modalRef.componentInstance.newRowSubject.subscribe(\r\n        (theNewRow: any[]) => {\r\n          this.dictionaryEntries = theNewRow.concat(this.dictionaryEntries);\r\n          this.gridOptions.api.setRowData(this.dictionaryEntries);\r\n          this.newRowSubscription = null;\r\n\r\n          // Important to note this will not add rows to the demo but will when imported to CORE or other applications.\r\n          this.newRowPost(theNewRow[0]).subscribe(\r\n            () => {\r\n              this.getDictionaryEntries();\r\n            }\r\n          );\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Comparater To Compare 2 Dates\r\n   * @param date1 Date 1\r\n   * @param date2 Date 2\r\n   */\r\n  dateComparator(date1, date2) {\r\n\r\n    let date1Number = monthToComparableNumber(date1);\r\n    let date2Number = monthToComparableNumber(date2);\r\n\r\n    if (date1Number === null && date2Number === null) {\r\n      return 0;\r\n    }\r\n\r\n    if (date1Number === null) {\r\n      return -1;\r\n    }\r\n\r\n    if (date2Number === null) {\r\n      return 1;\r\n    }\r\n\r\n    return date1Number - date2Number;\r\n  }\r\n}\r\n\r\n/**\r\n * Extracts Date And Turn To A Numerical Value For Comparing Purposes\r\n * @param date The date to comparable number\r\n */\r\nfunction monthToComparableNumber(date) {\r\n\r\n  if (date === undefined || date === null || date.length !== 10) {\r\n    return null;\r\n  }\r\n\r\n  let yearNumber = date.substring(0, 4);\r\n  let monthNumber = date.substring(5, 7);\r\n  let dayNumber = date.substring(8, 10);\r\n\r\n  return yearNumber * 10000 + monthNumber * 100 + dayNumber;\r\n}\r\n"]}
|