@adins/ucsearch 2.9.19 → 2.9.21

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.
@@ -19,3 +19,24 @@ export declare class AdInsConstant {
19
19
  static JoinTypeInner: string;
20
20
  static JoinTypeLeft: string;
21
21
  }
22
+ export declare const MIME_TYPES: {
23
+ readonly csv: "text/csv;charset=UTF-8";
24
+ readonly excel: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8";
25
+ readonly json: "text/json;charset=UTF-8";
26
+ };
27
+ export declare const EXPORT_DATA_TYPES: {
28
+ readonly csv: "csv";
29
+ readonly excel: "excel";
30
+ readonly json: "json";
31
+ };
32
+ export declare const EXTENSION_TYPE: {
33
+ readonly csv: ".csv";
34
+ readonly excel: ".xlsx";
35
+ readonly json: ".json";
36
+ };
37
+ export declare const ALLOWED_MIME_TYPES: readonly ["text/csv;charset=UTF-8", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8", "text/json;charset=UTF-8"];
38
+ export declare const ALLOWED_EXPORT_DATA_TYPES: readonly ["csv", "excel", "json"];
39
+ export declare const ALLOWED_EXTENSION_TYPE: readonly [".csv", ".xlsx", ".json"];
40
+ export declare type FileMimeType = typeof ALLOWED_MIME_TYPES[number];
41
+ export declare type FileExportDataType = typeof ALLOWED_EXPORT_DATA_TYPES[number];
42
+ export declare type FileExtensionType = typeof ALLOWED_EXTENSION_TYPE[number];
@@ -0,0 +1,12 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class ExportFileService {
3
+ exportFileAsExcel(json: any[], fileName: string): void;
4
+ exportFileAsJson(json: any[], fileName: string): void;
5
+ exportFileAsCsv(json: any[], fileName: string): void;
6
+ private genExcelBuffer;
7
+ private genJsonBuffer;
8
+ private genCsvBuffer;
9
+ private saveAsFile;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<ExportFileService, never>;
11
+ static ɵprov: i0.ɵɵInjectableDeclaration<ExportFileService>;
12
+ }
@@ -6,21 +6,23 @@ import { DatePipe } from '@angular/common';
6
6
  import { InputSearchObj } from './model/input-search-obj.model';
7
7
  import { CriteriaObj } from './model/criteria-obj.model';
8
8
  import { RequestCriteriaObj } from './model/request-criteria-obj.model';
9
- import { ExcelService } from './services/excel-service/excel-service';
10
9
  import { ToastrService } from 'ngx-toastr';
11
10
  import { KeyValueReportObj } from './model/key-value-report.model';
12
11
  import { CookieService } from 'ngx-cookie';
13
12
  import { KeyValueUCSearchObj, ListKeyValueMonth } from './model/key-value-uc-search.model';
13
+ import { ExportFileService } from './services/export-file.service';
14
+ import { ActivatedRoute } from '@angular/router';
14
15
  import * as i0 from "@angular/core";
15
16
  export declare class UCSearchComponent implements OnInit {
16
17
  private http;
17
- private excelService;
18
18
  private _renderer2;
19
19
  private _document;
20
20
  toastr: ToastrService;
21
21
  private cookieService;
22
22
  private datePipe;
23
23
  private elemRef;
24
+ private exportFileService;
25
+ private route;
24
26
  set content(content: NgForm);
25
27
  myForm: ElementRef;
26
28
  searchInput: InputSearchObj;
@@ -56,10 +58,12 @@ export declare class UCSearchComponent implements OnInit {
56
58
  apiUrl: string;
57
59
  arrCrit: any;
58
60
  searchForm: NgForm;
59
- constructor(http: HttpClient, excelService: ExcelService, _renderer2: Renderer2, _document: any, toastr: ToastrService, cookieService: CookieService, datePipe: DatePipe, elemRef: ElementRef);
61
+ queryParam: Record<string, string>;
62
+ constructor(http: HttpClient, _renderer2: Renderer2, _document: any, toastr: ToastrService, cookieService: CookieService, datePipe: DatePipe, elemRef: ElementRef, exportFileService: ExportFileService, route: ActivatedRoute);
60
63
  changeState(): void;
61
64
  ngOnInit(): Promise<void>;
62
65
  initiateForm(): Promise<void>;
66
+ private autofill;
63
67
  SetRoleOfficeCodes(i: number): void;
64
68
  setDefaultValueMonth(value: any): number;
65
69
  setMonthDDL(month: any): KeyValueUCSearchObj[];
@@ -67,16 +71,17 @@ export declare class UCSearchComponent implements OnInit {
67
71
  setYearDDL(year: any): KeyValueUCSearchObj[];
68
72
  getJSON(url: string): Observable<any>;
69
73
  postJSON(url: string, criteria?: any): Observable<any>;
70
- searchClick(IsExportExcel?: boolean): void;
74
+ searchClick(IsExportExcel?: boolean, ExtFile?: string): void;
71
75
  reset(): Promise<void>;
72
- search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit?: CriteriaObj[], IsExportExcel?: boolean): Promise<void>;
76
+ search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit?: CriteriaObj[], IsExportExcel?: boolean, extFile?: string): Promise<void>;
73
77
  checkValueGteLte(component: any): boolean;
74
78
  mapDataFile(bodyListData: any, bodyDataArr: any, headerListData: any): any[];
79
+ private checkNeedDataToExport;
75
80
  GenerateReport(enjiForm: NgForm): void;
76
81
  lessThanFour(): boolean;
77
82
  resolveObject(obj: any, url: string, crit?: RequestCriteriaObj): void;
78
83
  transformToDecimal(element: any): void;
79
- exportAsXLSX(): void;
84
+ exportAsFile(extFile: string): void;
80
85
  onChangeEvent(optValue: any, afFilter: any): void;
81
86
  SetProcessKey(idx: number, wfKeyFilter: string): void;
82
87
  switchCase(condList: any): boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@adins/ucsearch",
3
- "version": "2.9.19",
3
+ "version": "2.9.21",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^13.1.2",
6
6
  "@angular/core": "^13.1.2"
@@ -1,29 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import * as FileSaver from 'file-saver';
3
- import * as XLSX from 'xlsx';
4
- import * as i0 from "@angular/core";
5
- const EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';
6
- const EXCEL_EXTENSION = '.xlsx';
7
- export class ExcelService {
8
- constructor() { }
9
- exportAsExcelFile(json, excelFileName) {
10
- const worksheet = XLSX.utils.json_to_sheet(json);
11
- console.log('worksheet', worksheet);
12
- const workbook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };
13
- const excelBuffer = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });
14
- //const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'buffer' });
15
- this.saveAsExcelFile(excelBuffer, excelFileName);
16
- }
17
- saveAsExcelFile(buffer, fileName) {
18
- const data = new Blob([buffer], {
19
- type: EXCEL_TYPE
20
- });
21
- FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);
22
- }
23
- }
24
- /** @nocollapse */ /** @nocollapse */ ExcelService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: ExcelService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
25
- /** @nocollapse */ /** @nocollapse */ ExcelService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: ExcelService });
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: ExcelService, decorators: [{
27
- type: Injectable
28
- }], ctorParameters: function () { return []; } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhjZWwtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Vjc2VhcmNoL3NyYy9saWIvc2VydmljZXMvZXhjZWwtc2VydmljZS9leGNlbC1zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxLQUFLLFNBQVMsTUFBTSxZQUFZLENBQUM7QUFDeEMsT0FBTyxLQUFLLElBQUksTUFBTSxNQUFNLENBQUM7O0FBRTdCLE1BQU0sVUFBVSxHQUFHLGlGQUFpRixDQUFDO0FBQ3JHLE1BQU0sZUFBZSxHQUFHLE9BQU8sQ0FBQztBQUdoQyxNQUFNLE9BQU8sWUFBWTtJQUV2QixnQkFBZ0IsQ0FBQztJQUVWLGlCQUFpQixDQUFDLElBQVcsRUFBRSxhQUFxQjtRQUV6RCxNQUFNLFNBQVMsR0FBbUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUMsU0FBUyxDQUFDLENBQUM7UUFDbkMsTUFBTSxRQUFRLEdBQWtCLEVBQUUsTUFBTSxFQUFFLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDeEYsTUFBTSxXQUFXLEdBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ25GLHNGQUFzRjtRQUN0RixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRU8sZUFBZSxDQUFDLE1BQVcsRUFBRSxRQUFnQjtRQUNuRCxNQUFNLElBQUksR0FBUyxJQUFJLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3BDLElBQUksRUFBRSxVQUFVO1NBQ2pCLENBQUMsQ0FBQztRQUNILFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLFFBQVEsR0FBRyxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxlQUFlLENBQUMsQ0FBQztJQUN6RixDQUFDOzsrSUFuQlUsWUFBWTttSkFBWixZQUFZOzJGQUFaLFlBQVk7a0JBRHhCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCAqIGFzIEZpbGVTYXZlciBmcm9tICdmaWxlLXNhdmVyJztcclxuaW1wb3J0ICogYXMgWExTWCBmcm9tICd4bHN4JztcclxuXHJcbmNvbnN0IEVYQ0VMX1RZUEUgPSAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LnNwcmVhZHNoZWV0bWwuc2hlZXQ7Y2hhcnNldD1VVEYtOCc7XHJcbmNvbnN0IEVYQ0VMX0VYVEVOU0lPTiA9ICcueGxzeCc7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBFeGNlbFNlcnZpY2Uge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBwdWJsaWMgZXhwb3J0QXNFeGNlbEZpbGUoanNvbjogYW55W10sIGV4Y2VsRmlsZU5hbWU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgXHJcbiAgICBjb25zdCB3b3Jrc2hlZXQ6IFhMU1guV29ya1NoZWV0ID0gWExTWC51dGlscy5qc29uX3RvX3NoZWV0KGpzb24pO1xyXG4gICAgY29uc29sZS5sb2coJ3dvcmtzaGVldCcsd29ya3NoZWV0KTtcclxuICAgIGNvbnN0IHdvcmtib29rOiBYTFNYLldvcmtCb29rID0geyBTaGVldHM6IHsgJ2RhdGEnOiB3b3Jrc2hlZXQgfSwgU2hlZXROYW1lczogWydkYXRhJ10gfTtcclxuICAgIGNvbnN0IGV4Y2VsQnVmZmVyOiBhbnkgPSBYTFNYLndyaXRlKHdvcmtib29rLCB7IGJvb2tUeXBlOiAneGxzeCcsIHR5cGU6ICdhcnJheScgfSk7XHJcbiAgICAvL2NvbnN0IGV4Y2VsQnVmZmVyOiBhbnkgPSBYTFNYLndyaXRlKHdvcmtib29rLCB7IGJvb2tUeXBlOiAneGxzeCcsIHR5cGU6ICdidWZmZXInIH0pO1xyXG4gICAgdGhpcy5zYXZlQXNFeGNlbEZpbGUoZXhjZWxCdWZmZXIsIGV4Y2VsRmlsZU5hbWUpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzYXZlQXNFeGNlbEZpbGUoYnVmZmVyOiBhbnksIGZpbGVOYW1lOiBzdHJpbmcpOiB2b2lkIHtcclxuICAgIGNvbnN0IGRhdGE6IEJsb2IgPSBuZXcgQmxvYihbYnVmZmVyXSwge1xyXG4gICAgICB0eXBlOiBFWENFTF9UWVBFXHJcbiAgICB9KTtcclxuICAgIEZpbGVTYXZlci5zYXZlQXMoZGF0YSwgZmlsZU5hbWUgKyAnX2V4cG9ydF8nICsgbmV3IERhdGUoKS5nZXRUaW1lKCkgKyBFWENFTF9FWFRFTlNJT04pO1xyXG4gIH1cclxuXHJcbn0iXX0=
@@ -1,8 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- export declare class ExcelService {
3
- constructor();
4
- exportAsExcelFile(json: any[], excelFileName: string): void;
5
- private saveAsExcelFile;
6
- static ɵfac: i0.ɵɵFactoryDeclaration<ExcelService, never>;
7
- static ɵprov: i0.ɵɵInjectableDeclaration<ExcelService>;
8
- }