cps-ui-kit 0.0.1
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/README.md +24 -0
- package/assets/icons/absa-logo.svg +12 -0
- package/assets/icons/access-denied.svg +12 -0
- package/assets/icons/access-menu.svg +11 -0
- package/assets/icons/access-unlock.svg +19 -0
- package/assets/icons/access.svg +9 -0
- package/assets/icons/add-domain.svg +8 -0
- package/assets/icons/add.svg +7 -0
- package/assets/icons/avatar-top-menu.svg +13 -0
- package/assets/icons/avatar.svg +8 -0
- package/assets/icons/bell.svg +7 -0
- package/assets/icons/book.svg +7 -0
- package/assets/icons/bookmark.svg +6 -0
- package/assets/icons/briefcase.svg +12 -0
- package/assets/icons/browse.svg +9 -0
- package/assets/icons/burger-arrow.svg +7 -0
- package/assets/icons/caret-down.svg +6 -0
- package/assets/icons/change.svg +6 -0
- package/assets/icons/checked.svg +15 -0
- package/assets/icons/chevron-down-2.svg +8 -0
- package/assets/icons/chevron-down.svg +6 -0
- package/assets/icons/circle.svg +6 -0
- package/assets/icons/close-x-2.svg +6 -0
- package/assets/icons/close-x.svg +8 -0
- package/assets/icons/community.svg +12 -0
- package/assets/icons/construction.svg +10 -0
- package/assets/icons/controls.svg +29 -0
- package/assets/icons/csv.svg +9 -0
- package/assets/icons/cub.svg +6 -0
- package/assets/icons/database.svg +12 -0
- package/assets/icons/datepicker.svg +8 -0
- package/assets/icons/delete.svg +6 -0
- package/assets/icons/dislike.svg +13 -0
- package/assets/icons/dots.svg +6 -0
- package/assets/icons/download.svg +12 -0
- package/assets/icons/dq.svg +24 -0
- package/assets/icons/dropdown-menu.svg +8 -0
- package/assets/icons/edit.svg +9 -0
- package/assets/icons/expand.svg +9 -0
- package/assets/icons/export.svg +6 -0
- package/assets/icons/eye.svg +8 -0
- package/assets/icons/filter.svg +8 -0
- package/assets/icons/filter_2.svg +11 -0
- package/assets/icons/follow.svg +13 -0
- package/assets/icons/glossary.svg +16 -0
- package/assets/icons/graph.svg +27 -0
- package/assets/icons/grid-view.svg +6 -0
- package/assets/icons/grid.svg +9 -0
- package/assets/icons/health.svg +6 -0
- package/assets/icons/heart.svg +6 -0
- package/assets/icons/help-circle.svg +7 -0
- package/assets/icons/home.svg +21 -0
- package/assets/icons/insight.svg +9 -0
- package/assets/icons/issues.svg +7 -0
- package/assets/icons/jpeg.svg +8 -0
- package/assets/icons/kris.svg +28 -0
- package/assets/icons/last-seen-product.svg +8 -0
- package/assets/icons/like.svg +7 -0
- package/assets/icons/line-vertical.svg +39 -0
- package/assets/icons/lock.svg +7 -0
- package/assets/icons/logout.svg +16 -0
- package/assets/icons/menu-expand.svg +17 -0
- package/assets/icons/minus.svg +10 -0
- package/assets/icons/multiple_users.svg +8 -0
- package/assets/icons/open.svg +7 -0
- package/assets/icons/path.svg +7 -0
- package/assets/icons/pdf.svg +9 -0
- package/assets/icons/plus.svg +6 -0
- package/assets/icons/projects.svg +10 -0
- package/assets/icons/question.svg +13 -0
- package/assets/icons/questions.svg +23 -0
- package/assets/icons/rectangle-rounded.svg +7 -0
- package/assets/icons/refresh-browse.svg +6 -0
- package/assets/icons/remove.svg +9 -0
- package/assets/icons/right.svg +7 -0
- package/assets/icons/schema_filter.svg +7 -0
- package/assets/icons/search.svg +9 -0
- package/assets/icons/settings.svg +9 -0
- package/assets/icons/sliders.svg +13 -0
- package/assets/icons/smart.svg +7 -0
- package/assets/icons/star.svg +6 -0
- package/assets/icons/stepper-completed.svg +6 -0
- package/assets/icons/success.svg +8 -0
- package/assets/icons/suggestion.svg +7 -0
- package/assets/icons/survivorship.svg +25 -0
- package/assets/icons/table-row-error.svg +6 -0
- package/assets/icons/table-row-success.svg +7 -0
- package/assets/icons/table-row-warning.svg +9 -0
- package/assets/icons/toast-error.svg +12 -0
- package/assets/icons/toast-info.svg +12 -0
- package/assets/icons/toast-success.svg +7 -0
- package/assets/icons/toast-warning.svg +12 -0
- package/assets/icons/tools.svg +18 -0
- package/assets/icons/user.svg +7 -0
- package/assets/icons/users.svg +10 -0
- package/assets/icons/vector-down.svg +7 -0
- package/assets/icons/vector-right.svg +6 -0
- package/assets/icons/vector-up.svg +7 -0
- package/assets/icons/vector.svg +7 -0
- package/assets/icons/wallet.svg +10 -0
- package/assets/icons/warning-circle.svg +12 -0
- package/assets/icons/warning.svg +7 -0
- package/assets/icons/widget-button-icon.svg +9 -0
- package/assets/icons/xls.svg +9 -0
- package/esm2020/cps-ui-kit.mjs +5 -0
- package/esm2020/lib/components/cps-button/cps-button.component.mjs +136 -0
- package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +73 -0
- package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +58 -0
- package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +163 -0
- package/esm2020/lib/components/cps-input/cps-input.component.mjs +168 -0
- package/esm2020/lib/components/cps-radio/cps-radio.component.mjs +76 -0
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +302 -0
- package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +103 -0
- package/esm2020/lib/directives/click-outside.directive.mjs +32 -0
- package/esm2020/lib/pipes/combine-labels.pipe.mjs +24 -0
- package/esm2020/lib/pipes/label-by-value.pipe.mjs +15 -0
- package/esm2020/lib/utils/colors-utils.mjs +55 -0
- package/esm2020/lib/utils/size-utils.mjs +22 -0
- package/esm2020/public-api.mjs +12 -0
- package/fesm2015/cps-ui-kit.mjs +1210 -0
- package/fesm2015/cps-ui-kit.mjs.map +1 -0
- package/fesm2020/cps-ui-kit.mjs +1184 -0
- package/fesm2020/cps-ui-kit.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/cps-button/cps-button.component.d.ts +28 -0
- package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +25 -0
- package/lib/components/cps-chip/cps-chip.component.d.ts +16 -0
- package/lib/components/cps-icon/cps-icon.component.d.ts +18 -0
- package/lib/components/cps-input/cps-input.component.d.ts +50 -0
- package/lib/components/cps-radio/cps-radio.component.d.ts +30 -0
- package/lib/components/cps-select/cps-select.component.d.ts +54 -0
- package/lib/components/cps-tag/cps-tag.component.d.ts +29 -0
- package/lib/directives/click-outside.directive.d.ts +10 -0
- package/lib/pipes/combine-labels.pipe.d.ts +7 -0
- package/lib/pipes/label-by-value.pipe.d.ts +7 -0
- package/lib/utils/colors-utils.d.ts +6 -0
- package/lib/utils/size-utils.d.ts +5 -0
- package/package.json +40 -0
- package/public-api.d.ts +8 -0
- package/styles/_colors.scss +456 -0
- package/styles/_variables.scss +1 -0
- package/styles/bootstrap-grid.css +4071 -0
- package/styles/styles.scss +2 -0
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { Subscription } from 'rxjs';
|
|
5
|
+
import { convertSize } from '../../utils/size-utils';
|
|
6
|
+
import { CpsIconComponent } from '../cps-icon/cps-icon.component';
|
|
7
|
+
import { CpsChipComponent } from '../cps-chip/cps-chip.component';
|
|
8
|
+
import { ClickOutsideDirective } from '../../directives/click-outside.directive';
|
|
9
|
+
import { LabelByValuePipe } from '../../pipes/label-by-value.pipe';
|
|
10
|
+
import { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@angular/forms";
|
|
13
|
+
import * as i2 from "@angular/common";
|
|
14
|
+
export class CpsSelectComponent {
|
|
15
|
+
set value(value) {
|
|
16
|
+
value = this._convertValue(value);
|
|
17
|
+
this._value = value;
|
|
18
|
+
this.onChange(value);
|
|
19
|
+
}
|
|
20
|
+
get value() {
|
|
21
|
+
return this._value;
|
|
22
|
+
}
|
|
23
|
+
constructor(_control) {
|
|
24
|
+
this._control = _control;
|
|
25
|
+
this.label = '';
|
|
26
|
+
this.placeholder = 'Please select';
|
|
27
|
+
this.hint = '';
|
|
28
|
+
this.returnObject = true;
|
|
29
|
+
this.multiple = false;
|
|
30
|
+
this.disabled = false;
|
|
31
|
+
this.width = '100%';
|
|
32
|
+
this.selectAll = true;
|
|
33
|
+
this.chips = true;
|
|
34
|
+
this.closableChips = true;
|
|
35
|
+
this.clearable = false;
|
|
36
|
+
this.openOnClear = true;
|
|
37
|
+
this.options = [];
|
|
38
|
+
this.optionLabel = 'label';
|
|
39
|
+
this.optionValue = 'value'; // works only if returnObject === false (TODO potentially can be of any type)
|
|
40
|
+
this.optionInfo = 'info';
|
|
41
|
+
this.hideDetails = false;
|
|
42
|
+
this._value = undefined;
|
|
43
|
+
this.valueChanged = new EventEmitter();
|
|
44
|
+
this._statusChangesSubscription = new Subscription();
|
|
45
|
+
this.error = '';
|
|
46
|
+
this.cvtWidth = '';
|
|
47
|
+
this.isOpened = false;
|
|
48
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
49
|
+
this.onChange = (event) => { };
|
|
50
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
51
|
+
this.onTouched = () => { };
|
|
52
|
+
if (this._control) {
|
|
53
|
+
this._control.valueAccessor = this;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
ngOnChanges(changes) {
|
|
57
|
+
// eslint-disable-next-line dot-notation
|
|
58
|
+
if ('_value' in changes && changes['_value'].isFirstChange()) {
|
|
59
|
+
this.value = this._convertValue(this.value);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
ngOnInit() {
|
|
63
|
+
this.cvtWidth = convertSize(this.width);
|
|
64
|
+
if (this.multiple && !this._value) {
|
|
65
|
+
this._value = [];
|
|
66
|
+
}
|
|
67
|
+
this._statusChangesSubscription = this._control?.statusChanges?.subscribe(() => {
|
|
68
|
+
this._checkErrors();
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
ngOnDestroy() {
|
|
72
|
+
this._statusChangesSubscription?.unsubscribe();
|
|
73
|
+
}
|
|
74
|
+
toggleOptions(dd, show) {
|
|
75
|
+
if (this.disabled || !dd)
|
|
76
|
+
return;
|
|
77
|
+
if (typeof show === 'boolean') {
|
|
78
|
+
if (show)
|
|
79
|
+
dd.classList.add('active');
|
|
80
|
+
else
|
|
81
|
+
dd.classList.remove('active');
|
|
82
|
+
}
|
|
83
|
+
else
|
|
84
|
+
dd.classList.toggle('active');
|
|
85
|
+
this.isOpened = dd.classList.contains('active');
|
|
86
|
+
if (this.isOpened) {
|
|
87
|
+
const selected = this.selectContainer.nativeElement.querySelector('.selected');
|
|
88
|
+
if (selected)
|
|
89
|
+
selected.scrollIntoView();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
// private _filterOptions() {
|
|
93
|
+
// if (!this.optionsFilter || !this.multiple) return;
|
|
94
|
+
// this.filteredOptions = this.options.filter((o) => {
|
|
95
|
+
// if (this.returnObject) {
|
|
96
|
+
// return !this.value.find((v: any) => v === o);
|
|
97
|
+
// }
|
|
98
|
+
// return !this.value.find((v: any) => v === o[this.optionValue]);
|
|
99
|
+
// });
|
|
100
|
+
// }
|
|
101
|
+
select(option, byValue) {
|
|
102
|
+
const val = byValue
|
|
103
|
+
? option
|
|
104
|
+
: this.returnObject
|
|
105
|
+
? option
|
|
106
|
+
: option[this.optionValue];
|
|
107
|
+
if (this.multiple) {
|
|
108
|
+
let res = [];
|
|
109
|
+
if (this.value.includes(val)) {
|
|
110
|
+
res = this.value.filter((v) => v !== val);
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
this.options.forEach((o) => {
|
|
114
|
+
const ov = this.returnObject ? o : o[this.optionValue];
|
|
115
|
+
if (this.value.some((v) => v === ov) || val === ov) {
|
|
116
|
+
res.push(ov);
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
this.updateValue(res);
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
this.updateValue(val);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
onOptionClick(option, dd) {
|
|
127
|
+
this.select(option, false);
|
|
128
|
+
if (!this.multiple) {
|
|
129
|
+
this.toggleOptions(dd, false);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
toggleAll() {
|
|
133
|
+
let res = [];
|
|
134
|
+
if (this.value.length < this.options.length) {
|
|
135
|
+
if (this.returnObject) {
|
|
136
|
+
res = this.options;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
this.options.forEach((o) => {
|
|
140
|
+
res.push(o[this.optionValue]);
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
this.updateValue(res);
|
|
145
|
+
}
|
|
146
|
+
_checkErrors() {
|
|
147
|
+
const errors = this._control?.errors;
|
|
148
|
+
if (!this._control?.control?.touched || !errors) {
|
|
149
|
+
this.error = '';
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
if ('required' in errors) {
|
|
153
|
+
this.error = 'Field is required';
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
const errArr = Object.values(errors);
|
|
157
|
+
if (errArr.length < 1) {
|
|
158
|
+
this.error = '';
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const message = errArr.find((msg) => typeof msg === 'string');
|
|
162
|
+
this.error = message || 'Unknown error';
|
|
163
|
+
}
|
|
164
|
+
registerOnChange(fn) {
|
|
165
|
+
this.onChange = fn;
|
|
166
|
+
}
|
|
167
|
+
registerOnTouched(fn) {
|
|
168
|
+
this.onTouched = fn;
|
|
169
|
+
}
|
|
170
|
+
_convertValue(value) {
|
|
171
|
+
if (!this.returnObject) {
|
|
172
|
+
if (this.multiple) {
|
|
173
|
+
if (Array.isArray(value)) {
|
|
174
|
+
const temp = [];
|
|
175
|
+
value.forEach((v) => {
|
|
176
|
+
if (typeof v !== 'string') {
|
|
177
|
+
temp.push(v ? v[this.optionValue] : '');
|
|
178
|
+
}
|
|
179
|
+
else
|
|
180
|
+
temp.push(v);
|
|
181
|
+
});
|
|
182
|
+
value = temp;
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
if (!value)
|
|
186
|
+
value = [];
|
|
187
|
+
else {
|
|
188
|
+
if (typeof value !== 'string') {
|
|
189
|
+
value = [value[this.optionValue]];
|
|
190
|
+
}
|
|
191
|
+
else
|
|
192
|
+
value = [value];
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
if (typeof value !== 'string') {
|
|
198
|
+
value = value ? value[this.optionValue] : '';
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
if (this.multiple) {
|
|
204
|
+
if (!Array.isArray(value)) {
|
|
205
|
+
value = [value];
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
return value;
|
|
210
|
+
}
|
|
211
|
+
writeValue(value) {
|
|
212
|
+
value = this._convertValue(value);
|
|
213
|
+
this.value = value;
|
|
214
|
+
}
|
|
215
|
+
updateValue(value) {
|
|
216
|
+
this.writeValue(value);
|
|
217
|
+
this.onChange(value);
|
|
218
|
+
this.valueChanged.emit(value);
|
|
219
|
+
}
|
|
220
|
+
clear(dd, event) {
|
|
221
|
+
event.stopPropagation();
|
|
222
|
+
if ((!this.multiple && this.value) ||
|
|
223
|
+
(this.multiple && this.value?.length > 0)) {
|
|
224
|
+
if (this.openOnClear) {
|
|
225
|
+
this.toggleOptions(dd, true);
|
|
226
|
+
}
|
|
227
|
+
const val = this.multiple ? [] : this.returnObject ? undefined : '';
|
|
228
|
+
this.updateValue(val);
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
232
|
+
setDisabledState(disabled) { }
|
|
233
|
+
onBlur() {
|
|
234
|
+
this._control?.control?.markAsTouched();
|
|
235
|
+
this._checkErrors();
|
|
236
|
+
}
|
|
237
|
+
focus() {
|
|
238
|
+
this.selectContainer?.nativeElement?.focus();
|
|
239
|
+
this.toggleOptions(this.selectContainer?.nativeElement, true);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
CpsSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsSelectComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
243
|
+
CpsSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsSelectComponent, isStandalone: true, selector: "cps-select", inputs: { label: "label", placeholder: "placeholder", hint: "hint", returnObject: "returnObject", multiple: "multiple", disabled: "disabled", width: "width", selectAll: "selectAll", chips: "chips", closableChips: "closableChips", clearable: "clearable", openOnClear: "openOnClear", options: "options", optionLabel: "optionLabel", optionValue: "optionValue", optionInfo: "optionInfo", hideDetails: "hideDetails", _value: ["value", "_value"] }, outputs: { valueChanged: "valueChanged" }, viewQueries: [{ propertyName: "selectContainer", first: true, predicate: ["selectContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n [ngStyle]=\"{ width: cvtWidth }\"\n class=\"cps-select\"\n tabindex=\"0\"\n [ngClass]=\"{ disabled: disabled, error: error }\"\n #selectContainer\n (keydown.escape)=\"toggleOptions(selectContainer, false)\"\n (blur)=\"onBlur()\"\n>\n <label *ngIf=\"label\" class=\"cps-select-label\">{{ label }}</label>\n <div\n [class.focused]=\"isOpened\"\n (clickOutside)=\"toggleOptions(selectContainer, false)\"\n >\n <div class=\"cps-select-box\" (click)=\"toggleOptions(selectContainer)\">\n <div\n class=\"cps-select-box-placeholder\"\n *ngIf=\"(!value && !multiple) || (value?.length < 1 && multiple)\"\n >\n {{ placeholder }}\n </div>\n <div\n class=\"cps-select-box-items\"\n *ngIf=\"(value && !multiple) || (value?.length > 0 && multiple)\"\n >\n <span *ngIf=\"!multiple\" class=\"single-item\">\n {{\n returnObject\n ? value[optionLabel]\n : (value | labelByValue : options : optionValue : optionLabel)\n }}</span\n >\n <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n <span>\n {{\n value\n | combineLabels\n : options\n : optionValue\n : optionLabel\n : returnObject\n }}</span\n >\n </div>\n\n <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n <cps-chip\n *ngFor=\"let val of value\"\n [disabled]=\"disabled\"\n [closable]=\"closableChips\"\n (closed)=\"select(val, true)\"\n [label]=\"\n returnObject\n ? val[optionLabel]\n : (val | labelByValue : options : optionValue : optionLabel)\n \"\n >\n </cps-chip>\n </div>\n </div>\n <span class=\"cps-select-box-icons\">\n <span *ngIf=\"clearable && !disabled\" class=\"cps-select-box-clear-icon\">\n <cps-icon\n icon=\"delete\"\n size=\"small\"\n (click)=\"clear(selectContainer, $event)\"\n ></cps-icon>\n </span>\n <span class=\"cps-select-box-chevron\">\n <cps-icon\n icon=\"chevron-down\"\n size=\"small\"\n color=\"text-dark\"\n ></cps-icon>\n </span>\n </span>\n </div>\n\n <div class=\"cps-select-options\">\n <div\n class=\"cps-select-options-option select-all-option\"\n [class.allselected]=\"value?.length === options.length\"\n *ngIf=\"multiple && selectAll\"\n (click)=\"toggleAll()\"\n >\n <span>\n <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n </span>\n <span class=\"cps-select-options-option-label\">Select all</span>\n </span>\n </div>\n <div\n class=\"cps-select-options-option\"\n *ngFor=\"let option of options\"\n (click)=\"onOptionClick(option, selectContainer)\"\n [class.selected]=\"\n multiple\n ? returnObject\n ? value?.includes(option)\n : value?.includes(option[optionValue])\n : returnObject\n ? option === value\n : option[optionValue] === value\n \"\n >\n <span>\n <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n </span>\n <span class=\"cps-select-options-option-label\">{{\n option[optionLabel]\n }}</span>\n </span>\n\n <span class=\"cps-select-options-option-info\">{{\n option[optionInfo]\n }}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"!error && !hideDetails\" class=\"cps-select-hint\">{{ hint }}</div>\n <div *ngIf=\"error && !hideDetails\" class=\"cps-select-error\">{{ error }}</div>\n</div>\n", styles: [":host{display:flex}:host .cps-select{position:relative;width:100%;outline:none;font-family:Source Sans Pro,sans-serif}:host .cps-select.active .cps-select-options{display:block}:host .cps-select.active .cps-select-box{border:1px solid var(--cps-color-calm)}:host .cps-select .cps-select-label{display:inline-block;margin-bottom:.2rem;color:var(--cps-color-text-dark);font-size:.875rem}:host .cps-select .cps-select-box{overflow:hidden;justify-content:space-between;min-height:38px;width:100%;cursor:pointer;background:white;font-size:1rem;outline:none;padding:0 12px;border-radius:4px;align-items:center;display:flex;border:1px solid var(--cps-color-text-lightest);transition-duration:.2s}:host .cps-select .cps-select-box-placeholder{color:var(--cps-color-text-lightest);font-style:italic}:host .cps-select .cps-select-box-items .text-group,:host .cps-select .cps-select-box-items .single-item{color:var(--cps-color-text-dark);padding-top:3px;padding-bottom:3px}:host .cps-select .cps-select-box-items .chips-group cps-chip{padding-bottom:3px;padding-top:3px;padding-right:4px}text-group :host .cps-select .cps-select-box:hover{border:1px solid var(--cps-color-calm)}:host .cps-select .cps-select-box .cps-select-box-icons{display:flex}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon{display:flex;color:var(--cps-color-calm);margin-left:8px}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon cps-icon{opacity:.5;transition-duration:.2s}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon cps-icon:hover{opacity:1}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-chevron{display:flex;margin-left:8px;transition-duration:.2s}:host .cps-select.active .cps-select-box-chevron{top:22px;transform:rotate(180deg)}:host .cps-select .cps-select-options{z-index:1001;position:absolute;width:100%;background:white;box-shadow:0 5px 20px #0000000d;border-radius:4px;overflow-x:hidden;display:none;max-height:240px;overflow-y:auto;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f}:host .cps-select .cps-select-options .cps-select-options-option{padding:12px;justify-content:space-between;display:flex;cursor:pointer}:host .cps-select .cps-select-options .cps-select-options-option:hover{background:#f8f4f5}:host .cps-select .cps-select-options .cps-select-options-option-label{color:var(--cps-color-text-dark)}:host .cps-select .cps-select-options .cps-select-options-option-info{color:var(--cps-color-text-light)}:host .cps-select .cps-select-options .cps-select-options-option-check{background-color:transparent;border:0;width:16px;height:16px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;transition:border-color 90ms cubic-bezier(0,0,.2,.1),background-color 90ms cubic-bezier(0,0,.2,.1);margin-right:8px;opacity:0}:host .cps-select .cps-select-options .cps-select-options-option-check:after{color:var(--cps-color-calm);top:4px;left:1px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box;position:absolute;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}:host .cps-select .cps-select-options .cps-select-options-option.selected,:host .cps-select .cps-select-options .cps-select-options-option.allselected{font-weight:600}:host .cps-select .cps-select-options .cps-select-options-option.selected .cps-select-options-option-label,:host .cps-select .cps-select-options .cps-select-options-option.allselected .cps-select-options-option-label{color:var(--cps-color-calm)}:host .cps-select .cps-select-options .cps-select-options-option.selected .cps-select-options-option-check,:host .cps-select .cps-select-options .cps-select-options-option.allselected .cps-select-options-option-check{opacity:1}:host .cps-select .cps-select-options .cps-select-options-option.selected{background:#efe4e7}:host .cps-select .cps-select-hint{color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;cursor:default;margin-top:.2rem}:host .cps-select .cps-select-error{color:#c33;font-weight:700;font-size:.75rem;min-height:1.125rem;cursor:default;margin-top:.2rem}:host .cps-select.disabled{pointer-events:none}:host .cps-select.disabled .cps-select-box{background:#f7f7f7}:host .cps-select.disabled .cps-select-box-items{color:var(--cps-color-text-light)}:host .cps-select.disabled .cps-select-box-items .text-group,:host .cps-select.disabled .cps-select-box-items .single-item{color:var(--cps-color-text-light)}:host .cps-select.disabled .cps-select-label{color:var(--cps-color-text-mild)}:host .cps-select.error .cps-select-box{border-color:#c33!important;background:#fef3f2!important}:host .cps-select .select-all-option{border-bottom:1px solid lightgrey;font-weight:600}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: ClickOutsideDirective, selector: "[clickOutside]", outputs: ["clickOutside"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "component", type: CpsChipComponent, selector: "cps-chip", inputs: ["label", "icon", "iconPosition", "closable", "disabled"], outputs: ["closed"] }, { kind: "pipe", type: LabelByValuePipe, name: "labelByValue" }, { kind: "pipe", type: CombineLabelsPipe, name: "combineLabels" }] });
|
|
244
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsSelectComponent, decorators: [{
|
|
245
|
+
type: Component,
|
|
246
|
+
args: [{ standalone: true, imports: [
|
|
247
|
+
CommonModule,
|
|
248
|
+
FormsModule,
|
|
249
|
+
ClickOutsideDirective,
|
|
250
|
+
CpsIconComponent,
|
|
251
|
+
CpsChipComponent,
|
|
252
|
+
LabelByValuePipe,
|
|
253
|
+
CombineLabelsPipe
|
|
254
|
+
], selector: 'cps-select', template: "<div\n [ngStyle]=\"{ width: cvtWidth }\"\n class=\"cps-select\"\n tabindex=\"0\"\n [ngClass]=\"{ disabled: disabled, error: error }\"\n #selectContainer\n (keydown.escape)=\"toggleOptions(selectContainer, false)\"\n (blur)=\"onBlur()\"\n>\n <label *ngIf=\"label\" class=\"cps-select-label\">{{ label }}</label>\n <div\n [class.focused]=\"isOpened\"\n (clickOutside)=\"toggleOptions(selectContainer, false)\"\n >\n <div class=\"cps-select-box\" (click)=\"toggleOptions(selectContainer)\">\n <div\n class=\"cps-select-box-placeholder\"\n *ngIf=\"(!value && !multiple) || (value?.length < 1 && multiple)\"\n >\n {{ placeholder }}\n </div>\n <div\n class=\"cps-select-box-items\"\n *ngIf=\"(value && !multiple) || (value?.length > 0 && multiple)\"\n >\n <span *ngIf=\"!multiple\" class=\"single-item\">\n {{\n returnObject\n ? value[optionLabel]\n : (value | labelByValue : options : optionValue : optionLabel)\n }}</span\n >\n <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n <span>\n {{\n value\n | combineLabels\n : options\n : optionValue\n : optionLabel\n : returnObject\n }}</span\n >\n </div>\n\n <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n <cps-chip\n *ngFor=\"let val of value\"\n [disabled]=\"disabled\"\n [closable]=\"closableChips\"\n (closed)=\"select(val, true)\"\n [label]=\"\n returnObject\n ? val[optionLabel]\n : (val | labelByValue : options : optionValue : optionLabel)\n \"\n >\n </cps-chip>\n </div>\n </div>\n <span class=\"cps-select-box-icons\">\n <span *ngIf=\"clearable && !disabled\" class=\"cps-select-box-clear-icon\">\n <cps-icon\n icon=\"delete\"\n size=\"small\"\n (click)=\"clear(selectContainer, $event)\"\n ></cps-icon>\n </span>\n <span class=\"cps-select-box-chevron\">\n <cps-icon\n icon=\"chevron-down\"\n size=\"small\"\n color=\"text-dark\"\n ></cps-icon>\n </span>\n </span>\n </div>\n\n <div class=\"cps-select-options\">\n <div\n class=\"cps-select-options-option select-all-option\"\n [class.allselected]=\"value?.length === options.length\"\n *ngIf=\"multiple && selectAll\"\n (click)=\"toggleAll()\"\n >\n <span>\n <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n </span>\n <span class=\"cps-select-options-option-label\">Select all</span>\n </span>\n </div>\n <div\n class=\"cps-select-options-option\"\n *ngFor=\"let option of options\"\n (click)=\"onOptionClick(option, selectContainer)\"\n [class.selected]=\"\n multiple\n ? returnObject\n ? value?.includes(option)\n : value?.includes(option[optionValue])\n : returnObject\n ? option === value\n : option[optionValue] === value\n \"\n >\n <span>\n <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n </span>\n <span class=\"cps-select-options-option-label\">{{\n option[optionLabel]\n }}</span>\n </span>\n\n <span class=\"cps-select-options-option-info\">{{\n option[optionInfo]\n }}</span>\n </div>\n </div>\n </div>\n <div *ngIf=\"!error && !hideDetails\" class=\"cps-select-hint\">{{ hint }}</div>\n <div *ngIf=\"error && !hideDetails\" class=\"cps-select-error\">{{ error }}</div>\n</div>\n", styles: [":host{display:flex}:host .cps-select{position:relative;width:100%;outline:none;font-family:Source Sans Pro,sans-serif}:host .cps-select.active .cps-select-options{display:block}:host .cps-select.active .cps-select-box{border:1px solid var(--cps-color-calm)}:host .cps-select .cps-select-label{display:inline-block;margin-bottom:.2rem;color:var(--cps-color-text-dark);font-size:.875rem}:host .cps-select .cps-select-box{overflow:hidden;justify-content:space-between;min-height:38px;width:100%;cursor:pointer;background:white;font-size:1rem;outline:none;padding:0 12px;border-radius:4px;align-items:center;display:flex;border:1px solid var(--cps-color-text-lightest);transition-duration:.2s}:host .cps-select .cps-select-box-placeholder{color:var(--cps-color-text-lightest);font-style:italic}:host .cps-select .cps-select-box-items .text-group,:host .cps-select .cps-select-box-items .single-item{color:var(--cps-color-text-dark);padding-top:3px;padding-bottom:3px}:host .cps-select .cps-select-box-items .chips-group cps-chip{padding-bottom:3px;padding-top:3px;padding-right:4px}text-group :host .cps-select .cps-select-box:hover{border:1px solid var(--cps-color-calm)}:host .cps-select .cps-select-box .cps-select-box-icons{display:flex}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon{display:flex;color:var(--cps-color-calm);margin-left:8px}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon cps-icon{opacity:.5;transition-duration:.2s}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-clear-icon cps-icon:hover{opacity:1}:host .cps-select .cps-select-box .cps-select-box-icons .cps-select-box-chevron{display:flex;margin-left:8px;transition-duration:.2s}:host .cps-select.active .cps-select-box-chevron{top:22px;transform:rotate(180deg)}:host .cps-select .cps-select-options{z-index:1001;position:absolute;width:100%;background:white;box-shadow:0 5px 20px #0000000d;border-radius:4px;overflow-x:hidden;display:none;max-height:240px;overflow-y:auto;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f}:host .cps-select .cps-select-options .cps-select-options-option{padding:12px;justify-content:space-between;display:flex;cursor:pointer}:host .cps-select .cps-select-options .cps-select-options-option:hover{background:#f8f4f5}:host .cps-select .cps-select-options .cps-select-options-option-label{color:var(--cps-color-text-dark)}:host .cps-select .cps-select-options .cps-select-options-option-info{color:var(--cps-color-text-light)}:host .cps-select .cps-select-options .cps-select-options-option-check{background-color:transparent;border:0;width:16px;height:16px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;transition:border-color 90ms cubic-bezier(0,0,.2,.1),background-color 90ms cubic-bezier(0,0,.2,.1);margin-right:8px;opacity:0}:host .cps-select .cps-select-options .cps-select-options-option-check:after{color:var(--cps-color-calm);top:4px;left:1px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box;position:absolute;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}:host .cps-select .cps-select-options .cps-select-options-option.selected,:host .cps-select .cps-select-options .cps-select-options-option.allselected{font-weight:600}:host .cps-select .cps-select-options .cps-select-options-option.selected .cps-select-options-option-label,:host .cps-select .cps-select-options .cps-select-options-option.allselected .cps-select-options-option-label{color:var(--cps-color-calm)}:host .cps-select .cps-select-options .cps-select-options-option.selected .cps-select-options-option-check,:host .cps-select .cps-select-options .cps-select-options-option.allselected .cps-select-options-option-check{opacity:1}:host .cps-select .cps-select-options .cps-select-options-option.selected{background:#efe4e7}:host .cps-select .cps-select-hint{color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;cursor:default;margin-top:.2rem}:host .cps-select .cps-select-error{color:#c33;font-weight:700;font-size:.75rem;min-height:1.125rem;cursor:default;margin-top:.2rem}:host .cps-select.disabled{pointer-events:none}:host .cps-select.disabled .cps-select-box{background:#f7f7f7}:host .cps-select.disabled .cps-select-box-items{color:var(--cps-color-text-light)}:host .cps-select.disabled .cps-select-box-items .text-group,:host .cps-select.disabled .cps-select-box-items .single-item{color:var(--cps-color-text-light)}:host .cps-select.disabled .cps-select-label{color:var(--cps-color-text-mild)}:host .cps-select.error .cps-select-box{border-color:#c33!important;background:#fef3f2!important}:host .cps-select .select-all-option{border-bottom:1px solid lightgrey;font-weight:600}\n"] }]
|
|
255
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
256
|
+
type: Self
|
|
257
|
+
}, {
|
|
258
|
+
type: Optional
|
|
259
|
+
}] }]; }, propDecorators: { label: [{
|
|
260
|
+
type: Input
|
|
261
|
+
}], placeholder: [{
|
|
262
|
+
type: Input
|
|
263
|
+
}], hint: [{
|
|
264
|
+
type: Input
|
|
265
|
+
}], returnObject: [{
|
|
266
|
+
type: Input
|
|
267
|
+
}], multiple: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], disabled: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], width: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], selectAll: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], chips: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], closableChips: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], clearable: [{
|
|
280
|
+
type: Input
|
|
281
|
+
}], openOnClear: [{
|
|
282
|
+
type: Input
|
|
283
|
+
}], options: [{
|
|
284
|
+
type: Input
|
|
285
|
+
}], optionLabel: [{
|
|
286
|
+
type: Input
|
|
287
|
+
}], optionValue: [{
|
|
288
|
+
type: Input
|
|
289
|
+
}], optionInfo: [{
|
|
290
|
+
type: Input
|
|
291
|
+
}], hideDetails: [{
|
|
292
|
+
type: Input
|
|
293
|
+
}], _value: [{
|
|
294
|
+
type: Input,
|
|
295
|
+
args: ['value']
|
|
296
|
+
}], valueChanged: [{
|
|
297
|
+
type: Output
|
|
298
|
+
}], selectContainer: [{
|
|
299
|
+
type: ViewChild,
|
|
300
|
+
args: ['selectContainer']
|
|
301
|
+
}] } });
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-select.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,SAAS,EAET,YAAY,EACZ,KAAK,EAIL,QAAQ,EACR,MAAM,EACN,IAAI,EAEJ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAa,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AACjF,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;;;;AAiBpE,MAAM,OAAO,kBAAkB;IAsB7B,IAAI,KAAK,CAAE,KAAU;QACnB,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAcD,YAAyC,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QA1CnD,UAAK,GAAG,EAAE,CAAC;QACX,gBAAW,GAAG,eAAe,CAAC;QAC9B,SAAI,GAAG,EAAE,CAAC;QACV,iBAAY,GAAG,IAAI,CAAC;QACpB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,UAAK,GAAoB,MAAM,CAAC;QAChC,cAAS,GAAG,IAAI,CAAC;QACjB,UAAK,GAAG,IAAI,CAAC;QACb,kBAAa,GAAG,IAAI,CAAC;QACrB,cAAS,GAAG,KAAK,CAAC;QAClB,gBAAW,GAAG,IAAI,CAAC;QACnB,YAAO,GAAG,EAAW,CAAC;QACtB,gBAAW,GAAG,OAAO,CAAC;QACtB,gBAAW,GAAG,OAAO,CAAC,CAAC,6EAA6E;QACpG,eAAU,GAAG,MAAM,CAAC;QACpB,gBAAW,GAAG,KAAK,CAAC;QAEb,WAAM,GAAQ,SAAS,CAAC;QAY9B,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QAKzC,+BAA0B,GAAiB,IAAI,YAAY,EAAE,CAAC;QAEtE,UAAK,GAAG,EAAE,CAAC;QACX,aAAQ,GAAG,EAAE,CAAC;QAEd,aAAQ,GAAG,KAAK,CAAC;QA8HjB,gEAAgE;QAChE,aAAQ,GAAG,CAAC,KAAU,EAAE,EAAE,GAAE,CAAC,CAAC;QAC9B,gEAAgE;QAChE,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QA9HnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC;SACpC;IACH,CAAC;IAED,WAAW,CAAE,OAAsB;QACjC,wCAAwC;QACxC,IAAI,QAAQ,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,EAAE,EAAE;YAC5D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC7C;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACjC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;SAClB;QAED,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,EAAE,SAAS,CACvE,GAAG,EAAE;YACH,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CACc,CAAC;IACpB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,0BAA0B,EAAE,WAAW,EAAE,CAAC;IACjD,CAAC;IAED,aAAa,CAAE,EAAe,EAAE,IAAc;QAC5C,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE;YAAE,OAAO;QACjC,IAAI,OAAO,IAAI,KAAK,SAAS,EAAE;YAC7B,IAAI,IAAI;gBAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;;gBAChC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;SACpC;;YAAM,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAErC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAEhD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,MAAM,QAAQ,GACZ,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YAChE,IAAI,QAAQ;gBAAE,QAAQ,CAAC,cAAc,EAAE,CAAC;SACzC;IACH,CAAC;IAED,6BAA6B;IAC7B,uDAAuD;IACvD,wDAAwD;IACxD,+BAA+B;IAC/B,sDAAsD;IACtD,QAAQ;IACR,sEAAsE;IACtE,QAAQ;IACR,IAAI;IAEJ,MAAM,CAAE,MAAW,EAAE,OAAgB;QACnC,MAAM,GAAG,GAAG,OAAO;YACjB,CAAC,CAAC,MAAM;YACR,CAAC,CAAC,IAAI,CAAC,YAAY;gBACjB,CAAC,CAAC,MAAM;gBACR,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,GAAG,GAAG,EAAS,CAAC;YACpB,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBAC5B,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;aAChD;iBAAM;gBACL,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACzB,MAAM,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBACvD,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,IAAI,GAAG,KAAK,EAAE,EAAE;wBACvD,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;qBACd;gBACH,CAAC,CAAC,CAAC;aACJ;YACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;IACH,CAAC;IAED,aAAa,CAAE,MAAW,EAAE,EAAe;QACzC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,SAAS;QACP,IAAI,GAAG,GAAG,EAAE,CAAC;QACb,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC3C,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC;aACpB;iBAAM;gBACL,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACzB,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBAChC,CAAC,CAAC,CAAC;aACJ;SACF;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAEO,YAAY;QAClB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;QAErC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,IAAI,CAAC,MAAM,EAAE;YAC/C,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAChB,OAAO;SACR;QAED,IAAI,UAAU,IAAI,MAAM,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,mBAAmB,CAAC;YACjC,OAAO;SACR;QAED,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAChB,OAAO;SACR;QACD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC;QAE9D,IAAI,CAAC,KAAK,GAAG,OAAO,IAAI,eAAe,CAAC;IAC1C,CAAC;IAOD,gBAAgB,CAAE,EAAO;QACvB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAE,EAAO;QACxB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAEO,aAAa,CAAE,KAAU;QAC/B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACxB,MAAM,IAAI,GAAQ,EAAE,CAAC;oBACrB,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;wBAClB,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;4BACzB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;yBACzC;;4BAAM,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACtB,CAAC,CAAC,CAAC;oBACH,KAAK,GAAG,IAAI,CAAC;iBACd;qBAAM;oBACL,IAAI,CAAC,KAAK;wBAAE,KAAK,GAAG,EAAE,CAAC;yBAClB;wBACH,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;4BAC7B,KAAK,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;yBACnC;;4BAAM,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;qBACxB;iBACF;aACF;iBAAM;gBACL,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;iBAC9C;aACF;SACF;aAAM;YACL,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACzB,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;iBACjB;aACF;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU,CAAE,KAAU;QACpB,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAEO,WAAW,CAAE,KAAU;QAC7B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,KAAK,CAAE,EAAe,EAAE,KAAU;QAChC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IACE,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC;YAC9B,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,EACzC;YACA,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;aAC9B;YACD,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;IACH,CAAC;IAED,gEAAgE;IAChE,gBAAgB,CAAE,QAAiB,IAAG,CAAC;IAEvC,MAAM;QACJ,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC;QACxC,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;QAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;IAChE,CAAC;;+GA5PU,kBAAkB;mGAAlB,kBAAkB,qrBCvC/B,w3HA0HA,20JD/FI,YAAY,kbACZ,WAAW,+BACX,qBAAqB,sFACrB,gBAAgB,wFAChB,gBAAgB,wIAChB,gBAAgB,gDAChB,iBAAiB;2FAMR,kBAAkB;kBAf9B,SAAS;iCACI,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,qBAAqB;wBACrB,gBAAgB;wBAChB,gBAAgB;wBAChB,gBAAgB;wBAChB,iBAAiB;qBAClB,YACS,YAAY;;0BAgDR,IAAI;;0BAAI,QAAQ;4CA1CrB,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEU,MAAM;sBAArB,KAAK;uBAAC,OAAO;gBAYJ,YAAY;sBAArB,MAAM;gBAGL,eAAe;sBADhB,SAAS;uBAAC,iBAAiB","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/size-utils';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsChipComponent } from '../cps-chip/cps-chip.component';\nimport { ClickOutsideDirective } from '../../directives/click-outside.directive';\nimport { LabelByValuePipe } from '../../pipes/label-by-value.pipe';\nimport { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ClickOutsideDirective,\n    CpsIconComponent,\n    CpsChipComponent,\n    LabelByValuePipe,\n    CombineLabelsPipe\n  ],\n  selector: 'cps-select',\n  templateUrl: './cps-select.component.html',\n  styleUrls: ['./cps-select.component.scss']\n})\nexport class CpsSelectComponent\nimplements ControlValueAccessor, OnInit, OnDestroy, OnChanges {\n  @Input() label = '';\n  @Input() placeholder = 'Please select';\n  @Input() hint = '';\n  @Input() returnObject = true;\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() selectAll = true;\n  @Input() chips = true;\n  @Input() closableChips = true;\n  @Input() clearable = false;\n  @Input() openOnClear = true;\n  @Input() options = [] as any[];\n  @Input() optionLabel = 'label';\n  @Input() optionValue = 'value'; // works only if returnObject === false (TODO potentially can be of any type)\n  @Input() optionInfo = 'info';\n  @Input() hideDetails = false;\n\n  @Input('value') _value: any = undefined;\n\n  set value (value: any) {\n    value = this._convertValue(value);\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value (): any {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('selectContainer')\n    selectContainer!: ElementRef;\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  error = '';\n  cvtWidth = '';\n\n  isOpened = false;\n\n  constructor (@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    // eslint-disable-next-line dot-notation\n    if ('_value' in changes && changes['_value'].isFirstChange()) {\n      this.value = this._convertValue(this.value);\n    }\n  }\n\n  ngOnInit () {\n    this.cvtWidth = convertSize(this.width);\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy () {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  toggleOptions (dd: HTMLElement, show?: boolean): void {\n    if (this.disabled || !dd) return;\n    if (typeof show === 'boolean') {\n      if (show) dd.classList.add('active');\n      else dd.classList.remove('active');\n    } else dd.classList.toggle('active');\n\n    this.isOpened = dd.classList.contains('active');\n\n    if (this.isOpened) {\n      const selected =\n        this.selectContainer.nativeElement.querySelector('.selected');\n      if (selected) selected.scrollIntoView();\n    }\n  }\n\n  // private _filterOptions() {\n  //   if (!this.optionsFilter || !this.multiple) return;\n  //   this.filteredOptions = this.options.filter((o) => {\n  //     if (this.returnObject) {\n  //       return !this.value.find((v: any) => v === o);\n  //     }\n  //     return !this.value.find((v: any) => v === o[this.optionValue]);\n  //   });\n  // }\n\n  select (option: any, byValue: boolean): void {\n    const val = byValue\n      ? option\n      : this.returnObject\n        ? option\n        : option[this.optionValue];\n    if (this.multiple) {\n      let res = [] as any;\n      if (this.value.includes(val)) {\n        res = this.value.filter((v: any) => v !== val);\n      } else {\n        this.options.forEach((o) => {\n          const ov = this.returnObject ? o : o[this.optionValue];\n          if (this.value.some((v: any) => v === ov) || val === ov) {\n            res.push(ov);\n          }\n        });\n      }\n      this.updateValue(res);\n    } else {\n      this.updateValue(val);\n    }\n  }\n\n  onOptionClick (option: any, dd: HTMLElement) {\n    this.select(option, false);\n    if (!this.multiple) {\n      this.toggleOptions(dd, false);\n    }\n  }\n\n  toggleAll () {\n    let res = [];\n    if (this.value.length < this.options.length) {\n      if (this.returnObject) {\n        res = this.options;\n      } else {\n        this.options.forEach((o) => {\n          res.push(o[this.optionValue]);\n        });\n      }\n    }\n    this.updateValue(res);\n  }\n\n  private _checkErrors (): void {\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange (fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched (fn: any) {\n    this.onTouched = fn;\n  }\n\n  private _convertValue (value: any): any {\n    if (!this.returnObject) {\n      if (this.multiple) {\n        if (Array.isArray(value)) {\n          const temp: any = [];\n          value.forEach((v) => {\n            if (typeof v !== 'string') {\n              temp.push(v ? v[this.optionValue] : '');\n            } else temp.push(v);\n          });\n          value = temp;\n        } else {\n          if (!value) value = [];\n          else {\n            if (typeof value !== 'string') {\n              value = [value[this.optionValue]];\n            } else value = [value];\n          }\n        }\n      } else {\n        if (typeof value !== 'string') {\n          value = value ? value[this.optionValue] : '';\n        }\n      }\n    } else {\n      if (this.multiple) {\n        if (!Array.isArray(value)) {\n          value = [value];\n        }\n      }\n    }\n    return value;\n  }\n\n  writeValue (value: any) {\n    value = this._convertValue(value);\n    this.value = value;\n  }\n\n  private updateValue (value: any): void {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  clear (dd: HTMLElement, event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.value) ||\n      (this.multiple && this.value?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this.toggleOptions(dd, true);\n      }\n      const val = this.multiple ? [] : this.returnObject ? undefined : '';\n      this.updateValue(val);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState (disabled: boolean) {}\n\n  onBlur () {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  focus () {\n    this.selectContainer?.nativeElement?.focus();\n    this.toggleOptions(this.selectContainer?.nativeElement, true);\n  }\n}\n","<div\n  [ngStyle]=\"{ width: cvtWidth }\"\n  class=\"cps-select\"\n  tabindex=\"0\"\n  [ngClass]=\"{ disabled: disabled, error: error }\"\n  #selectContainer\n  (keydown.escape)=\"toggleOptions(selectContainer, false)\"\n  (blur)=\"onBlur()\"\n>\n  <label *ngIf=\"label\" class=\"cps-select-label\">{{ label }}</label>\n  <div\n    [class.focused]=\"isOpened\"\n    (clickOutside)=\"toggleOptions(selectContainer, false)\"\n  >\n    <div class=\"cps-select-box\" (click)=\"toggleOptions(selectContainer)\">\n      <div\n        class=\"cps-select-box-placeholder\"\n        *ngIf=\"(!value && !multiple) || (value?.length < 1 && multiple)\"\n      >\n        {{ placeholder }}\n      </div>\n      <div\n        class=\"cps-select-box-items\"\n        *ngIf=\"(value && !multiple) || (value?.length > 0 && multiple)\"\n      >\n        <span *ngIf=\"!multiple\" class=\"single-item\">\n          {{\n            returnObject\n              ? value[optionLabel]\n              : (value | labelByValue : options : optionValue : optionLabel)\n          }}</span\n        >\n        <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n          <span>\n            {{\n              value\n                | combineLabels\n                  : options\n                  : optionValue\n                  : optionLabel\n                  : returnObject\n            }}</span\n          >\n        </div>\n\n        <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n          <cps-chip\n            *ngFor=\"let val of value\"\n            [disabled]=\"disabled\"\n            [closable]=\"closableChips\"\n            (closed)=\"select(val, true)\"\n            [label]=\"\n              returnObject\n                ? val[optionLabel]\n                : (val | labelByValue : options : optionValue : optionLabel)\n            \"\n          >\n          </cps-chip>\n        </div>\n      </div>\n      <span class=\"cps-select-box-icons\">\n        <span *ngIf=\"clearable && !disabled\" class=\"cps-select-box-clear-icon\">\n          <cps-icon\n            icon=\"delete\"\n            size=\"small\"\n            (click)=\"clear(selectContainer, $event)\"\n          ></cps-icon>\n        </span>\n        <span class=\"cps-select-box-chevron\">\n          <cps-icon\n            icon=\"chevron-down\"\n            size=\"small\"\n            color=\"text-dark\"\n          ></cps-icon>\n        </span>\n      </span>\n    </div>\n\n    <div class=\"cps-select-options\">\n      <div\n        class=\"cps-select-options-option select-all-option\"\n        [class.allselected]=\"value?.length === options.length\"\n        *ngIf=\"multiple && selectAll\"\n        (click)=\"toggleAll()\"\n      >\n        <span>\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">Select all</span>\n        </span>\n      </div>\n      <div\n        class=\"cps-select-options-option\"\n        *ngFor=\"let option of options\"\n        (click)=\"onOptionClick(option, selectContainer)\"\n        [class.selected]=\"\n          multiple\n            ? returnObject\n              ? value?.includes(option)\n              : value?.includes(option[optionValue])\n            : returnObject\n            ? option === value\n            : option[optionValue] === value\n        \"\n      >\n        <span>\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">{{\n            option[optionLabel]\n          }}</span>\n        </span>\n\n        <span class=\"cps-select-options-option-info\">{{\n          option[optionInfo]\n        }}</span>\n      </div>\n    </div>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-select-hint\">{{ hint }}</div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-select-error\">{{ error }}</div>\n</div>\n"]}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
|
|
3
|
+
import { getCSSColor } from '../../utils/colors-utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
export class CpsTagComponent {
|
|
8
|
+
set value(value) {
|
|
9
|
+
this._value = value;
|
|
10
|
+
this.onChange(value);
|
|
11
|
+
}
|
|
12
|
+
get value() {
|
|
13
|
+
return this._value;
|
|
14
|
+
}
|
|
15
|
+
constructor(_control) {
|
|
16
|
+
this._control = _control;
|
|
17
|
+
this.type = 'custom'; // higher precedence over color
|
|
18
|
+
this.label = '';
|
|
19
|
+
this.color = '';
|
|
20
|
+
this.disabled = false;
|
|
21
|
+
this.selectable = false;
|
|
22
|
+
this.valueChanged = new EventEmitter();
|
|
23
|
+
this.classesList = [];
|
|
24
|
+
this.tagColor = '';
|
|
25
|
+
this._value = false;
|
|
26
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
27
|
+
this.onChange = (event) => { };
|
|
28
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
29
|
+
this.onTouched = () => { };
|
|
30
|
+
if (this._control) {
|
|
31
|
+
this._control.valueAccessor = this;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
ngOnChanges() {
|
|
35
|
+
this.setClasses();
|
|
36
|
+
}
|
|
37
|
+
setClasses() {
|
|
38
|
+
this.classesList = ['tag'];
|
|
39
|
+
if (this.selectable) {
|
|
40
|
+
this.classesList.push('tag--selectable');
|
|
41
|
+
}
|
|
42
|
+
if (this.disabled) {
|
|
43
|
+
this.classesList.push('tag--disabled');
|
|
44
|
+
}
|
|
45
|
+
switch (this.type) {
|
|
46
|
+
case 'security': {
|
|
47
|
+
this.classesList.push('tag--security');
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
case 'classification': {
|
|
51
|
+
this.classesList.push('tag--classification');
|
|
52
|
+
break;
|
|
53
|
+
}
|
|
54
|
+
default:
|
|
55
|
+
if (this.color)
|
|
56
|
+
this.tagColor = getCSSColor(this.color);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
registerOnChange(fn) {
|
|
60
|
+
this.onChange = fn;
|
|
61
|
+
}
|
|
62
|
+
registerOnTouched(fn) {
|
|
63
|
+
this.onTouched = fn;
|
|
64
|
+
}
|
|
65
|
+
writeValue(value) {
|
|
66
|
+
this.value = value;
|
|
67
|
+
}
|
|
68
|
+
toggleSelected() {
|
|
69
|
+
if (this.disabled || !this.selectable)
|
|
70
|
+
return;
|
|
71
|
+
this._updateValue(!this.value);
|
|
72
|
+
}
|
|
73
|
+
_updateValue(value) {
|
|
74
|
+
this.writeValue(value);
|
|
75
|
+
this.onChange(value);
|
|
76
|
+
this.valueChanged.emit(value);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
CpsTagComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTagComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
80
|
+
CpsTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsTagComponent, isStandalone: true, selector: "cps-tag", inputs: { type: "type", label: "label", color: "color", disabled: "disabled", selectable: "selectable", value: "value" }, outputs: { valueChanged: "valueChanged" }, usesOnChanges: true, ngImport: i0, template: "<div\n [ngClass]=\"classesList\"\n [class.unselected]=\"!value && selectable\"\n [ngStyle]=\"{ 'border-color': tagColor || 'none' }\"\n (click)=\"toggleSelected()\"\n>\n <p>{{ label }}</p>\n</div>\n", styles: [":host{width:-moz-fit-content;width:fit-content;display:inline-block;-webkit-user-select:none;user-select:none}:host .tag{min-height:25px;align-items:center;padding:0 10px;background-color:#fff;display:inline-flex;cursor:default;border:solid 1px;border-left:solid 4px}:host .tag.tag--security{border-color:var(--cps-color-warn)}:host .tag.tag--classification{border-color:var(--cps-color-info)}:host .tag.tag--selectable{cursor:pointer}:host .tag.tag--selectable:hover:not(:active):not(:disabled){box-shadow:1px 3px 4px #0000001a}:host .tag.tag--disabled{pointer-events:none;border-color:var(--cps-color-line-dark)!important}:host .tag.tag--disabled p{color:var(--cps-color-text-light)}:host .tag.unselected{border-color:var(--cps-color-text-light)!important}:host .tag p{margin:0;font-size:11px;color:var(--cps-color-text-dark)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
81
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTagComponent, decorators: [{
|
|
82
|
+
type: Component,
|
|
83
|
+
args: [{ standalone: true, imports: [CommonModule], selector: 'cps-tag', template: "<div\n [ngClass]=\"classesList\"\n [class.unselected]=\"!value && selectable\"\n [ngStyle]=\"{ 'border-color': tagColor || 'none' }\"\n (click)=\"toggleSelected()\"\n>\n <p>{{ label }}</p>\n</div>\n", styles: [":host{width:-moz-fit-content;width:fit-content;display:inline-block;-webkit-user-select:none;user-select:none}:host .tag{min-height:25px;align-items:center;padding:0 10px;background-color:#fff;display:inline-flex;cursor:default;border:solid 1px;border-left:solid 4px}:host .tag.tag--security{border-color:var(--cps-color-warn)}:host .tag.tag--classification{border-color:var(--cps-color-info)}:host .tag.tag--selectable{cursor:pointer}:host .tag.tag--selectable:hover:not(:active):not(:disabled){box-shadow:1px 3px 4px #0000001a}:host .tag.tag--disabled{pointer-events:none;border-color:var(--cps-color-line-dark)!important}:host .tag.tag--disabled p{color:var(--cps-color-text-light)}:host .tag.unselected{border-color:var(--cps-color-text-light)!important}:host .tag p{margin:0;font-size:11px;color:var(--cps-color-text-dark)}\n"] }]
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
85
|
+
type: Self
|
|
86
|
+
}, {
|
|
87
|
+
type: Optional
|
|
88
|
+
}] }]; }, propDecorators: { type: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], label: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], color: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], disabled: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], selectable: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], value: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], valueChanged: [{
|
|
101
|
+
type: Output
|
|
102
|
+
}] } });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLXRhZy9jcHMtdGFnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBRUwsUUFBUSxFQUNSLE1BQU0sRUFDTixJQUFJLEVBQ0wsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBVXZELE1BQU0sT0FBTyxlQUFlO0lBTTFCLElBQWEsS0FBSyxDQUFFLEtBQWM7UUFDaEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFTRCxZQUF5QyxRQUFtQjtRQUFuQixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBckJuRCxTQUFJLEdBQTZDLFFBQVEsQ0FBQyxDQUFDLCtCQUErQjtRQUMxRixVQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ1gsVUFBSyxHQUFHLEVBQUUsQ0FBQztRQUNYLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZUFBVSxHQUFHLEtBQUssQ0FBQztRQVVsQixpQkFBWSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFFckQsZ0JBQVcsR0FBYSxFQUFFLENBQUM7UUFDM0IsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUVOLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFtQ3ZCLGdFQUFnRTtRQUNoRSxhQUFRLEdBQUcsQ0FBQyxLQUFVLEVBQUUsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUM5QixnRUFBZ0U7UUFDaEUsY0FBUyxHQUFHLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQW5DbkIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQztTQUNwQztJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTNCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1NBQzFDO1FBQ0QsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1NBQ3hDO1FBQ0QsUUFBUSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2pCLEtBQUssVUFBVSxDQUFDLENBQUM7Z0JBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7Z0JBQ3ZDLE1BQU07YUFDUDtZQUNELEtBQUssZ0JBQWdCLENBQUMsQ0FBQztnQkFDckIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztnQkFDN0MsTUFBTTthQUNQO1lBQ0Q7Z0JBQ0UsSUFBSSxJQUFJLENBQUMsS0FBSztvQkFBRSxJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDM0Q7SUFDSCxDQUFDO0lBT0QsZ0JBQWdCLENBQUUsRUFBTztRQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsaUJBQWlCLENBQUUsRUFBTztRQUN4QixJQUFJLENBQUMsU0FBUyxHQUFHLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRUQsVUFBVSxDQUFFLEtBQWM7UUFDeEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVELGNBQWM7UUFDWixJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVTtZQUFFLE9BQU87UUFDOUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRU8sWUFBWSxDQUFFLEtBQWM7UUFDbEMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2QixJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7OzRHQWpGVSxlQUFlO2dHQUFmLGVBQWUsNlBDcEI1Qiw2TUFRQSx1M0JET1ksWUFBWTsyRkFLWCxlQUFlO2tCQVAzQixTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiLFNBQVM7OzBCQTBCTCxJQUFJOzswQkFBSSxRQUFROzRDQXJCckIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNPLEtBQUs7c0JBQWpCLEtBQUs7Z0JBU0ksWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT3B0aW9uYWwsXG4gIE91dHB1dCxcbiAgU2VsZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGdldENTU0NvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXV0aWxzJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOZ0NvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdjcHMtdGFnJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nwcy10YWcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcHMtdGFnLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3BzVGFnQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHR5cGU6ICdzZWN1cml0eScgfCAnY2xhc3NpZmljYXRpb24nIHwgJ2N1c3RvbScgPSAnY3VzdG9tJzsgLy8gaGlnaGVyIHByZWNlZGVuY2Ugb3ZlciBjb2xvclxuICBASW5wdXQoKSBsYWJlbCA9ICcnO1xuICBASW5wdXQoKSBjb2xvciA9ICcnO1xuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlO1xuICBASW5wdXQoKSBzZWxlY3RhYmxlID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNldCB2YWx1ZSAodmFsdWU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xuICAgIHRoaXMub25DaGFuZ2UodmFsdWUpO1xuICB9XG5cbiAgZ2V0IHZhbHVlICgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XG4gIH1cblxuICBAT3V0cHV0KCkgdmFsdWVDaGFuZ2VkID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gIGNsYXNzZXNMaXN0OiBzdHJpbmdbXSA9IFtdO1xuICB0YWdDb2xvciA9ICcnO1xuXG4gIHByaXZhdGUgX3ZhbHVlID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IgKEBTZWxmKCkgQE9wdGlvbmFsKCkgcHJpdmF0ZSBfY29udHJvbDogTmdDb250cm9sKSB7XG4gICAgaWYgKHRoaXMuX2NvbnRyb2wpIHtcbiAgICAgIHRoaXMuX2NvbnRyb2wudmFsdWVBY2Nlc3NvciA9IHRoaXM7XG4gICAgfVxuICB9XG5cbiAgbmdPbkNoYW5nZXMgKCk6IHZvaWQge1xuICAgIHRoaXMuc2V0Q2xhc3NlcygpO1xuICB9XG5cbiAgc2V0Q2xhc3NlcyAoKTogdm9pZCB7XG4gICAgdGhpcy5jbGFzc2VzTGlzdCA9IFsndGFnJ107XG5cbiAgICBpZiAodGhpcy5zZWxlY3RhYmxlKSB7XG4gICAgICB0aGlzLmNsYXNzZXNMaXN0LnB1c2goJ3RhZy0tc2VsZWN0YWJsZScpO1xuICAgIH1cbiAgICBpZiAodGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy5jbGFzc2VzTGlzdC5wdXNoKCd0YWctLWRpc2FibGVkJyk7XG4gICAgfVxuICAgIHN3aXRjaCAodGhpcy50eXBlKSB7XG4gICAgICBjYXNlICdzZWN1cml0eSc6IHtcbiAgICAgICAgdGhpcy5jbGFzc2VzTGlzdC5wdXNoKCd0YWctLXNlY3VyaXR5Jyk7XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgICAgY2FzZSAnY2xhc3NpZmljYXRpb24nOiB7XG4gICAgICAgIHRoaXMuY2xhc3Nlc0xpc3QucHVzaCgndGFnLS1jbGFzc2lmaWNhdGlvbicpO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIGlmICh0aGlzLmNvbG9yKSB0aGlzLnRhZ0NvbG9yID0gZ2V0Q1NTQ29sb3IodGhpcy5jb2xvcik7XG4gICAgfVxuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxuICBvbkNoYW5nZSA9IChldmVudDogYW55KSA9PiB7fTtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxuICBvblRvdWNoZWQgPSAoKSA9PiB7fTtcblxuICByZWdpc3Rlck9uQ2hhbmdlIChmbjogYW55KSB7XG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICB9XG5cbiAgcmVnaXN0ZXJPblRvdWNoZWQgKGZuOiBhbnkpIHtcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICB9XG5cbiAgd3JpdGVWYWx1ZSAodmFsdWU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gIH1cblxuICB0b2dnbGVTZWxlY3RlZCAoKSB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgIXRoaXMuc2VsZWN0YWJsZSkgcmV0dXJuO1xuICAgIHRoaXMuX3VwZGF0ZVZhbHVlKCF0aGlzLnZhbHVlKTtcbiAgfVxuXG4gIHByaXZhdGUgX3VwZGF0ZVZhbHVlICh2YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMud3JpdGVWYWx1ZSh2YWx1ZSk7XG4gICAgdGhpcy5vbkNoYW5nZSh2YWx1ZSk7XG4gICAgdGhpcy52YWx1ZUNoYW5nZWQuZW1pdCh2YWx1ZSk7XG4gIH1cbn1cbiIsIjxkaXZcbiAgW25nQ2xhc3NdPVwiY2xhc3Nlc0xpc3RcIlxuICBbY2xhc3MudW5zZWxlY3RlZF09XCIhdmFsdWUgJiYgc2VsZWN0YWJsZVwiXG4gIFtuZ1N0eWxlXT1cInsgJ2JvcmRlci1jb2xvcic6IHRhZ0NvbG9yIHx8ICdub25lJyB9XCJcbiAgKGNsaWNrKT1cInRvZ2dsZVNlbGVjdGVkKClcIlxuPlxuICA8cD57eyBsYWJlbCB9fTwvcD5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Directive, Output, EventEmitter, HostListener } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class ClickOutsideDirective {
|
|
4
|
+
// eslint-disable-next-line no-useless-constructor
|
|
5
|
+
constructor(elementRef) {
|
|
6
|
+
this.elementRef = elementRef;
|
|
7
|
+
this.clickOutside = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
onClick(target) {
|
|
10
|
+
if (!this.elementRef?.nativeElement?.classList?.contains('focused'))
|
|
11
|
+
return;
|
|
12
|
+
const clickedInside = this.elementRef?.nativeElement?.contains(target);
|
|
13
|
+
if (!clickedInside) {
|
|
14
|
+
this.clickOutside.emit();
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
ClickOutsideDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ClickOutsideDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
19
|
+
ClickOutsideDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: ClickOutsideDirective, isStandalone: true, selector: "[clickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event.target)" } }, ngImport: i0 });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ClickOutsideDirective, decorators: [{
|
|
21
|
+
type: Directive,
|
|
22
|
+
args: [{
|
|
23
|
+
standalone: true,
|
|
24
|
+
selector: '[clickOutside]'
|
|
25
|
+
}]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { clickOutside: [{
|
|
27
|
+
type: Output
|
|
28
|
+
}], onClick: [{
|
|
29
|
+
type: HostListener,
|
|
30
|
+
args: ['document:click', ['$event.target']]
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULE1BQU0sRUFDTixZQUFZLEVBRVosWUFBWSxFQUNiLE1BQU0sZUFBZSxDQUFDOztBQU12QixNQUFNLE9BQU8scUJBQXFCO0lBR2hDLGtEQUFrRDtJQUNsRCxZQUFxQixVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBSGpDLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUdKLENBQUM7SUFHeEMsT0FBTyxDQUFFLE1BQVc7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxRQUFRLENBQUMsU0FBUyxDQUFDO1lBQUUsT0FBTztRQUM1RSxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLGFBQWEsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdkUsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUNsQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQzs7a0hBYlUscUJBQXFCO3NHQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGdCQUFnQjtpQkFDM0I7aUdBRVcsWUFBWTtzQkFBckIsTUFBTTtnQkFNQSxPQUFPO3NCQURiLFlBQVk7dUJBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIE91dHB1dCxcbiAgRXZlbnRFbWl0dGVyLFxuICBFbGVtZW50UmVmLFxuICBIb3N0TGlzdGVuZXJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1tjbGlja091dHNpZGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBDbGlja091dHNpZGVEaXJlY3RpdmUge1xuICBAT3V0cHV0KCkgY2xpY2tPdXRzaWRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2VsZXNzLWNvbnN0cnVjdG9yXG4gIGNvbnN0cnVjdG9yIChwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgQEhvc3RMaXN0ZW5lcignZG9jdW1lbnQ6Y2xpY2snLCBbJyRldmVudC50YXJnZXQnXSlcbiAgcHVibGljIG9uQ2xpY2sgKHRhcmdldDogYW55KSB7XG4gICAgaWYgKCF0aGlzLmVsZW1lbnRSZWY/Lm5hdGl2ZUVsZW1lbnQ/LmNsYXNzTGlzdD8uY29udGFpbnMoJ2ZvY3VzZWQnKSkgcmV0dXJuO1xuICAgIGNvbnN0IGNsaWNrZWRJbnNpZGUgPSB0aGlzLmVsZW1lbnRSZWY/Lm5hdGl2ZUVsZW1lbnQ/LmNvbnRhaW5zKHRhcmdldCk7XG4gICAgaWYgKCFjbGlja2VkSW5zaWRlKSB7XG4gICAgICB0aGlzLmNsaWNrT3V0c2lkZS5lbWl0KCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CombineLabelsPipe {
|
|
4
|
+
transform(values, options, valueKey, labelKey, returnObject) {
|
|
5
|
+
return values
|
|
6
|
+
.map((v) => {
|
|
7
|
+
if (returnObject) {
|
|
8
|
+
return v[labelKey];
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
const option = options.find((opt) => opt[valueKey] === v);
|
|
12
|
+
return option ? option[labelKey] : 'unknown';
|
|
13
|
+
}
|
|
14
|
+
})
|
|
15
|
+
.join(', ');
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
CombineLabelsPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CombineLabelsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
19
|
+
CombineLabelsPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: CombineLabelsPipe, isStandalone: true, name: "combineLabels" });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CombineLabelsPipe, decorators: [{
|
|
21
|
+
type: Pipe,
|
|
22
|
+
args: [{ standalone: true, name: 'combineLabels' }]
|
|
23
|
+
}] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYmluZS1sYWJlbHMucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9waXBlcy9jb21iaW5lLWxhYmVscy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUdwRCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLFNBQVMsQ0FDUCxNQUFhLEVBQ2IsT0FBYyxFQUNkLFFBQWdCLEVBQ2hCLFFBQWdCLEVBQ2hCLFlBQXFCO1FBRXJCLE9BQU8sTUFBTTthQUNWLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQ1QsSUFBSSxZQUFZLEVBQUU7Z0JBQ2hCLE9BQU8sQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQ3BCO2lCQUFNO2dCQUNMLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztnQkFDMUQsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO2FBQzlDO1FBQ0gsQ0FBQyxDQUFDO2FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hCLENBQUM7OzhHQWxCVSxpQkFBaUI7NEdBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixJQUFJO21CQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AUGlwZSh7IHN0YW5kYWxvbmU6IHRydWUsIG5hbWU6ICdjb21iaW5lTGFiZWxzJyB9KVxuZXhwb3J0IGNsYXNzIENvbWJpbmVMYWJlbHNQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybSAoXG4gICAgdmFsdWVzOiBhbnlbXSxcbiAgICBvcHRpb25zOiBhbnlbXSxcbiAgICB2YWx1ZUtleTogc3RyaW5nLFxuICAgIGxhYmVsS2V5OiBzdHJpbmcsXG4gICAgcmV0dXJuT2JqZWN0OiBib29sZWFuXG4gICk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHZhbHVlc1xuICAgICAgLm1hcCgodikgPT4ge1xuICAgICAgICBpZiAocmV0dXJuT2JqZWN0KSB7XG4gICAgICAgICAgcmV0dXJuIHZbbGFiZWxLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnN0IG9wdGlvbiA9IG9wdGlvbnMuZmluZCgob3B0KSA9PiBvcHRbdmFsdWVLZXldID09PSB2KTtcbiAgICAgICAgICByZXR1cm4gb3B0aW9uID8gb3B0aW9uW2xhYmVsS2V5XSA6ICd1bmtub3duJztcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICAgIC5qb2luKCcsICcpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class LabelByValuePipe {
|
|
4
|
+
transform(value, options, valueKey, labelKey) {
|
|
5
|
+
const option = options.find((opt) => opt[valueKey] === value);
|
|
6
|
+
return option ? option[labelKey] : 'unknown';
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
LabelByValuePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LabelByValuePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
10
|
+
LabelByValuePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: LabelByValuePipe, isStandalone: true, name: "labelByValue" });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LabelByValuePipe, decorators: [{
|
|
12
|
+
type: Pipe,
|
|
13
|
+
args: [{ standalone: true, name: 'labelByValue' }]
|
|
14
|
+
}] });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwtYnktdmFsdWUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9waXBlcy9sYWJlbC1ieS12YWx1ZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUdwRCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFNBQVMsQ0FDUCxLQUFhLEVBQ2IsT0FBYyxFQUNkLFFBQWdCLEVBQ2hCLFFBQWdCO1FBRWhCLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQztRQUM5RCxPQUFPLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDL0MsQ0FBQzs7NkdBVFUsZ0JBQWdCOzJHQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsSUFBSTttQkFBQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLGNBQWMsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoeyBzdGFuZGFsb25lOiB0cnVlLCBuYW1lOiAnbGFiZWxCeVZhbHVlJyB9KVxuZXhwb3J0IGNsYXNzIExhYmVsQnlWYWx1ZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtIChcbiAgICB2YWx1ZTogc3RyaW5nLFxuICAgIG9wdGlvbnM6IGFueVtdLFxuICAgIHZhbHVlS2V5OiBzdHJpbmcsXG4gICAgbGFiZWxLZXk6IHN0cmluZ1xuICApOiBzdHJpbmcge1xuICAgIGNvbnN0IG9wdGlvbiA9IG9wdGlvbnMuZmluZCgob3B0KSA9PiBvcHRbdmFsdWVLZXldID09PSB2YWx1ZSk7XG4gICAgcmV0dXJuIG9wdGlvbiA/IG9wdGlvbltsYWJlbEtleV0gOiAndW5rbm93bic7XG4gIH1cbn1cbiJdfQ==
|