@symphony-talent/component-library 4.189.0 → 4.191.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.
- package/esm2020/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.component.mjs +6 -4
- package/esm2020/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.module.mjs +4 -3
- package/esm2020/lib/atoms/grid/framework/merge-contact-clicked-open-modal/merge-contact-clicked-open-modal.component.mjs +2 -2
- package/esm2020/lib/atoms/input-radio/input-radio.component.mjs +6 -5
- package/esm2020/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.mjs +5 -2
- package/esm2020/lib/organisms/ai-search-assistant-drawer/ai-search-assistant-drawer.component.mjs +7 -4
- package/esm2020/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.mjs +128 -0
- package/esm2020/lib/organisms/merge-contacts-modal/merge-contacts-modal.model.mjs +2 -0
- package/esm2020/lib/organisms/merge-contacts-modal/merge-contacts-modal.module.mjs +66 -0
- package/esm2020/lib/organisms/organisms.module.mjs +5 -5
- package/esm2020/projects/component-library/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.component.mjs +6 -4
- package/esm2020/projects/component-library/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.module.mjs +4 -3
- package/esm2020/projects/component-library/lib/atoms/grid/framework/merge-contact-clicked-open-modal/merge-contact-clicked-open-modal.component.mjs +2 -2
- package/esm2020/projects/component-library/lib/atoms/input-radio/input-radio.component.mjs +6 -5
- package/esm2020/projects/component-library/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.mjs +5 -2
- package/esm2020/projects/component-library/lib/organisms/ai-search-assistant-drawer/ai-search-assistant-drawer.component.mjs +7 -4
- package/esm2020/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.mjs +128 -0
- package/esm2020/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.model.mjs +2 -0
- package/esm2020/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.module.mjs +66 -0
- package/esm2020/projects/component-library/lib/organisms/organisms.module.mjs +5 -5
- package/esm2020/projects/component-library/public-api.mjs +4 -1
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/symphony-talent-component-library-projects-component-library.mjs +192 -18
- package/fesm2015/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
- package/fesm2015/symphony-talent-component-library.mjs +192 -18
- package/fesm2015/symphony-talent-component-library.mjs.map +1 -1
- package/fesm2020/symphony-talent-component-library-projects-component-library.mjs +192 -18
- package/fesm2020/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
- package/fesm2020/symphony-talent-component-library.mjs +192 -18
- package/fesm2020/symphony-talent-component-library.mjs.map +1 -1
- package/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.component.d.ts +1 -1
- package/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.module.d.ts +1 -1
- package/lib/atoms/input-radio/input-radio.component.d.ts +3 -2
- package/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.d.ts +40 -0
- package/lib/organisms/merge-contacts-modal/merge-contacts-modal.model.d.ts +13 -0
- package/lib/organisms/merge-contacts-modal/merge-contacts-modal.module.d.ts +19 -0
- package/lib/organisms/organisms.module.d.ts +4 -3
- package/package.json +1 -1
- package/projects/component-library/global.scss +27 -0
- package/projects/component-library/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.component.d.ts +1 -1
- package/projects/component-library/lib/atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.module.d.ts +1 -1
- package/projects/component-library/lib/atoms/input-radio/input-radio.component.d.ts +3 -2
- package/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.d.ts +40 -0
- package/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.model.d.ts +13 -0
- package/projects/component-library/lib/organisms/merge-contacts-modal/merge-contacts-modal.module.d.ts +19 -0
- package/projects/component-library/lib/organisms/organisms.module.d.ts +4 -3
- package/projects/component-library/public-api.d.ts +3 -0
- package/public-api.d.ts +3 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { AlertDuration, ToasterAlertModel, ToasterAlertType, } from '../../atoms/toaster-alert/toaster-alert.model';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
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";
|
|
7
|
+
import * as i4 from "../../atoms/toaster-alert/toaster-alert.component";
|
|
8
|
+
import * as i5 from "../../atoms/sfx-loader/sfx-loader.component";
|
|
9
|
+
import * as i6 from "../../atoms/h5/h5.component";
|
|
10
|
+
import * as i7 from "../../atoms/input-radio/input-radio.component";
|
|
11
|
+
import * as i8 from "../../atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.component";
|
|
12
|
+
import * as i9 from "../../atoms/icon-wrapper/icon-wrapper.component";
|
|
13
|
+
import * as i10 from "../../atoms/status-pill/status-pill.component";
|
|
14
|
+
import * as i11 from "../../atoms/button-v2/button.component";
|
|
15
|
+
import * as i12 from "@angular/common";
|
|
16
|
+
export class MergeContactsModalComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.isLoading = false;
|
|
19
|
+
this.hasError = false;
|
|
20
|
+
this.next = new EventEmitter();
|
|
21
|
+
this.cancel = new EventEmitter();
|
|
22
|
+
this.notDuplicate = new EventEmitter();
|
|
23
|
+
this.selectionChange = new EventEmitter();
|
|
24
|
+
this.hideSuccessToast = new EventEmitter();
|
|
25
|
+
this.hideFailureToast = new EventEmitter();
|
|
26
|
+
this.requestConfirmSuggestion = new EventEmitter();
|
|
27
|
+
this.requestCancelConfirmSuggestion = new EventEmitter();
|
|
28
|
+
this.confirmSuggestion = null;
|
|
29
|
+
this.showSuccessToast = false;
|
|
30
|
+
this.showFailureToast = false;
|
|
31
|
+
this.successToast = new ToasterAlertModel();
|
|
32
|
+
this.successToast.type = ToasterAlertType.Success;
|
|
33
|
+
this.successToast.message = "Contact removed from duplicates successfully";
|
|
34
|
+
this.successToast.duration = AlertDuration.FiveSeconds;
|
|
35
|
+
this.successToast.showCloseIcon = true;
|
|
36
|
+
this.failureToast = new ToasterAlertModel();
|
|
37
|
+
this.failureToast.type = ToasterAlertType.Error;
|
|
38
|
+
this.failureToast.message = "Failed to remove contact from duplicates";
|
|
39
|
+
this.failureToast.duration = AlertDuration.FiveSeconds;
|
|
40
|
+
this.failureToast.showCloseIcon = true;
|
|
41
|
+
}
|
|
42
|
+
onNext() {
|
|
43
|
+
this.next.emit();
|
|
44
|
+
}
|
|
45
|
+
onCancel() {
|
|
46
|
+
this.cancel.emit();
|
|
47
|
+
}
|
|
48
|
+
onSelect(suggestion) {
|
|
49
|
+
this.selected = suggestion;
|
|
50
|
+
this.selectionChange.emit(suggestion);
|
|
51
|
+
}
|
|
52
|
+
onNotDuplicate(suggestion) {
|
|
53
|
+
this.requestConfirmSuggestion.emit(suggestion);
|
|
54
|
+
}
|
|
55
|
+
cancelNotDuplicate() {
|
|
56
|
+
this.requestCancelConfirmSuggestion.emit();
|
|
57
|
+
}
|
|
58
|
+
confirmOnNotDuplicate() {
|
|
59
|
+
if (this.confirmSuggestion) {
|
|
60
|
+
this.notDuplicate.emit({
|
|
61
|
+
selected: this.model.selectedContact,
|
|
62
|
+
suggestion: this.confirmSuggestion,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
handleNotDuplicateSuccess() {
|
|
67
|
+
const removed = this.confirmSuggestion;
|
|
68
|
+
if (removed) {
|
|
69
|
+
this.model.suggestions = this.model.suggestions.filter((s) => s !== removed);
|
|
70
|
+
if (this.selected === removed) {
|
|
71
|
+
this.selected = null;
|
|
72
|
+
}
|
|
73
|
+
this.confirmSuggestion = null;
|
|
74
|
+
this.showSuccessToast = true;
|
|
75
|
+
this.isLoading = false;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
handleNotDuplicateError() {
|
|
79
|
+
this.showFailureToast = true;
|
|
80
|
+
this.isLoading = false;
|
|
81
|
+
}
|
|
82
|
+
onHideSuccessToast() {
|
|
83
|
+
this.hideSuccessToast.emit();
|
|
84
|
+
}
|
|
85
|
+
onHideFailureToast() {
|
|
86
|
+
this.hideFailureToast.emit();
|
|
87
|
+
}
|
|
88
|
+
getContactUrl(id) {
|
|
89
|
+
const url = window.location.href;
|
|
90
|
+
const [baseUrl] = url.split('#');
|
|
91
|
+
return `${baseUrl}#/candidateprofileview?id=${id}`;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
MergeContactsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
+
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", confirmSuggestion: "confirmSuggestion", showSuccessToast: "showSuccessToast", showFailureToast: "showFailureToast" }, 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 text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"></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 <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 </section>\n <section 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
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalComponent, decorators: [{
|
|
97
|
+
type: Component,
|
|
98
|
+
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 text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"></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 <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 </section>\n <section 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
|
+
}], ctorParameters: function () { return []; }, propDecorators: { model: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], isLoading: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], hasError: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], next: [{
|
|
106
|
+
type: Output
|
|
107
|
+
}], cancel: [{
|
|
108
|
+
type: Output
|
|
109
|
+
}], notDuplicate: [{
|
|
110
|
+
type: Output
|
|
111
|
+
}], selectionChange: [{
|
|
112
|
+
type: Output
|
|
113
|
+
}], hideSuccessToast: [{
|
|
114
|
+
type: Output
|
|
115
|
+
}], hideFailureToast: [{
|
|
116
|
+
type: Output
|
|
117
|
+
}], requestConfirmSuggestion: [{
|
|
118
|
+
type: Output
|
|
119
|
+
}], requestCancelConfirmSuggestion: [{
|
|
120
|
+
type: Output
|
|
121
|
+
}], confirmSuggestion: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], showSuccessToast: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], showFailureToast: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}] } });
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"merge-contacts-modal.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.ts","../../../../../projects/component-library/src/lib/organisms/merge-contacts-modal/merge-contacts-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MergeContactsModalModel, MergeContactSuggestion } from './merge-contacts-modal.model';\nimport {\n  AlertDuration,\n  ToasterAlertModel,\n  ToasterAlertType,\n} from '../../atoms/toaster-alert/toaster-alert.model';\n\n@Component({\n  selector: 'symphony-merge-contacts-modal',\n  templateUrl: './merge-contacts-modal.component.html',\n  styleUrls: ['./merge-contacts-modal.component.scss']\n})\nexport class MergeContactsModalComponent {\n  @Input() model: MergeContactsModalModel;\n  @Input() isLoading = false;\n  @Input() hasError = false;\n  @Output() next = new EventEmitter<void>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() notDuplicate = new EventEmitter<{\n    selected: MergeContactsModalModel['selectedContact'];\n    suggestion: MergeContactSuggestion;\n  }>();\n  @Output() selectionChange = new EventEmitter<MergeContactSuggestion>();\n  @Output() hideSuccessToast = new EventEmitter<void>();\n  @Output() hideFailureToast = new EventEmitter<void>();\n  @Output() requestConfirmSuggestion = new EventEmitter<MergeContactSuggestion>();\n  @Output() requestCancelConfirmSuggestion = new EventEmitter<void>();\n  selected: MergeContactSuggestion;\n  @Input() confirmSuggestion: MergeContactSuggestion | null = null;\n  @Input() showSuccessToast = false;\n  @Input() showFailureToast = false;\n  successToast: ToasterAlertModel;\n  failureToast: ToasterAlertModel;\n\n  constructor() {\n  this.successToast = new ToasterAlertModel();\n  this.successToast.type = ToasterAlertType.Success;\n  this.successToast.message = \"Contact removed from duplicates successfully\";\n  this.successToast.duration = AlertDuration.FiveSeconds;\n  this.successToast.showCloseIcon = true;\n\n  this.failureToast = new ToasterAlertModel();\n  this.failureToast.type = ToasterAlertType.Error;\n  this.failureToast.message = \"Failed to remove contact from duplicates\";\n  this.failureToast.duration = AlertDuration.FiveSeconds;\n  this.failureToast.showCloseIcon = true;\n  }\n\n  onNext() {\n    this.next.emit();\n  }\n\n  onCancel() {\n    this.cancel.emit();\n  }\n\n  onSelect(suggestion: MergeContactSuggestion) {\n    this.selected = suggestion;\n    this.selectionChange.emit(suggestion);\n  }\n\n  onNotDuplicate(suggestion: MergeContactSuggestion) {\n    this.requestConfirmSuggestion.emit(suggestion);\n  }\n\n  cancelNotDuplicate() {\n    this.requestCancelConfirmSuggestion.emit();\n  }\n\n  confirmOnNotDuplicate() {\n    if (this.confirmSuggestion) {\n      this.notDuplicate.emit({\n        selected: this.model.selectedContact,\n        suggestion: this.confirmSuggestion,\n      });\n     }\n  }\n\n  handleNotDuplicateSuccess() {\n    const removed = this.confirmSuggestion;\n    if (removed) {\n      this.model.suggestions = this.model.suggestions.filter(\n        (s) => s !== removed\n      );\n      if (this.selected === removed) {\n        this.selected = null;\n      }\n      this.confirmSuggestion = null;\n      this.showSuccessToast = true;\n      this.isLoading = false;\n    }\n  }\n\n  handleNotDuplicateError() {\n    this.showFailureToast = true;\n    this.isLoading = false;\n  }\n\n  onHideSuccessToast() {\n    this.hideSuccessToast.emit();\n  }\n  onHideFailureToast() {\n    this.hideFailureToast.emit();\n  }\n\n  getContactUrl(id: string): string {\n    const url = window.location.href;\n    const [baseUrl] = url.split('#');\n    return `${baseUrl}#/candidateprofileview?id=${id}`;\n  }\n}\n","<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 text=\"Step 1 of 2 - Select the duplicate contact that needs to be merged.\"></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    <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  </section>\n  <section 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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnQtbGlicmFyeS9zcmMvbGliL29yZ2FuaXNtcy9tZXJnZS1jb250YWN0cy1tb2RhbC9tZXJnZS1jb250YWN0cy1tb2RhbC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBNZXJnZUNvbnRhY3REZXRhaWwge1xuICBpZDogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGVtYWlsOiBzdHJpbmc7XG4gIGNyaXRlcmlhOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXJnZUNvbnRhY3RTdWdnZXN0aW9uIGV4dGVuZHMgTWVyZ2VDb250YWN0RGV0YWlsIHtcbiAgc3RhdHVzZXM6IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lcmdlQ29udGFjdHNNb2RhbE1vZGVsIHtcbiAgc2VsZWN0ZWRDb250YWN0OiBNZXJnZUNvbnRhY3REZXRhaWw7XG4gIHN1Z2dlc3Rpb25zOiBNZXJnZUNvbnRhY3RTdWdnZXN0aW9uW107XG59XG4iXX0=
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MergeContactsModalComponent } from './merge-contacts-modal.component';
|
|
4
|
+
import { H4Module } from '../../atoms/h4/h4.module';
|
|
5
|
+
import { ParagraphModule } from '../../atoms/paragraph/paragraph.module';
|
|
6
|
+
import { IconModule } from '../../atoms/icon/icon.module';
|
|
7
|
+
import { ButtonV2Module } from '../../atoms/button-v2/button.module';
|
|
8
|
+
import { IconWrapperModule } from '../../atoms/icon-wrapper/icon-wrapper.module';
|
|
9
|
+
import { InputRadioModule } from '../../atoms/input-radio/input-radio.module';
|
|
10
|
+
import { StatusPillModule } from '../../atoms/status-pill/status-pill.module';
|
|
11
|
+
import { H5Module } from '../../atoms/h5/h5.module';
|
|
12
|
+
import { SfxLoaderModule } from '../../atoms/sfx-loader/sfx-loader.module';
|
|
13
|
+
import { GridCellClickedOpenNewTabModule } from '../../atoms/grid/framework/grid-cell-clicked-open-new-tab/grid-cell-clicked-open-new-tab.module';
|
|
14
|
+
import { ToasterAlertModule } from '../../atoms/toaster-alert/toaster-alert.module';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
export class MergeContactsModalModule {
|
|
17
|
+
}
|
|
18
|
+
MergeContactsModalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
19
|
+
MergeContactsModalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalModule, declarations: [MergeContactsModalComponent], imports: [CommonModule,
|
|
20
|
+
H4Module,
|
|
21
|
+
ParagraphModule,
|
|
22
|
+
IconModule,
|
|
23
|
+
ButtonV2Module,
|
|
24
|
+
IconWrapperModule,
|
|
25
|
+
InputRadioModule,
|
|
26
|
+
StatusPillModule,
|
|
27
|
+
H5Module,
|
|
28
|
+
SfxLoaderModule,
|
|
29
|
+
GridCellClickedOpenNewTabModule,
|
|
30
|
+
ToasterAlertModule], exports: [MergeContactsModalComponent] });
|
|
31
|
+
MergeContactsModalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalModule, imports: [[
|
|
32
|
+
CommonModule,
|
|
33
|
+
H4Module,
|
|
34
|
+
ParagraphModule,
|
|
35
|
+
IconModule,
|
|
36
|
+
ButtonV2Module,
|
|
37
|
+
IconWrapperModule,
|
|
38
|
+
InputRadioModule,
|
|
39
|
+
StatusPillModule,
|
|
40
|
+
H5Module,
|
|
41
|
+
SfxLoaderModule,
|
|
42
|
+
GridCellClickedOpenNewTabModule,
|
|
43
|
+
ToasterAlertModule,
|
|
44
|
+
]] });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactsModalModule, decorators: [{
|
|
46
|
+
type: NgModule,
|
|
47
|
+
args: [{
|
|
48
|
+
declarations: [MergeContactsModalComponent],
|
|
49
|
+
imports: [
|
|
50
|
+
CommonModule,
|
|
51
|
+
H4Module,
|
|
52
|
+
ParagraphModule,
|
|
53
|
+
IconModule,
|
|
54
|
+
ButtonV2Module,
|
|
55
|
+
IconWrapperModule,
|
|
56
|
+
InputRadioModule,
|
|
57
|
+
StatusPillModule,
|
|
58
|
+
H5Module,
|
|
59
|
+
SfxLoaderModule,
|
|
60
|
+
GridCellClickedOpenNewTabModule,
|
|
61
|
+
ToasterAlertModule,
|
|
62
|
+
],
|
|
63
|
+
exports: [MergeContactsModalComponent],
|
|
64
|
+
}]
|
|
65
|
+
}] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtY29udGFjdHMtbW9kYWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9vcmdhbmlzbXMvbWVyZ2UtY29udGFjdHMtbW9kYWwvbWVyZ2UtY29udGFjdHMtbW9kYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDekUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLGlHQUFpRyxDQUFDO0FBQ2xKLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDOztBQW9CcEYsTUFBTSxPQUFPLHdCQUF3Qjs7cUhBQXhCLHdCQUF3QjtzSEFBeEIsd0JBQXdCLGlCQWpCcEIsMkJBQTJCLGFBRXhDLFlBQVk7UUFDWixRQUFRO1FBQ1IsZUFBZTtRQUNmLFVBQVU7UUFDVixjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLGdCQUFnQjtRQUNoQixnQkFBZ0I7UUFDaEIsUUFBUTtRQUNSLGVBQWU7UUFDZiwrQkFBK0I7UUFDL0Isa0JBQWtCLGFBRVYsMkJBQTJCO3NIQUUxQix3QkFBd0IsWUFoQjFCO1lBQ1AsWUFBWTtZQUNaLFFBQVE7WUFDUixlQUFlO1lBQ2YsVUFBVTtZQUNWLGNBQWM7WUFDZCxpQkFBaUI7WUFDakIsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixRQUFRO1lBQ1IsZUFBZTtZQUNmLCtCQUErQjtZQUMvQixrQkFBa0I7U0FDbkI7MkZBR1Usd0JBQXdCO2tCQWxCcEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDM0MsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osUUFBUTt3QkFDUixlQUFlO3dCQUNmLFVBQVU7d0JBQ1YsY0FBYzt3QkFDZCxpQkFBaUI7d0JBQ2pCLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQixRQUFRO3dCQUNSLGVBQWU7d0JBQ2YsK0JBQStCO3dCQUMvQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO2lCQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWVyZ2VDb250YWN0c01vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9tZXJnZS1jb250YWN0cy1tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSDRNb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9oNC9oNC5tb2R1bGUnO1xuaW1wb3J0IHsgUGFyYWdyYXBoTW9kdWxlIH0gZnJvbSAnLi4vLi4vYXRvbXMvcGFyYWdyYXBoL3BhcmFncmFwaC5tb2R1bGUnO1xuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gJy4uLy4uL2F0b21zL2ljb24vaWNvbi5tb2R1bGUnO1xuaW1wb3J0IHsgQnV0dG9uVjJNb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9idXR0b24tdjIvYnV0dG9uLm1vZHVsZSc7XG5pbXBvcnQgeyBJY29uV3JhcHBlck1vZHVsZSB9IGZyb20gJy4uLy4uL2F0b21zL2ljb24td3JhcHBlci9pY29uLXdyYXBwZXIubW9kdWxlJztcbmltcG9ydCB7IElucHV0UmFkaW9Nb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9pbnB1dC1yYWRpby9pbnB1dC1yYWRpby5tb2R1bGUnO1xuaW1wb3J0IHsgU3RhdHVzUGlsbE1vZHVsZSB9IGZyb20gJy4uLy4uL2F0b21zL3N0YXR1cy1waWxsL3N0YXR1cy1waWxsLm1vZHVsZSc7XG5pbXBvcnQgeyBINU1vZHVsZSB9IGZyb20gJy4uLy4uL2F0b21zL2g1L2g1Lm1vZHVsZSc7XG5pbXBvcnQgeyBTZnhMb2FkZXJNb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9zZngtbG9hZGVyL3NmeC1sb2FkZXIubW9kdWxlJztcbmltcG9ydCB7IEdyaWRDZWxsQ2xpY2tlZE9wZW5OZXdUYWJNb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9ncmlkL2ZyYW1ld29yay9ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIvZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLm1vZHVsZSc7XG5pbXBvcnQgeyBUb2FzdGVyQWxlcnRNb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy90b2FzdGVyLWFsZXJ0L3RvYXN0ZXItYWxlcnQubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTWVyZ2VDb250YWN0c01vZGFsQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBINE1vZHVsZSxcbiAgICBQYXJhZ3JhcGhNb2R1bGUsXG4gICAgSWNvbk1vZHVsZSxcbiAgICBCdXR0b25WMk1vZHVsZSxcbiAgICBJY29uV3JhcHBlck1vZHVsZSxcbiAgICBJbnB1dFJhZGlvTW9kdWxlLFxuICAgIFN0YXR1c1BpbGxNb2R1bGUsXG4gICAgSDVNb2R1bGUsXG4gICAgU2Z4TG9hZGVyTW9kdWxlLFxuICAgIEdyaWRDZWxsQ2xpY2tlZE9wZW5OZXdUYWJNb2R1bGUsXG4gICAgVG9hc3RlckFsZXJ0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbTWVyZ2VDb250YWN0c01vZGFsQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTWVyZ2VDb250YWN0c01vZGFsTW9kdWxlIHt9XG4iXX0=
|
|
@@ -32,7 +32,7 @@ import { FilterDetailModule } from './filter-detail/filter-detail.module';
|
|
|
32
32
|
import { ReportsCardListModule } from './reports-card-list/reports-card-list.module';
|
|
33
33
|
import { GridActionBarV2Module } from './grid-action-bar-v2/grid-action-bar-v2.module';
|
|
34
34
|
import { GenerateLicenseModalModule } from './generate-license-modal/generate-license-modal.module';
|
|
35
|
-
|
|
35
|
+
import { MergeContactsModalModule } from './merge-contacts-modal/merge-contacts-modal.module';
|
|
36
36
|
import { AISearchAssistantDrawerModule } from './ai-search-assistant-drawer/ai-search-assistant-drawer.module';
|
|
37
37
|
import { SaveSearchModalModule } from './save-search-modal/save-search-modal.module';
|
|
38
38
|
import * as i0 from "@angular/core";
|
|
@@ -72,7 +72,7 @@ OrganismsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version
|
|
|
72
72
|
ReportsCardListModule,
|
|
73
73
|
GridActionBarV2Module,
|
|
74
74
|
GenerateLicenseModalModule,
|
|
75
|
-
|
|
75
|
+
MergeContactsModalModule,
|
|
76
76
|
AISearchAssistantDrawerModule,
|
|
77
77
|
SaveSearchModalModule] });
|
|
78
78
|
OrganismsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: OrganismsModule, imports: [[
|
|
@@ -109,7 +109,7 @@ OrganismsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version
|
|
|
109
109
|
ReportsCardListModule,
|
|
110
110
|
GridActionBarV2Module,
|
|
111
111
|
GenerateLicenseModalModule,
|
|
112
|
-
|
|
112
|
+
MergeContactsModalModule,
|
|
113
113
|
AISearchAssistantDrawerModule,
|
|
114
114
|
SaveSearchModalModule
|
|
115
115
|
]] });
|
|
@@ -151,10 +151,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
|
|
|
151
151
|
ReportsCardListModule,
|
|
152
152
|
GridActionBarV2Module,
|
|
153
153
|
GenerateLicenseModalModule,
|
|
154
|
-
|
|
154
|
+
MergeContactsModalModule,
|
|
155
155
|
AISearchAssistantDrawerModule,
|
|
156
156
|
SaveSearchModalModule
|
|
157
157
|
]
|
|
158
158
|
}]
|
|
159
159
|
}] });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"organisms.module.js","sourceRoot":"","sources":["../../../../projects/component-library/src/lib/organisms/organisms.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NoteListModule } from './note-list/note-list.module';\nimport { TaskListModule } from './task-list/task-list.module';\nimport { TypographyModule } from '../design-guide/typography/typography.module';\nimport { IconExplorerModule } from '../design-guide/icon-explorer/icon-explorer.module';\nimport { CardListModule } from './card-list/card-list.module';\nimport { ConfirmationModalModule } from './confirmation-modal/confirmation-modal.module';\nimport { UploadResumeModalModule } from './upload-resume-modal/upload-resume-modal.module';\nimport { FeedbackCardListModule } from './feedback-card-list/feedback-card-list.module';\nimport { FeedbackDetailHeaderModule } from './feedback-detail-header/feedback-detail-header.module';\nimport { FeedbackDetailCandidateInfoModule } from './feedback-detail-candidate-info/feedback-detail-candidate-info.module';\nimport { FeedbackLoginModalModule } from './feedback-login-modal/feedback-login-modal.module';\nimport { GridActionsModule } from './grid-actions/grid-actions.module';\nimport { GridControlsModule } from './grid-controls/grid-controls.module';\nimport { GridDownloadModule } from './grid-download/grid-download.module';\nimport { ActionBarModule } from './action-bar/action-bar.module';\nimport { ActionBarJobListModule } from './action-bar-job-list/action-bar-job-list.module';\nimport { DocumentManagementListModule } from './document-management-list/document-management-list.module';\nimport { InputCheckboxListModule } from './input-checkbox-list/input-checkbox-list.module';\nimport { SettingsDetailNavigationListModule } from './settings-detail-navigation-list/settings-detail-navigation-list.module';\nimport { EditableSettingItemListModule } from './editable-setting-item-list/editable-setting-item-list.module';\nimport { AdditionalInformationCardListModule } from './additional-information-card-list/additional-information-card-list.module';\nimport { AdditionModalModule } from './addition-modal/addition-modal.module';\nimport { H4Module } from \"../atoms/h4/h4.module\";\nimport { ParagraphModule } from \"../atoms/paragraph/paragraph.module\";\nimport { ButtonModule } from \"../atoms/button/button.module\";\nimport { InformationModalModule } from './information-modal/information-modal.module';\nimport { ChatHistoryMessageListModule } from './chat-history-message-list/chat-history-message-list.module';\nimport { AssignedToWidgetModule } from './assigned-to-widget/assigned-to-widget.module';\nimport { FilterDetailModule } from './filter-detail/filter-detail.module';\nimport { ReportsCardListModule } from './reports-card-list/reports-card-list.module';\nimport { GridActionBarV2Module } from './grid-action-bar-v2/grid-action-bar-v2.module';\nimport { GenerateLicenseModalModule } from './generate-license-modal/generate-license-modal.module';\n// import { MergeContactsModalModule } from './merge-contacts-modal/merge-contacts-modal.module';\nimport { AISearchAssistantDrawerModule } from './ai-search-assistant-drawer/ai-search-assistant-drawer.module';\nimport { SaveSearchModalModule } from './save-search-modal/save-search-modal.module';\n\n@NgModule({\n    declarations: [\n    ],\n    imports: [\n        CommonModule,\n        NoteListModule,\n        TaskListModule,\n        TypographyModule,\n        IconExplorerModule,\n        CardListModule,\n        ConfirmationModalModule,\n        UploadResumeModalModule,\n        FeedbackCardListModule,\n        FeedbackDetailHeaderModule,\n        FeedbackDetailCandidateInfoModule,\n        FeedbackLoginModalModule,\n        GridActionsModule,\n        GridControlsModule,\n        GridDownloadModule,\n        ActionBarModule,\n        ActionBarJobListModule,\n        DocumentManagementListModule,\n        InputCheckboxListModule,\n        SettingsDetailNavigationListModule,\n        EditableSettingItemListModule,\n        AdditionalInformationCardListModule,\n        AdditionModalModule,\n        H4Module,\n        ParagraphModule,\n        ButtonModule,\n        InformationModalModule,\n        ChatHistoryMessageListModule,\n        AssignedToWidgetModule,\n        FilterDetailModule,\n        ReportsCardListModule,\n        GridActionBarV2Module,\n        GenerateLicenseModalModule,\n        // MergeContactsModalModule,\n        AISearchAssistantDrawerModule,\n        SaveSearchModalModule\n    ]\n})\nexport class OrganismsModule {}\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"organisms.module.js","sourceRoot":"","sources":["../../../../projects/component-library/src/lib/organisms/organisms.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NoteListModule } from './note-list/note-list.module';\nimport { TaskListModule } from './task-list/task-list.module';\nimport { TypographyModule } from '../design-guide/typography/typography.module';\nimport { IconExplorerModule } from '../design-guide/icon-explorer/icon-explorer.module';\nimport { CardListModule } from './card-list/card-list.module';\nimport { ConfirmationModalModule } from './confirmation-modal/confirmation-modal.module';\nimport { UploadResumeModalModule } from './upload-resume-modal/upload-resume-modal.module';\nimport { FeedbackCardListModule } from './feedback-card-list/feedback-card-list.module';\nimport { FeedbackDetailHeaderModule } from './feedback-detail-header/feedback-detail-header.module';\nimport { FeedbackDetailCandidateInfoModule } from './feedback-detail-candidate-info/feedback-detail-candidate-info.module';\nimport { FeedbackLoginModalModule } from './feedback-login-modal/feedback-login-modal.module';\nimport { GridActionsModule } from './grid-actions/grid-actions.module';\nimport { GridControlsModule } from './grid-controls/grid-controls.module';\nimport { GridDownloadModule } from './grid-download/grid-download.module';\nimport { ActionBarModule } from './action-bar/action-bar.module';\nimport { ActionBarJobListModule } from './action-bar-job-list/action-bar-job-list.module';\nimport { DocumentManagementListModule } from './document-management-list/document-management-list.module';\nimport { InputCheckboxListModule } from './input-checkbox-list/input-checkbox-list.module';\nimport { SettingsDetailNavigationListModule } from './settings-detail-navigation-list/settings-detail-navigation-list.module';\nimport { EditableSettingItemListModule } from './editable-setting-item-list/editable-setting-item-list.module';\nimport { AdditionalInformationCardListModule } from './additional-information-card-list/additional-information-card-list.module';\nimport { AdditionModalModule } from './addition-modal/addition-modal.module';\nimport { H4Module } from \"../atoms/h4/h4.module\";\nimport { ParagraphModule } from \"../atoms/paragraph/paragraph.module\";\nimport { ButtonModule } from \"../atoms/button/button.module\";\nimport { InformationModalModule } from './information-modal/information-modal.module';\nimport { ChatHistoryMessageListModule } from './chat-history-message-list/chat-history-message-list.module';\nimport { AssignedToWidgetModule } from './assigned-to-widget/assigned-to-widget.module';\nimport { FilterDetailModule } from './filter-detail/filter-detail.module';\nimport { ReportsCardListModule } from './reports-card-list/reports-card-list.module';\nimport { GridActionBarV2Module } from './grid-action-bar-v2/grid-action-bar-v2.module';\nimport { GenerateLicenseModalModule } from './generate-license-modal/generate-license-modal.module';\nimport { MergeContactsModalModule } from './merge-contacts-modal/merge-contacts-modal.module';\nimport { AISearchAssistantDrawerModule } from './ai-search-assistant-drawer/ai-search-assistant-drawer.module';\nimport { SaveSearchModalModule } from './save-search-modal/save-search-modal.module';\n\n@NgModule({\n    declarations: [\n    ],\n    imports: [\n        CommonModule,\n        NoteListModule,\n        TaskListModule,\n        TypographyModule,\n        IconExplorerModule,\n        CardListModule,\n        ConfirmationModalModule,\n        UploadResumeModalModule,\n        FeedbackCardListModule,\n        FeedbackDetailHeaderModule,\n        FeedbackDetailCandidateInfoModule,\n        FeedbackLoginModalModule,\n        GridActionsModule,\n        GridControlsModule,\n        GridDownloadModule,\n        ActionBarModule,\n        ActionBarJobListModule,\n        DocumentManagementListModule,\n        InputCheckboxListModule,\n        SettingsDetailNavigationListModule,\n        EditableSettingItemListModule,\n        AdditionalInformationCardListModule,\n        AdditionModalModule,\n        H4Module,\n        ParagraphModule,\n        ButtonModule,\n        InformationModalModule,\n        ChatHistoryMessageListModule,\n        AssignedToWidgetModule,\n        FilterDetailModule,\n        ReportsCardListModule,\n        GridActionBarV2Module,\n        GenerateLicenseModalModule,\n        MergeContactsModalModule,\n        AISearchAssistantDrawerModule,\n        SaveSearchModalModule\n    ]\n})\nexport class OrganismsModule {}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class GridCellClickedOpenNewTabComponent {
|
|
4
4
|
constructor() {
|
|
@@ -12,9 +12,11 @@ export class GridCellClickedOpenNewTabComponent {
|
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
GridCellClickedOpenNewTabComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
GridCellClickedOpenNewTabComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", ngImport: i0, template: "<a\n id=\"grid-cell-link-open-new-tab\"\n class=\"sfx-font-bold sfx-cursor-pointer\"\n [href]=\"newTabUrl\"\n target=\"_blank\"\n>\n <i class=\"si-menu-return icon-open-new-tab\"></i>\n</a>", styles: [".icon-open-new-tab:after{content:\"\";display:inline-block;width:16px;height:16px;background:transparent;position:relative;top:3px;left:-10px;border-radius:3px 0 3px 3px/3px 0px 3px 3px;border:2px solid #334860}.icon-open-new-tab:before{transform:rotate(145deg);display:inline-block;font-size:14px;top:-5px;position:relative;right:-11px;color:#334860}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
15
|
+
GridCellClickedOpenNewTabComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: GridCellClickedOpenNewTabComponent, selector: "symphony-grid-cell-clicked-open-new-tab", inputs: { newTabUrl: "newTabUrl" }, ngImport: i0, template: "<a\n id=\"grid-cell-link-open-new-tab\"\n class=\"sfx-font-bold sfx-cursor-pointer\"\n [href]=\"newTabUrl\"\n target=\"_blank\"\n>\n <i class=\"si-menu-return icon-open-new-tab\"></i>\n</a>", styles: [".icon-open-new-tab:after{content:\"\";display:inline-block;width:16px;height:16px;background:transparent;position:relative;top:3px;left:-10px;border-radius:3px 0 3px 3px/3px 0px 3px 3px;border:2px solid #334860}.icon-open-new-tab:before{transform:rotate(145deg);display:inline-block;font-size:14px;top:-5px;position:relative;right:-11px;color:#334860}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
16
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabComponent, decorators: [{
|
|
17
17
|
type: Component,
|
|
18
18
|
args: [{ selector: 'symphony-grid-cell-clicked-open-new-tab', encapsulation: ViewEncapsulation.None, template: "<a\n id=\"grid-cell-link-open-new-tab\"\n class=\"sfx-font-bold sfx-cursor-pointer\"\n [href]=\"newTabUrl\"\n target=\"_blank\"\n>\n <i class=\"si-menu-return icon-open-new-tab\"></i>\n</a>", styles: [".icon-open-new-tab:after{content:\"\";display:inline-block;width:16px;height:16px;background:transparent;position:relative;top:3px;left:-10px;border-radius:3px 0 3px 3px/3px 0px 3px 3px;border:2px solid #334860}.icon-open-new-tab:before{transform:rotate(145deg);display:inline-block;font-size:14px;top:-5px;position:relative;right:-11px;color:#334860}\n"] }]
|
|
19
|
-
}]
|
|
20
|
-
|
|
19
|
+
}], propDecorators: { newTabUrl: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}] } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudC1saWJyYXJ5L3NyYy9saWIvYXRvbXMvZ3JpZC9mcmFtZXdvcmsvZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiL2dyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnQtbGlicmFyeS9zcmMvbGliL2F0b21zL2dyaWQvZnJhbWV3b3JrL2dyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYi9ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBU3BFLE1BQU0sT0FBTyxrQ0FBa0M7SUFOL0M7UUFPVyxjQUFTLEdBQVcsRUFBRSxDQUFDO0tBU2pDO0lBUEMsTUFBTSxDQUFDLE1BQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDOzsrSEFUVSxrQ0FBa0M7bUhBQWxDLGtDQUFrQyxtSENUL0Msb01BT0k7MkZERVMsa0NBQWtDO2tCQU45QyxTQUFTOytCQUNFLHlDQUF5QyxpQkFHcEMsaUJBQWlCLENBQUMsSUFBSTs4QkFHNUIsU0FBUztzQkFBakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJQ2VsbFJlbmRlcmVyQW5ndWxhckNvbXAgfSBmcm9tICdhZy1ncmlkLWFuZ3VsYXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzeW1waG9ueS1ncmlkLWNlbGwtY2xpY2tlZC1vcGVuLW5ldy10YWInLFxuICB0ZW1wbGF0ZVVybDogJy4vZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgR3JpZENlbGxDbGlja2VkT3Blbk5ld1RhYkNvbXBvbmVudCBpbXBsZW1lbnRzIElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB7XG4gIEBJbnB1dCgpIG5ld1RhYlVybDogc3RyaW5nID0gJyc7XG5cbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XG4gICAgdGhpcy5uZXdUYWJVcmwgPSBwYXJhbXMudmFsdWU7XG4gIH1cblxuICByZWZyZXNoKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuIiwiPGFcbiAgaWQ9XCJncmlkLWNlbGwtbGluay1vcGVuLW5ldy10YWJcIlxuICBjbGFzcz1cInNmeC1mb250LWJvbGQgc2Z4LWN1cnNvci1wb2ludGVyXCJcbiAgW2hyZWZdPVwibmV3VGFiVXJsXCJcbiAgdGFyZ2V0PVwiX2JsYW5rXCJcbj5cbiAgPGkgY2xhc3M9XCJzaS1tZW51LXJldHVybiBpY29uLW9wZW4tbmV3LXRhYlwiPjwvaT5cbjwvYT4iXX0=
|
|
@@ -5,7 +5,7 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
export class GridCellClickedOpenNewTabModule {
|
|
6
6
|
}
|
|
7
7
|
GridCellClickedOpenNewTabModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
-
GridCellClickedOpenNewTabModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabModule, declarations: [GridCellClickedOpenNewTabComponent], imports: [CommonModule] });
|
|
8
|
+
GridCellClickedOpenNewTabModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabModule, declarations: [GridCellClickedOpenNewTabComponent], imports: [CommonModule], exports: [GridCellClickedOpenNewTabComponent] });
|
|
9
9
|
GridCellClickedOpenNewTabModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: GridCellClickedOpenNewTabModule, imports: [[
|
|
10
10
|
CommonModule
|
|
11
11
|
]] });
|
|
@@ -15,7 +15,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
|
|
|
15
15
|
declarations: [GridCellClickedOpenNewTabComponent],
|
|
16
16
|
imports: [
|
|
17
17
|
CommonModule
|
|
18
|
-
]
|
|
18
|
+
],
|
|
19
|
+
exports: [GridCellClickedOpenNewTabComponent]
|
|
19
20
|
}]
|
|
20
21
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudC1saWJyYXJ5L3NyYy9saWIvYXRvbXMvZ3JpZC9mcmFtZXdvcmsvZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiL2dyaWQtY2VsbC1jbGlja2VkLW9wZW4tbmV3LXRhYi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sNENBQTRDLENBQUM7O0FBV2hHLE1BQU0sT0FBTywrQkFBK0I7OzRIQUEvQiwrQkFBK0I7NkhBQS9CLCtCQUErQixpQkFOM0Isa0NBQWtDLGFBRS9DLFlBQVksYUFFSixrQ0FBa0M7NkhBRWpDLCtCQUErQixZQUxqQztZQUNQLFlBQVk7U0FDYjsyRkFHVSwrQkFBK0I7a0JBUDNDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0NBQWtDLENBQUM7b0JBQ2xELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3FCQUNiO29CQUNELE9BQU8sRUFBRSxDQUFDLGtDQUFrQyxDQUFDO2lCQUM5QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgR3JpZENlbGxDbGlja2VkT3Blbk5ld1RhYkNvbXBvbmVudCB9IGZyb20gJy4vZ3JpZC1jZWxsLWNsaWNrZWQtb3Blbi1uZXctdGFiLmNvbXBvbmVudCc7XG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtHcmlkQ2VsbENsaWNrZWRPcGVuTmV3VGFiQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbR3JpZENlbGxDbGlja2VkT3Blbk5ld1RhYkNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgR3JpZENlbGxDbGlja2VkT3Blbk5ld1RhYk1vZHVsZSB7IH1cbiJdfQ==
|
|
@@ -21,10 +21,10 @@ export class MergeContactClickedOpenModalComponent {
|
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
MergeContactClickedOpenModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactClickedOpenModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
24
|
-
MergeContactClickedOpenModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactClickedOpenModalComponent, selector: "symphony-merge-contact-clicked-open-modal", outputs: { clicked: "clicked" }, ngImport: i0, template: "<button\n id=\"merge-contact-open-modal\"\n class=\"icon-merge-contact-clicked-open-modal sfx-font-bold sfx-cursor-pointer si-merge\"\n [disabled]=\"!enableMergeButton\"\n (click)=\"onClick()\"\n aria-label=\"Merge Contact\"\n type=\"button\"\n [title]=\"!enableMergeButton ? 'No Duplicates Exist' : 'Merge Duplicates'\"\n>\n</button>", styles: [".icon-merge-contact-clicked-open-modal{background:none;border:none;padding:0;margin:0;display:inline-block;align-items:center;font-size:14px;top:2px;position:relative;color:#334860;outline:none;cursor:pointer}
|
|
24
|
+
MergeContactClickedOpenModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: MergeContactClickedOpenModalComponent, selector: "symphony-merge-contact-clicked-open-modal", outputs: { clicked: "clicked" }, ngImport: i0, template: "<button\n id=\"merge-contact-open-modal\"\n class=\"icon-merge-contact-clicked-open-modal sfx-font-bold sfx-cursor-pointer si-merge\"\n [disabled]=\"!enableMergeButton\"\n (click)=\"onClick()\"\n aria-label=\"Merge Contact\"\n type=\"button\"\n [title]=\"!enableMergeButton ? 'No Duplicates Exist' : 'Merge Duplicates'\"\n>\n</button>", styles: [".icon-merge-contact-clicked-open-modal{background:none;border:none;padding:0;margin:0;display:inline-block;align-items:center;font-size:14px;top:2px;position:relative;color:#334860;outline:none;cursor:pointer}.icon-merge-contact-clicked-open-modal:disabled{cursor:not-allowed;opacity:50%}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: MergeContactClickedOpenModalComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
27
|
-
args: [{ selector: 'symphony-merge-contact-clicked-open-modal', encapsulation: ViewEncapsulation.None, template: "<button\n id=\"merge-contact-open-modal\"\n class=\"icon-merge-contact-clicked-open-modal sfx-font-bold sfx-cursor-pointer si-merge\"\n [disabled]=\"!enableMergeButton\"\n (click)=\"onClick()\"\n aria-label=\"Merge Contact\"\n type=\"button\"\n [title]=\"!enableMergeButton ? 'No Duplicates Exist' : 'Merge Duplicates'\"\n>\n</button>", styles: [".icon-merge-contact-clicked-open-modal{background:none;border:none;padding:0;margin:0;display:inline-block;align-items:center;font-size:14px;top:2px;position:relative;color:#334860;outline:none;cursor:pointer}
|
|
27
|
+
args: [{ selector: 'symphony-merge-contact-clicked-open-modal', encapsulation: ViewEncapsulation.None, template: "<button\n id=\"merge-contact-open-modal\"\n class=\"icon-merge-contact-clicked-open-modal sfx-font-bold sfx-cursor-pointer si-merge\"\n [disabled]=\"!enableMergeButton\"\n (click)=\"onClick()\"\n aria-label=\"Merge Contact\"\n type=\"button\"\n [title]=\"!enableMergeButton ? 'No Duplicates Exist' : 'Merge Duplicates'\"\n>\n</button>", styles: [".icon-merge-contact-clicked-open-modal{background:none;border:none;padding:0;margin:0;display:inline-block;align-items:center;font-size:14px;top:2px;position:relative;color:#334860;outline:none;cursor:pointer}.icon-merge-contact-clicked-open-modal:disabled{cursor:not-allowed;opacity:50%}\n"] }]
|
|
28
28
|
}], propDecorators: { clicked: [{
|
|
29
29
|
type: Output
|
|
30
30
|
}] } });
|
|
@@ -6,20 +6,21 @@ export class InputRadioComponent {
|
|
|
6
6
|
this.clicked = new EventEmitter();
|
|
7
7
|
}
|
|
8
8
|
onClick() {
|
|
9
|
-
this.isActive ? (this.isActive = false) : (this.isActive = true);
|
|
10
9
|
this.clicked.emit({
|
|
11
10
|
label: this.label,
|
|
12
|
-
isActive:
|
|
11
|
+
isActive: true,
|
|
13
12
|
});
|
|
14
13
|
}
|
|
15
14
|
}
|
|
16
15
|
InputRadioComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: InputRadioComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
-
InputRadioComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: InputRadioComponent, selector: "symphony-input-radio", inputs: { isActive: "isActive", label: "label", isRequired: "isRequired" }, outputs: { clicked: "clicked" }, ngImport: i0, template: "<div class=\"sfx-radio\" (click)=\"onClick()\">\n <input\n type=\"radio\"\n class=\"sfx-radio-input
|
|
16
|
+
InputRadioComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: InputRadioComponent, selector: "symphony-input-radio", inputs: { isActive: "isActive", name: "name", label: "label", isRequired: "isRequired" }, outputs: { clicked: "clicked" }, ngImport: i0, template: "<div class=\"sfx-radio\" (click)=\"onClick()\">\n <input\n type=\"radio\"\n class=\"sfx-radio-input\"\n [checked]=\"isActive\"\n [name]=\"name || label\"\n id=\"{{ label }}\"\n />\n <label for=\"{{ label }}\" class=\"Font400\"\n >{{ label }}<span class=\"requiredField\" *ngIf=\"isRequired\">*</span></label\n >\n</div>\n", styles: [".requiredField{color:#000!important}.sfx-radio{margin:10px 0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.sfx-radio .sfx-radio-input{top:0;left:0;width:100%;cursor:inherit;height:100%;margin:0;opacity:0;padding:0;z-index:1}.sfx-radio .sfx-radio-input~label{display:inline-block;position:relative;cursor:pointer;height:100%;line-height:20px;font-size:14px;color:#000;font-family:neuzeit_groteskbold}.sfx-radio .sfx-radio-input+*:before{content:\"\";display:inline-block;vertical-align:bottom;width:1rem;height:1rem;margin-right:.5rem;margin-bottom:.2rem;border-radius:50%;border-style:solid;border-width:.1rem;border-color:#000}.sfx-radio .sfx-radio-input:checked+*:before{background:radial-gradient(black 0%,black 40%,transparent 50%,transparent)}.sfx-radio .sfx-radio-input:checked+*{color:#000}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
18
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: InputRadioComponent, decorators: [{
|
|
19
18
|
type: Component,
|
|
20
|
-
args: [{ selector: 'symphony-input-radio', template: "<div class=\"sfx-radio\" (click)=\"onClick()\">\n <input\n type=\"radio\"\n class=\"sfx-radio-input
|
|
19
|
+
args: [{ selector: 'symphony-input-radio', template: "<div class=\"sfx-radio\" (click)=\"onClick()\">\n <input\n type=\"radio\"\n class=\"sfx-radio-input\"\n [checked]=\"isActive\"\n [name]=\"name || label\"\n id=\"{{ label }}\"\n />\n <label for=\"{{ label }}\" class=\"Font400\"\n >{{ label }}<span class=\"requiredField\" *ngIf=\"isRequired\">*</span></label\n >\n</div>\n", styles: [".requiredField{color:#000!important}.sfx-radio{margin:10px 0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.sfx-radio .sfx-radio-input{top:0;left:0;width:100%;cursor:inherit;height:100%;margin:0;opacity:0;padding:0;z-index:1}.sfx-radio .sfx-radio-input~label{display:inline-block;position:relative;cursor:pointer;height:100%;line-height:20px;font-size:14px;color:#000;font-family:neuzeit_groteskbold}.sfx-radio .sfx-radio-input+*:before{content:\"\";display:inline-block;vertical-align:bottom;width:1rem;height:1rem;margin-right:.5rem;margin-bottom:.2rem;border-radius:50%;border-style:solid;border-width:.1rem;border-color:#000}.sfx-radio .sfx-radio-input:checked+*:before{background:radial-gradient(black 0%,black 40%,transparent 50%,transparent)}.sfx-radio .sfx-radio-input:checked+*{color:#000}\n"] }]
|
|
21
20
|
}], ctorParameters: function () { return []; }, propDecorators: { isActive: [{
|
|
22
21
|
type: Input
|
|
22
|
+
}], name: [{
|
|
23
|
+
type: Input
|
|
23
24
|
}], label: [{
|
|
24
25
|
type: Input
|
|
25
26
|
}], isRequired: [{
|
|
@@ -27,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
|
|
|
27
28
|
}], clicked: [{
|
|
28
29
|
type: Output
|
|
29
30
|
}] } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtcmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9hdG9tcy9pbnB1dC1yYWRpby9pbnB1dC1yYWRpby5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnQtbGlicmFyeS9zcmMvbGliL2F0b21zL2lucHV0LXJhZGlvL2lucHV0LXJhZGlvLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU92RSxNQUFNLE9BQU8sbUJBQW1CO0lBUTlCO1FBRlUsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFFN0IsQ0FBQztJQUVoQixPQUFPO1FBQ0wsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7WUFDaEIsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2pCLFFBQVEsRUFBRSxJQUFJO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7Z0hBZlUsbUJBQW1CO29HQUFuQixtQkFBbUIsdUxDUGhDLHlWQVlBOzJGRExhLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDRSxzQkFBc0I7MEVBS3ZCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUVJLE9BQU87c0JBQWhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzeW1waG9ueS1pbnB1dC1yYWRpbycsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbnB1dC1yYWRpby5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2lucHV0LXJhZGlvLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIElucHV0UmFkaW9Db21wb25lbnQge1xuICBASW5wdXQoKSBpc0FjdGl2ZTogYm9vbGVhbjtcbiAgQElucHV0KCkgbmFtZT86IHN0cmluZztcbiAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcbiAgQElucHV0KCkgaXNSZXF1aXJlZDogYm9vbGVhbjtcblxuICBAT3V0cHV0KCkgY2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBvbkNsaWNrKCkge1xuICAgIHRoaXMuY2xpY2tlZC5lbWl0KHtcbiAgICAgIGxhYmVsOiB0aGlzLmxhYmVsLFxuICAgICAgaXNBY3RpdmU6IHRydWUsXG4gICAgfSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzZngtcmFkaW9cIiAoY2xpY2spPVwib25DbGljaygpXCI+XG4gIDxpbnB1dFxuICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgY2xhc3M9XCJzZngtcmFkaW8taW5wdXRcIlxuICAgIFtjaGVja2VkXT1cImlzQWN0aXZlXCJcbiAgICBbbmFtZV09XCJuYW1lIHx8IGxhYmVsXCJcbiAgICBpZD1cInt7IGxhYmVsIH19XCJcbiAgLz5cbiAgPGxhYmVsIGZvcj1cInt7IGxhYmVsIH19XCIgY2xhc3M9XCJGb250NDAwXCJcbiAgICA+e3sgbGFiZWwgfX08c3BhbiBjbGFzcz1cInJlcXVpcmVkRmllbGRcIiAqbmdJZj1cImlzUmVxdWlyZWRcIj4qPC9zcGFuPjwvbGFiZWxcbiAgPlxuPC9kaXY+XG4iXX0=
|
|
@@ -113,7 +113,10 @@ export class InputTextareaWithSendComponent {
|
|
|
113
113
|
this.onChange('');
|
|
114
114
|
this.valueChanged.emit('');
|
|
115
115
|
if (this.autoResize) {
|
|
116
|
-
setTimeout(() =>
|
|
116
|
+
setTimeout(() => {
|
|
117
|
+
this.adjustTextareaHeight();
|
|
118
|
+
this.refreshInputState();
|
|
119
|
+
}, 0);
|
|
117
120
|
}
|
|
118
121
|
}
|
|
119
122
|
}
|
|
@@ -162,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
|
|
|
162
165
|
type: ViewChild,
|
|
163
166
|
args: ['textareaElement']
|
|
164
167
|
}] } });
|
|
165
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-textarea-with-send.component.js","sourceRoot":"","sources":["../../../../../../../projects/component-library/src/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.ts","../../../../../../../projects/component-library/src/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, ViewChild, ElementRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'symphony-input-textarea-with-send',\n  templateUrl: './input-textarea-with-send.component.html',\n  styleUrls: ['./input-textarea-with-send.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputTextareaWithSendComponent),\n      multi: true\n    }\n  ]\n})\nexport class InputTextareaWithSendComponent implements ControlValueAccessor, AfterViewInit {\n  @Input() placeholder: string = 'Type your message...';\n  @Input() isDisabled: boolean = false;\n  @Input() maxCharacterLimit?: number;\n  @Input() showCharacterCount: boolean = false;\n  @Input() minRows: number = 1;\n  @Input() maxRows: number = 6;\n  @Input() sendButtonIcon: string = 'si-arrow-next';\n  @Input() sendButtonAriaLabel: string = 'Send message';\n  @Input() autoResize: boolean = true;\n\n  @Output() sendClicked = new EventEmitter<string>();\n  @Output() enterPressed = new EventEmitter<string>();\n  @Output() valueChanged = new EventEmitter<string>();\n\n  @ViewChild('textareaElement') textareaElement!: ElementRef<HTMLTextAreaElement>;\n\n  value: string = '';\n  currentRows: number = 1;\n  characterCount: number = 0;\n  characterLimitExceeded: boolean = false;\n  canSendMessage: boolean = false;\n  \n  private onChange = (value: string) => {};\n  public onTouched = () => {};\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    if (this.autoResize) {\n      this.adjustTextareaHeight();\n    }\n    // Initialize computed properties\n    this.refreshInputState();\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: string): void {\n    this.value = value || '';\n    this.refreshInputState();\n    if (this.autoResize) {\n      setTimeout(() => this.adjustTextareaHeight(), 0);\n    }\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  onInputChange(event: Event): void {\n    const target = event.target as HTMLTextAreaElement;\n    this.value = target.value;\n    // Update computed properties for character count and send button\n    this.refreshInputState();\n    this.onChange(this.value);\n    this.valueChanged.emit(this.value);\n    this.cdr.detectChanges();\n    \n    if (this.autoResize) {\n      this.adjustTextareaHeight();\n    }\n  }\n\n  onInputKeyPress(event: KeyboardEvent): void {\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      if (this.canSendMessage) {\n        this.onSendClick();\n      }\n    }\n  }\n\n  onSendClick(): void {\n    if (this.canSendMessage) {\n      this.sendClicked.emit(this.value);\n      this.enterPressed.emit(this.value);\n    }\n  }\n\n  private adjustTextareaHeight(): void {\n    if (!this.textareaElement) return;\n\n    const textarea = this.textareaElement.nativeElement;\n    \n    // Reset height to auto to get the scroll height\n    textarea.style.height = 'auto';\n    \n    // Calculate the number of lines\n    const lineHeight = 24; // Base line height in pixels\n    const padding = 16; // Top + bottom padding\n    const minHeight = this.minRows * lineHeight + padding;\n    const maxHeight = this.maxRows * lineHeight + padding;\n    \n    let newHeight = Math.max(textarea.scrollHeight, minHeight);\n    newHeight = Math.min(newHeight, maxHeight);\n    \n    textarea.style.height = newHeight + 'px';\n    \n    // Update current rows for styling purposes\n    this.currentRows = Math.ceil((newHeight - padding) / lineHeight);\n  }\n\n  private refreshInputState(): void {\n    // Update character count\n    this.characterCount = this.value?.length || 0;\n    \n    // Update character limit exceeded status\n    this.characterLimitExceeded = !!this.maxCharacterLimit && this.characterCount > this.maxCharacterLimit;\n    \n    // Update can send status\n    const trimmedValue = this.value?.trim();\n    const hasValue = !!trimmedValue;\n    const withinLimit = !this.maxCharacterLimit || this.characterCount <= this.maxCharacterLimit;\n    \n    this.canSendMessage = !this.isDisabled && hasValue && withinLimit;\n  }\n\n  focus(): void {\n    if (this.textareaElement) {\n      this.textareaElement.nativeElement.focus();\n    }\n  }\n\n  clear(): void {\n    this.value = '';\n    this.onChange('');\n    this.valueChanged.emit('');\n    \n    if (this.autoResize) {\n      setTimeout(() => this.adjustTextareaHeight(), 0);\n    }\n  }\n} ","<div class=\"input-textarea-with-send-container\">\n  <!-- Character Counter -->\n  <div \n    class=\"character-counter sfx-mb-10\"\n    *ngIf=\"showCharacterCount && maxCharacterLimit\">\n    <span \n      class=\"counter-text\"\n      [class.counter-exceeded]=\"characterLimitExceeded\">\n      {{ characterCount }} / {{ maxCharacterLimit }}\n    </span>\n  </div>\n\n  <!-- Input with Send Button -->\n  <div class=\"input-wrapper\">\n    <textarea\n      #textareaElement\n      class=\"textarea-input\"\n      [value]=\"value\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"isDisabled\"\n      [maxLength]=\"maxCharacterLimit\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onInputKeyPress($event)\"\n      (blur)=\"onTouched()\"\n      rows=\"1\">\n    </textarea>\n    \n    <!-- Send Button -->\n    <button\n      type=\"button\"\n      class=\"send-button\"\n      [class.enabled]=\"canSendMessage\"\n      [class.disabled]=\"!canSendMessage\"\n      [disabled]=\"!canSendMessage\"\n      (click)=\"onSendClick()\"\n      id=\"button-textarea-send\"\n      [attr.aria-label]=\"sendButtonAriaLabel\">\n      <symphony-icon [icon]=\"sendButtonIcon\" [size]=\"'10px'\"></symphony-icon>\n    </button>\n  </div>\n</div> "]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-textarea-with-send.component.js","sourceRoot":"","sources":["../../../../../../../projects/component-library/src/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.ts","../../../../../../../projects/component-library/src/lib/atoms/input-textarea-with-send/input-textarea-with-send.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, ViewChild, ElementRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'symphony-input-textarea-with-send',\n  templateUrl: './input-textarea-with-send.component.html',\n  styleUrls: ['./input-textarea-with-send.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputTextareaWithSendComponent),\n      multi: true\n    }\n  ]\n})\nexport class InputTextareaWithSendComponent implements ControlValueAccessor, AfterViewInit {\n  @Input() placeholder: string = 'Type your message...';\n  @Input() isDisabled: boolean = false;\n  @Input() maxCharacterLimit?: number;\n  @Input() showCharacterCount: boolean = false;\n  @Input() minRows: number = 1;\n  @Input() maxRows: number = 6;\n  @Input() sendButtonIcon: string = 'si-arrow-next';\n  @Input() sendButtonAriaLabel: string = 'Send message';\n  @Input() autoResize: boolean = true;\n\n  @Output() sendClicked = new EventEmitter<string>();\n  @Output() enterPressed = new EventEmitter<string>();\n  @Output() valueChanged = new EventEmitter<string>();\n\n  @ViewChild('textareaElement') textareaElement!: ElementRef<HTMLTextAreaElement>;\n\n  value: string = '';\n  currentRows: number = 1;\n  characterCount: number = 0;\n  characterLimitExceeded: boolean = false;\n  canSendMessage: boolean = false;\n  \n  private onChange = (value: string) => {};\n  public onTouched = () => {};\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    if (this.autoResize) {\n      this.adjustTextareaHeight();\n    }\n    // Initialize computed properties\n    this.refreshInputState();\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: string): void {\n    this.value = value || '';\n    this.refreshInputState();\n    if (this.autoResize) {\n      setTimeout(() => this.adjustTextareaHeight(), 0);\n    }\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  onInputChange(event: Event): void {\n    const target = event.target as HTMLTextAreaElement;\n    this.value = target.value;\n    // Update computed properties for character count and send button\n    this.refreshInputState();\n    this.onChange(this.value);\n    this.valueChanged.emit(this.value);\n    this.cdr.detectChanges();\n    \n    if (this.autoResize) {\n      this.adjustTextareaHeight();\n    }\n  }\n\n  onInputKeyPress(event: KeyboardEvent): void {\n    if (event.key === 'Enter' && !event.shiftKey) {\n      event.preventDefault();\n      if (this.canSendMessage) {\n        this.onSendClick();\n      }\n    }\n  }\n\n  onSendClick(): void {\n    if (this.canSendMessage) {\n      this.sendClicked.emit(this.value);\n      this.enterPressed.emit(this.value);\n    }\n  }\n\n  private adjustTextareaHeight(): void {\n    if (!this.textareaElement) return;\n\n    const textarea = this.textareaElement.nativeElement;\n    \n    // Reset height to auto to get the scroll height\n    textarea.style.height = 'auto';\n    \n    // Calculate the number of lines\n    const lineHeight = 24; // Base line height in pixels\n    const padding = 16; // Top + bottom padding\n    const minHeight = this.minRows * lineHeight + padding;\n    const maxHeight = this.maxRows * lineHeight + padding;\n    \n    let newHeight = Math.max(textarea.scrollHeight, minHeight);\n    newHeight = Math.min(newHeight, maxHeight);\n    \n    textarea.style.height = newHeight + 'px';\n    \n    // Update current rows for styling purposes\n    this.currentRows = Math.ceil((newHeight - padding) / lineHeight);\n  }\n\n  private refreshInputState(): void {\n    // Update character count\n    this.characterCount = this.value?.length || 0;\n    \n    // Update character limit exceeded status\n    this.characterLimitExceeded = !!this.maxCharacterLimit && this.characterCount > this.maxCharacterLimit;\n    \n    // Update can send status\n    const trimmedValue = this.value?.trim();\n    const hasValue = !!trimmedValue;\n    const withinLimit = !this.maxCharacterLimit || this.characterCount <= this.maxCharacterLimit;\n    \n    this.canSendMessage = !this.isDisabled && hasValue && withinLimit;\n  }\n\n  focus(): void {\n    if (this.textareaElement) {\n      this.textareaElement.nativeElement.focus();\n    }\n  }\n\n  clear(): void {\n    this.value = '';\n    this.onChange('');\n    this.valueChanged.emit('');\n    \n    if (this.autoResize) {\n      setTimeout(() => {\n        this.adjustTextareaHeight();\n        this.refreshInputState();\n      }, 0);\n    }\n  }\n} ","<div class=\"input-textarea-with-send-container\">\n  <!-- Character Counter -->\n  <div \n    class=\"character-counter sfx-mb-10\"\n    *ngIf=\"showCharacterCount && maxCharacterLimit\">\n    <span \n      class=\"counter-text\"\n      [class.counter-exceeded]=\"characterLimitExceeded\">\n      {{ characterCount }} / {{ maxCharacterLimit }}\n    </span>\n  </div>\n\n  <!-- Input with Send Button -->\n  <div class=\"input-wrapper\">\n    <textarea\n      #textareaElement\n      class=\"textarea-input\"\n      [value]=\"value\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"isDisabled\"\n      [maxLength]=\"maxCharacterLimit\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onInputKeyPress($event)\"\n      (blur)=\"onTouched()\"\n      rows=\"1\">\n    </textarea>\n    \n    <!-- Send Button -->\n    <button\n      type=\"button\"\n      class=\"send-button\"\n      [class.enabled]=\"canSendMessage\"\n      [class.disabled]=\"!canSendMessage\"\n      [disabled]=\"!canSendMessage\"\n      (click)=\"onSendClick()\"\n      id=\"button-textarea-send\"\n      [attr.aria-label]=\"sendButtonAriaLabel\">\n      <symphony-icon [icon]=\"sendButtonIcon\" [size]=\"'10px'\"></symphony-icon>\n    </button>\n  </div>\n</div> "]}
|