@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.
- package/components/attribute-edit.component.d.ts +6 -6
- package/esm2022/components/attribute-configuration.component.mjs +3 -3
- package/esm2022/components/attribute-container.component.mjs +5 -5
- package/esm2022/components/attribute-edit.component.mjs +637 -625
- package/esm2022/services/attribute.service.mjs +11 -10
- package/fesm2022/huntsman-cancer-institute-cod.mjs +626 -613
- package/fesm2022/huntsman-cancer-institute-cod.mjs.map +1 -1
- package/package.json +4 -4
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Component, ElementRef, Renderer2 } from
|
|
2
|
-
import { NgbModal } from
|
|
3
|
-
import { AttributeBase } from
|
|
4
|
-
import { AttributeService } from
|
|
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.
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
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
|
-
</
|
|
238
|
-
</
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
[
|
|
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
|
-
|
|
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
|
|
258
|
-
<div class="cod-label pl-1">
|
|
259
|
-
{{entry.display}}
|
|
260
|
-
</div>
|
|
158
|
+
class="form-control"/>
|
|
261
159
|
</div>
|
|
262
|
-
</
|
|
263
|
-
</
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
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
|
-
|
|
304
|
-
|
|
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
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
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
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
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:
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
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
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
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
|
-
</
|
|
562
|
-
</
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
[
|
|
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
|
-
|
|
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
|
|
582
|
-
<div class="cod-label pl-1">
|
|
583
|
-
{{entry.display}}
|
|
584
|
-
</div>
|
|
488
|
+
class="form-control"/>
|
|
585
489
|
</div>
|
|
586
|
-
</
|
|
587
|
-
</
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
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
|
-
|
|
628
|
-
|
|
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
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
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
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
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"]}
|