@huntsman-cancer-institute/cod 16.0.1 → 16.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,11 @@
1
- import { ElementRef, Renderer2 } from "@angular/core";
2
- import { NgbModal } from "@ng-bootstrap/ng-bootstrap";
3
- import { AttributeBase } from "./attribute-base";
4
- import { AttributeService } from "../services/attribute.service";
1
+ import { ElementRef, Renderer2 } from '@angular/core';
2
+ import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
3
+ import { AttributeBase } from './attribute-base';
4
+ import { AttributeService } from '../services/attribute.service';
5
5
  import * as i0 from "@angular/core";
6
6
  /**
7
- * This component is specifically designed to exist in a modal for editing. This is different from the flex attribute
8
- * because components such as the grid need extra configuration for editing.
7
+ * This component is specifically designed to exist in a modal for editing.
8
+ * This is different from the flex attribute because components such as the grid need extra configuration for editing.
9
9
  */
10
10
  export declare class AttributeEditComponent extends AttributeBase {
11
11
  constructor(attributeService: AttributeService, elementRef: ElementRef, renderer: Renderer2, modalService: NgbModal);
@@ -111,7 +111,7 @@ export class AttributeConfigurationComponent {
111
111
  <div *ngIf="editPopup" [id]="'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'"
112
112
  class="d-flex flex-grow-1 attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}">
113
113
  <div class="ml-auto mr-0" (click)="edit(editModal, attributeContainer)">
114
- <i class="fas fa-pencil"></i>
114
+ <i class="fas fa-pencil-alt"></i>
115
115
  </div>
116
116
  </div>
117
117
  </ng-template>
@@ -180,7 +180,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
180
180
  <div *ngIf="editPopup" [id]="'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'"
181
181
  class="d-flex flex-grow-1 attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}">
182
182
  <div class="ml-auto mr-0" (click)="edit(editModal, attributeContainer)">
183
- <i class="fas fa-pencil"></i>
183
+ <i class="fas fa-pencil-alt"></i>
184
184
  </div>
185
185
  </div>
186
186
  </ng-template>
@@ -260,4 +260,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
260
260
  type: ViewChild,
261
261
  args: [NgbAccordion, { static: false }]
262
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"]}
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-alt\"></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"]}
@@ -117,12 +117,12 @@ export class AttributeContainerComponent {
117
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
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: `
119
119
  <hci-busy [getBusySubjects]="getBusySubjects"></hci-busy>
120
-
120
+
121
121
  <ng-container *ngIf="attributeContainer">
122
122
  <div *ngIf="editPopup" [id]="'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'"
123
123
  class="d-flex attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}">
124
124
  <div class="ml-auto mr-0" (click)="edit(editModal, attributeContainer)">
125
- <i class="fas fa-pencil"></i>
125
+ <i class="fas fa-pencil-alt"></i>
126
126
  </div>
127
127
  </div>
128
128
  <div class="d-flex flex-grow-1 y-auto" style="flex: 1 1 1px;">
@@ -175,12 +175,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
175
175
  selector: "hci-attribute-container",
176
176
  template: `
177
177
  <hci-busy [getBusySubjects]="getBusySubjects"></hci-busy>
178
-
178
+
179
179
  <ng-container *ngIf="attributeContainer">
180
180
  <div *ngIf="editPopup" [id]="'id-attribute-container-' + attributeContainer.idAttributeContainer + '-header'"
181
181
  class="d-flex attribute-container-header {{'sort-order-' + attributeContainer.sortOrder}}">
182
182
  <div class="ml-auto mr-0" (click)="edit(editModal, attributeContainer)">
183
- <i class="fas fa-pencil"></i>
183
+ <i class="fas fa-pencil-alt"></i>
184
184
  </div>
185
185
  </div>
186
186
  <div class="d-flex flex-grow-1 y-auto" style="flex: 1 1 1px;">
@@ -255,4 +255,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
255
255
  }], boundData: [{
256
256
  type: Input
257
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"]}
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-alt\"></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"]}