@huntsman-cancer-institute/cod 16.0.0 → 17.0.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.
Files changed (56) hide show
  1. package/cod.module.d.ts +31 -31
  2. package/components/attribute-absolute.component.d.ts +28 -28
  3. package/components/attribute-base.d.ts +135 -135
  4. package/components/attribute-configuration.component.d.ts +52 -52
  5. package/components/attribute-container.component.d.ts +50 -50
  6. package/components/attribute-default.component.d.ts +20 -20
  7. package/components/attribute-edit.component.d.ts +15 -15
  8. package/components/attribute-flex.component.d.ts +25 -25
  9. package/date/date-util.d.ts +9 -9
  10. package/esm2022/cod.module.mjs +119 -119
  11. package/esm2022/components/attribute-absolute.component.mjs +104 -104
  12. package/esm2022/components/attribute-base.mjs +564 -564
  13. package/esm2022/components/attribute-configuration.component.mjs +138 -138
  14. package/esm2022/components/attribute-container.component.mjs +155 -155
  15. package/esm2022/components/attribute-default.component.mjs +63 -63
  16. package/esm2022/components/attribute-edit.component.mjs +33 -33
  17. package/esm2022/components/attribute-flex.component.mjs +58 -58
  18. package/esm2022/date/date-util.mjs +59 -59
  19. package/esm2022/huntsman-cancer-institute-cod.mjs +4 -4
  20. package/esm2022/index.mjs +20 -20
  21. package/esm2022/model/attribute-choice.entity.mjs +1 -1
  22. package/esm2022/model/attribute-configuration.dto.mjs +1 -1
  23. package/esm2022/model/attribute-configuration.entity.mjs +1 -1
  24. package/esm2022/model/attribute-container.entity.mjs +1 -1
  25. package/esm2022/model/attribute-dictionary.entity.mjs +1 -1
  26. package/esm2022/model/attribute-long-text.entity.mjs +1 -1
  27. package/esm2022/model/attribute-value-grid-row.entity.mjs +1 -1
  28. package/esm2022/model/attribute-value-set.entity.mjs +1 -1
  29. package/esm2022/model/attribute-value.entity.mjs +2 -2
  30. package/esm2022/model/attribute.entity.mjs +1 -1
  31. package/esm2022/model/dictionary-entries.dto.mjs +2 -2
  32. package/esm2022/model/extractable-field-status.entity.mjs +1 -1
  33. package/esm2022/model/graphical-attribute.entity.mjs +1 -1
  34. package/esm2022/model/pre-eval.dto.mjs +2 -2
  35. package/esm2022/pipes/is-group-attribute.pipe.mjs +32 -32
  36. package/esm2022/services/attribute.service.mjs +1211 -1211
  37. package/fesm2022/huntsman-cancer-institute-cod.mjs +2409 -2409
  38. package/fesm2022/huntsman-cancer-institute-cod.mjs.map +1 -1
  39. package/index.d.ts +27 -27
  40. package/model/attribute-choice.entity.d.ts +16 -16
  41. package/model/attribute-configuration.dto.d.ts +13 -13
  42. package/model/attribute-configuration.entity.d.ts +12 -12
  43. package/model/attribute-container.entity.d.ts +9 -9
  44. package/model/attribute-dictionary.entity.d.ts +12 -12
  45. package/model/attribute-long-text.entity.d.ts +4 -4
  46. package/model/attribute-value-grid-row.entity.d.ts +7 -7
  47. package/model/attribute-value-set.entity.d.ts +11 -11
  48. package/model/attribute-value.entity.d.ts +28 -28
  49. package/model/attribute.entity.d.ts +26 -26
  50. package/model/dictionary-entries.dto.d.ts +6 -6
  51. package/model/extractable-field-status.entity.d.ts +8 -8
  52. package/model/graphical-attribute.entity.d.ts +13 -13
  53. package/model/pre-eval.dto.d.ts +5 -5
  54. package/package.json +23 -7
  55. package/pipes/is-group-attribute.pipe.d.ts +13 -13
  56. package/services/attribute.service.d.ts +263 -263
@@ -1,121 +1,121 @@
1
- import { ChangeDetectorRef, Component, ElementRef, Input, Renderer2, HostBinding } from "@angular/core";
2
- import { Subscription } from "rxjs";
3
- import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
4
- import { AttributeService } from "../services/attribute.service";
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "../services/attribute.service";
7
- import * as i2 from "@ng-bootstrap/ng-bootstrap";
8
- import * as i3 from "@angular/common";
9
- import * as i4 from "@huntsman-cancer-institute/misc";
10
- import * as i5 from "./attribute-absolute.component";
11
- import * as i6 from "./attribute-flex.component";
12
- import * as i7 from "./attribute-edit.component";
13
- import * as i8 from "../pipes/is-group-attribute.pipe";
14
- /**
15
- * This component should be added on to any screen that displays a container with COD content. This container
16
- * represents the one of the containers, which in turn contain attributes which display those values in the
17
- * attributeValueSet.
18
- */
19
- export class AttributeContainerComponent {
20
- constructor(attributeService, elementRef, renderer, changeDetectorRef, modalService) {
21
- this.attributeService = attributeService;
22
- this.elementRef = elementRef;
23
- this.renderer = renderer;
24
- this.changeDetectorRef = changeDetectorRef;
25
- this.modalService = modalService;
26
- this.classList = "hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1";
27
- this.editInline = true;
28
- this.editPopup = false;
29
- this.editable = true;
30
- this.windowDimension = {};
31
- this.subscriptions = new Subscription();
32
- this.getBusySubjects = () => {
33
- let subjects = [];
34
- //subjects.push(this.attributeService.getAttributeConfigurationLoadingSubject());
35
- subjects.push(this.attributeService.getLoadingSubject());
36
- return subjects;
37
- };
38
- }
39
- /**
40
- * Upon init, subscribe to the configuration and value set.
41
- */
42
- ngOnInit() {
43
- if (!this.editable) {
44
- this.editInline = false;
45
- this.editPopup = false;
46
- }
47
- this.attributeService.setAttributeConfigurationById(this.idAttributeConfiguration, this.idAttributeValueSet, this.idParentObject);
48
- this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration) => {
49
- if (attributeConfiguration) {
50
- this.attributeConfiguration = attributeConfiguration;
51
- if (this.idAttributeContainer !== undefined) {
52
- this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);
53
- }
54
- if (this.indexOfContainer !== undefined) {
55
- if (this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {
56
- this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];
57
- }
58
- }
59
- }
60
- }));
61
- this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension) => {
62
- if (windowDimension) {
63
- this.windowDimension = windowDimension;
64
- }
65
- }));
66
- this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet) => {
67
- this.attributeValueSet = attributeValueSet;
68
- if (this.attributeValueSet) {
69
- this.attributeService.notifyAttributes();
70
- }
71
- }));
72
- }
73
- set boundData(value) {
74
- this.attributeService.setBoundData(value);
75
- }
76
- ngOnDestroy() {
77
- this.subscriptions.unsubscribe();
78
- }
79
- ngOnChanges(changes) {
80
- if (!this.editable) {
81
- this.editInline = false;
82
- this.editPopup = false;
83
- }
84
- if (changes.idAttributeContainer) {
85
- this.idAttributeContainer = changes.idAttributeContainer.currentValue;
86
- this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);
87
- }
88
- if (changes.indexOfContainer) {
89
- this.indexOfContainer = changes.indexOfContainer.currentValue;
90
- if (this.attributeConfiguration && this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {
91
- this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];
92
- }
93
- }
94
- }
95
- getAttributeService() {
96
- return this.attributeService;
97
- }
98
- edit(modal, editContainer) {
99
- this.editContainer = editContainer;
100
- this.modalService.open(modal, { windowClass: "modal-lg" }).result.then((result) => {
101
- if (result === "Save") {
102
- this.attributeService.updateAttributeValueSet();
103
- }
104
- else if (result === "Cancel") {
105
- this.attributeService.clearUpdatedAttributeValues();
106
- }
107
- }, (reason) => { });
108
- }
109
- post() {
110
- this.attributeService.updateAttributeValueSet();
111
- }
112
- getAttributeContainerById(idAttributeContainer) {
113
- if (this.attributeConfiguration) {
114
- return this.attributeConfiguration.attributeContainers.find(x => x.idAttributeContainer === idAttributeContainer);
115
- }
116
- }
117
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeContainerComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
118
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AttributeContainerComponent, selector: "hci-attribute-container", inputs: { idAttributeValueSet: "idAttributeValueSet", idAttributeConfiguration: "idAttributeConfiguration", idAttributeContainer: "idAttributeContainer", indexOfContainer: "indexOfContainer", idParentObject: "idParentObject", attributeContainer: "attributeContainer", attributeConfiguration: "attributeConfiguration", attributeValueSet: "attributeValueSet", editInline: "editInline", editPopup: "editPopup", editable: "editable", boundData: "boundData" }, host: { properties: { "class": "this.classList" } }, usesOnChanges: true, ngImport: i0, template: `
1
+ import { ChangeDetectorRef, Component, ElementRef, Input, Renderer2, HostBinding } from "@angular/core";
2
+ import { Subscription } from "rxjs";
3
+ import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
4
+ import { AttributeService } from "../services/attribute.service";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../services/attribute.service";
7
+ import * as i2 from "@ng-bootstrap/ng-bootstrap";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "@huntsman-cancer-institute/misc";
10
+ import * as i5 from "./attribute-absolute.component";
11
+ import * as i6 from "./attribute-flex.component";
12
+ import * as i7 from "./attribute-edit.component";
13
+ import * as i8 from "../pipes/is-group-attribute.pipe";
14
+ /**
15
+ * This component should be added on to any screen that displays a container with COD content. This container
16
+ * represents the one of the containers, which in turn contain attributes which display those values in the
17
+ * attributeValueSet.
18
+ */
19
+ export class AttributeContainerComponent {
20
+ constructor(attributeService, elementRef, renderer, changeDetectorRef, modalService) {
21
+ this.attributeService = attributeService;
22
+ this.elementRef = elementRef;
23
+ this.renderer = renderer;
24
+ this.changeDetectorRef = changeDetectorRef;
25
+ this.modalService = modalService;
26
+ this.classList = "hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1";
27
+ this.editInline = true;
28
+ this.editPopup = false;
29
+ this.editable = true;
30
+ this.windowDimension = {};
31
+ this.subscriptions = new Subscription();
32
+ this.getBusySubjects = () => {
33
+ let subjects = [];
34
+ //subjects.push(this.attributeService.getAttributeConfigurationLoadingSubject());
35
+ subjects.push(this.attributeService.getLoadingSubject());
36
+ return subjects;
37
+ };
38
+ }
39
+ /**
40
+ * Upon init, subscribe to the configuration and value set.
41
+ */
42
+ ngOnInit() {
43
+ if (!this.editable) {
44
+ this.editInline = false;
45
+ this.editPopup = false;
46
+ }
47
+ this.attributeService.setAttributeConfigurationById(this.idAttributeConfiguration, this.idAttributeValueSet, this.idParentObject);
48
+ this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration) => {
49
+ if (attributeConfiguration) {
50
+ this.attributeConfiguration = attributeConfiguration;
51
+ if (this.idAttributeContainer !== undefined) {
52
+ this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);
53
+ }
54
+ if (this.indexOfContainer !== undefined) {
55
+ if (this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {
56
+ this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];
57
+ }
58
+ }
59
+ }
60
+ }));
61
+ this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension) => {
62
+ if (windowDimension) {
63
+ this.windowDimension = windowDimension;
64
+ }
65
+ }));
66
+ this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet) => {
67
+ this.attributeValueSet = attributeValueSet;
68
+ if (this.attributeValueSet) {
69
+ this.attributeService.notifyAttributes();
70
+ }
71
+ }));
72
+ }
73
+ set boundData(value) {
74
+ this.attributeService.setBoundData(value);
75
+ }
76
+ ngOnDestroy() {
77
+ this.subscriptions.unsubscribe();
78
+ }
79
+ ngOnChanges(changes) {
80
+ if (!this.editable) {
81
+ this.editInline = false;
82
+ this.editPopup = false;
83
+ }
84
+ if (changes.idAttributeContainer) {
85
+ this.idAttributeContainer = changes.idAttributeContainer.currentValue;
86
+ this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);
87
+ }
88
+ if (changes.indexOfContainer) {
89
+ this.indexOfContainer = changes.indexOfContainer.currentValue;
90
+ if (this.attributeConfiguration && this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {
91
+ this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];
92
+ }
93
+ }
94
+ }
95
+ getAttributeService() {
96
+ return this.attributeService;
97
+ }
98
+ edit(modal, editContainer) {
99
+ this.editContainer = editContainer;
100
+ this.modalService.open(modal, { windowClass: "modal-lg" }).result.then((result) => {
101
+ if (result === "Save") {
102
+ this.attributeService.updateAttributeValueSet();
103
+ }
104
+ else if (result === "Cancel") {
105
+ this.attributeService.clearUpdatedAttributeValues();
106
+ }
107
+ }, (reason) => { });
108
+ }
109
+ post() {
110
+ this.attributeService.updateAttributeValueSet();
111
+ }
112
+ getAttributeContainerById(idAttributeContainer) {
113
+ if (this.attributeConfiguration) {
114
+ return this.attributeConfiguration.attributeContainers.find(x => x.idAttributeContainer === idAttributeContainer);
115
+ }
116
+ }
117
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeContainerComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
118
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AttributeContainerComponent, selector: "hci-attribute-container", inputs: { idAttributeValueSet: "idAttributeValueSet", idAttributeConfiguration: "idAttributeConfiguration", idAttributeContainer: "idAttributeContainer", indexOfContainer: "indexOfContainer", idParentObject: "idParentObject", attributeContainer: "attributeContainer", attributeConfiguration: "attributeConfiguration", attributeValueSet: "attributeValueSet", editInline: "editInline", editPopup: "editPopup", editable: "editable", boundData: "boundData" }, host: { properties: { "class": "this.classList" } }, usesOnChanges: true, ngImport: i0, template: `
119
119
  <hci-busy [getBusySubjects]="getBusySubjects"></hci-busy>
120
120
 
121
121
  <ng-container *ngIf="attributeContainer">
@@ -167,12 +167,12 @@ export class AttributeContainerComponent {
167
167
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
168
168
  </div>
169
169
  </ng-template>
170
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.BusyComponent, selector: "hci-busy", inputs: ["busy", "busySubjects", "getBusySubjects", "parentSelector", "rootClass", "icon", "iconSize", "showIcon", "mxAuto", "myAuto", "text", "template", "config"] }, { kind: "component", type: i5.AttributeAbsoluteComponent, selector: "hci-attribute-absolute" }, { kind: "component", type: i6.AttributeFlexComponent, selector: "hci-attribute-flex" }, { kind: "component", type: i7.AttributeEditComponent, selector: "hci-attribute-edit" }, { kind: "pipe", type: i8.IsGroupAttributePipe, name: "isGroupAttribute" }] }); }
171
- }
172
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeContainerComponent, decorators: [{
173
- type: Component,
174
- args: [{
175
- selector: "hci-attribute-container",
170
+ `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.BusyComponent, selector: "hci-busy", inputs: ["busy", "busySubjects", "getBusySubjects", "parentSelector", "rootClass", "icon", "iconSize", "showIcon", "mxAuto", "myAuto", "text", "template", "config"] }, { kind: "component", type: i5.AttributeAbsoluteComponent, selector: "hci-attribute-absolute" }, { kind: "component", type: i6.AttributeFlexComponent, selector: "hci-attribute-flex" }, { kind: "component", type: i7.AttributeEditComponent, selector: "hci-attribute-edit" }, { kind: "pipe", type: i8.IsGroupAttributePipe, name: "isGroupAttribute" }] }); }
171
+ }
172
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeContainerComponent, decorators: [{
173
+ type: Component,
174
+ args: [{
175
+ selector: "hci-attribute-container",
176
176
  template: `
177
177
  <hci-busy [getBusySubjects]="getBusySubjects"></hci-busy>
178
178
 
@@ -225,34 +225,34 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
225
225
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
226
226
  </div>
227
227
  </ng-template>
228
- `
229
- }]
230
- }], ctorParameters: function () { return [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.NgbModal }]; }, propDecorators: { classList: [{
231
- type: HostBinding,
232
- args: ["class"]
233
- }], idAttributeValueSet: [{
234
- type: Input
235
- }], idAttributeConfiguration: [{
236
- type: Input
237
- }], idAttributeContainer: [{
238
- type: Input
239
- }], indexOfContainer: [{
240
- type: Input
241
- }], idParentObject: [{
242
- type: Input
243
- }], attributeContainer: [{
244
- type: Input
245
- }], attributeConfiguration: [{
246
- type: Input
247
- }], attributeValueSet: [{
248
- type: Input
249
- }], editInline: [{
250
- type: Input
251
- }], editPopup: [{
252
- type: Input
253
- }], editable: [{
254
- type: Input
255
- }], boundData: [{
256
- type: Input
257
- }] } });
258
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-container.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, isDevMode,\r\n  QueryList, Renderer2, ViewChildren, SimpleChanges, HostBinding, TemplateRef\r\n} from \"@angular/core\";\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport {NgbModal, NgbPanel} from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {AccordionNavComponent} from \"@huntsman-cancer-institute/misc\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {AttributeConfiguration} from \"../model/attribute-configuration.entity\";\r\nimport {AttributeValueSet} from \"../model/attribute-value-set.entity\";\r\nimport {AttributeContainer} from \"../model/attribute-container.entity\";\r\n\r\n/**\r\n * This component should be added on to any screen that displays a container with COD content.  This container\r\n * represents the one of the containers, which in turn contain attributes which display those values in the\r\n * attributeValueSet.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-container\",\r\n  template: `\r\n    <hci-busy [getBusySubjects]=\"getBusySubjects\"></hci-busy>\r\n  \r\n    <ng-container *ngIf=\"attributeContainer\">\r\n      <div *ngIf=\"editPopup\" [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'\"\r\n           class=\"d-flex attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}\">\r\n        <div class=\"ml-auto mr-0\" (click)=\"edit(editModal, attributeContainer)\">\r\n          <i class=\"fas fa-pencil\"></i>\r\n        </div>\r\n      </div>\r\n      <div class=\"d-flex flex-grow-1 y-auto\" style=\"flex: 1 1 1px;\">\r\n        <div class=\"attribute-container\"\r\n             [class.col-md-12]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.flex]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.flex-wrap]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.absolute]=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\">\r\n          <ng-container *ngFor=\"let attribute of attributeContainer.graphicalAttributes | isGroupAttribute: false\">\r\n            <ng-container *ngIf=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y' && attribute.codeAttributeDataType !== 'LINE'\">\r\n              <hci-attribute-flex [id]=\"'id-attribute-' + attribute.idAttribute\"\r\n                                  [attribute]=\"attribute\"\r\n                                  [editInline]=\"editInline\"\r\n                                  [class.attribute]=\"true\"\r\n                                  [class.col-4]=\"attribute.codeAttributeDataType !== 'GA' && attribute.codeAttributeDataType !== 'LINE'\"\r\n                                  [class.col-12]=\"attribute.codeAttributeDataType === 'GA' || attribute.codeAttributeDataType === 'LINE'\"></hci-attribute-flex>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\">\r\n              <hci-attribute-absolute [id]=\"'id-attribute-' + attribute.idAttribute\"\r\n                                      [attribute]=\"attribute\"\r\n                                      [editInline]=\"editInline\"\r\n                                      [class.attribute]=\"true\"></hci-attribute-absolute>\r\n            </ng-container>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <ng-template #editModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{editContainer.containerName}}\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editContainer.graphicalAttributes | isGroupAttribute: false\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n        <button class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n        <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n})\r\nexport class AttributeContainerComponent {\r\n  @HostBinding(\"class\") classList: string = \"hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1\";\r\n\r\n  @Input() idAttributeValueSet: number;\r\n  @Input() idAttributeConfiguration: number;\r\n  @Input() idAttributeContainer: number;\r\n  @Input() indexOfContainer: number;\r\n  @Input() idParentObject: number;\r\n\r\n  @Input() attributeContainer: AttributeContainer;\r\n  @Input() attributeConfiguration: AttributeConfiguration;\r\n  @Input() attributeValueSet: AttributeValueSet;\r\n  \r\n  @Input() editInline: boolean = true;\r\n  @Input() editPopup: boolean =  false;\r\n  @Input() editable: boolean = true;\r\n\r\n  editContainer: AttributeContainer;\r\n\r\n  windowDimension: any = {};\r\n\r\n  subscriptions: Subscription = new Subscription();\r\n  \r\n  getBusySubjects: Function = () => {\r\n    let subjects: any[] = [];\r\n  \r\n    //subjects.push(this.attributeService.getAttributeConfigurationLoadingSubject());\r\n    subjects.push(this.attributeService.getLoadingSubject());\r\n    \r\n    return subjects;\r\n  };\r\n\r\n  constructor(private attributeService: AttributeService,\r\n              private elementRef: ElementRef,\r\n              private renderer: Renderer2,\r\n              private changeDetectorRef: ChangeDetectorRef,\r\n              private modalService: NgbModal) {}\r\n\r\n  /**\r\n   * Upon init, subscribe to the configuration and value set.\r\n   */\r\n  ngOnInit() {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    this.attributeService.setAttributeConfigurationById(this.idAttributeConfiguration, this.idAttributeValueSet, this.idParentObject);\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration: AttributeConfiguration) => {\r\n      if(attributeConfiguration) {\r\n        this.attributeConfiguration = attributeConfiguration;\r\n\r\n        if (this.idAttributeContainer !== undefined) {\r\n          this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);\r\n        }\r\n\r\n        if (this.indexOfContainer !== undefined) {\r\n          if (this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {\r\n            this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];\r\n          }\r\n        }\r\n      }\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension: any) => {\r\n      if(windowDimension){\r\n        this.windowDimension = windowDimension;\r\n      }\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet: AttributeValueSet) => {\r\n      this.attributeValueSet = attributeValueSet;\r\n\r\n      if (this.attributeValueSet) {\r\n        this.attributeService.notifyAttributes();\r\n      }\r\n    }));\r\n  }\r\n\r\n  @Input() set boundData(value: any) {\r\n    this.attributeService.setBoundData(value);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    if (changes.idAttributeContainer) {\r\n      this.idAttributeContainer = changes.idAttributeContainer.currentValue;\r\n\r\n      this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);\r\n    }\r\n\r\n    if (changes.indexOfContainer) {\r\n      this.indexOfContainer = changes.indexOfContainer.currentValue;\r\n      if (this.attributeConfiguration && this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {\r\n        this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];\r\n      }\r\n    }\r\n  }\r\n\r\n  getAttributeService(): AttributeService {\r\n    return this.attributeService;\r\n  }\r\n\r\n  edit(modal: TemplateRef<any>, editContainer: AttributeContainer): void {\r\n    this.editContainer = editContainer;\r\n\r\n    this.modalService.open(modal, {windowClass: \"modal-lg\"}).result.then((result) => {\r\n      if (result === \"Save\") {\r\n        this.attributeService.updateAttributeValueSet();\r\n      } else if (result === \"Cancel\") {\r\n        this.attributeService.clearUpdatedAttributeValues();\r\n      }\r\n    }, (reason) => {});\r\n  }\r\n\r\n  post(): void {\r\n    this.attributeService.updateAttributeValueSet();\r\n  }\r\n\r\n  getAttributeContainerById(idAttributeContainer: number): AttributeContainer {\r\n    if (this.attributeConfiguration) {\r\n      return this.attributeConfiguration.attributeContainers.find(x => x.idAttributeContainer === idAttributeContainer);\r\n    }\r\n  }\r\n}\r\n"]}
228
+ `
229
+ }]
230
+ }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.NgbModal }], propDecorators: { classList: [{
231
+ type: HostBinding,
232
+ args: ["class"]
233
+ }], idAttributeValueSet: [{
234
+ type: Input
235
+ }], idAttributeConfiguration: [{
236
+ type: Input
237
+ }], idAttributeContainer: [{
238
+ type: Input
239
+ }], indexOfContainer: [{
240
+ type: Input
241
+ }], idParentObject: [{
242
+ type: Input
243
+ }], attributeContainer: [{
244
+ type: Input
245
+ }], attributeConfiguration: [{
246
+ type: Input
247
+ }], attributeValueSet: [{
248
+ type: Input
249
+ }], editInline: [{
250
+ type: Input
251
+ }], editPopup: [{
252
+ type: Input
253
+ }], editable: [{
254
+ type: Input
255
+ }], boundData: [{
256
+ type: Input
257
+ }] } });
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-container.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, isDevMode,\r\n  QueryList, Renderer2, ViewChildren, SimpleChanges, HostBinding, TemplateRef\r\n} from \"@angular/core\";\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport {NgbModal, NgbPanel} from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {AccordionNavComponent} from \"@huntsman-cancer-institute/misc\";\r\nimport {AttributeService} from \"../services/attribute.service\";\r\nimport {AttributeConfiguration} from \"../model/attribute-configuration.entity\";\r\nimport {AttributeValueSet} from \"../model/attribute-value-set.entity\";\r\nimport {AttributeContainer} from \"../model/attribute-container.entity\";\r\n\r\n/**\r\n * This component should be added on to any screen that displays a container with COD content.  This container\r\n * represents the one of the containers, which in turn contain attributes which display those values in the\r\n * attributeValueSet.\r\n */\r\n@Component({\r\n  selector: \"hci-attribute-container\",\r\n  template: `\r\n    <hci-busy [getBusySubjects]=\"getBusySubjects\"></hci-busy>\r\n  \r\n    <ng-container *ngIf=\"attributeContainer\">\r\n      <div *ngIf=\"editPopup\" [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'\"\r\n           class=\"d-flex attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}\">\r\n        <div class=\"ml-auto mr-0\" (click)=\"edit(editModal, attributeContainer)\">\r\n          <i class=\"fas fa-pencil\"></i>\r\n        </div>\r\n      </div>\r\n      <div class=\"d-flex flex-grow-1 y-auto\" style=\"flex: 1 1 1px;\">\r\n        <div class=\"attribute-container\"\r\n             [class.col-md-12]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.flex]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.flex-wrap]=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y'\"\r\n             [class.absolute]=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\">\r\n          <ng-container *ngFor=\"let attribute of attributeContainer.graphicalAttributes | isGroupAttribute: false\">\r\n            <ng-container *ngIf=\"attributeContainer.isAutoLayout && attributeContainer.isAutoLayout === 'Y' && attribute.codeAttributeDataType !== 'LINE'\">\r\n              <hci-attribute-flex [id]=\"'id-attribute-' + attribute.idAttribute\"\r\n                                  [attribute]=\"attribute\"\r\n                                  [editInline]=\"editInline\"\r\n                                  [class.attribute]=\"true\"\r\n                                  [class.col-4]=\"attribute.codeAttributeDataType !== 'GA' && attribute.codeAttributeDataType !== 'LINE'\"\r\n                                  [class.col-12]=\"attribute.codeAttributeDataType === 'GA' || attribute.codeAttributeDataType === 'LINE'\"></hci-attribute-flex>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\">\r\n              <hci-attribute-absolute [id]=\"'id-attribute-' + attribute.idAttribute\"\r\n                                      [attribute]=\"attribute\"\r\n                                      [editInline]=\"editInline\"\r\n                                      [class.attribute]=\"true\"></hci-attribute-absolute>\r\n            </ng-container>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <ng-template #editModal let-close=\"close\">\r\n      <div class=\"modal-header\">\r\n        {{editContainer.containerName}}\r\n      </div>\r\n      <div class=\"modal-body d-flex flex-column hci-cod-edit\">\r\n        <ng-container *ngFor=\"let attribute of editContainer.graphicalAttributes | isGroupAttribute: false\">\r\n          <hci-attribute-edit [id]=\"'edit-id-attribute-' + attribute.idAttribute\"\r\n                              [attribute]=\"attribute\"\r\n                              class=\"attribute\"></hci-attribute-edit>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"modal-footer\">\r\n        <button class=\"btn btn-primary\" (click)=\"close('Save')\">Save</button>\r\n        <button class=\"btn btn-primary\" (click)=\"close('Cancel')\">Cancel</button>\r\n      </div>\r\n    </ng-template>\r\n  `\r\n})\r\nexport class AttributeContainerComponent {\r\n  @HostBinding(\"class\") classList: string = \"hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1\";\r\n\r\n  @Input() idAttributeValueSet: number;\r\n  @Input() idAttributeConfiguration: number;\r\n  @Input() idAttributeContainer: number;\r\n  @Input() indexOfContainer: number;\r\n  @Input() idParentObject: number;\r\n\r\n  @Input() attributeContainer: AttributeContainer;\r\n  @Input() attributeConfiguration: AttributeConfiguration;\r\n  @Input() attributeValueSet: AttributeValueSet;\r\n  \r\n  @Input() editInline: boolean = true;\r\n  @Input() editPopup: boolean =  false;\r\n  @Input() editable: boolean = true;\r\n\r\n  editContainer: AttributeContainer;\r\n\r\n  windowDimension: any = {};\r\n\r\n  subscriptions: Subscription = new Subscription();\r\n  \r\n  getBusySubjects: Function = () => {\r\n    let subjects: any[] = [];\r\n  \r\n    //subjects.push(this.attributeService.getAttributeConfigurationLoadingSubject());\r\n    subjects.push(this.attributeService.getLoadingSubject());\r\n    \r\n    return subjects;\r\n  };\r\n\r\n  constructor(private attributeService: AttributeService,\r\n              private elementRef: ElementRef,\r\n              private renderer: Renderer2,\r\n              private changeDetectorRef: ChangeDetectorRef,\r\n              private modalService: NgbModal) {}\r\n\r\n  /**\r\n   * Upon init, subscribe to the configuration and value set.\r\n   */\r\n  ngOnInit() {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    this.attributeService.setAttributeConfigurationById(this.idAttributeConfiguration, this.idAttributeValueSet, this.idParentObject);\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration: AttributeConfiguration) => {\r\n      if(attributeConfiguration) {\r\n        this.attributeConfiguration = attributeConfiguration;\r\n\r\n        if (this.idAttributeContainer !== undefined) {\r\n          this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);\r\n        }\r\n\r\n        if (this.indexOfContainer !== undefined) {\r\n          if (this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {\r\n            this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];\r\n          }\r\n        }\r\n      }\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension: any) => {\r\n      if(windowDimension){\r\n        this.windowDimension = windowDimension;\r\n      }\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet: AttributeValueSet) => {\r\n      this.attributeValueSet = attributeValueSet;\r\n\r\n      if (this.attributeValueSet) {\r\n        this.attributeService.notifyAttributes();\r\n      }\r\n    }));\r\n  }\r\n\r\n  @Input() set boundData(value: any) {\r\n    this.attributeService.setBoundData(value);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    if (changes.idAttributeContainer) {\r\n      this.idAttributeContainer = changes.idAttributeContainer.currentValue;\r\n\r\n      this.attributeContainer = this.getAttributeContainerById(this.idAttributeContainer);\r\n    }\r\n\r\n    if (changes.indexOfContainer) {\r\n      this.indexOfContainer = changes.indexOfContainer.currentValue;\r\n      if (this.attributeConfiguration && this.attributeConfiguration.attributeContainers[this.indexOfContainer]) {\r\n        this.attributeContainer = this.attributeConfiguration.attributeContainers[this.indexOfContainer];\r\n      }\r\n    }\r\n  }\r\n\r\n  getAttributeService(): AttributeService {\r\n    return this.attributeService;\r\n  }\r\n\r\n  edit(modal: TemplateRef<any>, editContainer: AttributeContainer): void {\r\n    this.editContainer = editContainer;\r\n\r\n    this.modalService.open(modal, {windowClass: \"modal-lg\"}).result.then((result) => {\r\n      if (result === \"Save\") {\r\n        this.attributeService.updateAttributeValueSet();\r\n      } else if (result === \"Cancel\") {\r\n        this.attributeService.clearUpdatedAttributeValues();\r\n      }\r\n    }, (reason) => {});\r\n  }\r\n\r\n  post(): void {\r\n    this.attributeService.updateAttributeValueSet();\r\n  }\r\n\r\n  getAttributeContainerById(idAttributeContainer: number): AttributeContainer {\r\n    if (this.attributeConfiguration) {\r\n      return this.attributeConfiguration.attributeContainers.find(x => x.idAttributeContainer === idAttributeContainer);\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,43 +1,43 @@
1
- import { Component, forwardRef, Input } from "@angular/core";
2
- import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "@huntsman-cancer-institute/input";
7
- export class AttributeDefaultComponent {
8
- get value() {
9
- return this._value;
10
- }
11
- ;
12
- set value(v) {
13
- this.onTouched();
14
- if (v !== this.value) {
15
- this._value = v;
16
- this.onChange(v);
17
- }
18
- }
19
- constructor() {
20
- this._value = "";
21
- this.onChange = (_) => { };
22
- this.onTouched = () => { };
23
- }
24
- ngOnInit() { }
25
- writeValue(v) {
26
- this._value = v;
27
- }
28
- registerOnChange(fn) {
29
- this.onChange = fn;
30
- }
31
- registerOnTouched(fn) {
32
- this.onTouched = fn;
33
- }
34
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeDefaultComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
35
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AttributeDefaultComponent, selector: "hci-attribute-default", inputs: { id: "id", name: "name", attribute: "attribute" }, providers: [
36
- {
37
- provide: NG_VALUE_ACCESSOR,
38
- useExisting: forwardRef(() => AttributeDefaultComponent),
39
- multi: true
40
- }
1
+ import { Component, forwardRef, Input } from "@angular/core";
2
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/forms";
6
+ import * as i3 from "@huntsman-cancer-institute/input";
7
+ export class AttributeDefaultComponent {
8
+ get value() {
9
+ return this._value;
10
+ }
11
+ ;
12
+ set value(v) {
13
+ this.onTouched();
14
+ if (v !== this.value) {
15
+ this._value = v;
16
+ this.onChange(v);
17
+ }
18
+ }
19
+ constructor() {
20
+ this._value = "";
21
+ this.onChange = (_) => { };
22
+ this.onTouched = () => { };
23
+ }
24
+ ngOnInit() { }
25
+ writeValue(v) {
26
+ this._value = v;
27
+ }
28
+ registerOnChange(fn) {
29
+ this.onChange = fn;
30
+ }
31
+ registerOnTouched(fn) {
32
+ this.onTouched = fn;
33
+ }
34
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeDefaultComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
35
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AttributeDefaultComponent, selector: "hci-attribute-default", inputs: { id: "id", name: "name", attribute: "attribute" }, providers: [
36
+ {
37
+ provide: NG_VALUE_ACCESSOR,
38
+ useExisting: forwardRef(() => AttributeDefaultComponent),
39
+ multi: true
40
+ }
41
41
  ], ngImport: i0, template: `
42
42
  <!-- String -->
43
43
  <ng-container *ngIf="attribute.codeAttributeDataType.toUpperCase() === 'S'">
@@ -169,12 +169,12 @@ export class AttributeDefaultComponent {
169
169
  [name]="name"
170
170
  disabled>
171
171
  </ng-container>
172
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.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: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.NativeSelectComponent, selector: "hci-native-select", inputs: ["class", "name", "label", "url", "entries", "required", "idKey", "displayKey", "disabled", "sortKey", "sortNumeric", "filterKey", "filter"] }] }); }
173
- }
174
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeDefaultComponent, decorators: [{
175
- type: Component,
176
- args: [{
177
- selector: "hci-attribute-default",
172
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.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: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.NativeSelectComponent, selector: "hci-native-select", inputs: ["class", "name", "label", "url", "entries", "required", "idKey", "displayKey", "disabled", "sortKey", "sortNumeric", "filterKey", "filter"] }] }); }
173
+ }
174
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeDefaultComponent, decorators: [{
175
+ type: Component,
176
+ args: [{
177
+ selector: "hci-attribute-default",
178
178
  template: `
179
179
  <!-- String -->
180
180
  <ng-container *ngIf="attribute.codeAttributeDataType.toUpperCase() === 'S'">
@@ -306,20 +306,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
306
306
  [name]="name"
307
307
  disabled>
308
308
  </ng-container>
309
- `,
310
- providers: [
311
- {
312
- provide: NG_VALUE_ACCESSOR,
313
- useExisting: forwardRef(() => AttributeDefaultComponent),
314
- multi: true
315
- }
316
- ]
317
- }]
318
- }], ctorParameters: function () { return []; }, propDecorators: { id: [{
319
- type: Input
320
- }], name: [{
321
- type: Input
322
- }], attribute: [{
323
- type: Input
324
- }] } });
325
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-default.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-default.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;;;;;AAkJvE,MAAM,OAAO,yBAAyB;IAWpC,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAAA,CAAC;IAEF,IAAI,KAAK,CAAC,CAAS;QACjB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;YACpB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;SAClB;IACH,CAAC;IAED;QArBA,WAAM,GAAW,EAAE,CAAC;QAMpB,aAAQ,GAAQ,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC/B,cAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAcX,CAAC;IAEhB,QAAQ,KAAU,CAAC;IAEnB,UAAU,CAAC,CAAS;QAClB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;+GArCU,yBAAyB;mGAAzB,yBAAyB,4GARzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;gBACxD,KAAK,EAAE,IAAI;aACZ;SACF,0BA1IS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmIT;;4FASU,yBAAyB;kBA9IrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmIT;oBACD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;4BACxD,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF;0EAKU,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import {Component, forwardRef, Input} from \"@angular/core\";\r\n\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\n\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n@Component({\r\n  selector: \"hci-attribute-default\",\r\n  template: `\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'S'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'TXT'\">\r\n      <textarea type=\"text\"\r\n                class=\"form-control\"\r\n                [id]=\"id\"\r\n                [name]=\"name\"\r\n                spellcheck=\"spellcheck\"\r\n                lang=\"en\"\r\n                [(ngModel)]=\"value\">\r\n      </textarea>\r\n    </ng-container>\r\n\r\n    <!-- Checkbox -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'CB'\">\r\n      <input type=\"checkbox\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\"\r\n             [checked]=\"value && value.toUpperCase() === 'Y'\">\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'N'\">\r\n      <input type=\"number\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'I'\">\r\n      <input type=\"number\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'D'\">\r\n      <input type=\"date\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'DT'\">\r\n      <input type=\"date\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'B'\">\r\n      <select [(ngModel)]=\"value\"\r\n             class=\"form-control edit-renderer\"\r\n             [id]=\"id\"\r\n             [name]=\"name\">\r\n        <option [ngValue]=\"'Y'\" [selected]=\"value && value.toUpperCase() === 'Y'\">Y</option>\r\n        <option [ngValue]=\"'N'\" [selected]=\"value && value.toUpperCase() === 'N'\">N</option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Extended Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'EB'\">\r\n      <select [(ngModel)]=\"value\"\r\n              class=\"form-control edit-renderer\"\r\n              [id]=\"id\"\r\n              [name]=\"name\">\r\n        <option [ngValue]=\"'Y'\" [selected]=\"value && value.toUpperCase() === 'Y'\">Y</option>\r\n        <option [ngValue]=\"'N'\" [selected]=\"value && value.toUpperCase() === 'N'\">N</option>\r\n        <option [ngValue]=\"'U'\" [selected]=\"value && value.toUpperCase() === 'U'\">U</option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'AC' && attribute.isMultiValue.toUpperCase() === 'N'\">\r\n      <select [(ngModel)]=\"value\"\r\n              class=\"form-control edit-renderer\"\r\n              [id]=\"id\"\r\n              [name]=\"name\">\r\n        <option *ngFor=\"let attributeChoice of attribute.attributeChoices\"\r\n                [ngValue]=\"attributeChoice\"\r\n                [selected]=\"value && value.toUpperCase() === attributeChoice.idAttributeChoice.toString().toUpperCase()\">\r\n          {{ attributeChoice.choice }}\r\n        </option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'AC' && attribute.isMultiValue.toUpperCase() === 'Y'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             disabled>\r\n    </ng-container>\r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'DICT'\">\r\n      <hci-native-select [(ngModel)]=\"value\"\r\n                         [className]=\"attribute.attributeDictionary.className\"\r\n                         [id]=\"id\"\r\n                         [name]=\"name\">\r\n      </hci-native-select>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'GA'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             disabled>\r\n    </ng-container>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttributeDefaultComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class AttributeDefaultComponent implements ControlValueAccessor {\r\n\r\n  _value: string = \"\";\r\n\r\n  @Input() id: string;\r\n  @Input() name: string;\r\n  @Input() attribute: GraphicalAttribute;\r\n\r\n  onChange: any = (_: any) => {};\r\n  onTouched: any = () => {};\r\n\r\n  get value(): string {\r\n    return this._value;\r\n  };\r\n\r\n  set value(v: string) {\r\n    this.onTouched();\r\n    if (v !== this.value) {\r\n      this._value = v;\r\n      this.onChange(v);\r\n    }\r\n  }\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  writeValue(v: string) {\r\n    this._value = v;\r\n  }\r\n\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n}\r\n"]}
309
+ `,
310
+ providers: [
311
+ {
312
+ provide: NG_VALUE_ACCESSOR,
313
+ useExisting: forwardRef(() => AttributeDefaultComponent),
314
+ multi: true
315
+ }
316
+ ]
317
+ }]
318
+ }], ctorParameters: () => [], propDecorators: { id: [{
319
+ type: Input
320
+ }], name: [{
321
+ type: Input
322
+ }], attribute: [{
323
+ type: Input
324
+ }] } });
325
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-default.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-default.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;;;;;AAkJvE,MAAM,OAAO,yBAAyB;IAWpC,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAAA,CAAC;IAEF,IAAI,KAAK,CAAC,CAAS;QACjB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAED;QArBA,WAAM,GAAW,EAAE,CAAC;QAMpB,aAAQ,GAAQ,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC/B,cAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAcX,CAAC;IAEhB,QAAQ,KAAU,CAAC;IAEnB,UAAU,CAAC,CAAS;QAClB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;8GArCU,yBAAyB;kGAAzB,yBAAyB,4GARzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;gBACxD,KAAK,EAAE,IAAI;aACZ;SACF,0BA1IS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmIT;;2FASU,yBAAyB;kBA9IrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmIT;oBACD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;4BACxD,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF;wDAKU,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import {Component, forwardRef, Input} from \"@angular/core\";\r\n\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\n\r\nimport {GraphicalAttribute} from \"../model/graphical-attribute.entity\";\r\n\r\n@Component({\r\n  selector: \"hci-attribute-default\",\r\n  template: `\r\n    <!-- String -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'S'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Text -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'TXT'\">\r\n      <textarea type=\"text\"\r\n                class=\"form-control\"\r\n                [id]=\"id\"\r\n                [name]=\"name\"\r\n                spellcheck=\"spellcheck\"\r\n                lang=\"en\"\r\n                [(ngModel)]=\"value\">\r\n      </textarea>\r\n    </ng-container>\r\n\r\n    <!-- Checkbox -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'CB'\">\r\n      <input type=\"checkbox\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\"\r\n             [checked]=\"value && value.toUpperCase() === 'Y'\">\r\n    </ng-container>\r\n\r\n    <!-- Numeric -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'N'\">\r\n      <input type=\"number\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Integer -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'I'\">\r\n      <input type=\"number\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Date -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'D'\">\r\n      <input type=\"date\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Date Time -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'DT'\">\r\n      <input type=\"date\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             [(ngModel)]=\"value\">\r\n    </ng-container>\r\n\r\n    <!-- Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'B'\">\r\n      <select [(ngModel)]=\"value\"\r\n             class=\"form-control edit-renderer\"\r\n             [id]=\"id\"\r\n             [name]=\"name\">\r\n        <option [ngValue]=\"'Y'\" [selected]=\"value && value.toUpperCase() === 'Y'\">Y</option>\r\n        <option [ngValue]=\"'N'\" [selected]=\"value && value.toUpperCase() === 'N'\">N</option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Extended Boolean -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'EB'\">\r\n      <select [(ngModel)]=\"value\"\r\n              class=\"form-control edit-renderer\"\r\n              [id]=\"id\"\r\n              [name]=\"name\">\r\n        <option [ngValue]=\"'Y'\" [selected]=\"value && value.toUpperCase() === 'Y'\">Y</option>\r\n        <option [ngValue]=\"'N'\" [selected]=\"value && value.toUpperCase() === 'N'\">N</option>\r\n        <option [ngValue]=\"'U'\" [selected]=\"value && value.toUpperCase() === 'U'\">U</option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Single -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'AC' && attribute.isMultiValue.toUpperCase() === 'N'\">\r\n      <select [(ngModel)]=\"value\"\r\n              class=\"form-control edit-renderer\"\r\n              [id]=\"id\"\r\n              [name]=\"name\">\r\n        <option *ngFor=\"let attributeChoice of attribute.attributeChoices\"\r\n                [ngValue]=\"attributeChoice\"\r\n                [selected]=\"value && value.toUpperCase() === attributeChoice.idAttributeChoice.toString().toUpperCase()\">\r\n          {{ attributeChoice.choice }}\r\n        </option>\r\n      </select>\r\n    </ng-container>\r\n\r\n    <!-- Choice: Multi -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'AC' && attribute.isMultiValue.toUpperCase() === 'Y'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             disabled>\r\n    </ng-container>\r\n\r\n    <!-- Dictionary -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'DICT'\">\r\n      <hci-native-select [(ngModel)]=\"value\"\r\n                         [className]=\"attribute.attributeDictionary.className\"\r\n                         [id]=\"id\"\r\n                         [name]=\"name\">\r\n      </hci-native-select>\r\n    </ng-container>\r\n\r\n    <!-- Grid -->\r\n    <ng-container *ngIf=\"attribute.codeAttributeDataType.toUpperCase() === 'GA'\">\r\n      <input type=\"text\"\r\n             class=\"form-control\"\r\n             [id]=\"id\"\r\n             [name]=\"name\"\r\n             disabled>\r\n    </ng-container>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttributeDefaultComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class AttributeDefaultComponent implements ControlValueAccessor {\r\n\r\n  _value: string = \"\";\r\n\r\n  @Input() id: string;\r\n  @Input() name: string;\r\n  @Input() attribute: GraphicalAttribute;\r\n\r\n  onChange: any = (_: any) => {};\r\n  onTouched: any = () => {};\r\n\r\n  get value(): string {\r\n    return this._value;\r\n  };\r\n\r\n  set value(v: string) {\r\n    this.onTouched();\r\n    if (v !== this.value) {\r\n      this._value = v;\r\n      this.onChange(v);\r\n    }\r\n  }\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  writeValue(v: string) {\r\n    this._value = v;\r\n  }\r\n\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n}\r\n"]}