vcomply-workflow-engine 3.4.23 → 3.4.25

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 (101) hide show
  1. package/esm2020/lib/add-multiple-responsibility/add-multiple-responsibility.component.mjs +2 -4
  2. package/esm2020/lib/add-multiple-risk/add-multiple-risk.component.mjs +2 -3
  3. package/esm2020/lib/formgroup/cs-select/cs-select.component.mjs +5 -5
  4. package/esm2020/lib/formgroup/cs-switch/cs-switch.component.mjs +1 -4
  5. package/esm2020/lib/log-an-issue/log-an-issue.component.mjs +1 -11
  6. package/esm2020/lib/more-option/more-option.component.mjs +5 -6
  7. package/esm2020/lib/pipes/filter.pipe.mjs +1 -2
  8. package/esm2020/lib/pipes/search.pipe.mjs +3 -5
  9. package/esm2020/lib/sharedComponents/approval-workflow/approval-create-form/approval-create-form.component.mjs +3 -7
  10. package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow-list/approval-workflow-list.component.mjs +1 -5
  11. package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow.component.mjs +1 -7
  12. package/esm2020/lib/sharedComponents/assessment-editor/create-assessment-container/create-assessment-container.component.mjs +80 -36
  13. package/esm2020/lib/sharedComponents/assessment-list/assessment-list.component.mjs +27 -21
  14. package/esm2020/lib/sharedComponents/assessment-preview/preview/preview.component.mjs +7 -4
  15. package/esm2020/lib/sharedComponents/audit-category-list/audit-category-list.component.mjs +3 -4
  16. package/esm2020/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.mjs +3 -9
  17. package/esm2020/lib/sharedComponents/bulk-view/bulk-view.component.mjs +9 -7
  18. package/esm2020/lib/sharedComponents/category-multiselect/category-multi-select.component.mjs +7 -9
  19. package/esm2020/lib/sharedComponents/checkpoint/checkpoints/checkpoints.component.mjs +93 -27
  20. package/esm2020/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.mjs +11 -9
  21. package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-container/checkpoints-policy-container.component.mjs +13 -12
  22. package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.mjs +28 -19
  23. package/esm2020/lib/sharedComponents/floating-bar/floating-bar.component.mjs +8 -8
  24. package/esm2020/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +35 -37
  25. package/esm2020/lib/sharedComponents/framework-list/parent-table/parent-table.component.mjs +7 -7
  26. package/esm2020/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +1 -12
  27. package/esm2020/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +1 -3
  28. package/esm2020/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +1 -13
  29. package/esm2020/lib/sharedComponents/frequency/frequency-due-date/frequency-due-date.component.mjs +1 -7
  30. package/esm2020/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.mjs +1 -26
  31. package/esm2020/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +1 -15
  32. package/esm2020/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +1 -14
  33. package/esm2020/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +14 -8
  34. package/esm2020/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +1 -13
  35. package/esm2020/lib/sharedComponents/frequency/frequency-radio-list/frequency-radio-list.component.mjs +1 -2
  36. package/esm2020/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +1 -18
  37. package/esm2020/lib/sharedComponents/frequency/frequency-top/frequency-top.component.mjs +2 -2
  38. package/esm2020/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +1 -12
  39. package/esm2020/lib/sharedComponents/frequency/frequency.service.mjs +2 -11
  40. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-annual/frequency-dialog-annual.component.mjs +1 -2
  41. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-biannual/frequency-dialog-biannual.component.mjs +1 -2
  42. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-monthly/frequency-dialog-monthly.component.mjs +1 -2
  43. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-one-time/frequency-dialog-one-time.component.mjs +1 -2
  44. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-quarterly/frequency-dialog-quarterly.component.mjs +1 -2
  45. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-radio-list/frequency-dialog-radio-list.component.mjs +1 -2
  46. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.mjs +2 -2
  47. package/esm2020/lib/sharedComponents/group-users-list/group-users-list.component.mjs +1 -3
  48. package/esm2020/lib/sharedComponents/link-program/link-program/link-program.component.mjs +48 -38
  49. package/esm2020/lib/sharedComponents/link-program/restapi.service.mjs +31 -16
  50. package/esm2020/lib/sharedComponents/no-data/no-data.component.mjs +2 -4
  51. package/esm2020/lib/sharedComponents/owner-list/owner-list.component.mjs +12 -10
  52. package/esm2020/lib/sharedComponents/program-listing/program-listing.component.mjs +127 -58
  53. package/esm2020/lib/sharedComponents/radio-list-with-pagination/radio-list.component.mjs +4 -7
  54. package/esm2020/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.mjs +9 -7
  55. package/esm2020/lib/sharedComponents/risk-classification/risk-classification.component.mjs +11 -6
  56. package/esm2020/lib/sharedComponents/select-approvers/select-approvers.component.mjs +1 -2
  57. package/esm2020/lib/sharedComponents/users-radio-list/users-radio-list.component.mjs +2 -3
  58. package/esm2020/lib/ui-kit/formgroup/cs-switch/cs-switch.component.mjs +1 -4
  59. package/esm2020/lib/ui-kit/popover/popover-longpress.directive.mjs +1 -3
  60. package/esm2020/lib/ui-kit/popover/popover.component.mjs +26 -12
  61. package/esm2020/lib/ui-kit/tooltip/tooltip.directive.mjs +8 -5
  62. package/esm2020/lib/workflow/shared/components/attributes/attributes.component.mjs +1 -2
  63. package/esm2020/lib/workflow/shared/components/edit-mode/edit-mode.component.mjs +1 -4
  64. package/esm2020/lib/workflow/shared/components/grc-object-list/grc-object-list.component.mjs +1 -2
  65. package/esm2020/lib/workflow/shared/components/list-popup/list-popup.component.mjs +1 -4
  66. package/esm2020/lib/workflow/shared/components/table-card/table-card.component.mjs +4 -8
  67. package/esm2020/lib/workflow-assessment/import-an-assessment/import-an-assessment.component.mjs +245 -108
  68. package/esm2020/lib/workflow-assessment/workflow-assessment.component.mjs +2 -4
  69. package/esm2020/lib/workflow-compliance/workflow-compliance.component.mjs +10 -8
  70. package/esm2020/lib/workflow-engine-container/workflow-engine-container.component.mjs +1 -5
  71. package/esm2020/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.mjs +45 -45
  72. package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/define-framework-listing.component.mjs +43 -25
  73. package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/pipes/sub-cat-indeter.pipe.mjs +4 -4
  74. package/esm2020/lib/workflow-program/create-program-ui/floating-bar/floating-bar.component.mjs +1 -2
  75. package/esm2020/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.mjs +25 -14
  76. package/esm2020/lib/workflow-program/create-program-ui/pipes/assessment-resolver.pipe.mjs +6 -3
  77. package/esm2020/lib/workflow-program/create-program-ui/role-list/role-list.component.mjs +25 -19
  78. package/esm2020/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +1 -4
  79. package/esm2020/lib/workflow-program/workflow-program.component.mjs +232 -110
  80. package/esm2020/lib/workflow-services/add-risk.service.mjs +1 -2
  81. package/esm2020/lib/workflow-services/assessment.service.mjs +1 -5
  82. package/esm2020/lib/workflow-services/programs.service.mjs +173 -57
  83. package/fesm2015/vcomply-workflow-engine.mjs +1381 -937
  84. package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
  85. package/fesm2020/vcomply-workflow-engine.mjs +1394 -945
  86. package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
  87. package/lib/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
  88. package/lib/sharedComponents/assessment-list/assessment-list.component.d.ts +4 -5
  89. package/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.d.ts +2 -3
  90. package/lib/sharedComponents/bulk-view/bulk-view.component.d.ts +2 -3
  91. package/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.d.ts +2 -4
  92. package/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.d.ts +1 -1
  93. package/lib/sharedComponents/link-program/restapi.service.d.ts +3 -3
  94. package/lib/sharedComponents/no-data/no-data.component.d.ts +2 -4
  95. package/lib/ui-kit/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
  96. package/lib/workflow/shared/components/edit-mode/edit-mode.component.d.ts +2 -3
  97. package/lib/workflow/shared/components/list-popup/list-popup.component.d.ts +2 -3
  98. package/lib/workflow/shared/components/table-card/table-card.component.d.ts +2 -5
  99. package/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.d.ts +8 -9
  100. package/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.d.ts +2 -4
  101. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
1
+ import { Component, Input, Output, EventEmitter, ViewChild, } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "../../../ui-kit/snack-bar/snack-bar.service";
4
4
  import * as i2 from "@angular/forms";
@@ -32,12 +32,11 @@ export class CheckpointsQuestionsComponent {
32
32
  radio: 'Type your question here [Radio]',
33
33
  checkbox: 'Type your question here [CheckBox]',
34
34
  date: 'Type your question here [Date]',
35
- upload: 'Type your question here [Upload]'
35
+ upload: 'Type your question here [Upload]',
36
36
  };
37
37
  this.description = '';
38
38
  }
39
- ngOnInit() {
40
- }
39
+ ngOnInit() { }
41
40
  saveDescription() {
42
41
  this.addInstruction = false;
43
42
  if (this.extractContent(this.checkpointInstruction) === '') {
@@ -48,11 +47,12 @@ export class CheckpointsQuestionsComponent {
48
47
  extractContent(s) {
49
48
  var span = document.createElement('span');
50
49
  span.innerHTML = s;
51
- return (span.textContent || span.innerText).replace(/&nbsp;/g, '').replace(/\<br\s*[\/]?>/gi, '').trim();
50
+ return (span.textContent || span.innerText)
51
+ .replace(/&nbsp;/g, '')
52
+ .replace(/\<br\s*[\/]?>/gi, '')
53
+ .trim();
52
54
  }
53
- ;
54
55
  ngOnChanges(changes) {
55
- console.log(changes, this.errorIndex);
56
56
  if (changes.errorIndex) {
57
57
  if (this.errorIndex >= 0) {
58
58
  this.activeQuestionIndex = this.errorIndex;
@@ -90,7 +90,9 @@ export class CheckpointsQuestionsComponent {
90
90
  this.removeOption.emit({ questionIndex, optionIndex, type });
91
91
  }
92
92
  deleteOnBackspace(questionIndex, optionIndex, type) {
93
- if (this.checkpointData[questionIndex].options[optionIndex].label.length < 1 && this.checkpointData[questionIndex].options.length > 1) {
93
+ if (this.checkpointData[questionIndex].options[optionIndex].label.length <
94
+ 1 &&
95
+ this.checkpointData[questionIndex].options.length > 1) {
94
96
  this.removeOption.emit({ questionIndex, optionIndex, type });
95
97
  }
96
98
  }
@@ -126,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
126
128
  type: ViewChild,
127
129
  args: ['datePicker']
128
130
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkpoints-questions.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter, ViewChild, OnChanges, SimpleChanges, ElementRef } from '@angular/core';\r\nimport { DatePickerComponent } from 'ng2-date-picker';\r\nimport { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';\r\n\r\n@Component({\r\n  selector: 'app-checkpoints-questions',\r\n  templateUrl: './checkpoints-questions.component.html',\r\n  styleUrls: ['./checkpoints-questions.component.less']\r\n})\r\nexport class CheckpointsQuestionsComponent implements OnInit, OnChanges {\r\n\r\n  constructor(private elementRef:ElementRef, private snackbar: SnackBarService) { }\r\n  @Input() checkpointData: any = [];\r\n  @Input() questionTypeList = [];\r\n  @Input() errorIndex = -1;\r\n  @Input() checkpointInstruction :string = '';\r\n  @Output() createQuestion = new EventEmitter();\r\n  @Output() deleteQuestion = new EventEmitter();\r\n  @Output() copyQuestion = new EventEmitter();\r\n  @Output() blankQuestion = new EventEmitter();\r\n  @Output() createOption = new EventEmitter();\r\n  @Output() removeOption = new EventEmitter();\r\n  @Output() updateDescription = new EventEmitter();\r\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\r\n  datePickerOverlay = false;\r\n  activeQuestionIndex = 0;\r\n  addInstruction!: boolean ;\r\n\r\n  placeholder: any = {\r\n    textbox: 'Type your question here [Text Box]',\r\n    select: 'Type your question here [Select]',\r\n    radio: 'Type your question here [Radio]',\r\n    checkbox: 'Type your question here [CheckBox]',\r\n    date: 'Type your question here [Date]',\r\n    upload: 'Type your question here [Upload]'\r\n  };\r\n  description: any = '';\r\n  ngOnInit(): void {\r\n\r\n  }\r\n\r\n  saveDescription(){\r\n    this.addInstruction = false;\r\n    if(this.extractContent(this.checkpointInstruction) === ''){\r\n      this.checkpointInstruction = '';\r\n    }\r\n    this.updateDescription.emit(this.checkpointInstruction)\r\n  }\r\n  extractContent(s:string) {\r\n    var span = document.createElement('span');\r\n    span.innerHTML = s;\r\n    return (span.textContent || span.innerText).replace(/&nbsp;/g, '').replace(/\\<br\\s*[\\/]?>/gi, '').trim();\r\n  };\r\n  ngOnChanges(changes: SimpleChanges){\r\n    console.log(changes, this.errorIndex);\r\n    if (changes.errorIndex){\r\n      if (this.errorIndex >= 0 ){\r\n        this.activeQuestionIndex = this.errorIndex;\r\n      }\r\n    }\r\n  }\r\n  openDatePicker() {\r\n    this.datePicker.api.open();\r\n    this.datePickerOverlay = true;\r\n  }\r\n  closeDatepicker() {\r\n    this.datePicker.api.close();\r\n    this.datePickerOverlay = false;\r\n  }\r\n  addQuestion(type: any){\r\n  //  this.createQuestion.emit(type.type);\r\n   // this.activeQuestionIndex = this.checkpointData.length - 1;\r\n  }\r\n  removeQuestion(index: number){\r\n    this.deleteQuestion.emit(index);\r\n    this.activeQuestionIndex = index - 1;\r\n  }\r\n  cloneQuestion(index: number){\r\n    // this.activeQuestionIndex = index + 1;\r\n    // this.copyQuestion.emit(index);\r\n\r\n  }\r\n  blankClone(type: string, index: number){\r\n    // this.blankQuestion.emit({type, index});\r\n    // this.activeQuestionIndex = index + 1;\r\n  }\r\n\r\n  addOption(questionIndex: number, optionIndex: number, type: string){\r\n    // this.createOption.emit({questionIndex, optionIndex, type});\r\n  }\r\n\r\n  deleteOption(questionIndex: number, optionIndex: number, type: string){\r\n    this.removeOption.emit({questionIndex, optionIndex, type});\r\n  }\r\n\r\n  deleteOnBackspace(questionIndex: number, optionIndex: number, type: string){\r\n    if (this.checkpointData[questionIndex].options[optionIndex].label.length < 1 && this.checkpointData[questionIndex].options.length  > 1) {\r\n      this.removeOption.emit({questionIndex, optionIndex, type});\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<!-- <p>checkpoints-questions works!</p> -->\r\n<div class=\"checkpoints-questions\">\r\n    <div class=\"checkpoints-questions-blocks instruction\"\r\n        [class.filled]=\"checkpointInstruction.length>0 && !addInstruction\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\" *ngIf=\"!addInstruction\"><i class=\"icons\">&#xe932;</i></span>\r\n                <span class=\"text\" *ngIf=\"!addInstruction\" \r\n                    [innerHTML]=\"checkpointInstruction.length>0 ? (checkpointInstruction | formatHtml) :'Add instruction'\"></span>\r\n                <span class=\"text\" *ngIf=\"addInstruction && false\">\r\n                    <vcomply-editor [(ngModel)]=\"checkpointInstruction\" [editorConfig]=\"{mode: 'prime',\r\n                    colorPalette: true,\r\n                    link: true,\r\n                    placeholder: 'Add instruction',\r\n                    buttonName:'SAVE', id:'checkpoint-instructions'}\" (comment)=\"saveDescription()\"></vcomply-editor>\r\n                </span>\r\n            </h3>\r\n        </div>\r\n    </div>\r\n\r\n    <ng-container *ngFor=\"let question of checkpointData; let questionIndex = index\">\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"['textbox','date','upload'].includes(question?.type)\"\r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\" readonly>\r\n                </h3>\r\n                <ng-container class=\"preview\" *ngIf=\"activeQuestionIndex !== questionIndex\">\r\n                    <label class=\"file-upload\" *ngIf=\"question.type==='upload'\">\r\n                        <input type=\"file\" disabled>\r\n                        <span><i class=\"icons\">&#xe9ed;</i> Browse File</span>\r\n                    </label>\r\n                    <ng-container *ngIf=\"question.type === 'date'\">\r\n                        <div class=\"date-picker\">\r\n                            <i class=\"icons\">&#xe92d;</i>\r\n                            <input type=\"text\" placeholder=\"Select date\"\r\n                                (click)=\"openDatePicker();$event.stopPropagation(); datePickerOverlay = true;\" disabled>\r\n                            <dp-date-picker #datePicker (click)=\"$event.stopPropagation();\"> </dp-date-picker>\r\n                            <div class=\"vx-overlay\" (click)=\"closeDatepicker();$event.stopPropagation();\"\r\n                                *ngIf=\"datePickerOverlay\"></div>\r\n                        </div>\r\n                    </ng-container>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <!-- <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button> -->\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'radio'\"\r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\"\r\n                            [disabled]=\"activeQuestionIndex === questionIndex\"><input [(ngModel)]=\"option.label\"\r\n                                \r\n                                [id]=\"'radio-' + '' + questionIndex + '' + opIndex\" type=\"text\" placeholder=\"Option\">\r\n                        </app-cs-radio>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n                    <!-- <li *ngIf=\"activeQuestionIndex === questionIndex && false\" class=\"add-new\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input type=\"text\" readonly placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\">\r\n                        </app-cs-radio>\r\n                    </li> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'select'\" \r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-radio [oneLine]=\"true\" readonly\r\n                            [disabled]=\"activeQuestionIndex === questionIndex\">\r\n                            <input [(ngModel)]=\"option.label\"\r\n                                name =\"'select-' + '' + questionIndex + '' + opIndex\" (keydown.enter)=\"addOption(questionIndex,opIndex,question.type)\"\r\n                                (keydown.backspace)=\"deleteOnBackspace(questionIndex,opIndex,question.type)\"\r\n                                [id]=\"'select-' + '' + questionIndex + '' + opIndex\" type=\"text\" placeholder=\"Option\">\r\n                        </app-cs-radio>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n<!-- \r\n                    <li *ngIf=\"activeQuestionIndex === questionIndex\" class=\"add-new\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\"><input readonly type=\"text\"\r\n                                placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\">\r\n                        </app-cs-radio>\r\n                    </li> -->\r\n                    <!-- <button (click)=\"addOption(questionIndex,question?.options?.length,question.type)\"\r\n                        *ngIf=\"activeQuestionIndex === questionIndex\">Add More Options</button> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'checkbox'\" \r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-checkbox [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input [(ngModel)]=\"option.label\" type=\"text\" placeholder=\"Option\"\r\n                                [id]=\"'checkbox-' + '' + questionIndex + '' + opIndex\"\r\n                                (keydown.enter)=\"addOption(questionIndex,opIndex,question.type)\"\r\n                                (keydown.backspace)=\"deleteOnBackspace(questionIndex,opIndex,question.type)\">\r\n                        </app-cs-checkbox>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n                    <!-- <li *ngIf=\"activeQuestionIndex === questionIndex\" class=\"add-new\">\r\n                        <app-cs-checkbox [oneLine]=\"true\"\r\n                            (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\"\r\n                            [disabled]=\"true\">\r\n                            <input [disabled]=\"true\" type=\"text\" placeholder=\"Add more option\">\r\n                        </app-cs-checkbox>\r\n                    </li> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <!-- <div class=\"checkpoints-questions-blocks\" [class.active]=\"true\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\">2. <span class=\"required\">*</span></span>\r\n                <input class=\"text\" type=\"text\" placeholder=\"Type your question here [Select Box]\" value=\"Has the previous audit report been closed out?\">\r\n            </h3>\r\n            <ul class=\"list\">\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>Yes</span></app-cs-radio> <button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>No</span></app-cs-radio><button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>N/A</span></app-cs-radio><button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><input type=\"text\" placeholder=\"Option\"></app-cs-radio> <button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n        <div class=\"footer\">\r\n            <div class=\"left\">\r\n                <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is required</app-cs-checkbox>\r\n            </div>\r\n            <div class=\"right\">\r\n                <ul>\r\n                    <li><button><i class=\"icons\">&#xe915;</i></button></li>\r\n                    <li><button><i class=\"icons\">&#xe923;</i></button></li>\r\n                    <li><button><i class=\"icons\">&#xe9b6;</i></button></li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n    </div> -->\r\n    </ng-container>\r\n    <!-- <button class=\"btn-add-new\" type=\"button\" appPopover (click)=\"newCheckpoint.popover()\" placement=\"left\">+ Add a new\r\n        checkpoint</button> -->\r\n    <!-- <app-popover #newCheckpoint>\r\n\r\n        <ul class=\"checkpoint-type-list\">\r\n            <li><span class=\"checkpoint-type-list-title\">Add Checkpoints</span></li>\r\n            <li *ngFor=\"let type of questionTypeList\">\r\n                <button (click)=\"addQuestion(type)\">\r\n                    <i class=\"icons\" [innerHTML]=\"type.icon\"></i>\r\n                    <span class=\"value\">\r\n                        {{type?.text}}\r\n                    </span>\r\n                </button>\r\n            </li>\r\n        </ul>\r\n    </app-popover> -->\r\n</div>\r\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkpoints-questions.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ElementRef,\r\n} from '@angular/core';\r\nimport { DatePickerComponent } from 'ng2-date-picker';\r\nimport { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';\r\n\r\n@Component({\r\n  selector: 'app-checkpoints-questions',\r\n  templateUrl: './checkpoints-questions.component.html',\r\n  styleUrls: ['./checkpoints-questions.component.less'],\r\n})\r\nexport class CheckpointsQuestionsComponent implements OnInit, OnChanges {\r\n  constructor(\r\n    private elementRef: ElementRef,\r\n    private snackbar: SnackBarService\r\n  ) {}\r\n  @Input() checkpointData: any = [];\r\n  @Input() questionTypeList = [];\r\n  @Input() errorIndex = -1;\r\n  @Input() checkpointInstruction: string = '';\r\n  @Output() createQuestion = new EventEmitter();\r\n  @Output() deleteQuestion = new EventEmitter();\r\n  @Output() copyQuestion = new EventEmitter();\r\n  @Output() blankQuestion = new EventEmitter();\r\n  @Output() createOption = new EventEmitter();\r\n  @Output() removeOption = new EventEmitter();\r\n  @Output() updateDescription = new EventEmitter();\r\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\r\n  datePickerOverlay = false;\r\n  activeQuestionIndex = 0;\r\n  addInstruction!: boolean;\r\n\r\n  placeholder: any = {\r\n    textbox: 'Type your question here [Text Box]',\r\n    select: 'Type your question here [Select]',\r\n    radio: 'Type your question here [Radio]',\r\n    checkbox: 'Type your question here [CheckBox]',\r\n    date: 'Type your question here [Date]',\r\n    upload: 'Type your question here [Upload]',\r\n  };\r\n  description: any = '';\r\n  ngOnInit(): void {}\r\n\r\n  saveDescription() {\r\n    this.addInstruction = false;\r\n    if (this.extractContent(this.checkpointInstruction) === '') {\r\n      this.checkpointInstruction = '';\r\n    }\r\n    this.updateDescription.emit(this.checkpointInstruction);\r\n  }\r\n  extractContent(s: string) {\r\n    var span = document.createElement('span');\r\n    span.innerHTML = s;\r\n    return (span.textContent || span.innerText)\r\n      .replace(/&nbsp;/g, '')\r\n      .replace(/\\<br\\s*[\\/]?>/gi, '')\r\n      .trim();\r\n  }\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.errorIndex) {\r\n      if (this.errorIndex >= 0) {\r\n        this.activeQuestionIndex = this.errorIndex;\r\n      }\r\n    }\r\n  }\r\n  openDatePicker() {\r\n    this.datePicker.api.open();\r\n    this.datePickerOverlay = true;\r\n  }\r\n  closeDatepicker() {\r\n    this.datePicker.api.close();\r\n    this.datePickerOverlay = false;\r\n  }\r\n  addQuestion(type: any) {\r\n    //  this.createQuestion.emit(type.type);\r\n    // this.activeQuestionIndex = this.checkpointData.length - 1;\r\n  }\r\n  removeQuestion(index: number) {\r\n    this.deleteQuestion.emit(index);\r\n    this.activeQuestionIndex = index - 1;\r\n  }\r\n  cloneQuestion(index: number) {\r\n    // this.activeQuestionIndex = index + 1;\r\n    // this.copyQuestion.emit(index);\r\n  }\r\n  blankClone(type: string, index: number) {\r\n    // this.blankQuestion.emit({type, index});\r\n    // this.activeQuestionIndex = index + 1;\r\n  }\r\n\r\n  addOption(questionIndex: number, optionIndex: number, type: string) {\r\n    // this.createOption.emit({questionIndex, optionIndex, type});\r\n  }\r\n\r\n  deleteOption(questionIndex: number, optionIndex: number, type: string) {\r\n    this.removeOption.emit({ questionIndex, optionIndex, type });\r\n  }\r\n\r\n  deleteOnBackspace(questionIndex: number, optionIndex: number, type: string) {\r\n    if (\r\n      this.checkpointData[questionIndex].options[optionIndex].label.length <\r\n        1 &&\r\n      this.checkpointData[questionIndex].options.length > 1\r\n    ) {\r\n      this.removeOption.emit({ questionIndex, optionIndex, type });\r\n    }\r\n  }\r\n}\r\n","<!-- <p>checkpoints-questions works!</p> -->\r\n<div class=\"checkpoints-questions\">\r\n    <div class=\"checkpoints-questions-blocks instruction\"\r\n        [class.filled]=\"checkpointInstruction.length>0 && !addInstruction\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\" *ngIf=\"!addInstruction\"><i class=\"icons\">&#xe932;</i></span>\r\n                <span class=\"text\" *ngIf=\"!addInstruction\" \r\n                    [innerHTML]=\"checkpointInstruction.length>0 ? (checkpointInstruction | formatHtml) :'Add instruction'\"></span>\r\n                <span class=\"text\" *ngIf=\"addInstruction && false\">\r\n                    <vcomply-editor [(ngModel)]=\"checkpointInstruction\" [editorConfig]=\"{mode: 'prime',\r\n                    colorPalette: true,\r\n                    link: true,\r\n                    placeholder: 'Add instruction',\r\n                    buttonName:'SAVE', id:'checkpoint-instructions'}\" (comment)=\"saveDescription()\"></vcomply-editor>\r\n                </span>\r\n            </h3>\r\n        </div>\r\n    </div>\r\n\r\n    <ng-container *ngFor=\"let question of checkpointData; let questionIndex = index\">\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"['textbox','date','upload'].includes(question?.type)\"\r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\" readonly>\r\n                </h3>\r\n                <ng-container class=\"preview\" *ngIf=\"activeQuestionIndex !== questionIndex\">\r\n                    <label class=\"file-upload\" *ngIf=\"question.type==='upload'\">\r\n                        <input type=\"file\" disabled>\r\n                        <span><i class=\"icons\">&#xe9ed;</i> Browse File</span>\r\n                    </label>\r\n                    <ng-container *ngIf=\"question.type === 'date'\">\r\n                        <div class=\"date-picker\">\r\n                            <i class=\"icons\">&#xe92d;</i>\r\n                            <input type=\"text\" placeholder=\"Select date\"\r\n                                (click)=\"openDatePicker();$event.stopPropagation(); datePickerOverlay = true;\" disabled>\r\n                            <dp-date-picker #datePicker (click)=\"$event.stopPropagation();\"> </dp-date-picker>\r\n                            <div class=\"vx-overlay\" (click)=\"closeDatepicker();$event.stopPropagation();\"\r\n                                *ngIf=\"datePickerOverlay\"></div>\r\n                        </div>\r\n                    </ng-container>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <!-- <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button> -->\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'radio'\"\r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\"\r\n                            [disabled]=\"activeQuestionIndex === questionIndex\"><input [(ngModel)]=\"option.label\"\r\n                                \r\n                                [id]=\"'radio-' + '' + questionIndex + '' + opIndex\" type=\"text\" placeholder=\"Option\">\r\n                        </app-cs-radio>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n                    <!-- <li *ngIf=\"activeQuestionIndex === questionIndex && false\" class=\"add-new\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input type=\"text\" readonly placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\">\r\n                        </app-cs-radio>\r\n                    </li> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'select'\" \r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-radio [oneLine]=\"true\" readonly\r\n                            [disabled]=\"activeQuestionIndex === questionIndex\">\r\n                            <input [(ngModel)]=\"option.label\"\r\n                                name =\"'select-' + '' + questionIndex + '' + opIndex\" (keydown.enter)=\"addOption(questionIndex,opIndex,question.type)\"\r\n                                (keydown.backspace)=\"deleteOnBackspace(questionIndex,opIndex,question.type)\"\r\n                                [id]=\"'select-' + '' + questionIndex + '' + opIndex\" type=\"text\" placeholder=\"Option\">\r\n                        </app-cs-radio>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n<!-- \r\n                    <li *ngIf=\"activeQuestionIndex === questionIndex\" class=\"add-new\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\"><input readonly type=\"text\"\r\n                                placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\">\r\n                        </app-cs-radio>\r\n                    </li> -->\r\n                    <!-- <button (click)=\"addOption(questionIndex,question?.options?.length,question.type)\"\r\n                        *ngIf=\"activeQuestionIndex === questionIndex\">Add More Options</button> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div  class=\"checkpoints-questions-blocks\"\r\n            *ngIf=\"question?.type === 'checkbox'\" \r\n            [class.error]=\"errorIndex === questionIndex\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\">\r\n                    <span class=\"counter\">{{questionIndex+1}}. <span class=\"required\"\r\n                            *ngIf=\"question.required\">*</span></span>\r\n                    <input class=\"text\" type=\"text\" [placeholder]=\"placeholder[question.type]\"\r\n                        [(ngModel)]=\"question.label\"readonly>\r\n                </h3>\r\n                <ul class=\"list\">\r\n                    <li *ngFor=\"let option of question?.options; let opIndex = index\">\r\n                        <app-cs-checkbox [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input [(ngModel)]=\"option.label\" type=\"text\" placeholder=\"Option\"\r\n                                [id]=\"'checkbox-' + '' + questionIndex + '' + opIndex\"\r\n                                (keydown.enter)=\"addOption(questionIndex,opIndex,question.type)\"\r\n                                (keydown.backspace)=\"deleteOnBackspace(questionIndex,opIndex,question.type)\">\r\n                        </app-cs-checkbox>\r\n                        <!-- <button class=\"close\" (click)=\"deleteOption(questionIndex,opIndex,question.type)\"\r\n                            *ngIf=\"activeQuestionIndex === questionIndex && question?.options.length > 1\"><i\r\n                                class=\"icons\">&#xe90d;</i></button> -->\r\n                    </li>\r\n                    <!-- <li *ngIf=\"activeQuestionIndex === questionIndex\" class=\"add-new\">\r\n                        <app-cs-checkbox [oneLine]=\"true\"\r\n                            (click)=\"addOption(questionIndex,question?.options?.length-1,question.type)\"\r\n                            [disabled]=\"true\">\r\n                            <input [disabled]=\"true\" type=\"text\" placeholder=\"Add more option\">\r\n                        </app-cs-checkbox>\r\n                    </li> -->\r\n                </ul>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is\r\n                        required</app-cs-checkbox>\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"blankClone(question.type,questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li> -->\r\n                        <li>\r\n                            <button class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\"\r\n                                [tooltipMandatory]=\"true\"\r\n                                (click)=\"removeQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <!-- <li>\r\n                            <button [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\"\r\n                                (click)=\"cloneQuestion(questionIndex);$event.stopPropagation();\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li> -->\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <!-- <div class=\"checkpoints-questions-blocks\" [class.active]=\"true\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\">2. <span class=\"required\">*</span></span>\r\n                <input class=\"text\" type=\"text\" placeholder=\"Type your question here [Select Box]\" value=\"Has the previous audit report been closed out?\">\r\n            </h3>\r\n            <ul class=\"list\">\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>Yes</span></app-cs-radio> <button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>No</span></app-cs-radio><button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><span>N/A</span></app-cs-radio><button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n                <li>\r\n                    <app-cs-radio [oneLine]=\"true\"><input type=\"text\" placeholder=\"Option\"></app-cs-radio> <button class=\"close\"><i class=\"icons\">&#xe90d;</i></button>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n        <div class=\"footer\">\r\n            <div class=\"left\">\r\n                <app-cs-checkbox [ngValue]=\"question.required\" (ngValueChange)=\"question.required = $event\">Is required</app-cs-checkbox>\r\n            </div>\r\n            <div class=\"right\">\r\n                <ul>\r\n                    <li><button><i class=\"icons\">&#xe915;</i></button></li>\r\n                    <li><button><i class=\"icons\">&#xe923;</i></button></li>\r\n                    <li><button><i class=\"icons\">&#xe9b6;</i></button></li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n    </div> -->\r\n    </ng-container>\r\n    <!-- <button class=\"btn-add-new\" type=\"button\" appPopover (click)=\"newCheckpoint.popover()\" placement=\"left\">+ Add a new\r\n        checkpoint</button> -->\r\n    <!-- <app-popover #newCheckpoint>\r\n\r\n        <ul class=\"checkpoint-type-list\">\r\n            <li><span class=\"checkpoint-type-list-title\">Add Checkpoints</span></li>\r\n            <li *ngFor=\"let type of questionTypeList\">\r\n                <button (click)=\"addQuestion(type)\">\r\n                    <i class=\"icons\" [innerHTML]=\"type.icon\"></i>\r\n                    <span class=\"value\">\r\n                        {{type?.text}}\r\n                    </span>\r\n                </button>\r\n            </li>\r\n        </ul>\r\n    </app-popover> -->\r\n</div>\r\n"]}
@@ -1,5 +1,5 @@
1
1
  import cloneDeep from 'lodash-es/cloneDeep';
2
- import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "./../../../ui-kit/snack-bar/snack-bar.service";
5
5
  import * as i2 from "../checkpoints-policy-questions/checkpoints-policy-questions.component";
@@ -16,14 +16,13 @@ export class CheckpointsPolicyContainerComponent {
16
16
  ngOnInit() {
17
17
  this.checkpointData = cloneDeep(this.checkpointData);
18
18
  if (this.checkpointData.length === 0) {
19
- this.checkpointData = [{
20
- "ranswer": "",
21
- "question": "",
22
- "answers": [
23
- "",
24
- ""
25
- ]
26
- }];
19
+ this.checkpointData = [
20
+ {
21
+ ranswer: '',
22
+ question: '',
23
+ answers: ['', ''],
24
+ },
25
+ ];
27
26
  }
28
27
  setTimeout(() => {
29
28
  this.animation = false;
@@ -42,7 +41,6 @@ export class CheckpointsPolicyContainerComponent {
42
41
  delete element._id;
43
42
  }
44
43
  });
45
- console.log(this.requiredPoint, this.checkpointData);
46
44
  if (this.requiredPoint > this.checkpointData.length) {
47
45
  this.snackbarService.show(`The points required to attest this policy cannot exceed ${this.checkpointData.length}.`);
48
46
  }
@@ -51,7 +49,10 @@ export class CheckpointsPolicyContainerComponent {
51
49
  this.snackbarService.show(`The points required to attest this policy cannot be 0`);
52
50
  }
53
51
  else {
54
- this.saveCheckPoint.emit({ requiredPoint: this.requiredPoint, checkpointDetails: this.checkpointData });
52
+ this.saveCheckPoint.emit({
53
+ requiredPoint: this.requiredPoint,
54
+ checkpointDetails: this.checkpointData,
55
+ });
55
56
  }
56
57
  }
57
58
  }
@@ -73,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
73
74
  }], checkpointData: [{
74
75
  type: Input
75
76
  }] } });
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL2NoZWNrcG9pbnQtcG9saWN5L2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIvY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL2NoZWNrcG9pbnQtcG9saWN5L2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIvY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFRLFNBQVMsTUFBTyxxQkFBcUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRMUYsTUFBTSxPQUFPLG1DQUFtQztJQUU5QyxZQUFvQixlQUFnQztRQUFoQyxvQkFBZSxHQUFmLGVBQWUsQ0FBaUI7UUFEcEQsY0FBUyxHQUFHLElBQUksQ0FBQztRQUVQLG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNyQyxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFckMsa0JBQWEsR0FBRyxDQUFDLENBQUM7UUFDbEIsbUJBQWMsR0FBUSxFQUFFLENBQUM7SUFMc0IsQ0FBQztJQU96RCxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3JELElBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ25DLElBQUksQ0FBQyxjQUFjLEdBQUcsQ0FBQztvQkFDckIsU0FBUyxFQUFFLEVBQUU7b0JBQ2IsVUFBVSxFQUFFLEVBQUU7b0JBQ2QsU0FBUyxFQUFFO3dCQUNULEVBQUU7d0JBQ0YsRUFBRTtxQkFDSDtpQkFDRixDQUFDLENBQUE7U0FDSDtRQUNELFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUN6QixDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDUixJQUFHLElBQUksQ0FBQyxhQUFhLEtBQUssQ0FBQyxFQUFDO1lBQzFCLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDO1NBQ3hCO0lBQ0gsQ0FBQztJQUdELElBQUk7UUFDSCxJQUFJLENBQUMsbUNBQW1DLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDMUQsQ0FBQztJQUNELGFBQWEsQ0FBQyxLQUFTO1FBQ3BCLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxDQUFDO1FBQzVCLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBVyxFQUFFLEVBQUU7WUFDM0MsSUFBRyxPQUFPLEVBQUUsR0FBRyxFQUFDO2dCQUNkLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQzthQUNwQjtRQUVGLENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUNyRCxJQUFHLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUM7WUFDL0MsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsMkRBQTJELElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQTtTQUN0SDthQUFJO1lBQ0gsSUFBRyxJQUFJLENBQUMsYUFBYSxHQUFHLENBQUMsRUFBQztnQkFDekIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsdURBQXVELENBQUMsQ0FBQTthQUNsRjtpQkFBSTtnQkFDSixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLGlCQUFpQixFQUFHLElBQUksQ0FBQyxjQUFjLEVBQUMsQ0FBQyxDQUFDO2FBQ3ZHO1NBRUY7SUFFSixDQUFDOztnSUFyRFUsbUNBQW1DO29IQUFuQyxtQ0FBbUMsNFdDVmhELGcwQ0FrQ0E7MkZEeEJhLG1DQUFtQztrQkFML0MsU0FBUzsrQkFDRSxrQ0FBa0M7c0dBT2xDLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csY0FBYztzQkFBdkIsTUFBTTtnQkFDb0MsbUNBQW1DO3NCQUE3RSxTQUFTO3VCQUFDLFlBQVksRUFBQyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7Z0JBQ2hDLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNuYWNrQmFyU2VydmljZSB9IGZyb20gJy4vLi4vLi4vLi4vdWkta2l0L3NuYWNrLWJhci9zbmFjay1iYXIuc2VydmljZSc7XHJcbmltcG9ydCAgY2xvbmVEZWVwICBmcm9tICdsb2Rhc2gtZXMvY2xvbmVEZWVwJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoZWNrcG9pbnRzUG9saWN5UXVlc3Rpb25zQ29tcG9uZW50IH0gZnJvbSAnLi4vY2hlY2twb2ludHMtcG9saWN5LXF1ZXN0aW9ucy9jaGVja3BvaW50cy1wb2xpY3ktcXVlc3Rpb25zLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1jaGVja3BvaW50cy1wb2xpY3ktY29udGFpbmVyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQubGVzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaGVja3BvaW50c1BvbGljeUNvbnRhaW5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgYW5pbWF0aW9uID0gdHJ1ZTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHNuYWNrYmFyU2VydmljZTogU25hY2tCYXJTZXJ2aWNlKSB7IH1cclxuICBAT3V0cHV0KCkgY2xvc2VDaGVja1BvaW50ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gIEBPdXRwdXQoKSBzYXZlQ2hlY2tQb2ludCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBAVmlld0NoaWxkKCdjaGVja3BvaW50Jyx7IHN0YXRpYzogZmFsc2UgfSkgQ2hlY2twb2ludHNQb2xpY3lRdWVzdGlvbnNDb21wb25lbnQhOiBDaGVja3BvaW50c1BvbGljeVF1ZXN0aW9uc0NvbXBvbmVudDtcclxuICBASW5wdXQoKSByZXF1aXJlZFBvaW50ID0gMDtcclxuICBASW5wdXQoKSBjaGVja3BvaW50RGF0YTogYW55ID0gW107XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5jaGVja3BvaW50RGF0YSA9IGNsb25lRGVlcCh0aGlzLmNoZWNrcG9pbnREYXRhKTtcclxuICAgIGlmKHRoaXMuY2hlY2twb2ludERhdGEubGVuZ3RoID09PSAwICl7XHJcbiAgICAgIHRoaXMuY2hlY2twb2ludERhdGEgPSBbe1xyXG4gICAgICAgIFwicmFuc3dlclwiOiBcIlwiLFxyXG4gICAgICAgIFwicXVlc3Rpb25cIjogXCJcIixcclxuICAgICAgICBcImFuc3dlcnNcIjogW1xyXG4gICAgICAgICAgXCJcIixcclxuICAgICAgICAgIFwiXCJcclxuICAgICAgICBdXHJcbiAgICAgIH1dXHJcbiAgICB9XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5hbmltYXRpb24gPSBmYWxzZTtcclxuICAgIH0sIDUwMCk7XHJcbiAgICBpZih0aGlzLnJlcXVpcmVkUG9pbnQgPT09IDApe1xyXG4gICAgICB0aGlzLnJlcXVpcmVkUG9pbnQgPSAxO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcblxyXG4gIG5leHQoKXtcclxuICAgdGhpcy5DaGVja3BvaW50c1BvbGljeVF1ZXN0aW9uc0NvbXBvbmVudC5zYXZlQ2hlY2tQb2ludCgpXHJcbiAgfVxyXG4gIHNhdmVRdWVzdGlvbnMoZXZlbnQ6YW55KXtcclxuICAgICB0aGlzLmNoZWNrcG9pbnREYXRhID0gZXZlbnQ7XHJcbiAgICAgdGhpcy5jaGVja3BvaW50RGF0YS5mb3JFYWNoKChlbGVtZW50OmFueSkgPT4ge1xyXG4gICAgICBpZihlbGVtZW50Py5faWQpe1xyXG4gICAgICAgIGRlbGV0ZSBlbGVtZW50Ll9pZDtcclxuICAgICAgfVxyXG5cclxuICAgICB9KTtcclxuICAgICBjb25zb2xlLmxvZyh0aGlzLnJlcXVpcmVkUG9pbnQsIHRoaXMuY2hlY2twb2ludERhdGEpO1xyXG4gICAgIGlmKHRoaXMucmVxdWlyZWRQb2ludCA+IHRoaXMuY2hlY2twb2ludERhdGEubGVuZ3RoKXtcclxuICAgICAgICAgdGhpcy5zbmFja2JhclNlcnZpY2Uuc2hvdyhgVGhlIHBvaW50cyByZXF1aXJlZCB0byBhdHRlc3QgdGhpcyBwb2xpY3kgY2Fubm90IGV4Y2VlZCAke3RoaXMuY2hlY2twb2ludERhdGEubGVuZ3RofS5gKVxyXG4gICAgIH1lbHNle1xyXG4gICAgICAgaWYodGhpcy5yZXF1aXJlZFBvaW50IDwgMSl7XHJcbiAgICAgICAgdGhpcy5zbmFja2JhclNlcnZpY2Uuc2hvdyhgVGhlIHBvaW50cyByZXF1aXJlZCB0byBhdHRlc3QgdGhpcyBwb2xpY3kgY2Fubm90IGJlIDBgKVxyXG4gICAgICAgfWVsc2V7XHJcbiAgICAgICAgdGhpcy5zYXZlQ2hlY2tQb2ludC5lbWl0KHtyZXF1aXJlZFBvaW50OiB0aGlzLnJlcXVpcmVkUG9pbnQsIGNoZWNrcG9pbnREZXRhaWxzIDogdGhpcy5jaGVja3BvaW50RGF0YX0pO1xyXG4gICAgICAgfVxyXG5cclxuICAgICB9XHJcblxyXG4gIH1cclxufVxyXG4iLCI8IS0tIDxwPmNoZWNrcG9pbnRzIHdvcmtzITwvcD4gLS0+XHJcbjxkaXYgY2xhc3M9XCJjaGVja3BvaW50c1wiIFtjbGFzcy5hbmltYXRlXT1cImFuaW1hdGlvblwiPlxyXG4gIDxkaXZcclxuICAgIGNsYXNzPVwiY2hlY2twb2ludHMtaGVhZCB2eC1kLWZsZXggdngtYWxpZ24tY2VudGVyIHZ4LWp1c3RpZnktYmV0d2VlbiB2eC1wbC00IHZ4LXByLTRcIlxyXG4gID5cclxuICAgIDxkaXYgY2xhc3M9XCJ2eC1mcy0xNCB2eC1mdy01MDAgdngtbGFiZWwtdHh0XCI+QWRkIFF1ZXN0aW9uczwvZGl2PlxyXG4gIDwvZGl2PlxyXG4gIDxkaXYgY2xhc3M9XCJjaGVja3BvaW50cy1ib2R5XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY2hlY2twb2ludHMtYm9keS1pbm5lciB2eC1tYi00XCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJjaGVja3BvaW50cy1ib2R5LWluc2lkZVwiPlxyXG4gICAgICAgIDwhLS0gPGFwcC1jaGVja3BvaW50cy1saXN0PjwvYXBwLWNoZWNrcG9pbnRzLWxpc3Q+IC0tPlxyXG4gICAgICAgIDxhcHAtY2hlY2twb2ludHMtcG9saWN5LXF1ZXN0aW9uc1xyXG4gICAgICAgICAgWyhyZXF1aXJlZFBvaW50KV09XCJyZXF1aXJlZFBvaW50XCJcclxuICAgICAgICAgIChjaGFuZ2VNYXgpPVwicmVxdWlyZWRQb2ludCA9ICRldmVudFwiXHJcbiAgICAgICAgICAjY2hlY2twb2ludFxyXG4gICAgICAgICAgW2NoZWNrcG9pbnREZXRhaWxzXT1cImNoZWNrcG9pbnREYXRhXCJcclxuICAgICAgICAgIChzYXZlVmFsaWRRdWVzdGlvbnMpPVwic2F2ZVF1ZXN0aW9ucygkZXZlbnQpXCJcclxuICAgICAgICA+PC9hcHAtY2hlY2twb2ludHMtcG9saWN5LXF1ZXN0aW9ucz5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuXHJcbiAgICA8ZGl2IGNsYXNzPVwiY2hlY2twb2ludHMtZm9vdGVyXCI+XHJcbiAgICAgIDxhcHAtY2hlY2twb2ludC1mbG9hdGluZy1iYXJcclxuICAgICAgICBbaXNQb2xpY3lDaGVja3BvaW50XT1cInRydWVcIlxyXG4gICAgICAgIChjbG9zZUxpc3QpPVwiY2xvc2VDaGVja1BvaW50LmVtaXQoKVwiXHJcbiAgICAgICAgW3BsdXJhbFRleHRdPVwiJ1F1ZXN0aW9ucyBzZWxlY3RlZCdcIlxyXG4gICAgICAgIFtzaW5ndWxhclRleHRdPVwiJ1F1ZXN0aW9uIHNlbGVjdGVkJ1wiXHJcbiAgICAgICAgKHNhdmVMaXN0KT1cIm5leHQoKVwiXHJcbiAgICAgICAgWyhyZXF1aXJlZFBvaW50KV09XCJyZXF1aXJlZFBvaW50XCJcclxuICAgICAgICBbY291bnRdPVwiY2hlY2twb2ludERhdGE/Lmxlbmd0aFwiXHJcbiAgICAgID48L2FwcC1jaGVja3BvaW50LWZsb2F0aW5nLWJhcj5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL2NoZWNrcG9pbnQtcG9saWN5L2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIvY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL2NoZWNrcG9pbnQtcG9saWN5L2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIvY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLFNBQVMsTUFBTSxxQkFBcUIsQ0FBQztBQUM1QyxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxFQUNOLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRdkIsTUFBTSxPQUFPLG1DQUFtQztJQUU5QyxZQUFvQixlQUFnQztRQUFoQyxvQkFBZSxHQUFmLGVBQWUsQ0FBaUI7UUFEcEQsY0FBUyxHQUFHLElBQUksQ0FBQztRQUVQLG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNyQyxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFHckMsa0JBQWEsR0FBRyxDQUFDLENBQUM7UUFDbEIsbUJBQWMsR0FBUSxFQUFFLENBQUM7SUFOcUIsQ0FBQztJQVF4RCxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3JELElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ3BDLElBQUksQ0FBQyxjQUFjLEdBQUc7Z0JBQ3BCO29CQUNFLE9BQU8sRUFBRSxFQUFFO29CQUNYLFFBQVEsRUFBRSxFQUFFO29CQUNaLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUM7aUJBQ2xCO2FBQ0YsQ0FBQztTQUNIO1FBQ0QsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUNSLElBQUksSUFBSSxDQUFDLGFBQWEsS0FBSyxDQUFDLEVBQUU7WUFDNUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUM7U0FDeEI7SUFDSCxDQUFDO0lBRUQsSUFBSTtRQUNGLElBQUksQ0FBQyxtQ0FBbUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUM1RCxDQUFDO0lBQ0QsYUFBYSxDQUFDLEtBQVU7UUFDdEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7UUFDNUIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFZLEVBQUUsRUFBRTtZQUMzQyxJQUFJLE9BQU8sRUFBRSxHQUFHLEVBQUU7Z0JBQ2hCLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQzthQUNwQjtRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFO1lBQ25ELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUN2QiwyREFBMkQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FDekYsQ0FBQztTQUNIO2FBQU07WUFDTCxJQUFJLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxFQUFFO2dCQUMxQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FDdkIsdURBQXVELENBQ3hELENBQUM7YUFDSDtpQkFBTTtnQkFDTCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztvQkFDdkIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO29CQUNqQyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsY0FBYztpQkFDdkMsQ0FBQyxDQUFDO2FBQ0o7U0FDRjtJQUNILENBQUM7O2dJQXZEVSxtQ0FBbUM7b0hBQW5DLG1DQUFtQyw0V0NqQmhELGcwQ0FrQ0E7MkZEakJhLG1DQUFtQztrQkFML0MsU0FBUzsrQkFDRSxrQ0FBa0M7c0dBT2xDLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csY0FBYztzQkFBdkIsTUFBTTtnQkFFUCxtQ0FBbUM7c0JBRGxDLFNBQVM7dUJBQUMsWUFBWSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRTtnQkFFakMsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU25hY2tCYXJTZXJ2aWNlIH0gZnJvbSAnLi8uLi8uLi8uLi91aS1raXQvc25hY2stYmFyL3NuYWNrLWJhci5zZXJ2aWNlJztcclxuaW1wb3J0IGNsb25lRGVlcCBmcm9tICdsb2Rhc2gtZXMvY2xvbmVEZWVwJztcclxuaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIElucHV0LFxyXG4gIE9uSW5pdCxcclxuICBPdXRwdXQsXHJcbiAgVmlld0NoaWxkLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDaGVja3BvaW50c1BvbGljeVF1ZXN0aW9uc0NvbXBvbmVudCB9IGZyb20gJy4uL2NoZWNrcG9pbnRzLXBvbGljeS1xdWVzdGlvbnMvY2hlY2twb2ludHMtcG9saWN5LXF1ZXN0aW9ucy5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtY2hlY2twb2ludHMtcG9saWN5LWNvbnRhaW5lcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NoZWNrcG9pbnRzLXBvbGljeS1jb250YWluZXIuY29tcG9uZW50Lmxlc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENoZWNrcG9pbnRzUG9saWN5Q29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBhbmltYXRpb24gPSB0cnVlO1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc25hY2tiYXJTZXJ2aWNlOiBTbmFja0JhclNlcnZpY2UpIHt9XHJcbiAgQE91dHB1dCgpIGNsb3NlQ2hlY2tQb2ludCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBAT3V0cHV0KCkgc2F2ZUNoZWNrUG9pbnQgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQFZpZXdDaGlsZCgnY2hlY2twb2ludCcsIHsgc3RhdGljOiBmYWxzZSB9KVxyXG4gIENoZWNrcG9pbnRzUG9saWN5UXVlc3Rpb25zQ29tcG9uZW50ITogQ2hlY2twb2ludHNQb2xpY3lRdWVzdGlvbnNDb21wb25lbnQ7XHJcbiAgQElucHV0KCkgcmVxdWlyZWRQb2ludCA9IDA7XHJcbiAgQElucHV0KCkgY2hlY2twb2ludERhdGE6IGFueSA9IFtdO1xyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuY2hlY2twb2ludERhdGEgPSBjbG9uZURlZXAodGhpcy5jaGVja3BvaW50RGF0YSk7XHJcbiAgICBpZiAodGhpcy5jaGVja3BvaW50RGF0YS5sZW5ndGggPT09IDApIHtcclxuICAgICAgdGhpcy5jaGVja3BvaW50RGF0YSA9IFtcclxuICAgICAgICB7XHJcbiAgICAgICAgICByYW5zd2VyOiAnJyxcclxuICAgICAgICAgIHF1ZXN0aW9uOiAnJyxcclxuICAgICAgICAgIGFuc3dlcnM6IFsnJywgJyddLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIF07XHJcbiAgICB9XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5hbmltYXRpb24gPSBmYWxzZTtcclxuICAgIH0sIDUwMCk7XHJcbiAgICBpZiAodGhpcy5yZXF1aXJlZFBvaW50ID09PSAwKSB7XHJcbiAgICAgIHRoaXMucmVxdWlyZWRQb2ludCA9IDE7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZXh0KCkge1xyXG4gICAgdGhpcy5DaGVja3BvaW50c1BvbGljeVF1ZXN0aW9uc0NvbXBvbmVudC5zYXZlQ2hlY2tQb2ludCgpO1xyXG4gIH1cclxuICBzYXZlUXVlc3Rpb25zKGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuY2hlY2twb2ludERhdGEgPSBldmVudDtcclxuICAgIHRoaXMuY2hlY2twb2ludERhdGEuZm9yRWFjaCgoZWxlbWVudDogYW55KSA9PiB7XHJcbiAgICAgIGlmIChlbGVtZW50Py5faWQpIHtcclxuICAgICAgICBkZWxldGUgZWxlbWVudC5faWQ7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gICAgaWYgKHRoaXMucmVxdWlyZWRQb2ludCA+IHRoaXMuY2hlY2twb2ludERhdGEubGVuZ3RoKSB7XHJcbiAgICAgIHRoaXMuc25hY2tiYXJTZXJ2aWNlLnNob3coXHJcbiAgICAgICAgYFRoZSBwb2ludHMgcmVxdWlyZWQgdG8gYXR0ZXN0IHRoaXMgcG9saWN5IGNhbm5vdCBleGNlZWQgJHt0aGlzLmNoZWNrcG9pbnREYXRhLmxlbmd0aH0uYFxyXG4gICAgICApO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgaWYgKHRoaXMucmVxdWlyZWRQb2ludCA8IDEpIHtcclxuICAgICAgICB0aGlzLnNuYWNrYmFyU2VydmljZS5zaG93KFxyXG4gICAgICAgICAgYFRoZSBwb2ludHMgcmVxdWlyZWQgdG8gYXR0ZXN0IHRoaXMgcG9saWN5IGNhbm5vdCBiZSAwYFxyXG4gICAgICAgICk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgdGhpcy5zYXZlQ2hlY2tQb2ludC5lbWl0KHtcclxuICAgICAgICAgIHJlcXVpcmVkUG9pbnQ6IHRoaXMucmVxdWlyZWRQb2ludCxcclxuICAgICAgICAgIGNoZWNrcG9pbnREZXRhaWxzOiB0aGlzLmNoZWNrcG9pbnREYXRhLFxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjwhLS0gPHA+Y2hlY2twb2ludHMgd29ya3MhPC9wPiAtLT5cclxuPGRpdiBjbGFzcz1cImNoZWNrcG9pbnRzXCIgW2NsYXNzLmFuaW1hdGVdPVwiYW5pbWF0aW9uXCI+XHJcbiAgPGRpdlxyXG4gICAgY2xhc3M9XCJjaGVja3BvaW50cy1oZWFkIHZ4LWQtZmxleCB2eC1hbGlnbi1jZW50ZXIgdngtanVzdGlmeS1iZXR3ZWVuIHZ4LXBsLTQgdngtcHItNFwiXHJcbiAgPlxyXG4gICAgPGRpdiBjbGFzcz1cInZ4LWZzLTE0IHZ4LWZ3LTUwMCB2eC1sYWJlbC10eHRcIj5BZGQgUXVlc3Rpb25zPC9kaXY+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cImNoZWNrcG9pbnRzLWJvZHlcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJjaGVja3BvaW50cy1ib2R5LWlubmVyIHZ4LW1iLTRcIj5cclxuICAgICAgPGRpdiBjbGFzcz1cImNoZWNrcG9pbnRzLWJvZHktaW5zaWRlXCI+XHJcbiAgICAgICAgPCEtLSA8YXBwLWNoZWNrcG9pbnRzLWxpc3Q+PC9hcHAtY2hlY2twb2ludHMtbGlzdD4gLS0+XHJcbiAgICAgICAgPGFwcC1jaGVja3BvaW50cy1wb2xpY3ktcXVlc3Rpb25zXHJcbiAgICAgICAgICBbKHJlcXVpcmVkUG9pbnQpXT1cInJlcXVpcmVkUG9pbnRcIlxyXG4gICAgICAgICAgKGNoYW5nZU1heCk9XCJyZXF1aXJlZFBvaW50ID0gJGV2ZW50XCJcclxuICAgICAgICAgICNjaGVja3BvaW50XHJcbiAgICAgICAgICBbY2hlY2twb2ludERldGFpbHNdPVwiY2hlY2twb2ludERhdGFcIlxyXG4gICAgICAgICAgKHNhdmVWYWxpZFF1ZXN0aW9ucyk9XCJzYXZlUXVlc3Rpb25zKCRldmVudClcIlxyXG4gICAgICAgID48L2FwcC1jaGVja3BvaW50cy1wb2xpY3ktcXVlc3Rpb25zPlxyXG4gICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG5cclxuICAgIDxkaXYgY2xhc3M9XCJjaGVja3BvaW50cy1mb290ZXJcIj5cclxuICAgICAgPGFwcC1jaGVja3BvaW50LWZsb2F0aW5nLWJhclxyXG4gICAgICAgIFtpc1BvbGljeUNoZWNrcG9pbnRdPVwidHJ1ZVwiXHJcbiAgICAgICAgKGNsb3NlTGlzdCk9XCJjbG9zZUNoZWNrUG9pbnQuZW1pdCgpXCJcclxuICAgICAgICBbcGx1cmFsVGV4dF09XCInUXVlc3Rpb25zIHNlbGVjdGVkJ1wiXHJcbiAgICAgICAgW3Npbmd1bGFyVGV4dF09XCInUXVlc3Rpb24gc2VsZWN0ZWQnXCJcclxuICAgICAgICAoc2F2ZUxpc3QpPVwibmV4dCgpXCJcclxuICAgICAgICBbKHJlcXVpcmVkUG9pbnQpXT1cInJlcXVpcmVkUG9pbnRcIlxyXG4gICAgICAgIFtjb3VudF09XCJjaGVja3BvaW50RGF0YT8ubGVuZ3RoXCJcclxuICAgICAgPjwvYXBwLWNoZWNrcG9pbnQtZmxvYXRpbmctYmFyPlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -30,8 +30,7 @@ export class CheckpointsPolicyQuestionsComponent {
30
30
  });
31
31
  }
32
32
  }
33
- ngOnInit() {
34
- }
33
+ ngOnInit() { }
35
34
  /**
36
35
  * Changes active question index
37
36
  * @param index
@@ -48,9 +47,7 @@ export class CheckpointsPolicyQuestionsComponent {
48
47
  const QUESTION = {
49
48
  ranswer: '',
50
49
  question: '',
51
- answers: [
52
- '', ''
53
- ]
50
+ answers: ['', ''],
54
51
  };
55
52
  this.checkPointQuestions.splice(index + 1, 0, QUESTION);
56
53
  }
@@ -64,10 +61,9 @@ export class CheckpointsPolicyQuestionsComponent {
64
61
  }
65
62
  deleteOption(questionIndex, optionIndex) {
66
63
  this.checkPointQuestions[questionIndex].answers.splice(optionIndex, 1);
67
- this.focusAnOption(questionIndex, (optionIndex - 1));
64
+ this.focusAnOption(questionIndex, optionIndex - 1);
68
65
  }
69
66
  focusAnOption(questionIndex, optionIndex) {
70
- console.log("focus", questionIndex, optionIndex);
71
67
  setTimeout(() => {
72
68
  const EL = document.getElementById('option' + '-' + questionIndex + '' + optionIndex);
73
69
  if (EL) {
@@ -76,7 +72,9 @@ export class CheckpointsPolicyQuestionsComponent {
76
72
  }, 10);
77
73
  }
78
74
  deleteOnBackspace(questionIndex, optionIndex) {
79
- if (this.checkPointQuestions[questionIndex].answers?.length > 2 && this.checkPointQuestions[questionIndex].answers[optionIndex].trim().length === 0) {
75
+ if (this.checkPointQuestions[questionIndex].answers?.length > 2 &&
76
+ this.checkPointQuestions[questionIndex].answers[optionIndex].trim()
77
+ .length === 0) {
80
78
  this.deleteOption(questionIndex, optionIndex);
81
79
  }
82
80
  }
@@ -86,9 +84,7 @@ export class CheckpointsPolicyQuestionsComponent {
86
84
  const QUESTION = {
87
85
  ranswer: '',
88
86
  question: '',
89
- answers: [
90
- '', ''
91
- ]
87
+ answers: ['', ''],
92
88
  };
93
89
  this.checkPointQuestions.push(QUESTION);
94
90
  this.requiredPoint = 1;
@@ -98,7 +94,8 @@ export class CheckpointsPolicyQuestionsComponent {
98
94
  }
99
95
  selectRightAnswer(evt, index, answerIndex) {
100
96
  if (evt) {
101
- this.checkPointQuestions[index].ranswer = this.checkPointQuestions[index][answerIndex];
97
+ this.checkPointQuestions[index].ranswer =
98
+ this.checkPointQuestions[index][answerIndex];
102
99
  this.rightAnswerIndex[index] = answerIndex;
103
100
  this.reValidate(index);
104
101
  }
@@ -124,31 +121,43 @@ export class CheckpointsPolicyQuestionsComponent {
124
121
  this.errorTracker = [];
125
122
  await this.checkPointQuestions.forEach((element, index) => {
126
123
  if (element.question.trim().length === 0) {
127
- this.errorTracker[index] = { type: 'QUESTION', message: 'Please add a question.' };
124
+ this.errorTracker[index] = {
125
+ type: 'QUESTION',
126
+ message: 'Please add a question.',
127
+ };
128
128
  }
129
129
  else {
130
130
  if (element.answers.length >= 2) {
131
131
  if (this.isOptionValid(element.answers) === false) {
132
- this.errorTracker[index] = { type: 'OPTION', message: 'You need to complete all the answer options.' };
132
+ this.errorTracker[index] = {
133
+ type: 'OPTION',
134
+ message: 'You need to complete all the answer options.',
135
+ };
133
136
  }
134
137
  else {
135
138
  if (this.checkDuplicate(element?.answers) === true) {
136
- this.errorTracker[index] = { type: 'OPTION', message: 'Two options cannot have same title.' };
139
+ this.errorTracker[index] = {
140
+ type: 'OPTION',
141
+ message: 'Two options cannot have same title.',
142
+ };
137
143
  }
138
144
  else {
139
145
  if (element?.ranswer?.length === 0) {
140
- this.errorTracker[index] = { type: 'OPTION', message: 'Select the correct answer choice for this question.' };
146
+ this.errorTracker[index] = {
147
+ type: 'OPTION',
148
+ message: 'Select the correct answer choice for this question.',
149
+ };
141
150
  }
142
151
  }
143
152
  }
144
153
  }
145
154
  }
146
155
  });
147
- console.log(this.checkPointQuestions);
148
156
  return this.errorTracker.length > 0 ? false : true;
149
157
  }
150
158
  isOptionValid(options) {
151
- if (options.length === options.filter((ele) => ele.trim().length > 0).length) {
159
+ if (options.length ===
160
+ options.filter((ele) => ele.trim().length > 0).length) {
152
161
  return true;
153
162
  }
154
163
  else {
@@ -185,4 +194,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
185
194
  }], saveValidQuestions: [{
186
195
  type: Output
187
196
  }] } });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkpoints-policy-questions.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n\r\n@Component({\r\n  selector: 'app-checkpoints-policy-questions',\r\n  templateUrl: './checkpoints-policy-questions.component.html',\r\n  styleUrls: ['./checkpoints-policy-questions.component.less']\r\n})\r\nexport class CheckpointsPolicyQuestionsComponent implements OnInit {\r\n  checkPointQuestions :any = [];\r\n  @Output() changeMax = new EventEmitter();\r\n  @Input() requiredPoint = 0;\r\n  @Output() requiredPointChange = new EventEmitter();\r\n  @Input() set checkpointDetails(value:any){\r\n       this.checkPointQuestions = value;\r\n       if(this.checkPointQuestions.length){\r\n         this.checkPointQuestions.forEach((element:any,index:number) => {\r\n            const answerIndex = element?.answers.indexOf(element?.ranswer);\r\n            if(answerIndex > -1 && element.ranswer.trim().length > 0){\r\n              this.rightAnswerIndex[index]=answerIndex;\r\n            }\r\n         });\r\n       }\r\n  }\r\n  @Output() saveValidQuestions = new EventEmitter();\r\n  activeQuestionIndex = 0 ;\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  errorTracker:any = [];\r\n  rightAnswerIndex :any = [];\r\n\r\n/**\r\n * Changes active question index\r\n * @param index\r\n */\r\nchangeActiveQuestion(index:number){\r\n     this.activeQuestionIndex = index;\r\n  }\r\n\r\ncloneQuestion(index: any, isBlank ?:boolean){\r\n  if(isBlank === false){\r\n    const COPY_ARR = JSON.parse(JSON.stringify(this.checkPointQuestions[index]));\r\n    this.checkPointQuestions.splice(index + 1, 0, COPY_ARR);\r\n  }\r\n  if(isBlank === true){\r\n    const QUESTION = {\r\n      ranswer : '',\r\n      question : '',\r\n      answers : [\r\n        '',''\r\n\r\n      ]\r\n    }\r\n    this.checkPointQuestions.splice(index + 1, 0, QUESTION);\r\n\r\n  }\r\n  this.changeActiveQuestion(index+1);\r\n  this.requiredPointChange.emit(this.requiredPoint +1)\r\n  //this.changeMax.emit(this.checkPointQuestions.length)\r\n}\r\n\r\naddOption(questionIndex:number, optionIndex :number){\r\n  this.checkPointQuestions[questionIndex].answers.splice(optionIndex + 1, 0, '');\r\n  this.focusAnOption(questionIndex, optionIndex + 1)\r\n}\r\ndeleteOption(questionIndex:number, optionIndex :number){\r\n  this.checkPointQuestions[questionIndex].answers.splice(optionIndex, 1);\r\n  this.focusAnOption(questionIndex, (optionIndex - 1))\r\n}\r\n\r\nfocusAnOption(questionIndex:number, optionIndex :number){\r\n  console.log(\"focus\",questionIndex,optionIndex)\r\n  setTimeout(() => {\r\n    const EL: any = document.getElementById('option' + '-' + questionIndex + '' + optionIndex);\r\n    if (EL) { EL.focus(); }\r\n  }, 10);\r\n}\r\n\r\ndeleteOnBackspace(questionIndex:number, optionIndex :number){\r\n  if(this.checkPointQuestions[questionIndex].answers?.length > 2 &&  this.checkPointQuestions[questionIndex].answers[optionIndex].trim().length === 0 ){\r\n    this.deleteOption(questionIndex,optionIndex);\r\n  }\r\n}\r\ndeleteQuestion(questionIndex:number){\r\n  this.checkPointQuestions.splice(questionIndex, 1);\r\n  if(this.checkPointQuestions.length === 0 ){\r\n    const QUESTION = {\r\n      ranswer : '',\r\n      question : '',\r\n      answers : [\r\n        '',''\r\n      ]\r\n    }\r\n    this.checkPointQuestions.push(QUESTION);\r\n    this.requiredPoint = 1;\r\n  }\r\n  //this.changeMax.emit(this.checkPointQuestions.length)\r\n  this.requiredPointChange.emit(this.requiredPoint - 1)\r\n}\r\nselectRightAnswer(evt:any, index: number,answerIndex:string){\r\n  if(evt){\r\n    this.checkPointQuestions[index].ranswer =  this.checkPointQuestions[index][answerIndex];\r\n    this.rightAnswerIndex[index] = answerIndex;\r\n    this.reValidate(index);\r\n  }\r\n}\r\n\r\nreValidate(questionIndex:number){\r\n  if(this.errorTracker[questionIndex]){\r\n    this.validateForm();\r\n  }\r\n}\r\n\r\n\r\n\r\nasync saveCheckPoint(){\r\n  const validStatus = await this.validateForm();\r\n  if(validStatus){\r\n    this.saveValidQuestions.emit(this.checkPointQuestions);\r\n  }\r\n}\r\n\r\nmapRightAnswers(){\r\n  this.checkPointQuestions.forEach((element:any,index:number) => {\r\n    element.ranswer =  element.answers[this.rightAnswerIndex[index]] ??'';\r\n  });\r\n}\r\nasync validateForm(){\r\n  await this.mapRightAnswers()\r\n  this.errorTracker = [];\r\n  await this.checkPointQuestions.forEach((element:any,index:number) => {\r\n    if(element.question.trim().length === 0){\r\n      this.errorTracker[index] = {type :'QUESTION',message: 'Please add a question.'}\r\n    }else{\r\n       if(element.answers.length  >=  2 ){\r\n           if(this.isOptionValid(element.answers) === false){\r\n            this.errorTracker[index] = {type :'OPTION',message: 'You need to complete all the answer options.'};\r\n\r\n           }else{\r\n             if(this.checkDuplicate(element?.answers) === true){\r\n              this.errorTracker[index] = {type :'OPTION',message: 'Two options cannot have same title.'}\r\n             }\r\n             else{\r\n               if(element?.ranswer?.length === 0){\r\n                this.errorTracker[index] = {type :'OPTION',message: 'Select the correct answer choice for this question.'}\r\n              }\r\n             }\r\n           }\r\n       }\r\n    }\r\n  });\r\n  console.log(this.checkPointQuestions);\r\n  return this.errorTracker.length > 0 ? false : true\r\n}\r\nisOptionValid(options:any){\r\n  if(options.length === options.filter((ele:any) => ele.trim().length > 0).length){\r\n    return true;\r\n  }else{\r\n    return false;\r\n  }\r\n}\r\ncheckDuplicate(arr :any ) {\r\n  let result = false;\r\n  // create a Set with array elements\r\n  const s = new Set(arr);\r\n  // compare the size of array and Set\r\n  if(arr.length !== s.size){\r\n     result = true;\r\n  }\r\n  return result;\r\n}\r\n\r\ntrackByFn(index: any, item: any) {\r\n  return index;\r\n}\r\n\r\n\r\n}\r\n","<div class=\"checkpoints-policy-questions\">\r\n    <!-- <div class=\"checkpoints-questions-blocks instruction\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\"><i class=\"icons\">&#xe932;</i></span>\r\n                <span class=\"text\">Add instruction</span>\r\n            </h3>\r\n        </div>\r\n    </div> -->\r\n    <!-- <small>\r\n      <pre>\r\n        {{checkPointQuestions |json}}\r\n      </pre>\r\n    </small> -->\r\n    <div class=\"checkpoints-policy-questions-top vx-d-flex vx-align-center vx-justify-between vx-pb-2 vx-mb-2\">\r\n        <div class=\"vx-d-flex vx-align-center\">\r\n            <span class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">TOTAL POINTS</span>\r\n            <span class=\"vx-fs-11 vx-paragraph-txt vx-mr-1\">(Each question carries 1 point)</span>\r\n            <div class=\"question-count vx-fs-12 vx-paragraph-txt vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center\">{{checkPointQuestions.length}}</div>\r\n        </div>\r\n        <div class=\"vx-d-flex vx-align-center\">\r\n            <span class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase\">POINTS REQUIRED TO ATTEST: <span class=\"vx-fs-14 vx-txt-red\">*</span></span>\r\n            <i class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\" appPopover (click)=\"policyPassing.popover()\" placement=\"right\">&#xe91f;</i>\r\n            <input class=\"attestInput\"  type=\"number\" [(ngModel)]=\"requiredPoint\" [max]=\"checkPointQuestions.length\"   onkeydown=\"return event.keyCode !== 190\" min=\"0\"\r\n            oninput=\"this.value = Math.abs(this.value);\" (ngModelChange)=\"requiredPointChange.emit(requiredPoint)\"/>\r\n            <app-popover #policyPassing [dontCloseonClick]=\"true\">\r\n                <div class=\"infoPopup\">\r\n                 Every correct answer choice carries 1 point. You can specify the total number of questions that the reader must answer correctly in order to attest the policy.\r\n                </div>\r\n            </app-popover>\r\n        </div>\r\n    </div>\r\n    <ng-container *ngFor=\"let questionValue of checkPointQuestions; let questionIndex = index\">\r\n      <!-- [class.error]=\"questionIndex === 0\" -->\r\n        <div class=\"checkpoints-policy-questions-blocks\" [appScrollInView]=\"activeQuestionIndex === questionIndex\"   [class.active]=\"activeQuestionIndex === questionIndex\" (click)=\"changeActiveQuestion(questionIndex)\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\" >\r\n                    <span class=\"counter\">{{questionIndex + 1}}.\r\n                      <!-- <span class=\"required\">*</span> -->\r\n                    </span>\r\n                    <input [appConditionalFocus]=\"activeQuestionIndex === questionIndex\" [(ngModel)]=\"questionValue.question\" class=\"text\" type=\"text\"\r\n                        placeholder=\"Type your question here\" (ngModelChange)=\"reValidate(questionIndex)\"\r\n                       >\r\n                </h3>\r\n                <p class=\"error-message\" *ngIf=\"errorTracker[questionIndex]?.type === 'QUESTION'\">{{errorTracker[questionIndex]?.message}}</p>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of questionValue.answers; let optionIndex = index;trackBy:trackByFn\">\r\n                        <app-cs-radio  [readonly]=\"option?.trim()?.length === 0\" [name]=\"'option-' + '' + questionIndex + '' + optionIndex\" [checked]=\"rightAnswerIndex[questionIndex] === optionIndex ? true  :false \"\r\n                        (checkedEvent)=\"selectRightAnswer($event,questionIndex,optionIndex)\" [oneLine]=\"true\" [id]=\"optionIndex + 'wee'\" >\r\n                          <input  [id]=\"'option-' + '' + questionIndex + '' + optionIndex\" (ngModelChange)=\"reValidate(questionIndex)\"\r\n                          (keydown.enter)=\"addOption(questionIndex,optionIndex)\"\r\n                          (keydown.backspace)=\"deleteOnBackspace(questionIndex,optionIndex)\"\r\n                          placeholder=\"Option\" [(ngModel)]=\"questionValue.answers[optionIndex]\" type=\"text\" placeholder=\"Option\" />\r\n                        </app-cs-radio>\r\n                        <button *ngIf=\"questionValue?.answers?.length > 2 && activeQuestionIndex === questionIndex\" (click)=\"deleteOption(questionIndex,optionIndex)\" class=\"close\" ><i class=\"icons\">&#xe90d;</i></button>\r\n                    </li>\r\n\r\n                    <li class=\"add-new\" *ngIf=\"activeQuestionIndex === questionIndex\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input type=\"text\" readonly placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,questionValue?.answers?.length-1)\">\r\n                        </app-cs-radio>\r\n                    </li>\r\n                </ul>\r\n                <p class=\"error-message\" *ngIf=\"errorTracker[questionIndex]?.type === 'OPTION'\">{{errorTracker[questionIndex]?.message}}</p>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <!-- <app-cs-checkbox>Is required</app-cs-checkbox> -->\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <li>\r\n                            <button (click)=\"cloneQuestion(questionIndex,true);$event.stopPropagation();\" [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button  (click)=\"deleteQuestion(questionIndex)\" class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button (click)=\"cloneQuestion(questionIndex,false);$event.stopPropagation();\" [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <button class=\"btn-add-new vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-d-flex vx-align-center vx-justify-center\" type=\"button\" (click)=\"cloneQuestion(checkPointQuestions.length -1,true);$event.stopPropagation();\">+ ADD A NEW QUESTION</button>\r\n</div>\r\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkpoints-policy-questions.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-checkpoints-policy-questions',\r\n  templateUrl: './checkpoints-policy-questions.component.html',\r\n  styleUrls: ['./checkpoints-policy-questions.component.less'],\r\n})\r\nexport class CheckpointsPolicyQuestionsComponent implements OnInit {\r\n  checkPointQuestions: any = [];\r\n  @Output() changeMax = new EventEmitter();\r\n  @Input() requiredPoint = 0;\r\n  @Output() requiredPointChange = new EventEmitter();\r\n  @Input() set checkpointDetails(value: any) {\r\n    this.checkPointQuestions = value;\r\n    if (this.checkPointQuestions.length) {\r\n      this.checkPointQuestions.forEach((element: any, index: number) => {\r\n        const answerIndex = element?.answers.indexOf(element?.ranswer);\r\n        if (answerIndex > -1 && element.ranswer.trim().length > 0) {\r\n          this.rightAnswerIndex[index] = answerIndex;\r\n        }\r\n      });\r\n    }\r\n  }\r\n  @Output() saveValidQuestions = new EventEmitter();\r\n  activeQuestionIndex = 0;\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  errorTracker: any = [];\r\n  rightAnswerIndex: any = [];\r\n\r\n  /**\r\n   * Changes active question index\r\n   * @param index\r\n   */\r\n  changeActiveQuestion(index: number) {\r\n    this.activeQuestionIndex = index;\r\n  }\r\n\r\n  cloneQuestion(index: any, isBlank?: boolean) {\r\n    if (isBlank === false) {\r\n      const COPY_ARR = JSON.parse(\r\n        JSON.stringify(this.checkPointQuestions[index])\r\n      );\r\n      this.checkPointQuestions.splice(index + 1, 0, COPY_ARR);\r\n    }\r\n    if (isBlank === true) {\r\n      const QUESTION = {\r\n        ranswer: '',\r\n        question: '',\r\n        answers: ['', ''],\r\n      };\r\n      this.checkPointQuestions.splice(index + 1, 0, QUESTION);\r\n    }\r\n    this.changeActiveQuestion(index + 1);\r\n    this.requiredPointChange.emit(this.requiredPoint + 1);\r\n    //this.changeMax.emit(this.checkPointQuestions.length)\r\n  }\r\n\r\n  addOption(questionIndex: number, optionIndex: number) {\r\n    this.checkPointQuestions[questionIndex].answers.splice(\r\n      optionIndex + 1,\r\n      0,\r\n      ''\r\n    );\r\n    this.focusAnOption(questionIndex, optionIndex + 1);\r\n  }\r\n  deleteOption(questionIndex: number, optionIndex: number) {\r\n    this.checkPointQuestions[questionIndex].answers.splice(optionIndex, 1);\r\n    this.focusAnOption(questionIndex, optionIndex - 1);\r\n  }\r\n\r\n  focusAnOption(questionIndex: number, optionIndex: number) {\r\n    setTimeout(() => {\r\n      const EL: any = document.getElementById(\r\n        'option' + '-' + questionIndex + '' + optionIndex\r\n      );\r\n      if (EL) {\r\n        EL.focus();\r\n      }\r\n    }, 10);\r\n  }\r\n\r\n  deleteOnBackspace(questionIndex: number, optionIndex: number) {\r\n    if (\r\n      this.checkPointQuestions[questionIndex].answers?.length > 2 &&\r\n      this.checkPointQuestions[questionIndex].answers[optionIndex].trim()\r\n        .length === 0\r\n    ) {\r\n      this.deleteOption(questionIndex, optionIndex);\r\n    }\r\n  }\r\n  deleteQuestion(questionIndex: number) {\r\n    this.checkPointQuestions.splice(questionIndex, 1);\r\n    if (this.checkPointQuestions.length === 0) {\r\n      const QUESTION = {\r\n        ranswer: '',\r\n        question: '',\r\n        answers: ['', ''],\r\n      };\r\n      this.checkPointQuestions.push(QUESTION);\r\n      this.requiredPoint = 1;\r\n    }\r\n    //this.changeMax.emit(this.checkPointQuestions.length)\r\n    this.requiredPointChange.emit(this.requiredPoint - 1);\r\n  }\r\n  selectRightAnswer(evt: any, index: number, answerIndex: string) {\r\n    if (evt) {\r\n      this.checkPointQuestions[index].ranswer =\r\n        this.checkPointQuestions[index][answerIndex];\r\n      this.rightAnswerIndex[index] = answerIndex;\r\n      this.reValidate(index);\r\n    }\r\n  }\r\n\r\n  reValidate(questionIndex: number) {\r\n    if (this.errorTracker[questionIndex]) {\r\n      this.validateForm();\r\n    }\r\n  }\r\n\r\n  async saveCheckPoint() {\r\n    const validStatus = await this.validateForm();\r\n    if (validStatus) {\r\n      this.saveValidQuestions.emit(this.checkPointQuestions);\r\n    }\r\n  }\r\n\r\n  mapRightAnswers() {\r\n    this.checkPointQuestions.forEach((element: any, index: number) => {\r\n      element.ranswer = element.answers[this.rightAnswerIndex[index]] ?? '';\r\n    });\r\n  }\r\n  async validateForm() {\r\n    await this.mapRightAnswers();\r\n    this.errorTracker = [];\r\n    await this.checkPointQuestions.forEach((element: any, index: number) => {\r\n      if (element.question.trim().length === 0) {\r\n        this.errorTracker[index] = {\r\n          type: 'QUESTION',\r\n          message: 'Please add a question.',\r\n        };\r\n      } else {\r\n        if (element.answers.length >= 2) {\r\n          if (this.isOptionValid(element.answers) === false) {\r\n            this.errorTracker[index] = {\r\n              type: 'OPTION',\r\n              message: 'You need to complete all the answer options.',\r\n            };\r\n          } else {\r\n            if (this.checkDuplicate(element?.answers) === true) {\r\n              this.errorTracker[index] = {\r\n                type: 'OPTION',\r\n                message: 'Two options cannot have same title.',\r\n              };\r\n            } else {\r\n              if (element?.ranswer?.length === 0) {\r\n                this.errorTracker[index] = {\r\n                  type: 'OPTION',\r\n                  message:\r\n                    'Select the correct answer choice for this question.',\r\n                };\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    });\r\n    return this.errorTracker.length > 0 ? false : true;\r\n  }\r\n  isOptionValid(options: any) {\r\n    if (\r\n      options.length ===\r\n      options.filter((ele: any) => ele.trim().length > 0).length\r\n    ) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  checkDuplicate(arr: any) {\r\n    let result = false;\r\n    // create a Set with array elements\r\n    const s = new Set(arr);\r\n    // compare the size of array and Set\r\n    if (arr.length !== s.size) {\r\n      result = true;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  trackByFn(index: any, item: any) {\r\n    return index;\r\n  }\r\n}\r\n","<div class=\"checkpoints-policy-questions\">\r\n    <!-- <div class=\"checkpoints-questions-blocks instruction\">\r\n        <div class=\"container\">\r\n            <h3 class=\"question\">\r\n                <span class=\"counter\"><i class=\"icons\">&#xe932;</i></span>\r\n                <span class=\"text\">Add instruction</span>\r\n            </h3>\r\n        </div>\r\n    </div> -->\r\n    <!-- <small>\r\n      <pre>\r\n        {{checkPointQuestions |json}}\r\n      </pre>\r\n    </small> -->\r\n    <div class=\"checkpoints-policy-questions-top vx-d-flex vx-align-center vx-justify-between vx-pb-2 vx-mb-2\">\r\n        <div class=\"vx-d-flex vx-align-center\">\r\n            <span class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">TOTAL POINTS</span>\r\n            <span class=\"vx-fs-11 vx-paragraph-txt vx-mr-1\">(Each question carries 1 point)</span>\r\n            <div class=\"question-count vx-fs-12 vx-paragraph-txt vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center\">{{checkPointQuestions.length}}</div>\r\n        </div>\r\n        <div class=\"vx-d-flex vx-align-center\">\r\n            <span class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase\">POINTS REQUIRED TO ATTEST: <span class=\"vx-fs-14 vx-txt-red\">*</span></span>\r\n            <i class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\" appPopover (click)=\"policyPassing.popover()\" placement=\"right\">&#xe91f;</i>\r\n            <input class=\"attestInput\"  type=\"number\" [(ngModel)]=\"requiredPoint\" [max]=\"checkPointQuestions.length\"   onkeydown=\"return event.keyCode !== 190\" min=\"0\"\r\n            oninput=\"this.value = Math.abs(this.value);\" (ngModelChange)=\"requiredPointChange.emit(requiredPoint)\"/>\r\n            <app-popover #policyPassing [dontCloseonClick]=\"true\">\r\n                <div class=\"infoPopup\">\r\n                 Every correct answer choice carries 1 point. You can specify the total number of questions that the reader must answer correctly in order to attest the policy.\r\n                </div>\r\n            </app-popover>\r\n        </div>\r\n    </div>\r\n    <ng-container *ngFor=\"let questionValue of checkPointQuestions; let questionIndex = index\">\r\n      <!-- [class.error]=\"questionIndex === 0\" -->\r\n        <div class=\"checkpoints-policy-questions-blocks\" [appScrollInView]=\"activeQuestionIndex === questionIndex\"   [class.active]=\"activeQuestionIndex === questionIndex\" (click)=\"changeActiveQuestion(questionIndex)\">\r\n            <div class=\"container\">\r\n                <h3 class=\"question\" >\r\n                    <span class=\"counter\">{{questionIndex + 1}}.\r\n                      <!-- <span class=\"required\">*</span> -->\r\n                    </span>\r\n                    <input [appConditionalFocus]=\"activeQuestionIndex === questionIndex\" [(ngModel)]=\"questionValue.question\" class=\"text\" type=\"text\"\r\n                        placeholder=\"Type your question here\" (ngModelChange)=\"reValidate(questionIndex)\"\r\n                       >\r\n                </h3>\r\n                <p class=\"error-message\" *ngIf=\"errorTracker[questionIndex]?.type === 'QUESTION'\">{{errorTracker[questionIndex]?.message}}</p>\r\n                <ul class=\"list\">\r\n\r\n                    <li *ngFor=\"let option of questionValue.answers; let optionIndex = index;trackBy:trackByFn\">\r\n                        <app-cs-radio  [readonly]=\"option?.trim()?.length === 0\" [name]=\"'option-' + '' + questionIndex + '' + optionIndex\" [checked]=\"rightAnswerIndex[questionIndex] === optionIndex ? true  :false \"\r\n                        (checkedEvent)=\"selectRightAnswer($event,questionIndex,optionIndex)\" [oneLine]=\"true\" [id]=\"optionIndex + 'wee'\" >\r\n                          <input  [id]=\"'option-' + '' + questionIndex + '' + optionIndex\" (ngModelChange)=\"reValidate(questionIndex)\"\r\n                          (keydown.enter)=\"addOption(questionIndex,optionIndex)\"\r\n                          (keydown.backspace)=\"deleteOnBackspace(questionIndex,optionIndex)\"\r\n                          placeholder=\"Option\" [(ngModel)]=\"questionValue.answers[optionIndex]\" type=\"text\" placeholder=\"Option\" />\r\n                        </app-cs-radio>\r\n                        <button *ngIf=\"questionValue?.answers?.length > 2 && activeQuestionIndex === questionIndex\" (click)=\"deleteOption(questionIndex,optionIndex)\" class=\"close\" ><i class=\"icons\">&#xe90d;</i></button>\r\n                    </li>\r\n\r\n                    <li class=\"add-new\" *ngIf=\"activeQuestionIndex === questionIndex\">\r\n                        <app-cs-radio [oneLine]=\"true\" [readonly]=\"true\">\r\n                            <input type=\"text\" readonly placeholder=\"Add more option\"\r\n                                (click)=\"addOption(questionIndex,questionValue?.answers?.length-1)\">\r\n                        </app-cs-radio>\r\n                    </li>\r\n                </ul>\r\n                <p class=\"error-message\" *ngIf=\"errorTracker[questionIndex]?.type === 'OPTION'\">{{errorTracker[questionIndex]?.message}}</p>\r\n            </div>\r\n\r\n            <div class=\"footer\">\r\n                <div class=\"left\">\r\n                    <!-- <app-cs-checkbox>Is required</app-cs-checkbox> -->\r\n                </div>\r\n                <div class=\"right\">\r\n                    <ul>\r\n                        <li>\r\n                            <button (click)=\"cloneQuestion(questionIndex,true);$event.stopPropagation();\" [appTooltip]=\"'Add new'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe915;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button  (click)=\"deleteQuestion(questionIndex)\" class=\"delete\" [appTooltip]=\"'Delete'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe923;</i>\r\n                            </button>\r\n                        </li>\r\n                        <li>\r\n                            <button (click)=\"cloneQuestion(questionIndex,false);$event.stopPropagation();\" [appTooltip]=\"'Copy'\" placement=\"bottom\" delay=\"0\" [tooltipMandatory]=\"true\">\r\n                                <i class=\"icons\">&#xe9b6;</i>\r\n                            </button>\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <button class=\"btn-add-new vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-d-flex vx-align-center vx-justify-center\" type=\"button\" (click)=\"cloneQuestion(checkPointQuestions.length -1,true);$event.stopPropagation();\">+ ADD A NEW QUESTION</button>\r\n</div>\r\n"]}