valtech-components 2.0.145 → 2.0.147
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.
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
// modal-select.component.ts
|
|
2
1
|
import { CommonModule } from '@angular/common';
|
|
3
2
|
import { Component, inject, Input, ViewChild } from '@angular/core';
|
|
4
3
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
@@ -24,30 +23,50 @@ export class SelectSearchComponent {
|
|
|
24
23
|
this.displayValue = '';
|
|
25
24
|
}
|
|
26
25
|
ngOnInit() {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
this.filteredItems = [...this.props.options];
|
|
32
|
-
}
|
|
26
|
+
this.initializeItems();
|
|
27
|
+
this.syncControlValueWithSelectedItems();
|
|
33
28
|
this.updateDisplayValue();
|
|
34
29
|
}
|
|
30
|
+
ngOnChanges(changes) {
|
|
31
|
+
// Detectar cuando cambian las opciones
|
|
32
|
+
if (changes['props'] && this.props?.options) {
|
|
33
|
+
this.initializeItems();
|
|
34
|
+
this.syncControlValueWithSelectedItems();
|
|
35
|
+
this.updateDisplayValue();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
35
38
|
ionViewWillEnter() {
|
|
39
|
+
this.initializeItems();
|
|
40
|
+
this.syncControlValueWithSelectedItems();
|
|
41
|
+
this.updateDisplayValue();
|
|
42
|
+
}
|
|
43
|
+
initializeItems() {
|
|
36
44
|
if (this.props?.options) {
|
|
37
45
|
this.filteredItems = [...this.props.options];
|
|
38
46
|
}
|
|
39
47
|
else {
|
|
40
|
-
this.filteredItems = [
|
|
48
|
+
this.filteredItems = [];
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
syncControlValueWithSelectedItems() {
|
|
52
|
+
// Sincronizar el valor del control con los elementos seleccionados
|
|
53
|
+
if (this.props?.control?.value) {
|
|
54
|
+
const controlValue = this.props.control.value;
|
|
55
|
+
const selectedOption = this.props.options?.find(opt => opt[this.valueProperty] === controlValue);
|
|
56
|
+
if (selectedOption) {
|
|
57
|
+
this.selectedItems = [selectedOption];
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.selectedItems = [];
|
|
61
|
+
}
|
|
41
62
|
}
|
|
42
|
-
this.updateDisplayValue();
|
|
43
63
|
}
|
|
44
64
|
onFilter(event) {
|
|
45
|
-
console.log('onFilter: ', event);
|
|
46
65
|
if (!event) {
|
|
47
|
-
this.filteredItems = [...this.props.options];
|
|
66
|
+
this.filteredItems = this.props?.options ? [...this.props.options] : [];
|
|
48
67
|
return;
|
|
49
68
|
}
|
|
50
|
-
if (this.props.options.length === 0) {
|
|
69
|
+
if (!this.props?.options || this.props.options.length === 0) {
|
|
51
70
|
return;
|
|
52
71
|
}
|
|
53
72
|
const text = replaceSpecialChars(event.toLowerCase());
|
|
@@ -58,14 +77,13 @@ export class SelectSearchComponent {
|
|
|
58
77
|
}
|
|
59
78
|
return false;
|
|
60
79
|
});
|
|
61
|
-
console.log('filter: ', filter);
|
|
62
80
|
this.filteredItems = filter;
|
|
63
81
|
}
|
|
64
82
|
onFocus() {
|
|
65
|
-
console.log('onFocus
|
|
83
|
+
console.log('onFocus');
|
|
66
84
|
}
|
|
67
85
|
onBlur() {
|
|
68
|
-
console.log('onBlur
|
|
86
|
+
console.log('onBlur');
|
|
69
87
|
}
|
|
70
88
|
openModal() {
|
|
71
89
|
if (this.modal) {
|
|
@@ -120,15 +138,20 @@ export class SelectSearchComponent {
|
|
|
120
138
|
}
|
|
121
139
|
}
|
|
122
140
|
applyChanges() {
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
141
|
+
if (!this.props?.control) {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
if (this.selectedItems.length > 0) {
|
|
145
|
+
this.props.control.setValue(this.selectedItems[0][this.valueProperty]);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.props.control.setValue(null);
|
|
149
|
+
}
|
|
128
150
|
this.props.control.updateValueAndValidity();
|
|
151
|
+
this.props.control.markAsDirty();
|
|
129
152
|
}
|
|
130
153
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
131
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectSearchComponent, isStandalone: true, selector: "val-select-search", inputs: { label: "label", labelProperty: "labelProperty", valueProperty: "valueProperty", multiple: "multiple", placeholder: "placeholder", props: "props" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["modal"], descendants: true }], ngImport: i0, template: `
|
|
154
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectSearchComponent, isStandalone: true, selector: "val-select-search", inputs: { label: "label", labelProperty: "labelProperty", valueProperty: "valueProperty", multiple: "multiple", placeholder: "placeholder", props: "props" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["modal"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
132
155
|
<ion-input
|
|
133
156
|
type="text"
|
|
134
157
|
[value]="displayValue"
|
|
@@ -223,4 +246,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
223
246
|
}], props: [{
|
|
224
247
|
type: Input
|
|
225
248
|
}] } });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/select-search/select-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["// modal-select.component.ts\nimport { CommonModule } from '@angular/common';\nimport { Component, inject, Input, ViewChild } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule, IonModal } from '@ionic/angular';\nimport { IconService } from '../../../services/icons.service';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\nimport { ViewWillEnter } from '@ionic/angular/standalone';\n\n@Component({\n  selector: 'val-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, SearchbarComponent, ReactiveFormsModule],\n  template: `\n    <ion-input\n      type=\"text\"\n      [value]=\"displayValue\"\n      [placeholder]=\"props?.placeholder || placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input style=\"position: absolute;\" [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\n    <ion-modal #modal trigger=\"open-modal\" [initialBreakpoint]=\"0.75\" [breakpoints]=\"[0, 0.5, 0.75, 1]\">\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>{{ label }}</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"cancelModal()\">Cancelar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n          <ion-toolbar>\n            <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n          </ion-toolbar>\n        </ion-header>\n        <ion-content>\n          <ion-list>\n            <ion-item *ngFor=\"let item of filteredItems\" button (click)=\"selectItem(item)\" detail=\"false\">\n              <ion-label>{{ item[labelProperty] }}</ion-label>\n              <ion-icon *ngIf=\"isItemSelected(item)\" name=\"checkmark-outline\" slot=\"end\" color=\"primary\"></ion-icon>\n            </ion-item>\n            <ion-item *ngIf=\"filteredItems.length === 0\">\n              <ion-label color=\"medium\">No se encontraron resultados</ion-label>\n            </ion-item>\n          </ion-list>\n        </ion-content>\n      </ng-template>\n    </ion-modal>\n  `,\n  styles: [``],\n})\nexport class SelectSearchComponent implements ViewWillEnter {\n  @ViewChild('modal') modal!: IonModal;\n\n  @Input() label: string = 'Seleccionar';\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() multiple: boolean = false;\n  @Input() placeholder: string = 'Seleccione una opción';\n  @Input() props: InputMetadata;\n\n  icon = inject(IconService);\n\n  searchTerm: string = '';\n  filteredItems: InputOption[] = [];\n  selectedItems: InputOption[] = [];\n  displayValue: string = '';\n\n  ngOnInit() {\n    if (this.props?.options) {\n      this.filteredItems = [...this.props.options];\n    } else {\n      this.filteredItems = [...this.props.options];\n    }\n\n    this.updateDisplayValue();\n  }\n\n  ionViewWillEnter(): void {\n    if (this.props?.options) {\n      this.filteredItems = [...this.props.options];\n    } else {\n      this.filteredItems = [...this.props.options];\n    }\n\n    this.updateDisplayValue();\n  }\n\n  onFilter(event) {\n    console.log('onFilter: ', event);\n\n    if (!event) {\n      this.filteredItems = [...this.props.options];\n      return;\n    }\n    if (this.props.options.length === 0) {\n      return;\n    }\n    const text = replaceSpecialChars(event.toLowerCase());\n    const filter = this.props.options.filter(element => {\n      const values = Object.values(element).map((a: string) => replaceSpecialChars(`${a}`).toLocaleLowerCase());\n      if (values.some((value: string) => value.indexOf(text) > -1)) {\n        return true;\n      }\n      return false;\n    });\n    console.log('filter: ', filter);\n    this.filteredItems = filter;\n  }\n\n  onFocus() {\n    console.log('onFocus: ');\n  }\n\n  onBlur() {\n    console.log('onBlur: ');\n  }\n\n  openModal() {\n    if (this.modal) {\n      this.modal.present();\n    }\n  }\n\n  preventDefaultBehavior(event: MouseEvent) {\n    event.preventDefault(); // Evita el comportamiento predeterminado del selector\n    event.stopPropagation(); // Detiene la propagación del evento\n    this.openModal();\n  }\n\n  cancelModal() {\n    if (this.modal) {\n      this.modal.dismiss();\n    }\n  }\n\n  selectItem(item: any) {\n    if (this.multiple) {\n      const index = this.selectedItems.findIndex(\n        selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n      );\n\n      if (index === -1) {\n        this.selectedItems.push(item);\n      } else {\n        this.selectedItems.splice(index, 1);\n      }\n    } else {\n      this.selectedItems = [item];\n      this.cancelModal();\n    }\n\n    this.updateDisplayValue();\n    this.applyChanges();\n  }\n\n  isItemSelected(item: any): boolean {\n    return this.selectedItems.some(selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]);\n  }\n\n  updateDisplayValue() {\n    if (this.selectedItems.length === 0) {\n      this.displayValue = '';\n      return;\n    }\n\n    if (this.multiple) {\n      if (this.selectedItems.length === 1) {\n        this.displayValue = this.selectedItems[0][this.labelProperty];\n      } else {\n        this.displayValue = `${this.selectedItems.length} elementos seleccionados`;\n      }\n    } else {\n      this.displayValue = this.selectedItems[0][this.labelProperty];\n    }\n  }\n\n  applyChanges() {\n    console.log('applyChanges: ', this.selectedItems);\n    // if (this.props.control.invalid) {\n    //   return;\n    // }\n\n    this.props.control.setValue(this.selectedItems[0].id);\n    this.props.control.updateValueAndValidity();\n  }\n}\n"]}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/select-search/select-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, inject, Input, OnChanges, SimpleChanges, ViewChild } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule, IonModal } from '@ionic/angular';\nimport { ViewWillEnter } from '@ionic/angular/standalone';\nimport { IconService } from '../../../services/icons.service';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\n@Component({\n  selector: 'val-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, SearchbarComponent, ReactiveFormsModule],\n  template: `\n    <ion-input\n      type=\"text\"\n      [value]=\"displayValue\"\n      [placeholder]=\"props?.placeholder || placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input style=\"position: absolute;\" [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\n    <ion-modal #modal trigger=\"open-modal\" [initialBreakpoint]=\"0.75\" [breakpoints]=\"[0, 0.5, 0.75, 1]\">\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>{{ label }}</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"cancelModal()\">Cancelar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n          <ion-toolbar>\n            <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n          </ion-toolbar>\n        </ion-header>\n        <ion-content>\n          <ion-list>\n            <ion-item *ngFor=\"let item of filteredItems\" button (click)=\"selectItem(item)\" detail=\"false\">\n              <ion-label>{{ item[labelProperty] }}</ion-label>\n              <ion-icon *ngIf=\"isItemSelected(item)\" name=\"checkmark-outline\" slot=\"end\" color=\"primary\"></ion-icon>\n            </ion-item>\n            <ion-item *ngIf=\"filteredItems.length === 0\">\n              <ion-label color=\"medium\">No se encontraron resultados</ion-label>\n            </ion-item>\n          </ion-list>\n        </ion-content>\n      </ng-template>\n    </ion-modal>\n  `,\n  styles: [``],\n})\nexport class SelectSearchComponent implements ViewWillEnter, OnChanges {\n  @ViewChild('modal') modal!: IonModal;\n\n  @Input() label: string = 'Seleccionar';\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() multiple: boolean = false;\n  @Input() placeholder: string = 'Seleccione una opción';\n  @Input() props: InputMetadata;\n\n  icon = inject(IconService);\n\n  searchTerm: string = '';\n  filteredItems: InputOption[] = [];\n  selectedItems: InputOption[] = [];\n  displayValue: string = '';\n\n  ngOnInit() {\n    this.initializeItems();\n    this.syncControlValueWithSelectedItems();\n    this.updateDisplayValue();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Detectar cuando cambian las opciones\n    if (changes['props'] && this.props?.options) {\n      this.initializeItems();\n      this.syncControlValueWithSelectedItems();\n      this.updateDisplayValue();\n    }\n  }\n\n  ionViewWillEnter(): void {\n    this.initializeItems();\n    this.syncControlValueWithSelectedItems();\n    this.updateDisplayValue();\n  }\n\n  private initializeItems(): void {\n    if (this.props?.options) {\n      this.filteredItems = [...this.props.options];\n    } else {\n      this.filteredItems = [];\n    }\n  }\n\n  private syncControlValueWithSelectedItems(): void {\n    // Sincronizar el valor del control con los elementos seleccionados\n    if (this.props?.control?.value) {\n      const controlValue = this.props.control.value;\n      const selectedOption = this.props.options?.find(opt => opt[this.valueProperty] === controlValue);\n\n      if (selectedOption) {\n        this.selectedItems = [selectedOption];\n      } else {\n        this.selectedItems = [];\n      }\n    }\n  }\n\n  onFilter(event) {\n    if (!event) {\n      this.filteredItems = this.props?.options ? [...this.props.options] : [];\n      return;\n    }\n\n    if (!this.props?.options || this.props.options.length === 0) {\n      return;\n    }\n\n    const text = replaceSpecialChars(event.toLowerCase());\n    const filter = this.props.options.filter(element => {\n      const values = Object.values(element).map((a: string) => replaceSpecialChars(`${a}`).toLocaleLowerCase());\n      if (values.some((value: string) => value.indexOf(text) > -1)) {\n        return true;\n      }\n      return false;\n    });\n\n    this.filteredItems = filter;\n  }\n\n  onFocus() {\n    console.log('onFocus');\n  }\n\n  onBlur() {\n    console.log('onBlur');\n  }\n\n  openModal() {\n    if (this.modal) {\n      this.modal.present();\n    }\n  }\n\n  preventDefaultBehavior(event: MouseEvent) {\n    event.preventDefault(); // Evita el comportamiento predeterminado del selector\n    event.stopPropagation(); // Detiene la propagación del evento\n    this.openModal();\n  }\n\n  cancelModal() {\n    if (this.modal) {\n      this.modal.dismiss();\n    }\n  }\n\n  selectItem(item: any) {\n    if (this.multiple) {\n      const index = this.selectedItems.findIndex(\n        selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n      );\n\n      if (index === -1) {\n        this.selectedItems.push(item);\n      } else {\n        this.selectedItems.splice(index, 1);\n      }\n    } else {\n      this.selectedItems = [item];\n      this.cancelModal();\n    }\n\n    this.updateDisplayValue();\n    this.applyChanges();\n  }\n\n  isItemSelected(item: any): boolean {\n    return this.selectedItems.some(selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]);\n  }\n\n  updateDisplayValue() {\n    if (this.selectedItems.length === 0) {\n      this.displayValue = '';\n      return;\n    }\n\n    if (this.multiple) {\n      if (this.selectedItems.length === 1) {\n        this.displayValue = this.selectedItems[0][this.labelProperty];\n      } else {\n        this.displayValue = `${this.selectedItems.length} elementos seleccionados`;\n      }\n    } else {\n      this.displayValue = this.selectedItems[0][this.labelProperty];\n    }\n  }\n\n  applyChanges() {\n    if (!this.props?.control) {\n      return;\n    }\n\n    if (this.selectedItems.length > 0) {\n      this.props.control.setValue(this.selectedItems[0][this.valueProperty]);\n    } else {\n      this.props.control.setValue(null);\n    }\n\n    this.props.control.updateValueAndValidity();\n    this.props.control.markAsDirty();\n  }\n}\n"]}
|
|
@@ -2124,7 +2124,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
2124
2124
|
type: Output
|
|
2125
2125
|
}] } });
|
|
2126
2126
|
|
|
2127
|
-
// modal-select.component.ts
|
|
2128
2127
|
class SelectSearchComponent {
|
|
2129
2128
|
constructor() {
|
|
2130
2129
|
this.label = 'Seleccionar';
|
|
@@ -2139,30 +2138,50 @@ class SelectSearchComponent {
|
|
|
2139
2138
|
this.displayValue = '';
|
|
2140
2139
|
}
|
|
2141
2140
|
ngOnInit() {
|
|
2142
|
-
|
|
2143
|
-
|
|
2144
|
-
}
|
|
2145
|
-
else {
|
|
2146
|
-
this.filteredItems = [...this.props.options];
|
|
2147
|
-
}
|
|
2141
|
+
this.initializeItems();
|
|
2142
|
+
this.syncControlValueWithSelectedItems();
|
|
2148
2143
|
this.updateDisplayValue();
|
|
2149
2144
|
}
|
|
2145
|
+
ngOnChanges(changes) {
|
|
2146
|
+
// Detectar cuando cambian las opciones
|
|
2147
|
+
if (changes['props'] && this.props?.options) {
|
|
2148
|
+
this.initializeItems();
|
|
2149
|
+
this.syncControlValueWithSelectedItems();
|
|
2150
|
+
this.updateDisplayValue();
|
|
2151
|
+
}
|
|
2152
|
+
}
|
|
2150
2153
|
ionViewWillEnter() {
|
|
2154
|
+
this.initializeItems();
|
|
2155
|
+
this.syncControlValueWithSelectedItems();
|
|
2156
|
+
this.updateDisplayValue();
|
|
2157
|
+
}
|
|
2158
|
+
initializeItems() {
|
|
2151
2159
|
if (this.props?.options) {
|
|
2152
2160
|
this.filteredItems = [...this.props.options];
|
|
2153
2161
|
}
|
|
2154
2162
|
else {
|
|
2155
|
-
this.filteredItems = [
|
|
2163
|
+
this.filteredItems = [];
|
|
2164
|
+
}
|
|
2165
|
+
}
|
|
2166
|
+
syncControlValueWithSelectedItems() {
|
|
2167
|
+
// Sincronizar el valor del control con los elementos seleccionados
|
|
2168
|
+
if (this.props?.control?.value) {
|
|
2169
|
+
const controlValue = this.props.control.value;
|
|
2170
|
+
const selectedOption = this.props.options?.find(opt => opt[this.valueProperty] === controlValue);
|
|
2171
|
+
if (selectedOption) {
|
|
2172
|
+
this.selectedItems = [selectedOption];
|
|
2173
|
+
}
|
|
2174
|
+
else {
|
|
2175
|
+
this.selectedItems = [];
|
|
2176
|
+
}
|
|
2156
2177
|
}
|
|
2157
|
-
this.updateDisplayValue();
|
|
2158
2178
|
}
|
|
2159
2179
|
onFilter(event) {
|
|
2160
|
-
console.log('onFilter: ', event);
|
|
2161
2180
|
if (!event) {
|
|
2162
|
-
this.filteredItems = [...this.props.options];
|
|
2181
|
+
this.filteredItems = this.props?.options ? [...this.props.options] : [];
|
|
2163
2182
|
return;
|
|
2164
2183
|
}
|
|
2165
|
-
if (this.props.options.length === 0) {
|
|
2184
|
+
if (!this.props?.options || this.props.options.length === 0) {
|
|
2166
2185
|
return;
|
|
2167
2186
|
}
|
|
2168
2187
|
const text = replaceSpecialChars(event.toLowerCase());
|
|
@@ -2173,14 +2192,13 @@ class SelectSearchComponent {
|
|
|
2173
2192
|
}
|
|
2174
2193
|
return false;
|
|
2175
2194
|
});
|
|
2176
|
-
console.log('filter: ', filter);
|
|
2177
2195
|
this.filteredItems = filter;
|
|
2178
2196
|
}
|
|
2179
2197
|
onFocus() {
|
|
2180
|
-
console.log('onFocus
|
|
2198
|
+
console.log('onFocus');
|
|
2181
2199
|
}
|
|
2182
2200
|
onBlur() {
|
|
2183
|
-
console.log('onBlur
|
|
2201
|
+
console.log('onBlur');
|
|
2184
2202
|
}
|
|
2185
2203
|
openModal() {
|
|
2186
2204
|
if (this.modal) {
|
|
@@ -2235,15 +2253,20 @@ class SelectSearchComponent {
|
|
|
2235
2253
|
}
|
|
2236
2254
|
}
|
|
2237
2255
|
applyChanges() {
|
|
2238
|
-
|
|
2239
|
-
|
|
2240
|
-
|
|
2241
|
-
|
|
2242
|
-
|
|
2256
|
+
if (!this.props?.control) {
|
|
2257
|
+
return;
|
|
2258
|
+
}
|
|
2259
|
+
if (this.selectedItems.length > 0) {
|
|
2260
|
+
this.props.control.setValue(this.selectedItems[0][this.valueProperty]);
|
|
2261
|
+
}
|
|
2262
|
+
else {
|
|
2263
|
+
this.props.control.setValue(null);
|
|
2264
|
+
}
|
|
2243
2265
|
this.props.control.updateValueAndValidity();
|
|
2266
|
+
this.props.control.markAsDirty();
|
|
2244
2267
|
}
|
|
2245
2268
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2246
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectSearchComponent, isStandalone: true, selector: "val-select-search", inputs: { label: "label", labelProperty: "labelProperty", valueProperty: "valueProperty", multiple: "multiple", placeholder: "placeholder", props: "props" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["modal"], descendants: true }], ngImport: i0, template: `
|
|
2269
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectSearchComponent, isStandalone: true, selector: "val-select-search", inputs: { label: "label", labelProperty: "labelProperty", valueProperty: "valueProperty", multiple: "multiple", placeholder: "placeholder", props: "props" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["modal"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
2247
2270
|
<ion-input
|
|
2248
2271
|
type="text"
|
|
2249
2272
|
[value]="displayValue"
|