@huntsman-cancer-institute/cod 16.0.1 → 16.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,7 @@
1
- import { Component, ElementRef, Renderer2 } from "@angular/core";
2
- import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
3
- import { AttributeBase } from "./attribute-base";
4
- import { AttributeService } from "../services/attribute.service";
1
+ import { Component, ElementRef, Renderer2 } from '@angular/core';
2
+ import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
3
+ import { AttributeBase } from './attribute-base';
4
+ import { AttributeService } from '../services/attribute.service';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../services/attribute.service";
7
7
  import * as i2 from "@ng-bootstrap/ng-bootstrap";
@@ -11,11 +11,11 @@ import * as i5 from "@angular/forms";
11
11
  import * as i6 from "@angular/material/datepicker";
12
12
  import * as i7 from "@angular-material-components/datetime-picker";
13
13
  /**
14
- * This component is specifically designed to exist in a modal for editing. This is different from the flex attribute
15
- * because components such as the grid need extra configuration for editing.
14
+ * This component is specifically designed to exist in a modal for editing.
15
+ * This is different from the flex attribute because components such as the grid need extra configuration for editing.
16
16
  */
17
17
  export class AttributeEditComponent extends AttributeBase {
18
- //dictionaryEndpoint = this.attributeService.dictionaryEndpoint;
18
+ // dictionaryEndpoint = this.attributeService.dictionaryEndpoint;
19
19
  constructor(attributeService, elementRef, renderer, modalService) {
20
20
  super(attributeService, elementRef, renderer, modalService);
21
21
  }
@@ -24,649 +24,661 @@ export class AttributeEditComponent extends AttributeBase {
24
24
  }
25
25
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeEditComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
26
26
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AttributeEditComponent, selector: "hci-attribute-edit", usesInheritance: true, ngImport: i0, template: `
27
- <!-- String -->
28
- <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
29
- <div #attributeRef
30
- class="d-flex flex-row">
31
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
32
- {{attribute.displayName}}
33
- </div>
34
- <div class="d-flex col-md-6">
35
- <input #inputRef
36
- type="text"
37
- [ngModel]="attributeValues[0].valueString"
38
- (ngModelChange)="valueStringChange($event)"
39
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
40
- />
41
- </div>
42
- </div>
43
- </ng-container>
44
-
45
- <!-- Text -->
46
- <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
47
- <div #attributeRef
48
- class="d-flex flex-row">
49
- <div class="d-flex col-md-6">
50
- {{attribute.displayName}}
51
- </div>
52
- <div class="d-flex col-md-6">
53
- <input #inputRef
54
- type="text"
55
- spellcheck="spellcheck"
56
- lang="en"
57
- [ngModel]="attributeValues[0].valueLongText.textData"
58
- (ngModelChange)="valueTextChange($event)"
59
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
60
- />
61
- </div>
62
- </div>
63
- </ng-container>
64
-
65
- <!-- Numeric -->
66
- <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
67
- <div #attributeRef
68
- class="d-flex flex-row">
69
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
70
- {{attribute.displayName}}
71
- </div>
72
- <div class="d-flex col-md-6">
73
- <input #inputRef
74
- type="number"
75
- [ngModel]="attributeValues[0].valueNumeric"
76
- (ngModelChange)="valueNumericChange($event)"/>
77
- </div>
78
- </div>
79
- </ng-container>
80
-
81
- <!-- Integer -->
82
- <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
83
- <div #attributeRef
84
- class="d-flex flex-row">
85
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
86
- {{attribute.displayName}}
87
- </div>
88
- <div class="d-flex col-md-6">
89
- <input #inputRef
90
- type="number"
91
- [ngModel]="attributeValues[0].valueInteger"
92
- (ngModelChange)="valueIntegerChange($event)" />
93
- </div>
94
- </div>
95
- </ng-container>
96
-
97
- <!-- Date -->
98
- <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
99
- <div #attributeRef
100
- class="d-flex flex-row">
101
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
102
- {{attribute.displayName}}
103
- </div>
104
- <div class="d-flex col-md-6">
105
- <input #inputRef
106
- matInput
107
- name="valueDate"
108
- [(ngModel)]="attributeValues[0].valueDate"
109
- (ngModelChange)="valueDateChange($event)"
110
- [matDatepicker]="valueDate"
111
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
112
- >
113
- <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
114
- <mat-datepicker #valueDate></mat-datepicker>
115
- </div>
116
- </div>
117
- </ng-container>
118
-
119
- <!-- Date Time -->
120
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
121
- <div #attributeRef
122
- class="d-flex flex-row">
123
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
124
- {{attribute.displayName}}
125
- </div>
126
- <div class="d-flex col-md-6">
127
- <input #inputRef
128
- matInput
129
- name="valueDateTime"
130
- [(ngModel)]="attributeValues[0].date"
131
- (ngModelChange)="valueDateChange($event)"
132
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
133
- [ngxMatDatetimePicker]="dtpicker">
134
- <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
135
- <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
136
- </div>
137
- </div>
138
- </ng-container>
139
-
140
- <!-- Checkbox -->
141
- <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
142
- <div #attributeRef
143
- class="d-flex flex-row">
144
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
145
- {{attribute.displayName}}
146
- </div>
147
- <div class="d-flex col-md-6">
148
- <input #inputRef
149
- type="checkbox"
150
- [checked]="attributeValues[0].valueString === 'Y'"
151
- (change)="valueCheckboxChange($event)"
152
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
153
- class="form-control" />
154
- </div>
155
- </div>
156
- </ng-container>
157
-
158
- <!-- Boolean -->
159
- <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
160
- <div #attributeRef
161
- class="d-flex flex-row">
162
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
163
- {{attribute.displayName}}
164
- </div>
165
- <div class="d-flex col-md-6">
166
- <select [ngModel]="attributeValues[0].valueString"
167
- (ngModelChange)="valueStringChange($event)"
168
- class="edit-renderer">
169
- <option [ngValue]="undefined"></option>
170
- <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
171
- <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
172
- </select>
173
- </div>
174
- </div>
175
- </ng-container>
176
-
177
- <!-- Extended Boolean -->
178
- <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
179
- <div #attributeRef
180
- class="d-flex flex-row">
181
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
182
- {{attribute.displayName}}
183
- </div>
184
- <div class="d-flex col-md-6">
185
- <select [ngModel]="attributeValues[0].valueString"
186
- (ngModelChange)="valueStringChange($event)"
187
- class="edit-renderer">
188
- <option [ngValue]="undefined"></option>
189
- <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
190
- <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
191
- <option [ngValue]="'U'" [selected]="attributeValues[0].valueString === 'U'">Unknown</option>
192
- </select>
193
- </div>
194
- </div>
195
- </ng-container>
196
-
197
- <!-- Choice: Single -->
198
- <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
199
- <div #attributeRef
200
- class="d-flex flex-row">
201
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
202
- {{attribute.displayName}}
203
- </div>
204
- <div class="d-flex col-md-6">
205
- <select [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
206
- (ngModelChange)="valueChoiceChange($event)"
207
- class="edit-renderer">
208
- <option [ngValue]="undefined"></option>
209
- <option *ngFor="let attributeChoice of attributeChoices"
210
- [ngValue]="attributeChoice.idAttributeChoice">
211
- {{ attributeChoice.choice }}
212
- </option>
213
- </select>
214
- </div>
215
- </div>
216
- </ng-container>
217
-
218
- <!-- Choice: Multi -->
219
- <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
220
- <div #attributeRef
221
- class="d-flex flex-row">
222
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
223
- {{attribute.displayName}}
224
- </div>
225
- <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
226
- <ng-container *ngFor="let attributeChoice of attributeChoices">
227
- <div class="d-flex">
228
- <input type="checkbox"
229
- [checked]="attributeChoice.value"
27
+ <!-- String -->
28
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
29
+ <div #attributeRef
30
+ class="d-flex flex-row">
31
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
32
+ {{attribute.displayName}}
33
+ </div>
34
+ <div class="d-flex col-md-6">
35
+ <input #inputRef
36
+ type="text"
37
+ [ngModel]="attributeValues[0].valueString"
38
+ (ngModelChange)="valueStringChange($event)"
230
39
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
231
- (change)="valueMultiChoiceChange(attributeChoice)"
232
- class="form-control checkbox mt-auto mb-auto mr-2" />
233
- <div class="cod-label pl-1">
234
- {{attributeChoice.choice}}
235
- </div>
40
+ />
41
+ </div>
42
+ </div>
43
+ </ng-container>
44
+
45
+ <!-- Text -->
46
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
47
+ <div #attributeRef
48
+ class="d-flex flex-row">
49
+ <div class="d-flex col-md-6">
50
+ {{attribute.displayName}}
51
+ </div>
52
+ <div class="d-flex col-md-6">
53
+
54
+ <textarea
55
+ #inputRef
56
+ type="text"
57
+ spellcheck="spellcheck"
58
+ lang="en"
59
+ [ngModel]="attributeValues[0].valueLongText.textData"
60
+ (ngModelChange)="valueTextChange($event)"
61
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
62
+ style="width: 500px; height: 125px; resize: none;"
63
+ >
64
+ </textarea>
65
+
66
+ </div>
67
+ </div>
68
+ </ng-container>
69
+
70
+ <!-- Numeric -->
71
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
72
+ <div #attributeRef
73
+ class="d-flex flex-row">
74
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
75
+ {{attribute.displayName}}
76
+ </div>
77
+ <div class="d-flex col-md-6">
78
+ <input #inputRef
79
+ type="number"
80
+ [ngModel]="attributeValues[0].valueNumeric"
81
+ (ngModelChange)="valueNumericChange($event)"/>
82
+ </div>
83
+ </div>
84
+ </ng-container>
85
+
86
+ <!-- Integer -->
87
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
88
+ <div #attributeRef
89
+ class="d-flex flex-row">
90
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
91
+ {{attribute.displayName}}
92
+ </div>
93
+ <div class="d-flex col-md-6">
94
+ <input #inputRef
95
+ type="number"
96
+ [ngModel]="attributeValues[0].valueInteger"
97
+ (ngModelChange)="valueIntegerChange($event)"/>
236
98
  </div>
237
- </ng-container>
238
- </div>
239
- </div>
240
- </ng-container>
241
-
242
- <!-- Dictionary: Multi -->
243
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
244
- <div #attributeRef
245
- class="d-flex flex-row">
246
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
247
- {{attribute.displayName}}
248
- </div>
249
- <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
250
- <ng-container *ngFor="let entry of dictionaryEntries">
251
- <div class="d-flex">
252
- <input type="checkbox"
253
- [checked]="entry.checked"
99
+ </div>
100
+ </ng-container>
101
+
102
+ <!-- Date -->
103
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
104
+ <div #attributeRef
105
+ class="d-flex flex-row">
106
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
107
+ {{attribute.displayName}}
108
+ </div>
109
+ <div class="d-flex col-md-6">
110
+ <input #inputRef
111
+ matInput
112
+ name="valueDate"
113
+ [(ngModel)]="attributeValues[0].valueDate"
114
+ (ngModelChange)="valueDateChange($event)"
115
+ [matDatepicker]="valueDate"
116
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
117
+ >
118
+ <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
119
+ <mat-datepicker #valueDate></mat-datepicker>
120
+ </div>
121
+ </div>
122
+ </ng-container>
123
+
124
+ <!-- Date Time -->
125
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
126
+ <div #attributeRef
127
+ class="d-flex flex-row">
128
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
129
+ {{attribute.displayName}}
130
+ </div>
131
+ <div class="d-flex col-md-6">
132
+ <input #inputRef
133
+ matInput
134
+ name="valueDateTime"
135
+ [(ngModel)]="attributeValues[0].date"
136
+ (ngModelChange)="valueDateChange($event)"
254
137
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
255
- (change)="valueMultiDictChange(entry)"
138
+ [ngxMatDatetimePicker]="dtpicker">
139
+ <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
140
+ <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
141
+ </div>
142
+ </div>
143
+ </ng-container>
144
+
145
+ <!-- Checkbox -->
146
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
147
+ <div #attributeRef
148
+ class="d-flex flex-row">
149
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
150
+ {{attribute.displayName}}
151
+ </div>
152
+ <div class="d-flex col-md-6">
153
+ <input #inputRef
154
+ type="checkbox"
155
+ [checked]="attributeValues[0].valueString === 'Y'"
156
+ (change)="valueCheckboxChange($event)"
256
157
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
257
- class="form-control checkbox" />
258
- <div class="cod-label pl-1">
259
- {{entry.display}}
260
- </div>
158
+ class="form-control"/>
261
159
  </div>
262
- </ng-container>
263
- </div>
264
- </div>
265
- </ng-container>
266
-
267
- <!-- Dictionary -->
268
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
269
- <div #attributeRef
270
- class="d-flex flex-row">
271
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
272
- {{attribute.displayName}}
273
- </div>
274
- <div class="d-flex col-md-6">
275
- <select #inputRef
276
- [ngModel]="attributeValues[0].valueIdDictionary"
277
- (ngModelChange)="valueDictChange($event)"
278
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
279
- class="form-control edit-renderer">
280
- <option [ngValue]="undefined"></option>
281
- <option *ngFor="let entry of dictionaryEntries"
282
- [ngValue]="entry.value">
283
- {{ entry.display }}
284
- </option>
285
- </select>
286
- </div>
287
- </div>
288
- </ng-container>
289
-
290
- <!-- Grid -->
291
- <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
292
- <div #attributeRef
293
- class="d-flex flex-column">
294
- <div *ngIf="attribute.displayName" class="d-flex col-md-12">
295
- <div>
296
- {{attribute.displayName}}
297
- </div>
298
- <div style="margin-left: auto;">
299
- <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
160
+ </div>
161
+ </ng-container>
162
+
163
+ <!-- Boolean -->
164
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
165
+ <div #attributeRef
166
+ class="d-flex flex-row">
167
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
168
+ {{attribute.displayName}}
169
+ </div>
170
+ <div class="d-flex col-md-6">
171
+ <select [ngModel]="attributeValues[0].valueString"
172
+ (ngModelChange)="valueStringChange($event)"
173
+ class="edit-renderer">
174
+ <option [ngValue]="undefined"></option>
175
+ <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
176
+ <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
177
+ </select>
178
+ </div>
179
+ </div>
180
+ </ng-container>
181
+
182
+ <!-- Extended Boolean -->
183
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
184
+ <div #attributeRef
185
+ class="d-flex flex-row">
186
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
187
+ {{attribute.displayName}}
188
+ </div>
189
+ <div class="d-flex col-md-6">
190
+ <select [ngModel]="attributeValues[0].valueString"
191
+ (ngModelChange)="valueStringChange($event)"
192
+ class="edit-renderer">
193
+ <option [ngValue]="undefined"></option>
194
+ <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
195
+ <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
196
+ <option [ngValue]="'U'" [selected]="attributeValues[0].valueString === 'U'">Unknown</option>
197
+ </select>
198
+ </div>
199
+ </div>
200
+ </ng-container>
201
+
202
+ <!-- Choice: Single -->
203
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
204
+ <div #attributeRef
205
+ class="d-flex flex-row">
206
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
207
+ {{attribute.displayName}}
208
+ </div>
209
+ <div class="d-flex col-md-6">
210
+ <select
211
+ [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
212
+ (ngModelChange)="valueChoiceChange($event)"
213
+ class="edit-renderer">
214
+ <option [ngValue]="undefined"></option>
215
+ <option *ngFor="let attributeChoice of attributeChoices"
216
+ [ngValue]="attributeChoice.idAttributeChoice">
217
+ {{ attributeChoice.choice }}
218
+ </option>
219
+ </select>
220
+ </div>
221
+ </div>
222
+ </ng-container>
223
+
224
+ <!-- Choice: Multi -->
225
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
226
+ <div #attributeRef
227
+ class="d-flex flex-row">
228
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
229
+ {{attribute.displayName}}
230
+ </div>
231
+ <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
232
+ <ng-container *ngFor="let attributeChoice of attributeChoices">
233
+ <div class="d-flex">
234
+ <input type="checkbox"
235
+ [checked]="attributeChoice.value"
236
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
237
+ (change)="valueMultiChoiceChange(attributeChoice)"
238
+ class="form-control checkbox mt-auto mb-auto mr-2"/>
239
+ <div class="cod-label pl-1">
240
+ {{attributeChoice.choice}}
241
+ </div>
242
+ </div>
243
+ </ng-container>
244
+ </div>
245
+ </div>
246
+ </ng-container>
247
+
248
+ <!-- Dictionary: Multi -->
249
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
250
+ <div #attributeRef
251
+ class="d-flex flex-row">
252
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
253
+ {{attribute.displayName}}
254
+ </div>
255
+ <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
256
+ <ng-container *ngFor="let entry of dictionaryEntries">
257
+ <div class="d-flex">
258
+ <input type="checkbox"
259
+ [checked]="entry.checked"
260
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
261
+ (change)="valueMultiDictChange(entry)"
262
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
263
+ class="form-control checkbox"/>
264
+ <div class="cod-label pl-1">
265
+ {{entry.display}}
266
+ </div>
267
+ </div>
268
+ </ng-container>
269
+ </div>
270
+ </div>
271
+ </ng-container>
272
+
273
+ <!-- Dictionary -->
274
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
275
+ <div #attributeRef
276
+ class="d-flex flex-row">
277
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
278
+ {{attribute.displayName}}
279
+ </div>
280
+ <div class="d-flex col-md-6">
281
+ <select #inputRef
282
+ [ngModel]="attributeValues[0].valueIdDictionary"
283
+ (ngModelChange)="valueDictChange($event)"
284
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
285
+ class="form-control edit-renderer">
286
+ <option [ngValue]="undefined"></option>
287
+ <option *ngFor="let entry of dictionaryEntries"
288
+ [ngValue]="entry.value">
289
+ {{ entry.display }}
290
+ </option>
291
+ </select>
292
+ </div>
293
+ </div>
294
+ </ng-container>
295
+
296
+ <!-- Grid -->
297
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
298
+ <div #attributeRef
299
+ class="d-flex flex-column">
300
+ <div *ngIf="attribute.displayName" class="d-flex col-md-12">
301
+ <div>
302
+ {{attribute.displayName}}
303
+ </div>
304
+ <div style="margin-left: auto;">
305
+ <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
300
306
  <span class="ga-icon">
301
307
  <i class="fas fa-plus fa-xs"></i>
302
308
  </span>
303
- </button>
304
- <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
309
+ </button>
310
+ <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
305
311
  <span class="ga-icon">
306
312
  <i class="fas fa-minus fa-xs"></i>
307
313
  </span>
308
- </button>
309
- </div>
310
- </div>
311
- <div class="d-flex col-md-12">
312
- <ag-grid-angular #gridAttribute
313
- class="ag-theme-alpine"
314
- (gridReady)="this.onGridReady($event)"
315
- (modelUpdated)="onModelUpdated($event)"
316
- (gridSizeChanged)="onGridSizeChanged($event)"
317
- (rowDoubleClicked)="editGridRow(editGridModal, attribute.idAttribute, $event)"
318
- [gridOptions]="this.gridOptions"
319
- [rowSelection]="'single'"
320
- [columnDefs]="gridColumns"
321
- [rowData]="gridData"
322
- [style.width]="attribute.w + 'px'"
323
- [style.height]="attribute.h + 'px'">
324
- </ag-grid-angular>
325
- </div>
326
- </div>
327
- </ng-container>
328
-
329
- <ng-template #editGridModal let-close="close">
330
- <div class="modal-header">
331
- {{attribute.displayName}} Grid Row
332
- </div>
333
- <div class="modal-body d-flex flex-column hci-cod-edit">
334
- <ng-container *ngFor="let attribute of editGroupRowAttributes">
335
- <hci-attribute-edit [id]="'edit-id-attribute-' + attribute.idAttribute"
336
- [groupAttributeRowId]="editGroupAttributeRowId"
337
- [attribute]="attribute"
338
- class="attribute"></hci-attribute-edit>
314
+ </button>
315
+ </div>
316
+ </div>
317
+ <div class="d-flex col-md-12">
318
+ <ag-grid-angular #gridAttribute
319
+ class="ag-theme-alpine"
320
+ (gridReady)="this.onGridReady($event)"
321
+ (modelUpdated)="onModelUpdated($event)"
322
+ (gridSizeChanged)="onGridSizeChanged($event)"
323
+ (rowDoubleClicked)="editGridRow(editGridModal, attribute.idAttribute, $event)"
324
+ [gridOptions]="this.gridOptions"
325
+ [rowSelection]="'single'"
326
+ [columnDefs]="gridColumns"
327
+ [rowData]="gridData"
328
+ [style.width]="attribute.w + 'px'"
329
+ [style.height]="attribute.h + 'px'">
330
+ </ag-grid-angular>
331
+ </div>
332
+ </div>
339
333
  </ng-container>
340
- </div>
341
- <div class="modal-footer">
342
- <button class="btn btn-primary" (click)="close('Save')">Save</button>
343
- <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
344
- </div>
345
- </ng-template>
346
- `, isInline: true, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i7.NgxMatDatetimepicker, selector: "ngx-mat-datetime-picker", exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i7.NgxMatDatepickerInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "min", "max", "matDatepickerFilter"], exportAs: ["ngxMatDatepickerInput"] }, { kind: "component", type: AttributeEditComponent, selector: "hci-attribute-edit" }] }); }
334
+
335
+ <ng-template #editGridModal let-close="close">
336
+ <div class="modal-header">
337
+ {{attribute.displayName}} Grid Row
338
+ </div>
339
+ <div class="modal-body d-flex flex-column hci-cod-edit">
340
+ <ng-container *ngFor="let attribute of editGroupRowAttributes">
341
+ <hci-attribute-edit [id]="'edit-id-attribute-' + attribute.idAttribute"
342
+ [groupAttributeRowId]="editGroupAttributeRowId"
343
+ [attribute]="attribute"
344
+ class="attribute"></hci-attribute-edit>
345
+ </ng-container>
346
+ </div>
347
+ <div class="modal-footer">
348
+ <button class="btn btn-primary" (click)="close('Save')">Save</button>
349
+ <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
350
+ </div>
351
+ </ng-template>
352
+ `, isInline: true, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i7.NgxMatDatetimepicker, selector: "ngx-mat-datetime-picker", exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i7.NgxMatDatepickerInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "min", "max", "matDatepickerFilter"], exportAs: ["ngxMatDatepickerInput"] }, { kind: "component", type: AttributeEditComponent, selector: "hci-attribute-edit" }] }); }
347
353
  }
348
354
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeEditComponent, decorators: [{
349
355
  type: Component,
350
- args: [{ selector: "hci-attribute-edit", template: `
351
- <!-- String -->
352
- <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
353
- <div #attributeRef
354
- class="d-flex flex-row">
355
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
356
- {{attribute.displayName}}
357
- </div>
358
- <div class="d-flex col-md-6">
359
- <input #inputRef
360
- type="text"
361
- [ngModel]="attributeValues[0].valueString"
362
- (ngModelChange)="valueStringChange($event)"
363
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
364
- />
365
- </div>
366
- </div>
367
- </ng-container>
368
-
369
- <!-- Text -->
370
- <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
371
- <div #attributeRef
372
- class="d-flex flex-row">
373
- <div class="d-flex col-md-6">
374
- {{attribute.displayName}}
375
- </div>
376
- <div class="d-flex col-md-6">
377
- <input #inputRef
378
- type="text"
379
- spellcheck="spellcheck"
380
- lang="en"
381
- [ngModel]="attributeValues[0].valueLongText.textData"
382
- (ngModelChange)="valueTextChange($event)"
383
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
384
- />
385
- </div>
386
- </div>
387
- </ng-container>
388
-
389
- <!-- Numeric -->
390
- <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
391
- <div #attributeRef
392
- class="d-flex flex-row">
393
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
394
- {{attribute.displayName}}
395
- </div>
396
- <div class="d-flex col-md-6">
397
- <input #inputRef
398
- type="number"
399
- [ngModel]="attributeValues[0].valueNumeric"
400
- (ngModelChange)="valueNumericChange($event)"/>
401
- </div>
402
- </div>
403
- </ng-container>
404
-
405
- <!-- Integer -->
406
- <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
407
- <div #attributeRef
408
- class="d-flex flex-row">
409
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
410
- {{attribute.displayName}}
411
- </div>
412
- <div class="d-flex col-md-6">
413
- <input #inputRef
414
- type="number"
415
- [ngModel]="attributeValues[0].valueInteger"
416
- (ngModelChange)="valueIntegerChange($event)" />
417
- </div>
418
- </div>
419
- </ng-container>
420
-
421
- <!-- Date -->
422
- <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
423
- <div #attributeRef
424
- class="d-flex flex-row">
425
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
426
- {{attribute.displayName}}
427
- </div>
428
- <div class="d-flex col-md-6">
429
- <input #inputRef
430
- matInput
431
- name="valueDate"
432
- [(ngModel)]="attributeValues[0].valueDate"
433
- (ngModelChange)="valueDateChange($event)"
434
- [matDatepicker]="valueDate"
435
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
436
- >
437
- <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
438
- <mat-datepicker #valueDate></mat-datepicker>
439
- </div>
440
- </div>
441
- </ng-container>
442
-
443
- <!-- Date Time -->
444
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
445
- <div #attributeRef
446
- class="d-flex flex-row">
447
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
448
- {{attribute.displayName}}
449
- </div>
450
- <div class="d-flex col-md-6">
451
- <input #inputRef
452
- matInput
453
- name="valueDateTime"
454
- [(ngModel)]="attributeValues[0].date"
455
- (ngModelChange)="valueDateChange($event)"
456
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
457
- [ngxMatDatetimePicker]="dtpicker">
458
- <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
459
- <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
460
- </div>
461
- </div>
462
- </ng-container>
463
-
464
- <!-- Checkbox -->
465
- <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
466
- <div #attributeRef
467
- class="d-flex flex-row">
468
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
469
- {{attribute.displayName}}
470
- </div>
471
- <div class="d-flex col-md-6">
472
- <input #inputRef
473
- type="checkbox"
474
- [checked]="attributeValues[0].valueString === 'Y'"
475
- (change)="valueCheckboxChange($event)"
476
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
477
- class="form-control" />
478
- </div>
479
- </div>
480
- </ng-container>
481
-
482
- <!-- Boolean -->
483
- <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
484
- <div #attributeRef
485
- class="d-flex flex-row">
486
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
487
- {{attribute.displayName}}
488
- </div>
489
- <div class="d-flex col-md-6">
490
- <select [ngModel]="attributeValues[0].valueString"
491
- (ngModelChange)="valueStringChange($event)"
492
- class="edit-renderer">
493
- <option [ngValue]="undefined"></option>
494
- <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
495
- <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
496
- </select>
497
- </div>
498
- </div>
499
- </ng-container>
500
-
501
- <!-- Extended Boolean -->
502
- <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
503
- <div #attributeRef
504
- class="d-flex flex-row">
505
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
506
- {{attribute.displayName}}
507
- </div>
508
- <div class="d-flex col-md-6">
509
- <select [ngModel]="attributeValues[0].valueString"
510
- (ngModelChange)="valueStringChange($event)"
511
- class="edit-renderer">
512
- <option [ngValue]="undefined"></option>
513
- <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
514
- <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
515
- <option [ngValue]="'U'" [selected]="attributeValues[0].valueString === 'U'">Unknown</option>
516
- </select>
517
- </div>
518
- </div>
519
- </ng-container>
520
-
521
- <!-- Choice: Single -->
522
- <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
523
- <div #attributeRef
524
- class="d-flex flex-row">
525
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
526
- {{attribute.displayName}}
527
- </div>
528
- <div class="d-flex col-md-6">
529
- <select [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
530
- (ngModelChange)="valueChoiceChange($event)"
531
- class="edit-renderer">
532
- <option [ngValue]="undefined"></option>
533
- <option *ngFor="let attributeChoice of attributeChoices"
534
- [ngValue]="attributeChoice.idAttributeChoice">
535
- {{ attributeChoice.choice }}
536
- </option>
537
- </select>
538
- </div>
539
- </div>
540
- </ng-container>
541
-
542
- <!-- Choice: Multi -->
543
- <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
544
- <div #attributeRef
545
- class="d-flex flex-row">
546
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
547
- {{attribute.displayName}}
548
- </div>
549
- <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
550
- <ng-container *ngFor="let attributeChoice of attributeChoices">
551
- <div class="d-flex">
552
- <input type="checkbox"
553
- [checked]="attributeChoice.value"
356
+ args: [{ selector: 'hci-attribute-edit', template: `
357
+ <!-- String -->
358
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'S'">
359
+ <div #attributeRef
360
+ class="d-flex flex-row">
361
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
362
+ {{attribute.displayName}}
363
+ </div>
364
+ <div class="d-flex col-md-6">
365
+ <input #inputRef
366
+ type="text"
367
+ [ngModel]="attributeValues[0].valueString"
368
+ (ngModelChange)="valueStringChange($event)"
554
369
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
555
- (change)="valueMultiChoiceChange(attributeChoice)"
556
- class="form-control checkbox mt-auto mb-auto mr-2" />
557
- <div class="cod-label pl-1">
558
- {{attributeChoice.choice}}
559
- </div>
370
+ />
371
+ </div>
372
+ </div>
373
+ </ng-container>
374
+
375
+ <!-- Text -->
376
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'TXT'">
377
+ <div #attributeRef
378
+ class="d-flex flex-row">
379
+ <div class="d-flex col-md-6">
380
+ {{attribute.displayName}}
381
+ </div>
382
+ <div class="d-flex col-md-6">
383
+
384
+ <textarea
385
+ #inputRef
386
+ type="text"
387
+ spellcheck="spellcheck"
388
+ lang="en"
389
+ [ngModel]="attributeValues[0].valueLongText.textData"
390
+ (ngModelChange)="valueTextChange($event)"
391
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
392
+ style="width: 500px; height: 125px; resize: none;"
393
+ >
394
+ </textarea>
395
+
396
+ </div>
397
+ </div>
398
+ </ng-container>
399
+
400
+ <!-- Numeric -->
401
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'N'">
402
+ <div #attributeRef
403
+ class="d-flex flex-row">
404
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
405
+ {{attribute.displayName}}
406
+ </div>
407
+ <div class="d-flex col-md-6">
408
+ <input #inputRef
409
+ type="number"
410
+ [ngModel]="attributeValues[0].valueNumeric"
411
+ (ngModelChange)="valueNumericChange($event)"/>
412
+ </div>
413
+ </div>
414
+ </ng-container>
415
+
416
+ <!-- Integer -->
417
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'I'">
418
+ <div #attributeRef
419
+ class="d-flex flex-row">
420
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
421
+ {{attribute.displayName}}
422
+ </div>
423
+ <div class="d-flex col-md-6">
424
+ <input #inputRef
425
+ type="number"
426
+ [ngModel]="attributeValues[0].valueInteger"
427
+ (ngModelChange)="valueIntegerChange($event)"/>
560
428
  </div>
561
- </ng-container>
562
- </div>
563
- </div>
564
- </ng-container>
565
-
566
- <!-- Dictionary: Multi -->
567
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
568
- <div #attributeRef
569
- class="d-flex flex-row">
570
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
571
- {{attribute.displayName}}
572
- </div>
573
- <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
574
- <ng-container *ngFor="let entry of dictionaryEntries">
575
- <div class="d-flex">
576
- <input type="checkbox"
577
- [checked]="entry.checked"
429
+ </div>
430
+ </ng-container>
431
+
432
+ <!-- Date -->
433
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'D'">
434
+ <div #attributeRef
435
+ class="d-flex flex-row">
436
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
437
+ {{attribute.displayName}}
438
+ </div>
439
+ <div class="d-flex col-md-6">
440
+ <input #inputRef
441
+ matInput
442
+ name="valueDate"
443
+ [(ngModel)]="attributeValues[0].valueDate"
444
+ (ngModelChange)="valueDateChange($event)"
445
+ [matDatepicker]="valueDate"
446
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
447
+ >
448
+ <mat-datepicker-toggle matSuffix [for]="valueDate" class="cod-dp-toggle"></mat-datepicker-toggle>
449
+ <mat-datepicker #valueDate></mat-datepicker>
450
+ </div>
451
+ </div>
452
+ </ng-container>
453
+
454
+ <!-- Date Time -->
455
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DT'">
456
+ <div #attributeRef
457
+ class="d-flex flex-row">
458
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
459
+ {{attribute.displayName}}
460
+ </div>
461
+ <div class="d-flex col-md-6">
462
+ <input #inputRef
463
+ matInput
464
+ name="valueDateTime"
465
+ [(ngModel)]="attributeValues[0].date"
466
+ (ngModelChange)="valueDateChange($event)"
578
467
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
579
- (change)="valueMultiDictChange(entry)"
468
+ [ngxMatDatetimePicker]="dtpicker">
469
+ <mat-datepicker-toggle matSuffix [for]="dtpicker" class="cod-dp-toggle"></mat-datepicker-toggle>
470
+ <ngx-mat-datetime-picker #dtpicker [showSeconds]="true"></ngx-mat-datetime-picker>
471
+ </div>
472
+ </div>
473
+ </ng-container>
474
+
475
+ <!-- Checkbox -->
476
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'CB'">
477
+ <div #attributeRef
478
+ class="d-flex flex-row">
479
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
480
+ {{attribute.displayName}}
481
+ </div>
482
+ <div class="d-flex col-md-6">
483
+ <input #inputRef
484
+ type="checkbox"
485
+ [checked]="attributeValues[0].valueString === 'Y'"
486
+ (change)="valueCheckboxChange($event)"
580
487
  [disabled]="!editInline || attribute.isCalculated === 'Y'"
581
- class="form-control checkbox" />
582
- <div class="cod-label pl-1">
583
- {{entry.display}}
584
- </div>
488
+ class="form-control"/>
585
489
  </div>
586
- </ng-container>
587
- </div>
588
- </div>
589
- </ng-container>
590
-
591
- <!-- Dictionary -->
592
- <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
593
- <div #attributeRef
594
- class="d-flex flex-row">
595
- <div *ngIf="attribute.displayName" class="d-flex col-md-6">
596
- {{attribute.displayName}}
597
- </div>
598
- <div class="d-flex col-md-6">
599
- <select #inputRef
600
- [ngModel]="attributeValues[0].valueIdDictionary"
601
- (ngModelChange)="valueDictChange($event)"
602
- [disabled]="!editInline || attribute.isCalculated === 'Y'"
603
- class="form-control edit-renderer">
604
- <option [ngValue]="undefined"></option>
605
- <option *ngFor="let entry of dictionaryEntries"
606
- [ngValue]="entry.value">
607
- {{ entry.display }}
608
- </option>
609
- </select>
610
- </div>
611
- </div>
612
- </ng-container>
613
-
614
- <!-- Grid -->
615
- <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
616
- <div #attributeRef
617
- class="d-flex flex-column">
618
- <div *ngIf="attribute.displayName" class="d-flex col-md-12">
619
- <div>
620
- {{attribute.displayName}}
621
- </div>
622
- <div style="margin-left: auto;">
623
- <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
490
+ </div>
491
+ </ng-container>
492
+
493
+ <!-- Boolean -->
494
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'B'">
495
+ <div #attributeRef
496
+ class="d-flex flex-row">
497
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
498
+ {{attribute.displayName}}
499
+ </div>
500
+ <div class="d-flex col-md-6">
501
+ <select [ngModel]="attributeValues[0].valueString"
502
+ (ngModelChange)="valueStringChange($event)"
503
+ class="edit-renderer">
504
+ <option [ngValue]="undefined"></option>
505
+ <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
506
+ <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
507
+ </select>
508
+ </div>
509
+ </div>
510
+ </ng-container>
511
+
512
+ <!-- Extended Boolean -->
513
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'EB'">
514
+ <div #attributeRef
515
+ class="d-flex flex-row">
516
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
517
+ {{attribute.displayName}}
518
+ </div>
519
+ <div class="d-flex col-md-6">
520
+ <select [ngModel]="attributeValues[0].valueString"
521
+ (ngModelChange)="valueStringChange($event)"
522
+ class="edit-renderer">
523
+ <option [ngValue]="undefined"></option>
524
+ <option [ngValue]="'Y'" [selected]="attributeValues[0].valueString === 'Y'">Yes</option>
525
+ <option [ngValue]="'N'" [selected]="attributeValues[0].valueString === 'N'">No</option>
526
+ <option [ngValue]="'U'" [selected]="attributeValues[0].valueString === 'U'">Unknown</option>
527
+ </select>
528
+ </div>
529
+ </div>
530
+ </ng-container>
531
+
532
+ <!-- Choice: Single -->
533
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'">
534
+ <div #attributeRef
535
+ class="d-flex flex-row">
536
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
537
+ {{attribute.displayName}}
538
+ </div>
539
+ <div class="d-flex col-md-6">
540
+ <select
541
+ [ngModel]="(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined"
542
+ (ngModelChange)="valueChoiceChange($event)"
543
+ class="edit-renderer">
544
+ <option [ngValue]="undefined"></option>
545
+ <option *ngFor="let attributeChoice of attributeChoices"
546
+ [ngValue]="attributeChoice.idAttributeChoice">
547
+ {{ attributeChoice.choice }}
548
+ </option>
549
+ </select>
550
+ </div>
551
+ </div>
552
+ </ng-container>
553
+
554
+ <!-- Choice: Multi -->
555
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'">
556
+ <div #attributeRef
557
+ class="d-flex flex-row">
558
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
559
+ {{attribute.displayName}}
560
+ </div>
561
+ <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
562
+ <ng-container *ngFor="let attributeChoice of attributeChoices">
563
+ <div class="d-flex">
564
+ <input type="checkbox"
565
+ [checked]="attributeChoice.value"
566
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
567
+ (change)="valueMultiChoiceChange(attributeChoice)"
568
+ class="form-control checkbox mt-auto mb-auto mr-2"/>
569
+ <div class="cod-label pl-1">
570
+ {{attributeChoice.choice}}
571
+ </div>
572
+ </div>
573
+ </ng-container>
574
+ </div>
575
+ </div>
576
+ </ng-container>
577
+
578
+ <!-- Dictionary: Multi -->
579
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'">
580
+ <div #attributeRef
581
+ class="d-flex flex-row">
582
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
583
+ {{attribute.displayName}}
584
+ </div>
585
+ <div class="d-flex flex-column col-md-6" style="row-gap: 5px">
586
+ <ng-container *ngFor="let entry of dictionaryEntries">
587
+ <div class="d-flex">
588
+ <input type="checkbox"
589
+ [checked]="entry.checked"
590
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
591
+ (change)="valueMultiDictChange(entry)"
592
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
593
+ class="form-control checkbox"/>
594
+ <div class="cod-label pl-1">
595
+ {{entry.display}}
596
+ </div>
597
+ </div>
598
+ </ng-container>
599
+ </div>
600
+ </div>
601
+ </ng-container>
602
+
603
+ <!-- Dictionary -->
604
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'">
605
+ <div #attributeRef
606
+ class="d-flex flex-row">
607
+ <div *ngIf="attribute.displayName" class="d-flex col-md-6">
608
+ {{attribute.displayName}}
609
+ </div>
610
+ <div class="d-flex col-md-6">
611
+ <select #inputRef
612
+ [ngModel]="attributeValues[0].valueIdDictionary"
613
+ (ngModelChange)="valueDictChange($event)"
614
+ [disabled]="!editInline || attribute.isCalculated === 'Y'"
615
+ class="form-control edit-renderer">
616
+ <option [ngValue]="undefined"></option>
617
+ <option *ngFor="let entry of dictionaryEntries"
618
+ [ngValue]="entry.value">
619
+ {{ entry.display }}
620
+ </option>
621
+ </select>
622
+ </div>
623
+ </div>
624
+ </ng-container>
625
+
626
+ <!-- Grid -->
627
+ <ng-container *ngIf="attribute.codeAttributeDataType === 'GA'">
628
+ <div #attributeRef
629
+ class="d-flex flex-column">
630
+ <div *ngIf="attribute.displayName" class="d-flex col-md-12">
631
+ <div>
632
+ {{attribute.displayName}}
633
+ </div>
634
+ <div style="margin-left: auto;">
635
+ <button class="btn-ga" (click)="addGridRow(editGridModal, attribute.idAttribute)">
624
636
  <span class="ga-icon">
625
637
  <i class="fas fa-plus fa-xs"></i>
626
638
  </span>
627
- </button>
628
- <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
639
+ </button>
640
+ <button class="btn-ga" (click)="removeGridRow(attribute.idAttribute)">
629
641
  <span class="ga-icon">
630
642
  <i class="fas fa-minus fa-xs"></i>
631
643
  </span>
632
- </button>
633
- </div>
634
- </div>
635
- <div class="d-flex col-md-12">
636
- <ag-grid-angular #gridAttribute
637
- class="ag-theme-alpine"
638
- (gridReady)="this.onGridReady($event)"
639
- (modelUpdated)="onModelUpdated($event)"
640
- (gridSizeChanged)="onGridSizeChanged($event)"
641
- (rowDoubleClicked)="editGridRow(editGridModal, attribute.idAttribute, $event)"
642
- [gridOptions]="this.gridOptions"
643
- [rowSelection]="'single'"
644
- [columnDefs]="gridColumns"
645
- [rowData]="gridData"
646
- [style.width]="attribute.w + 'px'"
647
- [style.height]="attribute.h + 'px'">
648
- </ag-grid-angular>
649
- </div>
650
- </div>
651
- </ng-container>
652
-
653
- <ng-template #editGridModal let-close="close">
654
- <div class="modal-header">
655
- {{attribute.displayName}} Grid Row
656
- </div>
657
- <div class="modal-body d-flex flex-column hci-cod-edit">
658
- <ng-container *ngFor="let attribute of editGroupRowAttributes">
659
- <hci-attribute-edit [id]="'edit-id-attribute-' + attribute.idAttribute"
660
- [groupAttributeRowId]="editGroupAttributeRowId"
661
- [attribute]="attribute"
662
- class="attribute"></hci-attribute-edit>
644
+ </button>
645
+ </div>
646
+ </div>
647
+ <div class="d-flex col-md-12">
648
+ <ag-grid-angular #gridAttribute
649
+ class="ag-theme-alpine"
650
+ (gridReady)="this.onGridReady($event)"
651
+ (modelUpdated)="onModelUpdated($event)"
652
+ (gridSizeChanged)="onGridSizeChanged($event)"
653
+ (rowDoubleClicked)="editGridRow(editGridModal, attribute.idAttribute, $event)"
654
+ [gridOptions]="this.gridOptions"
655
+ [rowSelection]="'single'"
656
+ [columnDefs]="gridColumns"
657
+ [rowData]="gridData"
658
+ [style.width]="attribute.w + 'px'"
659
+ [style.height]="attribute.h + 'px'">
660
+ </ag-grid-angular>
661
+ </div>
662
+ </div>
663
663
  </ng-container>
664
- </div>
665
- <div class="modal-footer">
666
- <button class="btn btn-primary" (click)="close('Save')">Save</button>
667
- <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
668
- </div>
669
- </ng-template>
670
- `, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"] }]
664
+
665
+ <ng-template #editGridModal let-close="close">
666
+ <div class="modal-header">
667
+ {{attribute.displayName}} Grid Row
668
+ </div>
669
+ <div class="modal-body d-flex flex-column hci-cod-edit">
670
+ <ng-container *ngFor="let attribute of editGroupRowAttributes">
671
+ <hci-attribute-edit [id]="'edit-id-attribute-' + attribute.idAttribute"
672
+ [groupAttributeRowId]="editGroupAttributeRowId"
673
+ [attribute]="attribute"
674
+ class="attribute"></hci-attribute-edit>
675
+ </ng-container>
676
+ </div>
677
+ <div class="modal-footer">
678
+ <button class="btn btn-primary" (click)="close('Save')">Save</button>
679
+ <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
680
+ </div>
681
+ </ng-template>
682
+ `, styles: [".hci-cod button.mat-icon-button.mat-button-base{height:20px;width:20px;line-height:unset}.btn-ga{padding:0;height:18px;width:18px}.ga-icon{font-size:.9em;vertical-align:top}.hci-cod .mat-datepicker-toggle-default-icon{height:20px;width:20px}\n"] }]
671
683
  }], ctorParameters: function () { return [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.NgbModal }]; } });
672
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-edit.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-edit.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EAMV,SAAS,EAEV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;AAO/D;;;GAGG;AA4VH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,gEAAgE;IAEhE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;+GAVU,sBAAsB;mGAAtB,sBAAsB,iFAzVvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT,6qWAyBU,sBAAsB;;4FAAtB,sBAAsB;kBA3VlC,SAAS;+BACE,oBAAoB,YACpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgUT","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  InjectionToken,\r\n  Input,\r\n  isDevMode,\r\n  QueryList,\r\n  Renderer2,\r\n  ViewChildren\r\n} from \"@angular/core\";\r\n\r\nimport {NgbModal} from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {AttributeBase} from \"./attribute-base\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {AttributeLongText} from \"../model/attribute-long-text.entity\";\r\nimport {Attribute} from \"../model/attribute.entity\";\r\nimport {AttributeValue} from \"../model/attribute-value.entity\";\r\nimport {AttributeChoice} from \"../model/attribute-choice.entity\";\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.  This is different from the flex attribute\r\n * because components such as the grid need extra configuration for editing.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-edit\",\r\n  template: `\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n        <div #attributeRef\r\n             class=\"d-flex flex-row\">\r\n          <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n           {{attribute.displayName}}\r\n          </div>\r\n          <div class=\"d-flex col-md-6\">\r\n            <input #inputRef\r\n                   type=\"text\"\r\n                   [ngModel]=\"attributeValues[0].valueString\"\r\n                   (ngModelChange)=\"valueStringChange($event)\"\r\n                   [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            />\r\n          </div>\r\n        </div>\r\n    </ng-container>\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div class=\"d-flex col-md-6\">\r\n            {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <input #inputRef\r\n                 type=\"text\"\r\n                 spellcheck=\"spellcheck\"\r\n                 lang=\"en\"\r\n                 [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n                 (ngModelChange)=\"valueTextChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [ngModel]=\"attributeValues[0].valueNumeric\"\r\n                 (ngModelChange)=\"valueNumericChange($event)\"/>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <input #inputRef\r\n                 type=\"number\"\r\n                 [ngModel]=\"attributeValues[0].valueInteger\"\r\n                 (ngModelChange)=\"valueIntegerChange($event)\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n            {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n           <input #inputRef\r\n              matInput\r\n              name=\"valueDate\"\r\n              [(ngModel)]=\"attributeValues[0].valueDate\"\r\n              (ngModelChange)=\"valueDateChange($event)\"\r\n              [matDatepicker]=\"valueDate\"\r\n              [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n              >\r\n            <mat-datepicker-toggle  matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n            <mat-datepicker #valueDate></mat-datepicker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <input #inputRef\r\n                 matInput\r\n                 name=\"valueDateTime\"\r\n                 [(ngModel)]=\"attributeValues[0].date\"\r\n                 (ngModelChange)=\"valueDateChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 [ngxMatDatetimePicker]=\"dtpicker\">\r\n               <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n               <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Checkbox -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <input #inputRef\r\n                 type=\"checkbox\"\r\n                 [checked]=\"attributeValues[0].valueString === 'Y'\"\r\n                 (change)=\"valueCheckboxChange($event)\"\r\n                 [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                 class=\"form-control\" />\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Extended Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'EB'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"attributeValues[0].valueString\"\r\n                  (ngModelChange)=\"valueStringChange($event)\"\r\n                  class=\"edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n            <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n            <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                  (ngModelChange)=\"valueChoiceChange($event)\"\r\n                  class=\"edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let attributeChoice of attributeChoices\"\r\n                    [ngValue]=\"attributeChoice.idAttributeChoice\">\r\n              {{ attributeChoice.choice }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n          <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n            <div class=\"d-flex\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"attributeChoice.value\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                     class=\"form-control checkbox mt-auto mb-auto mr-2\" />\r\n              <div class=\"cod-label pl-1\">\r\n                {{attributeChoice.choice}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n    \r\n    <!-- Dictionary: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n          <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n            <div class=\"d-flex\">\r\n              <input type=\"checkbox\"\r\n                     [checked]=\"entry.checked\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     (change)=\"valueMultiDictChange(entry)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control checkbox\" />\r\n              <div class=\"cod-label pl-1\">\r\n                {{entry.display}}\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>   \r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-row\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n          {{attribute.displayName}}\r\n        </div>\r\n        <div class=\"d-flex col-md-6\">\r\n          <select #inputRef\r\n                  [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                  (ngModelChange)=\"valueDictChange($event)\"\r\n                  [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                  class=\"form-control edit-renderer\">\r\n            <option [ngValue]=\"undefined\"></option>\r\n            <option *ngFor=\"let entry of dictionaryEntries\"\r\n                    [ngValue]=\"entry.value\">\r\n              {{ entry.display }}\r\n            </option>\r\n          </select>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n      <div #attributeRef\r\n           class=\"d-flex flex-column\">\r\n        <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-12\">\r\n          <div>\r\n            {{attribute.displayName}}\r\n          </div>\r\n          <div style=\"margin-left: auto;\">\r\n            <button class=\"btn-ga\" (click)=\"addGridRow(editGridModal, attribute.idAttribute)\">\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n            <button class=\"btn-ga\" (click)=\"removeGridRow(attribute.idAttribute)\">\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n        <div class=\"d-flex col-md-12\">\r\n          <ag-grid-angular #gridAttribute\r\n              class=\"ag-theme-alpine\"\r\n              (gridReady)=\"this.onGridReady($event)\"\r\n              (modelUpdated)=\"onModelUpdated($event)\"\r\n              (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n              (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n              [gridOptions]=\"this.gridOptions\"\r\n              [rowSelection]=\"'single'\"\r\n              [columnDefs]=\"gridColumns\"\r\n              [rowData]=\"gridData\"\r\n              [style.width]=\"attribute.w + 'px'\"\r\n              [style.height]=\"attribute.h + 'px'\">\r\n          </ag-grid-angular>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <ng-template #editGridModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{attribute.displayName}} Grid Row\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n        <button class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n        <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n  styles: [`\r\n    .hci-cod button.mat-icon-button.mat-button-base {\r\n        height: 20px;\r\n        width: 20px;\r\n        line-height: unset;\r\n    }\r\n\r\n    .btn-ga {\r\n      padding: 0px;\r\n      height: 18px;\r\n      width: 18px;\r\n    }\r\n\r\n    .ga-icon {\r\n      font-size: .9em;\r\n      vertical-align: top;\r\n    }\r\n\r\n    .hci-cod .mat-datepicker-toggle-default-icon {\r\n      height: 20px;\r\n      width: 20px;\r\n    }\r\n `]\r\n})\r\nexport class AttributeEditComponent extends AttributeBase {\r\n\r\n  //dictionaryEndpoint = this.attributeService.dictionaryEndpoint;\r\n\r\n  constructor(attributeService: AttributeService, elementRef: ElementRef, renderer: Renderer2, modalService: NgbModal) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  init(): void {\r\n    super.init();\r\n  }\r\n}\r\n"]}
684
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-edit.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-edit.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,SAAS,EACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;AAE/D;;;GAGG;AAuWH,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAEvD,iEAAiE;IAEjE,YAAY,gBAAkC,EAAE,UAAsB,EAAE,QAAmB,EAAE,YAAsB;QACjH,KAAK,CAAC,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI;QACF,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;+GAVU,sBAAsB;mGAAtB,sBAAsB,iFAlW7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAsUC,6qWA4BM,sBAAsB;;4FAAtB,sBAAsB;kBAtWlC,SAAS;+BAEI,oBAAoB,YAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAsUC","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Renderer2\r\n} from '@angular/core';\r\n\r\nimport {NgbModal} from '@ng-bootstrap/ng-bootstrap';\r\nimport {AttributeBase} from './attribute-base';\r\nimport {AttributeService} from '../services/attribute.service';\r\n\r\n/**\r\n * This component is specifically designed to exist in a modal for editing.\r\n * This is different from the flex attribute because components such as the grid need extra configuration for editing.\r\n */\r\n@Component(\r\n  {\r\n    selector: 'hci-attribute-edit',\r\n    template:\r\n      `\r\n        <!-- String -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'S'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"text\"\r\n                     [ngModel]=\"attributeValues[0].valueString\"\r\n                     (ngModelChange)=\"valueStringChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n              />\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Text -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'TXT'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n\r\n          <textarea\r\n            #inputRef\r\n            type=\"text\"\r\n            spellcheck=\"spellcheck\"\r\n            lang=\"en\"\r\n            [ngModel]=\"attributeValues[0].valueLongText.textData\"\r\n            (ngModelChange)=\"valueTextChange($event)\"\r\n            [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n            style=\"width: 500px; height: 125px; resize: none;\"\r\n          >\r\n          </textarea>\r\n\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Numeric -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'N'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueNumeric\"\r\n                     (ngModelChange)=\"valueNumericChange($event)\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Integer -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'I'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"number\"\r\n                     [ngModel]=\"attributeValues[0].valueInteger\"\r\n                     (ngModelChange)=\"valueIntegerChange($event)\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Date -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'D'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     matInput\r\n                     name=\"valueDate\"\r\n                     [(ngModel)]=\"attributeValues[0].valueDate\"\r\n                     (ngModelChange)=\"valueDateChange($event)\"\r\n                     [matDatepicker]=\"valueDate\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n              >\r\n              <mat-datepicker-toggle matSuffix [for]=\"valueDate\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n              <mat-datepicker #valueDate></mat-datepicker>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Date Time -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DT'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     matInput\r\n                     name=\"valueDateTime\"\r\n                     [(ngModel)]=\"attributeValues[0].date\"\r\n                     (ngModelChange)=\"valueDateChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     [ngxMatDatetimePicker]=\"dtpicker\">\r\n              <mat-datepicker-toggle matSuffix [for]=\"dtpicker\" class=\"cod-dp-toggle\"></mat-datepicker-toggle>\r\n              <ngx-mat-datetime-picker #dtpicker [showSeconds]=\"true\"></ngx-mat-datetime-picker>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Checkbox -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'CB'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <input #inputRef\r\n                     type=\"checkbox\"\r\n                     [checked]=\"attributeValues[0].valueString === 'Y'\"\r\n                     (change)=\"valueCheckboxChange($event)\"\r\n                     [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                     class=\"form-control\"/>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Boolean -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'B'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <select [ngModel]=\"attributeValues[0].valueString\"\r\n                      (ngModelChange)=\"valueStringChange($event)\"\r\n                      class=\"edit-renderer\">\r\n                <option [ngValue]=\"undefined\"></option>\r\n                <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n                <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n              </select>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Extended Boolean -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'EB'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <select [ngModel]=\"attributeValues[0].valueString\"\r\n                      (ngModelChange)=\"valueStringChange($event)\"\r\n                      class=\"edit-renderer\">\r\n                <option [ngValue]=\"undefined\"></option>\r\n                <option [ngValue]=\"'Y'\" [selected]=\"attributeValues[0].valueString === 'Y'\">Yes</option>\r\n                <option [ngValue]=\"'N'\" [selected]=\"attributeValues[0].valueString === 'N'\">No</option>\r\n                <option [ngValue]=\"'U'\" [selected]=\"attributeValues[0].valueString === 'U'\">Unknown</option>\r\n              </select>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Choice: Single -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'N'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <select\r\n                [ngModel]=\"(attributeValues[0].valueAttributeChoice)?attributeValues[0].valueAttributeChoice.idAttributeChoice:undefined\"\r\n                (ngModelChange)=\"valueChoiceChange($event)\"\r\n                class=\"edit-renderer\">\r\n                <option [ngValue]=\"undefined\"></option>\r\n                <option *ngFor=\"let attributeChoice of attributeChoices\"\r\n                        [ngValue]=\"attributeChoice.idAttributeChoice\">\r\n                  {{ attributeChoice.choice }}\r\n                </option>\r\n              </select>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Choice: Multi -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'AC' && attribute.isMultiValue === 'Y'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let attributeChoice of attributeChoices\">\r\n                <div class=\"d-flex\">\r\n                  <input type=\"checkbox\"\r\n                         [checked]=\"attributeChoice.value\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                         (change)=\"valueMultiChoiceChange(attributeChoice)\"\r\n                         class=\"form-control checkbox mt-auto mb-auto mr-2\"/>\r\n                  <div class=\"cod-label pl-1\">\r\n                    {{attributeChoice.choice}}\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Dictionary: Multi -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'Y'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex flex-column col-md-6\" style=\"row-gap: 5px\">\r\n              <ng-container *ngFor=\"let entry of dictionaryEntries\">\r\n                <div class=\"d-flex\">\r\n                  <input type=\"checkbox\"\r\n                         [checked]=\"entry.checked\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                         (change)=\"valueMultiDictChange(entry)\"\r\n                         [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                         class=\"form-control checkbox\"/>\r\n                  <div class=\"cod-label pl-1\">\r\n                    {{entry.display}}\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Dictionary -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'DICT' && attribute.isMultiValue === 'N'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-row\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-6\">\r\n              {{attribute.displayName}}\r\n            </div>\r\n            <div class=\"d-flex col-md-6\">\r\n              <select #inputRef\r\n                      [ngModel]=\"attributeValues[0].valueIdDictionary\"\r\n                      (ngModelChange)=\"valueDictChange($event)\"\r\n                      [disabled]=\"!editInline || attribute.isCalculated === 'Y'\"\r\n                      class=\"form-control edit-renderer\">\r\n                <option [ngValue]=\"undefined\"></option>\r\n                <option *ngFor=\"let entry of dictionaryEntries\"\r\n                        [ngValue]=\"entry.value\">\r\n                  {{ entry.display }}\r\n                </option>\r\n              </select>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!-- Grid -->\r\n        <ng-container *ngIf=\"attribute.codeAttributeDataType === 'GA'\">\r\n          <div #attributeRef\r\n               class=\"d-flex flex-column\">\r\n            <div *ngIf=\"attribute.displayName\" class=\"d-flex col-md-12\">\r\n              <div>\r\n                {{attribute.displayName}}\r\n              </div>\r\n              <div style=\"margin-left: auto;\">\r\n                <button class=\"btn-ga\" (click)=\"addGridRow(editGridModal, attribute.idAttribute)\">\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-plus fa-xs\"></i>\r\n              </span>\r\n                </button>\r\n                <button class=\"btn-ga\" (click)=\"removeGridRow(attribute.idAttribute)\">\r\n              <span class=\"ga-icon\">\r\n                <i class=\"fas fa-minus fa-xs\"></i>\r\n              </span>\r\n                </button>\r\n              </div>\r\n            </div>\r\n            <div class=\"d-flex col-md-12\">\r\n              <ag-grid-angular #gridAttribute\r\n                               class=\"ag-theme-alpine\"\r\n                               (gridReady)=\"this.onGridReady($event)\"\r\n                               (modelUpdated)=\"onModelUpdated($event)\"\r\n                               (gridSizeChanged)=\"onGridSizeChanged($event)\"\r\n                               (rowDoubleClicked)=\"editGridRow(editGridModal, attribute.idAttribute, $event)\"\r\n                               [gridOptions]=\"this.gridOptions\"\r\n                               [rowSelection]=\"'single'\"\r\n                               [columnDefs]=\"gridColumns\"\r\n                               [rowData]=\"gridData\"\r\n                               [style.width]=\"attribute.w + 'px'\"\r\n                               [style.height]=\"attribute.h + 'px'\">\r\n              </ag-grid-angular>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-template #editGridModal let-close=\"close\">\r\n          <div class=\"modal-header\">\r\n            {{attribute.displayName}} Grid Row\r\n          </div>\r\n          <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n            <ng-container *ngFor=\"let attribute of editGroupRowAttributes\">\r\n              <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                                  [groupAttributeRowId]=\"editGroupAttributeRowId\"\r\n                                  [attribute]=\"attribute\"\r\n                                  class=\"attribute\"></hci-attribute-edit>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"modal-footer\">\r\n            <button class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n            <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n          </div>\r\n        </ng-template>\r\n      `,\r\n    styles: [\r\n      `\r\n        .hci-cod button.mat-icon-button.mat-button-base {\r\n          height: 20px;\r\n          width: 20px;\r\n          line-height: unset;\r\n        }\r\n\r\n        .btn-ga {\r\n          padding: 0px;\r\n          height: 18px;\r\n          width: 18px;\r\n        }\r\n\r\n        .ga-icon {\r\n          font-size: .9em;\r\n          vertical-align: top;\r\n        }\r\n\r\n        .hci-cod .mat-datepicker-toggle-default-icon {\r\n          height: 20px;\r\n          width: 20px;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class AttributeEditComponent extends AttributeBase {\r\n\r\n  // dictionaryEndpoint = this.attributeService.dictionaryEndpoint;\r\n\r\n  constructor(attributeService: AttributeService, elementRef: ElementRef, renderer: Renderer2, modalService: NgbModal) {\r\n    super(attributeService, elementRef, renderer, modalService);\r\n  }\r\n\r\n  init(): void {\r\n    super.init();\r\n  }\r\n}\r\n"]}