brainloper-ui 14.0.16 → 14.0.18

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 (97) hide show
  1. package/esm2020/brainloper-ui.mjs +5 -0
  2. package/esm2020/public_api.mjs +53 -0
  3. package/esm2020/src/app/modules/brainloper-ui/brainloper-ui.module.mjs +305 -0
  4. package/esm2020/src/app/modules/brainloper-ui/components/bread-crumb/bread-crumb.component.mjs +29 -0
  5. package/esm2020/src/app/modules/brainloper-ui/components/buttons/button-icon/button-icon.component.mjs +23 -0
  6. package/esm2020/src/app/modules/brainloper-ui/components/buttons/button-label/button-label.component.mjs +83 -0
  7. package/esm2020/src/app/modules/brainloper-ui/components/carousel/carousel.component.mjs +31 -0
  8. package/esm2020/src/app/modules/brainloper-ui/components/combos/combos.component.mjs +176 -0
  9. package/esm2020/src/app/modules/brainloper-ui/components/data-table/data-table.component.mjs +691 -0
  10. package/esm2020/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.mjs +118 -0
  11. package/esm2020/src/app/modules/brainloper-ui/components/file-input/file-input.component.mjs +185 -0
  12. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/doc.mjs +2 -0
  13. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/fondoTransparente.mjs +2 -0
  14. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/pdf.mjs +2 -0
  15. package/esm2020/src/app/modules/brainloper-ui/components/filters/filters.component.mjs +222 -0
  16. package/esm2020/src/app/modules/brainloper-ui/components/report/generate-pdf/generate-pdf.component.mjs +80 -0
  17. package/esm2020/src/app/modules/brainloper-ui/components/report/template-fuel/template-fuel.component.mjs +81 -0
  18. package/esm2020/src/app/modules/brainloper-ui/components/select-filter/select-filter.component.mjs +108 -0
  19. package/esm2020/src/app/modules/data/rolesAndPermissions.mjs +491 -0
  20. package/esm2020/src/app/modules/interfaces/buttons/button-icon.mjs +2 -0
  21. package/esm2020/src/app/modules/interfaces/buttons/button-lavel-edit.mjs +2 -0
  22. package/esm2020/src/app/modules/interfaces/combos/combos-configuration.mjs +2 -0
  23. package/esm2020/src/app/modules/interfaces/common/Permissions.mjs +8 -0
  24. package/esm2020/src/app/modules/interfaces/data-table/params.mjs +2 -0
  25. package/esm2020/src/app/modules/interfaces/data-table/rules.mjs +2 -0
  26. package/esm2020/src/app/modules/interfaces/data-table/table-columns.mjs +2 -0
  27. package/esm2020/src/app/modules/interfaces/data-table/table-configuration.mjs +2 -0
  28. package/esm2020/src/app/modules/interfaces/enum/enumActions.mjs +7 -0
  29. package/esm2020/src/app/modules/interfaces/enum/enumRules.mjs +8 -0
  30. package/esm2020/src/app/modules/interfaces/file-forms-service/file-forms-params.mjs +2 -0
  31. package/esm2020/src/app/modules/interfaces/file-forms-service/file-input-params.mjs +2 -0
  32. package/esm2020/src/app/modules/interfaces/filters/header-filters.mjs +2 -0
  33. package/esm2020/src/app/modules/interfaces/menu-break-crumb/menu-break-crumb.mjs +8 -0
  34. package/esm2020/src/app/modules/interfaces/report/template-pdf-ot.mjs +2 -0
  35. package/esm2020/src/app/modules/interfaces/report/template-pfd-fo.mjs +2 -0
  36. package/esm2020/src/app/modules/services/crypto.service.mjs +37 -0
  37. package/esm2020/src/app/modules/services/export-data.service.mjs +166 -0
  38. package/esm2020/src/app/modules/services/file-forms.service.mjs +24 -0
  39. package/esm2020/src/app/modules/services/functions.service.mjs +54 -0
  40. package/esm2020/src/app/modules/services/generate-pdf.service.mjs +58 -0
  41. package/esm2020/src/app/modules/services/http.service.mjs +154 -0
  42. package/esm2020/src/app/modules/services/loading/loading.component.mjs +28 -0
  43. package/esm2020/src/app/modules/services/local-storage.service.mjs +115 -0
  44. package/esm2020/src/app/modules/services/message.service.mjs +200 -0
  45. package/esm2020/src/app/modules/services/screen-size-util.mjs +6 -0
  46. package/esm2020/src/app/modules/services/session.service.mjs +42 -0
  47. package/fesm2015/brainloper-ui.mjs +3443 -0
  48. package/fesm2015/brainloper-ui.mjs.map +1 -0
  49. package/fesm2020/brainloper-ui.mjs +3404 -0
  50. package/fesm2020/brainloper-ui.mjs.map +1 -0
  51. package/index.d.ts +5 -0
  52. package/package.json +1 -5
  53. package/public_api.d.ts +52 -0
  54. package/src/app/modules/brainloper-ui/brainloper-ui.module.d.ts +73 -0
  55. package/src/app/modules/brainloper-ui/components/bread-crumb/bread-crumb.component.d.ts +13 -0
  56. package/src/app/modules/brainloper-ui/components/buttons/button-icon/button-icon.component.d.ts +10 -0
  57. package/src/app/modules/brainloper-ui/components/buttons/button-label/button-label.component.d.ts +24 -0
  58. package/src/app/modules/brainloper-ui/components/carousel/carousel.component.d.ts +12 -0
  59. package/src/app/modules/brainloper-ui/components/combos/combos.component.d.ts +46 -0
  60. package/src/app/modules/brainloper-ui/components/data-table/data-table.component.d.ts +121 -0
  61. package/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.d.ts +21 -0
  62. package/src/app/modules/brainloper-ui/components/file-input/file-input.component.d.ts +42 -0
  63. package/src/app/modules/brainloper-ui/components/file-input/imagenes/doc.d.ts +2 -0
  64. package/src/app/modules/brainloper-ui/components/file-input/imagenes/fondoTransparente.d.ts +2 -0
  65. package/src/app/modules/brainloper-ui/components/file-input/imagenes/pdf.d.ts +2 -0
  66. package/src/app/modules/brainloper-ui/components/filters/filters.component.d.ts +30 -0
  67. package/src/app/modules/brainloper-ui/components/report/generate-pdf/generate-pdf.component.d.ts +35 -0
  68. package/src/app/modules/brainloper-ui/components/report/template-fuel/template-fuel.component.d.ts +36 -0
  69. package/src/app/modules/brainloper-ui/components/select-filter/select-filter.component.d.ts +26 -0
  70. package/src/app/modules/data/rolesAndPermissions.d.ts +2 -0
  71. package/src/app/modules/interfaces/buttons/button-icon.d.ts +9 -0
  72. package/src/app/modules/interfaces/buttons/button-lavel-edit.d.ts +6 -0
  73. package/src/app/modules/interfaces/combos/combos-configuration.d.ts +13 -0
  74. package/src/app/modules/interfaces/common/Permissions.d.ts +40 -0
  75. package/src/app/modules/interfaces/data-table/params.d.ts +7 -0
  76. package/src/app/modules/interfaces/data-table/rules.d.ts +8 -0
  77. package/src/app/modules/interfaces/data-table/table-columns.d.ts +25 -0
  78. package/src/app/modules/interfaces/data-table/table-configuration.d.ts +25 -0
  79. package/src/app/modules/interfaces/enum/enumActions.d.ts +5 -0
  80. package/src/app/modules/interfaces/enum/enumRules.d.ts +6 -0
  81. package/src/app/modules/interfaces/file-forms-service/file-forms-params.d.ts +4 -0
  82. package/src/app/modules/interfaces/file-forms-service/file-input-params.d.ts +13 -0
  83. package/src/app/modules/interfaces/filters/header-filters.d.ts +13 -0
  84. package/src/app/modules/interfaces/menu-break-crumb/menu-break-crumb.d.ts +10 -0
  85. package/src/app/modules/interfaces/report/template-pdf-ot.d.ts +19 -0
  86. package/src/app/modules/interfaces/report/template-pfd-fo.d.ts +20 -0
  87. package/src/app/modules/services/crypto.service.d.ts +10 -0
  88. package/src/app/modules/services/export-data.service.d.ts +18 -0
  89. package/src/app/modules/services/file-forms.service.d.ts +7 -0
  90. package/src/app/modules/services/functions.service.d.ts +13 -0
  91. package/src/app/modules/services/generate-pdf.service.d.ts +12 -0
  92. package/src/app/modules/services/http.service.d.ts +21 -0
  93. package/src/app/modules/services/loading/loading.component.d.ts +15 -0
  94. package/src/app/modules/services/local-storage.service.d.ts +49 -0
  95. package/src/app/modules/services/message.service.d.ts +23 -0
  96. package/src/app/modules/services/screen-size-util.d.ts +3 -0
  97. package/src/app/modules/services/session.service.d.ts +14 -0
@@ -0,0 +1,3443 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Component, ViewEncapsulation, Inject, Injectable, EventEmitter, ViewChild, Input, Output, NgModule } from '@angular/core';
3
+ import * as i2 from '@angular/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import * as i3 from '@angular/material/button';
6
+ import { MatButtonModule } from '@angular/material/button';
7
+ import { MatAutocompleteModule } from '@angular/material/autocomplete';
8
+ import * as i13 from '@angular/material/checkbox';
9
+ import { MatCheckboxModule } from '@angular/material/checkbox';
10
+ import * as i9 from '@angular/material/datepicker';
11
+ import { MatDatepickerModule } from '@angular/material/datepicker';
12
+ import * as i4 from '@angular/material/form-field';
13
+ import { MatFormFieldModule } from '@angular/material/form-field';
14
+ import * as i7 from '@angular/material/input';
15
+ import { MatInputModule } from '@angular/material/input';
16
+ import { MatRadioModule } from '@angular/material/radio';
17
+ import * as i8 from '@angular/material/select';
18
+ import { MatSelectModule } from '@angular/material/select';
19
+ import { MatSliderModule } from '@angular/material/slider';
20
+ import { MatSlideToggleModule } from '@angular/material/slide-toggle';
21
+ import * as i10 from '@angular/material/menu';
22
+ import { MatMenuModule } from '@angular/material/menu';
23
+ import { MatSidenavModule } from '@angular/material/sidenav';
24
+ import { MatToolbarModule } from '@angular/material/toolbar';
25
+ import { MatCardModule } from '@angular/material/card';
26
+ import { MatDividerModule } from '@angular/material/divider';
27
+ import { MatExpansionModule } from '@angular/material/expansion';
28
+ import { MatGridListModule } from '@angular/material/grid-list';
29
+ import { MatListModule } from '@angular/material/list';
30
+ import { MatStepperModule } from '@angular/material/stepper';
31
+ import { MatTabsModule } from '@angular/material/tabs';
32
+ import { MatTreeModule } from '@angular/material/tree';
33
+ import { MatButtonToggleModule } from '@angular/material/button-toggle';
34
+ import { MatBadgeModule } from '@angular/material/badge';
35
+ import { MatChipsModule } from '@angular/material/chips';
36
+ import * as i3$2 from '@angular/material/icon';
37
+ import { MatIconModule } from '@angular/material/icon';
38
+ import * as i3$1 from '@angular/material/progress-spinner';
39
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
40
+ import { MatProgressBarModule } from '@angular/material/progress-bar';
41
+ import * as i8$1 from '@angular/material/core';
42
+ import { MatRippleModule, MatNativeDateModule } from '@angular/material/core';
43
+ import { MatBottomSheetModule } from '@angular/material/bottom-sheet';
44
+ import * as i1 from '@angular/material/dialog';
45
+ import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
46
+ import { MatSnackBarModule } from '@angular/material/snack-bar';
47
+ import * as i7$1 from '@angular/material/tooltip';
48
+ import { MatTooltipModule } from '@angular/material/tooltip';
49
+ import * as i5 from '@angular/material/paginator';
50
+ import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
51
+ import { MatSortModule } from '@angular/material/sort';
52
+ import { MatTableModule } from '@angular/material/table';
53
+ import * as i2$1 from '@ng-bootstrap/ng-bootstrap';
54
+ import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
55
+ import * as i1$2 from '@angular/forms';
56
+ import { UntypedFormGroup, UntypedFormControl, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
57
+ import * as i1$1 from '@angular/common/http';
58
+ import { HttpParams, HttpClientModule } from '@angular/common/http';
59
+ import { forkJoin } from 'rxjs';
60
+ import { map } from 'rxjs/operators';
61
+ import Swal from 'sweetalert2';
62
+ import * as i1$4 from 'ngx-lottie';
63
+ import { LottieModule } from 'ngx-lottie';
64
+ import player from 'lottie-web';
65
+ import jsPDF from 'jspdf';
66
+ import html2canvas from 'html2canvas';
67
+ import * as i1$3 from '@angular/router';
68
+ import { RouterModule } from '@angular/router';
69
+ import { __awaiter } from 'tslib';
70
+ import * as fs from 'file-saver';
71
+ import { Workbook } from 'exceljs';
72
+ import Compressor from 'compressorjs';
73
+ import { MaxSizeValidator } from '@angular-material-components/file-input';
74
+ import * as CryptoJS from 'crypto-js';
75
+ import { compress, decompress } from 'lz-string';
76
+
77
+ class LoadingComponent {
78
+ constructor(dialogRef, data) {
79
+ this.dialogRef = dialogRef;
80
+ this.data = data;
81
+ this.options = {
82
+ path: '/assets/loading.json'
83
+ };
84
+ }
85
+ ngOnInit() {
86
+ }
87
+ animationCreated(animationItem) {
88
+ console.log(animationItem);
89
+ }
90
+ }
91
+ LoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
92
+ LoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: LoadingComponent, selector: "app-loading", ngImport: i0, template: "<div style=\"display: flex; justify-content: center;align-items: center; flex-direction: column;\">\r\n\r\n <div style='font-size: 20px;'>\r\n <strong>{{data.title}}</strong>\r\n </div>\r\n <div>\r\n <!-- <ng-lottie width='170px' [options]=\"options\" (animationCreated)=\"animationCreated($event)\"></ng-lottie> -->\r\n <img width='170px' src=\"assets/loading.gif\" alt=\"\">\r\n </div>\r\n <div style='text-align: center;'>\r\n {{data.message}}\r\n </div>\r\n\r\n</div>\r\n", styles: [".mat-dialog-container{overflow:hidden!important;background-color:#fff!important}\n"], encapsulation: i0.ViewEncapsulation.None });
93
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingComponent, decorators: [{
94
+ type: Component,
95
+ args: [{ selector: 'app-loading', encapsulation: ViewEncapsulation.None, template: "<div style=\"display: flex; justify-content: center;align-items: center; flex-direction: column;\">\r\n\r\n <div style='font-size: 20px;'>\r\n <strong>{{data.title}}</strong>\r\n </div>\r\n <div>\r\n <!-- <ng-lottie width='170px' [options]=\"options\" (animationCreated)=\"animationCreated($event)\"></ng-lottie> -->\r\n <img width='170px' src=\"assets/loading.gif\" alt=\"\">\r\n </div>\r\n <div style='text-align: center;'>\r\n {{data.message}}\r\n </div>\r\n\r\n</div>\r\n", styles: [".mat-dialog-container{overflow:hidden!important;background-color:#fff!important}\n"] }]
96
+ }], ctorParameters: function () {
97
+ return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
98
+ type: Inject,
99
+ args: [MAT_DIALOG_DATA]
100
+ }] }];
101
+ } });
102
+
103
+ class MessageService {
104
+ constructor(dialog) {
105
+ this.dialog = dialog;
106
+ this.loadingNow = false;
107
+ this.warningQueue = [];
108
+ this.showingWarning = false;
109
+ }
110
+ openLoading(title, message) {
111
+ if (!this.loadingNow) {
112
+ this.loadingNow = true;
113
+ this.loading = this.dialog.open(LoadingComponent, {
114
+ data: {
115
+ title,
116
+ message
117
+ },
118
+ width: '250px',
119
+ // height:'280px',
120
+ disableClose: true,
121
+ });
122
+ }
123
+ }
124
+ closeLoading() {
125
+ if (this.loadingNow) {
126
+ this.loading.close();
127
+ this.loadingNow = false;
128
+ }
129
+ }
130
+ Error(title, message, showCancelButton = false, confirmButtonText = 'Aceptar', cancelButtonText = 'Cancelar') {
131
+ return new Promise((resolve, reject) => {
132
+ Swal.fire({
133
+ title: title,
134
+ text: message,
135
+ icon: 'error',
136
+ showCancelButton: showCancelButton,
137
+ confirmButtonText: confirmButtonText,
138
+ cancelButtonText: cancelButtonText,
139
+ customClass: {
140
+ confirmButton: 'confirm-button-class',
141
+ cancelButton: 'cancel-button-class',
142
+ }
143
+ }).then((result) => {
144
+ if (result.value) {
145
+ resolve(true);
146
+ }
147
+ else if (result.dismiss === Swal.DismissReason.cancel) {
148
+ resolve(false);
149
+ }
150
+ });
151
+ });
152
+ }
153
+ Success(title, message, showCancelButton = false, confirmButtonText = 'Aceptar', cancelButtonText = 'Cancelar') {
154
+ return new Promise((resolve, reject) => {
155
+ Swal.fire({
156
+ title: title,
157
+ text: message,
158
+ icon: 'success',
159
+ showCancelButton: showCancelButton,
160
+ confirmButtonText: confirmButtonText,
161
+ cancelButtonText: cancelButtonText,
162
+ customClass: {
163
+ confirmButton: 'confirm-button-class',
164
+ cancelButton: 'cancel-button-class',
165
+ }
166
+ }).then((result) => {
167
+ if (result.value) {
168
+ resolve(true);
169
+ }
170
+ else if (result.dismiss === Swal.DismissReason.cancel) {
171
+ resolve(false);
172
+ }
173
+ });
174
+ });
175
+ }
176
+ Warning(title, message, showCancelButton = false, confirmButtonText = 'Aceptar', cancelButtonText = 'Cancelar', allowOutsideClick = false) {
177
+ return new Promise((resolve, reject) => {
178
+ const warningData = {
179
+ title: title,
180
+ message: message,
181
+ showCancelButton: showCancelButton,
182
+ confirmButtonText: confirmButtonText,
183
+ cancelButtonText: cancelButtonText,
184
+ resolve: resolve,
185
+ allowOutsideClick
186
+ };
187
+ this.warningQueue.push(warningData);
188
+ if (!this.showingWarning) {
189
+ this.showNextWarning();
190
+ }
191
+ });
192
+ }
193
+ showNextWarning() {
194
+ if (this.warningQueue.length > 0) {
195
+ this.showingWarning = true;
196
+ const warningData = this.warningQueue.shift();
197
+ Swal.fire({
198
+ title: warningData.title,
199
+ text: warningData.message,
200
+ icon: 'warning',
201
+ showCancelButton: warningData.showCancelButton,
202
+ confirmButtonText: warningData.confirmButtonText,
203
+ cancelButtonText: warningData.cancelButtonText,
204
+ customClass: {
205
+ confirmButton: 'confirm-button-class',
206
+ cancelButton: 'cancel-button-class',
207
+ },
208
+ allowOutsideClick: warningData.allowOutsideClick,
209
+ }).then((result) => {
210
+ this.showingWarning = false;
211
+ if (result.value) {
212
+ warningData.resolve(true);
213
+ }
214
+ else if (result.dismiss === Swal.DismissReason.cancel) {
215
+ warningData.resolve(false);
216
+ }
217
+ this.showNextWarning();
218
+ });
219
+ }
220
+ }
221
+ Info(title, message, showCancelButton = false, confirmButtonText = 'Aceptar', cancelButtonText = 'Cancelar') {
222
+ return new Promise((resolve, reject) => {
223
+ Swal.fire({
224
+ title: title,
225
+ text: message,
226
+ icon: 'info',
227
+ showCancelButton: showCancelButton,
228
+ confirmButtonText: confirmButtonText,
229
+ cancelButtonText: cancelButtonText,
230
+ customClass: {
231
+ confirmButton: 'confirm-button-class',
232
+ cancelButton: 'cancel-button-class',
233
+ }
234
+ }).then((result) => {
235
+ if (result.value) {
236
+ resolve(true);
237
+ }
238
+ else if (result.dismiss === Swal.DismissReason.cancel) {
239
+ resolve(false);
240
+ }
241
+ });
242
+ });
243
+ }
244
+ SuccessToast(message, duration = 4000) {
245
+ Swal.fire({
246
+ position: 'top-end',
247
+ icon: 'success',
248
+ title: message,
249
+ showConfirmButton: false,
250
+ toast: true,
251
+ timer: duration,
252
+ width: 'auto'
253
+ });
254
+ }
255
+ ErrorToast(message, duration = 4000) {
256
+ Swal.fire({
257
+ position: 'top-end',
258
+ icon: 'error',
259
+ title: message,
260
+ showConfirmButton: false,
261
+ toast: true,
262
+ timer: duration,
263
+ width: 'auto'
264
+ });
265
+ }
266
+ WarningToast(message, duration = 4000) {
267
+ Swal.fire({
268
+ position: 'top-end',
269
+ icon: 'warning',
270
+ title: message,
271
+ showConfirmButton: false,
272
+ toast: true,
273
+ timer: duration,
274
+ width: 'auto'
275
+ });
276
+ }
277
+ InfoToast(message, duration = 4000) {
278
+ Swal.fire({
279
+ position: 'top-end',
280
+ icon: 'info',
281
+ title: message,
282
+ showConfirmButton: false,
283
+ toast: true,
284
+ timer: duration,
285
+ width: 'auto'
286
+ });
287
+ }
288
+ }
289
+ MessageService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MessageService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable });
290
+ MessageService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MessageService, providedIn: 'root' });
291
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MessageService, decorators: [{
292
+ type: Injectable,
293
+ args: [{
294
+ providedIn: 'root'
295
+ }]
296
+ }], ctorParameters: function () { return [{ type: i1.MatDialog }]; } });
297
+
298
+ class HttpService {
299
+ constructor(http, message) {
300
+ this.http = http;
301
+ this.message = message;
302
+ }
303
+ getData(url, params) {
304
+ let data = new HttpParams();
305
+ if (params) {
306
+ params.forEach(element => {
307
+ data = data.append(`${element.id}`, `${element.value}`);
308
+ });
309
+ }
310
+ return this.http.get(url, { params: data });
311
+ }
312
+ postData(url, body, params) {
313
+ let data = new HttpParams();
314
+ if (params) {
315
+ params.forEach(element => {
316
+ data = data.append(`${element.id}`, `${element.value}`);
317
+ });
318
+ }
319
+ return this.http.post(url, body, { params: data });
320
+ }
321
+ putData(url, body, params) {
322
+ let data = new HttpParams();
323
+ if (params) {
324
+ params.forEach(element => {
325
+ data = data.append(`${element.id}`, `${element.value}`);
326
+ });
327
+ }
328
+ return this.http.put(url, body, { params: data });
329
+ }
330
+ deleteData(url, params) {
331
+ let data = new HttpParams();
332
+ if (params) {
333
+ params.forEach(element => {
334
+ data = data.append(`${element.id}`, `${element.value}`);
335
+ });
336
+ }
337
+ return this.http.delete(url, { params: data });
338
+ }
339
+ getDataPromise(url, params) {
340
+ let data = new HttpParams();
341
+ if (params) {
342
+ params.forEach(element => {
343
+ data = data.append(`${element.id}`, `${element.value}`);
344
+ });
345
+ }
346
+ return new Promise((resolve, reject) => {
347
+ this.http.get(url, { params: data }).subscribe(res => resolve(res), err => reject(err));
348
+ });
349
+ }
350
+ postDataPromise(url, body, params) {
351
+ let data = new HttpParams();
352
+ if (params) {
353
+ params.forEach(element => {
354
+ data = data.append(`${element.id}`, `${element.value}`);
355
+ });
356
+ }
357
+ return new Promise((resolve, reject) => {
358
+ this.http.post(url, body, { params: data }).subscribe(res => resolve(res), err => reject(err));
359
+ });
360
+ }
361
+ putDataPromise(url, body, params) {
362
+ let data = new HttpParams();
363
+ if (params) {
364
+ params.forEach(element => {
365
+ data = data.append(`${element.id}`, `${element.value}`);
366
+ });
367
+ }
368
+ return new Promise((resolve, reject) => {
369
+ this.http.put(url, body, { params: data }).subscribe(res => resolve(res), err => reject(err));
370
+ });
371
+ }
372
+ deleteDataPromise(url, params) {
373
+ let data = new HttpParams();
374
+ if (params) {
375
+ params.forEach(element => {
376
+ data = data.append(`${element.id}`, `${element.value}`);
377
+ });
378
+ }
379
+ return new Promise((resolve, reject) => {
380
+ this.http.delete(url, { params: data }).subscribe(res => resolve(res), err => reject(err));
381
+ });
382
+ }
383
+ getDataBody(url, params) {
384
+ let data = new HttpParams();
385
+ if (params) {
386
+ params.forEach(element => {
387
+ data = data.append(`${element.id}`, `${element.value}`);
388
+ });
389
+ }
390
+ return new Promise((resolve, reject) => {
391
+ this.http.get(url, { params: data }).subscribe(res => {
392
+ if (res['code'] === 0 && res['body']) {
393
+ resolve(res['body']);
394
+ }
395
+ else {
396
+ resolve(null);
397
+ this.message.Error("Error", res['message']);
398
+ }
399
+ }, err => reject(err));
400
+ });
401
+ }
402
+ postDataBody(url, body, params) {
403
+ let data = new HttpParams();
404
+ if (params) {
405
+ params.forEach(element => {
406
+ data = data.append(`${element.id}`, `${element.value}`);
407
+ });
408
+ }
409
+ return new Promise((resolve, reject) => {
410
+ this.http.post(url, body, { params: data }).subscribe(res => {
411
+ if (res['code'] === 0 && res['body']) {
412
+ resolve(res['body']);
413
+ }
414
+ else {
415
+ resolve(null);
416
+ this.message.Error("Error", res['message']);
417
+ }
418
+ }, err => reject(err));
419
+ });
420
+ }
421
+ putDataBody(url, body, params) {
422
+ let data = new HttpParams();
423
+ if (params) {
424
+ params.forEach(element => {
425
+ data = data.append(`${element.id}`, `${element.value}`);
426
+ });
427
+ }
428
+ return new Promise((resolve, reject) => {
429
+ this.http.put(url, body, { params: data }).subscribe(res => {
430
+ if (res['code'] === 0 && res['body']) {
431
+ resolve(res['body']);
432
+ }
433
+ else {
434
+ resolve(null);
435
+ this.message.Error("Error", res['message']);
436
+ }
437
+ }, err => reject(err));
438
+ });
439
+ }
440
+ }
441
+ HttpService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpService, deps: [{ token: i1$1.HttpClient }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Injectable });
442
+ HttpService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpService });
443
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpService, decorators: [{
444
+ type: Injectable
445
+ }], ctorParameters: function () { return [{ type: i1$1.HttpClient }, { type: MessageService }]; } });
446
+
447
+ class TableModalComponent {
448
+ constructor(dialogRef, data, formBuilder, http) {
449
+ this.dialogRef = dialogRef;
450
+ this.data = data;
451
+ this.formBuilder = formBuilder;
452
+ this.http = http;
453
+ this.modalForm = new UntypedFormGroup({});
454
+ this.dataCombo = {};
455
+ }
456
+ onNoClick() {
457
+ this.dialogRef.close();
458
+ }
459
+ ngOnInit() {
460
+ let group = {};
461
+ let httpRequests = [];
462
+ this.data.columns.map((element) => {
463
+ if (element.type === 'currency') {
464
+ element.value = element.value ? element.value.replace(/\./g, '') : '';
465
+ element.type = 'number';
466
+ }
467
+ if (!element.disregardForAdd) {
468
+ if (element.type === 'combo') {
469
+ this.dataCombo[element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID] = '';
470
+ }
471
+ let initialValue = this.data.action === 'edit' ? element.value : '';
472
+ if (element.type === 'date' && element.value) {
473
+ let s = element.value.split('/');
474
+ initialValue = `${s[2]}-${s[1]}-${s[0]}`;
475
+ }
476
+ group[element.ID] = element.required ? new UntypedFormControl(initialValue, Validators.required) : new UntypedFormControl(initialValue);
477
+ if (element.paramsCombo) {
478
+ httpRequests.push(this.createHttpRequest(element, group));
479
+ }
480
+ }
481
+ });
482
+ if (httpRequests.length > 0) {
483
+ forkJoin(httpRequests).subscribe(() => {
484
+ this.modalForm = new UntypedFormGroup(group);
485
+ });
486
+ }
487
+ else {
488
+ this.modalForm = new UntypedFormGroup(group);
489
+ }
490
+ }
491
+ // Extraemos la creación de la solicitud HTTP a su propia función para mejorar la legibilidad
492
+ createHttpRequest(element, group) {
493
+ return this.http
494
+ .getData(element.paramsCombo.url, element.paramsCombo.urlParams)
495
+ .pipe(map((res) => {
496
+ if (res['code'] === 0) {
497
+ element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
498
+ this.dataCombo[element.identifierCombo] = res['body'];
499
+ if (this.data.action !== 'edit') {
500
+ return;
501
+ }
502
+ this.dataCombo[element.identifierCombo].some((data) => {
503
+ if (data[element.paramsCombo.selectionField] === element.value ||
504
+ data[element.paramsCombo.visibleField] === element.value) {
505
+ var value = data[element.paramsCombo.selectionField];
506
+ element.value = value;
507
+ group[element.ID].setValue(value);
508
+ return true;
509
+ }
510
+ return false;
511
+ });
512
+ }
513
+ }));
514
+ }
515
+ onSubmit() {
516
+ if (this.modalForm.valid) {
517
+ this.data.columns.map((element) => {
518
+ if (element.paramsCombo && element.paramsCombo.returnDataSelect) {
519
+ element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
520
+ let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.ID]);
521
+ if (x) {
522
+ this.modalForm.addControl(element.ID + 'Combo', new UntypedFormControl(x));
523
+ }
524
+ }
525
+ });
526
+ this.dialogRef.close(this.modalForm.value);
527
+ }
528
+ }
529
+ onChange(id, $event, type) {
530
+ switch (type) {
531
+ case 'combo':
532
+ this.modalForm.get(id).setValue($event.value);
533
+ break;
534
+ default:
535
+ this.modalForm.get(id).setValue($event.target.value);
536
+ break;
537
+ }
538
+ }
539
+ }
540
+ TableModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableModalComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i1$2.UntypedFormBuilder }, { token: HttpService }], target: i0.ɵɵFactoryTarget.Component });
541
+ TableModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableModalComponent, selector: "app-table-modal", ngImport: i0, template: "<div>\r\n <div style='display:flex; justify-content: space-between;'>\r\n <div>\r\n <strong>\r\n <h3 *ngIf='data.action==\"edit\"'> Editar </h3>\r\n <h3 *ngIf='data.action==\"add\"'> Agregar </h3>\r\n </strong>\r\n </div>\r\n <div mat-dialog-close>\r\n <i class=\"fa fa-times-circle\" style=\"font-size: 150%; position: relative;\"></i>\r\n </div>\r\n </div>\r\n\r\n <form [formGroup]=\"modalForm\">\r\n\r\n <div *ngFor='let input of data.columns'>\r\n\r\n\r\n\r\n <div *ngIf='data.action==\"edit\"; else Agregar'>\r\n <mat-form-field *ngIf=\"!input.disregardForEdit\">\r\n <div *ngIf='input.type==\"combo\"; else otherInputEdit'>\r\n\r\n <mat-select [value]=\"input.value\" (selectionChange)='onChange(input.ID,$event, input.type)'\r\n placeholder='{{input.label}}' [required]=\"input.required\">\r\n <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n [value]='data[input.paramsCombo.selectionField]'>\r\n {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n </mat-select>\r\n </div>\r\n\r\n <ng-template #otherInputEdit>\r\n <input [type]='input.type' [name]='input.ID' [value]='input.value'\r\n (input)='onChange(input.ID,$event, input.type)' matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n </ng-template>\r\n\r\n <mat-error>Campo Obligatorio</mat-error>\r\n </mat-form-field>\r\n\r\n </div>\r\n\r\n <ng-template #Agregar>\r\n <mat-form-field *ngIf=\"!input.disregardForAdd\">\r\n <div *ngIf='input.type==\"combo\"; else otherInput'>\r\n\r\n <mat-select (selectionChange)='onChange(input.ID,$event, input.type)' placeholder='{{input.label}}' [required]=\"input.required\">\r\n <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n [value]='data[input.paramsCombo.selectionField]'>\r\n {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n </mat-select>\r\n\r\n </div>\r\n\r\n <ng-template #otherInput>\r\n <input [type]='input.type' [name]='input.ID' (input)='onChange(input.ID, $event, input.type)'\r\n matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n\r\n </ng-template>\r\n <mat-error>Campo Obligatorio</mat-error>\r\n </mat-form-field>\r\n </ng-template>\r\n\r\n\r\n\r\n\r\n </div>\r\n\r\n <button *ngIf='data.action==\"add\" || data.action==\"edit\"'\r\n (click)='onSubmit()'\r\n color='primary'\r\n mat-raised-button\r\n [disabled]=\"!modalForm.valid\">Guardar</button>\r\n\r\n </form>\r\n</div>\r\n\r\n", styles: ["button{width:100%}mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8$1.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
542
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableModalComponent, decorators: [{
543
+ type: Component,
544
+ args: [{ selector: 'app-table-modal', template: "<div>\r\n <div style='display:flex; justify-content: space-between;'>\r\n <div>\r\n <strong>\r\n <h3 *ngIf='data.action==\"edit\"'> Editar </h3>\r\n <h3 *ngIf='data.action==\"add\"'> Agregar </h3>\r\n </strong>\r\n </div>\r\n <div mat-dialog-close>\r\n <i class=\"fa fa-times-circle\" style=\"font-size: 150%; position: relative;\"></i>\r\n </div>\r\n </div>\r\n\r\n <form [formGroup]=\"modalForm\">\r\n\r\n <div *ngFor='let input of data.columns'>\r\n\r\n\r\n\r\n <div *ngIf='data.action==\"edit\"; else Agregar'>\r\n <mat-form-field *ngIf=\"!input.disregardForEdit\">\r\n <div *ngIf='input.type==\"combo\"; else otherInputEdit'>\r\n\r\n <mat-select [value]=\"input.value\" (selectionChange)='onChange(input.ID,$event, input.type)'\r\n placeholder='{{input.label}}' [required]=\"input.required\">\r\n <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n [value]='data[input.paramsCombo.selectionField]'>\r\n {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n </mat-select>\r\n </div>\r\n\r\n <ng-template #otherInputEdit>\r\n <input [type]='input.type' [name]='input.ID' [value]='input.value'\r\n (input)='onChange(input.ID,$event, input.type)' matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n </ng-template>\r\n\r\n <mat-error>Campo Obligatorio</mat-error>\r\n </mat-form-field>\r\n\r\n </div>\r\n\r\n <ng-template #Agregar>\r\n <mat-form-field *ngIf=\"!input.disregardForAdd\">\r\n <div *ngIf='input.type==\"combo\"; else otherInput'>\r\n\r\n <mat-select (selectionChange)='onChange(input.ID,$event, input.type)' placeholder='{{input.label}}' [required]=\"input.required\">\r\n <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n [value]='data[input.paramsCombo.selectionField]'>\r\n {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n </mat-select>\r\n\r\n </div>\r\n\r\n <ng-template #otherInput>\r\n <input [type]='input.type' [name]='input.ID' (input)='onChange(input.ID, $event, input.type)'\r\n matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n\r\n </ng-template>\r\n <mat-error>Campo Obligatorio</mat-error>\r\n </mat-form-field>\r\n </ng-template>\r\n\r\n\r\n\r\n\r\n </div>\r\n\r\n <button *ngIf='data.action==\"add\" || data.action==\"edit\"'\r\n (click)='onSubmit()'\r\n color='primary'\r\n mat-raised-button\r\n [disabled]=\"!modalForm.valid\">Guardar</button>\r\n\r\n </form>\r\n</div>\r\n\r\n", styles: ["button{width:100%}mat-form-field{width:100%}\n"] }]
545
+ }], ctorParameters: function () {
546
+ return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
547
+ type: Inject,
548
+ args: [MAT_DIALOG_DATA]
549
+ }] }, { type: i1$2.UntypedFormBuilder }, { type: HttpService }];
550
+ } });
551
+
552
+ class SelectFilterComponent {
553
+ constructor(fb) {
554
+ this.showSpinner = true;
555
+ this.noResultsMessage = 'No results';
556
+ this.noResults = false;
557
+ this.localSpinner = false;
558
+ this.filteredReturn = new EventEmitter();
559
+ this.filteredItems = [];
560
+ this.searchForm = fb.group({
561
+ value: ''
562
+ });
563
+ }
564
+ ngOnInit() {
565
+ this.searchFormValueChangesSubscription = this.searchForm.valueChanges.subscribe(value => {
566
+ const searchValue = value['value'] ? value['value'].toLowerCase() : '';
567
+ if (this.showSpinner) {
568
+ this.localSpinner = true;
569
+ }
570
+ if (searchValue) {
571
+ if (this.displayMember == null) {
572
+ this.filteredItems = this.array.filter(name => name.toLowerCase().includes(searchValue));
573
+ }
574
+ else if (this.hasGroup && this.groupArrayName && this.displayMember) {
575
+ this.filteredItems = this.array.map(a => {
576
+ const objCopy = Object.assign({}, a);
577
+ objCopy[this.groupArrayName] = objCopy[this.groupArrayName].filter(g => g[this.displayMember].toLowerCase().includes(searchValue));
578
+ return objCopy;
579
+ }).filter(x => x[this.groupArrayName].length > 0);
580
+ }
581
+ else {
582
+ this.filteredItems = this.array.filter(name => name[this.displayMember].toLowerCase().includes(searchValue));
583
+ }
584
+ this.noResults = this.filteredItems.length === 0;
585
+ }
586
+ else {
587
+ this.filteredItems = [...this.array];
588
+ this.noResults = false;
589
+ }
590
+ this.filteredReturn.emit(this.filteredItems);
591
+ setTimeout(() => {
592
+ if (this.showSpinner) {
593
+ this.localSpinner = false;
594
+ }
595
+ }, 2000);
596
+ });
597
+ setTimeout(() => {
598
+ this.input.nativeElement.focus();
599
+ }, 500);
600
+ if (!this.placeholder) {
601
+ this.placeholder = 'Search...';
602
+ }
603
+ }
604
+ handleKeydown(event) {
605
+ const isAlphanumeric = (event.key && event.key.length === 1) ||
606
+ (event.code >= 'KeyA' && event.code <= 'KeyZ') ||
607
+ (event.code >= 'Digit0' && event.code <= 'Digit9') ||
608
+ (event.code === 'Space');
609
+ if (isAlphanumeric) {
610
+ event.stopPropagation();
611
+ }
612
+ }
613
+ ngOnDestroy() {
614
+ this.filteredReturn.emit(this.array);
615
+ this.searchFormValueChangesSubscription.unsubscribe();
616
+ }
617
+ }
618
+ SelectFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectFilterComponent, deps: [{ token: i1$2.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
619
+ SelectFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectFilterComponent, selector: "app-select-filter", inputs: { array: "array", placeholder: "placeholder", color: "color", displayMember: "displayMember", showSpinner: "showSpinner", noResultsMessage: "noResultsMessage", hasGroup: "hasGroup", groupArrayName: "groupArrayName" }, outputs: { filteredReturn: "filteredReturn" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"searchForm\" class=\"mat-filter\" [ngStyle]=\"{'background-color': color ? color : 'white'}\">\n <div>\n <input #input class=\"mat-filter-input\" matInput placeholder=\"{{placeholder}}\" formControlName=\"value\" (keydown)=\"handleKeydown($event)\">\n <mat-spinner *ngIf=\"localSpinner\" class=\"spinner\" diameter=\"16\"></mat-spinner>\n </div>\n <div *ngIf=\"noResults\"\n class=\"noResultsMessage\">\n {{noResultsMessage}}\n</div>\n</form>\n", styles: [".mat-filter{position:sticky;top:0;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:gray;z-index:100;font-size:inherit;box-shadow:none;border-radius:0;padding:16px;box-sizing:border-box}.mat-filter-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;border:0;background-color:transparent;background-color:initial;color:gray;width:100%}.spinner{position:absolute;right:16px;top:calc(50% - 8px)}.noResultsMessage{margin-top:10px;font-family:Roboto,Helvetica Neue,sans-serif;font-size:16px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3$1.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i1$2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
620
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectFilterComponent, decorators: [{
621
+ type: Component,
622
+ args: [{ selector: 'app-select-filter', template: "<form [formGroup]=\"searchForm\" class=\"mat-filter\" [ngStyle]=\"{'background-color': color ? color : 'white'}\">\n <div>\n <input #input class=\"mat-filter-input\" matInput placeholder=\"{{placeholder}}\" formControlName=\"value\" (keydown)=\"handleKeydown($event)\">\n <mat-spinner *ngIf=\"localSpinner\" class=\"spinner\" diameter=\"16\"></mat-spinner>\n </div>\n <div *ngIf=\"noResults\"\n class=\"noResultsMessage\">\n {{noResultsMessage}}\n</div>\n</form>\n", styles: [".mat-filter{position:sticky;top:0;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:gray;z-index:100;font-size:inherit;box-shadow:none;border-radius:0;padding:16px;box-sizing:border-box}.mat-filter-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;border:0;background-color:transparent;background-color:initial;color:gray;width:100%}.spinner{position:absolute;right:16px;top:calc(50% - 8px)}.noResultsMessage{margin-top:10px;font-family:Roboto,Helvetica Neue,sans-serif;font-size:16px}\n"] }]
623
+ }], ctorParameters: function () { return [{ type: i1$2.FormBuilder }]; }, propDecorators: { input: [{
624
+ type: ViewChild,
625
+ args: ['input', { static: true }]
626
+ }], array: [{
627
+ type: Input,
628
+ args: ['array']
629
+ }], placeholder: [{
630
+ type: Input,
631
+ args: ['placeholder']
632
+ }], color: [{
633
+ type: Input,
634
+ args: ['color']
635
+ }], displayMember: [{
636
+ type: Input,
637
+ args: ['displayMember']
638
+ }], showSpinner: [{
639
+ type: Input,
640
+ args: ['showSpinner']
641
+ }], noResultsMessage: [{
642
+ type: Input,
643
+ args: ['noResultsMessage']
644
+ }], hasGroup: [{
645
+ type: Input,
646
+ args: ['hasGroup']
647
+ }], groupArrayName: [{
648
+ type: Input,
649
+ args: ['groupArrayName']
650
+ }], filteredReturn: [{
651
+ type: Output
652
+ }] } });
653
+
654
+ class CombosComponent {
655
+ constructor(http) {
656
+ this.http = http;
657
+ this.filter = false;
658
+ this.checkbox = false;
659
+ this.required = false;
660
+ this.disabled = false;
661
+ this.addFinal = false;
662
+ this.appearance = '';
663
+ this.control = new UntypedFormControl();
664
+ this.tooltipDescription = null;
665
+ this.tooltipActive = false;
666
+ this.changeOption = new EventEmitter();
667
+ this.changeOptionDataComplete = new EventEmitter();
668
+ this.returnDataCombo = new EventEmitter();
669
+ }
670
+ ngOnInit() {
671
+ if (!this.configuration.label) {
672
+ this.configuration.label = this.configuration.visibleField;
673
+ }
674
+ this.initData();
675
+ if (this.reloadCombo) {
676
+ this.reloadCombo.subscribe((res) => {
677
+ if (res == 'selected') {
678
+ this.control.setValue(this.configuration.selected);
679
+ }
680
+ else {
681
+ this.initData();
682
+ }
683
+ });
684
+ }
685
+ this.control.setValue(this.configuration.selected);
686
+ //console.log(this.configuration)
687
+ }
688
+ ngOnChanges(changes) {
689
+ if (this.dataCombos && (changes === null || changes === void 0 ? void 0 : changes.dataCombos)) {
690
+ this.dataCombos = changes.dataCombos.currentValue;
691
+ this.filteredList = this.dataCombos.slice();
692
+ }
693
+ if (this.control && this.control.value) {
694
+ this.configuration.selected = this.control.value;
695
+ }
696
+ }
697
+ initData() {
698
+ if (this.configuration.urlCombo) {
699
+ this.getData();
700
+ }
701
+ else {
702
+ if (this.dataCombos) {
703
+ this.filteredList = this.dataCombos.slice();
704
+ }
705
+ }
706
+ }
707
+ getData() {
708
+ this.http
709
+ .getData(this.configuration.urlCombo, this.configuration.urlParams)
710
+ .subscribe((res) => {
711
+ if (res['code'] === 0) {
712
+ this.dataCombos = res['body'];
713
+ if (this.additionalData) {
714
+ if (this.addFinal) {
715
+ this.dataCombos = this.dataCombos.concat(this.additionalData);
716
+ }
717
+ else {
718
+ this.dataCombos = this.additionalData.concat(this.dataCombos);
719
+ }
720
+ }
721
+ this.returnDataCombo.emit(this.dataCombos);
722
+ this.filteredList = this.dataCombos.slice();
723
+ }
724
+ else {
725
+ console.log('error en la consulta para datos combo');
726
+ }
727
+ }, (err) => {
728
+ console.log(err);
729
+ });
730
+ }
731
+ selectedData($event) {
732
+ this.findData($event);
733
+ this.changeOption.emit($event.value);
734
+ }
735
+ findData($event) {
736
+ let d = [];
737
+ if (this.checkbox) {
738
+ const lookup = new Map(this.dataCombos.map((item) => [
739
+ item[this.configuration.selectionField],
740
+ item,
741
+ ]));
742
+ for (const id of $event.value) {
743
+ const foundItem = lookup.get(id);
744
+ if (foundItem) {
745
+ d.push(foundItem);
746
+ }
747
+ }
748
+ }
749
+ else {
750
+ d = this.dataCombos.find((x) => x[this.configuration.selectionField] == $event.value);
751
+ }
752
+ this.changeOptionDataComplete.emit(d);
753
+ if (this.configuration.fileTooltip && !this.checkbox) {
754
+ if (d) {
755
+ this.tooltipDescription = d[this.configuration.fileTooltip];
756
+ this.tooltipActive = true;
757
+ setTimeout(() => {
758
+ this.tooltip.show();
759
+ }, 50);
760
+ setTimeout(() => {
761
+ this.tooltip.hide();
762
+ }, 10000);
763
+ }
764
+ else
765
+ this.tooltipDescription = null;
766
+ }
767
+ else
768
+ this.tooltipDescription = null;
769
+ }
770
+ toggleTooltip() {
771
+ this.tooltipActive = !this.tooltipActive;
772
+ if (this.tooltipActive) {
773
+ this.tooltip.show();
774
+ }
775
+ else {
776
+ this.tooltip.hide();
777
+ }
778
+ }
779
+ }
780
+ CombosComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CombosComponent, deps: [{ token: HttpService }], target: i0.ɵɵFactoryTarget.Component });
781
+ CombosComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CombosComponent, selector: "combos", inputs: { dataCombos: "dataCombos", additionalData: "additionalData", configuration: "configuration", filter: "filter", checkbox: "checkbox", required: "required", disabled: "disabled", addFinal: "addFinal", appearance: "appearance", reloadCombo: "reloadCombo", control: "control" }, outputs: { changeOption: "changeOption", changeOptionDataComplete: "changeOptionDataComplete", returnDataCombo: "returnDataCombo" }, viewQueries: [{ propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div style=\"display: flex; flex-direction: row; justify-content: space-between\">\r\n <div class=\"combo-container\">\r\n\r\n <mat-icon\r\n class=\"m-1 icon-information\"\r\n *ngIf=\"tooltipDescription\"\r\n matTooltip=\"{{tooltipDescription}}\"\r\n matTooltipPosition=\"above\"\r\n #tooltip=\"matTooltip\"\r\n (click)=\"toggleTooltip()\"\r\n matTooltipClass=\"custom-tooltip\"\r\n >info</mat-icon>\r\n\r\n <mat-form-field style=\"width: 100%\" [appearance]=\"appearance\">\r\n <mat-label style=\"text-transform: capitalize\">{{\r\n configuration.label\r\n }}</mat-label>\r\n <mat-select [multiple]=\"checkbox\" (selectionChange)=\"selectedData(control)\" [required]=\"required\"\r\n [formControl]=\"control\" [disabled]=\"disabled\">\r\n <app-select-filter [noResultsMessage]=\"'No hay resultados'\" *ngIf=\"filter\" [placeholder]=\"'Filter'\" [displayMember]=\"configuration.visibleField\"\r\n [array]=\"dataCombos\" (filteredReturn)=\"filteredList = $event\">\r\n </app-select-filter>\r\n <mat-option [value]=\"data[configuration.selectionField]\" *ngFor=\"let data of filteredList\">\r\n {{ data[configuration.visibleField] }}\r\n </mat-option>\r\n </mat-select>\r\n <mat-error *ngIf=\"required\">Campo requerido</mat-error>\r\n </mat-form-field>\r\n </div>\r\n</div>\r\n\r\n", styles: [".mat-form-field{width:100%}.combo-container{width:100%;display:flex;align-items:center}.icon-information{cursor:pointer;color:gray}.mat-icon{font-size:1.1rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8$1.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i7$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: SelectFilterComponent, selector: "app-select-filter", inputs: ["array", "placeholder", "color", "displayMember", "showSpinner", "noResultsMessage", "hasGroup", "groupArrayName"], outputs: ["filteredReturn"] }] });
782
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CombosComponent, decorators: [{
783
+ type: Component,
784
+ args: [{ selector: 'combos', template: "<div style=\"display: flex; flex-direction: row; justify-content: space-between\">\r\n <div class=\"combo-container\">\r\n\r\n <mat-icon\r\n class=\"m-1 icon-information\"\r\n *ngIf=\"tooltipDescription\"\r\n matTooltip=\"{{tooltipDescription}}\"\r\n matTooltipPosition=\"above\"\r\n #tooltip=\"matTooltip\"\r\n (click)=\"toggleTooltip()\"\r\n matTooltipClass=\"custom-tooltip\"\r\n >info</mat-icon>\r\n\r\n <mat-form-field style=\"width: 100%\" [appearance]=\"appearance\">\r\n <mat-label style=\"text-transform: capitalize\">{{\r\n configuration.label\r\n }}</mat-label>\r\n <mat-select [multiple]=\"checkbox\" (selectionChange)=\"selectedData(control)\" [required]=\"required\"\r\n [formControl]=\"control\" [disabled]=\"disabled\">\r\n <app-select-filter [noResultsMessage]=\"'No hay resultados'\" *ngIf=\"filter\" [placeholder]=\"'Filter'\" [displayMember]=\"configuration.visibleField\"\r\n [array]=\"dataCombos\" (filteredReturn)=\"filteredList = $event\">\r\n </app-select-filter>\r\n <mat-option [value]=\"data[configuration.selectionField]\" *ngFor=\"let data of filteredList\">\r\n {{ data[configuration.visibleField] }}\r\n </mat-option>\r\n </mat-select>\r\n <mat-error *ngIf=\"required\">Campo requerido</mat-error>\r\n </mat-form-field>\r\n </div>\r\n</div>\r\n\r\n", styles: [".mat-form-field{width:100%}.combo-container{width:100%;display:flex;align-items:center}.icon-information{cursor:pointer;color:gray}.mat-icon{font-size:1.1rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}\n"] }]
785
+ }], ctorParameters: function () { return [{ type: HttpService }]; }, propDecorators: { dataCombos: [{
786
+ type: Input
787
+ }], additionalData: [{
788
+ type: Input
789
+ }], configuration: [{
790
+ type: Input
791
+ }], filter: [{
792
+ type: Input
793
+ }], checkbox: [{
794
+ type: Input
795
+ }], required: [{
796
+ type: Input
797
+ }], disabled: [{
798
+ type: Input
799
+ }], addFinal: [{
800
+ type: Input
801
+ }], appearance: [{
802
+ type: Input
803
+ }], reloadCombo: [{
804
+ type: Input
805
+ }], control: [{
806
+ type: Input
807
+ }], tooltip: [{
808
+ type: ViewChild,
809
+ args: ['tooltip']
810
+ }], changeOption: [{
811
+ type: Output
812
+ }], changeOptionDataComplete: [{
813
+ type: Output
814
+ }], returnDataCombo: [{
815
+ type: Output
816
+ }] } });
817
+
818
+ class GeneratePdfComponent {
819
+ constructor(dialogRef, dataModal, dialog, message) {
820
+ this.dialogRef = dialogRef;
821
+ this.dataModal = dataModal;
822
+ this.dialog = dialog;
823
+ this.message = message;
824
+ this.data = {
825
+ name: '',
826
+ nit: '',
827
+ address: '',
828
+ telephone: '',
829
+ mail: '',
830
+ image: '',
831
+ code: '',
832
+ date: '',
833
+ responsible: '',
834
+ third: '',
835
+ odometer: '',
836
+ approved_by: '',
837
+ description: '',
838
+ consecutive: '',
839
+ nameProvider: '',
840
+ addressProvider: '',
841
+ area: '',
842
+ };
843
+ }
844
+ ngOnInit() {
845
+ this.data = this.dataModal.data;
846
+ }
847
+ ngAfterViewInit() {
848
+ if (this.dataModal.autoGenerate) {
849
+ this.downloadPDF();
850
+ }
851
+ }
852
+ downloadPDF() {
853
+ this.message.openLoading("Cargando", "Generando PDF");
854
+ const DATA = document.getElementById('templateOT');
855
+ const doc = new jsPDF('p', 'pt', 'a4');
856
+ const options = {
857
+ background: 'white',
858
+ scale: 3
859
+ };
860
+ html2canvas(DATA, options)
861
+ .then((canvas) => {
862
+ const img = canvas.toDataURL('image/PNG');
863
+ //add img canvas to pdf
864
+ const bufferX = 15;
865
+ const bufferY = 15;
866
+ const imgProps = doc.getImageProperties(img);
867
+ const pdfWidth = doc.internal.pageSize.getWidth() - 2 * bufferX;
868
+ const pdfHeight = (imgProps.height * pdfWidth) / imgProps.width;
869
+ doc.addImage(img, 'PNG', bufferX, bufferY, pdfWidth, pdfHeight, undefined, 'FAST');
870
+ return doc;
871
+ })
872
+ .then((docResult) => {
873
+ //docResult.save(`${new Date().toISOString()}_reporte.pdf`);
874
+ docResult.output('dataurlnewwindow', { filename: 'reporte.pdf' });
875
+ this.dialog.closeAll();
876
+ this.message.closeLoading();
877
+ });
878
+ }
879
+ }
880
+ GeneratePdfComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GeneratePdfComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i1.MatDialog }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Component });
881
+ GeneratePdfComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: GeneratePdfComponent, selector: "app-generate-pdf", ngImport: i0, template: "<div id=\"templateOT\" #templateOT>\r\n <div class=\"template-ot\" style=\"display: flex; flex-direction: column; width:100%; margin:0; background-color: white;\">\r\n\r\n <!-- Encabezado -->\r\n <div class=\"borde\" style=\"width:100%; height:30mm; display:flex; flex-direction: row; align-items: center; \">\r\n <div style=\"width:70%; display:flex; flex-direction:column; align-items: center;\">\r\n <h2 style=\"margin:0; padding:0; text-align: center; text-transform: uppercase;\">{{data.name}}</h2>\r\n <h2 style=\"margin:0; padding:0; text-align: center; \">NIT: {{data.nit}}</h2>\r\n <div style=\"width:70%; display:flex; flex-direction:row; justify-content: space-around;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">{{data.address}}</h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">TEL: {{data.telephone}}</h3>\r\n </div>\r\n </div>\r\n <div style=\"width:30%;\">\r\n <div class=\"img\"\r\n style=\"width:90%; height:100px; margin: 10px; padding: 15px; background-image: url({{data.image}});\">\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <div class=\"borde\"\r\n style=\"width:100%; height:10mm; display:flex; flex-direction: row; justify-content: space-around; align-items: center; background: #F0F4FF;\">\r\n <h2 style=\"margin:0; padding:0;\">ORDEN DE TRABAJO</h2>\r\n <h2 style=\"margin:0; padding:0;\">N\u00B0: {{data.consecutive}}</h2>\r\n\r\n </div>\r\n\r\n <!-- Cuerpo -->\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Fecha:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.date}}</h2>\r\n </div>\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">C\u00F3digo:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.code}}</h2>\r\n </div>\r\n <div style=\"width:12%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">\u00C1rea:</h2>\r\n </div>\r\n <div style=\"width:32%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.area}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Operario:</h2>\r\n </div>\r\n <div style=\"width:47%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.responsible}}</h2>\r\n </div>\r\n <div style=\"width:18%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Od\u00F3metro:</h2>\r\n </div>\r\n <div style=\"width:22%\">\r\n <h2 style=\"text-align: center; margin-top:15px; padding:0\">{{data.odometer}}</h2>\r\n </div>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:10m; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Datos del proveedor</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row ; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Nombre:</h2>\r\n </div>\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">{{data.nameProvider}}</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Direcci\u00F3n:</h2>\r\n </div>\r\n <div style=\"width:35%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.addressProvider}}</h2>\r\n </div>\r\n\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:8mm; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Detalles del servicio</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:20mm;\">\r\n <h3 style=\"margin-top:11px; padding:0;\">{{data.description}}</h3>\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:10mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin:1px; padding:0;\">AUTORIZADA POR:</h2>\r\n </div>\r\n <div style=\"width:65%\">\r\n <h2 style=\"text-align: center; margin:5px; padding:0;\">{{data.approved_by}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- piso -->\r\n <div class=\"borde\"\r\n style=\"width:100%; height:15mm; display: flex; flex-direction: column; justify-content: center;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Favor adjuntar la orden a la factura o cuenta de cobro\r\n </h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">{{data.mail}}</h3>\r\n\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n<div style=\"display: flex; justify-content: center; margin-top: 15px;\">\r\n <button (click)=\"downloadPDF()\" color='primary' mat-raised-button>Generar PDF</button>\r\n</div>", styles: [".img{background-size:100%;background-repeat:no-repeat;background-position:center;background-size:contain}h2{font-size:1rem}.borde{border:1px solid blue}\n"], dependencies: [{ kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
882
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GeneratePdfComponent, decorators: [{
883
+ type: Component,
884
+ args: [{ selector: 'app-generate-pdf', template: "<div id=\"templateOT\" #templateOT>\r\n <div class=\"template-ot\" style=\"display: flex; flex-direction: column; width:100%; margin:0; background-color: white;\">\r\n\r\n <!-- Encabezado -->\r\n <div class=\"borde\" style=\"width:100%; height:30mm; display:flex; flex-direction: row; align-items: center; \">\r\n <div style=\"width:70%; display:flex; flex-direction:column; align-items: center;\">\r\n <h2 style=\"margin:0; padding:0; text-align: center; text-transform: uppercase;\">{{data.name}}</h2>\r\n <h2 style=\"margin:0; padding:0; text-align: center; \">NIT: {{data.nit}}</h2>\r\n <div style=\"width:70%; display:flex; flex-direction:row; justify-content: space-around;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">{{data.address}}</h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">TEL: {{data.telephone}}</h3>\r\n </div>\r\n </div>\r\n <div style=\"width:30%;\">\r\n <div class=\"img\"\r\n style=\"width:90%; height:100px; margin: 10px; padding: 15px; background-image: url({{data.image}});\">\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <div class=\"borde\"\r\n style=\"width:100%; height:10mm; display:flex; flex-direction: row; justify-content: space-around; align-items: center; background: #F0F4FF;\">\r\n <h2 style=\"margin:0; padding:0;\">ORDEN DE TRABAJO</h2>\r\n <h2 style=\"margin:0; padding:0;\">N\u00B0: {{data.consecutive}}</h2>\r\n\r\n </div>\r\n\r\n <!-- Cuerpo -->\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Fecha:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.date}}</h2>\r\n </div>\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">C\u00F3digo:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.code}}</h2>\r\n </div>\r\n <div style=\"width:12%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">\u00C1rea:</h2>\r\n </div>\r\n <div style=\"width:32%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.area}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:13%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Operario:</h2>\r\n </div>\r\n <div style=\"width:47%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.responsible}}</h2>\r\n </div>\r\n <div style=\"width:18%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Od\u00F3metro:</h2>\r\n </div>\r\n <div style=\"width:22%\">\r\n <h2 style=\"text-align: center; margin-top:15px; padding:0\">{{data.odometer}}</h2>\r\n </div>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:10m; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Datos del proveedor</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row ; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Nombre:</h2>\r\n </div>\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">{{data.nameProvider}}</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Direcci\u00F3n:</h2>\r\n </div>\r\n <div style=\"width:35%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.addressProvider}}</h2>\r\n </div>\r\n\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:8mm; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Detalles del servicio</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:20mm;\">\r\n <h3 style=\"margin-top:11px; padding:0;\">{{data.description}}</h3>\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:10mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin:1px; padding:0;\">AUTORIZADA POR:</h2>\r\n </div>\r\n <div style=\"width:65%\">\r\n <h2 style=\"text-align: center; margin:5px; padding:0;\">{{data.approved_by}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- piso -->\r\n <div class=\"borde\"\r\n style=\"width:100%; height:15mm; display: flex; flex-direction: column; justify-content: center;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Favor adjuntar la orden a la factura o cuenta de cobro\r\n </h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">{{data.mail}}</h3>\r\n\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n<div style=\"display: flex; justify-content: center; margin-top: 15px;\">\r\n <button (click)=\"downloadPDF()\" color='primary' mat-raised-button>Generar PDF</button>\r\n</div>", styles: [".img{background-size:100%;background-repeat:no-repeat;background-position:center;background-size:contain}h2{font-size:1rem}.borde{border:1px solid blue}\n"] }]
885
+ }], ctorParameters: function () {
886
+ return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
887
+ type: Inject,
888
+ args: [MAT_DIALOG_DATA]
889
+ }] }, { type: i1.MatDialog }, { type: MessageService }];
890
+ } });
891
+
892
+ class TemplateFuelComponent {
893
+ constructor(dialogRef, dataModal, dialog, message) {
894
+ this.dialogRef = dialogRef;
895
+ this.dataModal = dataModal;
896
+ this.dialog = dialog;
897
+ this.message = message;
898
+ this.data = {
899
+ name: '',
900
+ nit: '',
901
+ address: '',
902
+ telephone: '',
903
+ mail: '',
904
+ image: '',
905
+ code: '',
906
+ date: '',
907
+ responsible: '',
908
+ id_place: '',
909
+ approved_by: '',
910
+ detalle: '',
911
+ description: '',
912
+ consecutive: '',
913
+ namePlace: '',
914
+ addressPlace: '',
915
+ area: '',
916
+ odometer: '',
917
+ };
918
+ }
919
+ ngOnInit() {
920
+ this.data = this.dataModal.data;
921
+ }
922
+ ngAfterViewInit() {
923
+ if (this.dataModal.autoGenerate) {
924
+ this.downloadPDF();
925
+ }
926
+ }
927
+ downloadPDF() {
928
+ this.message.openLoading("Cargando", "Generando PDF");
929
+ const DATA = document.getElementById('templateFO');
930
+ const doc = new jsPDF('p', 'pt', 'a4');
931
+ const options = {
932
+ background: 'white',
933
+ scale: 3
934
+ };
935
+ html2canvas(DATA, options)
936
+ .then((canvas) => {
937
+ const img = canvas.toDataURL('image/PNG');
938
+ //add img canvas to pdf
939
+ const bufferX = 15;
940
+ const bufferY = 15;
941
+ const imgProps = doc.getImageProperties(img);
942
+ const pdfWidth = doc.internal.pageSize.getWidth() - 2 * bufferX;
943
+ const pdfHeight = (imgProps.height * pdfWidth) / imgProps.width;
944
+ doc.addImage(img, 'PNG', bufferX, bufferY, pdfWidth, pdfHeight, undefined, 'FAST');
945
+ return doc;
946
+ })
947
+ .then((docResult) => {
948
+ //docResult.save(`${new Date().toISOString()}_reporte.pdf`);
949
+ docResult.output('dataurlnewwindow', { filename: 'fuekreporte.pdf' });
950
+ this.dialog.closeAll();
951
+ this.message.closeLoading();
952
+ });
953
+ }
954
+ }
955
+ TemplateFuelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TemplateFuelComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i1.MatDialog }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Component });
956
+ TemplateFuelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TemplateFuelComponent, selector: "app-template-fuel", ngImport: i0, template: "<div id=\"templateFO\" #templateFO>\r\n <div class=\"template-ot\" style=\"display: flex; flex-direction: column; width:100%; margin:0; background-color: white;\">\r\n\r\n <!-- Encabezado -->\r\n <div class=\"borde\" style=\"width:100%; height:30mm; display:flex; flex-direction: row; align-items: center; \">\r\n <div style=\"width:70%; display:flex; flex-direction:column; align-items: center;\">\r\n <h2 style=\"margin:0; padding:0; text-align: center; text-transform: uppercase;\">{{data.name}}</h2>\r\n <h2 style=\"margin:0; padding:0; text-align: center; \">NIT: {{data.nit}}</h2>\r\n <div style=\"width:70%; display:flex; flex-direction:row; justify-content: space-around;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">{{data.address}}</h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">TEL: {{data.telephone}}</h3>\r\n </div>\r\n </div>\r\n <div style=\"width:30%;\">\r\n <div class=\"img\"\r\n style=\"width:90%; height:100px; margin: 10px; padding: 15px; background-image: url({{data.image}});\">\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <div class=\"borde\"\r\n style=\"width:100%; height:10mm; display:flex; flex-direction: row; justify-content: space-around; align-items: center; background: #F0F4FF;\">\r\n <h2 style=\"margin:0; padding:0;\">ORDEN DE COMBUSTIBLE</h2>\r\n <h2 style=\"margin:0; padding:0;\">N\u00B0: {{data.consecutive}}</h2>\r\n\r\n </div>\r\n\r\n <!-- Cuerpo -->\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Fecha:</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.date}}</h2>\r\n </div>\r\n <div style=\"width:18%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Od\u00F3metro:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.odometer}}</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">\u00C1rea:</h2>\r\n </div>\r\n <div style=\"width:40%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.area}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">C\u00F3digo:</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.code}}</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Operario:</h2>\r\n </div>\r\n <div style=\"width:45%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.responsible}}</h2>\r\n </div>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:10m; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Datos del proveedor</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row ; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Lugar:</h2>\r\n </div>\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">{{data.namePlace}}</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Direcci\u00F3n:</h2>\r\n </div>\r\n <div style=\"width:35%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.addressPlace}}</h2>\r\n </div>\r\n\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:8mm; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Detalles del servicio</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:20mm;\">\r\n <h3 style=\"margin: 6px 0 0 25px; padding:0;\">{{data.detalle}}</h3>\r\n <h3 style=\"margin: 0 0 0 25px; padding:0;\">Descripci\u00F3n: {{data.description}}</h3>\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:10mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin:1px; padding:0;\">AUTORIZADA POR:</h2>\r\n </div>\r\n <div style=\"width:65%\">\r\n <h2 style=\"text-align: center; margin:5px; padding:0;\">{{data.approved_by}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- piso -->\r\n <div class=\"borde\"\r\n style=\"width:100%; height:15mm; display: flex; flex-direction: column; justify-content: center;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Favor adjuntar la orden de venta o factura\r\n </h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">{{data.mail}}</h3>\r\n\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n<div style=\"display: flex; justify-content: center; margin-top: 15px;\">\r\n <button (click)=\"downloadPDF()\" color='primary' mat-raised-button>Generar PDF</button>\r\n</div>\r\n", styles: [".img{background-size:100%;background-repeat:no-repeat;background-position:center;background-size:contain}h2{font-size:1rem}.borde{border:1px solid blue}\n"], dependencies: [{ kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
957
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TemplateFuelComponent, decorators: [{
958
+ type: Component,
959
+ args: [{ selector: 'app-template-fuel', template: "<div id=\"templateFO\" #templateFO>\r\n <div class=\"template-ot\" style=\"display: flex; flex-direction: column; width:100%; margin:0; background-color: white;\">\r\n\r\n <!-- Encabezado -->\r\n <div class=\"borde\" style=\"width:100%; height:30mm; display:flex; flex-direction: row; align-items: center; \">\r\n <div style=\"width:70%; display:flex; flex-direction:column; align-items: center;\">\r\n <h2 style=\"margin:0; padding:0; text-align: center; text-transform: uppercase;\">{{data.name}}</h2>\r\n <h2 style=\"margin:0; padding:0; text-align: center; \">NIT: {{data.nit}}</h2>\r\n <div style=\"width:70%; display:flex; flex-direction:row; justify-content: space-around;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">{{data.address}}</h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center; \">TEL: {{data.telephone}}</h3>\r\n </div>\r\n </div>\r\n <div style=\"width:30%;\">\r\n <div class=\"img\"\r\n style=\"width:90%; height:100px; margin: 10px; padding: 15px; background-image: url({{data.image}});\">\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <div class=\"borde\"\r\n style=\"width:100%; height:10mm; display:flex; flex-direction: row; justify-content: space-around; align-items: center; background: #F0F4FF;\">\r\n <h2 style=\"margin:0; padding:0;\">ORDEN DE COMBUSTIBLE</h2>\r\n <h2 style=\"margin:0; padding:0;\">N\u00B0: {{data.consecutive}}</h2>\r\n\r\n </div>\r\n\r\n <!-- Cuerpo -->\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Fecha:</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.date}}</h2>\r\n </div>\r\n <div style=\"width:18%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Od\u00F3metro:</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.odometer}}</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">\u00C1rea:</h2>\r\n </div>\r\n <div style=\"width:40%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.area}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">C\u00F3digo:</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.code}}</h2>\r\n </div>\r\n <div style=\"width:20%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">Operario:</h2>\r\n </div>\r\n <div style=\"width:45%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:5px; padding:0;\">{{data.responsible}}</h2>\r\n </div>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:10m; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Datos del proveedor</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:11mm; display:flex; flex-direction:row ; align-items: center\">\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Lugar:</h2>\r\n </div>\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">{{data.namePlace}}</h2>\r\n </div>\r\n <div style=\"width:15%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin-top:3px; padding:0;\">Direcci\u00F3n:</h2>\r\n </div>\r\n <div style=\"width:35%\">\r\n <h2 style=\"text-align: center; margin-top:20px; padding:0;\">{{data.addressPlace}}</h2>\r\n </div>\r\n\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:8mm; background: #F0F4FF;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Detalles del servicio</h3>\r\n </div>\r\n <div class=\"borde\" style=\"width:100%; height:20mm;\">\r\n <h3 style=\"margin: 6px 0 0 25px; padding:0;\">{{data.detalle}}</h3>\r\n <h3 style=\"margin: 0 0 0 25px; padding:0;\">Descripci\u00F3n: {{data.description}}</h3>\r\n </div>\r\n\r\n <div class=\"borde\" style=\"width:100%; height:10mm; display:flex; flex-direction:row; align-items: center\">\r\n <div style=\"width:35%; border-right:1px solid blue; height: 100%;\">\r\n <h2 style=\"text-align: center; margin:1px; padding:0;\">AUTORIZADA POR:</h2>\r\n </div>\r\n <div style=\"width:65%\">\r\n <h2 style=\"text-align: center; margin:5px; padding:0;\">{{data.approved_by}}</h2>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- piso -->\r\n <div class=\"borde\"\r\n style=\"width:100%; height:15mm; display: flex; flex-direction: column; justify-content: center;\">\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">Favor adjuntar la orden de venta o factura\r\n </h3>\r\n <h3 style=\"margin:0; padding:0; text-align: center;\">{{data.mail}}</h3>\r\n\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n<div style=\"display: flex; justify-content: center; margin-top: 15px;\">\r\n <button (click)=\"downloadPDF()\" color='primary' mat-raised-button>Generar PDF</button>\r\n</div>\r\n", styles: [".img{background-size:100%;background-repeat:no-repeat;background-position:center;background-size:contain}h2{font-size:1rem}.borde{border:1px solid blue}\n"] }]
960
+ }], ctorParameters: function () {
961
+ return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
962
+ type: Inject,
963
+ args: [MAT_DIALOG_DATA]
964
+ }] }, { type: i1.MatDialog }, { type: MessageService }];
965
+ } });
966
+
967
+ class BreadCrumbComponent {
968
+ constructor(router) {
969
+ this.router = router;
970
+ this.menu = [];
971
+ this.selectRouter = new EventEmitter();
972
+ }
973
+ ngOnInit() {
974
+ }
975
+ handlerRouter(menu) {
976
+ if (menu.router != null)
977
+ this.router.navigate([menu.router]);
978
+ this.selectRouter.emit(menu);
979
+ }
980
+ }
981
+ BreadCrumbComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BreadCrumbComponent, deps: [{ token: i1$3.Router }], target: i0.ɵɵFactoryTarget.Component });
982
+ BreadCrumbComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: BreadCrumbComponent, selector: "app-bread-crumb", inputs: { menu: "menu" }, outputs: { selectRouter: "selectRouter" }, ngImport: i0, template: "<div aria-label=\"breadcrumb\">\r\n <ol class=\"breadcrumb\">\r\n <li *ngFor=\"let m of menu\" [class]=\"m.current?'active':''\" class=\"breadcrumb-item\" (click)=\"handlerRouter(m)\">{{m.name}}</li>\r\n </ol>\r\n</div>\r\n", styles: [".breadcrumb-item{cursor:pointer}.breadcrumb{background-color:#b7b9bb!important;padding:10px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
983
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BreadCrumbComponent, decorators: [{
984
+ type: Component,
985
+ args: [{ selector: 'app-bread-crumb', template: "<div aria-label=\"breadcrumb\">\r\n <ol class=\"breadcrumb\">\r\n <li *ngFor=\"let m of menu\" [class]=\"m.current?'active':''\" class=\"breadcrumb-item\" (click)=\"handlerRouter(m)\">{{m.name}}</li>\r\n </ol>\r\n</div>\r\n", styles: [".breadcrumb-item{cursor:pointer}.breadcrumb{background-color:#b7b9bb!important;padding:10px}\n"] }]
986
+ }], ctorParameters: function () { return [{ type: i1$3.Router }]; }, propDecorators: { menu: [{
987
+ type: Input
988
+ }], selectRouter: [{
989
+ type: Output
990
+ }] } });
991
+
992
+ class ButtonIconComponent {
993
+ constructor() {
994
+ this.clickButton = new EventEmitter();
995
+ }
996
+ ngOnInit() {
997
+ }
998
+ }
999
+ ButtonIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1000
+ ButtonIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ButtonIconComponent, selector: "app-button-icon", inputs: { items: "items" }, outputs: { clickButton: "clickButton" }, ngImport: i0, template: "<div style=\"height: 100%\" class=\"d-flex flex-wrap justify-content-around align-items-center\">\r\n <div *ngFor=\"let item of items\" [class]=\"items.length > 6 ? 'col-3' : 'col-4'\">\r\n <div *ngIf=\"item.active\" class=\"icon-menu\" matTooltip=\"{{ item.description }}\" matTooltipPosition=\"above\" matTooltipClass=\"custom-tooltip\">\r\n <button style=\"border: none; background: transparent\">\r\n <div [class]=\"'icon mat-elevation-z6'\" [style.background]=\"item.color\" matRipple (click)=\"clickButton.emit(item)\">\r\n <i [class]=\"'fa iconFa fa-' + item.icon\" [style.color]=\"item.iconColor ?? 'white'\"></i>\r\n </div>\r\n </button>\r\n <div>\r\n <h3 style=\"text-align: center; line-height: 20px\">{{ item.name }}</h3>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n", styles: ["div.icon-menu{display:flex;align-items:center;flex-direction:column}div.icon{width:120px;background-color:#fff;height:120px;border-radius:22px;cursor:pointer;display:flex;justify-content:center;align-items:center}.iconFa{width:70px;height:70px}font{font-size:.6rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}@media screen and (max-height: 360px){div.icon{width:90px;height:90px;border-radius:18px}.iconFa{width:50px;height:50px}h3{font-size:70%}}@media screen and (max-width: 360px){div.icon{width:80px;height:80px;border-radius:20px}.iconFa{width:50px;height:50px}h3{font-size:70%}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8$1.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i7$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
1001
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonIconComponent, decorators: [{
1002
+ type: Component,
1003
+ args: [{ selector: 'app-button-icon', template: "<div style=\"height: 100%\" class=\"d-flex flex-wrap justify-content-around align-items-center\">\r\n <div *ngFor=\"let item of items\" [class]=\"items.length > 6 ? 'col-3' : 'col-4'\">\r\n <div *ngIf=\"item.active\" class=\"icon-menu\" matTooltip=\"{{ item.description }}\" matTooltipPosition=\"above\" matTooltipClass=\"custom-tooltip\">\r\n <button style=\"border: none; background: transparent\">\r\n <div [class]=\"'icon mat-elevation-z6'\" [style.background]=\"item.color\" matRipple (click)=\"clickButton.emit(item)\">\r\n <i [class]=\"'fa iconFa fa-' + item.icon\" [style.color]=\"item.iconColor ?? 'white'\"></i>\r\n </div>\r\n </button>\r\n <div>\r\n <h3 style=\"text-align: center; line-height: 20px\">{{ item.name }}</h3>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n", styles: ["div.icon-menu{display:flex;align-items:center;flex-direction:column}div.icon{width:120px;background-color:#fff;height:120px;border-radius:22px;cursor:pointer;display:flex;justify-content:center;align-items:center}.iconFa{width:70px;height:70px}font{font-size:.6rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}@media screen and (max-height: 360px){div.icon{width:90px;height:90px;border-radius:18px}.iconFa{width:50px;height:50px}h3{font-size:70%}}@media screen and (max-width: 360px){div.icon{width:80px;height:80px;border-radius:20px}.iconFa{width:50px;height:50px}h3{font-size:70%}}\n"] }]
1004
+ }], ctorParameters: function () { return []; }, propDecorators: { clickButton: [{
1005
+ type: Output
1006
+ }], items: [{
1007
+ type: Input
1008
+ }] } });
1009
+
1010
+ class CarouselComponent {
1011
+ constructor() {
1012
+ this.ic1 = 1;
1013
+ this.ic2 = 1;
1014
+ this.ic3 = 1;
1015
+ }
1016
+ ngOnInit() {
1017
+ }
1018
+ ngAfterContentChecked() {
1019
+ let c1 = document.getElementById("itemCarousel1");
1020
+ let c2 = document.getElementById("itemCarousel2");
1021
+ let c3 = document.getElementById("itemCarousel3");
1022
+ if (c1)
1023
+ this.ic1 = c1.childElementCount;
1024
+ if (c2)
1025
+ this.ic2 = c2.childElementCount;
1026
+ if (c3)
1027
+ this.ic3 = c3.childElementCount;
1028
+ }
1029
+ }
1030
+ CarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CarouselComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1031
+ CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CarouselComponent, selector: "app-carousel", ngImport: i0, template: "<ngb-carousel>\t\r\n\t\t<ng-template ngbSlide *ngIf=\"ic1 == 1\" > \r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel1\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel1]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\r\n\t\t<ng-template ngbSlide *ngIf=\"ic2 == 1\">\r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel2\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel2]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\t\r\n\t\t<ng-template ngbSlide *ngIf=\"ic3 == 1\">\r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel3\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel3]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\t\r\n</ngb-carousel>\r\n", styles: ["::ng-deep .carousel-control-next-icon{background-image:url()!important}::ng-deep .carousel-control-next{display:flex!important;justify-content:flex-end!important}::ng-deep .carousel-control-prev-icon{background-image:url()!important}::ng-deep .carousel-control-prev{display:flex!important;justify-content:flex-start!important}::ng-deep .carousel-indicators li{background-color:#212121!important}.item-container{min-height:60vh;margin:0 30px}@media screen and (max-width: 350px){.item-container{margin:0 20px}}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$1.NgbCarousel, selector: "ngb-carousel", inputs: ["animation", "activeId", "interval", "wrap", "keyboard", "pauseOnHover", "pauseOnFocus", "showNavigationArrows", "showNavigationIndicators"], outputs: ["slide", "slid"], exportAs: ["ngbCarousel"] }, { kind: "directive", type: i2$1.NgbSlide, selector: "ng-template[ngbSlide]", inputs: ["id"], outputs: ["slid"] }] });
1032
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CarouselComponent, decorators: [{
1033
+ type: Component,
1034
+ args: [{ selector: 'app-carousel', template: "<ngb-carousel>\t\r\n\t\t<ng-template ngbSlide *ngIf=\"ic1 == 1\" > \r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel1\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel1]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\r\n\t\t<ng-template ngbSlide *ngIf=\"ic2 == 1\">\r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel2\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel2]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\t\r\n\t\t<ng-template ngbSlide *ngIf=\"ic3 == 1\">\r\n\t\t\t<div class=\"item-container\" id=\"itemCarousel3\">\r\n\t\t\t\t<ng-content select=\"[itemCarousel3]\"></ng-content>\r\n\t\t\t</div>\t\t\r\n\t\t</ng-template>\t\r\n</ngb-carousel>\r\n", styles: ["::ng-deep .carousel-control-next-icon{background-image:url()!important}::ng-deep .carousel-control-next{display:flex!important;justify-content:flex-end!important}::ng-deep .carousel-control-prev-icon{background-image:url()!important}::ng-deep .carousel-control-prev{display:flex!important;justify-content:flex-start!important}::ng-deep .carousel-indicators li{background-color:#212121!important}.item-container{min-height:60vh;margin:0 30px}@media screen and (max-width: 350px){.item-container{margin:0 20px}}\n"] }]
1035
+ }], ctorParameters: function () { return []; } });
1036
+
1037
+ class ScreenSizeUtil {
1038
+ static isMobile() {
1039
+ return screen.width <= 600;
1040
+ }
1041
+ }
1042
+
1043
+ class FunctionsService {
1044
+ constructor() { }
1045
+ dateForm(date) {
1046
+ let data = new Date(date);
1047
+ let change = `${data.getFullYear()}/${data.getMonth() + 1}/${data.getDate()}`;
1048
+ return (change);
1049
+ }
1050
+ dateIso(date) {
1051
+ let data = date.toString();
1052
+ let cut = data.replace(/(.*)\T.*/, '$1');
1053
+ let add = `${cut}T05:00:00.000Z`;
1054
+ let fecha = add.replace(/(.*)\T.*/, '$1');
1055
+ return (fecha);
1056
+ }
1057
+ dateDB(date) {
1058
+ let day = this.validateTwoDigitFormat(date.getDate().toString());
1059
+ let month = this.validateTwoDigitFormat((date.getMonth() + 1).toString());
1060
+ return `${date.getFullYear()}-${month}-${day}`;
1061
+ }
1062
+ dateWithTime(date) {
1063
+ if (!date)
1064
+ return "";
1065
+ var value = date.split("T");
1066
+ return value[0] + " " + value[1].split(".")[0];
1067
+ }
1068
+ areObjectsEqual(obj1, obj2) {
1069
+ return JSON.stringify(obj1) === JSON.stringify(obj2);
1070
+ }
1071
+ removeDuplicateObjects(originalArray) {
1072
+ const uniqueArray = [];
1073
+ originalArray.forEach((obj) => {
1074
+ if (!uniqueArray.some((uniqueObj) => this.areObjectsEqual(obj, uniqueObj))) {
1075
+ uniqueArray.push(obj);
1076
+ }
1077
+ });
1078
+ return uniqueArray;
1079
+ }
1080
+ validateTwoDigitFormat(number) {
1081
+ if (number.length == 1)
1082
+ number = "0" + number;
1083
+ return number;
1084
+ }
1085
+ }
1086
+ FunctionsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
1087
+ FunctionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, providedIn: 'root' });
1088
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, decorators: [{
1089
+ type: Injectable,
1090
+ args: [{
1091
+ providedIn: 'root'
1092
+ }]
1093
+ }], ctorParameters: function () { return []; } });
1094
+
1095
+ class FiltersComponent {
1096
+ constructor(functionEter, http) {
1097
+ this.functionEter = functionEter;
1098
+ this.http = http;
1099
+ this.headerFilters = [];
1100
+ this.applyFilters = new EventEmitter();
1101
+ this.headerFiltersValue = "-1";
1102
+ this.headerFiltersSelected = [];
1103
+ this.movil = ScreenSizeUtil.isMobile();
1104
+ this.filtersPost = [];
1105
+ this.loadDates();
1106
+ this.loadDatesBetween();
1107
+ }
1108
+ ngOnChanges(changes) {
1109
+ return __awaiter(this, void 0, void 0, function* () {
1110
+ if (changes) {
1111
+ yield this.loadFilter();
1112
+ }
1113
+ });
1114
+ }
1115
+ ngOnInit() {
1116
+ return __awaiter(this, void 0, void 0, function* () {
1117
+ // if(this.headerFilters && this.headerFilters.length > 0)
1118
+ // await this.loadFilter()
1119
+ });
1120
+ }
1121
+ handlerFiltersDate(deleteFilter, item, valueDate = null, valueBetween1 = null, valueBetween2 = null) {
1122
+ switch (item.type) {
1123
+ case 'date':
1124
+ if (deleteFilter) {
1125
+ this.delteFilter({
1126
+ labelFilter: 'Fecha entre',
1127
+ type: 'dateRange'
1128
+ });
1129
+ }
1130
+ else {
1131
+ this.loadDates(new Date(valueDate + "T05:00:00.000Z"));
1132
+ }
1133
+ break;
1134
+ case 'dateRange':
1135
+ if (deleteFilter) {
1136
+ this.delteFilter({
1137
+ labelFilter: 'Fecha igual a',
1138
+ type: 'date'
1139
+ });
1140
+ }
1141
+ else {
1142
+ this.loadDatesBetween(false, new Date(valueBetween1 + "T05:00:00.000Z"), new Date(valueBetween2 + "T05:00:00.000Z"));
1143
+ }
1144
+ break;
1145
+ default:
1146
+ break;
1147
+ }
1148
+ }
1149
+ selectFilter($event) {
1150
+ let validate = this.headerFiltersSelected.find(x => x.labelFilter == $event.value);
1151
+ if (!validate) {
1152
+ let value = this.headerFilters.find(x => x.labelFilter == $event.value);
1153
+ if (value) {
1154
+ this.headerFiltersSelected.push(value);
1155
+ this.handlerFiltersDate(true, { type: value.type });
1156
+ }
1157
+ }
1158
+ setTimeout(() => {
1159
+ this.headerFiltersValue = null;
1160
+ }, 500);
1161
+ }
1162
+ selectFilterData($event, item) {
1163
+ return __awaiter(this, void 0, void 0, function* () {
1164
+ let i = this.headerFiltersSelected.findIndex(x => x.labelFilter == item.labelFilter);
1165
+ if (i >= 0)
1166
+ this.headerFiltersSelected[i].value = $event.value;
1167
+ let f = this.filtersPost.findIndex(x => x.labelFilter == item.labelFilter);
1168
+ if ($event.value) {
1169
+ let value = null;
1170
+ switch (item.type) {
1171
+ case 'select':
1172
+ value = $event.value;
1173
+ break;
1174
+ case 'date':
1175
+ value = this.functionEter.dateDB($event.value);
1176
+ break;
1177
+ case 'dateRange':
1178
+ value = `${this.functionEter.dateDB(this.campaignOne.controls.start.value)},${this.functionEter.dateDB(this.campaignOne.controls.end.value)}`;
1179
+ break;
1180
+ default:
1181
+ break;
1182
+ }
1183
+ if (!value)
1184
+ return;
1185
+ if (f >= 0) {
1186
+ this.filtersPost[f].value = value;
1187
+ }
1188
+ else {
1189
+ this.filtersPost.push({
1190
+ tN: btoa(item.tN),
1191
+ primaryKey: item.fileNameDb ? item.fileNameDb : item.primaryKey,
1192
+ type: item.type,
1193
+ value: value,
1194
+ labelFilter: item.labelFilter
1195
+ });
1196
+ }
1197
+ this.applyFilters.emit(this.filtersPost);
1198
+ }
1199
+ });
1200
+ }
1201
+ delteFilter(item) {
1202
+ let i = this.headerFiltersSelected.findIndex(x => x.labelFilter == item.labelFilter);
1203
+ let f = this.filtersPost.findIndex(x => x.labelFilter == item.labelFilter);
1204
+ if (i >= 0) {
1205
+ this.headerFiltersSelected[i].value = "-1";
1206
+ this.headerFiltersSelected.splice(i, 1);
1207
+ }
1208
+ if (f >= 0) {
1209
+ this.filtersPost.splice(f, 1);
1210
+ this.applyFilters.emit(this.filtersPost);
1211
+ }
1212
+ this.handlerFiltersDate(false, item);
1213
+ setTimeout(() => {
1214
+ this.headerFiltersValue = null;
1215
+ }, 500);
1216
+ }
1217
+ loadDates(value = null) {
1218
+ this.fecha = new UntypedFormGroup({
1219
+ fecha: new UntypedFormControl(value)
1220
+ });
1221
+ }
1222
+ loadDatesBetween(init = true, value1 = null, value2 = null) {
1223
+ if (init) {
1224
+ this.campaignOne = new UntypedFormGroup({
1225
+ start: new UntypedFormControl(null),
1226
+ end: new UntypedFormControl(null),
1227
+ });
1228
+ this.campaignTwo = new UntypedFormGroup({
1229
+ start: new UntypedFormControl(null),
1230
+ end: new UntypedFormControl(null),
1231
+ });
1232
+ return;
1233
+ }
1234
+ var day1 = 1;
1235
+ var day2 = 15;
1236
+ if (!value1) {
1237
+ value1 = new Date();
1238
+ }
1239
+ else {
1240
+ day1 = value1.getDate();
1241
+ }
1242
+ if (!value2) {
1243
+ value2 = new Date();
1244
+ }
1245
+ else {
1246
+ day2 = value2.getDate();
1247
+ }
1248
+ this.campaignOne = new UntypedFormGroup({
1249
+ start: new UntypedFormControl(new Date(value1.getFullYear(), value1.getMonth(), day1)),
1250
+ end: new UntypedFormControl(new Date(value2.getFullYear(), value2.getMonth(), day2)),
1251
+ });
1252
+ this.campaignTwo = new UntypedFormGroup({
1253
+ start: new UntypedFormControl(new Date(value1.getFullYear(), value1.getMonth(), day1)),
1254
+ end: new UntypedFormControl(new Date(value1.getFullYear(), value1.getMonth(), day1)),
1255
+ });
1256
+ }
1257
+ loadFilter() {
1258
+ var _a, _b;
1259
+ return __awaiter(this, void 0, void 0, function* () {
1260
+ // if (this.headerFiltersSelected.length != 0) {
1261
+ // return
1262
+ // }
1263
+ let applyFilter = false;
1264
+ for (let element of this.headerFilters) {
1265
+ if (element.urlData) {
1266
+ let res = yield this.http.getDataBody(element.urlData);
1267
+ element.body = res;
1268
+ }
1269
+ else if (element.type == 'select') {
1270
+ element.body = element.data;
1271
+ }
1272
+ element.filteredList = element.body;
1273
+ if (!element.primaryKey)
1274
+ element.primaryKey = element.visibleField;
1275
+ if (element.type == "date")
1276
+ element.labelFilter = (_a = element.labelFilter) !== null && _a !== void 0 ? _a : "Fecha igual a";
1277
+ if (element.type == "dateRange")
1278
+ element.labelFilter = (_b = element.labelFilter) !== null && _b !== void 0 ? _b : "Fecha entre";
1279
+ if (element.active) {
1280
+ this.headerFiltersSelected.push(element);
1281
+ this.filtersPost.push({
1282
+ tN: btoa(element.tN),
1283
+ primaryKey: element.fileNameDb ? element.fileNameDb : element.primaryKey,
1284
+ type: element.type,
1285
+ value: element.value,
1286
+ labelFilter: element.labelFilter
1287
+ });
1288
+ this.handlerFiltersDate(false, element, element.value, element.value.split(',')[0], element.value.split(',')[1]);
1289
+ if (element.value && element.value != '') {
1290
+ applyFilter = true;
1291
+ }
1292
+ }
1293
+ }
1294
+ if (applyFilter) {
1295
+ this.applyFilters.emit(this.filtersPost);
1296
+ }
1297
+ });
1298
+ }
1299
+ }
1300
+ FiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FiltersComponent, deps: [{ token: FunctionsService }, { token: HttpService }], target: i0.ɵɵFactoryTarget.Component });
1301
+ FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FiltersComponent, selector: "app-filters", inputs: { headerFilters: "headerFilters" }, outputs: { applyFilters: "applyFilters" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"headerFilters && headerFilters.length > 0\" style=\"display: flex; width: 100%; flex-wrap: wrap;\" class=\"col-12 mb-2\">\r\n <div class=\"col-md-4 col-12\">\r\n <mat-form-field >\r\n <mat-label>Filtros</mat-label>\r\n <mat-select (selectionChange)=\"selectFilter($event)\" [(ngModel)]=\"headerFiltersValue\">\r\n <mat-option\r\n *ngFor=\"let f of headerFilters\"\r\n value=\"{{ f.labelFilter }}\"\r\n >\r\n {{ f.labelFilter }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n\r\n <div *ngFor=\"let item of headerFiltersSelected\" class=\"col-md-4 col-12 d-flex align-items-center\">\r\n <mat-form-field *ngIf=\"item.type == 'select'\">\r\n <mat-label>Filtrar por {{item.labelFilter}}</mat-label>\r\n <mat-select (selectionChange)=\"selectFilterData($event, item)\" [value]=\"item.value\">\r\n <app-select-filter\r\n [placeholder]=\"'Filter'\"\r\n [displayMember]=\"item.visibleField\"\r\n [array]=\"item.body\"\r\n (filteredReturn)=\"item.filteredList = $event\"\r\n [noResultsMessage]=\"'No hay resultados'\"\r\n >\r\n </app-select-filter>\r\n <mat-option\r\n *ngFor=\"let data of item.filteredList\"\r\n value=\"{{ data[item.primaryKey] }}\"\r\n >\r\n {{ data[item.visibleField] }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"item.type == 'date'\" [formGroup]=\"fecha\">\r\n <mat-label>{{item.labelFilter}}</mat-label>\r\n <input (dateInput)=\"selectFilterData($event, item)\" matInput [matDatepicker]=\"Fecha\" autocomplete=\"off\" matInput\r\n formControlName='fecha' required>\r\n <mat-datepicker-toggle matSuffix [for]=\"Fecha\">\r\n </mat-datepicker-toggle>\r\n <mat-datepicker dateInput #Fecha [touchUi]='movil?true:false'></mat-datepicker>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"item.type == 'dateRange'\">\r\n <mat-label>{{item.labelFilter}}</mat-label>\r\n <mat-date-range-input\r\n [formGroup]=\"campaignOne\"\r\n [rangePicker]=\"campaignOnePicker\"\r\n [comparisonStart]=\"campaignTwo.value.start\"\r\n [comparisonEnd]=\"campaignTwo.value.end\">\r\n <input matStartDate placeholder=\"Start date\" formControlName=\"start\">\r\n <input (dateInput)=\"selectFilterData($event, item)\" matEndDate placeholder=\"End date\" formControlName=\"end\">\r\n </mat-date-range-input>\r\n <mat-datepicker-toggle matSuffix [for]=\"campaignOnePicker\"></mat-datepicker-toggle>\r\n <mat-date-range-picker #campaignOnePicker></mat-date-range-picker>\r\n </mat-form-field>\r\n\r\n <div class=\"p-2\" style=\"cursor: pointer\" (click)=\"delteFilter(item)\"><mat-icon>cancel</mat-icon></div>\r\n\r\n </div>\r\n</div>\r\n", styles: ["mat-form-field{padding:0!important;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8$1.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i9.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i9.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i9.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i9.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i9.MatStartDate, selector: "input[matStartDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i9.MatEndDate, selector: "input[matEndDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i9.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1$2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: SelectFilterComponent, selector: "app-select-filter", inputs: ["array", "placeholder", "color", "displayMember", "showSpinner", "noResultsMessage", "hasGroup", "groupArrayName"], outputs: ["filteredReturn"] }] });
1302
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FiltersComponent, decorators: [{
1303
+ type: Component,
1304
+ args: [{ selector: 'app-filters', template: "<div *ngIf=\"headerFilters && headerFilters.length > 0\" style=\"display: flex; width: 100%; flex-wrap: wrap;\" class=\"col-12 mb-2\">\r\n <div class=\"col-md-4 col-12\">\r\n <mat-form-field >\r\n <mat-label>Filtros</mat-label>\r\n <mat-select (selectionChange)=\"selectFilter($event)\" [(ngModel)]=\"headerFiltersValue\">\r\n <mat-option\r\n *ngFor=\"let f of headerFilters\"\r\n value=\"{{ f.labelFilter }}\"\r\n >\r\n {{ f.labelFilter }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n\r\n <div *ngFor=\"let item of headerFiltersSelected\" class=\"col-md-4 col-12 d-flex align-items-center\">\r\n <mat-form-field *ngIf=\"item.type == 'select'\">\r\n <mat-label>Filtrar por {{item.labelFilter}}</mat-label>\r\n <mat-select (selectionChange)=\"selectFilterData($event, item)\" [value]=\"item.value\">\r\n <app-select-filter\r\n [placeholder]=\"'Filter'\"\r\n [displayMember]=\"item.visibleField\"\r\n [array]=\"item.body\"\r\n (filteredReturn)=\"item.filteredList = $event\"\r\n [noResultsMessage]=\"'No hay resultados'\"\r\n >\r\n </app-select-filter>\r\n <mat-option\r\n *ngFor=\"let data of item.filteredList\"\r\n value=\"{{ data[item.primaryKey] }}\"\r\n >\r\n {{ data[item.visibleField] }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"item.type == 'date'\" [formGroup]=\"fecha\">\r\n <mat-label>{{item.labelFilter}}</mat-label>\r\n <input (dateInput)=\"selectFilterData($event, item)\" matInput [matDatepicker]=\"Fecha\" autocomplete=\"off\" matInput\r\n formControlName='fecha' required>\r\n <mat-datepicker-toggle matSuffix [for]=\"Fecha\">\r\n </mat-datepicker-toggle>\r\n <mat-datepicker dateInput #Fecha [touchUi]='movil?true:false'></mat-datepicker>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"item.type == 'dateRange'\">\r\n <mat-label>{{item.labelFilter}}</mat-label>\r\n <mat-date-range-input\r\n [formGroup]=\"campaignOne\"\r\n [rangePicker]=\"campaignOnePicker\"\r\n [comparisonStart]=\"campaignTwo.value.start\"\r\n [comparisonEnd]=\"campaignTwo.value.end\">\r\n <input matStartDate placeholder=\"Start date\" formControlName=\"start\">\r\n <input (dateInput)=\"selectFilterData($event, item)\" matEndDate placeholder=\"End date\" formControlName=\"end\">\r\n </mat-date-range-input>\r\n <mat-datepicker-toggle matSuffix [for]=\"campaignOnePicker\"></mat-datepicker-toggle>\r\n <mat-date-range-picker #campaignOnePicker></mat-date-range-picker>\r\n </mat-form-field>\r\n\r\n <div class=\"p-2\" style=\"cursor: pointer\" (click)=\"delteFilter(item)\"><mat-icon>cancel</mat-icon></div>\r\n\r\n </div>\r\n</div>\r\n", styles: ["mat-form-field{padding:0!important;width:100%}\n"] }]
1305
+ }], ctorParameters: function () { return [{ type: FunctionsService }, { type: HttpService }]; }, propDecorators: { headerFilters: [{
1306
+ type: Input
1307
+ }], applyFilters: [{
1308
+ type: Output
1309
+ }] } });
1310
+
1311
+ const Root = {
1312
+ id: 1,
1313
+ name: 'root',
1314
+ hasAccessToAll: true,
1315
+ };
1316
+ const Administrative = {
1317
+ id: 2,
1318
+ name: 'Administrativo',
1319
+ modules: [
1320
+ {
1321
+ id: 0,
1322
+ name: "Inicio"
1323
+ },
1324
+ {
1325
+ id: 2,
1326
+ name: "Administración",
1327
+ hasAccessToAll: true,
1328
+ },
1329
+ {
1330
+ id: 3,
1331
+ name: "Mantenimiento",
1332
+ hasAccessToAll: true
1333
+ },
1334
+ {
1335
+ id: 4,
1336
+ name: "Combustible",
1337
+ hasAccessToAll: true
1338
+ },
1339
+ {
1340
+ id: 5,
1341
+ name: "Personal",
1342
+ hasAccessToAll: true
1343
+ },
1344
+ {
1345
+ id: 6,
1346
+ name: "Indicadores",
1347
+ hasAccessToAll: true
1348
+ },
1349
+ {
1350
+ id: 7,
1351
+ name: "Inspecciones",
1352
+ hasAccessToAll: true
1353
+ },
1354
+ {
1355
+ id: 8,
1356
+ name: "Almacén",
1357
+ hasAccessToAll: true
1358
+ },
1359
+ {
1360
+ id: 9,
1361
+ name: "Localización",
1362
+ hasAccessToAll: true
1363
+ },
1364
+ {
1365
+ id: 10,
1366
+ name: "Alquiler",
1367
+ hasAccessToAll: true
1368
+ },
1369
+ ],
1370
+ };
1371
+ const MaintenanceManager = {
1372
+ id: 3,
1373
+ name: 'Jefe Mantenimiento',
1374
+ modules: [
1375
+ {
1376
+ id: 0,
1377
+ name: "Inicio"
1378
+ },
1379
+ {
1380
+ id: 2,
1381
+ name: "Administración",
1382
+ hasAccessToAll: true,
1383
+ },
1384
+ {
1385
+ id: 3,
1386
+ name: "Mantenimiento",
1387
+ hasAccessToAll: true
1388
+ },
1389
+ {
1390
+ id: 4,
1391
+ name: "Combustible",
1392
+ hasAccessToAll: true
1393
+ },
1394
+ {
1395
+ id: 5,
1396
+ name: "Personal",
1397
+ hasAccessToAll: true
1398
+ },
1399
+ {
1400
+ id: 6,
1401
+ name: "Indicadores",
1402
+ hasAccessToAll: true
1403
+ },
1404
+ {
1405
+ id: 7,
1406
+ name: "Inspecciones",
1407
+ hasAccessToAll: true
1408
+ },
1409
+ {
1410
+ id: 8,
1411
+ name: "Almacén",
1412
+ hasAccessToAll: true
1413
+ },
1414
+ {
1415
+ id: 9,
1416
+ name: "Localización",
1417
+ hasAccessToAll: true
1418
+ },
1419
+ {
1420
+ id: 10,
1421
+ name: "Alquiler",
1422
+ hasAccessToAll: true
1423
+ },
1424
+ ],
1425
+ };
1426
+ const BasicOperator = {
1427
+ id: 4,
1428
+ name: 'Operario básico',
1429
+ modules: [
1430
+ {
1431
+ id: 0,
1432
+ name: "Inicio"
1433
+ },
1434
+ {
1435
+ id: 2,
1436
+ name: "Administración",
1437
+ subModules: [
1438
+ { id: 2, name: "Terceros", permissions: { readDetail: true, readAll: true } },
1439
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1440
+ ]
1441
+ },
1442
+ {
1443
+ id: 3,
1444
+ name: "Mantenimiento",
1445
+ subModules: [
1446
+ { id: 10, name: "Registro de Mtto", permissions: { write: true } },
1447
+ { id: 12, name: "Solicitudes Mtto", permissions: { readDetail: true, write: true, delete: true, update: true } },
1448
+ { id: 7, name: "Ejecucion O.T", permissions: { readOwn: true, closeOT: true } },
1449
+ ]
1450
+ },
1451
+ {
1452
+ id: 4,
1453
+ name: "Combustible",
1454
+ subModules: [
1455
+ { id: 16, name: "Solicitudes", permissions: { readDetail: true, write: true, delete: true, update: true } },
1456
+ { id: 17, name: 'Órdenes', permissions: { readDetail: true, closeOT: true } },
1457
+ ]
1458
+ },
1459
+ {
1460
+ id: 7,
1461
+ name: "Inspecciones",
1462
+ subModules: [
1463
+ { id: 27, name: "Diligenciar", permissions: { write: true, update: true } },
1464
+ { id: 28, name: "Consultar", permissions: { readAll: true } },
1465
+ ]
1466
+ },
1467
+ {
1468
+ id: 9,
1469
+ name: "Localización",
1470
+ subModules: [
1471
+ { id: 38, name: "Iniciar ruta", permissions: { readDetail: true, write: true } },
1472
+ ]
1473
+ },
1474
+ // {
1475
+ // id: 10,
1476
+ // name: "Alquiler",
1477
+ // subModules: [
1478
+ // {id: 41, name: "Ingreso", permissions: {readDetail:true, write:true}},
1479
+ // {id: 42, name: "Despacho", permissions: {readDetail:true, write:true}},
1480
+ // {id: 43, name: "Catalogo", permissions: {readDetail:true, write:true}},
1481
+ // {id: 44, name: "Orden Alquiler", permissions: {readDetail:true, write:true}},
1482
+ // ]
1483
+ // }
1484
+ ]
1485
+ };
1486
+ const BasicMechanical = {
1487
+ id: 5,
1488
+ name: 'Mecanico básico',
1489
+ modules: [
1490
+ {
1491
+ id: 0,
1492
+ name: "Inicio"
1493
+ },
1494
+ {
1495
+ id: 2,
1496
+ name: "Administración",
1497
+ subModules: [
1498
+ { id: 2, name: "Terceros", permissions: { readDetail: true, readAll: true } },
1499
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1500
+ ]
1501
+ },
1502
+ {
1503
+ id: 3,
1504
+ name: "Mantenimiento",
1505
+ subModules: [
1506
+ { id: 10, name: "Registro de Mtto", permissions: { write: true } },
1507
+ { id: 12, name: "Solicitudes Mtto", permissions: { readDetail: true, write: true, delete: true, update: true } },
1508
+ { id: 7, name: "Ejecucion O.T", permissions: { readOwn: true, closeOT: true } },
1509
+ ]
1510
+ },
1511
+ {
1512
+ id: 4,
1513
+ name: "Combustible",
1514
+ subModules: [
1515
+ { id: 16, name: "Solicitudes", permissions: { readDetail: true, write: true, delete: true, update: true } },
1516
+ ]
1517
+ },
1518
+ {
1519
+ id: 7,
1520
+ name: "Inspecciones",
1521
+ subModules: [
1522
+ { id: 27, name: "Diligenciar", permissions: { write: true, update: true } },
1523
+ { id: 28, name: "Consultar", permissions: { readAll: true } },
1524
+ ]
1525
+ }
1526
+ ]
1527
+ };
1528
+ const BasicStorer = {
1529
+ id: 6,
1530
+ name: 'Almacenista básico',
1531
+ modules: [
1532
+ {
1533
+ id: 0,
1534
+ name: "Inicio"
1535
+ },
1536
+ {
1537
+ id: 2,
1538
+ name: "Administración",
1539
+ subModules: [
1540
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1541
+ { id: 25, name: "Datos", permissions: {} },
1542
+ ]
1543
+ },
1544
+ {
1545
+ id: 3,
1546
+ name: "Mantenimiento",
1547
+ subModules: [
1548
+ { id: 33, name: "Despachar", permissions: { readAll: true, allocateResources: true } },
1549
+ ]
1550
+ },
1551
+ {
1552
+ id: 6,
1553
+ name: "Indicadores",
1554
+ subModules: [
1555
+ { id: 35, name: "Almacen", permissions: { readAll: true, write: true, delete: true, update: true } },
1556
+ ]
1557
+ },
1558
+ {
1559
+ id: 8,
1560
+ name: "Almacén",
1561
+ subModules: [
1562
+ { id: 30, name: "Entradas", permissions: { readAll: true, write: true, delete: true, update: true } },
1563
+ { id: 31, name: "Salidas", permissions: { readAll: true, write: true, delete: true, update: true } },
1564
+ { id: 32, name: "Inventario", permissions: { readAll: true, write: true, delete: true, update: true } },
1565
+ { id: 34, name: "Orden Compra", permissions: { readAll: true, write: true, delete: true, update: true } },
1566
+ { id: 39, name: "Bodegas", permissions: { readAll: true, write: true, delete: true, update: true } },
1567
+ ]
1568
+ },
1569
+ // {
1570
+ // id: 10,
1571
+ // name: "Alquiler",
1572
+ // hasAccessToAll: true
1573
+ // }
1574
+ ],
1575
+ };
1576
+ const AdvanceStorer = {
1577
+ id: 7,
1578
+ name: 'Almacenista avanzado',
1579
+ modules: [
1580
+ {
1581
+ id: 0,
1582
+ name: "Inicio"
1583
+ },
1584
+ {
1585
+ id: 2,
1586
+ name: "Administración",
1587
+ subModules: [
1588
+ { id: 2, name: "Terceros", permissions: { readAll: true } },
1589
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1590
+ ]
1591
+ },
1592
+ {
1593
+ id: 3,
1594
+ name: "Mantenimiento",
1595
+ subModules: [
1596
+ { id: 4, name: "Equipos", permissions: { readAll: true } },
1597
+ { id: 8, name: "Históricos", permissions: { readAll: true } },
1598
+ { id: 9, name: "Calendario", permissions: { readAll: true } },
1599
+ { id: 33, name: "Despachar", permissions: { readAll: true, allocateResources: true } },
1600
+ ]
1601
+ },
1602
+ {
1603
+ id: 6,
1604
+ name: "Indicadores",
1605
+ subModules: [
1606
+ { id: 35, name: "Almacen", permissions: { readAll: true, write: true, delete: true, update: true } },
1607
+ ]
1608
+ },
1609
+ {
1610
+ id: 8,
1611
+ name: "Almacén",
1612
+ subModules: [
1613
+ { id: 30, name: "Entradas", permissions: { readAll: true, write: true, delete: true, update: true } },
1614
+ { id: 31, name: "Salidas", permissions: { readAll: true, write: true, delete: true, update: true } },
1615
+ { id: 32, name: "Inventario", permissions: { readAll: true, write: true, delete: true, update: true } },
1616
+ { id: 34, name: "Orden Compra", permissions: { readAll: true, write: true, delete: true, update: true } },
1617
+ ]
1618
+ },
1619
+ ],
1620
+ };
1621
+ const AdvanceOperator = {
1622
+ id: 8,
1623
+ name: 'Operario avanzado',
1624
+ modules: [
1625
+ {
1626
+ id: 0,
1627
+ name: "Inicio",
1628
+ subModules: []
1629
+ },
1630
+ {
1631
+ id: 2,
1632
+ name: "Administración",
1633
+ subModules: [
1634
+ { id: 2, name: "Terceros", permissions: { readAll: true } },
1635
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1636
+ ]
1637
+ },
1638
+ {
1639
+ id: 3,
1640
+ name: "Mantenimiento",
1641
+ subModules: [
1642
+ { id: 4, name: "Equipos", permissions: { readAll: true } },
1643
+ { id: 5, name: "Actividades", permissions: { readAll: true } },
1644
+ { id: 7, name: "Ejecucion O.T", permissions: { readOwn: true, closeOT: true } },
1645
+ { id: 8, name: "Históricos", permissions: { readAll: true } },
1646
+ { id: 9, name: "Calendario", permissions: { readAll: true } },
1647
+ { id: 10, name: "Registro de Mtto", permissions: { readAll: true, write: true } },
1648
+ { id: 12, name: "Solicitudes Mtto", permissions: { readAll: true, write: true, delete: true, update: true } }
1649
+ ]
1650
+ },
1651
+ {
1652
+ id: 4,
1653
+ name: "Combustible",
1654
+ subModules: [
1655
+ { id: 16, name: "Solicitudes", permissions: { readAll: true, write: true, delete: true, update: true } },
1656
+ { id: 17, name: "Órdenes", permissions: { readOwn: true, closeOT: true } },
1657
+ { id: 18, name: "Históricos", permissions: { readAll: true } },
1658
+ ]
1659
+ },
1660
+ {
1661
+ id: 7,
1662
+ name: "Inspecciones",
1663
+ subModules: [
1664
+ { id: 27, name: "Diligenciar", permissions: { readAll: true, write: true, delete: true, update: true } },
1665
+ { id: 28, name: "Consultar", permissions: { readAll: true, write: true, delete: true, update: true } },
1666
+ ]
1667
+ },
1668
+ {
1669
+ id: 8,
1670
+ name: "Almacén",
1671
+ subModules: [
1672
+ { id: 32, name: "Inventario", permissions: { readAll: true } },
1673
+ ]
1674
+ },
1675
+ {
1676
+ id: 9,
1677
+ name: "Localización",
1678
+ subModules: [
1679
+ { id: 37, name: "Históricos", permissions: { readAll: true, write: true } },
1680
+ { id: 38, name: "Iniciar ruta", permissions: { readAll: true, write: true, delete: true, update: true } },
1681
+ ]
1682
+ },
1683
+ ]
1684
+ };
1685
+ const AdvanceMechanical = {
1686
+ id: 9,
1687
+ name: 'Mecanico avanzado',
1688
+ modules: [
1689
+ {
1690
+ id: 0,
1691
+ name: "Inicio",
1692
+ subModules: []
1693
+ },
1694
+ {
1695
+ id: 2,
1696
+ name: "Administración",
1697
+ subModules: [
1698
+ { id: 2, name: "Terceros", permissions: { readAll: true } },
1699
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1700
+ ]
1701
+ },
1702
+ {
1703
+ id: 3,
1704
+ name: "Mantenimiento",
1705
+ subModules: [
1706
+ { id: 4, name: "Equipos", permissions: { readAll: true } },
1707
+ { id: 5, name: "Actividades", permissions: { readAll: true } },
1708
+ { id: 7, name: "Ejecucion O.T", permissions: { readOwn: true, closeOT: true } },
1709
+ { id: 8, name: "Históricos", permissions: { readAll: true } },
1710
+ { id: 9, name: "Calendario", permissions: { readAll: true } },
1711
+ { id: 10, name: "Registro de Mtto", permissions: { readAll: true, write: true } },
1712
+ { id: 12, name: "Solicitudes Mtto", permissions: { readAll: true, write: true, delete: true, update: true } }
1713
+ ]
1714
+ },
1715
+ {
1716
+ id: 4,
1717
+ name: "Combustible",
1718
+ subModules: [
1719
+ { id: 16, name: "Solicitudes", permissions: { readAll: true, write: true, delete: true, update: true } },
1720
+ { id: 17, name: "Órdenes", permissions: { readOwn: true, closeOT: true } },
1721
+ { id: 18, name: "Históricos", permissions: { readAll: true } },
1722
+ ]
1723
+ },
1724
+ {
1725
+ id: 7,
1726
+ name: "Inspecciones",
1727
+ subModules: [
1728
+ { id: 27, name: "Diligenciar", permissions: { readAll: true, write: true, delete: true, update: true } },
1729
+ { id: 28, name: "Consultar", permissions: { readAll: true, write: true, delete: true, update: true } },
1730
+ ]
1731
+ },
1732
+ {
1733
+ id: 8,
1734
+ name: "Almacén",
1735
+ subModules: [
1736
+ { id: 32, name: "Inventario", permissions: { readAll: true } },
1737
+ ]
1738
+ },
1739
+ ]
1740
+ };
1741
+ const OperatorFusion = {
1742
+ id: 10,
1743
+ name: 'Operario fusion',
1744
+ modules: [
1745
+ {
1746
+ id: 0,
1747
+ name: "Inicio"
1748
+ },
1749
+ {
1750
+ id: 2,
1751
+ name: "Administración",
1752
+ subModules: [
1753
+ { id: 3, name: "Perfil", permissions: { readDetail: true, update: true } },
1754
+ ]
1755
+ },
1756
+ {
1757
+ id: 3,
1758
+ name: "Mantenimiento",
1759
+ subModules: [
1760
+ { id: 10, name: "Registro de Mtto", permissions: { write: true } },
1761
+ { id: 12, name: "Solicitudes Mtto", permissions: { readDetail: true, write: true, delete: true, update: true } },
1762
+ { id: 8, name: "Históricos", permissions: { readAll: true, update: true } },
1763
+ ]
1764
+ },
1765
+ {
1766
+ id: 4,
1767
+ name: "Combustible",
1768
+ subModules: [
1769
+ { id: 16, name: "Solicitudes", permissions: { readDetail: true, write: true, delete: true, update: true } },
1770
+ ]
1771
+ },
1772
+ {
1773
+ id: 7,
1774
+ name: "Inspecciones",
1775
+ subModules: [
1776
+ { id: 27, name: "Diligenciar", permissions: { write: true, update: true } },
1777
+ { id: 28, name: "Consultar", permissions: { readAll: true } },
1778
+ ]
1779
+ },
1780
+ {
1781
+ id: 9,
1782
+ name: "Localización",
1783
+ subModules: [
1784
+ { id: 38, name: "Iniciar ruta", permissions: { readDetail: true, write: true } },
1785
+ ]
1786
+ },
1787
+ ]
1788
+ };
1789
+ const modulesByRol = [
1790
+ Root,
1791
+ Administrative,
1792
+ MaintenanceManager,
1793
+ BasicOperator,
1794
+ BasicMechanical,
1795
+ BasicStorer,
1796
+ AdvanceOperator,
1797
+ AdvanceStorer,
1798
+ AdvanceMechanical,
1799
+ OperatorFusion
1800
+ ];
1801
+
1802
+ class ExportDataService {
1803
+ constructor(http, functionEter, message) {
1804
+ this.http = http;
1805
+ this.functionEter = functionEter;
1806
+ this.message = message;
1807
+ }
1808
+ generateExcelWithSheets(title, header, name, bodies, url, params, filtersPost, titleFields, sheetNameFields, BodyFields) {
1809
+ return __awaiter(this, void 0, void 0, function* () {
1810
+ this.message.openLoading("Cargando", "Generando archivo");
1811
+ bodies = yield this.getDataBody(url, params, bodies, filtersPost);
1812
+ const workbook = new Workbook();
1813
+ for (let index = 0; index < bodies.length; index++) {
1814
+ const body = bodies[index];
1815
+ if (titleFields) {
1816
+ title = titleFields.map(param => body[param]).join("-");
1817
+ }
1818
+ var nameSheet = "sheet";
1819
+ if (sheetNameFields) {
1820
+ nameSheet = sheetNameFields.map(param => body[param]).join("-");
1821
+ }
1822
+ const worksheet = yield this.generateToXlsx(title, header, `(${(index + 1) + ') ' + nameSheet}`, body, null, null, null, BodyFields, false);
1823
+ workbook.addWorksheet(worksheet.name, { views: [{ state: 'frozen', ySplit: 1 }] });
1824
+ const newWorksheet = workbook.getWorksheet(worksheet.name);
1825
+ newWorksheet.model = worksheet.model;
1826
+ }
1827
+ const buffer = yield workbook.xlsx.writeBuffer();
1828
+ this.saveAsExcelFile(buffer, name);
1829
+ this.message.closeLoading();
1830
+ });
1831
+ }
1832
+ generateToXlsx(title, header, name, body, url, params, filtersPost, BodyFields, generateFile = true) {
1833
+ var _a;
1834
+ return __awaiter(this, void 0, void 0, function* () {
1835
+ if (!generateFile)
1836
+ this.message.openLoading("Cargando", "Generando el archivo");
1837
+ body = yield this.getDataBody(url, params, body, filtersPost);
1838
+ let workbook = new Workbook();
1839
+ let worksheet = workbook.addWorksheet(name);
1840
+ // Add new row
1841
+ let titleRow = worksheet.addRow([title]);
1842
+ // Set font, size and style in title row.
1843
+ titleRow.font = {
1844
+ name: 'Comic Sans MS',
1845
+ family: 4,
1846
+ size: 16,
1847
+ underline: 'double',
1848
+ bold: true,
1849
+ };
1850
+ // Blank Row
1851
+ // worksheet.addRow([]);
1852
+ // let addheader = false
1853
+ // for (let p of header.filter(x => x.id === null)) {
1854
+ // worksheet.addRow([body[p.value]??p.value])
1855
+ // addheader = true
1856
+ // }
1857
+ worksheet.addRow([]);
1858
+ let addheader = false;
1859
+ for (let p of header.filter(x => x.id === null)) {
1860
+ let value = p.value;
1861
+ const matches = value.match(/{(.*?)}/g);
1862
+ if (matches) {
1863
+ matches.forEach(match => {
1864
+ var _a;
1865
+ const key = match.slice(1, -1);
1866
+ value = value.replace(match, (_a = body[key]) !== null && _a !== void 0 ? _a : match);
1867
+ });
1868
+ }
1869
+ worksheet.addRow([value]);
1870
+ addheader = true;
1871
+ }
1872
+ if (addheader)
1873
+ worksheet.addRow([]);
1874
+ //Add Header Row
1875
+ let headerRowValue = header.filter(x => x.id != null).map((p) => { var _a; return (_a = p.value) !== null && _a !== void 0 ? _a : p.id; });
1876
+ let _headerRowValue = worksheet.addRow(headerRowValue);
1877
+ // Cell Style : Fill and Border
1878
+ _headerRowValue.eachCell((cell, number) => {
1879
+ cell.fill = {
1880
+ type: 'pattern',
1881
+ pattern: 'lightUp',
1882
+ fgColor: { argb: '6775f500' },
1883
+ bgColor: { argb: '6775f500' },
1884
+ };
1885
+ cell.border = {
1886
+ top: { style: 'thin' },
1887
+ left: { style: 'thin' },
1888
+ bottom: { style: 'thin' },
1889
+ right: { style: 'thin' },
1890
+ };
1891
+ });
1892
+ var headerRow = header.filter(x => x.id != null);
1893
+ let data = BodyFields != null ? (_a = body[BodyFields]) !== null && _a !== void 0 ? _a : [] : body;
1894
+ for (let d of data) {
1895
+ var row = [];
1896
+ for (let h of headerRow) {
1897
+ var dh = d[`${h.id}`];
1898
+ if (h.rules) {
1899
+ for (const rule of h.rules) {
1900
+ if (rule.rule == enumRules$2['==']) {
1901
+ if (dh == rule.valueRule.toString())
1902
+ dh = rule.valueAction;
1903
+ }
1904
+ }
1905
+ }
1906
+ row.push(dh === null || dh === void 0 ? void 0 : dh.toString());
1907
+ }
1908
+ worksheet.addRow(row);
1909
+ }
1910
+ worksheet.columns.forEach(function (column, i) {
1911
+ var maxLength = 0;
1912
+ column["eachCell"]({ includeEmpty: true }, function (cell) {
1913
+ var columnLength = cell.value ? cell.value.toString().length : 10;
1914
+ if (columnLength > maxLength) {
1915
+ maxLength = columnLength;
1916
+ }
1917
+ });
1918
+ column.width = maxLength < 10 ? 10 : maxLength;
1919
+ });
1920
+ if (!generateFile) {
1921
+ return worksheet;
1922
+ }
1923
+ workbook.xlsx.writeBuffer().then((data) => {
1924
+ this.saveAsExcelFile(data, name);
1925
+ });
1926
+ if (!generateFile)
1927
+ this.message.closeLoading();
1928
+ });
1929
+ }
1930
+ saveAsExcelFile(buffer, fileName) {
1931
+ const data = new Blob([buffer], {
1932
+ type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'
1933
+ });
1934
+ fs.saveAs(data, `${fileName}_export_${new Date().getTime()}.xlsx`);
1935
+ }
1936
+ getDataBody(url, params, body, filtersPost) {
1937
+ return __awaiter(this, void 0, void 0, function* () {
1938
+ if (body)
1939
+ return body;
1940
+ if (url) {
1941
+ var res;
1942
+ res = yield this.http.postDataBody(url, filtersPost, params);
1943
+ if (res['count']) {
1944
+ return res['data'];
1945
+ }
1946
+ else {
1947
+ return res;
1948
+ }
1949
+ }
1950
+ });
1951
+ }
1952
+ }
1953
+ ExportDataService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, deps: [{ token: HttpService }, { token: FunctionsService }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Injectable });
1954
+ ExportDataService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, providedIn: 'root' });
1955
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, decorators: [{
1956
+ type: Injectable,
1957
+ args: [{
1958
+ providedIn: 'root'
1959
+ }]
1960
+ }], ctorParameters: function () { return [{ type: HttpService }, { type: FunctionsService }, { type: MessageService }]; } });
1961
+ var enumRules$2;
1962
+ (function (enumRules) {
1963
+ enumRules[enumRules[">"] = 0] = ">";
1964
+ enumRules[enumRules["<"] = 1] = "<";
1965
+ enumRules[enumRules["=="] = 2] = "==";
1966
+ enumRules[enumRules["!="] = 3] = "!=";
1967
+ })(enumRules$2 || (enumRules$2 = {}));
1968
+
1969
+ const spanishRangeLabel = (page, pageSize, length) => {
1970
+ if (length == 0 || pageSize == 0) {
1971
+ return `0 de ${length}`;
1972
+ }
1973
+ length = Math.max(length, 0);
1974
+ const startIndex = page * pageSize;
1975
+ const endIndex = startIndex < length
1976
+ ? Math.min(startIndex + pageSize, length)
1977
+ : startIndex + pageSize;
1978
+ return `${startIndex + 1} - ${endIndex} de ${length}`;
1979
+ };
1980
+ const rolesAndPermissions = modulesByRol;
1981
+ class DataTableComponent {
1982
+ constructor(dialog, http, message, functionEter, paginatorTranslate, exportService) {
1983
+ this.dialog = dialog;
1984
+ this.http = http;
1985
+ this.message = message;
1986
+ this.functionEter = functionEter;
1987
+ this.paginatorTranslate = paginatorTranslate;
1988
+ this.exportService = exportService;
1989
+ this.data = [];
1990
+ this.configuration = {
1991
+ add: false,
1992
+ edit: false,
1993
+ delete: false,
1994
+ active: false,
1995
+ selectable: false,
1996
+ print: false,
1997
+ addPer: false,
1998
+ editPer: false,
1999
+ primaryKey: 'id',
2000
+ exportXslx: false,
2001
+ hideTitle: true,
2002
+ hideFilter: true,
2003
+ notInitialize: false,
2004
+ exportXslxByRow: false,
2005
+ exportXslxWithPages: false,
2006
+ view: false,
2007
+ closeOrder: false,
2008
+ packOff: false,
2009
+ advance: false,
2010
+ advanceLabel: null,
2011
+ income: false,
2012
+ exit: false,
2013
+ sendEmail: false,
2014
+ };
2015
+ this.titleLoading = '';
2016
+ this.messageLoading = '';
2017
+ this.headerFileXlsm = [];
2018
+ this.headerFilters = [];
2019
+ this.xslxParams = null;
2020
+ this.roleId = 0;
2021
+ this.moduleId = 0;
2022
+ this.subModuleId = 0;
2023
+ this.hasAccessToAll = true;
2024
+ this.rolesAndPermissionUser = {};
2025
+ this.clickRow = new EventEmitter();
2026
+ this.add = new EventEmitter();
2027
+ this.edit = new EventEmitter();
2028
+ this.delete = new EventEmitter();
2029
+ this.print = new EventEmitter();
2030
+ this.exportXslxByRow = new EventEmitter();
2031
+ this.active = new EventEmitter();
2032
+ this.selected = new EventEmitter();
2033
+ this.view = new EventEmitter();
2034
+ this.closeOrder = new EventEmitter();
2035
+ this.packOff = new EventEmitter();
2036
+ this.advance = new EventEmitter();
2037
+ this.income = new EventEmitter();
2038
+ this.exit = new EventEmitter();
2039
+ this.internalData = new EventEmitter();
2040
+ this.sendEmail = new EventEmitter();
2041
+ this.movil = ScreenSizeUtil.isMobile();
2042
+ this.filtersPost = [];
2043
+ this.selectedRows = []; /** almacena las filas seleccionadas */
2044
+ this.checkboxs = {};
2045
+ this.selectAll = false;
2046
+ this.indeterminateState = false;
2047
+ this.originalData = [];
2048
+ this.paginatorActive = true;
2049
+ this.screen = true;
2050
+ this.pageSizeOptions = [5, 10, 25, 50, 100];
2051
+ this.pageSize = screen.width > 500 ? 10 : 5;
2052
+ this.length = 0;
2053
+ this.page = 0;
2054
+ this.above = ['above'];
2055
+ this.buttonsConfig = [];
2056
+ this.paginatorTranslate.itemsPerPageLabel = 'Elementos por página';
2057
+ this.paginatorTranslate.nextPageLabel = 'Siguiente página';
2058
+ this.paginatorTranslate.lastPageLabel = 'Última página';
2059
+ this.paginatorTranslate.previousPageLabel = 'Página anterior';
2060
+ this.paginatorTranslate.firstPageLabel = 'Primera página';
2061
+ this.paginatorTranslate.getRangeLabel = spanishRangeLabel;
2062
+ }
2063
+ ngOnInit() {
2064
+ return __awaiter(this, void 0, void 0, function* () {
2065
+ this.validateRolAndPermission();
2066
+ if (window.screen.width > 1000) {
2067
+ this.screen = true;
2068
+ window.addEventListener('resize', () => {
2069
+ window.screen.width > 1000
2070
+ ? (this.screen = true)
2071
+ : (this.screen = false);
2072
+ });
2073
+ }
2074
+ else {
2075
+ this.screen = false;
2076
+ window.addEventListener('resize', () => {
2077
+ window.screen.width > 1000
2078
+ ? (this.screen = true)
2079
+ : (this.screen = false);
2080
+ });
2081
+ }
2082
+ if (this.reloadTable) {
2083
+ this.reloadTable.subscribe((res) => {
2084
+ this.originalData = [];
2085
+ this.selectAll = false;
2086
+ this.seletecAllEvent('');
2087
+ });
2088
+ }
2089
+ this.titleLoading == '' ? (this.titleLoading = 'Cargando') : '';
2090
+ this.messageLoading == ''
2091
+ ? (this.messageLoading = 'Obteniendo datos...')
2092
+ : '';
2093
+ this.url && !this.configuration.notInitialize
2094
+ ? this.message.openLoading(this.titleLoading, this.messageLoading)
2095
+ : '';
2096
+ try {
2097
+ if (this.url && !this.configuration.notInitialize) {
2098
+ let service = yield this.getDateTableByUrl();
2099
+ this.data = service['data'];
2100
+ this.length = service['count'];
2101
+ this.data.forEach((row) => {
2102
+ this.checkboxs[row[this.configuration.primaryKey]] = false;
2103
+ });
2104
+ this.internalData.emit(service);
2105
+ setTimeout(() => {
2106
+ this.message.closeLoading();
2107
+ }, 1000);
2108
+ this.validateRules();
2109
+ }
2110
+ else if (!this.url) {
2111
+ this.paginatorActive = false;
2112
+ }
2113
+ }
2114
+ catch (error) {
2115
+ console.log(error);
2116
+ }
2117
+ });
2118
+ }
2119
+ validateRolAndPermission() {
2120
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
2121
+ if (this.roleId == 0) {
2122
+ let rolePermissions = rolesAndPermissions === null || rolesAndPermissions === void 0 ? void 0 : rolesAndPermissions.find(x => x.id == this.roleId);
2123
+ this.hasAccessToAll = (_d = (_a = rolePermissions === null || rolePermissions === void 0 ? void 0 : rolePermissions.hasAccessToAll) !== null && _a !== void 0 ? _a : (_c = (_b = rolePermissions.modules) === null || _b === void 0 ? void 0 : _b.find(x => x.id == this.moduleId)) === null || _c === void 0 ? void 0 : _c.hasAccessToAll) !== null && _d !== void 0 ? _d : false;
2124
+ }
2125
+ ;
2126
+ this.rolesAndPermissionUser = (_k = (_j = (_h = (_g = (_f = (_e = rolesAndPermissions === null || rolesAndPermissions === void 0 ? void 0 : rolesAndPermissions.find(x => x.id == this.roleId)) === null || _e === void 0 ? void 0 : _e.modules) === null || _f === void 0 ? void 0 : _f.find(x => x.id == this.moduleId)) === null || _g === void 0 ? void 0 : _g.subModules) === null || _h === void 0 ? void 0 : _h.find(x => x.id == this.subModuleId)) === null || _j === void 0 ? void 0 : _j.permissions) !== null && _k !== void 0 ? _k : {};
2127
+ if (!this.hasAccessToAll && !this.rolesAndPermissionUser.readAll && this.rolesAndPermissionUser.readOwn == true) {
2128
+ this.params = [...this.params, { id: 'readOwn', value: true }];
2129
+ }
2130
+ this.configureButtons();
2131
+ }
2132
+ configureButtons() {
2133
+ this.buttonsConfig = [
2134
+ {
2135
+ action: 'edit',
2136
+ conditionShowHeader: () => this.selectedRows.length === 1 &&
2137
+ this.configuration.edit &&
2138
+ this.hasPermission('update'),
2139
+ condition: () => this.configuration.edit && this.hasPermission('update'),
2140
+ icon: 'fa-edit',
2141
+ tooltip: 'Editar',
2142
+ },
2143
+ {
2144
+ action: 'print',
2145
+ conditionShowHeader: () => this.selectedRows.length === 1 &&
2146
+ this.configuration.print &&
2147
+ this.screen &&
2148
+ this.hasPermission('print'),
2149
+ condition: () => this.configuration.print && this.screen && this.hasPermission('print'),
2150
+ icon: 'fa-print',
2151
+ tooltip: 'Imprimir',
2152
+ },
2153
+ {
2154
+ action: 'active',
2155
+ conditionShowHeader: () => this.selectedRows.length > 0 && this.configuration.active && this.hasPermission('activateAndInactivate'),
2156
+ condition: () => this.configuration.active && this.hasPermission('activateAndInactivate'),
2157
+ icon: 'fa-adjust',
2158
+ tooltip: 'Activar/Desactivar',
2159
+ },
2160
+ {
2161
+ action: 'add',
2162
+ conditionShowHeader: () => this.selectedRows.length === 0 && this.configuration.add && this.hasPermission('write'),
2163
+ condition: () => false,
2164
+ icon: 'fa-plus-circle',
2165
+ tooltip: 'Nuevo',
2166
+ },
2167
+ {
2168
+ action: 'income',
2169
+ conditionShowHeader: () => this.selectedRows.length === 0 && this.configuration.income && this.hasPermission('write'),
2170
+ condition: () => false,
2171
+ icon: 'fa-user-plus',
2172
+ tooltip: 'Ingreso',
2173
+ },
2174
+ {
2175
+ action: 'exit',
2176
+ conditionShowHeader: () => this.selectedRows.length === 0 && this.configuration.exit && this.hasPermission('write'),
2177
+ condition: () => false,
2178
+ icon: 'fa-user-times',
2179
+ tooltip: 'Salida',
2180
+ },
2181
+ {
2182
+ action: 'view',
2183
+ conditionShowHeader: () => this.selectedRows.length === 1 && this.configuration.view && this.hasPermission('readDetail'),
2184
+ condition: () => this.configuration.view && this.hasPermission('readDetail'),
2185
+ icon: 'fa-eye',
2186
+ tooltip: 'Ver detalle',
2187
+ },
2188
+ {
2189
+ action: 'closeOrder',
2190
+ conditionShowHeader: () => (this.selectedRows.length === 1 && this.configuration.closeOrder) && this.hasPermission('closeOT'),
2191
+ condition: () => this.configuration.closeOrder && this.hasPermission('closeOT'),
2192
+ icon: 'fa-check-circle',
2193
+ tooltip: 'Cerrar orden',
2194
+ },
2195
+ {
2196
+ action: 'packOff',
2197
+ conditionShowHeader: () => this.selectedRows.length === 1 && this.configuration.packOff && this.hasPermission('allocateResources'),
2198
+ condition: () => this.configuration.packOff && this.hasPermission('allocateResources'),
2199
+ icon: 'fa-cart-arrow-down',
2200
+ tooltip: 'Despachar recursos',
2201
+ },
2202
+ {
2203
+ action: 'advance',
2204
+ conditionShowHeader: () => this.selectedRows.length === 1 && this.configuration.advance && this.hasPermission('advance'),
2205
+ condition: () => this.configuration.advance && this.hasPermission('advance'),
2206
+ icon: 'fa-arrow-right',
2207
+ tooltip: this.configuration.advanceLabel,
2208
+ },
2209
+ {
2210
+ action: 'sendEmail',
2211
+ conditionShowHeader: () => this.selectedRows.length === 1 &&
2212
+ this.configuration.sendEmail &&
2213
+ this.screen &&
2214
+ this.hasPermission('sendEmail'),
2215
+ condition: () => this.configuration.sendEmail && this.screen && this.hasPermission('sendEmail'),
2216
+ icon: 'fa-mail-bulk',
2217
+ tooltip: 'Envia correo',
2218
+ },
2219
+ {
2220
+ action: 'exportToExcel',
2221
+ conditionShowHeader: () => this.selectedRows.length === 0 &&
2222
+ this.data.length > 0 &&
2223
+ (this.configuration.exportXslx || this.configuration.exportXslxWithPages) &&
2224
+ this.hasPermission('export'),
2225
+ condition: () => false,
2226
+ icon: 'fa-download',
2227
+ tooltip: 'Exportar Tabla',
2228
+ },
2229
+ {
2230
+ action: 'exportToExcelByRow',
2231
+ conditionShowHeader: () => this.selectedRows.length === 1 && this.configuration.exportXslxByRow && this.hasPermission('export'),
2232
+ condition: () => this.configuration.exportXslxByRow && this.hasPermission('export'),
2233
+ icon: 'fa-download',
2234
+ tooltip: 'Exportar Registro',
2235
+ },
2236
+ {
2237
+ action: 'delete',
2238
+ conditionShowHeader: () => this.selectedRows.length > 0 && this.configuration.delete && this.hasPermission('delete'),
2239
+ condition: () => this.configuration.delete && this.hasPermission('delete'),
2240
+ icon: 'fa-trash',
2241
+ tooltip: 'Eliminar',
2242
+ },
2243
+ ];
2244
+ }
2245
+ hasPermission(permission) {
2246
+ var _a, _b;
2247
+ if (this.hasAccessToAll)
2248
+ return true;
2249
+ return (_b = (_a = this.rolesAndPermissionUser) === null || _a === void 0 ? void 0 : _a[permission]) !== null && _b !== void 0 ? _b : false;
2250
+ }
2251
+ getDateTableByUrl() {
2252
+ return __awaiter(this, void 0, void 0, function* () {
2253
+ this.validarParams();
2254
+ return yield this.http.postDataBody(this.url, this.filtersPost, this.params);
2255
+ });
2256
+ }
2257
+ validarParams() {
2258
+ this.params = this.functionEter.removeDuplicateObjects(this.params);
2259
+ if (this.params) {
2260
+ if (!this.params.find((x) => x.id == 'page')) {
2261
+ this.params.push({ id: 'page', value: '0' });
2262
+ }
2263
+ if (!this.params.find((x) => x.id == 'per_page')) {
2264
+ this.params.push({ id: 'per_page', value: this.pageSize });
2265
+ }
2266
+ if (!this.params.find((x) => x.id == 'filter')) {
2267
+ this.params.push({ id: 'filter', value: '' });
2268
+ }
2269
+ }
2270
+ }
2271
+ validateRules() {
2272
+ var _a;
2273
+ return __awaiter(this, void 0, void 0, function* () {
2274
+ for (const [index, columns] of this.columns.entries()) {
2275
+ for (const [indexData, element] of this.data.entries()) {
2276
+ if (columns.rules) {
2277
+ for (const rule of columns.rules) {
2278
+ if (rule.rule == enumRules$1['==']) {
2279
+ if (element[columns.ID] &&
2280
+ element[columns.ID].toString() == rule.valueRule.toString()) {
2281
+ this.data[indexData][columns.ID] = rule.valueAction;
2282
+ }
2283
+ }
2284
+ }
2285
+ }
2286
+ const columnValue = element[columns.ID];
2287
+ if (columns.type == 'fecha' || columns.type == 'date')
2288
+ this.data[indexData][columns.ID] =
2289
+ this.functionEter.dateIso(columnValue);
2290
+ if (columns.type == 'dateWithTime')
2291
+ this.data[indexData][columns.ID] = this.functionEter.dateWithTime((_a = columnValue === null || columnValue === void 0 ? void 0 : columnValue.toString()) !== null && _a !== void 0 ? _a : columnValue);
2292
+ if (columns.type == 'currency')
2293
+ this.data[indexData][columns.ID] =
2294
+ Intl.NumberFormat('es-CO').format(columnValue);
2295
+ if (columns.type == 'boolean')
2296
+ this.data[indexData][columns.ID] = columnValue == 1 ? 'Si' : 'No';
2297
+ }
2298
+ }
2299
+ });
2300
+ }
2301
+ ngOnChanges(changes) {
2302
+ if (changes.data) {
2303
+ if (this.data) {
2304
+ this.data.forEach((row) => {
2305
+ this.checkboxs[row[this.configuration.primaryKey]] = false;
2306
+ });
2307
+ if (this.originalData.length == 0) {
2308
+ if (this.data.length != 0) {
2309
+ this.data.forEach((element) => {
2310
+ this.originalData.push(element);
2311
+ });
2312
+ }
2313
+ }
2314
+ }
2315
+ this.validateRules();
2316
+ }
2317
+ if (changes.configuration) {
2318
+ this.updateButtonConfig();
2319
+ }
2320
+ }
2321
+ updateButtonConfig() {
2322
+ this.buttonsConfig = this.buttonsConfig.map((button) => {
2323
+ var _a;
2324
+ if (button.action === 'advance') {
2325
+ return Object.assign(Object.assign({}, button), { tooltip: (_a = this.configuration.advanceLabel) !== null && _a !== void 0 ? _a : 'Avanzar' });
2326
+ }
2327
+ return button;
2328
+ });
2329
+ }
2330
+ clickOnRoW(rowData) {
2331
+ let state = this.checkboxs[rowData[this.configuration.primaryKey]];
2332
+ if (!this.configuration.selectable) {
2333
+ this.clearCheckboxes();
2334
+ }
2335
+ this.selection(rowData, { checked: !state }, this.configuration.selectable);
2336
+ this.clickRow.emit(rowData);
2337
+ }
2338
+ showMenu($event) {
2339
+ $event.stopPropagation();
2340
+ }
2341
+ action(action, row = null) {
2342
+ var currentRow = row ? [row] : this.selectedRows;
2343
+ switch (action) {
2344
+ case 'add':
2345
+ if (this.configuration.addPer) {
2346
+ this.add.emit(this.length);
2347
+ }
2348
+ else {
2349
+ this.dialog
2350
+ .open(TableModalComponent, {
2351
+ data: {
2352
+ action,
2353
+ columns: JSON.parse(JSON.stringify(this.columns)),
2354
+ },
2355
+ width: '60vh',
2356
+ })
2357
+ .afterClosed()
2358
+ .subscribe((result) => {
2359
+ if (result) {
2360
+ this.add.emit(result);
2361
+ }
2362
+ });
2363
+ }
2364
+ break;
2365
+ case 'edit':
2366
+ if (this.configuration.editPer) {
2367
+ this.edit.emit(currentRow);
2368
+ }
2369
+ else {
2370
+ let columns;
2371
+ columns = this.columns;
2372
+ columns.forEach((column, index) => {
2373
+ Object.keys(currentRow[0]).forEach((key) => {
2374
+ if (column.ID == key) {
2375
+ columns[index].value = currentRow[0][key];
2376
+ }
2377
+ });
2378
+ });
2379
+ this.dialog
2380
+ .open(TableModalComponent, {
2381
+ data: {
2382
+ action,
2383
+ columns: JSON.parse(JSON.stringify(this.columns)),
2384
+ values: currentRow[0],
2385
+ },
2386
+ width: '60vh',
2387
+ })
2388
+ .afterClosed()
2389
+ .subscribe((result) => {
2390
+ if (result) {
2391
+ this.edit.emit({ new: result, old: currentRow[0] });
2392
+ }
2393
+ });
2394
+ }
2395
+ break;
2396
+ case 'delete':
2397
+ this.delete.emit(currentRow);
2398
+ break;
2399
+ case 'print':
2400
+ this.print.emit(currentRow);
2401
+ break;
2402
+ case 'active':
2403
+ this.active.emit(currentRow);
2404
+ break;
2405
+ case 'exportToExcel':
2406
+ this.exportToExcel();
2407
+ break;
2408
+ case 'exportToExcelByRow':
2409
+ this.exportXslxByRow.emit(currentRow);
2410
+ break;
2411
+ case 'view':
2412
+ this.view.emit(currentRow);
2413
+ break;
2414
+ case 'closeOrder':
2415
+ this.closeOrder.emit(currentRow);
2416
+ break;
2417
+ case 'packOff':
2418
+ this.packOff.emit(currentRow);
2419
+ break;
2420
+ case 'advance':
2421
+ this.advance.emit(currentRow);
2422
+ break;
2423
+ case 'income':
2424
+ this.income.emit(this.length);
2425
+ break;
2426
+ case 'exit':
2427
+ this.exit.emit(this.length);
2428
+ break;
2429
+ case 'sendEmail':
2430
+ this.sendEmail.emit(currentRow);
2431
+ break;
2432
+ }
2433
+ }
2434
+ shouldShowMenu() {
2435
+ return this.buttonsConfig.some((btn) => btn.condition());
2436
+ }
2437
+ exportToExcel() {
2438
+ let params = [];
2439
+ if (this.url && this.params) {
2440
+ params = [...this.params];
2441
+ if (this.xslxParams) {
2442
+ params = [...params, ...this.xslxParams];
2443
+ }
2444
+ let i = params.findIndex((x) => x.id == 'per_page');
2445
+ if (i != -1)
2446
+ params[i].value = 100000000;
2447
+ }
2448
+ if (this.configuration.exportXslxWithPages) {
2449
+ this.exportService.generateExcelWithSheets(this.title, this.headerFileXlsm, this.title, this.url ? null : this.data, this.url, params, this.filtersPost, this.xslxTitleFields, this.xslxSheetNameFields, this.xslxBodyFields);
2450
+ }
2451
+ else {
2452
+ this.exportService.generateToXlsx(this.title, this.headerFileXlsm, this.title, this.url ? null : this.data, this.url, params, this.filtersPost);
2453
+ }
2454
+ }
2455
+ selection(row, $event, emitEvent = true) {
2456
+ this.checkboxs[row[this.configuration.primaryKey]] = $event.checked;
2457
+ if ($event.checked) {
2458
+ this.selectedRows.push(row);
2459
+ }
2460
+ else {
2461
+ let index = this.selectedRows.indexOf(row);
2462
+ this.selectedRows.splice(index, 1);
2463
+ }
2464
+ if (this.configuration.selectable && emitEvent) {
2465
+ this.selected.emit(this.selectedRows);
2466
+ }
2467
+ if (this.selectedRows.length == this.data.length) {
2468
+ this.selectAll = true;
2469
+ }
2470
+ else {
2471
+ this.selectAll = false;
2472
+ }
2473
+ if (this.selectedRows.length > 0 &&
2474
+ this.selectedRows.length < this.data.length) {
2475
+ this.indeterminateState = true;
2476
+ }
2477
+ else {
2478
+ this.indeterminateState = false;
2479
+ }
2480
+ }
2481
+ clicked($event) {
2482
+ event.stopPropagation();
2483
+ }
2484
+ seletecAllEvent($event) {
2485
+ return __awaiter(this, void 0, void 0, function* () {
2486
+ this.indeterminateState = false;
2487
+ if (this.selectAll) {
2488
+ Object.keys(this.checkboxs).forEach((key) => {
2489
+ this.checkboxs[key] = true;
2490
+ });
2491
+ this.selectedRows = [];
2492
+ let data = this.data;
2493
+ data.forEach((element) => {
2494
+ this.selectedRows.push(element);
2495
+ });
2496
+ this.selected.emit(this.selectedRows);
2497
+ }
2498
+ else {
2499
+ this.clearCheckboxes();
2500
+ this.selected.emit(this.selectedRows);
2501
+ }
2502
+ let service = yield this.getDateTableByUrl();
2503
+ this.data = service['data'];
2504
+ this.internalData.emit(service);
2505
+ this.length = service['count'];
2506
+ this.validateRules();
2507
+ });
2508
+ }
2509
+ clearCheckboxes() {
2510
+ Object.keys(this.checkboxs).forEach((key) => {
2511
+ this.checkboxs[key] = false;
2512
+ });
2513
+ this.selectedRows = [];
2514
+ }
2515
+ changeFilters() {
2516
+ if (this.params)
2517
+ this.params.forEach((element) => {
2518
+ if (element.id == 'filter') {
2519
+ element.value = this.filters;
2520
+ }
2521
+ });
2522
+ this.applyFilters();
2523
+ }
2524
+ applyFilters($event) {
2525
+ return __awaiter(this, void 0, void 0, function* () {
2526
+ if ($event)
2527
+ this.filtersPost = $event;
2528
+ if (this.url) {
2529
+ let res = yield this.getDateTableByUrl();
2530
+ this.data = res['data'];
2531
+ this.validateRules();
2532
+ this.length = res['count'];
2533
+ this.internalData.emit(res);
2534
+ }
2535
+ else {
2536
+ this.data = this.originalData.filter((data) => {
2537
+ for (let key of Object.keys(data)) {
2538
+ let result = data[key]
2539
+ .toString()
2540
+ .toLowerCase()
2541
+ .includes(this.filters.toLowerCase());
2542
+ if (result) {
2543
+ return data;
2544
+ }
2545
+ }
2546
+ });
2547
+ }
2548
+ });
2549
+ }
2550
+ changePage($event) {
2551
+ this.params.forEach((element, index) => {
2552
+ if (element.id == 'per_page') {
2553
+ element.value = $event.pageSize;
2554
+ }
2555
+ if (element.id == 'page') {
2556
+ element.value = $event.pageIndex;
2557
+ }
2558
+ });
2559
+ this.applyFilters();
2560
+ }
2561
+ }
2562
+ DataTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DataTableComponent, deps: [{ token: i1.MatDialog }, { token: HttpService }, { token: MessageService }, { token: FunctionsService }, { token: i5.MatPaginatorIntl }, { token: ExportDataService }], target: i0.ɵɵFactoryTarget.Component });
2563
+ DataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DataTableComponent, selector: "data-table", inputs: { title: "title", columns: "columns", data: "data", combo: "combo", configuration: "configuration", reloadTable: "reloadTable", url: "url", params: "params", titleLoading: "titleLoading", messageLoading: "messageLoading", headerFileXlsm: "headerFileXlsm", headerFilters: "headerFilters", xslxTitleFields: "xslxTitleFields", xslxSheetNameFields: "xslxSheetNameFields", xslxBodyFields: "xslxBodyFields", xslxParams: "xslxParams", roleId: "roleId", moduleId: "moduleId", subModuleId: "subModuleId" }, outputs: { clickRow: "clickRow", add: "add", edit: "edit", delete: "delete", print: "print", exportXslxByRow: "exportXslxByRow", active: "active", selected: "selected", view: "view", closeOrder: "closeOrder", packOff: "packOff", advance: "advance", income: "income", exit: "exit", internalData: "internalData", sendEmail: "sendEmail" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"contenedor-tabla\">\r\n <app-filters [headerFilters]=\"headerFilters\" (applyFilters)=\"applyFilters($event)\">\r\n </app-filters>\r\n\r\n <div style='display: flex; flex-direction: row; justify-content: space-between; align-items: center;'>\r\n <div style='flex:1; font-size: 1rem;'>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length>0 && selectedRows.length<2 && configuration.selectable'> {{selectedRows.length}} Seleccionado </p></strong>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length>1'> {{selectedRows.length}} Seleccionados </p></strong>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length<1 && !configuration.hideTitle'> {{title}} </p></strong>\r\n </div>\r\n\r\n <div *ngIf=\"!configuration.hideFilter\" style='flex:3; padding-right: 10px; margin-bottom: 5px;'>\r\n <mat-form-field class='filter'>\r\n <input type=\"text\" [(ngModel)]='filters' (keyup)='changeFilters()' matInput placeholder=\"Filtrar\">\r\n </mat-form-field>\r\n </div>\r\n\r\n <ng-container *ngTemplateOutlet=\"buttonsTable\"></ng-container>\r\n\r\n </div>\r\n\r\n <table class=\"table_Eter table-hover\">\r\n <thead class=\"dark\">\r\n <tr >\r\n <th *ngIf='configuration.selectable' style='justify-content: center;'>\r\n <mat-checkbox color='primary' (change)='seletecAllEvent($event)' [(ngModel)]='selectAll' [indeterminate]='indeterminateState'> </mat-checkbox> </th>\r\n <th\r\n [class]=\"column.style?.movil\"\r\n *ngFor='let column of columns' scope=\"col\"\r\n [ngStyle]=\"column.style\"\r\n >{{column.label}}</th>\r\n <th *ngIf=\"shouldShowMenu()\"></th>\r\n </tr>\r\n </thead>\r\n <tbody class='mat-elevation-z3'>\r\n\r\n <tr style=\"cursor: pointer;\" *ngFor='let row of data' (click)='clickOnRoW(row)' [class]=\"checkboxs[row[configuration.primaryKey]]?'selected-row':''\">\r\n <th *ngIf='configuration.selectable' style='justify-content: center;'> <mat-checkbox color='primary' [(ngModel)]='checkboxs[row[configuration.primaryKey]]' (click)='clicked($event)' (change)='selection(row, $event)'> </mat-checkbox> </th>\r\n <th [class]='column.style?.movil' [ngStyle]='column.style' scope=\"row\" *ngFor='let column of columns'>{{ row[column.ID] }}</th>\r\n\r\n <th *ngIf=\"shouldShowMenu()\" style=\"display: flex; justify-content: center; align-items: center; overflow: visible;\">\r\n <mat-icon\r\n (click)=\"showMenu($event)\"\r\n [matMenuTriggerFor]=\"menu\"\r\n matRipple\r\n class=\"menu_more_vert\"\r\n aria-hidden=\"false\"\r\n aria-label=\"Example delete icon\"\r\n >more_vert</mat-icon>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngFor=\"let btn of buttonsConfig\" >\r\n <button *ngIf=\"btn.condition()\" (click)=\"action(btn.action, row)\" mat-menu-item class=\"d-flex align-items-center w-100\" >\r\n <i class=\"fa {{btn.icon}} btn-accion\" style=\"font-size:120%; margin-right: 10px\"></i>\r\n {{btn.tooltip}}\r\n </button>\r\n </div>\r\n\r\n </mat-menu>\r\n </th>\r\n\r\n </tr>\r\n\r\n\r\n </tbody>\r\n\r\n </table>\r\n\r\n <div *ngIf='length == 0 && data.length == 0' style=\"margin-left: 10px;\"> <strong>No se encontr\u00F3 informaci\u00F3n</strong></div>\r\n\r\n <mat-paginator *ngIf=\"paginatorActive\"\r\n [length]=\"length\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"pageSizeOptions\" showFirstLastButtons\r\n (page)=\"changePage($event)\"></mat-paginator>\r\n\r\n </div>\r\n\r\n<ng-template #buttonsTable let-fontSize=\"fontSize\" let-marginRight=\"marginRight\" style='flex:0.5; display:flex; flex-direction: row; justify-content: flex-end;'>\r\n <ng-container *ngFor=\"let btn of buttonsConfig\">\r\n <div *ngIf=\"btn.conditionShowHeader()\" (click)=\"action(btn.action)\" matTooltip=\"{{btn.tooltip}}\" matTooltipPosition=\"above\">\r\n <i class=\"fa {{btn.icon}} btn-accion\" [ngStyle]=\"{'font-size': fontSize ? fontSize : '170%', 'margin-right': marginRight ? marginRight : '15px'}\"></i>\r\n </div>\r\n </ng-container>\r\n</ng-template>\r\n\r\n", styles: [".contenedor-tabla{width:100%;overflow-x:auto}.table_Eter{width:100%;margin-bottom:4px;color:primary;border-collapse:collapse}.table_Eter .dark th{color:#fff;background-color:#343a40;border-color:#454d55;text-align:center;vertical-align:middle}.table_Eter thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table_Eter th,.table_Eter td{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6}th{text-align:inherit}*,*:before,*:after{box-sizing:border-box}.btn-accion{cursor:pointer}mat-form-field{padding:0!important;width:100%}.filter{padding:0;margin-bottom:10px;width:100%}.filter ::ng-deep .mat-form-field-underline{bottom:3px!important}.filter ::ng-deep .mat-form-field-infix{border:0!important}.filter ::ng-deep .mat-form-field-wrapper{padding:0}.filter ::ng-deep .mat-form-field-appearance-legacy .mat-form-field-wrapper{padding:0}.selected-row{color:#212529;background-color:#00000013}button:focus{outline:none!important}@media only screen and (max-width: 600px){.no-movil{display:none}}::ng-deep .mat-paginator{background:transparent!important}@media screen and (max-width: 400px){.filter{padding:0;margin-bottom:40px;width:70%}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i8$1.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i13.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i7$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: FiltersComponent, selector: "app-filters", inputs: ["headerFilters"], outputs: ["applyFilters"] }] });
2564
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DataTableComponent, decorators: [{
2565
+ type: Component,
2566
+ args: [{ selector: 'data-table', template: "<div class=\"contenedor-tabla\">\r\n <app-filters [headerFilters]=\"headerFilters\" (applyFilters)=\"applyFilters($event)\">\r\n </app-filters>\r\n\r\n <div style='display: flex; flex-direction: row; justify-content: space-between; align-items: center;'>\r\n <div style='flex:1; font-size: 1rem;'>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length>0 && selectedRows.length<2 && configuration.selectable'> {{selectedRows.length}} Seleccionado </p></strong>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length>1'> {{selectedRows.length}} Seleccionados </p></strong>\r\n <strong><p style='margin:0' *ngIf='selectedRows.length<1 && !configuration.hideTitle'> {{title}} </p></strong>\r\n </div>\r\n\r\n <div *ngIf=\"!configuration.hideFilter\" style='flex:3; padding-right: 10px; margin-bottom: 5px;'>\r\n <mat-form-field class='filter'>\r\n <input type=\"text\" [(ngModel)]='filters' (keyup)='changeFilters()' matInput placeholder=\"Filtrar\">\r\n </mat-form-field>\r\n </div>\r\n\r\n <ng-container *ngTemplateOutlet=\"buttonsTable\"></ng-container>\r\n\r\n </div>\r\n\r\n <table class=\"table_Eter table-hover\">\r\n <thead class=\"dark\">\r\n <tr >\r\n <th *ngIf='configuration.selectable' style='justify-content: center;'>\r\n <mat-checkbox color='primary' (change)='seletecAllEvent($event)' [(ngModel)]='selectAll' [indeterminate]='indeterminateState'> </mat-checkbox> </th>\r\n <th\r\n [class]=\"column.style?.movil\"\r\n *ngFor='let column of columns' scope=\"col\"\r\n [ngStyle]=\"column.style\"\r\n >{{column.label}}</th>\r\n <th *ngIf=\"shouldShowMenu()\"></th>\r\n </tr>\r\n </thead>\r\n <tbody class='mat-elevation-z3'>\r\n\r\n <tr style=\"cursor: pointer;\" *ngFor='let row of data' (click)='clickOnRoW(row)' [class]=\"checkboxs[row[configuration.primaryKey]]?'selected-row':''\">\r\n <th *ngIf='configuration.selectable' style='justify-content: center;'> <mat-checkbox color='primary' [(ngModel)]='checkboxs[row[configuration.primaryKey]]' (click)='clicked($event)' (change)='selection(row, $event)'> </mat-checkbox> </th>\r\n <th [class]='column.style?.movil' [ngStyle]='column.style' scope=\"row\" *ngFor='let column of columns'>{{ row[column.ID] }}</th>\r\n\r\n <th *ngIf=\"shouldShowMenu()\" style=\"display: flex; justify-content: center; align-items: center; overflow: visible;\">\r\n <mat-icon\r\n (click)=\"showMenu($event)\"\r\n [matMenuTriggerFor]=\"menu\"\r\n matRipple\r\n class=\"menu_more_vert\"\r\n aria-hidden=\"false\"\r\n aria-label=\"Example delete icon\"\r\n >more_vert</mat-icon>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngFor=\"let btn of buttonsConfig\" >\r\n <button *ngIf=\"btn.condition()\" (click)=\"action(btn.action, row)\" mat-menu-item class=\"d-flex align-items-center w-100\" >\r\n <i class=\"fa {{btn.icon}} btn-accion\" style=\"font-size:120%; margin-right: 10px\"></i>\r\n {{btn.tooltip}}\r\n </button>\r\n </div>\r\n\r\n </mat-menu>\r\n </th>\r\n\r\n </tr>\r\n\r\n\r\n </tbody>\r\n\r\n </table>\r\n\r\n <div *ngIf='length == 0 && data.length == 0' style=\"margin-left: 10px;\"> <strong>No se encontr\u00F3 informaci\u00F3n</strong></div>\r\n\r\n <mat-paginator *ngIf=\"paginatorActive\"\r\n [length]=\"length\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"pageSizeOptions\" showFirstLastButtons\r\n (page)=\"changePage($event)\"></mat-paginator>\r\n\r\n </div>\r\n\r\n<ng-template #buttonsTable let-fontSize=\"fontSize\" let-marginRight=\"marginRight\" style='flex:0.5; display:flex; flex-direction: row; justify-content: flex-end;'>\r\n <ng-container *ngFor=\"let btn of buttonsConfig\">\r\n <div *ngIf=\"btn.conditionShowHeader()\" (click)=\"action(btn.action)\" matTooltip=\"{{btn.tooltip}}\" matTooltipPosition=\"above\">\r\n <i class=\"fa {{btn.icon}} btn-accion\" [ngStyle]=\"{'font-size': fontSize ? fontSize : '170%', 'margin-right': marginRight ? marginRight : '15px'}\"></i>\r\n </div>\r\n </ng-container>\r\n</ng-template>\r\n\r\n", styles: [".contenedor-tabla{width:100%;overflow-x:auto}.table_Eter{width:100%;margin-bottom:4px;color:primary;border-collapse:collapse}.table_Eter .dark th{color:#fff;background-color:#343a40;border-color:#454d55;text-align:center;vertical-align:middle}.table_Eter thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table_Eter th,.table_Eter td{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6}th{text-align:inherit}*,*:before,*:after{box-sizing:border-box}.btn-accion{cursor:pointer}mat-form-field{padding:0!important;width:100%}.filter{padding:0;margin-bottom:10px;width:100%}.filter ::ng-deep .mat-form-field-underline{bottom:3px!important}.filter ::ng-deep .mat-form-field-infix{border:0!important}.filter ::ng-deep .mat-form-field-wrapper{padding:0}.filter ::ng-deep .mat-form-field-appearance-legacy .mat-form-field-wrapper{padding:0}.selected-row{color:#212529;background-color:#00000013}button:focus{outline:none!important}@media only screen and (max-width: 600px){.no-movil{display:none}}::ng-deep .mat-paginator{background:transparent!important}@media screen and (max-width: 400px){.filter{padding:0;margin-bottom:40px;width:70%}}\n"] }]
2567
+ }], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: HttpService }, { type: MessageService }, { type: FunctionsService }, { type: i5.MatPaginatorIntl }, { type: ExportDataService }]; }, propDecorators: { title: [{
2568
+ type: Input
2569
+ }], columns: [{
2570
+ type: Input
2571
+ }], data: [{
2572
+ type: Input
2573
+ }], combo: [{
2574
+ type: Input
2575
+ }], configuration: [{
2576
+ type: Input
2577
+ }], reloadTable: [{
2578
+ type: Input
2579
+ }], url: [{
2580
+ type: Input
2581
+ }], params: [{
2582
+ type: Input
2583
+ }], titleLoading: [{
2584
+ type: Input
2585
+ }], messageLoading: [{
2586
+ type: Input
2587
+ }], headerFileXlsm: [{
2588
+ type: Input
2589
+ }], headerFilters: [{
2590
+ type: Input
2591
+ }], xslxTitleFields: [{
2592
+ type: Input
2593
+ }], xslxSheetNameFields: [{
2594
+ type: Input
2595
+ }], xslxBodyFields: [{
2596
+ type: Input
2597
+ }], xslxParams: [{
2598
+ type: Input
2599
+ }], roleId: [{
2600
+ type: Input
2601
+ }], moduleId: [{
2602
+ type: Input
2603
+ }], subModuleId: [{
2604
+ type: Input
2605
+ }], clickRow: [{
2606
+ type: Output
2607
+ }], add: [{
2608
+ type: Output
2609
+ }], edit: [{
2610
+ type: Output
2611
+ }], delete: [{
2612
+ type: Output
2613
+ }], print: [{
2614
+ type: Output
2615
+ }], exportXslxByRow: [{
2616
+ type: Output
2617
+ }], active: [{
2618
+ type: Output
2619
+ }], selected: [{
2620
+ type: Output
2621
+ }], view: [{
2622
+ type: Output
2623
+ }], closeOrder: [{
2624
+ type: Output
2625
+ }], packOff: [{
2626
+ type: Output
2627
+ }], advance: [{
2628
+ type: Output
2629
+ }], income: [{
2630
+ type: Output
2631
+ }], exit: [{
2632
+ type: Output
2633
+ }], internalData: [{
2634
+ type: Output
2635
+ }], sendEmail: [{
2636
+ type: Output
2637
+ }], paginator: [{
2638
+ type: ViewChild,
2639
+ args: [MatPaginator, { static: true }]
2640
+ }] } });
2641
+ var enumRules$1;
2642
+ (function (enumRules) {
2643
+ enumRules[enumRules[">"] = 0] = ">";
2644
+ enumRules[enumRules["<"] = 1] = "<";
2645
+ enumRules[enumRules["=="] = 2] = "==";
2646
+ enumRules[enumRules["!="] = 3] = "!=";
2647
+ })(enumRules$1 || (enumRules$1 = {}));
2648
+
2649
+ var imagenPdf = '';
2650
+
2651
+ var imagenDoc = '';
2652
+
2653
+ var imagenFondoTransparente = '';
2654
+
2655
+ class FileFormsService {
2656
+ constructor() { }
2657
+ createMultipartForm(file, params) {
2658
+ const formD = new FormData();
2659
+ formD.append('file', file, 'form-data'); //Asigna el campo File
2660
+ if (params) {
2661
+ params.forEach((element) => {
2662
+ formD.append(element.id, element.value);
2663
+ });
2664
+ }
2665
+ return (formD);
2666
+ }
2667
+ }
2668
+ FileFormsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2669
+ FileFormsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, providedIn: 'root' });
2670
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, decorators: [{
2671
+ type: Injectable,
2672
+ args: [{
2673
+ providedIn: 'root'
2674
+ }]
2675
+ }], ctorParameters: function () { return []; } });
2676
+
2677
+ class FileInputComponent {
2678
+ constructor(fileForms, http, message, formBuilder) {
2679
+ this.fileForms = fileForms;
2680
+ this.http = http;
2681
+ this.message = message;
2682
+ this.formBuilder = formBuilder;
2683
+ this.color = 'primary';
2684
+ this.disabled = false;
2685
+ this.multiple = false;
2686
+ this.maxSize = 16;
2687
+ this.size = 100000; //tamaño a comprimir las imagenes en bites
2688
+ this.fileSave = new EventEmitter();
2689
+ this.file = null;
2690
+ this.icon = 'folder';
2691
+ this.formFile = this.formBuilder.group({
2692
+ requiredfile: []
2693
+ });
2694
+ this.fileControl = new UntypedFormControl(this.files, [
2695
+ Validators.required,
2696
+ MaxSizeValidator(this.maxSize * 1024)
2697
+ ]);
2698
+ }
2699
+ ngOnInit() {
2700
+ this.form = this.formBuilder.group({
2701
+ file: []
2702
+ });
2703
+ this.sizePicture = {
2704
+ width: `${this.params.style.width}`,
2705
+ height: `${this.params.style.height}`,
2706
+ "border-radius": '5%',
2707
+ border: `${this.params.style.border}`,
2708
+ };
2709
+ if (this.params.edit == true) {
2710
+ this.edit = 'img';
2711
+ }
2712
+ else {
2713
+ this.edit = '';
2714
+ }
2715
+ this.typeFile = this.params.typeFile;
2716
+ this.functionTypeFile();
2717
+ }
2718
+ functionTypeFile() {
2719
+ if (this.params.style.shape == "circular") {
2720
+ this.sizePicture['border-radius'] = "50%";
2721
+ this.sizePicture.width = `${screen.width * (this.params.style.width.replace('%', '') / 100)}px`;
2722
+ this.sizePicture.height = this.sizePicture.width;
2723
+ }
2724
+ this.border = {
2725
+ "borderRadius": `${this.sizePicture['border-radius']}`
2726
+ };
2727
+ this.styleForm = {
2728
+ width: `${this.params.style.width}`,
2729
+ height: `${this.params.style.height}`
2730
+ };
2731
+ this.styleImg = {
2732
+ width: '100%',
2733
+ height: '100%',
2734
+ "border-radius": `${this.sizePicture['border-radius']}`,
2735
+ };
2736
+ switch (this.typeFile) {
2737
+ case 'imagen':
2738
+ if (!this.params.imageSrc) {
2739
+ this.imageSrc = imagenFondoTransparente;
2740
+ }
2741
+ else {
2742
+ this.imageSrc = this.params.imageSrc;
2743
+ }
2744
+ this.type = 'image/*';
2745
+ break;
2746
+ case 'pdf':
2747
+ this.type = '.pdf';
2748
+ this.imageSrc = imagenFondoTransparente;
2749
+ break;
2750
+ case 'doc':
2751
+ this.type = '.doc, .docx';
2752
+ this.imageSrc = imagenFondoTransparente;
2753
+ break;
2754
+ default:
2755
+ break;
2756
+ }
2757
+ }
2758
+ fileChange($event) {
2759
+ return __awaiter(this, void 0, void 0, function* () {
2760
+ if ($event.target['files'][0]['size'] < 15000000) {
2761
+ let r;
2762
+ if ($event.target['files'] && $event.target['files'][0]) {
2763
+ this.file = $event.target['files'][0];
2764
+ switch (this.typeFile) {
2765
+ case 'pdf':
2766
+ r = false;
2767
+ this.styleImg = {
2768
+ width: '100%',
2769
+ height: '100%',
2770
+ "border-radius": `${this.sizePicture['border-radius']}`,
2771
+ "background-image": `url(${imagenPdf})`,
2772
+ "background-position": "center",
2773
+ "background-size": "30% 65%",
2774
+ "background-repeat": "no-repeat"
2775
+ };
2776
+ break;
2777
+ case 'imagen':
2778
+ const reader = new FileReader();
2779
+ reader.onload = e => this.imageSrc = reader.result;
2780
+ reader.readAsDataURL(this.file);
2781
+ r = yield this.compressor();
2782
+ break;
2783
+ case 'doc':
2784
+ r = false;
2785
+ this.styleImg = {
2786
+ width: '100%',
2787
+ height: '100%',
2788
+ "border-radius": `${this.sizePicture['border-radius']}`,
2789
+ "background-image": `url(${imagenDoc})`,
2790
+ "background-position": "center",
2791
+ "background-size": "30% 65%",
2792
+ "background-repeat": "no-repeat"
2793
+ };
2794
+ break;
2795
+ default:
2796
+ break;
2797
+ }
2798
+ }
2799
+ if (r == false) {
2800
+ this.fileSave.emit({ new: this.file });
2801
+ }
2802
+ else {
2803
+ const reader = new FileReader();
2804
+ reader.onload = e => this.imageSrc = reader.result;
2805
+ reader.readAsDataURL(r);
2806
+ this.fileSave.emit({ new: this.file, compressor: r });
2807
+ }
2808
+ }
2809
+ else {
2810
+ this.message.Error('Error', 'Archivo muy pesado, tamaño mínimo 15 MB');
2811
+ }
2812
+ });
2813
+ }
2814
+ compressor() {
2815
+ if (this.file.size > 500000 && this.file.size < 15000000) {
2816
+ let factor = (this.size * 100) / this.file.size;
2817
+ let y = ((Math.pow(factor, 3)) * (Math.pow(10, -6))) - (0.00059 * (Math.pow(factor, 2))) + (0.0399 * factor);
2818
+ return new Promise((resolve, reject) => {
2819
+ new Compressor(this.file, {
2820
+ quality: y,
2821
+ success(result) {
2822
+ resolve(result);
2823
+ }
2824
+ });
2825
+ });
2826
+ }
2827
+ else {
2828
+ return (false);
2829
+ }
2830
+ }
2831
+ selectFile($event) {
2832
+ console.log($event);
2833
+ }
2834
+ }
2835
+ FileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileInputComponent, deps: [{ token: FileFormsService }, { token: HttpService }, { token: MessageService }, { token: i1$2.UntypedFormBuilder }], target: i0.ɵɵFactoryTarget.Component });
2836
+ FileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FileInputComponent, selector: "file-input", inputs: { params: "params", icon: "icon" }, outputs: { fileSave: "fileSave" }, ngImport: i0, template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\r\n\r\n\t<img [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\">\r\n\r\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\r\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\r\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\r\n\t\t\t(change)='fileChange($event)'>\r\n\t</div>\r\n\r\n</div>\r\n<div *ngIf=\"params.input == 'formulario'\">\r\n\r\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\r\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\r\n </ngx-mat-file-input> -->\r\n\r\n <!-- </mat-form-field> -->\r\n\r\n <mat-form-field [ngStyle]=\"styleForm\">\r\n <div style=\"display: flex;\">\r\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\r\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\r\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\r\n (change)='fileChange($event)'>\r\n </div>\r\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\r\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\r\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\r\n </mat-form-field>\r\n\r\n</div>\r\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
2837
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileInputComponent, decorators: [{
2838
+ type: Component,
2839
+ args: [{ selector: 'file-input', template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\r\n\r\n\t<img [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\">\r\n\r\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\r\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\r\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\r\n\t\t\t(change)='fileChange($event)'>\r\n\t</div>\r\n\r\n</div>\r\n<div *ngIf=\"params.input == 'formulario'\">\r\n\r\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\r\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\r\n </ngx-mat-file-input> -->\r\n\r\n <!-- </mat-form-field> -->\r\n\r\n <mat-form-field [ngStyle]=\"styleForm\">\r\n <div style=\"display: flex;\">\r\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\r\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\r\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\r\n (change)='fileChange($event)'>\r\n </div>\r\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\r\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\r\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\r\n </mat-form-field>\r\n\r\n</div>\r\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"] }]
2840
+ }], ctorParameters: function () { return [{ type: FileFormsService }, { type: HttpService }, { type: MessageService }, { type: i1$2.UntypedFormBuilder }]; }, propDecorators: { params: [{
2841
+ type: Input
2842
+ }], fileSave: [{
2843
+ type: Output
2844
+ }], icon: [{
2845
+ type: Input
2846
+ }] } });
2847
+
2848
+ class ButtonLabelComponent {
2849
+ constructor() {
2850
+ this.updateLabel = new EventEmitter();
2851
+ this.labels = [];
2852
+ this.labelsEdit = [];
2853
+ this.color = null;
2854
+ this.iconColor = null;
2855
+ this.modeEdit = [];
2856
+ this.currentValueToEdit = "";
2857
+ this.indexToedit = -1;
2858
+ this.initEventClink = false;
2859
+ }
2860
+ ngOnInit() {
2861
+ }
2862
+ ngOnChanges(changes) {
2863
+ if (changes) {
2864
+ if (changes.labelsEdit && !this.initEventClink && this.labelsEdit.length > 0 && this.labelsEdit.find(x => x.edit == true)) {
2865
+ document.addEventListener('click', ($event) => this.onPageClick($event));
2866
+ this.initEventClink = true;
2867
+ }
2868
+ }
2869
+ }
2870
+ finishEditLabel(index) {
2871
+ this.labelsEdit[index].value = this.currentValueToEdit;
2872
+ this.modeEdit[index] = false;
2873
+ this.updateLabel.emit({
2874
+ value: this.labelsEdit[index].value,
2875
+ labels: this.labelsEdit[index].label,
2876
+ position: index
2877
+ });
2878
+ }
2879
+ editLabel(index) {
2880
+ this.spanElement = document.getElementById('button-edit-' + index);
2881
+ this.currentValueToEdit = this.labelsEdit[index].value;
2882
+ this.modeEdit[index] = true;
2883
+ this.indexToedit = index;
2884
+ }
2885
+ onPageClick($event) {
2886
+ if (!ButtonLabelComponent.isDescendant($event.target, this.spanElement) && this.modeEdit) {
2887
+ for (let [index, value] of this.modeEdit.entries()) {
2888
+ this.modeEdit[index] = this.indexToedit == index ? true : false;
2889
+ }
2890
+ }
2891
+ this.indexToedit = -1;
2892
+ }
2893
+ static isDescendant(child, parent) {
2894
+ let node = child.parentNode;
2895
+ while (node != null) {
2896
+ if (node === parent) {
2897
+ return true;
2898
+ }
2899
+ node = node.parentNode;
2900
+ }
2901
+ return false;
2902
+ }
2903
+ ngOnDestroy() {
2904
+ document.removeEventListener('click', ($event) => this.onPageClick($event));
2905
+ }
2906
+ }
2907
+ ButtonLabelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2908
+ ButtonLabelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ButtonLabelComponent, selector: "app-button-label", inputs: { labels: "labels", labelsEdit: "labelsEdit", color: "color", iconColor: "iconColor" }, outputs: { updateLabel: "updateLabel" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"labels\" class=\"d-flex justify-content-center my-3 flex-wrap\">\r\n <div *ngFor=\"let item of labels;\">\r\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\">\r\n {{item}}\r\n </h4>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"labelsEdit\" class=\"d-flex justify-content-center my-3 flex-wrap\">\r\n <div *ngFor=\"let item of labelsEdit; let i = index\">\r\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\" [id]=\"'button-edit-' + i\">\r\n <h6 *ngIf=\"item.label\" class=\"mr-1 font-weight-bold m-0\">{{item.label}} </h6>\r\n <div *ngIf=\"!modeEdit[i]\">{{item.value}}</div>\r\n <div class=\"cursor-pointer\" (click)='editLabel(i)' *ngIf=\"!modeEdit[i] && item.edit\" matTooltip=\"Editar\" matTooltipPosition=\"above\">\r\n <mat-icon class=\"ml-1 pencil-edit cursor-pointer\" matTooltip=\"Editar\" matTooltipPosition=\"above\" [style.color]=\"iconColor\">edit</mat-icon>\r\n </div>\r\n\r\n <input *ngIf=\"modeEdit[i] && item.edit\" type=\"text\" [(ngModel)]='currentValueToEdit' matInput placeholder=\"Filtrar\">\r\n\r\n <div class=\"cursor-pointer\" (click)='finishEditLabel(i)' *ngIf=\"modeEdit[i] && item.edit\" matTooltip=\"Aceptar\" matTooltipPosition=\"above\">\r\n <i class=\"fa fa-check btn-accion\" style=\"margin-left: 15px;\"></i>\r\n </div>\r\n\r\n </h4>\r\n </div>\r\n</div>\r\n", styles: [".label-text{padding:5px;margin:5px 10px;border-radius:10px;-webkit-text-decoration:center;text-decoration:center;font-weight:500}.pencil-edit{font-size:16px;display:flex;align-items:center;justify-content:center}.cursor-pointer{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i7$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
2909
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonLabelComponent, decorators: [{
2910
+ type: Component,
2911
+ args: [{ selector: 'app-button-label', template: "<div *ngIf=\"labels\" class=\"d-flex justify-content-center my-3 flex-wrap\">\r\n <div *ngFor=\"let item of labels;\">\r\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\">\r\n {{item}}\r\n </h4>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"labelsEdit\" class=\"d-flex justify-content-center my-3 flex-wrap\">\r\n <div *ngFor=\"let item of labelsEdit; let i = index\">\r\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\" [id]=\"'button-edit-' + i\">\r\n <h6 *ngIf=\"item.label\" class=\"mr-1 font-weight-bold m-0\">{{item.label}} </h6>\r\n <div *ngIf=\"!modeEdit[i]\">{{item.value}}</div>\r\n <div class=\"cursor-pointer\" (click)='editLabel(i)' *ngIf=\"!modeEdit[i] && item.edit\" matTooltip=\"Editar\" matTooltipPosition=\"above\">\r\n <mat-icon class=\"ml-1 pencil-edit cursor-pointer\" matTooltip=\"Editar\" matTooltipPosition=\"above\" [style.color]=\"iconColor\">edit</mat-icon>\r\n </div>\r\n\r\n <input *ngIf=\"modeEdit[i] && item.edit\" type=\"text\" [(ngModel)]='currentValueToEdit' matInput placeholder=\"Filtrar\">\r\n\r\n <div class=\"cursor-pointer\" (click)='finishEditLabel(i)' *ngIf=\"modeEdit[i] && item.edit\" matTooltip=\"Aceptar\" matTooltipPosition=\"above\">\r\n <i class=\"fa fa-check btn-accion\" style=\"margin-left: 15px;\"></i>\r\n </div>\r\n\r\n </h4>\r\n </div>\r\n</div>\r\n", styles: [".label-text{padding:5px;margin:5px 10px;border-radius:10px;-webkit-text-decoration:center;text-decoration:center;font-weight:500}.pencil-edit{font-size:16px;display:flex;align-items:center;justify-content:center}.cursor-pointer{cursor:pointer}\n"] }]
2912
+ }], ctorParameters: function () { return []; }, propDecorators: { updateLabel: [{
2913
+ type: Output
2914
+ }], labels: [{
2915
+ type: Input
2916
+ }], labelsEdit: [{
2917
+ type: Input
2918
+ }], color: [{
2919
+ type: Input
2920
+ }], iconColor: [{
2921
+ type: Input
2922
+ }] } });
2923
+
2924
+ const Material = [
2925
+ MatSlideToggleModule,
2926
+ MatProgressBarModule,
2927
+ MatRippleModule,
2928
+ MatBottomSheetModule,
2929
+ MatChipsModule,
2930
+ MatTreeModule,
2931
+ MatButtonModule,
2932
+ MatButtonToggleModule,
2933
+ MatBadgeModule,
2934
+ MatIconModule,
2935
+ MatProgressSpinnerModule,
2936
+ MatToolbarModule,
2937
+ MatSidenavModule,
2938
+ MatMenuModule,
2939
+ MatListModule,
2940
+ MatDividerModule,
2941
+ MatGridListModule,
2942
+ MatExpansionModule,
2943
+ MatTabsModule,
2944
+ MatCardModule,
2945
+ MatStepperModule,
2946
+ MatFormFieldModule,
2947
+ MatInputModule,
2948
+ MatSelectModule,
2949
+ MatAutocompleteModule,
2950
+ MatCheckboxModule,
2951
+ MatRadioModule,
2952
+ MatDatepickerModule,
2953
+ MatTooltipModule,
2954
+ MatSnackBarModule,
2955
+ MatDialogModule,
2956
+ MatTableModule,
2957
+ MatSortModule,
2958
+ MatPaginatorModule,
2959
+ MatSliderModule,
2960
+ MatNativeDateModule
2961
+ ];
2962
+ function playerFactory() {
2963
+ return player;
2964
+ }
2965
+ class BrainloperUiModule {
2966
+ }
2967
+ BrainloperUiModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BrainloperUiModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2968
+ BrainloperUiModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: BrainloperUiModule, declarations: [DataTableComponent,
2969
+ TableModalComponent,
2970
+ CombosComponent,
2971
+ FileInputComponent,
2972
+ LoadingComponent,
2973
+ GeneratePdfComponent,
2974
+ TemplateFuelComponent,
2975
+ BreadCrumbComponent,
2976
+ ButtonLabelComponent,
2977
+ ButtonIconComponent,
2978
+ CarouselComponent,
2979
+ FiltersComponent,
2980
+ SelectFilterComponent], imports: [CommonModule,
2981
+ MatButtonModule, MatSlideToggleModule,
2982
+ MatProgressBarModule,
2983
+ MatRippleModule,
2984
+ MatBottomSheetModule,
2985
+ MatChipsModule,
2986
+ MatTreeModule,
2987
+ MatButtonModule,
2988
+ MatButtonToggleModule,
2989
+ MatBadgeModule,
2990
+ MatIconModule,
2991
+ MatProgressSpinnerModule,
2992
+ MatToolbarModule,
2993
+ MatSidenavModule,
2994
+ MatMenuModule,
2995
+ MatListModule,
2996
+ MatDividerModule,
2997
+ MatGridListModule,
2998
+ MatExpansionModule,
2999
+ MatTabsModule,
3000
+ MatCardModule,
3001
+ MatStepperModule,
3002
+ MatFormFieldModule,
3003
+ MatInputModule,
3004
+ MatSelectModule,
3005
+ MatAutocompleteModule,
3006
+ MatCheckboxModule,
3007
+ MatRadioModule,
3008
+ MatDatepickerModule,
3009
+ MatTooltipModule,
3010
+ MatSnackBarModule,
3011
+ MatDialogModule,
3012
+ MatTableModule,
3013
+ MatSortModule,
3014
+ MatPaginatorModule,
3015
+ MatSliderModule,
3016
+ MatNativeDateModule, NgbModule,
3017
+ FormsModule,
3018
+ ReactiveFormsModule,
3019
+ HttpClientModule, i1$4.LottieModule, i1$3.RouterModule, MatTooltipModule], exports: [MatSlideToggleModule,
3020
+ MatProgressBarModule,
3021
+ MatRippleModule,
3022
+ MatBottomSheetModule,
3023
+ MatChipsModule,
3024
+ MatTreeModule,
3025
+ MatButtonModule,
3026
+ MatButtonToggleModule,
3027
+ MatBadgeModule,
3028
+ MatIconModule,
3029
+ MatProgressSpinnerModule,
3030
+ MatToolbarModule,
3031
+ MatSidenavModule,
3032
+ MatMenuModule,
3033
+ MatListModule,
3034
+ MatDividerModule,
3035
+ MatGridListModule,
3036
+ MatExpansionModule,
3037
+ MatTabsModule,
3038
+ MatCardModule,
3039
+ MatStepperModule,
3040
+ MatFormFieldModule,
3041
+ MatInputModule,
3042
+ MatSelectModule,
3043
+ MatAutocompleteModule,
3044
+ MatCheckboxModule,
3045
+ MatRadioModule,
3046
+ MatDatepickerModule,
3047
+ MatTooltipModule,
3048
+ MatSnackBarModule,
3049
+ MatDialogModule,
3050
+ MatTableModule,
3051
+ MatSortModule,
3052
+ MatPaginatorModule,
3053
+ MatSliderModule,
3054
+ MatNativeDateModule, DataTableComponent,
3055
+ TableModalComponent,
3056
+ CombosComponent,
3057
+ FileInputComponent,
3058
+ LoadingComponent,
3059
+ BreadCrumbComponent,
3060
+ ButtonLabelComponent,
3061
+ ButtonIconComponent,
3062
+ NgbModule,
3063
+ CarouselComponent,
3064
+ FiltersComponent,
3065
+ SelectFilterComponent] });
3066
+ BrainloperUiModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BrainloperUiModule, providers: [
3067
+ HttpService
3068
+ ], imports: [CommonModule,
3069
+ MatButtonModule,
3070
+ Material,
3071
+ NgbModule,
3072
+ FormsModule,
3073
+ ReactiveFormsModule,
3074
+ HttpClientModule,
3075
+ LottieModule.forRoot({ player: playerFactory }),
3076
+ RouterModule.forRoot([]),
3077
+ MatTooltipModule, MatSlideToggleModule,
3078
+ MatProgressBarModule,
3079
+ MatRippleModule,
3080
+ MatBottomSheetModule,
3081
+ MatChipsModule,
3082
+ MatTreeModule,
3083
+ MatButtonModule,
3084
+ MatButtonToggleModule,
3085
+ MatBadgeModule,
3086
+ MatIconModule,
3087
+ MatProgressSpinnerModule,
3088
+ MatToolbarModule,
3089
+ MatSidenavModule,
3090
+ MatMenuModule,
3091
+ MatListModule,
3092
+ MatDividerModule,
3093
+ MatGridListModule,
3094
+ MatExpansionModule,
3095
+ MatTabsModule,
3096
+ MatCardModule,
3097
+ MatStepperModule,
3098
+ MatFormFieldModule,
3099
+ MatInputModule,
3100
+ MatSelectModule,
3101
+ MatAutocompleteModule,
3102
+ MatCheckboxModule,
3103
+ MatRadioModule,
3104
+ MatDatepickerModule,
3105
+ MatTooltipModule,
3106
+ MatSnackBarModule,
3107
+ MatDialogModule,
3108
+ MatTableModule,
3109
+ MatSortModule,
3110
+ MatPaginatorModule,
3111
+ MatSliderModule,
3112
+ MatNativeDateModule, NgbModule] });
3113
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BrainloperUiModule, decorators: [{
3114
+ type: NgModule,
3115
+ args: [{
3116
+ declarations: [
3117
+ DataTableComponent,
3118
+ TableModalComponent,
3119
+ CombosComponent,
3120
+ FileInputComponent,
3121
+ LoadingComponent,
3122
+ GeneratePdfComponent,
3123
+ TemplateFuelComponent,
3124
+ BreadCrumbComponent,
3125
+ ButtonLabelComponent,
3126
+ ButtonIconComponent,
3127
+ CarouselComponent,
3128
+ FiltersComponent,
3129
+ SelectFilterComponent
3130
+ ],
3131
+ imports: [
3132
+ CommonModule,
3133
+ MatButtonModule,
3134
+ Material,
3135
+ NgbModule,
3136
+ FormsModule,
3137
+ ReactiveFormsModule,
3138
+ HttpClientModule,
3139
+ LottieModule.forRoot({ player: playerFactory }),
3140
+ RouterModule.forRoot([]),
3141
+ MatTooltipModule
3142
+ ],
3143
+ exports: [
3144
+ Material,
3145
+ DataTableComponent,
3146
+ TableModalComponent,
3147
+ CombosComponent,
3148
+ FileInputComponent,
3149
+ LoadingComponent,
3150
+ BreadCrumbComponent,
3151
+ ButtonLabelComponent,
3152
+ ButtonIconComponent,
3153
+ NgbModule,
3154
+ CarouselComponent,
3155
+ FiltersComponent,
3156
+ SelectFilterComponent
3157
+ ],
3158
+ providers: [
3159
+ HttpService
3160
+ ]
3161
+ }]
3162
+ }] });
3163
+
3164
+ //declare var require: any
3165
+ //var CryptoJS = require("crypto-js");
3166
+ class CryptoService {
3167
+ constructor() {
3168
+ this.key = "ssaldkmaosweiuf231owdalsd0";
3169
+ }
3170
+ asignarKey(key) {
3171
+ this.key = key;
3172
+ }
3173
+ encode(data) {
3174
+ const strData = JSON.stringify(data);
3175
+ let c = CryptoJS.AES.encrypt(strData, this.key);
3176
+ return c;
3177
+ }
3178
+ decode(data) {
3179
+ try {
3180
+ var bytes = CryptoJS.AES.decrypt(data, this.key);
3181
+ var str = bytes.toString(CryptoJS.enc.Utf8);
3182
+ return JSON.parse(str);
3183
+ }
3184
+ catch (e) {
3185
+ console.log('Error try to decode string');
3186
+ }
3187
+ }
3188
+ }
3189
+ CryptoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CryptoService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
3190
+ CryptoService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CryptoService, providedIn: 'root' });
3191
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CryptoService, decorators: [{
3192
+ type: Injectable,
3193
+ args: [{
3194
+ providedIn: 'root'
3195
+ }]
3196
+ }], ctorParameters: function () { return []; } });
3197
+
3198
+ class SessionService {
3199
+ constructor(cripto) {
3200
+ this.cripto = cripto;
3201
+ this.key = "V2xoU2JHTnBRbnBpTWxvd1pESkdlVnBUUW10YVYzaHNaRzFXZG1OSE1XeGlibEU9"; //btoa 3 rounds
3202
+ }
3203
+ getMain() {
3204
+ const info = sessionStorage.getItem(this.key);
3205
+ if (info) {
3206
+ return this.cripto.decode(info);
3207
+ }
3208
+ return {};
3209
+ }
3210
+ keyAssign(key) {
3211
+ this.key = key;
3212
+ }
3213
+ getData(key) {
3214
+ var sesion = this.getMain();
3215
+ return sesion[key] || '';
3216
+ }
3217
+ setData(key, value) {
3218
+ var actual = this.getMain() || {};
3219
+ actual[key] = value;
3220
+ const dataF = this.cripto.encode(actual);
3221
+ sessionStorage.setItem(this.key, dataF);
3222
+ }
3223
+ getSessionVars() {
3224
+ const info = this.getMain();
3225
+ return info || {};
3226
+ }
3227
+ }
3228
+ SessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SessionService, deps: [{ token: CryptoService }], target: i0.ɵɵFactoryTarget.Injectable });
3229
+ SessionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SessionService, providedIn: 'root' });
3230
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SessionService, decorators: [{
3231
+ type: Injectable,
3232
+ args: [{
3233
+ providedIn: 'root'
3234
+ }]
3235
+ }], ctorParameters: function () { return [{ type: CryptoService }]; } });
3236
+
3237
+ class GeneratePdfService {
3238
+ constructor(dialog) {
3239
+ this.dialog = dialog;
3240
+ }
3241
+ getPdfOt(data, autoGenerateData) {
3242
+ let autoGenerate = false;
3243
+ if (autoGenerateData) {
3244
+ autoGenerate = autoGenerateData;
3245
+ }
3246
+ return new Promise((resolve, rejects) => {
3247
+ let screen = "850px";
3248
+ // if ( window.screen.width<1000) {
3249
+ // screen = "100vw"
3250
+ // }
3251
+ this.dialog.open(GeneratePdfComponent, {
3252
+ data: {
3253
+ data,
3254
+ autoGenerate: autoGenerate
3255
+ },
3256
+ width: screen
3257
+ }).afterClosed().subscribe((res) => {
3258
+ return resolve(true);
3259
+ });
3260
+ });
3261
+ }
3262
+ getPdfFo(data, autoGenerateData) {
3263
+ let autoGenerate = false;
3264
+ if (autoGenerateData) {
3265
+ autoGenerate = autoGenerateData;
3266
+ }
3267
+ return new Promise((resolve, rejects) => {
3268
+ let screen = "850px";
3269
+ this.dialog.open(TemplateFuelComponent, {
3270
+ data: {
3271
+ data,
3272
+ autoGenerate: autoGenerate
3273
+ },
3274
+ width: screen
3275
+ }).afterClosed().subscribe((res) => {
3276
+ return resolve(true);
3277
+ });
3278
+ });
3279
+ }
3280
+ }
3281
+ GeneratePdfService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GeneratePdfService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable });
3282
+ GeneratePdfService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GeneratePdfService, providedIn: 'root' });
3283
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GeneratePdfService, decorators: [{
3284
+ type: Injectable,
3285
+ args: [{
3286
+ providedIn: 'root'
3287
+ }]
3288
+ }], ctorParameters: function () { return [{ type: i1.MatDialog }]; } });
3289
+
3290
+ class LocalStorageService {
3291
+ constructor() {
3292
+ this.prefix = 'bl-f';
3293
+ this.store = window.localStorage;
3294
+ this.prefix += '.';
3295
+ }
3296
+ /**
3297
+ * set key in local storage
3298
+ * @param key key
3299
+ * @param value value
3300
+ */
3301
+ set(key, value) {
3302
+ key = this.prefix + key;
3303
+ this.store.setItem(key, compress(JSON.stringify(value))); // compress data
3304
+ return true;
3305
+ }
3306
+ /**
3307
+ * get key in local storage
3308
+ * @param key key
3309
+ * @returns value as object
3310
+ */
3311
+ get(key) {
3312
+ key = this.prefix + key;
3313
+ const datacompressed = this.store.getItem(key);
3314
+ if (!datacompressed) {
3315
+ return null;
3316
+ }
3317
+ const item = decompress(datacompressed); // decompress
3318
+ return JSON.parse(item);
3319
+ }
3320
+ /**
3321
+ * remove a key
3322
+ * @param key key to remove
3323
+ * @returns boolean
3324
+ */
3325
+ remove(key) {
3326
+ key = this.prefix + key;
3327
+ this.store.removeItem(key);
3328
+ return true;
3329
+ }
3330
+ /**
3331
+ * clear all
3332
+ * @returns boolean
3333
+ */
3334
+ clear() {
3335
+ this.store.clear();
3336
+ return true;
3337
+ }
3338
+ /**
3339
+ * get all keys present in local storage
3340
+ * @returns array of keys
3341
+ */
3342
+ getAllKeys() {
3343
+ let keys = [];
3344
+ for (let index = 0; index < this.store.length; index++) {
3345
+ const key = this.store.key(index);
3346
+ if (key.indexOf(this.prefix) === 0) {
3347
+ keys.push(key.substr(this.prefix.length));
3348
+ }
3349
+ }
3350
+ return keys;
3351
+ }
3352
+ /**
3353
+ * set key with expire time
3354
+ * @param key key
3355
+ * @param value value
3356
+ * @returns true if set correctly
3357
+ */
3358
+ setWhitExpiry(key, value) {
3359
+ const now = new Date();
3360
+ const ttl = 3600 * 1000;
3361
+ const item = {
3362
+ value: value,
3363
+ expiry: now.getTime() + ttl,
3364
+ };
3365
+ key = this.prefix + key;
3366
+ this.store.setItem(key, compress(JSON.stringify(item))); // compress data
3367
+ return true;
3368
+ }
3369
+ /**
3370
+ * return key with expire time
3371
+ * @param key key
3372
+ * @returns return object with data or null if key expired
3373
+ */
3374
+ getWithExpiry(key) {
3375
+ key = this.prefix + key;
3376
+ const datacompressed = this.store.getItem(key);
3377
+ if (!datacompressed) {
3378
+ return null;
3379
+ }
3380
+ const itemStr = decompress(datacompressed); // decompress
3381
+ const item = JSON.parse(itemStr);
3382
+ const now = new Date();
3383
+ if (!item) {
3384
+ return null;
3385
+ }
3386
+ if (now.getTime() > item.expiry) {
3387
+ this.store.removeItem(key);
3388
+ return null;
3389
+ }
3390
+ return item.value;
3391
+ }
3392
+ }
3393
+ LocalStorageService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LocalStorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
3394
+ LocalStorageService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LocalStorageService, providedIn: 'root' });
3395
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LocalStorageService, decorators: [{
3396
+ type: Injectable,
3397
+ args: [{
3398
+ providedIn: 'root',
3399
+ }]
3400
+ }], ctorParameters: function () { return []; } });
3401
+
3402
+ class MenuBreadCrumb {
3403
+ constructor() {
3404
+ this.name = "";
3405
+ this.router = null;
3406
+ this.current = false;
3407
+ }
3408
+ }
3409
+
3410
+ var enumActions;
3411
+ (function (enumActions) {
3412
+ enumActions[enumActions["REPLACE"] = 0] = "REPLACE";
3413
+ enumActions[enumActions["ADD"] = 1] = "ADD";
3414
+ enumActions[enumActions["REMOVE"] = 2] = "REMOVE";
3415
+ })(enumActions || (enumActions = {}));
3416
+
3417
+ var enumRules;
3418
+ (function (enumRules) {
3419
+ enumRules[enumRules[">"] = 0] = ">";
3420
+ enumRules[enumRules["<"] = 1] = "<";
3421
+ enumRules[enumRules["=="] = 2] = "==";
3422
+ enumRules[enumRules["!="] = 3] = "!=";
3423
+ })(enumRules || (enumRules = {}));
3424
+
3425
+ class IRolesAndPermissions {
3426
+ constructor() {
3427
+ this.hasAccessToAll = false;
3428
+ }
3429
+ }
3430
+ class Permissions {
3431
+ }
3432
+
3433
+ /**
3434
+ * @modules
3435
+ * exportacion de modulos adjuntos a brainloper
3436
+ */
3437
+
3438
+ /**
3439
+ * Generated bundle index. Do not edit.
3440
+ */
3441
+
3442
+ export { BrainloperUiModule, BreadCrumbComponent, ButtonIconComponent, ButtonLabelComponent, CarouselComponent, CombosComponent, CryptoService, DataTableComponent, ExportDataService, FileFormsService, FileInputComponent, FiltersComponent, FunctionsService, GeneratePdfService, HttpService, IRolesAndPermissions, LoadingComponent, LocalStorageService, MenuBreadCrumb, MessageService, Permissions, ScreenSizeUtil, SelectFilterComponent, SessionService, TableModalComponent, enumActions, enumRules, modulesByRol, playerFactory };
3443
+ //# sourceMappingURL=brainloper-ui.mjs.map