bpm-core 0.0.26 → 0.0.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/esm2022/lib/app/app.component.mjs +9 -10
  2. package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +3 -3
  3. package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +2 -2
  4. package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +4 -40
  5. package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +3 -3
  6. package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs +6 -4
  7. package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +2 -2
  8. package/esm2022/lib/components/shared-components/form-field/checkbox/checkbox.component.mjs +42 -31
  9. package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +63 -14
  10. package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +70 -137
  11. package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +42 -78
  12. package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +5 -19
  13. package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +23 -115
  14. package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +20 -72
  15. package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +20 -74
  16. package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +20 -104
  17. package/esm2022/lib/components/shared-components/form-field/input-telephone/input-telephone.component.mjs +20 -39
  18. package/esm2022/lib/components/shared-components/form-field/textarea/textarea.component.mjs +27 -59
  19. package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +3 -6
  20. package/esm2022/lib/environments/environment.local.mjs +2 -2
  21. package/esm2022/lib/services/core.service.ts.mjs +7 -8
  22. package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +2 -2
  23. package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +37 -23
  24. package/fesm2022/bpm-core.mjs +538 -958
  25. package/fesm2022/bpm-core.mjs.map +1 -1
  26. package/lib/app/app.component.d.ts +1 -2
  27. package/lib/components/app-component-sections/activities/activities.component.d.ts +2 -2
  28. package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +1 -1
  29. package/lib/components/app-component-sections/form-section/form-section.component.d.ts +3 -4
  30. package/lib/components/app-component-sections/service-header/service-header.component.d.ts +1 -1
  31. package/lib/components/shared-components/action-buttons/action-buttons.component.d.ts +3 -1
  32. package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +1 -1
  33. package/lib/components/shared-components/form-field/checkbox/checkbox.component.d.ts +10 -7
  34. package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +15 -5
  35. package/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.d.ts +15 -15
  36. package/lib/components/shared-components/form-field/date-picker/date-picker.component.d.ts +6 -13
  37. package/lib/components/shared-components/form-field/input/input.component.d.ts +2 -6
  38. package/lib/components/shared-components/form-field/input-currency/input-currency.component.d.ts +6 -23
  39. package/lib/components/shared-components/form-field/input-email/input-email.component.d.ts +4 -18
  40. package/lib/components/shared-components/form-field/input-mask/input-mask.component.d.ts +4 -18
  41. package/lib/components/shared-components/form-field/input-number/input-number.component.d.ts +5 -20
  42. package/lib/components/shared-components/form-field/input-telephone/input-telephone.component.d.ts +4 -15
  43. package/lib/components/shared-components/form-field/textarea/textarea.component.d.ts +5 -14
  44. package/lib/components/shared-components/form-field/validation-errors/validation-errors.component.d.ts +1 -2
  45. package/lib/services/core.service.ts.d.ts +1 -1
  46. package/lib/testComponent/request-details-section/request-details-section.component.d.ts +5 -7
  47. package/package.json +3 -2
  48. package/esm2022/lib/testComponent/services/state-machine.service.mjs +0 -148
  49. package/lib/testComponent/services/state-machine.service.d.ts +0 -29
@@ -50,8 +50,8 @@ export class ServiceHeaderComponent {
50
50
  onCommentsFormClick() {
51
51
  const comments = this.form.commentsDrop;
52
52
  const resultData = [];
53
- for (let index = 0; index < comments.length; index++) {
54
- const item = comments[index];
53
+ for (const element of comments) {
54
+ const item = element;
55
55
  const obj = {
56
56
  name: item['employeeName'],
57
57
  title: item.jobPosition,
@@ -163,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
163
163
  }], serviceBrief: [{
164
164
  type: Input
165
165
  }] } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, Input} from '@angular/core';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants/constants';\r\nimport {MAT_DIALOG_DATA, MatDialog} from '@angular/material/dialog';\r\nimport {CoreI18nService, CoreService, FeedBackService, SidenavService} from '../../../services';\r\nimport {ProfileSectionComponent} from '../profile-section/profile-section.component';\r\nimport {FeedbackSectionComponent} from '../feedback-section/feedback-section.component';\r\nimport {NgClass, NgIf} from '@angular/common';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatDivider} from '@angular/material/divider';\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from '@angular/material/menu';\r\nimport {FaqSidenavComponent} from '../faq-sidenav/faq-sidenav.component';\r\nimport {ActivitiesComponent} from '../activities/activities.component';\r\nimport * as moment from 'moment'\r\n\r\n\r\n@Component({\r\n  selector: 'core-service-header',\r\n  templateUrl: './service-header.component.html',\r\n  styleUrls: ['./service-header.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgIf,\r\n    SatPopoverModule,\r\n    MatDivider,\r\n    MatMenuTrigger,\r\n    NgClass,\r\n    MatMenu,\r\n    MatMenuItem\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [FeedBackService,\r\n    {provide: MAT_DIALOG_DATA, useValue: {}},\r\n  ]\r\n})\r\nexport class ServiceHeaderComponent implements AfterViewInit {\r\n  @Input() form: Form;\r\n  @Input() showHistory = false;\r\n  @Input() isLoading = false;\r\n  @Input() showApprovalHistory = false;\r\n  @Input() approvalHistory: any;\r\n  @Input() creationDate: string;\r\n  @Input() formTitle: string;\r\n  @Input() section: Section;\r\n  @Input() serviceBrief: any[] = [];\r\n  approvals: any[] = [];\r\n  public feedBackIcon: string = null;\r\n  flagPriority: string;\r\n\r\n  constructor(\r\n    private cdRef: ChangeDetectorRef,\r\n    public coreService:CoreService,\r\n    public i18n: CoreI18nService, private feedBackService: FeedBackService,\r\n    private readonly dialog: MatDialog, private readonly sidenavService: SidenavService,\r\n  ) {\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.getApprovalHistory();\r\n    this.creationDate = moment(this.form?.header?.creationDate).locale('en-US').format(\"DD/MM/YYYY HH:mm:ss\");\r\n    this.cdRef.detectChanges();\r\n\r\n  }\r\n\r\n  onCommentsFormClick() {\r\n    const comments: any = this.form.commentsDrop;\r\n    const resultData = [];\r\n    for (let index = 0; index < comments.length; index++) {\r\n      const item = comments[index];\r\n      const obj =\r\n        {\r\n          name: item['employeeName'],\r\n          title: item.jobPosition,\r\n          image: item['profilePicture'],\r\n          date: moment(item['commentDate']).locale('en-US').format('YYYY-MM-DD'),\r\n          time: moment(item['commentDate']).locale('en-US').format('h:mm a'),\r\n          comment: item['commentBody'],\r\n          attachments: item['attachment']\r\n        };\r\n      resultData.push(obj);\r\n    }\r\n    this.coreService.activities = resultData;\r\n    this.sidenavService.publish('open', ActivitiesComponent);\r\n  }\r\n\r\n  feedback(): void {\r\n    this.dialog.open(FeedbackSectionComponent, {\r\n      panelClass: ['main-popup'],\r\n      data: {\r\n        profile: this.form.profileInfoDrop,\r\n        inboxItem: this.form.inboxItem,\r\n        form: this.form\r\n      }\r\n    });\r\n  }\r\n\r\n  showUserInfo(): void {\r\n    if (!this.isLoading) {\r\n      this.sidenavService.data = this.form?.profileInfoDrop;\r\n      this.sidenavService.publish('open', ProfileSectionComponent);\r\n    }\r\n  }\r\n\r\n  setFlagPriority(id: string) {\r\n    this.flagPriority = id;\r\n    this.form.inboxItem.flagPriority = id;\r\n    // this.stateMachineService.dispatch(Constants.STATE_MACHINE_ACTION_SET_FLAG, id).then(() => {\r\n    // });\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (status) {\r\n      if (this.isLoading) {\r\n        return 'loading';\r\n      } else if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase().includes('deny')\r\n        || status.toLowerCase().includes('reject')\r\n        || status?.toLowerCase() === 'reject' || status?.toLowerCase() === 'unsatisfied' || status?.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status?.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    } else {\r\n      return 'success';\r\n    }\r\n  }\r\n\r\n  openFaq() {\r\n    this.sidenavService.publish('open', FaqSidenavComponent, 'end', 'over', this.serviceBrief);\r\n  }\r\n\r\n  getApprovalHistory() {\r\n    this.approvalHistory?.forEach((element: { approver: { personName: any; personEmail: string; }; positionType: any; }, index: number) => {\r\n      const obj = {\r\n        id: index + 1,\r\n        name: element.approver.personName,\r\n        title: element.positionType,\r\n        image: '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + element.approver.personEmail,\r\n        status: this.form.sections[index + 1] ? this.statusClass(this.form.sections[index + 1].body.details.decision.key) : '',\r\n        statusLabel: this.form.sections[index + 1] ? this.form.sections[index + 1].body.details.decision.value : ''\r\n      };\r\n      this.approvals.push(obj);\r\n    });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n  <div class=\"d-flex align-items-center justify-content-end gap-2 my-2\" *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n\r\n    <!-- flag-->\r\n    <ds-button\r\n      *ngIf=\"form?.inboxItem && !form.sections[form.sections.length -1].header.readOnly && !isLoading\"\r\n      square\r\n      icon\r\n      size=\"small\"\r\n      [matMenuTriggerFor]=\"menu\"\r\n      class=\"icon-btn-shadow\">\r\n      <ds-icon\r\n        [ngClass]=\"{'fc-purple' : (flagPriority === '0' ||  flagPriority === null),'fc-yellow' : flagPriority === '1','fc-green' : flagPriority === '2','fc-coral' : flagPriority === '3'}\"\r\n        icon=\"flag-o\" class=\"fs-20 fs-md-17 fc-purple\">\r\n      </ds-icon>\r\n    </ds-button>\r\n    <mat-menu #menu=\"matMenu\" panelClass=\"action-menu\">\r\n      <button mat-menu-item (click)=\"setFlagPriority('0')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-purple fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('1')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-yellow fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('2')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-green fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('3')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n    </mat-menu>\r\n\r\n    <!-- print-->\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  <header class=\"service-header bc-white p-3 p-sm-4 py-4 gap-3 {{statusClass(form?.header?.status?.['key'])}}\">\r\n\r\n    <div class=\"service-header-icon\">\r\n      <img\r\n        alt=\"\"\r\n        src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n    </div>\r\n\r\n    <div class=\"flex-grow-1 d-flex flex-column flex-sm-row align-items-sm-center gap-2\">\r\n      <div class=\"flex-grow-1\">\r\n        <!-- title-->\r\n        <h1 class=\"fs-20 fs-md-16 fw-bold fc-black header-title m-0\">{{ formTitle }}\r\n          <ds-icon\r\n            icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" *ngIf=\"serviceBrief.length\"\r\n            (click)=\"openFaq()\"></ds-icon>\r\n        </h1>\r\n        <div\r\n          class=\"header-user d-flex align-items-sm-center gap-2 mt-sm-1\"\r\n          *ngIf=\"form?.header?.status?.['key'] !== 'NEW' || isLoading\">\r\n          <ds-avatar\r\n            *ngIf=\"!isLoading\" image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n            class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n          <span\r\n            class=\"fs-12 text-truncate d-sm-block cursor-pointer\" (click)=\"showUserInfo()\"\r\n            [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ coreService.getShortName(form?.header?.requesterName) }}</span>\r\n          <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n          <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ form?.header?.formId }}</span>\r\n          <mat-divider *ngIf=\"creationDate\" class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n          <span *ngIf=\"creationDate\" class=\"fs-14\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ creationDate }}</span>\r\n        </div>\r\n      </div>\r\n      <!-- header-actions-->\r\n      <div\r\n        class=\"header-actions d-flex flex-row flex-sm-column justify-content-between justify-content-sm-center gap-2 mt-2 mt-sm-0\"\r\n        *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n        <ds-status\r\n          *ngIf=\"form?.header?.status?.['key'] !== 'NEW' && !isLoading\"\r\n          status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n        </ds-status>\r\n\r\n        <div class=\"d-flex align-items-center justify-content-end gap-2\">\r\n          <!-- feedback-->\r\n<!--            *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback ==='true'|| form?.inboxItem?.hasFeedback==='true') && !isLoading\"-->\r\n        <!--  <ds-button\r\n            square icon size=\"small\" (click)=\"feedback()\">\r\n            <ds-icon\r\n              icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\"\r\n              [ngClass]=\"{'fc-green':feedBackIcon === 'feedbackResponded' , 'fc-red': feedBackIcon === 'respondToFeedback' , 'fc-yellow': feedBackIcon === 'waitingFeedback'}\">\r\n            </ds-icon>\r\n          </ds-button>-->\r\n          <ds-button\r\n            *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n            (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n            <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n          </ds-button>\r\n          <ng-container *ngIf=\"showApprovalHistory\">\r\n            <ds-button\r\n              color=\"white\" shape=\"text\" square size=\"small\" [satPopoverAnchor]=\"workflow\"\r\n              #workflowAnchor=\"satPopoverAnchor\" (click)=\"workflowAnchor.popover.open()\">\r\n              <slot name=\"prefix\">\r\n                <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n              </slot>\r\n            </ds-button>\r\n\r\n            <sat-popover\r\n              #workflow [anchor]=\"workflowAnchor\" [hasBackdrop]=\"true\" verticalAlign=\"below\"\r\n              horizontalAlign=\"end\">\r\n              <div class=\"default-popover p-3\" style=\"min-width: 330px;\">\r\n                <ds-approvals *ngIf=\"approvalHistory\" class=\"popover-approvals\" approvalsData=\"{{approvals}}\">\r\n                </ds-approvals>\r\n              </div>\r\n            </sat-popover>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n  </header>\r\n</ng-container>\r\n<header\r\n  class=\"mb-4 mt-4 d-flex align-items-center justify-content-between align-items-end gap-2\"\r\n  *ngIf=\"(form?.header?.status?.['key'] === 'NEW')\">\r\n  <section>\r\n    <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n      {{ i18n.translate('Hello') }}\r\n      {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n    </h6>\r\n    <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n      {{ formTitle }}\r\n      <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" *ngIf=\"serviceBrief.length\" (click)=\"openFaq()\">\r\n      </ds-icon>\r\n    </h1>\r\n  </section>\r\n\r\n</header>\r\n"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, Input} from '@angular/core';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants/constants';\r\nimport {MAT_DIALOG_DATA, MatDialog} from '@angular/material/dialog';\r\nimport {CoreI18nService, CoreService, FeedBackService, SidenavService} from '../../../services';\r\nimport {ProfileSectionComponent} from '../profile-section/profile-section.component';\r\nimport {FeedbackSectionComponent} from '../feedback-section/feedback-section.component';\r\nimport {NgClass, NgIf} from '@angular/common';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatDivider} from '@angular/material/divider';\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from '@angular/material/menu';\r\nimport {FaqSidenavComponent} from '../faq-sidenav/faq-sidenav.component';\r\nimport {ActivitiesComponent} from '../activities/activities.component';\r\nimport * as moment from 'moment'\r\n\r\n\r\n@Component({\r\n  selector: 'core-service-header',\r\n  templateUrl: './service-header.component.html',\r\n  styleUrls: ['./service-header.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgIf,\r\n    SatPopoverModule,\r\n    MatDivider,\r\n    MatMenuTrigger,\r\n    NgClass,\r\n    MatMenu,\r\n    MatMenuItem\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [FeedBackService,\r\n    {provide: MAT_DIALOG_DATA, useValue: {}},\r\n  ]\r\n})\r\nexport class ServiceHeaderComponent implements AfterViewInit {\r\n  @Input() form: Form;\r\n  @Input() showHistory = false;\r\n  @Input() isLoading = false;\r\n  @Input() showApprovalHistory = false;\r\n  @Input() approvalHistory: any;\r\n  @Input() creationDate: string;\r\n  @Input() formTitle: string;\r\n  @Input() section: Section;\r\n  @Input() serviceBrief: any[] = [];\r\n  approvals: any[] = [];\r\n  public feedBackIcon: string = null;\r\n  flagPriority: string;\r\n\r\n  constructor(\r\n    private cdRef: ChangeDetectorRef,\r\n    public coreService:CoreService,\r\n    public i18n: CoreI18nService, private feedBackService: FeedBackService,\r\n    private readonly dialog: MatDialog, private readonly sidenavService: SidenavService,\r\n  ) {\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.getApprovalHistory();\r\n    this.creationDate = moment(this.form?.header?.creationDate).locale('en-US').format(\"DD/MM/YYYY HH:mm:ss\");\r\n    this.cdRef.detectChanges();\r\n\r\n  }\r\n\r\n  onCommentsFormClick() {\r\n    const comments: any = this.form.commentsDrop;\r\n    const resultData = [];\r\n    for (const element of comments) {\r\n      const item = element;\r\n      const obj =\r\n        {\r\n          name: item['employeeName'],\r\n          title: item.jobPosition,\r\n          image: item['profilePicture'],\r\n          date: moment(item['commentDate']).locale('en-US').format('YYYY-MM-DD'),\r\n          time: moment(item['commentDate']).locale('en-US').format('h:mm a'),\r\n          comment: item['commentBody'],\r\n          attachments: item['attachment']\r\n        };\r\n      resultData.push(obj);\r\n    }\r\n    this.coreService.activities = resultData;\r\n    this.sidenavService.publish('open', ActivitiesComponent);\r\n  }\r\n\r\n  feedback(): void {\r\n    this.dialog.open(FeedbackSectionComponent, {\r\n      panelClass: ['main-popup'],\r\n      data: {\r\n        profile: this.form.profileInfoDrop,\r\n        inboxItem: this.form.inboxItem,\r\n        form: this.form\r\n      }\r\n    });\r\n  }\r\n\r\n  showUserInfo(): void {\r\n    if (!this.isLoading) {\r\n      this.sidenavService.data = this.form?.profileInfoDrop;\r\n      this.sidenavService.publish('open', ProfileSectionComponent);\r\n    }\r\n  }\r\n\r\n  setFlagPriority(id: string) {\r\n    this.flagPriority = id;\r\n    this.form.inboxItem.flagPriority = id;\r\n    // this.stateMachineService.dispatch(Constants.STATE_MACHINE_ACTION_SET_FLAG, id).then(() => {\r\n    // });\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (status) {\r\n      if (this.isLoading) {\r\n        return 'loading';\r\n      } else if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase().includes('deny')\r\n        || status.toLowerCase().includes('reject')\r\n        || status?.toLowerCase() === 'reject' || status?.toLowerCase() === 'unsatisfied' || status?.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status?.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    } else {\r\n      return 'success';\r\n    }\r\n  }\r\n\r\n  openFaq() {\r\n    this.sidenavService.publish('open', FaqSidenavComponent, 'end', 'over', this.serviceBrief);\r\n  }\r\n\r\n  getApprovalHistory() {\r\n    this.approvalHistory?.forEach((element: { approver: { personName: any; personEmail: string; }; positionType: any; }, index: number) => {\r\n      const obj = {\r\n        id: index + 1,\r\n        name: element.approver.personName,\r\n        title: element.positionType,\r\n        image: '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + element.approver.personEmail,\r\n        status: this.form.sections[index + 1] ? this.statusClass(this.form.sections[index + 1].body.details.decision.key) : '',\r\n        statusLabel: this.form.sections[index + 1] ? this.form.sections[index + 1].body.details.decision.value : ''\r\n      };\r\n      this.approvals.push(obj);\r\n    });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n  <div class=\"d-flex align-items-center justify-content-end gap-2 my-2\" *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n\r\n    <!-- flag-->\r\n    <ds-button\r\n      *ngIf=\"form?.inboxItem && !form.sections[form.sections.length -1].header.readOnly && !isLoading\"\r\n      square\r\n      icon\r\n      size=\"small\"\r\n      [matMenuTriggerFor]=\"menu\"\r\n      class=\"icon-btn-shadow\">\r\n      <ds-icon\r\n        [ngClass]=\"{'fc-purple' : (flagPriority === '0' ||  flagPriority === null),'fc-yellow' : flagPriority === '1','fc-green' : flagPriority === '2','fc-coral' : flagPriority === '3'}\"\r\n        icon=\"flag-o\" class=\"fs-20 fs-md-17 fc-purple\">\r\n      </ds-icon>\r\n    </ds-button>\r\n    <mat-menu #menu=\"matMenu\" panelClass=\"action-menu\">\r\n      <button mat-menu-item (click)=\"setFlagPriority('0')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-purple fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('1')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-yellow fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('2')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-green fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n      <button mat-menu-item (click)=\"setFlagPriority('3')\">\r\n        <ds-icon icon=\"flag-o\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n      </button>\r\n    </mat-menu>\r\n\r\n    <!-- print-->\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  <header class=\"service-header bc-white p-3 p-sm-4 py-4 gap-3 {{statusClass(form?.header?.status?.['key'])}}\">\r\n\r\n    <div class=\"service-header-icon\">\r\n      <img\r\n        alt=\"\"\r\n        src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n    </div>\r\n\r\n    <div class=\"flex-grow-1 d-flex flex-column flex-sm-row align-items-sm-center gap-2\">\r\n      <div class=\"flex-grow-1\">\r\n        <!-- title-->\r\n        <h1 class=\"fs-20 fs-md-16 fw-bold fc-black header-title m-0\">{{ formTitle }}\r\n          <ds-icon\r\n            icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" *ngIf=\"serviceBrief.length\"\r\n            (click)=\"openFaq()\"></ds-icon>\r\n        </h1>\r\n        <div\r\n          class=\"header-user d-flex align-items-sm-center gap-2 mt-sm-1\"\r\n          *ngIf=\"form?.header?.status?.['key'] !== 'NEW' || isLoading\">\r\n          <ds-avatar\r\n            *ngIf=\"!isLoading\" image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n            class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n          <span\r\n            class=\"fs-12 text-truncate d-sm-block cursor-pointer\" (click)=\"showUserInfo()\"\r\n            [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ coreService.getShortName(form?.header?.requesterName) }}</span>\r\n          <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n          <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ form?.header?.formId }}</span>\r\n          <mat-divider *ngIf=\"creationDate\" class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n          <span *ngIf=\"creationDate\" class=\"fs-14\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ creationDate }}</span>\r\n        </div>\r\n      </div>\r\n      <!-- header-actions-->\r\n      <div\r\n        class=\"header-actions d-flex flex-row flex-sm-column justify-content-between justify-content-sm-center gap-2 mt-2 mt-sm-0\"\r\n        *ngIf=\"!(form?.header?.status?.['key'] === 'NEW')\">\r\n        <ds-status\r\n          *ngIf=\"form?.header?.status?.['key'] !== 'NEW' && !isLoading\"\r\n          status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n        </ds-status>\r\n\r\n        <div class=\"d-flex align-items-center justify-content-end gap-2\">\r\n          <!-- feedback-->\r\n<!--            *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback ==='true'|| form?.inboxItem?.hasFeedback==='true') && !isLoading\"-->\r\n        <!--  <ds-button\r\n            square icon size=\"small\" (click)=\"feedback()\">\r\n            <ds-icon\r\n              icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\"\r\n              [ngClass]=\"{'fc-green':feedBackIcon === 'feedbackResponded' , 'fc-red': feedBackIcon === 'respondToFeedback' , 'fc-yellow': feedBackIcon === 'waitingFeedback'}\">\r\n            </ds-icon>\r\n          </ds-button>-->\r\n          <ds-button\r\n            *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n            (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n            <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n          </ds-button>\r\n          <ng-container *ngIf=\"showApprovalHistory\">\r\n            <ds-button\r\n              color=\"white\" shape=\"text\" square size=\"small\" [satPopoverAnchor]=\"workflow\"\r\n              #workflowAnchor=\"satPopoverAnchor\" (click)=\"workflowAnchor.popover.open()\">\r\n              <slot name=\"prefix\">\r\n                <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n              </slot>\r\n            </ds-button>\r\n\r\n            <sat-popover\r\n              #workflow [anchor]=\"workflowAnchor\" [hasBackdrop]=\"true\" verticalAlign=\"below\"\r\n              horizontalAlign=\"end\">\r\n              <div class=\"default-popover p-3\" style=\"min-width: 330px;\">\r\n                <ds-approvals *ngIf=\"approvalHistory\" class=\"popover-approvals\" approvalsData=\"{{approvals}}\">\r\n                </ds-approvals>\r\n              </div>\r\n            </sat-popover>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n  </header>\r\n</ng-container>\r\n<header\r\n  class=\"mb-4 mt-4 d-flex align-items-center justify-content-between align-items-end gap-2\"\r\n  *ngIf=\"(form?.header?.status?.['key'] === 'NEW')\">\r\n  <section>\r\n    <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n      {{ i18n.translate('Hello') }}\r\n      {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n    </h6>\r\n    <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n      {{ formTitle }}\r\n      <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" *ngIf=\"serviceBrief.length\" (click)=\"openFaq()\">\r\n      </ds-icon>\r\n    </h1>\r\n  </section>\r\n\r\n</header>\r\n"]}
@@ -28,7 +28,9 @@ export class ActionButtonsComponent {
28
28
  resetFormEmit = new EventEmitter();
29
29
  customCallEmit = new EventEmitter();
30
30
  actionStates;
31
- isSubmitting = {};
31
+ isSubmitting = {
32
+ 'SUBMIT': false
33
+ };
32
34
  submittingForm;
33
35
  constructor(i18n, actionStateService, coreService, dialog, toasterService, cdRef, sidenavService) {
34
36
  this.i18n = i18n;
@@ -101,7 +103,7 @@ export class ActionButtonsComponent {
101
103
  return '';
102
104
  }
103
105
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ActionButtonsComponent, deps: [{ token: i1.CoreI18nService }, { token: i1.ActionStateService }, { token: i1.CoreService }, { token: i2.MatDialog }, { token: i3.ToastrService }, { token: i0.ChangeDetectorRef }, { token: i1.SidenavService }], target: i0.ɵɵFactoryTarget.Component });
104
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ActionButtonsComponent, isStandalone: true, selector: "lib-action-buttons", inputs: { lovOptions: "lovOptions", lovType: "lovType", fieldsForm: "fieldsForm", form: "form", section: "section", sections: "sections", showApprovalCycle: "showApprovalCycle", customCall: "customCall" }, outputs: { resetFormEmit: "resetFormEmit", customCallEmit: "customCallEmit" }, ngImport: i0, template: "<div class=\"mt-4\">\r\n @if (lovType === 'button') {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n @for (item of lovOptions; track $index) {\r\n <ds-button\r\n loading=\"{{isSubmitting[item.value]}}\"\r\n [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n shape=\"{{ buttonShape(item) }}\"\r\n color=\"{{ buttonColor(item) }}\"\r\n (click)=\"onSubmit(item?.value)\">\r\n {{ item?.['description'] }}\r\n </ds-button>\r\n }\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 justify-content-end gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <ds-button\r\n [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n loading=\"{{isSubmitting['SUBMIT']}}\"\r\n (click)=\"onSubmit('SUBMIT')\">\r\n {{ i18n.translate('submit') }}\r\n </ds-button>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ApprovalsWorkflowComponent, selector: "lib-approvals-workflow", inputs: ["section", "form"] }] });
106
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ActionButtonsComponent, isStandalone: true, selector: "lib-action-buttons", inputs: { lovOptions: "lovOptions", lovType: "lovType", fieldsForm: "fieldsForm", form: "form", section: "section", sections: "sections", showApprovalCycle: "showApprovalCycle", customCall: "customCall" }, outputs: { resetFormEmit: "resetFormEmit", customCallEmit: "customCallEmit" }, ngImport: i0, template: "<div class=\"mt-4\">\r\n @if (lovType === 'button') {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n @for (item of lovOptions; track $index) {\r\n <ds-button\r\n loading=\"{{isSubmitting[item.value]}}\"\r\n [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n shape=\"{{ buttonShape(item) }}\"\r\n color=\"{{ buttonColor(item) }}\"\r\n (click)=\"onSubmit(item?.value)\">\r\n {{ item?.['description'] }}\r\n </ds-button>\r\n }\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n <ds-button\r\n [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n loading=\"{{isSubmitting['SUBMIT']}}\"\r\n (click)=\"onSubmit('SUBMIT')\">\r\n {{ i18n.translate('submit') }}\r\n </ds-button>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ApprovalsWorkflowComponent, selector: "lib-approvals-workflow", inputs: ["section", "form"] }] });
105
107
  }
106
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ActionButtonsComponent, decorators: [{
107
109
  type: Component,
@@ -111,7 +113,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
111
113
  NgIf,
112
114
  NgForOf,
113
115
  ApprovalsWorkflowComponent
114
- ], template: "<div class=\"mt-4\">\r\n @if (lovType === 'button') {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n @for (item of lovOptions; track $index) {\r\n <ds-button\r\n loading=\"{{isSubmitting[item.value]}}\"\r\n [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n shape=\"{{ buttonShape(item) }}\"\r\n color=\"{{ buttonColor(item) }}\"\r\n (click)=\"onSubmit(item?.value)\">\r\n {{ item?.['description'] }}\r\n </ds-button>\r\n }\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 justify-content-end gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <ds-button\r\n [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n loading=\"{{isSubmitting['SUBMIT']}}\"\r\n (click)=\"onSubmit('SUBMIT')\">\r\n {{ i18n.translate('submit') }}\r\n </ds-button>\r\n </div>\r\n }\r\n</div>\r\n" }]
116
+ ], template: "<div class=\"mt-4\">\r\n @if (lovType === 'button') {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n @for (item of lovOptions; track $index) {\r\n <ds-button\r\n loading=\"{{isSubmitting[item.value]}}\"\r\n [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n shape=\"{{ buttonShape(item) }}\"\r\n color=\"{{ buttonColor(item) }}\"\r\n (click)=\"onSubmit(item?.value)\">\r\n {{ item?.['description'] }}\r\n </ds-button>\r\n }\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n </ds-button>\r\n @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n }\r\n <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n <ds-button\r\n [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n loading=\"{{isSubmitting['SUBMIT']}}\"\r\n (click)=\"onSubmit('SUBMIT')\">\r\n {{ i18n.translate('submit') }}\r\n </ds-button>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n" }]
115
117
  }], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i1.ActionStateService }, { type: i1.CoreService }, { type: i2.MatDialog }, { type: i3.ToastrService }, { type: i0.ChangeDetectorRef }, { type: i1.SidenavService }], propDecorators: { lovOptions: [{
116
118
  type: Input
117
119
  }], lovType: [{
@@ -133,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
133
135
  }], customCallEmit: [{
134
136
  type: Output
135
137
  }] } });
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-buttons.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.ts","../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, NO_ERRORS_SCHEMA, Output} from '@angular/core';\r\nimport * as constants from \"../../../constants\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {InputComponent} from \"../form-field\";\r\nimport {ActionStateService, CoreI18nService, CoreService, SidenavService} from \"../../../services\";\r\nimport {Form, Section} from \"../../../interfaces\";\r\nimport {SubmitDialogComponent} from \"../dialogs/submit-dialog/submit-dialog.component\";\r\nimport {NoopScrollStrategy} from \"@angular/cdk/overlay\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {ApprovalsWorkflowComponent} from \"../../app-component-sections/approvals-workflow/approvals-workflow.component\";\r\n\r\n@Component({\r\n  selector: 'lib-action-buttons',\r\n  templateUrl: './action-buttons.component.html',\r\n  styleUrl: './action-buttons.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    ApprovalsWorkflowComponent\r\n  ]\r\n})\r\nexport class ActionButtonsComponent implements AfterViewInit {\r\n  @Input() lovOptions: any[];\r\n  @Input() lovType: string;\r\n  @Input() fieldsForm: FormGroup;\r\n  @Input() form: Form;\r\n  @Input() section: Section;\r\n  @Input() sections: Section[];\r\n  @Input() showApprovalCycle: boolean = true;\r\n  @Input() customCall: boolean = false;\r\n  @Output() resetFormEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() customCallEmit: EventEmitter<any> = new EventEmitter();\r\n  actionStates: { [action: string]: boolean };\r\n  isSubmitting = {};\r\n  submittingForm: boolean;\r\n\r\n  constructor(public i18n: CoreI18nService,\r\n              private actionStateService: ActionStateService,\r\n              private coreService: CoreService,\r\n              public dialog: MatDialog,\r\n              private toasterService: ToastrService,\r\n              private cdRef: ChangeDetectorRef,\r\n              private sidenavService: SidenavService\r\n  ) {\r\n    this.actionStateService.actionStates$.subscribe(states => this.actionStates = states);\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.lovOptions?.forEach((item) => {\r\n      this.isSubmitting[item.value] = false\r\n    })\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  resetForm() {\r\n    this.resetFormEmit.emit()\r\n  }\r\n\r\n  onSubmit(action: string) {\r\n    if (this.customCall) {\r\n      this.customCallEmit.emit(action)\r\n    } else {\r\n      this.submitForm(action, this.section)\r\n    }\r\n  }\r\n\r\n  submitForm(action: string, section: Section) {\r\n    const lastSection = this.sections[this.sections.length - 1];\r\n\r\n    if (lastSection.body.details.decision) {\r\n      lastSection.body.details.decision = {key: action};\r\n    }\r\n\r\n    this.isSubmitting[action] = true;\r\n    this.submittingForm = true;\r\n\r\n    this.coreService.submitForm(section, action).subscribe(\r\n      (response: any) => {\r\n        if (response) {\r\n          this.isSubmitting[action] = false;\r\n          this.success(response);\r\n        }\r\n      },\r\n      (err: any) => {\r\n        err?.error?.meta?.messages?.forEach((msg) => {\r\n          this.submittingForm = false;\r\n          this.isSubmitting[action] = false;\r\n          this.toasterService.error(msg.message);\r\n        });\r\n      }\r\n    );\r\n  }\r\n\r\n  success(response) {\r\n    console.log('success', response)\r\n    const dialogRef = this.dialog.open(SubmitDialogComponent, {\r\n      data: response,\r\n      panelClass: ['main-popup', 'confirm-dialog'],\r\n      scrollStrategy: new NoopScrollStrategy(),\r\n    });\r\n    dialogRef.afterClosed().subscribe(() => {\r\n      window.location.reload();\r\n    });\r\n  }\r\n\r\n  buttonShape(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_CANCEL || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'outline';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  buttonColor(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'red';\r\n    }\r\n    return '';\r\n  }\r\n}\r\n","<div class=\"mt-4\">\r\n  @if (lovType === 'button') {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n        @for (item of lovOptions; track $index) {\r\n          <ds-button\r\n            loading=\"{{isSubmitting[item.value]}}\"\r\n            [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n            shape=\"{{ buttonShape(item) }}\"\r\n            color=\"{{ buttonColor(item) }}\"\r\n            (click)=\"onSubmit(item?.value)\">\r\n            {{ item?.['description'] }}\r\n          </ds-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  } @else {\r\n    <div class=\"d-flex flex-wrap align-items-center flex-grow-1 justify-content-end gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <ds-button\r\n        [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n        loading=\"{{isSubmitting['SUBMIT']}}\"\r\n        (click)=\"onSubmit('SUBMIT')\">\r\n        {{ i18n.translate('submit') }}\r\n      </ds-button>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-buttons.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.ts","../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, NO_ERRORS_SCHEMA, Output} from '@angular/core';\r\nimport * as constants from \"../../../constants\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {InputComponent} from \"../form-field\";\r\nimport {ActionStateService, CoreI18nService, CoreService, SidenavService} from \"../../../services\";\r\nimport {Form, Section} from \"../../../interfaces\";\r\nimport {SubmitDialogComponent} from \"../dialogs/submit-dialog/submit-dialog.component\";\r\nimport {NoopScrollStrategy} from \"@angular/cdk/overlay\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {ApprovalsWorkflowComponent} from \"../../app-component-sections/approvals-workflow/approvals-workflow.component\";\r\n\r\n@Component({\r\n  selector: 'lib-action-buttons',\r\n  templateUrl: './action-buttons.component.html',\r\n  styleUrl: './action-buttons.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    ApprovalsWorkflowComponent\r\n  ]\r\n})\r\nexport class ActionButtonsComponent implements AfterViewInit {\r\n  @Input() lovOptions: any[];\r\n  @Input() lovType: string;\r\n  @Input() fieldsForm: FormGroup;\r\n  @Input() form: Form;\r\n  @Input() section: Section;\r\n  @Input() sections: Section[];\r\n  @Input() showApprovalCycle: boolean = true;\r\n  @Input() customCall: boolean = false;\r\n  @Output() resetFormEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() customCallEmit: EventEmitter<any> = new EventEmitter();\r\n  actionStates: { [action: string]: boolean };\r\n  isSubmitting = {\r\n    'SUBMIT':false\r\n  };\r\n  submittingForm: boolean;\r\n\r\n  constructor(public i18n: CoreI18nService,\r\n              private actionStateService: ActionStateService,\r\n              private coreService: CoreService,\r\n              public dialog: MatDialog,\r\n              private toasterService: ToastrService,\r\n              private cdRef: ChangeDetectorRef,\r\n              private sidenavService: SidenavService\r\n  ) {\r\n    this.actionStateService.actionStates$.subscribe(states => this.actionStates = states);\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.lovOptions?.forEach((item) => {\r\n      this.isSubmitting[item.value] = false\r\n    })\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  resetForm() {\r\n    this.resetFormEmit.emit()\r\n  }\r\n\r\n  onSubmit(action: string) {\r\n    if (this.customCall) {\r\n      this.customCallEmit.emit(action)\r\n    } else {\r\n      this.submitForm(action, this.section)\r\n    }\r\n  }\r\n\r\n  submitForm(action: string, section: Section) {\r\n    const lastSection = this.sections[this.sections.length - 1];\r\n\r\n    if (lastSection.body.details.decision) {\r\n      lastSection.body.details.decision = {key: action};\r\n    }\r\n\r\n    this.isSubmitting[action] = true;\r\n    this.submittingForm = true;\r\n\r\n    this.coreService.submitForm(section, action).subscribe(\r\n      (response: any) => {\r\n        if (response) {\r\n          this.isSubmitting[action] = false;\r\n          this.success(response);\r\n        }\r\n      },\r\n      (err: any) => {\r\n        err?.error?.meta?.messages?.forEach((msg) => {\r\n          this.submittingForm = false;\r\n          this.isSubmitting[action] = false;\r\n          this.toasterService.error(msg.message);\r\n        });\r\n      }\r\n    );\r\n  }\r\n\r\n  success(response) {\r\n    console.log('success', response)\r\n    const dialogRef = this.dialog.open(SubmitDialogComponent, {\r\n      data: response,\r\n      panelClass: ['main-popup', 'confirm-dialog'],\r\n      scrollStrategy: new NoopScrollStrategy(),\r\n    });\r\n    dialogRef.afterClosed().subscribe(() => {\r\n      window.location.reload();\r\n    });\r\n  }\r\n\r\n  buttonShape(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_CANCEL || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'outline';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  buttonColor(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'red';\r\n    }\r\n    return '';\r\n  }\r\n}\r\n","<div class=\"mt-4\">\r\n  @if (lovType === 'button') {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n        @for (item of lovOptions; track $index) {\r\n          <ds-button\r\n            loading=\"{{isSubmitting[item.value]}}\"\r\n            [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n            shape=\"{{ buttonShape(item) }}\"\r\n            color=\"{{ buttonColor(item) }}\"\r\n            (click)=\"onSubmit(item?.value)\">\r\n            {{ item?.['description'] }}\r\n          </ds-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  } @else {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n      <ds-button\r\n        [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n        loading=\"{{isSubmitting['SUBMIT']}}\"\r\n        (click)=\"onSubmit('SUBMIT')\">\r\n        {{ i18n.translate('submit') }}\r\n      </ds-button>\r\n    </div>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
@@ -66,7 +66,7 @@ export class AttachmentSectionDataComponent extends BaseComponent {
66
66
  });*/
67
67
  }
68
68
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AttachmentSectionDataComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
69
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: AttachmentSectionDataComponent, isStandalone: true, selector: "app-add-attachment-section", inputs: { hasColumnBreak: "hasColumnBreak" }, usesInheritance: true, ngImport: i0, template: "<div class=\"popup-container\">\r\n <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n <ds-button (click)=\"close()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n </div>\r\n <mat-dialog-content>\r\n <div class=\"px-md-4 mt-3\">\r\n <!-- add [callApi]=\"true\" input mobile issue not able to download it by base 64 -->\r\n\r\n <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"dialogData?.multiple\" [allowedExtensions]=\"dialogData?.data\"\r\n [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\" (emitedValue)=\"handleAttachmentEmitValue($event)\"\r\n >\r\n </app-file-uploader>\r\n\r\n <app-textarea class=\"section-item d-block mt-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n [label]=\"i18n.translate('description')\" [required]=\"dialogData.isRequired\" [minLength]='1' [maxLength]='500'\r\n [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n </app-textarea>\r\n\r\n <app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n </app-textarea>\r\n\r\n </div>\r\n </mat-dialog-content>\r\n <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n <ds-button shape=\"outline\" (click)=\"close()\" [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n </ds-button>\r\n <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n [disabled]=\"(!(popupData?.fileContents || popupData?.attachmentId ) ||( dialogData.isRequired && !popupData?.fileDescription )|| uploading)\">\r\n @if(!editMode){\r\n <span>{{i18n.translate('add')}}</span>\r\n }\r\n @if(editMode){\r\n <span>{{i18n.translate('edit')}}</span>\r\n }\r\n\r\n </ds-button>\r\n </mat-dialog-actions>\r\n\r\n</div>\r\n", styles: ["::ng-deep .add-attachment-dialog{--popup-max-width: 500px !important;--popup-width: 100% !important}::ng-deep .default-footer ds-button::part(base){--btn-min-width: 90px }\n"], dependencies: [{ kind: "component", type: TextareaComponent, selector: "app-textarea", inputs: ["label", "tooltip", "className", "preventSpecailChar"] }, { kind: "directive", type: MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: DocsUploaderComponent, selector: "app-file-uploader", inputs: ["useCrop", "formKey", "showLabel", "downloadLink", "showActions", "styleHeight", "fileInputHeight", "styleWidth", "hints", "label", "callApi", "tooltip", "attachments", "optional", "display", "attachType", "error", "displayedFiles", "getDataFromTemplate", "allowFileContentsWithMultiAttachments", "accept", "signType", "showSignButton", "printType", "showPrintButton", "downloadType", "showDownloadButton", "preventFileContents", "maxSize"], outputs: ["selectedTemplateAttachment", "addSignatureClicked", "printActionClicked", "downloadActionClicked"] }, { kind: "directive", type: MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }] });
69
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: AttachmentSectionDataComponent, isStandalone: true, selector: "app-add-attachment-section", inputs: { hasColumnBreak: "hasColumnBreak" }, usesInheritance: true, ngImport: i0, template: "<div class=\"popup-container\">\r\n <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n <ds-button (click)=\"close()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n </div>\r\n <mat-dialog-content>\r\n <div class=\"px-md-4 mt-3\">\r\n <!-- add [callApi]=\"true\" input mobile issue not able to download it by base 64 -->\r\n\r\n <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"dialogData?.multiple\" [allowedExtensions]=\"dialogData?.data\"\r\n [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\" (emitedValue)=\"handleAttachmentEmitValue($event)\"\r\n >\r\n </app-file-uploader>\r\n\r\n <app-textarea class=\"section-item d-block mt-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n [label]=\"i18n.translate('description')\" [required]=\"dialogData.isRequired\" [minLength]='1' [maxLength]='500'\r\n [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n </app-textarea>\r\n\r\n <app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n </app-textarea>\r\n\r\n </div>\r\n </mat-dialog-content>\r\n <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n <ds-button shape=\"outline\" (click)=\"close()\" [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n </ds-button>\r\n <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n [disabled]=\"(!(popupData?.fileContents || popupData?.attachmentId ) ||( dialogData.isRequired && !popupData?.fileDescription )|| uploading)\">\r\n @if(!editMode){\r\n <span>{{i18n.translate('add')}}</span>\r\n }\r\n @if(editMode){\r\n <span>{{i18n.translate('edit')}}</span>\r\n }\r\n\r\n </ds-button>\r\n </mat-dialog-actions>\r\n\r\n</div>\r\n", styles: ["::ng-deep .add-attachment-dialog{--popup-max-width: 500px !important;--popup-width: 100% !important}::ng-deep .default-footer ds-button::part(base){--btn-min-width: 90px }\n"], dependencies: [{ kind: "component", type: TextareaComponent, selector: "app-textarea", inputs: ["className", "preventSpecailChar"] }, { kind: "directive", type: MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: DocsUploaderComponent, selector: "app-file-uploader", inputs: ["useCrop", "formKey", "showLabel", "downloadLink", "showActions", "styleHeight", "fileInputHeight", "styleWidth", "hints", "label", "callApi", "tooltip", "attachments", "optional", "display", "attachType", "error", "displayedFiles", "getDataFromTemplate", "allowFileContentsWithMultiAttachments", "accept", "signType", "showSignButton", "printType", "showPrintButton", "downloadType", "showDownloadButton", "preventFileContents", "maxSize"], outputs: ["selectedTemplateAttachment", "addSignatureClicked", "printActionClicked", "downloadActionClicked"] }, { kind: "directive", type: MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }] });
70
70
  }
71
71
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AttachmentSectionDataComponent, decorators: [{
72
72
  type: Component,
@@ -74,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
74
74
  }], propDecorators: { hasColumnBreak: [{
75
75
  type: Input
76
76
  }] } });
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,4CAA4C,CAAC;AAC3E,OAAO,EAAC,gBAAgB,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAC5E,OAAO,EAAC,qBAAqB,EAAC,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAC,IAAI,EAAC,MAAM,iBAAiB,CAAC;;AAUrC,MAAM,OAAO,8BAA+B,SAAQ,aAAa;IAC/D,SAAS,GAAQ,EAAE,CAAC;IACpB,YAAY,GAAQ,EAAE,CAAC;IACvB,SAAS,CAAU;IACnB,QAAQ,CAAU;IACT,cAAc,CAAU;IAEjC,QAAQ;QACN;;;;;;;;WAQG;IACL,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAED,eAAe,CAAC,IAAS,EAAE,SAAiB;QAC1C,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;IACnC,CAAC;IAED,yBAAyB,CAAC,IAAS;QACjC,IAAI,CAAC,SAAS,GAAG;YACf,cAAc,EAAE,IAAI,EAAE,YAAY;YAClC,UAAU,EAAE,IAAI,EAAE,QAAQ;YAC1B,UAAU,EAAE,IAAI,EAAE,QAAQ;YAC1B,iBAAiB,EAAE,IAAI,CAAC,SAAS,EAAE,eAAe;YAClD,mBAAmB,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACtD,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;SAClD,CAAA;IACH,CAAC;IAED,cAAc;QACZ,MAAM,IAAI,GAAG;YACX,iBAAiB,EAAE,IAAI,CAAC,SAAS,EAAE,eAAe;YAClD,mBAAmB,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACtD,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACjD,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ;YACpC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ;YACpC,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY;SAC7C,CAAA;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB;;;;;;;;;;;;;;;eAeO;IACT,CAAC;uGAhEU,8BAA8B;2FAA9B,8BAA8B,2JCf3C,m/FAkDA,uODrCY,iBAAiB,0HAAE,gBAAgB,yGAAE,qBAAqB,gnBAAE,gBAAgB;;2FAE3E,8BAA8B;kBAR1C,SAAS;+BACE,4BAA4B,cAG1B,IAAI,WACP,CAAC,sBAAsB,CAAC,WACxB,CAAC,iBAAiB,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,IAAI,CAAC;8BAOpF,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\r\nimport { TextareaComponent } from '../textarea/textarea.component';\r\nimport { BaseComponent } from '../base-component/base-component.component';\r\nimport {MatDialogActions, MatDialogContent} from \"@angular/material/dialog\";\r\nimport {DocsUploaderComponent} from \"../../doc-uploader/docs-uploader.component\";\r\nimport {NgIf} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [TextareaComponent, MatDialogContent, DocsUploaderComponent, MatDialogActions, NgIf]\r\n})\r\nexport class AttachmentSectionDataComponent extends BaseComponent {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n\r\n  ngOnInit() {\r\n    /*if (this.coreStateMachineService?.attachmentListData) {\r\n      this.popupData = this.coreStateMachineService.attachmentListData\r\n      this.popupDataOrg = Object.assign({} , this.popupData)   ///// ibrahim solve isse related to discard data whenn click close\r\n      this.editMode = true;\r\n    }\r\n    if(this.dialogData){\r\n      console.log(this.dialogData);\r\n\r\n    }*/\r\n  }\r\n\r\n  close(){\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      \"fileContents\": data?.fileContents,\r\n      \"fileName\": data?.fileName,\r\n      \"mimeType\": data?.mimeType,\r\n      \"fileDescription\": this.popupData?.fileDescription,\r\n      \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n      \"fileComments\": this.popupData?.attachmentcomment,\r\n    }\r\n  }\r\n\r\n  addAttachments() {\r\n    const data = {\r\n      \"fileDescription\": this.popupData?.fileDescription,\r\n      \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n      \"fileComments\": this.popupData?.attachmentcomment,\r\n      \"fileName\": this.popupData?.fileName,\r\n      \"mimeType\": this.popupData?.mimeType,\r\n      \"fileContents\": this.popupData?.fileContents,\r\n    }\r\n    this.uploading = true;\r\n    /*this.coreStateMachineService.dispatch('getAttachments', data)\r\n      .then((Response: any) => {\r\n        this.uploading = false;\r\n        if (Response) {\r\n          this.coreStateMachineService.attachmentListData = null\r\n          const newObj = {\r\n            \"fileDescription\": this.popupData?.fileDescription,\r\n            \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n            \"fileComments\": this.popupData?.attachmentcomment,\r\n            \"fileName\": this.popupData?.fileName,\r\n            \"attachmentId\": Response.attachment.attachmentId,\r\n            \"mimeType\": this.popupData?.mimeType\r\n          }\r\n          this.dialogRef.close(newObj);\r\n        }\r\n      });*/\r\n  }\r\n\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n    <ds-button (click)=\"close()\" icon>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <!-- add [callApi]=\"true\"  input mobile issue not able to download it by base 64 -->\r\n\r\n      <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n        [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n        [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"dialogData?.multiple\" [allowedExtensions]=\"dialogData?.data\"\r\n        [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\" (emitedValue)=\"handleAttachmentEmitValue($event)\"\r\n        >\r\n      </app-file-uploader>\r\n\r\n      <app-textarea class=\"section-item d-block mt-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n        [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n        [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n        [label]=\"i18n.translate('description')\" [required]=\"dialogData.isRequired\" [minLength]='1' [maxLength]='500'\r\n        [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n      </app-textarea>\r\n\r\n      <app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n        [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n        [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n        [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n        [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n      </app-textarea>\r\n\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button  shape=\"outline\" (click)=\"close()\" [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n    </ds-button>\r\n    <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!(popupData?.fileContents || popupData?.attachmentId ) ||( dialogData.isRequired && !popupData?.fileDescription )|| uploading)\">\r\n      @if(!editMode){\r\n      <span>{{i18n.translate('add')}}</span>\r\n      }\r\n      @if(editMode){\r\n      <span>{{i18n.translate('edit')}}</span>\r\n      }\r\n\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n\r\n</div>\r\n"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,4CAA4C,CAAC;AAC3E,OAAO,EAAC,gBAAgB,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAC5E,OAAO,EAAC,qBAAqB,EAAC,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAC,IAAI,EAAC,MAAM,iBAAiB,CAAC;;AAUrC,MAAM,OAAO,8BAA+B,SAAQ,aAAa;IAC/D,SAAS,GAAQ,EAAE,CAAC;IACpB,YAAY,GAAQ,EAAE,CAAC;IACvB,SAAS,CAAU;IACnB,QAAQ,CAAU;IACT,cAAc,CAAU;IAEjC,QAAQ;QACN;;;;;;;;WAQG;IACL,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAED,eAAe,CAAC,IAAS,EAAE,SAAiB;QAC1C,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;IACnC,CAAC;IAED,yBAAyB,CAAC,IAAS;QACjC,IAAI,CAAC,SAAS,GAAG;YACf,cAAc,EAAE,IAAI,EAAE,YAAY;YAClC,UAAU,EAAE,IAAI,EAAE,QAAQ;YAC1B,UAAU,EAAE,IAAI,EAAE,QAAQ;YAC1B,iBAAiB,EAAE,IAAI,CAAC,SAAS,EAAE,eAAe;YAClD,mBAAmB,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACtD,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;SAClD,CAAA;IACH,CAAC;IAED,cAAc;QACZ,MAAM,IAAI,GAAG;YACX,iBAAiB,EAAE,IAAI,CAAC,SAAS,EAAE,eAAe;YAClD,mBAAmB,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACtD,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,iBAAiB;YACjD,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ;YACpC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ;YACpC,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY;SAC7C,CAAA;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB;;;;;;;;;;;;;;;eAeO;IACT,CAAC;uGAhEU,8BAA8B;2FAA9B,8BAA8B,2JCf3C,m/FAkDA,uODrCY,iBAAiB,sGAAE,gBAAgB,yGAAE,qBAAqB,gnBAAE,gBAAgB;;2FAE3E,8BAA8B;kBAR1C,SAAS;+BACE,4BAA4B,cAG1B,IAAI,WACP,CAAC,sBAAsB,CAAC,WACxB,CAAC,iBAAiB,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,IAAI,CAAC;8BAOpF,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\r\nimport { TextareaComponent } from '../textarea/textarea.component';\r\nimport { BaseComponent } from '../base-component/base-component.component';\r\nimport {MatDialogActions, MatDialogContent} from \"@angular/material/dialog\";\r\nimport {DocsUploaderComponent} from \"../../doc-uploader/docs-uploader.component\";\r\nimport {NgIf} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [TextareaComponent, MatDialogContent, DocsUploaderComponent, MatDialogActions, NgIf]\r\n})\r\nexport class AttachmentSectionDataComponent extends BaseComponent {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n\r\n  ngOnInit() {\r\n    /*if (this.coreStateMachineService?.attachmentListData) {\r\n      this.popupData = this.coreStateMachineService.attachmentListData\r\n      this.popupDataOrg = Object.assign({} , this.popupData)   ///// ibrahim solve isse related to discard data whenn click close\r\n      this.editMode = true;\r\n    }\r\n    if(this.dialogData){\r\n      console.log(this.dialogData);\r\n\r\n    }*/\r\n  }\r\n\r\n  close(){\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      \"fileContents\": data?.fileContents,\r\n      \"fileName\": data?.fileName,\r\n      \"mimeType\": data?.mimeType,\r\n      \"fileDescription\": this.popupData?.fileDescription,\r\n      \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n      \"fileComments\": this.popupData?.attachmentcomment,\r\n    }\r\n  }\r\n\r\n  addAttachments() {\r\n    const data = {\r\n      \"fileDescription\": this.popupData?.fileDescription,\r\n      \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n      \"fileComments\": this.popupData?.attachmentcomment,\r\n      \"fileName\": this.popupData?.fileName,\r\n      \"mimeType\": this.popupData?.mimeType,\r\n      \"fileContents\": this.popupData?.fileContents,\r\n    }\r\n    this.uploading = true;\r\n    /*this.coreStateMachineService.dispatch('getAttachments', data)\r\n      .then((Response: any) => {\r\n        this.uploading = false;\r\n        if (Response) {\r\n          this.coreStateMachineService.attachmentListData = null\r\n          const newObj = {\r\n            \"fileDescription\": this.popupData?.fileDescription,\r\n            \"attachmentcomment\": this.popupData?.attachmentcomment,\r\n            \"fileComments\": this.popupData?.attachmentcomment,\r\n            \"fileName\": this.popupData?.fileName,\r\n            \"attachmentId\": Response.attachment.attachmentId,\r\n            \"mimeType\": this.popupData?.mimeType\r\n          }\r\n          this.dialogRef.close(newObj);\r\n        }\r\n      });*/\r\n  }\r\n\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n    <ds-button (click)=\"close()\" icon>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <!-- add [callApi]=\"true\"  input mobile issue not able to download it by base 64 -->\r\n\r\n      <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n        [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n        [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"dialogData?.multiple\" [allowedExtensions]=\"dialogData?.data\"\r\n        [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\" (emitedValue)=\"handleAttachmentEmitValue($event)\"\r\n        >\r\n      </app-file-uploader>\r\n\r\n      <app-textarea class=\"section-item d-block mt-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n        [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n        [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n        [label]=\"i18n.translate('description')\" [required]=\"dialogData.isRequired\" [minLength]='1' [maxLength]='500'\r\n        [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n      </app-textarea>\r\n\r\n      <app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n        [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n        [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n        [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n        [errorMessage]=\"i18n.translate('lenghtMin1Max500')\">\r\n      </app-textarea>\r\n\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button  shape=\"outline\" (click)=\"close()\" [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n    </ds-button>\r\n    <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!(popupData?.fileContents || popupData?.attachmentId ) ||( dialogData.isRequired && !popupData?.fileDescription )|| uploading)\">\r\n      @if(!editMode){\r\n      <span>{{i18n.translate('add')}}</span>\r\n      }\r\n      @if(editMode){\r\n      <span>{{i18n.translate('edit')}}</span>\r\n      }\r\n\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n\r\n</div>\r\n"]}
@@ -1,52 +1,49 @@
1
1
  /* eslint-disable @typescript-eslint/no-empty-function */
2
2
  /* eslint-disable @angular-eslint/use-lifecycle-interface */
3
3
  /* eslint-disable @angular-eslint/component-selector */
4
- import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, Output } from '@angular/core';
5
- import { BaseComponent } from '../base-component/base-component.component';
4
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, forwardRef, inject, Input, Output } from '@angular/core';
6
5
  import { MatCheckbox } from "@angular/material/checkbox";
7
- import { FormsModule } from "@angular/forms";
6
+ import { FormsModule, NG_VALUE_ACCESSOR } from "@angular/forms";
8
7
  import { NgIf } from "@angular/common";
8
+ import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
9
+ import { TermsConditionsComponent } from '../../terms-conditions/terms-conditions.component';
10
+ import { MatDialog } from '@angular/material/dialog';
9
11
  import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/forms";
11
- export class CheckBoxComponent extends BaseComponent {
12
+ export class CheckBoxComponent extends ControlValueAccessorDirective {
12
13
  containTerms;
13
14
  termsLabel;
14
15
  linkText;
15
16
  hrefLink;
17
+ link;
18
+ name;
19
+ randomID;
20
+ termsBody;
16
21
  downloadCheckBox = new EventEmitter();
17
- ngOnInit() {
18
- this.value = this.field ? JSON.parse(this.field) : false;
19
- // this.resetPropagator.subscribe(this, this.resetCheckBoxData);
20
- }
21
- resetCheckBoxData() {
22
- if (!this.isReadOnly) {
23
- this.emitedValue.emit('false');
24
- this.value = false;
25
- }
26
- }
22
+ dialog = inject(MatDialog);
27
23
  openUrl() {
28
24
  window.open(this.hrefLink);
29
25
  }
30
26
  valueChange(event) {
31
27
  const checked = event.checked;
32
- this.value = checked;
33
- this.field = (checked).toString();
34
- this.emitedValue.emit(this.field);
35
- }
36
- downloadFile() {
37
- this.downloadCheckBox.emit();
28
+ this.control.setValue(checked);
38
29
  }
39
30
  openTermsPopup() {
40
- // const dialogRef = this.dialog.open(TermsConditionsComponent, {
41
- // data: this.termsBody,
42
- // width: '700px',
43
- // panelClass: ['main-popup'],
44
- // });
45
- // dialogRef.afterClosed().subscribe(() => {
46
- // });
31
+ const dialogRef = this.dialog.open(TermsConditionsComponent, {
32
+ data: this.termsBody,
33
+ width: '700px',
34
+ panelClass: ['main-popup'],
35
+ });
36
+ dialogRef.afterClosed().subscribe(() => {
37
+ });
47
38
  }
48
39
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CheckBoxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
49
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: CheckBoxComponent, isStandalone: true, selector: "app-checkbox", inputs: { containTerms: "containTerms", termsLabel: "termsLabel", linkText: "linkText", hrefLink: "hrefLink" }, outputs: { downloadCheckBox: "downloadCheckBox" }, usesInheritance: true, ngImport: i0, template: "<mat-checkbox\r\n class=\"my-3\" [disabled]=\"isReadOnly || disabled\" id=\"{{name}}{{randomID}}\" [(ngModel)]=\"value\" [name]=\"name\"\r\n (change)=\"valueChange($event)\" [checked]=\"field\"\r\n>\r\n <span class=\"fs-12 fw-medium fc-onyx\">\r\n {{ isReadOnly ? labelTextReadMode : labelTextWriteMode }}\r\n </span>\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" *ngIf=\"containTerms\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : i18n.translate('termsAndConditions') }}\r\n </span>\r\n <ng-container *ngIf=\"link\">\r\n <span> | </span>\r\n <a class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\" href=\"{{hrefLink}}\" target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n <!-- <a *ngIf=\"containDownload\" style=\"color: blue;\" class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" href=\"{{hrefLink}}\" target=\"_top\"> {{termsLabel}}</a> -->\r\n</mat-checkbox>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}\n"], dependencies: [{ kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
40
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: CheckBoxComponent, isStandalone: true, selector: "app-checkbox", inputs: { containTerms: "containTerms", termsLabel: "termsLabel", linkText: "linkText", hrefLink: "hrefLink", link: "link", name: "name", randomID: "randomID", termsBody: "termsBody" }, outputs: { downloadCheckBox: "downloadCheckBox" }, providers: [
41
+ {
42
+ provide: NG_VALUE_ACCESSOR,
43
+ useExisting: forwardRef(() => CheckBoxComponent),
44
+ multi: true,
45
+ },
46
+ ], usesInheritance: true, ngImport: i0, template: "<mat-checkbox\r\n class=\"my-3\" [disabled]=\"isDisabled\" id=\"{{name}}{{randomID}}\" [name]=\"name\"\r\n (change)=\"valueChange($event)\" [checked]=\"control.value\">\r\n <span class=\"fs-12 fw-medium fc-onyx\">\r\n {{ isReadOnly ? labelTextReadMode : labelTextWriteMode }}\r\n </span>\r\n @if(containTerms){\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : i18n.translate('termsAndConditions') }}\r\n </span>\r\n }\r\n @if (link){\r\n <ng-container>\r\n <span> | </span>\r\n <a class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\" href=\"{{hrefLink}}\" target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n }\r\n \r\n <!-- <a *ngIf=\"containDownload\" style=\"color: blue;\" class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" href=\"{{hrefLink}}\" target=\"_top\"> {{termsLabel}}</a> -->\r\n</mat-checkbox>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}\n"], dependencies: [{ kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: FormsModule }] });
50
47
  }
51
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CheckBoxComponent, decorators: [{
52
49
  type: Component,
@@ -54,7 +51,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
54
51
  MatCheckbox,
55
52
  FormsModule,
56
53
  NgIf
57
- ], standalone: true, template: "<mat-checkbox\r\n class=\"my-3\" [disabled]=\"isReadOnly || disabled\" id=\"{{name}}{{randomID}}\" [(ngModel)]=\"value\" [name]=\"name\"\r\n (change)=\"valueChange($event)\" [checked]=\"field\"\r\n>\r\n <span class=\"fs-12 fw-medium fc-onyx\">\r\n {{ isReadOnly ? labelTextReadMode : labelTextWriteMode }}\r\n </span>\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" *ngIf=\"containTerms\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : i18n.translate('termsAndConditions') }}\r\n </span>\r\n <ng-container *ngIf=\"link\">\r\n <span> | </span>\r\n <a class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\" href=\"{{hrefLink}}\" target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n <!-- <a *ngIf=\"containDownload\" style=\"color: blue;\" class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" href=\"{{hrefLink}}\" target=\"_top\"> {{termsLabel}}</a> -->\r\n</mat-checkbox>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}\n"] }]
54
+ ], standalone: true, providers: [
55
+ {
56
+ provide: NG_VALUE_ACCESSOR,
57
+ useExisting: forwardRef(() => CheckBoxComponent),
58
+ multi: true,
59
+ },
60
+ ], template: "<mat-checkbox\r\n class=\"my-3\" [disabled]=\"isDisabled\" id=\"{{name}}{{randomID}}\" [name]=\"name\"\r\n (change)=\"valueChange($event)\" [checked]=\"control.value\">\r\n <span class=\"fs-12 fw-medium fc-onyx\">\r\n {{ isReadOnly ? labelTextReadMode : labelTextWriteMode }}\r\n </span>\r\n @if(containTerms){\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : i18n.translate('termsAndConditions') }}\r\n </span>\r\n }\r\n @if (link){\r\n <ng-container>\r\n <span> | </span>\r\n <a class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\" href=\"{{hrefLink}}\" target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n }\r\n \r\n <!-- <a *ngIf=\"containDownload\" style=\"color: blue;\" class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\" href=\"{{hrefLink}}\" target=\"_top\"> {{termsLabel}}</a> -->\r\n</mat-checkbox>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}\n"] }]
58
61
  }], propDecorators: { containTerms: [{
59
62
  type: Input
60
63
  }], termsLabel: [{
@@ -63,7 +66,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
63
66
  type: Input
64
67
  }], hrefLink: [{
65
68
  type: Input
69
+ }], link: [{
70
+ type: Input
71
+ }], name: [{
72
+ type: Input
73
+ }], randomID: [{
74
+ type: Input
75
+ }], termsBody: [{
76
+ type: Input
66
77
  }], downloadCheckBox: [{
67
78
  type: Output
68
79
  }] } });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEseURBQXlEO0FBQ3pELDREQUE0RDtBQUM1RCx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDM0UsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsSUFBSSxFQUFDLE1BQU0saUJBQWlCLENBQUM7OztBQWVyQyxNQUFNLE9BQU8saUJBQWtCLFNBQVEsYUFBYTtJQUN6QyxZQUFZLENBQVU7SUFDdEIsVUFBVSxDQUFTO0lBQ25CLFFBQVEsQ0FBUztJQUNqQixRQUFRLENBQVM7SUFDaEIsZ0JBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUNoRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO1FBRXpELGdFQUFnRTtJQUNsRSxDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUM5QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU87UUFDTCxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQTtJQUM1QixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVU7UUFDcEIsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUM5QixJQUFJLENBQUMsS0FBSyxHQUFHLE9BQU8sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDbEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ25DLENBQUM7SUFFRCxZQUFZO1FBQ1YsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxDQUFBO0lBQzlCLENBQUM7SUFFRCxjQUFjO1FBQ1osaUVBQWlFO1FBQ2pFLDBCQUEwQjtRQUMxQixvQkFBb0I7UUFDcEIsZ0NBQWdDO1FBQ2hDLE1BQU07UUFFTiw0Q0FBNEM7UUFDNUMsTUFBTTtJQUNSLENBQUM7dUdBM0NVLGlCQUFpQjsyRkFBakIsaUJBQWlCLGtRQ3RCOUIseWtDQXFCQSxtNUJETkksV0FBVyx1VkFDWCxXQUFXLCtWQUNYLElBQUk7OzJGQUtLLGlCQUFpQjtrQkFiN0IsU0FBUzsrQkFDRSxjQUFjLFdBR2YsQ0FBQyxzQkFBc0IsQ0FBQyxXQUN4Qjt3QkFDUCxXQUFXO3dCQUNYLFdBQVc7d0JBQ1gsSUFBSTtxQkFDTCxjQUNXLElBQUk7OEJBSVAsWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxnQkFBZ0I7c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb24gKi9cclxuLyogZXNsaW50LWRpc2FibGUgQGFuZ3VsYXItZXNsaW50L3VzZS1saWZlY3ljbGUtaW50ZXJmYWNlICovXHJcbi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtc2VsZWN0b3IgKi9cclxuaW1wb3J0IHsgQ29tcG9uZW50LCBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uL2Jhc2UtY29tcG9uZW50L2Jhc2UtY29tcG9uZW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7TWF0Q2hlY2tib3h9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveFwiO1xyXG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtOZ0lmfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1jaGVja2JveCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jaGVja2JveC5jb21wb25lbnQuc2NzcyddLFxyXG4gIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBNYXRDaGVja2JveCxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTmdJZlxyXG4gIF0sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG5cclxufSlcclxuZXhwb3J0IGNsYXNzIENoZWNrQm94Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgY29udGFpblRlcm1zOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIHRlcm1zTGFiZWw6IHN0cmluZztcclxuICBASW5wdXQoKSBsaW5rVGV4dDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGhyZWZMaW5rOiBzdHJpbmc7XHJcbiAgQE91dHB1dCgpIGRvd25sb2FkQ2hlY2tCb3ggPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnZhbHVlID0gdGhpcy5maWVsZCA/IEpTT04ucGFyc2UodGhpcy5maWVsZCkgOiBmYWxzZTtcclxuXHJcbiAgICAvLyB0aGlzLnJlc2V0UHJvcGFnYXRvci5zdWJzY3JpYmUodGhpcywgdGhpcy5yZXNldENoZWNrQm94RGF0YSk7XHJcbiAgfVxyXG5cclxuICByZXNldENoZWNrQm94RGF0YSgpIHtcclxuICAgIGlmICghdGhpcy5pc1JlYWRPbmx5KSB7XHJcbiAgICAgIHRoaXMuZW1pdGVkVmFsdWUuZW1pdCgnZmFsc2UnKVxyXG4gICAgICB0aGlzLnZhbHVlID0gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvcGVuVXJsKCl7XHJcbiAgICB3aW5kb3cub3Blbih0aGlzLmhyZWZMaW5rKVxyXG4gIH1cclxuXHJcbiAgdmFsdWVDaGFuZ2UoZXZlbnQ6IGFueSkge1xyXG4gICAgY29uc3QgY2hlY2tlZCA9IGV2ZW50LmNoZWNrZWQ7XHJcbiAgICB0aGlzLnZhbHVlID0gY2hlY2tlZDtcclxuICAgIHRoaXMuZmllbGQgPSAoY2hlY2tlZCkudG9TdHJpbmcoKTtcclxuICAgIHRoaXMuZW1pdGVkVmFsdWUuZW1pdCh0aGlzLmZpZWxkKVxyXG4gIH1cclxuXHJcbiAgZG93bmxvYWRGaWxlKCl7XHJcbiAgICB0aGlzLmRvd25sb2FkQ2hlY2tCb3guZW1pdCgpXHJcbiAgfVxyXG5cclxuICBvcGVuVGVybXNQb3B1cCgpOiB2b2lkIHtcclxuICAgIC8vIGNvbnN0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4oVGVybXNDb25kaXRpb25zQ29tcG9uZW50LCB7XHJcbiAgICAvLyAgIGRhdGE6IHRoaXMudGVybXNCb2R5LFxyXG4gICAgLy8gICB3aWR0aDogJzcwMHB4JyxcclxuICAgIC8vICAgcGFuZWxDbGFzczogWydtYWluLXBvcHVwJ10sXHJcbiAgICAvLyB9KTtcclxuXHJcbiAgICAvLyBkaWFsb2dSZWYuYWZ0ZXJDbG9zZWQoKS5zdWJzY3JpYmUoKCkgPT4ge1xyXG4gICAgLy8gfSk7XHJcbiAgfVxyXG59XHJcbiIsIjxtYXQtY2hlY2tib3hcclxuICBjbGFzcz1cIm15LTNcIiBbZGlzYWJsZWRdPVwiaXNSZWFkT25seSB8fCBkaXNhYmxlZFwiIGlkPVwie3tuYW1lfX17e3JhbmRvbUlEfX1cIiBbKG5nTW9kZWwpXT1cInZhbHVlXCIgW25hbWVdPVwibmFtZVwiXHJcbiAgKGNoYW5nZSk9XCJ2YWx1ZUNoYW5nZSgkZXZlbnQpXCIgW2NoZWNrZWRdPVwiZmllbGRcIlxyXG4+XHJcbiAgPHNwYW4gY2xhc3M9XCJmcy0xMiBmdy1tZWRpdW0gZmMtb255eFwiPlxyXG4gICAge3sgaXNSZWFkT25seSA/IGxhYmVsVGV4dFJlYWRNb2RlIDogbGFiZWxUZXh0V3JpdGVNb2RlIH19XHJcbiAgPC9zcGFuPlxyXG4gIDxzcGFuXHJcbiAgICBjbGFzcz1cImZzLTEyIGZ3LWJvbGQgZmMtY29yYWwgY3Vyc29yLXBvaW50ZXIgbXgtMVwiICpuZ0lmPVwiY29udGFpblRlcm1zXCJcclxuICAgIChjbGljayk9XCJvcGVuVGVybXNQb3B1cCgpOyBmYWxzZVwiPlxyXG4gICAge3sgdGVybXNMYWJlbCA/IHRlcm1zTGFiZWwgOiBpMThuLnRyYW5zbGF0ZSgndGVybXNBbmRDb25kaXRpb25zJykgfX1cclxuICA8L3NwYW4+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImxpbmtcIj5cclxuICAgIDxzcGFuPiB8IDwvc3Bhbj5cclxuICAgIDxhIGNsYXNzPVwiZnMtMTIgZnctYm9sZCBmYy1jb3JhbCBjdXJzb3ItcG9pbnRlciBteC0xIGQtaW5saW5lLWZsZXggYWxpZ24taXRlbXMtY2VudGVyIGdhcC0xXCIgaHJlZj1cInt7aHJlZkxpbmt9fVwiIHRhcmdldD1cIl9ibGFua1wiPlxyXG4gICAgICA8ZHMtaWNvbiBpY29uPVwiZXh0ZXJuYWwtbGlua1wiPjwvZHMtaWNvbj5cclxuICAgICAgPHNwYW4gY2xhc3M9XCJ1bmRlcmxpbmVcIj57eyBsaW5rVGV4dCB9fTwvc3Bhbj5cclxuICAgIDwvYT5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuICA8IS0tIDxhICpuZ0lmPVwiY29udGFpbkRvd25sb2FkXCIgc3R5bGU9XCJjb2xvcjogYmx1ZTtcIiBjbGFzcz1cImZzLTEyIGZ3LWJvbGQgZmMtY29yYWwgY3Vyc29yLXBvaW50ZXIgbXgtMVwiIGhyZWY9XCJ7e2hyZWZMaW5rfX1cIiB0YXJnZXQ9XCJfdG9wXCI+IHt7dGVybXNMYWJlbH19PC9hPiAtLT5cclxuPC9tYXQtY2hlY2tib3g+XHJcbiJdfQ==
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEseURBQXlEO0FBQ3pELDREQUE0RDtBQUM1RCx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ILE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsV0FBVyxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUQsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3JDLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFzQnJELE1BQU0sT0FBTyxpQkFBd0IsU0FBUSw2QkFBbUM7SUFDckUsWUFBWSxDQUFVO0lBQ3RCLFVBQVUsQ0FBUztJQUNuQixRQUFRLENBQVM7SUFDakIsUUFBUSxDQUFTO0lBQ2pCLElBQUksQ0FBUztJQUNiLElBQUksQ0FBUztJQUNiLFFBQVEsQ0FBUztJQUNqQixTQUFTLENBQU07SUFDZCxnQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBQ2hELE1BQU0sR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFFM0IsT0FBTztRQUNMLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0lBQzVCLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBVTtRQUNwQixNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzlCLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ2hDLENBQUM7SUFFRCxjQUFjO1FBQ1osTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsd0JBQXdCLEVBQUU7WUFDM0QsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3BCLEtBQUssRUFBRSxPQUFPO1lBQ2QsVUFBVSxFQUFFLENBQUMsWUFBWSxDQUFDO1NBQzNCLENBQUMsQ0FBQztRQUVILFNBQVMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ3ZDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt1R0E5QlUsaUJBQWlCOzJGQUFqQixpQkFBaUIsd1NBVGpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDaEQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQzVCSCxpa0NBeUJBLG01QkRSSSxXQUFXLHVWQUNYLFdBQVc7OzJGQWFGLGlCQUFpQjtrQkFwQjdCLFNBQVM7K0JBQ0UsY0FBYyxXQUdmLENBQUMsc0JBQXNCLENBQUMsV0FDeEI7d0JBQ1AsV0FBVzt3QkFDWCxXQUFXO3dCQUNYLElBQUk7cUJBQ0wsY0FDVyxJQUFJLGFBQ0w7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsa0JBQWtCLENBQUM7NEJBQ2hELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGOzhCQUlRLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0ksZ0JBQWdCO3NCQUF6QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWZ1bmN0aW9uICovXHJcbi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC91c2UtbGlmZWN5Y2xlLWludGVyZmFjZSAqL1xyXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvY29tcG9uZW50LXNlbGVjdG9yICovXHJcbmltcG9ydCB7IENvbXBvbmVudCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgRXZlbnRFbWl0dGVyLCBmb3J3YXJkUmVmLCBpbmplY3QsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtNYXRDaGVja2JveH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94XCI7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGUsIE5HX1ZBTFVFX0FDQ0VTU09SfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtOZ0lmfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlIH0gZnJvbSAnLi4vY29udHJvbC12YWx1ZS1hY2Nlc3Nvci5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBUZXJtc0NvbmRpdGlvbnNDb21wb25lbnQgfSBmcm9tICcuLi8uLi90ZXJtcy1jb25kaXRpb25zL3Rlcm1zLWNvbmRpdGlvbnMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWNoZWNrYm94JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NoZWNrYm94LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdENoZWNrYm94LFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBOZ0lmXHJcbiAgXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQ2hlY2tCb3hDb21wb25lbnQpLFxyXG4gICAgICBtdWx0aTogdHJ1ZSxcclxuICAgIH0sXHJcbiAgXVxyXG5cclxufSlcclxuZXhwb3J0IGNsYXNzIENoZWNrQm94Q29tcG9uZW50PFR5cGU+IGV4dGVuZHMgQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmU8VHlwZT4ge1xyXG4gIEBJbnB1dCgpIGNvbnRhaW5UZXJtczogYm9vbGVhbjtcclxuICBASW5wdXQoKSB0ZXJtc0xhYmVsOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGlua1RleHQ6IHN0cmluZztcclxuICBASW5wdXQoKSBocmVmTGluazogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGxpbms6IHN0cmluZztcclxuICBASW5wdXQoKSBuYW1lOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcmFuZG9tSUQ6IHN0cmluZztcclxuICBASW5wdXQoKSB0ZXJtc0JvZHk6IGFueTtcclxuICBAT3V0cHV0KCkgZG93bmxvYWRDaGVja0JveCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBkaWFsb2cgPSBpbmplY3QoTWF0RGlhbG9nKTtcclxuIFxyXG4gIG9wZW5VcmwoKXtcclxuICAgIHdpbmRvdy5vcGVuKHRoaXMuaHJlZkxpbmspXHJcbiAgfVxyXG5cclxuICB2YWx1ZUNoYW5nZShldmVudDogYW55KSB7XHJcbiAgICBjb25zdCBjaGVja2VkID0gZXZlbnQuY2hlY2tlZDtcclxuICAgIHRoaXMuY29udHJvbC5zZXRWYWx1ZShjaGVja2VkKVxyXG4gIH1cclxuXHJcbiAgb3BlblRlcm1zUG9wdXAoKTogdm9pZCB7XHJcbiAgICBjb25zdCBkaWFsb2dSZWYgPSB0aGlzLmRpYWxvZy5vcGVuKFRlcm1zQ29uZGl0aW9uc0NvbXBvbmVudCwge1xyXG4gICAgICBkYXRhOiB0aGlzLnRlcm1zQm9keSxcclxuICAgICAgd2lkdGg6ICc3MDBweCcsXHJcbiAgICAgIHBhbmVsQ2xhc3M6IFsnbWFpbi1wb3B1cCddLFxyXG4gICAgfSk7XHJcblxyXG4gICAgZGlhbG9nUmVmLmFmdGVyQ2xvc2VkKCkuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iLCI8bWF0LWNoZWNrYm94XHJcbiAgY2xhc3M9XCJteS0zXCIgW2Rpc2FibGVkXT1cImlzRGlzYWJsZWRcIiBpZD1cInt7bmFtZX19e3tyYW5kb21JRH19XCIgW25hbWVdPVwibmFtZVwiXHJcbiAgKGNoYW5nZSk9XCJ2YWx1ZUNoYW5nZSgkZXZlbnQpXCIgW2NoZWNrZWRdPVwiY29udHJvbC52YWx1ZVwiPlxyXG4gIDxzcGFuIGNsYXNzPVwiZnMtMTIgZnctbWVkaXVtIGZjLW9ueXhcIj5cclxuICAgIHt7IGlzUmVhZE9ubHkgPyBsYWJlbFRleHRSZWFkTW9kZSA6IGxhYmVsVGV4dFdyaXRlTW9kZSB9fVxyXG4gIDwvc3Bhbj5cclxuICBAaWYoY29udGFpblRlcm1zKXtcclxuICAgIDxzcGFuXHJcbiAgICBjbGFzcz1cImZzLTEyIGZ3LWJvbGQgZmMtY29yYWwgY3Vyc29yLXBvaW50ZXIgbXgtMVwiXHJcbiAgICAoY2xpY2spPVwib3BlblRlcm1zUG9wdXAoKTsgZmFsc2VcIj5cclxuICAgIHt7IHRlcm1zTGFiZWwgPyB0ZXJtc0xhYmVsIDogaTE4bi50cmFuc2xhdGUoJ3Rlcm1zQW5kQ29uZGl0aW9ucycpIH19XHJcbiAgPC9zcGFuPlxyXG4gIH1cclxuIEBpZiAobGluayl7XHJcbiAgPG5nLWNvbnRhaW5lcj5cclxuICAgIDxzcGFuPiB8IDwvc3Bhbj5cclxuICAgIDxhIGNsYXNzPVwiZnMtMTIgZnctYm9sZCBmYy1jb3JhbCBjdXJzb3ItcG9pbnRlciBteC0xIGQtaW5saW5lLWZsZXggYWxpZ24taXRlbXMtY2VudGVyIGdhcC0xXCIgaHJlZj1cInt7aHJlZkxpbmt9fVwiIHRhcmdldD1cIl9ibGFua1wiPlxyXG4gICAgICA8ZHMtaWNvbiBpY29uPVwiZXh0ZXJuYWwtbGlua1wiPjwvZHMtaWNvbj5cclxuICAgICAgPHNwYW4gY2xhc3M9XCJ1bmRlcmxpbmVcIj57eyBsaW5rVGV4dCB9fTwvc3Bhbj5cclxuICAgIDwvYT5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuIH1cclxuIFxyXG4gIDwhLS0gPGEgKm5nSWY9XCJjb250YWluRG93bmxvYWRcIiBzdHlsZT1cImNvbG9yOiBibHVlO1wiIGNsYXNzPVwiZnMtMTIgZnctYm9sZCBmYy1jb3JhbCBjdXJzb3ItcG9pbnRlciBteC0xXCIgaHJlZj1cInt7aHJlZkxpbmt9fVwiIHRhcmdldD1cIl90b3BcIj4ge3t0ZXJtc0xhYmVsfX08L2E+IC0tPlxyXG48L21hdC1jaGVja2JveD5cclxuIl19