@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,105 +1,105 @@
1
- import { ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, QueryList, Renderer2, ViewChild, ViewChildren, HostBinding } from "@angular/core";
2
- import { Subject, Subscription } from "rxjs";
3
- import { NgbAccordion, NgbModal, NgbPanel } from "@ng-bootstrap/ng-bootstrap";
4
- import { AccordionNavComponent } from "@huntsman-cancer-institute/misc";
5
- import { AttributeService } from "../services/attribute.service";
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "../services/attribute.service";
8
- import * as i2 from "@ng-bootstrap/ng-bootstrap";
9
- import * as i3 from "@angular/common";
10
- import * as i4 from "@huntsman-cancer-institute/misc";
11
- import * as i5 from "./attribute-absolute.component";
12
- import * as i6 from "./attribute-flex.component";
13
- import * as i7 from "./attribute-edit.component";
14
- import * as i8 from "../pipes/is-group-attribute.pipe";
15
- /**
16
- * This component should be added on to any screen that displays an entity with an idAttributeValueSet. This configuration
17
- * represents the parent of separate containers, which in turn contain attributes which display those values in the
18
- * attributeValueSet.
19
- */
20
- export class AttributeConfigurationComponent {
21
- constructor(attributeService, elementRef, renderer, changeDetectorRef, modalService) {
22
- this.attributeService = attributeService;
23
- this.elementRef = elementRef;
24
- this.renderer = renderer;
25
- this.changeDetectorRef = changeDetectorRef;
26
- this.modalService = modalService;
27
- this.classList = "hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1";
28
- this.editInline = true;
29
- this.editPopup = false;
30
- this.editable = true;
31
- this.loadingSubject = new Subject();
32
- this.windowDimension = {};
33
- this.subscriptions = new Subscription();
34
- }
35
- /**
36
- * Upon init, subscribe to the configuration and value set.
37
- */
38
- ngOnInit() {
39
- if (!this.editable) {
40
- this.editInline = false;
41
- this.editPopup = false;
42
- }
43
- this.loadingSubject = this.attributeService.getLoadingSubject();
44
- this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration) => {
45
- this.attributeConfiguration = attributeConfiguration;
46
- this.attributeService.setAttributeValueSet(this.idAttributeValueSet, this.idParentObject);
47
- }));
48
- this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension) => {
49
- this.windowDimension = windowDimension;
50
- }));
51
- this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet) => {
52
- this.attributeValueSet = attributeValueSet;
53
- if (this.attributeValueSet) {
54
- this.attributeService.notifyAttributes();
55
- }
56
- }));
57
- }
58
- set boundData(value) {
59
- this.attributeService.setBoundData(value);
60
- }
61
- ngOnDestroy() {
62
- this.subscriptions.unsubscribe();
63
- }
64
- set accordion(accordion) {
65
- if (accordion) {
66
- accordion.panels.reset([this.cPanels.toArray(), this.vPanels.toArray()]);
67
- accordion.ngAfterContentChecked();
68
- if (this.accordionNav && !this.accordionNav.accordion) {
69
- this.accordionNav.setAccordion(accordion);
70
- }
71
- this.changeDetectorRef.detectChanges();
72
- }
73
- }
74
- ngOnChanges(changes) {
75
- if (!this.editable) {
76
- this.editInline = false;
77
- this.editPopup = false;
78
- }
79
- if (changes["accordionNav"] && this.accordionNav && this.accordion) {
80
- this.accordionNav.accordion = this.accordion;
81
- this.accordionNav.panels = this.accordion.panels;
82
- }
83
- }
84
- getAttributeService() {
85
- return this.attributeService;
86
- }
87
- edit(modal, editContainer) {
88
- this.editContainer = editContainer;
89
- this.modalService.open(modal, { windowClass: "modal-lg" }).result.then((result) => {
90
- if (result === "Save") {
91
- this.attributeService.updateAttributeValueSet();
92
- }
93
- else if (result === "Cancel") {
94
- this.attributeService.clearUpdatedAttributeValues();
95
- }
96
- }, (reason) => { });
97
- }
98
- post() {
99
- this.attributeService.updateAttributeValueSet();
100
- }
101
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeConfigurationComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AttributeConfigurationComponent, selector: "hci-attribute-configuration", inputs: { idAttributeValueSet: "idAttributeValueSet", idParentObject: "idParentObject", accordionNav: "accordionNav", editInline: "editInline", editPopup: "editPopup", editable: "editable", boundData: "boundData" }, host: { properties: { "class": "this.classList" } }, queries: [{ propertyName: "cPanels", predicate: NgbPanel }], viewQueries: [{ propertyName: "accordion", first: true, predicate: NgbAccordion, descendants: true }, { propertyName: "vPanels", predicate: NgbPanel, descendants: true }], usesOnChanges: true, ngImport: i0, template: `
1
+ import { ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, QueryList, Renderer2, ViewChild, ViewChildren, HostBinding } from "@angular/core";
2
+ import { Subject, Subscription } from "rxjs";
3
+ import { NgbAccordion, NgbModal, NgbPanel } from "@ng-bootstrap/ng-bootstrap";
4
+ import { AccordionNavComponent } from "@huntsman-cancer-institute/misc";
5
+ import { AttributeService } from "../services/attribute.service";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../services/attribute.service";
8
+ import * as i2 from "@ng-bootstrap/ng-bootstrap";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "@huntsman-cancer-institute/misc";
11
+ import * as i5 from "./attribute-absolute.component";
12
+ import * as i6 from "./attribute-flex.component";
13
+ import * as i7 from "./attribute-edit.component";
14
+ import * as i8 from "../pipes/is-group-attribute.pipe";
15
+ /**
16
+ * This component should be added on to any screen that displays an entity with an idAttributeValueSet. This configuration
17
+ * represents the parent of separate containers, which in turn contain attributes which display those values in the
18
+ * attributeValueSet.
19
+ */
20
+ export class AttributeConfigurationComponent {
21
+ constructor(attributeService, elementRef, renderer, changeDetectorRef, modalService) {
22
+ this.attributeService = attributeService;
23
+ this.elementRef = elementRef;
24
+ this.renderer = renderer;
25
+ this.changeDetectorRef = changeDetectorRef;
26
+ this.modalService = modalService;
27
+ this.classList = "hci-attribute-configuration hci-cod d-flex flex-column flex-grow-1";
28
+ this.editInline = true;
29
+ this.editPopup = false;
30
+ this.editable = true;
31
+ this.loadingSubject = new Subject();
32
+ this.windowDimension = {};
33
+ this.subscriptions = new Subscription();
34
+ }
35
+ /**
36
+ * Upon init, subscribe to the configuration and value set.
37
+ */
38
+ ngOnInit() {
39
+ if (!this.editable) {
40
+ this.editInline = false;
41
+ this.editPopup = false;
42
+ }
43
+ this.loadingSubject = this.attributeService.getLoadingSubject();
44
+ this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration) => {
45
+ this.attributeConfiguration = attributeConfiguration;
46
+ this.attributeService.setAttributeValueSet(this.idAttributeValueSet, this.idParentObject);
47
+ }));
48
+ this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension) => {
49
+ this.windowDimension = windowDimension;
50
+ }));
51
+ this.subscriptions.add(this.attributeService.getAttributeValueSet().subscribe((attributeValueSet) => {
52
+ this.attributeValueSet = attributeValueSet;
53
+ if (this.attributeValueSet) {
54
+ this.attributeService.notifyAttributes();
55
+ }
56
+ }));
57
+ }
58
+ set boundData(value) {
59
+ this.attributeService.setBoundData(value);
60
+ }
61
+ ngOnDestroy() {
62
+ this.subscriptions.unsubscribe();
63
+ }
64
+ set accordion(accordion) {
65
+ if (accordion) {
66
+ accordion.panels.reset([this.cPanels.toArray(), this.vPanels.toArray()]);
67
+ accordion.ngAfterContentChecked();
68
+ if (this.accordionNav && !this.accordionNav.accordion) {
69
+ this.accordionNav.setAccordion(accordion);
70
+ }
71
+ this.changeDetectorRef.detectChanges();
72
+ }
73
+ }
74
+ ngOnChanges(changes) {
75
+ if (!this.editable) {
76
+ this.editInline = false;
77
+ this.editPopup = false;
78
+ }
79
+ if (changes["accordionNav"] && this.accordionNav && this.accordion) {
80
+ this.accordionNav.accordion = this.accordion;
81
+ this.accordionNav.panels = this.accordion.panels;
82
+ }
83
+ }
84
+ getAttributeService() {
85
+ return this.attributeService;
86
+ }
87
+ edit(modal, editContainer) {
88
+ this.editContainer = editContainer;
89
+ this.modalService.open(modal, { windowClass: "modal-lg" }).result.then((result) => {
90
+ if (result === "Save") {
91
+ this.attributeService.updateAttributeValueSet();
92
+ }
93
+ else if (result === "Cancel") {
94
+ this.attributeService.clearUpdatedAttributeValues();
95
+ }
96
+ }, (reason) => { });
97
+ }
98
+ post() {
99
+ this.attributeService.updateAttributeValueSet();
100
+ }
101
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeConfigurationComponent, deps: [{ token: i1.AttributeService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i2.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
102
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AttributeConfigurationComponent, selector: "hci-attribute-configuration", inputs: { idAttributeValueSet: "idAttributeValueSet", idParentObject: "idParentObject", accordionNav: "accordionNav", editInline: "editInline", editPopup: "editPopup", editable: "editable", boundData: "boundData" }, host: { properties: { "class": "this.classList" } }, queries: [{ propertyName: "cPanels", predicate: NgbPanel }], viewQueries: [{ propertyName: "accordion", first: true, predicate: NgbAccordion, descendants: true }, { propertyName: "vPanels", predicate: NgbPanel, descendants: true }], usesOnChanges: true, ngImport: i0, template: `
103
103
  <hci-busy [busySubjects]="[loadingSubject]"></hci-busy>
104
104
 
105
105
  <ng-container *ngIf="attributeConfiguration && attributeValueSet">
@@ -162,12 +162,12 @@ export class AttributeConfigurationComponent {
162
162
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
163
163
  </div>
164
164
  </ng-template>
165
- `, 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: i2.NgbAccordion, selector: "ngb-accordion", inputs: ["animation", "activeIds", "closeOthers", "destroyOnHide", "type"], outputs: ["panelChange", "shown", "hidden"], exportAs: ["ngbAccordion"] }, { kind: "directive", type: i2.NgbPanel, selector: "ngb-panel", inputs: ["disabled", "id", "title", "type", "cardClass"], outputs: ["shown", "hidden"] }, { kind: "directive", type: i2.NgbPanelTitle, selector: "ng-template[ngbPanelTitle]" }, { kind: "directive", type: i2.NgbPanelContent, selector: "ng-template[ngbPanelContent]" }, { 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" }] }); }
166
- }
167
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AttributeConfigurationComponent, decorators: [{
168
- type: Component,
169
- args: [{
170
- selector: "hci-attribute-configuration",
165
+ `, 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: i2.NgbAccordion, selector: "ngb-accordion", inputs: ["animation", "activeIds", "closeOthers", "destroyOnHide", "type"], outputs: ["panelChange", "shown", "hidden"], exportAs: ["ngbAccordion"] }, { kind: "directive", type: i2.NgbPanel, selector: "ngb-panel", inputs: ["disabled", "id", "title", "type", "cardClass"], outputs: ["shown", "hidden"] }, { kind: "directive", type: i2.NgbPanelTitle, selector: "ng-template[ngbPanelTitle]" }, { kind: "directive", type: i2.NgbPanelContent, selector: "ng-template[ngbPanelContent]" }, { 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" }] }); }
166
+ }
167
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AttributeConfigurationComponent, decorators: [{
168
+ type: Component,
169
+ args: [{
170
+ selector: "hci-attribute-configuration",
171
171
  template: `
172
172
  <hci-busy [busySubjects]="[loadingSubject]"></hci-busy>
173
173
 
@@ -231,33 +231,33 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
231
231
  <button class="btn btn-primary" (click)="close('Cancel')">Cancel</button>
232
232
  </div>
233
233
  </ng-template>
234
- `
235
- }]
236
- }], ctorParameters: function () { return [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.NgbModal }]; }, propDecorators: { classList: [{
237
- type: HostBinding,
238
- args: ["class"]
239
- }], idAttributeValueSet: [{
240
- type: Input
241
- }], idParentObject: [{
242
- type: Input
243
- }], accordionNav: [{
244
- type: Input
245
- }], editInline: [{
246
- type: Input
247
- }], editPopup: [{
248
- type: Input
249
- }], editable: [{
250
- type: Input
251
- }], vPanels: [{
252
- type: ViewChildren,
253
- args: [NgbPanel]
254
- }], cPanels: [{
255
- type: ContentChildren,
256
- args: [NgbPanel]
257
- }], boundData: [{
258
- type: Input
259
- }], accordion: [{
260
- type: ViewChild,
261
- args: [NgbAccordion, { static: false }]
262
- }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-configuration.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-configuration.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, isDevMode, TemplateRef,\r\n  QueryList, Renderer2, SimpleChange, ViewChild, ViewChildren, OnInit, OnDestroy, HostBinding\r\n} from \"@angular/core\";\r\n\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport {NgbAccordion, NgbModal, NgbPanel} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {AccordionNavComponent} from \"@huntsman-cancer-institute/misc\";\r\n\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 an entity with an idAttributeValueSet.  This configuration\r\n * represents the parent of separate 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-configuration\",\r\n  template: `\r\n    <hci-busy [busySubjects]=\"[loadingSubject]\"></hci-busy>\r\n\r\n    <ng-container *ngIf=\"attributeConfiguration && attributeValueSet\">\r\n      <ngb-accordion #accordion=\"ngbAccordion\" class=\"y-auto\">\r\n        <ng-content></ng-content>\r\n        <ng-container *ngFor=\"let attributeContainer of attributeConfiguration.attributeContainers\">\r\n          <ngb-panel [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer\" [title]=\"attributeContainer.containerName\">\r\n            <ng-template ngbPanelTitle>\r\n              <div *ngIf=\"editPopup\" [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'\"\r\n                   class=\"d-flex flex-grow-1 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            </ng-template>\r\n            <ng-template ngbPanelContent>\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                   [class.x-auto]=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\"\r\n                   [style.height.px]=\"(!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N') ? windowDimension.height : 'auto'\">\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            </ng-template>\r\n          </ngb-panel>\r\n        </ng-container>\r\n      </ngb-accordion>\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 AttributeConfigurationComponent implements OnInit, OnDestroy {\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() idParentObject: number;\r\n  \r\n  @Input() accordionNav: AccordionNavComponent;\r\n  \r\n  @Input() editInline: boolean = true;\r\n  @Input() editPopup: boolean =  false;\r\n  @Input() editable: boolean = true;\r\n\r\n  @ViewChildren(NgbPanel) vPanels: QueryList<NgbPanel>;\r\n  @ContentChildren(NgbPanel) cPanels: QueryList<NgbPanel>;\r\n\r\n  attributeConfiguration: AttributeConfiguration;\r\n  attributeValueSet: AttributeValueSet;\r\n\r\n  loadingSubject: Subject<boolean> = new Subject<boolean>();\r\n\r\n  editContainer: AttributeContainer;\r\n\r\n  windowDimension: any = {};\r\n\r\n  subscriptions: Subscription = new Subscription();\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.loadingSubject = this.attributeService.getLoadingSubject();\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration: AttributeConfiguration) => {\r\n      this.attributeConfiguration = attributeConfiguration;\r\n      \r\n      this.attributeService.setAttributeValueSet(this.idAttributeValueSet, this.idParentObject);\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension: any) => {\r\n      this.windowDimension = windowDimension;\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  @ViewChild(NgbAccordion, {static: false})\r\n  set accordion(accordion: NgbAccordion) {\r\n    if (accordion) {\r\n      accordion.panels.reset([this.cPanels.toArray(), this.vPanels.toArray()]);\r\n      accordion.ngAfterContentChecked();\r\n\r\n      if (this.accordionNav && !this.accordionNav.accordion) {\r\n        this.accordionNav.setAccordion(accordion);\r\n      }\r\n\r\n      this.changeDetectorRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: {[propName: string]: SimpleChange}) {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    if (changes[\"accordionNav\"] && this.accordionNav && this.accordion) {\r\n      this.accordionNav.accordion = this.accordion;\r\n      this.accordionNav.panels = this.accordion.panels;\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}\r\n"]}
234
+ `
235
+ }]
236
+ }], ctorParameters: () => [{ type: i1.AttributeService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.NgbModal }], propDecorators: { classList: [{
237
+ type: HostBinding,
238
+ args: ["class"]
239
+ }], idAttributeValueSet: [{
240
+ type: Input
241
+ }], idParentObject: [{
242
+ type: Input
243
+ }], accordionNav: [{
244
+ type: Input
245
+ }], editInline: [{
246
+ type: Input
247
+ }], editPopup: [{
248
+ type: Input
249
+ }], editable: [{
250
+ type: Input
251
+ }], vPanels: [{
252
+ type: ViewChildren,
253
+ args: [NgbPanel]
254
+ }], cPanels: [{
255
+ type: ContentChildren,
256
+ args: [NgbPanel]
257
+ }], boundData: [{
258
+ type: Input
259
+ }], accordion: [{
260
+ type: ViewChild,
261
+ args: [NgbAccordion, { static: false }]
262
+ }] } });
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attribute-configuration.component.js","sourceRoot":"","sources":["../../../../projects/cod/src/components/attribute-configuration.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef, Component, ContentChildren, ElementRef, Input, isDevMode, TemplateRef,\r\n  QueryList, Renderer2, SimpleChange, ViewChild, ViewChildren, OnInit, OnDestroy, HostBinding\r\n} from \"@angular/core\";\r\n\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport {NgbAccordion, NgbModal, NgbPanel} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {AccordionNavComponent} from \"@huntsman-cancer-institute/misc\";\r\n\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 an entity with an idAttributeValueSet.  This configuration\r\n * represents the parent of separate 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-configuration\",\r\n  template: `\r\n    <hci-busy [busySubjects]=\"[loadingSubject]\"></hci-busy>\r\n\r\n    <ng-container *ngIf=\"attributeConfiguration && attributeValueSet\">\r\n      <ngb-accordion #accordion=\"ngbAccordion\" class=\"y-auto\">\r\n        <ng-content></ng-content>\r\n        <ng-container *ngFor=\"let attributeContainer of attributeConfiguration.attributeContainers\">\r\n          <ngb-panel [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer\" [title]=\"attributeContainer.containerName\">\r\n            <ng-template ngbPanelTitle>\r\n              <div *ngIf=\"editPopup\" [id]=\"'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'\"\r\n                   class=\"d-flex flex-grow-1 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            </ng-template>\r\n            <ng-template ngbPanelContent>\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                   [class.x-auto]=\"!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N'\"\r\n                   [style.height.px]=\"(!attributeContainer.isAutoLayout || attributeContainer.isAutoLayout === 'N') ? windowDimension.height : 'auto'\">\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            </ng-template>\r\n          </ngb-panel>\r\n        </ng-container>\r\n      </ngb-accordion>\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 AttributeConfigurationComponent implements OnInit, OnDestroy {\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() idParentObject: number;\r\n  \r\n  @Input() accordionNav: AccordionNavComponent;\r\n  \r\n  @Input() editInline: boolean = true;\r\n  @Input() editPopup: boolean =  false;\r\n  @Input() editable: boolean = true;\r\n\r\n  @ViewChildren(NgbPanel) vPanels: QueryList<NgbPanel>;\r\n  @ContentChildren(NgbPanel) cPanels: QueryList<NgbPanel>;\r\n\r\n  attributeConfiguration: AttributeConfiguration;\r\n  attributeValueSet: AttributeValueSet;\r\n\r\n  loadingSubject: Subject<boolean> = new Subject<boolean>();\r\n\r\n  editContainer: AttributeContainer;\r\n\r\n  windowDimension: any = {};\r\n\r\n  subscriptions: Subscription = new Subscription();\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.loadingSubject = this.attributeService.getLoadingSubject();\r\n\r\n    this.subscriptions.add(this.attributeService.getAttributeConfigurationSubject().subscribe((attributeConfiguration: AttributeConfiguration) => {\r\n      this.attributeConfiguration = attributeConfiguration;\r\n      \r\n      this.attributeService.setAttributeValueSet(this.idAttributeValueSet, this.idParentObject);\r\n    }));\r\n\r\n    this.subscriptions.add(this.attributeService.attributeConfigurationDimensionSubject.subscribe((windowDimension: any) => {\r\n      this.windowDimension = windowDimension;\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  @ViewChild(NgbAccordion, {static: false})\r\n  set accordion(accordion: NgbAccordion) {\r\n    if (accordion) {\r\n      accordion.panels.reset([this.cPanels.toArray(), this.vPanels.toArray()]);\r\n      accordion.ngAfterContentChecked();\r\n\r\n      if (this.accordionNav && !this.accordionNav.accordion) {\r\n        this.accordionNav.setAccordion(accordion);\r\n      }\r\n\r\n      this.changeDetectorRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: {[propName: string]: SimpleChange}) {\r\n    if (! this.editable) {\r\n      this.editInline = false;\r\n      this.editPopup = false;\r\n    }\r\n    \r\n    if (changes[\"accordionNav\"] && this.accordionNav && this.accordion) {\r\n      this.accordionNav.accordion = this.accordion;\r\n      this.accordionNav.panels = this.accordion.panels;\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}\r\n"]}