valtech-components 2.0.133 → 2.0.135

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.
@@ -48,14 +48,14 @@ export class SelectorModalComponent {
48
48
  onFilter(event) {
49
49
  console.log('💡 onSearch::: ', event);
50
50
  if (!event) {
51
- this.listVolatile = this.props.options;
51
+ this.props.options = this.listVolatile;
52
52
  return;
53
53
  }
54
- if (this.listVolatile.length === 0) {
54
+ if (this.props.options.length === 0) {
55
55
  return;
56
56
  }
57
57
  const text = replaceSpecialChars(event.toLowerCase());
58
- const filter = this.listVolatile.filter(element => {
58
+ const filter = this.props.options.filter(element => {
59
59
  const values = Object.values(element).map((a) => replaceSpecialChars(`${a}`).toLocaleLowerCase());
60
60
  if (values.some((value) => value.indexOf(text) > -1)) {
61
61
  return true;
@@ -63,7 +63,7 @@ export class SelectorModalComponent {
63
63
  return false;
64
64
  });
65
65
  console.log('filter: ', filter);
66
- this.listVolatile = filter;
66
+ this.props.options = filter;
67
67
  }
68
68
  onBlur() {
69
69
  this.searching = false;
@@ -72,6 +72,9 @@ export class SelectorModalComponent {
72
72
  this.searching = true;
73
73
  }
74
74
  showSelected() {
75
+ if (!this.props.control) {
76
+ return '';
77
+ }
75
78
  const option = this.props.options.find(x => x.id === this.props.control.value);
76
79
  if (option) {
77
80
  return option.name;
@@ -124,10 +127,10 @@ export class SelectorModalComponent {
124
127
  <ion-content>
125
128
  <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
126
129
 
127
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
130
+ <div class="unit-list-container" *ngIf="props.options.length > 0">
128
131
  <ion-list class="unit-list">
129
132
  <ion-radio-group allow-empty-selection [(ngModel)]="selectedOption">
130
- <ion-item *ngFor="let option of listVolatile">
133
+ <ion-item *ngFor="let option of props.options">
131
134
  <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
132
135
  </ion-item>
133
136
  </ion-radio-group>
@@ -201,10 +204,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
201
204
  <ion-content>
202
205
  <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
203
206
 
204
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
207
+ <div class="unit-list-container" *ngIf="props.options.length > 0">
205
208
  <ion-list class="unit-list">
206
209
  <ion-radio-group allow-empty-selection [(ngModel)]="selectedOption">
207
- <ion-item *ngFor="let option of listVolatile">
210
+ <ion-item *ngFor="let option of props.options">
208
211
  <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
209
212
  </ion-item>
210
213
  </ion-radio-group>
@@ -225,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
225
228
  }], showAllAtStart: [{
226
229
  type: Input
227
230
  }] } });
228
- //# 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 { FormsModule, NgModel, ReactiveFormsModule } from '@angular/forms';\nimport {\n  IonButton,\n  IonButtons,\n  IonContent,\n  IonFooter,\n  IonHeader,\n  IonInput,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonModal,\n  IonRadio,\n  IonRadioGroup,\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    FormsModule,\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    IonRadioGroup,\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      type=\"text\"\n      [value]=\"showSelected()\"\n      [placeholder]=\"props.placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\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 [(ngModel)]=\"selectedOption\">\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  selectedOption = '';\n\n  constructor() {}\n\n  ngOnInit() {\n    this.listVolatile = this.props.options;\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.props.control.setValue(this.selectedOption);\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"]}
231
+ //# 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 { FormsModule, NgModel, ReactiveFormsModule } from '@angular/forms';\nimport {\n  IonButton,\n  IonButtons,\n  IonContent,\n  IonFooter,\n  IonHeader,\n  IonInput,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonModal,\n  IonRadio,\n  IonRadioGroup,\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    FormsModule,\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    IonRadioGroup,\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      type=\"text\"\n      [value]=\"showSelected()\"\n      [placeholder]=\"props.placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\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=\"props.options.length > 0\">\n            <ion-list class=\"unit-list\">\n              <ion-radio-group allow-empty-selection [(ngModel)]=\"selectedOption\">\n                <ion-item *ngFor=\"let option of props.options\">\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  selectedOption = '';\n\n  constructor() {}\n\n  ngOnInit() {\n    this.listVolatile = this.props.options;\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.props.control.setValue(this.selectedOption);\n  }\n\n  onFilter(event: string) {\n    console.log('💡 onSearch::: ', event);\n    if (!event) {\n      this.props.options = this.listVolatile;\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.props.options = filter;\n  }\n\n  onBlur() {\n    this.searching = false;\n  }\n\n  onFocus() {\n    this.searching = true;\n  }\n\n  showSelected(): string {\n    if (!this.props.control) {\n      return '';\n    }\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"]}
@@ -2162,14 +2162,14 @@ class SelectorModalComponent {
2162
2162
  onFilter(event) {
2163
2163
  console.log('💡 onSearch::: ', event);
2164
2164
  if (!event) {
2165
- this.listVolatile = this.props.options;
2165
+ this.props.options = this.listVolatile;
2166
2166
  return;
2167
2167
  }
2168
- if (this.listVolatile.length === 0) {
2168
+ if (this.props.options.length === 0) {
2169
2169
  return;
2170
2170
  }
2171
2171
  const text = replaceSpecialChars(event.toLowerCase());
2172
- const filter = this.listVolatile.filter(element => {
2172
+ const filter = this.props.options.filter(element => {
2173
2173
  const values = Object.values(element).map((a) => replaceSpecialChars(`${a}`).toLocaleLowerCase());
2174
2174
  if (values.some((value) => value.indexOf(text) > -1)) {
2175
2175
  return true;
@@ -2177,7 +2177,7 @@ class SelectorModalComponent {
2177
2177
  return false;
2178
2178
  });
2179
2179
  console.log('filter: ', filter);
2180
- this.listVolatile = filter;
2180
+ this.props.options = filter;
2181
2181
  }
2182
2182
  onBlur() {
2183
2183
  this.searching = false;
@@ -2186,6 +2186,9 @@ class SelectorModalComponent {
2186
2186
  this.searching = true;
2187
2187
  }
2188
2188
  showSelected() {
2189
+ if (!this.props.control) {
2190
+ return '';
2191
+ }
2189
2192
  const option = this.props.options.find(x => x.id === this.props.control.value);
2190
2193
  if (option) {
2191
2194
  return option.name;
@@ -2238,10 +2241,10 @@ class SelectorModalComponent {
2238
2241
  <ion-content>
2239
2242
  <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2240
2243
 
2241
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2244
+ <div class="unit-list-container" *ngIf="props.options.length > 0">
2242
2245
  <ion-list class="unit-list">
2243
2246
  <ion-radio-group allow-empty-selection [(ngModel)]="selectedOption">
2244
- <ion-item *ngFor="let option of listVolatile">
2247
+ <ion-item *ngFor="let option of props.options">
2245
2248
  <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2246
2249
  </ion-item>
2247
2250
  </ion-radio-group>
@@ -2315,10 +2318,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2315
2318
  <ion-content>
2316
2319
  <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2317
2320
 
2318
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2321
+ <div class="unit-list-container" *ngIf="props.options.length > 0">
2319
2322
  <ion-list class="unit-list">
2320
2323
  <ion-radio-group allow-empty-selection [(ngModel)]="selectedOption">
2321
- <ion-item *ngFor="let option of listVolatile">
2324
+ <ion-item *ngFor="let option of props.options">
2322
2325
  <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2323
2326
  </ion-item>
2324
2327
  </ion-radio-group>