@rosoftlab/ionic 1.0.0-alpha-0

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.
Files changed (48) hide show
  1. package/README.md +27 -0
  2. package/esm2022/lib/components/index.mjs +4 -0
  3. package/esm2022/lib/components/rsl-ionic-crud.component/rsl-ionic-crud.component.mjs +266 -0
  4. package/esm2022/lib/components/rsl-ionic-data-table/rsl-ionic-data-table.component.mjs +292 -0
  5. package/esm2022/lib/components/rsl-ionic-grid/rsl-ionic-grid.component.mjs +269 -0
  6. package/esm2022/lib/decorators/index.mjs +3 -0
  7. package/esm2022/lib/decorators/ionic-datatable-layout.mjs +10 -0
  8. package/esm2022/lib/decorators/ionic-list.decorator.mjs +9 -0
  9. package/esm2022/lib/interfaces/index.mjs +2 -0
  10. package/esm2022/lib/interfaces/ionic-list-layout-config.mjs +2 -0
  11. package/esm2022/lib/ionic-dialog.service.mjs +51 -0
  12. package/esm2022/lib/rsl-ionic-module.module.mjs +86 -0
  13. package/esm2022/lib/translate.extension.mjs +48 -0
  14. package/esm2022/lib/types/index.mjs +2 -0
  15. package/esm2022/lib/types/repeat/repeat-section.type.mjs +135 -0
  16. package/esm2022/lib/validators/index.mjs +2 -0
  17. package/esm2022/lib/validators/must-match.mjs +12 -0
  18. package/esm2022/lib/wrappers/accordion-wrapper.component.mjs +50 -0
  19. package/esm2022/lib/wrappers/index.mjs +3 -0
  20. package/esm2022/lib/wrappers/panel-wrapper.component.mjs +37 -0
  21. package/esm2022/lib/wrappers/wrappers.module.mjs +56 -0
  22. package/esm2022/public-api.mjs +12 -0
  23. package/esm2022/rosoftlab-ionic.mjs +5 -0
  24. package/fesm2022/rosoftlab-ionic.mjs +1251 -0
  25. package/fesm2022/rosoftlab-ionic.mjs.map +1 -0
  26. package/index.d.ts +5 -0
  27. package/lib/components/index.d.ts +3 -0
  28. package/lib/components/rsl-ionic-crud.component/rsl-ionic-crud.component.d.ts +69 -0
  29. package/lib/components/rsl-ionic-data-table/rsl-ionic-data-table.component.d.ts +66 -0
  30. package/lib/components/rsl-ionic-grid/rsl-ionic-grid.component.d.ts +58 -0
  31. package/lib/decorators/index.d.ts +2 -0
  32. package/lib/decorators/ionic-datatable-layout.d.ts +7 -0
  33. package/lib/decorators/ionic-list.decorator.d.ts +2 -0
  34. package/lib/interfaces/index.d.ts +1 -0
  35. package/lib/interfaces/ionic-list-layout-config.d.ts +8 -0
  36. package/lib/ionic-dialog.service.d.ts +10 -0
  37. package/lib/rsl-ionic-module.module.d.ts +13 -0
  38. package/lib/translate.extension.d.ts +17 -0
  39. package/lib/types/index.d.ts +1 -0
  40. package/lib/types/repeat/repeat-section.type.d.ts +51 -0
  41. package/lib/validators/index.d.ts +1 -0
  42. package/lib/validators/must-match.d.ts +6 -0
  43. package/lib/wrappers/accordion-wrapper.component.d.ts +6 -0
  44. package/lib/wrappers/index.d.ts +2 -0
  45. package/lib/wrappers/panel-wrapper.component.d.ts +6 -0
  46. package/lib/wrappers/wrappers.module.d.ts +13 -0
  47. package/package.json +31 -0
  48. package/public-api.d.ts +8 -0
@@ -0,0 +1,135 @@
1
+ import { Component, ElementRef, ViewChild } from '@angular/core';
2
+ import { FieldArrayType } from '@ngx-formly/core';
3
+ import { TranslateService } from '@ngx-translate/core';
4
+ import { getValueFromJsonData, readFileAsync } from '@rosoftlab/core';
5
+ import { FileSaverService } from 'ngx-filesaver';
6
+ import * as XLSX from 'xlsx';
7
+ import { IonicDialogService } from '../../ionic-dialog.service';
8
+ import { WrappersModule } from '../../wrappers/wrappers.module';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../ionic-dialog.service";
11
+ import * as i2 from "@ngx-translate/core";
12
+ import * as i3 from "ngx-filesaver";
13
+ import * as i4 from "@angular/common";
14
+ import * as i5 from "@ionic/angular";
15
+ import * as i6 from "@ngx-formly/core";
16
+ export class RepeatTypeComponent extends FieldArrayType {
17
+ constructor(dialogService, translate, fileSaverService) {
18
+ super();
19
+ this.dialogService = dialogService;
20
+ this.translate = translate;
21
+ this.fileSaverService = fileSaverService;
22
+ this.data = null;
23
+ this.serach = null;
24
+ this.showSerach = false;
25
+ this.filterValue = null;
26
+ this.importDataProp = null;
27
+ this.exportDataProp = null;
28
+ this.deleteMessage = this.translate.instant("General.Delete.Question");
29
+ this.deleteButton = this.translate.instant("General.Delete.Button");
30
+ this.cancelButton = this.translate.instant("General.Cancel.Button");
31
+ }
32
+ remove(i, { markAsDirty } = { markAsDirty: true }) {
33
+ this.dialogService.confirm(this.deleteMessage, null, this.deleteButton, this.cancelButton).then((value) => {
34
+ if (value.data) {
35
+ var onDelete = this.field.props['onDelete'];
36
+ if (onDelete) {
37
+ onDelete(this.field.fieldGroup[i].model).subscribe(() => {
38
+ super.remove(i);
39
+ });
40
+ }
41
+ super.remove(i);
42
+ }
43
+ });
44
+ }
45
+ ngOnInit() {
46
+ this.typeKey = this.field.key;
47
+ this.serach = this.props['search'];
48
+ this.exportDataProp = this.props['export'] || null;
49
+ this.importDataProp = this.props['import'] || null;
50
+ if (this.serach) {
51
+ this.showSerach = this.serach.showSerach;
52
+ }
53
+ }
54
+ postPopulate(field) {
55
+ if (this.showSerach) {
56
+ this.data = field.fieldGroup;
57
+ if (this.filterValue) {
58
+ this.field.fieldGroup = this.data.filter(f => f.formControl.value[this.serach.searchProp].toLowerCase().includes(this.filterValue));
59
+ }
60
+ }
61
+ }
62
+ handleChange(event) {
63
+ if (this.showSerach) {
64
+ if (this.data == null && this.field.fieldGroup !== null) {
65
+ this.data = this.field.fieldGroup;
66
+ }
67
+ this.filterValue = event.target.value.toLowerCase();
68
+ this.field.fieldGroup = this.data.filter(f => f.formControl.value[this.serach.searchProp].toLowerCase().includes(this.filterValue));
69
+ }
70
+ }
71
+ importData() {
72
+ this.fileInput.nativeElement.click();
73
+ }
74
+ async handleImportFile(event) {
75
+ const file = event.target.files[0];
76
+ if (file) {
77
+ try {
78
+ const fileContents = await readFileAsync(file);
79
+ // Handle the file contents here (e.g., display or process the data)
80
+ const wb = XLSX.read(fileContents); //, { type: 'binary' });
81
+ const wsname = wb.SheetNames[0];
82
+ const ws = wb.Sheets[wsname];
83
+ const excelData = XLSX.utils.sheet_to_json(ws); //, { header: 1 });
84
+ excelData.forEach(element => {
85
+ const jsonX = getValueFromJsonData(element, this.importDataProp.keyProp);
86
+ const idx = this.field.parent.model[this.typeKey].findIndex(f => f[this.importDataProp.keyProp] === jsonX);
87
+ if (idx >= 0) {
88
+ const existingdata = this.field.parent.model[this.typeKey][idx];
89
+ for (const prop of this.importDataProp.propertiesToImport) {
90
+ const jsonVal = getValueFromJsonData(element, prop);
91
+ if (existingdata[prop] !== jsonVal) {
92
+ var fieldControl = this.field.fieldGroup[idx].formControl;
93
+ fieldControl.controls[prop].setValue(jsonVal);
94
+ }
95
+ }
96
+ }
97
+ else {
98
+ super.add(null, element);
99
+ }
100
+ });
101
+ }
102
+ catch (error) {
103
+ console.error('Error reading the file:', error);
104
+ }
105
+ }
106
+ }
107
+ exportData() {
108
+ // Filter the data to include only the specified properties
109
+ const filteredData = this.field.parent.model[this.typeKey].map(item => {
110
+ const filteredItem = {};
111
+ for (const prop of this.exportDataProp.propertiesToExport) {
112
+ filteredItem[prop] = item[prop];
113
+ }
114
+ return filteredItem;
115
+ });
116
+ const ws = XLSX.utils.json_to_sheet(filteredData);
117
+ const wb = XLSX.utils.book_new();
118
+ XLSX.utils.book_append_sheet(wb, ws, this.exportDataProp.sheetName);
119
+ const excelBuffer = XLSX.write(wb, { bookType: 'xlsx', type: 'array' });
120
+ const blob = new Blob([excelBuffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
121
+ this.fileSaverService.save(blob, this.exportDataProp.fileName);
122
+ }
123
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: RepeatTypeComponent, deps: [{ token: i1.IonicDialogService }, { token: i2.TranslateService }, { token: i3.FileSaverService }], target: i0.ɵɵFactoryTarget.Component }); }
124
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: RepeatTypeComponent, isStandalone: true, selector: "formly-repeat-section", viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ion-header [translucent]=\"true\">\r\n <ion-toolbar>\r\n <ng-container [ngTemplateOutlet]=\"header\"></ng-container>\r\n </ion-toolbar>\r\n <ng-container [ngTemplateOutlet]=\"search\"></ng-container>\r\n</ion-header>\r\n\r\n<ng-template #header>\r\n <ion-title class=\"ion-text-left\">{{props.label}}</ion-title>\r\n\r\n <ion-button slot=\"end\" (click)=\"exportData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"exportDataProp\">\r\n <ion-icon name=\"cloud-download-outline\"></ion-icon>\r\n </ion-button>\r\n\r\n <ion-button slot=\"end\" (click)=\"importData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"importDataProp\">\r\n <ion-icon name=\"cloud-upload-outline\"></ion-icon>\r\n </ion-button>\r\n <input #fileInput type=\"file\" style=\"display: none\" accept=\".xlsx,.xls,.csv\" (change)=\"handleImportFile($event)\">\r\n\r\n <ion-button slot=\"end\" (click)=\"add()\" fill=\"clear\" [disabled]=\"props.disabled\">\r\n <ion-icon size=\"large\" name=\"add\"></ion-icon>\r\n </ion-button>\r\n</ng-template>\r\n\r\n\r\n<ion-list lines=\"full\">\r\n <ion-item *ngFor=\"let field of field.fieldGroup; let i = index\" class=\"row align-items-baseline\">\r\n <formly-field class=\"formly-ion-list-item\" [field]=\"field\"></formly-field>\r\n <ion-button [disabled]=\"props.disabled\" color=\"danger\" slot=\"end\" (click)='remove(i)'>\r\n <ion-icon slot=\"icon-only\" name=\"trash\"></ion-icon>\r\n </ion-button>\r\n </ion-item>\r\n</ion-list>\r\n\r\n\r\n<ng-template #search>\r\n <ion-toolbar *ngIf=\"showSerach\">\r\n <ion-searchbar [debounce]=\"1000\" (ionChange)=\"handleChange($event)\"></ion-searchbar>\r\n </ion-toolbar>\r\n</ng-template>", styles: [".formly-ion-list-item{display:inline;width:100%}\n"], dependencies: [{ kind: "ngmodule", type: WrappersModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.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: i5.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i5.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i5.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i5.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i5.IonSearchbar, selector: "ion-searchbar", inputs: ["animated", "autocomplete", "autocorrect", "cancelButtonIcon", "cancelButtonText", "clearIcon", "color", "debounce", "disabled", "enterkeyhint", "inputmode", "mode", "placeholder", "searchIcon", "showCancelButton", "showClearButton", "spellcheck", "type", "value"] }, { kind: "component", type: i5.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: i5.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "directive", type: i5.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }, { kind: "component", type: i6.FormlyField, selector: "formly-field", inputs: ["field"] }] }); }
125
+ }
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: RepeatTypeComponent, decorators: [{
127
+ type: Component,
128
+ args: [{ standalone: true, selector: 'formly-repeat-section', imports: [
129
+ WrappersModule
130
+ ], template: "<ion-header [translucent]=\"true\">\r\n <ion-toolbar>\r\n <ng-container [ngTemplateOutlet]=\"header\"></ng-container>\r\n </ion-toolbar>\r\n <ng-container [ngTemplateOutlet]=\"search\"></ng-container>\r\n</ion-header>\r\n\r\n<ng-template #header>\r\n <ion-title class=\"ion-text-left\">{{props.label}}</ion-title>\r\n\r\n <ion-button slot=\"end\" (click)=\"exportData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"exportDataProp\">\r\n <ion-icon name=\"cloud-download-outline\"></ion-icon>\r\n </ion-button>\r\n\r\n <ion-button slot=\"end\" (click)=\"importData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"importDataProp\">\r\n <ion-icon name=\"cloud-upload-outline\"></ion-icon>\r\n </ion-button>\r\n <input #fileInput type=\"file\" style=\"display: none\" accept=\".xlsx,.xls,.csv\" (change)=\"handleImportFile($event)\">\r\n\r\n <ion-button slot=\"end\" (click)=\"add()\" fill=\"clear\" [disabled]=\"props.disabled\">\r\n <ion-icon size=\"large\" name=\"add\"></ion-icon>\r\n </ion-button>\r\n</ng-template>\r\n\r\n\r\n<ion-list lines=\"full\">\r\n <ion-item *ngFor=\"let field of field.fieldGroup; let i = index\" class=\"row align-items-baseline\">\r\n <formly-field class=\"formly-ion-list-item\" [field]=\"field\"></formly-field>\r\n <ion-button [disabled]=\"props.disabled\" color=\"danger\" slot=\"end\" (click)='remove(i)'>\r\n <ion-icon slot=\"icon-only\" name=\"trash\"></ion-icon>\r\n </ion-button>\r\n </ion-item>\r\n</ion-list>\r\n\r\n\r\n<ng-template #search>\r\n <ion-toolbar *ngIf=\"showSerach\">\r\n <ion-searchbar [debounce]=\"1000\" (ionChange)=\"handleChange($event)\"></ion-searchbar>\r\n </ion-toolbar>\r\n</ng-template>", styles: [".formly-ion-list-item{display:inline;width:100%}\n"] }]
131
+ }], ctorParameters: function () { return [{ type: i1.IonicDialogService }, { type: i2.TranslateService }, { type: i3.FileSaverService }]; }, propDecorators: { fileInput: [{
132
+ type: ViewChild,
133
+ args: ['fileInput']
134
+ }] } });
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeat-section.type.js","sourceRoot":"","sources":["../../../../../../../projects/rosoftlab/ionic/src/lib/types/repeat/repeat-section.type.ts","../../../../../../../projects/rosoftlab/ionic/src/lib/types/repeat/repeat-section.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { FieldArrayType, FormlyFieldConfig } from '@ngx-formly/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { getValueFromJsonData, readFileAsync } from '@rosoftlab/core';\r\nimport { FileSaverService } from 'ngx-filesaver';\r\nimport * as XLSX from 'xlsx';\r\nimport { IonicDialogService } from '../../ionic-dialog.service';\r\nimport { WrappersModule } from '../../wrappers/wrappers.module';\r\n\r\ninterface SearchProp {\r\n  showSerach: boolean\r\n  searchProp: string\r\n}\r\ninterface ExportDataProp {\r\n  propertiesToExport: string[]\r\n  sheetName: string;\r\n  fileName: string;\r\n}\r\ninterface ImportDataProp {\r\n  keyProp: string\r\n  propertiesToImport: string[]\r\n}\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  standalone: true,\r\n  selector: 'formly-repeat-section',\r\n  templateUrl: './repeat-section.html',\r\n  styleUrls: ['./repeat-section.scss'],\r\n  imports: [\r\n    WrappersModule\r\n  ]\r\n})\r\nexport class RepeatTypeComponent extends FieldArrayType {\r\n  /**\r\n   *\r\n   */\r\n  @ViewChild('fileInput') fileInput: ElementRef;\r\n  data: FormlyFieldConfig[] = null;\r\n  serach: SearchProp = null;\r\n  showSerach: boolean = false;\r\n  deleteMessage: string\r\n  deleteButton: string\r\n  cancelButton: string\r\n  filterValue: string = null;\r\n  typeKey: string;\r\n  importDataProp: ImportDataProp = null;\r\n  exportDataProp: ExportDataProp = null;\r\n  constructor(\r\n    public dialogService: IonicDialogService,\r\n    public translate: TranslateService,\r\n    private fileSaverService: FileSaverService) {\r\n    super();\r\n    this.deleteMessage = this.translate.instant(\"General.Delete.Question\")\r\n    this.deleteButton = this.translate.instant(\"General.Delete.Button\")\r\n    this.cancelButton = this.translate.instant(\"General.Cancel.Button\")\r\n\r\n  }\r\n  override remove(i: number, { markAsDirty } = { markAsDirty: true }) {\r\n    this.dialogService.confirm(this.deleteMessage, null, this.deleteButton, this.cancelButton).then(\r\n      (value: any) => {\r\n        if (value.data) {\r\n          var onDelete = this.field.props['onDelete'];\r\n          if (onDelete) {\r\n            onDelete(this.field.fieldGroup[i].model).subscribe(\r\n              () => {\r\n                super.remove(i);\r\n              }\r\n            )\r\n          }\r\n          super.remove(i);\r\n        }\r\n      }\r\n    )\r\n  }\r\n  ngOnInit() {\r\n    this.typeKey = this.field.key as string\r\n    this.serach = this.props['search']\r\n    this.exportDataProp = this.props['export'] || null\r\n    this.importDataProp = this.props['import'] || null\r\n    if (this.serach) {\r\n      this.showSerach = this.serach.showSerach\r\n    }\r\n\r\n  }\r\n  postPopulate(field: any) {\r\n    if (this.showSerach) {\r\n      this.data = field.fieldGroup\r\n      if (this.filterValue) {\r\n        this.field.fieldGroup = this.data.filter(f => f.formControl.value[this.serach.searchProp].toLowerCase().includes(this.filterValue))\r\n      }\r\n    }\r\n  }\r\n  handleChange(event) {\r\n    if (this.showSerach) {\r\n      if (this.data == null && this.field.fieldGroup !== null) {\r\n        this.data = this.field.fieldGroup\r\n      }\r\n      this.filterValue = event.target.value.toLowerCase();\r\n      this.field.fieldGroup = this.data.filter(f => f.formControl.value[this.serach.searchProp].toLowerCase().includes(this.filterValue))\r\n    }\r\n  }\r\n  importData() {\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n  async handleImportFile(event: any) {\r\n    const file = event.target.files[0];\r\n\r\n    if (file) {\r\n      try {\r\n\r\n\r\n        const fileContents = await readFileAsync(file);\r\n        // Handle the file contents here (e.g., display or process the data)\r\n        const wb: XLSX.WorkBook = XLSX.read(fileContents)//, { type: 'binary' });\r\n        const wsname: string = wb.SheetNames[0];\r\n        const ws: XLSX.WorkSheet = wb.Sheets[wsname];\r\n        const excelData = XLSX.utils.sheet_to_json(ws)//, { header: 1 });\r\n        excelData.forEach(element => {\r\n          const jsonX = getValueFromJsonData(element, this.importDataProp.keyProp)\r\n          const idx = this.field.parent.model[this.typeKey].findIndex(f => f[this.importDataProp.keyProp] === jsonX)\r\n          if (idx >= 0) {\r\n            const existingdata = this.field.parent.model[this.typeKey][idx]\r\n            for (const prop of this.importDataProp.propertiesToImport) {\r\n              const jsonVal = getValueFromJsonData(element, prop)\r\n              if (existingdata[prop] !== jsonVal) {\r\n                var fieldControl = this.field.fieldGroup[idx].formControl as FormGroup\r\n                fieldControl.controls[prop].setValue(jsonVal)\r\n              }\r\n            }\r\n          } else {\r\n            super.add(null, element)\r\n          }\r\n        });\r\n\r\n      } catch (error) {\r\n        console.error('Error reading the file:', error);\r\n      }\r\n    }\r\n  }\r\n\r\n  exportData() {\r\n\r\n    // Filter the data to include only the specified properties\r\n    const filteredData = this.field.parent.model[this.typeKey].map(item => {\r\n      const filteredItem: any = {};\r\n      for (const prop of this.exportDataProp.propertiesToExport) {\r\n        filteredItem[prop] = item[prop];\r\n      }\r\n      return filteredItem;\r\n    });\r\n\r\n    const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet(filteredData);\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n    XLSX.utils.book_append_sheet(wb, ws, this.exportDataProp.sheetName);\r\n\r\n    const excelBuffer: any = XLSX.write(wb, { bookType: 'xlsx', type: 'array' });\r\n\r\n    const blob = new Blob([excelBuffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });\r\n    this.fileSaverService.save(blob, this.exportDataProp.fileName);\r\n  }\r\n\r\n  // getValueFromJsonData(jsonData: any, key: string): any {\r\n  //   // Convert the key and all JSON keys to lowercase\r\n  //   const lowercaseKey = key.toLowerCase();\r\n  //   const lowercaseKeys = Object.keys(jsonData).map(k => k.toLowerCase());\r\n\r\n  //   // Find the lowercase key in the lowercase keys array\r\n  //   const index = lowercaseKeys.indexOf(lowercaseKey);\r\n\r\n  //   // If found, use the original (proper case) key to access the value\r\n  //   if (index !== -1) {\r\n  //     const originalKey = Object.keys(jsonData)[index];\r\n  //     return jsonData[originalKey];\r\n  //   }\r\n\r\n  //   // Key not found\r\n  //   return undefined;\r\n  // }\r\n  // private readFileAsync(file: File): Promise<any> {\r\n  //   return new Promise<any>((resolve, reject) => {\r\n  //     const reader = new FileReader();\r\n\r\n  //     reader.onload = (event: any) => {\r\n  //       resolve(event.target.result);\r\n  //     };\r\n\r\n  //     reader.onerror = (event: any) => {\r\n  //       reject(event.target.error);\r\n  //     };\r\n\r\n  //     reader.readAsArrayBuffer(file);\r\n  //   });\r\n  // }\r\n}","<ion-header [translucent]=\"true\">\r\n  <ion-toolbar>\r\n    <ng-container [ngTemplateOutlet]=\"header\"></ng-container>\r\n  </ion-toolbar>\r\n  <ng-container [ngTemplateOutlet]=\"search\"></ng-container>\r\n</ion-header>\r\n\r\n<ng-template #header>\r\n  <ion-title class=\"ion-text-left\">{{props.label}}</ion-title>\r\n\r\n  <ion-button slot=\"end\" (click)=\"exportData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"exportDataProp\">\r\n    <ion-icon name=\"cloud-download-outline\"></ion-icon>\r\n  </ion-button>\r\n\r\n  <ion-button slot=\"end\" (click)=\"importData()\" fill=\"clear\" [disabled]=\"props.disabled\" *ngIf=\"importDataProp\">\r\n    <ion-icon name=\"cloud-upload-outline\"></ion-icon>\r\n  </ion-button>\r\n  <input #fileInput type=\"file\" style=\"display: none\" accept=\".xlsx,.xls,.csv\" (change)=\"handleImportFile($event)\">\r\n\r\n  <ion-button slot=\"end\" (click)=\"add()\" fill=\"clear\" [disabled]=\"props.disabled\">\r\n    <ion-icon size=\"large\" name=\"add\"></ion-icon>\r\n  </ion-button>\r\n</ng-template>\r\n\r\n\r\n<ion-list lines=\"full\">\r\n  <ion-item *ngFor=\"let field of field.fieldGroup; let i = index\" class=\"row align-items-baseline\">\r\n    <formly-field class=\"formly-ion-list-item\" [field]=\"field\"></formly-field>\r\n    <ion-button [disabled]=\"props.disabled\" color=\"danger\" slot=\"end\" (click)='remove(i)'>\r\n      <ion-icon slot=\"icon-only\" name=\"trash\"></ion-icon>\r\n    </ion-button>\r\n  </ion-item>\r\n</ion-list>\r\n\r\n\r\n<ng-template #search>\r\n  <ion-toolbar *ngIf=\"showSerach\">\r\n    <ion-searchbar [debounce]=\"1000\" (ionChange)=\"handleChange($event)\"></ion-searchbar>\r\n  </ion-toolbar>\r\n</ng-template>"]}
@@ -0,0 +1,2 @@
1
+ export * from './must-match';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvaW9uaWMvc3JjL2xpYi92YWxpZGF0b3JzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tdXN0LW1hdGNoJztcclxuIl19
@@ -0,0 +1,12 @@
1
+ export function fieldMatchValidator(control) {
2
+ const { password, confirmPassword } = control.value;
3
+ // avoid displaying the message error when values are empty
4
+ if (!confirmPassword || !password) {
5
+ return null;
6
+ }
7
+ if (confirmPassword === password) {
8
+ return null;
9
+ }
10
+ return { fieldMatch: { message: 'Fields.Not.Matching' } };
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVzdC1tYXRjaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Jvc29mdGxhYi9pb25pYy9zcmMvbGliL3ZhbGlkYXRvcnMvbXVzdC1tYXRjaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLFVBQVUsbUJBQW1CLENBQUMsT0FBd0I7SUFDeEQsTUFBTSxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUUsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBRXBELDJEQUEyRDtJQUMzRCxJQUFJLENBQUMsZUFBZSxJQUFJLENBQUMsUUFBUSxFQUFFO1FBQy9CLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFFRCxJQUFJLGVBQWUsS0FBSyxRQUFRLEVBQUU7UUFDOUIsT0FBTyxJQUFJLENBQUM7S0FDZjtJQUVELE9BQU8sRUFBRSxVQUFVLEVBQUUsRUFBRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsRUFBRSxDQUFDO0FBQzlELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBmaWVsZE1hdGNoVmFsaWRhdG9yKGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCkge1xuICAgIGNvbnN0IHsgcGFzc3dvcmQsIGNvbmZpcm1QYXNzd29yZCB9ID0gY29udHJvbC52YWx1ZTtcblxuICAgIC8vIGF2b2lkIGRpc3BsYXlpbmcgdGhlIG1lc3NhZ2UgZXJyb3Igd2hlbiB2YWx1ZXMgYXJlIGVtcHR5XG4gICAgaWYgKCFjb25maXJtUGFzc3dvcmQgfHwgIXBhc3N3b3JkKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGlmIChjb25maXJtUGFzc3dvcmQgPT09IHBhc3N3b3JkKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiB7IGZpZWxkTWF0Y2g6IHsgbWVzc2FnZTogJ0ZpZWxkcy5Ob3QuTWF0Y2hpbmcnIH0gfTtcbn0iXX0=
@@ -0,0 +1,50 @@
1
+ import { Component } from '@angular/core';
2
+ import { FieldWrapper } from '@ngx-formly/core';
3
+ import { WrappersModule } from './wrappers.module';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ionic/angular";
6
+ export class AccordionWrapperComponent extends FieldWrapper {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: AccordionWrapperComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: AccordionWrapperComponent, isStandalone: true, selector: "formly-accordion-panel", usesInheritance: true, ngImport: i0, template: `
9
+
10
+ <ion-accordion-group [value]="['first']">
11
+ <ion-accordion value="first">
12
+ <ion-item slot="header">
13
+ <ion-card-title>{{ props.label}}</ion-card-title>
14
+ </ion-item>
15
+ <div class="ion-padding" slot="content">
16
+ <ng-container #fieldComponent></ng-container>
17
+ </div>
18
+ </ion-accordion>
19
+ </ion-accordion-group>
20
+
21
+
22
+
23
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: WrappersModule }, { kind: "component", type: i1.IonAccordion, selector: "ion-accordion", inputs: ["disabled", "mode", "readonly", "toggleIcon", "toggleIconSlot", "value"] }, { kind: "component", type: i1.IonAccordionGroup, selector: "ion-accordion-group", inputs: ["animated", "disabled", "expand", "mode", "multiple", "readonly", "value"] }, { kind: "component", type: i1.IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: i1.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }] }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: AccordionWrapperComponent, decorators: [{
26
+ type: Component,
27
+ args: [{
28
+ standalone: true,
29
+ // eslint-disable-next-line @angular-eslint/component-selector
30
+ selector: 'formly-accordion-panel',
31
+ template: `
32
+
33
+ <ion-accordion-group [value]="['first']">
34
+ <ion-accordion value="first">
35
+ <ion-item slot="header">
36
+ <ion-card-title>{{ props.label}}</ion-card-title>
37
+ </ion-item>
38
+ <div class="ion-padding" slot="content">
39
+ <ng-container #fieldComponent></ng-container>
40
+ </div>
41
+ </ion-accordion>
42
+ </ion-accordion-group>
43
+
44
+
45
+
46
+ `,
47
+ imports: [WrappersModule]
48
+ }]
49
+ }] });
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcm9zb2Z0bGFiL2lvbmljL3NyYy9saWIvd3JhcHBlcnMvYWNjb3JkaW9uLXdyYXBwZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBd0JuRCxNQUFNLE9BQU8seUJBQTBCLFNBQVEsWUFBWTs4R0FBOUMseUJBQXlCO2tHQUF6Qix5QkFBeUIseUdBbEIxQjs7Ozs7Ozs7Ozs7Ozs7O0dBZVQsMkRBQ1MsY0FBYzs7MkZBRWIseUJBQXlCO2tCQXRCckMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsOERBQThEO29CQUM5RCxRQUFRLEVBQUUsd0JBQXdCO29CQUNsQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7OztHQWVUO29CQUNELE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmllbGRXcmFwcGVyIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XHJcbmltcG9ydCB7IFdyYXBwZXJzTW9kdWxlIH0gZnJvbSAnLi93cmFwcGVycy5tb2R1bGUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxyXG4gIHNlbGVjdG9yOiAnZm9ybWx5LWFjY29yZGlvbi1wYW5lbCcsXHJcbiAgdGVtcGxhdGU6IGBcclxuXHJcbiAgPGlvbi1hY2NvcmRpb24tZ3JvdXAgIFt2YWx1ZV09XCJbJ2ZpcnN0J11cIj5cclxuICAgIDxpb24tYWNjb3JkaW9uIHZhbHVlPVwiZmlyc3RcIj5cclxuICAgICAgICA8aW9uLWl0ZW0gc2xvdD1cImhlYWRlclwiPlxyXG4gICAgICAgICAgICA8aW9uLWNhcmQtdGl0bGU+e3sgcHJvcHMubGFiZWx9fTwvaW9uLWNhcmQtdGl0bGU+XHJcbiAgICAgICAgPC9pb24taXRlbT5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiaW9uLXBhZGRpbmdcIiBzbG90PVwiY29udGVudFwiPlxyXG4gICAgICAgICAgICA8bmctY29udGFpbmVyICNmaWVsZENvbXBvbmVudD48L25nLWNvbnRhaW5lcj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvaW9uLWFjY29yZGlvbj5cclxuICA8L2lvbi1hY2NvcmRpb24tZ3JvdXA+XHJcblxyXG5cclxuICAgICAgICAgICAgXHJcbiAgYCxcclxuICBpbXBvcnRzOiBbV3JhcHBlcnNNb2R1bGVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25XcmFwcGVyQ29tcG9uZW50IGV4dGVuZHMgRmllbGRXcmFwcGVyIHsgfVxyXG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './accordion-wrapper.component';
2
+ export * from './panel-wrapper.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvaW9uaWMvc3JjL2xpYi93cmFwcGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLCtCQUErQixDQUFBO0FBQzdDLGNBQWMsMkJBQTJCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FjY29yZGlvbi13cmFwcGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9wYW5lbC13cmFwcGVyLmNvbXBvbmVudCdcclxuXHJcbiJdfQ==
@@ -0,0 +1,37 @@
1
+ import { Component } from '@angular/core';
2
+ import { FieldWrapper } from '@ngx-formly/core';
3
+ import { WrappersModule } from './wrappers.module';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ionic/angular";
6
+ export class PanelWrapperComponent extends FieldWrapper {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: PanelWrapperComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: PanelWrapperComponent, isStandalone: true, selector: "formly-wrapper-panel", usesInheritance: true, ngImport: i0, template: `
9
+ <ion-card>
10
+ <ion-card-header>
11
+ <ion-card-title>{{ props.label}}</ion-card-title>
12
+ </ion-card-header>
13
+ <ion-card-content>
14
+ <ng-container #fieldComponent></ng-container>
15
+ </ion-card-content>
16
+ </ion-card>
17
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: WrappersModule }, { kind: "component", type: i1.IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i1.IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: i1.IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: i1.IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }] }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: PanelWrapperComponent, decorators: [{
20
+ type: Component,
21
+ args: [{
22
+ standalone: true,
23
+ selector: 'formly-wrapper-panel',
24
+ template: `
25
+ <ion-card>
26
+ <ion-card-header>
27
+ <ion-card-title>{{ props.label}}</ion-card-title>
28
+ </ion-card-header>
29
+ <ion-card-content>
30
+ <ng-container #fieldComponent></ng-container>
31
+ </ion-card-content>
32
+ </ion-card>
33
+ `,
34
+ imports: [WrappersModule]
35
+ }]
36
+ }] });
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFuZWwtd3JhcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvaW9uaWMvc3JjL2xpYi93cmFwcGVycy9wYW5lbC13cmFwcGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7OztBQWlCbkQsTUFBTSxPQUFPLHFCQUFzQixTQUFRLFlBQVk7OEdBQTFDLHFCQUFxQjtrR0FBckIscUJBQXFCLHVHQVp0Qjs7Ozs7Ozs7O0dBU1QsMkRBQ1MsY0FBYzs7MkZBRWIscUJBQXFCO2tCQWZqQyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUU7Ozs7Ozs7OztHQVNUO29CQUNELE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpZWxkV3JhcHBlciB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgV3JhcHBlcnNNb2R1bGUgfSBmcm9tICcuL3dyYXBwZXJzLm1vZHVsZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2Zvcm1seS13cmFwcGVyLXBhbmVsJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8aW9uLWNhcmQ+XG4gICAgICA8aW9uLWNhcmQtaGVhZGVyPlxuICAgICAgICA8aW9uLWNhcmQtdGl0bGU+e3sgcHJvcHMubGFiZWx9fTwvaW9uLWNhcmQtdGl0bGU+XG4gICAgICA8L2lvbi1jYXJkLWhlYWRlcj5cbiAgICAgIDxpb24tY2FyZC1jb250ZW50PlxuICAgICAgICA8bmctY29udGFpbmVyICNmaWVsZENvbXBvbmVudD48L25nLWNvbnRhaW5lcj5cbiAgICAgIDwvaW9uLWNhcmQtY29udGVudD5cbiAgICA8L2lvbi1jYXJkPlxuICBgLFxuICBpbXBvcnRzOiBbV3JhcHBlcnNNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIFBhbmVsV3JhcHBlckNvbXBvbmVudCBleHRlbmRzIEZpZWxkV3JhcHBlciB7IH1cbiJdfQ==
@@ -0,0 +1,56 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { ReactiveFormsModule } from '@angular/forms';
4
+ import { IonicModule } from '@ionic/angular';
5
+ import { FORMLY_CONFIG, FormlyModule } from '@ngx-formly/core';
6
+ import { FormlyIonicModule } from '@ngx-formly/ionic';
7
+ import { TranslateModule, TranslateService } from '@ngx-translate/core';
8
+ import { NgxDatatableModule } from '@swimlane/ngx-datatable';
9
+ import { registerTranslateExtension } from '../translate.extension';
10
+ import * as i0 from "@angular/core";
11
+ const COMMON_MODULES = [
12
+ CommonModule,
13
+ IonicModule,
14
+ ReactiveFormsModule,
15
+ FormlyIonicModule,
16
+ NgxDatatableModule
17
+ ];
18
+ export class WrappersModule {
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: WrappersModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
20
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.1", ngImport: i0, type: WrappersModule, imports: [CommonModule,
21
+ IonicModule,
22
+ ReactiveFormsModule,
23
+ FormlyIonicModule,
24
+ NgxDatatableModule, TranslateModule], exports: [CommonModule,
25
+ IonicModule,
26
+ ReactiveFormsModule,
27
+ FormlyIonicModule,
28
+ NgxDatatableModule, FormlyModule,
29
+ TranslateModule] }); }
30
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: WrappersModule, providers: [
31
+ { provide: FORMLY_CONFIG, multi: true, useFactory: registerTranslateExtension, deps: [TranslateService] },
32
+ ], imports: [COMMON_MODULES, TranslateModule, CommonModule,
33
+ IonicModule,
34
+ ReactiveFormsModule,
35
+ FormlyIonicModule,
36
+ NgxDatatableModule, FormlyModule,
37
+ TranslateModule] }); }
38
+ }
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: WrappersModule, decorators: [{
40
+ type: NgModule,
41
+ args: [{
42
+ imports: [
43
+ ...COMMON_MODULES,
44
+ TranslateModule
45
+ ],
46
+ providers: [
47
+ { provide: FORMLY_CONFIG, multi: true, useFactory: registerTranslateExtension, deps: [TranslateService] },
48
+ ],
49
+ exports: [
50
+ ...COMMON_MODULES,
51
+ FormlyModule,
52
+ TranslateModule
53
+ ],
54
+ }]
55
+ }] });
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid3JhcHBlcnMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcm9zb2Z0bGFiL2lvbmljL3NyYy9saWIvd3JhcHBlcnMvd3JhcHBlcnMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFcEUsTUFBTSxjQUFjLEdBQUc7SUFDckIsWUFBWTtJQUNaLFdBQVc7SUFDWCxtQkFBbUI7SUFDbkIsaUJBQWlCO0lBQ2pCLGtCQUFrQjtDQUNuQixDQUFDO0FBZ0JGLE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxZQXJCekIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsaUJBQWlCO1lBQ2pCLGtCQUFrQixFQU1oQixlQUFlLGFBVmpCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGlCQUFpQjtZQUNqQixrQkFBa0IsRUFhaEIsWUFBWTtZQUNaLGVBQWU7K0dBR04sY0FBYyxhQVRkO1lBQ1QsRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLDBCQUEwQixFQUFFLElBQUksRUFBRSxDQUFDLGdCQUFnQixDQUFDLEVBQUU7U0FDMUcsWUFMSSxjQUFjLEVBQ2pCLGVBQWUsRUFWakIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsaUJBQWlCO1lBQ2pCLGtCQUFrQixFQWFoQixZQUFZO1lBQ1osZUFBZTs7MkZBR04sY0FBYztrQkFkMUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsR0FBRyxjQUFjO3dCQUNqQixlQUFlO3FCQUNoQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1QsRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLDBCQUEwQixFQUFFLElBQUksRUFBRSxDQUFDLGdCQUFnQixDQUFDLEVBQUU7cUJBQzFHO29CQUNELE9BQU8sRUFBRTt3QkFDUCxHQUFHLGNBQWM7d0JBQ2pCLFlBQVk7d0JBQ1osZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IEZPUk1MWV9DT05GSUcsIEZvcm1seU1vZHVsZSB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgRm9ybWx5SW9uaWNNb2R1bGUgfSBmcm9tICdAbmd4LWZvcm1seS9pb25pYyc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUsIFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IE5neERhdGF0YWJsZU1vZHVsZSB9IGZyb20gJ0Bzd2ltbGFuZS9uZ3gtZGF0YXRhYmxlJztcbmltcG9ydCB7IHJlZ2lzdGVyVHJhbnNsYXRlRXh0ZW5zaW9uIH0gZnJvbSAnLi4vdHJhbnNsYXRlLmV4dGVuc2lvbic7XG5cbmNvbnN0IENPTU1PTl9NT0RVTEVTID0gW1xuICBDb21tb25Nb2R1bGUsXG4gIElvbmljTW9kdWxlLFxuICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICBGb3JtbHlJb25pY01vZHVsZSxcbiAgTmd4RGF0YXRhYmxlTW9kdWxlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgLi4uQ09NTU9OX01PRFVMRVMsXG4gICAgVHJhbnNsYXRlTW9kdWxlXG4gIF0sXG4gIHByb3ZpZGVyczogW1xuICAgIHsgcHJvdmlkZTogRk9STUxZX0NPTkZJRywgbXVsdGk6IHRydWUsIHVzZUZhY3Rvcnk6IHJlZ2lzdGVyVHJhbnNsYXRlRXh0ZW5zaW9uLCBkZXBzOiBbVHJhbnNsYXRlU2VydmljZV0gfSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIC4uLkNPTU1PTl9NT0RVTEVTLFxuICAgIEZvcm1seU1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGVcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgV3JhcHBlcnNNb2R1bGUgeyB9XG4iXX0=
@@ -0,0 +1,12 @@
1
+ /*
2
+ * Public API Surface of ionic
3
+ */
4
+ export * from './lib/components';
5
+ export * from './lib/decorators';
6
+ export * from './lib/interfaces';
7
+ export * from './lib/ionic-dialog.service';
8
+ export * from './lib/translate.extension';
9
+ export * from './lib/types';
10
+ export * from './lib/validators';
11
+ export * from './lib/wrappers';
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3Jvc29mdGxhYi9pb25pYy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGlvbmljXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZWNvcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW9uaWMtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJhbnNsYXRlLmV4dGVuc2lvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dyYXBwZXJzJztcblxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9zb2Z0bGFiLWlvbmljLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvcm9zb2Z0bGFiL2lvbmljL3NyYy9yb3NvZnRsYWItaW9uaWMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==