tango-app-ui-manage-users 3.7.0-alpha.1 → 3.7.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/tango-manage-users/assign-store-popup/assign-store-popup.component.mjs +19 -17
- package/esm2022/lib/components/tango-manage-users/brand-user/brand-user.component.mjs +25 -19
- package/esm2022/lib/components/tango-manage-users/user-table/alert-popup/alert-popup.component.mjs +23 -12
- package/esm2022/lib/components-v2/add-users/add-users.component.mjs +3 -3
- package/esm2022/lib/components-v2/chip-select/chip-select.component.mjs +178 -0
- package/esm2022/lib/components-v2/teams-creation/teams-creation.component.mjs +21 -9
- package/esm2022/lib/components-v2/teams-list/teams-list.component.mjs +37 -26
- package/esm2022/lib/components-v2/users-manage/users-manage.component.mjs +12 -9
- package/esm2022/lib/services-v2/manage-users.service.mjs +5 -1
- package/esm2022/lib/tango-manage-users.module.mjs +6 -3
- package/fesm2022/tango-app-ui-manage-users.mjs +314 -95
- package/fesm2022/tango-app-ui-manage-users.mjs.map +1 -1
- package/lib/components/tango-manage-users/brand-user/brand-user.component.d.ts +4 -1
- package/lib/components/tango-manage-users/user-table/alert-popup/alert-popup.component.d.ts +8 -4
- package/lib/components-v2/chip-select/chip-select.component.d.ts +36 -0
- package/lib/components-v2/teams-creation/teams-creation.component.d.ts +3 -0
- package/lib/components-v2/teams-list/teams-list.component.d.ts +2 -0
- package/lib/components-v2/users-manage/users-manage.component.d.ts +3 -1
- package/lib/services-v2/manage-users.service.d.ts +2 -0
- package/lib/tango-manage-users.module.d.ts +8 -7
- package/package.json +1 -1
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services-v2/manage-users.service";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@angular/forms";
|
|
6
|
+
export class ChipSelectComponent {
|
|
7
|
+
cd;
|
|
8
|
+
authService;
|
|
9
|
+
onClick(event) {
|
|
10
|
+
const target = event.target;
|
|
11
|
+
if (!target.closest('.dropdown')) {
|
|
12
|
+
this.showDropdown = false;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
items;
|
|
16
|
+
searchField;
|
|
17
|
+
multi;
|
|
18
|
+
idField;
|
|
19
|
+
selectedValues = [];
|
|
20
|
+
disabled;
|
|
21
|
+
label;
|
|
22
|
+
badgeValue;
|
|
23
|
+
searchKey;
|
|
24
|
+
selected = new EventEmitter();
|
|
25
|
+
filteredValues = [];
|
|
26
|
+
showDropdown;
|
|
27
|
+
searchValue;
|
|
28
|
+
instanceId;
|
|
29
|
+
constructor(cd, authService) {
|
|
30
|
+
this.cd = cd;
|
|
31
|
+
this.authService = authService;
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this.instanceId = crypto.randomUUID();
|
|
35
|
+
this.authService.dropDownTrigger.subscribe((e) => {
|
|
36
|
+
if (e !== this.instanceId) {
|
|
37
|
+
this.showDropdown = false;
|
|
38
|
+
this.cd.detectChanges();
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
ngOnChanges(changes) {
|
|
43
|
+
if (changes['items'] && this.items?.length) {
|
|
44
|
+
this.initializeItems();
|
|
45
|
+
}
|
|
46
|
+
if (changes['selectedValues'] && Array.isArray(changes['selectedValues']?.currentValue)) {
|
|
47
|
+
this.updateSelectedValues();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
initializeItems() {
|
|
51
|
+
this.filteredValues = this.items.map((item) => ({ ...item }));
|
|
52
|
+
this.updateSelectedValues();
|
|
53
|
+
}
|
|
54
|
+
updateSelectedValues() {
|
|
55
|
+
this.filteredValues?.forEach((filteredItem) => {
|
|
56
|
+
filteredItem.isSelected = false;
|
|
57
|
+
});
|
|
58
|
+
this.selectedValues?.forEach((selectedItem) => {
|
|
59
|
+
const item = this.filteredValues?.find((filteredItem) => filteredItem?.[this.idField] === selectedItem?.[this.idField]);
|
|
60
|
+
if (item) {
|
|
61
|
+
item.isSelected = true;
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
openDropdown(event) {
|
|
66
|
+
this.authService.dropDownTrigger.next(this.instanceId);
|
|
67
|
+
event.stopPropagation();
|
|
68
|
+
this.showDropdown = !this.showDropdown;
|
|
69
|
+
}
|
|
70
|
+
onInput(event) {
|
|
71
|
+
if (!event.target.value) {
|
|
72
|
+
this.filteredValues = [...this.items];
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
const searchTerm = event?.target?.value.toLowerCase();
|
|
76
|
+
this.filteredValues = this.items?.filter((item) => this.searchField.some(field => item[field]?.toLowerCase().includes(searchTerm.toLowerCase())));
|
|
77
|
+
// this.filteredValues = this.items?.filter((item: any) =>
|
|
78
|
+
// item[this.searchField]?.toLowerCase().includes(searchTerm)
|
|
79
|
+
// );
|
|
80
|
+
}
|
|
81
|
+
this.updateSelectedValues();
|
|
82
|
+
this.cd.detectChanges();
|
|
83
|
+
}
|
|
84
|
+
onSelect(event, item) {
|
|
85
|
+
if (this.multi) {
|
|
86
|
+
if (event.currentTarget.checked) {
|
|
87
|
+
this.selectedValues.push(item);
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
this.selectedValues = this.selectedValues.filter((elem) => elem[this.idField] !== item[this.idField]);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.selectedValues = [{ ...item }];
|
|
95
|
+
this.filteredValues.forEach((element) => {
|
|
96
|
+
if (element[this.idField] !== item[this.idField]) {
|
|
97
|
+
element.isSelected = false;
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
this.showDropdown = false;
|
|
101
|
+
}
|
|
102
|
+
const valuesToEmit = this.selectedValues.map((value) => {
|
|
103
|
+
const selectedItem = { ...value };
|
|
104
|
+
delete selectedItem.isSelected;
|
|
105
|
+
return selectedItem;
|
|
106
|
+
});
|
|
107
|
+
this.cd.detectChanges();
|
|
108
|
+
this.emitSelectedValues(valuesToEmit);
|
|
109
|
+
}
|
|
110
|
+
onSelectAll(event) {
|
|
111
|
+
const selectAll = event.currentTarget.checked;
|
|
112
|
+
this.filteredValues.forEach((item) => item.isSelected = selectAll);
|
|
113
|
+
if (selectAll) {
|
|
114
|
+
this.selectedValues = [...this.filteredValues];
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
this.selectedValues = [];
|
|
118
|
+
}
|
|
119
|
+
const valuesToEmit = this.selectedValues.map((value) => {
|
|
120
|
+
const { isSelected, ...selectedItem } = value;
|
|
121
|
+
return selectedItem;
|
|
122
|
+
});
|
|
123
|
+
this.cd.detectChanges();
|
|
124
|
+
this.emitSelectedValues(valuesToEmit);
|
|
125
|
+
}
|
|
126
|
+
emitSelectedValues(values) {
|
|
127
|
+
if (this.multi) {
|
|
128
|
+
this.selected.emit(values);
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
this.selected.emit(values[0]);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
checkIfAllSelected() {
|
|
135
|
+
return this.filteredValues.every((item) => item.isSelected);
|
|
136
|
+
}
|
|
137
|
+
removeBadge(data, index) {
|
|
138
|
+
// this.removed.emit([data._id])
|
|
139
|
+
this.selectedValues = this.selectedValues.reduce((acc, item) => {
|
|
140
|
+
if (item._id !== data._id) {
|
|
141
|
+
acc.push(item);
|
|
142
|
+
}
|
|
143
|
+
return acc;
|
|
144
|
+
}, []);
|
|
145
|
+
this.emitSelectedValues(this.selectedValues);
|
|
146
|
+
this.updateSelectedValues();
|
|
147
|
+
}
|
|
148
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChipSelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ManageUsersService }], target: i0.ɵɵFactoryTarget.Component });
|
|
149
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ChipSelectComponent, selector: "lib-chip-select", inputs: { items: "items", searchField: "searchField", multi: "multi", idField: "idField", selectedValues: "selectedValues", disabled: "disabled", label: "label", badgeValue: "badgeValue", searchKey: "searchKey" }, outputs: { selected: "selected" }, host: { listeners: { "document:click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"chip-box\">\r\n <div class=\"outer-container d-flex align-items-center position-relative w-100\">\r\n <div class=\"input-container form-control\">\r\n <ng-container *ngFor=\"let item of selectedValues;let i=index\">\r\n <span *ngIf=\"i <= 9\" class=\"chip\">\r\n <span class=\"me-3\">{{item?.[searchKey[0]] || item?.[searchKey[1]]}}</span>\r\n <span (click)=\"removeBadge(item,i)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n </span>\r\n </ng-container>\r\n <span *ngIf=\"selectedValues?.length > 9\" class=\"chip\"> +{{selectedValues?.length - 9}}</span>\r\n <input style=\"min-height: 44px;\" type=\"text\" class=\"form-control dropdown-input ps-3 me-3\" [(ngModel)]=\"searchValue\" (click)=\"openDropdown($event)\" (input)=\"onInput($event)\" id=\"searchInput\">\r\n </div>\r\n </div>\r\n <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-chip dropdown\" >\r\n <!-- <div class=\"w-100 input-wrapper\">\r\n <input [(ngModel)]=\"searchValue\" placeholder=\"Search\" (input)=\"onInput($event)\" type=\"text\"> \r\n <svg class=\"search-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg> \r\n </div> -->\r\n <ul>\r\n <li *ngIf=\"multi && filteredValues?.length\">\r\n <label class=\"form-check\" for=\"selectAll\">\r\n <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n id=\"selectAll\">\r\n <span class=\"form-check-label\">\r\n Select All\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi ? '': 'ps-0'\" class=\"form-check\">\r\n <input [ngClass]=\"multi ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n [id]=\"item[idField] + instanceId\">\r\n <span class=\"form-check-label\" >\r\n <!-- {{item[searchKey[0]] || item?.[searchKey[1]]}} -->\r\n {{item[searchField[0] || item?.[searchField[1]]]}}\r\n </span> <span class=\"badge-value ms-5\">\r\n {{item[badgeValue]}}\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngIf=\"!filteredValues?.length\" >\r\n <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n </li>\r\n </ul> \r\n </div> \r\n \r\n</div>", styles: [":host{width:100%;height:100%}.chip-box{position:relative;background-color:#fff}.chip-box .form-select{font-size:1.1rem;font-weight:600;border-radius:8px!important;color:var(--Gray-500, #344054);border:1px solid var(--Gray-300, #D0D5DD)!important;min-height:42.5px;max-height:300px!important}.chip-box .disable-input{pointer-events:none;background-color:#f9fafb!important}.chip-box .input-chip{position:absolute;width:100%;z-index:1}.chip-box .input-chip .input-wrapper{padding:8px 10px;background-color:#fff;border-top-right-radius:8px;border-top-left-radius:8px;border-top:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.chip-box .input-chip .input-wrapper input{width:100%;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);box-shadow:0 1px 2px #1018280d;padding:10px 14px 10px 30px;outline:none}.chip-box .input-chip .input-wrapper input ::placeholder{color:var(--Gray-500, #667085);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.chip-box .input-chip .input-wrapper .search-icon{position:absolute;left:20px;top:20px}.chip-box .input-chip ul{position:relative;background-color:#fff;margin:0;padding:0;max-height:200px;min-height:auto;overflow-y:auto;border-bottom-right-radius:8px;border-bottom-left-radius:8px;border-bottom:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.chip-box .input-chip ul .selected{background:#f9fafb}.chip-box .input-chip ul li{list-style:none;padding:10px 16px;cursor:pointer}.chip-box .input-chip ul li label{cursor:pointer}.chip-box .input-chip ul li:hover{background:#f9fafb}.outer-container{position:relative}.outer-container .form-control{padding-top:0;padding-bottom:0}.outer-container .input-container{min-height:auto;max-height:100px!important;overflow:auto;width:100%;display:flex;flex-wrap:wrap}.outer-container .input-container input{all:unset;flex:1;min-width:50px}.outer-container .input-container .chip{margin:10px 0 10px 10px;padding:3px 10px;border-radius:16px;background:var(--Gray-100, #F2F4F7);color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.outer-container .input-container .chip:nth-child(1){margin-left:0}.form-check{display:flex;align-items:center}.form-check-input{height:16px;width:16px;border-radius:4px;border:1px solid var(--Primary-600, #00A3FF)}.form-check-input:checked{--bs-form-check-bg-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAICAYAAADA+m62AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAB4SURBVHgBhY7NDUBQEIRnqcJNKXTg6qYTStCB+Isy6IQSNMDa9SLh5eWZZPcw+81kCX/quABhD73QyKXsGoyIvNCJSto2hEhNtY4N9cwYeMXEsVqB1GaSauRQOpty2tSmO3FgloAmF5nEhgyoesMO6CuFW66fn2xdFyA3ZzcRLrMAAAAASUVORK5CYII=);background-color:#eaf8ff;border-color:#00a3ff}.form-check-label{color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-style:normal;font-weight:500;line-height:20px}.badge-value{color:var(--Gray-500, #667085);font-size:12px;font-weight:500;line-height:18px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
150
|
+
}
|
|
151
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChipSelectComponent, decorators: [{
|
|
152
|
+
type: Component,
|
|
153
|
+
args: [{ selector: 'lib-chip-select', template: "<div class=\"chip-box\">\r\n <div class=\"outer-container d-flex align-items-center position-relative w-100\">\r\n <div class=\"input-container form-control\">\r\n <ng-container *ngFor=\"let item of selectedValues;let i=index\">\r\n <span *ngIf=\"i <= 9\" class=\"chip\">\r\n <span class=\"me-3\">{{item?.[searchKey[0]] || item?.[searchKey[1]]}}</span>\r\n <span (click)=\"removeBadge(item,i)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n </span>\r\n </ng-container>\r\n <span *ngIf=\"selectedValues?.length > 9\" class=\"chip\"> +{{selectedValues?.length - 9}}</span>\r\n <input style=\"min-height: 44px;\" type=\"text\" class=\"form-control dropdown-input ps-3 me-3\" [(ngModel)]=\"searchValue\" (click)=\"openDropdown($event)\" (input)=\"onInput($event)\" id=\"searchInput\">\r\n </div>\r\n </div>\r\n <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-chip dropdown\" >\r\n <!-- <div class=\"w-100 input-wrapper\">\r\n <input [(ngModel)]=\"searchValue\" placeholder=\"Search\" (input)=\"onInput($event)\" type=\"text\"> \r\n <svg class=\"search-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg> \r\n </div> -->\r\n <ul>\r\n <li *ngIf=\"multi && filteredValues?.length\">\r\n <label class=\"form-check\" for=\"selectAll\">\r\n <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n id=\"selectAll\">\r\n <span class=\"form-check-label\">\r\n Select All\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi ? '': 'ps-0'\" class=\"form-check\">\r\n <input [ngClass]=\"multi ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n [id]=\"item[idField] + instanceId\">\r\n <span class=\"form-check-label\" >\r\n <!-- {{item[searchKey[0]] || item?.[searchKey[1]]}} -->\r\n {{item[searchField[0] || item?.[searchField[1]]]}}\r\n </span> <span class=\"badge-value ms-5\">\r\n {{item[badgeValue]}}\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngIf=\"!filteredValues?.length\" >\r\n <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n </li>\r\n </ul> \r\n </div> \r\n \r\n</div>", styles: [":host{width:100%;height:100%}.chip-box{position:relative;background-color:#fff}.chip-box .form-select{font-size:1.1rem;font-weight:600;border-radius:8px!important;color:var(--Gray-500, #344054);border:1px solid var(--Gray-300, #D0D5DD)!important;min-height:42.5px;max-height:300px!important}.chip-box .disable-input{pointer-events:none;background-color:#f9fafb!important}.chip-box .input-chip{position:absolute;width:100%;z-index:1}.chip-box .input-chip .input-wrapper{padding:8px 10px;background-color:#fff;border-top-right-radius:8px;border-top-left-radius:8px;border-top:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.chip-box .input-chip .input-wrapper input{width:100%;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);box-shadow:0 1px 2px #1018280d;padding:10px 14px 10px 30px;outline:none}.chip-box .input-chip .input-wrapper input ::placeholder{color:var(--Gray-500, #667085);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.chip-box .input-chip .input-wrapper .search-icon{position:absolute;left:20px;top:20px}.chip-box .input-chip ul{position:relative;background-color:#fff;margin:0;padding:0;max-height:200px;min-height:auto;overflow-y:auto;border-bottom-right-radius:8px;border-bottom-left-radius:8px;border-bottom:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.chip-box .input-chip ul .selected{background:#f9fafb}.chip-box .input-chip ul li{list-style:none;padding:10px 16px;cursor:pointer}.chip-box .input-chip ul li label{cursor:pointer}.chip-box .input-chip ul li:hover{background:#f9fafb}.outer-container{position:relative}.outer-container .form-control{padding-top:0;padding-bottom:0}.outer-container .input-container{min-height:auto;max-height:100px!important;overflow:auto;width:100%;display:flex;flex-wrap:wrap}.outer-container .input-container input{all:unset;flex:1;min-width:50px}.outer-container .input-container .chip{margin:10px 0 10px 10px;padding:3px 10px;border-radius:16px;background:var(--Gray-100, #F2F4F7);color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.outer-container .input-container .chip:nth-child(1){margin-left:0}.form-check{display:flex;align-items:center}.form-check-input{height:16px;width:16px;border-radius:4px;border:1px solid var(--Primary-600, #00A3FF)}.form-check-input:checked{--bs-form-check-bg-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAICAYAAADA+m62AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAB4SURBVHgBhY7NDUBQEIRnqcJNKXTg6qYTStCB+Isy6IQSNMDa9SLh5eWZZPcw+81kCX/quABhD73QyKXsGoyIvNCJSto2hEhNtY4N9cwYeMXEsVqB1GaSauRQOpty2tSmO3FgloAmF5nEhgyoesMO6CuFW66fn2xdFyA3ZzcRLrMAAAAASUVORK5CYII=);background-color:#eaf8ff;border-color:#00a3ff}.form-check-label{color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-style:normal;font-weight:500;line-height:20px}.badge-value{color:var(--Gray-500, #667085);font-size:12px;font-weight:500;line-height:18px}\n"] }]
|
|
154
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ManageUsersService }], propDecorators: { onClick: [{
|
|
155
|
+
type: HostListener,
|
|
156
|
+
args: ['document:click', ['$event']]
|
|
157
|
+
}], items: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], searchField: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], multi: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], idField: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], selectedValues: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], disabled: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], label: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], badgeValue: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], searchKey: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], selected: [{
|
|
176
|
+
type: Output
|
|
177
|
+
}] } });
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip-select.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-manage-users/src/lib/components-v2/chip-select/chip-select.component.ts","../../../../../../projects/tango-manage-users/src/lib/components-v2/chip-select/chip-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { ManageUsersService } from '../../services-v2/manage-users.service';\r\n\r\n@Component({\r\n  selector: 'lib-chip-select',\r\n  templateUrl: './chip-select.component.html',\r\n  styleUrl: './chip-select.component.scss'\r\n})\r\nexport class ChipSelectComponent implements OnInit, OnChanges {\r\n\r\n  @HostListener('document:click', ['$event'])\r\n    onClick(event: MouseEvent) {\r\n      const target = event.target as HTMLElement;\r\n      if (!target.closest('.dropdown')) {\r\n        this.showDropdown = false;\r\n      }\r\n    }\r\n   \r\n    @Input() items: any\r\n    @Input() searchField:any[]\r\n    @Input() multi: boolean\r\n    @Input() idField: string\r\n    @Input() selectedValues: any = []\r\n    @Input() disabled: boolean | undefined\r\n    @Input() label: string\r\n    @Input() badgeValue: string\r\n    @Input() searchKey: any;\r\n   \r\n    @Output() selected = new EventEmitter<any>()\r\n    filteredValues: any = []\r\n    showDropdown: boolean\r\n    searchValue: string\r\n    instanceId: any;\r\n   \r\n   \r\n    constructor(private cd: ChangeDetectorRef, private authService: ManageUsersService) { }\r\n    ngOnInit(): void {\r\n      this.instanceId = crypto.randomUUID();\r\n      this.authService.dropDownTrigger.subscribe((e)=>{           \r\n        if(e !== this.instanceId){        \r\n          this.showDropdown = false\r\n          this.cd.detectChanges()\r\n        }\r\n      })\r\n    }\r\n   \r\n    ngOnChanges(changes: SimpleChanges): void {\r\n   \r\n      if (changes['items'] && this.items?.length) {\r\n        this.initializeItems();\r\n      }\r\n  \r\n      if (changes['selectedValues'] && Array.isArray(changes['selectedValues']?.currentValue)) {            \r\n        this.updateSelectedValues();\r\n      }\r\n    }\r\n   \r\n    initializeItems() {\r\n      this.filteredValues = this.items.map((item: any) => ({ ...item }));\r\n      this.updateSelectedValues()\r\n    }\r\n   \r\n    updateSelectedValues() { \r\n      this.filteredValues?.forEach((filteredItem: any) => {\r\n        filteredItem.isSelected = false;\r\n      });\r\n  \r\n      this.selectedValues?.forEach((selectedItem: any) => {\r\n        const item = this.filteredValues?.find((filteredItem: any) => filteredItem?.[this.idField] === selectedItem?.[this.idField]);\r\n        if (item) {\r\n          item.isSelected = true;\r\n        }\r\n      });\r\n    }\r\n   \r\n    openDropdown(event: any) {\r\n      this.authService.dropDownTrigger.next(this.instanceId)\r\n      event.stopPropagation();\r\n      this.showDropdown = !this.showDropdown;\r\n    }\r\n   \r\n    onInput(event: any) {\r\n      if (!event.target.value) {\r\n        this.filteredValues = [...this.items];\r\n      } else {\r\n        const searchTerm = event?.target?.value.toLowerCase();\r\n        this.filteredValues = this.items?.filter((item: any) => \r\n          this.searchField.some(field => item[field]?.toLowerCase().includes(searchTerm.toLowerCase()))\r\n        );\r\n        // this.filteredValues = this.items?.filter((item: any) =>\r\n        //   item[this.searchField]?.toLowerCase().includes(searchTerm)\r\n        // );\r\n      }\r\n      this.updateSelectedValues();\r\n      this.cd.detectChanges();\r\n    }\r\n   \r\n    onSelect(event: any, item: any) {    \r\n      if (this.multi) {\r\n        if (event.currentTarget.checked) {\r\n          this.selectedValues.push(item );        \r\n        } else {\r\n          this.selectedValues = this.selectedValues.filter((elem: any) => elem[this.idField] !== item[this.idField]);\r\n        }\r\n      } else {\r\n        this.selectedValues = [{ ...item }];\r\n        this.filteredValues.forEach((element:any) => {\r\n          if(element[this.idField] !== item[this.idField]){\r\n            element.isSelected = false\r\n          }\r\n        });\r\n        this.showDropdown = false;\r\n        \r\n      }\r\n      const valuesToEmit = this.selectedValues.map((value: any) => {\r\n        const selectedItem = { ...value };\r\n        delete selectedItem.isSelected;\r\n        return selectedItem;\r\n      });\r\n   \r\n      this.cd.detectChanges();\r\n      this.emitSelectedValues(valuesToEmit);\r\n   \r\n    }\r\n   \r\n    onSelectAll(event: any) {\r\n      const selectAll = event.currentTarget.checked;\r\n      this.filteredValues.forEach((item: any) => item.isSelected = selectAll);\r\n   \r\n      if (selectAll) {\r\n        this.selectedValues = [...this.filteredValues];\r\n      } else {\r\n        this.selectedValues = [];\r\n      }\r\n   \r\n      const valuesToEmit = this.selectedValues.map((value: any) => {\r\n        const { isSelected, ...selectedItem } = value;\r\n        return selectedItem;\r\n      });\r\n   \r\n      this.cd.detectChanges();\r\n      this.emitSelectedValues(valuesToEmit);\r\n    }\r\n   \r\n   \r\n    emitSelectedValues(values: any[]) {\r\n      if (this.multi) {\r\n        this.selected.emit(values);\r\n      } else {\r\n        this.selected.emit(values[0]);\r\n      }\r\n    }\r\n   \r\n    checkIfAllSelected() {\r\n      return this.filteredValues.every((item: any) => item.isSelected);\r\n    }\r\n  \r\n    removeBadge(data:any, index:any) {\r\n      // this.removed.emit([data._id])\r\n      this.selectedValues = this.selectedValues.reduce((acc: any[], item: any) => {\r\n        if (item._id !== data._id) {\r\n            acc.push(item);\r\n        }\r\n        return acc;\r\n    }, []);\r\n      this.emitSelectedValues(this.selectedValues);\r\n      this.updateSelectedValues();\r\n    }\r\n\r\n}\r\n","<div class=\"chip-box\">\r\n    <div class=\"outer-container d-flex align-items-center position-relative w-100\">\r\n        <div class=\"input-container form-control\">\r\n            <ng-container *ngFor=\"let item of selectedValues;let i=index\">\r\n                <span *ngIf=\"i <= 9\" class=\"chip\">\r\n                    <span class=\"me-3\">{{item?.[searchKey[0]] || item?.[searchKey[1]]}}</span>\r\n                    <span (click)=\"removeBadge(item,i)\"><svg\r\n                            xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n                            <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                    </span>\r\n                </span>\r\n            </ng-container>\r\n            <span *ngIf=\"selectedValues?.length > 9\" class=\"chip\"> +{{selectedValues?.length - 9}}</span>\r\n            <input style=\"min-height: 44px;\" type=\"text\" class=\"form-control dropdown-input ps-3 me-3\" [(ngModel)]=\"searchValue\" (click)=\"openDropdown($event)\" (input)=\"onInput($event)\" id=\"searchInput\">\r\n        </div>\r\n    </div>\r\n    <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-chip dropdown\" >\r\n            <!-- <div class=\"w-100 input-wrapper\">\r\n            <input [(ngModel)]=\"searchValue\" placeholder=\"Search\"  (input)=\"onInput($event)\" type=\"text\">  \r\n            <svg class=\"search-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n                <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n            </svg>  \r\n            </div> -->\r\n        <ul>\r\n            <li *ngIf=\"multi && filteredValues?.length\">\r\n                <label class=\"form-check\" for=\"selectAll\">\r\n                    <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n                        id=\"selectAll\">\r\n                    <span class=\"form-check-label\">\r\n                        Select All\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n                <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi  ? '': 'ps-0'\" class=\"form-check\">\r\n                    <input [ngClass]=\"multi  ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n                        [id]=\"item[idField] + instanceId\">\r\n                    <span class=\"form-check-label\" >\r\n                        <!-- {{item[searchKey[0]] || item?.[searchKey[1]]}} -->\r\n                         {{item[searchField[0] || item?.[searchField[1]]]}}\r\n                    </span>  <span class=\"badge-value ms-5\">\r\n                        {{item[badgeValue]}}\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngIf=\"!filteredValues?.length\" >\r\n                <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n            </li>\r\n        </ul>  \r\n    </div>  \r\n   \r\n</div>"]}
|