@pega/angular-sdk-components 0.23.3 → 0.23.5

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 (30) hide show
  1. package/esm2022/lib/_bridge/helpers/sdk-pega-component-map.mjs +61 -52
  2. package/esm2022/lib/_components/designSystemExtension/field-group/field-group.component.mjs +31 -0
  3. package/esm2022/lib/_components/designSystemExtension/material-details-fields/material-details-fields.component.mjs +3 -3
  4. package/esm2022/lib/_components/field/check-box/check-box.component.mjs +5 -3
  5. package/esm2022/lib/_components/field/date/date.component.mjs +9 -3
  6. package/esm2022/lib/_components/field/group/group.component.mjs +61 -0
  7. package/esm2022/lib/_components/template/app-shell/app-shell.component.mjs +3 -3
  8. package/esm2022/lib/_components/template/case-view/case-view.component.mjs +2 -2
  9. package/esm2022/lib/_components/template/default-form/default-form.component.mjs +3 -3
  10. package/esm2022/lib/_components/template/details/details.component.mjs +3 -2
  11. package/esm2022/lib/_helpers/formatters/boolean.mjs +20 -0
  12. package/esm2022/lib/_helpers/formatters/common.mjs +16 -0
  13. package/esm2022/lib/_helpers/formatters/currency.mjs +68 -0
  14. package/esm2022/lib/_helpers/formatters/date.mjs +69 -0
  15. package/esm2022/lib/_helpers/formatters/index.mjs +110 -0
  16. package/esm2022/public-api.mjs +2 -1
  17. package/fesm2022/pega-angular-sdk-components.mjs +13897 -13534
  18. package/fesm2022/pega-angular-sdk-components.mjs.map +1 -1
  19. package/lib/_bridge/helpers/sdk-pega-component-map.d.ts +55 -51
  20. package/lib/_components/designSystemExtension/field-group/field-group.component.d.ts +12 -0
  21. package/lib/_components/field/check-box/check-box.component.d.ts +4 -0
  22. package/lib/_components/field/date/date.component.d.ts +1 -0
  23. package/lib/_components/field/group/group.component.d.ts +33 -0
  24. package/lib/_helpers/formatters/boolean.d.ts +4 -0
  25. package/lib/_helpers/formatters/common.d.ts +2 -0
  26. package/lib/_helpers/formatters/currency.d.ts +9 -0
  27. package/lib/_helpers/formatters/date.d.ts +10 -0
  28. package/lib/_helpers/formatters/index.d.ts +18 -0
  29. package/package.json +1 -1
  30. package/public-api.d.ts +1 -0
@@ -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"]}
@@ -48,14 +48,14 @@ export class DefaultFormComponent {
48
48
  this.arChildren$ = ReferenceComponent.normalizePConnArray(kids[0].getPConnect().getChildren());
49
49
  }
50
50
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DefaultFormComponent, deps: [{ token: i1.TemplateUtils }], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DefaultFormComponent, isStandalone: true, selector: "app-default-form", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, ngImport: i0, template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DefaultFormComponent, isStandalone: true, selector: "app-default-form", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, ngImport: i0, template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));column-gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);column-gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);column-gap:1rem}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-one-column .grid-column{grid-column:1}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
52
52
  }
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DefaultFormComponent, decorators: [{
54
54
  type: Component,
55
- args: [{ selector: 'app-default-form', standalone: true, imports: [CommonModule, forwardRef(() => ComponentMapperComponent)], template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"] }]
55
+ args: [{ selector: 'app-default-form', standalone: true, imports: [CommonModule, forwardRef(() => ComponentMapperComponent)], template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));column-gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);column-gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);column-gap:1rem}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-one-column .grid-column{grid-column:1}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"] }]
56
56
  }], ctorParameters: function () { return [{ type: i1.TemplateUtils }]; }, propDecorators: { pConn$: [{
57
57
  type: Input
58
58
  }], formGroup$: [{
59
59
  type: Input
60
60
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOERBQThELENBQUM7Ozs7QUFpQnhHLE1BQU0sT0FBTyxvQkFBb0I7SUFzQi9CLFlBQW9CLGFBQTRCO1FBQTVCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBWGhELHdCQUFtQixHQUFHO1lBQ3BCLFNBQVM7WUFDVCxhQUFhO1lBQ2IsU0FBUztZQUNULGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIsbUJBQW1CO1lBQ25CLG1CQUFtQjtZQUNuQixjQUFjO1NBQ2YsQ0FBQztJQUVpRCxDQUFDO0lBRXBELFFBQVE7UUFDTixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBc0IsQ0FBQztRQUNyRSxJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsRUFBRSxRQUFRLENBQUM7UUFDdEMsTUFBTSxTQUFTLEdBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxDQUFDO1FBQzlELElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxFQUFFLFNBQVMsQ0FBQztRQUN0QyxJQUFJLENBQUMsS0FBSyxHQUFHLFNBQVMsRUFBRSxLQUFLLENBQUM7UUFDOUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQVcsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBRS9GLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztRQUNoRSxRQUFRLE9BQU8sRUFBRTtZQUNmLEtBQUssR0FBRztnQkFDTixJQUFJLENBQUMsU0FBUyxHQUFHLDhCQUE4QixDQUFDO2dCQUNoRCxNQUFNO1lBQ1IsS0FBSyxHQUFHO2dCQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07WUFDUixLQUFLLEdBQUc7Z0JBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxnQ0FBZ0MsQ0FBQztnQkFDbEQsTUFBTTtZQUNSO2dCQUNFLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07U0FDVDtRQUVELGdEQUFnRDtRQUNoRCw0REFBNEQ7UUFDNUQsa0JBQWtCO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsa0JBQWtCLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDakcsQ0FBQzsrR0FyRFUsb0JBQW9CO21HQUFwQixvQkFBb0Isb0lDckJqQyw0M0JBbUJBLDhvQkRBWSxZQUFZLDBmQUFtQix3QkFBd0I7OzRGQUV0RCxvQkFBb0I7a0JBUGhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBR2hCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUMsQ0FBQztvR0FHMUQsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBSZWZlcmVuY2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9pbmZyYS9yZWZlcmVuY2UvcmVmZXJlbmNlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21wb25lbnRNYXBwZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9fYnJpZGdlL2NvbXBvbmVudC1tYXBwZXIvY29tcG9uZW50LW1hcHBlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGVtcGxhdGVVdGlscyB9IGZyb20gJy4uLy4uLy4uL19oZWxwZXJzL3RlbXBsYXRlLXV0aWxzJztcblxuaW50ZXJmYWNlIERlZmF1bHRGb3JtUHJvcHMge1xuICAvLyBJZiBhbnksIGVudGVyIGFkZGl0aW9uYWwgcHJvcHMgdGhhdCBvbmx5IGV4aXN0IG9uIHRoaXMgY29tcG9uZW50XG4gIE51bUNvbHM6IHN0cmluZztcbiAgdGVtcGxhdGU6IHN0cmluZztcbiAgaW5zdHJ1Y3Rpb25zOiBzdHJpbmc7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1kZWZhdWx0LWZvcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIGZvcndhcmRSZWYoKCkgPT4gQ29tcG9uZW50TWFwcGVyQ29tcG9uZW50KV1cbn0pXG5leHBvcnQgY2xhc3MgRGVmYXVsdEZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwQ29ubiQ6IHR5cGVvZiBQQ29ubmVjdDtcbiAgQElucHV0KCkgZm9ybUdyb3VwJDogRm9ybUdyb3VwO1xuXG4gIGFyQ2hpbGRyZW4kOiBhbnlbXTtcbiAgZGl2Q2xhc3MkOiBzdHJpbmc7XG4gIHRlbXBsYXRlOiBhbnk7XG4gIHNob3dMYWJlbDogYW55O1xuICBsYWJlbDogYW55O1xuICBpbnN0cnVjdGlvbnM6IHN0cmluZztcblxuICBOT19IRUFERVJfVEVNUExBVEVTID0gW1xuICAgICdTdWJUYWJzJyxcbiAgICAnU2ltcGxlVGFibGUnLFxuICAgICdEZXRhaWxzJyxcbiAgICAnRGV0YWlsc1R3b0NvbHVtbicsXG4gICAgJ0RldGFpbHNUaHJlZUNvbHVtbicsXG4gICAgJ05hcnJvd1dpZGVEZXRhaWxzJyxcbiAgICAnV2lkZU5hcnJvd0RldGFpbHMnLFxuICAgICdDb25maXJtYXRpb24nXG4gIF07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0ZW1wbGF0ZVV0aWxzOiBUZW1wbGF0ZVV0aWxzKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGNvbmZpZ1Byb3BzID0gdGhpcy5wQ29ubiQuZ2V0Q29uZmlnUHJvcHMoKSBhcyBEZWZhdWx0Rm9ybVByb3BzO1xuICAgIHRoaXMudGVtcGxhdGUgPSBjb25maWdQcm9wcz8udGVtcGxhdGU7XG4gICAgY29uc3QgcHJvcFRvVXNlOiBhbnkgPSB7IC4uLnRoaXMucENvbm4kLmdldEluaGVyaXRlZFByb3BzKCkgfTtcbiAgICB0aGlzLnNob3dMYWJlbCA9IHByb3BUb1VzZT8uc2hvd0xhYmVsO1xuICAgIHRoaXMubGFiZWwgPSBwcm9wVG9Vc2U/LmxhYmVsO1xuICAgIGNvbnN0IGtpZHMgPSB0aGlzLnBDb25uJC5nZXRDaGlsZHJlbigpIGFzIGFueVtdO1xuICAgIHRoaXMuaW5zdHJ1Y3Rpb25zID0gdGhpcy50ZW1wbGF0ZVV0aWxzLmdldEluc3RydWN0aW9ucyh0aGlzLnBDb25uJCwgY29uZmlnUHJvcHM/Lmluc3RydWN0aW9ucyk7XG5cbiAgICBjb25zdCBudW1Db2xzID0gY29uZmlnUHJvcHMuTnVtQ29scyA/IGNvbmZpZ1Byb3BzLk51bUNvbHMgOiAnMSc7XG4gICAgc3dpdGNoIChudW1Db2xzKSB7XG4gICAgICBjYXNlICcxJzpcbiAgICAgICAgdGhpcy5kaXZDbGFzcyQgPSAncHNkay1kZWZhdWx0LWZvcm0tb25lLWNvbHVtbic7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAnMic6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLXR3by1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJzMnOlxuICAgICAgICB0aGlzLmRpdkNsYXNzJCA9ICdwc2RrLWRlZmF1bHQtZm9ybS10aHJlZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLW9uZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICB9XG5cbiAgICAvLyByZXBvaW50IGNoaWxkcmVuIGJlZm9yZSBnZXR0aW5nIHRlbXBsYXRlQXJyYXlcbiAgICAvLyBDaGlsZHJlbiBtYXkgY29udGFpbiAncmVmZXJlbmNlJyBjb21wb25lbnQsIHNvIHdlIG5lZWQgdG9cbiAgICAvLyAgbm9ybWFsaXplIHRoZW1cbiAgICB0aGlzLmFyQ2hpbGRyZW4kID0gUmVmZXJlbmNlQ29tcG9uZW50Lm5vcm1hbGl6ZVBDb25uQXJyYXkoa2lkc1swXS5nZXRQQ29ubmVjdCgpLmdldENoaWxkcmVuKCkpO1xuICB9XG59XG4iLCI8IS0tIFdoZW4gYWRkaW5nIGEgY29tcG9uZW50IGhlcmUsIGFkZCB0aGUgc2FtZSBjb21wb25lbnQgaW4gJ3JlZ2lvbicgdGVtcGxhdGUgYXMgd2VsbCAtLT5cbjxkaXYgKm5nSWY9XCIhTk9fSEVBREVSX1RFTVBMQVRFUy5pbmNsdWRlcyh0ZW1wbGF0ZSkgJiYgc2hvd0xhYmVsXCI+XG4gIDxkaXYgY2xhc3M9XCJ0ZW1wbGF0ZS10aXRsZS1jb250YWluZXJcIj57eyBsYWJlbCB9fTwvZGl2PlxuPC9kaXY+XG48ZGl2ICpuZ0lmPVwiaW5zdHJ1Y3Rpb25zXCIgY2xhc3M9XCJwc2RrLWRlZmF1bHQtZm9ybS1pbnN0cnVjdGlvbi10ZXh0XCI+XG4gIDxkaXYga2V5PVwiaW5zdHJ1Y3Rpb25zXCIgaWQ9XCJpbnN0cnVjdGlvbi10ZXh0XCIgW2lubmVySFRNTF09XCJpbnN0cnVjdGlvbnNcIj48L2Rpdj5cbjwvZGl2PlxuPGRpdiBbY2xhc3NOYW1lXT1cImRpdkNsYXNzJFwiPlxuICA8ZGl2ICpuZ0Zvcj1cImxldCBraWQgb2YgYXJDaGlsZHJlbiRcIiBbbmdDbGFzc109XCJ7ICdncmlkLWNvbHVtbic6IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSA9PT0gJ1ZpZXcnIH1cIj5cbiAgICA8Y29tcG9uZW50LW1hcHBlclxuICAgICAgW25hbWVdPVwia2lkLmdldFBDb25uZWN0KCkuZ2V0Q29tcG9uZW50TmFtZSgpXCJcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIHBDb25uJDoga2lkLmdldFBDb25uZWN0KCksXG4gICAgICAgIGZvcm1Hcm91cCQ6IGZvcm1Hcm91cCRcbiAgICAgIH1cIlxuICAgICAgZXJyb3JNc2c9XCJEZWZhdWx0Rm9ybSB3YW50cyBjb21wb25lbnQgbm90IHlldCBhdmFpbGFibGU6IHt7IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSB9fVwiXG4gICAgPjwvY29tcG9uZW50LW1hcHBlcj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOERBQThELENBQUM7Ozs7QUFpQnhHLE1BQU0sT0FBTyxvQkFBb0I7SUFzQi9CLFlBQW9CLGFBQTRCO1FBQTVCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBWGhELHdCQUFtQixHQUFHO1lBQ3BCLFNBQVM7WUFDVCxhQUFhO1lBQ2IsU0FBUztZQUNULGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIsbUJBQW1CO1lBQ25CLG1CQUFtQjtZQUNuQixjQUFjO1NBQ2YsQ0FBQztJQUVpRCxDQUFDO0lBRXBELFFBQVE7UUFDTixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBc0IsQ0FBQztRQUNyRSxJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsRUFBRSxRQUFRLENBQUM7UUFDdEMsTUFBTSxTQUFTLEdBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxDQUFDO1FBQzlELElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxFQUFFLFNBQVMsQ0FBQztRQUN0QyxJQUFJLENBQUMsS0FBSyxHQUFHLFNBQVMsRUFBRSxLQUFLLENBQUM7UUFDOUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQVcsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBRS9GLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztRQUNoRSxRQUFRLE9BQU8sRUFBRTtZQUNmLEtBQUssR0FBRztnQkFDTixJQUFJLENBQUMsU0FBUyxHQUFHLDhCQUE4QixDQUFDO2dCQUNoRCxNQUFNO1lBQ1IsS0FBSyxHQUFHO2dCQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07WUFDUixLQUFLLEdBQUc7Z0JBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxnQ0FBZ0MsQ0FBQztnQkFDbEQsTUFBTTtZQUNSO2dCQUNFLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07U0FDVDtRQUVELGdEQUFnRDtRQUNoRCw0REFBNEQ7UUFDNUQsa0JBQWtCO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsa0JBQWtCLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDakcsQ0FBQzsrR0FyRFUsb0JBQW9CO21HQUFwQixvQkFBb0Isb0lDckJqQyw0M0JBbUJBLDR0QkRBWSxZQUFZLDBmQUFtQix3QkFBd0I7OzRGQUV0RCxvQkFBb0I7a0JBUGhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBR2hCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUMsQ0FBQztvR0FHMUQsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBSZWZlcmVuY2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9pbmZyYS9yZWZlcmVuY2UvcmVmZXJlbmNlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21wb25lbnRNYXBwZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9fYnJpZGdlL2NvbXBvbmVudC1tYXBwZXIvY29tcG9uZW50LW1hcHBlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGVtcGxhdGVVdGlscyB9IGZyb20gJy4uLy4uLy4uL19oZWxwZXJzL3RlbXBsYXRlLXV0aWxzJztcblxuaW50ZXJmYWNlIERlZmF1bHRGb3JtUHJvcHMge1xuICAvLyBJZiBhbnksIGVudGVyIGFkZGl0aW9uYWwgcHJvcHMgdGhhdCBvbmx5IGV4aXN0IG9uIHRoaXMgY29tcG9uZW50XG4gIE51bUNvbHM6IHN0cmluZztcbiAgdGVtcGxhdGU6IHN0cmluZztcbiAgaW5zdHJ1Y3Rpb25zOiBzdHJpbmc7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1kZWZhdWx0LWZvcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIGZvcndhcmRSZWYoKCkgPT4gQ29tcG9uZW50TWFwcGVyQ29tcG9uZW50KV1cbn0pXG5leHBvcnQgY2xhc3MgRGVmYXVsdEZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwQ29ubiQ6IHR5cGVvZiBQQ29ubmVjdDtcbiAgQElucHV0KCkgZm9ybUdyb3VwJDogRm9ybUdyb3VwO1xuXG4gIGFyQ2hpbGRyZW4kOiBhbnlbXTtcbiAgZGl2Q2xhc3MkOiBzdHJpbmc7XG4gIHRlbXBsYXRlOiBhbnk7XG4gIHNob3dMYWJlbDogYW55O1xuICBsYWJlbDogYW55O1xuICBpbnN0cnVjdGlvbnM6IHN0cmluZztcblxuICBOT19IRUFERVJfVEVNUExBVEVTID0gW1xuICAgICdTdWJUYWJzJyxcbiAgICAnU2ltcGxlVGFibGUnLFxuICAgICdEZXRhaWxzJyxcbiAgICAnRGV0YWlsc1R3b0NvbHVtbicsXG4gICAgJ0RldGFpbHNUaHJlZUNvbHVtbicsXG4gICAgJ05hcnJvd1dpZGVEZXRhaWxzJyxcbiAgICAnV2lkZU5hcnJvd0RldGFpbHMnLFxuICAgICdDb25maXJtYXRpb24nXG4gIF07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0ZW1wbGF0ZVV0aWxzOiBUZW1wbGF0ZVV0aWxzKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGNvbmZpZ1Byb3BzID0gdGhpcy5wQ29ubiQuZ2V0Q29uZmlnUHJvcHMoKSBhcyBEZWZhdWx0Rm9ybVByb3BzO1xuICAgIHRoaXMudGVtcGxhdGUgPSBjb25maWdQcm9wcz8udGVtcGxhdGU7XG4gICAgY29uc3QgcHJvcFRvVXNlOiBhbnkgPSB7IC4uLnRoaXMucENvbm4kLmdldEluaGVyaXRlZFByb3BzKCkgfTtcbiAgICB0aGlzLnNob3dMYWJlbCA9IHByb3BUb1VzZT8uc2hvd0xhYmVsO1xuICAgIHRoaXMubGFiZWwgPSBwcm9wVG9Vc2U/LmxhYmVsO1xuICAgIGNvbnN0IGtpZHMgPSB0aGlzLnBDb25uJC5nZXRDaGlsZHJlbigpIGFzIGFueVtdO1xuICAgIHRoaXMuaW5zdHJ1Y3Rpb25zID0gdGhpcy50ZW1wbGF0ZVV0aWxzLmdldEluc3RydWN0aW9ucyh0aGlzLnBDb25uJCwgY29uZmlnUHJvcHM/Lmluc3RydWN0aW9ucyk7XG5cbiAgICBjb25zdCBudW1Db2xzID0gY29uZmlnUHJvcHMuTnVtQ29scyA/IGNvbmZpZ1Byb3BzLk51bUNvbHMgOiAnMSc7XG4gICAgc3dpdGNoIChudW1Db2xzKSB7XG4gICAgICBjYXNlICcxJzpcbiAgICAgICAgdGhpcy5kaXZDbGFzcyQgPSAncHNkay1kZWZhdWx0LWZvcm0tb25lLWNvbHVtbic7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAnMic6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLXR3by1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJzMnOlxuICAgICAgICB0aGlzLmRpdkNsYXNzJCA9ICdwc2RrLWRlZmF1bHQtZm9ybS10aHJlZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLW9uZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICB9XG5cbiAgICAvLyByZXBvaW50IGNoaWxkcmVuIGJlZm9yZSBnZXR0aW5nIHRlbXBsYXRlQXJyYXlcbiAgICAvLyBDaGlsZHJlbiBtYXkgY29udGFpbiAncmVmZXJlbmNlJyBjb21wb25lbnQsIHNvIHdlIG5lZWQgdG9cbiAgICAvLyAgbm9ybWFsaXplIHRoZW1cbiAgICB0aGlzLmFyQ2hpbGRyZW4kID0gUmVmZXJlbmNlQ29tcG9uZW50Lm5vcm1hbGl6ZVBDb25uQXJyYXkoa2lkc1swXS5nZXRQQ29ubmVjdCgpLmdldENoaWxkcmVuKCkpO1xuICB9XG59XG4iLCI8IS0tIFdoZW4gYWRkaW5nIGEgY29tcG9uZW50IGhlcmUsIGFkZCB0aGUgc2FtZSBjb21wb25lbnQgaW4gJ3JlZ2lvbicgdGVtcGxhdGUgYXMgd2VsbCAtLT5cbjxkaXYgKm5nSWY9XCIhTk9fSEVBREVSX1RFTVBMQVRFUy5pbmNsdWRlcyh0ZW1wbGF0ZSkgJiYgc2hvd0xhYmVsXCI+XG4gIDxkaXYgY2xhc3M9XCJ0ZW1wbGF0ZS10aXRsZS1jb250YWluZXJcIj57eyBsYWJlbCB9fTwvZGl2PlxuPC9kaXY+XG48ZGl2ICpuZ0lmPVwiaW5zdHJ1Y3Rpb25zXCIgY2xhc3M9XCJwc2RrLWRlZmF1bHQtZm9ybS1pbnN0cnVjdGlvbi10ZXh0XCI+XG4gIDxkaXYga2V5PVwiaW5zdHJ1Y3Rpb25zXCIgaWQ9XCJpbnN0cnVjdGlvbi10ZXh0XCIgW2lubmVySFRNTF09XCJpbnN0cnVjdGlvbnNcIj48L2Rpdj5cbjwvZGl2PlxuPGRpdiBbY2xhc3NOYW1lXT1cImRpdkNsYXNzJFwiPlxuICA8ZGl2ICpuZ0Zvcj1cImxldCBraWQgb2YgYXJDaGlsZHJlbiRcIiBbbmdDbGFzc109XCJ7ICdncmlkLWNvbHVtbic6IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSA9PT0gJ1ZpZXcnIH1cIj5cbiAgICA8Y29tcG9uZW50LW1hcHBlclxuICAgICAgW25hbWVdPVwia2lkLmdldFBDb25uZWN0KCkuZ2V0Q29tcG9uZW50TmFtZSgpXCJcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIHBDb25uJDoga2lkLmdldFBDb25uZWN0KCksXG4gICAgICAgIGZvcm1Hcm91cCQ6IGZvcm1Hcm91cCRcbiAgICAgIH1cIlxuICAgICAgZXJyb3JNc2c9XCJEZWZhdWx0Rm9ybSB3YW50cyBjb21wb25lbnQgbm90IHlldCBhdmFpbGFibGU6IHt7IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSB9fVwiXG4gICAgPjwvY29tcG9uZW50LW1hcHBlcj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -55,7 +55,7 @@ export class DetailsComponent {
55
55
  fields?.forEach(field => {
56
56
  const thePConn = field.getPConnect();
57
57
  const theCompType = thePConn.getComponentName().toLowerCase();
58
- if (theCompType === 'reference') {
58
+ if (theCompType === 'reference' || theCompType === 'group') {
59
59
  const configProps = thePConn.getConfigProps();
60
60
  configProps.readOnly = true;
61
61
  configProps.displayMode = 'LABELS_LEFT';
@@ -68,6 +68,7 @@ export class DetailsComponent {
68
68
  };
69
69
  const viewContConfig = {
70
70
  meta: {
71
+ ...thePConn.getMetadata(),
71
72
  type: theCompType,
72
73
  config: configProps
73
74
  },
@@ -99,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
99
100
  }], ctorParameters: function () { return [{ type: i1.AngularPConnectService }]; }, propDecorators: { pConn$: [{
100
101
  type: Input
101
102
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"details.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/details/details.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/details/details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n@Component({\n  selector: 'app-details',\n  templateUrl: './details.component.html',\n  styleUrls: ['./details.component.scss'],\n  standalone: true,\n  imports: [forwardRef(() => ComponentMapperComponent)]\n})\nexport class DetailsComponent implements OnInit, OnDestroy {\n  constructor(private angularPConnect: AngularPConnectService) {}\n\n  @Input() pConn$: typeof PConnect;\n\n  highlightedDataArr: any[] = [];\n  showHighlightedData: boolean;\n  arFields$: any[] = [];\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\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  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  checkAndUpdate() {\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    }\n  }\n\n  updateSelf() {\n    const rawMetaData: any = this.pConn$.resolveConfigProps((this.pConn$.getRawMetadata() as any).config);\n    this.showHighlightedData = rawMetaData?.showHighlightedData;\n\n    if (this.showHighlightedData) {\n      const highlightedData = rawMetaData?.highlightedData;\n      this.highlightedDataArr = highlightedData.map(field => {\n        field.config.displayMode = 'STACKED_LARGE_VAL';\n\n        if (field.config.value === '@P .pyStatusWork') {\n          field.type = 'TextInput';\n          field.config.displayAsStatus = true;\n        }\n\n        return field;\n      });\n    }\n\n    const kids = this.pConn$.getChildren() as any[];\n    for (const kid of kids) {\n      this.arFields$ = [];\n      const pKid = kid.getPConnect();\n      const fields = pKid.getChildren();\n      fields?.forEach(field => {\n        const thePConn = field.getPConnect();\n        const theCompType = thePConn.getComponentName().toLowerCase();\n        if (theCompType === 'reference') {\n          const configProps = thePConn.getConfigProps();\n          configProps.readOnly = true;\n          configProps.displayMode = 'LABELS_LEFT';\n          const propToUse = { ...thePConn.getInheritedProps() };\n          configProps.label = propToUse?.label;\n          const options = {\n            context: thePConn.getContextName(),\n            pageReference: thePConn.getPageReference(),\n            referenceList: thePConn.getReferenceList()\n          };\n          const viewContConfig = {\n            meta: {\n              type: theCompType,\n              config: configProps\n            },\n            options\n          };\n          const theViewCont = PCore.createPConnect(viewContConfig);\n          const data = {\n            type: theCompType,\n            pConn: theViewCont?.getPConnect()\n          };\n          this.arFields$.push(data);\n        } else {\n          const data = {\n            type: theCompType,\n            config: thePConn.getConfigProps()\n          };\n          this.arFields$.push(data);\n        }\n      });\n    }\n  }\n}\n","<div>\n  <component-mapper name=\"MaterialDetails\" [props]=\"{ arFields$, arHighlightedFields: highlightedDataArr, layout: 'one-column' }\"></component-mapper>\n</div>\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"details.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/details/details.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/details/details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n@Component({\n  selector: 'app-details',\n  templateUrl: './details.component.html',\n  styleUrls: ['./details.component.scss'],\n  standalone: true,\n  imports: [forwardRef(() => ComponentMapperComponent)]\n})\nexport class DetailsComponent implements OnInit, OnDestroy {\n  constructor(private angularPConnect: AngularPConnectService) {}\n\n  @Input() pConn$: typeof PConnect;\n\n  highlightedDataArr: any[] = [];\n  showHighlightedData: boolean;\n  arFields$: any[] = [];\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\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  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  checkAndUpdate() {\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    }\n  }\n\n  updateSelf() {\n    const rawMetaData: any = this.pConn$.resolveConfigProps((this.pConn$.getRawMetadata() as any).config);\n    this.showHighlightedData = rawMetaData?.showHighlightedData;\n\n    if (this.showHighlightedData) {\n      const highlightedData = rawMetaData?.highlightedData;\n      this.highlightedDataArr = highlightedData.map(field => {\n        field.config.displayMode = 'STACKED_LARGE_VAL';\n\n        if (field.config.value === '@P .pyStatusWork') {\n          field.type = 'TextInput';\n          field.config.displayAsStatus = true;\n        }\n\n        return field;\n      });\n    }\n\n    const kids = this.pConn$.getChildren() as any[];\n    for (const kid of kids) {\n      this.arFields$ = [];\n      const pKid = kid.getPConnect();\n      const fields = pKid.getChildren();\n      fields?.forEach(field => {\n        const thePConn = field.getPConnect();\n        const theCompType = thePConn.getComponentName().toLowerCase();\n        if (theCompType === 'reference' || theCompType === 'group') {\n          const configProps = thePConn.getConfigProps();\n          configProps.readOnly = true;\n          configProps.displayMode = 'LABELS_LEFT';\n          const propToUse = { ...thePConn.getInheritedProps() };\n          configProps.label = propToUse?.label;\n          const options = {\n            context: thePConn.getContextName(),\n            pageReference: thePConn.getPageReference(),\n            referenceList: thePConn.getReferenceList()\n          };\n          const viewContConfig = {\n            meta: {\n              ...thePConn.getMetadata(),\n              type: theCompType,\n              config: configProps\n            },\n            options\n          };\n          const theViewCont = PCore.createPConnect(viewContConfig);\n          const data = {\n            type: theCompType,\n            pConn: theViewCont?.getPConnect()\n          };\n          this.arFields$.push(data);\n        } else {\n          const data = {\n            type: theCompType,\n            config: thePConn.getConfigProps()\n          };\n          this.arFields$.push(data);\n        }\n      });\n    }\n  }\n}\n","<div>\n  <component-mapper name=\"MaterialDetails\" [props]=\"{ arFields$, arHighlightedFields: highlightedDataArr, layout: 'one-column' }\"></component-mapper>\n</div>\n"]}
@@ -0,0 +1,20 @@
1
+ function Boolean(value, { allowEmpty = true, tick = '', cross = '' } = {}) {
2
+ if ((!allowEmpty && !value) || value === false || value?.toString()?.toLowerCase() === 'false' || value === 0 || value === '0') {
3
+ return cross || '';
4
+ }
5
+ if (value === true || value?.toString()?.toLowerCase() === 'true' || value === 1 || value === '1') {
6
+ return tick || '';
7
+ }
8
+ if (allowEmpty && (value === 'null' || value === '' || value === null || typeof value === 'undefined')) {
9
+ return '- -';
10
+ }
11
+ return value;
12
+ }
13
+ export default {
14
+ TrueFalse: (value, options) => Boolean(value, {
15
+ ...options,
16
+ tick: options.trueLabel || 'True',
17
+ cross: options.falseLabel || 'False'
18
+ })
19
+ };
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vbGVhbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9faGVscGVycy9mb3JtYXR0ZXJzL2Jvb2xlYW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsU0FBUyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsVUFBVSxHQUFHLElBQUksRUFBRSxJQUFJLEdBQUcsRUFBRSxFQUFFLEtBQUssR0FBRyxFQUFFLEVBQUUsR0FBRyxFQUFFO0lBQ3ZFLElBQUksQ0FBQyxDQUFDLFVBQVUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssS0FBSyxLQUFLLElBQUksS0FBSyxFQUFFLFFBQVEsRUFBRSxFQUFFLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxLQUFLLEtBQUssQ0FBQyxJQUFJLEtBQUssS0FBSyxHQUFHLEVBQUU7UUFDOUgsT0FBTyxLQUFLLElBQUksRUFBRSxDQUFDO0tBQ3BCO0lBQ0QsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxXQUFXLEVBQUUsS0FBSyxNQUFNLElBQUksS0FBSyxLQUFLLENBQUMsSUFBSSxLQUFLLEtBQUssR0FBRyxFQUFFO1FBQ2pHLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQztLQUNuQjtJQUNELElBQUksVUFBVSxJQUFJLENBQUMsS0FBSyxLQUFLLE1BQU0sSUFBSSxLQUFLLEtBQUssRUFBRSxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksT0FBTyxLQUFLLEtBQUssV0FBVyxDQUFDLEVBQUU7UUFDdEcsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVELGVBQWU7SUFDYixTQUFTLEVBQUUsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FDNUIsT0FBTyxDQUFDLEtBQUssRUFBRTtRQUNiLEdBQUcsT0FBTztRQUNWLElBQUksRUFBRSxPQUFPLENBQUMsU0FBUyxJQUFJLE1BQU07UUFDakMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksT0FBTztLQUNyQyxDQUFDO0NBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIEJvb2xlYW4odmFsdWUsIHsgYWxsb3dFbXB0eSA9IHRydWUsIHRpY2sgPSAnJywgY3Jvc3MgPSAnJyB9ID0ge30pIHtcbiAgaWYgKCghYWxsb3dFbXB0eSAmJiAhdmFsdWUpIHx8IHZhbHVlID09PSBmYWxzZSB8fCB2YWx1ZT8udG9TdHJpbmcoKT8udG9Mb3dlckNhc2UoKSA9PT0gJ2ZhbHNlJyB8fCB2YWx1ZSA9PT0gMCB8fCB2YWx1ZSA9PT0gJzAnKSB7XG4gICAgcmV0dXJuIGNyb3NzIHx8ICcnO1xuICB9XG4gIGlmICh2YWx1ZSA9PT0gdHJ1ZSB8fCB2YWx1ZT8udG9TdHJpbmcoKT8udG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnIHx8IHZhbHVlID09PSAxIHx8IHZhbHVlID09PSAnMScpIHtcbiAgICByZXR1cm4gdGljayB8fCAnJztcbiAgfVxuICBpZiAoYWxsb3dFbXB0eSAmJiAodmFsdWUgPT09ICdudWxsJyB8fCB2YWx1ZSA9PT0gJycgfHwgdmFsdWUgPT09IG51bGwgfHwgdHlwZW9mIHZhbHVlID09PSAndW5kZWZpbmVkJykpIHtcbiAgICByZXR1cm4gJy0gLSc7XG4gIH1cbiAgcmV0dXJuIHZhbHVlO1xufVxuXG5leHBvcnQgZGVmYXVsdCB7XG4gIFRydWVGYWxzZTogKHZhbHVlLCBvcHRpb25zKSA9PlxuICAgIEJvb2xlYW4odmFsdWUsIHtcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICB0aWNrOiBvcHRpb25zLnRydWVMYWJlbCB8fCAnVHJ1ZScsXG4gICAgICBjcm9zczogb3B0aW9ucy5mYWxzZUxhYmVsIHx8ICdGYWxzZSdcbiAgICB9KVxufTtcbiJdfQ==
@@ -0,0 +1,16 @@
1
+ export function getLocale(locale = '') {
2
+ // use locale if specified
3
+ if (locale)
4
+ return locale;
5
+ // otherwise, use operator locale if it's defined
6
+ if (PCore.getEnvironmentInfo().getLocale())
7
+ return PCore.getEnvironmentInfo().getLocale();
8
+ // fallback
9
+ return Intl.DateTimeFormat().resolvedOptions().locale;
10
+ }
11
+ export function getCurrentTimezone(timezone = 'America/New_York') {
12
+ if (timezone)
13
+ return timezone;
14
+ return PCore?.getLocaleUtils?.().getTimeZoneInUse?.();
15
+ }
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci1zZGstY29tcG9uZW50cy9zcmMvbGliL19oZWxwZXJzL2Zvcm1hdHRlcnMvY29tbW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxTQUFTLENBQUMsU0FBaUIsRUFBRTtJQUMzQywwQkFBMEI7SUFDMUIsSUFBSSxNQUFNO1FBQUUsT0FBTyxNQUFNLENBQUM7SUFDMUIsaURBQWlEO0lBQ2pELElBQUksS0FBSyxDQUFDLGtCQUFrQixFQUFFLENBQUMsU0FBUyxFQUFFO1FBQUUsT0FBTyxLQUFLLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUMxRixXQUFXO0lBQ1gsT0FBTyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsZUFBZSxFQUFFLENBQUMsTUFBTSxDQUFDO0FBQ3hELENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCLENBQUMsV0FBbUIsa0JBQWtCO0lBQ3RFLElBQUksUUFBUTtRQUFFLE9BQU8sUUFBUSxDQUFDO0lBQzlCLE9BQU8sS0FBSyxFQUFFLGNBQWMsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDO0FBQ3hELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gZ2V0TG9jYWxlKGxvY2FsZTogc3RyaW5nID0gJycpIHtcbiAgLy8gdXNlIGxvY2FsZSBpZiBzcGVjaWZpZWRcbiAgaWYgKGxvY2FsZSkgcmV0dXJuIGxvY2FsZTtcbiAgLy8gb3RoZXJ3aXNlLCB1c2Ugb3BlcmF0b3IgbG9jYWxlIGlmIGl0J3MgZGVmaW5lZFxuICBpZiAoUENvcmUuZ2V0RW52aXJvbm1lbnRJbmZvKCkuZ2V0TG9jYWxlKCkpIHJldHVybiBQQ29yZS5nZXRFbnZpcm9ubWVudEluZm8oKS5nZXRMb2NhbGUoKTtcbiAgLy8gZmFsbGJhY2tcbiAgcmV0dXJuIEludGwuRGF0ZVRpbWVGb3JtYXQoKS5yZXNvbHZlZE9wdGlvbnMoKS5sb2NhbGU7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDdXJyZW50VGltZXpvbmUodGltZXpvbmU6IHN0cmluZyA9ICdBbWVyaWNhL05ld19Zb3JrJykge1xuICBpZiAodGltZXpvbmUpIHJldHVybiB0aW1lem9uZTtcbiAgcmV0dXJuIFBDb3JlPy5nZXRMb2NhbGVVdGlscz8uKCkuZ2V0VGltZVpvbmVJblVzZT8uKCk7XG59XG4iXX0=
@@ -0,0 +1,68 @@
1
+ import { getLocale } from './common';
2
+ import { currencyMap } from './currency-map';
3
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
4
+ function NumberFormatter(value, { locale = 'en-US', decPlaces = 2, style = '', currency = 'USD' } = {}) {
5
+ const currentLocale = getLocale(locale);
6
+ if (value !== null && value !== undefined) {
7
+ return Number(value).toLocaleString(currentLocale, {
8
+ minimumFractionDigits: decPlaces,
9
+ maximumFractionDigits: decPlaces
10
+ });
11
+ }
12
+ return value;
13
+ }
14
+ function CurrencyFormatter(value, { symbol = true, position = 'before', locale = 'en-US', decPlaces = 2, style = 'currency', currency = 'USD' } = {}) {
15
+ const currentLocale = getLocale(locale);
16
+ let formattedValue = value;
17
+ if (value !== null && value !== undefined && value !== '') {
18
+ formattedValue = NumberFormatter(value, {
19
+ locale: currentLocale,
20
+ decPlaces,
21
+ style,
22
+ currency
23
+ });
24
+ let countryCode = currentLocale?.split('-')[1].toUpperCase();
25
+ // If countryCode is still undefined, setting it as US
26
+ if (!countryCode) {
27
+ countryCode = 'US';
28
+ }
29
+ let code;
30
+ if (symbol) {
31
+ code = currencyMap[countryCode]?.symbolFormat;
32
+ }
33
+ else {
34
+ code = currencyMap[countryCode]?.currencyCode;
35
+ }
36
+ // if position is provided, change placeholder accordingly.
37
+ if (position && code) {
38
+ if (position.toLowerCase() === 'before' && code.startsWith('{#}')) {
39
+ code = code.slice(3) + code.slice(0, 3);
40
+ }
41
+ else if (position.toLowerCase() === 'after' && code.indexOf('{#}') === code.length - 3) {
42
+ code = code.slice(-3) + code.slice(0, -3);
43
+ }
44
+ }
45
+ return code?.replace('{#}', formattedValue) || formattedValue;
46
+ }
47
+ return formattedValue;
48
+ }
49
+ function SymbolFormatter(value, { symbol = '$', suffix = true, locale = 'en-US' } = {}) {
50
+ let formattedValue = value;
51
+ if (value !== null && value !== undefined) {
52
+ formattedValue = NumberFormatter(value, { locale });
53
+ return suffix ? `${formattedValue}${symbol}` : `${symbol}${formattedValue}`;
54
+ }
55
+ return formattedValue;
56
+ }
57
+ export default {
58
+ Currency: (value, options) => CurrencyFormatter(value, options),
59
+ 'Currency-Code': (value, options) => CurrencyFormatter(value, { ...options, symbol: false }),
60
+ Decimal: (value, options) => NumberFormatter(value, options),
61
+ 'Decimal-Auto': (value, options) => NumberFormatter(value, {
62
+ ...options,
63
+ decPlaces: Number.isInteger(value) ? 0 : 2
64
+ }),
65
+ Integer: (value, options) => NumberFormatter(value, { ...options, decPlaces: 0 }),
66
+ Percentage: (value, options) => SymbolFormatter(value, { ...options, symbol: '%' })
67
+ };
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyLXNkay1jb21wb25lbnRzL3NyYy9saWIvX2hlbHBlcnMvZm9ybWF0dGVycy9jdXJyZW5jeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3Qyw2REFBNkQ7QUFDN0QsU0FBUyxlQUFlLENBQUMsS0FBSyxFQUFFLEVBQUUsTUFBTSxHQUFHLE9BQU8sRUFBRSxTQUFTLEdBQUcsQ0FBQyxFQUFFLEtBQUssR0FBRyxFQUFFLEVBQUUsUUFBUSxHQUFHLEtBQUssRUFBRSxHQUFHLEVBQUU7SUFDcEcsTUFBTSxhQUFhLEdBQXVCLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1RCxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtRQUN6QyxPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxjQUFjLENBQUMsYUFBYSxFQUFFO1lBQ2pELHFCQUFxQixFQUFFLFNBQVM7WUFDaEMscUJBQXFCLEVBQUUsU0FBUztTQUNqQyxDQUFDLENBQUM7S0FDSjtJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVELFNBQVMsaUJBQWlCLENBQ3hCLEtBQWEsRUFDYixFQUFFLE1BQU0sR0FBRyxJQUFJLEVBQUUsUUFBUSxHQUFHLFFBQVEsRUFBRSxNQUFNLEdBQUcsT0FBTyxFQUFFLFNBQVMsR0FBRyxDQUFDLEVBQUUsS0FBSyxHQUFHLFVBQVUsRUFBRSxRQUFRLEdBQUcsS0FBSyxFQUFFLEdBQUcsRUFBRTtJQUVsSCxNQUFNLGFBQWEsR0FBdUIsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVELElBQUksY0FBYyxHQUFXLEtBQUssQ0FBQztJQUNuQyxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxLQUFLLEtBQUssRUFBRSxFQUFFO1FBQ3pELGNBQWMsR0FBRyxlQUFlLENBQUMsS0FBSyxFQUFFO1lBQ3RDLE1BQU0sRUFBRSxhQUFhO1lBQ3JCLFNBQVM7WUFDVCxLQUFLO1lBQ0wsUUFBUTtTQUNULENBQUMsQ0FBQztRQUVILElBQUksV0FBVyxHQUF1QixhQUFhLEVBQUUsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRWpGLHNEQUFzRDtRQUN0RCxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ2hCLFdBQVcsR0FBRyxJQUFJLENBQUM7U0FDcEI7UUFFRCxJQUFJLElBQVksQ0FBQztRQUNqQixJQUFJLE1BQU0sRUFBRTtZQUNWLElBQUksR0FBRyxXQUFXLENBQUMsV0FBVyxDQUFDLEVBQUUsWUFBWSxDQUFDO1NBQy9DO2FBQU07WUFDTCxJQUFJLEdBQUcsV0FBVyxDQUFDLFdBQVcsQ0FBQyxFQUFFLFlBQVksQ0FBQztTQUMvQztRQUVELDJEQUEyRDtRQUMzRCxJQUFJLFFBQVEsSUFBSSxJQUFJLEVBQUU7WUFDcEIsSUFBSSxRQUFRLENBQUMsV0FBVyxFQUFFLEtBQUssUUFBUSxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ2pFLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO2FBQ3pDO2lCQUFNLElBQUksUUFBUSxDQUFDLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO2dCQUN4RixJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDM0M7U0FDRjtRQUNELE9BQU8sSUFBSSxFQUFFLE9BQU8sQ0FBQyxLQUFLLEVBQUUsY0FBYyxDQUFDLElBQUksY0FBYyxDQUFDO0tBQy9EO0lBQ0QsT0FBTyxjQUFjLENBQUM7QUFDeEIsQ0FBQztBQUVELFNBQVMsZUFBZSxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sR0FBRyxHQUFHLEVBQUUsTUFBTSxHQUFHLElBQUksRUFBRSxNQUFNLEdBQUcsT0FBTyxFQUFFLEdBQUcsRUFBRTtJQUNwRixJQUFJLGNBQWMsR0FBVyxLQUFLLENBQUM7SUFDbkMsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7UUFDekMsY0FBYyxHQUFHLGVBQWUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQ3BELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLGNBQWMsR0FBRyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLEdBQUcsY0FBYyxFQUFFLENBQUM7S0FDN0U7SUFDRCxPQUFPLGNBQWMsQ0FBQztBQUN4QixDQUFDO0FBRUQsZUFBZTtJQUNiLFFBQVEsRUFBRSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxPQUFPLENBQUM7SUFDL0QsZUFBZSxFQUFFLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLEVBQUUsR0FBRyxPQUFPLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxDQUFDO0lBQzVGLE9BQU8sRUFBRSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDO0lBQzVELGNBQWMsRUFBRSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUNqQyxlQUFlLENBQUMsS0FBSyxFQUFFO1FBQ3JCLEdBQUcsT0FBTztRQUNWLFNBQVMsRUFBRSxNQUFNLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDM0MsQ0FBQztJQUNKLE9BQU8sRUFBRSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxHQUFHLE9BQU8sRUFBRSxTQUFTLEVBQUUsQ0FBQyxFQUFFLENBQUM7SUFDakYsVUFBVSxFQUFFLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxFQUFFLEdBQUcsT0FBTyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQztDQUNwRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0TG9jYWxlIH0gZnJvbSAnLi9jb21tb24nO1xuaW1wb3J0IHsgY3VycmVuY3lNYXAgfSBmcm9tICcuL2N1cnJlbmN5LW1hcCc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbmZ1bmN0aW9uIE51bWJlckZvcm1hdHRlcih2YWx1ZSwgeyBsb2NhbGUgPSAnZW4tVVMnLCBkZWNQbGFjZXMgPSAyLCBzdHlsZSA9ICcnLCBjdXJyZW5jeSA9ICdVU0QnIH0gPSB7fSk6IHN0cmluZyB7XG4gIGNvbnN0IGN1cnJlbnRMb2NhbGU6IHN0cmluZyB8IHVuZGVmaW5lZCA9IGdldExvY2FsZShsb2NhbGUpO1xuICBpZiAodmFsdWUgIT09IG51bGwgJiYgdmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBOdW1iZXIodmFsdWUpLnRvTG9jYWxlU3RyaW5nKGN1cnJlbnRMb2NhbGUsIHtcbiAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogZGVjUGxhY2VzLFxuICAgICAgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiBkZWNQbGFjZXNcbiAgICB9KTtcbiAgfVxuICByZXR1cm4gdmFsdWU7XG59XG5cbmZ1bmN0aW9uIEN1cnJlbmN5Rm9ybWF0dGVyKFxuICB2YWx1ZTogc3RyaW5nLFxuICB7IHN5bWJvbCA9IHRydWUsIHBvc2l0aW9uID0gJ2JlZm9yZScsIGxvY2FsZSA9ICdlbi1VUycsIGRlY1BsYWNlcyA9IDIsIHN0eWxlID0gJ2N1cnJlbmN5JywgY3VycmVuY3kgPSAnVVNEJyB9ID0ge31cbik6IHN0cmluZyB7XG4gIGNvbnN0IGN1cnJlbnRMb2NhbGU6IHN0cmluZyB8IHVuZGVmaW5lZCA9IGdldExvY2FsZShsb2NhbGUpO1xuICBsZXQgZm9ybWF0dGVkVmFsdWU6IHN0cmluZyA9IHZhbHVlO1xuICBpZiAodmFsdWUgIT09IG51bGwgJiYgdmFsdWUgIT09IHVuZGVmaW5lZCAmJiB2YWx1ZSAhPT0gJycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IE51bWJlckZvcm1hdHRlcih2YWx1ZSwge1xuICAgICAgbG9jYWxlOiBjdXJyZW50TG9jYWxlLFxuICAgICAgZGVjUGxhY2VzLFxuICAgICAgc3R5bGUsXG4gICAgICBjdXJyZW5jeVxuICAgIH0pO1xuXG4gICAgbGV0IGNvdW50cnlDb2RlOiBzdHJpbmcgfCB1bmRlZmluZWQgPSBjdXJyZW50TG9jYWxlPy5zcGxpdCgnLScpWzFdLnRvVXBwZXJDYXNlKCk7XG5cbiAgICAvLyBJZiBjb3VudHJ5Q29kZSBpcyBzdGlsbCB1bmRlZmluZWQsIHNldHRpbmcgaXQgYXMgVVNcbiAgICBpZiAoIWNvdW50cnlDb2RlKSB7XG4gICAgICBjb3VudHJ5Q29kZSA9ICdVUyc7XG4gICAgfVxuXG4gICAgbGV0IGNvZGU6IHN0cmluZztcbiAgICBpZiAoc3ltYm9sKSB7XG4gICAgICBjb2RlID0gY3VycmVuY3lNYXBbY291bnRyeUNvZGVdPy5zeW1ib2xGb3JtYXQ7XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvZGUgPSBjdXJyZW5jeU1hcFtjb3VudHJ5Q29kZV0/LmN1cnJlbmN5Q29kZTtcbiAgICB9XG5cbiAgICAvLyBpZiBwb3NpdGlvbiBpcyBwcm92aWRlZCwgY2hhbmdlIHBsYWNlaG9sZGVyIGFjY29yZGluZ2x5LlxuICAgIGlmIChwb3NpdGlvbiAmJiBjb2RlKSB7XG4gICAgICBpZiAocG9zaXRpb24udG9Mb3dlckNhc2UoKSA9PT0gJ2JlZm9yZScgJiYgY29kZS5zdGFydHNXaXRoKCd7I30nKSkge1xuICAgICAgICBjb2RlID0gY29kZS5zbGljZSgzKSArIGNvZGUuc2xpY2UoMCwgMyk7XG4gICAgICB9IGVsc2UgaWYgKHBvc2l0aW9uLnRvTG93ZXJDYXNlKCkgPT09ICdhZnRlcicgJiYgY29kZS5pbmRleE9mKCd7I30nKSA9PT0gY29kZS5sZW5ndGggLSAzKSB7XG4gICAgICAgIGNvZGUgPSBjb2RlLnNsaWNlKC0zKSArIGNvZGUuc2xpY2UoMCwgLTMpO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gY29kZT8ucmVwbGFjZSgneyN9JywgZm9ybWF0dGVkVmFsdWUpIHx8IGZvcm1hdHRlZFZhbHVlO1xuICB9XG4gIHJldHVybiBmb3JtYXR0ZWRWYWx1ZTtcbn1cblxuZnVuY3Rpb24gU3ltYm9sRm9ybWF0dGVyKHZhbHVlLCB7IHN5bWJvbCA9ICckJywgc3VmZml4ID0gdHJ1ZSwgbG9jYWxlID0gJ2VuLVVTJyB9ID0ge30pOiBzdHJpbmcge1xuICBsZXQgZm9ybWF0dGVkVmFsdWU6IHN0cmluZyA9IHZhbHVlO1xuICBpZiAodmFsdWUgIT09IG51bGwgJiYgdmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gTnVtYmVyRm9ybWF0dGVyKHZhbHVlLCB7IGxvY2FsZSB9KTtcbiAgICByZXR1cm4gc3VmZml4ID8gYCR7Zm9ybWF0dGVkVmFsdWV9JHtzeW1ib2x9YCA6IGAke3N5bWJvbH0ke2Zvcm1hdHRlZFZhbHVlfWA7XG4gIH1cbiAgcmV0dXJuIGZvcm1hdHRlZFZhbHVlO1xufVxuXG5leHBvcnQgZGVmYXVsdCB7XG4gIEN1cnJlbmN5OiAodmFsdWUsIG9wdGlvbnMpID0+IEN1cnJlbmN5Rm9ybWF0dGVyKHZhbHVlLCBvcHRpb25zKSxcbiAgJ0N1cnJlbmN5LUNvZGUnOiAodmFsdWUsIG9wdGlvbnMpID0+IEN1cnJlbmN5Rm9ybWF0dGVyKHZhbHVlLCB7IC4uLm9wdGlvbnMsIHN5bWJvbDogZmFsc2UgfSksXG4gIERlY2ltYWw6ICh2YWx1ZSwgb3B0aW9ucykgPT4gTnVtYmVyRm9ybWF0dGVyKHZhbHVlLCBvcHRpb25zKSxcbiAgJ0RlY2ltYWwtQXV0byc6ICh2YWx1ZSwgb3B0aW9ucykgPT5cbiAgICBOdW1iZXJGb3JtYXR0ZXIodmFsdWUsIHtcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBkZWNQbGFjZXM6IE51bWJlci5pc0ludGVnZXIodmFsdWUpID8gMCA6IDJcbiAgICB9KSxcbiAgSW50ZWdlcjogKHZhbHVlLCBvcHRpb25zKSA9PiBOdW1iZXJGb3JtYXR0ZXIodmFsdWUsIHsgLi4ub3B0aW9ucywgZGVjUGxhY2VzOiAwIH0pLFxuICBQZXJjZW50YWdlOiAodmFsdWUsIG9wdGlvbnMpID0+IFN5bWJvbEZvcm1hdHRlcih2YWx1ZSwgeyAuLi5vcHRpb25zLCBzeW1ib2w6ICclJyB9KVxufTtcbiJdfQ==
@@ -0,0 +1,69 @@
1
+ import dayjs from 'dayjs';
2
+ import relativeTime from 'dayjs/plugin/relativeTime';
3
+ import localizedFormat from 'dayjs/plugin/localizedFormat';
4
+ import utc from 'dayjs/plugin/utc';
5
+ import tzone from 'dayjs/plugin/timezone';
6
+ dayjs.extend(relativeTime);
7
+ dayjs.extend(localizedFormat);
8
+ dayjs.extend(utc);
9
+ dayjs.extend(tzone);
10
+ const types = ['fromNow', 'customFormat'];
11
+ // value should be in ISO 8601 format.
12
+ function DateFormatter(value, { type = types[1], format = 'DD/MM/YYYY', timezone = 'America/New_York' } = {}) {
13
+ if (!value)
14
+ return value;
15
+ switch (type) {
16
+ case types[1]:
17
+ if (timezone)
18
+ return dayjs(value).tz(timezone).format(format);
19
+ return dayjs(value).format(format);
20
+ case types[0]:
21
+ return dayjs(value).from(dayjs());
22
+ default:
23
+ return value;
24
+ }
25
+ }
26
+ // value should be in hh:mm:ss format (00:00:00 - 23:59:59).
27
+ function TimeFormatter(value, options) {
28
+ if (!value)
29
+ return value;
30
+ const { locale = 'en-US' } = options;
31
+ const timeOnlyRegex = /^(?:[01]\d|2[0123]):(?:[012345]\d):(?:[012345]\d)$/;
32
+ if (value.length === 8 && timeOnlyRegex.test(value)) {
33
+ const tempDate = new Date();
34
+ const hours = parseInt(value.substr(0, 2), 10);
35
+ const minutes = parseInt(value.substr(3, 2), 10);
36
+ const seconds = parseInt(value.substr(6, 2), 10);
37
+ tempDate.setHours(hours);
38
+ tempDate.setMinutes(minutes);
39
+ tempDate.setSeconds(seconds);
40
+ return tempDate.toLocaleTimeString(locale);
41
+ }
42
+ return DateFormatter(value, options);
43
+ }
44
+ export default {
45
+ 'DateTime-Long': (value, options) => DateFormatter(value, { ...options, type: 'customFormat', format: 'LLL' }),
46
+ 'DateTime-Short': (value, options) => DateFormatter(value, {
47
+ ...options,
48
+ type: 'customFormat',
49
+ format: 'MMM DD, YYYY'
50
+ }),
51
+ 'DateTime-Since': value => DateFormatter(value, { type: 'fromNow' }),
52
+ 'Time-Only': (value, options) => TimeFormatter(value, {
53
+ ...options,
54
+ type: 'customFormat',
55
+ format: 'hh:mm:ss A'
56
+ }),
57
+ convertToTimezone: (value, options) => {
58
+ return value && options && options.timezone
59
+ ? DateFormatter(value, {
60
+ ...options,
61
+ type: 'customFormat',
62
+ format: 'YYYY-MM-DDTHH:mm:ss'
63
+ })
64
+ : value;
65
+ },
66
+ convertFromTimezone: (value, timezone) => (value && timezone ? dayjs.tz(value, timezone).utc().format() : value),
67
+ Date: (value, options) => DateFormatter(value, { type: 'customFormat', ...options })
68
+ };
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9faGVscGVycy9mb3JtYXR0ZXJzL2RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE9BQU8sWUFBWSxNQUFNLDJCQUEyQixDQUFDO0FBQ3JELE9BQU8sZUFBZSxNQUFNLDhCQUE4QixDQUFDO0FBQzNELE9BQU8sR0FBRyxNQUFNLGtCQUFrQixDQUFDO0FBQ25DLE9BQU8sS0FBSyxNQUFNLHVCQUF1QixDQUFDO0FBRTFDLEtBQUssQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDM0IsS0FBSyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQztBQUM5QixLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ2xCLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7QUFFcEIsTUFBTSxLQUFLLEdBQUcsQ0FBQyxTQUFTLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFFMUMsc0NBQXNDO0FBQ3RDLFNBQVMsYUFBYSxDQUFDLEtBQWEsRUFBRSxFQUFFLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxHQUFHLFlBQVksRUFBRSxRQUFRLEdBQUcsa0JBQWtCLEVBQUUsR0FBRyxFQUFFO0lBQ2xILElBQUksQ0FBQyxLQUFLO1FBQUUsT0FBTyxLQUFLLENBQUM7SUFDekIsUUFBUSxJQUFJLEVBQUU7UUFDWixLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDWCxJQUFJLFFBQVE7Z0JBQUUsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM5RCxPQUFPLEtBQUssQ0FBQyxLQUFL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QUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ2hILElBQUksRUFBRSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsY0FBYyxFQUFFLEdBQUcsT0FBTyxFQUFFLENBQUM7Q0FDckYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkYXlqcyBmcm9tICdkYXlqcyc7XG5pbXBvcnQgcmVsYXRpdmVUaW1lIGZyb20gJ2RheWpzL3BsdWdpbi9yZWxhdGl2ZVRpbWUnO1xuaW1wb3J0IGxvY2FsaXplZEZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vbG9jYWxpemVkRm9ybWF0JztcbmltcG9ydCB1dGMgZnJvbSAnZGF5anMvcGx1Z2luL3V0Yyc7XG5pbXBvcnQgdHpvbmUgZnJvbSAnZGF5anMvcGx1Z2luL3RpbWV6b25lJztcblxuZGF5anMuZXh0ZW5kKHJlbGF0aXZlVGltZSk7XG5kYXlqcy5leHRlbmQobG9jYWxpemVkRm9ybWF0KTtcbmRheWpzLmV4dGVuZCh1dGMpO1xuZGF5anMuZXh0ZW5kKHR6b25lKTtcblxuY29uc3QgdHlwZXMgPSBbJ2Zyb21Ob3cnLCAnY3VzdG9tRm9ybWF0J107XG5cbi8vIHZhbHVlIHNob3VsZCBiZSBpbiBJU08gODYwMSBmb3JtYXQuXG5mdW5jdGlvbiBEYXRlRm9ybWF0dGVyKHZhbHVlOiBzdHJpbmcsIHsgdHlwZSA9IHR5cGVzWzFdLCBmb3JtYXQgPSAnREQvTU0vWVlZWScsIHRpbWV6b25lID0gJ0FtZXJpY2EvTmV3X1lvcmsnIH0gPSB7fSkge1xuICBpZiAoIXZhbHVlKSByZXR1cm4gdmFsdWU7XG4gIHN3aXRjaCAodHlwZSkge1xuICAgIGNhc2UgdHlwZXNbMV06XG4gICAgICBpZiAodGltZXpvbmUpIHJldHVybiBkYXlqcyh2YWx1ZSkudHoodGltZXpvbmUpLmZvcm1hdChmb3JtYXQpO1xuICAgICAgcmV0dXJuIGRheWpzKHZhbHVlKS5mb3JtYXQoZm9ybWF0KTtcbiAgICBjYXNlIHR5cGVzWzBdOlxuICAgICAgcmV0dXJuIGRheWpzKHZhbHVlKS5mcm9tKGRheWpzKCkpO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gdmFsdWU7XG4gIH1cbn1cbi8vIHZhbHVlIHNob3VsZCBiZSBpbiBoaDptbTpzcyBmb3JtYXQgKDAwOjAwOjAwIC0gMjM6NTk6NTkpLlxuZnVuY3Rpb24gVGltZUZvcm1hdHRlcih2YWx1ZSwgb3B0aW9ucykge1xuICBpZiAoIXZhbHVlKSByZXR1cm4gdmFsdWU7XG4gIGNvbnN0IHsgbG9jYWxlID0gJ2VuLVVTJyB9ID0gb3B0aW9ucztcbiAgY29uc3QgdGltZU9ubHlSZWdleCA9IC9eKD86WzAxXVxcZHwyWzAxMjNdKTooPzpbMDEyMzQ1XVxcZCk6KD86WzAxMjM0NV1cXGQpJC87XG4gIGlmICh2YWx1ZS5sZW5ndGggPT09IDggJiYgdGltZU9ubHlSZWdleC50ZXN0KHZhbHVlKSkge1xuICAgIGNvbnN0IHRlbXBEYXRlID0gbmV3IERhdGUoKTtcbiAgICBjb25zdCBob3VycyA9IHBhcnNlSW50KHZhbHVlLnN1YnN0cigwLCAyKSwgMTApO1xuICAgIGNvbnN0IG1pbnV0ZXMgPSBwYXJzZUludCh2YWx1ZS5zdWJzdHIoMywgMiksIDEwKTtcbiAgICBjb25zdCBzZWNvbmRzID0gcGFyc2VJbnQodmFsdWUuc3Vic3RyKDYsIDIpLCAxMCk7XG4gICAgdGVtcERhdGUuc2V0SG91cnMoaG91cnMpO1xuICAgIHRlbXBEYXRlLnNldE1pbnV0ZXMobWludXRlcyk7XG4gICAgdGVtcERhdGUuc2V0U2Vjb25kcyhzZWNvbmRzKTtcbiAgICByZXR1cm4gdGVtcERhdGUudG9Mb2NhbGVUaW1lU3RyaW5nKGxvY2FsZSk7XG4gIH1cbiAgcmV0dXJuIERhdGVGb3JtYXR0ZXIodmFsdWUsIG9wdGlvbnMpO1xufVxuXG5leHBvcnQgZGVmYXVsdCB7XG4gICdEYXRlVGltZS1Mb25nJzogKHZhbHVlLCBvcHRpb25zKSA9PiBEYXRlRm9ybWF0dGVyKHZhbHVlLCB7IC4uLm9wdGlvbnMsIHR5cGU6ICdjdXN0b21Gb3JtYXQnLCBmb3JtYXQ6ICdMTEwnIH0pLFxuICAnRGF0ZVRpbWUtU2hvcnQnOiAodmFsdWUsIG9wdGlvbnMpID0+XG4gICAgRGF0ZUZvcm1hdHRlcih2YWx1ZSwge1xuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIHR5cGU6ICdjdXN0b21Gb3JtYXQnLFxuICAgICAgZm9ybWF0OiAnTU1NIERELCBZWVlZJ1xuICAgIH0pLFxuICAnRGF0ZVRpbWUtU2luY2UnOiB2YWx1ZSA9PiBEYXRlRm9ybWF0dGVyKHZhbHVlLCB7IHR5cGU6ICdmcm9tTm93JyB9KSxcbiAgJ1RpbWUtT25seSc6ICh2YWx1ZSwgb3B0aW9ucykgPT5cbiAgICBUaW1lRm9ybWF0dGVyKHZhbHVlLCB7XG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgdHlwZTogJ2N1c3RvbUZvcm1hdCcsXG4gICAgICBmb3JtYXQ6ICdoaDptbTpzcyBBJ1xuICAgIH0pLFxuICBjb252ZXJ0VG9UaW1lem9uZTogKHZhbHVlLCBvcHRpb25zKSA9PiB7XG4gICAgcmV0dXJuIHZhbHVlICYmIG9wdGlvbnMgJiYgb3B0aW9ucy50aW1lem9uZVxuICAgICAgPyBEYXRlRm9ybWF0dGVyKHZhbHVlLCB7XG4gICAgICAgICAgLi4ub3B0aW9ucyxcbiAgICAgICAgICB0eXBlOiAnY3VzdG9tRm9ybWF0JyxcbiAgICAgICAgICBmb3JtYXQ6ICdZWVlZLU1NLUREVEhIOm1tOnNzJ1xuICAgICAgICB9KVxuICAgICAgOiB2YWx1ZTtcbiAgfSxcbiAgY29udmVydEZyb21UaW1lem9uZTogKHZhbHVlLCB0aW1lem9uZSkgPT4gKHZhbHVlICYmIHRpbWV6b25lID8gZGF5anMudHoodmFsdWUsIHRpbWV6b25lKS51dGMoKS5mb3JtYXQoKSA6IHZhbHVlKSxcbiAgRGF0ZTogKHZhbHVlLCBvcHRpb25zKSA9PiBEYXRlRm9ybWF0dGVyKHZhbHVlLCB7IHR5cGU6ICdjdXN0b21Gb3JtYXQnLCAuLi5vcHRpb25zIH0pXG59O1xuIl19
@@ -0,0 +1,110 @@
1
+ import Boolean from './boolean';
2
+ import Currency from './currency';
3
+ import DateFormatter from './date';
4
+ import { getCurrentTimezone, getLocale } from './common';
5
+ export default {
6
+ ...Boolean,
7
+ ...Currency,
8
+ ...DateFormatter
9
+ };
10
+ function getDateObject(text) {
11
+ if (text instanceof Date)
12
+ return text;
13
+ // TODO - cleanup formatters util functions as DX APIs are returning values per ISO std now.
14
+ const timeStamp = text.replace(/-/g, '');
15
+ const isDateTime = timeStamp.indexOf('GMT') !== -1;
16
+ const year = parseInt(timeStamp.substr(0, 4), 10);
17
+ const month = parseInt(timeStamp.substr(4, 2), 10) - 1;
18
+ const day = parseInt(timeStamp.substr(6, 2), 10);
19
+ const date = new Date();
20
+ date.setDate(day);
21
+ date.setMonth(month);
22
+ date.setFullYear(year);
23
+ if (isDateTime) {
24
+ const hours = parseInt(timeStamp.substr(9, 2), 10);
25
+ const minutes = parseInt(timeStamp.substr(11, 2), 10);
26
+ const seconds = parseInt(timeStamp.substr(13, 2), 10);
27
+ const ms = parseInt(timeStamp.substr(16, 3), 10);
28
+ date.setHours(hours);
29
+ date.setMinutes(minutes);
30
+ date.setSeconds(seconds);
31
+ date.setMilliseconds(ms);
32
+ }
33
+ return date;
34
+ }
35
+ function isIsoDate(str) {
36
+ if (!/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}.\d{3}Z/.test(str))
37
+ return false;
38
+ const d = new Date(str);
39
+ return d.toISOString() === str;
40
+ }
41
+ function parseDateInISO(value) {
42
+ const isMilliSeconds = /^[0-9]+$/.exec(value);
43
+ if (isMilliSeconds) {
44
+ const date = new Date(parseInt(value, 10));
45
+ return date.toISOString();
46
+ }
47
+ if (isIsoDate(value)) {
48
+ const date = new Date(value);
49
+ return date.toISOString();
50
+ }
51
+ return value ? getDateObject(value).toISOString() : value;
52
+ }
53
+ export function format(value, type, options = {}) {
54
+ let formattedValue;
55
+ switch (type?.toLowerCase()) {
56
+ case 'currency': {
57
+ const defaultOptions = {
58
+ locale: getLocale(),
59
+ position: 'before',
60
+ decPlaces: 2
61
+ };
62
+ const params = { ...defaultOptions, ...options };
63
+ formattedValue = Currency.Currency(value, params);
64
+ break;
65
+ }
66
+ case 'decimal': {
67
+ const defaultOptions = { locale: getLocale(), decPlaces: 2 };
68
+ const params = { ...defaultOptions, ...options };
69
+ formattedValue = Currency.Decimal(value, params);
70
+ break;
71
+ }
72
+ case 'integer': {
73
+ const defaultOptions = { locale: getLocale() };
74
+ const params = { ...defaultOptions, ...options };
75
+ formattedValue = Currency.Integer(value, params);
76
+ break;
77
+ }
78
+ case 'date': {
79
+ const defaultOptions = {
80
+ format: 'MMM DD, YYYY',
81
+ timezone: getCurrentTimezone()
82
+ };
83
+ const params = { ...defaultOptions, ...options };
84
+ formattedValue = DateFormatter.Date(parseDateInISO(value), params);
85
+ break;
86
+ }
87
+ case 'datetime': {
88
+ const defaultOptions = {
89
+ format: 'MMM DD, YYYY h:mm A',
90
+ timezone: getCurrentTimezone()
91
+ };
92
+ const params = { ...defaultOptions, ...options };
93
+ formattedValue = DateFormatter.Date(parseDateInISO(value), params);
94
+ break;
95
+ }
96
+ case 'boolean':
97
+ case 'checkbox': {
98
+ formattedValue = Boolean.TrueFalse(value, { allowEmpty: false, ...options });
99
+ break;
100
+ }
101
+ case 'userreference': {
102
+ formattedValue = value.userName;
103
+ break;
104
+ }
105
+ default:
106
+ formattedValue = value;
107
+ }
108
+ return formattedValue;
109
+ }
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/angular-sdk-components/src/lib/_helpers/formatters/index.ts"],"names":[],"mappings":"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","sourcesContent":["import Boolean from './boolean';\nimport Currency from './currency';\nimport DateFormatter from './date';\nimport { getCurrentTimezone, getLocale } from './common';\n\nexport default {\n  ...Boolean,\n  ...Currency,\n  ...DateFormatter\n};\n\nfunction getDateObject(text): Date {\n  if (text instanceof Date) return text;\n\n  // TODO - cleanup formatters util functions as DX APIs are returning values per ISO std now.\n  const timeStamp = text.replace(/-/g, '');\n  const isDateTime = timeStamp.indexOf('GMT') !== -1;\n  const year = parseInt(timeStamp.substr(0, 4), 10);\n  const month = parseInt(timeStamp.substr(4, 2), 10) - 1;\n  const day = parseInt(timeStamp.substr(6, 2), 10);\n\n  const date = new Date();\n\n  date.setDate(day);\n  date.setMonth(month);\n  date.setFullYear(year);\n\n  if (isDateTime) {\n    const hours = parseInt(timeStamp.substr(9, 2), 10);\n    const minutes = parseInt(timeStamp.substr(11, 2), 10);\n    const seconds = parseInt(timeStamp.substr(13, 2), 10);\n    const ms = parseInt(timeStamp.substr(16, 3), 10);\n    date.setHours(hours);\n    date.setMinutes(minutes);\n    date.setSeconds(seconds);\n    date.setMilliseconds(ms);\n  }\n\n  return date;\n}\n\nfunction isIsoDate(str) {\n  if (!/\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}.\\d{3}Z/.test(str)) return false;\n  const d = new Date(str);\n  return d.toISOString() === str;\n}\n\nfunction parseDateInISO(value) {\n  const isMilliSeconds = /^[0-9]+$/.exec(value);\n  if (isMilliSeconds) {\n    const date = new Date(parseInt(value, 10));\n    return date.toISOString();\n  }\n\n  if (isIsoDate(value)) {\n    const date = new Date(value);\n    return date.toISOString();\n  }\n\n  return value ? getDateObject(value).toISOString() : value;\n}\n\nexport function format(value, type, options = {}): string {\n  let formattedValue: string;\n\n  switch (type?.toLowerCase()) {\n    case 'currency': {\n      const defaultOptions = {\n        locale: getLocale(),\n        position: 'before',\n        decPlaces: 2\n      };\n      const params = { ...defaultOptions, ...options };\n      formattedValue = Currency.Currency(value, params);\n      break;\n    }\n\n    case 'decimal': {\n      const defaultOptions = { locale: getLocale(), decPlaces: 2 };\n      const params = { ...defaultOptions, ...options };\n      formattedValue = Currency.Decimal(value, params);\n      break;\n    }\n\n    case 'integer': {\n      const defaultOptions = { locale: getLocale() };\n      const params = { ...defaultOptions, ...options };\n      formattedValue = Currency.Integer(value, params);\n      break;\n    }\n\n    case 'date': {\n      const defaultOptions = {\n        format: 'MMM DD, YYYY',\n        timezone: getCurrentTimezone()\n      };\n      const params = { ...defaultOptions, ...options };\n      formattedValue = DateFormatter.Date(parseDateInISO(value), params);\n      break;\n    }\n\n    case 'datetime': {\n      const defaultOptions = {\n        format: 'MMM DD, YYYY h:mm A',\n        timezone: getCurrentTimezone()\n      };\n      const params = { ...defaultOptions, ...options };\n      formattedValue = DateFormatter.Date(parseDateInISO(value), params);\n      break;\n    }\n\n    case 'boolean':\n    case 'checkbox': {\n      formattedValue = Boolean.TrueFalse(value, { allowEmpty: false, ...options });\n      break;\n    }\n\n    case 'userreference': {\n      formattedValue = value.userName;\n      break;\n    }\n\n    default:\n      formattedValue = value;\n  }\n  return formattedValue;\n}\n"]}