valtech-components 2.0.105 → 2.0.107

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.
@@ -2,7 +2,7 @@
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { Component, Input } from '@angular/core';
4
4
  import { ReactiveFormsModule } from '@angular/forms';
5
- import { IonButton, IonButtons, IonContent, IonFooter, IonHeader, IonInput, IonItem, IonLabel, IonList, IonModal, IonRadio, IonTitle, IonToolbar, } from '@ionic/angular/standalone';
5
+ import { IonButton, IonButtons, IonContent, IonFooter, IonHeader, IonInput, IonItem, IonLabel, IonList, IonModal, IonRadio, IonSelect, IonTitle, IonToolbar, } from '@ionic/angular/standalone';
6
6
  import { replaceSpecialChars } from '../../../shared/utils/text';
7
7
  import { SearchbarComponent } from '../searchbar/searchbar.component';
8
8
  import * as i0 from "@angular/core";
@@ -23,9 +23,15 @@ export class SelectorModalComponent {
23
23
  this.selection = -1;
24
24
  this.showAllAtStart = true;
25
25
  this.searching = false;
26
+ this.isModalOpen = false;
26
27
  this.listVolatile = [];
27
28
  this.noResult = SEARCH_SELECTOR_NO_RESULT;
28
29
  this.noNothing = SEARCH_SELECTOR_NO_OPTIONS;
30
+ this.customModalOptions = {
31
+ header: 'Seleccione',
32
+ breakpoints: [0, 0.6],
33
+ initialBreakpoint: 0.6,
34
+ };
29
35
  }
30
36
  ngOnInit() {
31
37
  this.listVolatile = [];
@@ -34,9 +40,7 @@ export class SelectorModalComponent {
34
40
  }
35
41
  }
36
42
  dismiss() {
37
- this.modalController.dismiss({
38
- confirmed: false,
39
- });
43
+ this.toggleModal(false);
40
44
  }
41
45
  applyChanges() {
42
46
  console.log(this.props.control);
@@ -80,11 +84,36 @@ export class SelectorModalComponent {
80
84
  }
81
85
  return '';
82
86
  }
87
+ toggleModal(isOpen) {
88
+ this.isModalOpen = isOpen;
89
+ }
90
+ preventDefaultBehavior(event) {
91
+ event.preventDefault(); // Evita el comportamiento predeterminado del selector
92
+ event.stopPropagation(); // Detiene la propagación del evento
93
+ this.toggleModal(!this.isModalOpen); // Abre el modal personalizado
94
+ }
83
95
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorModalComponent, deps: [{ token: i1.ModalController }], target: i0.ɵɵFactoryTarget.Component }); }
84
96
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectorModalComponent, isStandalone: true, selector: "val-search-selector-input", inputs: { props: "props", selection: "selection", showAllAtStart: "showAllAtStart" }, ngImport: i0, template: `
85
- <ion-input id="select-search-option-action" [value]="showSelected()" [placeholder]="props.placeholder" readonly>
86
- </ion-input>
87
- <ion-modal trigger="select-search-option-action" #modal>
97
+ <!-- <ion-select
98
+ id="select-search-option-action"
99
+ [formControl]="props.control"
100
+ [label]="props.label"
101
+ [interfaceOptions]="customModalOptions"
102
+ interface="popover"
103
+ [placeholder]="[props.placeholder]"
104
+ cancelText="Cancelar"
105
+ okText="Ok"
106
+ (mousedown)="preventDefaultBehavior($event)"
107
+ >
108
+ </ion-select> -->
109
+ <ion-input
110
+ [formControl]="props.control"
111
+ type="text"
112
+ [placeholder]="props.placeholder"
113
+ readonly
114
+ (mousedown)="preventDefaultBehavior($event)"
115
+ ></ion-input>
116
+ <ion-modal #modal [isOpen]="isModalOpen">
88
117
  <ng-template>
89
118
  <ion-header>
90
119
  <ion-toolbar>
@@ -135,10 +164,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
135
164
  SearchbarComponent,
136
165
  IonModal,
137
166
  IonInput,
167
+ IonSelect,
138
168
  ], template: `
139
- <ion-input id="select-search-option-action" [value]="showSelected()" [placeholder]="props.placeholder" readonly>
140
- </ion-input>
141
- <ion-modal trigger="select-search-option-action" #modal>
169
+ <!-- <ion-select
170
+ id="select-search-option-action"
171
+ [formControl]="props.control"
172
+ [label]="props.label"
173
+ [interfaceOptions]="customModalOptions"
174
+ interface="popover"
175
+ [placeholder]="[props.placeholder]"
176
+ cancelText="Cancelar"
177
+ okText="Ok"
178
+ (mousedown)="preventDefaultBehavior($event)"
179
+ >
180
+ </ion-select> -->
181
+ <ion-input
182
+ [formControl]="props.control"
183
+ type="text"
184
+ [placeholder]="props.placeholder"
185
+ readonly
186
+ (mousedown)="preventDefaultBehavior($event)"
187
+ ></ion-input>
188
+ <ion-modal #modal [isOpen]="isModalOpen">
142
189
  <ng-template>
143
190
  <ion-header>
144
191
  <ion-toolbar>
@@ -176,4 +223,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
176
223
  }], showAllAtStart: [{
177
224
  type: Input
178
225
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-selector-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/search-selector-input/search-selector-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport { CommonModule } from '@angular/common';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { ModalController } from '@ionic/angular';\nimport {\n  IonButton,\n  IonButtons,\n  IonContent,\n  IonFooter,\n  IonHeader,\n  IonInput,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonModal,\n  IonRadio,\n  IonTitle,\n  IonToolbar,\n} from '@ionic/angular/standalone';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\nexport const SEARCH_SELECTOR_NO_RESULT = {\n  title: 'No se encontraron resultados',\n  subtitle: 'Intenta con otras palabras.',\n};\n\nexport const SEARCH_SELECTOR_NO_OPTIONS = {\n  title: 'No hay opciones',\n  subtitle: 'El campo seleccionado no tiene opciones. Intenta nuevamente más tarde.',\n};\n\n@Component({\n  selector: 'val-search-selector-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    IonHeader,\n    IonToolbar,\n    IonTitle,\n    IonButtons,\n    IonButton,\n    IonFooter,\n    IonList,\n    IonContent,\n    IonItem,\n    IonLabel,\n    IonRadio,\n    SearchbarComponent,\n    IonModal,\n    IonInput,\n  ],\n  template: `\n    <ion-input id=\"select-search-option-action\" [value]=\"showSelected()\" [placeholder]=\"props.placeholder\" readonly>\n    </ion-input>\n    <ion-modal trigger=\"select-search-option-action\" #modal>\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>Seleccione</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"dismiss()\">Cancelar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n        </ion-header>\n\n        <ion-content>\n          <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n\n          <div class=\"unit-list-container\" *ngIf=\"listVolatile.length > 0\">\n            <ion-list class=\"unit-list\">\n              <ion-radio-group allow-empty-selection [formControl]=\"props.control\">\n                <ion-item *ngFor=\"let option of listVolatile\">\n                  <ion-radio justify=\"space-between\" color=\"primary\" [value]=\"option.id\">{{ option.name }}</ion-radio>\n                </ion-item>\n              </ion-radio-group>\n            </ion-list>\n          </div>\n        </ion-content>\n        <ion-footer style=\"display: flex;justify-content: space-around;padding: 8px 0px;\">\n          <ion-button color=\"dark\" shape=\"round\" fill=\"outline\" (click)=\"dismiss()\"> Cancelar </ion-button>\n          <ion-button color=\"primary\" shape=\"round\" (click)=\"applyChanges()\"> Confirmar </ion-button>\n        </ion-footer>\n      </ng-template>\n    </ion-modal>\n  `,\n  styleUrls: ['./search-selector-input.component.scss'],\n})\nexport class SelectorModalComponent implements OnInit {\n  @Input() props: InputMetadata;\n\n  @Input() selection = -1;\n\n  @Input() showAllAtStart = true;\n\n  searching = false;\n\n  listVolatile: InputOption[] = [];\n\n  noResult = SEARCH_SELECTOR_NO_RESULT;\n  noNothing = SEARCH_SELECTOR_NO_OPTIONS;\n\n  constructor(public modalController: ModalController) {}\n\n  ngOnInit() {\n    this.listVolatile = [];\n\n    if (this.showAllAtStart) {\n      this.listVolatile = this.props.options;\n    }\n  }\n\n  dismiss() {\n    this.modalController.dismiss({\n      confirmed: false,\n    });\n  }\n\n  applyChanges() {\n    console.log(this.props.control);\n    if (this.props.control.invalid) {\n      return;\n    }\n\n    this.modalController.dismiss({\n      confirmed: true,\n    });\n  }\n\n  onFilter(event: string) {\n    console.log('💡 onSearch::: ', event);\n    if (!event) {\n      this.listVolatile = this.props.options;\n      return;\n    }\n    if (this.listVolatile.length === 0) {\n      return;\n    }\n    const text = replaceSpecialChars(event.toLowerCase());\n    const filter = this.listVolatile.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.listVolatile = filter;\n  }\n\n  onBlur() {\n    this.searching = false;\n  }\n\n  onFocus() {\n    this.searching = true;\n  }\n\n  showSelected(): string {\n    const option = this.props.options.find(x => x.id === this.props.control.value);\n    if (option) {\n      return option.name;\n    }\n    return '';\n  }\n}\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-selector-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/search-selector-input/search-selector-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport { CommonModule } from '@angular/common';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { ModalController } from '@ionic/angular';\nimport {\n  IonButton,\n  IonButtons,\n  IonContent,\n  IonFooter,\n  IonHeader,\n  IonInput,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonModal,\n  IonRadio,\n  IonSelect,\n  IonTitle,\n  IonToolbar,\n} from '@ionic/angular/standalone';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\nexport const SEARCH_SELECTOR_NO_RESULT = {\n  title: 'No se encontraron resultados',\n  subtitle: 'Intenta con otras palabras.',\n};\n\nexport const SEARCH_SELECTOR_NO_OPTIONS = {\n  title: 'No hay opciones',\n  subtitle: 'El campo seleccionado no tiene opciones. Intenta nuevamente más tarde.',\n};\n\n@Component({\n  selector: 'val-search-selector-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    IonHeader,\n    IonToolbar,\n    IonTitle,\n    IonButtons,\n    IonButton,\n    IonFooter,\n    IonList,\n    IonContent,\n    IonItem,\n    IonLabel,\n    IonRadio,\n    SearchbarComponent,\n    IonModal,\n    IonInput,\n    IonSelect,\n  ],\n  template: `\n    <!-- <ion-select\n      id=\"select-search-option-action\"\n      [formControl]=\"props.control\"\n      [label]=\"props.label\"\n      [interfaceOptions]=\"customModalOptions\"\n      interface=\"popover\"\n      [placeholder]=\"[props.placeholder]\"\n      cancelText=\"Cancelar\"\n      okText=\"Ok\"\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    >\n    </ion-select> -->\n    <ion-input\n      [formControl]=\"props.control\"\n      type=\"text\"\n      [placeholder]=\"props.placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    ></ion-input>\n    <ion-modal #modal [isOpen]=\"isModalOpen\">\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>Seleccione</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"dismiss()\">Cancelar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n        </ion-header>\n\n        <ion-content>\n          <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n\n          <div class=\"unit-list-container\" *ngIf=\"listVolatile.length > 0\">\n            <ion-list class=\"unit-list\">\n              <ion-radio-group allow-empty-selection [formControl]=\"props.control\">\n                <ion-item *ngFor=\"let option of listVolatile\">\n                  <ion-radio justify=\"space-between\" color=\"primary\" [value]=\"option.id\">{{ option.name }}</ion-radio>\n                </ion-item>\n              </ion-radio-group>\n            </ion-list>\n          </div>\n        </ion-content>\n        <ion-footer style=\"display: flex;justify-content: space-around;padding: 8px 0px;\">\n          <ion-button color=\"dark\" shape=\"round\" fill=\"outline\" (click)=\"dismiss()\"> Cancelar </ion-button>\n          <ion-button color=\"primary\" shape=\"round\" (click)=\"applyChanges()\"> Confirmar </ion-button>\n        </ion-footer>\n      </ng-template>\n    </ion-modal>\n  `,\n  styleUrls: ['./search-selector-input.component.scss'],\n})\nexport class SelectorModalComponent implements OnInit {\n  @Input() props: InputMetadata;\n\n  @Input() selection = -1;\n\n  @Input() showAllAtStart = true;\n\n  searching = false;\n  isModalOpen = false;\n\n  listVolatile: InputOption[] = [];\n\n  noResult = SEARCH_SELECTOR_NO_RESULT;\n  noNothing = SEARCH_SELECTOR_NO_OPTIONS;\n\n  customModalOptions = {\n    header: 'Seleccione',\n    breakpoints: [0, 0.6],\n    initialBreakpoint: 0.6,\n  };\n\n  constructor(public modalController: ModalController) {}\n\n  ngOnInit() {\n    this.listVolatile = [];\n\n    if (this.showAllAtStart) {\n      this.listVolatile = this.props.options;\n    }\n  }\n\n  dismiss() {\n    this.toggleModal(false);\n  }\n\n  applyChanges() {\n    console.log(this.props.control);\n    if (this.props.control.invalid) {\n      return;\n    }\n\n    this.modalController.dismiss({\n      confirmed: true,\n    });\n  }\n\n  onFilter(event: string) {\n    console.log('💡 onSearch::: ', event);\n    if (!event) {\n      this.listVolatile = this.props.options;\n      return;\n    }\n    if (this.listVolatile.length === 0) {\n      return;\n    }\n    const text = replaceSpecialChars(event.toLowerCase());\n    const filter = this.listVolatile.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.listVolatile = filter;\n  }\n\n  onBlur() {\n    this.searching = false;\n  }\n\n  onFocus() {\n    this.searching = true;\n  }\n\n  showSelected(): string {\n    const option = this.props.options.find(x => x.id === this.props.control.value);\n    if (option) {\n      return option.name;\n    }\n    return '';\n  }\n\n  toggleModal(isOpen) {\n    this.isModalOpen = isOpen;\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.toggleModal(!this.isModalOpen); // Abre el modal personalizado\n  }\n}\n"]}
@@ -2132,9 +2132,15 @@ class SelectorModalComponent {
2132
2132
  this.selection = -1;
2133
2133
  this.showAllAtStart = true;
2134
2134
  this.searching = false;
2135
+ this.isModalOpen = false;
2135
2136
  this.listVolatile = [];
2136
2137
  this.noResult = SEARCH_SELECTOR_NO_RESULT;
2137
2138
  this.noNothing = SEARCH_SELECTOR_NO_OPTIONS;
2139
+ this.customModalOptions = {
2140
+ header: 'Seleccione',
2141
+ breakpoints: [0, 0.6],
2142
+ initialBreakpoint: 0.6,
2143
+ };
2138
2144
  }
2139
2145
  ngOnInit() {
2140
2146
  this.listVolatile = [];
@@ -2143,9 +2149,7 @@ class SelectorModalComponent {
2143
2149
  }
2144
2150
  }
2145
2151
  dismiss() {
2146
- this.modalController.dismiss({
2147
- confirmed: false,
2148
- });
2152
+ this.toggleModal(false);
2149
2153
  }
2150
2154
  applyChanges() {
2151
2155
  console.log(this.props.control);
@@ -2189,11 +2193,36 @@ class SelectorModalComponent {
2189
2193
  }
2190
2194
  return '';
2191
2195
  }
2196
+ toggleModal(isOpen) {
2197
+ this.isModalOpen = isOpen;
2198
+ }
2199
+ preventDefaultBehavior(event) {
2200
+ event.preventDefault(); // Evita el comportamiento predeterminado del selector
2201
+ event.stopPropagation(); // Detiene la propagación del evento
2202
+ this.toggleModal(!this.isModalOpen); // Abre el modal personalizado
2203
+ }
2192
2204
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorModalComponent, deps: [{ token: i1$3.ModalController }], target: i0.ɵɵFactoryTarget.Component }); }
2193
2205
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectorModalComponent, isStandalone: true, selector: "val-search-selector-input", inputs: { props: "props", selection: "selection", showAllAtStart: "showAllAtStart" }, ngImport: i0, template: `
2194
- <ion-input id="select-search-option-action" [value]="showSelected()" [placeholder]="props.placeholder" readonly>
2195
- </ion-input>
2196
- <ion-modal trigger="select-search-option-action" #modal>
2206
+ <!-- <ion-select
2207
+ id="select-search-option-action"
2208
+ [formControl]="props.control"
2209
+ [label]="props.label"
2210
+ [interfaceOptions]="customModalOptions"
2211
+ interface="popover"
2212
+ [placeholder]="[props.placeholder]"
2213
+ cancelText="Cancelar"
2214
+ okText="Ok"
2215
+ (mousedown)="preventDefaultBehavior($event)"
2216
+ >
2217
+ </ion-select> -->
2218
+ <ion-input
2219
+ [formControl]="props.control"
2220
+ type="text"
2221
+ [placeholder]="props.placeholder"
2222
+ readonly
2223
+ (mousedown)="preventDefaultBehavior($event)"
2224
+ ></ion-input>
2225
+ <ion-modal #modal [isOpen]="isModalOpen">
2197
2226
  <ng-template>
2198
2227
  <ion-header>
2199
2228
  <ion-toolbar>
@@ -2244,10 +2273,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2244
2273
  SearchbarComponent,
2245
2274
  IonModal,
2246
2275
  IonInput,
2276
+ IonSelect,
2247
2277
  ], template: `
2248
- <ion-input id="select-search-option-action" [value]="showSelected()" [placeholder]="props.placeholder" readonly>
2249
- </ion-input>
2250
- <ion-modal trigger="select-search-option-action" #modal>
2278
+ <!-- <ion-select
2279
+ id="select-search-option-action"
2280
+ [formControl]="props.control"
2281
+ [label]="props.label"
2282
+ [interfaceOptions]="customModalOptions"
2283
+ interface="popover"
2284
+ [placeholder]="[props.placeholder]"
2285
+ cancelText="Cancelar"
2286
+ okText="Ok"
2287
+ (mousedown)="preventDefaultBehavior($event)"
2288
+ >
2289
+ </ion-select> -->
2290
+ <ion-input
2291
+ [formControl]="props.control"
2292
+ type="text"
2293
+ [placeholder]="props.placeholder"
2294
+ readonly
2295
+ (mousedown)="preventDefaultBehavior($event)"
2296
+ ></ion-input>
2297
+ <ion-modal #modal [isOpen]="isModalOpen">
2251
2298
  <ng-template>
2252
2299
  <ion-header>
2253
2300
  <ion-toolbar>