monkey-style-guide-v2 0.0.21 → 0.0.23
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/assets/scss/directives/_index.scss +1 -0
- package/assets/scss/directives/_popover.scss +81 -0
- package/assets/scss/theme.scss +5 -0
- package/esm2022/lib/components/accordion/accordion.component.mjs +11 -20
- package/esm2022/lib/components/action-bar/action-bar.component.mjs +3 -3
- package/esm2022/lib/components/button/button.component.mjs +6 -2
- package/esm2022/lib/components/checkbox/checkbox.component.mjs +9 -13
- package/esm2022/lib/components/date-range/date-range.component.mjs +2 -2
- package/esm2022/lib/components/form-field/form-field-control.mjs +1 -1
- package/esm2022/lib/components/form-field/form-field.component.mjs +15 -18
- package/esm2022/lib/components/form-field/form-field.module.mjs +4 -2
- package/esm2022/lib/components/icon/icon.component.mjs +4 -4
- package/esm2022/lib/components/icon-button/icon-button.component.mjs +2 -2
- package/esm2022/lib/components/index.mjs +3 -1
- package/esm2022/lib/components/input-phone/index.mjs +7 -0
- package/esm2022/lib/components/input-phone/input-phone.component.mjs +324 -0
- package/esm2022/lib/components/modal/components/confirmation.component.mjs +68 -0
- package/esm2022/lib/components/modal/components/default.mjs +1 -6
- package/esm2022/lib/components/modal/modal-config.mjs +2 -3
- package/esm2022/lib/components/modal/modal-ref.mjs +9 -2
- package/esm2022/lib/components/modal/modal.component.mjs +8 -6
- package/esm2022/lib/components/modal/modal.module.mjs +4 -1
- package/esm2022/lib/components/modal/modal.service.mjs +44 -31
- package/esm2022/lib/components/modal/utils.mjs +2 -1
- package/esm2022/lib/components/option/option.component.mjs +21 -5
- package/esm2022/lib/components/radio-button/index.mjs +7 -0
- package/esm2022/lib/components/radio-button/radio-button.component.mjs +190 -0
- package/esm2022/lib/components/security-level/security-level.component.mjs +3 -3
- package/esm2022/lib/components/select/select.component.mjs +5 -9
- package/esm2022/lib/components/status/status.component.mjs +3 -3
- package/esm2022/lib/components/table/components/pagination-size/pagination-size.mjs +2 -2
- package/esm2022/lib/components/toast/toast.component.mjs +3 -3
- package/esm2022/lib/components/tooltip/tooltip/tooltip.component.mjs +3 -3
- package/esm2022/lib/components/tooltip/tooltip.directive.mjs +12 -3
- package/esm2022/lib/directives/error.mjs +5 -5
- package/esm2022/lib/directives/helper.mjs +5 -5
- package/esm2022/lib/directives/index.mjs +2 -1
- package/esm2022/lib/directives/info.mjs +5 -5
- package/esm2022/lib/directives/label.mjs +5 -5
- package/esm2022/lib/directives/module.mjs +41 -35
- package/esm2022/lib/directives/popover.mjs +380 -0
- package/esm2022/lib/directives/prefix.mjs +5 -5
- package/esm2022/lib/directives/suffix.mjs +5 -5
- package/esm2022/lib/interfaces/index.mjs +2 -1
- package/esm2022/lib/interfaces/popover.mjs +2 -0
- package/esm2022/lib/services/dictionary.service.mjs +3 -3
- package/esm2022/lib/services/index.mjs +1 -2
- package/esm2022/lib/tokens/index.mjs +4 -2
- package/esm2022/utils/icon.mjs +277 -0
- package/esm2022/utils/index.mjs +2 -1
- package/fesm2022/monkey-style-guide-v2.mjs +2019 -828
- package/fesm2022/monkey-style-guide-v2.mjs.map +1 -1
- package/lib/components/accordion/accordion.component.d.ts +0 -3
- package/lib/components/button/button.component.d.ts +2 -0
- package/lib/components/checkbox/checkbox.component.d.ts +0 -3
- package/lib/components/form-field/form-field-control.d.ts +3 -3
- package/lib/components/form-field/form-field.component.d.ts +0 -5
- package/lib/components/form-field/form-field.module.d.ts +2 -1
- package/lib/components/icon/icon.component.d.ts +1 -1
- package/lib/components/index.d.ts +2 -0
- package/lib/components/input-phone/index.d.ts +6 -0
- package/lib/components/input-phone/input-phone.component.d.ts +68 -0
- package/lib/components/modal/components/confirmation.component.d.ts +12 -0
- package/lib/components/modal/components/default.d.ts +0 -5
- package/lib/components/modal/modal-config.d.ts +10 -6
- package/lib/components/modal/modal-ref.d.ts +1 -0
- package/lib/components/modal/modal.module.d.ts +10 -9
- package/lib/components/modal/modal.service.d.ts +4 -4
- package/lib/components/modal/utils.d.ts +3 -1
- package/lib/components/option/option.component.d.ts +4 -1
- package/lib/components/radio-button/index.d.ts +6 -0
- package/lib/components/radio-button/radio-button.component.d.ts +54 -0
- package/lib/components/select/select.component.d.ts +0 -3
- package/lib/components/tooltip/tooltip.directive.d.ts +1 -0
- package/lib/directives/error.d.ts +3 -3
- package/lib/directives/helper.d.ts +3 -3
- package/lib/directives/index.d.ts +1 -0
- package/lib/directives/info.d.ts +3 -3
- package/lib/directives/label.d.ts +3 -3
- package/lib/directives/module.d.ts +2 -1
- package/lib/directives/popover.d.ts +65 -0
- package/lib/directives/prefix.d.ts +3 -3
- package/lib/directives/suffix.d.ts +3 -3
- package/lib/interfaces/index.d.ts +1 -0
- package/lib/interfaces/popover.d.ts +7 -0
- package/lib/services/index.d.ts +0 -1
- package/lib/tokens/index.d.ts +3 -1
- package/monkey-style-guide-v2-0.0.23.tgz +0 -0
- package/package.json +3 -2
- package/utils/icon.d.ts +8 -0
- package/utils/index.d.ts +1 -0
- package/esm2022/lib/services/icons.service.mjs +0 -56
- package/lib/services/icons.service.d.ts +0 -16
- package/monkey-style-guide-v2-0.0.21.tgz +0 -0
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
/** ************************
|
|
2
|
+
* Copyright Monkey Exchange. All Rights Reserved
|
|
3
|
+
* This style guide was developed by Monkey Exchange Team
|
|
4
|
+
* MIT Licence
|
|
5
|
+
************************* */
|
|
6
|
+
import { CommonModule } from '@angular/common';
|
|
7
|
+
import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChildren, DestroyRef, ElementRef, EventEmitter, HostBinding, inject, Input, Optional, Output, ViewEncapsulation } from '@angular/core';
|
|
8
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
9
|
+
import { FormsModule, NgControl, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
10
|
+
import { Subject } from 'rxjs';
|
|
11
|
+
import { UtilIconComponent } from '../../../utils';
|
|
12
|
+
import { IdGenerator } from '../../../utils/id-generator';
|
|
13
|
+
import { MonkeyFormFieldControl } from '../form-field/form-field-control';
|
|
14
|
+
import { MonkeyOptionComponent } from '../option/option.component';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "../form-field/form-field.component";
|
|
17
|
+
export class MonkeyRadioButtonComponent {
|
|
18
|
+
get classes() {
|
|
19
|
+
return `${this.position} ${this.size}`;
|
|
20
|
+
}
|
|
21
|
+
get disabled() {
|
|
22
|
+
if (this.ngControl && this.ngControl.disabled !== null) {
|
|
23
|
+
return this.ngControl.disabled;
|
|
24
|
+
}
|
|
25
|
+
return this._disabled;
|
|
26
|
+
}
|
|
27
|
+
set disabled(value) {
|
|
28
|
+
this._disabled = value;
|
|
29
|
+
if (this.focused) {
|
|
30
|
+
this.focused = false;
|
|
31
|
+
this.stateChanges.next();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
get required() {
|
|
35
|
+
return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;
|
|
36
|
+
}
|
|
37
|
+
set required(value) {
|
|
38
|
+
this._required = value;
|
|
39
|
+
this.stateChanges.next();
|
|
40
|
+
}
|
|
41
|
+
set value(value) {
|
|
42
|
+
if (this._value !== value) {
|
|
43
|
+
this._value = value;
|
|
44
|
+
this._onChange(value);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
get value() {
|
|
48
|
+
return this._value;
|
|
49
|
+
}
|
|
50
|
+
constructor(changeDetectorRef, formField) {
|
|
51
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
52
|
+
this.formField = formField;
|
|
53
|
+
this.tabIndex = 0;
|
|
54
|
+
this.onChange = new EventEmitter();
|
|
55
|
+
this.onSearch = new EventEmitter();
|
|
56
|
+
this.position = 'horizontal';
|
|
57
|
+
this.size = 'lg';
|
|
58
|
+
this._value = null;
|
|
59
|
+
this._destroyRef = inject(DestroyRef);
|
|
60
|
+
this.idGenerator = inject(IdGenerator);
|
|
61
|
+
this.ngControl = inject(NgControl, { self: true, optional: true });
|
|
62
|
+
this._elementRef = inject(ElementRef);
|
|
63
|
+
this.focused = false;
|
|
64
|
+
this._disabled = false;
|
|
65
|
+
this.id = this.idGenerator.getId('monkey-radiobutton-');
|
|
66
|
+
this.stateChanges = new Subject();
|
|
67
|
+
this.type = 'radio-button';
|
|
68
|
+
this._onChange = () => { };
|
|
69
|
+
this._onTouched = () => { };
|
|
70
|
+
if (this.ngControl) {
|
|
71
|
+
this.ngControl.valueAccessor = this;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
changeSelected() {
|
|
75
|
+
setTimeout(() => {
|
|
76
|
+
if (this.options) {
|
|
77
|
+
this.options.forEach((opt) => {
|
|
78
|
+
opt.selected = opt.value === this.value;
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
this.changeDetectorRef.markForCheck();
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
initializeOptions() {
|
|
85
|
+
setTimeout(() => {
|
|
86
|
+
this.options?.forEach((option) => {
|
|
87
|
+
option.type = 'radio';
|
|
88
|
+
if (!option.action) {
|
|
89
|
+
option.action = this.selectOption.bind(this, option);
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
this.changeDetectorRef.markForCheck();
|
|
93
|
+
}, 0);
|
|
94
|
+
}
|
|
95
|
+
ngAfterContentInit() {
|
|
96
|
+
this.initializeOptions();
|
|
97
|
+
this.options.changes.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => {
|
|
98
|
+
this.initializeOptions();
|
|
99
|
+
this.changeSelected();
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
selectOption(option) {
|
|
103
|
+
if (!option.disabled && !this.disabled) {
|
|
104
|
+
this.value = option.value;
|
|
105
|
+
this._onChange(this.value);
|
|
106
|
+
this.onChange.emit(this.value);
|
|
107
|
+
this.options.forEach((opt) => {
|
|
108
|
+
opt.selected = opt.value === this.value;
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
writeValue(value) {
|
|
113
|
+
this.value = value;
|
|
114
|
+
this.changeSelected();
|
|
115
|
+
}
|
|
116
|
+
onContainerClick(event) {
|
|
117
|
+
if (this.disabled)
|
|
118
|
+
return;
|
|
119
|
+
this._elementRef.nativeElement.focus();
|
|
120
|
+
}
|
|
121
|
+
_onFocus() {
|
|
122
|
+
if (!this.disabled) {
|
|
123
|
+
this.focused = true;
|
|
124
|
+
this._onTouched();
|
|
125
|
+
this.stateChanges.next();
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
_onBlur() {
|
|
129
|
+
this.focused = false;
|
|
130
|
+
this.stateChanges.next();
|
|
131
|
+
}
|
|
132
|
+
registerOnChange(fn) {
|
|
133
|
+
this._onChange = fn;
|
|
134
|
+
}
|
|
135
|
+
registerOnTouched(fn) {
|
|
136
|
+
this._onTouched = fn;
|
|
137
|
+
}
|
|
138
|
+
setDisabledState(isDisabled) {
|
|
139
|
+
this.disabled = isDisabled;
|
|
140
|
+
this.initializeOptions();
|
|
141
|
+
}
|
|
142
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyRadioButtonComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.MonkeyFormFieldComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
143
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: MonkeyRadioButtonComponent, isStandalone: true, selector: "monkey-radiobutton", inputs: { tabIndex: "tabIndex", position: "position", size: "size", disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], value: "value" }, outputs: { onChange: "onChange", onSearch: "onSearch" }, host: { attributes: { "data-testid": "monkey-radiobutton" }, listeners: { "focus": "_onFocus()", "blur": "_onBlur()" }, properties: { "class.mecx-disabled": "disabled", "class.mecx-radiobutton-focused": "focused", "attr.id": "id", "attr.tabindex": "disabled ? -1 : tabIndex", "class": "this.classes" }, classAttribute: "mecx-radiobutton" }, providers: [
|
|
144
|
+
// eslint-disable-next-line no-use-before-define
|
|
145
|
+
{ provide: MonkeyFormFieldControl, useExisting: MonkeyRadioButtonComponent }
|
|
146
|
+
], queries: [{ propertyName: "options", predicate: MonkeyOptionComponent }], ngImport: i0, template: "<ng-content />\n", styles: ["monkey-radiobutton{display:inline-flex;width:100%;min-width:0;position:relative;flex-wrap:wrap}monkey-radiobutton:focus-visible,monkey-radiobutton:focus{outline:none}monkey-radiobutton.vertical{flex-direction:column}monkey-radiobutton.mecx-disabled monkey-option{opacity:.5;pointer-events:none}monkey-radiobutton.mecx-disabled monkey-option:before{background:var(--mecx-color-white);border-color:var(--mecx-color-gray-400)}monkey-radiobutton.mecx-form-field-invalid{background:var(--mecx-color-error-700)}monkey-radiobutton.md monkey-option:before{width:16px;height:16px}monkey-radiobutton.sm monkey-option:before{width:14px;height:14px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
147
|
+
}
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyRadioButtonComponent, decorators: [{
|
|
149
|
+
type: Component,
|
|
150
|
+
args: [{ selector: 'monkey-radiobutton', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, UtilIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
|
151
|
+
// eslint-disable-next-line no-use-before-define
|
|
152
|
+
{ provide: MonkeyFormFieldControl, useExisting: MonkeyRadioButtonComponent }
|
|
153
|
+
], host: {
|
|
154
|
+
'data-testid': 'monkey-radiobutton',
|
|
155
|
+
class: 'mecx-radiobutton',
|
|
156
|
+
'[class.mecx-disabled]': 'disabled',
|
|
157
|
+
'[class.mecx-radiobutton-focused]': 'focused',
|
|
158
|
+
'[attr.id]': 'id',
|
|
159
|
+
'[attr.tabindex]': 'disabled ? -1 : tabIndex',
|
|
160
|
+
'(focus)': '_onFocus()',
|
|
161
|
+
'(blur)': '_onBlur()'
|
|
162
|
+
}, template: "<ng-content />\n", styles: ["monkey-radiobutton{display:inline-flex;width:100%;min-width:0;position:relative;flex-wrap:wrap}monkey-radiobutton:focus-visible,monkey-radiobutton:focus{outline:none}monkey-radiobutton.vertical{flex-direction:column}monkey-radiobutton.mecx-disabled monkey-option{opacity:.5;pointer-events:none}monkey-radiobutton.mecx-disabled monkey-option:before{background:var(--mecx-color-white);border-color:var(--mecx-color-gray-400)}monkey-radiobutton.mecx-form-field-invalid{background:var(--mecx-color-error-700)}monkey-radiobutton.md monkey-option:before{width:16px;height:16px}monkey-radiobutton.sm monkey-option:before{width:14px;height:14px}\n"] }]
|
|
163
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.MonkeyFormFieldComponent, decorators: [{
|
|
164
|
+
type: Optional
|
|
165
|
+
}] }], propDecorators: { options: [{
|
|
166
|
+
type: ContentChildren,
|
|
167
|
+
args: [MonkeyOptionComponent]
|
|
168
|
+
}], tabIndex: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], onChange: [{
|
|
171
|
+
type: Output
|
|
172
|
+
}], onSearch: [{
|
|
173
|
+
type: Output
|
|
174
|
+
}], position: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], size: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], classes: [{
|
|
179
|
+
type: HostBinding,
|
|
180
|
+
args: ['class']
|
|
181
|
+
}], disabled: [{
|
|
182
|
+
type: Input,
|
|
183
|
+
args: [{ transform: booleanAttribute }]
|
|
184
|
+
}], required: [{
|
|
185
|
+
type: Input,
|
|
186
|
+
args: [{ transform: booleanAttribute }]
|
|
187
|
+
}], value: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}] } });
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-button.component.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/radio-button/radio-button.component.ts","../../../../../../projects/monkey-style-guide-v2/src/lib/components/radio-button/radio-button.component.html"],"names":[],"mappings":"AAAA;;;;6BAI6B;AAE7B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,gBAAgB,EAChB,uBAAuB,EAEvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,UAAU,EACV,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EAEN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAEL,WAAW,EACX,SAAS,EACT,mBAAmB,EACnB,UAAU,EACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAE1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;;;AAyBnE,MAAM,OAAO,0BAA0B;IAgBrC,IACI,OAAO;QACT,OAAO,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IACzC,CAAC;IAED,IACI,QAAQ;QACV,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YACvD,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QACjC,CAAC;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC;IAC/F,CAAC;IAED,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAID,IACI,KAAK,CAAC,KAAU;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAuBD,YACU,iBAAoC,EACxB,SAAmC;QAD/C,sBAAiB,GAAjB,iBAAiB,CAAmB;QACxB,cAAS,GAAT,SAAS,CAA0B;QAhFhD,aAAQ,GAAG,CAAC,CAAC;QAEZ,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAE9B,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAE/B,aAAQ,GAAG,YAAY,CAAC;QAGjC,SAAI,GAAe,IAAI,CAAC;QAgDxB,WAAM,GAAG,IAAI,CAAC;QAEN,gBAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAExB,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEnD,cAAS,GAAqB,MAAM,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAE,CAAC;QAEvE,gBAAW,GACnB,MAAM,CAAyE,UAAU,CAAC,CAAC;QAE7F,YAAO,GAAY,KAAK,CAAC;QAEzB,cAAS,GAAY,KAAK,CAAC;QAElB,OAAE,GAAW,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAE3D,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEnC,SAAI,GAAW,cAAc,CAAC;QA8EvC,cAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QAE1B,eAAU,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QA1EzB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;oBAC3B,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;gBAC1C,CAAC,CAAC,CAAC;YACL,CAAC;YACD,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB;QACvB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC/B,MAAM,CAAC,IAAI,GAAG,OAAO,CAAC;gBACtB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;oBACnB,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;gBACvD,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7E,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY,CAAC,MAA6B;QACxC,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACvC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAE/B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC3B,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;YAC1C,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,KAAiB;QAChC,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE1B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACzC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAMD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;+GA9KU,0BAA0B;mGAA1B,0BAA0B,6JAqBjB,gBAAgB,sCAiBhB,gBAAgB,8aArDzB;YACT,gDAAgD;YAChD,EAAE,OAAO,EAAE,sBAAsB,EAAE,WAAW,EAAE,0BAA0B,EAAE;SAC7E,kDAegB,qBAAqB,6BCnExC,kBACA,wrBD2CY,YAAY,8BAAE,mBAAmB,8BAAE,WAAW;;4FAoB7C,0BAA0B;kBAvBtC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,EAAE,WAAW,EAAE,iBAAiB,CAAC,mBAC3D,uBAAuB,CAAC,MAAM,iBAGhC,iBAAiB,CAAC,IAAI,aAC1B;wBACT,gDAAgD;wBAChD,EAAE,OAAO,EAAE,sBAAsB,EAAE,WAAW,4BAA4B,EAAE;qBAC7E,QACK;wBACJ,aAAa,EAAE,oBAAoB;wBACnC,KAAK,EAAE,kBAAkB;wBACzB,uBAAuB,EAAE,UAAU;wBACnC,kCAAkC,EAAE,SAAS;wBAC7C,WAAW,EAAE,IAAI;wBACjB,iBAAiB,EAAE,0BAA0B;wBAC7C,SAAS,EAAE,YAAY;wBACvB,QAAQ,EAAE,WAAW;qBACtB;;0BAuFE,QAAQ;yCAlF6B,OAAO;sBAA9C,eAAe;uBAAC,qBAAqB;gBAE7B,QAAQ;sBAAhB,KAAK;gBAEI,QAAQ;sBAAjB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAEE,QAAQ;sBAAhB,KAAK;gBAGN,IAAI;sBADH,KAAK;gBAIF,OAAO;sBADV,WAAW;uBAAC,OAAO;gBAMhB,QAAQ;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAkBlC,QAAQ;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAalC,KAAK;sBADR,KAAK","sourcesContent":["/** ************************\n * Copyright Monkey Exchange. All Rights Reserved\n * This style guide was developed by Monkey Exchange Team\n * MIT Licence\n ************************* */\n\nimport { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  inject,\n  Input,\n  Optional,\n  Output,\n  QueryList,\n  ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { UtilIconComponent } from '../../../utils';\nimport { IdGenerator } from '../../../utils/id-generator';\nimport { MonkeySize } from '../../interfaces';\nimport { MonkeyFormFieldControl } from '../form-field/form-field-control';\nimport { MonkeyFormFieldComponent } from '../form-field/form-field.component';\nimport { MonkeyOptionComponent } from '../option/option.component';\n\n@Component({\n  selector: 'monkey-radiobutton',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, UtilIconComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'radio-button.component.html',\n  styleUrls: ['./radio-button.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    // eslint-disable-next-line no-use-before-define\n    { provide: MonkeyFormFieldControl, useExisting: MonkeyRadioButtonComponent }\n  ],\n  host: {\n    'data-testid': 'monkey-radiobutton',\n    class: 'mecx-radiobutton',\n    '[class.mecx-disabled]': 'disabled',\n    '[class.mecx-radiobutton-focused]': 'focused',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n    '(focus)': '_onFocus()',\n    '(blur)': '_onBlur()'\n  }\n})\nexport class MonkeyRadioButtonComponent\n  implements MonkeyFormFieldControl, ControlValueAccessor, AfterContentInit\n{\n  @ContentChildren(MonkeyOptionComponent) options!: QueryList<MonkeyOptionComponent>;\n\n  @Input() tabIndex = 0;\n\n  @Output() onChange = new EventEmitter();\n\n  @Output() onSearch = new EventEmitter();\n\n  @Input() position = 'horizontal';\n\n  @Input()\n  size: MonkeySize = 'lg';\n\n  @HostBinding('class')\n  get classes() {\n    return `${this.position} ${this.size}`;\n  }\n\n  @Input({ transform: booleanAttribute })\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled;\n    }\n    return this._disabled;\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n\n  @Input({ transform: booleanAttribute })\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n\n  private _required: boolean | undefined;\n\n  @Input()\n  set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n      this._onChange(value);\n    }\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  _value = null;\n\n  private _destroyRef = inject(DestroyRef);\n\n  private readonly idGenerator = inject(IdGenerator);\n\n  ngControl: NgControl | null = inject(NgControl, { self: true, optional: true })!;\n\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  focused: boolean = false;\n\n  _disabled: boolean = false;\n\n  readonly id: string = this.idGenerator.getId('monkey-radiobutton-');\n\n  readonly stateChanges = new Subject<void>();\n\n  readonly type: string = 'radio-button';\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    @Optional() private formField: MonkeyFormFieldComponent\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  private changeSelected() {\n    setTimeout(() => {\n      if (this.options) {\n        this.options.forEach((opt) => {\n          opt.selected = opt.value === this.value;\n        });\n      }\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private initializeOptions() {\n    setTimeout(() => {\n      this.options?.forEach((option) => {\n        option.type = 'radio';\n        if (!option.action) {\n          option.action = this.selectOption.bind(this, option);\n        }\n      });\n      this.changeDetectorRef.markForCheck();\n    }, 0);\n  }\n\n  ngAfterContentInit() {\n    this.initializeOptions();\n    this.options.changes.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => {\n      this.initializeOptions();\n      this.changeSelected();\n    });\n  }\n\n  selectOption(option: MonkeyOptionComponent): void {\n    if (!option.disabled && !this.disabled) {\n      this.value = option.value;\n      this._onChange(this.value);\n      this.onChange.emit(this.value);\n\n      this.options.forEach((opt) => {\n        opt.selected = opt.value === this.value;\n      });\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.changeSelected();\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if (this.disabled) return;\n\n    this._elementRef.nativeElement.focus();\n  }\n\n  _onFocus() {\n    if (!this.disabled) {\n      this.focused = true;\n      this._onTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  _onBlur() {\n    this.focused = false;\n    this.stateChanges.next();\n  }\n\n  _onChange: any = () => {};\n\n  _onTouched: any = () => {};\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.initializeOptions();\n  }\n}\n","<ng-content />\n"]}
|
|
@@ -39,7 +39,7 @@ export class MonkeySecurityLevelComponent {
|
|
|
39
39
|
this.id = this.id;
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySecurityLevelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MonkeySecurityLevelComponent, isStandalone: true, selector: "monkey-security-level", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, score: { classPropertyName: "score", publicName: "score", isSignal: true, isRequired: true, transformFunction: null }, strengthLabel: { classPropertyName: "strengthLabel", publicName: "strengthLabel", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null } }, host: { attributes: { "data-testid": "monkey-security-level" }, properties: { "attr.id": "id", "id": "id", "class": "this.class" } }, ngImport: i0, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:var(--mecx-color-gray-700);font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:var(--mecx-color-gray-900);margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MonkeySecurityLevelComponent, isStandalone: true, selector: "monkey-security-level", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, score: { classPropertyName: "score", publicName: "score", isSignal: true, isRequired: true, transformFunction: null }, strengthLabel: { classPropertyName: "strengthLabel", publicName: "strengthLabel", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null } }, host: { attributes: { "data-testid": "monkey-security-level" }, properties: { "attr.id": "id", "id": "id", "class": "this.class" } }, ngImport: i0, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:var(--mecx-color-gray-700);font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:var(--mecx-color-gray-900);margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:var(--mecx-color-gray-300);position:relative;overflow:hidden}monkey-security-level .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}monkey-security-level.very-strong .bar:before{background:var(--mecx-color-success-main);width:100%}monkey-security-level.strong .bar:before{background:var(--mecx-color-success-main);width:80%}monkey-security-level.medium .bar:before{background:var(--mecx-color-warning-main);width:66%}monkey-security-level.weak .bar:before{background:var(--mecx-color-error-700);width:33%}monkey-security-level.empty .bar:before{background:var(--mecx-color-error-700);width:0%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySecurityLevelComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
@@ -47,11 +47,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
47
47
|
'data-testid': 'monkey-security-level',
|
|
48
48
|
'[attr.id]': 'id',
|
|
49
49
|
'[id]': 'id'
|
|
50
|
-
}, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:var(--mecx-color-gray-700);font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:var(--mecx-color-gray-900);margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background
|
|
50
|
+
}, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:var(--mecx-color-gray-700);font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:var(--mecx-color-gray-900);margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:var(--mecx-color-gray-300);position:relative;overflow:hidden}monkey-security-level .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}monkey-security-level.very-strong .bar:before{background:var(--mecx-color-success-main);width:100%}monkey-security-level.strong .bar:before{background:var(--mecx-color-success-main);width:80%}monkey-security-level.medium .bar:before{background:var(--mecx-color-warning-main);width:66%}monkey-security-level.weak .bar:before{background:var(--mecx-color-error-700);width:33%}monkey-security-level.empty .bar:before{background:var(--mecx-color-error-700);width:0%}\n"] }]
|
|
51
51
|
}], ctorParameters: () => [], propDecorators: { class: [{
|
|
52
52
|
type: HostBinding,
|
|
53
53
|
args: ['class']
|
|
54
54
|
}], id: [{
|
|
55
55
|
type: Input
|
|
56
56
|
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjdXJpdHktbGV2ZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LXN0eWxlLWd1aWRlLXYyL3NyYy9saWIvY29tcG9uZW50cy9zZWN1cml0eS1sZXZlbC9zZWN1cml0eS1sZXZlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL3NlY3VyaXR5LWxldmVsL3NlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OzZCQUk2QjtBQUM3QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEcsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFlN0MsTUFBTSxPQUFPLDRCQUE0QjtJQU92QyxJQUNXLEtBQUs7UUFDZCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN2QixPQUFPLE9BQU8sQ0FBQztRQUNqQixDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsR0FBRyxFQUFFLENBQUM7WUFDdkIsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsR0FBRyxFQUFFLENBQUM7WUFDOUMsT0FBTyxRQUFRLENBQUM7UUFDbEIsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsSUFBSSxFQUFFLENBQUM7WUFDL0MsT0FBTyxRQUFRLENBQUM7UUFDbEIsQ0FBQztRQUVELE9BQU8sYUFBYSxDQUFDO0lBQ3ZCLENBQUM7SUFNRCxJQUNJLEVBQUU7UUFDSixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDbEIsQ0FBQztJQUVELElBQUksRUFBRSxDQUFDLEtBQWE7UUFDbEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQztJQUNoQyxDQUFDO0lBRUQ7UUF4Q0EsVUFBSyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBRXhCLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFFakMsa0JBQWEsR0FBRyxLQUFLLEVBQVUsQ0FBQztRQXVCdEIsU0FBSSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxLQUFLLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQWNuRSwwQ0FBMEM7UUFDMUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ3BCLENBQUM7K0dBNUNVLDRCQUE0QjttR0FBNUIsNEJBQTRCLGt0QkN0QnpDLDJTQVdBLG13Q0RBWSxZQUFZOzs0RkFXWCw0QkFBNEI7a0JBYnhDLFNBQVM7b0NBQ08saUJBQWlCLENBQUMsSUFBSSxXQUM1QixDQUFDLFlBQVksQ0FBQyxZQUNiLHVCQUF1QixjQUNyQixJQUFJLFFBR1Y7d0JBQ0osYUFBYSxFQUFFLHVCQUF1Qjt3QkFDdEMsV0FBVyxFQUFFLElBQUk7d0JBQ2pCLE1BQU0sRUFBRSxJQUFJO3FCQUNiO3dEQVVVLEtBQUs7c0JBRGYsV0FBVzt1QkFBQyxPQUFPO2dCQTBCaEIsRUFBRTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyoqICoqKioqKioqKioqKioqKioqKioqKioqKlxuICogQ29weXJpZ2h0IE1vbmtleSBFeGNoYW5nZS4gQWxsIFJpZ2h0cyBSZXNlcnZlZFxuICogVGhpcyBzdHlsZSBndWlkZSB3YXMgZGV2ZWxvcGVkIGJ5IE1vbmtleSBFeGNoYW5nZSBUZWFtXG4gKiBNSVQgTGljZW5jZVxuICoqKioqKioqKioqKioqKioqKioqKioqKiogKi9cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBpbmplY3QsIElucHV0LCBpbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElkR2VuZXJhdG9yIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHNlbGVjdG9yOiAnbW9ua2V5LXNlY3VyaXR5LWxldmVsJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc3R5bGVVcmw6ICcuL3NlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5zY3NzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5odG1sJyxcbiAgaG9zdDoge1xuICAgICdkYXRhLXRlc3RpZCc6ICdtb25rZXktc2VjdXJpdHktbGV2ZWwnLFxuICAgICdbYXR0ci5pZF0nOiAnaWQnLFxuICAgICdbaWRdJzogJ2lkJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIE1vbmtleVNlY3VyaXR5TGV2ZWxDb21wb25lbnQge1xuICBsYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBzY29yZSA9IGlucHV0LnJlcXVpcmVkPG51bWJlcj4oKTtcblxuICBzdHJlbmd0aExhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBwdWJsaWMgZ2V0IGNsYXNzKCk6IHN0cmluZyB7XG4gICAgaWYgKHRoaXMuc2NvcmUoKSA9PT0gMCkge1xuICAgICAgcmV0dXJuICdlbXB0eSc7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuc2NvcmUoKSA8IDMwMCkge1xuICAgICAgcmV0dXJuICd3ZWFrJztcbiAgICB9XG5cbiAgICBpZiAodGhpcy5zY29yZSgpID49IDMwMCAmJiB0aGlzLnNjb3JlKCkgPCA4MDApIHtcbiAgICAgIHJldHVybiAnbWVkaXVtJztcbiAgICB9XG5cbiAgICBpZiAodGhpcy5zY29yZSgpID49IDgwMCAmJiB0aGlzLnNjb3JlKCkgPCAxMDAwKSB7XG4gICAgICByZXR1cm4gJ3N0cm9uZyc7XG4gICAgfVxuXG4gICAgcmV0dXJuICd2ZXJ5LXN0cm9uZyc7XG4gIH1cblxuICBwcm90ZWN0ZWQgX3VpZCA9IGluamVjdChJZEdlbmVyYXRvcikuZ2V0SWQoJ21vbmtleS1zZWN1cml0eS1sZXZlbC0nKTtcblxuICBwcm90ZWN0ZWQgX2lkITogc3RyaW5nO1xuXG4gIEBJbnB1dCgpXG4gIGdldCBpZCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl9pZDtcbiAgfVxuXG4gIHNldCBpZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5faWQgPSB2YWx1ZSB8fCB0aGlzLl91aWQ7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tc2VsZi1hc3NpZ25cbiAgICB0aGlzLmlkID0gdGhpcy5pZDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImJvZHlcIj5cbiAgPGRpdj5cbiAgICA8c3BhbiBkYXRhLXRlc3RpZD1cImxhYmVsXCIgKm5nSWY9XCJsYWJlbCgpIGFzIGxiXCI+XG4gICAgICB7eyBsYiB9fVxuICAgIDwvc3Bhbj5cbiAgICA8c3BhbiBkYXRhLXRlc3RpZD1cInN0ci1sYWJlbFwiIGNsYXNzPVwibGV2ZWwtaW5mb1wiICpuZ0lmPVwic3RyZW5ndGhMYWJlbCgpIGFzIHN0ckxhYmVsXCI+XG4gICAgICB7eyBzdHJMYWJlbCB9fVxuICAgIDwvc3Bhbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJiYXJcIj48L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -10,10 +10,9 @@ import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChildren,
|
|
|
10
10
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
11
11
|
import { FormsModule, NgControl, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
12
12
|
import { debounceTime, Subject } from 'rxjs';
|
|
13
|
-
import { normalizeStringToSearch, sanitizeString } from '../../../utils';
|
|
13
|
+
import { normalizeStringToSearch, sanitizeString, UtilIconComponent } from '../../../utils';
|
|
14
14
|
import { IdGenerator } from '../../../utils/id-generator';
|
|
15
15
|
import { MonkeyDictionaryService } from '../../services/dictionary.service';
|
|
16
|
-
import { MonkeyIconsService } from '../../services/icons.service';
|
|
17
16
|
import { MonkeyFormFieldControl } from '../form-field/form-field-control';
|
|
18
17
|
import { MonkeyOptionComponent } from '../option/option.component';
|
|
19
18
|
import * as i0 from "@angular/core";
|
|
@@ -68,7 +67,6 @@ export class MonkeySelectComponent {
|
|
|
68
67
|
this.labelSelected = '';
|
|
69
68
|
this.overlayRef = null;
|
|
70
69
|
this._destroyRef = inject(DestroyRef);
|
|
71
|
-
this.iconArrowDown = inject(MonkeyIconsService).arrowDown;
|
|
72
70
|
this.idGenerator = inject(IdGenerator);
|
|
73
71
|
this.ngControl = inject(NgControl, { self: true, optional: true });
|
|
74
72
|
this._elementRef = inject(ElementRef);
|
|
@@ -82,8 +80,6 @@ export class MonkeySelectComponent {
|
|
|
82
80
|
this.searchHandle = new EventEmitter();
|
|
83
81
|
this.searchDictionary = inject(MonkeyDictionaryService).get('NO-DATA');
|
|
84
82
|
this.loadingDictionary = inject(MonkeyDictionaryService).get('LOADING');
|
|
85
|
-
this.imgSearchNoData = inject(MonkeyIconsService).searchFail;
|
|
86
|
-
this.imgSearch = inject(MonkeyIconsService).search;
|
|
87
83
|
this.showSearchNoData = false;
|
|
88
84
|
this.isOpen = false;
|
|
89
85
|
this.searchData = '';
|
|
@@ -349,7 +345,7 @@ export class MonkeySelectComponent {
|
|
|
349
345
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MonkeySelectComponent, isStandalone: true, selector: "monkey-select", inputs: { tabIndex: "tabIndex", placeholder: "placeholder", loading: ["loading", "loading", booleanAttribute], showSearch: ["showSearch", "showSearch", booleanAttribute], searchPlaceholder: "searchPlaceholder", callbackSearch: ["callbackSearch", "callbackSearch", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], value: "value" }, outputs: { onChange: "onChange", onSearch: "onSearch" }, host: { attributes: { "data-testid": "monkey-select" }, listeners: { "focus": "_onFocus()", "blur": "_onBlur()" }, properties: { "class.mecx-select-disabled": "_disabled", "class.mecx-select-focused": "focused", "attr.id": "id", "attr.tabindex": "disabled ? -1 : tabIndex" }, classAttribute: "mecx-select" }, providers: [
|
|
350
346
|
// eslint-disable-next-line no-use-before-define
|
|
351
347
|
{ provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent }
|
|
352
|
-
], queries: [{ propertyName: "options", predicate: MonkeyOptionComponent }], viewQueries: [{ propertyName: "overlayTemplate", first: true, predicate: ["overlayTemplate"], descendants: true }, { propertyName: "overlayEl", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <
|
|
348
|
+
], queries: [{ propertyName: "options", predicate: MonkeyOptionComponent }], viewQueries: [{ propertyName: "overlayTemplate", first: true, predicate: ["overlayTemplate"], descendants: true }, { propertyName: "overlayEl", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <util-icon class=\"mecx-select-icon\" name=\"arrowDown\" />\n }\n</div>\n\n<ng-template #overlayTemplate>\n <div class=\"mecx-select-body-overlay\">\n @if (showSearch) {\n <div class=\"mecx-select-search\">\n <util-icon class=\"mecx-select-search-icon\" name=\"search\" />\n <input\n (input)=\"onHandleSearch($event)\"\n type=\"text\"\n [id]=\"id + '-search'\"\n autocomplete=\"off\"\n maxlength=\"50\"\n [placeholder]=\"searchPlaceholder\"\n [(ngModel)]=\"searchData\"\n />\n </div>\n }\n <div\n class=\"mecx-select-overlay\"\n #overlay\n [@animation]=\"isOpen ? 'open' : 'closed'\"\n (@animation.done)=\"onAnimationEnd($event)\"\n >\n <ng-content />\n </div>\n @if (showSearch && showSearchNoData) {\n <div class=\"mecx-select-search-no-data\">\n <util-icon class=\"mecx-select-search-no-data-icon\" name=\"searchFail\" />\n {{ searchDictionary | async }}\n </div>\n }\n @if (loading) {\n <div class=\"mecx-select-search-loading\">\n {{ loadingDictionary | async }}\n </div>\n }\n </div>\n</ng-template>\n", styles: ["monkey-select{display:inline-flex;width:100%;min-width:0;position:relative}monkey-select:focus-visible,monkey-select:focus{outline:none}.mecx-select-trigger{width:100%;display:inline-flex;align-items:center;cursor:pointer;gap:8px;box-sizing:border-box}.mecx-select-trigger .mecx-select-value{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--mecx-color-gray-500);font-size:14px;line-height:24px;letter-spacing:.42px}.mecx-select-trigger .mecx-select-value.has-value{color:var(--mecx-color-gray-900)}.mecx-select-trigger .mecx-select-icon{display:flex;transition:all .2s ease-in-out}.mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-theme-main)}.mecx-select-disabled .mecx-select-trigger{background-color:var(--mecx-color-gray-50);border-color:var(--mecx-color-gray-50);cursor:default}.mecx-select-disabled .mecx-select-trigger .mecx-select-value{color:var(--mecx-color-gray-400)}.mecx-select-disabled .mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-gray-400)}.mecx-select-trigger.open .mecx-select-icon{transform:rotate(180deg)}.mecx-select-body-overlay{width:100%;background:#fff;border:2px solid var(--mecx-color-gray-400);overflow:hidden;border-radius:4px;box-shadow:0 16px 32px 0 var(--mecx-color-box-shadow)}.mecx-select-body-overlay .mecx-select-search{display:flex;gap:4px;border-bottom:2px solid var(--mecx-color-gray-400);padding:8px}.mecx-select-body-overlay .mecx-select-search-icon{width:12px;display:flex}.mecx-select-body-overlay .mecx-select-search-icon svg path{stroke:var(--mecx-color-gray-600)}.mecx-select-body-overlay input{border:none;width:90%;color:var(--mecx-color-gray-600)!important;font-size:12px;letter-spacing:.54px}.mecx-select-body-overlay .mecx-select-search-no-data,.mecx-select-body-overlay .mecx-select-search-loading{padding:12px;display:flex;justify-content:center;flex-direction:column;align-items:center;gap:4px;color:var(--mecx-color-gray-600);font-size:12px;letter-spacing:.54px;text-align:center}.mecx-select-body-overlay .mecx-select-search-no-data-icon svg path,.mecx-select-body-overlay .mecx-select-search-loading-icon svg path{stroke:var(--mecx-color-gray-600)}.mecx-select-overlay{width:100%;background:#fff;overflow:hidden auto;max-height:360px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: UtilIconComponent, selector: "util-icon", inputs: ["name"] }], animations: [
|
|
353
349
|
trigger('animation', [
|
|
354
350
|
transition(':enter', [
|
|
355
351
|
style({
|
|
@@ -371,7 +367,7 @@ export class MonkeySelectComponent {
|
|
|
371
367
|
}
|
|
372
368
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySelectComponent, decorators: [{
|
|
373
369
|
type: Component,
|
|
374
|
-
args: [{ selector: 'monkey-select', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
|
370
|
+
args: [{ selector: 'monkey-select', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, UtilIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
|
375
371
|
// eslint-disable-next-line no-use-before-define
|
|
376
372
|
{ provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent }
|
|
377
373
|
], animations: [
|
|
@@ -401,7 +397,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
401
397
|
'[attr.tabindex]': 'disabled ? -1 : tabIndex',
|
|
402
398
|
'(focus)': '_onFocus()',
|
|
403
399
|
'(blur)': '_onBlur()'
|
|
404
|
-
}, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <
|
|
400
|
+
}, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <util-icon class=\"mecx-select-icon\" name=\"arrowDown\" />\n }\n</div>\n\n<ng-template #overlayTemplate>\n <div class=\"mecx-select-body-overlay\">\n @if (showSearch) {\n <div class=\"mecx-select-search\">\n <util-icon class=\"mecx-select-search-icon\" name=\"search\" />\n <input\n (input)=\"onHandleSearch($event)\"\n type=\"text\"\n [id]=\"id + '-search'\"\n autocomplete=\"off\"\n maxlength=\"50\"\n [placeholder]=\"searchPlaceholder\"\n [(ngModel)]=\"searchData\"\n />\n </div>\n }\n <div\n class=\"mecx-select-overlay\"\n #overlay\n [@animation]=\"isOpen ? 'open' : 'closed'\"\n (@animation.done)=\"onAnimationEnd($event)\"\n >\n <ng-content />\n </div>\n @if (showSearch && showSearchNoData) {\n <div class=\"mecx-select-search-no-data\">\n <util-icon class=\"mecx-select-search-no-data-icon\" name=\"searchFail\" />\n {{ searchDictionary | async }}\n </div>\n }\n @if (loading) {\n <div class=\"mecx-select-search-loading\">\n {{ loadingDictionary | async }}\n </div>\n }\n </div>\n</ng-template>\n", styles: ["monkey-select{display:inline-flex;width:100%;min-width:0;position:relative}monkey-select:focus-visible,monkey-select:focus{outline:none}.mecx-select-trigger{width:100%;display:inline-flex;align-items:center;cursor:pointer;gap:8px;box-sizing:border-box}.mecx-select-trigger .mecx-select-value{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--mecx-color-gray-500);font-size:14px;line-height:24px;letter-spacing:.42px}.mecx-select-trigger .mecx-select-value.has-value{color:var(--mecx-color-gray-900)}.mecx-select-trigger .mecx-select-icon{display:flex;transition:all .2s ease-in-out}.mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-theme-main)}.mecx-select-disabled .mecx-select-trigger{background-color:var(--mecx-color-gray-50);border-color:var(--mecx-color-gray-50);cursor:default}.mecx-select-disabled .mecx-select-trigger .mecx-select-value{color:var(--mecx-color-gray-400)}.mecx-select-disabled .mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-gray-400)}.mecx-select-trigger.open .mecx-select-icon{transform:rotate(180deg)}.mecx-select-body-overlay{width:100%;background:#fff;border:2px solid var(--mecx-color-gray-400);overflow:hidden;border-radius:4px;box-shadow:0 16px 32px 0 var(--mecx-color-box-shadow)}.mecx-select-body-overlay .mecx-select-search{display:flex;gap:4px;border-bottom:2px solid var(--mecx-color-gray-400);padding:8px}.mecx-select-body-overlay .mecx-select-search-icon{width:12px;display:flex}.mecx-select-body-overlay .mecx-select-search-icon svg path{stroke:var(--mecx-color-gray-600)}.mecx-select-body-overlay input{border:none;width:90%;color:var(--mecx-color-gray-600)!important;font-size:12px;letter-spacing:.54px}.mecx-select-body-overlay .mecx-select-search-no-data,.mecx-select-body-overlay .mecx-select-search-loading{padding:12px;display:flex;justify-content:center;flex-direction:column;align-items:center;gap:4px;color:var(--mecx-color-gray-600);font-size:12px;letter-spacing:.54px;text-align:center}.mecx-select-body-overlay .mecx-select-search-no-data-icon svg path,.mecx-select-body-overlay .mecx-select-search-loading-icon svg path{stroke:var(--mecx-color-gray-600)}.mecx-select-overlay{width:100%;background:#fff;overflow:hidden auto;max-height:360px}\n"] }]
|
|
405
401
|
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }, { type: i2.MonkeyFormFieldComponent, decorators: [{
|
|
406
402
|
type: Optional
|
|
407
403
|
}] }], propDecorators: { overlayTemplate: [{
|
|
@@ -445,4 +441,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
445
441
|
}], value: [{
|
|
446
442
|
type: Input
|
|
447
443
|
}] } });
|
|
448
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/select/select.component.ts","../../../../../../projects/monkey-style-guide-v2/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/** ************************\n * Copyright Monkey Exchange. All Rights Reserved\n * This style guide was developed by Monkey Exchange Team\n * MIT Licence\n ************************* */\n\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { ConnectedPosition, Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport { debounceTime, Subject } from 'rxjs';\nimport { normalizeStringToSearch, sanitizeString } from '../../../utils';\nimport { IdGenerator } from '../../../utils/id-generator';\nimport { MonkeyDictionaryService } from '../../services/dictionary.service';\nimport { MonkeyIconsService } from '../../services/icons.service';\nimport { MonkeyFormFieldControl } from '../form-field/form-field-control';\nimport { MonkeyFormFieldComponent } from '../form-field/form-field.component';\nimport { MonkeyOptionComponent } from '../option/option.component';\n\n@Component({\n  selector: 'monkey-select',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule, FormsModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    // eslint-disable-next-line no-use-before-define\n    { provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent }\n  ],\n  animations: [\n    trigger('animation', [\n      transition(':enter', [\n        style({\n          opacity: 0,\n          transform: 'scaleY(.9)'\n        }),\n        animate(\n          '100ms ease-in-out',\n          style({\n            opacity: 1,\n            transform: 'scaleY(1)'\n          })\n        )\n      ]),\n      state(\n        'closed',\n        style({\n          transform: 'scaleY(.9)',\n          opacity: 0\n        })\n      ),\n      transition('closed <=> open', animate('200ms ease-in-out'))\n    ])\n  ],\n  host: {\n    'data-testid': 'monkey-select',\n    class: 'mecx-select',\n    '[class.mecx-select-disabled]': '_disabled',\n    '[class.mecx-select-focused]': 'focused',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n    '(focus)': '_onFocus()',\n    '(blur)': '_onBlur()'\n  }\n})\nexport class MonkeySelectComponent\n  implements\n    MonkeyFormFieldControl,\n    ControlValueAccessor,\n    AfterContentInit,\n    OnInit,\n    OnDestroy,\n    OnChanges\n{\n  @ViewChild('overlayTemplate') overlayTemplate!: TemplateRef<any>;\n\n  @ViewChild('overlay') overlayEl!: ElementRef;\n\n  @ViewChild('trigger') trigger!: ElementRef;\n\n  @ContentChildren(MonkeyOptionComponent) options!: QueryList<MonkeyOptionComponent>;\n\n  @Input() tabIndex = 0;\n\n  @Output() onChange = new EventEmitter();\n\n  @Output() onSearch = new EventEmitter();\n\n  @Input({ required: true }) placeholder = '';\n\n  @Input({ transform: booleanAttribute })\n  loading = false;\n\n  @Input({ transform: booleanAttribute })\n  showSearch = true;\n\n  @Input()\n  searchPlaceholder = '';\n\n  @Input({ transform: booleanAttribute })\n  callbackSearch = false;\n\n  @Input({ transform: booleanAttribute })\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled;\n    }\n    return this._disabled;\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n\n  @Input({ transform: booleanAttribute })\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n\n  private _required: boolean | undefined;\n\n  @Input()\n  set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n      this._onChange(value);\n    }\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  _value = null;\n\n  labelSelected = '';\n\n  private overlayRef: OverlayRef | null = null;\n\n  private _destroyRef = inject(DestroyRef);\n\n  readonly iconArrowDown = inject(MonkeyIconsService).arrowDown;\n\n  private readonly idGenerator = inject(IdGenerator);\n\n  ngControl: NgControl | null = inject(NgControl, { self: true, optional: true })!;\n\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  readonly currency: boolean = false;\n\n  focused: boolean = false;\n\n  _disabled: boolean = false;\n\n  readonly id: string = this.idGenerator.getId('monkey-select-');\n\n  readonly percent: boolean = false;\n\n  readonly stateChanges = new Subject<void>();\n\n  readonly type: string = '';\n\n  readonly searchHandle = new EventEmitter<string>();\n\n  readonly searchDictionary = inject(MonkeyDictionaryService).get('NO-DATA');\n\n  readonly loadingDictionary = inject(MonkeyDictionaryService).get('LOADING');\n\n  readonly imgSearchNoData = inject(MonkeyIconsService).searchFail;\n\n  readonly imgSearch = inject(MonkeyIconsService).search;\n\n  showSearchNoData = false;\n\n  isOpen = false;\n\n  searchData = '';\n\n  constructor(\n    private overlay: Overlay,\n    private changeDetectorRef: ChangeDetectorRef,\n    private viewContainerRef: ViewContainerRef,\n    @Optional() private formField: MonkeyFormFieldComponent\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  private changeControl() {\n    if (this.formField?.control) {\n      this.formField.control.loading = this.loading;\n    }\n  }\n\n  private changeSelected() {\n    setTimeout(() => {\n      if (this.options) {\n        this.options.forEach((opt) => {\n          opt.selected = opt.value === this.value;\n        });\n        this.updateSelectedLabel();\n      }\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private initializeOptions() {\n    this.options.forEach((option) => {\n      if (!option.action) {\n        option.action = this.selectOption.bind(this, option);\n      }\n    });\n  }\n\n  private openDropdown(): void {\n    if (this.options?.length) {\n      this.formField.control.disableToBeDirty = true;\n      this.isOpen = true;\n      this.createOverlay();\n    }\n  }\n\n  private closeDropdown() {\n    this.changeDetectorRef.markForCheck();\n    this.isOpen = false;\n    this.focused = false;\n    this.formField.control.disableToBeDirty = false;\n    if (!this.callbackSearch) {\n      this.searchData = '';\n    }\n  }\n\n  private closeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n  }\n\n  private initializeWithOverlay() {\n    if (this.showSearch) {\n      const element = this.overlayRef?.overlayElement.querySelector(\n        `#${this.id}-search`\n      ) as HTMLElement;\n\n      this.options.forEach((opt) => {\n        const element = this.overlayRef?.overlayElement.querySelector(\n          `#${opt.id}`\n        ) as HTMLElement | null;\n        if (!element) return;\n        element.style.display = '';\n      });\n\n      setTimeout(() => {\n        element?.focus();\n      }, 0);\n      this.showSearchNoData = false;\n    }\n\n    setTimeout(() => {\n      const selected = this.options.find((opt) => {\n        return opt.selected;\n      });\n\n      if (selected) {\n        const element = this.overlayRef?.overlayElement.querySelector(\n          `#${selected.id}`\n        ) as HTMLElement;\n        element?.scrollIntoView({ behavior: 'instant', block: 'center' });\n      }\n    }, 0);\n  }\n\n  private createOverlay(): void {\n    if (this.overlayRef) {\n      return;\n    }\n\n    const offset = 4;\n    const positions: ConnectedPosition[] = [\n      {\n        originX: 'start',\n        originY: 'bottom',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetY: offset\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n        offsetY: -offset\n      }\n    ];\n\n    let anchor = this.trigger;\n    let width = anchor.nativeElement.offsetWidth;\n\n    if (this.formField?.elementRef) {\n      const el = this.formField?.elementRef.nativeElement.querySelector('.mecx-form-field-body');\n      anchor = el;\n      width = el.offsetWidth;\n    }\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(anchor)\n      .withPositions(positions)\n      .withPush(true);\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n      width,\n      hasBackdrop: true,\n      backdropClass: 'no-class'\n    });\n\n    const portal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);\n\n    this.overlayRef.attach(portal);\n\n    this.overlayRef\n      .backdropClick()\n      .pipe(takeUntilDestroyed(this._destroyRef))\n      .subscribe(() => {\n        return this.closeDropdown();\n      });\n\n    this.initializeWithOverlay();\n  }\n\n  private updateSelectedLabel(): void {\n    const selectedOption = this.options.find((opt) => {\n      return opt.value === this.value;\n    });\n    this.labelSelected = selectedOption ? selectedOption.displayContent : '';\n  }\n\n  private executeSearch(search: string): void {\n    let found = false;\n    this.options.forEach((opt) => {\n      const element = this.overlayRef?.overlayElement.querySelector(\n        `#${opt.id}`\n      ) as HTMLElement | null;\n\n      if (!element) return;\n\n      const isMatch = normalizeStringToSearch(opt.displayContent).includes(\n        normalizeStringToSearch(search)\n      );\n      if (isMatch) {\n        found = true;\n      }\n      element.style.display = isMatch ? '' : 'none';\n    });\n\n    this.repositionScroll();\n    this.showSearchNoData = !found;\n  }\n\n  private repositionScroll() {\n    const overlayElement = this.overlayRef?.overlayElement.querySelector(\n      '.mecx-select-overlay'\n    ) as HTMLElement;\n\n    if (overlayElement) {\n      overlayElement.scrollTop = 0;\n    }\n  }\n\n  ngOnInit() {\n    this.searchHandle\n      .pipe(debounceTime(200), takeUntilDestroyed(this._destroyRef))\n      .subscribe((search: string) => {\n        if (this.callbackSearch) {\n          this.onSearch.next(search);\n          this.repositionScroll();\n        } else {\n          this.executeSearch(search);\n        }\n      });\n  }\n\n  ngAfterContentInit() {\n    this.initializeOptions();\n    this.options.changes.pipe(takeUntilDestroyed(this._destroyRef)).subscribe((resp) => {\n      this.updateSelectedLabel();\n      this.initializeOptions();\n      this.changeSelected();\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n  }\n\n  toggleDropdown(): void {\n    if (!this.disabled) {\n      if (this.isOpen) {\n        this.closeDropdown();\n        this._onTouched();\n      } else {\n        this.openDropdown();\n      }\n    }\n  }\n\n  onAnimationEnd = (event: any) => {\n    if (event.toState === 'closed') {\n      this.closeOverlay();\n    }\n  };\n\n  selectOption(option: MonkeyOptionComponent): void {\n    if (!option.disabled && !this.disabled) {\n      this.value = option.value;\n      this.updateSelectedLabel();\n      this.closeDropdown();\n      this._onChange(this.value);\n      this.onChange.emit(this.value);\n\n      this.options.forEach((opt) => {\n        opt.selected = opt.value === this.value;\n      });\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.changeSelected();\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if (this.disabled) return;\n\n    this.openDropdown();\n    this._elementRef.nativeElement.focus();\n  }\n\n  _onFocus() {\n    if (!this.disabled) {\n      this.focused = true;\n      this._onTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  _onBlur() {\n    this.focused = false;\n    this.stateChanges.next();\n  }\n\n  _onChange: any = () => {};\n\n  _onTouched: any = () => {};\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let hasChanges = false;\n    // eslint-disable-next-line dot-notation\n    const changesLoading = changes?.['loading'];\n    if (changesLoading?.currentValue !== changesLoading?.previousValue) {\n      hasChanges = true;\n      this.changeControl();\n    }\n\n    if (hasChanges) {\n      this.stateChanges.next();\n    }\n  }\n\n  onHandleSearch(event: Event) {\n    try {\n      const { value } = event.target as HTMLInputElement;\n      const handled = sanitizeString(value);\n      this.searchHandle.next(handled || '');\n    } catch (e) {\n      // not to do\n    }\n  }\n}\n","<div\n  class=\"mecx-select-trigger\"\n  [class.open]=\"isOpen\"\n  (click)=\"toggleDropdown()\"\n  role=\"combobox\"\n  [attr.aria-expanded]=\"isOpen\"\n  #trigger\n>\n  <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n    <span>{{ labelSelected || placeholder }}</span>\n  </div>\n\n  @if (!loading) {\n    <div class=\"mecx-select-icon\" [innerHTML]=\"iconArrowDown\"></div>\n  }\n</div>\n\n<ng-template #overlayTemplate>\n  <div class=\"mecx-select-body-overlay\">\n    @if (showSearch) {\n      <div class=\"mecx-select-search\">\n        <div class=\"mecx-select-search-icon\" [innerHTML]=\"imgSearch\"></div>\n        <input\n          (input)=\"onHandleSearch($event)\"\n          type=\"text\"\n          [id]=\"id + '-search'\"\n          autocomplete=\"off\"\n          maxlength=\"50\"\n          [placeholder]=\"searchPlaceholder\"\n          [(ngModel)]=\"searchData\"\n        />\n      </div>\n    }\n    <div\n      class=\"mecx-select-overlay\"\n      #overlay\n      [@animation]=\"isOpen ? 'open' : 'closed'\"\n      (@animation.done)=\"onAnimationEnd($event)\"\n    >\n      <ng-content />\n    </div>\n    @if (showSearch && showSearchNoData) {\n      <div class=\"mecx-select-search-no-data\">\n        <div class=\"mecx-select-search-no-data-icon\" [innerHTML]=\"imgSearchNoData\"></div>\n        {{ searchDictionary | async }}\n      </div>\n    }\n    @if (loading) {\n      <div class=\"mecx-select-search-loading\">\n        {{ loadingDictionary | async }}\n      </div>\n    }\n  </div>\n</ng-template>\n"]}
|
|
444
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/select/select.component.ts","../../../../../../projects/monkey-style-guide-v2/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/** ************************\n * Copyright Monkey Exchange. All Rights Reserved\n * This style guide was developed by Monkey Exchange Team\n * MIT Licence\n ************************* */\n\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { ConnectedPosition, Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport { debounceTime, Subject } from 'rxjs';\nimport { normalizeStringToSearch, sanitizeString, UtilIconComponent } from '../../../utils';\nimport { IdGenerator } from '../../../utils/id-generator';\nimport { MonkeyDictionaryService } from '../../services/dictionary.service';\nimport { MonkeyFormFieldControl } from '../form-field/form-field-control';\nimport { MonkeyFormFieldComponent } from '../form-field/form-field.component';\nimport { MonkeyOptionComponent } from '../option/option.component';\n\n@Component({\n  selector: 'monkey-select',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, UtilIconComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    // eslint-disable-next-line no-use-before-define\n    { provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent }\n  ],\n  animations: [\n    trigger('animation', [\n      transition(':enter', [\n        style({\n          opacity: 0,\n          transform: 'scaleY(.9)'\n        }),\n        animate(\n          '100ms ease-in-out',\n          style({\n            opacity: 1,\n            transform: 'scaleY(1)'\n          })\n        )\n      ]),\n      state(\n        'closed',\n        style({\n          transform: 'scaleY(.9)',\n          opacity: 0\n        })\n      ),\n      transition('closed <=> open', animate('200ms ease-in-out'))\n    ])\n  ],\n  host: {\n    'data-testid': 'monkey-select',\n    class: 'mecx-select',\n    '[class.mecx-select-disabled]': '_disabled',\n    '[class.mecx-select-focused]': 'focused',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n    '(focus)': '_onFocus()',\n    '(blur)': '_onBlur()'\n  }\n})\nexport class MonkeySelectComponent\n  implements\n    MonkeyFormFieldControl,\n    ControlValueAccessor,\n    AfterContentInit,\n    OnInit,\n    OnDestroy,\n    OnChanges\n{\n  @ViewChild('overlayTemplate') overlayTemplate!: TemplateRef<any>;\n\n  @ViewChild('overlay') overlayEl!: ElementRef;\n\n  @ViewChild('trigger') trigger!: ElementRef;\n\n  @ContentChildren(MonkeyOptionComponent) options!: QueryList<MonkeyOptionComponent>;\n\n  @Input() tabIndex = 0;\n\n  @Output() onChange = new EventEmitter();\n\n  @Output() onSearch = new EventEmitter();\n\n  @Input({ required: true }) placeholder = '';\n\n  @Input({ transform: booleanAttribute })\n  loading = false;\n\n  @Input({ transform: booleanAttribute })\n  showSearch = true;\n\n  @Input()\n  searchPlaceholder = '';\n\n  @Input({ transform: booleanAttribute })\n  callbackSearch = false;\n\n  @Input({ transform: booleanAttribute })\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled;\n    }\n    return this._disabled;\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n\n  @Input({ transform: booleanAttribute })\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n\n  private _required: boolean | undefined;\n\n  @Input()\n  set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n      this._onChange(value);\n    }\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  _value = null;\n\n  labelSelected = '';\n\n  private overlayRef: OverlayRef | null = null;\n\n  private _destroyRef = inject(DestroyRef);\n\n  private readonly idGenerator = inject(IdGenerator);\n\n  ngControl: NgControl | null = inject(NgControl, { self: true, optional: true })!;\n\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  readonly currency: boolean = false;\n\n  focused: boolean = false;\n\n  _disabled: boolean = false;\n\n  readonly id: string = this.idGenerator.getId('monkey-select-');\n\n  readonly percent: boolean = false;\n\n  readonly stateChanges = new Subject<void>();\n\n  readonly type: string = '';\n\n  readonly searchHandle = new EventEmitter<string>();\n\n  readonly searchDictionary = inject(MonkeyDictionaryService).get('NO-DATA');\n\n  readonly loadingDictionary = inject(MonkeyDictionaryService).get('LOADING');\n\n  showSearchNoData = false;\n\n  isOpen = false;\n\n  searchData = '';\n\n  constructor(\n    private overlay: Overlay,\n    private changeDetectorRef: ChangeDetectorRef,\n    private viewContainerRef: ViewContainerRef,\n    @Optional() private formField: MonkeyFormFieldComponent\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  private changeControl() {\n    if (this.formField?.control) {\n      this.formField.control.loading = this.loading;\n    }\n  }\n\n  private changeSelected() {\n    setTimeout(() => {\n      if (this.options) {\n        this.options.forEach((opt) => {\n          opt.selected = opt.value === this.value;\n        });\n        this.updateSelectedLabel();\n      }\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private initializeOptions() {\n    this.options.forEach((option) => {\n      if (!option.action) {\n        option.action = this.selectOption.bind(this, option);\n      }\n    });\n  }\n\n  private openDropdown(): void {\n    if (this.options?.length) {\n      this.formField.control.disableToBeDirty = true;\n      this.isOpen = true;\n      this.createOverlay();\n    }\n  }\n\n  private closeDropdown() {\n    this.changeDetectorRef.markForCheck();\n    this.isOpen = false;\n    this.focused = false;\n    this.formField.control.disableToBeDirty = false;\n    if (!this.callbackSearch) {\n      this.searchData = '';\n    }\n  }\n\n  private closeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n  }\n\n  private initializeWithOverlay() {\n    if (this.showSearch) {\n      const element = this.overlayRef?.overlayElement.querySelector(\n        `#${this.id}-search`\n      ) as HTMLElement;\n\n      this.options.forEach((opt) => {\n        const element = this.overlayRef?.overlayElement.querySelector(\n          `#${opt.id}`\n        ) as HTMLElement | null;\n        if (!element) return;\n        element.style.display = '';\n      });\n\n      setTimeout(() => {\n        element?.focus();\n      }, 0);\n      this.showSearchNoData = false;\n    }\n\n    setTimeout(() => {\n      const selected = this.options.find((opt) => {\n        return opt.selected;\n      });\n\n      if (selected) {\n        const element = this.overlayRef?.overlayElement.querySelector(\n          `#${selected.id}`\n        ) as HTMLElement;\n        element?.scrollIntoView({ behavior: 'instant', block: 'center' });\n      }\n    }, 0);\n  }\n\n  private createOverlay(): void {\n    if (this.overlayRef) {\n      return;\n    }\n\n    const offset = 4;\n    const positions: ConnectedPosition[] = [\n      {\n        originX: 'start',\n        originY: 'bottom',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetY: offset\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n        offsetY: -offset\n      }\n    ];\n\n    let anchor = this.trigger;\n    let width = anchor.nativeElement.offsetWidth;\n\n    if (this.formField?.elementRef) {\n      const el = this.formField?.elementRef.nativeElement.querySelector('.mecx-form-field-body');\n      anchor = el;\n      width = el.offsetWidth;\n    }\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(anchor)\n      .withPositions(positions)\n      .withPush(true);\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n      width,\n      hasBackdrop: true,\n      backdropClass: 'no-class'\n    });\n\n    const portal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);\n\n    this.overlayRef.attach(portal);\n\n    this.overlayRef\n      .backdropClick()\n      .pipe(takeUntilDestroyed(this._destroyRef))\n      .subscribe(() => {\n        return this.closeDropdown();\n      });\n\n    this.initializeWithOverlay();\n  }\n\n  private updateSelectedLabel(): void {\n    const selectedOption = this.options.find((opt) => {\n      return opt.value === this.value;\n    });\n    this.labelSelected = selectedOption ? selectedOption.displayContent : '';\n  }\n\n  private executeSearch(search: string): void {\n    let found = false;\n    this.options.forEach((opt) => {\n      const element = this.overlayRef?.overlayElement.querySelector(\n        `#${opt.id}`\n      ) as HTMLElement | null;\n\n      if (!element) return;\n\n      const isMatch = normalizeStringToSearch(opt.displayContent).includes(\n        normalizeStringToSearch(search)\n      );\n      if (isMatch) {\n        found = true;\n      }\n      element.style.display = isMatch ? '' : 'none';\n    });\n\n    this.repositionScroll();\n    this.showSearchNoData = !found;\n  }\n\n  private repositionScroll() {\n    const overlayElement = this.overlayRef?.overlayElement.querySelector(\n      '.mecx-select-overlay'\n    ) as HTMLElement;\n\n    if (overlayElement) {\n      overlayElement.scrollTop = 0;\n    }\n  }\n\n  ngOnInit() {\n    this.searchHandle\n      .pipe(debounceTime(200), takeUntilDestroyed(this._destroyRef))\n      .subscribe((search: string) => {\n        if (this.callbackSearch) {\n          this.onSearch.next(search);\n          this.repositionScroll();\n        } else {\n          this.executeSearch(search);\n        }\n      });\n  }\n\n  ngAfterContentInit() {\n    this.initializeOptions();\n    this.options.changes.pipe(takeUntilDestroyed(this._destroyRef)).subscribe((resp) => {\n      this.updateSelectedLabel();\n      this.initializeOptions();\n      this.changeSelected();\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n  }\n\n  toggleDropdown(): void {\n    if (!this.disabled) {\n      if (this.isOpen) {\n        this.closeDropdown();\n        this._onTouched();\n      } else {\n        this.openDropdown();\n      }\n    }\n  }\n\n  onAnimationEnd = (event: any) => {\n    if (event.toState === 'closed') {\n      this.closeOverlay();\n    }\n  };\n\n  selectOption(option: MonkeyOptionComponent): void {\n    if (!option.disabled && !this.disabled) {\n      this.value = option.value;\n      this.updateSelectedLabel();\n      this.closeDropdown();\n      this._onChange(this.value);\n      this.onChange.emit(this.value);\n\n      this.options.forEach((opt) => {\n        opt.selected = opt.value === this.value;\n      });\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.changeSelected();\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if (this.disabled) return;\n\n    this.openDropdown();\n    this._elementRef.nativeElement.focus();\n  }\n\n  _onFocus() {\n    if (!this.disabled) {\n      this.focused = true;\n      this._onTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  _onBlur() {\n    this.focused = false;\n    this.stateChanges.next();\n  }\n\n  _onChange: any = () => {};\n\n  _onTouched: any = () => {};\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let hasChanges = false;\n    // eslint-disable-next-line dot-notation\n    const changesLoading = changes?.['loading'];\n    if (changesLoading?.currentValue !== changesLoading?.previousValue) {\n      hasChanges = true;\n      this.changeControl();\n    }\n\n    if (hasChanges) {\n      this.stateChanges.next();\n    }\n  }\n\n  onHandleSearch(event: Event) {\n    try {\n      const { value } = event.target as HTMLInputElement;\n      const handled = sanitizeString(value);\n      this.searchHandle.next(handled || '');\n    } catch (e) {\n      // not to do\n    }\n  }\n}\n","<div\n  class=\"mecx-select-trigger\"\n  [class.open]=\"isOpen\"\n  (click)=\"toggleDropdown()\"\n  role=\"combobox\"\n  [attr.aria-expanded]=\"isOpen\"\n  #trigger\n>\n  <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n    <span>{{ labelSelected || placeholder }}</span>\n  </div>\n\n  @if (!loading) {\n    <util-icon class=\"mecx-select-icon\" name=\"arrowDown\" />\n  }\n</div>\n\n<ng-template #overlayTemplate>\n  <div class=\"mecx-select-body-overlay\">\n    @if (showSearch) {\n      <div class=\"mecx-select-search\">\n        <util-icon class=\"mecx-select-search-icon\" name=\"search\" />\n        <input\n          (input)=\"onHandleSearch($event)\"\n          type=\"text\"\n          [id]=\"id + '-search'\"\n          autocomplete=\"off\"\n          maxlength=\"50\"\n          [placeholder]=\"searchPlaceholder\"\n          [(ngModel)]=\"searchData\"\n        />\n      </div>\n    }\n    <div\n      class=\"mecx-select-overlay\"\n      #overlay\n      [@animation]=\"isOpen ? 'open' : 'closed'\"\n      (@animation.done)=\"onAnimationEnd($event)\"\n    >\n      <ng-content />\n    </div>\n    @if (showSearch && showSearchNoData) {\n      <div class=\"mecx-select-search-no-data\">\n        <util-icon class=\"mecx-select-search-no-data-icon\" name=\"searchFail\" />\n        {{ searchDictionary | async }}\n      </div>\n    }\n    @if (loading) {\n      <div class=\"mecx-select-search-loading\">\n        {{ loadingDictionary | async }}\n      </div>\n    }\n  </div>\n</ng-template>\n"]}
|