bpm-core 0.0.67 → 0.0.68

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.
@@ -203,7 +203,7 @@ export class FormSectionComponent {
203
203
  * @return {string} - The CSS class corresponding to the given status.
204
204
  */
205
205
  statusClass(status) {
206
- status = status ? status.toLowerCase() : '';
206
+ // status = status ? status.toLowerCase() : '';
207
207
  let statusStrategy = StatusMap[status] || StatusMap['default'];
208
208
  return statusStrategy.class;
209
209
  }
@@ -252,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
252
252
  }], sectionName: [{
253
253
  type: Input
254
254
  }] } });
255
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input, OnInit} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\nimport {format} from 'date-fns';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\nconst StatusMap = {\r\n  [Constants.FORM_STATUS_REJECTED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCELLED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_REJECT]: {class: 'danger', icon: 'close'},\r\n  [Constants.SECTION_STATUS_UNSATISFIED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCEL]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_PENDING]: {class: 'warning', icon: 'clock'},\r\n  'default': {class: 'success', icon: 'check'}\r\n}\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit {\r\n  userType = 'recipient';\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  processingDate: string;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n  }\r\n\r\n  /**\r\n   * Method to initialize various components when the component is initialized.\r\n   *\r\n   * @return {void}\r\n   */\r\n  ngOnInit() {\r\n    this.initSectionFormComponent();\r\n    this.initSectionName();\r\n    this.initInput();\r\n    this.initProcessingDate();\r\n  }\r\n\r\n  /**\r\n   * Initializes the section form component by fetching it from the segment dynamic loader service.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionFormComponent() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Initializes the section name based on the provided section data.\r\n   * If the section's body contains a 'stageName' property, the section name is set to the value of that property.\r\n   * Otherwise, the section name is retrieved using the segmentDynamicLoaderService based on the section ID.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionName() {\r\n    if (this.section.body.details?.['stageName']) {\r\n      this.sectionName = this.section.body.details['stageName']?.value ??this.section.body.details['stageName'];\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Initializes the input object with the provided values for read-only status, list of values, section, and form.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initInput() {\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      form: this.form\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Initializes the processing date based on the section's header processing date.\r\n   * If the processing date is available in the section header, it formats the processing date\r\n   * and assigns it to the processingDate property of the instance.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initProcessingDate() {\r\n    if (this.section?.header?.processingDate) {\r\n      this.processingDate = format(new Date(this.section.header.processingDate), \"dd/MM/yyyy hh:mm:ss\");\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Check if the section is expanded.\r\n   *\r\n   * @return {boolean} Returns true if the section is expanded, false otherwise.\r\n   */\r\n  get isExpanded(): boolean {\r\n    const hasSections = Boolean(this.form?.sections?.length);\r\n    const isAnySectionExpandable = hasSections && this.form.sections.some(section => 'expandStage' in (section?.body?.details || {}));\r\n    return isAnySectionExpandable ? (this.section?.body?.details?.['expandStage'] === 'true') : true;\r\n  }\r\n\r\n  /**\r\n   * Create a ProfileInfoDrop object from the response object.\r\n   *\r\n   * @param {any} response - The response object containing user profile information.\r\n   *\r\n   * @return {ProfileInfoDrop} A ProfileInfoDrop object created from the response data.\r\n   */\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    const user = response?.[\"Users\"][0];\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      user?.employeeNumber,\r\n      user?.email,\r\n      user?.name,\r\n      user?.generalDepartment?.name,\r\n      user?.position?.name,\r\n      user?.sector?.name,\r\n      user?.department?.name,\r\n      user?.generalDepartment?.code,\r\n      user?.location,\r\n      user?.nationality?.desc,\r\n      user?.contact?.mobile,\r\n      user?.manager?.name,\r\n      user?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Method to open or create a user profile.\r\n   *\r\n   * @param {ProfileInfoDrop} userData - The user profile data to open or create.\r\n   * @param {string} personType - The type of person this profile belongs to.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  /**\r\n   * Toggles the display of small profile information for a given person type\r\n   *\r\n   * @param {any} event - The event that triggered the toggle\r\n   * @param {string} personType - The type of person for which to display the profile information\r\n   *\r\n   * @return {void}\r\n   */\r\n  toggleSmallProfileInfo(event: any, personType: string): void {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (!userInfo.profile) {\r\n      this.popoverType = personType;\r\n      let userEmail = this.getUserEmail(personType);\r\n      this.fetchAndSetUserProfile(userEmail, personType);\r\n    } else {\r\n      this.openOrCreateUserProfile(userInfo.profile, personType);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieves the email of the user based on the personType parameter.\r\n   *\r\n   * @param {string} personType - Type of the person ('recipient' or others).\r\n   * @return {string} - The email address of the user.\r\n   */\r\n  private getUserEmail(personType: string): string {\r\n    return (personType === 'recipient'\r\n        ? this.section.header.personToThumbnail.split('=')[1]\r\n        : this?.section?.header?.delegatedToThumbnail.split('=')[1]\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Fetches the user profile using the provided user email and person type, then sets the profile.\r\n   *\r\n   * @param {string} userEmail - The email of the user whose profile is to be fetched and set.\r\n   * @param {string} personType - The type of person (e.g., employee, customer) for whom the profile is being fetched.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private fetchAndSetUserProfile(userEmail: string, personType: string): void {\r\n    this.coreService.employeeProfile(userEmail).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((response: any) => {\r\n      if (response) {\r\n        let userData = this.createUserProfileFromResponse(response);\r\n        this.openOrCreateUserProfile(userData, personType);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS class associated with the input status.\r\n   *\r\n   * @param {string} status - The status for which the CSS class is needed.\r\n   * @return {string} - The CSS class corresponding to the given status.\r\n   */\r\n  statusClass(status: string): string {\r\n    status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.class;\r\n  }\r\n\r\n  /**\r\n   * Returns the icon associated with the provided status.\r\n   *\r\n   * @param {string} status - The status for which to retrieve the icon.\r\n   * @return {string} The icon corresponding to the provided status.\r\n   */\r\n  statusIcon(status: string): string {\r\n    status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.icon;\r\n  }\r\n}\r\n","<mat-expansion-panel class=\"mb-4\" [expanded]=\"isExpanded\" hideToggle #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          @if (section.header?.processedBy) {\r\n            <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\">\r\n              {{ processingDate }}\r\n            </bdi>\r\n          }\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n        @if (!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false') {\r\n          <ng-container>\r\n            @if (section?.header?.personTo) {\r\n              <div\r\n                class=\"d-flex align-items-center gap-3\"\r\n                (click)=\"$event.stopImmediatePropagation();\">\r\n                <div\r\n                  (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n                  class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n                  [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n                  <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                  @if (!section?.header?.delegatedTo) {\r\n                    <span\r\n                      class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\"\r\n                      [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                    >{{ section?.header?.personTo }}</span>\r\n                  }\r\n                </div>\r\n                @if (section?.header?.delegatedTo) {\r\n                  <div\r\n                    class=\"d-flex align-items-center gap-3\"\r\n                    (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n                    <img\r\n                      class=\"rotate-arrow\"\r\n                      alt=\"\"\r\n                      src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n                    <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                      <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                      <span\r\n                        class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n                    </div>\r\n                  </div>\r\n                }\r\n              </div>\r\n            }\r\n          </ng-container>\r\n        }\r\n\r\n        @if (section?.body?.details?.['decision']?.key) {\r\n          <ds-status\r\n            class=\"main-status\"\r\n            status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n          </ds-status>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        @if (approvalPanel.expanded) {\r\n          <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n        } @else {\r\n          <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n        }\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input, OnInit} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\nimport {format} from 'date-fns';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\nconst StatusMap = {\r\n  [Constants.FORM_STATUS_REJECTED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCELLED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_REJECT]: {class: 'danger', icon: 'close'},\r\n  [Constants.SECTION_STATUS_UNSATISFIED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCEL]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_PENDING]: {class: 'warning', icon: 'clock'},\r\n  'default': {class: 'success', icon: 'check'}\r\n}\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit {\r\n  userType = 'recipient';\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  processingDate: string;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n  }\r\n\r\n  /**\r\n   * Method to initialize various components when the component is initialized.\r\n   *\r\n   * @return {void}\r\n   */\r\n  ngOnInit() {\r\n    this.initSectionFormComponent();\r\n    this.initSectionName();\r\n    this.initInput();\r\n    this.initProcessingDate();\r\n  }\r\n\r\n  /**\r\n   * Initializes the section form component by fetching it from the segment dynamic loader service.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionFormComponent() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Initializes the section name based on the provided section data.\r\n   * If the section's body contains a 'stageName' property, the section name is set to the value of that property.\r\n   * Otherwise, the section name is retrieved using the segmentDynamicLoaderService based on the section ID.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionName() {\r\n    if (this.section.body.details?.['stageName']) {\r\n      this.sectionName = this.section.body.details['stageName']?.value ??this.section.body.details['stageName'];\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Initializes the input object with the provided values for read-only status, list of values, section, and form.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initInput() {\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      form: this.form\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Initializes the processing date based on the section's header processing date.\r\n   * If the processing date is available in the section header, it formats the processing date\r\n   * and assigns it to the processingDate property of the instance.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initProcessingDate() {\r\n    if (this.section?.header?.processingDate) {\r\n      this.processingDate = format(new Date(this.section.header.processingDate), \"dd/MM/yyyy hh:mm:ss\");\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Check if the section is expanded.\r\n   *\r\n   * @return {boolean} Returns true if the section is expanded, false otherwise.\r\n   */\r\n  get isExpanded(): boolean {\r\n    const hasSections = Boolean(this.form?.sections?.length);\r\n    const isAnySectionExpandable = hasSections && this.form.sections.some(section => 'expandStage' in (section?.body?.details || {}));\r\n    return isAnySectionExpandable ? (this.section?.body?.details?.['expandStage'] === 'true') : true;\r\n  }\r\n\r\n  /**\r\n   * Create a ProfileInfoDrop object from the response object.\r\n   *\r\n   * @param {any} response - The response object containing user profile information.\r\n   *\r\n   * @return {ProfileInfoDrop} A ProfileInfoDrop object created from the response data.\r\n   */\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    const user = response?.[\"Users\"][0];\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      user?.employeeNumber,\r\n      user?.email,\r\n      user?.name,\r\n      user?.generalDepartment?.name,\r\n      user?.position?.name,\r\n      user?.sector?.name,\r\n      user?.department?.name,\r\n      user?.generalDepartment?.code,\r\n      user?.location,\r\n      user?.nationality?.desc,\r\n      user?.contact?.mobile,\r\n      user?.manager?.name,\r\n      user?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Method to open or create a user profile.\r\n   *\r\n   * @param {ProfileInfoDrop} userData - The user profile data to open or create.\r\n   * @param {string} personType - The type of person this profile belongs to.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  /**\r\n   * Toggles the display of small profile information for a given person type\r\n   *\r\n   * @param {any} event - The event that triggered the toggle\r\n   * @param {string} personType - The type of person for which to display the profile information\r\n   *\r\n   * @return {void}\r\n   */\r\n  toggleSmallProfileInfo(event: any, personType: string): void {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (!userInfo.profile) {\r\n      this.popoverType = personType;\r\n      let userEmail = this.getUserEmail(personType);\r\n      this.fetchAndSetUserProfile(userEmail, personType);\r\n    } else {\r\n      this.openOrCreateUserProfile(userInfo.profile, personType);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieves the email of the user based on the personType parameter.\r\n   *\r\n   * @param {string} personType - Type of the person ('recipient' or others).\r\n   * @return {string} - The email address of the user.\r\n   */\r\n  private getUserEmail(personType: string): string {\r\n    return (personType === 'recipient'\r\n        ? this.section.header.personToThumbnail.split('=')[1]\r\n        : this?.section?.header?.delegatedToThumbnail.split('=')[1]\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Fetches the user profile using the provided user email and person type, then sets the profile.\r\n   *\r\n   * @param {string} userEmail - The email of the user whose profile is to be fetched and set.\r\n   * @param {string} personType - The type of person (e.g., employee, customer) for whom the profile is being fetched.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private fetchAndSetUserProfile(userEmail: string, personType: string): void {\r\n    this.coreService.employeeProfile(userEmail).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((response: any) => {\r\n      if (response) {\r\n        let userData = this.createUserProfileFromResponse(response);\r\n        this.openOrCreateUserProfile(userData, personType);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS class associated with the input status.\r\n   *\r\n   * @param {string} status - The status for which the CSS class is needed.\r\n   * @return {string} - The CSS class corresponding to the given status.\r\n   */\r\n  statusClass(status: string): string {\r\n    // status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.class;\r\n  }\r\n\r\n  /**\r\n   * Returns the icon associated with the provided status.\r\n   *\r\n   * @param {string} status - The status for which to retrieve the icon.\r\n   * @return {string} The icon corresponding to the provided status.\r\n   */\r\n  statusIcon(status: string): string {\r\n    status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.icon;\r\n  }\r\n}\r\n","<mat-expansion-panel class=\"mb-4\" [expanded]=\"isExpanded\" hideToggle #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          @if (section.header?.processedBy) {\r\n            <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\">\r\n              {{ processingDate }}\r\n            </bdi>\r\n          }\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n        @if (!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false') {\r\n          <ng-container>\r\n            @if (section?.header?.personTo) {\r\n              <div\r\n                class=\"d-flex align-items-center gap-3\"\r\n                (click)=\"$event.stopImmediatePropagation();\">\r\n                <div\r\n                  (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n                  class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n                  [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n                  <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                  @if (!section?.header?.delegatedTo) {\r\n                    <span\r\n                      class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\"\r\n                      [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                    >{{ section?.header?.personTo }}</span>\r\n                  }\r\n                </div>\r\n                @if (section?.header?.delegatedTo) {\r\n                  <div\r\n                    class=\"d-flex align-items-center gap-3\"\r\n                    (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n                    <img\r\n                      class=\"rotate-arrow\"\r\n                      alt=\"\"\r\n                      src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n                    <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                      <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                      <span\r\n                        class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n                    </div>\r\n                  </div>\r\n                }\r\n              </div>\r\n            }\r\n          </ng-container>\r\n        }\r\n\r\n        @if (section?.body?.details?.['decision']?.key) {\r\n          <ds-status\r\n            class=\"main-status\"\r\n            status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n          </ds-status>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        @if (approvalPanel.expanded) {\r\n          <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n        } @else {\r\n          <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n        }\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n"]}
@@ -1,7 +1,8 @@
1
1
  import { GeneralApproverSectionComponent } from "../general-approver-section/general-approver-section.component";
2
2
  export default {
3
3
  roleToApprovalSectionMapping: {
4
- vpr_d: GeneralApproverSectionComponent
4
+ vpr_d: GeneralApproverSectionComponent,
5
+ sel_dsg: GeneralApproverSectionComponent,
5
6
  }
6
7
  };
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudC1keW5hbWljLWxvYWRlci5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL3Rlc3RDb21wb25lbnQvY29uZmlnL3NlZ21lbnQtZHluYW1pYy1sb2FkZXIuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLGdFQUFnRSxDQUFDO0FBRy9HLGVBQWU7SUFDYiw0QkFBNEIsRUFBRTtRQUM1QixLQUFLLEVBQUUsK0JBQStCO0tBQ3ZDO0NBQ0YsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7R2VuZXJhbEFwcHJvdmVyU2VjdGlvbkNvbXBvbmVudH0gZnJvbSBcIi4uL2dlbmVyYWwtYXBwcm92ZXItc2VjdGlvbi9nZW5lcmFsLWFwcHJvdmVyLXNlY3Rpb24uY29tcG9uZW50XCI7XHJcblxyXG5cclxuZXhwb3J0IGRlZmF1bHQge1xyXG4gIHJvbGVUb0FwcHJvdmFsU2VjdGlvbk1hcHBpbmc6IHtcclxuICAgIHZwcl9kOiBHZW5lcmFsQXBwcm92ZXJTZWN0aW9uQ29tcG9uZW50XHJcbiAgfVxyXG59XHJcbiJdfQ==
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudC1keW5hbWljLWxvYWRlci5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL3Rlc3RDb21wb25lbnQvY29uZmlnL3NlZ21lbnQtZHluYW1pYy1sb2FkZXIuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLGdFQUFnRSxDQUFDO0FBRy9HLGVBQWU7SUFDYiw0QkFBNEIsRUFBRTtRQUM1QixLQUFLLEVBQUUsK0JBQStCO1FBQ3RDLE9BQU8sRUFBRywrQkFBK0I7S0FDMUM7Q0FDRixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtHZW5lcmFsQXBwcm92ZXJTZWN0aW9uQ29tcG9uZW50fSBmcm9tIFwiLi4vZ2VuZXJhbC1hcHByb3Zlci1zZWN0aW9uL2dlbmVyYWwtYXBwcm92ZXItc2VjdGlvbi5jb21wb25lbnRcIjtcclxuXHJcblxyXG5leHBvcnQgZGVmYXVsdCB7XHJcbiAgcm9sZVRvQXBwcm92YWxTZWN0aW9uTWFwcGluZzoge1xyXG4gICAgdnByX2Q6IEdlbmVyYWxBcHByb3ZlclNlY3Rpb25Db21wb25lbnQsXHJcbiAgICBzZWxfZHNnIDogR2VuZXJhbEFwcHJvdmVyU2VjdGlvbkNvbXBvbmVudCxcclxuICB9XHJcbn1cclxuIl19
@@ -1,10 +1,9 @@
1
1
  import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input, NO_ERRORS_SCHEMA } from '@angular/core';
2
2
  import { NgClass, NgForOf, NgIf } from "@angular/common";
3
- import { ActionButtonsComponent } from "../../components/shared-components";
4
- import { FormControl, FormGroup, ReactiveFormsModule, Validators } from "@angular/forms";
3
+ import { ActionButtonsComponent, TextareaComponent } from "../../components/shared-components";
4
+ import { FormControl, ReactiveFormsModule } from "@angular/forms";
5
5
  import { CustomSearchableComponent, InputComponent } from '../../components/shared-components';
6
6
  import { ValidationErrorsComponent } from '../../components/shared-components/form-field/validation-errors/validation-errors.component';
7
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
8
7
  import * as i0 from "@angular/core";
9
8
  import * as i1 from "../../services";
10
9
  import * as i2 from "@angular/forms";
@@ -20,10 +19,7 @@ export class GeneralApproverSectionComponent {
20
19
  fieldsForm;
21
20
  numbers = [...Array(100).keys()].map(i => i + 1);
22
21
  destroyRef = inject(DestroyRef);
23
- formGroup = new FormGroup({
24
- name: new FormControl('', [Validators.required, Validators.maxLength(3), Validators.minLength(2)]),
25
- countries: new FormControl('', Validators.required),
26
- });
22
+ formGroup;
27
23
  constructor(i18n, fb, actionStateService) {
28
24
  this.i18n = i18n;
29
25
  this.fb = fb;
@@ -31,25 +27,19 @@ export class GeneralApproverSectionComponent {
31
27
  }
32
28
  ngOnInit() {
33
29
  this.createForm();
30
+ this.formGroup.setValue(this.section.body.details);
34
31
  }
35
32
  createForm() {
36
- let newForm = {
37
- input1: ['', Validators.required]
38
- };
39
- this.lov?.['decision']?.options?.forEach(option => {
40
- newForm[option.value] = [''];
33
+ this.formGroup = this.fb.group({
34
+ comment: new FormControl(''),
35
+ decision: new FormControl(''),
41
36
  });
42
- this.fieldsForm = this.fb.group(newForm);
43
- const checkValidityAndUpdate = () => {
37
+ this.formGroup.valueChanges.subscribe(value => {
44
38
  this.lov?.['decision']?.options?.forEach(option => {
45
39
  let isActionValid = this.checkValidity(option.value);
46
40
  this.actionStateService.setActionValid(option.value, isActionValid);
47
- this.section.body.details = this.fieldsForm.value;
41
+ this.section.body.details = this.formGroup.value;
48
42
  });
49
- };
50
- checkValidityAndUpdate();
51
- this.fieldsForm.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
52
- checkValidityAndUpdate();
53
43
  });
54
44
  }
55
45
  checkValidity(action) {
@@ -71,7 +61,7 @@ export class GeneralApproverSectionComponent {
71
61
  this.fieldsForm.reset();
72
62
  }
73
63
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, deps: [{ token: i1.CoreI18nService }, { token: i2.FormBuilder }, { token: i1.ActionStateService }], target: i0.ɵɵFactoryTarget.Component });
74
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InputComponent, selector: "app-input", inputs: ["floatLabel", "className", "iconPrefixName", "iconSuffixName", "emitedChangedValue1", "customErrorMessages"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
64
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div>\r\n <form [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\"\r\n [formGroup]=\"formGroup\">\r\n\r\n <app-textarea class=\"section-item\" formControlName=\"comment\" [label]=\"'comment'\" [required]=\"false\"\r\n [isReadOnly]=\"section?.header?.readOnly\">\r\n </app-textarea>\r\n\r\n </form>\r\n</div>\r\n\r\n\r\n@if (!section?.header?.readOnly) {\r\n<div class=\"mt-4\">\r\n <lib-action-buttons [lovOptions]=\"lov?.['decision']?.options\" [lovType]=\"lov?.['decision']?.type\" [section]=\"section\"\r\n [form]=\"form\" [sections]=\"form.sections\" [showApprovalCycle]=\"true\" [customCall]=\"false\" [fieldsForm]=\"formGroup\"\r\n (customCallEmit)=\"customCallSubmit($event)\" (resetFormEmit)=\"resetForm()\" />\r\n</div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: TextareaComponent, selector: "app-textarea", inputs: ["className", "preventSpecailChar"] }] });
75
65
  }
76
66
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, decorators: [{
77
67
  type: Component,
@@ -83,8 +73,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
83
73
  ActionButtonsComponent,
84
74
  ReactiveFormsModule,
85
75
  ValidationErrorsComponent,
86
- CustomSearchableComponent
87
- ], template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"] }]
76
+ CustomSearchableComponent,
77
+ TextareaComponent
78
+ ], template: "<div>\r\n <form [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\"\r\n [formGroup]=\"formGroup\">\r\n\r\n <app-textarea class=\"section-item\" formControlName=\"comment\" [label]=\"'comment'\" [required]=\"false\"\r\n [isReadOnly]=\"section?.header?.readOnly\">\r\n </app-textarea>\r\n\r\n </form>\r\n</div>\r\n\r\n\r\n@if (!section?.header?.readOnly) {\r\n<div class=\"mt-4\">\r\n <lib-action-buttons [lovOptions]=\"lov?.['decision']?.options\" [lovType]=\"lov?.['decision']?.type\" [section]=\"section\"\r\n [form]=\"form\" [sections]=\"form.sections\" [showApprovalCycle]=\"true\" [customCall]=\"false\" [fieldsForm]=\"formGroup\"\r\n (customCallEmit)=\"customCallSubmit($event)\" (resetFormEmit)=\"resetForm()\" />\r\n</div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"] }]
88
79
  }], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i2.FormBuilder }, { type: i1.ActionStateService }], propDecorators: { isReadOnly: [{
89
80
  type: Input
90
81
  }], section: [{
@@ -96,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
96
87
  }], className: [{
97
88
  type: Input
98
89
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-approver-section.component.js","sourceRoot":"","sources":["../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.ts","../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input, NO_ERRORS_SCHEMA, OnInit} from '@angular/core';\r\nimport {Form, Section} from \"../../interfaces\";\r\nimport {ActionStateService, CoreI18nService} from \"../../services\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {ActionButtonsComponent} from \"../../components/shared-components\";\r\nimport {FormBuilder, FormControl, FormGroup, ReactiveFormsModule, Validators} from \"@angular/forms\";\r\nimport {CustomSearchableComponent, InputComponent} from '../../components/shared-components';\r\nimport {ValidationErrorsComponent} from '../../components/shared-components/form-field/validation-errors/validation-errors.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'app-general-approver-section',\r\n  templateUrl: './general-approver-section.component.html',\r\n  styleUrls: ['./general-approver-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ActionButtonsComponent,\r\n    ReactiveFormsModule,\r\n    ValidationErrorsComponent,\r\n    CustomSearchableComponent\r\n  ]\r\n})\r\nexport class GeneralApproverSectionComponent implements OnInit{\r\n\r\n  @Input() isReadOnly: boolean;\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() className: string = \"info-section\";\r\n  fieldsForm: FormGroup;\r\n  numbers = [...Array(100).keys()].map(i => i + 1);\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  formGroup = new FormGroup({\r\n    name: new FormControl('', [Validators.required, Validators.maxLength(3), Validators.minLength(2)]),\r\n    countries: new FormControl('', Validators.required),\r\n  });\r\n\r\n\r\n  constructor(public i18n: CoreI18nService, private fb: FormBuilder, private actionStateService: ActionStateService) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.createForm();\r\n  }\r\n\r\n  createForm() {\r\n    let newForm = {\r\n      input1: ['', Validators.required]\r\n    };\r\n    this.lov?.['decision']?.options?.forEach(option => {\r\n      newForm[option.value] = [''];\r\n    })\r\n    this.fieldsForm = this.fb.group(newForm);\r\n\r\n    const checkValidityAndUpdate = () => {\r\n      this.lov?.['decision']?.options?.forEach(option => {\r\n        let isActionValid = this.checkValidity(option.value);\r\n        this.actionStateService.setActionValid(option.value, isActionValid);\r\n        this.section.body.details = this.fieldsForm.value\r\n      });\r\n    }\r\n\r\n    checkValidityAndUpdate();\r\n\r\n    this.fieldsForm.valueChanges.pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe(() => {\r\n      checkValidityAndUpdate();\r\n    });\r\n\r\n  }\r\n\r\n  checkValidity(action: string): boolean {\r\n    switch (action) {\r\n      case 'APPROVE':\r\n        return true;\r\n      case 'REJECT':\r\n        return this.fieldsForm.valid;\r\n      case 'SENDBACK':\r\n        return this.fieldsForm.valid;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n\r\n  customCallSubmit(action: string) {\r\n    console.log('customCallSubmit', action)\r\n  }\r\n\r\n  resetForm() {\r\n    this.fieldsForm.reset()\r\n  }\r\n\r\n}\r\n","<div\r\n  [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n  <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n    <div class=\"d-flex gap-2\">\r\n\r\n      Request details working fine\r\n\r\n    </div>\r\n\r\n  </ds-alert>\r\n\r\n  <form [formGroup]=\"fieldsForm\">\r\n    <app-input formControlName=\"input1\"></app-input>\r\n  </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n  <div class=\"mt-4\">\r\n    <lib-action-buttons\r\n      [lovOptions]=\"lov?.['decision']?.options\"\r\n      [lovType]=\"lov?.['decision']?.type\"\r\n      [section]=\"section\"\r\n      [form]=\"form\"\r\n      [sections]=\"form.sections\"\r\n      [showApprovalCycle]=\"true\"\r\n      [customCall]=\"false\"\r\n      [fieldsForm]=\"fieldsForm\"\r\n      (customCallEmit)=\"customCallSubmit($event)\"\r\n      (resetFormEmit)=\"resetForm()\"\r\n    />\r\n  </div>\r\n}\r\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-approver-section.component.js","sourceRoot":"","sources":["../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.ts","../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input, NO_ERRORS_SCHEMA, OnInit} from '@angular/core';\r\nimport {Form, Section} from \"../../interfaces\";\r\nimport {ActionStateService, CoreI18nService} from \"../../services\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {ActionButtonsComponent, TextareaComponent} from \"../../components/shared-components\";\r\nimport {FormBuilder, FormControl, FormGroup, ReactiveFormsModule, Validators} from \"@angular/forms\";\r\nimport {CustomSearchableComponent, InputComponent} from '../../components/shared-components';\r\nimport {ValidationErrorsComponent} from '../../components/shared-components/form-field/validation-errors/validation-errors.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'app-general-approver-section',\r\n  templateUrl: './general-approver-section.component.html',\r\n  styleUrls: ['./general-approver-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ActionButtonsComponent,\r\n    ReactiveFormsModule,\r\n    ValidationErrorsComponent,\r\n    CustomSearchableComponent,\r\n    TextareaComponent\r\n  ]\r\n})\r\nexport class GeneralApproverSectionComponent implements OnInit{\r\n\r\n  @Input() isReadOnly: boolean;\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() className: string = \"info-section\";\r\n  fieldsForm: FormGroup;\r\n  numbers = [...Array(100).keys()].map(i => i + 1);\r\n  destroyRef = inject(DestroyRef);\r\n  formGroup: FormGroup;\r\n\r\n\r\n  constructor(public i18n: CoreI18nService, private fb: FormBuilder, private actionStateService: ActionStateService) {\r\n\r\n  }\r\n\r\nngOnInit() {\r\n    this.createForm();\r\n    this.formGroup.setValue(this.section.body.details);\r\n  }\r\n\r\n  createForm() {\r\n    this.formGroup = this.fb.group({\r\n      comment: new FormControl('' ),\r\n      decision: new FormControl(''),\r\n    });\r\n    this.formGroup.valueChanges.subscribe(value => {\r\n      this.lov?.['decision']?.options?.forEach(option => {\r\n        let isActionValid = this.checkValidity(option.value);\r\n        this.actionStateService.setActionValid(option.value, isActionValid);\r\n        this.section.body.details = this.formGroup.value\r\n      })\r\n    })\r\n  }\r\n\r\n  checkValidity(action: string): boolean {\r\n    switch (action) {\r\n      case 'APPROVE':\r\n        return true;\r\n      case 'REJECT':\r\n        return this.fieldsForm.valid;\r\n      case 'SENDBACK':\r\n        return this.fieldsForm.valid;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n\r\n  customCallSubmit(action: string) {\r\n    console.log('customCallSubmit', action)\r\n  }\r\n\r\n  resetForm() {\r\n    this.fieldsForm.reset()\r\n  }\r\n\r\n}\r\n","<div>\r\n  <form [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\"\r\n    [formGroup]=\"formGroup\">\r\n\r\n    <app-textarea class=\"section-item\" formControlName=\"comment\" [label]=\"'comment'\" [required]=\"false\"\r\n      [isReadOnly]=\"section?.header?.readOnly\">\r\n    </app-textarea>\r\n\r\n  </form>\r\n</div>\r\n\r\n\r\n@if (!section?.header?.readOnly) {\r\n<div class=\"mt-4\">\r\n  <lib-action-buttons [lovOptions]=\"lov?.['decision']?.options\" [lovType]=\"lov?.['decision']?.type\" [section]=\"section\"\r\n    [form]=\"form\" [sections]=\"form.sections\" [showApprovalCycle]=\"true\" [customCall]=\"false\" [fieldsForm]=\"formGroup\"\r\n    (customCallEmit)=\"customCallSubmit($event)\" (resetFormEmit)=\"resetForm()\" />\r\n</div>\r\n}\r\n"]}
@@ -12,7 +12,7 @@ import { NgIf, CommonModule, NgSwitchCase, DecimalPipe, DatePipe, NgClass, NgSwi
12
12
  import * as i4$1 from '@angular/material/core';
13
13
  import { MAT_DATE_FORMATS, MatNativeDateModule } from '@angular/material/core';
14
14
  import * as i4 from '@angular/forms';
15
- import { NG_VALUE_ACCESSOR, FormControl, ControlContainer, NgForm, Validators, NgControl, FormControlName, FormGroupDirective, ReactiveFormsModule, FormsModule, FormGroup } from '@angular/forms';
15
+ import { NG_VALUE_ACCESSOR, FormControl, ControlContainer, NgForm, Validators, NgControl, FormControlName, FormGroupDirective, ReactiveFormsModule, FormsModule } from '@angular/forms';
16
16
  import * as i3 from '@angular/platform-browser';
17
17
  import { MatCheckbox } from '@angular/material/checkbox';
18
18
  import * as i2 from 'ngx-toastr';
@@ -6495,7 +6495,7 @@ class FormSectionComponent {
6495
6495
  * @return {string} - The CSS class corresponding to the given status.
6496
6496
  */
6497
6497
  statusClass(status) {
6498
- status = status ? status.toLowerCase() : '';
6498
+ // status = status ? status.toLowerCase() : '';
6499
6499
  let statusStrategy = StatusMap[status] || StatusMap['default'];
6500
6500
  return statusStrategy.class;
6501
6501
  }
@@ -7488,10 +7488,7 @@ class GeneralApproverSectionComponent {
7488
7488
  fieldsForm;
7489
7489
  numbers = [...Array(100).keys()].map(i => i + 1);
7490
7490
  destroyRef = inject(DestroyRef);
7491
- formGroup = new FormGroup({
7492
- name: new FormControl('', [Validators.required, Validators.maxLength(3), Validators.minLength(2)]),
7493
- countries: new FormControl('', Validators.required),
7494
- });
7491
+ formGroup;
7495
7492
  constructor(i18n, fb, actionStateService) {
7496
7493
  this.i18n = i18n;
7497
7494
  this.fb = fb;
@@ -7499,25 +7496,19 @@ class GeneralApproverSectionComponent {
7499
7496
  }
7500
7497
  ngOnInit() {
7501
7498
  this.createForm();
7499
+ this.formGroup.setValue(this.section.body.details);
7502
7500
  }
7503
7501
  createForm() {
7504
- let newForm = {
7505
- input1: ['', Validators.required]
7506
- };
7507
- this.lov?.['decision']?.options?.forEach(option => {
7508
- newForm[option.value] = [''];
7502
+ this.formGroup = this.fb.group({
7503
+ comment: new FormControl(''),
7504
+ decision: new FormControl(''),
7509
7505
  });
7510
- this.fieldsForm = this.fb.group(newForm);
7511
- const checkValidityAndUpdate = () => {
7506
+ this.formGroup.valueChanges.subscribe(value => {
7512
7507
  this.lov?.['decision']?.options?.forEach(option => {
7513
7508
  let isActionValid = this.checkValidity(option.value);
7514
7509
  this.actionStateService.setActionValid(option.value, isActionValid);
7515
- this.section.body.details = this.fieldsForm.value;
7510
+ this.section.body.details = this.formGroup.value;
7516
7511
  });
7517
- };
7518
- checkValidityAndUpdate();
7519
- this.fieldsForm.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
7520
- checkValidityAndUpdate();
7521
7512
  });
7522
7513
  }
7523
7514
  checkValidity(action) {
@@ -7539,7 +7530,7 @@ class GeneralApproverSectionComponent {
7539
7530
  this.fieldsForm.reset();
7540
7531
  }
7541
7532
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, deps: [{ token: CoreI18nService }, { token: i4.FormBuilder }, { token: ActionStateService }], target: i0.ɵɵFactoryTarget.Component });
7542
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InputComponent, selector: "app-input", inputs: ["floatLabel", "className", "iconPrefixName", "iconSuffixName", "emitedChangedValue1", "customErrorMessages"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
7533
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div>\r\n <form [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\"\r\n [formGroup]=\"formGroup\">\r\n\r\n <app-textarea class=\"section-item\" formControlName=\"comment\" [label]=\"'comment'\" [required]=\"false\"\r\n [isReadOnly]=\"section?.header?.readOnly\">\r\n </app-textarea>\r\n\r\n </form>\r\n</div>\r\n\r\n\r\n@if (!section?.header?.readOnly) {\r\n<div class=\"mt-4\">\r\n <lib-action-buttons [lovOptions]=\"lov?.['decision']?.options\" [lovType]=\"lov?.['decision']?.type\" [section]=\"section\"\r\n [form]=\"form\" [sections]=\"form.sections\" [showApprovalCycle]=\"true\" [customCall]=\"false\" [fieldsForm]=\"formGroup\"\r\n (customCallEmit)=\"customCallSubmit($event)\" (resetFormEmit)=\"resetForm()\" />\r\n</div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: TextareaComponent, selector: "app-textarea", inputs: ["className", "preventSpecailChar"] }] });
7543
7534
  }
7544
7535
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, decorators: [{
7545
7536
  type: Component,
@@ -7551,8 +7542,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
7551
7542
  ActionButtonsComponent,
7552
7543
  ReactiveFormsModule,
7553
7544
  ValidationErrorsComponent,
7554
- CustomSearchableComponent
7555
- ], template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"] }]
7545
+ CustomSearchableComponent,
7546
+ TextareaComponent
7547
+ ], template: "<div>\r\n <form [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\"\r\n [formGroup]=\"formGroup\">\r\n\r\n <app-textarea class=\"section-item\" formControlName=\"comment\" [label]=\"'comment'\" [required]=\"false\"\r\n [isReadOnly]=\"section?.header?.readOnly\">\r\n </app-textarea>\r\n\r\n </form>\r\n</div>\r\n\r\n\r\n@if (!section?.header?.readOnly) {\r\n<div class=\"mt-4\">\r\n <lib-action-buttons [lovOptions]=\"lov?.['decision']?.options\" [lovType]=\"lov?.['decision']?.type\" [section]=\"section\"\r\n [form]=\"form\" [sections]=\"form.sections\" [showApprovalCycle]=\"true\" [customCall]=\"false\" [fieldsForm]=\"formGroup\"\r\n (customCallEmit)=\"customCallSubmit($event)\" (resetFormEmit)=\"resetForm()\" />\r\n</div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"] }]
7556
7548
  }], ctorParameters: () => [{ type: CoreI18nService }, { type: i4.FormBuilder }, { type: ActionStateService }], propDecorators: { isReadOnly: [{
7557
7549
  type: Input
7558
7550
  }], section: [{
@@ -7567,7 +7559,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
7567
7559
 
7568
7560
  var segmentDynamicLoaderConfiguration = {
7569
7561
  roleToApprovalSectionMapping: {
7570
- vpr_d: GeneralApproverSectionComponent
7562
+ vpr_d: GeneralApproverSectionComponent,
7563
+ sel_dsg: GeneralApproverSectionComponent,
7571
7564
  }
7572
7565
  };
7573
7566