@pega/angular-sdk-components 0.23.9 → 0.23.10

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 (32) hide show
  1. package/esm2022/lib/_bridge/angular-pconnect.mjs +14 -2
  2. package/esm2022/lib/_components/field/auto-complete/auto-complete.component.mjs +4 -2
  3. package/esm2022/lib/_components/field/check-box/check-box.component.mjs +5 -4
  4. package/esm2022/lib/_components/field/currency/currency.component.mjs +5 -2
  5. package/esm2022/lib/_components/field/date/date.component.mjs +5 -2
  6. package/esm2022/lib/_components/field/date-time/date-time.component.mjs +4 -5
  7. package/esm2022/lib/_components/field/dropdown/dropdown.component.mjs +1 -5
  8. package/esm2022/lib/_components/field/email/email.component.mjs +5 -3
  9. package/esm2022/lib/_components/field/integer/integer.component.mjs +5 -3
  10. package/esm2022/lib/_components/field/percentage/percentage.component.mjs +5 -3
  11. package/esm2022/lib/_components/field/phone/phone.component.mjs +4 -3
  12. package/esm2022/lib/_components/field/radio-buttons/radio-buttons.component.mjs +5 -6
  13. package/esm2022/lib/_components/field/text-area/text-area.component.mjs +5 -7
  14. package/esm2022/lib/_components/field/text-input/text-input.component.mjs +5 -3
  15. package/esm2022/lib/_components/field/time/time.component.mjs +5 -4
  16. package/esm2022/lib/_components/field/url/url.component.mjs +5 -3
  17. package/esm2022/lib/_components/field/user-reference/user-reference.component.mjs +5 -6
  18. package/esm2022/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.mjs +2 -8
  19. package/esm2022/lib/_components/infra/reference/reference.component.mjs +14 -11
  20. package/esm2022/lib/_components/infra/root-container/root-container.component.mjs +3 -13
  21. package/esm2022/lib/_components/template/default-form/default-form.component.mjs +39 -8
  22. package/esm2022/lib/_components/template/field-group-template/field-group-template.component.mjs +2 -2
  23. package/fesm2022/pega-angular-sdk-components.mjs +109 -79
  24. package/fesm2022/pega-angular-sdk-components.mjs.map +1 -1
  25. package/lib/_bridge/angular-pconnect.d.ts +2 -0
  26. package/lib/_components/field/dropdown/dropdown.component.d.ts +0 -1
  27. package/lib/_components/field/radio-buttons/radio-buttons.component.d.ts +0 -1
  28. package/lib/_components/field/text-area/text-area.component.d.ts +0 -1
  29. package/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.d.ts +1 -2
  30. package/lib/_components/infra/root-container/root-container.component.d.ts +0 -1
  31. package/lib/_components/template/default-form/default-form.component.d.ts +9 -3
  32. package/package.json +1 -1
@@ -49,10 +49,6 @@ export class ModalViewContainerComponent {
49
49
  this.formGroup$ = fb.group({ hideRequired: false });
50
50
  }
51
51
  ngOnInit() {
52
- if (this.displayOnlyFA$) {
53
- // for when non modal
54
- this.bShowAsModal$ = false;
55
- }
56
52
  // First thing in initialization is registering and subscribing to the AngularPConnect service
57
53
  this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
58
54
  const baseContext = this.pConn$.getContextName();
@@ -328,16 +324,14 @@ export class ModalViewContainerComponent {
328
324
  return `${this.localizedVal('Create', this.localeCategory)} ${this.localizedVal(caseTypeName, undefined, caseLocaleRef)} (${ID})`;
329
325
  }
330
326
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ModalViewContainerComponent, deps: [{ token: i1.AngularPConnectService }, { token: i0.NgZone }, { token: i2.ProgressSpinnerService }, { token: i3.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
331
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ModalViewContainerComponent, isStandalone: true, selector: "app-modal-view-container", inputs: { pConn$: "pConn$", displayOnlyFA$: "displayOnlyFA$" }, outputs: { modalVisibleChange: "modalVisibleChange" }, ngImport: i0, template: "<div id=\"dialog\" *ngIf=\"bShowModal$ && bShowAsModal$\" class=\"psdk-dialog-background\">\n <div class=\"psdk-modal-view-container-top\" id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$, isInModal$: true, banners }\"\n ></component-mapper>\n <div *ngIf=\"isMultiRecord\">\n <component-mapper\n name=\"ListViewActionButtons\"\n [props]=\"{ pConn$: createdViewPConn$, context$ }\"\n [outputEvents]=\"{ closeActionsDialog: closeActionsDialog }\"\n ></component-mapper>\n </div>\n </div>\n</div>\n\n<div *ngIf=\"bShowModal$ && !bShowAsModal$\">\n <div id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$ }\"\n ></component-mapper>\n </div>\n</div>\n\n<div *ngIf=\"bShowCancelAlert$\">\n <component-mapper\n name=\"CancelAlert\"\n [props]=\"{ bShowAlert$: bShowCancelAlert$, pConn$: cancelPConn$ }\"\n [parent]=\"this\"\n [outputEvents]=\"{ onAlertState$: onAlertState }\"\n ></component-mapper>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i4.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
327
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ModalViewContainerComponent, isStandalone: true, selector: "app-modal-view-container", inputs: { pConn$: "pConn$" }, outputs: { modalVisibleChange: "modalVisibleChange" }, ngImport: i0, template: "<div id=\"dialog\" *ngIf=\"bShowModal$ && bShowAsModal$\" class=\"psdk-dialog-background\">\n <div class=\"psdk-modal-view-container-top\" id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$, isInModal$: true, banners }\"\n ></component-mapper>\n <div *ngIf=\"isMultiRecord\">\n <component-mapper\n name=\"ListViewActionButtons\"\n [props]=\"{ pConn$: createdViewPConn$, context$ }\"\n [outputEvents]=\"{ closeActionsDialog: closeActionsDialog }\"\n ></component-mapper>\n </div>\n </div>\n</div>\n\n<div *ngIf=\"bShowModal$ && !bShowAsModal$\">\n <div id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$ }\"\n ></component-mapper>\n </div>\n</div>\n\n<div *ngIf=\"bShowCancelAlert$\">\n <component-mapper\n name=\"CancelAlert\"\n [props]=\"{ bShowAlert$: bShowCancelAlert$, pConn$: cancelPConn$ }\"\n [parent]=\"this\"\n [outputEvents]=\"{ onAlertState$: onAlertState }\"\n ></component-mapper>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i4.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
332
328
  }
333
329
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ModalViewContainerComponent, decorators: [{
334
330
  type: Component,
335
331
  args: [{ selector: 'app-modal-view-container', standalone: true, imports: [CommonModule, forwardRef(() => ComponentMapperComponent)], template: "<div id=\"dialog\" *ngIf=\"bShowModal$ && bShowAsModal$\" class=\"psdk-dialog-background\">\n <div class=\"psdk-modal-view-container-top\" id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$, isInModal$: true, banners }\"\n ></component-mapper>\n <div *ngIf=\"isMultiRecord\">\n <component-mapper\n name=\"ListViewActionButtons\"\n [props]=\"{ pConn$: createdViewPConn$, context$ }\"\n [outputEvents]=\"{ closeActionsDialog: closeActionsDialog }\"\n ></component-mapper>\n </div>\n </div>\n</div>\n\n<div *ngIf=\"bShowModal$ && !bShowAsModal$\">\n <div id=\"{{ buildName$ }}\">\n <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n <component-mapper\n name=\"Assignment\"\n [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$ }\"\n ></component-mapper>\n </div>\n</div>\n\n<div *ngIf=\"bShowCancelAlert$\">\n <component-mapper\n name=\"CancelAlert\"\n [props]=\"{ bShowAlert$: bShowCancelAlert$, pConn$: cancelPConn$ }\"\n [parent]=\"this\"\n [outputEvents]=\"{ onAlertState$: onAlertState }\"\n ></component-mapper>\n</div>\n" }]
336
332
  }], ctorParameters: function () { return [{ type: i1.AngularPConnectService }, { type: i0.NgZone }, { type: i2.ProgressSpinnerService }, { type: i3.FormBuilder }]; }, propDecorators: { pConn$: [{
337
333
  type: Input
338
- }], displayOnlyFA$: [{
339
- type: Input
340
334
  }], modalVisibleChange: [{
341
335
  type: Output
342
336
  }] } });
343
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-view-container.component.js","sourceRoot":"","sources":["../../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.ts","../../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, NgZone, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport isEqual from 'fast-deep-equal';\nimport { AngularPConnectData, AngularPConnectService } from '../../../../_bridge/angular-pconnect';\nimport { ProgressSpinnerService } from '../../../../_messages/progress-spinner.service';\nimport { ComponentMapperComponent } from '../../../../_bridge/component-mapper/component-mapper.component';\nimport { getBanners } from '../../../../_helpers/case-utils';\nimport { ReferenceComponent } from '../../reference/reference.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\n@Component({\n  selector: 'app-modal-view-container',\n  templateUrl: './modal-view-container.component.html',\n  styleUrls: ['./modal-view-container.component.scss'],\n  standalone: true,\n  imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class ModalViewContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() displayOnlyFA$: boolean;\n\n  // for when non modal\n  @Output() modalVisibleChange = new EventEmitter<boolean>();\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  arChildren$: any[];\n  stateProps$: Object;\n  banners: any;\n  templateName$: string;\n  buildName$: string;\n  context$: string;\n  title$ = '';\n  bShowModal$ = false;\n  bShowAsModal$ = true;\n  itemKey$: string;\n  formGroup$: FormGroup;\n  oCaseInfo: Object = {};\n\n  // for causing a change on assignment\n  updateToken$ = 0;\n\n  routingInfoRef: any = {};\n\n  // created object is now a View with a Template\n  //  Use its PConnect to render the CaseView; DON'T replace this.pConn$\n  createdViewPConn$: any;\n\n  bSubscribed = false;\n  cancelPConn$?: typeof PConnect;\n  bShowCancelAlert$ = false;\n  bAlertState: boolean;\n  localizedVal: Function;\n  localeCategory = 'Data Object';\n  isMultiRecord = false;\n  actionsDialog = false;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private ngZone: NgZone,\n    private psService: ProgressSpinnerService,\n    private fb: FormBuilder\n  ) {\n    // create the formGroup\n    this.formGroup$ = fb.group({ hideRequired: false });\n  }\n\n  ngOnInit(): void {\n    if (this.displayOnlyFA$) {\n      // for when non modal\n      this.bShowAsModal$ = false;\n    }\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    const baseContext = this.pConn$.getContextName();\n    const acName = this.pConn$.getContainerName();\n\n    // for now, in general this should be overridden by updateSelf(), and not be blank\n    if (this.itemKey$ === '') {\n      this.itemKey$ = baseContext.concat('/').concat(acName);\n    }\n\n    const containerMgr: any = this.pConn$.getContainerManager();\n\n    containerMgr.initializeContainers({\n      type: 'multiple'\n    });\n\n    // const { CONTAINER_TYPE, PUB_SUB_EVENTS } = PCore.getConstants();\n\n    this.angularPConnect.shouldComponentUpdate(this);\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n\n    const { PUB_SUB_EVENTS } = PCore.getConstants();\n\n    PCore.getPubSubUtils().unsubscribe(\n      PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT,\n      PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT /* Should be same unique string passed during subscription */\n    );\n    this.bSubscribed = false;\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    } else if (this.bShowModal$) {\n      // right now onlu get one updated when initial diaplay.  So, once modal is up\n      // let fall through and do a check with \"compareCaseInfoIsDifferent\" until fixed\n      // this.updateSelf();\n    }\n  }\n\n  // updateSelf\n  updateSelf(): void {\n    // routingInfo was added as component prop in populateAdditionalProps\n    const routingInfo = this.angularPConnect.getComponentProp(this, 'routingInfo');\n    this.routingInfoRef.current = routingInfo;\n\n    let loadingInfo;\n    try {\n      // @ts-ignore - Property 'getLoadingStatus' is private and only accessible within class 'C11nEnv'\n      loadingInfo = this.pConn$.getLoadingStatus();\n    } catch (ex) {\n      /* empty */\n    }\n    // const configProps = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());\n    this.stateProps$ = this.pConn$.getStateProps();\n    this.banners = this.getBanners();\n\n    if (!loadingInfo) {\n      // turn off spinner\n      // this.psService.sendMessage(false);\n    }\n\n    if (routingInfo && !loadingInfo /* && this.bUpdate */) {\n      const currentOrder = routingInfo.accessedOrder;\n\n      if (undefined == currentOrder) {\n        return;\n      }\n\n      const currentItems = routingInfo.items;\n\n      const { key, latestItem } = this.getKeyAndLatestItem(routingInfo);\n\n      if (currentOrder.length > 0) {\n        if (currentItems[key] && currentItems[key].view && Object.keys(currentItems[key].view).length > 0) {\n          const currentItem = currentItems[key];\n          const rootView = currentItem.view;\n          const { context } = rootView.config;\n          const config: any = { meta: rootView };\n          config.options = {\n            context: currentItem.context,\n            hasForm: true,\n            pageReference: context || this.pConn$.getPageReference()\n          };\n\n          if (!this.bSubscribed) {\n            this.bSubscribed = true;\n            const { PUB_SUB_EVENTS } = PCore.getConstants();\n            PCore.getPubSubUtils().subscribe(\n              PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT,\n              payload => {\n                this.showAlert(payload);\n              },\n              PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT\n            );\n          }\n\n          // let configObject = PCore.createPConnect(config);\n\n          // THIS is where the ViewContainer creates a View\n          // The config has meta.config.type = \"view\"\n          this.createView(routingInfo, currentItem, latestItem, key);\n        }\n      } else {\n        this.hideModal();\n      }\n    }\n  }\n\n  createView(routingInfo, currentItem, latestItem, key) {\n    const configObject = this.getConfigObject(currentItem, null, false);\n    const newComp = configObject?.getPConnect();\n    // const newCompName = newComp.getComponentName();\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const caseInfo = newComp && newComp.getDataObject() && newComp.getDataObject().caseInfo ? newComp.getDataObject().caseInfo : null;\n    // The metadata for pyDetails changed such that the \"template\": \"CaseView\"\n    //  is no longer a child of the created View but is in the created View's\n    //  config. So, we DON'T want to replace this.pConn$ since the created\n    //  component is a View (and not a ViewContainer). We now look for the\n    //  \"template\" type directly in the created component (newComp) and NOT\n    //  as a child of the newly created component.\n    // console.log(`---> ModalViewContainer created new ${newCompName}`);\n\n    // Use the newly created component (View) info but DO NOT replace\n    //  this ModalViewContainer's pConn$, etc.\n    //  Note that we're now using the newly created View's PConnect in the\n    //  ViewContainer HTML template to guide what's rendered similar to what\n    //  the Nebula/Constellation return of React.Fragment does\n\n    // right now need to check caseInfo for changes, to trigger redraw, not getting\n    // changes from angularPconnect except for first draw\n    if (newComp && caseInfo && this.compareCaseInfoIsDifferent(caseInfo)) {\n      this.psService.sendMessage(false);\n\n      this.ngZone.run(() => {\n        this.createdViewPConn$ = newComp;\n        const newConfigProps = newComp.getConfigProps();\n        this.templateName$ = 'template' in newConfigProps ? (newConfigProps.template as string) : '';\n\n        const { actionName } = latestItem;\n        const theNewCaseInfo = newComp.getCaseInfo();\n        // const caseName = theNewCaseInfo.getName();\n        const ID = theNewCaseInfo.getBusinessID() || theNewCaseInfo.getID();\n\n        const caseTypeName = theNewCaseInfo.getCaseTypeName();\n        const isDataObject = routingInfo.items[latestItem.context].resourceType === PCore.getConstants().RESOURCE_TYPES.DATA;\n        const dataObjectAction = routingInfo.items[latestItem.context].resourceStatus;\n        this.isMultiRecord = routingInfo.items[latestItem.context].isMultiRecordData;\n        this.context$ = latestItem.context;\n        this.title$ =\n          isDataObject || this.isMultiRecord\n            ? this.getModalHeading(dataObjectAction)\n            : this.determineModalHeaderByAction(\n                actionName,\n                caseTypeName,\n                ID,\n                `${theNewCaseInfo?.getClassName()}!CASE!${theNewCaseInfo.getName()}`.toUpperCase()\n              );\n        const bIsRefComponent = this.checkIfRefComponent(newComp);\n\n        if (bIsRefComponent) {\n          const newPConn = ReferenceComponent.normalizePConn(newComp);\n          this.arChildren$ = ReferenceComponent.normalizePConnArray(newPConn.getChildren());\n        } else {\n          // update children with new view's children\n          this.arChildren$ = newComp.getChildren() as any;\n        }\n\n        this.bShowModal$ = true;\n\n        // for when non modal\n        this.modalVisibleChange.emit(this.bShowModal$);\n\n        // save off itemKey to be used for finishAssignment, etc.\n        this.itemKey$ = key;\n\n        // cause a change for assignment\n        this.updateToken$ = new Date().getTime();\n      });\n    }\n  }\n\n  hideModal() {\n    if (this.bShowModal$) {\n      // other code in Nebula/Constellation not needed currently, but if so later,\n      // should put here\n    }\n\n    this.ngZone.run(() => {\n      this.bShowModal$ = false;\n\n      // for when non modal\n      this.modalVisibleChange.emit(this.bShowModal$);\n\n      this.oCaseInfo = {};\n    });\n  }\n\n  getConfigObject(item, pConnect, isReverseCoexistence = false) {\n    let config;\n    if (isReverseCoexistence) {\n      config = {\n        options: {\n          pageReference: pConnect?.getPageReference(),\n          hasForm: true,\n          containerName: pConnect?.getContainerName() || PCore.getConstants().MODAL\n        }\n      };\n      return PCore.createPConnect(config);\n    }\n    if (item) {\n      const { context, view, isBulkAction } = item;\n      const target = PCore.getContainerUtils().getTargetFromContainerItemID(context);\n      config = {\n        meta: view,\n        options: {\n          context,\n          pageReference: view.config.context || pConnect.getPageReference(),\n          hasForm: true,\n          ...(isBulkAction && { isBulkAction }),\n          containerName: pConnect?.getContainerName() || PCore.getConstants().MODAL,\n          target\n        }\n      };\n      return PCore.createPConnect(config);\n    }\n    return null;\n  }\n\n  checkIfRefComponent(thePConn: any): boolean {\n    let bReturn = false;\n    if (thePConn && thePConn.getComponentName() == 'reference') {\n      bReturn = true;\n    }\n\n    return bReturn;\n  }\n\n  onAlertState(bData: boolean) {\n    this.bAlertState = bData;\n    this.bShowCancelAlert$ = false;\n    if (this.bAlertState) {\n      this.hideModal();\n    }\n  }\n\n  showAlert(payload) {\n    const { latestItem } = this.getKeyAndLatestItem(this.routingInfoRef.current);\n    const { isModalAction } = payload;\n\n    /*\n      If we are in create stage full page mode, created a new case and trying to click on cancel button\n      it will show two alert dialogs which is not expected. Hence isModalAction flag to avoid that.\n    */\n    if (latestItem && isModalAction && !this.actionsDialog) {\n      const configObject = this.getConfigObject(latestItem, this.pConn$);\n      this.ngZone.run(() => {\n        this.cancelPConn$ = configObject?.getPConnect();\n        this.bShowCancelAlert$ = true;\n      });\n    }\n  }\n\n  hasContainerItems(routingInfo) {\n    if (routingInfo) {\n      const { accessedOrder, items } = routingInfo;\n      return accessedOrder && accessedOrder.length > 0 && items;\n    }\n    return false;\n  }\n\n  getKeyAndLatestItem(routinginfo) {\n    if (this.hasContainerItems(routinginfo)) {\n      const { accessedOrder, items } = routinginfo;\n      const key = accessedOrder[accessedOrder.length - 1];\n      const latestItem = items[key];\n      return { key, latestItem };\n    }\n    return {};\n  }\n\n  compareCaseInfoIsDifferent(oCurrentCaseInfo: Object): boolean {\n    let bRet = false;\n\n    // fast-deep-equal version\n    if (isEqual !== undefined) {\n      bRet = !isEqual(this.oCaseInfo, oCurrentCaseInfo);\n    } else {\n      const sCurrnentCaseInfo = JSON.stringify(oCurrentCaseInfo);\n      const sOldCaseInfo = JSON.stringify(this.oCaseInfo);\n      // stringify compare version\n      if (sCurrnentCaseInfo != sOldCaseInfo) {\n        bRet = true;\n      }\n    }\n\n    // if different, save off new case info\n    if (bRet) {\n      this.oCaseInfo = JSON.parse(JSON.stringify(oCurrentCaseInfo));\n    }\n\n    return bRet;\n  }\n\n  getBanners() {\n    return getBanners({ target: this.itemKey$, ...this.stateProps$ });\n  }\n\n  getModalHeading(dataObjectAction) {\n    return dataObjectAction === PCore.getConstants().RESOURCE_STATUS.CREATE\n      ? this.localizedVal('Add Record', this.localeCategory)\n      : this.localizedVal('Edit Record', this.localeCategory);\n  }\n\n  determineModalHeaderByAction(actionName, caseTypeName, ID, caseLocaleRef) {\n    if (actionName) {\n      return this.localizedVal(actionName, this.localeCategory);\n    }\n    return `${this.localizedVal('Create', this.localeCategory)} ${this.localizedVal(caseTypeName, undefined, caseLocaleRef)} (${ID})`;\n  }\n\n  closeActionsDialog = () => {\n    this.actionsDialog = true;\n    // this.ngZone.run(() => {\n    this.bShowModal$ = false;\n\n    // for when non modal\n    this.modalVisibleChange.emit(this.bShowModal$);\n\n    this.oCaseInfo = {};\n    // });\n  };\n}\n","<div id=\"dialog\" *ngIf=\"bShowModal$ && bShowAsModal$\" class=\"psdk-dialog-background\">\n  <div class=\"psdk-modal-view-container-top\" id=\"{{ buildName$ }}\">\n    <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n    <component-mapper\n      name=\"Assignment\"\n      [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$, isInModal$: true, banners }\"\n    ></component-mapper>\n    <div *ngIf=\"isMultiRecord\">\n      <component-mapper\n        name=\"ListViewActionButtons\"\n        [props]=\"{ pConn$: createdViewPConn$, context$ }\"\n        [outputEvents]=\"{ closeActionsDialog: closeActionsDialog }\"\n      ></component-mapper>\n    </div>\n  </div>\n</div>\n\n<div *ngIf=\"bShowModal$ && !bShowAsModal$\">\n  <div id=\"{{ buildName$ }}\">\n    <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n    <component-mapper\n      name=\"Assignment\"\n      [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$ }\"\n    ></component-mapper>\n  </div>\n</div>\n\n<div *ngIf=\"bShowCancelAlert$\">\n  <component-mapper\n    name=\"CancelAlert\"\n    [props]=\"{ bShowAlert$: bShowCancelAlert$, pConn$: cancelPConn$ }\"\n    [parent]=\"this\"\n    [outputEvents]=\"{ onAlertState$: onAlertState }\"\n  ></component-mapper>\n</div>\n"]}
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-view-container.component.js","sourceRoot":"","sources":["../../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.ts","../../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, NgZone, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport isEqual from 'fast-deep-equal';\nimport { AngularPConnectData, AngularPConnectService } from '../../../../_bridge/angular-pconnect';\nimport { ProgressSpinnerService } from '../../../../_messages/progress-spinner.service';\nimport { ComponentMapperComponent } from '../../../../_bridge/component-mapper/component-mapper.component';\nimport { getBanners } from '../../../../_helpers/case-utils';\nimport { ReferenceComponent } from '../../reference/reference.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\n@Component({\n  selector: 'app-modal-view-container',\n  templateUrl: './modal-view-container.component.html',\n  styleUrls: ['./modal-view-container.component.scss'],\n  standalone: true,\n  imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class ModalViewContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n\n  // for when non modal\n  @Output() modalVisibleChange = new EventEmitter<boolean>();\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  arChildren$: any[];\n  stateProps$: Object;\n  banners: any;\n  templateName$: string;\n  buildName$: string;\n  context$: string;\n  title$ = '';\n  bShowModal$ = false;\n  bShowAsModal$ = true;\n  itemKey$: string;\n  formGroup$: FormGroup;\n  oCaseInfo: Object = {};\n\n  // for causing a change on assignment\n  updateToken$ = 0;\n\n  routingInfoRef: any = {};\n\n  // created object is now a View with a Template\n  //  Use its PConnect to render the CaseView; DON'T replace this.pConn$\n  createdViewPConn$: any;\n\n  bSubscribed = false;\n  cancelPConn$?: typeof PConnect;\n  bShowCancelAlert$ = false;\n  bAlertState: boolean;\n  localizedVal: Function;\n  localeCategory = 'Data Object';\n  isMultiRecord = false;\n  actionsDialog = false;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private ngZone: NgZone,\n    private psService: ProgressSpinnerService,\n    private fb: FormBuilder\n  ) {\n    // create the formGroup\n    this.formGroup$ = fb.group({ hideRequired: false });\n  }\n\n  ngOnInit(): void {\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    const baseContext = this.pConn$.getContextName();\n    const acName = this.pConn$.getContainerName();\n\n    // for now, in general this should be overridden by updateSelf(), and not be blank\n    if (this.itemKey$ === '') {\n      this.itemKey$ = baseContext.concat('/').concat(acName);\n    }\n\n    const containerMgr: any = this.pConn$.getContainerManager();\n\n    containerMgr.initializeContainers({\n      type: 'multiple'\n    });\n\n    // const { CONTAINER_TYPE, PUB_SUB_EVENTS } = PCore.getConstants();\n\n    this.angularPConnect.shouldComponentUpdate(this);\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n\n    const { PUB_SUB_EVENTS } = PCore.getConstants();\n\n    PCore.getPubSubUtils().unsubscribe(\n      PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT,\n      PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT /* Should be same unique string passed during subscription */\n    );\n    this.bSubscribed = false;\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    } else if (this.bShowModal$) {\n      // right now onlu get one updated when initial diaplay.  So, once modal is up\n      // let fall through and do a check with \"compareCaseInfoIsDifferent\" until fixed\n      // this.updateSelf();\n    }\n  }\n\n  // updateSelf\n  updateSelf(): void {\n    // routingInfo was added as component prop in populateAdditionalProps\n    const routingInfo = this.angularPConnect.getComponentProp(this, 'routingInfo');\n    this.routingInfoRef.current = routingInfo;\n\n    let loadingInfo;\n    try {\n      // @ts-ignore - Property 'getLoadingStatus' is private and only accessible within class 'C11nEnv'\n      loadingInfo = this.pConn$.getLoadingStatus();\n    } catch (ex) {\n      /* empty */\n    }\n    // const configProps = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());\n    this.stateProps$ = this.pConn$.getStateProps();\n    this.banners = this.getBanners();\n\n    if (!loadingInfo) {\n      // turn off spinner\n      // this.psService.sendMessage(false);\n    }\n\n    if (routingInfo && !loadingInfo /* && this.bUpdate */) {\n      const currentOrder = routingInfo.accessedOrder;\n\n      if (undefined == currentOrder) {\n        return;\n      }\n\n      const currentItems = routingInfo.items;\n\n      const { key, latestItem } = this.getKeyAndLatestItem(routingInfo);\n\n      if (currentOrder.length > 0) {\n        if (currentItems[key] && currentItems[key].view && Object.keys(currentItems[key].view).length > 0) {\n          const currentItem = currentItems[key];\n          const rootView = currentItem.view;\n          const { context } = rootView.config;\n          const config: any = { meta: rootView };\n          config.options = {\n            context: currentItem.context,\n            hasForm: true,\n            pageReference: context || this.pConn$.getPageReference()\n          };\n\n          if (!this.bSubscribed) {\n            this.bSubscribed = true;\n            const { PUB_SUB_EVENTS } = PCore.getConstants();\n            PCore.getPubSubUtils().subscribe(\n              PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT,\n              payload => {\n                this.showAlert(payload);\n              },\n              PUB_SUB_EVENTS.EVENT_SHOW_CANCEL_ALERT\n            );\n          }\n\n          // let configObject = PCore.createPConnect(config);\n\n          // THIS is where the ViewContainer creates a View\n          // The config has meta.config.type = \"view\"\n          this.createView(routingInfo, currentItem, latestItem, key);\n        }\n      } else {\n        this.hideModal();\n      }\n    }\n  }\n\n  createView(routingInfo, currentItem, latestItem, key) {\n    const configObject = this.getConfigObject(currentItem, null, false);\n    const newComp = configObject?.getPConnect();\n    // const newCompName = newComp.getComponentName();\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const caseInfo = newComp && newComp.getDataObject() && newComp.getDataObject().caseInfo ? newComp.getDataObject().caseInfo : null;\n    // The metadata for pyDetails changed such that the \"template\": \"CaseView\"\n    //  is no longer a child of the created View but is in the created View's\n    //  config. So, we DON'T want to replace this.pConn$ since the created\n    //  component is a View (and not a ViewContainer). We now look for the\n    //  \"template\" type directly in the created component (newComp) and NOT\n    //  as a child of the newly created component.\n    // console.log(`---> ModalViewContainer created new ${newCompName}`);\n\n    // Use the newly created component (View) info but DO NOT replace\n    //  this ModalViewContainer's pConn$, etc.\n    //  Note that we're now using the newly created View's PConnect in the\n    //  ViewContainer HTML template to guide what's rendered similar to what\n    //  the Nebula/Constellation return of React.Fragment does\n\n    // right now need to check caseInfo for changes, to trigger redraw, not getting\n    // changes from angularPconnect except for first draw\n    if (newComp && caseInfo && this.compareCaseInfoIsDifferent(caseInfo)) {\n      this.psService.sendMessage(false);\n\n      this.ngZone.run(() => {\n        this.createdViewPConn$ = newComp;\n        const newConfigProps = newComp.getConfigProps();\n        this.templateName$ = 'template' in newConfigProps ? (newConfigProps.template as string) : '';\n\n        const { actionName } = latestItem;\n        const theNewCaseInfo = newComp.getCaseInfo();\n        // const caseName = theNewCaseInfo.getName();\n        const ID = theNewCaseInfo.getBusinessID() || theNewCaseInfo.getID();\n\n        const caseTypeName = theNewCaseInfo.getCaseTypeName();\n        const isDataObject = routingInfo.items[latestItem.context].resourceType === PCore.getConstants().RESOURCE_TYPES.DATA;\n        const dataObjectAction = routingInfo.items[latestItem.context].resourceStatus;\n        this.isMultiRecord = routingInfo.items[latestItem.context].isMultiRecordData;\n        this.context$ = latestItem.context;\n        this.title$ =\n          isDataObject || this.isMultiRecord\n            ? this.getModalHeading(dataObjectAction)\n            : this.determineModalHeaderByAction(\n                actionName,\n                caseTypeName,\n                ID,\n                `${theNewCaseInfo?.getClassName()}!CASE!${theNewCaseInfo.getName()}`.toUpperCase()\n              );\n        const bIsRefComponent = this.checkIfRefComponent(newComp);\n\n        if (bIsRefComponent) {\n          const newPConn = ReferenceComponent.normalizePConn(newComp);\n          this.arChildren$ = ReferenceComponent.normalizePConnArray(newPConn.getChildren());\n        } else {\n          // update children with new view's children\n          this.arChildren$ = newComp.getChildren() as any;\n        }\n\n        this.bShowModal$ = true;\n\n        // for when non modal\n        this.modalVisibleChange.emit(this.bShowModal$);\n\n        // save off itemKey to be used for finishAssignment, etc.\n        this.itemKey$ = key;\n\n        // cause a change for assignment\n        this.updateToken$ = new Date().getTime();\n      });\n    }\n  }\n\n  hideModal() {\n    if (this.bShowModal$) {\n      // other code in Nebula/Constellation not needed currently, but if so later,\n      // should put here\n    }\n\n    this.ngZone.run(() => {\n      this.bShowModal$ = false;\n\n      // for when non modal\n      this.modalVisibleChange.emit(this.bShowModal$);\n\n      this.oCaseInfo = {};\n    });\n  }\n\n  getConfigObject(item, pConnect, isReverseCoexistence = false) {\n    let config;\n    if (isReverseCoexistence) {\n      config = {\n        options: {\n          pageReference: pConnect?.getPageReference(),\n          hasForm: true,\n          containerName: pConnect?.getContainerName() || PCore.getConstants().MODAL\n        }\n      };\n      return PCore.createPConnect(config);\n    }\n    if (item) {\n      const { context, view, isBulkAction } = item;\n      const target = PCore.getContainerUtils().getTargetFromContainerItemID(context);\n      config = {\n        meta: view,\n        options: {\n          context,\n          pageReference: view.config.context || pConnect.getPageReference(),\n          hasForm: true,\n          ...(isBulkAction && { isBulkAction }),\n          containerName: pConnect?.getContainerName() || PCore.getConstants().MODAL,\n          target\n        }\n      };\n      return PCore.createPConnect(config);\n    }\n    return null;\n  }\n\n  checkIfRefComponent(thePConn: any): boolean {\n    let bReturn = false;\n    if (thePConn && thePConn.getComponentName() == 'reference') {\n      bReturn = true;\n    }\n\n    return bReturn;\n  }\n\n  onAlertState(bData: boolean) {\n    this.bAlertState = bData;\n    this.bShowCancelAlert$ = false;\n    if (this.bAlertState) {\n      this.hideModal();\n    }\n  }\n\n  showAlert(payload) {\n    const { latestItem } = this.getKeyAndLatestItem(this.routingInfoRef.current);\n    const { isModalAction } = payload;\n\n    /*\n      If we are in create stage full page mode, created a new case and trying to click on cancel button\n      it will show two alert dialogs which is not expected. Hence isModalAction flag to avoid that.\n    */\n    if (latestItem && isModalAction && !this.actionsDialog) {\n      const configObject = this.getConfigObject(latestItem, this.pConn$);\n      this.ngZone.run(() => {\n        this.cancelPConn$ = configObject?.getPConnect();\n        this.bShowCancelAlert$ = true;\n      });\n    }\n  }\n\n  hasContainerItems(routingInfo) {\n    if (routingInfo) {\n      const { accessedOrder, items } = routingInfo;\n      return accessedOrder && accessedOrder.length > 0 && items;\n    }\n    return false;\n  }\n\n  getKeyAndLatestItem(routinginfo) {\n    if (this.hasContainerItems(routinginfo)) {\n      const { accessedOrder, items } = routinginfo;\n      const key = accessedOrder[accessedOrder.length - 1];\n      const latestItem = items[key];\n      return { key, latestItem };\n    }\n    return {};\n  }\n\n  compareCaseInfoIsDifferent(oCurrentCaseInfo: Object): boolean {\n    let bRet = false;\n\n    // fast-deep-equal version\n    if (isEqual !== undefined) {\n      bRet = !isEqual(this.oCaseInfo, oCurrentCaseInfo);\n    } else {\n      const sCurrnentCaseInfo = JSON.stringify(oCurrentCaseInfo);\n      const sOldCaseInfo = JSON.stringify(this.oCaseInfo);\n      // stringify compare version\n      if (sCurrnentCaseInfo != sOldCaseInfo) {\n        bRet = true;\n      }\n    }\n\n    // if different, save off new case info\n    if (bRet) {\n      this.oCaseInfo = JSON.parse(JSON.stringify(oCurrentCaseInfo));\n    }\n\n    return bRet;\n  }\n\n  getBanners() {\n    return getBanners({ target: this.itemKey$, ...this.stateProps$ });\n  }\n\n  getModalHeading(dataObjectAction) {\n    return dataObjectAction === PCore.getConstants().RESOURCE_STATUS.CREATE\n      ? this.localizedVal('Add Record', this.localeCategory)\n      : this.localizedVal('Edit Record', this.localeCategory);\n  }\n\n  determineModalHeaderByAction(actionName, caseTypeName, ID, caseLocaleRef) {\n    if (actionName) {\n      return this.localizedVal(actionName, this.localeCategory);\n    }\n    return `${this.localizedVal('Create', this.localeCategory)} ${this.localizedVal(caseTypeName, undefined, caseLocaleRef)} (${ID})`;\n  }\n\n  closeActionsDialog = () => {\n    this.actionsDialog = true;\n    // this.ngZone.run(() => {\n    this.bShowModal$ = false;\n\n    // for when non modal\n    this.modalVisibleChange.emit(this.bShowModal$);\n\n    this.oCaseInfo = {};\n    // });\n  };\n}\n","<div id=\"dialog\" *ngIf=\"bShowModal$ && bShowAsModal$\" class=\"psdk-dialog-background\">\n  <div class=\"psdk-modal-view-container-top\" id=\"{{ buildName$ }}\">\n    <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n    <component-mapper\n      name=\"Assignment\"\n      [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$, isInModal$: true, banners }\"\n    ></component-mapper>\n    <div *ngIf=\"isMultiRecord\">\n      <component-mapper\n        name=\"ListViewActionButtons\"\n        [props]=\"{ pConn$: createdViewPConn$, context$ }\"\n        [outputEvents]=\"{ closeActionsDialog: closeActionsDialog }\"\n      ></component-mapper>\n    </div>\n  </div>\n</div>\n\n<div *ngIf=\"bShowModal$ && !bShowAsModal$\">\n  <div id=\"{{ buildName$ }}\">\n    <h3 *ngIf=\"title$ != ''\">{{ title$ }}</h3>\n    <component-mapper\n      name=\"Assignment\"\n      [props]=\"{ pConn$: createdViewPConn$, formGroup$, arChildren$, itemKey$, isCreateStage$: true, updateToken$ }\"\n    ></component-mapper>\n  </div>\n</div>\n\n<div *ngIf=\"bShowCancelAlert$\">\n  <component-mapper\n    name=\"CancelAlert\"\n    [props]=\"{ bShowAlert$: bShowCancelAlert$, pConn$: cancelPConn$ }\"\n    [parent]=\"this\"\n    [outputEvents]=\"{ onAlertState$: onAlertState }\"\n  ></component-mapper>\n</div>\n"]}
@@ -21,18 +21,16 @@ export class ReferenceComponent {
21
21
  static createFullReferencedViewFromRef(inPConn) {
22
22
  // BAIL and ERROR if inPConn is NOT a reference!
23
23
  if (inPConn.getComponentName() !== 'reference') {
24
- // debugger;
25
24
  console.error(`Reference component: createFullReferencedViewFromRef inPConn is NOT a reference! ${inPConn.getComponentName()}`);
26
25
  }
27
- const theResolvedConfigProps = inPConn.resolveConfigProps(inPConn.getConfigProps());
28
26
  const referenceConfig = { ...inPConn.getComponentConfig() } || {};
29
27
  // Since SDK-A implements Reference as static methods and we don't rely on
30
28
  // the Reference component's handling of the visibility prop, we leave it in
31
29
  // (and also leaving the others in for now) so the referenced View can act on
32
30
  // the visibility prop. (The following 3 lines were carried over from React SDK)
33
31
  delete referenceConfig?.name;
34
- // delete referenceConfig?.type;
35
- // delete referenceConfig?.visibility;
32
+ delete referenceConfig?.type;
33
+ delete referenceConfig?.visibility;
36
34
  const viewMetadata = inPConn.getReferencedView();
37
35
  if (!viewMetadata) {
38
36
  console.log('View not found ', inPConn.getComponentConfig());
@@ -47,23 +45,28 @@ export class ReferenceComponent {
47
45
  ...referenceConfig
48
46
  }
49
47
  };
48
+ const theResolvedConfigProps = inPConn.resolveConfigProps(inPConn.getConfigProps());
49
+ const { visibility = true, context, readOnly = false, displayMode = '' } = theResolvedConfigProps;
50
50
  if (ReferenceComponent.bLogging) {
51
- console.log(`Reference: about to call createComponent with pageReference: context: ${theResolvedConfigProps.context}`);
51
+ console.log(`Reference: about to call createComponent with pageReference: context: ${inPConn.getContextName()}`);
52
52
  }
53
53
  const viewComponent = inPConn.createComponent(viewObject, null, null, {
54
- pageReference: theResolvedConfigProps.context
54
+ pageReference: context && context.startsWith('@CLASS') ? '' : context
55
55
  });
56
56
  // updating the referencedComponent should trigger a render
57
57
  const newCompPConnect = viewComponent.getPConnect();
58
58
  newCompPConnect.setInheritedConfig({
59
59
  ...referenceConfig,
60
- readOnly: theResolvedConfigProps.readOnly ? theResolvedConfigProps.readOnly : false,
61
- displayMode: theResolvedConfigProps.displayMode ? theResolvedConfigProps.displayMode : null
60
+ readOnly,
61
+ displayMode
62
62
  });
63
63
  if (ReferenceComponent.bLogging) {
64
64
  console.log(`Angular Reference component: createFullReferencedViewFromRef -> newCompPConnect configProps: ${JSON.stringify(newCompPConnect.getConfigProps())}`);
65
65
  }
66
- return newCompPConnect;
66
+ if (visibility !== false) {
67
+ return newCompPConnect;
68
+ }
69
+ return null;
67
70
  }
68
71
  // STATIC method that other components can call to normalize
69
72
  // a pConn object that might be a 'reference'. If the incoming
@@ -97,7 +100,7 @@ export class ReferenceComponent {
97
100
  // debugger;
98
101
  let theRefViewPConn = this.createFullReferencedViewFromRef(inPConn.getPConnect());
99
102
  // now return its PConnect
100
- theRefViewPConn = theRefViewPConn.getComponent();
103
+ theRefViewPConn = theRefViewPConn?.getComponent();
101
104
  // const theFullReference = theRefViewPConn.getPConnect().getFullReference();
102
105
  // console.log(`theFullReference: ${theFullReference}`);
103
106
  return theRefViewPConn;
@@ -130,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
130
133
  type: Component,
131
134
  args: [{ selector: 'app-reference', standalone: true, template: "<!-- Reference component is all static methods so .html not used -->\n" }]
132
135
  }], ctorParameters: function () { return []; } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reference.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/reference/reference.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/reference/reference.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\n\n/**\n * WARNING: It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\n@Component({\n  selector: 'app-reference',\n  templateUrl: './reference.component.html',\n  styleUrls: ['./reference.component.scss'],\n  standalone: true\n})\nexport class ReferenceComponent {\n  referencedComponent: any = null;\n\n  /* Used to toggle some class-wide logging */\n  private static bLogging = false;\n\n  constructor() {\n    // With new static method approach, this shouldn't be called any more\n    window.alert(`in ReferenceComponent constructor!`);\n\n    console.error(`in ReferenceComponent constructor!`);\n  }\n\n  // onStateChange and updateSelf methods removed from original implementation\n  //  when we moved to the static method implementation.\n\n  // STATIC method to create a normalized PConn (a fully realized View that the 'reference'\n  //  component refers to) from the given pConn. Has to add in some stuff as in the constructor\n  static createFullReferencedViewFromRef(inPConn: any) {\n    // BAIL and ERROR if inPConn is NOT a reference!\n    if (inPConn.getComponentName() !== 'reference') {\n      // debugger;\n\n      console.error(`Reference component: createFullReferencedViewFromRef inPConn is NOT a reference! ${inPConn.getComponentName()}`);\n    }\n\n    const theResolvedConfigProps = inPConn.resolveConfigProps(inPConn.getConfigProps());\n\n    const referenceConfig = { ...inPConn.getComponentConfig() } || {};\n\n    // Since SDK-A implements Reference as static methods and we don't rely on\n    //  the Reference component's handling of the visibility prop, we leave it in\n    //  (and also leaving the others in for now) so the referenced View can act on\n    //  the visibility prop. (The following 3 lines were carried over from React SDK)\n    delete referenceConfig?.name;\n    // delete referenceConfig?.type;\n    // delete referenceConfig?.visibility;\n\n    const viewMetadata = inPConn.getReferencedView();\n\n    if (!viewMetadata) {\n      console.log('View not found ', inPConn.getComponentConfig());\n      return null;\n    }\n\n    // If we get here, we have metadata for a View component...\n    // const referencedComponentName = viewMetadata.type;\n\n    const viewObject = {\n      ...viewMetadata,\n      config: {\n        ...viewMetadata.config,\n        ...referenceConfig\n      }\n    };\n\n    if (ReferenceComponent.bLogging) {\n      console.log(`Reference: about to call createComponent with pageReference: context: ${theResolvedConfigProps.context}`);\n    }\n\n    const viewComponent = inPConn.createComponent(viewObject, null, null, {\n      pageReference: theResolvedConfigProps.context\n    });\n\n    // updating the referencedComponent should trigger a render\n    const newCompPConnect = viewComponent.getPConnect();\n\n    newCompPConnect.setInheritedConfig({\n      ...referenceConfig,\n      readOnly: theResolvedConfigProps.readOnly ? theResolvedConfigProps.readOnly : false,\n      displayMode: theResolvedConfigProps.displayMode ? theResolvedConfigProps.displayMode : null\n    });\n\n    if (ReferenceComponent.bLogging) {\n      console.log(\n        `Angular Reference component: createFullReferencedViewFromRef -> newCompPConnect configProps: ${JSON.stringify(\n          newCompPConnect.getConfigProps()\n        )}`\n      );\n    }\n\n    return newCompPConnect;\n  }\n\n  // STATIC method that other components can call to normalize\n  //  a pConn object that might be a 'reference'. If the incoming\n  //  pConn is a reference, return its dereferenced View PConnect's\n  //  getPConnect. Otherwise, return the passed in pConn unchanged\n  //  inPConn = a PConn object (ex: { getPConnect()} )\n  static normalizePConn(inPConn: any) {\n    // debugger;\n\n    let returnObj = false;\n    let thePConnType = '';\n\n    if (inPConn.getPConnect) {\n      // inPConn is an object (ex: { getPConnect()} ), so we want to return\n      //  any referenced view as the object containing the\n      //  the getPConnect function\n      returnObj = true;\n      thePConnType = inPConn.getPConnect().getComponentName();\n    } else {\n      // inPConn is an object with the PConnect function, so we want\n      //  to return any referenced view as the object containing the\n      //  the c11n function\n      returnObj = false;\n      thePConnType = inPConn.getComponentName();\n    }\n\n    if (thePConnType === 'reference') {\n      if (returnObj) {\n        //  WAS...\n        // const theRefViewPConn = inPConn.getPConnect().getReferencedViewPConnect(true);\n        // Now: ALWAYS calling createFullReferencedViewFromRef to have options, PageReference, etc.\n        //  set correctly in the C11nEnv (PConnect) object\n        // debugger;\n        let theRefViewPConn = this.createFullReferencedViewFromRef(inPConn.getPConnect());\n        // now return its PConnect\n        theRefViewPConn = theRefViewPConn.getComponent();\n\n        // const theFullReference = theRefViewPConn.getPConnect().getFullReference();\n        // console.log(`theFullReference: ${theFullReference}`);\n\n        return theRefViewPConn;\n      }\n      // console.log(`created theFullRefView full reference: ${theFullRefView.getFullReference()}`);\n      // debugger;\n\n      return this.createFullReferencedViewFromRef(inPConn);\n    }\n    return inPConn;\n  }\n\n  // STATIC method that other components can call to normalize\n  //  an array of pConn objects where any of the children might\n  //  be a 'reference'. The array returns an array of children\n  //  where any 'reference' is replaced with its ReferencedView\n  //  inPConnArray is an array of PConn objects or functions.\n  //    Its value is passed to normalizePConn\n\n  static normalizePConnArray(inPConnArray: any) {\n    if (!(inPConnArray?.length > 0)) {\n      // null or empty array, return what was passed in\n      return inPConnArray;\n    }\n\n    return inPConnArray.map(child => {\n      return ReferenceComponent.normalizePConn(child);\n    });\n  }\n}\n","<!-- Reference component is all static methods so .html not used -->\n"]}
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reference.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/reference/reference.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/reference/reference.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\n\n/**\n * WARNING: It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\n@Component({\n  selector: 'app-reference',\n  templateUrl: './reference.component.html',\n  styleUrls: ['./reference.component.scss'],\n  standalone: true\n})\nexport class ReferenceComponent {\n  referencedComponent: any = null;\n\n  /* Used to toggle some class-wide logging */\n  private static bLogging = false;\n\n  constructor() {\n    // With new static method approach, this shouldn't be called any more\n    window.alert(`in ReferenceComponent constructor!`);\n\n    console.error(`in ReferenceComponent constructor!`);\n  }\n\n  // onStateChange and updateSelf methods removed from original implementation\n  //  when we moved to the static method implementation.\n\n  // STATIC method to create a normalized PConn (a fully realized View that the 'reference'\n  //  component refers to) from the given pConn. Has to add in some stuff as in the constructor\n  static createFullReferencedViewFromRef(inPConn: any) {\n    // BAIL and ERROR if inPConn is NOT a reference!\n    if (inPConn.getComponentName() !== 'reference') {\n      console.error(`Reference component: createFullReferencedViewFromRef inPConn is NOT a reference! ${inPConn.getComponentName()}`);\n    }\n\n    const referenceConfig = { ...inPConn.getComponentConfig() } || {};\n\n    // Since SDK-A implements Reference as static methods and we don't rely on\n    //  the Reference component's handling of the visibility prop, we leave it in\n    //  (and also leaving the others in for now) so the referenced View can act on\n    //  the visibility prop. (The following 3 lines were carried over from React SDK)\n    delete referenceConfig?.name;\n    delete referenceConfig?.type;\n    delete referenceConfig?.visibility;\n\n    const viewMetadata = inPConn.getReferencedView();\n\n    if (!viewMetadata) {\n      console.log('View not found ', inPConn.getComponentConfig());\n      return null;\n    }\n\n    // If we get here, we have metadata for a View component...\n    // const referencedComponentName = viewMetadata.type;\n\n    const viewObject = {\n      ...viewMetadata,\n      config: {\n        ...viewMetadata.config,\n        ...referenceConfig\n      }\n    };\n    const theResolvedConfigProps = inPConn.resolveConfigProps(inPConn.getConfigProps());\n    const { visibility = true, context, readOnly = false, displayMode = '' } = theResolvedConfigProps;\n\n    if (ReferenceComponent.bLogging) {\n      console.log(`Reference: about to call createComponent with pageReference: context: ${inPConn.getContextName()}`);\n    }\n\n    const viewComponent = inPConn.createComponent(viewObject, null, null, {\n      pageReference: context && context.startsWith('@CLASS') ? '' : context\n    });\n\n    // updating the referencedComponent should trigger a render\n    const newCompPConnect = viewComponent.getPConnect();\n\n    newCompPConnect.setInheritedConfig({\n      ...referenceConfig,\n      readOnly,\n      displayMode\n    });\n\n    if (ReferenceComponent.bLogging) {\n      console.log(\n        `Angular Reference component: createFullReferencedViewFromRef -> newCompPConnect configProps: ${JSON.stringify(\n          newCompPConnect.getConfigProps()\n        )}`\n      );\n    }\n\n    if (visibility !== false) {\n      return newCompPConnect;\n    }\n\n    return null;\n  }\n\n  // STATIC method that other components can call to normalize\n  //  a pConn object that might be a 'reference'. If the incoming\n  //  pConn is a reference, return its dereferenced View PConnect's\n  //  getPConnect. Otherwise, return the passed in pConn unchanged\n  //  inPConn = a PConn object (ex: { getPConnect()} )\n  static normalizePConn(inPConn: any) {\n    // debugger;\n\n    let returnObj = false;\n    let thePConnType = '';\n\n    if (inPConn.getPConnect) {\n      // inPConn is an object (ex: { getPConnect()} ), so we want to return\n      //  any referenced view as the object containing the\n      //  the getPConnect function\n      returnObj = true;\n      thePConnType = inPConn.getPConnect().getComponentName();\n    } else {\n      // inPConn is an object with the PConnect function, so we want\n      //  to return any referenced view as the object containing the\n      //  the c11n function\n      returnObj = false;\n      thePConnType = inPConn.getComponentName();\n    }\n\n    if (thePConnType === 'reference') {\n      if (returnObj) {\n        //  WAS...\n        // const theRefViewPConn = inPConn.getPConnect().getReferencedViewPConnect(true);\n        // Now: ALWAYS calling createFullReferencedViewFromRef to have options, PageReference, etc.\n        //  set correctly in the C11nEnv (PConnect) object\n        // debugger;\n        let theRefViewPConn = this.createFullReferencedViewFromRef(inPConn.getPConnect());\n        // now return its PConnect\n        theRefViewPConn = theRefViewPConn?.getComponent();\n\n        // const theFullReference = theRefViewPConn.getPConnect().getFullReference();\n        // console.log(`theFullReference: ${theFullReference}`);\n\n        return theRefViewPConn;\n      }\n      // console.log(`created theFullRefView full reference: ${theFullRefView.getFullReference()}`);\n      // debugger;\n\n      return this.createFullReferencedViewFromRef(inPConn);\n    }\n    return inPConn;\n  }\n\n  // STATIC method that other components can call to normalize\n  //  an array of pConn objects where any of the children might\n  //  be a 'reference'. The array returns an array of children\n  //  where any 'reference' is replaced with its ReferencedView\n  //  inPConnArray is an array of PConn objects or functions.\n  //    Its value is passed to normalizePConn\n\n  static normalizePConnArray(inPConnArray: any) {\n    if (!(inPConnArray?.length > 0)) {\n      // null or empty array, return what was passed in\n      return inPConnArray;\n    }\n\n    return inPConnArray.map(child => {\n      return ReferenceComponent.normalizePConn(child);\n    });\n  }\n}\n","<!-- Reference component is all static methods so .html not used -->\n"]}
@@ -88,16 +88,6 @@ export class RootContainerComponent {
88
88
  this.updateSelf();
89
89
  }
90
90
  }
91
- modalVisibleChanged(isVisible) {
92
- if (this.displayOnlyFA$) {
93
- if (isVisible) {
94
- this.bShowRoot$ = false;
95
- }
96
- else {
97
- this.bShowRoot$ = true;
98
- }
99
- }
100
- }
101
91
  updateSelf() {
102
92
  // need to call this.getCurrentCompleteProps (not this.thePConn.getConfigProps)
103
93
  // to get full set of props that affect this component in Redux
@@ -206,7 +196,7 @@ export class RootContainerComponent {
206
196
  }
207
197
  }
208
198
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RootContainerComponent, deps: [{ token: i1.AngularPConnectService }, { token: i2.ProgressSpinnerService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
209
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RootContainerComponent, isStandalone: true, selector: "app-root-container", inputs: { pConn$: "pConn$", displayOnlyFA$: "displayOnlyFA$", isMashup$: "isMashup$" }, ngImport: i0, template: "<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n <div [ngSwitch]=\"componentName$\">\n <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n <!-- <app-reference *ngSwitchCase=\"'reference'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-reference> -->\n <component-mapper\n *ngSwitchCase=\"'ViewContainer'\"\n name=\"ViewContainer\"\n [props]=\"{ pConn$: displayOnlyFA$ ? viewContainerPConn$ : pConn$, displayOnlyFA$ }\"\n ></component-mapper>\n <app-hybrid-view-container *ngSwitchCase=\"'HybridViewContainer'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-hybrid-view-container>\n <app-modal-view-container\n *ngSwitchCase=\"'ModalViewContainer'\"\n [pConn$]=\"pConn$\"\n [displayOnlyFA$]=\"displayOnlyFA$\"\n (modalVisibleChange)=\"modalVisibleChanged($event)\"\n ></app-modal-view-container>\n <div *ngSwitchCase=\"''\"></div>\n <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n <app-modal-view-container\n [pConn$]=\"mConn$\"\n [displayOnlyFA$]=\"displayOnlyFA$\"\n (modalVisibleChange)=\"modalVisibleChanged($event)\"\n ></app-modal-view-container>\n</div>\n", styles: [".progress-box{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-background-color);position:fixed;z-index:99999;top:0rem;left:0rem;opacity:.5}.progress-spinner{text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatProgressSpinnerModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i4.MatProgressSpinner; }), selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i0.forwardRef(function () { return HybridViewContainerComponent; }), selector: "app-hybrid-view-container", inputs: ["pConn$", "formGroup$", "displayOnlyFA$"] }, { kind: "component", type: i0.forwardRef(function () { return ModalViewContainerComponent; }), selector: "app-modal-view-container", inputs: ["pConn$", "displayOnlyFA$"], outputs: ["modalVisibleChange"] }, { kind: "component", type: i0.forwardRef(function () { return PreviewViewContainerComponent; }), selector: "app-preview-view-container", inputs: ["pConn$"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
199
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RootContainerComponent, isStandalone: true, selector: "app-root-container", inputs: { pConn$: "pConn$", displayOnlyFA$: "displayOnlyFA$", isMashup$: "isMashup$" }, ngImport: i0, template: "<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n <div [ngSwitch]=\"componentName$\">\n <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n <component-mapper\n *ngSwitchCase=\"'ViewContainer'\"\n name=\"ViewContainer\"\n [props]=\"{ pConn$: viewContainerPConn$, displayOnlyFA$ }\"\n ></component-mapper>\n <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n <app-modal-view-container [pConn$]=\"mConn$\"></app-modal-view-container>\n</div>\n", styles: [".progress-box{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-background-color);position:fixed;z-index:99999;top:0rem;left:0rem;opacity:.5}.progress-spinner{text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "ngmodule", type: i0.forwardRef(function () { return MatProgressSpinnerModule; }) }, { kind: "component", type: i0.forwardRef(function () { return i4.MatProgressSpinner; }), selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i0.forwardRef(function () { return ModalViewContainerComponent; }), selector: "app-modal-view-container", inputs: ["pConn$"], outputs: ["modalVisibleChange"] }, { kind: "component", type: i0.forwardRef(function () { return PreviewViewContainerComponent; }), selector: "app-preview-view-container", inputs: ["pConn$"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
210
200
  }
211
201
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RootContainerComponent, decorators: [{
212
202
  type: Component,
@@ -217,7 +207,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
217
207
  ModalViewContainerComponent,
218
208
  PreviewViewContainerComponent,
219
209
  forwardRef(() => ComponentMapperComponent)
220
- ], template: "<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n <div [ngSwitch]=\"componentName$\">\n <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n <!-- <app-reference *ngSwitchCase=\"'reference'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-reference> -->\n <component-mapper\n *ngSwitchCase=\"'ViewContainer'\"\n name=\"ViewContainer\"\n [props]=\"{ pConn$: displayOnlyFA$ ? viewContainerPConn$ : pConn$, displayOnlyFA$ }\"\n ></component-mapper>\n <app-hybrid-view-container *ngSwitchCase=\"'HybridViewContainer'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-hybrid-view-container>\n <app-modal-view-container\n *ngSwitchCase=\"'ModalViewContainer'\"\n [pConn$]=\"pConn$\"\n [displayOnlyFA$]=\"displayOnlyFA$\"\n (modalVisibleChange)=\"modalVisibleChanged($event)\"\n ></app-modal-view-container>\n <div *ngSwitchCase=\"''\"></div>\n <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n <app-modal-view-container\n [pConn$]=\"mConn$\"\n [displayOnlyFA$]=\"displayOnlyFA$\"\n (modalVisibleChange)=\"modalVisibleChanged($event)\"\n ></app-modal-view-container>\n</div>\n", styles: [".progress-box{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-background-color);position:fixed;z-index:99999;top:0rem;left:0rem;opacity:.5}.progress-spinner{text-align:center}\n"] }]
210
+ ], template: "<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n <div [ngSwitch]=\"componentName$\">\n <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n <component-mapper\n *ngSwitchCase=\"'ViewContainer'\"\n name=\"ViewContainer\"\n [props]=\"{ pConn$: viewContainerPConn$, displayOnlyFA$ }\"\n ></component-mapper>\n <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n <app-modal-view-container [pConn$]=\"mConn$\"></app-modal-view-container>\n</div>\n", styles: [".progress-box{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-background-color);position:fixed;z-index:99999;top:0rem;left:0rem;opacity:.5}.progress-spinner{text-align:center}\n"] }]
221
211
  }], ctorParameters: function () { return [{ type: i1.AngularPConnectService }, { type: i2.ProgressSpinnerService }, { type: i0.NgZone }]; }, propDecorators: { pConn$: [{
222
212
  type: Input
223
213
  }], displayOnlyFA$: [{
@@ -225,4 +215,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
225
215
  }], isMashup$: [{
226
216
  type: Input
227
217
  }] } });
228
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-container.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { interval, Subscription } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ProgressSpinnerService } from '../../../_messages/progress-spinner.service';\nimport { ReferenceComponent } from '../reference/reference.component';\nimport { PreviewViewContainerComponent } from '../Containers/preview-view-container/preview-view-container.component';\nimport { ModalViewContainerComponent } from '../Containers/modal-view-container/modal-view-container.component';\nimport { HybridViewContainerComponent } from '../Containers/hybrid-view-container/hybrid-view-container.component';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\nconst options = { context: 'app' };\n\n@Component({\n  selector: 'app-root-container',\n  templateUrl: './root-container.component.html',\n  styleUrls: ['./root-container.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatProgressSpinnerModule,\n    HybridViewContainerComponent,\n    ModalViewContainerComponent,\n    PreviewViewContainerComponent,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class RootContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() displayOnlyFA$: boolean;\n  @Input() isMashup$: boolean;\n\n  // For interaction with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  componentName$ = '';\n  bIsProgress$ = false;\n\n  // preview and modalview pConn\n  pvConn$: any = null;\n  mConn$: any = null;\n\n  bShowRoot$ = true;\n\n  progressSpinnerSubscription: Subscription;\n  spinnerTimer: any = null;\n  viewContainerPConn$: any = null;\n  localizedVal: any;\n  localeCategory = 'Messages';\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private psService: ProgressSpinnerService,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    const myContext = 'app';\n\n    const { containers } = PCore.getStore().getState();\n    const items = Object.keys(containers).filter(item => item.includes('root'));\n\n    (PCore.getContainerUtils().getContainerAPI() as any).addContainerItems(items);\n\n    // add preview and modalview containers to redux\n    // keep local copies of the the pConnect that is related\n\n    const configObjPreview = PCore.createPConnect({\n      meta: {\n        type: 'PreviewViewContainer',\n        config: {\n          name: 'preview'\n        }\n      },\n      options\n    });\n\n    this.pvConn$ = configObjPreview.getPConnect();\n\n    const configObjModal = PCore.createPConnect({\n      meta: {\n        type: 'ModalViewContainer',\n        config: {\n          name: 'modal'\n        }\n      },\n      options: {\n        pageReference: 'pyPortal',\n        context: myContext\n      }\n    });\n\n    // clear out hasViewContainer\n    sessionStorage.setItem('hasViewContainer', 'false');\n\n    this.mConn$ = configObjModal.getPConnect();\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    // handle showing and hiding the progress spinner\n    this.progressSpinnerSubscription = this.psService.getMessage().subscribe(message => {\n      this.showHideProgress(message.show);\n    });\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  modalVisibleChanged(isVisible) {\n    if (this.displayOnlyFA$) {\n      if (isVisible) {\n        this.bShowRoot$ = false;\n      } else {\n        this.bShowRoot$ = true;\n      }\n    }\n  }\n\n  updateSelf() {\n    // need to call this.getCurrentCompleteProps (not this.thePConn.getConfigProps)\n    //  to get full set of props that affect this component in Redux\n    const myProps: any = this.angularPConnect.getCurrentCompleteProps(this);\n\n    const renderingModes = ['portal', 'view'];\n    const noPortalMode = 'noPortal';\n\n    const { renderingMode, children, skeleton, routingInfo } = myProps;\n\n    if (routingInfo && renderingModes.includes(renderingMode)) {\n      const { accessedOrder, items } = routingInfo;\n      if (accessedOrder && items) {\n        // bootstrap loadPortal resolves to here\n        const key = accessedOrder[accessedOrder.length - 1];\n        if (items[key] && items[key].view && Object.keys(items[key].view).length > 0) {\n          const itemView = items[key].view;\n\n          const rootObject: any = PCore.createPConnect({\n            meta: itemView,\n            options: {\n              context: items[key].context\n            }\n          });\n\n          setTimeout(() => {\n            // makes sure Angular tracks these changes\n            this.ngZone.run(() => {\n              // the new rootObject may be a 'reference'. So,\n              //  normalize it to get the referencedView if that's the case\n              const theNewPConn = ReferenceComponent.normalizePConn(rootObject.getPConnect());\n              // update ComponentName$ before we update pConn$ to make sure they're in sync\n              //  when rendering...\n              this.componentName$ = theNewPConn.getComponentName();\n\n              this.pConn$ = theNewPConn;\n              // this.pConn$ = rootObject.getPConnect();\n\n              console.log(`RootContainer updated pConn$ to be: ${this.componentName$}`);\n            });\n          });\n        }\n      }\n    } else if (renderingMode === noPortalMode) {\n      // console.log(`RootContainer: renderingMode === noPortalMode: ${noPortalMode}`);\n      this.generateViewContainerForNoPortal();\n    } else if (children && children.length > 0) {\n      // haven't resolved to here\n    } else if (skeleton !== undefined) {\n      // TODO: need to update once skeletons are available;\n    }\n  }\n\n  generateViewContainerForNoPortal() {\n    // bootstrap loadMashup resolves to here\n    const arChildren = this.pConn$.getChildren() as any[];\n    if (arChildren && arChildren.length == 1) {\n      // have to have a quick timeout or get an \"expressions changed\" angular error\n      setTimeout(() => {\n        this.ngZone.run(() => {\n          const localPConn = arChildren[0].getPConnect();\n\n          this.componentName$ = localPConn.getComponentName();\n          if (this.componentName$ === 'ViewContainer') {\n            const configProps: any = this.pConn$.getConfigProps();\n            const viewContConfig = {\n              meta: {\n                type: 'ViewContainer',\n                config: configProps\n              },\n              options\n            };\n\n            this.viewContainerPConn$ = PCore.createPConnect(viewContConfig).getPConnect();\n          }\n          this.bShowRoot$ = true;\n        });\n      });\n    }\n  }\n\n  showHideProgress(bShow: boolean) {\n    // only show spinner after 500ms wait, so if server fast, won't see\n    if (bShow) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        if (!this.spinnerTimer || this.spinnerTimer.isStopped) {\n          this.spinnerTimer = interval(500).subscribe(() => {\n            try {\n              this.spinnerTimer.unsubscribe();\n            } catch (ex) {\n              /* empty */\n            }\n\n            this.ngZone.run(() => {\n              this.bIsProgress$ = true;\n            });\n          });\n        }\n      }\n    } else {\n      if (this.spinnerTimer && !this.spinnerTimer.isStopped) {\n        this.spinnerTimer.unsubscribe();\n      }\n\n      // don't touch bIsProgress$ unless differnent\n      if (bShow != this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        this.ngZone.run(() => {\n          this.bIsProgress$ = bShow;\n        });\n      }\n    }\n  }\n}\n","<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n  <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n  <div [ngSwitch]=\"componentName$\">\n    <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n    <!-- <app-reference *ngSwitchCase=\"'reference'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-reference> -->\n    <component-mapper\n      *ngSwitchCase=\"'ViewContainer'\"\n      name=\"ViewContainer\"\n      [props]=\"{ pConn$: displayOnlyFA$ ? viewContainerPConn$ : pConn$, displayOnlyFA$ }\"\n    ></component-mapper>\n    <app-hybrid-view-container *ngSwitchCase=\"'HybridViewContainer'\" [pConn$]=\"pConn$\" [displayOnlyFA$]=\"displayOnlyFA$\"></app-hybrid-view-container>\n    <app-modal-view-container\n      *ngSwitchCase=\"'ModalViewContainer'\"\n      [pConn$]=\"pConn$\"\n      [displayOnlyFA$]=\"displayOnlyFA$\"\n      (modalVisibleChange)=\"modalVisibleChanged($event)\"\n    ></app-modal-view-container>\n    <div *ngSwitchCase=\"''\"></div>\n    <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n  </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n  <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n  <app-modal-view-container\n    [pConn$]=\"mConn$\"\n    [displayOnlyFA$]=\"displayOnlyFA$\"\n    (modalVisibleChange)=\"modalVisibleChanged($event)\"\n  ></app-modal-view-container>\n</div>\n"]}
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-container.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { interval, Subscription } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ProgressSpinnerService } from '../../../_messages/progress-spinner.service';\nimport { ReferenceComponent } from '../reference/reference.component';\nimport { PreviewViewContainerComponent } from '../Containers/preview-view-container/preview-view-container.component';\nimport { ModalViewContainerComponent } from '../Containers/modal-view-container/modal-view-container.component';\nimport { HybridViewContainerComponent } from '../Containers/hybrid-view-container/hybrid-view-container.component';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\nconst options = { context: 'app' };\n\n@Component({\n  selector: 'app-root-container',\n  templateUrl: './root-container.component.html',\n  styleUrls: ['./root-container.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatProgressSpinnerModule,\n    HybridViewContainerComponent,\n    ModalViewContainerComponent,\n    PreviewViewContainerComponent,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class RootContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() displayOnlyFA$: boolean;\n  @Input() isMashup$: boolean;\n\n  // For interaction with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  componentName$ = '';\n  bIsProgress$ = false;\n\n  // preview and modalview pConn\n  pvConn$: any = null;\n  mConn$: any = null;\n\n  bShowRoot$ = true;\n\n  progressSpinnerSubscription: Subscription;\n  spinnerTimer: any = null;\n  viewContainerPConn$: any = null;\n  localizedVal: any;\n  localeCategory = 'Messages';\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private psService: ProgressSpinnerService,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    const myContext = 'app';\n\n    const { containers } = PCore.getStore().getState();\n    const items = Object.keys(containers).filter(item => item.includes('root'));\n\n    (PCore.getContainerUtils().getContainerAPI() as any).addContainerItems(items);\n\n    // add preview and modalview containers to redux\n    // keep local copies of the the pConnect that is related\n\n    const configObjPreview = PCore.createPConnect({\n      meta: {\n        type: 'PreviewViewContainer',\n        config: {\n          name: 'preview'\n        }\n      },\n      options\n    });\n\n    this.pvConn$ = configObjPreview.getPConnect();\n\n    const configObjModal = PCore.createPConnect({\n      meta: {\n        type: 'ModalViewContainer',\n        config: {\n          name: 'modal'\n        }\n      },\n      options: {\n        pageReference: 'pyPortal',\n        context: myContext\n      }\n    });\n\n    // clear out hasViewContainer\n    sessionStorage.setItem('hasViewContainer', 'false');\n\n    this.mConn$ = configObjModal.getPConnect();\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    // handle showing and hiding the progress spinner\n    this.progressSpinnerSubscription = this.psService.getMessage().subscribe(message => {\n      this.showHideProgress(message.show);\n    });\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  updateSelf() {\n    // need to call this.getCurrentCompleteProps (not this.thePConn.getConfigProps)\n    //  to get full set of props that affect this component in Redux\n    const myProps: any = this.angularPConnect.getCurrentCompleteProps(this);\n\n    const renderingModes = ['portal', 'view'];\n    const noPortalMode = 'noPortal';\n\n    const { renderingMode, children, skeleton, routingInfo } = myProps;\n\n    if (routingInfo && renderingModes.includes(renderingMode)) {\n      const { accessedOrder, items } = routingInfo;\n      if (accessedOrder && items) {\n        // bootstrap loadPortal resolves to here\n        const key = accessedOrder[accessedOrder.length - 1];\n        if (items[key] && items[key].view && Object.keys(items[key].view).length > 0) {\n          const itemView = items[key].view;\n\n          const rootObject: any = PCore.createPConnect({\n            meta: itemView,\n            options: {\n              context: items[key].context\n            }\n          });\n\n          setTimeout(() => {\n            // makes sure Angular tracks these changes\n            this.ngZone.run(() => {\n              // the new rootObject may be a 'reference'. So,\n              //  normalize it to get the referencedView if that's the case\n              const theNewPConn = ReferenceComponent.normalizePConn(rootObject.getPConnect());\n              // update ComponentName$ before we update pConn$ to make sure they're in sync\n              //  when rendering...\n              this.componentName$ = theNewPConn.getComponentName();\n\n              this.pConn$ = theNewPConn;\n              // this.pConn$ = rootObject.getPConnect();\n\n              console.log(`RootContainer updated pConn$ to be: ${this.componentName$}`);\n            });\n          });\n        }\n      }\n    } else if (renderingMode === noPortalMode) {\n      // console.log(`RootContainer: renderingMode === noPortalMode: ${noPortalMode}`);\n      this.generateViewContainerForNoPortal();\n    } else if (children && children.length > 0) {\n      // haven't resolved to here\n    } else if (skeleton !== undefined) {\n      // TODO: need to update once skeletons are available;\n    }\n  }\n\n  generateViewContainerForNoPortal() {\n    // bootstrap loadMashup resolves to here\n    const arChildren = this.pConn$.getChildren() as any[];\n    if (arChildren && arChildren.length == 1) {\n      // have to have a quick timeout or get an \"expressions changed\" angular error\n      setTimeout(() => {\n        this.ngZone.run(() => {\n          const localPConn = arChildren[0].getPConnect();\n\n          this.componentName$ = localPConn.getComponentName();\n          if (this.componentName$ === 'ViewContainer') {\n            const configProps: any = this.pConn$.getConfigProps();\n            const viewContConfig = {\n              meta: {\n                type: 'ViewContainer',\n                config: configProps\n              },\n              options\n            };\n\n            this.viewContainerPConn$ = PCore.createPConnect(viewContConfig).getPConnect();\n          }\n          this.bShowRoot$ = true;\n        });\n      });\n    }\n  }\n\n  showHideProgress(bShow: boolean) {\n    // only show spinner after 500ms wait, so if server fast, won't see\n    if (bShow) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        if (!this.spinnerTimer || this.spinnerTimer.isStopped) {\n          this.spinnerTimer = interval(500).subscribe(() => {\n            try {\n              this.spinnerTimer.unsubscribe();\n            } catch (ex) {\n              /* empty */\n            }\n\n            this.ngZone.run(() => {\n              this.bIsProgress$ = true;\n            });\n          });\n        }\n      }\n    } else {\n      if (this.spinnerTimer && !this.spinnerTimer.isStopped) {\n        this.spinnerTimer.unsubscribe();\n      }\n\n      // don't touch bIsProgress$ unless differnent\n      if (bShow != this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        this.ngZone.run(() => {\n          this.bIsProgress$ = bShow;\n        });\n      }\n    }\n  }\n}\n","<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n  <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n  <div [ngSwitch]=\"componentName$\">\n    <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n    <component-mapper\n      *ngSwitchCase=\"'ViewContainer'\"\n      name=\"ViewContainer\"\n      [props]=\"{ pConn$: viewContainerPConn$, displayOnlyFA$ }\"\n    ></component-mapper>\n    <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n  </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n  <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n  <app-modal-view-container [pConn$]=\"mConn$\"></app-modal-view-container>\n</div>\n"]}