@sapphire-ion/framework 0.30.17 → 1.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/esm2022/lib/classes/inputs/table-field.mjs +8 -2
- package/esm2022/lib/components/default/default-list/list.mjs +1 -1
- package/esm2022/lib/components/default/default-table/default-table.component.mjs +18 -6
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +12 -11
- package/esm2022/lib/components/default/default-view/default-view.component.mjs +10 -10
- package/esm2022/lib/components/default/default.module.mjs +12 -4
- package/esm2022/lib/components/filter/filter.component.mjs +2 -2
- package/esm2022/lib/components/inputs/custom-input.mjs +57 -49
- package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +31 -34
- package/esm2022/lib/components/inputs/input-bool/input-bool.configuration.mjs +4 -4
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +33 -46
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.mjs +2 -2
- package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +86 -97
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +158 -190
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.configuration.mjs +6 -1
- package/esm2022/lib/components/inputs/input-file/download-button/download-button.component.mjs +12 -10
- package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +60 -98
- package/esm2022/lib/components/inputs/input-file/input-file.configuration.mjs +18 -5
- package/esm2022/lib/components/inputs/input-provider-factory.mjs +4 -7
- package/esm2022/lib/components/inputs/input-select/directives/sion-label-template.directive.mjs +16 -0
- package/esm2022/lib/components/inputs/input-select/directives/sion-option-template.directive.mjs +18 -0
- package/esm2022/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.mjs +16 -0
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +233 -264
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +45 -29
- package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +27 -42
- package/esm2022/lib/components/inputs/input-string/input-string.configuration.mjs +1 -1
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +26 -38
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.configuration.mjs +7 -0
- package/esm2022/lib/components/inputs/inputs.module.mjs +72 -81
- package/esm2022/lib/components/login/login-admin/login-admin.component.mjs +1 -1
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +132 -0
- package/esm2022/lib/components/popover/sion-popover.module.mjs +23 -0
- package/esm2022/lib/components/popover/sion-popover.service.mjs +33 -0
- package/esm2022/lib/components/stepper/step/step.component.mjs +3 -3
- package/esm2022/lib/components/stepper/stepper.component.mjs +13 -13
- package/esm2022/lib/guards/error.interceptor.mjs +2 -2
- package/esm2022/lib/index.mjs +10 -6
- package/esm2022/lib/services/utils.service.mjs +3 -3
- package/esm2022/lib/services/web/api-url-provider.service.mjs +2 -2
- package/esm2022/lib/services/web/http.ativo.service.mjs +2 -2
- package/fesm2022/sapphire-ion-framework.mjs +1200 -1737
- package/fesm2022/sapphire-ion-framework.mjs.map +1 -1
- package/lib/classes/inputs/table-field.d.ts +1 -0
- package/lib/components/default/default.module.d.ts +3 -1
- package/lib/components/inputs/custom-input.d.ts +26 -22
- package/lib/components/inputs/input-bool/input-bool.component.d.ts +13 -16
- package/lib/components/inputs/input-bool/input-bool.configuration.d.ts +2 -2
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.d.ts +13 -18
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.d.ts +1 -1
- package/lib/components/inputs/input-date/input-date.component.d.ts +21 -24
- package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +21 -36
- package/lib/components/inputs/input-decimal/input-decimal.configuration.d.ts +3 -0
- package/lib/components/inputs/input-file/download-button/download-button.component.d.ts +2 -1
- package/lib/components/inputs/input-file/input-file.component.d.ts +20 -32
- package/lib/components/inputs/input-file/input-file.configuration.d.ts +2 -5
- package/lib/components/inputs/input-provider-factory.d.ts +1 -1
- package/lib/components/inputs/input-select/directives/sion-label-template.directive.d.ts +12 -0
- package/lib/components/inputs/input-select/directives/sion-option-template.directive.d.ts +11 -0
- package/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.d.ts +12 -0
- package/lib/components/inputs/input-select/input-select.component.d.ts +60 -58
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +11 -9
- package/lib/components/inputs/input-string/input-string.component.d.ts +11 -16
- package/lib/components/inputs/input-textarea/input-textarea.component.d.ts +11 -15
- package/lib/components/inputs/input-textarea/input-textarea.configuration.d.ts +4 -0
- package/lib/components/inputs/inputs.module.d.ts +18 -21
- package/lib/components/popover/sion-popover/sion-popover.component.d.ts +30 -0
- package/lib/components/popover/sion-popover.module.d.ts +8 -0
- package/lib/components/popover/sion-popover.service.d.ts +12 -0
- package/lib/components/stepper/step/step.component.d.ts +1 -1
- package/lib/components/stepper/stepper.component.d.ts +3 -6
- package/lib/index.d.ts +5 -4
- package/lib/services/utils.service.d.ts +1 -1
- package/package.json +2 -1
- package/themes/compiled-styles.scss +157 -4
- package/themes/components/default/default-table/default-table.component.scss +0 -13
- package/themes/components/default/default-table/th-filter/th-filter.component.scss +0 -3
- package/themes/components/inputs/input-bool/input-bool.component.scss +2 -13
- package/themes/components/inputs/input-date/input-date.component.scss +33 -34
- package/themes/components/inputs/input-decimal/input-decimal.component.scss +8 -42
- package/themes/components/inputs/input-file/input-file.component.scss +16 -2
- package/themes/components/inputs/input-select/input-select.component.scss +47 -24
- package/themes/components/inputs/input-textarea/input-textarea.component.scss +7 -0
- package/themes/components/inputs/inputs.scss +103 -49
- package/themes/components/inputs_old/inputs.scss +67 -0
- package/themes/components/popover/sion-popover/sion-popover.component.scss +48 -0
- package/themes/styles/components.scss +34 -0
- package/themes/styles/ionic/ion-datetime.scss +3 -2
- package/esm2022/lib/components/inputs/custom-signal-input.mjs +0 -74
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +0 -487
- package/esm2022/lib/components/inputs/input-loading/input-loading.component.mjs +0 -16
- package/esm2022/lib/components/inputs/input-select/ISelect.mjs +0 -11
- package/esm2022/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.mjs +0 -42
- package/esm2022/lib/components/inputs/input-select/input-select-option/input-select-option.component.mjs +0 -46
- package/esm2022/lib/components/inputs/input-select/input-select-template.directive.mjs +0 -16
- package/lib/components/inputs/custom-signal-input.d.ts +0 -38
- package/lib/components/inputs/input-color/input-color.component.d.ts +0 -80
- package/lib/components/inputs/input-loading/input-loading.component.d.ts +0 -7
- package/lib/components/inputs/input-select/ISelect.d.ts +0 -21
- package/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.d.ts +0 -18
- package/lib/components/inputs/input-select/input-select-option/input-select-option.component.d.ts +0 -24
- package/lib/components/inputs/input-select/input-select-template.directive.d.ts +0 -8
- package/themes/components/inputs/input-loading/input-loading.component.scss +0 -0
- package/themes/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.scss +0 -0
- package/themes/components/inputs/input-select/input-select-option/input-select-option.component.scss +0 -0
- /package/themes/components/{inputs → inputs_old}/input-color/input-color.component.scss +0 -0
|
@@ -1,322 +1,291 @@
|
|
|
1
|
-
import { Component,
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
|
|
1
|
+
import { Component, computed, ContentChild, effect, ElementRef, HostListener, inject, Injector, input, model, signal, TemplateRef, ViewChild, } from '@angular/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { IonModal } from '@ionic/angular';
|
|
4
|
+
import { debounceTime, distinctUntilChanged, Subject, takeUntil } from 'rxjs';
|
|
6
5
|
import { BindLabelFactory, BindValueFactory, InputSelectConfiguration } from './input.select.configuration';
|
|
7
|
-
import {
|
|
8
|
-
import { InputSelectOptionComponent } from './input-select-option/input-select-option.component';
|
|
9
|
-
import { ISelect } from './ISelect';
|
|
6
|
+
import { SIonPopoverComponent } from '../../popover/sion-popover/sion-popover.component';
|
|
10
7
|
import { InputProviderFactory } from '../input-provider-factory';
|
|
11
|
-
import {
|
|
8
|
+
import { CustomInput } from '../custom-input';
|
|
12
9
|
import { Search } from '../../../services/utils.service';
|
|
10
|
+
import { SIonPlaceholderTemplateDirective } from './directives/sion-placeholder-template.directive';
|
|
11
|
+
import { SIonOptionTemplateDirective } from './directives/sion-option-template.directive';
|
|
12
|
+
import { SIonLabelTemplateDirective } from './directives/sion-label-template.directive';
|
|
13
|
+
import { HttpServiceAtivo } from '../../../services/web/http.ativo.service';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@angular
|
|
15
|
+
import * as i1 from "@ionic/angular";
|
|
15
16
|
import * as i2 from "@angular/common";
|
|
16
|
-
import * as i3 from "@
|
|
17
|
-
import * as i4 from "
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
import * as i3 from "@angular/forms";
|
|
18
|
+
import * as i4 from "../../popover/sion-popover/sion-popover.component";
|
|
19
|
+
export class NewInputSelectComponent extends CustomInput {
|
|
20
|
+
SetCurrentItemLabel() {
|
|
21
|
+
if (this.configuration().multiple) {
|
|
22
|
+
this.currentLabel = this.lstOptions.filter(p => p.selected).map(p => p.label).join(', ');
|
|
23
|
+
this.currentItems = this.lstOptions.filter(p => p.selected);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
this.currentLabel = this.lstOptions.find(p => p.selected)?.label;
|
|
27
|
+
this.currentItems = this.lstOptions.find(p => p.selected);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
UpdateLstOptions(search) {
|
|
31
|
+
// Update the search
|
|
32
|
+
if (search) {
|
|
33
|
+
this.lstOptions = Search(this.lstOptionsItemValue(), search, (item) => item.label);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.lstOptions = this.lstOptionsItemValue();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
UpdateSelected() {
|
|
40
|
+
if (this.configuration().multiple) {
|
|
41
|
+
const arr = this.value() || [];
|
|
42
|
+
for (const item of this.lstOptions) {
|
|
43
|
+
item.selected = arr.find(p => p == item.value) != undefined;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.lstOptions.forEach((item) => { item.selected = this.value() == item.value; });
|
|
48
|
+
}
|
|
49
|
+
this.SetCurrentItemLabel();
|
|
50
|
+
}
|
|
51
|
+
focus(event) { }
|
|
52
|
+
constructor() {
|
|
22
53
|
super();
|
|
23
|
-
this.controlContainer = controlContainer;
|
|
24
|
-
this.elementRef = elementRef;
|
|
25
54
|
/** Items disponíveis no select */
|
|
26
55
|
this.items = model([]);
|
|
27
56
|
/** Configuração do select */
|
|
28
|
-
this.configuration =
|
|
57
|
+
this.configuration = input(new InputSelectConfiguration());
|
|
29
58
|
this.loadingFromLoader = false;
|
|
30
|
-
this.
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
return
|
|
59
|
+
this.currentLabel = undefined;
|
|
60
|
+
this.currentItems = undefined;
|
|
61
|
+
this.lstOptionsItemValue = computed(() => {
|
|
62
|
+
const bindLabel = BindLabelFactory(this.configuration());
|
|
63
|
+
const bindValue = BindValueFactory(this.configuration());
|
|
64
|
+
return this.items().filter(p => this.somenteAtivos() && this.isServiceAtivo() ? p.ativo : true).map(p => {
|
|
65
|
+
const item = new ItemValue();
|
|
66
|
+
item.label = bindLabel(p);
|
|
67
|
+
item.value = bindValue(p);
|
|
68
|
+
item.item = p;
|
|
69
|
+
item.selected = this.value() == item.value;
|
|
70
|
+
item.disabled = p.disabled || false || (this.isServiceAtivo && p.ativo == false);
|
|
71
|
+
return item;
|
|
72
|
+
});
|
|
36
73
|
});
|
|
37
|
-
this.
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
this.
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
effect(() => { this.Update(); }, { allowSignalWrites: true });
|
|
52
|
-
this.updateInterval = interval(1000);
|
|
53
|
-
this.updateSubscription = this.updateInterval.subscribe(() => {
|
|
54
|
-
if (this.lastItemsQtd != this.items().length) {
|
|
55
|
-
this.lastItemsQtd = this.items().length;
|
|
56
|
-
this.Update();
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
ngOnDestroy() {
|
|
61
|
-
this.updateSubscription.unsubscribe();
|
|
74
|
+
this.lstOptions = [];
|
|
75
|
+
this.isServiceAtivo = computed(() => { return this.configuration().loadFromService instanceof HttpServiceAtivo; });
|
|
76
|
+
this.somenteAtivos = signal(true);
|
|
77
|
+
this.selectedIndex = undefined;
|
|
78
|
+
this.searchBarControl = new FormControl('');
|
|
79
|
+
this.searchValue = signal("");
|
|
80
|
+
this.searchBarSubscription = null;
|
|
81
|
+
this.destroy$ = new Subject();
|
|
82
|
+
this.injector = inject(Injector);
|
|
83
|
+
this.floatingVisible = false;
|
|
84
|
+
effect(() => {
|
|
85
|
+
this.UpdateLstOptions(this.searchValue());
|
|
86
|
+
this.UpdateSelected();
|
|
87
|
+
}, { allowSignalWrites: true });
|
|
62
88
|
}
|
|
63
|
-
ngOnInit() {
|
|
64
|
-
super.ngOnInit();
|
|
89
|
+
async ngOnInit() {
|
|
90
|
+
await super.ngOnInit();
|
|
65
91
|
this.configuration().loader.AddComponent(this);
|
|
66
92
|
this.configuration().loader.Refresh(this.items());
|
|
67
93
|
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
this.
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
94
|
+
HandleKeyboardEvent(event) {
|
|
95
|
+
// [ Popover ]
|
|
96
|
+
if (this.selectContent?.nativeElement?.contains(event.target)) {
|
|
97
|
+
if (event.key == "Tab") {
|
|
98
|
+
event.preventDefault();
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
else if (event.key == "Escape") {
|
|
102
|
+
event.preventDefault();
|
|
103
|
+
event.stopPropagation();
|
|
104
|
+
this.Dismiss();
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
81
107
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
if (
|
|
85
|
-
|
|
86
|
-
this.
|
|
108
|
+
// [ inputContainer ]
|
|
109
|
+
if (this.inputContainer.nativeElement.contains(event.target)) {
|
|
110
|
+
if (["ArrowDown", "ArrowUp"].includes(event.key)) {
|
|
111
|
+
event.preventDefault();
|
|
112
|
+
this.Present(event);
|
|
113
|
+
return;
|
|
87
114
|
}
|
|
88
|
-
return;
|
|
89
115
|
}
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
116
|
+
// [ inputSelectSearchBar ]
|
|
117
|
+
if (this.inputSearchBar.nativeElement == event.target) {
|
|
118
|
+
if (event.key == "Enter") {
|
|
119
|
+
event.preventDefault();
|
|
120
|
+
// If the select is not ativo ignore the selected item
|
|
121
|
+
const item = this.lstOptions[this.selectedIndex];
|
|
122
|
+
if (this.isServiceAtivo() && !item.item.ativo) {
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
this.Select(item);
|
|
94
126
|
return;
|
|
95
127
|
}
|
|
96
|
-
else if (
|
|
97
|
-
this.
|
|
98
|
-
|
|
128
|
+
else if (event.key == "ArrowDown") {
|
|
129
|
+
if (this.selectedIndex == undefined) {
|
|
130
|
+
this.selectedIndex = 0;
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
event.preventDefault();
|
|
134
|
+
this.selectedIndex = (this.selectedIndex < this.lstOptions.length - 1 ? this.selectedIndex + 1 : this.selectedIndex);
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
else if (event.key == "ArrowUp") {
|
|
138
|
+
if (this.selectedIndex == undefined) {
|
|
139
|
+
this.selectedIndex = 0;
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
event.preventDefault();
|
|
143
|
+
this.selectedIndex = (this.selectedIndex > 0 ? this.selectedIndex - 1 : this.selectedIndex);
|
|
99
144
|
return;
|
|
100
145
|
}
|
|
101
|
-
this.CurrentLabel = "";
|
|
102
|
-
this.CurrentlyNoValue = false;
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
UpdateSelected() {
|
|
107
|
-
if (this.lstOptions && this.lstOptions.length) {
|
|
108
|
-
this.lstOptions.forEach(p => p.isSelected = false);
|
|
109
|
-
this.lstOptions.filter(p => Array.isArray(this._model) ? this._model.includes(p.value) : this._model == p.value).forEach(p => p.isSelected = true);
|
|
110
146
|
}
|
|
111
147
|
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
148
|
+
ngAfterViewInit() {
|
|
149
|
+
const observable = this.searchBarControl.valueChanges.pipe(takeUntil(this.destroy$), distinctUntilChanged(), debounceTime(200));
|
|
150
|
+
this.searchBarSubscription = observable.subscribe((value) => {
|
|
151
|
+
this.selectedIndex = undefined;
|
|
152
|
+
this.searchValue.set(value);
|
|
153
|
+
});
|
|
117
154
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
if (this._model && this.items()) {
|
|
124
|
-
return this.items().filter(p => Array.isArray(this._model) ? this._model.includes(this.bindValue()(p)) : this._model == this.bindValue()(p));
|
|
155
|
+
ClearSearchBar() {
|
|
156
|
+
this.destroy$.next();
|
|
157
|
+
this.destroy$.complete();
|
|
158
|
+
if (this.searchBarSubscription) {
|
|
159
|
+
this.searchBarSubscription.unsubscribe();
|
|
125
160
|
}
|
|
126
|
-
return [];
|
|
127
161
|
}
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
this.SetModel(value);
|
|
131
|
-
this.propagateChange(this._model);
|
|
162
|
+
ngOnDestroy() {
|
|
163
|
+
this.ClearSearchBar();
|
|
132
164
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
}
|
|
138
|
-
this._model = value;
|
|
139
|
-
this.Update();
|
|
140
|
-
return;
|
|
165
|
+
writeValue(obj) {
|
|
166
|
+
this.value.set(obj);
|
|
167
|
+
this.runValidation();
|
|
168
|
+
this.UpdateSelected();
|
|
141
169
|
}
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
170
|
+
SetValue(obj) {
|
|
171
|
+
this.value.set(obj);
|
|
172
|
+
this.runValidation();
|
|
173
|
+
this.UpdateSelected();
|
|
174
|
+
this.propagateChange(this.value());
|
|
175
|
+
if (!this.configuration().multiple) {
|
|
176
|
+
this.Dismiss();
|
|
147
177
|
}
|
|
148
178
|
}
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
179
|
+
Clear(event) {
|
|
180
|
+
event.stopPropagation();
|
|
181
|
+
if (this.configuration().multiple) {
|
|
182
|
+
this.SetValue([]);
|
|
152
183
|
}
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
UpdateUseDefaultModelOptions() {
|
|
156
|
-
this.useDefaultModelOptions.set(this.GetUseDefaultModelOptions());
|
|
157
|
-
if (this.useDefaultModelOptions()) {
|
|
158
|
-
if (this.items().length != this.lstOptions.length) {
|
|
159
|
-
this.items.set(this.lstOptions.map(p => p.model()));
|
|
160
|
-
}
|
|
184
|
+
else {
|
|
185
|
+
this.SetValue(undefined);
|
|
161
186
|
}
|
|
162
187
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
var value = this.bindValue()(item);
|
|
172
|
-
if (this._model) {
|
|
173
|
-
if (this._model.includes(value)) {
|
|
174
|
-
this.model = [...this._model.filter(p => p != value)];
|
|
188
|
+
Select(itemValue) {
|
|
189
|
+
const item = itemValue.value;
|
|
190
|
+
if (this.configuration().multiple) {
|
|
191
|
+
const currentValue = this.value();
|
|
192
|
+
if (Array.isArray(currentValue)) {
|
|
193
|
+
const index = currentValue.findIndex(p => p == item);
|
|
194
|
+
if (index > -1) {
|
|
195
|
+
currentValue.splice(index, 1);
|
|
175
196
|
}
|
|
176
197
|
else {
|
|
177
|
-
|
|
198
|
+
currentValue.push(item);
|
|
178
199
|
}
|
|
179
|
-
|
|
200
|
+
this.SetValue([...currentValue]);
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
this.SetValue([item]);
|
|
180
204
|
}
|
|
181
|
-
this.model = [value];
|
|
182
|
-
return;
|
|
183
205
|
}
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
const Popover = this.ionPopoverComponent;
|
|
188
|
-
const PopoverElement = this.ionPopoverElement.nativeElement;
|
|
189
|
-
const PopoverContent = Array.from(Array.from(PopoverElement.shadowRoot.children).find(p => p.classList.contains("popover-wrapper")).children).find(p => p.classList.contains("popover-content"));
|
|
190
|
-
PopoverContent.style.width = this.inputContainer.nativeElement.offsetWidth + 'px';
|
|
191
|
-
await Popover.present($event);
|
|
192
|
-
this.searchbarComponent.setFocus();
|
|
193
|
-
if (this.cdkVirtualScrollViewport) {
|
|
194
|
-
this.cdkVirtualScrollViewport.nativeElement.scroll({ top: 1, behavior: 'smooth' });
|
|
206
|
+
else {
|
|
207
|
+
this.SetValue(item);
|
|
208
|
+
this.Dismiss();
|
|
195
209
|
}
|
|
196
|
-
this.focusedModel = null;
|
|
197
|
-
this.UpdateUseDefaultModelOptions();
|
|
198
210
|
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
211
|
+
async Present(event) {
|
|
212
|
+
if (isPortrait()) {
|
|
213
|
+
// Modal
|
|
214
|
+
await this.modal.present();
|
|
215
|
+
this.inputSearchBar.nativeElement.focus();
|
|
202
216
|
return;
|
|
203
217
|
}
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
this.itemComponent.nativeElement.click();
|
|
208
|
-
event.preventDefault();
|
|
209
|
-
}
|
|
210
|
-
else if (event.target == searchbarComponent) {
|
|
211
|
-
this.UpdateUseDefaultModelOptions();
|
|
212
|
-
const items = this.lstSearchItens();
|
|
213
|
-
if (event.key == "ArrowDown") {
|
|
214
|
-
if (this.focusedModel) {
|
|
215
|
-
const index = items.indexOf(this.focusedModel);
|
|
216
|
-
if (items[index + 1]) {
|
|
217
|
-
this.SetFocusedElement(items[index + 1]);
|
|
218
|
-
}
|
|
219
|
-
else {
|
|
220
|
-
this.SetFocusedElement(items[0]);
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
else {
|
|
224
|
-
if (items[0]) {
|
|
225
|
-
this.SetFocusedElement(items[0]);
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
else if (event.key == "ArrowUp") {
|
|
230
|
-
if (this.focusedModel) {
|
|
231
|
-
const index = items.indexOf(this.focusedModel);
|
|
232
|
-
if (items[index - 1]) {
|
|
233
|
-
this.SetFocusedElement(items[index - 1]);
|
|
234
|
-
}
|
|
235
|
-
else {
|
|
236
|
-
this.SetFocusedElement(items[items.length - 1]);
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
else if (event.key == "Enter") {
|
|
241
|
-
var Option;
|
|
242
|
-
if (this.useDefaultModelOptions()) {
|
|
243
|
-
Option = this.lstOptions.find(p => p.model() == this.focusedModel);
|
|
244
|
-
}
|
|
245
|
-
else {
|
|
246
|
-
Option = this.lstInternalOptions.find(p => p.model == this.focusedModel);
|
|
247
|
-
}
|
|
248
|
-
if (!Option.disabled) {
|
|
249
|
-
this.Select(this.focusedModel);
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
}
|
|
218
|
+
// Popover
|
|
219
|
+
await this.popover.present(event);
|
|
220
|
+
this.inputSearchBar.nativeElement.focus();
|
|
253
221
|
}
|
|
254
|
-
|
|
255
|
-
this.
|
|
256
|
-
|
|
257
|
-
if (this.useDefaultModelOptions()) {
|
|
258
|
-
Option = this.lstOptions.find(p => p.model() == focusedModel);
|
|
259
|
-
this.lstOptions.filter(p => p.onFocus).forEach(p => p.onFocus = false);
|
|
260
|
-
Option.onFocus = true;
|
|
222
|
+
async Dismiss() {
|
|
223
|
+
if (this.modal) {
|
|
224
|
+
await this.modal.dismiss();
|
|
261
225
|
}
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
this.lstInternalOptions.filter(p => p.onFocus).forEach(p => p.onFocus = false);
|
|
265
|
-
Option.onFocus = true;
|
|
226
|
+
if (this.popover) {
|
|
227
|
+
await this.popover.dismiss();
|
|
266
228
|
}
|
|
267
|
-
|
|
268
|
-
|
|
229
|
+
this.selectedIndex = undefined;
|
|
230
|
+
if (this.inputSelectLabel?.nativeElement) {
|
|
231
|
+
this.inputSelectLabel.nativeElement.focus();
|
|
269
232
|
}
|
|
270
233
|
}
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
])], queries: [{ propertyName: "lstOptions", predicate: InputSelectOptionComponent }], viewQueries: [{ propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true, read: (ElementRef) }, { propertyName: "inputContainer", first: true, predicate: ["container"], descendants: true, read: ElementRef }, { propertyName: "ionPopoverComponent", first: true, predicate: IonPopover, descendants: true }, { propertyName: "ionPopoverElement", first: true, predicate: IonPopover, descendants: true, read: ElementRef }, { propertyName: "searchbarComponent", first: true, predicate: IonSearchbar, descendants: true }, { propertyName: "inputComponent", first: true, predicate: IonInput, descendants: true }, { propertyName: "itemComponent", first: true, predicate: IonItem, descendants: true, read: ElementRef }, { propertyName: "lstInternalOptions", predicate: InputSelectInternalOptionComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"relative flex overflow-hidden\" #container>\r\n <ion-card \r\n class=\"focus-within:on-focus ion-card-input\" \r\n [disabled]=\"loading || loadingFromLoader || disabled\" \r\n [class.invalid]=\"invalid\"\r\n [class.submitted]=\"submitted\"\r\n [class.disabled]=\"disabled\"\r\n [ngClass]=\"{'!rounded-l-2xl !rounded-r-none !border-r-0': configuration().clearable}\"\r\n >\r\n <ion-card-content>\r\n <ion-item lines=\"none\" class=\"rounded-2xl w-full relative\" (click)=\"PresentPopover($event)\" [ngClass]=\"{'!rounded-l-2xl !rounded-r-none': configuration().clearable }\">\r\n <ion-input fill=\"none\" [readonly]=\"true\" labelPlacement=\"stacked\" [value]=\"CurrentLabel\" [class.no-items-opacity]=\"CurrentlyNoValue\">\r\n <ion-text id=\"label\" [ngClass]=\"{'required': required() }\" slot=\"label\" class=\"!text-dark\"> \r\n {{label}} \r\n </ion-text>\r\n </ion-input>\r\n @if(configuration().multiple){\r\n <div class=\"absolute left-0 bottom-0 h-6 w-full flex z-[90] overflow-x-auto\">\r\n @for(item of GetSelectedItens(); track $index){\r\n <div class=\"h-full flex bg-medium/10 border translucid-border rounded-lg mr-1 animated\">\r\n <div (click)=\"Select(item); $event.stopPropagation()\" class=\"bg-medium/10 cursor-pointer translucid-border min-w-min !border-l-0 !border-y-0 h-full aspect-square flex items-center justify-center rounded-r-lg\"> \r\n <ion-icon color=\"danger\" name=\"close\"></ion-icon>\r\n </div>\r\n <div class=\"h-full px-1 select-none\"> {{bindLabel()(item)}} </div>\r\n </div>\r\n }\r\n </div>\r\n }\r\n </ion-item>\r\n \r\n </ion-card-content>\r\n </ion-card>\r\n <input-loading [loading]=\"loading || loadingFromLoader\"></input-loading>\r\n @if(configuration().clearable){\r\n <div class=\"w-12\">\r\n <ion-button (click)=\"Clear()\" [disabled]=\"loading || disabled || loadingFromLoader\" size=\"small\" fill=\"outline\" color=\"medium\" class=\"rounded-r-2xl h-full w-full\" style=\"--border-width: 1px 1px 2px 1px;\">\r\n <ion-icon name=\"backspace\" slot=\"icon-only\"></ion-icon>\r\n </ion-button>\r\n </div>\r\n }\r\n</div>\r\n\r\n<ion-popover class=\"input-select-popover\" [keepContentsMounted]=\"false\" [dismissOnSelect]=\"!configuration().multiple\" (didDismiss)=\"Search.set('')\">\r\n <ng-template>\r\n <div class=\"size-full flex flex-col bg-primary/10\">\r\n <div class=\"w-full shrink-0\" [hidden]=\"!configuration().searcheable\">\r\n <ion-searchbar [(ngModel)]=\"Search\" (ngModelChange)=\"SearchChanged()\" placeholder=\"Pesquisa...\" class=\"size-full bg-transparent\" [debounce]=\"100\"></ion-searchbar>\r\n </div>\r\n\r\n <div class=\"h-48 w-full overflow-hidden translucid-border !border-x-0 !border-b-0 rounded-t-2xl bg-light\" [ngClass]=\"{'!border-0': !configuration().searcheable}\">\r\n @if(!lstOptions || !lstOptions.length){\r\n <cdk-virtual-scroll-viewport itemSize=\"45\" [minBufferPx]=\"200\" [maxBufferPx]=\"300\" class=\"size-full\">\r\n <input-select-internal-option [model]=\"item\" *cdkVirtualFor=\"let item of lstSearchItens()\" [isSelected]=\"IsSelected(item)\">\r\n <ion-label class=\"truncate\">{{bindLabel()(item)}}</ion-label>\r\n </input-select-internal-option>\r\n </cdk-virtual-scroll-viewport>\r\n }\r\n @else {\r\n <div class=\"size-full overflow-y-auto overflow-x-hidden mask-y\">\r\n <ng-content select=\"input-select-option\"></ng-content>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n</ion-popover>", styles: [".no-items-opacity{--color: color-mix(in srgb, var(--ion-color-dark) 60%, transparent 40%)}.rounded-2xl,.\\!rounded-2xl{--border-radius: 1rem}.rounded-r-2xl,.\\!rounded-r-2xl{--border-radius: 0rem 1rem 1rem 0rem}.rounded-l-2xl,.\\!rounded-l-2xl{--border-radius: 1rem 0rem 0rem 1rem}.rounded-tr-none,.\\!rounded-tr-none{--border-radius: 0rem 0rem 1rem 0rem}\n", ".on-hover{background:color-mix(in srgb,var(--ion-color-light) 97%,transparent 3%)}.on-hover:hover{transition-property:all;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1);background:color-mix(in srgb,var(--ion-color-dark) 15%,transparent 93%)}ion-card.ion-card-input{margin:0;display:flex;height:100%;width:100%;align-items:center;justify-content:center;overflow:hidden;border-radius:1rem;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1);background:color-mix(in srgb,var(--ion-color-light) 97%,transparent 3%);border-bottom-color:var(--ion-color-medium);border-right-color:color-mix(in srgb,var(--ion-color-medium) 30%,transparent 70%);border-top-color:color-mix(in srgb,var(--ion-color-medium) 30%,transparent 70%);border-left-color:color-mix(in srgb,var(--ion-color-medium) 30%,transparent 70%);border-width:1px 1px 2px 1px;min-height:58px;max-height:58px;height:58px}ion-card.ion-card-input:hover{background:color-mix(in srgb,var(--ion-color-dark) 15%,transparent 93%)}ion-card.ion-card-input.submitted.invalid{border-color:color-mix(in srgb,var(--ion-color-danger) 75%,transparent 25%)!important}ion-card.ion-card-input.disabled{background-color:color-mix(in srgb,var(--ion-color-medium) 30%,transparent 70%)!important}ion-card.ion-card-input ion-card-content{width:100%;height:100%;background-color:transparent;padding:0}ion-item{--background: transparent}ion-text#label.required:after{content:\"*\";color:var(--ion-color-danger);vertical-align:text-bottom;font-size:small}ion-text#label:not(.required):after{content:var(--input-opcional-label, \"(Opcional)\");color:var(--ion-color-medium);vertical-align:text-bottom;font-size:small}.on-focus{border-bottom-color:var(--ion-color-primary)}.focus-within\\:on-focus:focus-within{border-bottom-color:var(--ion-color-primary)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonInput, selector: "ion-input", inputs: ["autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearInputIcon", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "spellcheck", "step", "type", "value"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonSearchbar, selector: "ion-searchbar", inputs: ["animated", "autocapitalize", "autocomplete", "autocorrect", "cancelButtonIcon", "cancelButtonText", "clearIcon", "color", "debounce", "disabled", "enterkeyhint", "inputmode", "maxlength", "minlength", "mode", "name", "placeholder", "searchIcon", "showCancelButton", "showClearButton", "spellcheck", "type", "value"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: i3.IonPopover, selector: "ion-popover" }, { kind: "directive", type: i3.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i4.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i4.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i5.InputLoadingComponent, selector: "input-loading", inputs: ["loading"] }, { kind: "component", type: i6.InputSelectInternalOptionComponent, selector: "input-select-internal-option", inputs: ["hidden", "disabled", "label", "model", "isSelected"], outputs: ["labelChange"] }] }); }
|
|
234
|
+
OnDismiss() {
|
|
235
|
+
this.floatingVisible = false;
|
|
236
|
+
this.searchValue.set('');
|
|
237
|
+
this.searchBarControl.setValue('');
|
|
238
|
+
}
|
|
239
|
+
OnPresent() {
|
|
240
|
+
this.floatingVisible = true;
|
|
241
|
+
}
|
|
242
|
+
isArray(obj) {
|
|
243
|
+
return Array.isArray(obj);
|
|
244
|
+
}
|
|
245
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NewInputSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
246
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: NewInputSelectComponent, selector: "input-select", inputs: { items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, configuration: { classPropertyName: "configuration", publicName: "configuration", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { items: "itemsChange" }, host: { listeners: { "document:keydown": "HandleKeyboardEvent($event)" } }, providers: [...InputProviderFactory.GetProviders(NewInputSelectComponent)], queries: [{ propertyName: "labelTemplate", first: true, predicate: SIonLabelTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "optionTemplate", first: true, predicate: SIonOptionTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "placeholderTemplate", first: true, predicate: SIonPlaceholderTemplateDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "inputContainer", first: true, predicate: ["inputContainer"], descendants: true }, { propertyName: "inputSelectLabel", first: true, predicate: ["inputSelectLabel"], descendants: true }, { propertyName: "inputSearchBar", first: true, predicate: ["inputSearchBar"], descendants: true }, { propertyName: "selectContent", first: true, predicate: ["selectContent"], descendants: true }, { propertyName: "popover", first: true, predicate: SIonPopoverComponent, descendants: true }, { propertyName: "modal", first: true, predicate: IonModal, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"focus($event); Present($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.manual-focus]=\"floatingVisible\"\r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"loading() || loadingFromLoader || disabled()\"\r\n [class.loading]=\"loading() || loadingFromLoader\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n \r\n <div class=\"w-full truncate outline-none\" [class.pr-7]=\"!configuration().clearable\" [class.pr-10]=\"configuration().clearable\" #inputSelectLabel tabindex=\"0\">\r\n @if (!configuration().multiple && currentLabel){\r\n @if(labelTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"labelTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: currentLabel, item: currentItems.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label\"> {{currentLabel}} </span>\r\n }\r\n }\r\n @else if (configuration().multiple && isArray(currentItems) && $any(currentItems).length) {\r\n <div class=\"w-full\">\r\n <div class=\"overflow-x-auto flex gap-2 size-full mask-x/2\">\r\n @for (item of currentItems; track $index) {\r\n <div class=\"translucid-border rounded-lg flex items-center justify-center gap-2 pl-2\">\r\n @if(labelTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"labelTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item.label, item: item.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label\"> {{item.label}} </span>\r\n }\r\n \r\n <div class=\"h-full aspect-square flex items-center justify-center cursor-pointer\" (click)=\"Select(item.value); $event.stopPropagation()\">\r\n <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n </div>\r\n <!-- <ion-button class=\"m-0 h-full\" (click)=\"Select(item.value); $event.stopPropagation()\" color=\"medium\" size=\"small\" fill=\"outline\" style=\"--border-radius: .5rem\">\r\n <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n </ion-button> -->\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n @else {\r\n @if(placeholderTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"placeholderTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: this.configuration().placeholder, placeholder: this.configuration().placeholder }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label !text-medium\"> {{this.configuration().placeholder}} </span>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"absolute bottom-1 flex flex-col items-center justify-center size-7\" [class.right-1]=\"!configuration().clearable\" [class.right-8]=\"configuration().clearable\">\r\n <ion-icon class=\"-mb-0.5\" name=\"chevron-up\"></ion-icon>\r\n <ion-icon class=\"-mt-0.5\" name=\"chevron-down\"></ion-icon>\r\n </div>\r\n @if(configuration().clearable){\r\n <ion-button class=\"absolute right-1 bottom-1\" (click)=\"Clear($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n </ion-button>\r\n } \r\n\r\n <div class=\"loading-container\" [class.loading]=\"loading() || loadingFromLoader\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>\r\n\r\n<ion-modal #modal (ionModalWillPresent)=\"OnPresent()\" (didDismiss)=\"OnDismiss()\" style=\"--width: 90%; --height: 90%;\" [keepContentsMounted]=\"true\">\r\n <ng-template>\r\n <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n </ng-template>\r\n</ion-modal>\r\n\r\n<sion-popover \r\n #popover \r\n [width]=\"inputContainer.offsetWidth + 'px'\" \r\n (onWillPresent)=\"OnPresent()\" \r\n (onDidDismiss)=\"OnDismiss()\" \r\n [anchor]=\"inputContainer\" \r\n [placement]=\"configuration().popoverConfiguration.placement\" \r\n [flip]=\"configuration().popoverConfiguration.flip\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n</sion-popover>\r\n\r\n<ng-template #selectContentTemplate>\r\n <div #selectContent class=\"select-content\">\r\n <div class=\"select-search-bar-container\">\r\n <div class=\"select-search-bar-icon-container !border-r-0 border-primary/70 bg-primary/70 shrink-0\">\r\n <ion-icon color=\"dark\" name=\"search\"></ion-icon>\r\n </div>\r\n <input #inputSearchBar tabindex=\"-1\" class=\"select-search-bar border-primary/70 !rounded-l-none\" [formControl]=\"searchBarControl\"/>\r\n </div> \r\n <ul class=\"select-item-list mask-y\" role=\"listbox\" [attr.aria-activedescendant]=\"'sion-is-' + selectedIndex\">\r\n @if(floatingVisible){\r\n @for (item of lstOptions; track item.value) { \r\n <ng-container \r\n [ngTemplateOutlet]=\"baseOptionTemplate\"\r\n [ngTemplateOutletContext]=\"{ item: item, index: $index }\">\r\n </ng-container>\r\n }\r\n }\r\n </ul>\r\n @if(isServiceAtivo()){\r\n <div class=\"w-full text-xs flex items-center justify-end\">\r\n <ion-checkbox [ngModel]=\"somenteAtivos()\" (ngModelChange)=\"somenteAtivos.set($event)\" class=\"scale-75\"> Somente ativos </ion-checkbox>\r\n </div>\r\n }\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #baseOptionTemplate let-item=\"item\" let-index=\"index\">\r\n <li [id]=\"'sion-is-' + index\" class=\"select-item\" [class.disabled]=\"item.disabled\" [attr.aria-selected]=\"index == selectedIndex\" (mouseenter)=\"selectedIndex = index\" (click)=\"Select(item)\">\r\n <div class=\"select-item-checkmark-conteiner\">\r\n @if(item.selected) {\r\n <ion-icon class=\"select-item-checkmark\" color=\"primary\" name=\"checkmark\"></ion-icon>\r\n }\r\n </div>\r\n @if (optionTemplate) {\r\n <ng-container \r\n [ngTemplateOutlet]=\"optionTemplate\"\r\n [ngTemplateOutletContext]=\"{ item: item.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"select-item-label\"> {{item.label}} </span>\r\n }\r\n </li>\r\n</ng-template>", styles: [".input-container{cursor:pointer!important}.input-select-label{pointer-events:none;min-height:1.5rem;width:100%;outline:2px solid transparent;outline-offset:2px;color:var(--ion-color-dark)}.select-content{display:flex;height:18rem;width:100%;flex-direction:column;gap:.25rem;overflow:hidden;padding:.25rem}.select-content .select-search-bar-container{display:flex;width:100%;flex-shrink:1}.select-content .select-search-bar-container .select-search-bar-icon-container{display:flex;height:100%;width:1.75rem;align-items:center;justify-content:center;border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-width:1px}.select-content .select-search-bar-container .select-search-bar{width:100%;flex-shrink:1;border-radius:.375rem;border-width:1px;background-color:transparent;padding-left:.5rem;padding-right:.5rem;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}@media (orientation: portrait){.select-content .select-search-bar-container .select-search-bar{height:2.5rem}}@media (orientation: landscape){.select-content .select-search-bar-container .select-search-bar{height:1.75rem}}.select-item-list{width:100%;height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.select-item-list .select-item{color:var(--ion-color-dark);display:flex;width:100%;flex-shrink:0;align-items:center;justify-content:flex-start;border-radius:.375rem;padding-right:.5rem}@media (orientation: portrait){.select-item-list .select-item{min-height:2.5rem}}@media (orientation: landscape){.select-item-list .select-item{min-height:2rem}}.select-item-list .select-item{cursor:pointer}.select-item-list .select-item.disabled{opacity:.5;pointer-events:none}.select-item-list .select-item:hover,.select-item-list .select-item:focus,.select-item-list .select-item[aria-selected=true]{background-color:color-mix(in srgb,var(--ion-color-dark) 20%,transparent)}.select-item-list .select-item .select-item-checkmark-conteiner{display:flex;height:100%;width:1.75rem;flex-shrink:0;align-items:center;justify-content:center}.select-item-list .select-item .select-item-label{width:100%}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 1px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:transform;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"], dependencies: [{ kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i1.IonCheckbox, selector: "ion-checkbox", inputs: ["alignment", "checked", "color", "disabled", "errorText", "helperText", "indeterminate", "justify", "labelPlacement", "mode", "name", "required", "value"] }, { kind: "component", type: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i1.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: i1.IonModal, selector: "ion-modal" }, { kind: "directive", type: i1.BooleanValueAccessor, selector: "ion-checkbox,ion-toggle" }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SIonPopoverComponent, selector: "sion-popover", inputs: ["fill", "arrow", "flip", "placement", "height", "width", "anchor"], outputs: ["onWillPresent", "onDidPresent", "onWillDismiss", "onDidDismiss", "visibleChange"] }] }); }
|
|
277
247
|
}
|
|
278
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type:
|
|
248
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NewInputSelectComponent, decorators: [{
|
|
279
249
|
type: Component,
|
|
280
|
-
args: [{ selector: 'input-select', providers: [InputProviderFactory.GetProvider(InputSelectComponent, [
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
type: SkipSelf
|
|
291
|
-
}] }, { type: i0.ElementRef }], propDecorators: { lstOptions: [{
|
|
292
|
-
type: ContentChildren,
|
|
293
|
-
args: [InputSelectOptionComponent]
|
|
294
|
-
}], lstInternalOptions: [{
|
|
295
|
-
type: ViewChildren,
|
|
296
|
-
args: [InputSelectInternalOptionComponent]
|
|
297
|
-
}], cdkVirtualScrollViewport: [{
|
|
298
|
-
type: ViewChild,
|
|
299
|
-
args: [CdkVirtualScrollViewport, { read: (ElementRef) }]
|
|
250
|
+
args: [{ selector: 'input-select', providers: [...InputProviderFactory.GetProviders(NewInputSelectComponent)], template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"focus($event); Present($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.manual-focus]=\"floatingVisible\"\r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"loading() || loadingFromLoader || disabled()\"\r\n [class.loading]=\"loading() || loadingFromLoader\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n \r\n <div class=\"w-full truncate outline-none\" [class.pr-7]=\"!configuration().clearable\" [class.pr-10]=\"configuration().clearable\" #inputSelectLabel tabindex=\"0\">\r\n @if (!configuration().multiple && currentLabel){\r\n @if(labelTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"labelTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: currentLabel, item: currentItems.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label\"> {{currentLabel}} </span>\r\n }\r\n }\r\n @else if (configuration().multiple && isArray(currentItems) && $any(currentItems).length) {\r\n <div class=\"w-full\">\r\n <div class=\"overflow-x-auto flex gap-2 size-full mask-x/2\">\r\n @for (item of currentItems; track $index) {\r\n <div class=\"translucid-border rounded-lg flex items-center justify-center gap-2 pl-2\">\r\n @if(labelTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"labelTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item.label, item: item.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label\"> {{item.label}} </span>\r\n }\r\n \r\n <div class=\"h-full aspect-square flex items-center justify-center cursor-pointer\" (click)=\"Select(item.value); $event.stopPropagation()\">\r\n <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n </div>\r\n <!-- <ion-button class=\"m-0 h-full\" (click)=\"Select(item.value); $event.stopPropagation()\" color=\"medium\" size=\"small\" fill=\"outline\" style=\"--border-radius: .5rem\">\r\n <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n </ion-button> -->\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n @else {\r\n @if(placeholderTemplate){\r\n <ng-container \r\n [ngTemplateOutlet]=\"placeholderTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: this.configuration().placeholder, placeholder: this.configuration().placeholder }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"input-select-label !text-medium\"> {{this.configuration().placeholder}} </span>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"absolute bottom-1 flex flex-col items-center justify-center size-7\" [class.right-1]=\"!configuration().clearable\" [class.right-8]=\"configuration().clearable\">\r\n <ion-icon class=\"-mb-0.5\" name=\"chevron-up\"></ion-icon>\r\n <ion-icon class=\"-mt-0.5\" name=\"chevron-down\"></ion-icon>\r\n </div>\r\n @if(configuration().clearable){\r\n <ion-button class=\"absolute right-1 bottom-1\" (click)=\"Clear($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n </ion-button>\r\n } \r\n\r\n <div class=\"loading-container\" [class.loading]=\"loading() || loadingFromLoader\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>\r\n\r\n<ion-modal #modal (ionModalWillPresent)=\"OnPresent()\" (didDismiss)=\"OnDismiss()\" style=\"--width: 90%; --height: 90%;\" [keepContentsMounted]=\"true\">\r\n <ng-template>\r\n <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n </ng-template>\r\n</ion-modal>\r\n\r\n<sion-popover \r\n #popover \r\n [width]=\"inputContainer.offsetWidth + 'px'\" \r\n (onWillPresent)=\"OnPresent()\" \r\n (onDidDismiss)=\"OnDismiss()\" \r\n [anchor]=\"inputContainer\" \r\n [placement]=\"configuration().popoverConfiguration.placement\" \r\n [flip]=\"configuration().popoverConfiguration.flip\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n</sion-popover>\r\n\r\n<ng-template #selectContentTemplate>\r\n <div #selectContent class=\"select-content\">\r\n <div class=\"select-search-bar-container\">\r\n <div class=\"select-search-bar-icon-container !border-r-0 border-primary/70 bg-primary/70 shrink-0\">\r\n <ion-icon color=\"dark\" name=\"search\"></ion-icon>\r\n </div>\r\n <input #inputSearchBar tabindex=\"-1\" class=\"select-search-bar border-primary/70 !rounded-l-none\" [formControl]=\"searchBarControl\"/>\r\n </div> \r\n <ul class=\"select-item-list mask-y\" role=\"listbox\" [attr.aria-activedescendant]=\"'sion-is-' + selectedIndex\">\r\n @if(floatingVisible){\r\n @for (item of lstOptions; track item.value) { \r\n <ng-container \r\n [ngTemplateOutlet]=\"baseOptionTemplate\"\r\n [ngTemplateOutletContext]=\"{ item: item, index: $index }\">\r\n </ng-container>\r\n }\r\n }\r\n </ul>\r\n @if(isServiceAtivo()){\r\n <div class=\"w-full text-xs flex items-center justify-end\">\r\n <ion-checkbox [ngModel]=\"somenteAtivos()\" (ngModelChange)=\"somenteAtivos.set($event)\" class=\"scale-75\"> Somente ativos </ion-checkbox>\r\n </div>\r\n }\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #baseOptionTemplate let-item=\"item\" let-index=\"index\">\r\n <li [id]=\"'sion-is-' + index\" class=\"select-item\" [class.disabled]=\"item.disabled\" [attr.aria-selected]=\"index == selectedIndex\" (mouseenter)=\"selectedIndex = index\" (click)=\"Select(item)\">\r\n <div class=\"select-item-checkmark-conteiner\">\r\n @if(item.selected) {\r\n <ion-icon class=\"select-item-checkmark\" color=\"primary\" name=\"checkmark\"></ion-icon>\r\n }\r\n </div>\r\n @if (optionTemplate) {\r\n <ng-container \r\n [ngTemplateOutlet]=\"optionTemplate\"\r\n [ngTemplateOutletContext]=\"{ item: item.item }\">\r\n </ng-container>\r\n }\r\n @else {\r\n <span class=\"select-item-label\"> {{item.label}} </span>\r\n }\r\n </li>\r\n</ng-template>", styles: [".input-container{cursor:pointer!important}.input-select-label{pointer-events:none;min-height:1.5rem;width:100%;outline:2px solid transparent;outline-offset:2px;color:var(--ion-color-dark)}.select-content{display:flex;height:18rem;width:100%;flex-direction:column;gap:.25rem;overflow:hidden;padding:.25rem}.select-content .select-search-bar-container{display:flex;width:100%;flex-shrink:1}.select-content .select-search-bar-container .select-search-bar-icon-container{display:flex;height:100%;width:1.75rem;align-items:center;justify-content:center;border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-width:1px}.select-content .select-search-bar-container .select-search-bar{width:100%;flex-shrink:1;border-radius:.375rem;border-width:1px;background-color:transparent;padding-left:.5rem;padding-right:.5rem;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}@media (orientation: portrait){.select-content .select-search-bar-container .select-search-bar{height:2.5rem}}@media (orientation: landscape){.select-content .select-search-bar-container .select-search-bar{height:1.75rem}}.select-item-list{width:100%;height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.select-item-list .select-item{color:var(--ion-color-dark);display:flex;width:100%;flex-shrink:0;align-items:center;justify-content:flex-start;border-radius:.375rem;padding-right:.5rem}@media (orientation: portrait){.select-item-list .select-item{min-height:2.5rem}}@media (orientation: landscape){.select-item-list .select-item{min-height:2rem}}.select-item-list .select-item{cursor:pointer}.select-item-list .select-item.disabled{opacity:.5;pointer-events:none}.select-item-list .select-item:hover,.select-item-list .select-item:focus,.select-item-list .select-item[aria-selected=true]{background-color:color-mix(in srgb,var(--ion-color-dark) 20%,transparent)}.select-item-list .select-item .select-item-checkmark-conteiner{display:flex;height:100%;width:1.75rem;flex-shrink:0;align-items:center;justify-content:center}.select-item-list .select-item .select-item-label{width:100%}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 1px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:transform;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"] }]
|
|
251
|
+
}], ctorParameters: () => [], propDecorators: { labelTemplate: [{
|
|
252
|
+
type: ContentChild,
|
|
253
|
+
args: [SIonLabelTemplateDirective, { read: TemplateRef }]
|
|
254
|
+
}], optionTemplate: [{
|
|
255
|
+
type: ContentChild,
|
|
256
|
+
args: [SIonOptionTemplateDirective, { read: TemplateRef }]
|
|
257
|
+
}], placeholderTemplate: [{
|
|
258
|
+
type: ContentChild,
|
|
259
|
+
args: [SIonPlaceholderTemplateDirective, { read: TemplateRef }]
|
|
300
260
|
}], inputContainer: [{
|
|
301
261
|
type: ViewChild,
|
|
302
|
-
args: ['
|
|
303
|
-
}],
|
|
262
|
+
args: ['inputContainer']
|
|
263
|
+
}], inputSelectLabel: [{
|
|
304
264
|
type: ViewChild,
|
|
305
|
-
args: [
|
|
306
|
-
}],
|
|
265
|
+
args: ['inputSelectLabel']
|
|
266
|
+
}], HandleKeyboardEvent: [{
|
|
267
|
+
type: HostListener,
|
|
268
|
+
args: ['document:keydown', ['$event']]
|
|
269
|
+
}], inputSearchBar: [{
|
|
307
270
|
type: ViewChild,
|
|
308
|
-
args: [
|
|
309
|
-
}],
|
|
271
|
+
args: ['inputSearchBar']
|
|
272
|
+
}], selectContent: [{
|
|
310
273
|
type: ViewChild,
|
|
311
|
-
args: [
|
|
312
|
-
}],
|
|
274
|
+
args: ['selectContent']
|
|
275
|
+
}], popover: [{
|
|
313
276
|
type: ViewChild,
|
|
314
|
-
args: [
|
|
315
|
-
}],
|
|
277
|
+
args: [SIonPopoverComponent]
|
|
278
|
+
}], modal: [{
|
|
316
279
|
type: ViewChild,
|
|
317
|
-
args: [
|
|
318
|
-
}], HandleKeyboardEvent: [{
|
|
319
|
-
type: HostListener,
|
|
320
|
-
args: ['document:keydown', ['$event']]
|
|
280
|
+
args: [IonModal]
|
|
321
281
|
}] } });
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-select/input-select.component.ts","../../../../../../src/lib/components/inputs/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, ElementRef, Host, HostListener, ModelSignal, OnDestroy, OnInit, Optional, QueryList, Signal, SkipSelf, ViewChild, ViewChildren, WritableSignal, computed, effect, forwardRef, model, signal } from '@angular/core';\r\nimport { IonInput, IonItem, IonPopover, IonSearchbar } from '@ionic/angular';\r\nimport { ControlContainer, ControlValueAccessor } from '@angular/forms';\r\nimport { Observable, Subscription, interval } from 'rxjs';\r\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\r\n\r\nimport { BindLabelFactory, BindValueFactory, DefaultModelOptions, InputSelectConfiguration } from './input.select.configuration';\r\nimport { InputSelectInternalOptionComponent } from './input-select-internal-option/input-select-internal-option.component';\r\nimport { InputSelectOptionComponent } from './input-select-option/input-select-option.component';\r\nimport { ISelect, ISelectOption } from './ISelect';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomSignalInput } from '../custom-signal-input';\r\nimport { Search } from '../../../services/utils.service';\r\n\r\n@Component({\r\n  selector: 'input-select',\r\n  templateUrl: './input-select.component.html',\r\n  styleUrls: ['./input-select.component.scss', '../inputs.scss'],\r\n  providers: [InputProviderFactory.GetProvider(InputSelectComponent, \r\n    [\r\n      { \r\n        provide: ISelect, useExisting: forwardRef(() => InputSelectComponent)\r\n      }\r\n    ]\r\n  )]\r\n})\r\nexport class InputSelectComponent extends CustomSignalInput<any> implements OnInit, OnDestroy, ControlValueAccessor, ISelect {\r\n\r\n  /** Items disponíveis no select */\r\n  public items            : ModelSignal<any[]>                    = model<any[]>([]);\r\n  /** Configuração do select */\r\n  public configuration    : ModelSignal<InputSelectConfiguration> = model<InputSelectConfiguration>(new InputSelectConfiguration()); \r\n  public loadingFromLoader: boolean = false;\r\n\r\n  @ContentChildren(InputSelectOptionComponent) lstOptions: QueryList<InputSelectOptionComponent>;\r\n  @ViewChildren(InputSelectInternalOptionComponent) lstInternalOptions: QueryList<InputSelectInternalOptionComponent>;\r\n  @ViewChild(CdkVirtualScrollViewport, { read: ElementRef<any> }) cdkVirtualScrollViewport: ElementRef<any>\r\n\r\n  private useDefaultModelOptions: WritableSignal<boolean> = signal<boolean>(false);\r\n  protected bindValue: Signal<((args: any) => any)>         = computed(() => { \r\n    if(this.useDefaultModelOptions()){ return ((obj: DefaultModelOptions): string => { return obj.value; }); }\r\n    return BindValueFactory(this.configuration());\r\n  });\r\n  protected bindLabel: Signal<((args: any) => string)>      = computed(() => {\r\n    if(this.useDefaultModelOptions()){ return ((obj: DefaultModelOptions): string => { return obj.label; }); }\r\n    return BindLabelFactory(this.configuration());\r\n  });\r\n\r\n  constructor(\r\n    @Optional() @Host() @SkipSelf()\r\n    override controlContainer: ControlContainer,\r\n    override elementRef      : ElementRef\r\n  ) { super();\r\n    effect(() => { this.Update(); }, { allowSignalWrites: true });\r\n\r\n    this.updateInterval     = interval(1000);\r\n    this.updateSubscription = this.updateInterval.subscribe(() => {\r\n      if(this.lastItemsQtd != this.items().length){\r\n        this.lastItemsQtd = this.items().length;\r\n        this.Update();\r\n      } \r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.updateSubscription.unsubscribe();\r\n  }\r\n\r\n  updateInterval: Observable<number> | null;\r\n  updateSubscription: Subscription;\r\n\r\n  lastItemsQtd: number | null = null;\r\n  \r\n  override ngOnInit() {\r\n    super.ngOnInit();\r\n\r\n    this.configuration().loader.AddComponent(this);\r\n    this.configuration().loader.Refresh(this.items());\r\n  }\r\n\r\n  public Clear(): void{ \r\n    this.model = null; \r\n    this.Update();\r\n  }\r\n  \r\n  protected CurrentLabel      : string  = \"\";\r\n  protected CurrentlyNoValue  : boolean = true;\r\n\r\n  public Update(){\r\n    this.UpdateSelected();\r\n    this.UpdateCurrentLabel(); \r\n  }\r\n  private UpdateCurrentLabel(): void{\r\n    if(this._model == null){ \r\n      this.CurrentLabel = this.configuration().placeholder;\r\n      this.CurrentlyNoValue = true;\r\n      return;\r\n    }\r\n    if(!this.configuration().multiple){\r\n      const m: any | null = this.items().find(p => this.bindValue()(p) == this._model);\r\n      if(m){ \r\n        this.CurrentLabel     = this.bindLabel()(m);\r\n        this.CurrentlyNoValue = false; \r\n      }\r\n      return;\r\n    }else{\r\n      if(!this._model){ \r\n        this.CurrentLabel = this.configuration().placeholder; \r\n        this.CurrentlyNoValue = true;\r\n        return; \r\n      }else\r\n      if(Array.isArray(this.model) && !this.model.length){ \r\n        this.CurrentLabel = this.configuration().placeholder; \r\n        this.CurrentlyNoValue = true;\r\n        return; \r\n      }\r\n      this.CurrentLabel     = \"\"; \r\n      this.CurrentlyNoValue = false;\r\n      return;\r\n    }\r\n  }\r\n  private UpdateSelected(){\r\n    if(this.lstOptions && this.lstOptions.length){\r\n      this.lstOptions.forEach(p => p.isSelected = false);\r\n      this.lstOptions.filter(p => Array.isArray(this._model) ? this._model.includes(p.value) : this._model == p.value).forEach(p => p.isSelected = true);\r\n    }\r\n  }\r\n\r\n  IsSelected(item: any){\r\n    if(Array.isArray(this._model)){\r\n      return this._model.includes(this.bindValue()(item));\r\n    }\r\n    return this._model == this.bindValue()(item);\r\n  }\r\n\r\n  /** Applies only on multiple */\r\n  protected GetSelectedItens(): any[]{\r\n    if(this._model && this.lstOptions.length){\r\n      return this.lstOptions.filter(p => p.isSelected).map(p => p.model()); \r\n    }\r\n    if(this._model && this.items()){\r\n      return this.items().filter(p => Array.isArray(this._model) ? this._model.includes(this.bindValue()(p)) : this._model == this.bindValue()(p)); \r\n    }\r\n\r\n    return [];\r\n  }\r\n\r\n  //[ Model ]\r\n  override _model: any = null;\r\n  override get model(): any      { return this._model;  }\r\n  override set model(value: any) { \r\n    this.SetModel(value);\r\n    this.propagateChange(this._model); \r\n  }\r\n  protected SetModel(value: any): void { \r\n    if(value == null ){ this._model = null; return; }\r\n\r\n    this._model = value;\r\n\r\n    this.Update();\r\n    return; \r\n  }\r\n\r\n  protected SearchChanged(): void{\r\n    if(this.lstOptions.length){\r\n      this.useDefaultModelOptions.set(true);\r\n      var lst = Search(this.lstOptions.map(p => p.model()), this.Search(), this.bindLabel()); \r\n      this.lstOptions.forEach(p => p.hidden = !lst.includes(p.model()))\r\n    }\r\n  }\r\n  \r\n  protected GetUseDefaultModelOptions(): boolean{\r\n    if(this.lstOptions && this.lstOptions.length){ return true; }\r\n    return false;\r\n  }\r\n\r\n  public UpdateUseDefaultModelOptions(): void{\r\n    this.useDefaultModelOptions.set(this.GetUseDefaultModelOptions());\r\n    if(this.useDefaultModelOptions()){ \r\n      if(this.items().length != this.lstOptions.length){\r\n        this.items.set(this.lstOptions.map(p => p.model())); \r\n      }\r\n    }\r\n  }\r\n\r\n  //[ Select ]\r\n  override writeValue(obj: any): void { this.SetModel(obj); }\r\n\r\n  public Select(item: any): void{\r\n    this.UpdateUseDefaultModelOptions();\r\n    \r\n    if(!this.configuration().multiple){ \r\n      this.model = this.bindValue()(item); \r\n    } \r\n    else{\r\n      var value =  this.bindValue()(item);\r\n\r\n      if(this._model){\r\n        if(this._model.includes(value)){ \r\n          this.model = [...this._model.filter(p => p != value)]; \r\n        }\r\n        else{\r\n          this.model = [...this._model, value];\r\n        }\r\n        return;\r\n      }\r\n\r\n      this.model = [value];\r\n      return;\r\n    }\r\n  }\r\n\r\n  protected interfaceOptions = { cssClass : 'wider-popover' }\r\n\r\n  @ViewChild('container', { read: ElementRef }) inputContainer: ElementRef<HTMLElement>;\r\n  @ViewChild(IonPopover) ionPopoverComponent: IonPopover;\r\n  @ViewChild(IonPopover, { read: ElementRef }) ionPopoverElement: ElementRef<HTMLElement>;\r\n  @ViewChild(IonSearchbar) searchbarComponent: IonSearchbar;\r\n\r\n  public async PresentPopover($event: MouseEvent) {\r\n    Object.defineProperty($event, 'target', { writable: false, value: this.inputContainer.nativeElement });\r\n    const Popover        = this.ionPopoverComponent;\r\n    const PopoverElement = this.ionPopoverElement.nativeElement as HTMLElement;\r\n    \r\n    const PopoverContent = Array.from(\r\n      Array.from(PopoverElement.shadowRoot.children).find(\r\n        p => p.classList.contains(\"popover-wrapper\")\r\n      ).children\r\n    ).find(\r\n      p => p.classList.contains(\"popover-content\")\r\n    ) as HTMLElement\r\n    PopoverContent.style.width = this.inputContainer.nativeElement.offsetWidth + 'px';\r\n    await Popover.present($event);\r\n    this.searchbarComponent.setFocus();\r\n\r\n    if(this.cdkVirtualScrollViewport){\r\n      this.cdkVirtualScrollViewport.nativeElement.scroll({ top: 1, behavior: 'smooth' });\r\n    }\r\n\r\n    this.focusedModel = null;\r\n    this.UpdateUseDefaultModelOptions();\r\n  };\r\n\r\n  protected Search        : ModelSignal<string> = model<string>(\"\");\r\n  protected lstSearchItens: Signal<any[]>       = computed<any[]>(() => { return Search(this.items(), this.Search(), this.bindLabel()); })\r\n\r\n  //#region [ Arrow/Tab Control ]\r\n  @ViewChild(IonInput) inputComponent: IonInput;\r\n  @ViewChild(IonItem, { read: ElementRef })  itemComponent : ElementRef<HTMLElement>;\r\n  @HostListener('document:keydown', ['$event'])\r\n  async HandleKeyboardEvent(event: KeyboardEvent) {\r\n    if(!this.inputComponent || !this.searchbarComponent){ return; }\r\n    \r\n    const inputComponent     = await this.inputComponent.getInputElement();\r\n    const searchbarComponent = await this.searchbarComponent.getInputElement();\r\n    \r\n    if(event.target == inputComponent && event.key == \"ArrowDown\" && this.configuration().searcheable){\r\n      this.itemComponent.nativeElement.click();\r\n      event.preventDefault();\r\n    }else\r\n    if(event.target == searchbarComponent){\r\n      this.UpdateUseDefaultModelOptions();\r\n\r\n      const items  = this.lstSearchItens();\r\n      if(event.key == \"ArrowDown\"){\r\n        if(this.focusedModel){\r\n          const index = items.indexOf(this.focusedModel);\r\n          \r\n          if(items[index + 1]){\r\n            this.SetFocusedElement(items[index + 1]);\r\n          }else{\r\n            this.SetFocusedElement(items[0]);\r\n          }\r\n        }else{\r\n          if(items[0]){\r\n            this.SetFocusedElement(items[0]);\r\n          }\r\n        }\r\n      }else\r\n      if(event.key == \"ArrowUp\"){\r\n        if(this.focusedModel){\r\n          const index = items.indexOf(this.focusedModel);\r\n\r\n          if(items[index - 1]){\r\n            this.SetFocusedElement(items[index - 1]);\r\n          }else{\r\n            this.SetFocusedElement(items[items.length -1]);\r\n          }\r\n        }\r\n      }else\r\n      if(event.key == \"Enter\"){\r\n        var Option: ISelectOption;\r\n        if(this.useDefaultModelOptions()){\r\n          Option = this.lstOptions.find(p => p.model() == this.focusedModel);\r\n        }else{\r\n          Option = this.lstInternalOptions.find(p => p.model == this.focusedModel);\r\n        }\r\n        if(!Option.disabled){\r\n          this.Select(this.focusedModel);\r\n        }\r\n      }\r\n    }\r\n  }\r\n  SetFocusedElement(focusedModel: any, scroll: boolean = true,): void{\r\n    this.focusedModel = focusedModel;\r\n    \r\n    var Option: ISelectOption;\r\n    if(this.useDefaultModelOptions()){\r\n      Option = this.lstOptions.find(p => p.model() == focusedModel);\r\n      this.lstOptions.filter(p => p.onFocus).forEach(p => p.onFocus = false);\r\n      Option.onFocus = true;\r\n    }else{\r\n      Option = this.lstInternalOptions.find(p => p.model == focusedModel);\r\n      this.lstInternalOptions.filter(p => p.onFocus).forEach(p => p.onFocus = false);\r\n      Option.onFocus = true;\r\n    }\r\n    \r\n    if(scroll){ Option.GetNativeElement().scrollIntoView({ behavior: 'smooth' }); }\r\n  }\r\n\r\n  focusedModel: any | null;\r\n  //#endregion [ Arrow/Tab Control ]\r\n}","<div class=\"relative flex overflow-hidden\" #container>\r\n  <ion-card \r\n      class=\"focus-within:on-focus ion-card-input\" \r\n      [disabled]=\"loading || loadingFromLoader || disabled\" \r\n      [class.invalid]=\"invalid\"\r\n      [class.submitted]=\"submitted\"\r\n      [class.disabled]=\"disabled\"\r\n      [ngClass]=\"{'!rounded-l-2xl !rounded-r-none !border-r-0': configuration().clearable}\"\r\n    >\r\n    <ion-card-content>\r\n      <ion-item lines=\"none\" class=\"rounded-2xl w-full relative\" (click)=\"PresentPopover($event)\" [ngClass]=\"{'!rounded-l-2xl !rounded-r-none': configuration().clearable }\">\r\n        <ion-input fill=\"none\" [readonly]=\"true\" labelPlacement=\"stacked\" [value]=\"CurrentLabel\" [class.no-items-opacity]=\"CurrentlyNoValue\">\r\n          <ion-text id=\"label\" [ngClass]=\"{'required': required() }\" slot=\"label\" class=\"!text-dark\"> \r\n            {{label}} \r\n          </ion-text>\r\n        </ion-input>\r\n        @if(configuration().multiple){\r\n          <div class=\"absolute left-0 bottom-0 h-6 w-full flex z-[90] overflow-x-auto\">\r\n            @for(item of GetSelectedItens(); track $index){\r\n              <div class=\"h-full flex bg-medium/10 border translucid-border rounded-lg mr-1 animated\">\r\n                <div (click)=\"Select(item); $event.stopPropagation()\" class=\"bg-medium/10 cursor-pointer translucid-border min-w-min !border-l-0 !border-y-0 h-full aspect-square flex items-center justify-center rounded-r-lg\"> \r\n                    <ion-icon color=\"danger\" name=\"close\"></ion-icon>\r\n                </div>\r\n                <div class=\"h-full px-1 select-none\"> {{bindLabel()(item)}} </div>\r\n              </div>\r\n            }\r\n          </div>\r\n        }\r\n      </ion-item>\r\n      \r\n    </ion-card-content>\r\n  </ion-card>\r\n  <input-loading [loading]=\"loading || loadingFromLoader\"></input-loading>\r\n  @if(configuration().clearable){\r\n    <div class=\"w-12\">\r\n      <ion-button (click)=\"Clear()\" [disabled]=\"loading || disabled || loadingFromLoader\" size=\"small\" fill=\"outline\" color=\"medium\" class=\"rounded-r-2xl h-full w-full\" style=\"--border-width: 1px 1px 2px 1px;\">\r\n        <ion-icon name=\"backspace\" slot=\"icon-only\"></ion-icon>\r\n      </ion-button>\r\n    </div>\r\n  }\r\n</div>\r\n\r\n<ion-popover class=\"input-select-popover\" [keepContentsMounted]=\"false\" [dismissOnSelect]=\"!configuration().multiple\" (didDismiss)=\"Search.set('')\">\r\n  <ng-template>\r\n    <div class=\"size-full flex flex-col bg-primary/10\">\r\n      <div class=\"w-full shrink-0\" [hidden]=\"!configuration().searcheable\">\r\n        <ion-searchbar [(ngModel)]=\"Search\" (ngModelChange)=\"SearchChanged()\" placeholder=\"Pesquisa...\" class=\"size-full bg-transparent\" [debounce]=\"100\"></ion-searchbar>\r\n      </div>\r\n\r\n      <div class=\"h-48 w-full overflow-hidden translucid-border !border-x-0 !border-b-0 rounded-t-2xl bg-light\" [ngClass]=\"{'!border-0': !configuration().searcheable}\">\r\n        @if(!lstOptions || !lstOptions.length){\r\n          <cdk-virtual-scroll-viewport itemSize=\"45\" [minBufferPx]=\"200\" [maxBufferPx]=\"300\" class=\"size-full\">\r\n            <input-select-internal-option [model]=\"item\" *cdkVirtualFor=\"let item of lstSearchItens()\" [isSelected]=\"IsSelected(item)\">\r\n              <ion-label class=\"truncate\">{{bindLabel()(item)}}</ion-label>\r\n            </input-select-internal-option>\r\n          </cdk-virtual-scroll-viewport>\r\n        }\r\n        @else {\r\n          <div class=\"size-full overflow-y-auto overflow-x-hidden mask-y\">\r\n            <ng-content select=\"input-select-option\"></ng-content>\r\n          </div>\r\n        }\r\n      </div>\r\n    </div>\r\n  </ng-template>\r\n</ion-popover>"]}
|
|
282
|
+
class ItemValue {
|
|
283
|
+
constructor() {
|
|
284
|
+
this.selected = false;
|
|
285
|
+
this.disabled = false;
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
function isPortrait() {
|
|
289
|
+
return window.innerHeight > window.innerWidth;
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-select/input-select.component.ts","../../../../../../src/lib/components/inputs/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, computed, ContentChild, effect, ElementRef, HostListener, inject, Injector, input, InputSignal, model, ModelSignal, signal, Signal, TemplateRef, ViewChild, WritableSignal, } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { IonModal } from '@ionic/angular';\r\n\r\nimport { debounceTime, distinctUntilChanged, Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { BindLabelFactory, BindValueFactory, InputSelectConfiguration } from './input.select.configuration';\r\nimport { SIonPopoverComponent } from '../../popover/sion-popover/sion-popover.component';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomInput } from '../custom-input';\r\nimport { Search } from '../../../services/utils.service';\r\n\r\nimport { PlaceholderTemplateContext, SIonPlaceholderTemplateDirective } from './directives/sion-placeholder-template.directive';\r\nimport { OptionTemplateContext, SIonOptionTemplateDirective } from './directives/sion-option-template.directive';\r\nimport { LabelTemplateContext, SIonLabelTemplateDirective } from './directives/sion-label-template.directive';\r\nimport { HttpServiceAtivo } from '../../../services/web/http.ativo.service';\r\n\r\n@Component({\r\n  selector: 'input-select',\r\n  templateUrl: './input-select.component.html',\r\n  styleUrls: ['./input-select.component.scss', '../inputs.scss'],\r\n  providers: [...InputProviderFactory.GetProviders(NewInputSelectComponent)],\r\n})\r\nexport class NewInputSelectComponent<T = any> extends CustomInput<T | T[]> implements AfterViewInit {\r\n\r\n  /** Items disponíveis no select */\r\n  items            : ModelSignal<any[]>                      = model<any[]>([]);\r\n  /** Configuração do select */\r\n  configuration    : InputSignal<InputSelectConfiguration> = input<InputSelectConfiguration>(new InputSelectConfiguration()); \r\n  loadingFromLoader: boolean = false;\r\n\r\n  currentLabel: string | undefined = undefined;\r\n  currentItems : any | ItemValue<any>[] | undefined = undefined;\r\n  \r\n  SetCurrentItemLabel(): void {\r\n    if(this.configuration().multiple){\r\n      this.currentLabel = this.lstOptions.filter(p => p.selected).map(p => p.label).join(', ');\r\n      this.currentItems = this.lstOptions.filter(p => p.selected);\r\n    }\r\n    else{\r\n      this.currentLabel = this.lstOptions.find(p => p.selected)?.label;\r\n      this.currentItems = this.lstOptions.find(p => p.selected);\r\n    }\r\n  }\r\n\r\n  lstOptionsItemValue: Signal<ItemValue<any>[]> = computed(() => {\r\n    const bindLabel = BindLabelFactory(this.configuration());\r\n    const bindValue = BindValueFactory(this.configuration());\r\n    return this.items().filter(p => this.somenteAtivos() && this.isServiceAtivo() ? p.ativo : true) .map(p => {\r\n      const item = new ItemValue<any>();\r\n      item.label = bindLabel(p);\r\n      item.value = bindValue(p);\r\n      item.item  = p;\r\n      item.selected = this.value() == item.value;\r\n      item.disabled = p.disabled || false || (this.isServiceAtivo && p.ativo == false);\r\n      return item;\r\n    });\r\n  });\r\n\r\n  lstOptions: ItemValue<any>[] = [];\r\n  UpdateLstOptions(search: string): void {\r\n    // Update the search \r\n    if (search) {\r\n      this.lstOptions = Search<ItemValue<any>>(this.lstOptionsItemValue(), search, (item: ItemValue<any>) => item.label);\r\n    } else { \r\n      this.lstOptions = this.lstOptionsItemValue(); \r\n    }\r\n  }\r\n  UpdateSelected(): void {\r\n    if (this.configuration().multiple){\r\n      const arr = this.value() as any[] || [];\r\n      for (const item of this.lstOptions) {\r\n        item.selected = arr.find(p => p == item.value) != undefined;\r\n      }\r\n    } else {\r\n      this.lstOptions.forEach((item: ItemValue<any>) => { item.selected = this.value() == item.value; });\r\n    }\r\n    this.SetCurrentItemLabel();\r\n  }\r\n\r\n  @ContentChild(SIonLabelTemplateDirective      , { read: TemplateRef }) labelTemplate      : TemplateRef<LabelTemplateContext<T>>;\r\n  @ContentChild(SIonOptionTemplateDirective     , { read: TemplateRef }) optionTemplate     : TemplateRef<OptionTemplateContext<T>>;\r\n  @ContentChild(SIonPlaceholderTemplateDirective, { read: TemplateRef }) placeholderTemplate: TemplateRef<PlaceholderTemplateContext>;\r\n\r\n\r\n  @ViewChild('inputContainer') inputContainer: ElementRef<HTMLDivElement>;\r\n  @ViewChild('inputSelectLabel') inputSelectLabel: ElementRef<HTMLDivElement>;\r\n  override focus(event: MouseEvent): void { }\r\n\r\n  constructor() { \r\n    super(); \r\n    effect(() => {\r\n      this.UpdateLstOptions(this.searchValue());\r\n      this.UpdateSelected();\r\n    }, { allowSignalWrites: true }) \r\n  }\r\n  override async ngOnInit(): Promise<void> {\r\n    await super.ngOnInit();\r\n    this.configuration().loader.AddComponent(this);\r\n    this.configuration().loader.Refresh(this.items());\r\n  }\r\n  isServiceAtivo: Signal<boolean> = computed(() => { return this.configuration().loadFromService instanceof HttpServiceAtivo; });\r\n  somenteAtivos: WritableSignal<boolean> = signal<boolean>(true);\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  HandleKeyboardEvent(event: KeyboardEvent): void {\r\n    // [ Popover ]\r\n    if(this.selectContent?.nativeElement?.contains(event.target as Node)){\r\n      if(event.key == \"Tab\"){\r\n        event.preventDefault();\r\n        return;\r\n      } else\r\n      if (event.key == \"Escape\"){\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n        this.Dismiss();\r\n        return;\r\n      }\r\n    }\r\n    // [ inputContainer ]\r\n    if(this.inputContainer.nativeElement.contains(event.target as Node)){ \r\n      if([\"ArrowDown\", \"ArrowUp\"].includes(event.key)){\r\n        event.preventDefault();\r\n        this.Present(event);\r\n        return;\r\n      }\r\n    }\r\n    // [ inputSelectSearchBar ]\r\n    if(this.inputSearchBar.nativeElement == event.target){\r\n      if(event.key == \"Enter\"){\r\n        event.preventDefault();\r\n        // If the select is not ativo ignore the selected item\r\n        const item = this.lstOptions[this.selectedIndex!];\r\n        if(this.isServiceAtivo() && !item.item.ativo) { return; }\r\n        this.Select(item);\r\n        return;\r\n      } else \r\n      if(event.key == \"ArrowDown\"){\r\n        if(this.selectedIndex == undefined){ this.selectedIndex = 0; return; }\r\n        event.preventDefault();\r\n        this.selectedIndex = (this.selectedIndex < this.lstOptions.length - 1 ? this.selectedIndex + 1 : this.selectedIndex)\r\n        return;\r\n      } else \r\n      if(event.key == \"ArrowUp\"){\r\n        if(this.selectedIndex == undefined){ this.selectedIndex = 0; return; }\r\n        event.preventDefault();\r\n        this.selectedIndex = (this.selectedIndex > 0 ? this.selectedIndex - 1 : this.selectedIndex)\r\n        return;\r\n      }\r\n    }\r\n  }\r\n  selectedIndex: number | undefined = undefined;\r\n\r\n  //[ Search Bar ]\r\n  @ViewChild('inputSearchBar') inputSearchBar: ElementRef<HTMLInputElement>;\r\n  searchBarControl: FormControl = new FormControl('');\r\n  searchValue     : WritableSignal<string> =  signal<string>(\"\");\r\n  private searchBarSubscription: Subscription | null = null;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  injector = inject(Injector);\r\n  ngAfterViewInit(): void {\r\n    const observable = this.searchBarControl.valueChanges.pipe(\r\n      takeUntil(this.destroy$),\r\n      distinctUntilChanged(),\r\n      debounceTime(200),\r\n    )\r\n    this.searchBarSubscription = observable.subscribe((value: string) => { \r\n      this.selectedIndex = undefined;\r\n      this.searchValue.set(value); \r\n    });\r\n  }\r\n\r\n  ClearSearchBar(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    if (this.searchBarSubscription) { this.searchBarSubscription.unsubscribe(); }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.ClearSearchBar();\r\n  }\r\n\r\n  override writeValue(obj: T | T[]): void | Promise<void> {\r\n    this.value.set(obj);\r\n    this.runValidation();\r\n    this.UpdateSelected();\r\n  }\r\n  \r\n  override SetValue(obj: T | T[]): void {\r\n    this.value.set(obj);\r\n    this.runValidation();\r\n    this.UpdateSelected();\r\n    this.propagateChange(this.value());\r\n    if(!this.configuration().multiple){\r\n      this.Dismiss();\r\n    }\r\n  }\r\n  Clear(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    if(this.configuration().multiple){\r\n      this.SetValue([]);\r\n    }\r\n    else {\r\n      this.SetValue(undefined);\r\n    }\r\n  }\r\n  public Select(itemValue: ItemValue<T>): void{\r\n    const item = itemValue.value;\r\n    if(this.configuration().multiple){\r\n      const currentValue = this.value();\r\n      if(Array.isArray(currentValue)){\r\n        const index = currentValue.findIndex(p => p == item);\r\n        if(index > -1){\r\n          currentValue.splice(index, 1);\r\n        } else {\r\n          currentValue.push(item);\r\n        }\r\n        this.SetValue([...currentValue]);\r\n      } else {\r\n        this.SetValue([item]);\r\n      }\r\n    } else {\r\n      this.SetValue(item);\r\n      this.Dismiss();\r\n    }\r\n  }\r\n\r\n  //#region [ Popover / Modal ]\r\n  @ViewChild('selectContent') selectContent: ElementRef<HTMLDivElement>;\r\n  @ViewChild(SIonPopoverComponent) popover: SIonPopoverComponent;\r\n  @ViewChild(IonModal)               modal: IonModal;\r\n\r\n  floatingVisible: boolean = false;\r\n  \r\n\r\n\r\n  async Present(event: Event): Promise<void> {\r\n    if(isPortrait()){\r\n      // Modal\r\n      await this.modal.present();\r\n      this.inputSearchBar.nativeElement.focus();\r\n      return;\r\n    }\r\n    // Popover\r\n    await this.popover.present(event);\r\n    this.inputSearchBar.nativeElement.focus();\r\n  }\r\n  async Dismiss(): Promise<void> {\r\n    if(this.modal) {\r\n      await this.modal.dismiss();\r\n    }\r\n    if(this.popover) {\r\n      await this.popover.dismiss();\r\n    }\r\n    this.selectedIndex = undefined;\r\n    if(this.inputSelectLabel?.nativeElement){ \r\n      this.inputSelectLabel.nativeElement.focus();\r\n    }\r\n  }\r\n  OnDismiss(): void {\r\n    this.floatingVisible = false; \r\n    this.searchValue.set('');\r\n    this.searchBarControl.setValue('');\r\n  }\r\n  OnPresent(): void {\r\n    this.floatingVisible = true;\r\n  }\r\n\r\n  isArray(obj : any ) {\r\n   return Array.isArray(obj)\r\n  }\r\n}\r\n\r\nclass ItemValue<T>{\r\n  label: string;\r\n  value: T;\r\n  selected: boolean = false;\r\n  item    : any; \r\n  disabled: boolean = false;\r\n}\r\n\r\nfunction isPortrait() {\r\n  return window.innerHeight > window.innerWidth;\r\n}","<div \r\n  #inputContainer\r\n  class=\"input-container\" \r\n  (click)=\"focus($event); Present($event)\"\r\n  [class.required]=\"required()\" \r\n  [class.submitted]=\"submitted()\" \r\n  [class.manual-focus]=\"floatingVisible\"\r\n  [class.invalid]=\"invalid\" \r\n  [class.disabled]=\"loading() || loadingFromLoader || disabled()\"\r\n  [class.loading]=\"loading() || loadingFromLoader\"\r\n>\r\n  <div class=\"input-label\"> \r\n    <span class=\"truncate\">\r\n      {{label()}} \r\n    </span>\r\n  </div>\r\n  \r\n  <div class=\"w-full truncate outline-none\" [class.pr-7]=\"!configuration().clearable\" [class.pr-10]=\"configuration().clearable\"  #inputSelectLabel tabindex=\"0\">\r\n    @if (!configuration().multiple && currentLabel){\r\n      @if(labelTemplate){\r\n        <ng-container \r\n          [ngTemplateOutlet]=\"labelTemplate\"\r\n          [ngTemplateOutletContext]=\"{ $implicit: currentLabel, item: currentItems.item }\">\r\n        </ng-container>\r\n      }\r\n      @else {\r\n        <span class=\"input-select-label\"> {{currentLabel}} </span>\r\n      }\r\n    }\r\n    @else if (configuration().multiple && isArray(currentItems) && $any(currentItems).length) {\r\n      <div class=\"w-full\">\r\n        <div class=\"overflow-x-auto flex gap-2 size-full mask-x/2\">\r\n          @for (item of currentItems; track $index) {\r\n            <div class=\"translucid-border rounded-lg flex items-center justify-center gap-2 pl-2\">\r\n              @if(labelTemplate){\r\n                <ng-container \r\n                  [ngTemplateOutlet]=\"labelTemplate\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: item.label, item: item.item }\">\r\n                </ng-container>\r\n              }\r\n              @else {\r\n                <span class=\"input-select-label\"> {{item.label}} </span>\r\n              }\r\n            \r\n              <div class=\"h-full aspect-square flex items-center justify-center cursor-pointer\" (click)=\"Select(item.value); $event.stopPropagation()\">\r\n                <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n              </div>\r\n              <!-- <ion-button class=\"m-0 h-full\" (click)=\"Select(item.value); $event.stopPropagation()\" color=\"medium\" size=\"small\" fill=\"outline\" style=\"--border-radius: .5rem\">\r\n                <ion-icon name=\"close\" color=\"danger\" slot=\"icon-only\"></ion-icon>\r\n              </ion-button> -->\r\n            </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    }\r\n    @else {\r\n      @if(placeholderTemplate){\r\n        <ng-container \r\n          [ngTemplateOutlet]=\"placeholderTemplate\"\r\n          [ngTemplateOutletContext]=\"{ $implicit: this.configuration().placeholder, placeholder: this.configuration().placeholder }\">\r\n        </ng-container>\r\n      }\r\n      @else {\r\n        <span class=\"input-select-label !text-medium\"> {{this.configuration().placeholder}} </span>\r\n      }\r\n    }\r\n  </div>\r\n\r\n  <div class=\"absolute bottom-1 flex flex-col items-center justify-center size-7\" [class.right-1]=\"!configuration().clearable\" [class.right-8]=\"configuration().clearable\">\r\n    <ion-icon class=\"-mb-0.5\" name=\"chevron-up\"></ion-icon>\r\n    <ion-icon class=\"-mt-0.5\" name=\"chevron-down\"></ion-icon>\r\n  </div>\r\n  @if(configuration().clearable){\r\n    <ion-button class=\"absolute right-1 bottom-1\" (click)=\"Clear($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n      <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n    </ion-button>\r\n  } \r\n\r\n  <div class=\"loading-container\" [class.loading]=\"loading() || loadingFromLoader\">\r\n    <ion-spinner></ion-spinner>\r\n  </div>\r\n</div>\r\n\r\n<ion-modal #modal (ionModalWillPresent)=\"OnPresent()\" (didDismiss)=\"OnDismiss()\" style=\"--width: 90%; --height: 90%;\" [keepContentsMounted]=\"true\">\r\n  <ng-template>\r\n    <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n  </ng-template>\r\n</ion-modal>\r\n\r\n<sion-popover \r\n    #popover \r\n    [width]=\"inputContainer.offsetWidth + 'px'\" \r\n    (onWillPresent)=\"OnPresent()\" \r\n    (onDidDismiss)=\"OnDismiss()\" \r\n    [anchor]=\"inputContainer\" \r\n    [placement]=\"configuration().popoverConfiguration.placement\" \r\n    [flip]=\"configuration().popoverConfiguration.flip\"\r\n  >\r\n  <ng-container [ngTemplateOutlet]=\"selectContentTemplate\"></ng-container>\r\n</sion-popover>\r\n\r\n<ng-template #selectContentTemplate>\r\n  <div #selectContent class=\"select-content\">\r\n    <div class=\"select-search-bar-container\">\r\n      <div class=\"select-search-bar-icon-container !border-r-0 border-primary/70 bg-primary/70 shrink-0\">\r\n        <ion-icon color=\"dark\" name=\"search\"></ion-icon>\r\n      </div>\r\n      <input #inputSearchBar tabindex=\"-1\" class=\"select-search-bar border-primary/70 !rounded-l-none\" [formControl]=\"searchBarControl\"/>\r\n    </div> \r\n    <ul class=\"select-item-list mask-y\" role=\"listbox\" [attr.aria-activedescendant]=\"'sion-is-' + selectedIndex\">\r\n      @if(floatingVisible){\r\n        @for (item of lstOptions; track item.value) { \r\n            <ng-container \r\n              [ngTemplateOutlet]=\"baseOptionTemplate\"\r\n              [ngTemplateOutletContext]=\"{ item: item, index: $index }\">\r\n            </ng-container>\r\n          }\r\n        }\r\n    </ul>\r\n    @if(isServiceAtivo()){\r\n      <div class=\"w-full text-xs flex items-center justify-end\">\r\n        <ion-checkbox [ngModel]=\"somenteAtivos()\" (ngModelChange)=\"somenteAtivos.set($event)\" class=\"scale-75\"> Somente ativos </ion-checkbox>\r\n      </div>\r\n    }\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #baseOptionTemplate let-item=\"item\" let-index=\"index\">\r\n  <li [id]=\"'sion-is-' + index\" class=\"select-item\" [class.disabled]=\"item.disabled\" [attr.aria-selected]=\"index == selectedIndex\" (mouseenter)=\"selectedIndex = index\" (click)=\"Select(item)\">\r\n    <div class=\"select-item-checkmark-conteiner\">\r\n      @if(item.selected) {\r\n        <ion-icon class=\"select-item-checkmark\" color=\"primary\" name=\"checkmark\"></ion-icon>\r\n      }\r\n    </div>\r\n    @if (optionTemplate) {\r\n      <ng-container \r\n        [ngTemplateOutlet]=\"optionTemplate\"\r\n        [ngTemplateOutletContext]=\"{ item: item.item }\">\r\n      </ng-container>\r\n    }\r\n    @else {\r\n      <span class=\"select-item-label\"> {{item.label}} </span>\r\n    }\r\n  </li>\r\n</ng-template>"]}
|