@symphony-talent/component-library 4.195.0 → 4.196.0

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.
@@ -2,8 +2,8 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { AlertDuration, ToasterAlertModel, ToasterAlertType, } from '../../atoms/toaster-alert/toaster-alert.model';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../atoms/h4/h4.component";
5
- import * as i2 from "../../atoms/paragraph/paragraph.component";
6
- import * as i3 from "../../atoms/icon/icon.component";
5
+ import * as i2 from "../../atoms/icon/icon.component";
6
+ import * as i3 from "../../atoms/paragraph/paragraph.component";
7
7
  import * as i4 from "../../atoms/toaster-alert/toaster-alert.component";
8
8
  import * as i5 from "../../atoms/sfx-loader/sfx-loader.component";
9
9
  import * as i6 from "../../atoms/h5/h5.component";
@@ -93,10 +93,10 @@ export class MergeContactsModalComponent {
93
93
  }
94
94
  }
95
95
  MergeContactsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
96
- MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: i1.H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: i2.ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: i3.IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: i4.ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: i5.SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: i6.H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: i7.InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: i8.GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: i9.IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: i10.StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: i11.ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
96
+ MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: i1.H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: i2.IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: i3.ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: i4.ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: i5.SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: i6.H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: i7.InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: i8.GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: i9.IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: i10.StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: i11.ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
97
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, decorators: [{
98
98
  type: Component,
99
- args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
99
+ args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
100
100
  }], ctorParameters: function () { return []; }, propDecorators: { model: [{
101
101
  type: Input
102
102
  }], isLoading: [{
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
130
130
  }], currentStep: [{
131
131
  type: Input
132
132
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQ0wsYUFBYSxFQUNiLGlCQUFpQixFQUNqQixnQkFBZ0IsR0FDakIsTUFBTSwrQ0FBK0MsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7QUFPdkQsTUFBTSxPQUFPLDJCQUEyQjtJQXVCdEM7UUFyQlMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUNsRCxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUNsQyxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUdyQyxDQUFDO1FBQ0ssb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUM3RCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQzVDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDNUMsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQTBCLENBQUM7UUFDdEUsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUMzRCxhQUFRLEdBQWtDLElBQUks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QUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsYUFBYSxDQUFDLEVBQVU7UUFDdEIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakMsT0FBTyxHQUFHLE9BQU8sNkJBQTZCLEVBQUUsRUFBRSxDQUFDO0lBQ3JELENBQUM7O3dIQWpHVSwyQkFBMkI7NEdBQTNCLDJCQUEyQix3bUJDYnhDLG13TkF3SUE7MkZEM0hhLDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSwrQkFBK0I7MEVBS2hDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksSUFBSTtzQkFBYixNQUFNO2dCQUNHLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUlHLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csZ0JBQWdCO3NCQUF6QixNQUFNO2dCQUNHLGdCQUFnQjtzQkFBekIsTUFBTTtnQkFDRyx3QkFBd0I7c0JBQWpDLE1BQU07Z0JBQ0csOEJBQThCO3NCQUF2QyxNQUFNO2dCQUNFLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbCwgTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB9IGZyb20gJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwubW9kZWwnO1xuaW1wb3J0IHtcbiAgQWxlcnREdXJhdGlvbixcbiAgVG9hc3RlckFsZXJ0TW9kZWwsXG4gIFRvYXN0ZXJBbGVydFR5cGUsXG59IGZyb20gJy4uLy4uL2F0b21zL3RvYXN0ZXItYWxlcnQvdG9hc3Rlci1hbGVydC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3N5bXBob255LW1lcmdlLWNvbnRhY3RzLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21lcmdlLWNvbnRhY3RzLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNZXJnZUNvbnRhY3RzTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBtb2RlbDogTWVyZ2VDb250YWN0c01vZGFsTW9kZWw7XG4gIEBJbnB1dCgpIGlzTG9hZGluZyA9IGZhbHNlO1xuICBASW5wdXQoKSBoYXNFcnJvciA9IGZhbHNlO1xuICBAT3V0cHV0KCkgbmV4dCA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGNhbmNlbCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIG5vdER1cGxpY2F0ZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xuICAgIHNlbGVjdGVkOiBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbFsnc2VsZWN0ZWRDb250YWN0J107XG4gICAgc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbjtcbiAgfT4oKTtcbiAgQE91dHB1dCgpIHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGhpZGVTdWNjZXNzVG9hc3QgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIEBPdXRwdXQoKSBoaWRlRmFpbHVyZVRvYXN0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxNZXJnZUNvbnRhY3RTdWdnZXN0aW9uPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENhbmNlbENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBASW5wdXQoKSBzZWxlY3RlZDogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBjb25maXJtU3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBzaG93U3VjY2Vzc1RvYXN0ID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNob3dGYWlsdXJlVG9hc3QgPSBmYWxzZTtcbiAgQElucHV0KCkgY3VycmVudFN0ZXA6IG51bWJlciA9IDE7XG4gIHN1Y2Nlc3NUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG4gIGZhaWx1cmVUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0ID0gbmV3IFRvYXN0ZXJBbGVydE1vZGVsKCk7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LnR5cGUgPSBUb2FzdGVyQWxlcnRUeXBlLlN1Y2Nlc3M7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0Lm1lc3NhZ2UgPSBcIkNvbnRhY3QgcmVtb3ZlZCBmcm9tIGR1cGxpY2F0ZXMgc3VjY2Vzc2Z1bGx5XCI7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LmR1cmF0aW9uID0gQWxlcnREdXJhdGlvbi5GaXZlU2Vjb25kcztcbiAgdGhpcy5zdWNjZXNzVG9hc3Quc2hvd0Nsb3NlSWNvbiA9IHRydWU7XG5cbiAgdGhpcy5mYWlsdXJlVG9hc3QgPSBuZXcgVG9hc3RlckFsZXJ0TW9kZWwoKTtcbiAgdGhpcy5mYWlsdXJlVG9hc3QudHlwZSA9IFRvYXN0ZXJBbGVydFR5cGUuRXJyb3I7XG4gIHRoaXMuZmFpbHVyZVRvYXN0Lm1lc3NhZ2UgPSBcIkZhaWxlZCB0byByZW1vdmUgY29udGFjdCBmcm9tIGR1cGxpY2F0ZXNcIjtcbiAgdGhpcy5mYWlsdXJlVG9hc3QuZHVyYXRpb24gPSBBbGVydER1cmF0aW9uLkZpdmVTZWNvbmRzO1xuICB0aGlzLmZhaWx1cmVUb2FzdC5zaG93Q2xvc2VJY29uID0gdHJ1ZTtcbiAgfVxuXG4gIG9uTmV4dCgpIHtcbiAgICB0aGlzLm5leHQuZW1pdCh0aGlzLnNlbGVjdGVkKTtcbiAgfVxuXG4gIG9uQ2FuY2VsKCkge1xuICAgIHRoaXMuY2FuY2VsLmVtaXQoKTtcbiAgfVxuXG4gIG9uU2VsZWN0KHN1Z2dlc3Rpb246IE1lcmdlQ29udGFjdFN1Z2dlc3Rpb24pIHtcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHN1Z2dlc3Rpb24pO1xuICB9XG5cbiAgb25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbikge1xuICAgIHRoaXMucmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uLmVtaXQoc3VnZ2VzdGlvbik7XG4gIH1cblxuICBjYW5jZWxOb3REdXBsaWNhdGUoKSB7XG4gICAgdGhpcy5yZXF1ZXN0Q2FuY2VsQ29uZmlybVN1Z2dlc3Rpb24uZW1pdCgpO1xuICB9XG5cbiAgY29uZmlybU9uTm90RHVwbGljYXRlKCkge1xuICAgIGlmICh0aGlzLmNvbmZpcm1TdWdnZXN0aW9uKSB7XG4gICAgICB0aGlzLm5vdER1cGxpY2F0ZS5lbWl0KHtcbiAgICAgICAgc2VsZWN0ZWQ6IHRoaXMubW9kZWwuc2VsZWN0ZWRDb250YWN0LFxuICAgICAgICBzdWdnZXN0aW9uOiB0aGlzLmNvbmZpcm1TdWdnZXN0aW9uLFxuICAgICAgfSk7XG4gICAgIH1cbiAgfVxuXG4gIGhhbmRsZU5vdER1cGxpY2F0ZVN1Y2Nlc3MoKSB7XG4gICAgY29uc3QgcmVtb3ZlZCA9IHRoaXMuY29uZmlybVN1Z2dlc3Rpb247XG4gICAgaWYgKHJlbW92ZWQpIHtcbiAgICAgIHRoaXMubW9kZWwuc3VnZ2VzdGlvbnMgPSB0aGlzLm1vZGVsLnN1Z2dlc3Rpb25zLmZpbHRlcihcbiAgICAgICAgKHMpID0+IHMgIT09IHJlbW92ZWRcbiAgICAgICk7XG4gICAgICBpZiAodGhpcy5zZWxlY3RlZCA9PT0gcmVtb3ZlZCkge1xuICAgICAgICB0aGlzLnNlbGVjdGVkID0gbnVsbDtcbiAgICAgIH1cbiAgICAgIHRoaXMuY29uZmlybVN1Z2dlc3Rpb24gPSBudWxsO1xuICAgICAgdGhpcy5zaG93U3VjY2Vzc1RvYXN0ID0gdHJ1ZTtcbiAgICAgIHRoaXMuaXNMb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgaGFuZGxlTm90RHVwbGljYXRlRXJyb3IoKSB7XG4gICAgdGhpcy5zaG93RmFpbHVyZVRvYXN0ID0gdHJ1ZTtcbiAgICB0aGlzLmlzTG9hZGluZyA9IGZhbHNlO1xuICB9XG5cbiAgb25IaWRlU3VjY2Vzc1RvYXN0KCkge1xuICAgIHRoaXMuaGlkZVN1Y2Nlc3NUb2FzdC5lbWl0KCk7XG4gIH1cbiAgb25IaWRlRmFpbHVyZVRvYXN0KCkge1xuICAgIHRoaXMuaGlkZUZhaWx1cmVUb2FzdC5lbWl0KCk7XG4gIH1cblxuICBnZXRDb250YWN0VXJsKGlkOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHVybCA9IHdpbmRvdy5sb2NhdGlvbi5ocmVmO1xuICAgIGNvbnN0IFtiYXNlVXJsXSA9IHVybC5zcGxpdCgnIycpO1xuICAgIHJldHVybiBgJHtiYXNlVXJsfSMvY2FuZGlkYXRlcHJvZmlsZXZpZXc/aWQ9JHtpZH1gO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic2Z4IHNmeC1tb2RhbCBtb2RhbC1jb250YWluZXJcIiAqbmdJZj1cIm1vZGVsXCI+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtaGVhZGVyIHNmeC1wLTMwIHNmeC1wdC00MFwiPlxuICAgIDxkaXYgY2xhc3M9XCJtb2RhbC10aXRsZVwiPlxuICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTggY29sLXNtLTggY29sLW1kLTggY29sLWxnLThcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDQgdGV4dD1cIk1lcmdlIENvbnRhY3RzXCI+PC9zeW1waG9ueS1oND5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic2Z4LW10LTE1XCI+XG4gICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAxXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlN0ZXAgMSBvZiAyIC0gU2VsZWN0IHRoZSBkdXBsaWNhdGUgY29udGFjdCB0aGF0IG5lZWRzIHRvIGJlIG1lcmdlZC5cIlxuICAgICAgICAgICAgPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlN0ZXAgMiBvZiAyIC0gTWVyZ2UgZHVwbGljYXRlIGNvbnRhY3RzXCJcbiAgICAgICAgICAgID48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtNCBjb2wtc20tNCBjb2wtbWQtNCBjb2wtbGctNFwiPlxuICAgICAgICAgIDxzeW1waG9ueS1pY29uXG4gICAgICAgICAgICBjbGFzcz1cInB1bGwtcmlnaHRcIlxuICAgICAgICAgICAgW2ljb25dPVwiJ3NpLWNsb3NlLW1vZGFsJ1wiXG4gICAgICAgICAgICAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCJcbiAgICAgICAgICA+PC9zeW1waG9ueS1pY29uPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtYm9keSBzZngtcC0zMFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiPlxuICAgIDxkaXYgY2xhc3M9XCJ0b2FzdGVyLWFsZXJ0LWNvbnRhaW5lci1nbG9iYWxcIj5cbiAgICAgICAgPHN5bXBob255LXRvYXN0ZXItYWxlcnRcbiAgICAgICAgICAqbmdJZj1cInNob3dTdWNjZXNzVG9hc3RcIlxuICAgICAgICAgIFthbGVydE1vZGVsXT1cInN1Y2Nlc3NUb2FzdFwiXG4gICAgICAgICAgKGhpZGVBbGVydCk9XCJvbkhpZGVTdWNjZXNzVG9hc3QoKVwiXG4gICAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgICA8c3ltcGhvbnktdG9hc3Rlci1hbGVydFxuICAgICAgICAqbmdJZj1cInNob3dGYWlsdXJlVG9hc3RcIlxuICAgICAgICBbYWxlcnRNb2RlbF09XCJmYWlsdXJlVG9hc3RcIlxuICAgICAgICAoaGlkZUFsZXJ0KT1cIm9uSGlkZUZhaWx1cmVUb2FzdCgpXCJcbiAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgPC9kaXY+XG4gICAgPGRpdiAqbmdJZj1cImlzTG9hZGluZ1wiIGNsYXNzPVwic2Z4LW10LTMwIHNmeC1tYi0zMFwiPlxuICAgICAgPHN5bXBob255LXNmeC1sb2FkZXI+PC9zeW1waG9ueS1zZngtbG9hZGVyPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCJoYXNFcnJvclwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJTb21ldGhpbmcgaGFzIHdlbnQgd3JvbmcuIFRyeSBhZ2FpbiBsYXRlciBvciBjb250YWN0IHN1cHBvcnRcIj48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgKCFtb2RlbD8uc3VnZ2VzdGlvbnMgfHwgbW9kZWwuc3VnZ2VzdGlvbnMubGVuZ3RoID09PSAwKVwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJObyBtb3JlIGR1cGxpY2F0ZXMgZXhpc3QgZm9yIHRoaXMgc2VsZWN0ZWQgY29udGFjdC4gUGxlYXNlIHRyeSBhZ2FpbiBsYXRlclwiPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhaXNMb2FkaW5nICYmICFoYXNFcnJvciAmJiAhY29uZmlybVN1Z2dlc3Rpb24gJiYgbW9kZWw/LnN1Z2dlc3Rpb25zPy5sZW5ndGhcIiBjbGFzcz1cInJvd1wiPlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8cCBjbGFzcz1cInNmeC1tdC00MCBzZngtZm9udC1ib2xkXCI+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0Lm5hbWUgfX0gIFt7eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuaWQgfX1dPC9wPlxuICAgICAgICA8cD57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuZW1haWwgfX08L3A+XG4gICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS02IGNvbC1tZC02IGNvbC1sZy02XCI+XG4gICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvbnNcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250YWluZXJcIj5cbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3VnZ2VzdGlvbiBvZiBtb2RlbC5zdWdnZXN0aW9uc1wiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLWl0ZW1cIj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWlucHV0LXJhZGlvXG4gICAgICAgICAgICAgICAgW2xhYmVsXT1cInN1Z2dlc3Rpb24ubmFtZSArICcgWycgKyBzdWdnZXN0aW9uLmlkICsgJ10nXCJcbiAgICAgICAgICAgICAgICBbbmFtZV09XCInbWVyZ2Utc3VnZ2VzdGlvbnMnXCJcbiAgICAgICAgICAgICAgICBbaXNBY3RpdmVdPVwic2VsZWN0ZWQgPT09IHN1Z2dlc3Rpb25cIlxuICAgICAgICAgICAgICAgIChjbGlja2VkKT1cIm9uU2VsZWN0KHN1Z2dlc3Rpb24pXCJcbiAgICAgICAgICAgICAgPjwvc3ltcGhvbnktaW5wdXQtcmFkaW8+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1hY3Rpb24gc2Z4LW10LTMwXCI+XG4gICAgICAgICAgICAgIDxzeW1waG9ueS1ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIgY2xhc3M9XCJpY29uLXVwd2FyZHNcIlxuICAgICAgICAgICAgICAgIFtuZXdUYWJVcmxdPVwiZ2V0Q29udGFjdFVybChzdWdnZXN0aW9uLmlkKVwiXG4gICAgICAgICAgICAgID48L3N5bXBob255LWdyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWljb24td3JhcHBlciBjbGFzcz1cIm5vdC1kdXBsaWNhdGUtaWNvbi1nbG9iYWxcIlxuICAgICAgICAgICAgICAgIHRpdGxlPVwiTWFyayBub3QgZHVwbGljYXRlXCIgKGNsaWNrZWQpPVwib25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbilcIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBbaWNvbl09XCInc2ktZXhjbHVkZSdcIj48L3N5bXBob255LWljb24+XG4gICAgICAgICAgICAgIDwvc3ltcGhvbnktaWNvbi13cmFwcGVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1pdGVtXCI+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1kZXRhaWxzXCI+XG4gICAgICAgICAgICAgIDxkaXY+e3sgc3VnZ2VzdGlvbi5lbWFpbCB9fTwvZGl2PlxuICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2Ygc3VnZ2VzdGlvbi5jcml0ZXJpYVwiIGNsYXNzPVwic2Z4LW10LTVcIj57eyBjcml0ZXJpb24gfX08L2Rpdj5cbiAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3RhdHVzIG9mIHN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICAgIDxzeW1waG9ueS1zdGF0dXMtcGlsbCBbc3RhdHVzUGlsbE1vZGVsXT1cIntzdGF0dXNDbGFzczogJ3N0YXR1c0dyZXknLCB2YWx1ZTogc3RhdHVzfVwiPjwvc3ltcGhvbnktc3RhdHVzLXBpbGw+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgY29uZmlybVN1Z2dlc3Rpb25cIj5cbiAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIHJlbW92ZSB0aGlzIGNvbnRhY3QgYXMgYSBwb3RlbnRpYWwgZHVwbGljYXRlPyBcIj48L3N5bXBob255LWg1PlxuICAgICAgPGRpdiBjbGFzcz1cInNmeC1tdC0yMCByYWRpby1hY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBjbGFzcz1cInBlbmRpbmctaWNvblwiIFtpY29uXT1cIidzaS1wZW5kaW5nLWluY29tcGxldGUnXCI+PC9zeW1waG9ueS1pY29uPlxuICAgICAgPHN5bXBob255LXBhcmFncmFwaCBjbGFzcz1cInNmeC1mb250LWl0YWxpY1wiIHRleHQ9XCJEb2luZyBzbyBpcyBpcnJldmVyc2libGUgYW5kIHRoaXMgY29udGFjdCB3aWxsIG5ldmVyIGJlIHNob3duIGFzIGEgcG90ZW50aWFsIGR1cGxpY2F0ZSBvZiB0aGlzIGNvbnRhY3QgYWdhaW4uXCI+PC9zeW1waG9ueS1wYXJhZ3JhcGg+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJyb3cgc2Z4LW10LTMwXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtMTIgY29sLXNtLTYgY29sLW1kLTYgY29sLWxnLTZcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICAgIDxwIGNsYXNzPVwic2Z4LW10LTQwIHNmeC1mb250LWJvbGRcIj57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QubmFtZSB9fSAgW3t7IG1vZGVsLnNlbGVjdGVkQ29udGFjdC5pZCB9fV08L3A+XG4gICAgICAgICAgPHA+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmVtYWlsIH19PC9wPlxuICAgICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvblwiPjwvc3ltcGhvbnktaDU+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInN1Z2dlc3Rpb24tY29uZmlybVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNmeC1mb250LWJvbGRcIj57eyBjb25maXJtU3VnZ2VzdGlvbi5uYW1lIH19IFt7eyBjb25maXJtU3VnZ2VzdGlvbi5pZCB9fV08L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzZngtbXQtNVwiPnt7IGNvbmZpcm1TdWdnZXN0aW9uLmVtYWlsIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgY29uZmlybVN1Z2dlc3Rpb24uY3JpdGVyaWFcIiBjbGFzcz1cInNmeC1tdC01XCI+e3sgY3JpdGVyaW9uIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBzdGF0dXMgb2YgY29uZmlybVN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICA8c3ltcGhvbnktc3RhdHVzLXBpbGwgW3N0YXR1c1BpbGxNb2RlbF09XCJ7c3RhdHVzQ2xhc3M6ICdzdGF0dXNHcmV5JywgdmFsdWU6IHN0YXR1c31cIj48L3N5bXBob255LXN0YXR1cy1waWxsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29uZmlybS1hY3Rpb25zXCI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ2FuY2VsXCJcbiAgICAgICAgICBbaXNTZWNvbmRhcnldPVwidHJ1ZVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY2FuY2VsTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ29uZmlybVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY29uZmlybU9uTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGVudCAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCI+PC9uZy1jb250ZW50PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDFcIiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxuICAgIDxzeW1waG9ueS1idXR0b24tdjIgdGV4dD1cIkNsb3NlXCIgW2lzU2Vjb25kYXJ5XT1cInRydWVcIiAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgPHN5bXBob255LWJ1dHRvbi12MiB0ZXh0PVwiTmV4dFwiIFtkaXNhYmxlZF09XCIhc2VsZWN0ZWQgfHwgISFjb25maXJtU3VnZ2VzdGlvblwiIChjbGlja2VkKT1cIm9uTmV4dCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gIDwvc2VjdGlvbj5cbjwvZGl2PlxuIl19
133
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQ0wsYUFBYSxFQUNiLGlCQUFpQixFQUNqQixnQkFBZ0IsR0FDakIsTUFBTSwrQ0FBK0MsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7QUFPdkQsTUFBTSxPQUFPLDJCQUEyQjtJQXVCdEM7UUFyQlMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUNsRCxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUNsQyxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUdyQyxDQUFDO1FBQ0ssb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUM3RCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQzVDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDNUMsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQTBCLENBQUM7UUFDdEUsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUMzRCxhQUFRLEdBQWtDLElBQUks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QUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsYUFBYSxDQUFDLEVBQVU7UUFDdEIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakMsT0FBTyxHQUFHLE9BQU8sNkJBQTZCLEVBQUUsRUFBRSxDQUFDO0lBQ3JELENBQUM7O3dIQWpHVSwyQkFBMkI7NEdBQTNCLDJCQUEyQix3bUJDYnhDLGttT0F5SUE7MkZENUhhLDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSwrQkFBK0I7MEVBS2hDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksSUFBSTtzQkFBYixNQUFNO2dCQUNHLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUlHLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csZ0JBQWdCO3NCQUF6QixNQUFNO2dCQUNHLGdCQUFnQjtzQkFBekIsTUFBTTtnQkFDRyx3QkFBd0I7c0JBQWpDLE1BQU07Z0JBQ0csOEJBQThCO3NCQUF2QyxNQUFNO2dCQUNFLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbCwgTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB9IGZyb20gJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwubW9kZWwnO1xuaW1wb3J0IHtcbiAgQWxlcnREdXJhdGlvbixcbiAgVG9hc3RlckFsZXJ0TW9kZWwsXG4gIFRvYXN0ZXJBbGVydFR5cGUsXG59IGZyb20gJy4uLy4uL2F0b21zL3RvYXN0ZXItYWxlcnQvdG9hc3Rlci1hbGVydC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3N5bXBob255LW1lcmdlLWNvbnRhY3RzLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21lcmdlLWNvbnRhY3RzLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNZXJnZUNvbnRhY3RzTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBtb2RlbDogTWVyZ2VDb250YWN0c01vZGFsTW9kZWw7XG4gIEBJbnB1dCgpIGlzTG9hZGluZyA9IGZhbHNlO1xuICBASW5wdXQoKSBoYXNFcnJvciA9IGZhbHNlO1xuICBAT3V0cHV0KCkgbmV4dCA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGNhbmNlbCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIG5vdER1cGxpY2F0ZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xuICAgIHNlbGVjdGVkOiBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbFsnc2VsZWN0ZWRDb250YWN0J107XG4gICAgc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbjtcbiAgfT4oKTtcbiAgQE91dHB1dCgpIHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGhpZGVTdWNjZXNzVG9hc3QgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIEBPdXRwdXQoKSBoaWRlRmFpbHVyZVRvYXN0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxNZXJnZUNvbnRhY3RTdWdnZXN0aW9uPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENhbmNlbENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBASW5wdXQoKSBzZWxlY3RlZDogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBjb25maXJtU3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBzaG93U3VjY2Vzc1RvYXN0ID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNob3dGYWlsdXJlVG9hc3QgPSBmYWxzZTtcbiAgQElucHV0KCkgY3VycmVudFN0ZXA6IG51bWJlciA9IDE7XG4gIHN1Y2Nlc3NUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG4gIGZhaWx1cmVUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0ID0gbmV3IFRvYXN0ZXJBbGVydE1vZGVsKCk7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LnR5cGUgPSBUb2FzdGVyQWxlcnRUeXBlLlN1Y2Nlc3M7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0Lm1lc3NhZ2UgPSBcIkNvbnRhY3QgcmVtb3ZlZCBmcm9tIGR1cGxpY2F0ZXMgc3VjY2Vzc2Z1bGx5XCI7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LmR1cmF0aW9uID0gQWxlcnREdXJhdGlvbi5GaXZlU2Vjb25kcztcbiAgdGhpcy5zdWNjZXNzVG9hc3Quc2hvd0Nsb3NlSWNvbiA9IHRydWU7XG5cbiAgdGhpcy5mYWlsdXJlVG9hc3QgPSBuZXcgVG9hc3RlckFsZXJ0TW9kZWwoKTtcbiAgdGhpcy5mYWlsdXJlVG9hc3QudHlwZSA9IFRvYXN0ZXJBbGVydFR5cGUuRXJyb3I7XG4gIHRoaXMuZmFpbHVyZVRvYXN0Lm1lc3NhZ2UgPSBcIkZhaWxlZCB0byByZW1vdmUgY29udGFjdCBmcm9tIGR1cGxpY2F0ZXNcIjtcbiAgdGhpcy5mYWlsdXJlVG9hc3QuZHVyYXRpb24gPSBBbGVydER1cmF0aW9uLkZpdmVTZWNvbmRzO1xuICB0aGlzLmZhaWx1cmVUb2FzdC5zaG93Q2xvc2VJY29uID0gdHJ1ZTtcbiAgfVxuXG4gIG9uTmV4dCgpIHtcbiAgICB0aGlzLm5leHQuZW1pdCh0aGlzLnNlbGVjdGVkKTtcbiAgfVxuXG4gIG9uQ2FuY2VsKCkge1xuICAgIHRoaXMuY2FuY2VsLmVtaXQoKTtcbiAgfVxuXG4gIG9uU2VsZWN0KHN1Z2dlc3Rpb246IE1lcmdlQ29udGFjdFN1Z2dlc3Rpb24pIHtcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHN1Z2dlc3Rpb24pO1xuICB9XG5cbiAgb25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbikge1xuICAgIHRoaXMucmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uLmVtaXQoc3VnZ2VzdGlvbik7XG4gIH1cblxuICBjYW5jZWxOb3REdXBsaWNhdGUoKSB7XG4gICAgdGhpcy5yZXF1ZXN0Q2FuY2VsQ29uZmlybVN1Z2dlc3Rpb24uZW1pdCgpO1xuICB9XG5cbiAgY29uZmlybU9uTm90RHVwbGljYXRlKCkge1xuICAgIGlmICh0aGlzLmNvbmZpcm1TdWdnZXN0aW9uKSB7XG4gICAgICB0aGlzLm5vdER1cGxpY2F0ZS5lbWl0KHtcbiAgICAgICAgc2VsZWN0ZWQ6IHRoaXMubW9kZWwuc2VsZWN0ZWRDb250YWN0LFxuICAgICAgICBzdWdnZXN0aW9uOiB0aGlzLmNvbmZpcm1TdWdnZXN0aW9uLFxuICAgICAgfSk7XG4gICAgIH1cbiAgfVxuXG4gIGhhbmRsZU5vdER1cGxpY2F0ZVN1Y2Nlc3MoKSB7XG4gICAgY29uc3QgcmVtb3ZlZCA9IHRoaXMuY29uZmlybVN1Z2dlc3Rpb247XG4gICAgaWYgKHJlbW92ZWQpIHtcbiAgICAgIHRoaXMubW9kZWwuc3VnZ2VzdGlvbnMgPSB0aGlzLm1vZGVsLnN1Z2dlc3Rpb25zLmZpbHRlcihcbiAgICAgICAgKHMpID0+IHMgIT09IHJlbW92ZWRcbiAgICAgICk7XG4gICAgICBpZiAodGhpcy5zZWxlY3RlZCA9PT0gcmVtb3ZlZCkge1xuICAgICAgICB0aGlzLnNlbGVjdGVkID0gbnVsbDtcbiAgICAgIH1cbiAgICAgIHRoaXMuY29uZmlybVN1Z2dlc3Rpb24gPSBudWxsO1xuICAgICAgdGhpcy5zaG93U3VjY2Vzc1RvYXN0ID0gdHJ1ZTtcbiAgICAgIHRoaXMuaXNMb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgaGFuZGxlTm90RHVwbGljYXRlRXJyb3IoKSB7XG4gICAgdGhpcy5zaG93RmFpbHVyZVRvYXN0ID0gdHJ1ZTtcbiAgICB0aGlzLmlzTG9hZGluZyA9IGZhbHNlO1xuICB9XG5cbiAgb25IaWRlU3VjY2Vzc1RvYXN0KCkge1xuICAgIHRoaXMuaGlkZVN1Y2Nlc3NUb2FzdC5lbWl0KCk7XG4gIH1cbiAgb25IaWRlRmFpbHVyZVRvYXN0KCkge1xuICAgIHRoaXMuaGlkZUZhaWx1cmVUb2FzdC5lbWl0KCk7XG4gIH1cblxuICBnZXRDb250YWN0VXJsKGlkOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHVybCA9IHdpbmRvdy5sb2NhdGlvbi5ocmVmO1xuICAgIGNvbnN0IFtiYXNlVXJsXSA9IHVybC5zcGxpdCgnIycpO1xuICAgIHJldHVybiBgJHtiYXNlVXJsfSMvY2FuZGlkYXRlcHJvZmlsZXZpZXc/aWQ9JHtpZH1gO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic2Z4IHNmeC1tb2RhbCBtb2RhbC1jb250YWluZXJcIiAqbmdJZj1cIm1vZGVsXCI+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtaGVhZGVyIHNmeC1wLTMwIHNmeC1wdC00MFwiPlxuICAgIDxkaXYgY2xhc3M9XCJtb2RhbC10aXRsZVwiPlxuICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTggY29sLXNtLTggY29sLW1kLTggY29sLWxnLThcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDQgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiIHRleHQ9XCJNYW5hZ2UgRHVwbGljYXRlc1wiPjwvc3ltcGhvbnktaDQ+XG4gICAgICAgICAgPHN5bXBob255LWg0ICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDJcIiB0ZXh0PVwiTWVyZ2UgQ29udGFjdHNcIj48L3N5bXBob255LWg0PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy00IGNvbC1zbS00IGNvbC1tZC00IGNvbC1sZy00XCI+XG4gICAgICAgICAgPHN5bXBob255LWljb25cbiAgICAgICAgICAgIGNsYXNzPVwicHVsbC1yaWdodFwiXG4gICAgICAgICAgICBbaWNvbl09XCInc2ktY2xvc2UtbW9kYWwnXCJcbiAgICAgICAgICAgIChjbGlja2VkKT1cIm9uQ2FuY2VsKClcIlxuICAgICAgICAgID48L3N5bXBob255LWljb24+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS0xMiBjb2wtbWQtMTIgY29sLWxnLTEyIHNmeC1tdC0xNVwiPlxuICAgICAgICAgICAgIDxzeW1waG9ueS1wYXJhZ3JhcGhcbiAgICAgICAgICAgICAgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiXG4gICAgICAgICAgICAgIHRleHQ9XCJUaGUgY29udGFjdHMgYmVsb3cgYXJlIHBvdGVudGlhbCBkdXBsaWNhdGVzLiBQbGVhc2UgY29tcGFyZSB0aGVpciBkYXRhIGFuZCBzZWxlY3QgdGhlIG9uZSB5b3Ugd291bGQgbGlrZSB0byBtZXJnZS5cIlxuICAgICAgICAgICAgPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlVzaW5nIHRoZSBmaWVsZHMgYmVsb3csIGNob29zZSBhIFByaW1hcnkgQ29udGFjdCwgYW5kIHRoZW4gc2VsZWN0IHRoZSBkYXRhIHlvdSB3b3VsZCBsaWtlIHRvIG1lcmdlIGFuZCBrZWVwIGluIHRoYXQgUHJpbWFyeSBDb250YWN0IFJlY29yZC4gTWVyZ2luZyBjb250YWN0cyBpcyBpcnJldmVyc2libGUuXCJcbiAgICAgICAgICAgID48L3N5bXBob255LXBhcmFncmFwaD4gICAgICAgIFxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtYm9keSBzZngtcC0zMFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiPlxuICAgIDxkaXYgY2xhc3M9XCJ0b2FzdGVyLWFsZXJ0LWNvbnRhaW5lci1nbG9iYWxcIj5cbiAgICAgICAgPHN5bXBob255LXRvYXN0ZXItYWxlcnRcbiAgICAgICAgICAqbmdJZj1cInNob3dTdWNjZXNzVG9hc3RcIlxuICAgICAgICAgIFthbGVydE1vZGVsXT1cInN1Y2Nlc3NUb2FzdFwiXG4gICAgICAgICAgKGhpZGVBbGVydCk9XCJvbkhpZGVTdWNjZXNzVG9hc3QoKVwiXG4gICAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgICA8c3ltcGhvbnktdG9hc3Rlci1hbGVydFxuICAgICAgICAqbmdJZj1cInNob3dGYWlsdXJlVG9hc3RcIlxuICAgICAgICBbYWxlcnRNb2RlbF09XCJmYWlsdXJlVG9hc3RcIlxuICAgICAgICAoaGlkZUFsZXJ0KT1cIm9uSGlkZUZhaWx1cmVUb2FzdCgpXCJcbiAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgPC9kaXY+XG4gICAgPGRpdiAqbmdJZj1cImlzTG9hZGluZ1wiIGNsYXNzPVwic2Z4LW10LTMwIHNmeC1tYi0zMFwiPlxuICAgICAgPHN5bXBob255LXNmeC1sb2FkZXI+PC9zeW1waG9ueS1zZngtbG9hZGVyPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCJoYXNFcnJvclwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJTb21ldGhpbmcgaGFzIHdlbnQgd3JvbmcuIFRyeSBhZ2FpbiBsYXRlciBvciBjb250YWN0IHN1cHBvcnRcIj48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgKCFtb2RlbD8uc3VnZ2VzdGlvbnMgfHwgbW9kZWwuc3VnZ2VzdGlvbnMubGVuZ3RoID09PSAwKVwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJObyBtb3JlIGR1cGxpY2F0ZXMgZXhpc3QgZm9yIHRoaXMgc2VsZWN0ZWQgY29udGFjdC4gUGxlYXNlIHRyeSBhZ2FpbiBsYXRlclwiPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhaXNMb2FkaW5nICYmICFoYXNFcnJvciAmJiAhY29uZmlybVN1Z2dlc3Rpb24gJiYgbW9kZWw/LnN1Z2dlc3Rpb25zPy5sZW5ndGhcIiBjbGFzcz1cInJvd1wiPlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8cCBjbGFzcz1cInNmeC1tdC00MCBzZngtZm9udC1ib2xkXCI+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0Lm5hbWUgfX0gIFt7eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuaWQgfX1dPC9wPlxuICAgICAgICA8cD57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuZW1haWwgfX08L3A+XG4gICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS02IGNvbC1tZC02IGNvbC1sZy02XCI+XG4gICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiUG90ZW50aWFsIER1cGxpY2F0ZXNcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250YWluZXJcIj5cbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3VnZ2VzdGlvbiBvZiBtb2RlbC5zdWdnZXN0aW9uc1wiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLWl0ZW1cIj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWlucHV0LXJhZGlvXG4gICAgICAgICAgICAgICAgW2xhYmVsXT1cInN1Z2dlc3Rpb24ubmFtZSArICcgWycgKyBzdWdnZXN0aW9uLmlkICsgJ10nXCJcbiAgICAgICAgICAgICAgICBbbmFtZV09XCInbWVyZ2Utc3VnZ2VzdGlvbnMnXCJcbiAgICAgICAgICAgICAgICBbaXNBY3RpdmVdPVwic2VsZWN0ZWQgPT09IHN1Z2dlc3Rpb25cIlxuICAgICAgICAgICAgICAgIChjbGlja2VkKT1cIm9uU2VsZWN0KHN1Z2dlc3Rpb24pXCJcbiAgICAgICAgICAgICAgPjwvc3ltcGhvbnktaW5wdXQtcmFkaW8+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1hY3Rpb24gc2Z4LW10LTMwXCI+XG4gICAgICAgICAgICAgIDxzeW1waG9ueS1ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIgY2xhc3M9XCJpY29uLXVwd2FyZHNcIlxuICAgICAgICAgICAgICAgIFtuZXdUYWJVcmxdPVwiZ2V0Q29udGFjdFVybChzdWdnZXN0aW9uLmlkKVwiXG4gICAgICAgICAgICAgID48L3N5bXBob255LWdyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWljb24td3JhcHBlciBjbGFzcz1cIm5vdC1kdXBsaWNhdGUtaWNvbi1nbG9iYWxcIlxuICAgICAgICAgICAgICAgIHRpdGxlPVwiTWFyayBub3QgZHVwbGljYXRlXCIgKGNsaWNrZWQpPVwib25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbilcIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBbaWNvbl09XCInc2ktZXhjbHVkZSdcIj48L3N5bXBob255LWljb24+XG4gICAgICAgICAgICAgIDwvc3ltcGhvbnktaWNvbi13cmFwcGVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1pdGVtXCI+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1kZXRhaWxzXCI+XG4gICAgICAgICAgICAgIDxkaXY+e3sgc3VnZ2VzdGlvbi5lbWFpbCB9fTwvZGl2PlxuICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2Ygc3VnZ2VzdGlvbi5jcml0ZXJpYVwiIGNsYXNzPVwic2Z4LW10LTVcIj57eyBjcml0ZXJpb24gfX08L2Rpdj5cbiAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3RhdHVzIG9mIHN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICAgIDxzeW1waG9ueS1zdGF0dXMtcGlsbCBbc3RhdHVzUGlsbE1vZGVsXT1cIntzdGF0dXNDbGFzczogJ3N0YXR1c0dyZXknLCB2YWx1ZTogc3RhdHVzfVwiPjwvc3ltcGhvbnktc3RhdHVzLXBpbGw+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgY29uZmlybVN1Z2dlc3Rpb25cIj5cbiAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIHJlbW92ZSB0aGlzIGNvbnRhY3QgYXMgYSBwb3RlbnRpYWwgZHVwbGljYXRlPyBcIj48L3N5bXBob255LWg1PlxuICAgICAgPGRpdiBjbGFzcz1cInNmeC1tdC0yMCByYWRpby1hY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBjbGFzcz1cInBlbmRpbmctaWNvblwiIFtpY29uXT1cIidzaS1wZW5kaW5nLWluY29tcGxldGUnXCI+PC9zeW1waG9ueS1pY29uPlxuICAgICAgPHN5bXBob255LXBhcmFncmFwaCBjbGFzcz1cInNmeC1mb250LWl0YWxpY1wiIHRleHQ9XCJEb2luZyBzbyBpcyBpcnJldmVyc2libGUgYW5kIHRoaXMgY29udGFjdCB3aWxsIG5ldmVyIGJlIHNob3duIGFzIGEgcG90ZW50aWFsIGR1cGxpY2F0ZSBvZiB0aGlzIGNvbnRhY3QgYWdhaW4uXCI+PC9zeW1waG9ueS1wYXJhZ3JhcGg+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJyb3cgc2Z4LW10LTMwXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtMTIgY29sLXNtLTYgY29sLW1kLTYgY29sLWxnLTZcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICAgIDxwIGNsYXNzPVwic2Z4LW10LTQwIHNmeC1mb250LWJvbGRcIj57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QubmFtZSB9fSAgW3t7IG1vZGVsLnNlbGVjdGVkQ29udGFjdC5pZCB9fV08L3A+XG4gICAgICAgICAgPHA+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmVtYWlsIH19PC9wPlxuICAgICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvblwiPjwvc3ltcGhvbnktaDU+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInN1Z2dlc3Rpb24tY29uZmlybVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNmeC1mb250LWJvbGRcIj57eyBjb25maXJtU3VnZ2VzdGlvbi5uYW1lIH19IFt7eyBjb25maXJtU3VnZ2VzdGlvbi5pZCB9fV08L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzZngtbXQtNVwiPnt7IGNvbmZpcm1TdWdnZXN0aW9uLmVtYWlsIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgY29uZmlybVN1Z2dlc3Rpb24uY3JpdGVyaWFcIiBjbGFzcz1cInNmeC1tdC01XCI+e3sgY3JpdGVyaW9uIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBzdGF0dXMgb2YgY29uZmlybVN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICA8c3ltcGhvbnktc3RhdHVzLXBpbGwgW3N0YXR1c1BpbGxNb2RlbF09XCJ7c3RhdHVzQ2xhc3M6ICdzdGF0dXNHcmV5JywgdmFsdWU6IHN0YXR1c31cIj48L3N5bXBob255LXN0YXR1cy1waWxsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29uZmlybS1hY3Rpb25zXCI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ2FuY2VsXCJcbiAgICAgICAgICBbaXNTZWNvbmRhcnldPVwidHJ1ZVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY2FuY2VsTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ29uZmlybVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY29uZmlybU9uTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGVudCAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCI+PC9uZy1jb250ZW50PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDFcIiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxuICAgIDxzeW1waG9ueS1idXR0b24tdjIgdGV4dD1cIkNsb3NlXCIgW2lzU2Vjb25kYXJ5XT1cInRydWVcIiAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgPHN5bXBob255LWJ1dHRvbi12MiB0ZXh0PVwiTmV4dFwiIFtkaXNhYmxlZF09XCIhc2VsZWN0ZWQgfHwgISFjb25maXJtU3VnZ2VzdGlvblwiIChjbGlja2VkKT1cIm9uTmV4dCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gIDwvc2VjdGlvbj5cbjwvZGl2PlxuIl19
@@ -2,8 +2,8 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { AlertDuration, ToasterAlertModel, ToasterAlertType, } from '../../atoms/toaster-alert/toaster-alert.model';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../atoms/h4/h4.component";
5
- import * as i2 from "../../atoms/paragraph/paragraph.component";
6
- import * as i3 from "../../atoms/icon/icon.component";
5
+ import * as i2 from "../../atoms/icon/icon.component";
6
+ import * as i3 from "../../atoms/paragraph/paragraph.component";
7
7
  import * as i4 from "../../atoms/toaster-alert/toaster-alert.component";
8
8
  import * as i5 from "../../atoms/sfx-loader/sfx-loader.component";
9
9
  import * as i6 from "../../atoms/h5/h5.component";
@@ -93,10 +93,10 @@ export class MergeContactsModalComponent {
93
93
  }
94
94
  }
95
95
  MergeContactsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
96
- MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: i1.H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: i2.ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: i3.IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: i4.ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: i5.SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: i6.H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: i7.InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: i8.GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: i9.IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: i10.StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: i11.ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
96
+ MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: i1.H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: i2.IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: i3.ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: i4.ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: i5.SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: i6.H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: i7.InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: i8.GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: i9.IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: i10.StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: i11.ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
97
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, decorators: [{
98
98
  type: Component,
99
- args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
99
+ args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
100
100
  }], ctorParameters: function () { return []; }, propDecorators: { model: [{
101
101
  type: Input
102
102
  }], isLoading: [{
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
130
130
  }], currentStep: [{
131
131
  type: Input
132
132
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQ0wsYUFBYSxFQUNiLGlCQUFpQixFQUNqQixnQkFBZ0IsR0FDakIsTUFBTSwrQ0FBK0MsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7QUFPdkQsTUFBTSxPQUFPLDJCQUEyQjtJQXVCdEM7UUFyQlMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUNsRCxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUNsQyxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUdyQyxDQUFDO1FBQ0ssb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUM3RCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQzVDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDNUMsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQTBCLENBQUM7UUFDdEUsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUMzRCxhQUFR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QWtCO1FBQ2hCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsYUFBYSxDQUFDLEVBQVU7UUFDdEIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakMsT0FBTyxHQUFHLE9BQU8sNkJBQTZCLEVBQUUsRUFBRSxDQUFDO0lBQ3JELENBQUM7O3dIQWpHVSwyQkFBMkI7NEdBQTNCLDJCQUEyQix3bUJDYnhDLG13TkF3SUE7MkZEM0hhLDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSwrQkFBK0I7MEVBS2hDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksSUFBSTtzQkFBYixNQUFNO2dCQUNHLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUlHLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csZ0JBQWdCO3NCQUF6QixNQUFNO2dCQUNHLGdCQUFnQjtzQkFBekIsTUFBTTtnQkFDRyx3QkFBd0I7c0JBQWpDLE1BQU07Z0JBQ0csOEJBQThCO3NCQUF2QyxNQUFNO2dCQUNFLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbCwgTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB9IGZyb20gJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwubW9kZWwnO1xuaW1wb3J0IHtcbiAgQWxlcnREdXJhdGlvbixcbiAgVG9hc3RlckFsZXJ0TW9kZWwsXG4gIFRvYXN0ZXJBbGVydFR5cGUsXG59IGZyb20gJy4uLy4uL2F0b21zL3RvYXN0ZXItYWxlcnQvdG9hc3Rlci1hbGVydC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3N5bXBob255LW1lcmdlLWNvbnRhY3RzLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21lcmdlLWNvbnRhY3RzLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNZXJnZUNvbnRhY3RzTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBtb2RlbDogTWVyZ2VDb250YWN0c01vZGFsTW9kZWw7XG4gIEBJbnB1dCgpIGlzTG9hZGluZyA9IGZhbHNlO1xuICBASW5wdXQoKSBoYXNFcnJvciA9IGZhbHNlO1xuICBAT3V0cHV0KCkgbmV4dCA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGNhbmNlbCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIG5vdER1cGxpY2F0ZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xuICAgIHNlbGVjdGVkOiBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbFsnc2VsZWN0ZWRDb250YWN0J107XG4gICAgc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbjtcbiAgfT4oKTtcbiAgQE91dHB1dCgpIHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGhpZGVTdWNjZXNzVG9hc3QgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIEBPdXRwdXQoKSBoaWRlRmFpbHVyZVRvYXN0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxNZXJnZUNvbnRhY3RTdWdnZXN0aW9uPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENhbmNlbENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBASW5wdXQoKSBzZWxlY3RlZDogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBjb25maXJtU3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBzaG93U3VjY2Vzc1RvYXN0ID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNob3dGYWlsdXJlVG9hc3QgPSBmYWxzZTtcbiAgQElucHV0KCkgY3VycmVudFN0ZXA6IG51bWJlciA9IDE7XG4gIHN1Y2Nlc3NUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG4gIGZhaWx1cmVUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0ID0gbmV3IFRvYXN0ZXJBbGVydE1vZGVsKCk7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LnR5cGUgPSBUb2FzdGVyQWxlcnRUeXBlLlN1Y2Nlc3M7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0Lm1lc3NhZ2UgPSBcIkNvbnRhY3QgcmVtb3ZlZCBmcm9tIGR1cGxpY2F0ZXMgc3VjY2Vzc2Z1bGx5XCI7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LmR1cmF0aW9uID0gQWxlcnREdXJhdGlvbi5GaXZlU2Vjb25kcztcbiAgdGhpcy5zdWNjZXNzVG9hc3Quc2hvd0Nsb3NlSWNvbiA9IHRydWU7XG5cbiAgdGhpcy5mYWlsdXJlVG9hc3QgPSBuZXcgVG9hc3RlckFsZXJ0TW9kZWwoKTtcbiAgdGhpcy5mYWlsdXJlVG9hc3QudHlwZSA9IFRvYXN0ZXJBbGVydFR5cGUuRXJyb3I7XG4gIHRoaXMuZmFpbHVyZVRvYXN0Lm1lc3NhZ2UgPSBcIkZhaWxlZCB0byByZW1vdmUgY29udGFjdCBmcm9tIGR1cGxpY2F0ZXNcIjtcbiAgdGhpcy5mYWlsdXJlVG9hc3QuZHVyYXRpb24gPSBBbGVydER1cmF0aW9uLkZpdmVTZWNvbmRzO1xuICB0aGlzLmZhaWx1cmVUb2FzdC5zaG93Q2xvc2VJY29uID0gdHJ1ZTtcbiAgfVxuXG4gIG9uTmV4dCgpIHtcbiAgICB0aGlzLm5leHQuZW1pdCh0aGlzLnNlbGVjdGVkKTtcbiAgfVxuXG4gIG9uQ2FuY2VsKCkge1xuICAgIHRoaXMuY2FuY2VsLmVtaXQoKTtcbiAgfVxuXG4gIG9uU2VsZWN0KHN1Z2dlc3Rpb246IE1lcmdlQ29udGFjdFN1Z2dlc3Rpb24pIHtcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHN1Z2dlc3Rpb24pO1xuICB9XG5cbiAgb25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbikge1xuICAgIHRoaXMucmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uLmVtaXQoc3VnZ2VzdGlvbik7XG4gIH1cblxuICBjYW5jZWxOb3REdXBsaWNhdGUoKSB7XG4gICAgdGhpcy5yZXF1ZXN0Q2FuY2VsQ29uZmlybVN1Z2dlc3Rpb24uZW1pdCgpO1xuICB9XG5cbiAgY29uZmlybU9uTm90RHVwbGljYXRlKCkge1xuICAgIGlmICh0aGlzLmNvbmZpcm1TdWdnZXN0aW9uKSB7XG4gICAgICB0aGlzLm5vdER1cGxpY2F0ZS5lbWl0KHtcbiAgICAgICAgc2VsZWN0ZWQ6IHRoaXMubW9kZWwuc2VsZWN0ZWRDb250YWN0LFxuICAgICAgICBzdWdnZXN0aW9uOiB0aGlzLmNvbmZpcm1TdWdnZXN0aW9uLFxuICAgICAgfSk7XG4gICAgIH1cbiAgfVxuXG4gIGhhbmRsZU5vdER1cGxpY2F0ZVN1Y2Nlc3MoKSB7XG4gICAgY29uc3QgcmVtb3ZlZCA9IHRoaXMuY29uZmlybVN1Z2dlc3Rpb247XG4gICAgaWYgKHJlbW92ZWQpIHtcbiAgICAgIHRoaXMubW9kZWwuc3VnZ2VzdGlvbnMgPSB0aGlzLm1vZGVsLnN1Z2dlc3Rpb25zLmZpbHRlcihcbiAgICAgICAgKHMpID0+IHMgIT09IHJlbW92ZWRcbiAgICAgICk7XG4gICAgICBpZiAodGhpcy5zZWxlY3RlZCA9PT0gcmVtb3ZlZCkge1xuICAgICAgICB0aGlzLnNlbGVjdGVkID0gbnVsbDtcbiAgICAgIH1cbiAgICAgIHRoaXMuY29uZmlybVN1Z2dlc3Rpb24gPSBudWxsO1xuICAgICAgdGhpcy5zaG93U3VjY2Vzc1RvYXN0ID0gdHJ1ZTtcbiAgICAgIHRoaXMuaXNMb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgaGFuZGxlTm90RHVwbGljYXRlRXJyb3IoKSB7XG4gICAgdGhpcy5zaG93RmFpbHVyZVRvYXN0ID0gdHJ1ZTtcbiAgICB0aGlzLmlzTG9hZGluZyA9IGZhbHNlO1xuICB9XG5cbiAgb25IaWRlU3VjY2Vzc1RvYXN0KCkge1xuICAgIHRoaXMuaGlkZVN1Y2Nlc3NUb2FzdC5lbWl0KCk7XG4gIH1cbiAgb25IaWRlRmFpbHVyZVRvYXN0KCkge1xuICAgIHRoaXMuaGlkZUZhaWx1cmVUb2FzdC5lbWl0KCk7XG4gIH1cblxuICBnZXRDb250YWN0VXJsKGlkOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHVybCA9IHdpbmRvdy5sb2NhdGlvbi5ocmVmO1xuICAgIGNvbnN0IFtiYXNlVXJsXSA9IHVybC5zcGxpdCgnIycpO1xuICAgIHJldHVybiBgJHtiYXNlVXJsfSMvY2FuZGlkYXRlcHJvZmlsZXZpZXc/aWQ9JHtpZH1gO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic2Z4IHNmeC1tb2RhbCBtb2RhbC1jb250YWluZXJcIiAqbmdJZj1cIm1vZGVsXCI+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtaGVhZGVyIHNmeC1wLTMwIHNmeC1wdC00MFwiPlxuICAgIDxkaXYgY2xhc3M9XCJtb2RhbC10aXRsZVwiPlxuICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTggY29sLXNtLTggY29sLW1kLTggY29sLWxnLThcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDQgdGV4dD1cIk1lcmdlIENvbnRhY3RzXCI+PC9zeW1waG9ueS1oND5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic2Z4LW10LTE1XCI+XG4gICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAxXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlN0ZXAgMSBvZiAyIC0gU2VsZWN0IHRoZSBkdXBsaWNhdGUgY29udGFjdCB0aGF0IG5lZWRzIHRvIGJlIG1lcmdlZC5cIlxuICAgICAgICAgICAgPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlN0ZXAgMiBvZiAyIC0gTWVyZ2UgZHVwbGljYXRlIGNvbnRhY3RzXCJcbiAgICAgICAgICAgID48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtNCBjb2wtc20tNCBjb2wtbWQtNCBjb2wtbGctNFwiPlxuICAgICAgICAgIDxzeW1waG9ueS1pY29uXG4gICAgICAgICAgICBjbGFzcz1cInB1bGwtcmlnaHRcIlxuICAgICAgICAgICAgW2ljb25dPVwiJ3NpLWNsb3NlLW1vZGFsJ1wiXG4gICAgICAgICAgICAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCJcbiAgICAgICAgICA+PC9zeW1waG9ueS1pY29uPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtYm9keSBzZngtcC0zMFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiPlxuICAgIDxkaXYgY2xhc3M9XCJ0b2FzdGVyLWFsZXJ0LWNvbnRhaW5lci1nbG9iYWxcIj5cbiAgICAgICAgPHN5bXBob255LXRvYXN0ZXItYWxlcnRcbiAgICAgICAgICAqbmdJZj1cInNob3dTdWNjZXNzVG9hc3RcIlxuICAgICAgICAgIFthbGVydE1vZGVsXT1cInN1Y2Nlc3NUb2FzdFwiXG4gICAgICAgICAgKGhpZGVBbGVydCk9XCJvbkhpZGVTdWNjZXNzVG9hc3QoKVwiXG4gICAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgICA8c3ltcGhvbnktdG9hc3Rlci1hbGVydFxuICAgICAgICAqbmdJZj1cInNob3dGYWlsdXJlVG9hc3RcIlxuICAgICAgICBbYWxlcnRNb2RlbF09XCJmYWlsdXJlVG9hc3RcIlxuICAgICAgICAoaGlkZUFsZXJ0KT1cIm9uSGlkZUZhaWx1cmVUb2FzdCgpXCJcbiAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgPC9kaXY+XG4gICAgPGRpdiAqbmdJZj1cImlzTG9hZGluZ1wiIGNsYXNzPVwic2Z4LW10LTMwIHNmeC1tYi0zMFwiPlxuICAgICAgPHN5bXBob255LXNmeC1sb2FkZXI+PC9zeW1waG9ueS1zZngtbG9hZGVyPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCJoYXNFcnJvclwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJTb21ldGhpbmcgaGFzIHdlbnQgd3JvbmcuIFRyeSBhZ2FpbiBsYXRlciBvciBjb250YWN0IHN1cHBvcnRcIj48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgKCFtb2RlbD8uc3VnZ2VzdGlvbnMgfHwgbW9kZWwuc3VnZ2VzdGlvbnMubGVuZ3RoID09PSAwKVwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJObyBtb3JlIGR1cGxpY2F0ZXMgZXhpc3QgZm9yIHRoaXMgc2VsZWN0ZWQgY29udGFjdC4gUGxlYXNlIHRyeSBhZ2FpbiBsYXRlclwiPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhaXNMb2FkaW5nICYmICFoYXNFcnJvciAmJiAhY29uZmlybVN1Z2dlc3Rpb24gJiYgbW9kZWw/LnN1Z2dlc3Rpb25zPy5sZW5ndGhcIiBjbGFzcz1cInJvd1wiPlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8cCBjbGFzcz1cInNmeC1tdC00MCBzZngtZm9udC1ib2xkXCI+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0Lm5hbWUgfX0gIFt7eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuaWQgfX1dPC9wPlxuICAgICAgICA8cD57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuZW1haWwgfX08L3A+XG4gICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS02IGNvbC1tZC02IGNvbC1sZy02XCI+XG4gICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvbnNcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250YWluZXJcIj5cbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3VnZ2VzdGlvbiBvZiBtb2RlbC5zdWdnZXN0aW9uc1wiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLWl0ZW1cIj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWlucHV0LXJhZGlvXG4gICAgICAgICAgICAgICAgW2xhYmVsXT1cInN1Z2dlc3Rpb24ubmFtZSArICcgWycgKyBzdWdnZXN0aW9uLmlkICsgJ10nXCJcbiAgICAgICAgICAgICAgICBbbmFtZV09XCInbWVyZ2Utc3VnZ2VzdGlvbnMnXCJcbiAgICAgICAgICAgICAgICBbaXNBY3RpdmVdPVwic2VsZWN0ZWQgPT09IHN1Z2dlc3Rpb25cIlxuICAgICAgICAgICAgICAgIChjbGlja2VkKT1cIm9uU2VsZWN0KHN1Z2dlc3Rpb24pXCJcbiAgICAgICAgICAgICAgPjwvc3ltcGhvbnktaW5wdXQtcmFkaW8+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1hY3Rpb24gc2Z4LW10LTMwXCI+XG4gICAgICAgICAgICAgIDxzeW1waG9ueS1ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIgY2xhc3M9XCJpY29uLXVwd2FyZHNcIlxuICAgICAgICAgICAgICAgIFtuZXdUYWJVcmxdPVwiZ2V0Q29udGFjdFVybChzdWdnZXN0aW9uLmlkKVwiXG4gICAgICAgICAgICAgID48L3N5bXBob255LWdyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWljb24td3JhcHBlciBjbGFzcz1cIm5vdC1kdXBsaWNhdGUtaWNvbi1nbG9iYWxcIlxuICAgICAgICAgICAgICAgIHRpdGxlPVwiTWFyayBub3QgZHVwbGljYXRlXCIgKGNsaWNrZWQpPVwib25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbilcIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBbaWNvbl09XCInc2ktZXhjbHVkZSdcIj48L3N5bXBob255LWljb24+XG4gICAgICAgICAgICAgIDwvc3ltcGhvbnktaWNvbi13cmFwcGVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1pdGVtXCI+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1kZXRhaWxzXCI+XG4gICAgICAgICAgICAgIDxkaXY+e3sgc3VnZ2VzdGlvbi5lbWFpbCB9fTwvZGl2PlxuICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2Ygc3VnZ2VzdGlvbi5jcml0ZXJpYVwiIGNsYXNzPVwic2Z4LW10LTVcIj57eyBjcml0ZXJpb24gfX08L2Rpdj5cbiAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3RhdHVzIG9mIHN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICAgIDxzeW1waG9ueS1zdGF0dXMtcGlsbCBbc3RhdHVzUGlsbE1vZGVsXT1cIntzdGF0dXNDbGFzczogJ3N0YXR1c0dyZXknLCB2YWx1ZTogc3RhdHVzfVwiPjwvc3ltcGhvbnktc3RhdHVzLXBpbGw+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgY29uZmlybVN1Z2dlc3Rpb25cIj5cbiAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIHJlbW92ZSB0aGlzIGNvbnRhY3QgYXMgYSBwb3RlbnRpYWwgZHVwbGljYXRlPyBcIj48L3N5bXBob255LWg1PlxuICAgICAgPGRpdiBjbGFzcz1cInNmeC1tdC0yMCByYWRpby1hY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBjbGFzcz1cInBlbmRpbmctaWNvblwiIFtpY29uXT1cIidzaS1wZW5kaW5nLWluY29tcGxldGUnXCI+PC9zeW1waG9ueS1pY29uPlxuICAgICAgPHN5bXBob255LXBhcmFncmFwaCBjbGFzcz1cInNmeC1mb250LWl0YWxpY1wiIHRleHQ9XCJEb2luZyBzbyBpcyBpcnJldmVyc2libGUgYW5kIHRoaXMgY29udGFjdCB3aWxsIG5ldmVyIGJlIHNob3duIGFzIGEgcG90ZW50aWFsIGR1cGxpY2F0ZSBvZiB0aGlzIGNvbnRhY3QgYWdhaW4uXCI+PC9zeW1waG9ueS1wYXJhZ3JhcGg+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJyb3cgc2Z4LW10LTMwXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtMTIgY29sLXNtLTYgY29sLW1kLTYgY29sLWxnLTZcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICAgIDxwIGNsYXNzPVwic2Z4LW10LTQwIHNmeC1mb250LWJvbGRcIj57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QubmFtZSB9fSAgW3t7IG1vZGVsLnNlbGVjdGVkQ29udGFjdC5pZCB9fV08L3A+XG4gICAgICAgICAgPHA+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmVtYWlsIH19PC9wPlxuICAgICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvblwiPjwvc3ltcGhvbnktaDU+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInN1Z2dlc3Rpb24tY29uZmlybVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNmeC1mb250LWJvbGRcIj57eyBjb25maXJtU3VnZ2VzdGlvbi5uYW1lIH19IFt7eyBjb25maXJtU3VnZ2VzdGlvbi5pZCB9fV08L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzZngtbXQtNVwiPnt7IGNvbmZpcm1TdWdnZXN0aW9uLmVtYWlsIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgY29uZmlybVN1Z2dlc3Rpb24uY3JpdGVyaWFcIiBjbGFzcz1cInNmeC1tdC01XCI+e3sgY3JpdGVyaW9uIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBzdGF0dXMgb2YgY29uZmlybVN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICA8c3ltcGhvbnktc3RhdHVzLXBpbGwgW3N0YXR1c1BpbGxNb2RlbF09XCJ7c3RhdHVzQ2xhc3M6ICdzdGF0dXNHcmV5JywgdmFsdWU6IHN0YXR1c31cIj48L3N5bXBob255LXN0YXR1cy1waWxsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29uZmlybS1hY3Rpb25zXCI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ2FuY2VsXCJcbiAgICAgICAgICBbaXNTZWNvbmRhcnldPVwidHJ1ZVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY2FuY2VsTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ29uZmlybVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY29uZmlybU9uTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGVudCAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCI+PC9uZy1jb250ZW50PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDFcIiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxuICAgIDxzeW1waG9ueS1idXR0b24tdjIgdGV4dD1cIkNsb3NlXCIgW2lzU2Vjb25kYXJ5XT1cInRydWVcIiAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgPHN5bXBob255LWJ1dHRvbi12MiB0ZXh0PVwiTmV4dFwiIFtkaXNhYmxlZF09XCIhc2VsZWN0ZWQgfHwgISFjb25maXJtU3VnZ2VzdGlvblwiIChjbGlja2VkKT1cIm9uTmV4dCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gIDwvc2VjdGlvbj5cbjwvZGl2PlxuIl19
133
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQ0wsYUFBYSxFQUNiLGlCQUFpQixFQUNqQixnQkFBZ0IsR0FDakIsTUFBTSwrQ0FBK0MsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7QUFPdkQsTUFBTSxPQUFPLDJCQUEyQjtJQXVCdEM7UUFyQlMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUNsRCxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUNsQyxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUdyQyxDQUFDO1FBQ0ssb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBMEIsQ0FBQztRQUM3RCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQzVDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDNUMsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQTBCLENBQUM7UUFDdEUsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUMzRCxhQUFR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QWtCO1FBQ2hCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsYUFBYSxDQUFDLEVBQVU7UUFDdEIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakMsT0FBTyxHQUFHLE9BQU8sNkJBQTZCLEVBQUUsRUFBRSxDQUFDO0lBQ3JELENBQUM7O3dIQWpHVSwyQkFBMkI7NEdBQTNCLDJCQUEyQix3bUJDYnhDLGttT0F5SUE7MkZENUhhLDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSwrQkFBK0I7MEVBS2hDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksSUFBSTtzQkFBYixNQUFNO2dCQUNHLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUlHLGVBQWU7c0JBQXhCLE1BQU07Z0JBQ0csZ0JBQWdCO3NCQUF6QixNQUFNO2dCQUNHLGdCQUFnQjtzQkFBekIsTUFBTTtnQkFDRyx3QkFBd0I7c0JBQWpDLE1BQU07Z0JBQ0csOEJBQThCO3NCQUF2QyxNQUFNO2dCQUNFLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbCwgTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB9IGZyb20gJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwubW9kZWwnO1xuaW1wb3J0IHtcbiAgQWxlcnREdXJhdGlvbixcbiAgVG9hc3RlckFsZXJ0TW9kZWwsXG4gIFRvYXN0ZXJBbGVydFR5cGUsXG59IGZyb20gJy4uLy4uL2F0b21zL3RvYXN0ZXItYWxlcnQvdG9hc3Rlci1hbGVydC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3N5bXBob255LW1lcmdlLWNvbnRhY3RzLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21lcmdlLWNvbnRhY3RzLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWVyZ2UtY29udGFjdHMtbW9kYWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNZXJnZUNvbnRhY3RzTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBtb2RlbDogTWVyZ2VDb250YWN0c01vZGFsTW9kZWw7XG4gIEBJbnB1dCgpIGlzTG9hZGluZyA9IGZhbHNlO1xuICBASW5wdXQoKSBoYXNFcnJvciA9IGZhbHNlO1xuICBAT3V0cHV0KCkgbmV4dCA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGNhbmNlbCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIG5vdER1cGxpY2F0ZSA9IG5ldyBFdmVudEVtaXR0ZXI8e1xuICAgIHNlbGVjdGVkOiBNZXJnZUNvbnRhY3RzTW9kYWxNb2RlbFsnc2VsZWN0ZWRDb250YWN0J107XG4gICAgc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbjtcbiAgfT4oKTtcbiAgQE91dHB1dCgpIHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8TWVyZ2VDb250YWN0U3VnZ2VzdGlvbj4oKTtcbiAgQE91dHB1dCgpIGhpZGVTdWNjZXNzVG9hc3QgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIEBPdXRwdXQoKSBoaWRlRmFpbHVyZVRvYXN0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxNZXJnZUNvbnRhY3RTdWdnZXN0aW9uPigpO1xuICBAT3V0cHV0KCkgcmVxdWVzdENhbmNlbENvbmZpcm1TdWdnZXN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBASW5wdXQoKSBzZWxlY3RlZDogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBjb25maXJtU3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbiB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBzaG93U3VjY2Vzc1RvYXN0ID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNob3dGYWlsdXJlVG9hc3QgPSBmYWxzZTtcbiAgQElucHV0KCkgY3VycmVudFN0ZXA6IG51bWJlciA9IDE7XG4gIHN1Y2Nlc3NUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG4gIGZhaWx1cmVUb2FzdDogVG9hc3RlckFsZXJ0TW9kZWw7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0ID0gbmV3IFRvYXN0ZXJBbGVydE1vZGVsKCk7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LnR5cGUgPSBUb2FzdGVyQWxlcnRUeXBlLlN1Y2Nlc3M7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0Lm1lc3NhZ2UgPSBcIkNvbnRhY3QgcmVtb3ZlZCBmcm9tIGR1cGxpY2F0ZXMgc3VjY2Vzc2Z1bGx5XCI7XG4gIHRoaXMuc3VjY2Vzc1RvYXN0LmR1cmF0aW9uID0gQWxlcnREdXJhdGlvbi5GaXZlU2Vjb25kcztcbiAgdGhpcy5zdWNjZXNzVG9hc3Quc2hvd0Nsb3NlSWNvbiA9IHRydWU7XG5cbiAgdGhpcy5mYWlsdXJlVG9hc3QgPSBuZXcgVG9hc3RlckFsZXJ0TW9kZWwoKTtcbiAgdGhpcy5mYWlsdXJlVG9hc3QudHlwZSA9IFRvYXN0ZXJBbGVydFR5cGUuRXJyb3I7XG4gIHRoaXMuZmFpbHVyZVRvYXN0Lm1lc3NhZ2UgPSBcIkZhaWxlZCB0byByZW1vdmUgY29udGFjdCBmcm9tIGR1cGxpY2F0ZXNcIjtcbiAgdGhpcy5mYWlsdXJlVG9hc3QuZHVyYXRpb24gPSBBbGVydER1cmF0aW9uLkZpdmVTZWNvbmRzO1xuICB0aGlzLmZhaWx1cmVUb2FzdC5zaG93Q2xvc2VJY29uID0gdHJ1ZTtcbiAgfVxuXG4gIG9uTmV4dCgpIHtcbiAgICB0aGlzLm5leHQuZW1pdCh0aGlzLnNlbGVjdGVkKTtcbiAgfVxuXG4gIG9uQ2FuY2VsKCkge1xuICAgIHRoaXMuY2FuY2VsLmVtaXQoKTtcbiAgfVxuXG4gIG9uU2VsZWN0KHN1Z2dlc3Rpb246IE1lcmdlQ29udGFjdFN1Z2dlc3Rpb24pIHtcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHN1Z2dlc3Rpb24pO1xuICB9XG5cbiAgb25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbjogTWVyZ2VDb250YWN0U3VnZ2VzdGlvbikge1xuICAgIHRoaXMucmVxdWVzdENvbmZpcm1TdWdnZXN0aW9uLmVtaXQoc3VnZ2VzdGlvbik7XG4gIH1cblxuICBjYW5jZWxOb3REdXBsaWNhdGUoKSB7XG4gICAgdGhpcy5yZXF1ZXN0Q2FuY2VsQ29uZmlybVN1Z2dlc3Rpb24uZW1pdCgpO1xuICB9XG5cbiAgY29uZmlybU9uTm90RHVwbGljYXRlKCkge1xuICAgIGlmICh0aGlzLmNvbmZpcm1TdWdnZXN0aW9uKSB7XG4gICAgICB0aGlzLm5vdER1cGxpY2F0ZS5lbWl0KHtcbiAgICAgICAgc2VsZWN0ZWQ6IHRoaXMubW9kZWwuc2VsZWN0ZWRDb250YWN0LFxuICAgICAgICBzdWdnZXN0aW9uOiB0aGlzLmNvbmZpcm1TdWdnZXN0aW9uLFxuICAgICAgfSk7XG4gICAgIH1cbiAgfVxuXG4gIGhhbmRsZU5vdER1cGxpY2F0ZVN1Y2Nlc3MoKSB7XG4gICAgY29uc3QgcmVtb3ZlZCA9IHRoaXMuY29uZmlybVN1Z2dlc3Rpb247XG4gICAgaWYgKHJlbW92ZWQpIHtcbiAgICAgIHRoaXMubW9kZWwuc3VnZ2VzdGlvbnMgPSB0aGlzLm1vZGVsLnN1Z2dlc3Rpb25zLmZpbHRlcihcbiAgICAgICAgKHMpID0+IHMgIT09IHJlbW92ZWRcbiAgICAgICk7XG4gICAgICBpZiAodGhpcy5zZWxlY3RlZCA9PT0gcmVtb3ZlZCkge1xuICAgICAgICB0aGlzLnNlbGVjdGVkID0gbnVsbDtcbiAgICAgIH1cbiAgICAgIHRoaXMuY29uZmlybVN1Z2dlc3Rpb24gPSBudWxsO1xuICAgICAgdGhpcy5zaG93U3VjY2Vzc1RvYXN0ID0gdHJ1ZTtcbiAgICAgIHRoaXMuaXNMb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgaGFuZGxlTm90RHVwbGljYXRlRXJyb3IoKSB7XG4gICAgdGhpcy5zaG93RmFpbHVyZVRvYXN0ID0gdHJ1ZTtcbiAgICB0aGlzLmlzTG9hZGluZyA9IGZhbHNlO1xuICB9XG5cbiAgb25IaWRlU3VjY2Vzc1RvYXN0KCkge1xuICAgIHRoaXMuaGlkZVN1Y2Nlc3NUb2FzdC5lbWl0KCk7XG4gIH1cbiAgb25IaWRlRmFpbHVyZVRvYXN0KCkge1xuICAgIHRoaXMuaGlkZUZhaWx1cmVUb2FzdC5lbWl0KCk7XG4gIH1cblxuICBnZXRDb250YWN0VXJsKGlkOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHVybCA9IHdpbmRvdy5sb2NhdGlvbi5ocmVmO1xuICAgIGNvbnN0IFtiYXNlVXJsXSA9IHVybC5zcGxpdCgnIycpO1xuICAgIHJldHVybiBgJHtiYXNlVXJsfSMvY2FuZGlkYXRlcHJvZmlsZXZpZXc/aWQ9JHtpZH1gO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic2Z4IHNmeC1tb2RhbCBtb2RhbC1jb250YWluZXJcIiAqbmdJZj1cIm1vZGVsXCI+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtaGVhZGVyIHNmeC1wLTMwIHNmeC1wdC00MFwiPlxuICAgIDxkaXYgY2xhc3M9XCJtb2RhbC10aXRsZVwiPlxuICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTggY29sLXNtLTggY29sLW1kLTggY29sLWxnLThcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDQgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiIHRleHQ9XCJNYW5hZ2UgRHVwbGljYXRlc1wiPjwvc3ltcGhvbnktaDQ+XG4gICAgICAgICAgPHN5bXBob255LWg0ICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDJcIiB0ZXh0PVwiTWVyZ2UgQ29udGFjdHNcIj48L3N5bXBob255LWg0PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy00IGNvbC1zbS00IGNvbC1tZC00IGNvbC1sZy00XCI+XG4gICAgICAgICAgPHN5bXBob255LWljb25cbiAgICAgICAgICAgIGNsYXNzPVwicHVsbC1yaWdodFwiXG4gICAgICAgICAgICBbaWNvbl09XCInc2ktY2xvc2UtbW9kYWwnXCJcbiAgICAgICAgICAgIChjbGlja2VkKT1cIm9uQ2FuY2VsKClcIlxuICAgICAgICAgID48L3N5bXBob255LWljb24+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS0xMiBjb2wtbWQtMTIgY29sLWxnLTEyIHNmeC1tdC0xNVwiPlxuICAgICAgICAgICAgIDxzeW1waG9ueS1wYXJhZ3JhcGhcbiAgICAgICAgICAgICAgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiXG4gICAgICAgICAgICAgIHRleHQ9XCJUaGUgY29udGFjdHMgYmVsb3cgYXJlIHBvdGVudGlhbCBkdXBsaWNhdGVzLiBQbGVhc2UgY29tcGFyZSB0aGVpciBkYXRhIGFuZCBzZWxlY3QgdGhlIG9uZSB5b3Ugd291bGQgbGlrZSB0byBtZXJnZS5cIlxuICAgICAgICAgICAgPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgICAgICAgICAgPHN5bXBob255LXBhcmFncmFwaFxuICAgICAgICAgICAgICAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCJcbiAgICAgICAgICAgICAgdGV4dD1cIlVzaW5nIHRoZSBmaWVsZHMgYmVsb3csIGNob29zZSBhIFByaW1hcnkgQ29udGFjdCwgYW5kIHRoZW4gc2VsZWN0IHRoZSBkYXRhIHlvdSB3b3VsZCBsaWtlIHRvIG1lcmdlIGFuZCBrZWVwIGluIHRoYXQgUHJpbWFyeSBDb250YWN0IFJlY29yZC4gTWVyZ2luZyBjb250YWN0cyBpcyBpcnJldmVyc2libGUuXCJcbiAgICAgICAgICAgID48L3N5bXBob255LXBhcmFncmFwaD4gICAgICAgIFxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uIGNsYXNzPVwibW9kYWwtYm9keSBzZngtcC0zMFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJjdXJyZW50U3RlcCA9PT0gMVwiPlxuICAgIDxkaXYgY2xhc3M9XCJ0b2FzdGVyLWFsZXJ0LWNvbnRhaW5lci1nbG9iYWxcIj5cbiAgICAgICAgPHN5bXBob255LXRvYXN0ZXItYWxlcnRcbiAgICAgICAgICAqbmdJZj1cInNob3dTdWNjZXNzVG9hc3RcIlxuICAgICAgICAgIFthbGVydE1vZGVsXT1cInN1Y2Nlc3NUb2FzdFwiXG4gICAgICAgICAgKGhpZGVBbGVydCk9XCJvbkhpZGVTdWNjZXNzVG9hc3QoKVwiXG4gICAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgICA8c3ltcGhvbnktdG9hc3Rlci1hbGVydFxuICAgICAgICAqbmdJZj1cInNob3dGYWlsdXJlVG9hc3RcIlxuICAgICAgICBbYWxlcnRNb2RlbF09XCJmYWlsdXJlVG9hc3RcIlxuICAgICAgICAoaGlkZUFsZXJ0KT1cIm9uSGlkZUZhaWx1cmVUb2FzdCgpXCJcbiAgICAgID48L3N5bXBob255LXRvYXN0ZXItYWxlcnQ+XG4gICAgPC9kaXY+XG4gICAgPGRpdiAqbmdJZj1cImlzTG9hZGluZ1wiIGNsYXNzPVwic2Z4LW10LTMwIHNmeC1tYi0zMFwiPlxuICAgICAgPHN5bXBob255LXNmeC1sb2FkZXI+PC9zeW1waG9ueS1zZngtbG9hZGVyPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCJoYXNFcnJvclwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJTb21ldGhpbmcgaGFzIHdlbnQgd3JvbmcuIFRyeSBhZ2FpbiBsYXRlciBvciBjb250YWN0IHN1cHBvcnRcIj48L3N5bXBob255LXBhcmFncmFwaD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgKCFtb2RlbD8uc3VnZ2VzdGlvbnMgfHwgbW9kZWwuc3VnZ2VzdGlvbnMubGVuZ3RoID09PSAwKVwiIGNsYXNzPVwic2Z4LW10LTMwXCI+XG4gICAgICA8c3ltcGhvbnktcGFyYWdyYXBoIHRleHQ9XCJObyBtb3JlIGR1cGxpY2F0ZXMgZXhpc3QgZm9yIHRoaXMgc2VsZWN0ZWQgY29udGFjdC4gUGxlYXNlIHRyeSBhZ2FpbiBsYXRlclwiPjwvc3ltcGhvbnktcGFyYWdyYXBoPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhaXNMb2FkaW5nICYmICFoYXNFcnJvciAmJiAhY29uZmlybVN1Z2dlc3Rpb24gJiYgbW9kZWw/LnN1Z2dlc3Rpb25zPy5sZW5ndGhcIiBjbGFzcz1cInJvd1wiPlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8cCBjbGFzcz1cInNmeC1tdC00MCBzZngtZm9udC1ib2xkXCI+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0Lm5hbWUgfX0gIFt7eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuaWQgfX1dPC9wPlxuICAgICAgICA8cD57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QuZW1haWwgfX08L3A+XG4gICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLXhzLTEyIGNvbC1zbS02IGNvbC1tZC02IGNvbC1sZy02XCI+XG4gICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiUG90ZW50aWFsIER1cGxpY2F0ZXNcIj48L3N5bXBob255LWg1PlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250YWluZXJcIj5cbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3VnZ2VzdGlvbiBvZiBtb2RlbC5zdWdnZXN0aW9uc1wiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJhZGlvLWl0ZW1cIj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWlucHV0LXJhZGlvXG4gICAgICAgICAgICAgICAgW2xhYmVsXT1cInN1Z2dlc3Rpb24ubmFtZSArICcgWycgKyBzdWdnZXN0aW9uLmlkICsgJ10nXCJcbiAgICAgICAgICAgICAgICBbbmFtZV09XCInbWVyZ2Utc3VnZ2VzdGlvbnMnXCJcbiAgICAgICAgICAgICAgICBbaXNBY3RpdmVdPVwic2VsZWN0ZWQgPT09IHN1Z2dlc3Rpb25cIlxuICAgICAgICAgICAgICAgIChjbGlja2VkKT1cIm9uU2VsZWN0KHN1Z2dlc3Rpb24pXCJcbiAgICAgICAgICAgICAgPjwvc3ltcGhvbnktaW5wdXQtcmFkaW8+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1hY3Rpb24gc2Z4LW10LTMwXCI+XG4gICAgICAgICAgICAgIDxzeW1waG9ueS1ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIgY2xhc3M9XCJpY29uLXVwd2FyZHNcIlxuICAgICAgICAgICAgICAgIFtuZXdUYWJVcmxdPVwiZ2V0Q29udGFjdFVybChzdWdnZXN0aW9uLmlkKVwiXG4gICAgICAgICAgICAgID48L3N5bXBob255LWdyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYj5cbiAgICAgICAgICAgICAgPHN5bXBob255LWljb24td3JhcHBlciBjbGFzcz1cIm5vdC1kdXBsaWNhdGUtaWNvbi1nbG9iYWxcIlxuICAgICAgICAgICAgICAgIHRpdGxlPVwiTWFyayBub3QgZHVwbGljYXRlXCIgKGNsaWNrZWQpPVwib25Ob3REdXBsaWNhdGUoc3VnZ2VzdGlvbilcIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBbaWNvbl09XCInc2ktZXhjbHVkZSdcIj48L3N5bXBob255LWljb24+XG4gICAgICAgICAgICAgIDwvc3ltcGhvbnktaWNvbi13cmFwcGVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1pdGVtXCI+XG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1kZXRhaWxzXCI+XG4gICAgICAgICAgICAgIDxkaXY+e3sgc3VnZ2VzdGlvbi5lbWFpbCB9fTwvZGl2PlxuICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2Ygc3VnZ2VzdGlvbi5jcml0ZXJpYVwiIGNsYXNzPVwic2Z4LW10LTVcIj57eyBjcml0ZXJpb24gfX08L2Rpdj5cbiAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgc3RhdHVzIG9mIHN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICAgIDxzeW1waG9ueS1zdGF0dXMtcGlsbCBbc3RhdHVzUGlsbE1vZGVsXT1cIntzdGF0dXNDbGFzczogJ3N0YXR1c0dyZXknLCB2YWx1ZTogc3RhdHVzfVwiPjwvc3ltcGhvbnktc3RhdHVzLXBpbGw+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIWlzTG9hZGluZyAmJiAhaGFzRXJyb3IgJiYgY29uZmlybVN1Z2dlc3Rpb25cIj5cbiAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIHJlbW92ZSB0aGlzIGNvbnRhY3QgYXMgYSBwb3RlbnRpYWwgZHVwbGljYXRlPyBcIj48L3N5bXBob255LWg1PlxuICAgICAgPGRpdiBjbGFzcz1cInNmeC1tdC0yMCByYWRpby1hY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8c3ltcGhvbnktaWNvbiBjbGFzcz1cInBlbmRpbmctaWNvblwiIFtpY29uXT1cIidzaS1wZW5kaW5nLWluY29tcGxldGUnXCI+PC9zeW1waG9ueS1pY29uPlxuICAgICAgPHN5bXBob255LXBhcmFncmFwaCBjbGFzcz1cInNmeC1mb250LWl0YWxpY1wiIHRleHQ9XCJEb2luZyBzbyBpcyBpcnJldmVyc2libGUgYW5kIHRoaXMgY29udGFjdCB3aWxsIG5ldmVyIGJlIHNob3duIGFzIGEgcG90ZW50aWFsIGR1cGxpY2F0ZSBvZiB0aGlzIGNvbnRhY3QgYWdhaW4uXCI+PC9zeW1waG9ueS1wYXJhZ3JhcGg+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJyb3cgc2Z4LW10LTMwXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wteHMtMTIgY29sLXNtLTYgY29sLW1kLTYgY29sLWxnLTZcIj5cbiAgICAgICAgICA8c3ltcGhvbnktaDUgdGV4dD1cIlNlbGVjdGVkIENvbnRhY3RcIj48L3N5bXBob255LWg1PlxuICAgICAgICAgIDxwIGNsYXNzPVwic2Z4LW10LTQwIHNmeC1mb250LWJvbGRcIj57eyBtb2RlbC5zZWxlY3RlZENvbnRhY3QubmFtZSB9fSAgW3t7IG1vZGVsLnNlbGVjdGVkQ29udGFjdC5pZCB9fV08L3A+XG4gICAgICAgICAgPHA+e3sgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmVtYWlsIH19PC9wPlxuICAgICAgICAgIDxwICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgbW9kZWwuc2VsZWN0ZWRDb250YWN0LmNyaXRlcmlhXCI+e3sgY3JpdGVyaW9uIH19PC9wPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC14cy0xMiBjb2wtc20tNiBjb2wtbWQtNiBjb2wtbGctNlwiPlxuICAgICAgICAgIDxzeW1waG9ueS1oNSB0ZXh0PVwiTWVyZ2UgU3VnZ2VzdGlvblwiPjwvc3ltcGhvbnktaDU+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInN1Z2dlc3Rpb24tY29uZmlybVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNmeC1mb250LWJvbGRcIj57eyBjb25maXJtU3VnZ2VzdGlvbi5uYW1lIH19IFt7eyBjb25maXJtU3VnZ2VzdGlvbi5pZCB9fV08L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzZngtbXQtNVwiPnt7IGNvbmZpcm1TdWdnZXN0aW9uLmVtYWlsIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjcml0ZXJpb24gb2YgY29uZmlybVN1Z2dlc3Rpb24uY3JpdGVyaWFcIiBjbGFzcz1cInNmeC1tdC01XCI+e3sgY3JpdGVyaW9uIH19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBzdGF0dXMgb2YgY29uZmlybVN1Z2dlc3Rpb24uc3RhdHVzZXNcIiBjbGFzcz1cInNmeC1tdC0xMFwiPlxuICAgICAgICAgICAgICA8c3ltcGhvbnktc3RhdHVzLXBpbGwgW3N0YXR1c1BpbGxNb2RlbF09XCJ7c3RhdHVzQ2xhc3M6ICdzdGF0dXNHcmV5JywgdmFsdWU6IHN0YXR1c31cIj48L3N5bXBob255LXN0YXR1cy1waWxsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29uZmlybS1hY3Rpb25zXCI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ2FuY2VsXCJcbiAgICAgICAgICBbaXNTZWNvbmRhcnldPVwidHJ1ZVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY2FuY2VsTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICAgIDxzeW1waG9ueS1idXR0b24tdjJcbiAgICAgICAgICB0ZXh0PVwiQ29uZmlybVwiXG4gICAgICAgICAgKGNsaWNrZWQpPVwiY29uZmlybU9uTm90RHVwbGljYXRlKClcIlxuICAgICAgICA+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGVudCAqbmdJZj1cImN1cnJlbnRTdGVwID09PSAyXCI+PC9uZy1jb250ZW50PlxuICA8L3NlY3Rpb24+XG4gIDxzZWN0aW9uICpuZ0lmPVwiY3VycmVudFN0ZXAgPT09IDFcIiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxuICAgIDxzeW1waG9ueS1idXR0b24tdjIgdGV4dD1cIkNsb3NlXCIgW2lzU2Vjb25kYXJ5XT1cInRydWVcIiAoY2xpY2tlZCk9XCJvbkNhbmNlbCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gICAgPHN5bXBob255LWJ1dHRvbi12MiB0ZXh0PVwiTmV4dFwiIFtkaXNhYmxlZF09XCIhc2VsZWN0ZWQgfHwgISFjb25maXJtU3VnZ2VzdGlvblwiIChjbGlja2VkKT1cIm9uTmV4dCgpXCI+PC9zeW1waG9ueS1idXR0b24tdjI+XG4gIDwvc2VjdGlvbj5cbjwvZGl2PlxuIl19
@@ -5267,10 +5267,10 @@ class MergeContactsModalComponent {
5267
5267
  }
5268
5268
  }
5269
5269
  MergeContactsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
5270
- MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
5270
+ MergeContactsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactsModalComponent, selector: "symphony-merge-contacts-modal", inputs: { model: "model", isLoading: "isLoading", hasError: "hasError", selected: "selected", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast", currentStep: "currentStep" }, outputs: { next: "next", cancel: "cancel", notDuplicate: "notDuplicate", selectionChange: "selectionChange", hideSuccessToast: "hideSuccessToast", hideFailureToast: "hideFailureToast", requestConfirmSuggestion: "requestConfirmSuggestion", requestCancelConfirmSuggestion: "requestCancelConfirmSuggestion" }, ngImport: i0, template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"], components: [{ type: H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: ParagraphComponent, selector: "symphony-paragraph", inputs: ["text", "isSecondary", "isFontBold"] }, { type: ToasterAlertComponent, selector: "symphony-toaster-alert", inputs: ["alertModel", "showAlert"], outputs: ["hideAlert", "refreshClicked"] }, { type: SfxLoaderComponent, selector: "symphony-sfx-loader", inputs: ["leftStyle", "message", "hasCustomMessage"] }, { type: H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: InputRadioComponent, selector: "symphony-input-radio", inputs: ["isActive", "name", "label", "isRequired"], outputs: ["clicked"] }, { type: GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: ["newTabUrl"] }, { type: IconWrapperComponent, selector: "symphony-icon-wrapper", inputs: ["backgroundColor", "isInverse", "hasHoverWithoutBorder", "isDisabled"], outputs: ["clicked"] }, { type: StatusPillComponent, selector: "symphony-status-pill", inputs: ["statusPillModel"] }, { type: ButtonV2Component, selector: "symphony-button-v2" }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
5271
5271
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, decorators: [{
5272
5272
  type: Component,
5273
- args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 text=\"Merge Contacts\"></symphony-h4>\n <div class=\"sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Step 2 of 2 - Merge duplicate contacts\"\n ></symphony-paragraph>\n </div>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestions\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
5273
+ args: [{ selector: 'symphony-merge-contacts-modal', template: "<div class=\"sfx sfx-modal modal-container\" *ngIf=\"model\">\n <section class=\"modal-header sfx-p-30 sfx-pt-40\">\n <div class=\"modal-title\">\n <div class=\"row\">\n <div class=\"col-xs-8 col-sm-8 col-md-8 col-lg-8\">\n <symphony-h4 *ngIf=\"currentStep === 1\" text=\"Manage Duplicates\"></symphony-h4>\n <symphony-h4 *ngIf=\"currentStep === 2\" text=\"Merge Contacts\"></symphony-h4>\n </div>\n <div class=\"col-xs-4 col-sm-4 col-md-4 col-lg-4\">\n <symphony-icon\n class=\"pull-right\"\n [icon]=\"'si-close-modal'\"\n (clicked)=\"onCancel()\"\n ></symphony-icon>\n </div>\n <div class=\"col-xs-12 col-sm-12 col-md-12 col-lg-12 sfx-mt-15\">\n <symphony-paragraph\n *ngIf=\"currentStep === 1\"\n text=\"The contacts below are potential duplicates. Please compare their data and select the one you would like to merge.\"\n ></symphony-paragraph>\n <symphony-paragraph\n *ngIf=\"currentStep === 2\"\n text=\"Using the fields below, choose a Primary Contact, and then select the data you would like to merge and keep in that Primary Contact Record. Merging contacts is irreversible.\"\n ></symphony-paragraph> \n </div>\n </div>\n </div>\n </section>\n <section class=\"modal-body sfx-p-30\">\n <ng-container *ngIf=\"currentStep === 1\">\n <div class=\"toaster-alert-container-global\">\n <symphony-toaster-alert\n *ngIf=\"showSuccessToast\"\n [alertModel]=\"successToast\"\n (hideAlert)=\"onHideSuccessToast()\"\n ></symphony-toaster-alert>\n <symphony-toaster-alert\n *ngIf=\"showFailureToast\"\n [alertModel]=\"failureToast\"\n (hideAlert)=\"onHideFailureToast()\"\n ></symphony-toaster-alert>\n </div>\n <div *ngIf=\"isLoading\" class=\"sfx-mt-30 sfx-mb-30\">\n <symphony-sfx-loader></symphony-sfx-loader>\n </div>\n <div *ngIf=\"hasError\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"Something has went wrong. Try again later or contact support\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && (!model?.suggestions || model.suggestions.length === 0)\" class=\"sfx-mt-30\">\n <symphony-paragraph text=\"No more duplicates exist for this selected contact. Please try again later\"></symphony-paragraph>\n </div>\n <div *ngIf=\"!isLoading && !hasError && !confirmSuggestion && model?.suggestions?.length\" class=\"row\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Potential Duplicates\"></symphony-h5>\n <div class=\"scrollable-container\">\n <div *ngFor=\"let suggestion of model.suggestions\">\n <div class=\"radio-item\">\n <symphony-input-radio\n [label]=\"suggestion.name + ' [' + suggestion.id + ']'\"\n [name]=\"'merge-suggestions'\"\n [isActive]=\"selected === suggestion\"\n (clicked)=\"onSelect(suggestion)\"\n ></symphony-input-radio>\n <div class=\"radio-action sfx-mt-30\">\n <symphony-grid-cell-clicked-open-new-tab class=\"icon-upwards\"\n [newTabUrl]=\"getContactUrl(suggestion.id)\"\n ></symphony-grid-cell-clicked-open-new-tab>\n <symphony-icon-wrapper class=\"not-duplicate-icon-global\"\n title=\"Mark not duplicate\" (clicked)=\"onNotDuplicate(suggestion)\">\n <symphony-icon [icon]=\"'si-exclude'\"></symphony-icon>\n </symphony-icon-wrapper>\n </div>\n </div>\n <div class=\"radio-item\">\n <div class=\"radio-details\">\n <div>{{ suggestion.email }}</div>\n <div *ngFor=\"let criterion of suggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of suggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!isLoading && !hasError && confirmSuggestion\">\n <symphony-h5 text=\"Are you sure you want to remove this contact as a potential duplicate? \"></symphony-h5>\n <div class=\"sfx-mt-20 radio-action\">\n <symphony-icon class=\"pending-icon\" [icon]=\"'si-pending-incomplete'\"></symphony-icon>\n <symphony-paragraph class=\"sfx-font-italic\" text=\"Doing so is irreversible and this contact will never be shown as a potential duplicate of this contact again.\"></symphony-paragraph>\n </div>\n <div class=\"row sfx-mt-30\">\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Selected Contact\"></symphony-h5>\n <p class=\"sfx-mt-40 sfx-font-bold\">{{ model.selectedContact.name }} [{{ model.selectedContact.id }}]</p>\n <p>{{ model.selectedContact.email }}</p>\n <p *ngFor=\"let criterion of model.selectedContact.criteria\">{{ criterion }}</p>\n </div>\n <div class=\"col-xs-12 col-sm-6 col-md-6 col-lg-6\">\n <symphony-h5 text=\"Merge Suggestion\"></symphony-h5>\n <div class=\"suggestion-confirm\">\n <div class=\"sfx-font-bold\">{{ confirmSuggestion.name }} [{{ confirmSuggestion.id }}]</div>\n <div class=\"sfx-mt-5\">{{ confirmSuggestion.email }}</div>\n <div *ngFor=\"let criterion of confirmSuggestion.criteria\" class=\"sfx-mt-5\">{{ criterion }}</div>\n <div *ngFor=\"let status of confirmSuggestion.statuses\" class=\"sfx-mt-10\">\n <symphony-status-pill [statusPillModel]=\"{statusClass: 'statusGrey', value: status}\"></symphony-status-pill>\n </div>\n </div>\n </div>\n </div>\n <div class=\"confirm-actions\">\n <symphony-button-v2\n text=\"Cancel\"\n [isSecondary]=\"true\"\n (clicked)=\"cancelNotDuplicate()\"\n ></symphony-button-v2>\n <symphony-button-v2\n text=\"Confirm\"\n (clicked)=\"confirmOnNotDuplicate()\"\n ></symphony-button-v2>\n </div>\n </div>\n </ng-container>\n <ng-content *ngIf=\"currentStep === 2\"></ng-content>\n </section>\n <section *ngIf=\"currentStep === 1\" class=\"modal-footer\">\n <symphony-button-v2 text=\"Close\" [isSecondary]=\"true\" (clicked)=\"onCancel()\"></symphony-button-v2>\n <symphony-button-v2 text=\"Next\" [disabled]=\"!selected || !!confirmSuggestion\" (clicked)=\"onNext()\"></symphony-button-v2>\n </section>\n</div>\n", styles: [".scrollable-container{max-height:500px;display:flex;flex-direction:column;overflow-y:auto;padding:10px;gap:10px}.radio-item{display:flex;align-items:flex-start;gap:5px}.radio-label{display:flex;align-items:center;gap:1px}.radio-details{padding-left:24px}.radio-action{margin-left:auto;display:flex}.icon-upwards{margin-top:-1px!important;margin-bottom:auto}.modal-footer{display:flex;gap:10px;width:100%;justify-content:flex-end}.confirm-actions{display:flex;gap:10px;margin-top:20px}.suggestion-confirm{margin-top:38px}.pending-icon{margin-right:8px}\n"] }]
5274
5274
  }], ctorParameters: function () { return []; }, propDecorators: { model: [{
5275
5275
  type: Input
5276
5276
  }], isLoading: [{