@pega/angular-sdk-components 0.23.3 → 0.23.4

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.
@@ -168,7 +168,7 @@ export class CaseViewComponent {
168
168
  const editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');
169
169
  const actionsAPI = this.pConn$.getActionsApi();
170
170
  const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);
171
- openLocalAction(editAction.ID, { ...editAction });
171
+ openLocalAction(editAction.ID, { ...editAction, containerName: 'modal', type: 'express' });
172
172
  }
173
173
  _menuActionClick(data) {
174
174
  const actionsAPI = this.pConn$.getActionsApi();
@@ -193,4 +193,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
193
193
  }], displayOnlyFA$: [{
194
194
  type: Input
195
195
  }] } });
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-view.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/case-view/case-view.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/case-view/case-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { interval } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface CaseViewProps {\n  // If any, enter additional props that only exist on this component\n  icon: string;\n  subheader: string;\n  header: string;\n}\n\n@Component({\n  selector: 'app-case-view',\n  templateUrl: './case-view.component.html',\n  styleUrls: ['./case-view.component.scss'],\n  providers: [Utils],\n  standalone: true,\n  imports: [CommonModule, MatToolbarModule, MatButtonModule, MatMenuModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class CaseViewComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n  @Input() displayOnlyFA$: boolean;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n  configProps$: CaseViewProps;\n\n  arChildren$: any[];\n\n  heading$ = '';\n  id$ = '';\n  status$ = '';\n  caseTabs$: any[] = [];\n  svgCase$: string;\n  tabData$: any;\n\n  mainTabs: any;\n  mainTabData: any;\n\n  arAvailableActions$: any[] = [];\n  arAvailabeProcesses$: any[] = [];\n\n  caseSummaryPConn$: any;\n  currentCaseID = '';\n  editAction: boolean;\n  bHasNewAttachments = false;\n  localizedVal: any;\n  localeCategory = 'CaseView';\n  localeKey: string;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\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    // this.updateSelf();\n    this.checkAndUpdate();\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  checkAndUpdate() {\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    // ONLY call updateSelf when the component should update\n    //    AND removing the \"gate\" that was put there since shouldComponentUpdate\n    //      should be the real \"gate\"\n    if (bUpdateSelf) {\n      // generally, don't want to refresh everything when data changes in caseView, it is usually the\n      // case summary.  But check if the case ID changes, this means a different case and we should\n      // update all.\n      if (this.hasCaseIDChanged()) {\n        this.fullUpdate();\n\n        // update okToInitFlowContainer, because case view was drawn, flow container will need to be init\n        // to match Nebula/Constellation\n        sessionStorage.setItem('okToInitFlowContainer', 'true');\n      } else {\n        this.updateHeaderAndSummary();\n      }\n    }\n  }\n\n  hasCaseIDChanged(): boolean {\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    if (this.currentCaseID !== this.pConn$.getDataObject().caseInfo.ID) {\n      // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n      this.currentCaseID = this.pConn$.getDataObject().caseInfo.ID;\n      return true;\n    }\n    return false;\n  }\n\n  updateHeaderAndSummary() {\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CaseViewProps;\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const hasNewAttachments = this.pConn$.getDataObject().caseInfo?.hasNewAttachments;\n\n    if (hasNewAttachments !== this.bHasNewAttachments) {\n      this.bHasNewAttachments = hasNewAttachments;\n      if (this.bHasNewAttachments) {\n        // @ts-ignore - Argument of type 'boolean' is not assignable to parameter of type 'object'\n        PCore.getPubSubUtils().publish((PCore.getEvents().getCaseEvent() as any).CASE_ATTACHMENTS_UPDATED_FROM_CASEVIEW, true);\n      }\n    }\n\n    const kids = this.pConn$.getChildren() as any[];\n    for (const kid of kids) {\n      const meta = kid.getPConnect().getRawMetadata();\n      if (meta.type.toLowerCase() == 'region' && meta.name.toLowerCase() == 'summary') {\n        this.caseSummaryPConn$ = kid.getPConnect().getChildren()[0].getPConnect();\n      }\n    }\n\n    // have to put in a timeout, otherwise get an angular change event error\n    const timer = interval(100).subscribe(() => {\n      timer.unsubscribe();\n\n      this.heading$ = PCore.getLocaleUtils().getLocaleValue(this.configProps$.header, '', this.localeKey);\n      this.id$ = this.configProps$.subheader;\n      // @ts-ignore - second parameter pageReference for getValue method should be optional\n      this.status$ = this.pConn$.getValue('.pyStatusWork');\n    });\n  }\n\n  fullUpdate() {\n    this.caseTabs$ = [];\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CaseViewProps;\n    // let caseTypeID = this.configProps$.ruleClass;\n    // let caseTypeName = this.configProps$.header;\n    // this.localeKey = `${caseTypeID}!CASE!${caseTypeName}`.toUpperCase();\n    this.localeKey = `${this.pConn$.getCaseInfo().getClassName()}!CASE!${this.pConn$.getCaseInfo().getName()}`.toUpperCase();\n    this.updateHeaderAndSummary();\n\n    this.arChildren$ = this.pConn$.getChildren() as any[];\n\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const caseInfo = this.pConn$.getDataObject().caseInfo;\n    this.currentCaseID = caseInfo.ID;\n    this.arAvailableActions$ = caseInfo?.availableActions ? caseInfo.availableActions : [];\n    this.editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');\n    this.arAvailabeProcesses$ = caseInfo?.availableProcesses ? caseInfo.availableProcesses : [];\n\n    this.svgCase$ = this.utils.getImageSrc(this.configProps$.icon, this.utils.getSDKStaticContentUrl());\n\n    // this.utils.consoleKidDump(this.pConn$);\n\n    if (!this.displayOnlyFA$) {\n      for (const kid of this.arChildren$) {\n        const kidPConn = kid.getPConnect();\n        if (kidPConn.getRawMetadata().name == 'Tabs') {\n          this.mainTabs = kid;\n          this.mainTabData = this.mainTabs.getPConnect().getChildren();\n        }\n      }\n\n      this.generateTabsData();\n    }\n  }\n\n  generateTabsData() {\n    this.mainTabs\n      .getPConnect()\n      .getChildren()\n      ?.forEach((child, i) => {\n        const config = child.getPConnect().resolveConfigProps(child.getPConnect().getRawMetadata()).config;\n        let { label } = config;\n        const { inheritedProps, visibility } = config;\n        // For some tabs, \"label\" property is not avaialable in theTabCompConfig, so will get them from inheritedProps\n        if (!label) {\n          inheritedProps.forEach((inheritedProp: any) => {\n            if (inheritedProp.prop === 'label') {\n              label = inheritedProp.value;\n            }\n          });\n        }\n        // We'll display the tabs when either visibility property doesn't exist or is true(if exists)\n        if (visibility === undefined || visibility === true) {\n          this.caseTabs$.push({ name: label, id: i });\n          // To make first visible tab display at the beginning\n          if (!this.tabData$) {\n            this.tabData$ = { type: 'DeferLoad', config: child.getPConnect().getRawMetadata().config };\n          }\n        }\n      });\n  }\n\n  updateSelf() {\n    this.fullUpdate();\n  }\n\n  onTabClick(tab: any) {\n    this.tabData$ = this.mainTabData[tab].getPConnect().getRawMetadata();\n    this.cdRef.detectChanges();\n  }\n\n  _editClick() {\n    const editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);\n\n    openLocalAction(editAction.ID, { ...editAction });\n  }\n\n  _menuActionClick(data) {\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);\n\n    openLocalAction(data.ID, { ...data, containerName: 'modal', type: 'express' });\n  }\n\n  _menuProcessClick(data) {\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openProcessAction = actionsAPI.openProcessAction.bind(actionsAPI);\n\n    openProcessAction(data.ID, { ...data });\n  }\n}\n","<div class=\"psdk-case-view\" id=\"case-view\">\n  <div *ngIf=\"!displayOnlyFA$\" class=\"psdk-case-view-info\">\n    <mat-toolbar color=\"primary\" class=\"psdk-case-view-toolbar\">\n      <mat-toolbar-row style=\"padding-left: 1rem\">\n        <div class=\"psdk-case-icon-div\">\n          <img class=\"psdk-case-svg-icon\" src=\"{{ svgCase$ }}\" />\n        </div>\n        <div class=\"psdk-case-view-heading\">\n          <div id=\"current-caseID\" [hidden]=\"true\">{{ currentCaseID }}</div>\n          <div class=\"psdk-case-view-heading-id\" id=\"caseId\">{{ id$ }}</div>\n          <div>\n            <h1>{{ heading$ }}</h1>\n          </div>\n        </div>\n      </mat-toolbar-row>\n    </mat-toolbar>\n\n    <div class=\"psdk-case-view-buttons\">\n      <button *ngIf=\"editAction\" mat-raised-button color=\"secondary\" (click)=\"_editClick()\">{{ localizedVal('Edit', localeCategory) }}</button>\n      <button mat-raised-button color=\"secondary\" [matMenuTriggerFor]=\"actionMenu\">{{ localizedVal('Actions...', localeCategory) }}</button>\n      <mat-menu #actionMenu=\"matMenu\" overlapTrigger=\"false\">\n        <ng-container *ngFor=\"let action of arAvailableActions$\">\n          <button mat-menu-item (click)=\"_menuActionClick(action)\">\n            {{ localizedVal(action.name, '', localeKey) }}\n          </button>\n        </ng-container>\n        <ng-container *ngFor=\"let process of arAvailabeProcesses$\">\n          <button mat-menu-item (click)=\"_menuProcessClick(process)\">\n            {{ process.name }}\n          </button>\n        </ng-container>\n      </mat-menu>\n    </div>\n\n    <div class=\"psdk-case-view-divider\"></div>\n\n    <div class=\"psdk-case-view-summary\">\n      <component-mapper name=\"CaseSummary\" [props]=\"{ pConn$: caseSummaryPConn$ }\"></component-mapper>\n    </div>\n\n    <component-mapper\n      *ngIf=\"caseTabs$.length > 1\"\n      name=\"VerticalTabs\"\n      [props]=\"{ tabConfig$: caseTabs$ }\"\n      [parent]=\"this\"\n      [outputEvents]=\"{ tabClick: onTabClick }\"\n    ></component-mapper>\n  </div>\n  <div class=\"psdk-case-view-main\">\n    <div *ngIf=\"!displayOnlyFA$\">\n      <div *ngFor=\"let kid of arChildren$\">\n        <div\n          *ngIf=\"\n            kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name.toLowerCase() == 'stages'\n          \"\n        >\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect() }\"></component-mapper>\n        </div>\n      </div>\n    </div>\n\n    <div *ngFor=\"let kid of arChildren$\">\n      <div\n        *ngIf=\"kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name.toLowerCase() == 'todo'\"\n      >\n        <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect(), formGroup$ }\"></component-mapper>\n      </div>\n    </div>\n\n    <div *ngFor=\"let kid of arChildren$\">\n      <div *ngIf=\"kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name == 'Main'\">\n        <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect(), formGroup$ }\"></component-mapper>\n      </div>\n    </div>\n\n    <div *ngIf=\"!displayOnlyFA$\">\n      <component-mapper name=\"DeferLoad\" [props]=\"{ pConn$, loadData$: tabData$, name: tabData$?.config?.name }\"></component-mapper>\n    </div>\n  </div>\n  <div *ngIf=\"!displayOnlyFA$\">\n    <div *ngIf=\"arChildren$\" class=\"psdk-case-view-utilities\">\n      <div *ngFor=\"let kid of arChildren$\">\n        <div *ngIf=\"kid.getPConnect().getRawMetadata()?.type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata()?.name == 'Utilities'\">\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect() }\"></component-mapper>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-view.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/case-view/case-view.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/case-view/case-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { interval } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface CaseViewProps {\n  // If any, enter additional props that only exist on this component\n  icon: string;\n  subheader: string;\n  header: string;\n}\n\n@Component({\n  selector: 'app-case-view',\n  templateUrl: './case-view.component.html',\n  styleUrls: ['./case-view.component.scss'],\n  providers: [Utils],\n  standalone: true,\n  imports: [CommonModule, MatToolbarModule, MatButtonModule, MatMenuModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class CaseViewComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n  @Input() displayOnlyFA$: boolean;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n  configProps$: CaseViewProps;\n\n  arChildren$: any[];\n\n  heading$ = '';\n  id$ = '';\n  status$ = '';\n  caseTabs$: any[] = [];\n  svgCase$: string;\n  tabData$: any;\n\n  mainTabs: any;\n  mainTabData: any;\n\n  arAvailableActions$: any[] = [];\n  arAvailabeProcesses$: any[] = [];\n\n  caseSummaryPConn$: any;\n  currentCaseID = '';\n  editAction: boolean;\n  bHasNewAttachments = false;\n  localizedVal: any;\n  localeCategory = 'CaseView';\n  localeKey: string;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\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    // this.updateSelf();\n    this.checkAndUpdate();\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  checkAndUpdate() {\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    // ONLY call updateSelf when the component should update\n    //    AND removing the \"gate\" that was put there since shouldComponentUpdate\n    //      should be the real \"gate\"\n    if (bUpdateSelf) {\n      // generally, don't want to refresh everything when data changes in caseView, it is usually the\n      // case summary.  But check if the case ID changes, this means a different case and we should\n      // update all.\n      if (this.hasCaseIDChanged()) {\n        this.fullUpdate();\n\n        // update okToInitFlowContainer, because case view was drawn, flow container will need to be init\n        // to match Nebula/Constellation\n        sessionStorage.setItem('okToInitFlowContainer', 'true');\n      } else {\n        this.updateHeaderAndSummary();\n      }\n    }\n  }\n\n  hasCaseIDChanged(): boolean {\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    if (this.currentCaseID !== this.pConn$.getDataObject().caseInfo.ID) {\n      // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n      this.currentCaseID = this.pConn$.getDataObject().caseInfo.ID;\n      return true;\n    }\n    return false;\n  }\n\n  updateHeaderAndSummary() {\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CaseViewProps;\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const hasNewAttachments = this.pConn$.getDataObject().caseInfo?.hasNewAttachments;\n\n    if (hasNewAttachments !== this.bHasNewAttachments) {\n      this.bHasNewAttachments = hasNewAttachments;\n      if (this.bHasNewAttachments) {\n        // @ts-ignore - Argument of type 'boolean' is not assignable to parameter of type 'object'\n        PCore.getPubSubUtils().publish((PCore.getEvents().getCaseEvent() as any).CASE_ATTACHMENTS_UPDATED_FROM_CASEVIEW, true);\n      }\n    }\n\n    const kids = this.pConn$.getChildren() as any[];\n    for (const kid of kids) {\n      const meta = kid.getPConnect().getRawMetadata();\n      if (meta.type.toLowerCase() == 'region' && meta.name.toLowerCase() == 'summary') {\n        this.caseSummaryPConn$ = kid.getPConnect().getChildren()[0].getPConnect();\n      }\n    }\n\n    // have to put in a timeout, otherwise get an angular change event error\n    const timer = interval(100).subscribe(() => {\n      timer.unsubscribe();\n\n      this.heading$ = PCore.getLocaleUtils().getLocaleValue(this.configProps$.header, '', this.localeKey);\n      this.id$ = this.configProps$.subheader;\n      // @ts-ignore - second parameter pageReference for getValue method should be optional\n      this.status$ = this.pConn$.getValue('.pyStatusWork');\n    });\n  }\n\n  fullUpdate() {\n    this.caseTabs$ = [];\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CaseViewProps;\n    // let caseTypeID = this.configProps$.ruleClass;\n    // let caseTypeName = this.configProps$.header;\n    // this.localeKey = `${caseTypeID}!CASE!${caseTypeName}`.toUpperCase();\n    this.localeKey = `${this.pConn$.getCaseInfo().getClassName()}!CASE!${this.pConn$.getCaseInfo().getName()}`.toUpperCase();\n    this.updateHeaderAndSummary();\n\n    this.arChildren$ = this.pConn$.getChildren() as any[];\n\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const caseInfo = this.pConn$.getDataObject().caseInfo;\n    this.currentCaseID = caseInfo.ID;\n    this.arAvailableActions$ = caseInfo?.availableActions ? caseInfo.availableActions : [];\n    this.editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');\n    this.arAvailabeProcesses$ = caseInfo?.availableProcesses ? caseInfo.availableProcesses : [];\n\n    this.svgCase$ = this.utils.getImageSrc(this.configProps$.icon, this.utils.getSDKStaticContentUrl());\n\n    // this.utils.consoleKidDump(this.pConn$);\n\n    if (!this.displayOnlyFA$) {\n      for (const kid of this.arChildren$) {\n        const kidPConn = kid.getPConnect();\n        if (kidPConn.getRawMetadata().name == 'Tabs') {\n          this.mainTabs = kid;\n          this.mainTabData = this.mainTabs.getPConnect().getChildren();\n        }\n      }\n\n      this.generateTabsData();\n    }\n  }\n\n  generateTabsData() {\n    this.mainTabs\n      .getPConnect()\n      .getChildren()\n      ?.forEach((child, i) => {\n        const config = child.getPConnect().resolveConfigProps(child.getPConnect().getRawMetadata()).config;\n        let { label } = config;\n        const { inheritedProps, visibility } = config;\n        // For some tabs, \"label\" property is not avaialable in theTabCompConfig, so will get them from inheritedProps\n        if (!label) {\n          inheritedProps.forEach((inheritedProp: any) => {\n            if (inheritedProp.prop === 'label') {\n              label = inheritedProp.value;\n            }\n          });\n        }\n        // We'll display the tabs when either visibility property doesn't exist or is true(if exists)\n        if (visibility === undefined || visibility === true) {\n          this.caseTabs$.push({ name: label, id: i });\n          // To make first visible tab display at the beginning\n          if (!this.tabData$) {\n            this.tabData$ = { type: 'DeferLoad', config: child.getPConnect().getRawMetadata().config };\n          }\n        }\n      });\n  }\n\n  updateSelf() {\n    this.fullUpdate();\n  }\n\n  onTabClick(tab: any) {\n    this.tabData$ = this.mainTabData[tab].getPConnect().getRawMetadata();\n    this.cdRef.detectChanges();\n  }\n\n  _editClick() {\n    const editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);\n\n    openLocalAction(editAction.ID, { ...editAction, containerName: 'modal', type: 'express' });\n  }\n\n  _menuActionClick(data) {\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);\n\n    openLocalAction(data.ID, { ...data, containerName: 'modal', type: 'express' });\n  }\n\n  _menuProcessClick(data) {\n    const actionsAPI = this.pConn$.getActionsApi();\n    const openProcessAction = actionsAPI.openProcessAction.bind(actionsAPI);\n\n    openProcessAction(data.ID, { ...data });\n  }\n}\n","<div class=\"psdk-case-view\" id=\"case-view\">\n  <div *ngIf=\"!displayOnlyFA$\" class=\"psdk-case-view-info\">\n    <mat-toolbar color=\"primary\" class=\"psdk-case-view-toolbar\">\n      <mat-toolbar-row style=\"padding-left: 1rem\">\n        <div class=\"psdk-case-icon-div\">\n          <img class=\"psdk-case-svg-icon\" src=\"{{ svgCase$ }}\" />\n        </div>\n        <div class=\"psdk-case-view-heading\">\n          <div id=\"current-caseID\" [hidden]=\"true\">{{ currentCaseID }}</div>\n          <div class=\"psdk-case-view-heading-id\" id=\"caseId\">{{ id$ }}</div>\n          <div>\n            <h1>{{ heading$ }}</h1>\n          </div>\n        </div>\n      </mat-toolbar-row>\n    </mat-toolbar>\n\n    <div class=\"psdk-case-view-buttons\">\n      <button *ngIf=\"editAction\" mat-raised-button color=\"secondary\" (click)=\"_editClick()\">{{ localizedVal('Edit', localeCategory) }}</button>\n      <button mat-raised-button color=\"secondary\" [matMenuTriggerFor]=\"actionMenu\">{{ localizedVal('Actions...', localeCategory) }}</button>\n      <mat-menu #actionMenu=\"matMenu\" overlapTrigger=\"false\">\n        <ng-container *ngFor=\"let action of arAvailableActions$\">\n          <button mat-menu-item (click)=\"_menuActionClick(action)\">\n            {{ localizedVal(action.name, '', localeKey) }}\n          </button>\n        </ng-container>\n        <ng-container *ngFor=\"let process of arAvailabeProcesses$\">\n          <button mat-menu-item (click)=\"_menuProcessClick(process)\">\n            {{ process.name }}\n          </button>\n        </ng-container>\n      </mat-menu>\n    </div>\n\n    <div class=\"psdk-case-view-divider\"></div>\n\n    <div class=\"psdk-case-view-summary\">\n      <component-mapper name=\"CaseSummary\" [props]=\"{ pConn$: caseSummaryPConn$ }\"></component-mapper>\n    </div>\n\n    <component-mapper\n      *ngIf=\"caseTabs$.length > 1\"\n      name=\"VerticalTabs\"\n      [props]=\"{ tabConfig$: caseTabs$ }\"\n      [parent]=\"this\"\n      [outputEvents]=\"{ tabClick: onTabClick }\"\n    ></component-mapper>\n  </div>\n  <div class=\"psdk-case-view-main\">\n    <div *ngIf=\"!displayOnlyFA$\">\n      <div *ngFor=\"let kid of arChildren$\">\n        <div\n          *ngIf=\"\n            kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name.toLowerCase() == 'stages'\n          \"\n        >\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect() }\"></component-mapper>\n        </div>\n      </div>\n    </div>\n\n    <div *ngFor=\"let kid of arChildren$\">\n      <div\n        *ngIf=\"kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name.toLowerCase() == 'todo'\"\n      >\n        <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect(), formGroup$ }\"></component-mapper>\n      </div>\n    </div>\n\n    <div *ngFor=\"let kid of arChildren$\">\n      <div *ngIf=\"kid.getPConnect().getRawMetadata().type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata().name == 'Main'\">\n        <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect(), formGroup$ }\"></component-mapper>\n      </div>\n    </div>\n\n    <div *ngIf=\"!displayOnlyFA$\">\n      <component-mapper name=\"DeferLoad\" [props]=\"{ pConn$, loadData$: tabData$, name: tabData$?.config?.name }\"></component-mapper>\n    </div>\n  </div>\n  <div *ngIf=\"!displayOnlyFA$\">\n    <div *ngIf=\"arChildren$\" class=\"psdk-case-view-utilities\">\n      <div *ngFor=\"let kid of arChildren$\">\n        <div *ngIf=\"kid.getPConnect().getRawMetadata()?.type.toLowerCase() == 'region' && kid.getPConnect().getRawMetadata()?.name == 'Utilities'\">\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.getPConnect() }\"></component-mapper>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -8200,7 +8200,7 @@ class CaseViewComponent {
8200
8200
  const editAction = this.arAvailableActions$.find(action => action.ID === 'pyUpdateCaseDetails');
8201
8201
  const actionsAPI = this.pConn$.getActionsApi();
8202
8202
  const openLocalAction = actionsAPI.openLocalAction.bind(actionsAPI);
8203
- openLocalAction(editAction.ID, { ...editAction });
8203
+ openLocalAction(editAction.ID, { ...editAction, containerName: 'modal', type: 'express' });
8204
8204
  }
8205
8205
  _menuActionClick(data) {
8206
8206
  const actionsAPI = this.pConn$.getActionsApi();