@pega/angular-sdk-components 0.242.8 → 0.242.9

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.
@@ -102,7 +102,12 @@ export class UserReferenceComponent {
102
102
  this.helperText = helperText;
103
103
  this.placeholder = placeholder || '';
104
104
  this.displayMode$ = displayMode;
105
- this.value$ = value && typeof value === 'object' && value.userName ? value.userName : (value ?? '');
105
+ if (value && typeof value === 'object') {
106
+ this.value$ = value.userName ? value.userName : '';
107
+ }
108
+ else {
109
+ this.value$ = value || '';
110
+ }
106
111
  const { readOnly, required } = props;
107
112
  [this.bReadonly$, this.bRequired$] = [readOnly, required].map(prop => prop === true || (typeof prop === 'string' && prop === 'true'));
108
113
  this.actionsApi = this.pConn$.getActionsApi();
@@ -258,4 +263,4 @@ function getUserName(pConn, userId = '') {
258
263
  });
259
264
  });
260
265
  }
261
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-reference.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/field/user-reference/user-reference.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/field/user-reference/user-reference.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\nimport { PConnFieldProps } from '../../../_types/PConnProps.interface';\nimport { map, Observable, startWith } from 'rxjs';\nimport { handleEvent } from '../../../_helpers/event-util';\n\nconst OPERATORS_DP = 'D_pyGetOperatorsForCurrentApplication';\nconst DROPDOWN_LIST = 'Drop-down list';\nconst SEARCH_BOX = 'Search box';\n\ninterface UserReferenceProps extends Omit<PConnFieldProps, 'value'> {\n  // If any, enter additional props that only exist on UserReference here\n  displayAs?: string;\n  value?: any;\n  showAsFormattedText?: boolean;\n  additionalProps?: object;\n  onRecordChange?: any;\n}\n\n@Component({\n  selector: 'app-user-reference',\n  templateUrl: './user-reference.component.html',\n  styleUrls: ['./user-reference.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class UserReferenceComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  angularPConnectData: AngularPConnectData = {};\n  controlName$: string;\n  value$;\n  userName$: string;\n  label$: string;\n  userID$: string;\n  options$: any;\n  bReadonly$: boolean;\n  bRequired$: boolean;\n  showAsFormattedText$?: boolean;\n  displayAs$?: string;\n  testId: string;\n  helperText: string;\n  placeholder: string;\n  displayMode$?: string;\n  filteredOptions: Observable<any[]>;\n  filterValue = '';\n\n  fieldControl = new FormControl('', null);\n  actionsApi: Object;\n  propName: string;\n  onRecordChange: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\n  ) {}\n\n  async ngOnInit(): Promise<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.controlName$ = this.angularPConnect.getComponentID(this);\n\n    await this.checkAndUpdate();\n\n    if (this.formGroup$) {\n      // add control to formGroup\n      this.formGroup$.addControl(this.controlName$, this.fieldControl);\n      this.fieldControl.setValue(this.getValue(this.value$));\n    }\n\n    this.filteredOptions = this.fieldControl.valueChanges.pipe(\n      startWith(this.getValue(this.value$) || ''),\n      map(value => this._filter(value || ''))\n    );\n  }\n\n  ngOnDestroy() {\n    if (this.formGroup$) {\n      this.formGroup$.removeControl(this.controlName$);\n    }\n\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  get type(): string {\n    if (this.bReadonly$ && this.showAsFormattedText$) {\n      return 'operator';\n    }\n    if (this.displayAs$ === DROPDOWN_LIST) {\n      return 'dropdown';\n    }\n    if (this.displayAs$ === SEARCH_BOX) {\n      return 'searchbox';\n    }\n\n    return '';\n  }\n\n  // Callback passed when subscribing to store change\n  async onStateChange() {\n    await this.checkAndUpdate();\n  }\n\n  private _filter(value: string): string[] {\n    const filterVal = (value || this.filterValue).toLowerCase();\n    return this.options$?.filter(option => option.value?.toLowerCase().includes(filterVal));\n  }\n\n  isUserNameAvailable = user => {\n    return typeof user === 'object' && user !== null && user.userName;\n  };\n\n  getUserName = user => {\n    return user.userName;\n  };\n\n  getValue = user => {\n    if (this.displayAs$ === DROPDOWN_LIST) {\n      return this.utils.getUserId(user) || this.getUserName(user);\n    }\n    return this.isUserNameAvailable(user) ? this.getUserName(user) : this.utils.getUserId(user);\n  };\n\n  async 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      await this.updateSelf();\n    }\n  }\n\n  async updateSelf() {\n    const props = this.pConn$.getConfigProps() as UserReferenceProps;\n    this.testId = props.testId;\n    this.onRecordChange = props?.onRecordChange;\n\n    const { label, displayAs, value, showAsFormattedText, helperText, placeholder, displayMode } = props;\n\n    this.label$ = label;\n    this.showAsFormattedText$ = showAsFormattedText;\n    this.displayAs$ = displayAs;\n    this.helperText = helperText;\n    this.placeholder = placeholder || '';\n    this.displayMode$ = displayMode;\n\n    this.value$ = value && typeof value === 'object' && value.userName ? value.userName : (value ?? '');\n\n    const { readOnly, required } = props;\n    [this.bReadonly$, this.bRequired$] = [readOnly, required].map(prop => prop === true || (typeof prop === 'string' && prop === 'true'));\n\n    this.actionsApi = this.pConn$.getActionsApi();\n    this.propName = this.pConn$.getStateProps().value;\n\n    this.userID$ = this.utils.getUserId(value);\n\n    if (this.userID$ && this.bReadonly$ && this.showAsFormattedText$) {\n      if (this.isUserNameAvailable(value)) {\n        this.userName$ = value.userName;\n      } else {\n        // if same user ref field is referred in view as editable & readonly formatted text\n        // referenced users won't be available, so get user details from dx api\n        // eslint-disable-next-line @typescript-eslint/no-use-before-define\n        this.userName$ = await getUserName(this.pConn$, this.userID$);\n      }\n    } else if (displayAs === DROPDOWN_LIST || displayAs === SEARCH_BOX) {\n      const queryPayload = {\n        dataViewName: OPERATORS_DP\n      };\n      try {\n        const resp = await PCore.getRestClient().invokeRestApi('getListData', { queryPayload }, ''); // 3rd arg empty string until typedef marked correctly\n        if (resp?.data) {\n          const ddDataSource = resp.data.data.map(listItem => ({\n            key: listItem.pyUserIdentifier,\n            value: listItem.pyUserName\n          }));\n          this.options$ = ddDataSource;\n        }\n      } catch (error) {\n        console.log(error);\n      }\n    }\n  }\n\n  fieldOnChange(event: any) {\n    if (event?.value === 'Select') {\n      event.value = '';\n    }\n    if (event?.target) {\n      this.filterValue = (event.target as HTMLInputElement).value;\n    }\n    const value = event?.value;\n    handleEvent(this.actionsApi, 'change', this.propName, value);\n  }\n\n  optionChanged(event: any) {\n    const value = event?.option?.value;\n    handleEvent(this.actionsApi, 'change', this.propName, value);\n  }\n\n  fieldOnBlur(event: any) {\n    let key = '';\n    if (event?.target?.value) {\n      const index = this.options$?.findIndex(element => element.value === event.target.value);\n      key = index > -1 ? (key = this.options$[index].key) : event.target.value;\n    }\n    const value = key;\n    handleEvent(this.actionsApi, 'changeNblur', this.propName, value);\n    if (this.onRecordChange) {\n      event.target.value = value;\n      this.onRecordChange(event);\n    }\n  }\n\n  getErrorMessage() {\n    let errMessage = '';\n\n    // look for validation messages for json, pre-defined or just an error pushed from workitem (400)\n    if (this.fieldControl.hasError('message')) {\n      errMessage = this.angularPConnectData.validateMessage ?? '';\n      return errMessage;\n    }\n    if (this.fieldControl.hasError('required')) {\n      errMessage = 'You must enter a value';\n    } else if (this.fieldControl.errors) {\n      errMessage = this.fieldControl.errors.toString();\n    }\n\n    return errMessage;\n  }\n}\n\nconst buildColumnForDisplayValue = dataObj => {\n  if (dataObj.columns) {\n    dataObj.columns = dataObj.columns.map(column => {\n      const tempColObj = { ...column };\n      if (tempColObj.key === 'true') {\n        tempColObj.useForSearch = true;\n      } else {\n        tempColObj.useForSearch = false;\n      }\n      return tempColObj;\n    });\n  }\n};\n\nfunction getUserName(pConn, userId = ''): Promise<string> {\n  return new Promise(resolve => {\n    const { parameters = {}, referenceList } = pConn.getConfigProps();\n    const contextName = pConn.getContextName();\n\n    // eslint-disable-next-line @typescript-eslint/no-shadow\n    const OPERATORS_DP = referenceList || PCore.getEnvironmentInfo().getDefaultOperatorDP() || '';\n\n    const columns = [\n      {\n        value: 'pyUserName',\n        display: 'true',\n        useForSearch: true,\n        primary: 'true'\n      },\n      {\n        value: 'pyUserIdentifier',\n        setProperty: 'Associated property',\n        key: 'true',\n        display: 'true',\n        secondary: 'true',\n        useForSearch: true\n      }\n    ];\n\n    const dataConfig: any = {\n      dataSource: OPERATORS_DP,\n      parameters,\n      matchPosition: 'equals',\n      listType: 'datapage',\n      columns,\n      cacheLifeSpan: 'form',\n      deferDatasource: false,\n      maxResultsDisplay: '1',\n      ignoreCase: true\n    };\n\n    PCore.getDataApi()\n      .init(dataConfig, contextName)\n      .then(dataApiObj => {\n        buildColumnForDisplayValue(dataApiObj);\n        dataApiObj.registerForBufferedCall({ waitTime: 50 });\n        dataApiObj.fetchData(userId).then((response: any) => {\n          resolve(response.data?.[0]?.pyUserName || userId);\n        });\n      });\n  });\n}\n","<div>\n  <div *ngIf=\"displayMode$; else noDisplayMode\">\n    <component-mapper name=\"FieldValueList\" [props]=\"{ label$, value$, displayMode$ }\"></component-mapper>\n  </div>\n  <ng-template #noDisplayMode>\n    <div class=\"psdk-user-reference\">\n      <div *ngIf=\"this.userID$ && type === 'operator'\">\n        <component-mapper name=\"Operator\" [props]=\"{ pConn$, name$: userName$ }\"></component-mapper>\n      </div>\n      <div [formGroup]=\"formGroup$\" *ngIf=\"type === 'dropdown'\">\n        <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\" [hintLabel]=\"helperText\">\n          <mat-select [required]=\"bRequired$\" [formControl]=\"fieldControl\" [attr.data-test-id]=\"testId\" (selectionChange)=\"fieldOnChange($event)\">\n            <mat-option *ngFor=\"let opt of options$\" [value]=\"opt.key\">\n              {{ opt.value }}\n            </mat-option>\n          </mat-select>\n          <mat-label>{{ label$ }}</mat-label>\n          <mat-error *ngIf=\"fieldControl.invalid\">\n            {{ getErrorMessage() }}\n          </mat-error>\n        </mat-form-field>\n      </div>\n      <div [formGroup]=\"formGroup$\" *ngIf=\"type === 'searchbox'\">\n        <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\" [hintLabel]=\"helperText\">\n          <mat-label>{{ label$ }}</mat-label>\n          <input\n            matInput\n            [placeholder]=\"placeholder\"\n            [formControl]=\"fieldControl\"\n            [required]=\"bRequired$\"\n            [matAutocomplete]=\"auto\"\n            [attr.data-test-id]=\"testId\"\n            (blur)=\"fieldOnBlur($event)\"\n          />\n          <mat-autocomplete #auto=\"matAutocomplete\" autoActiveFirstOption (optionSelected)=\"optionChanged($event)\">\n            <mat-option *ngFor=\"let opt of filteredOptions | async\" [value]=\"opt.value\">\n              <span>{{ opt.value }}</span>\n            </mat-option>\n          </mat-autocomplete>\n          <mat-error *ngIf=\"fieldControl.invalid\">\n            {{ getErrorMessage() }}\n          </mat-error>\n        </mat-form-field>\n      </div>\n    </div>\n  </ng-template>\n</div>\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-reference.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/field/user-reference/user-reference.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/field/user-reference/user-reference.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,UAAU,EAAa,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAa,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAGlE,OAAO,EAAE,wBAAwB,EAAE,MAAM,8DAA8D,CAAC;AAExG,OAAO,EAAE,GAAG,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;;;AAE3D,MAAM,YAAY,GAAG,uCAAuC,CAAC;AAC7D,MAAM,aAAa,GAAG,gBAAgB,CAAC;AACvC,MAAM,UAAU,GAAG,YAAY,CAAC;AA2BhC,MAAM,OAAO,sBAAsB;IA2BjC,YACU,eAAuC,EACvC,KAAY;QADZ,oBAAe,GAAf,eAAe,CAAwB;QACvC,UAAK,GAAL,KAAK,CAAO;QAzBtB,wBAAmB,GAAwB,EAAE,CAAC;QAgB9C,gBAAW,GAAG,EAAE,CAAC;QAEjB,iBAAY,GAAG,IAAI,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QAgEzC,wBAAmB,GAAG,IAAI,CAAC,EAAE;YAC3B,OAAO,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC;QACpE,CAAC,CAAC;QAEF,gBAAW,GAAG,IAAI,CAAC,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,CAAC;QACvB,CAAC,CAAC;QAEF,aAAQ,GAAG,IAAI,CAAC,EAAE;YAChB,IAAI,IAAI,CAAC,UAAU,KAAK,aAAa,EAAE,CAAC;gBACtC,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC9D,CAAC;YACD,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC9F,CAAC,CAAC;IArEC,CAAC;IAEJ,KAAK,CAAC,QAAQ;QACZ,8FAA8F;QAC9F,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,6BAA6B,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAExG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAE9D,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,2BAA2B;YAC3B,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;YACjE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACzD,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CACxD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,EAC3C,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CACxC,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;YAC3C,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,IAAI,IAAI;QACN,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACjD,OAAO,UAAU,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,KAAK,aAAa,EAAE,CAAC;YACtC,OAAO,UAAU,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,KAAK,UAAU,EAAE,CAAC;YACnC,OAAO,WAAW,CAAC;QACrB,CAAC;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,mDAAmD;IACnD,KAAK,CAAC,aAAa;QACjB,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;IAC9B,CAAC;IAEO,OAAO,CAAC,KAAa;QAC3B,MAAM,SAAS,GAAG,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5D,OAAO,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IAC1F,CAAC;IAiBD,KAAK,CAAC,cAAc;QAClB,gEAAgE;QAChE,4BAA4B;QAC5B,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAErE,wDAAwD;QACxD,IAAI,WAAW,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,UAAU;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAwB,CAAC;QACjE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,KAAK,EAAE,cAAc,CAAC;QAE5C,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,mBAAmB,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC;QAErG,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,oBAAoB,GAAG,mBAAmB,CAAC;QAChD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,WAAW,IAAI,EAAE,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;QAEhC,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,EAAE,CAAC;QAC5B,CAAC;QAED,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;QACrC,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC;QAEtI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QAC9C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,KAAK,CAAC;QAElD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAE3C,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACjE,IAAI,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC;gBACpC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC;YAClC,CAAC;iBAAM,CAAC;gBACN,mFAAmF;gBACnF,uEAAuE;gBACvE,mEAAmE;gBACnE,IAAI,CAAC,SAAS,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAChE,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,KAAK,aAAa,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;YACnE,MAAM,YAAY,GAAG;gBACnB,YAAY,EAAE,YAAY;aAC3B,CAAC;YACF,IAAI,CAAC;gBACH,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,aAAa,EAAE,CAAC,aAAa,CAAC,aAAa,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,sDAAsD;gBACnJ,IAAI,IAAI,EAAE,IAAI,EAAE,CAAC;oBACf,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;wBACnD,GAAG,EAAE,QAAQ,CAAC,gBAAgB;wBAC9B,KAAK,EAAE,QAAQ,CAAC,UAAU;qBAC3B,CAAC,CAAC,CAAC;oBACJ,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC;gBAC/B,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC;QACH,CAAC;IACH,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,IAAI,KAAK,EAAE,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;QACnB,CAAC;QACD,IAAI,KAAK,EAAE,MAAM,EAAE,CAAC;YAClB,IAAI,CAAC,WAAW,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QAC9D,CAAC;QACD,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK,CAAC;QAC3B,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC/D,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,MAAM,KAAK,GAAG,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC;QACnC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC/D,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,GAAG,GAAG,EAAE,CAAC;QACb,IAAI,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACxF,GAAG,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC3E,CAAC;QACD,MAAM,KAAK,GAAG,GAAG,CAAC;QAClB,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAClE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,UAAU,GAAG,EAAE,CAAC;QAEpB,iGAAiG;QACjG,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;YAC1C,UAAU,GAAG,IAAI,CAAC,mBAAmB,CAAC,eAAe,IAAI,EAAE,CAAC;YAC5D,OAAO,UAAU,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3C,UAAU,GAAG,wBAAwB,CAAC;QACxC,CAAC;aAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YACpC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACnD,CAAC;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;+GArNU,sBAAsB;mGAAtB,sBAAsB,sIC5CnC,+nEA+CA,+RDbI,YAAY,wYACZ,mBAAmB,suCACnB,kBAAkB,2dAClB,eAAe,kvBACf,eAAe,mDACf,cAAc,oZACd,qBAAqB,uvBACJ,wBAAwB;;4FAGhC,sBAAsB;kBAhBlC,SAAS;+BACE,oBAAoB,cAGlB,IAAI,WACP;wBACP,YAAY;wBACZ,mBAAmB;wBACnB,kBAAkB;wBAClB,eAAe;wBACf,eAAe;wBACf,cAAc;wBACd,qBAAqB;wBACrB,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;qBAC3C;+GAGQ,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK;;AAsNR,MAAM,0BAA0B,GAAG,OAAO,CAAC,EAAE;IAC3C,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QACpB,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YAC7C,MAAM,UAAU,GAAG,EAAE,GAAG,MAAM,EAAE,CAAC;YACjC,IAAI,UAAU,CAAC,GAAG,KAAK,MAAM,EAAE,CAAC;gBAC9B,UAAU,CAAC,YAAY,GAAG,IAAI,CAAC;YACjC,CAAC;iBAAM,CAAC;gBACN,UAAU,CAAC,YAAY,GAAG,KAAK,CAAC;YAClC,CAAC;YACD,OAAO,UAAU,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;AACH,CAAC,CAAC;AAEF,SAAS,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE;IACrC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;QAC3B,MAAM,EAAE,UAAU,GAAG,EAAE,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;QAClE,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;QAE3C,wDAAwD;QACxD,MAAM,YAAY,GAAG,aAAa,IAAI,KAAK,CAAC,kBAAkB,EAAE,CAAC,oBAAoB,EAAE,IAAI,EAAE,CAAC;QAE9F,MAAM,OAAO,GAAG;YACd;gBACE,KAAK,EAAE,YAAY;gBACnB,OAAO,EAAE,MAAM;gBACf,YAAY,EAAE,IAAI;gBAClB,OAAO,EAAE,MAAM;aAChB;YACD;gBACE,KAAK,EAAE,kBAAkB;gBACzB,WAAW,EAAE,qBAAqB;gBAClC,GAAG,EAAE,MAAM;gBACX,OAAO,EAAE,MAAM;gBACf,SAAS,EAAE,MAAM;gBACjB,YAAY,EAAE,IAAI;aACnB;SACF,CAAC;QAEF,MAAM,UAAU,GAAQ;YACtB,UAAU,EAAE,YAAY;YACxB,UAAU;YACV,aAAa,EAAE,QAAQ;YACvB,QAAQ,EAAE,UAAU;YACpB,OAAO;YACP,aAAa,EAAE,MAAM;YACrB,eAAe,EAAE,KAAK;YACtB,iBAAiB,EAAE,GAAG;YACtB,UAAU,EAAE,IAAI;SACjB,CAAC;QAEF,KAAK,CAAC,UAAU,EAAE;aACf,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC;aAC7B,IAAI,CAAC,UAAU,CAAC,EAAE;YACjB,0BAA0B,CAAC,UAAU,CAAC,CAAC;YACvC,UAAU,CAAC,uBAAuB,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;YACrD,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,QAAa,EAAE,EAAE;gBAClD,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,IAAI,MAAM,CAAC,CAAC;YACpD,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\nimport { PConnFieldProps } from '../../../_types/PConnProps.interface';\nimport { map, Observable, startWith } from 'rxjs';\nimport { handleEvent } from '../../../_helpers/event-util';\n\nconst OPERATORS_DP = 'D_pyGetOperatorsForCurrentApplication';\nconst DROPDOWN_LIST = 'Drop-down list';\nconst SEARCH_BOX = 'Search box';\n\ninterface UserReferenceProps extends Omit<PConnFieldProps, 'value'> {\n  // If any, enter additional props that only exist on UserReference here\n  displayAs?: string;\n  value?: any;\n  showAsFormattedText?: boolean;\n  additionalProps?: object;\n  onRecordChange?: any;\n}\n\n@Component({\n  selector: 'app-user-reference',\n  templateUrl: './user-reference.component.html',\n  styleUrls: ['./user-reference.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class UserReferenceComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  angularPConnectData: AngularPConnectData = {};\n  controlName$: string;\n  value$;\n  userName$: string;\n  label$: string;\n  userID$: string;\n  options$: any;\n  bReadonly$: boolean;\n  bRequired$: boolean;\n  showAsFormattedText$?: boolean;\n  displayAs$?: string;\n  testId: string;\n  helperText: string;\n  placeholder: string;\n  displayMode$?: string;\n  filteredOptions: Observable<any[]>;\n  filterValue = '';\n\n  fieldControl = new FormControl('', null);\n  actionsApi: Object;\n  propName: string;\n  onRecordChange: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\n  ) {}\n\n  async ngOnInit(): Promise<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.controlName$ = this.angularPConnect.getComponentID(this);\n\n    await this.checkAndUpdate();\n\n    if (this.formGroup$) {\n      // add control to formGroup\n      this.formGroup$.addControl(this.controlName$, this.fieldControl);\n      this.fieldControl.setValue(this.getValue(this.value$));\n    }\n\n    this.filteredOptions = this.fieldControl.valueChanges.pipe(\n      startWith(this.getValue(this.value$) || ''),\n      map(value => this._filter(value || ''))\n    );\n  }\n\n  ngOnDestroy() {\n    if (this.formGroup$) {\n      this.formGroup$.removeControl(this.controlName$);\n    }\n\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  get type(): string {\n    if (this.bReadonly$ && this.showAsFormattedText$) {\n      return 'operator';\n    }\n    if (this.displayAs$ === DROPDOWN_LIST) {\n      return 'dropdown';\n    }\n    if (this.displayAs$ === SEARCH_BOX) {\n      return 'searchbox';\n    }\n\n    return '';\n  }\n\n  // Callback passed when subscribing to store change\n  async onStateChange() {\n    await this.checkAndUpdate();\n  }\n\n  private _filter(value: string): string[] {\n    const filterVal = (value || this.filterValue).toLowerCase();\n    return this.options$?.filter(option => option.value?.toLowerCase().includes(filterVal));\n  }\n\n  isUserNameAvailable = user => {\n    return typeof user === 'object' && user !== null && user.userName;\n  };\n\n  getUserName = user => {\n    return user.userName;\n  };\n\n  getValue = user => {\n    if (this.displayAs$ === DROPDOWN_LIST) {\n      return this.utils.getUserId(user) || this.getUserName(user);\n    }\n    return this.isUserNameAvailable(user) ? this.getUserName(user) : this.utils.getUserId(user);\n  };\n\n  async 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      await this.updateSelf();\n    }\n  }\n\n  async updateSelf() {\n    const props = this.pConn$.getConfigProps() as UserReferenceProps;\n    this.testId = props.testId;\n    this.onRecordChange = props?.onRecordChange;\n\n    const { label, displayAs, value, showAsFormattedText, helperText, placeholder, displayMode } = props;\n\n    this.label$ = label;\n    this.showAsFormattedText$ = showAsFormattedText;\n    this.displayAs$ = displayAs;\n    this.helperText = helperText;\n    this.placeholder = placeholder || '';\n    this.displayMode$ = displayMode;\n\n    if (value && typeof value === 'object') {\n      this.value$ = value.userName ? value.userName : '';\n    } else {\n      this.value$ = value || '';\n    }\n\n    const { readOnly, required } = props;\n    [this.bReadonly$, this.bRequired$] = [readOnly, required].map(prop => prop === true || (typeof prop === 'string' && prop === 'true'));\n\n    this.actionsApi = this.pConn$.getActionsApi();\n    this.propName = this.pConn$.getStateProps().value;\n\n    this.userID$ = this.utils.getUserId(value);\n\n    if (this.userID$ && this.bReadonly$ && this.showAsFormattedText$) {\n      if (this.isUserNameAvailable(value)) {\n        this.userName$ = value.userName;\n      } else {\n        // if same user ref field is referred in view as editable & readonly formatted text\n        // referenced users won't be available, so get user details from dx api\n        // eslint-disable-next-line @typescript-eslint/no-use-before-define\n        this.userName$ = await getUserName(this.pConn$, this.userID$);\n      }\n    } else if (displayAs === DROPDOWN_LIST || displayAs === SEARCH_BOX) {\n      const queryPayload = {\n        dataViewName: OPERATORS_DP\n      };\n      try {\n        const resp = await PCore.getRestClient().invokeRestApi('getListData', { queryPayload }, ''); // 3rd arg empty string until typedef marked correctly\n        if (resp?.data) {\n          const ddDataSource = resp.data.data.map(listItem => ({\n            key: listItem.pyUserIdentifier,\n            value: listItem.pyUserName\n          }));\n          this.options$ = ddDataSource;\n        }\n      } catch (error) {\n        console.log(error);\n      }\n    }\n  }\n\n  fieldOnChange(event: any) {\n    if (event?.value === 'Select') {\n      event.value = '';\n    }\n    if (event?.target) {\n      this.filterValue = (event.target as HTMLInputElement).value;\n    }\n    const value = event?.value;\n    handleEvent(this.actionsApi, 'change', this.propName, value);\n  }\n\n  optionChanged(event: any) {\n    const value = event?.option?.value;\n    handleEvent(this.actionsApi, 'change', this.propName, value);\n  }\n\n  fieldOnBlur(event: any) {\n    let key = '';\n    if (event?.target?.value) {\n      const index = this.options$?.findIndex(element => element.value === event.target.value);\n      key = index > -1 ? (key = this.options$[index].key) : event.target.value;\n    }\n    const value = key;\n    handleEvent(this.actionsApi, 'changeNblur', this.propName, value);\n    if (this.onRecordChange) {\n      event.target.value = value;\n      this.onRecordChange(event);\n    }\n  }\n\n  getErrorMessage() {\n    let errMessage = '';\n\n    // look for validation messages for json, pre-defined or just an error pushed from workitem (400)\n    if (this.fieldControl.hasError('message')) {\n      errMessage = this.angularPConnectData.validateMessage ?? '';\n      return errMessage;\n    }\n    if (this.fieldControl.hasError('required')) {\n      errMessage = 'You must enter a value';\n    } else if (this.fieldControl.errors) {\n      errMessage = this.fieldControl.errors.toString();\n    }\n\n    return errMessage;\n  }\n}\n\nconst buildColumnForDisplayValue = dataObj => {\n  if (dataObj.columns) {\n    dataObj.columns = dataObj.columns.map(column => {\n      const tempColObj = { ...column };\n      if (tempColObj.key === 'true') {\n        tempColObj.useForSearch = true;\n      } else {\n        tempColObj.useForSearch = false;\n      }\n      return tempColObj;\n    });\n  }\n};\n\nfunction getUserName(pConn, userId = ''): Promise<string> {\n  return new Promise(resolve => {\n    const { parameters = {}, referenceList } = pConn.getConfigProps();\n    const contextName = pConn.getContextName();\n\n    // eslint-disable-next-line @typescript-eslint/no-shadow\n    const OPERATORS_DP = referenceList || PCore.getEnvironmentInfo().getDefaultOperatorDP() || '';\n\n    const columns = [\n      {\n        value: 'pyUserName',\n        display: 'true',\n        useForSearch: true,\n        primary: 'true'\n      },\n      {\n        value: 'pyUserIdentifier',\n        setProperty: 'Associated property',\n        key: 'true',\n        display: 'true',\n        secondary: 'true',\n        useForSearch: true\n      }\n    ];\n\n    const dataConfig: any = {\n      dataSource: OPERATORS_DP,\n      parameters,\n      matchPosition: 'equals',\n      listType: 'datapage',\n      columns,\n      cacheLifeSpan: 'form',\n      deferDatasource: false,\n      maxResultsDisplay: '1',\n      ignoreCase: true\n    };\n\n    PCore.getDataApi()\n      .init(dataConfig, contextName)\n      .then(dataApiObj => {\n        buildColumnForDisplayValue(dataApiObj);\n        dataApiObj.registerForBufferedCall({ waitTime: 50 });\n        dataApiObj.fetchData(userId).then((response: any) => {\n          resolve(response.data?.[0]?.pyUserName || userId);\n        });\n      });\n  });\n}\n","<div>\n  <div *ngIf=\"displayMode$; else noDisplayMode\">\n    <component-mapper name=\"FieldValueList\" [props]=\"{ label$, value$, displayMode$ }\"></component-mapper>\n  </div>\n  <ng-template #noDisplayMode>\n    <div class=\"psdk-user-reference\">\n      <div *ngIf=\"this.userID$ && type === 'operator'\">\n        <component-mapper name=\"Operator\" [props]=\"{ pConn$, name$: userName$ }\"></component-mapper>\n      </div>\n      <div [formGroup]=\"formGroup$\" *ngIf=\"type === 'dropdown'\">\n        <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\" [hintLabel]=\"helperText\">\n          <mat-select [required]=\"bRequired$\" [formControl]=\"fieldControl\" [attr.data-test-id]=\"testId\" (selectionChange)=\"fieldOnChange($event)\">\n            <mat-option *ngFor=\"let opt of options$\" [value]=\"opt.key\">\n              {{ opt.value }}\n            </mat-option>\n          </mat-select>\n          <mat-label>{{ label$ }}</mat-label>\n          <mat-error *ngIf=\"fieldControl.invalid\">\n            {{ getErrorMessage() }}\n          </mat-error>\n        </mat-form-field>\n      </div>\n      <div [formGroup]=\"formGroup$\" *ngIf=\"type === 'searchbox'\">\n        <mat-form-field class=\"psdk-full-width\" subscriptSizing=\"dynamic\" [hintLabel]=\"helperText\">\n          <mat-label>{{ label$ }}</mat-label>\n          <input\n            matInput\n            [placeholder]=\"placeholder\"\n            [formControl]=\"fieldControl\"\n            [required]=\"bRequired$\"\n            [matAutocomplete]=\"auto\"\n            [attr.data-test-id]=\"testId\"\n            (blur)=\"fieldOnBlur($event)\"\n          />\n          <mat-autocomplete #auto=\"matAutocomplete\" autoActiveFirstOption (optionSelected)=\"optionChanged($event)\">\n            <mat-option *ngFor=\"let opt of filteredOptions | async\" [value]=\"opt.value\">\n              <span>{{ opt.value }}</span>\n            </mat-option>\n          </mat-autocomplete>\n          <mat-error *ngIf=\"fieldControl.invalid\">\n            {{ getErrorMessage() }}\n          </mat-error>\n        </mat-form-field>\n      </div>\n    </div>\n  </ng-template>\n</div>\n"]}
@@ -127,8 +127,8 @@ export class RootContainerComponent {
127
127
  }
128
128
  async configureModalContainer() {
129
129
  const sdkConfig = await this.scService.getSdkConfig();
130
- const showModalsInEmbedMode = sdkConfig.serverConfig.showModalsInEmbedMode;
131
- if (!this.displayOnlyFA$ || showModalsInEmbedMode) {
130
+ const showModalsInEmbeddedMode = sdkConfig.serverConfig.showModalsInEmbeddedMode;
131
+ if (!this.displayOnlyFA$ || showModalsInEmbeddedMode) {
132
132
  const configObjModal = PCore.createPConnect({
133
133
  meta: {
134
134
  type: 'ModalViewContainer',
@@ -220,4 +220,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
220
220
  }], isMashup$: [{
221
221
  type: Input
222
222
  }] } });
223
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-container.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, forwardRef, OnDestroy, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { interval, Subscription } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ServerConfigService } from '../../../_services/server-config.service';\nimport { ProgressSpinnerService } from '../../../_messages/progress-spinner.service';\nimport { ReferenceComponent } from '../reference/reference.component';\nimport { PreviewViewContainerComponent } from '../Containers/preview-view-container/preview-view-container.component';\nimport { ModalViewContainerComponent } from '../Containers/modal-view-container/modal-view-container.component';\nimport { HybridViewContainerComponent } from '../Containers/hybrid-view-container/hybrid-view-container.component';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\nconst options = { context: 'app' };\n\n@Component({\n  selector: 'app-root-container',\n  templateUrl: './root-container.component.html',\n  styleUrls: ['./root-container.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatProgressSpinnerModule,\n    HybridViewContainerComponent,\n    ModalViewContainerComponent,\n    PreviewViewContainerComponent,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class RootContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() displayOnlyFA$: boolean;\n  @Input() isMashup$: boolean;\n\n  scService = inject(ServerConfigService);\n\n  // For interaction with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  componentName$ = '';\n  bIsProgress$ = false;\n\n  // preview and modalview pConn\n  pvConn$: any = null;\n  mConn$: any = null;\n\n  bShowRoot$ = true;\n\n  progressSpinnerSubscription: Subscription;\n  spinnerTimer: any = null;\n  viewContainerPConn$: any = null;\n  localizedVal: any;\n  localeCategory = 'Messages';\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private psService: ProgressSpinnerService,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    const { containers } = PCore.getStore().getState();\n    const items = Object.keys(containers).filter(item => item.includes('root'));\n\n    PCore.getContainerUtils().getContainerAPI().addContainerItems(items);\n\n    // add preview and modalview containers to redux\n    // keep local copies of the the pConnect that is related\n\n    const configObjPreview = PCore.createPConnect({\n      meta: {\n        type: 'PreviewViewContainer',\n        config: {\n          name: 'preview'\n        }\n      },\n      options\n    });\n\n    this.pvConn$ = configObjPreview.getPConnect();\n\n    this.configureModalContainer();\n\n    // clear out hasViewContainer\n    sessionStorage.setItem('hasViewContainer', 'false');\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    // handle showing and hiding the progress spinner\n    this.progressSpinnerSubscription = this.psService.getMessage().subscribe(message => {\n      this.showHideProgress(message.show);\n    });\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  updateSelf() {\n    // need to call this.getCurrentCompleteProps (not this.thePConn.getConfigProps)\n    //  to get full set of props that affect this component in Redux\n    const myProps: any = this.angularPConnect.getCurrentCompleteProps(this);\n\n    const renderingModes = ['portal', 'view'];\n    const noPortalMode = 'noPortal';\n\n    const { renderingMode, children, skeleton, routingInfo } = myProps;\n\n    if (routingInfo && renderingModes.includes(renderingMode)) {\n      const { accessedOrder, items } = routingInfo;\n      if (accessedOrder && items) {\n        // bootstrap loadPortal resolves to here\n        const key = accessedOrder[accessedOrder.length - 1];\n        if (items[key] && items[key].view && Object.keys(items[key].view).length > 0) {\n          const itemView = items[key].view;\n\n          const rootObject = PCore.createPConnect({\n            meta: itemView,\n            options: {\n              context: items[key].context\n            }\n          });\n\n          setTimeout(() => {\n            // makes sure Angular tracks these changes\n            this.ngZone.run(() => {\n              // the new rootObject may be a 'reference'. So,\n              //  normalize it to get the referencedView if that's the case\n              const theNewPConn = ReferenceComponent.normalizePConn(rootObject.getPConnect());\n              // update ComponentName$ before we update pConn$ to make sure they're in sync\n              //  when rendering...\n              this.componentName$ = theNewPConn.getComponentName();\n\n              this.pConn$ = theNewPConn;\n              // this.pConn$ = rootObject.getPConnect();\n\n              console.log(`RootContainer updated pConn$ to be: ${this.componentName$}`);\n            });\n          });\n        }\n      }\n    } else if (renderingMode === noPortalMode) {\n      // console.log(`RootContainer: renderingMode === noPortalMode: ${noPortalMode}`);\n      this.generateViewContainerForNoPortal();\n    } else if (children && children.length > 0) {\n      // haven't resolved to here\n    } else if (skeleton !== undefined) {\n      // TODO: need to update once skeletons are available;\n    }\n  }\n\n  async configureModalContainer() {\n    const sdkConfig = await this.scService.getSdkConfig();\n    const showModalsInEmbedMode = sdkConfig.serverConfig.showModalsInEmbedMode;\n\n    if (!this.displayOnlyFA$ || showModalsInEmbedMode) {\n      const configObjModal = PCore.createPConnect({\n        meta: {\n          type: 'ModalViewContainer',\n          config: {\n            name: 'modal'\n          }\n        },\n        options\n      });\n\n      this.mConn$ = configObjModal.getPConnect();\n    }\n  }\n\n  generateViewContainerForNoPortal() {\n    // bootstrap loadMashup resolves to here\n    const arChildren = this.pConn$.getChildren() as any[];\n    if (arChildren && arChildren.length == 1) {\n      // have to have a quick timeout or get an \"expressions changed\" angular error\n      setTimeout(() => {\n        this.ngZone.run(() => {\n          const localPConn = arChildren[0].getPConnect();\n\n          this.componentName$ = localPConn.getComponentName();\n          if (this.componentName$ === 'ViewContainer') {\n            const configProps = this.pConn$.getConfigProps();\n            const viewContConfig = {\n              meta: {\n                type: 'ViewContainer',\n                config: configProps\n              },\n              options\n            };\n\n            this.viewContainerPConn$ = PCore.createPConnect(viewContConfig).getPConnect();\n          }\n          this.bShowRoot$ = true;\n        });\n      });\n    }\n  }\n\n  showHideProgress(bShow: boolean) {\n    // only show spinner after 500ms wait, so if server fast, won't see\n    if (bShow) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        if (!this.spinnerTimer || this.spinnerTimer.isStopped) {\n          this.spinnerTimer = interval(500).subscribe(() => {\n            try {\n              this.spinnerTimer.unsubscribe();\n            } catch (ex) {\n              /* empty */\n            }\n\n            this.ngZone.run(() => {\n              this.bIsProgress$ = true;\n            });\n          });\n        }\n      }\n    } else {\n      if (this.spinnerTimer && !this.spinnerTimer.isStopped) {\n        this.spinnerTimer.unsubscribe();\n      }\n\n      // don't touch bIsProgress$ unless differnent\n      if (bShow != this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        this.ngZone.run(() => {\n          this.bIsProgress$ = bShow;\n        });\n      }\n    }\n  }\n}\n","<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n  <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n  <div [ngSwitch]=\"componentName$\">\n    <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n    <component-mapper\n      *ngSwitchCase=\"'ViewContainer'\"\n      name=\"ViewContainer\"\n      [props]=\"{ pConn$: viewContainerPConn$, displayOnlyFA$ }\"\n    ></component-mapper>\n    <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n  </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n  <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n  <app-modal-view-container [pConn$]=\"mConn$\"></app-modal-view-container>\n</div>\n"]}
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-container.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/infra/root-container/root-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, forwardRef, OnDestroy, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { interval, Subscription } from 'rxjs';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ServerConfigService } from '../../../_services/server-config.service';\nimport { ProgressSpinnerService } from '../../../_messages/progress-spinner.service';\nimport { ReferenceComponent } from '../reference/reference.component';\nimport { PreviewViewContainerComponent } from '../Containers/preview-view-container/preview-view-container.component';\nimport { ModalViewContainerComponent } from '../Containers/modal-view-container/modal-view-container.component';\nimport { HybridViewContainerComponent } from '../Containers/hybrid-view-container/hybrid-view-container.component';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\n/**\n * WARNING:  It is not expected that this file should be modified.  It is part of infrastructure code that works with\n * Redux and creation/update of Redux containers and PConnect.  Modifying this code could have undesireable results and\n * is totally at your own risk.\n */\n\nconst options = { context: 'app' };\n\n@Component({\n  selector: 'app-root-container',\n  templateUrl: './root-container.component.html',\n  styleUrls: ['./root-container.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatProgressSpinnerModule,\n    HybridViewContainerComponent,\n    ModalViewContainerComponent,\n    PreviewViewContainerComponent,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class RootContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() displayOnlyFA$: boolean;\n  @Input() isMashup$: boolean;\n\n  scService = inject(ServerConfigService);\n\n  // For interaction with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  componentName$ = '';\n  bIsProgress$ = false;\n\n  // preview and modalview pConn\n  pvConn$: any = null;\n  mConn$: any = null;\n\n  bShowRoot$ = true;\n\n  progressSpinnerSubscription: Subscription;\n  spinnerTimer: any = null;\n  viewContainerPConn$: any = null;\n  localizedVal: any;\n  localeCategory = 'Messages';\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private psService: ProgressSpinnerService,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    const { containers } = PCore.getStore().getState();\n    const items = Object.keys(containers).filter(item => item.includes('root'));\n\n    PCore.getContainerUtils().getContainerAPI().addContainerItems(items);\n\n    // add preview and modalview containers to redux\n    // keep local copies of the the pConnect that is related\n\n    const configObjPreview = PCore.createPConnect({\n      meta: {\n        type: 'PreviewViewContainer',\n        config: {\n          name: 'preview'\n        }\n      },\n      options\n    });\n\n    this.pvConn$ = configObjPreview.getPConnect();\n\n    this.configureModalContainer();\n\n    // clear out hasViewContainer\n    sessionStorage.setItem('hasViewContainer', 'false');\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    // handle showing and hiding the progress spinner\n    this.progressSpinnerSubscription = this.psService.getMessage().subscribe(message => {\n      this.showHideProgress(message.show);\n    });\n    this.localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    // Should always check the bridge to see if the component should update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  updateSelf() {\n    // need to call this.getCurrentCompleteProps (not this.thePConn.getConfigProps)\n    //  to get full set of props that affect this component in Redux\n    const myProps: any = this.angularPConnect.getCurrentCompleteProps(this);\n\n    const renderingModes = ['portal', 'view'];\n    const noPortalMode = 'noPortal';\n\n    const { renderingMode, children, skeleton, routingInfo } = myProps;\n\n    if (routingInfo && renderingModes.includes(renderingMode)) {\n      const { accessedOrder, items } = routingInfo;\n      if (accessedOrder && items) {\n        // bootstrap loadPortal resolves to here\n        const key = accessedOrder[accessedOrder.length - 1];\n        if (items[key] && items[key].view && Object.keys(items[key].view).length > 0) {\n          const itemView = items[key].view;\n\n          const rootObject = PCore.createPConnect({\n            meta: itemView,\n            options: {\n              context: items[key].context\n            }\n          });\n\n          setTimeout(() => {\n            // makes sure Angular tracks these changes\n            this.ngZone.run(() => {\n              // the new rootObject may be a 'reference'. So,\n              //  normalize it to get the referencedView if that's the case\n              const theNewPConn = ReferenceComponent.normalizePConn(rootObject.getPConnect());\n              // update ComponentName$ before we update pConn$ to make sure they're in sync\n              //  when rendering...\n              this.componentName$ = theNewPConn.getComponentName();\n\n              this.pConn$ = theNewPConn;\n              // this.pConn$ = rootObject.getPConnect();\n\n              console.log(`RootContainer updated pConn$ to be: ${this.componentName$}`);\n            });\n          });\n        }\n      }\n    } else if (renderingMode === noPortalMode) {\n      // console.log(`RootContainer: renderingMode === noPortalMode: ${noPortalMode}`);\n      this.generateViewContainerForNoPortal();\n    } else if (children && children.length > 0) {\n      // haven't resolved to here\n    } else if (skeleton !== undefined) {\n      // TODO: need to update once skeletons are available;\n    }\n  }\n\n  async configureModalContainer() {\n    const sdkConfig = await this.scService.getSdkConfig();\n    const showModalsInEmbeddedMode = sdkConfig.serverConfig.showModalsInEmbeddedMode;\n\n    if (!this.displayOnlyFA$ || showModalsInEmbeddedMode) {\n      const configObjModal = PCore.createPConnect({\n        meta: {\n          type: 'ModalViewContainer',\n          config: {\n            name: 'modal'\n          }\n        },\n        options\n      });\n\n      this.mConn$ = configObjModal.getPConnect();\n    }\n  }\n\n  generateViewContainerForNoPortal() {\n    // bootstrap loadMashup resolves to here\n    const arChildren = this.pConn$.getChildren() as any[];\n    if (arChildren && arChildren.length == 1) {\n      // have to have a quick timeout or get an \"expressions changed\" angular error\n      setTimeout(() => {\n        this.ngZone.run(() => {\n          const localPConn = arChildren[0].getPConnect();\n\n          this.componentName$ = localPConn.getComponentName();\n          if (this.componentName$ === 'ViewContainer') {\n            const configProps = this.pConn$.getConfigProps();\n            const viewContConfig = {\n              meta: {\n                type: 'ViewContainer',\n                config: configProps\n              },\n              options\n            };\n\n            this.viewContainerPConn$ = PCore.createPConnect(viewContConfig).getPConnect();\n          }\n          this.bShowRoot$ = true;\n        });\n      });\n    }\n  }\n\n  showHideProgress(bShow: boolean) {\n    // only show spinner after 500ms wait, so if server fast, won't see\n    if (bShow) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        if (!this.spinnerTimer || this.spinnerTimer.isStopped) {\n          this.spinnerTimer = interval(500).subscribe(() => {\n            try {\n              this.spinnerTimer.unsubscribe();\n            } catch (ex) {\n              /* empty */\n            }\n\n            this.ngZone.run(() => {\n              this.bIsProgress$ = true;\n            });\n          });\n        }\n      }\n    } else {\n      if (this.spinnerTimer && !this.spinnerTimer.isStopped) {\n        this.spinnerTimer.unsubscribe();\n      }\n\n      // don't touch bIsProgress$ unless differnent\n      if (bShow != this.bIsProgress$) {\n        // makes sure Angular tracks these changes\n        this.ngZone.run(() => {\n          this.bIsProgress$ = bShow;\n        });\n      }\n    }\n  }\n}\n","<div class=\"progress-box\" *ngIf=\"bIsProgress$\">\n  <mat-spinner class=\"progress-spinner\"></mat-spinner>\n</div>\n\n<div *ngIf=\"bShowRoot$\">\n  <div [ngSwitch]=\"componentName$\">\n    <component-mapper *ngSwitchCase=\"'View'\" name=\"View\" [props]=\"{ pConn$, displayOnlyFA$ }\"></component-mapper>\n    <component-mapper\n      *ngSwitchCase=\"'ViewContainer'\"\n      name=\"ViewContainer\"\n      [props]=\"{ pConn$: viewContainerPConn$, displayOnlyFA$ }\"\n    ></component-mapper>\n    <div *ngSwitchDefault>{{ localizedVal('RootContainer Missing: ' + componentName$, localeCategory) }}.</div>\n  </div>\n</div>\n\n<div *ngIf=\"pvConn$ != null\">\n  <app-preview-view-container [pConn$]=\"pvConn$\"></app-preview-view-container>\n</div>\n\n<div *ngIf=\"mConn$ != null\">\n  <app-modal-view-container [pConn$]=\"mConn$\"></app-modal-view-container>\n</div>\n"]}
@@ -57,12 +57,12 @@ export class ConfirmationComponent {
57
57
  PCore.getPubSubUtils().publish(PCore.getConstants().PUB_SUB_EVENTS.CASE_EVENTS.CLOSE_CONFIRM_VIEW, this.rootInfo);
58
58
  }
59
59
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ConfirmationComponent, deps: [{ token: i1.AngularPConnectService }], target: i0.ɵɵFactoryTarget.Component }); }
60
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ConfirmationComponent, isStandalone: true, selector: "app-confirmation", inputs: { pConn$: "pConn$" }, ngImport: i0, template: "<div>\n <div *ngIf=\"showConfirmView\">\n <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n <div *ngIf=\"showDetails\">\n <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n </div>\n <div *ngIf=\"showTasks && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n <div class=\"done-button\">\n <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n </div>\n </div>\n <div *ngIf=\"toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".done-button{justify-content:flex-end;display:flex;padding-bottom:1rem}.confirm-label{padding:0 16px;margin:0}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(() => CommonModule) }, { kind: "directive", type: i0.forwardRef(() => i2.NgIf), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatButtonModule) }, { kind: "component", type: i0.forwardRef(() => i3.MatButton), selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i0.forwardRef(() => ComponentMapperComponent), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
60
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ConfirmationComponent, isStandalone: true, selector: "app-confirmation", inputs: { pConn$: "pConn$" }, ngImport: i0, template: "<div>\n <div *ngIf=\"showConfirmView\">\n <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n <div *ngIf=\"showDetails\">\n <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n </div>\n <div *ngIf=\"showTasks && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n <div class=\"done-button\">\n <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n </div>\n </div>\n <div *ngIf=\"!showConfirmView && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".done-button{justify-content:flex-end;display:flex;padding-bottom:1rem}.confirm-label{padding:0 16px;margin:0}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(() => CommonModule) }, { kind: "directive", type: i0.forwardRef(() => i2.NgIf), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatButtonModule) }, { kind: "component", type: i0.forwardRef(() => i3.MatButton), selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i0.forwardRef(() => ComponentMapperComponent), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
61
61
  }
62
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ConfirmationComponent, decorators: [{
63
63
  type: Component,
64
- args: [{ selector: 'app-confirmation', standalone: true, imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)], template: "<div>\n <div *ngIf=\"showConfirmView\">\n <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n <div *ngIf=\"showDetails\">\n <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n </div>\n <div *ngIf=\"showTasks && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n <div class=\"done-button\">\n <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n </div>\n </div>\n <div *ngIf=\"toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".done-button{justify-content:flex-end;display:flex;padding-bottom:1rem}.confirm-label{padding:0 16px;margin:0}\n"] }]
64
+ args: [{ selector: 'app-confirmation', standalone: true, imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)], template: "<div>\n <div *ngIf=\"showConfirmView\">\n <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n <div *ngIf=\"showDetails\">\n <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n </div>\n <div *ngIf=\"showTasks && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n <div class=\"done-button\">\n <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n </div>\n </div>\n <div *ngIf=\"!showConfirmView && toDoList?.length > 0\">\n <component-mapper\n name=\"Todo\"\n [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".done-button{justify-content:flex-end;display:flex;padding-bottom:1rem}.confirm-label{padding:0 16px;margin:0}\n"] }]
65
65
  }], ctorParameters: () => [{ type: i1.AngularPConnectService }], propDecorators: { pConn$: [{
66
66
  type: Input
67
67
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/confirmation/confirmation.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/confirmation/confirmation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { publicConstants } from '@pega/pcore-pconnect-typedefs/constants';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { getToDoAssignments } from '../../infra/Containers/flow-container/helpers';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface ConfirmationProps {\n  // If any, enter additional props that only exist on this component\n  datasource: { source: any };\n  label: string;\n  showLabel: boolean;\n  showTasks: boolean;\n}\n\n@Component({\n  selector: 'app-confirmation',\n  templateUrl: './confirmation.component.html',\n  styleUrls: ['./confirmation.component.scss'],\n  standalone: true,\n  imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class ConfirmationComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n\n  angularPConnectData: AngularPConnectData = {};\n  configProps$: ConfirmationProps;\n\n  rootInfo: any;\n  datasource: any;\n  showTasks: any;\n  detailProps: any;\n  toDoList: any;\n  label: string;\n  CONSTS: typeof publicConstants;\n  showDetails: boolean;\n  showConfirmView = true;\n\n  constructor(private angularPConnect: AngularPConnectService) {}\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    this.CONSTS = PCore.getConstants();\n    const activeContainerItemID = PCore.getContainerUtils().getActiveContainerItemName(this.pConn$.getTarget() ?? null);\n    this.rootInfo = PCore.getContainerUtils().getContainerItemData(this.pConn$.getTarget(), activeContainerItemID);\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 theConfigProps = this.pConn$.getConfigProps() as ConfirmationProps;\n    this.datasource = theConfigProps?.datasource;\n    this.showTasks = theConfigProps?.showTasks;\n    this.label = theConfigProps?.label;\n    // Get the inherited props from the parent to determine label settings\n    // Not using whatsNext at the moment, need to figure out the use of it\n    // const whatsNext = this.datasource?.source;\n    // const items = whatsNext?.length > 0 ? whatsNext.map((item) => item.label) : '';\n    // const todoProps = { ...theConfigProps, renderTodoInConfirm: true };\n    this.toDoList = getToDoAssignments(this.pConn$);\n    this.detailProps = { ...theConfigProps, showLabel: false };\n    this.showDetails = this.pConn$?.getChildren()?.[0]?.getPConnect()?.getChildren()?.length > 0;\n  }\n\n  onConfirmViewClose() {\n    this.showConfirmView = false;\n    PCore.getPubSubUtils().publish(PCore.getConstants().PUB_SUB_EVENTS.CASE_EVENTS.CLOSE_CONFIRM_VIEW, this.rootInfo);\n  }\n}\n","<div>\n  <div *ngIf=\"showConfirmView\">\n    <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n    <div *ngIf=\"showDetails\">\n      <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n    </div>\n    <div *ngIf=\"showTasks && toDoList?.length > 0\">\n      <component-mapper\n        name=\"Todo\"\n        [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n      ></component-mapper>\n    </div>\n    <div class=\"done-button\">\n      <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n    </div>\n  </div>\n  <div *ngIf=\"toDoList?.length > 0\">\n    <component-mapper\n      name=\"Todo\"\n      [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n    ></component-mapper>\n  </div>\n</div>\n"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/confirmation/confirmation.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/confirmation/confirmation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { publicConstants } from '@pega/pcore-pconnect-typedefs/constants';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { getToDoAssignments } from '../../infra/Containers/flow-container/helpers';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface ConfirmationProps {\n  // If any, enter additional props that only exist on this component\n  datasource: { source: any };\n  label: string;\n  showLabel: boolean;\n  showTasks: boolean;\n}\n\n@Component({\n  selector: 'app-confirmation',\n  templateUrl: './confirmation.component.html',\n  styleUrls: ['./confirmation.component.scss'],\n  standalone: true,\n  imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class ConfirmationComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n\n  angularPConnectData: AngularPConnectData = {};\n  configProps$: ConfirmationProps;\n\n  rootInfo: any;\n  datasource: any;\n  showTasks: any;\n  detailProps: any;\n  toDoList: any;\n  label: string;\n  CONSTS: typeof publicConstants;\n  showDetails: boolean;\n  showConfirmView = true;\n\n  constructor(private angularPConnect: AngularPConnectService) {}\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    this.CONSTS = PCore.getConstants();\n    const activeContainerItemID = PCore.getContainerUtils().getActiveContainerItemName(this.pConn$.getTarget() ?? null);\n    this.rootInfo = PCore.getContainerUtils().getContainerItemData(this.pConn$.getTarget(), activeContainerItemID);\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 theConfigProps = this.pConn$.getConfigProps() as ConfirmationProps;\n    this.datasource = theConfigProps?.datasource;\n    this.showTasks = theConfigProps?.showTasks;\n    this.label = theConfigProps?.label;\n    // Get the inherited props from the parent to determine label settings\n    // Not using whatsNext at the moment, need to figure out the use of it\n    // const whatsNext = this.datasource?.source;\n    // const items = whatsNext?.length > 0 ? whatsNext.map((item) => item.label) : '';\n    // const todoProps = { ...theConfigProps, renderTodoInConfirm: true };\n    this.toDoList = getToDoAssignments(this.pConn$);\n    this.detailProps = { ...theConfigProps, showLabel: false };\n    this.showDetails = this.pConn$?.getChildren()?.[0]?.getPConnect()?.getChildren()?.length > 0;\n  }\n\n  onConfirmViewClose() {\n    this.showConfirmView = false;\n    PCore.getPubSubUtils().publish(PCore.getConstants().PUB_SUB_EVENTS.CASE_EVENTS.CLOSE_CONFIRM_VIEW, this.rootInfo);\n  }\n}\n","<div>\n  <div *ngIf=\"showConfirmView\">\n    <h2 id=\"confirm-label\" class=\"confirm-label\">{{ label }}</h2>\n    <div *ngIf=\"showDetails\">\n      <component-mapper name=\"Details\" [props]=\"{ pConn$ }\"></component-mapper>\n    </div>\n    <div *ngIf=\"showTasks && toDoList?.length > 0\">\n      <component-mapper\n        name=\"Todo\"\n        [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Open Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n      ></component-mapper>\n    </div>\n    <div class=\"done-button\">\n      <button mat-raised-button color=\"primary\" (click)=\"onConfirmViewClose()\">Done</button>\n    </div>\n  </div>\n  <div *ngIf=\"!showConfirmView && toDoList?.length > 0\">\n    <component-mapper\n      name=\"Todo\"\n      [props]=\"{ pConn$, datasource$: { source: toDoList }, headerText$: 'Tasks', type$: CONSTS.TODO, isConfirm: true }\"\n    ></component-mapper>\n  </div>\n</div>\n"]}