brainloper-ui 14.1.0 → 14.1.2

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 (95) hide show
  1. package/esm2020/brainloper-ui.mjs +4 -4
  2. package/esm2020/public_api.mjs +56 -51
  3. package/esm2020/src/app/modules/brainloper-ui/brainloper-ui.module.mjs +310 -305
  4. package/esm2020/src/app/modules/brainloper-ui/components/bread-crumb/bread-crumb.component.mjs +29 -29
  5. package/esm2020/src/app/modules/brainloper-ui/components/buttons/button-icon/button-icon.component.mjs +23 -23
  6. package/esm2020/src/app/modules/brainloper-ui/components/buttons/button-label/button-label.component.mjs +83 -83
  7. package/esm2020/src/app/modules/brainloper-ui/components/carousel/carousel.component.mjs +37 -31
  8. package/esm2020/src/app/modules/brainloper-ui/components/combos/combos.component.mjs +176 -176
  9. package/esm2020/src/app/modules/brainloper-ui/components/data-table/data-table.component.mjs +728 -652
  10. package/esm2020/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.mjs +118 -118
  11. package/esm2020/src/app/modules/brainloper-ui/components/file-input/file-input.component.mjs +186 -185
  12. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/doc.mjs +1 -1
  13. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/fondoTransparente.mjs +1 -1
  14. package/esm2020/src/app/modules/brainloper-ui/components/file-input/imagenes/pdf.mjs +1 -1
  15. package/esm2020/src/app/modules/brainloper-ui/components/filters/filters.component.mjs +222 -222
  16. package/esm2020/src/app/modules/brainloper-ui/components/report/generate-pdf/generate-pdf.component.mjs +80 -80
  17. package/esm2020/src/app/modules/brainloper-ui/components/report/template-fuel/template-fuel.component.mjs +81 -81
  18. package/esm2020/src/app/modules/brainloper-ui/components/select-filter/select-filter.component.mjs +108 -108
  19. package/esm2020/src/app/modules/directives/carousel-item.directive.mjs +18 -0
  20. package/esm2020/src/app/modules/interfaces/buttons/button-icon.mjs +2 -2
  21. package/esm2020/src/app/modules/interfaces/buttons/button-lavel-edit.mjs +2 -2
  22. package/esm2020/src/app/modules/interfaces/combos/combos-configuration.mjs +2 -2
  23. package/esm2020/src/app/modules/interfaces/data-table/params.mjs +2 -2
  24. package/esm2020/src/app/modules/interfaces/data-table/rules.mjs +2 -2
  25. package/esm2020/src/app/modules/interfaces/data-table/table-columns.mjs +2 -2
  26. package/esm2020/src/app/modules/interfaces/data-table/table-configuration.mjs +2 -2
  27. package/esm2020/src/app/modules/interfaces/enum/enumActions.mjs +8 -7
  28. package/esm2020/src/app/modules/interfaces/enum/enumRules.mjs +8 -8
  29. package/esm2020/src/app/modules/interfaces/file-forms-service/file-forms-params.mjs +2 -2
  30. package/esm2020/src/app/modules/interfaces/file-forms-service/file-input-params.mjs +2 -2
  31. package/esm2020/src/app/modules/interfaces/filters/header-filters.mjs +2 -2
  32. package/esm2020/src/app/modules/interfaces/menu-break-crumb/menu-break-crumb.mjs +8 -8
  33. package/esm2020/src/app/modules/interfaces/report/template-pdf-ot.mjs +2 -2
  34. package/esm2020/src/app/modules/interfaces/report/template-pfd-fo.mjs +2 -2
  35. package/esm2020/src/app/modules/services/crypto.service.mjs +37 -37
  36. package/esm2020/src/app/modules/services/export-data.service.mjs +166 -166
  37. package/esm2020/src/app/modules/services/file-forms.service.mjs +24 -24
  38. package/esm2020/src/app/modules/services/functions.service.mjs +54 -54
  39. package/esm2020/src/app/modules/services/generate-pdf.service.mjs +58 -58
  40. package/esm2020/src/app/modules/services/http.service.mjs +97 -154
  41. package/esm2020/src/app/modules/services/loading/loading.component.mjs +28 -28
  42. package/esm2020/src/app/modules/services/local-storage.service.mjs +115 -115
  43. package/esm2020/src/app/modules/services/message.service.mjs +200 -200
  44. package/esm2020/src/app/modules/services/screen-size-util.mjs +6 -6
  45. package/esm2020/src/app/modules/services/session.service.mjs +42 -42
  46. package/fesm2015/brainloper-ui.mjs +2819 -2769
  47. package/fesm2015/brainloper-ui.mjs.map +1 -1
  48. package/fesm2020/brainloper-ui.mjs +2779 -2733
  49. package/fesm2020/brainloper-ui.mjs.map +1 -1
  50. package/index.d.ts +5 -5
  51. package/package.json +3 -1
  52. package/public_api.d.ts +55 -50
  53. package/src/app/modules/brainloper-ui/brainloper-ui.module.d.ts +62 -73
  54. package/src/app/modules/brainloper-ui/components/bread-crumb/bread-crumb.component.d.ts +13 -13
  55. package/src/app/modules/brainloper-ui/components/buttons/button-icon/button-icon.component.d.ts +10 -10
  56. package/src/app/modules/brainloper-ui/components/buttons/button-label/button-label.component.d.ts +24 -24
  57. package/src/app/modules/brainloper-ui/components/carousel/carousel.component.d.ts +15 -12
  58. package/src/app/modules/brainloper-ui/components/combos/combos.component.d.ts +46 -46
  59. package/src/app/modules/brainloper-ui/components/data-table/data-table.component.d.ts +125 -119
  60. package/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.d.ts +21 -21
  61. package/src/app/modules/brainloper-ui/components/file-input/file-input.component.d.ts +42 -42
  62. package/src/app/modules/brainloper-ui/components/file-input/imagenes/doc.d.ts +2 -2
  63. package/src/app/modules/brainloper-ui/components/file-input/imagenes/fondoTransparente.d.ts +2 -2
  64. package/src/app/modules/brainloper-ui/components/file-input/imagenes/pdf.d.ts +2 -2
  65. package/src/app/modules/brainloper-ui/components/filters/filters.component.d.ts +30 -30
  66. package/src/app/modules/brainloper-ui/components/report/generate-pdf/generate-pdf.component.d.ts +35 -35
  67. package/src/app/modules/brainloper-ui/components/report/template-fuel/template-fuel.component.d.ts +36 -36
  68. package/src/app/modules/brainloper-ui/components/select-filter/select-filter.component.d.ts +26 -26
  69. package/src/app/modules/directives/carousel-item.directive.d.ts +9 -0
  70. package/src/app/modules/interfaces/buttons/button-icon.d.ts +9 -9
  71. package/src/app/modules/interfaces/buttons/button-lavel-edit.d.ts +6 -6
  72. package/src/app/modules/interfaces/combos/combos-configuration.d.ts +13 -13
  73. package/src/app/modules/interfaces/data-table/params.d.ts +7 -7
  74. package/src/app/modules/interfaces/data-table/rules.d.ts +8 -8
  75. package/src/app/modules/interfaces/data-table/table-columns.d.ts +25 -25
  76. package/src/app/modules/interfaces/data-table/table-configuration.d.ts +26 -25
  77. package/src/app/modules/interfaces/enum/enumActions.d.ts +6 -5
  78. package/src/app/modules/interfaces/enum/enumRules.d.ts +6 -6
  79. package/src/app/modules/interfaces/file-forms-service/file-forms-params.d.ts +4 -4
  80. package/src/app/modules/interfaces/file-forms-service/file-input-params.d.ts +13 -13
  81. package/src/app/modules/interfaces/filters/header-filters.d.ts +13 -13
  82. package/src/app/modules/interfaces/menu-break-crumb/menu-break-crumb.d.ts +10 -10
  83. package/src/app/modules/interfaces/report/template-pdf-ot.d.ts +19 -19
  84. package/src/app/modules/interfaces/report/template-pfd-fo.d.ts +20 -20
  85. package/src/app/modules/services/crypto.service.d.ts +10 -10
  86. package/src/app/modules/services/export-data.service.d.ts +18 -18
  87. package/src/app/modules/services/file-forms.service.d.ts +7 -7
  88. package/src/app/modules/services/functions.service.d.ts +13 -13
  89. package/src/app/modules/services/generate-pdf.service.d.ts +12 -12
  90. package/src/app/modules/services/http.service.d.ts +22 -21
  91. package/src/app/modules/services/loading/loading.component.d.ts +15 -15
  92. package/src/app/modules/services/local-storage.service.d.ts +49 -49
  93. package/src/app/modules/services/message.service.d.ts +23 -23
  94. package/src/app/modules/services/screen-size-util.d.ts +3 -3
  95. package/src/app/modules/services/session.service.d.ts +14 -14
@@ -1,166 +1,166 @@
1
- import { Injectable } from '@angular/core';
2
- import * as fs from 'file-saver';
3
- import { Workbook } from 'exceljs';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "./http.service";
6
- import * as i2 from "./functions.service";
7
- import * as i3 from "./message.service";
8
- export class ExportDataService {
9
- constructor(http, functionEter, message) {
10
- this.http = http;
11
- this.functionEter = functionEter;
12
- this.message = message;
13
- }
14
- async generateExcelWithSheets(title, header, name, bodies, url, params, filtersPost, titleFields, sheetNameFields, BodyFields) {
15
- this.message.openLoading("Cargando", "Generando archivo");
16
- bodies = await this.getDataBody(url, params, bodies, filtersPost);
17
- const workbook = new Workbook();
18
- for (let index = 0; index < bodies.length; index++) {
19
- const body = bodies[index];
20
- if (titleFields) {
21
- title = titleFields.map(param => body[param]).join("-");
22
- }
23
- var nameSheet = "sheet";
24
- if (sheetNameFields) {
25
- nameSheet = sheetNameFields.map(param => body[param]).join("-");
26
- }
27
- const worksheet = await this.generateToXlsx(title, header, `(${(index + 1) + ') ' + nameSheet}`, body, null, null, null, BodyFields, false);
28
- workbook.addWorksheet(worksheet.name, { views: [{ state: 'frozen', ySplit: 1 }] });
29
- const newWorksheet = workbook.getWorksheet(worksheet.name);
30
- newWorksheet.model = worksheet.model;
31
- }
32
- const buffer = await workbook.xlsx.writeBuffer();
33
- this.saveAsExcelFile(buffer, name);
34
- this.message.closeLoading();
35
- }
36
- async generateToXlsx(title, header, name, body, url, params, filtersPost, BodyFields, generateFile = true) {
37
- if (!generateFile)
38
- this.message.openLoading("Cargando", "Generando el archivo");
39
- body = await this.getDataBody(url, params, body, filtersPost);
40
- let workbook = new Workbook();
41
- let worksheet = workbook.addWorksheet(name);
42
- // Add new row
43
- let titleRow = worksheet.addRow([title]);
44
- // Set font, size and style in title row.
45
- titleRow.font = {
46
- name: 'Comic Sans MS',
47
- family: 4,
48
- size: 16,
49
- underline: 'double',
50
- bold: true,
51
- };
52
- // Blank Row
53
- // worksheet.addRow([]);
54
- // let addheader = false
55
- // for (let p of header.filter(x => x.id === null)) {
56
- // worksheet.addRow([body[p.value]??p.value])
57
- // addheader = true
58
- // }
59
- worksheet.addRow([]);
60
- let addheader = false;
61
- for (let p of header.filter(x => x.id === null)) {
62
- let value = p.value;
63
- const matches = value.match(/{(.*?)}/g);
64
- if (matches) {
65
- matches.forEach(match => {
66
- const key = match.slice(1, -1);
67
- value = value.replace(match, body[key] ?? match);
68
- });
69
- }
70
- worksheet.addRow([value]);
71
- addheader = true;
72
- }
73
- if (addheader)
74
- worksheet.addRow([]);
75
- //Add Header Row
76
- let headerRowValue = header.filter(x => x.id != null).map((p) => { return p.value ?? p.id; });
77
- let _headerRowValue = worksheet.addRow(headerRowValue);
78
- // Cell Style : Fill and Border
79
- _headerRowValue.eachCell((cell, number) => {
80
- cell.fill = {
81
- type: 'pattern',
82
- pattern: 'lightUp',
83
- fgColor: { argb: '6775f500' },
84
- bgColor: { argb: '6775f500' },
85
- };
86
- cell.border = {
87
- top: { style: 'thin' },
88
- left: { style: 'thin' },
89
- bottom: { style: 'thin' },
90
- right: { style: 'thin' },
91
- };
92
- });
93
- var headerRow = header.filter(x => x.id != null);
94
- let data = BodyFields != null ? body[BodyFields] ?? [] : body;
95
- for (let d of data) {
96
- var row = [];
97
- for (let h of headerRow) {
98
- var dh = d[`${h.id}`];
99
- if (h.rules) {
100
- for (const rule of h.rules) {
101
- if (rule.rule == enumRules['==']) {
102
- if (dh == rule.valueRule.toString())
103
- dh = rule.valueAction;
104
- }
105
- }
106
- }
107
- row.push(dh?.toString());
108
- }
109
- worksheet.addRow(row);
110
- }
111
- worksheet.columns.forEach(function (column, i) {
112
- var maxLength = 0;
113
- column["eachCell"]({ includeEmpty: true }, function (cell) {
114
- var columnLength = cell.value ? cell.value.toString().length : 10;
115
- if (columnLength > maxLength) {
116
- maxLength = columnLength;
117
- }
118
- });
119
- column.width = maxLength < 10 ? 10 : maxLength;
120
- });
121
- if (!generateFile) {
122
- return worksheet;
123
- }
124
- workbook.xlsx.writeBuffer().then((data) => {
125
- this.saveAsExcelFile(data, name);
126
- });
127
- if (!generateFile)
128
- this.message.closeLoading();
129
- }
130
- saveAsExcelFile(buffer, fileName) {
131
- const data = new Blob([buffer], {
132
- type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'
133
- });
134
- fs.saveAs(data, `${fileName}_export_${new Date().getTime()}.xlsx`);
135
- }
136
- async getDataBody(url, params, body, filtersPost) {
137
- if (body)
138
- return body;
139
- if (url) {
140
- var res;
141
- res = await this.http.postDataBody(url, filtersPost, params);
142
- if (res['count']) {
143
- return res['data'];
144
- }
145
- else {
146
- return res;
147
- }
148
- }
149
- }
150
- }
151
- ExportDataService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, deps: [{ token: i1.HttpService }, { token: i2.FunctionsService }, { token: i3.MessageService }], target: i0.ɵɵFactoryTarget.Injectable });
152
- ExportDataService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, providedIn: 'root' });
153
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, decorators: [{
154
- type: Injectable,
155
- args: [{
156
- providedIn: 'root'
157
- }]
158
- }], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.FunctionsService }, { type: i3.MessageService }]; } });
159
- var enumRules;
160
- (function (enumRules) {
161
- enumRules[enumRules[">"] = 0] = ">";
162
- enumRules[enumRules["<"] = 1] = "<";
163
- enumRules[enumRules["=="] = 2] = "==";
164
- enumRules[enumRules["!="] = 3] = "!=";
165
- })(enumRules || (enumRules = {}));
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-data.service.js","sourceRoot":"","sources":["../../../../../../src/app/modules/services/export-data.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { MessageService } from './message.service';\r\nimport { Injectable } from '@angular/core';\r\nimport { HttpService } from './http.service';\r\nimport * as fs from 'file-saver';\r\nimport { Workbook } from 'exceljs';\r\nimport { params } from '../interfaces/data-table/params';\r\nimport { FunctionsService } from './functions.service';\r\nimport { HeaderFilters } from '../interfaces/filters/header-filters';\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ExportDataService {\r\n\r\n  constructor(\r\n    private http: HttpService,\r\n    private functionEter: FunctionsService,\r\n    private message: MessageService) { }\r\n\r\n  async generateExcelWithSheets<T>(\r\n    title: string,\r\n    header: Array<params>,\r\n    name: string,\r\n    bodies?: Array<any>,\r\n    url?: string,\r\n    params?: params[],\r\n    filtersPost?: Array<HeaderFilters<any>>,\r\n    titleFields?: string[],\r\n    sheetNameFields?: string[],\r\n    BodyFields?:string): Promise<void> {\r\n\r\n    this.message.openLoading(\"Cargando\", \"Generando archivo\")\r\n\r\n   bodies = await this.getDataBody<Array<T>>(url, params, bodies, filtersPost)\r\n  const workbook = new Workbook();\r\n\r\n    for (let index = 0; index < bodies.length; index++) {\r\n      const body = bodies[index];\r\n\r\n      if (titleFields) {\r\n        title = titleFields.map(param => body[param]).join(\"-\");\r\n      }\r\n\r\n      var nameSheet = \"sheet\";\r\n\r\n      if (sheetNameFields) {\r\n        nameSheet = sheetNameFields.map(param => body[param]).join(\"-\");\r\n      }\r\n\r\n      const worksheet = await this.generateToXlsx(title, header, `(${(index+1)+') '+nameSheet}`, body, null, null, null, BodyFields, false);\r\n      workbook.addWorksheet(worksheet.name, { views: [{ state: 'frozen', ySplit: 1 }] });\r\n      const newWorksheet = workbook.getWorksheet(worksheet.name);\r\n      newWorksheet.model = worksheet.model;\r\n    }\r\n\r\n    const buffer = await workbook.xlsx.writeBuffer();\r\n    this.saveAsExcelFile(buffer, name);\r\n\r\n    this.message.closeLoading()\r\n  }\r\n\r\n  public async generateToXlsx<T>(\r\n    title: string,\r\n    header: Array<params>,\r\n    name: string,\r\n    body?: T,\r\n    url?: string,\r\n    params?: Array<params>,\r\n    filtersPost?: Array<HeaderFilters<any>>,\r\n    BodyFields?:string,\r\n    generateFile: boolean = true): Promise<any> {\r\n\r\n    if (!generateFile) this.message.openLoading(\"Cargando\", \"Generando el archivo\")\r\n\r\n    body = await this.getDataBody<T>(url, params, body, filtersPost)\r\n\r\n    let workbook = new Workbook();\r\n    let worksheet = workbook.addWorksheet(name);\r\n\r\n    // Add new row\r\n    let titleRow = worksheet.addRow([title]);\r\n\r\n    // Set font, size and style in title row.\r\n    titleRow.font = {\r\n      name: 'Comic Sans MS',\r\n      family: 4,\r\n      size: 16,\r\n      underline: 'double',\r\n      bold: true,\r\n    };\r\n\r\n    // Blank Row\r\n    // worksheet.addRow([]);\r\n    // let addheader = false\r\n    // for (let p of header.filter(x => x.id === null)) {\r\n    //   worksheet.addRow([body[p.value]??p.value])\r\n    //   addheader = true\r\n    // }\r\n\r\n    worksheet.addRow([]);\r\n    let addheader = false;\r\n    for (let p of header.filter(x => x.id === null)) {\r\n      let value = p.value;\r\n      const matches = value.match(/{(.*?)}/g);\r\n      if (matches) {\r\n        matches.forEach(match => {\r\n          const key = match.slice(1, -1);\r\n          value = value.replace(match, body[key] ?? match);\r\n        });\r\n      }\r\n      worksheet.addRow([value]);\r\n      addheader = true;\r\n    }\r\n\r\n    if (addheader) worksheet.addRow([]);\r\n\r\n    //Add Header Row\r\n    let headerRowValue = header.filter(x => x.id != null).map((p) => { return p.value??p.id })\r\n    let _headerRowValue = worksheet.addRow(headerRowValue);\r\n\r\n    // Cell Style : Fill and Border\r\n    _headerRowValue.eachCell((cell, number) => {\r\n      cell.fill = {\r\n        type: 'pattern',\r\n        pattern: 'lightUp',\r\n        fgColor: { argb: '6775f500' },\r\n        bgColor: { argb: '6775f500' },\r\n      };\r\n      cell.border = {\r\n        top: { style: 'thin' },\r\n        left: { style: 'thin' },\r\n        bottom: { style: 'thin' },\r\n        right: { style: 'thin' },\r\n      };\r\n    });\r\n\r\n    var headerRow = header.filter(x => x.id != null)\r\n\r\n    let data = BodyFields != null ? body[BodyFields] ?? [] : body\r\n    for (let d of data) {\r\n      var row = []\r\n      for (let h of headerRow) {\r\n        var dh = d[`${h.id}`]\r\n        if (h.rules) {\r\n          for (const rule of h.rules) {\r\n            if (rule.rule == enumRules['==']) {\r\n              if (dh == rule.valueRule.toString())\r\n                dh = rule.valueAction\r\n            }\r\n          }\r\n        }\r\n        row.push(dh?.toString())\r\n      }\r\n      worksheet.addRow(row);\r\n    }\r\n\r\n    worksheet.columns.forEach(function (column, i) {\r\n      var maxLength = 0;\r\n      column[\"eachCell\"]({ includeEmpty: true }, function (cell) {\r\n        var columnLength = cell.value ? cell.value.toString().length : 10;\r\n        if (columnLength > maxLength) {\r\n          maxLength = columnLength;\r\n        }\r\n      });\r\n      column.width = maxLength < 10 ? 10 : maxLength;\r\n    });\r\n\r\n    if (!generateFile) {\r\n      return worksheet;\r\n    }\r\n\r\n    workbook.xlsx.writeBuffer().then((data) => {\r\n      this.saveAsExcelFile(data, name);\r\n    });\r\n\r\n    if (!generateFile) this.message.closeLoading()\r\n  }\r\n\r\n  private saveAsExcelFile(buffer: any, fileName: string): void {\r\n    const data: Blob = new Blob([buffer], {\r\n      type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\r\n    });\r\n    fs.saveAs(data, `${fileName}_export_${new Date().getTime()}.xlsx`);\r\n  }\r\n\r\n  private async getDataBody<T>(url: string, params: Array<params>, body: T, filtersPost?: Array<HeaderFilters<any>>): Promise<T> {\r\n    if (body) return body;\r\n\r\n    if (url) {\r\n      var res: any\r\n      res = await this.http.postDataBody(url, filtersPost, params)\r\n      if (res['count']) {\r\n        return res['data']\r\n      } else {\r\n        return res\r\n      }\r\n    }\r\n\r\n  }\r\n}\r\n\r\nenum enumRules {\r\n  \">\",\r\n  \"<\",\r\n  \"==\",\r\n  \"!=\"\r\n}\r\n"]}
1
+ import { Injectable } from '@angular/core';
2
+ import * as fs from 'file-saver';
3
+ import { Workbook } from 'exceljs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "./http.service";
6
+ import * as i2 from "./functions.service";
7
+ import * as i3 from "./message.service";
8
+ export class ExportDataService {
9
+ constructor(http, functionEter, message) {
10
+ this.http = http;
11
+ this.functionEter = functionEter;
12
+ this.message = message;
13
+ }
14
+ async generateExcelWithSheets(title, header, name, bodies, url, params, filtersPost, titleFields, sheetNameFields, BodyFields) {
15
+ this.message.openLoading("Cargando", "Generando archivo");
16
+ bodies = await this.getDataBody(url, params, bodies, filtersPost);
17
+ const workbook = new Workbook();
18
+ for (let index = 0; index < bodies.length; index++) {
19
+ const body = bodies[index];
20
+ if (titleFields) {
21
+ title = titleFields.map(param => body[param]).join("-");
22
+ }
23
+ var nameSheet = "sheet";
24
+ if (sheetNameFields) {
25
+ nameSheet = sheetNameFields.map(param => body[param]).join("-");
26
+ }
27
+ const worksheet = await this.generateToXlsx(title, header, `(${(index + 1) + ') ' + nameSheet}`, body, null, null, null, BodyFields, false);
28
+ workbook.addWorksheet(worksheet.name, { views: [{ state: 'frozen', ySplit: 1 }] });
29
+ const newWorksheet = workbook.getWorksheet(worksheet.name);
30
+ newWorksheet.model = worksheet.model;
31
+ }
32
+ const buffer = await workbook.xlsx.writeBuffer();
33
+ this.saveAsExcelFile(buffer, name);
34
+ this.message.closeLoading();
35
+ }
36
+ async generateToXlsx(title, header, name, body, url, params, filtersPost, BodyFields, generateFile = true) {
37
+ if (!generateFile)
38
+ this.message.openLoading("Cargando", "Generando el archivo");
39
+ body = await this.getDataBody(url, params, body, filtersPost);
40
+ let workbook = new Workbook();
41
+ let worksheet = workbook.addWorksheet(name);
42
+ // Add new row
43
+ let titleRow = worksheet.addRow([title]);
44
+ // Set font, size and style in title row.
45
+ titleRow.font = {
46
+ name: 'Comic Sans MS',
47
+ family: 4,
48
+ size: 16,
49
+ underline: 'double',
50
+ bold: true,
51
+ };
52
+ // Blank Row
53
+ // worksheet.addRow([]);
54
+ // let addheader = false
55
+ // for (let p of header.filter(x => x.id === null)) {
56
+ // worksheet.addRow([body[p.value]??p.value])
57
+ // addheader = true
58
+ // }
59
+ worksheet.addRow([]);
60
+ let addheader = false;
61
+ for (let p of header.filter(x => x.id === null)) {
62
+ let value = p.value;
63
+ const matches = value.match(/{(.*?)}/g);
64
+ if (matches) {
65
+ matches.forEach(match => {
66
+ const key = match.slice(1, -1);
67
+ value = value.replace(match, body[key] ?? match);
68
+ });
69
+ }
70
+ worksheet.addRow([value]);
71
+ addheader = true;
72
+ }
73
+ if (addheader)
74
+ worksheet.addRow([]);
75
+ //Add Header Row
76
+ let headerRowValue = header.filter(x => x.id != null).map((p) => { return p.value ?? p.id; });
77
+ let _headerRowValue = worksheet.addRow(headerRowValue);
78
+ // Cell Style : Fill and Border
79
+ _headerRowValue.eachCell((cell, number) => {
80
+ cell.fill = {
81
+ type: 'pattern',
82
+ pattern: 'lightUp',
83
+ fgColor: { argb: '6775f500' },
84
+ bgColor: { argb: '6775f500' },
85
+ };
86
+ cell.border = {
87
+ top: { style: 'thin' },
88
+ left: { style: 'thin' },
89
+ bottom: { style: 'thin' },
90
+ right: { style: 'thin' },
91
+ };
92
+ });
93
+ var headerRow = header.filter(x => x.id != null);
94
+ let data = BodyFields != null ? body[BodyFields] ?? [] : body;
95
+ for (let d of data) {
96
+ var row = [];
97
+ for (let h of headerRow) {
98
+ var dh = d[`${h.id}`];
99
+ if (h.rules) {
100
+ for (const rule of h.rules) {
101
+ if (rule.rule == enumRules['==']) {
102
+ if (dh == rule.valueRule.toString())
103
+ dh = rule.valueAction;
104
+ }
105
+ }
106
+ }
107
+ row.push(dh?.toString());
108
+ }
109
+ worksheet.addRow(row);
110
+ }
111
+ worksheet.columns.forEach(function (column, i) {
112
+ var maxLength = 0;
113
+ column["eachCell"]({ includeEmpty: true }, function (cell) {
114
+ var columnLength = cell.value ? cell.value.toString().length : 10;
115
+ if (columnLength > maxLength) {
116
+ maxLength = columnLength;
117
+ }
118
+ });
119
+ column.width = maxLength < 10 ? 10 : maxLength;
120
+ });
121
+ if (!generateFile) {
122
+ return worksheet;
123
+ }
124
+ workbook.xlsx.writeBuffer().then((data) => {
125
+ this.saveAsExcelFile(data, name);
126
+ });
127
+ if (!generateFile)
128
+ this.message.closeLoading();
129
+ }
130
+ saveAsExcelFile(buffer, fileName) {
131
+ const data = new Blob([buffer], {
132
+ type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'
133
+ });
134
+ fs.saveAs(data, `${fileName}_export_${new Date().getTime()}.xlsx`);
135
+ }
136
+ async getDataBody(url, params, body, filtersPost) {
137
+ if (body)
138
+ return body;
139
+ if (url) {
140
+ var res;
141
+ res = await this.http.postDataBody(url, filtersPost, params);
142
+ if (res['count']) {
143
+ return res['data'];
144
+ }
145
+ else {
146
+ return res;
147
+ }
148
+ }
149
+ }
150
+ }
151
+ ExportDataService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, deps: [{ token: i1.HttpService }, { token: i2.FunctionsService }, { token: i3.MessageService }], target: i0.ɵɵFactoryTarget.Injectable });
152
+ ExportDataService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, providedIn: 'root' });
153
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportDataService, decorators: [{
154
+ type: Injectable,
155
+ args: [{
156
+ providedIn: 'root'
157
+ }]
158
+ }], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.FunctionsService }, { type: i3.MessageService }]; } });
159
+ var enumRules;
160
+ (function (enumRules) {
161
+ enumRules[enumRules[">"] = 0] = ">";
162
+ enumRules[enumRules["<"] = 1] = "<";
163
+ enumRules[enumRules["=="] = 2] = "==";
164
+ enumRules[enumRules["!="] = 3] = "!=";
165
+ })(enumRules || (enumRules = {}));
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-data.service.js","sourceRoot":"","sources":["../../../../../../src/app/modules/services/export-data.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { MessageService } from './message.service';\nimport { Injectable } from '@angular/core';\nimport { HttpService } from './http.service';\nimport * as fs from 'file-saver';\nimport { Workbook } from 'exceljs';\nimport { params } from '../interfaces/data-table/params';\nimport { FunctionsService } from './functions.service';\nimport { HeaderFilters } from '../interfaces/filters/header-filters';\n@Injectable({\n  providedIn: 'root'\n})\nexport class ExportDataService {\n\n  constructor(\n    private http: HttpService,\n    private functionEter: FunctionsService,\n    private message: MessageService) { }\n\n  async generateExcelWithSheets<T>(\n    title: string,\n    header: Array<params>,\n    name: string,\n    bodies?: Array<any>,\n    url?: string,\n    params?: params[],\n    filtersPost?: Array<HeaderFilters<any>>,\n    titleFields?: string[],\n    sheetNameFields?: string[],\n    BodyFields?:string): Promise<void> {\n\n    this.message.openLoading(\"Cargando\", \"Generando archivo\")\n\n   bodies = await this.getDataBody<Array<T>>(url, params, bodies, filtersPost)\n  const workbook = new Workbook();\n\n    for (let index = 0; index < bodies.length; index++) {\n      const body = bodies[index];\n\n      if (titleFields) {\n        title = titleFields.map(param => body[param]).join(\"-\");\n      }\n\n      var nameSheet = \"sheet\";\n\n      if (sheetNameFields) {\n        nameSheet = sheetNameFields.map(param => body[param]).join(\"-\");\n      }\n\n      const worksheet = await this.generateToXlsx(title, header, `(${(index+1)+') '+nameSheet}`, body, null, null, null, BodyFields, false);\n      workbook.addWorksheet(worksheet.name, { views: [{ state: 'frozen', ySplit: 1 }] });\n      const newWorksheet = workbook.getWorksheet(worksheet.name);\n      newWorksheet.model = worksheet.model;\n    }\n\n    const buffer = await workbook.xlsx.writeBuffer();\n    this.saveAsExcelFile(buffer, name);\n\n    this.message.closeLoading()\n  }\n\n  public async generateToXlsx<T>(\n    title: string,\n    header: Array<params>,\n    name: string,\n    body?: T,\n    url?: string,\n    params?: Array<params>,\n    filtersPost?: Array<HeaderFilters<any>>,\n    BodyFields?:string,\n    generateFile: boolean = true): Promise<any> {\n\n    if (!generateFile) this.message.openLoading(\"Cargando\", \"Generando el archivo\")\n\n    body = await this.getDataBody<T>(url, params, body, filtersPost)\n\n    let workbook = new Workbook();\n    let worksheet = workbook.addWorksheet(name);\n\n    // Add new row\n    let titleRow = worksheet.addRow([title]);\n\n    // Set font, size and style in title row.\n    titleRow.font = {\n      name: 'Comic Sans MS',\n      family: 4,\n      size: 16,\n      underline: 'double',\n      bold: true,\n    };\n\n    // Blank Row\n    // worksheet.addRow([]);\n    // let addheader = false\n    // for (let p of header.filter(x => x.id === null)) {\n    //   worksheet.addRow([body[p.value]??p.value])\n    //   addheader = true\n    // }\n\n    worksheet.addRow([]);\n    let addheader = false;\n    for (let p of header.filter(x => x.id === null)) {\n      let value = p.value;\n      const matches = value.match(/{(.*?)}/g);\n      if (matches) {\n        matches.forEach(match => {\n          const key = match.slice(1, -1);\n          value = value.replace(match, body[key] ?? match);\n        });\n      }\n      worksheet.addRow([value]);\n      addheader = true;\n    }\n\n    if (addheader) worksheet.addRow([]);\n\n    //Add Header Row\n    let headerRowValue = header.filter(x => x.id != null).map((p) => { return p.value??p.id })\n    let _headerRowValue = worksheet.addRow(headerRowValue);\n\n    // Cell Style : Fill and Border\n    _headerRowValue.eachCell((cell, number) => {\n      cell.fill = {\n        type: 'pattern',\n        pattern: 'lightUp',\n        fgColor: { argb: '6775f500' },\n        bgColor: { argb: '6775f500' },\n      };\n      cell.border = {\n        top: { style: 'thin' },\n        left: { style: 'thin' },\n        bottom: { style: 'thin' },\n        right: { style: 'thin' },\n      };\n    });\n\n    var headerRow = header.filter(x => x.id != null)\n\n    let data = BodyFields != null ? body[BodyFields] ?? [] : body\n    for (let d of data) {\n      var row = []\n      for (let h of headerRow) {\n        var dh = d[`${h.id}`]\n        if (h.rules) {\n          for (const rule of h.rules) {\n            if (rule.rule == enumRules['==']) {\n              if (dh == rule.valueRule.toString())\n                dh = rule.valueAction\n            }\n          }\n        }\n        row.push(dh?.toString())\n      }\n      worksheet.addRow(row);\n    }\n\n    worksheet.columns.forEach(function (column, i) {\n      var maxLength = 0;\n      column[\"eachCell\"]({ includeEmpty: true }, function (cell) {\n        var columnLength = cell.value ? cell.value.toString().length : 10;\n        if (columnLength > maxLength) {\n          maxLength = columnLength;\n        }\n      });\n      column.width = maxLength < 10 ? 10 : maxLength;\n    });\n\n    if (!generateFile) {\n      return worksheet;\n    }\n\n    workbook.xlsx.writeBuffer().then((data) => {\n      this.saveAsExcelFile(data, name);\n    });\n\n    if (!generateFile) this.message.closeLoading()\n  }\n\n  private saveAsExcelFile(buffer: any, fileName: string): void {\n    const data: Blob = new Blob([buffer], {\n      type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\n    });\n    fs.saveAs(data, `${fileName}_export_${new Date().getTime()}.xlsx`);\n  }\n\n  private async getDataBody<T>(url: string, params: Array<params>, body: T, filtersPost?: Array<HeaderFilters<any>>): Promise<T> {\n    if (body) return body;\n\n    if (url) {\n      var res: any\n      res = await this.http.postDataBody(url, filtersPost, params)\n      if (res['count']) {\n        return res['data']\n      } else {\n        return res\n      }\n    }\n\n  }\n}\n\nenum enumRules {\n  \">\",\n  \"<\",\n  \"==\",\n  \"!=\"\n}\n"]}
@@ -1,24 +1,24 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class FileFormsService {
4
- constructor() { }
5
- createMultipartForm(file, params) {
6
- const formD = new FormData();
7
- formD.append('file', file, 'form-data'); //Asigna el campo File
8
- if (params) {
9
- params.forEach((element) => {
10
- formD.append(element.id, element.value);
11
- });
12
- }
13
- return (formD);
14
- }
15
- }
16
- FileFormsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
17
- FileFormsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, providedIn: 'root' });
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, decorators: [{
19
- type: Injectable,
20
- args: [{
21
- providedIn: 'root'
22
- }]
23
- }], ctorParameters: function () { return []; } });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1mb3Jtcy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL3NlcnZpY2VzL2ZpbGUtZm9ybXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sZ0JBQWdCO0lBRTNCLGdCQUFnQixDQUFDO0lBRWpCLG1CQUFtQixDQUFDLElBQVMsRUFBRSxNQUFPO1FBRXBDLE1BQU0sS0FBSyxHQUFHLElBQUksUUFBUSxFQUFFLENBQUM7UUFDN0IsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUMsSUFBSSxFQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUEsc0JBQXNCO1FBQzVELElBQUcsTUFBTSxFQUFDO1lBQ1IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQVcsRUFBRSxFQUFFO2dCQUM3QixLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3hDLENBQUMsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxPQUFNLENBQUMsS0FBSyxDQUFDLENBQUE7SUFFZixDQUFDOzs2R0FmVSxnQkFBZ0I7aUhBQWhCLGdCQUFnQixjQUZmLE1BQU07MkZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbGVGb3Jtc1NlcnZpY2Uge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBjcmVhdGVNdWx0aXBhcnRGb3JtKGZpbGU6RmlsZSwgcGFyYW1zPyl7XHJcblxyXG4gICAgY29uc3QgZm9ybUQgPSBuZXcgRm9ybURhdGEoKTtcclxuICAgIGZvcm1ELmFwcGVuZCgnZmlsZScsZmlsZSwnZm9ybS1kYXRhJyk7Ly9Bc2lnbmEgZWwgY2FtcG8gRmlsZVxyXG4gICAgaWYocGFyYW1zKXtcclxuICAgICAgcGFyYW1zLmZvckVhY2goKGVsZW1lbnQ6YW55KSA9PiB7XHJcbiAgICAgICAgZm9ybUQuYXBwZW5kKGVsZW1lbnQuaWQsZWxlbWVudC52YWx1ZSlcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4oZm9ybUQpXHJcblxyXG4gIH1cclxuXHJcbn1cclxuIl19
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class FileFormsService {
4
+ constructor() { }
5
+ createMultipartForm(file, params) {
6
+ const formD = new FormData();
7
+ formD.append('file', file, 'form-data'); //Asigna el campo File
8
+ if (params) {
9
+ params.forEach((element) => {
10
+ formD.append(element.id, element.value);
11
+ });
12
+ }
13
+ return (formD);
14
+ }
15
+ }
16
+ FileFormsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
17
+ FileFormsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, providedIn: 'root' });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileFormsService, decorators: [{
19
+ type: Injectable,
20
+ args: [{
21
+ providedIn: 'root'
22
+ }]
23
+ }], ctorParameters: function () { return []; } });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1mb3Jtcy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL3NlcnZpY2VzL2ZpbGUtZm9ybXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sZ0JBQWdCO0lBRTNCLGdCQUFnQixDQUFDO0lBRWpCLG1CQUFtQixDQUFDLElBQVMsRUFBRSxNQUFPO1FBRXBDLE1BQU0sS0FBSyxHQUFHLElBQUksUUFBUSxFQUFFLENBQUM7UUFDN0IsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUMsSUFBSSxFQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUEsc0JBQXNCO1FBQzVELElBQUcsTUFBTSxFQUFDO1lBQ1IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQVcsRUFBRSxFQUFFO2dCQUM3QixLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3hDLENBQUMsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxPQUFNLENBQUMsS0FBSyxDQUFDLENBQUE7SUFFZixDQUFDOzs2R0FmVSxnQkFBZ0I7aUhBQWhCLGdCQUFnQixjQUZmLE1BQU07MkZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRmlsZUZvcm1zU2VydmljZSB7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBjcmVhdGVNdWx0aXBhcnRGb3JtKGZpbGU6RmlsZSwgcGFyYW1zPyl7XG5cbiAgICBjb25zdCBmb3JtRCA9IG5ldyBGb3JtRGF0YSgpO1xuICAgIGZvcm1ELmFwcGVuZCgnZmlsZScsZmlsZSwnZm9ybS1kYXRhJyk7Ly9Bc2lnbmEgZWwgY2FtcG8gRmlsZVxuICAgIGlmKHBhcmFtcyl7XG4gICAgICBwYXJhbXMuZm9yRWFjaCgoZWxlbWVudDphbnkpID0+IHtcbiAgICAgICAgZm9ybUQuYXBwZW5kKGVsZW1lbnQuaWQsZWxlbWVudC52YWx1ZSlcbiAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4oZm9ybUQpXG5cbiAgfVxuXG59XG4iXX0=
@@ -1,54 +1,54 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class FunctionsService {
4
- constructor() { }
5
- dateForm(date) {
6
- let data = new Date(date);
7
- let change = `${data.getFullYear()}/${data.getMonth() + 1}/${data.getDate()}`;
8
- return (change);
9
- }
10
- dateIso(date) {
11
- let data = date.toString();
12
- let cut = data.replace(/(.*)\T.*/, '$1');
13
- let add = `${cut}T05:00:00.000Z`;
14
- let fecha = add.replace(/(.*)\T.*/, '$1');
15
- return (fecha);
16
- }
17
- dateDB(date) {
18
- let day = this.validateTwoDigitFormat(date.getDate().toString());
19
- let month = this.validateTwoDigitFormat((date.getMonth() + 1).toString());
20
- return `${date.getFullYear()}-${month}-${day}`;
21
- }
22
- dateWithTime(date) {
23
- if (!date)
24
- return "";
25
- var value = date.split("T");
26
- return value[0] + " " + value[1].split(".")[0];
27
- }
28
- areObjectsEqual(obj1, obj2) {
29
- return JSON.stringify(obj1) === JSON.stringify(obj2);
30
- }
31
- removeDuplicateObjects(originalArray) {
32
- const uniqueArray = [];
33
- originalArray.forEach((obj) => {
34
- if (!uniqueArray.some((uniqueObj) => this.areObjectsEqual(obj, uniqueObj))) {
35
- uniqueArray.push(obj);
36
- }
37
- });
38
- return uniqueArray;
39
- }
40
- validateTwoDigitFormat(number) {
41
- if (number.length == 1)
42
- number = "0" + number;
43
- return number;
44
- }
45
- }
46
- FunctionsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
47
- FunctionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, providedIn: 'root' });
48
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, decorators: [{
49
- type: Injectable,
50
- args: [{
51
- providedIn: 'root'
52
- }]
53
- }], ctorParameters: function () { return []; } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb25zLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvc2VydmljZXMvZnVuY3Rpb25zLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUUzQixnQkFBZ0IsQ0FBQztJQUdqQixRQUFRLENBQUUsSUFBSTtRQUNiLElBQUksSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3pCLElBQUksTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUE7UUFDNUUsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ2pCLENBQUM7SUFFRCxPQUFPLENBQUUsSUFBSTtRQUNYLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMzQixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQTtRQUN4QyxJQUFJLEdBQUcsR0FBSSxHQUFHLEdBQUcsZ0JBQWdCLENBQUE7UUFDakMsSUFBSSxLQUFLLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUE7UUFDekMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ2hCLENBQUM7SUFFRCxNQUFNLENBQUUsSUFBSTtRQUNWLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUNoRSxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUN2RSxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLEtBQUssSUFBSSxHQUFHLEVBQUUsQ0FBQTtJQUNoRCxDQUFDO0lBRUQsWUFBWSxDQUFDLElBQVc7UUFDdEIsSUFBRyxDQUFDLElBQUk7WUFBRSxPQUFPLEVBQUUsQ0FBQTtRQUNuQixJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQzNCLE9BQVEsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ2pELENBQUM7SUFFRCxlQUFlLENBQUMsSUFBUyxFQUFFLElBQVM7UUFDbEMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELHNCQUFzQixDQUFDLGFBQW9CO1FBQ3pDLE1BQU0sV0FBVyxHQUFVLEVBQUUsQ0FBQztRQUM5QixhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDLEVBQUU7Z0JBQzFFLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDdkI7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFFTyxzQkFBc0IsQ0FBQyxNQUFjO1FBQzNDLElBQUcsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDO1lBQUUsTUFBTSxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUE7UUFDNUMsT0FBTyxNQUFNLENBQUE7SUFDZixDQUFDOzs2R0FqRFUsZ0JBQWdCO2lIQUFoQixnQkFBZ0IsY0FGZixNQUFNOzJGQUVQLGdCQUFnQjtrQkFINUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGdW5jdGlvbnNTZXJ2aWNlIHtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcblxyXG4gIGRhdGVGb3JtIChkYXRlKSB7XHJcbiAgIGxldCBkYXRhID0gbmV3IERhdGUoZGF0ZSlcclxuICAgbGV0IGNoYW5nZSA9IGAke2RhdGEuZ2V0RnVsbFllYXIoKX0vJHtkYXRhLmdldE1vbnRoKCkgKyAxfS8ke2RhdGEuZ2V0RGF0ZSgpfWBcclxuICAgIHJldHVybiAoY2hhbmdlKVxyXG4gIH1cclxuXHJcbiAgZGF0ZUlzbyAoZGF0ZSkge1xyXG4gICAgbGV0IGRhdGEgPSBkYXRlLnRvU3RyaW5nKCk7XHJcbiAgICBsZXQgY3V0ID0gZGF0YS5yZXBsYWNlKC8oLiopXFxULiovLCAnJDEnKVxyXG4gICAgbGV0IGFkZCAgPSBgJHtjdXR9VDA1OjAwOjAwLjAwMFpgXHJcbiAgICBsZXQgZmVjaGEgPSBhZGQucmVwbGFjZSgvKC4qKVxcVC4qLywgJyQxJylcclxuICAgIHJldHVybiAoZmVjaGEpXHJcbiAgfVxyXG5cclxuICBkYXRlREIgKGRhdGUpIHtcclxuICAgIGxldCBkYXkgPSB0aGlzLnZhbGlkYXRlVHdvRGlnaXRGb3JtYXQoZGF0ZS5nZXREYXRlKCkudG9TdHJpbmcoKSlcclxuICAgIGxldCBtb250aCA9IHRoaXMudmFsaWRhdGVUd29EaWdpdEZvcm1hdCgoZGF0ZS5nZXRNb250aCgpKzEpLnRvU3RyaW5nKCkpXHJcbiAgICByZXR1cm4gYCR7ZGF0ZS5nZXRGdWxsWWVhcigpfS0ke21vbnRofS0ke2RheX1gXHJcbiAgfVxyXG5cclxuICBkYXRlV2l0aFRpbWUoZGF0ZTpzdHJpbmcpOnN0cmluZ3tcclxuICAgIGlmKCFkYXRlKSByZXR1cm4gXCJcIlxyXG4gICAgdmFyIHZhbHVlID0gZGF0ZS5zcGxpdChcIlRcIilcclxuICAgIHJldHVybiAgdmFsdWVbMF0gKyBcIiBcIiArIHZhbHVlWzFdLnNwbGl0KFwiLlwiKVswXVxyXG4gIH1cclxuXHJcbiAgYXJlT2JqZWN0c0VxdWFsKG9iajE6IGFueSwgb2JqMjogYW55KTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gSlNPTi5zdHJpbmdpZnkob2JqMSkgPT09IEpTT04uc3RyaW5naWZ5KG9iajIpO1xyXG4gIH1cclxuXHJcbiAgcmVtb3ZlRHVwbGljYXRlT2JqZWN0cyhvcmlnaW5hbEFycmF5OiBhbnlbXSk6IGFueVtdIHtcclxuICAgIGNvbnN0IHVuaXF1ZUFycmF5OiBhbnlbXSA9IFtdO1xyXG4gICAgb3JpZ2luYWxBcnJheS5mb3JFYWNoKChvYmopID0+IHtcclxuICAgICAgaWYgKCF1bmlxdWVBcnJheS5zb21lKCh1bmlxdWVPYmopID0+IHRoaXMuYXJlT2JqZWN0c0VxdWFsKG9iaiwgdW5pcXVlT2JqKSkpIHtcclxuICAgICAgICB1bmlxdWVBcnJheS5wdXNoKG9iaik7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG5cclxuICAgIHJldHVybiB1bmlxdWVBcnJheTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgdmFsaWRhdGVUd29EaWdpdEZvcm1hdChudW1iZXI6IHN0cmluZyk6c3RyaW5ne1xyXG4gICAgaWYobnVtYmVyLmxlbmd0aCA9PSAxKSBudW1iZXIgPSBcIjBcIiArIG51bWJlclxyXG4gICAgcmV0dXJuIG51bWJlclxyXG4gIH1cclxuXHJcbn1cclxuIl19
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class FunctionsService {
4
+ constructor() { }
5
+ dateForm(date) {
6
+ let data = new Date(date);
7
+ let change = `${data.getFullYear()}/${data.getMonth() + 1}/${data.getDate()}`;
8
+ return (change);
9
+ }
10
+ dateIso(date) {
11
+ let data = date.toString();
12
+ let cut = data.replace(/(.*)\T.*/, '$1');
13
+ let add = `${cut}T05:00:00.000Z`;
14
+ let fecha = add.replace(/(.*)\T.*/, '$1');
15
+ return (fecha);
16
+ }
17
+ dateDB(date) {
18
+ let day = this.validateTwoDigitFormat(date.getDate().toString());
19
+ let month = this.validateTwoDigitFormat((date.getMonth() + 1).toString());
20
+ return `${date.getFullYear()}-${month}-${day}`;
21
+ }
22
+ dateWithTime(date) {
23
+ if (!date)
24
+ return "";
25
+ var value = date.split("T");
26
+ return value[0] + " " + value[1].split(".")[0];
27
+ }
28
+ areObjectsEqual(obj1, obj2) {
29
+ return JSON.stringify(obj1) === JSON.stringify(obj2);
30
+ }
31
+ removeDuplicateObjects(originalArray) {
32
+ const uniqueArray = [];
33
+ originalArray.forEach((obj) => {
34
+ if (!uniqueArray.some((uniqueObj) => this.areObjectsEqual(obj, uniqueObj))) {
35
+ uniqueArray.push(obj);
36
+ }
37
+ });
38
+ return uniqueArray;
39
+ }
40
+ validateTwoDigitFormat(number) {
41
+ if (number.length == 1)
42
+ number = "0" + number;
43
+ return number;
44
+ }
45
+ }
46
+ FunctionsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
47
+ FunctionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, providedIn: 'root' });
48
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FunctionsService, decorators: [{
49
+ type: Injectable,
50
+ args: [{
51
+ providedIn: 'root'
52
+ }]
53
+ }], ctorParameters: function () { return []; } });
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb25zLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvc2VydmljZXMvZnVuY3Rpb25zLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUUzQixnQkFBZ0IsQ0FBQztJQUdqQixRQUFRLENBQUUsSUFBSTtRQUNiLElBQUksSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3pCLElBQUksTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUE7UUFDNUUsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ2pCLENBQUM7SUFFRCxPQUFPLENBQUUsSUFBSTtRQUNYLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMzQixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQTtRQUN4QyxJQUFJLEdBQUcsR0FBSSxHQUFHLEdBQUcsZ0JBQWdCLENBQUE7UUFDakMsSUFBSSxLQUFLLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUE7UUFDekMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ2hCLENBQUM7SUFFRCxNQUFNLENBQUUsSUFBSTtRQUNWLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUNoRSxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUN2RSxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLEtBQUssSUFBSSxHQUFHLEVBQUUsQ0FBQTtJQUNoRCxDQUFDO0lBRUQsWUFBWSxDQUFDLElBQVc7UUFDdEIsSUFBRyxDQUFDLElBQUk7WUFBRSxPQUFPLEVBQUUsQ0FBQTtRQUNuQixJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQzNCLE9BQVEsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ2pELENBQUM7SUFFRCxlQUFlLENBQUMsSUFBUyxFQUFFLElBQVM7UUFDbEMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELHNCQUFzQixDQUFDLGFBQW9CO1FBQ3pDLE1BQU0sV0FBVyxHQUFVLEVBQUUsQ0FBQztRQUM5QixhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDLEVBQUU7Z0JBQzFFLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDdkI7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFFTyxzQkFBc0IsQ0FBQyxNQUFjO1FBQzNDLElBQUcsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDO1lBQUUsTUFBTSxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUE7UUFDNUMsT0FBTyxNQUFNLENBQUE7SUFDZixDQUFDOzs2R0FqRFUsZ0JBQWdCO2lIQUFoQixnQkFBZ0IsY0FGZixNQUFNOzJGQUVQLGdCQUFnQjtrQkFINUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEZ1bmN0aW9uc1NlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cblxuICBkYXRlRm9ybSAoZGF0ZSkge1xuICAgbGV0IGRhdGEgPSBuZXcgRGF0ZShkYXRlKVxuICAgbGV0IGNoYW5nZSA9IGAke2RhdGEuZ2V0RnVsbFllYXIoKX0vJHtkYXRhLmdldE1vbnRoKCkgKyAxfS8ke2RhdGEuZ2V0RGF0ZSgpfWBcbiAgICByZXR1cm4gKGNoYW5nZSlcbiAgfVxuXG4gIGRhdGVJc28gKGRhdGUpIHtcbiAgICBsZXQgZGF0YSA9IGRhdGUudG9TdHJpbmcoKTtcbiAgICBsZXQgY3V0ID0gZGF0YS5yZXBsYWNlKC8oLiopXFxULiovLCAnJDEnKVxuICAgIGxldCBhZGQgID0gYCR7Y3V0fVQwNTowMDowMC4wMDBaYFxuICAgIGxldCBmZWNoYSA9IGFkZC5yZXBsYWNlKC8oLiopXFxULiovLCAnJDEnKVxuICAgIHJldHVybiAoZmVjaGEpXG4gIH1cblxuICBkYXRlREIgKGRhdGUpIHtcbiAgICBsZXQgZGF5ID0gdGhpcy52YWxpZGF0ZVR3b0RpZ2l0Rm9ybWF0KGRhdGUuZ2V0RGF0ZSgpLnRvU3RyaW5nKCkpXG4gICAgbGV0IG1vbnRoID0gdGhpcy52YWxpZGF0ZVR3b0RpZ2l0Rm9ybWF0KChkYXRlLmdldE1vbnRoKCkrMSkudG9TdHJpbmcoKSlcbiAgICByZXR1cm4gYCR7ZGF0ZS5nZXRGdWxsWWVhcigpfS0ke21vbnRofS0ke2RheX1gXG4gIH1cblxuICBkYXRlV2l0aFRpbWUoZGF0ZTpzdHJpbmcpOnN0cmluZ3tcbiAgICBpZighZGF0ZSkgcmV0dXJuIFwiXCJcbiAgICB2YXIgdmFsdWUgPSBkYXRlLnNwbGl0KFwiVFwiKVxuICAgIHJldHVybiAgdmFsdWVbMF0gKyBcIiBcIiArIHZhbHVlWzFdLnNwbGl0KFwiLlwiKVswXVxuICB9XG5cbiAgYXJlT2JqZWN0c0VxdWFsKG9iajE6IGFueSwgb2JqMjogYW55KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KG9iajEpID09PSBKU09OLnN0cmluZ2lmeShvYmoyKTtcbiAgfVxuXG4gIHJlbW92ZUR1cGxpY2F0ZU9iamVjdHMob3JpZ2luYWxBcnJheTogYW55W10pOiBhbnlbXSB7XG4gICAgY29uc3QgdW5pcXVlQXJyYXk6IGFueVtdID0gW107XG4gICAgb3JpZ2luYWxBcnJheS5mb3JFYWNoKChvYmopID0+IHtcbiAgICAgIGlmICghdW5pcXVlQXJyYXkuc29tZSgodW5pcXVlT2JqKSA9PiB0aGlzLmFyZU9iamVjdHNFcXVhbChvYmosIHVuaXF1ZU9iaikpKSB7XG4gICAgICAgIHVuaXF1ZUFycmF5LnB1c2gob2JqKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiB1bmlxdWVBcnJheTtcbiAgfVxuXG4gIHByaXZhdGUgdmFsaWRhdGVUd29EaWdpdEZvcm1hdChudW1iZXI6IHN0cmluZyk6c3RyaW5ne1xuICAgIGlmKG51bWJlci5sZW5ndGggPT0gMSkgbnVtYmVyID0gXCIwXCIgKyBudW1iZXJcbiAgICByZXR1cm4gbnVtYmVyXG4gIH1cblxufVxuIl19