valtech-components 2.0.104 → 2.0.105

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,9 +2,9 @@
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, IonItem, IonLabel, IonList, IonRadio, IonTitle, IonToolbar, } from '@ionic/angular/standalone';
6
- import { SearchbarComponent } from '../searchbar/searchbar.component';
5
+ import { IonButton, IonButtons, IonContent, IonFooter, IonHeader, IonInput, IonItem, IonLabel, IonList, IonModal, IonRadio, IonTitle, IonToolbar, } from '@ionic/angular/standalone';
7
6
  import { replaceSpecialChars } from '../../../shared/utils/text';
7
+ import { SearchbarComponent } from '../searchbar/searchbar.component';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@ionic/angular";
10
10
  import * as i2 from "@angular/common";
@@ -73,35 +73,48 @@ export class SelectorModalComponent {
73
73
  onFocus() {
74
74
  this.searching = true;
75
75
  }
76
+ showSelected() {
77
+ const option = this.props.options.find(x => x.id === this.props.control.value);
78
+ if (option) {
79
+ return option.name;
80
+ }
81
+ return '';
82
+ }
76
83
  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 }); }
77
84
  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: `
78
- <ion-header>
79
- <ion-toolbar>
80
- <ion-title>Seleccione</ion-title>
81
- <ion-buttons slot="end">
82
- <ion-button (click)="dismiss()">Cancelar</ion-button>
83
- </ion-buttons>
84
- </ion-toolbar>
85
- </ion-header>
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>
88
+ <ng-template>
89
+ <ion-header>
90
+ <ion-toolbar>
91
+ <ion-title>Seleccione</ion-title>
92
+ <ion-buttons slot="end">
93
+ <ion-button (click)="dismiss()">Cancelar</ion-button>
94
+ </ion-buttons>
95
+ </ion-toolbar>
96
+ </ion-header>
86
97
 
87
- <ion-content>
88
- <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
98
+ <ion-content>
99
+ <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
89
100
 
90
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
91
- <ion-list class="unit-list">
92
- <ion-radio-group allow-empty-selection [formControl]="props.control">
93
- <ion-item *ngFor="let option of listVolatile">
94
- <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
95
- </ion-item>
96
- </ion-radio-group>
97
- </ion-list>
98
- </div>
99
- </ion-content>
100
- <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
101
- <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
102
- <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
103
- </ion-footer>
104
- `, isInline: true, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: 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: IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: SearchbarComponent, selector: "val-searchbar", inputs: ["disabled"], outputs: ["focusEvent", "blurEvent", "filterEvent"] }] }); }
101
+ <div class="unit-list-container" *ngIf="listVolatile.length > 0">
102
+ <ion-list class="unit-list">
103
+ <ion-radio-group allow-empty-selection [formControl]="props.control">
104
+ <ion-item *ngFor="let option of listVolatile">
105
+ <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
106
+ </ion-item>
107
+ </ion-radio-group>
108
+ </ion-list>
109
+ </div>
110
+ </ion-content>
111
+ <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
112
+ <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
113
+ <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
114
+ </ion-footer>
115
+ </ng-template>
116
+ </ion-modal>
117
+ `, isInline: true, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: 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: IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: SearchbarComponent, selector: "val-searchbar", inputs: ["disabled"], outputs: ["focusEvent", "blurEvent", "filterEvent"] }, { kind: "component", type: IonModal, selector: "ion-modal" }, { kind: "component", type: IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "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", "size", "spellcheck", "step", "type", "value"] }] }); }
105
118
  }
106
119
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorModalComponent, decorators: [{
107
120
  type: Component,
@@ -120,33 +133,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
120
133
  IonLabel,
121
134
  IonRadio,
122
135
  SearchbarComponent,
136
+ IonModal,
137
+ IonInput,
123
138
  ], template: `
124
- <ion-header>
125
- <ion-toolbar>
126
- <ion-title>Seleccione</ion-title>
127
- <ion-buttons slot="end">
128
- <ion-button (click)="dismiss()">Cancelar</ion-button>
129
- </ion-buttons>
130
- </ion-toolbar>
131
- </ion-header>
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>
142
+ <ng-template>
143
+ <ion-header>
144
+ <ion-toolbar>
145
+ <ion-title>Seleccione</ion-title>
146
+ <ion-buttons slot="end">
147
+ <ion-button (click)="dismiss()">Cancelar</ion-button>
148
+ </ion-buttons>
149
+ </ion-toolbar>
150
+ </ion-header>
132
151
 
133
- <ion-content>
134
- <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
152
+ <ion-content>
153
+ <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
135
154
 
136
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
137
- <ion-list class="unit-list">
138
- <ion-radio-group allow-empty-selection [formControl]="props.control">
139
- <ion-item *ngFor="let option of listVolatile">
140
- <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
141
- </ion-item>
142
- </ion-radio-group>
143
- </ion-list>
144
- </div>
145
- </ion-content>
146
- <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
147
- <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
148
- <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
149
- </ion-footer>
155
+ <div class="unit-list-container" *ngIf="listVolatile.length > 0">
156
+ <ion-list class="unit-list">
157
+ <ion-radio-group allow-empty-selection [formControl]="props.control">
158
+ <ion-item *ngFor="let option of listVolatile">
159
+ <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
160
+ </ion-item>
161
+ </ion-radio-group>
162
+ </ion-list>
163
+ </div>
164
+ </ion-content>
165
+ <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
166
+ <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
167
+ <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
168
+ </ion-footer>
169
+ </ng-template>
170
+ </ion-modal>
150
171
  `, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"] }]
151
172
  }], ctorParameters: () => [{ type: i1.ModalController }], propDecorators: { props: [{
152
173
  type: Input
@@ -155,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
155
176
  }], showAllAtStart: [{
156
177
  type: Input
157
178
  }] } });
158
- //# 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 { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { IonicModule, ModalController } from '@ionic/angular';\nimport {\n  IonButton,\n  IonButtons,\n  IonContent,\n  IonFooter,\n  IonHeader,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonRadio,\n  IonTitle,\n  IonToolbar,\n} from '@ionic/angular/standalone';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\nimport { InputMetadata, InputOption } from '../../types';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\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  ],\n  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  `,\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"]}
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"]}
@@ -2057,6 +2057,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2057
2057
  type: Input
2058
2058
  }] } });
2059
2059
 
2060
+ const replaceSpecialChars = (text) => text.normalize('NFD').replace(/[\u0300-\u036f]/g, '');
2061
+
2060
2062
  class SearchbarComponent {
2061
2063
  constructor() {
2062
2064
  this.focusEvent = new EventEmitter();
@@ -2115,8 +2117,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2115
2117
  type: Output
2116
2118
  }] } });
2117
2119
 
2118
- const replaceSpecialChars = (text) => text.normalize('NFD').replace(/[\u0300-\u036f]/g, '');
2119
-
2120
2120
  /* eslint-disable @typescript-eslint/naming-convention */
2121
2121
  const SEARCH_SELECTOR_NO_RESULT = {
2122
2122
  title: 'No se encontraron resultados',
@@ -2182,35 +2182,48 @@ class SelectorModalComponent {
2182
2182
  onFocus() {
2183
2183
  this.searching = true;
2184
2184
  }
2185
+ showSelected() {
2186
+ const option = this.props.options.find(x => x.id === this.props.control.value);
2187
+ if (option) {
2188
+ return option.name;
2189
+ }
2190
+ return '';
2191
+ }
2185
2192
  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 }); }
2186
2193
  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: `
2187
- <ion-header>
2188
- <ion-toolbar>
2189
- <ion-title>Seleccione</ion-title>
2190
- <ion-buttons slot="end">
2191
- <ion-button (click)="dismiss()">Cancelar</ion-button>
2192
- </ion-buttons>
2193
- </ion-toolbar>
2194
- </ion-header>
2195
-
2196
- <ion-content>
2197
- <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2198
-
2199
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2200
- <ion-list class="unit-list">
2201
- <ion-radio-group allow-empty-selection [formControl]="props.control">
2202
- <ion-item *ngFor="let option of listVolatile">
2203
- <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2204
- </ion-item>
2205
- </ion-radio-group>
2206
- </ion-list>
2207
- </div>
2208
- </ion-content>
2209
- <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
2210
- <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
2211
- <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
2212
- </ion-footer>
2213
- `, isInline: true, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: 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: IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: SearchbarComponent, selector: "val-searchbar", inputs: ["disabled"], outputs: ["focusEvent", "blurEvent", "filterEvent"] }] }); }
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>
2197
+ <ng-template>
2198
+ <ion-header>
2199
+ <ion-toolbar>
2200
+ <ion-title>Seleccione</ion-title>
2201
+ <ion-buttons slot="end">
2202
+ <ion-button (click)="dismiss()">Cancelar</ion-button>
2203
+ </ion-buttons>
2204
+ </ion-toolbar>
2205
+ </ion-header>
2206
+
2207
+ <ion-content>
2208
+ <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2209
+
2210
+ <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2211
+ <ion-list class="unit-list">
2212
+ <ion-radio-group allow-empty-selection [formControl]="props.control">
2213
+ <ion-item *ngFor="let option of listVolatile">
2214
+ <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2215
+ </ion-item>
2216
+ </ion-radio-group>
2217
+ </ion-list>
2218
+ </div>
2219
+ </ion-content>
2220
+ <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
2221
+ <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
2222
+ <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
2223
+ </ion-footer>
2224
+ </ng-template>
2225
+ </ion-modal>
2226
+ `, isInline: true, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: 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: IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: SearchbarComponent, selector: "val-searchbar", inputs: ["disabled"], outputs: ["focusEvent", "blurEvent", "filterEvent"] }, { kind: "component", type: IonModal, selector: "ion-modal" }, { kind: "component", type: IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "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", "size", "spellcheck", "step", "type", "value"] }] }); }
2214
2227
  }
2215
2228
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorModalComponent, decorators: [{
2216
2229
  type: Component,
@@ -2229,33 +2242,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2229
2242
  IonLabel,
2230
2243
  IonRadio,
2231
2244
  SearchbarComponent,
2245
+ IonModal,
2246
+ IonInput,
2232
2247
  ], template: `
2233
- <ion-header>
2234
- <ion-toolbar>
2235
- <ion-title>Seleccione</ion-title>
2236
- <ion-buttons slot="end">
2237
- <ion-button (click)="dismiss()">Cancelar</ion-button>
2238
- </ion-buttons>
2239
- </ion-toolbar>
2240
- </ion-header>
2241
-
2242
- <ion-content>
2243
- <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2244
-
2245
- <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2246
- <ion-list class="unit-list">
2247
- <ion-radio-group allow-empty-selection [formControl]="props.control">
2248
- <ion-item *ngFor="let option of listVolatile">
2249
- <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2250
- </ion-item>
2251
- </ion-radio-group>
2252
- </ion-list>
2253
- </div>
2254
- </ion-content>
2255
- <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
2256
- <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
2257
- <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
2258
- </ion-footer>
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>
2251
+ <ng-template>
2252
+ <ion-header>
2253
+ <ion-toolbar>
2254
+ <ion-title>Seleccione</ion-title>
2255
+ <ion-buttons slot="end">
2256
+ <ion-button (click)="dismiss()">Cancelar</ion-button>
2257
+ </ion-buttons>
2258
+ </ion-toolbar>
2259
+ </ion-header>
2260
+
2261
+ <ion-content>
2262
+ <val-searchbar (filterEvent)="onFilter($event)" (focusEvent)="onFocus()" (blurEvent)="onBlur()" />
2263
+
2264
+ <div class="unit-list-container" *ngIf="listVolatile.length > 0">
2265
+ <ion-list class="unit-list">
2266
+ <ion-radio-group allow-empty-selection [formControl]="props.control">
2267
+ <ion-item *ngFor="let option of listVolatile">
2268
+ <ion-radio justify="space-between" color="primary" [value]="option.id">{{ option.name }}</ion-radio>
2269
+ </ion-item>
2270
+ </ion-radio-group>
2271
+ </ion-list>
2272
+ </div>
2273
+ </ion-content>
2274
+ <ion-footer style="display: flex;justify-content: space-around;padding: 8px 0px;">
2275
+ <ion-button color="dark" shape="round" fill="outline" (click)="dismiss()"> Cancelar </ion-button>
2276
+ <ion-button color="primary" shape="round" (click)="applyChanges()"> Confirmar </ion-button>
2277
+ </ion-footer>
2278
+ </ng-template>
2279
+ </ion-modal>
2259
2280
  `, styles: [".form-element{margin-top:1rem;text-align:start}x .form-element:last-child{margin-bottom:2rem}.small-form{min-width:7.5rem;max-width:7.5rem}.sibling{margin-left:.5rem}ion-modal{--width: 290px;--height: 382px;--border-radius: 8px}ion-modal ion-datetime{height:382px}.filter-container{display:flex;margin-left:1rem}.filter-form{padding:0 .25rem 6.25rem}.options-container{margin-bottom:1rem}.unit-list-container{overflow-y:auto}.unit-list{padding-bottom:1rem;margin-bottom:.5rem}.detail-title{font-size:1.125rem;line-height:1.5rem;font-weight:700;margin:0;margin-bottom:.5rem;margin-left:.625rem;font-weight:800}@media (min-width: 768px){.detail-title{font-size:1.5rem;line-height:2rem}}.button-section{width:98%;height:3.75rem;border-radius:.5rem;margin:0 auto;padding:0 .25rem;max-width:36.25rem;margin-top:2.5rem}.event-selector{width:90%;margin-left:1rem}.selectable-container{margin-bottom:1rem}\n"] }]
2260
2281
  }], ctorParameters: () => [{ type: i1$3.ModalController }], propDecorators: { props: [{
2261
2282
  type: Input