vcomply-workflow-engine 6.0.45 → 6.0.47
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.
- package/esm2022/lib/sharedComponents/document-section/document-section.component.mjs +2 -2
- package/esm2022/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.mjs +5 -2
- package/esm2022/lib/workflow-policy/ms-word.constants.mjs +1 -2
- package/fesm2022/vcomply-workflow-engine.mjs +5 -3
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/workflow-policy/ms-word.constants.d.ts +0 -1
- package/package.json +1 -1
|
@@ -66,7 +66,7 @@ export class DocumentSectionComponent {
|
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
68
|
initialiseFeatureFlags() {
|
|
69
|
-
this.ff_policy_ms_word_integration = this.feature.isFeatureEnabled(
|
|
69
|
+
this.ff_policy_ms_word_integration = this.feature.isFeatureEnabled('ff_policy_ms_word_integration');
|
|
70
70
|
}
|
|
71
71
|
redirectUserToWordPolicy() {
|
|
72
72
|
window.open(WORD_URL_CONSTANTS.new_word_policy_url, '_blank');
|
|
@@ -259,4 +259,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
259
259
|
}], openTemplate: [{
|
|
260
260
|
type: Output
|
|
261
261
|
}] } });
|
|
262
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-section.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/document-section/document-section.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/document-section/document-section.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAC;AAMvB,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;AAO7F,MAAM,OAAO,wBAAwB;IAgCnC,YACU,QAAyB,EACzB,aAA4B,EAC5B,gBAAkC,EAClC,MAAc,EACd,KAAqB,EAC7B,gBAAkC,EAC1B,aAA4B;QAN5B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QAErB,kBAAa,GAAb,aAAa,CAAe;QArCtC,aAAQ,GAAG,EAAE,CAAC;QACd,aAAQ,GAAG,EAAE,CAAC;QACd,QAAG,GAAG,KAAK,CAAC;QACZ,UAAK,GAAG,KAAK,CAAC;QACd,QAAG,GAAG,KAAK,CAAC;QACZ,gBAAW,GAAG,KAAK,CAAC;QACpB,aAAQ,GAAG,KAAK,CAAC;QACjB,kCAA6B,GAAY,KAAK,CAAC;QAC/C,yBAAoB,GAAG,cAAc,CAAC,cAAc,CAAC;QAE5C,yBAAoB,GAAG,EAAE,CAAC;QAE1B,iBAAY,GAAG,KAAK,CAAC;QACrB,aAAQ,GAAQ,EAAE,CAAC;QACnB,eAAU,GAAQ,EAAE,CAAC;QACrB,oBAAe,GAAQ,EAAE,CAAC;QAG1B,gBAAW,GAAW,EAAE,CAAC;QACzB,qBAAgB,GAAY,KAAK,CAAC;QACjC,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAChC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAE5C,YAAO,GAAG,EAAE,CAAC;QACb,cAAS,GAAG;YACV,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,EAAE;SACZ,CAAC;QAoFF,iBAAY,GAAG,IAAI,CAAC;QACpB,kBAAa,GAAG,IAAI,CAAC;QA1EnB,IAAI,CAAC,OAAO,GAAG,QAAQ,EAAE,MAAM,CAAC;QAChC,IAAI,IAAI,CAAC,OAAO,IAAI,uBAAuB,EAAE;YAC3C,IAAI,CAAC,OAAO,GAAG,0BAA0B,CAAC;SAC3C;IACH,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,EAAE,YAAY,EAAE,YAAY,KAAK,KAAK,EAAE;YACjD,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;SAChC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CACrB,YAAY,CAAC,OAAO,CAAC,qBAAqB,CAAC,IAAI,MAAM,CACtD,CAAC;QACF,IACE,IAAI,CAAC,IAAI,KAAK,IAAI;YAClB,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,IAAI,KAAK,IAAI;YAClB,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAC9B;YACA,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,IAAI,CAAC;YACtC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;YAC1B,YAAY,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;SAChD;IACH,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,6BAA6B,GAAI,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,cAAc,CAAC,6BAA6B,CAAC,CAAC;IACpH,CAAC;IAEH,wBAAwB;QACtB,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAC;QAC9D,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAI,IAAI,CAAC,OAAO,GAAG,kBAAkB,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;IACzF,CAAC;IAEC,gBAAgB;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACtE,IAAG,GAAG,EAAC;gBACL,IAAI,CAAC,wBAAwB,EAAE,CAAC;aACjC;YACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,cAAc,CAAC,iCAAiC,EAChD,OAAO,CACR,CAAC;QACJ,CAAC,CACF,CAAC;IACF,CAAC;IAED,eAAe,CAAC,KAAe;QAC7B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;QACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI;aACnC,KAAK,CACJ,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAC3C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAC9B;aACA,WAAW,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC3B,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;SACvE;aAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;YACnC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;SACvE;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,4BAA4B,EAAE,OAAO,CAAC,CAAC;SAC3D;IACH,CAAC;IAID,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,KAAK,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC7B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SAC5B;aAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK,EAAE;YACnC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAC3B,CAAC,EAAE,EAAE,CAAC,CAAC;YACP,MAAM,UAAU,GAAG,IAAI,QAAQ,EAAE,CAAC;YAClC,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;YACtC,MAAM,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC;YACtD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,SAAS,CACtE,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,GAAG,EAAE;oBACP,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;iBAC1B;YACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,6GAA6G,EAC7G,OAAO,CACR,CAAC;YACJ,CAAC,CACF,CAAC;SACH;IACH,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC5B,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,MAAM,UAAU,GAAG,IAAI,QAAQ,EAAE,CAAC;QAClC,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC;QACtD,IAAI,CAAC,aAAa;aACf,cAAc,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC;aAC/C,SAAS,CACR,CAAC,GAAQ,EAAE,EAAE;YACX,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,IAAI,GAAG,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,EAAE;oBAClC,IAAI,CAAC,cAAc,EAAE,CAAC;iBACvB;qBAAM;oBACL,IAAI,GAAG,CAAC,OAAO,EAAE,QAAQ,CAAC,YAAY,CAAC,EAAE;wBACvC,IAAI,CAAC,SAAS,GAAG;4BACf,OAAO,EAAE,IAAI;4BACb,OAAO,EAAE,oDAAoD;yBAC9D,CAAC;qBACH;yBAAM;wBACL,IAAI,CAAC,SAAS,GAAG;4BACf,OAAO,EAAE,IAAI;4BACb,OAAO,EAAE,oDAAoD;yBAC9D,CAAC;qBACH;iBACF;aACF;QACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YAEzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,6GAA6G,EAC7G,OAAO,CACR,CAAC;QACJ,CAAC,CACF,CAAC;IACN,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,SAAS,GAAG;YACf,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,EAAE;SACZ,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,KAAK,KAAK,UAAU,EAAE;YACxB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEnC,IAAI,KAAK,KAAK,OAAO,EAAE;YACrB,6CAA6C;YAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YACtD,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC;YAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;YACzB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,aAAa;iBACf,iBAAiB,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;iBAC9C,SAAS,CACR,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,GAAG,EAAE;oBACP,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;oBACtB,MAAM,GAAG,GACP,IAAI,CAAC,OAAO,GAAG,6BAA6B,GAAG,IAAI,CAAC,QAAQ,CAAC;oBAC/D,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;iBAClD;YACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,6GAA6G,EAC7G,OAAO,CACR,CAAC;YACJ,CAAC,CACF,CAAC;SACL;aAAM,IAAI,KAAK,KAAK,MAAM,EAAE;YAC3B,MAAM,GAAG,GACP,IAAI,CAAC,OAAO,GAAG,6BAA6B,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC/D,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;SAClD;aAAM,IAAI,KAAK,KAAK,MAAM,EAAE;YACzB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;aAAM,IAAI,KAAK,KAAK,KAAK,EAAE;YAC1B,sCAAsC;YACtC,MAAM,GAAG,GACP,IAAI,CAAC,OAAO,GAAG,0BAA0B,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC5D,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;SAClD;aAAM,IAAI,KAAK,KAAK,UAAU,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SAC/D;QACD,YAAY,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC/B,YAAY,CAAC,OAAO,CAClB,qBAAqB,EACrB,IAAI,CAAC,SAAS,CAAC;YACb,IAAI,EAAE,IAAI,CAAC,oBAAoB;YAC/B,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC,CACH,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;+GA1QU,wBAAwB;mGAAxB,wBAAwB,sfCtBrC,ishBAoWA;;4FD9Ua,wBAAwB;kBALpC,SAAS;+BACE,sBAAsB;8QAgBvB,oBAAoB;sBAA5B,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,iBAAiB;sBAA1B,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,YAAY;sBAArB,MAAM","sourcesContent":["import { PlatformLocation } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { SnackBarService } from '../../ui-kit/snack-bar/snack-bar.service';\nimport { PolicyService } from '../../workflow-services/policy.service';\nimport { PolicyAPIService } from '../../workflow-services/policy-api.service';\nimport { IframeService } from '../../services/iframe.service';\nimport { WORD_CONSTANTS, WORD_URL_CONSTANTS } from '../../workflow-policy/ms-word.constants';\n\n@Component({\n  selector: 'lib-document-section',\n  templateUrl: './document-section.component.html',\n  styleUrls: ['./document-section.component.less'],\n})\nexport class DocumentSectionComponent implements OnInit, OnChanges {\n  private fileToUpload: any;\n  filename = '';\n  fileType = '';\n  pdf = false;\n  draft = false;\n  doc = false;\n  isUploading = false;\n  isLoader = false;\n  ff_policy_ms_word_integration: boolean = false;\n  createWordPolicyText = WORD_CONSTANTS.MS_WORD_OPTION;\n\n  @Input() selectedDocumentType = '';\n  @Input() feature: any;\n  @Input() templateView = false;\n  @Input() policyId: any = '';\n  @Input() policyName: any = '';\n  @Input() organization_id: any = '';\n  @Input() member_obj_id: any;\n  @Input() userInfo: any;\n  @Input() templateUrl: string = '';\n  @Input() isTemplateOpened: boolean = false;\n  @Output() disconnectRefresh = new EventEmitter();\n  @Output() editPolicy = new EventEmitter();\n  @Output() openTemplate = new EventEmitter();\n\n  baseURL = '';\n  docxError = {\n    visible: false,\n    message: '',\n  };\n\n  constructor(\n    private snackBar: SnackBarService,\n    private policyService: PolicyService,\n    private policyAPIService: PolicyAPIService,\n    private router: Router,\n    private route: ActivatedRoute,\n    platformLocation: PlatformLocation,\n    private iframeService: IframeService\n  ) {\n    this.baseURL = location?.origin;\n    if (this.baseURL == 'http://localhost:4200') {\n      this.baseURL = 'https://dev.v-comply.com';\n    }\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes?.templateView?.currentValue === false) {\n      this.selectedDocumentType = '';\n    }\n  }\n\n  ngOnInit(): void {\n    this.initialiseFeatureFlags();\n    const data = JSON.parse(\n      localStorage.getItem('lastFileNameAndType') ?? '\"{}\"'\n    );\n    if (\n      data.name !== null &&\n      data.name !== undefined &&\n      data.type !== null &&\n      data.type !== undefined &&\n      data.policyId == this.policyId\n    ) {\n      this.selectedDocumentType = data.type;\n      this.filename = data.name;\n      localStorage.removeItem('lastFileNameAndType');\n    }\n  }\n\n  initialiseFeatureFlags() {\n    this.ff_policy_ms_word_integration =  this.feature.isFeatureEnabled(WORD_CONSTANTS.ff_policy_ms_word_integration);\n  }\n\nredirectUserToWordPolicy() {\n  window.open(WORD_URL_CONSTANTS.new_word_policy_url, '_blank');\n  window.location.href =  this.baseURL + WORD_URL_CONSTANTS.workroom_url + this.policyId;\n}\n\n  createWordPolicy() {\n    this.isLoader = true;\n    this.policyAPIService.createWordPolicy(this.policyId).subscribe((res) => {\n      if(res){\n        this.redirectUserToWordPolicy();\n      }       \n      this.isLoader = false;\n    },\n    (err) => {\n      this.isLoader = false;\n      this.snackBar.show(\n        WORD_CONSTANTS.createWordPolicy_snackbar_message,\n        'alert'\n      );\n    }\n  );\n  }\n\n  handleFileInput(files: FileList): void {\n    this.fileToUpload = files[0];\n    this.filename = this.fileToUpload.name;\n    this.fileType = this.fileToUpload.name\n      .slice(\n        this.fileToUpload.name.lastIndexOf('.') + 1,\n        this.fileToUpload.name.length\n      )\n      .toLowerCase();\n    if (this.fileType === 'pdf') {\n      this.uploadFile({ file: this.fileToUpload, fileType: this.fileType });\n    } else if (this.fileType === 'docx') {\n      this.uploadFile({ file: this.fileToUpload, fileType: this.fileType });\n    } else {\n      this.snackBar.show('Please upload a valid file', 'alert');\n    }\n  }\n  showPdfBlock = true;\n  showDocxBlock = true;\n\n  uploadFile(event: any) {\n    this.isUploading = true;\n    if (event.fileType === 'docx') {\n      this.changeDocType('docx');\n      this.uploadDocxfile(event);\n    } else if (event.fileType === 'pdf') {\n      this.changeDocType('pdf');\n      this.showPdfBlock = false;\n      setTimeout(() => {\n        this.showPdfBlock = true;\n      }, 10);\n      const uploadData = new FormData();\n      uploadData.append('file', event.file);\n      const path = 'o/' + this.organization_id + '/policy/';\n      this.policyService.uploadFile(uploadData, this.policyId, path).subscribe(\n        (res) => {\n          if (res) {\n            this.isUploading = false;\n          }\n        },\n        (err) => {\n          this.isUploading = false;\n          this.snackBar.show(\n            \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n            'alert'\n          );\n        }\n      );\n    }\n  }\n\n  uploadDocxfile(event: any) {\n    this.resetDocsError();\n    this.showDocxBlock = false;\n    setTimeout(() => {\n      this.showDocxBlock = true;\n    }, 10);\n    const uploadData = new FormData();\n    uploadData.append('file', event.file);\n    const path = 'o/' + this.organization_id + '/policy/';\n    this.policyService\n      .uploadDocxFile(uploadData, this.policyId, path)\n      .subscribe(\n        (res: any) => {\n          if (res) {\n            this.isUploading = false;\n            if (res?.message?.includes('done')) {\n              this.resetDocsError();\n            } else {\n              if (res.message?.includes('RangeError')) {\n                this.docxError = {\n                  visible: true,\n                  message: 'The file size is too large and cannot be uploaded.',\n                };\n              } else {\n                this.docxError = {\n                  visible: true,\n                  message: 'Oops! An error occurred while uploading this file.',\n                };\n              }\n            }\n          }\n        },\n        (err) => {\n          this.isUploading = false;\n\n          this.snackBar.show(\n            \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n            'alert'\n          );\n        }\n      );\n  }\n\n  resetDocsError() {\n    this.docxError = {\n      visible: false,\n      message: '',\n    };\n  }\n\n  changeDocType(event: any) {\n    this.resetDocsError();\n    this.selectedDocumentType = event;\n    if (event === 'template') {\n      this.openTemplateList();\n    }\n  }\n\n  editor(event: string) {\n    this.disconnectRefresh.emit(false);\n\n    if (event === 'draft') {\n      // If it is a draft go directly to the editor\n      const uname = this.userInfo ? this.userInfo.name : '';\n      const uid = this.member_obj_id;\n      const name = this.policyName.trim();\n      const id = this.policyId;\n      this.isLoader = true;\n      this.policyService\n        .savePolicyDetails(uname, uid, id, name, '', 0)\n        .subscribe(\n          (res) => {\n            if (res) {\n              this.isLoader = false;\n              const url =\n                this.baseURL + '/all/policy/edit-policy?id=' + this.policyId;\n              this.iframeService.redirectIfInIframe(url, true);\n            }\n          },\n          (err) => {\n            this.isLoader = false;\n            this.snackBar.show(\n              \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n              'alert'\n            );\n          }\n        );\n    } else if (event === 'docx') {\n      const url =\n        this.baseURL + '/all/policy/edit-policy?id=' + this.policyId;\n      this.iframeService.redirectIfInIframe(url, true);\n    } else if (event === 'word') {\n        this.createWordPolicy();\n    } else if (event === 'pdf') {\n      // If it is a pdf send to the workroom\n      const url =\n        this.baseURL + '/all/policy/workroom?id=' + this.policyId;\n      this.iframeService.redirectIfInIframe(url, true);\n    } else if (event === 'template') {\n      this.iframeService.redirectIfInIframe(this.templateUrl, true);\n    }\n    localStorage.setItem('_dId', this.policyId);\n  }\n  editPolicyEmit() {\n    this.selectedDocumentType = '';\n    localStorage.setItem(\n      'lastFileNameAndType',\n      JSON.stringify({\n        type: this.selectedDocumentType,\n        name: this.filename,\n        policyId: this.policyId,\n      })\n    );\n    this.editPolicy.emit();\n  }\n\n  openTemplateList() {\n    this.openTemplate.emit();\n  }\n}\n","<div class=\"document-section\" [class.grayscale]=\"isTemplateOpened\">\n  <div class=\"document-section-inner\">\n    <div class=\"message-box\">\n      <svg\n        version=\"1.1\"\n        id=\"Capa_1\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 480.8 480.8\"\n        style=\"enable-background: new 0 0 480.8 480.8\"\n        xml:space=\"preserve\"\n      >\n        <path\n          style=\"fill: #ffd517\"\n          d=\"M317.112,314.4c-22.4,22.4-19.6,67.6-19.6,67.6h-113.6c0,0,2.4-45.2-19.6-67.6\n                                        c-24.4-21.6-40-52.8-40-87.6c0-64,52-116,116-116s116,52,116,116C356.312,261.6,341.112,292.8,317.112,314.4L317.112,314.4z\"\n        />\n        <g>\n          <path\n            style=\"fill: #e5e5e5\"\n            d=\"M300.712,417.6c0,6-4.8,10.8-10.8,10.8h-98.8c-6,0-10.8-4.8-10.8-10.8l0,0c0-6,4.8-10.8,10.8-10.8\n                                            h98.4C295.512,406.8,300.712,411.6,300.712,417.6L300.712,417.6z\"\n          />\n          <path\n            style=\"fill: #e5e5e5\"\n            d=\"M285.912,462.4c0,6-4.8,10.8-10.8,10.8h-69.2c-6,0-10.8-4.8-10.8-10.8l0,0c0-6,4.8-10.8,10.8-10.8\n                                            h69.2C281.112,451.6,285.912,456.4,285.912,462.4L285.912,462.4z\"\n          />\n        </g>\n        <g>\n          <path\n            style=\"fill: #210b20\"\n            d=\"M323.112,318.4c26-23.6,40.8-56.8,40.8-91.6c0-68-55.6-123.6-123.6-123.6s-123.6,55.6-123.6,123.6\n                                            c0,35.6,15.6,69.6,42,92.8c19.6,19.6,17.6,61.2,17.6,61.6c0,2,0.8,4,2,5.6c1.6,1.6,3.6,2.4,5.6,2.4h113.2c2,0,4-0.8,5.6-2.4\n                                            s2-3.6,2-5.6c0-0.4-2-42,17.6-61.6C322.712,319.2,323.112,318.8,323.112,318.4z M311.912,308.4c-0.8,0.4-1.2,1.2-1.6,2\n                                            c-17.6,18.8-20.4,49.6-20.8,64h-98c-0.4-14.8-3.6-46.8-22.4-65.6c-23.6-20.8-37.2-50.4-37.2-81.6c0-60,48.8-108.4,108.4-108.4\n                                            c60,0,108.4,48.8,108.4,108.4C348.712,258,335.512,288,311.912,308.4z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M240.312,135.2c-4,0-7.6,3.2-7.6,7.6c0,4,3.2,7.6,7.6,7.6c44.8,0,81.2,36.4,81.2,81.2\n                                            c0,4,3.2,7.6,7.6,7.6c4,0,7.6-3.2,7.6-7.6C336.712,178.4,293.512,135.2,240.312,135.2z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M308.312,417.6c0-10.4-8.4-18.4-18.4-18.4h-98.8c-10.4,0-18.4,8.4-18.4,18.4\n                                            c0,10.4,8.4,18.4,18.4,18.4h98.4C299.912,436,308.312,428,308.312,417.6z M289.512,420.8h-98.4c-2,0-3.2-1.6-3.2-3.2\n                                            c0-2,1.6-3.2,3.2-3.2h98.4c2,0,3.2,1.6,3.2,3.2C293.112,419.6,291.512,420.8,289.512,420.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M275.112,444h-69.2c-10.4,0-18.4,8.4-18.4,18.4c0,10.4,8.4,18.4,18.4,18.4h69.2\n                                            c10.4,0,18.4-8.4,18.4-18.4C293.512,452.4,285.112,444,275.112,444z M275.112,465.6h-69.2c-2,0-3.2-1.6-3.2-3.2\n                                            c0-2,1.6-3.2,3.2-3.2h69.2c2,0,3.2,1.6,3.2,3.2C278.312,464.4,277.112,465.6,275.112,465.6z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M247.912,58.8V7.6c0-4-3.2-7.6-7.6-7.6c-4,0-7.6,3.2-7.6,7.6v51.6c0,4,3.2,7.6,7.6,7.6\n                                            C244.712,66.4,247.912,63.2,247.912,58.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M366.312,38c-3.6-2.4-8-1.2-10.4,2l-28.4,42.8c-2.4,3.6-1.2,8,2,10.4c1.2,0.8,2.8,1.2,4,1.2\n                                            c2.4,0,4.8-1.2,6.4-3.2l28.4-42.8C370.712,45.2,369.512,40.4,366.312,38z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M149.912,92.8c1.2,0,2.8-0.4,4-1.2c3.6-2.4,4.4-6.8,2.4-10.4l-27.6-43.2c-2.4-3.6-6.8-4.4-10.4-2.4\n                                            c-3.6,2.4-4.4,6.8-2.4,10.4l27.6,43.2C145.112,91.6,147.512,92.8,149.912,92.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M43.912,128.8l45.2,24.4c1.2,0.8,2.4,0.8,3.6,0.8c2.8,0,5.2-1.6,6.8-4c2-3.6,0.8-8.4-3.2-10.4\n                                            l-45.2-24.4c-3.6-2-8.4-0.8-10.4,3.2C39.112,122.4,40.312,126.8,43.912,128.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M387.912,154.4c1.2,0,2.4-0.4,3.6-0.8l45.2-24.4c3.6-2,5.2-6.4,3.2-10.4c-2-3.6-6.4-5.2-10.4-3.2\n                                            l-45.2,24.4c-3.6,2-5.2,6.4-3.2,10.4C382.312,152.8,385.112,154.4,387.912,154.4z\"\n          />\n        </g>\n      </svg>\n      <p>\n        There are multiple ways to create a policy on VComply. You can either\n        draft it from scratch using VComply's online editor or upload an\n        existing DOCX or PDF file.\n      </p>\n    </div>\n    <label\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType == 'draft'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('draft')\"\n        [checked]=\"selectedDocumentType === 'draft'\"\n      />\n      <svg id=\"Draft\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20402\" data-name=\"Path 20402\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#565a6f\"/>\n        <path id=\"Path_20403\" data-name=\"Path 20403\" d=\"M21.884,8.51,10.549,10.384,12.426,21.06l4.38-.61a.333.333,0,0,1,.326.435c-.051.219-.338.235-.514.267-1.474.266-3.009.388-4.491.631-.416-.032-.321-.718-.441-1l-3-.365c-.213-.12-.2-.273-.2-.492.019-.622.092-1.251.125-1.872.16-3,.316-6,.5-8.993A9.457,9.457,0,0,1,9.152,8.1a.369.369,0,0,1,.265-.3l8.519.681L22.2,7.8c.225.068.246.19.3.393.553,2.288.758,4.775,1.285,7.083.143.531-.507.731-.642.2ZM17.211,21.932a.563.563,0,0,0-.072.24,8.549,8.549,0,0,0,0,1.187c.019.217.088.393.328.421a9.138,9.138,0,0,0,1.448-.021.53.53,0,0,0,.122-.065l3.756-3.771L21,18.13Zm5.329-5.35c-.365.286-.7.757-1.061,1.062L23.3,19.437c.3-.35.777-.687,1.05-1.044.15-.2.174-.312.017-.516a13.851,13.851,0,0,0-1.327-1.327.393.393,0,0,0-.23-.1.476.476,0,0,0-.271.13\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\"><strong>Create</strong> a Policy</div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n\n    \n    <label\n      *ngIf=\"ff_policy_ms_word_integration\"\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType == 'word'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('word')\"\n        [checked]=\"selectedDocumentType === 'word'\"\n      />\n      <svg id=\"Word-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20404\" data-name=\"Path 20404\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#1e5dd3\"/>\n        <path id=\"Path_20405\" data-name=\"Path 20405\" d=\"M10.419,9.718l1.889,9.121L12.44,20l.132-.885,2.152-9.4,2.626.018,2.187,9.106.174,1.132a13.4,13.4,0,0,1,.174-1.352c.5-2.954,1.188-5.88,1.7-8.832l.04-.07H24L21.085,22.281l-2.818-.026L15.931,12.22l-.16,1.077-2.015,8.986-2.829-.028L8,9.718Z\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">{{createWordPolicyText}}</div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n\n\n\n    <label\n      class=\"document-box\"\n      *ngIf=\"showDocxBlock\"\n      [class.active]=\"selectedDocumentType == 'docx' && !docxError?.visible\"\n      [class.error]=\"docxError?.visible\"\n    >\n      <input\n        type=\"file\"\n        accept=\".docx\"\n        id=\"DOCfile\"\n        (change)=\"handleFileInput($event.target.files)\"\n        onclick=\"event.stopPropagation();\"\n        #docxUploadButton\n      />\n      <svg id=\"Word-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20404\" data-name=\"Path 20404\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#1e5dd3\"/>\n        <path id=\"Path_20405\" data-name=\"Path 20405\" d=\"M10.419,9.718l1.889,9.121L12.44,20l.132-.885,2.152-9.4,2.626.018,2.187,9.106.174,1.132a13.4,13.4,0,0,1,.174-1.352c.5-2.954,1.188-5.88,1.7-8.832l.04-.07H24L21.085,22.281l-2.818-.026L15.931,12.22l-.16,1.077-2.015,8.986-2.829-.028L8,9.718Z\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">\n          <ng-container *ngIf=\"!(selectedDocumentType == 'docx' && filename)\"\n            >Upload a <strong>DOCX</strong></ng-container\n          >\n          <ng-container *ngIf=\"selectedDocumentType == 'docx' && filename\">{{\n            filename\n          }}</ng-container>\n        </div>\n        <div class=\"error-msg-text\" *ngIf=\"docxError?.visible\">\n          {{ docxError?.message }}\n        </div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea97;</i>\n        <div class=\"check-circle\" *ngIf=\"!docxError?.visible\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n        <i class=\"icons error-icon\" *ngIf=\"docxError?.visible\">&#xe914;</i>\n      </div>\n      <div\n        class=\"line-progress\"\n        *ngIf=\"selectedDocumentType == 'docx' && isUploading\"\n      >\n        <div class=\"line-progress-bar\"></div>\n      </div>\n    </label>\n    <label\n      class=\"document-box\"\n      *ngIf=\"showPdfBlock\"\n      [class.active]=\"selectedDocumentType == 'pdf'\"\n    >\n      <input\n        type=\"file\"\n        accept=\".pdf\"\n        id=\"PDFfile\"\n        (change)=\"handleFileInput($event.target.files)\"\n        onclick=\"event.stopPropagation();\"\n        #pdfUploadButton\n      />\n      <svg id=\"PDF-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20408\" data-name=\"Path 20408\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#a82a1d\"/>\n        <path id=\"Path_20409\" data-name=\"Path 20409\" d=\"M16.125,13.778A1.39,1.39,0,0,0,16.285,15a16.106,16.106,0,0,0,2.106,2.554c.312-.045.6-.047,1.2-.092a6.964,6.964,0,0,1,3.616.239,1.31,1.31,0,0,1,.784,1.361,1.176,1.176,0,0,1-1.075.981c-2.224.336-3.305-.9-4.579-1.746a2.094,2.094,0,0,0-.812.021,25.782,25.782,0,0,0-3.412.916c-.253.089-.338.3-.533.609a11.062,11.062,0,0,1-2.82,3.427,2.145,2.145,0,0,1-1.861.445c-1-.222-1.178-1.182-.5-1.942A9.452,9.452,0,0,1,10,20.462a14.714,14.714,0,0,1,2.418-1.109c.491-.461.556-.686.966-1.764.431-1.136.922-2.25,1.324-3.4a1.679,1.679,0,0,0-.035-1.062,7.7,7.7,0,0,1-.638-3.476,1.4,1.4,0,0,1,.959-1.393,1.279,1.279,0,0,1,1.464.8c.2.479.552,1.75-.331,4.728m-.377,1.377-1.418,3.422,3.353-.883-1.935-2.539m3.222,2.882A4.5,4.5,0,0,0,21.92,19.37c.377,0,.714-.131.733-.6.051-1.251-2.656-.864-3.682-.73m-6.96,2.037a9.788,9.788,0,0,0-2.975,1.8c-.218.171-.446.718-.282.984s.81.067,1-.12a9.29,9.29,0,0,0,2.253-2.664m3.246-7.243c-.045-.878.461-2.172.437-3.224-.008-.355-.051-.747-.5-.772-.364-.02-.534.476-.569.762a5.8,5.8,0,0,0,.636,3.234\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">\n          <ng-container *ngIf=\"!(selectedDocumentType == 'pdf' && filename)\"\n            >Upload a <strong>PDF</strong></ng-container\n          >\n          <ng-container *ngIf=\"selectedDocumentType == 'pdf' && filename\">{{\n            filename\n          }}</ng-container>\n        </div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea97;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n      <div\n        class=\"line-progress\"\n        *ngIf=\"selectedDocumentType == 'pdf' && isUploading\"\n      >\n        <div class=\"line-progress-bar\"></div>\n      </div>\n    </label>\n    <!-- Select a template -->\n    <label\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType === 'template'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('template')\"\n        [checked]=\"selectedDocumentType === 'template'\"\n      />\n      <svg id=\"TMP-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20406\" data-name=\"Path 20406\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#34aa44\"/>\n        <path id=\"Path_20410\" data-name=\"Path 20410\" d=\"M16,1.778V3.555H0V1.778A1.783,1.783,0,0,1,1.778,0H14.223A1.783,1.783,0,0,1,16,1.778M0,4.444H16v8.889a1.778,1.778,0,0,1-1.777,1.778H1.778A1.778,1.778,0,0,1,0,13.333ZM6.99,9.928A.891.891,0,0,0,6.1,9.039H3.642a.891.891,0,0,0-.888.889v2.456a.891.891,0,0,0,.888.889H6.1a.891.891,0,0,0,.888-.889Zm6.306,0a.892.892,0,0,0-.889-.889H9.948a.891.891,0,0,0-.888.889v2.456a.891.891,0,0,0,.888.889h2.459a.892.892,0,0,0,.889-.889ZM2.667,7.111A.889.889,0,0,0,3.556,8h8.889a.889.889,0,0,0,0-1.778H3.556a.889.889,0,0,0-.889.889\" transform=\"translate(8 7.999)\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">Draft Using a <strong>Template</strong></div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n    <!-- End Select a template -->\n    <app-loader-inline *ngIf=\"isLoader\"></app-loader-inline>\n  </div>\n</div>\n<div class=\"bottom-button\" [class.grayscale]=\"isTemplateOpened\">\n  <button\n    type=\"button\"\n    (click)=\"editPolicyEmit()\"\n    class=\"back\"\n    [class.disabled]=\"isTemplateOpened\"\n  >\n    <i class=\"icons\">&#xe91d;</i> Back\n  </button>\n  <button\n    type=\"button\"\n    (click)=\"editor(selectedDocumentType)\"\n    class=\"next\"\n    [class.disabled]=\"!selectedDocumentType || isTemplateOpened || isLoader\"\n  >\n    Next <i class=\"icons\">&#xe91e;</i>\n  </button>\n</div>\n"]}
|
|
262
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-section.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/document-section/document-section.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/document-section/document-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { PlatformLocation } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { SnackBarService } from '../../ui-kit/snack-bar/snack-bar.service';\nimport { PolicyService } from '../../workflow-services/policy.service';\nimport { PolicyAPIService } from '../../workflow-services/policy-api.service';\nimport { IframeService } from '../../services/iframe.service';\nimport { WORD_CONSTANTS, WORD_URL_CONSTANTS } from '../../workflow-policy/ms-word.constants';\n\n@Component({\n  selector: 'lib-document-section',\n  templateUrl: './document-section.component.html',\n  styleUrls: ['./document-section.component.less'],\n})\nexport class DocumentSectionComponent implements OnInit, OnChanges {\n  private fileToUpload: any;\n  filename = '';\n  fileType = '';\n  pdf = false;\n  draft = false;\n  doc = false;\n  isUploading = false;\n  isLoader = false;\n  ff_policy_ms_word_integration: boolean = false;\n  createWordPolicyText = WORD_CONSTANTS.MS_WORD_OPTION;\n\n  @Input() selectedDocumentType = '';\n  @Input() feature: any;\n  @Input() templateView = false;\n  @Input() policyId: any = '';\n  @Input() policyName: any = '';\n  @Input() organization_id: any = '';\n  @Input() member_obj_id: any;\n  @Input() userInfo: any;\n  @Input() templateUrl: string = '';\n  @Input() isTemplateOpened: boolean = false;\n  @Output() disconnectRefresh = new EventEmitter();\n  @Output() editPolicy = new EventEmitter();\n  @Output() openTemplate = new EventEmitter();\n\n  baseURL = '';\n  docxError = {\n    visible: false,\n    message: '',\n  };\n\n  constructor(\n    private snackBar: SnackBarService,\n    private policyService: PolicyService,\n    private policyAPIService: PolicyAPIService,\n    private router: Router,\n    private route: ActivatedRoute,\n    platformLocation: PlatformLocation,\n    private iframeService: IframeService\n  ) {\n    this.baseURL = location?.origin;\n    if (this.baseURL == 'http://localhost:4200') {\n      this.baseURL = 'https://dev.v-comply.com';\n    }\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes?.templateView?.currentValue === false) {\n      this.selectedDocumentType = '';\n    }\n  }\n\n  ngOnInit(): void {\n    this.initialiseFeatureFlags();\n    const data = JSON.parse(\n      localStorage.getItem('lastFileNameAndType') ?? '\"{}\"'\n    );\n    if (\n      data.name !== null &&\n      data.name !== undefined &&\n      data.type !== null &&\n      data.type !== undefined &&\n      data.policyId == this.policyId\n    ) {\n      this.selectedDocumentType = data.type;\n      this.filename = data.name;\n      localStorage.removeItem('lastFileNameAndType');\n    }\n  }\n\n  initialiseFeatureFlags() {\n    this.ff_policy_ms_word_integration =  this.feature.isFeatureEnabled('ff_policy_ms_word_integration');\n  }\n\nredirectUserToWordPolicy() {\n  window.open(WORD_URL_CONSTANTS.new_word_policy_url, '_blank');\n  window.location.href =  this.baseURL + WORD_URL_CONSTANTS.workroom_url + this.policyId;\n}\n\n  createWordPolicy() {\n    this.isLoader = true;\n    this.policyAPIService.createWordPolicy(this.policyId).subscribe((res) => {\n      if(res){\n        this.redirectUserToWordPolicy();\n      }       \n      this.isLoader = false;\n    },\n    (err) => {\n      this.isLoader = false;\n      this.snackBar.show(\n        WORD_CONSTANTS.createWordPolicy_snackbar_message,\n        'alert'\n      );\n    }\n  );\n  }\n\n  handleFileInput(files: FileList): void {\n    this.fileToUpload = files[0];\n    this.filename = this.fileToUpload.name;\n    this.fileType = this.fileToUpload.name\n      .slice(\n        this.fileToUpload.name.lastIndexOf('.') + 1,\n        this.fileToUpload.name.length\n      )\n      .toLowerCase();\n    if (this.fileType === 'pdf') {\n      this.uploadFile({ file: this.fileToUpload, fileType: this.fileType });\n    } else if (this.fileType === 'docx') {\n      this.uploadFile({ file: this.fileToUpload, fileType: this.fileType });\n    } else {\n      this.snackBar.show('Please upload a valid file', 'alert');\n    }\n  }\n  showPdfBlock = true;\n  showDocxBlock = true;\n\n  uploadFile(event: any) {\n    this.isUploading = true;\n    if (event.fileType === 'docx') {\n      this.changeDocType('docx');\n      this.uploadDocxfile(event);\n    } else if (event.fileType === 'pdf') {\n      this.changeDocType('pdf');\n      this.showPdfBlock = false;\n      setTimeout(() => {\n        this.showPdfBlock = true;\n      }, 10);\n      const uploadData = new FormData();\n      uploadData.append('file', event.file);\n      const path = 'o/' + this.organization_id + '/policy/';\n      this.policyService.uploadFile(uploadData, this.policyId, path).subscribe(\n        (res) => {\n          if (res) {\n            this.isUploading = false;\n          }\n        },\n        (err) => {\n          this.isUploading = false;\n          this.snackBar.show(\n            \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n            'alert'\n          );\n        }\n      );\n    }\n  }\n\n  uploadDocxfile(event: any) {\n    this.resetDocsError();\n    this.showDocxBlock = false;\n    setTimeout(() => {\n      this.showDocxBlock = true;\n    }, 10);\n    const uploadData = new FormData();\n    uploadData.append('file', event.file);\n    const path = 'o/' + this.organization_id + '/policy/';\n    this.policyService\n      .uploadDocxFile(uploadData, this.policyId, path)\n      .subscribe(\n        (res: any) => {\n          if (res) {\n            this.isUploading = false;\n            if (res?.message?.includes('done')) {\n              this.resetDocsError();\n            } else {\n              if (res.message?.includes('RangeError')) {\n                this.docxError = {\n                  visible: true,\n                  message: 'The file size is too large and cannot be uploaded.',\n                };\n              } else {\n                this.docxError = {\n                  visible: true,\n                  message: 'Oops! An error occurred while uploading this file.',\n                };\n              }\n            }\n          }\n        },\n        (err) => {\n          this.isUploading = false;\n\n          this.snackBar.show(\n            \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n            'alert'\n          );\n        }\n      );\n  }\n\n  resetDocsError() {\n    this.docxError = {\n      visible: false,\n      message: '',\n    };\n  }\n\n  changeDocType(event: any) {\n    this.resetDocsError();\n    this.selectedDocumentType = event;\n    if (event === 'template') {\n      this.openTemplateList();\n    }\n  }\n\n  editor(event: string) {\n    this.disconnectRefresh.emit(false);\n\n    if (event === 'draft') {\n      // If it is a draft go directly to the editor\n      const uname = this.userInfo ? this.userInfo.name : '';\n      const uid = this.member_obj_id;\n      const name = this.policyName.trim();\n      const id = this.policyId;\n      this.isLoader = true;\n      this.policyService\n        .savePolicyDetails(uname, uid, id, name, '', 0)\n        .subscribe(\n          (res) => {\n            if (res) {\n              this.isLoader = false;\n              const url =\n                this.baseURL + '/all/policy/edit-policy?id=' + this.policyId;\n              this.iframeService.redirectIfInIframe(url, true);\n            }\n          },\n          (err) => {\n            this.isLoader = false;\n            this.snackBar.show(\n              \"Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?\",\n              'alert'\n            );\n          }\n        );\n    } else if (event === 'docx') {\n      const url =\n        this.baseURL + '/all/policy/edit-policy?id=' + this.policyId;\n      this.iframeService.redirectIfInIframe(url, true);\n    } else if (event === 'word') {\n        this.createWordPolicy();\n    } else if (event === 'pdf') {\n      // If it is a pdf send to the workroom\n      const url =\n        this.baseURL + '/all/policy/workroom?id=' + this.policyId;\n      this.iframeService.redirectIfInIframe(url, true);\n    } else if (event === 'template') {\n      this.iframeService.redirectIfInIframe(this.templateUrl, true);\n    }\n    localStorage.setItem('_dId', this.policyId);\n  }\n  editPolicyEmit() {\n    this.selectedDocumentType = '';\n    localStorage.setItem(\n      'lastFileNameAndType',\n      JSON.stringify({\n        type: this.selectedDocumentType,\n        name: this.filename,\n        policyId: this.policyId,\n      })\n    );\n    this.editPolicy.emit();\n  }\n\n  openTemplateList() {\n    this.openTemplate.emit();\n  }\n}\n","<div class=\"document-section\" [class.grayscale]=\"isTemplateOpened\">\n  <div class=\"document-section-inner\">\n    <div class=\"message-box\">\n      <svg\n        version=\"1.1\"\n        id=\"Capa_1\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 480.8 480.8\"\n        style=\"enable-background: new 0 0 480.8 480.8\"\n        xml:space=\"preserve\"\n      >\n        <path\n          style=\"fill: #ffd517\"\n          d=\"M317.112,314.4c-22.4,22.4-19.6,67.6-19.6,67.6h-113.6c0,0,2.4-45.2-19.6-67.6\n                                        c-24.4-21.6-40-52.8-40-87.6c0-64,52-116,116-116s116,52,116,116C356.312,261.6,341.112,292.8,317.112,314.4L317.112,314.4z\"\n        />\n        <g>\n          <path\n            style=\"fill: #e5e5e5\"\n            d=\"M300.712,417.6c0,6-4.8,10.8-10.8,10.8h-98.8c-6,0-10.8-4.8-10.8-10.8l0,0c0-6,4.8-10.8,10.8-10.8\n                                            h98.4C295.512,406.8,300.712,411.6,300.712,417.6L300.712,417.6z\"\n          />\n          <path\n            style=\"fill: #e5e5e5\"\n            d=\"M285.912,462.4c0,6-4.8,10.8-10.8,10.8h-69.2c-6,0-10.8-4.8-10.8-10.8l0,0c0-6,4.8-10.8,10.8-10.8\n                                            h69.2C281.112,451.6,285.912,456.4,285.912,462.4L285.912,462.4z\"\n          />\n        </g>\n        <g>\n          <path\n            style=\"fill: #210b20\"\n            d=\"M323.112,318.4c26-23.6,40.8-56.8,40.8-91.6c0-68-55.6-123.6-123.6-123.6s-123.6,55.6-123.6,123.6\n                                            c0,35.6,15.6,69.6,42,92.8c19.6,19.6,17.6,61.2,17.6,61.6c0,2,0.8,4,2,5.6c1.6,1.6,3.6,2.4,5.6,2.4h113.2c2,0,4-0.8,5.6-2.4\n                                            s2-3.6,2-5.6c0-0.4-2-42,17.6-61.6C322.712,319.2,323.112,318.8,323.112,318.4z M311.912,308.4c-0.8,0.4-1.2,1.2-1.6,2\n                                            c-17.6,18.8-20.4,49.6-20.8,64h-98c-0.4-14.8-3.6-46.8-22.4-65.6c-23.6-20.8-37.2-50.4-37.2-81.6c0-60,48.8-108.4,108.4-108.4\n                                            c60,0,108.4,48.8,108.4,108.4C348.712,258,335.512,288,311.912,308.4z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M240.312,135.2c-4,0-7.6,3.2-7.6,7.6c0,4,3.2,7.6,7.6,7.6c44.8,0,81.2,36.4,81.2,81.2\n                                            c0,4,3.2,7.6,7.6,7.6c4,0,7.6-3.2,7.6-7.6C336.712,178.4,293.512,135.2,240.312,135.2z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M308.312,417.6c0-10.4-8.4-18.4-18.4-18.4h-98.8c-10.4,0-18.4,8.4-18.4,18.4\n                                            c0,10.4,8.4,18.4,18.4,18.4h98.4C299.912,436,308.312,428,308.312,417.6z M289.512,420.8h-98.4c-2,0-3.2-1.6-3.2-3.2\n                                            c0-2,1.6-3.2,3.2-3.2h98.4c2,0,3.2,1.6,3.2,3.2C293.112,419.6,291.512,420.8,289.512,420.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M275.112,444h-69.2c-10.4,0-18.4,8.4-18.4,18.4c0,10.4,8.4,18.4,18.4,18.4h69.2\n                                            c10.4,0,18.4-8.4,18.4-18.4C293.512,452.4,285.112,444,275.112,444z M275.112,465.6h-69.2c-2,0-3.2-1.6-3.2-3.2\n                                            c0-2,1.6-3.2,3.2-3.2h69.2c2,0,3.2,1.6,3.2,3.2C278.312,464.4,277.112,465.6,275.112,465.6z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M247.912,58.8V7.6c0-4-3.2-7.6-7.6-7.6c-4,0-7.6,3.2-7.6,7.6v51.6c0,4,3.2,7.6,7.6,7.6\n                                            C244.712,66.4,247.912,63.2,247.912,58.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M366.312,38c-3.6-2.4-8-1.2-10.4,2l-28.4,42.8c-2.4,3.6-1.2,8,2,10.4c1.2,0.8,2.8,1.2,4,1.2\n                                            c2.4,0,4.8-1.2,6.4-3.2l28.4-42.8C370.712,45.2,369.512,40.4,366.312,38z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M149.912,92.8c1.2,0,2.8-0.4,4-1.2c3.6-2.4,4.4-6.8,2.4-10.4l-27.6-43.2c-2.4-3.6-6.8-4.4-10.4-2.4\n                                            c-3.6,2.4-4.4,6.8-2.4,10.4l27.6,43.2C145.112,91.6,147.512,92.8,149.912,92.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M43.912,128.8l45.2,24.4c1.2,0.8,2.4,0.8,3.6,0.8c2.8,0,5.2-1.6,6.8-4c2-3.6,0.8-8.4-3.2-10.4\n                                            l-45.2-24.4c-3.6-2-8.4-0.8-10.4,3.2C39.112,122.4,40.312,126.8,43.912,128.8z\"\n          />\n          <path\n            style=\"fill: #210b20\"\n            d=\"M387.912,154.4c1.2,0,2.4-0.4,3.6-0.8l45.2-24.4c3.6-2,5.2-6.4,3.2-10.4c-2-3.6-6.4-5.2-10.4-3.2\n                                            l-45.2,24.4c-3.6,2-5.2,6.4-3.2,10.4C382.312,152.8,385.112,154.4,387.912,154.4z\"\n          />\n        </g>\n      </svg>\n      <p>\n        There are multiple ways to create a policy on VComply. You can either\n        draft it from scratch using VComply's online editor or upload an\n        existing DOCX or PDF file.\n      </p>\n    </div>\n    <label\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType == 'draft'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('draft')\"\n        [checked]=\"selectedDocumentType === 'draft'\"\n      />\n      <svg id=\"Draft\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20402\" data-name=\"Path 20402\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#565a6f\"/>\n        <path id=\"Path_20403\" data-name=\"Path 20403\" d=\"M21.884,8.51,10.549,10.384,12.426,21.06l4.38-.61a.333.333,0,0,1,.326.435c-.051.219-.338.235-.514.267-1.474.266-3.009.388-4.491.631-.416-.032-.321-.718-.441-1l-3-.365c-.213-.12-.2-.273-.2-.492.019-.622.092-1.251.125-1.872.16-3,.316-6,.5-8.993A9.457,9.457,0,0,1,9.152,8.1a.369.369,0,0,1,.265-.3l8.519.681L22.2,7.8c.225.068.246.19.3.393.553,2.288.758,4.775,1.285,7.083.143.531-.507.731-.642.2ZM17.211,21.932a.563.563,0,0,0-.072.24,8.549,8.549,0,0,0,0,1.187c.019.217.088.393.328.421a9.138,9.138,0,0,0,1.448-.021.53.53,0,0,0,.122-.065l3.756-3.771L21,18.13Zm5.329-5.35c-.365.286-.7.757-1.061,1.062L23.3,19.437c.3-.35.777-.687,1.05-1.044.15-.2.174-.312.017-.516a13.851,13.851,0,0,0-1.327-1.327.393.393,0,0,0-.23-.1.476.476,0,0,0-.271.13\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\"><strong>Create</strong> a Policy</div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n\n    \n    <label\n      *ngIf=\"ff_policy_ms_word_integration\"\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType == 'word'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('word')\"\n        [checked]=\"selectedDocumentType === 'word'\"\n      />\n      <svg id=\"Word-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20404\" data-name=\"Path 20404\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#1e5dd3\"/>\n        <path id=\"Path_20405\" data-name=\"Path 20405\" d=\"M10.419,9.718l1.889,9.121L12.44,20l.132-.885,2.152-9.4,2.626.018,2.187,9.106.174,1.132a13.4,13.4,0,0,1,.174-1.352c.5-2.954,1.188-5.88,1.7-8.832l.04-.07H24L21.085,22.281l-2.818-.026L15.931,12.22l-.16,1.077-2.015,8.986-2.829-.028L8,9.718Z\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">{{createWordPolicyText}}</div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n\n\n\n    <label\n      class=\"document-box\"\n      *ngIf=\"showDocxBlock\"\n      [class.active]=\"selectedDocumentType == 'docx' && !docxError?.visible\"\n      [class.error]=\"docxError?.visible\"\n    >\n      <input\n        type=\"file\"\n        accept=\".docx\"\n        id=\"DOCfile\"\n        (change)=\"handleFileInput($event.target.files)\"\n        onclick=\"event.stopPropagation();\"\n        #docxUploadButton\n      />\n      <svg id=\"Word-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20404\" data-name=\"Path 20404\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#1e5dd3\"/>\n        <path id=\"Path_20405\" data-name=\"Path 20405\" d=\"M10.419,9.718l1.889,9.121L12.44,20l.132-.885,2.152-9.4,2.626.018,2.187,9.106.174,1.132a13.4,13.4,0,0,1,.174-1.352c.5-2.954,1.188-5.88,1.7-8.832l.04-.07H24L21.085,22.281l-2.818-.026L15.931,12.22l-.16,1.077-2.015,8.986-2.829-.028L8,9.718Z\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">\n          <ng-container *ngIf=\"!(selectedDocumentType == 'docx' && filename)\"\n            >Upload a <strong>DOCX</strong></ng-container\n          >\n          <ng-container *ngIf=\"selectedDocumentType == 'docx' && filename\">{{\n            filename\n          }}</ng-container>\n        </div>\n        <div class=\"error-msg-text\" *ngIf=\"docxError?.visible\">\n          {{ docxError?.message }}\n        </div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea97;</i>\n        <div class=\"check-circle\" *ngIf=\"!docxError?.visible\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n        <i class=\"icons error-icon\" *ngIf=\"docxError?.visible\">&#xe914;</i>\n      </div>\n      <div\n        class=\"line-progress\"\n        *ngIf=\"selectedDocumentType == 'docx' && isUploading\"\n      >\n        <div class=\"line-progress-bar\"></div>\n      </div>\n    </label>\n    <label\n      class=\"document-box\"\n      *ngIf=\"showPdfBlock\"\n      [class.active]=\"selectedDocumentType == 'pdf'\"\n    >\n      <input\n        type=\"file\"\n        accept=\".pdf\"\n        id=\"PDFfile\"\n        (change)=\"handleFileInput($event.target.files)\"\n        onclick=\"event.stopPropagation();\"\n        #pdfUploadButton\n      />\n      <svg id=\"PDF-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20408\" data-name=\"Path 20408\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#a82a1d\"/>\n        <path id=\"Path_20409\" data-name=\"Path 20409\" d=\"M16.125,13.778A1.39,1.39,0,0,0,16.285,15a16.106,16.106,0,0,0,2.106,2.554c.312-.045.6-.047,1.2-.092a6.964,6.964,0,0,1,3.616.239,1.31,1.31,0,0,1,.784,1.361,1.176,1.176,0,0,1-1.075.981c-2.224.336-3.305-.9-4.579-1.746a2.094,2.094,0,0,0-.812.021,25.782,25.782,0,0,0-3.412.916c-.253.089-.338.3-.533.609a11.062,11.062,0,0,1-2.82,3.427,2.145,2.145,0,0,1-1.861.445c-1-.222-1.178-1.182-.5-1.942A9.452,9.452,0,0,1,10,20.462a14.714,14.714,0,0,1,2.418-1.109c.491-.461.556-.686.966-1.764.431-1.136.922-2.25,1.324-3.4a1.679,1.679,0,0,0-.035-1.062,7.7,7.7,0,0,1-.638-3.476,1.4,1.4,0,0,1,.959-1.393,1.279,1.279,0,0,1,1.464.8c.2.479.552,1.75-.331,4.728m-.377,1.377-1.418,3.422,3.353-.883-1.935-2.539m3.222,2.882A4.5,4.5,0,0,0,21.92,19.37c.377,0,.714-.131.733-.6.051-1.251-2.656-.864-3.682-.73m-6.96,2.037a9.788,9.788,0,0,0-2.975,1.8c-.218.171-.446.718-.282.984s.81.067,1-.12a9.29,9.29,0,0,0,2.253-2.664m3.246-7.243c-.045-.878.461-2.172.437-3.224-.008-.355-.051-.747-.5-.772-.364-.02-.534.476-.569.762a5.8,5.8,0,0,0,.636,3.234\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">\n          <ng-container *ngIf=\"!(selectedDocumentType == 'pdf' && filename)\"\n            >Upload a <strong>PDF</strong></ng-container\n          >\n          <ng-container *ngIf=\"selectedDocumentType == 'pdf' && filename\">{{\n            filename\n          }}</ng-container>\n        </div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea97;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n      <div\n        class=\"line-progress\"\n        *ngIf=\"selectedDocumentType == 'pdf' && isUploading\"\n      >\n        <div class=\"line-progress-bar\"></div>\n      </div>\n    </label>\n    <!-- Select a template -->\n    <label\n      class=\"document-box\"\n      [class.active]=\"selectedDocumentType === 'template'\"\n    >\n      <input\n        type=\"radio\"\n        name=\"selectedDocumentType\"\n        (change)=\"changeDocType('template')\"\n        [checked]=\"selectedDocumentType === 'template'\"\n      />\n      <svg id=\"TMP-Icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\">\n        <path id=\"Path_20406\" data-name=\"Path 20406\" d=\"M28,32H4a4,4,0,0,1-4-4V4A4,4,0,0,1,4,0H28a4,4,0,0,1,4,4V28a4,4,0,0,1-4,4\" fill=\"#34aa44\"/>\n        <path id=\"Path_20410\" data-name=\"Path 20410\" d=\"M16,1.778V3.555H0V1.778A1.783,1.783,0,0,1,1.778,0H14.223A1.783,1.783,0,0,1,16,1.778M0,4.444H16v8.889a1.778,1.778,0,0,1-1.777,1.778H1.778A1.778,1.778,0,0,1,0,13.333ZM6.99,9.928A.891.891,0,0,0,6.1,9.039H3.642a.891.891,0,0,0-.888.889v2.456a.891.891,0,0,0,.888.889H6.1a.891.891,0,0,0,.888-.889Zm6.306,0a.892.892,0,0,0-.889-.889H9.948a.891.891,0,0,0-.888.889v2.456a.891.891,0,0,0,.888.889h2.459a.892.892,0,0,0,.889-.889ZM2.667,7.111A.889.889,0,0,0,3.556,8h8.889a.889.889,0,0,0,0-1.778H3.556a.889.889,0,0,0-.889.889\" transform=\"translate(8 7.999)\" fill=\"#fff\"/>\n      </svg>\n      \n      <div class=\"label-right\">\n        <div class=\"value\">Draft Using a <strong>Template</strong></div>\n        <i class=\"icons document-box-icon vx-fs-16 vx-mr-2\">&#xea46;</i>\n        <div class=\"check-circle\">\n          <svg\n            class=\"checkIcon\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            viewBox=\"0 0 52 52\"\n          >\n            <circle\n              class=\"checkIcon__circle\"\n              cx=\"26\"\n              cy=\"26\"\n              r=\"25\"\n              fill=\"none\"\n            />\n            <path\n              class=\"checkIcon__check\"\n              fill=\"none\"\n              d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n            />\n          </svg>\n        </div>\n      </div>\n    </label>\n    <!-- End Select a template -->\n    <app-loader-inline *ngIf=\"isLoader\"></app-loader-inline>\n  </div>\n</div>\n<div class=\"bottom-button\" [class.grayscale]=\"isTemplateOpened\">\n  <button\n    type=\"button\"\n    (click)=\"editPolicyEmit()\"\n    class=\"back\"\n    [class.disabled]=\"isTemplateOpened\"\n  >\n    <i class=\"icons\">&#xe91d;</i> Back\n  </button>\n  <button\n    type=\"button\"\n    (click)=\"editor(selectedDocumentType)\"\n    class=\"next\"\n    [class.disabled]=\"!selectedDocumentType || isTemplateOpened || isLoader\"\n  >\n    Next <i class=\"icons\">&#xe91e;</i>\n  </button>\n</div>\n"]}
|
|
@@ -40,7 +40,9 @@ export class SelectTemplateListComponent {
|
|
|
40
40
|
this.isPreview = false;
|
|
41
41
|
this.selectedCategoryId = [];
|
|
42
42
|
this.onTemplateSelect = new EventEmitter();
|
|
43
|
-
|
|
43
|
+
if (config) {
|
|
44
|
+
this.env = config?.envConfig;
|
|
45
|
+
}
|
|
44
46
|
}
|
|
45
47
|
ngOnInit() {
|
|
46
48
|
this.setAnimation();
|
|
@@ -180,6 +182,7 @@ export class SelectTemplateListComponent {
|
|
|
180
182
|
this.isPreview = true;
|
|
181
183
|
this.previewTemplate = details;
|
|
182
184
|
this.fileUrl = `${this.env?.s3Url}${this.env?.s3Bucket}/${details?.s3DocxPath}`;
|
|
185
|
+
console.log(this.fileUrl, 'fileUrl');
|
|
183
186
|
}
|
|
184
187
|
onClosePreview() {
|
|
185
188
|
this.isPreview = false;
|
|
@@ -200,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
200
203
|
}], onTemplateSelect: [{
|
|
201
204
|
type: Output
|
|
202
205
|
}] } });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-template-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';\nimport { TemplateService } from '../services/template.service';\nimport { forkJoin } from 'rxjs';\nimport {\n  NO_DATA_FOUND_IMAGE,\n  NO_DATA_FOUND_MESSAGE,\n} from '../constants/template.constant';\nimport { PolicyService } from '../../../workflow-services/policy.service';\nimport { Configurations } from '../../../configurations';\n@Component({\n  selector: 'app-select-template-list',\n  templateUrl: './select-template-list.component.html',\n  styleUrls: ['./select-template-list.component.less'],\n})\nexport class SelectTemplateListComponent {\n  fileUrl: string = ''\n  env:any;\n  animation = false;\n  defaultTemplates: any[] = [];\n  customTemplates: any[] | null = null;\n  templateList: any[] = [];\n  currentTab = 'VCOMPLY';\n  loader: boolean = false;\n  categoryList: any[] = [];\n  defaultCategoryList: any[] = [];\n  userCreatedCategoryList: any[] = [];\n  sortStatus = -1;\n  searchCategory: string = '';\n  searchTemplate: string = '';\n  selectedCategory: any[] = [];\n  NO_DATA_FOUND_IMAGE = NO_DATA_FOUND_IMAGE;\n  NO_DATA_FOUND_MESSAGE = NO_DATA_FOUND_MESSAGE;\n  selectedTemplate: any[] = [];\n  isPreview = false;\n  previewTemplate: any;\n\n  @Input() selectedCategoryId: number[] = [];\n  @Input() feature: any;\n  @Output() onTemplateSelect = new EventEmitter<any>();\n\n  constructor(\n    private templateService: TemplateService,\n    private policyService: PolicyService,\n    @Optional() config?: Configurations\n  ) {\n    this.env = config?.envConfig\n  }\n\n  ngOnInit(): void {\n    this.setAnimation();\n    this.getTemplate();\n  }\n\n  setAnimation() {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n  }\n\n  switchTab(tab: string) {\n    this.currentTab = tab;\n    this.selectedCategory = [];\n    if (tab === 'VCOMPLY') {\n      this.templateList = [...this.defaultTemplates];\n      this.categoryList = this.defaultCategoryList;\n    } else {\n      if (this.customTemplates === null) {\n        this.getCustomTemplates();\n      } else {\n        this.templateList = [...this.customTemplates];\n        this.categoryList = this.userCreatedCategoryList;\n      }\n    }\n  }\n\n  getCustomTemplates() {\n    this.loader = true;\n    const payload = {\n      type: 'custom',\n      categoryId: this.selectedCategoryId.map(\n        (category: any) => category.item_id\n      ),\n    };\n    this.templateService.fetchTemplates(payload).subscribe((res: any) => {\n      this.customTemplates = res?.templates ?? [];\n      this.mapCustomTemplate();\n    });\n  }\n\n  mapCustomTemplate() {\n    this.policyService.getCategoriesList().subscribe((res: any) => {\n      this.userCreatedCategoryList = [...res];\n      this.userCreatedCategoryList = this.userCreatedCategoryList.map(\n        (res: any) => {\n          const parentItems = [...new Set(res?.parent_items ?? [])];\n          parentItems.unshift(res.item_name);\n          return {\n            ...res,\n            name: parentItems?.join(' < '),\n            parent_items: res?.parent_items.reverse(),\n          };\n        }\n      );\n      if (this.customTemplates) {\n        this.customTemplates = this.customTemplates.map((template: any) => {\n          return {\n            ...template,\n            categoryDetails: this.userCreatedCategoryList.filter(\n              (category: any) =>\n                template?.categoryId?.includes(category.item_id)\n            ),\n          };\n        });\n      }\n      this.templateList = [...new Set(this.customTemplates ?? [])];\n      const categoryIds = this.selectedCategoryId.map(\n        (category: any) => category.item_id\n      );\n      this.userCreatedCategoryList = this.userCreatedCategoryList.filter(\n        (category: any) => categoryIds?.includes(category.item_id)\n      );\n      this.loader = false;\n      this.categoryList = this.userCreatedCategoryList;\n    });\n  }\n\n  getTemplate() {\n    this.loader = true;\n    const payload = {\n      type: 'default',\n    };\n    forkJoin([\n      this.templateService.fetchTemplates(payload),\n      this.templateService.fetchDefaultCategories(),\n    ]).subscribe((res: any) => {\n      this.defaultTemplates = res[0]?.templates;\n      this.defaultCategoryList = res[1];\n      this.mapDefaultTemplate();\n      this.categoryList = [...new Set(this.defaultCategoryList)];\n\n      this.templateList = this.defaultTemplates;\n      this.loader = false;\n    });\n  }\n\n  mapDefaultTemplate() {\n    this.defaultTemplates = this.defaultTemplates.map((template: any) => {\n      const category = this.defaultCategoryList.filter((category: any) =>\n        template?.categoryId?.includes(category.item_id)\n      );\n      return {\n        ...template,\n        categoryDetails: category,\n      };\n    });\n  }\n\n  sortBy(key: string) {\n    this.sortStatus = this.sortStatus * -1;\n    this.templateList = this.templateService.sortByKey(\n      this.templateList,\n      key,\n      this.sortStatus\n    );\n  }\n\n  onSelectCategory(category: any, event: any) {\n    if (event.target.checked) {\n      this.selectedCategory.push(category?.item_id);\n    } else {\n      this.selectedCategory = this.selectedCategory.filter(\n        (id: any) => id !== category?.item_id\n      );\n    }\n    this.selectedCategory = [...new Set(this.selectedCategory)];\n  }\n\n  onApplyFilter(event: any) {\n    if (!event) {\n      this.selectedCategory = [];\n      return;\n    }\n    let selectedTemplate =\n      this.currentTab === 'VCOMPLY'\n        ? this.defaultTemplates\n        : this.customTemplates ?? [];\n    selectedTemplate = [...new Set(selectedTemplate)];\n    if (this.selectedCategory.length === 0) {\n      this.templateList = selectedTemplate;\n      return;\n    }\n    this.templateList = selectedTemplate.filter((template: any) => {\n      return template?.categoryId?.some((id: any) =>\n        this.selectedCategory.includes(id)\n      );\n    });\n  }\n\n  onSelectTemplate(template: any) {\n    this.selectedTemplate = [template];\n  }\n\n  save() {\n    this.onTemplateSelect.emit(this.selectedTemplate);\n  }\n\n  close() {\n    this.onTemplateSelect.emit([]);\n  }\n\n  deleteEvent() {\n    this.selectedTemplate = [];\n  }\n\n  onPreview(details: any) {\n    this.loader = false;\n    this.isPreview = true;\n    this.previewTemplate = details;\n    this.fileUrl = `${this.env?.s3Url}${this.env?.s3Bucket}/${details?.s3DocxPath}`;\n  }\n\n  onClosePreview() {\n    this.isPreview = false;\n    this.previewTemplate = null;\n  }\n}\n","<div\n  class=\"select-template-list\"\n  [class.animate]=\"animation\"\n  [class.withPreview]=\"isPreview\"\n>\n  <ng-container *ngIf=\"!isPreview\">\n    <div\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n    >\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Template</div>\n    </div>\n    <div class=\"select-template-list-body\">\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n\n      <div class=\"select-template-list-tab vx-d-flex vx-align-center vx-mb-2\">\n        <button\n          (click)=\"switchTab('VCOMPLY')\"\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n          [class.active]=\"currentTab === 'VCOMPLY'\"\n        >\n          VCOMPLY TEMPLATES\n        </button>\n        <button\n          (click)=\"switchTab('USER_CREATED')\"\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n          [class.active]=\"currentTab === 'USER_CREATED'\"\n        >\n          USER-CREATED TEMPLATES\n        </button>\n      </div>\n      <div class=\"search-block vx-mb-2\">\n        <i class=\"icons\">&#xe90b;</i>\n        <input type=\"text\" [(ngModel)]=\"searchTemplate\" placeholder=\"Search\" />\n      </div>\n      <div class=\"body-top vx-d-flex vx-align-center vx-justify-end vx-mb-2\">\n        <cs-multi-select\n          (searchText)=\"searchCategory = $event\"\n          [placeholder]=\"'Select Category'\"\n          [value]=\"selectedCategory\"\n          (applyFilter)=\"onApplyFilter($event)\"\n        >\n          <ng-container\n            *ngFor=\"\n              let eachCategory of categoryList\n                | SearchByKeys : ['name'] : searchCategory\n            \"\n          >\n            <cs-multi-select-option\n              [appTooltip]=\"eachCategory?.name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              [value]=\"eachCategory?.item_id\"\n              (change)=\"onSelectCategory(eachCategory, $event)\"\n              [tooltipMandatory]=\"true\"\n            >\n              {{ eachCategory?.name }}\n            </cs-multi-select-option>\n          </ng-container>\n        </cs-multi-select>\n      </div>\n      <div class=\"body-inner vx-mb-1\">\n        <ng-container *ngIf=\"!loader\">\n          <ng-container\n            *ngIf=\"\n              templateList\n                | SearchByKeys\n                  : ['name', 'categoryDetails']\n                  : searchTemplate as allTemplate\n            \"\n          >\n            <app-template-list-table\n              *ngIf=\"allTemplate.length\"\n              [templateList]=\"allTemplate\"\n              [loader]=\"loader\"\n              [categoryList]=\"categoryList\"\n              [selectedTemplate]=\"selectedTemplate[0]\"\n              [feature]=\"feature\"\n              (onSort)=\"sortBy($event)\"\n              (onSelectTemplate)=\"onSelectTemplate($event)\"\n              (onPreview)=\"onPreview($event)\"\n            ></app-template-list-table>\n            <app-no-data\n              *ngIf=\"!allTemplate?.length\"\n              [noDataImage]=\"NO_DATA_FOUND_IMAGE\"\n              [noDataText]=\"NO_DATA_FOUND_MESSAGE\"\n            ></app-no-data>\n          </ng-container>\n        </ng-container>\n      </div>\n\n      <app-floating-bar\n        (closeEvent)=\"save()\"\n        (closeList)=\"close()\"\n        [isDisabled]=\"selectedTemplate?.length === 0\"\n        [selectedData]=\"selectedTemplate\"\n        [displayElementKey]=\"'name'\"\n        [singularText]=\"'Template Selected'\"\n        (deleteEvent)=\"deleteEvent()\"\n      >\n      </app-floating-bar>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"isPreview\">\n    <div\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-pl-4 vx-pr-4\"\n    >\n      <button\n        (click)=\"onClosePreview()\"\n        class=\"previewBtn vx-fs-14 vx-fw-500 vx-label-txt vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n      >\n        <i class=\"icons vx-mr-1\">&#xe91d;</i>Preview\n      </button>\n      <div\n        class=\"template-name vx-fs-14 vx-ml-1\"\n        [appTooltip]=\"previewTemplate?.name\"\n        placement=\"bottom-left\"\n        delay=\"0\"\n        type=\"black\"\n        [tooltipMandatory]=\"false\"\n      >\n        {{ previewTemplate?.name }}\n      </div>\n    </div>\n    <div class=\"preview-template-body vx-d-flex vx-justify-center\">\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n\n      <div *ngIf=\"!loader\" class=\"preview-template-body-inner\">\n        <ngx-doc-viewer\n          [url]=\"fileUrl\"\n          viewer=\"office\"\n          style=\"width: 100%; height: 100%; margin: 0\"\n          disableContent=\"popout-hide\"\n        >\n        </ngx-doc-viewer>\n      </div>\n    </div>\n  </ng-container>\n</div>\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-template-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';\nimport { TemplateService } from '../services/template.service';\nimport { forkJoin } from 'rxjs';\nimport {\n  NO_DATA_FOUND_IMAGE,\n  NO_DATA_FOUND_MESSAGE,\n} from '../constants/template.constant';\nimport { PolicyService } from '../../../workflow-services/policy.service';\nimport { Configurations } from '../../../configurations';\n@Component({\n  selector: 'app-select-template-list',\n  templateUrl: './select-template-list.component.html',\n  styleUrls: ['./select-template-list.component.less'],\n})\nexport class SelectTemplateListComponent {\n  fileUrl: string = ''\n  env:any;\n  animation = false;\n  defaultTemplates: any[] = [];\n  customTemplates: any[] | null = null;\n  templateList: any[] = [];\n  currentTab = 'VCOMPLY';\n  loader: boolean = false;\n  categoryList: any[] = [];\n  defaultCategoryList: any[] = [];\n  userCreatedCategoryList: any[] = [];\n  sortStatus = -1;\n  searchCategory: string = '';\n  searchTemplate: string = '';\n  selectedCategory: any[] = [];\n  NO_DATA_FOUND_IMAGE = NO_DATA_FOUND_IMAGE;\n  NO_DATA_FOUND_MESSAGE = NO_DATA_FOUND_MESSAGE;\n  selectedTemplate: any[] = [];\n  isPreview = false;\n  previewTemplate: any;\n\n  @Input() selectedCategoryId: number[] = [];\n  @Input() feature: any;\n  @Output() onTemplateSelect = new EventEmitter<any>();\n\n  constructor(\n    private templateService: TemplateService,\n    private policyService: PolicyService,\n    @Optional() config?: Configurations\n  ) {\n    if(config){\n      this.env = config?.envConfig\n    }\n  }\n\n  ngOnInit(): void {\n    this.setAnimation();\n    this.getTemplate();\n  }\n\n  setAnimation() {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n  }\n\n  switchTab(tab: string) {\n    this.currentTab = tab;\n    this.selectedCategory = [];\n    if (tab === 'VCOMPLY') {\n      this.templateList = [...this.defaultTemplates];\n      this.categoryList = this.defaultCategoryList;\n    } else {\n      if (this.customTemplates === null) {\n        this.getCustomTemplates();\n      } else {\n        this.templateList = [...this.customTemplates];\n        this.categoryList = this.userCreatedCategoryList;\n      }\n    }\n  }\n\n  getCustomTemplates() {\n    this.loader = true;\n    const payload = {\n      type: 'custom',\n      categoryId: this.selectedCategoryId.map(\n        (category: any) => category.item_id\n      ),\n    };\n    this.templateService.fetchTemplates(payload).subscribe((res: any) => {\n      this.customTemplates = res?.templates ?? [];\n      this.mapCustomTemplate();\n    });\n  }\n\n  mapCustomTemplate() {\n    this.policyService.getCategoriesList().subscribe((res: any) => {\n      this.userCreatedCategoryList = [...res];\n      this.userCreatedCategoryList = this.userCreatedCategoryList.map(\n        (res: any) => {\n          const parentItems = [...new Set(res?.parent_items ?? [])];\n          parentItems.unshift(res.item_name);\n          return {\n            ...res,\n            name: parentItems?.join(' < '),\n            parent_items: res?.parent_items.reverse(),\n          };\n        }\n      );\n      if (this.customTemplates) {\n        this.customTemplates = this.customTemplates.map((template: any) => {\n          return {\n            ...template,\n            categoryDetails: this.userCreatedCategoryList.filter(\n              (category: any) =>\n                template?.categoryId?.includes(category.item_id)\n            ),\n          };\n        });\n      }\n      this.templateList = [...new Set(this.customTemplates ?? [])];\n      const categoryIds = this.selectedCategoryId.map(\n        (category: any) => category.item_id\n      );\n      this.userCreatedCategoryList = this.userCreatedCategoryList.filter(\n        (category: any) => categoryIds?.includes(category.item_id)\n      );\n      this.loader = false;\n      this.categoryList = this.userCreatedCategoryList;\n    });\n  }\n\n  getTemplate() {\n    this.loader = true;\n    const payload = {\n      type: 'default',\n    };\n    forkJoin([\n      this.templateService.fetchTemplates(payload),\n      this.templateService.fetchDefaultCategories(),\n    ]).subscribe((res: any) => {\n      this.defaultTemplates = res[0]?.templates;\n      this.defaultCategoryList = res[1];\n      this.mapDefaultTemplate();\n      this.categoryList = [...new Set(this.defaultCategoryList)];\n\n      this.templateList = this.defaultTemplates;\n      this.loader = false;\n    });\n  }\n\n  mapDefaultTemplate() {\n    this.defaultTemplates = this.defaultTemplates.map((template: any) => {\n      const category = this.defaultCategoryList.filter((category: any) =>\n        template?.categoryId?.includes(category.item_id)\n      );\n      return {\n        ...template,\n        categoryDetails: category,\n      };\n    });\n  }\n\n  sortBy(key: string) {\n    this.sortStatus = this.sortStatus * -1;\n    this.templateList = this.templateService.sortByKey(\n      this.templateList,\n      key,\n      this.sortStatus\n    );\n  }\n\n  onSelectCategory(category: any, event: any) {\n    if (event.target.checked) {\n      this.selectedCategory.push(category?.item_id);\n    } else {\n      this.selectedCategory = this.selectedCategory.filter(\n        (id: any) => id !== category?.item_id\n      );\n    }\n    this.selectedCategory = [...new Set(this.selectedCategory)];\n  }\n\n  onApplyFilter(event: any) {\n    if (!event) {\n      this.selectedCategory = [];\n      return;\n    }\n    let selectedTemplate =\n      this.currentTab === 'VCOMPLY'\n        ? this.defaultTemplates\n        : this.customTemplates ?? [];\n    selectedTemplate = [...new Set(selectedTemplate)];\n    if (this.selectedCategory.length === 0) {\n      this.templateList = selectedTemplate;\n      return;\n    }\n    this.templateList = selectedTemplate.filter((template: any) => {\n      return template?.categoryId?.some((id: any) =>\n        this.selectedCategory.includes(id)\n      );\n    });\n  }\n\n  onSelectTemplate(template: any) {\n    this.selectedTemplate = [template];\n  }\n\n  save() {\n    this.onTemplateSelect.emit(this.selectedTemplate);\n  }\n\n  close() {\n    this.onTemplateSelect.emit([]);\n  }\n\n  deleteEvent() {\n    this.selectedTemplate = [];\n  }\n\n  onPreview(details: any) {\n    this.loader = false;\n    this.isPreview = true;\n    this.previewTemplate = details;\n    this.fileUrl = `${this.env?.s3Url}${this.env?.s3Bucket}/${details?.s3DocxPath}`;\n    console.log(this.fileUrl, 'fileUrl');\n  }\n\n  onClosePreview() {\n    this.isPreview = false;\n    this.previewTemplate = null;\n  }\n}\n","<div\n  class=\"select-template-list\"\n  [class.animate]=\"animation\"\n  [class.withPreview]=\"isPreview\"\n>\n  <ng-container *ngIf=\"!isPreview\">\n    <div\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n    >\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Template</div>\n    </div>\n    <div class=\"select-template-list-body\">\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n\n      <div class=\"select-template-list-tab vx-d-flex vx-align-center vx-mb-2\">\n        <button\n          (click)=\"switchTab('VCOMPLY')\"\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n          [class.active]=\"currentTab === 'VCOMPLY'\"\n        >\n          VCOMPLY TEMPLATES\n        </button>\n        <button\n          (click)=\"switchTab('USER_CREATED')\"\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n          [class.active]=\"currentTab === 'USER_CREATED'\"\n        >\n          USER-CREATED TEMPLATES\n        </button>\n      </div>\n      <div class=\"search-block vx-mb-2\">\n        <i class=\"icons\">&#xe90b;</i>\n        <input type=\"text\" [(ngModel)]=\"searchTemplate\" placeholder=\"Search\" />\n      </div>\n      <div class=\"body-top vx-d-flex vx-align-center vx-justify-end vx-mb-2\">\n        <cs-multi-select\n          (searchText)=\"searchCategory = $event\"\n          [placeholder]=\"'Select Category'\"\n          [value]=\"selectedCategory\"\n          (applyFilter)=\"onApplyFilter($event)\"\n        >\n          <ng-container\n            *ngFor=\"\n              let eachCategory of categoryList\n                | SearchByKeys : ['name'] : searchCategory\n            \"\n          >\n            <cs-multi-select-option\n              [appTooltip]=\"eachCategory?.name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              [value]=\"eachCategory?.item_id\"\n              (change)=\"onSelectCategory(eachCategory, $event)\"\n              [tooltipMandatory]=\"true\"\n            >\n              {{ eachCategory?.name }}\n            </cs-multi-select-option>\n          </ng-container>\n        </cs-multi-select>\n      </div>\n      <div class=\"body-inner vx-mb-1\">\n        <ng-container *ngIf=\"!loader\">\n          <ng-container\n            *ngIf=\"\n              templateList\n                | SearchByKeys\n                  : ['name', 'categoryDetails']\n                  : searchTemplate as allTemplate\n            \"\n          >\n            <app-template-list-table\n              *ngIf=\"allTemplate.length\"\n              [templateList]=\"allTemplate\"\n              [loader]=\"loader\"\n              [categoryList]=\"categoryList\"\n              [selectedTemplate]=\"selectedTemplate[0]\"\n              [feature]=\"feature\"\n              (onSort)=\"sortBy($event)\"\n              (onSelectTemplate)=\"onSelectTemplate($event)\"\n              (onPreview)=\"onPreview($event)\"\n            ></app-template-list-table>\n            <app-no-data\n              *ngIf=\"!allTemplate?.length\"\n              [noDataImage]=\"NO_DATA_FOUND_IMAGE\"\n              [noDataText]=\"NO_DATA_FOUND_MESSAGE\"\n            ></app-no-data>\n          </ng-container>\n        </ng-container>\n      </div>\n\n      <app-floating-bar\n        (closeEvent)=\"save()\"\n        (closeList)=\"close()\"\n        [isDisabled]=\"selectedTemplate?.length === 0\"\n        [selectedData]=\"selectedTemplate\"\n        [displayElementKey]=\"'name'\"\n        [singularText]=\"'Template Selected'\"\n        (deleteEvent)=\"deleteEvent()\"\n      >\n      </app-floating-bar>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"isPreview\">\n    <div\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-pl-4 vx-pr-4\"\n    >\n      <button\n        (click)=\"onClosePreview()\"\n        class=\"previewBtn vx-fs-14 vx-fw-500 vx-label-txt vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n      >\n        <i class=\"icons vx-mr-1\">&#xe91d;</i>Preview\n      </button>\n      <div\n        class=\"template-name vx-fs-14 vx-ml-1\"\n        [appTooltip]=\"previewTemplate?.name\"\n        placement=\"bottom-left\"\n        delay=\"0\"\n        type=\"black\"\n        [tooltipMandatory]=\"false\"\n      >\n        {{ previewTemplate?.name }}\n      </div>\n    </div>\n    <div class=\"preview-template-body vx-d-flex vx-justify-center\">\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n\n      <div *ngIf=\"!loader\" class=\"preview-template-body-inner\">\n        <ngx-doc-viewer\n          [url]=\"fileUrl\"\n          viewer=\"office\"\n          style=\"width: 100%; height: 100%; margin: 0\"\n          disableContent=\"popout-hide\"\n        >\n        </ngx-doc-viewer>\n      </div>\n    </div>\n  </ng-container>\n</div>\n"]}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
export const WORD_CONSTANTS = {
|
|
2
2
|
MS_WORD_OPTION: 'Create a Policy using MS Word',
|
|
3
|
-
ff_policy_ms_word_integration: 'ff_policy_ms_word_integration',
|
|
4
3
|
createWordPolicy_snackbar_message: "Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?",
|
|
5
4
|
};
|
|
6
5
|
export const WORD_PAYLOAD = {
|
|
@@ -19,4 +18,4 @@ export const WORD_URL_CONSTANTS = {
|
|
|
19
18
|
createVersion: 'createVersion',
|
|
20
19
|
workroom_url: '/all/policy/workroom?id=',
|
|
21
20
|
};
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXMtd29yZC5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi93b3JrZmxvdy1wb2xpY3kvbXMtd29yZC5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzVCLGNBQWMsRUFBRSwrQkFBK0I7SUFDL0MsaUNBQWlDLEVBQy9CLDZHQUE2RztDQUNoSCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHO0lBQzFCLFdBQVcsRUFBRSxRQUFRO0lBQ3JCLFNBQVMsRUFBRSxPQUFPO0lBQ2xCLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLFlBQVksRUFBRSxDQUFDO0lBQ2YsY0FBYyxFQUFFLEVBQUU7SUFDbEIsR0FBRyxFQUFFO1FBQ0gsSUFBSSxFQUFFLEVBQUU7UUFDUixPQUFPLEVBQUUsRUFBRTtLQUNaO0NBQ0YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2hDLG1CQUFtQixFQUFFLGtCQUFrQjtJQUN2QyxhQUFhLEVBQUUsZUFBZTtJQUM5QixZQUFZLEVBQUUsMEJBQTBCO0NBQ3pDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgV09SRF9DT05TVEFOVFMgPSB7XG4gIE1TX1dPUkRfT1BUSU9OOiAnQ3JlYXRlIGEgUG9saWN5IHVzaW5nIE1TIFdvcmQnLFxuICBjcmVhdGVXb3JkUG9saWN5X3NuYWNrYmFyX21lc3NhZ2U6XG4gICAgXCJPb3BzISBTb21ldGhpbmcgd2VudCB3cm9uZyBhbmQgd2Ugd2VyZSB1bmFibGUgdG8gY29tcGxldGUgdGhpcyBhY3Rpb24uIExldCdzIGdpdmUgaXQgYW5vdGhlciB0cnksIHNoYWxsIHdlP1wiLFxufTtcblxuZXhwb3J0IGNvbnN0IFdPUkRfUEFZTE9BRCA9IHtcbiAgbW9kdWxlX25hbWU6ICdQT0xJQ1knLFxuICBpbmNyZW1lbnQ6ICdNQUpPUicsXG4gIGFjdGlvbjogJ0NSRUFURUQnLFxuICBtc193b3JkX3R5cGU6IDEsXG4gIGRvY3hfZmlsZV9wYXRoOiAnJyxcbiAgdXJsOiB7XG4gICAgZWRpdDogJycsXG4gICAgcHJldmlldzogJycsXG4gIH0sXG59O1xuXG5leHBvcnQgY29uc3QgV09SRF9VUkxfQ09OU1RBTlRTID0ge1xuICBuZXdfd29yZF9wb2xpY3lfdXJsOiAnaHR0cHM6Ly93b3JkLm5ldycsXG4gIGNyZWF0ZVZlcnNpb246ICdjcmVhdGVWZXJzaW9uJyxcbiAgd29ya3Jvb21fdXJsOiAnL2FsbC9wb2xpY3kvd29ya3Jvb20/aWQ9Jyxcbn07XG4iXX0=
|
|
@@ -34957,7 +34957,9 @@ class SelectTemplateListComponent {
|
|
|
34957
34957
|
this.isPreview = false;
|
|
34958
34958
|
this.selectedCategoryId = [];
|
|
34959
34959
|
this.onTemplateSelect = new EventEmitter();
|
|
34960
|
-
|
|
34960
|
+
if (config) {
|
|
34961
|
+
this.env = config?.envConfig;
|
|
34962
|
+
}
|
|
34961
34963
|
}
|
|
34962
34964
|
ngOnInit() {
|
|
34963
34965
|
this.setAnimation();
|
|
@@ -35097,6 +35099,7 @@ class SelectTemplateListComponent {
|
|
|
35097
35099
|
this.isPreview = true;
|
|
35098
35100
|
this.previewTemplate = details;
|
|
35099
35101
|
this.fileUrl = `${this.env?.s3Url}${this.env?.s3Bucket}/${details?.s3DocxPath}`;
|
|
35102
|
+
console.log(this.fileUrl, 'fileUrl');
|
|
35100
35103
|
}
|
|
35101
35104
|
onClosePreview() {
|
|
35102
35105
|
this.isPreview = false;
|
|
@@ -35378,7 +35381,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
35378
35381
|
|
|
35379
35382
|
const WORD_CONSTANTS = {
|
|
35380
35383
|
MS_WORD_OPTION: 'Create a Policy using MS Word',
|
|
35381
|
-
ff_policy_ms_word_integration: 'ff_policy_ms_word_integration',
|
|
35382
35384
|
createWordPolicy_snackbar_message: "Oops! Something went wrong and we were unable to complete this action. Let's give it another try, shall we?",
|
|
35383
35385
|
};
|
|
35384
35386
|
const WORD_PAYLOAD = {
|
|
@@ -35487,7 +35489,7 @@ class DocumentSectionComponent {
|
|
|
35487
35489
|
}
|
|
35488
35490
|
}
|
|
35489
35491
|
initialiseFeatureFlags() {
|
|
35490
|
-
this.ff_policy_ms_word_integration = this.feature.isFeatureEnabled(
|
|
35492
|
+
this.ff_policy_ms_word_integration = this.feature.isFeatureEnabled('ff_policy_ms_word_integration');
|
|
35491
35493
|
}
|
|
35492
35494
|
redirectUserToWordPolicy() {
|
|
35493
35495
|
window.open(WORD_URL_CONSTANTS.new_word_policy_url, '_blank');
|