@adins/ucsearch 2.0.23 → 2.0.25
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.
- package/README.md +14 -3
- package/bundles/ucsearch.umd.js +28 -22
- package/bundles/ucsearch.umd.js.map +1 -1
- package/bundles/ucsearch.umd.min.js +1 -1
- package/bundles/ucsearch.umd.min.js.map +1 -1
- package/esm2015/lib/model/CriteriaObj.model.js +28 -0
- package/esm2015/lib/model/InputSearchObj.Model.js +47 -0
- package/esm2015/lib/model/RequestCriteriaObj.model.js +1 -1
- package/esm2015/lib/ucsearch.component.js +10 -18
- package/esm5/lib/model/CriteriaObj.model.js +30 -0
- package/esm5/lib/model/InputSearchObj.Model.js +51 -0
- package/esm5/lib/model/RequestCriteriaObj.model.js +1 -1
- package/esm5/lib/ucsearch.component.js +11 -30
- package/fesm2015/ucsearch.js +24 -8
- package/fesm2015/ucsearch.js.map +1 -1
- package/fesm5/ucsearch.js +26 -20
- package/fesm5/ucsearch.js.map +1 -1
- package/lib/model/InputSearchObj.Model.d.ts +17 -0
- package/lib/model/RequestCriteriaObj.model.d.ts +1 -1
- package/lib/ucsearch.component.d.ts +3 -6
- package/package.json +1 -1
- package/ucsearch.metadata.json +1 -1
- package/esm2015/lib/model/CriteriaObj.Model.js +0 -28
- package/esm5/lib/model/CriteriaObj.Model.js +0 -30
- /package/lib/model/{CriteriaObj.Model.d.ts → CriteriaObj.model.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -3,6 +3,13 @@
|
|
|
3
3
|
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 7.2.0.
|
|
4
4
|
|
|
5
5
|
## Version
|
|
6
|
+
Version 2.0.25
|
|
7
|
+
1. fix onChangeEvent baca fullpath
|
|
8
|
+
2.
|
|
9
|
+
|
|
10
|
+
Version 2.0.24
|
|
11
|
+
1. fix onChangeEvent baca fullpath
|
|
12
|
+
|
|
6
13
|
Version 2.0.23
|
|
7
14
|
1. fix logic date
|
|
8
15
|
|
|
@@ -116,7 +123,7 @@ import this module :
|
|
|
116
123
|
lib-ucsearch
|
|
117
124
|
|
|
118
125
|
## Input
|
|
119
|
-
1. searchInput
|
|
126
|
+
1. searchInput : InputSearchObj (object) *mandatory
|
|
120
127
|
|
|
121
128
|
## Output
|
|
122
129
|
1. result : Emitting event after search, return resultData of search paging
|
|
@@ -124,8 +131,8 @@ lib-ucsearch
|
|
|
124
131
|
## Object property & JSON property
|
|
125
132
|
InputSearchObj :
|
|
126
133
|
- _url : search.json
|
|
127
|
-
- title : title for section paging // *optional, if using same json for multiple component
|
|
128
134
|
- enviromentUrl : environment path (foundation, setting, vendor)
|
|
135
|
+
- title : title for section paging // *optional, if using same json for multiple component
|
|
129
136
|
- apiQryPaging : search paging API path
|
|
130
137
|
- ddlEnvironments : [
|
|
131
138
|
{
|
|
@@ -137,6 +144,7 @@ InputSearchObj :
|
|
|
137
144
|
environment: environment.FoundationR3Url
|
|
138
145
|
}
|
|
139
146
|
]
|
|
147
|
+
- whereValue : list {"code",10,[1,2,3]} *optional // list string/any for value in whereQuery
|
|
140
148
|
|
|
141
149
|
search.json :
|
|
142
150
|
``` javascript
|
|
@@ -226,7 +234,10 @@ search.json :
|
|
|
226
234
|
],
|
|
227
235
|
"querystring": { // query data by sql
|
|
228
236
|
"select": "", // ex: "SELECT APP_ID AS appId, IS_ACTIVE AS isActive" *must use alias, field to select first must be the first row of grid
|
|
229
|
-
"from": "" // ex: "FROM dbo.APP WITH(NOLOCK)" *don't forget WITH(NOLOCK)
|
|
237
|
+
"from": "", // ex: "FROM dbo.APP WITH(NOLOCK)" *don't forget WITH(NOLOCK), INNER JOIN, DBO.
|
|
238
|
+
"where": "", // ex: "WHERE IS_ACTIVE = 1"
|
|
239
|
+
"where": "", // where when using whereValue, ex: "WHERE IS_ACTIVE = {0}" *must use whereValue
|
|
240
|
+
"groupby": "", // ex: "GROUP BY ....."
|
|
230
241
|
},
|
|
231
242
|
"orderby": {
|
|
232
243
|
"key": "A.APP_ID", // sort by name
|
package/bundles/ucsearch.umd.js
CHANGED
|
@@ -22,6 +22,24 @@
|
|
|
22
22
|
return UCSearchService;
|
|
23
23
|
}());
|
|
24
24
|
|
|
25
|
+
/**
|
|
26
|
+
* @fileoverview added by tsickle
|
|
27
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
28
|
+
*/
|
|
29
|
+
var InputSearchObj = /** @class */ (function () {
|
|
30
|
+
function InputSearchObj() {
|
|
31
|
+
this._url = "";
|
|
32
|
+
this.enviromentUrl = "";
|
|
33
|
+
this.title = "";
|
|
34
|
+
this.apiQryPaging = "";
|
|
35
|
+
this.arrCritObj = null;
|
|
36
|
+
this.addCritInput = new Array();
|
|
37
|
+
this.ddlEnvironments = new Array();
|
|
38
|
+
this.whereValue = new Array();
|
|
39
|
+
}
|
|
40
|
+
return InputSearchObj;
|
|
41
|
+
}());
|
|
42
|
+
|
|
25
43
|
/**
|
|
26
44
|
* @fileoverview added by tsickle
|
|
27
45
|
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
@@ -148,39 +166,23 @@
|
|
|
148
166
|
this.excelService = excelService;
|
|
149
167
|
this._renderer2 = _renderer2;
|
|
150
168
|
this._document = _document;
|
|
169
|
+
this.searchInput = new InputSearchObj();
|
|
151
170
|
this.result = new i0.EventEmitter();
|
|
152
171
|
this.pageSize = 10;
|
|
153
172
|
this.pageNow = 1;
|
|
154
173
|
this.isDataLoaded = false;
|
|
155
174
|
this.isHidden = false;
|
|
156
175
|
this.currentState = 'initial';
|
|
157
|
-
this.payLoad = '';
|
|
158
176
|
this.countForm = 0;
|
|
159
177
|
this.formattedAmount = '';
|
|
160
178
|
this.amount = 0;
|
|
161
179
|
}
|
|
162
|
-
// hide(obj:any){
|
|
163
|
-
// var target =event.srcElement;
|
|
164
|
-
// // var idAttr = target.attributes.id;
|
|
165
|
-
// // var value = idAttr.nodeValue;
|
|
166
|
-
// }
|
|
167
|
-
// hide(obj:any){
|
|
168
|
-
// var target =event.srcElement;
|
|
169
|
-
// // var idAttr = target.attributes.id;
|
|
170
|
-
// // var value = idAttr.nodeValue;
|
|
171
|
-
// }
|
|
172
180
|
/**
|
|
173
181
|
* @return {?}
|
|
174
182
|
*/
|
|
175
|
-
UCSearchComponent.prototype.changeState =
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
// // var idAttr = target.attributes.id;
|
|
179
|
-
// // var value = idAttr.nodeValue;
|
|
180
|
-
// }
|
|
181
|
-
/**
|
|
182
|
-
* @return {?}
|
|
183
|
-
*/
|
|
183
|
+
UCSearchComponent.prototype.changeState = /**
|
|
184
|
+
* @return {?}
|
|
185
|
+
*/
|
|
184
186
|
function () {
|
|
185
187
|
this.currentState = this.currentState === 'initial' ? 'final' : 'initial';
|
|
186
188
|
this.isHidden = this.isHidden === false ? true : false;
|
|
@@ -192,6 +194,7 @@
|
|
|
192
194
|
* @return {?}
|
|
193
195
|
*/
|
|
194
196
|
function () {
|
|
197
|
+
console.log("ucsearch");
|
|
195
198
|
this.apiUrl = this.searchInput.enviromentUrl + this.searchInput.apiQryPaging;
|
|
196
199
|
this.arrCrit = this.searchInput.arrCritObj;
|
|
197
200
|
/** @type {?} */
|
|
@@ -212,7 +215,6 @@
|
|
|
212
215
|
* @param {?} data
|
|
213
216
|
* @return {?}
|
|
214
217
|
*/function (data) {
|
|
215
|
-
console.log(data);
|
|
216
218
|
_this.configuration = data;
|
|
217
219
|
_this.exportData = data.exportExcel;
|
|
218
220
|
_this.countForm = data.component.length;
|
|
@@ -377,6 +379,10 @@
|
|
|
377
379
|
var arrCrit = new Array();
|
|
378
380
|
/** @type {?} */
|
|
379
381
|
var IsQueryIn = false;
|
|
382
|
+
// Inject whereQuery for where criteria
|
|
383
|
+
if (this.searchInput.whereValue.length != 0) {
|
|
384
|
+
this.configuration.querystring.whereQuery = this.searchInput.whereValue;
|
|
385
|
+
}
|
|
380
386
|
request.pageNo = pageNo;
|
|
381
387
|
request.rowPerPage = rowPerPage;
|
|
382
388
|
request.orderBy = orderBy;
|
|
@@ -612,7 +618,7 @@
|
|
|
612
618
|
else {
|
|
613
619
|
jsonComp[j].fullpath = jsonComp[j].url;
|
|
614
620
|
}
|
|
615
|
-
this.resolveObject(jsonComp[j], jsonComp[j].
|
|
621
|
+
this.resolveObject(jsonComp[j], jsonComp[j].fullpath, request);
|
|
616
622
|
}
|
|
617
623
|
}
|
|
618
624
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ucsearch.umd.js.map","sources":["ng://ucsearch/lib/ucsearch.service.ts","ng://ucsearch/lib/model/CriteriaObj.Model.ts","ng://ucsearch/lib/model/RequestCriteriaObj.model.ts","ng://ucsearch/lib/model/AdInstConstant.ts","ng://ucsearch/lib/services/excel-service/excel-service.ts","ng://ucsearch/lib/ucsearch.component.ts","ng://ucsearch/lib/ucsearch.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UCSearchService {\r\n\r\n constructor() { }\r\n}\r\n","export class CriteriaObj{\r\n propName:string;\r\n restriction:string;\r\n value:string;\r\n low:number;\r\n high:number;\r\n DataType:string;\r\n listValue : Array<any>;\r\n\r\n constructor()\r\n {\r\n this.low=0;\r\n this.high=0;\r\n this.DataType='Text';\r\n }\r\n\r\n}","import { CriteriaObj } from \"../model/CriteriaObj.model\";\r\n\r\nexport class RequestCriteriaObj{\r\n includeCount:boolean;\r\n includeData:boolean;\r\n pageNo:number;\r\n rowPerPage:number;\r\n orderBy:any;\r\n criteria:CriteriaObj[];\r\n isLoading : boolean;\r\n queryString: any;\r\n rowVersion: any;\r\n\r\n constructor()\r\n {\r\n this.includeCount=true;\r\n this.includeData=true;\r\n this.isLoading = true;\r\n this.queryString = '';\r\n this.rowVersion = '';\r\n }\r\n}","import { formatDate } from \"@angular/common\";\r\n\r\nexport class AdInsConstant {\r\n public static RestrictionBetween = \"Between\"\r\n public static RestrictionLike = \"Like\";\r\n public static RestrictionEq = \"Eq\";\r\n public static RestrictionNeq = \"NEQ\";\r\n public static RestrictionGt = \"GT\";\r\n public static RestrictionGte = \"GTE\";\r\n public static RestrictionLt = \"LT\";\r\n public static RestrictionLte = \"LTE\";\r\n public static RestrictionIn = \"IN\";\r\n public static RestrictionNotIn = \"NotIn\";\r\n public static RestrictionOr = \"Or\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionOrNeq = \"OrNeq\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionIsNull = \"isnull\";\r\n public static RestrictionIsNotNull = \"isnotnull\";\r\n public static RestrictionGTE = \"GTE\";\r\n public static RestrictionLTE = \"LTE\";\r\n public static showData = \"10,50,100\";\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport * as FileSaver from 'file-saver';\r\nimport * as XLSX from 'xlsx';\r\n\r\nconst EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';\r\nconst EXCEL_EXTENSION = '.xlsx';\r\n\r\n@Injectable()\r\nexport class ExcelService {\r\n\r\n constructor() { }\r\n\r\n public exportAsExcelFile(json: any[], excelFileName: string): void {\r\n \r\n const worksheet: XLSX.WorkSheet = XLSX.utils.json_to_sheet(json);\r\n console.log('worksheet',worksheet);\r\n const workbook: XLSX.WorkBook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };\r\n const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });\r\n //const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'buffer' });\r\n this.saveAsExcelFile(excelBuffer, excelFileName);\r\n }\r\n\r\n private saveAsExcelFile(buffer: any, fileName: string): void {\r\n const data: Blob = new Blob([buffer], {\r\n type: EXCEL_TYPE\r\n });\r\n FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);\r\n }\r\n\r\n}","import { Component, OnInit, Input, ViewChild, ElementRef, Inject, Renderer2, EventEmitter, Output, ViewEncapsulation } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { formatDate } from '@angular/common';\r\nimport { CriteriaObj } from './model/CriteriaObj.Model';\r\nimport { RequestCriteriaObj } from './model/RequestCriteriaObj.model';\r\nimport { AdInsConstant } from './model/AdInstConstant';\r\nimport { DOCUMENT } from '@angular/platform-browser';\r\nimport { ExcelService } from './services/excel-service/excel-service';\r\nimport { trigger, transition, style, animate, state } from '@angular/animations';\r\n\r\n@Component({\r\n selector: 'lib-UCSearch',\r\n templateUrl: './ucsearch.component.html',\r\n styles: [],\r\n providers: [ExcelService],\r\n animations: [\r\n trigger('changeDivSize', [\r\n state('initial', style({\r\n height: '*',\r\n opacity: '1',\r\n })),\r\n state('final', style({\r\n height: '0px',\r\n opacity: '0',\r\n overflow: 'hidden',\r\n })),\r\n transition('initial=>final', animate('300ms')),\r\n transition('final=>initial', animate('300ms'))\r\n ]),\r\n ]\r\n})\r\nexport class UCSearchComponent implements OnInit {\r\n\r\n @ViewChild('formIdSearch') myForm: ElementRef;\r\n @Input() searchInput: any;\r\n @Output() result: EventEmitter<any> = new EventEmitter();\r\n pageSize: any = 10;\r\n pageNow: any = 1;\r\n tempUrl: string;\r\n server: any;\r\n configuration: any;\r\n itemUrl: any;\r\n exportData: any;\r\n ExcelData: any;\r\n isDataLoaded: boolean = false;\r\n isHidden: boolean = false;\r\n\r\n currentState = 'initial';\r\n\r\n form: FormGroup;\r\n payLoad = '';\r\n countForm = 0;\r\n formattedAmount = '';\r\n amount = 0;\r\n apiUrl: string;\r\n arrCrit: any;\r\n constructor(private http: HttpClient, private excelService: ExcelService, private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {\r\n }\r\n // hide(obj:any){\r\n // var target =event.srcElement;\r\n // // var idAttr = target.attributes.id;\r\n // // var value = idAttr.nodeValue;\r\n // }\r\n\r\n changeState() {\r\n this.currentState = this.currentState === 'initial' ? 'final' : 'initial';\r\n this.isHidden = this.isHidden === false ? true : false;\r\n }\r\n\r\n ngOnInit() {\r\n this.apiUrl = this.searchInput.enviromentUrl + this.searchInput.apiQryPaging;\r\n this.arrCrit = this.searchInput.arrCritObj;\r\n let js = this._renderer2.createElement('script');\r\n js.text = `\r\n $(document).ready(function(){\r\n $(\"#flip\").click(function(){\r\n $(\"#panel\").slideToggle(\"slow\");\r\n });\r\n });\r\n `;\r\n this._renderer2.appendChild(this._document.body, js);\r\n this.initiateForm();\r\n }\r\n\r\n initiateForm() {\r\n this.getJSON(this.searchInput._url).subscribe(data => {\r\n console.log(data);\r\n this.configuration = data;\r\n this.exportData = data.exportExcel;\r\n this.countForm = data.component.length;\r\n this.isDataLoaded = true;\r\n\r\n if (this.searchInput.title != undefined && this.searchInput.title != \"\") {\r\n this.configuration.title = this.searchInput.title;\r\n }\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n //ini kalau datanya di load dari URL\r\n if (data.component[i].isFromURL == true) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n var criteriaObject = new CriteriaObj();\r\n criteriaObject.DataType = \"text\";\r\n criteriaObject.propName = data.component[i].criteriaPropName;\r\n criteriaObject.value = data.component[i].criteriaPropValue;\r\n criteriaObject.restriction = \"eq\";\r\n arrayCrit.push(criteriaObject);\r\n request.criteria = arrayCrit;\r\n request[data.component[i].criteriaPropName] = data.component[i].criteriaPropValue;\r\n\r\n // Pengecekan penggunaan url atau path\r\n if (data.component[i].path != undefined && data.component[i].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (data.component[i].name == this.searchInput.ddlEnvironments[y].name) {\r\n data.component[i].fullpath = this.searchInput.ddlEnvironments[y].environment + data.component[i].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n //lempar objectnya sekalian sama urlnya, nnti di bind di dalem karena masalah di asyncnya\r\n //biar tiap function ada state2nya sendiri\r\n this.resolveObject(data.component[i], data.component[i].fullpath, request);\r\n }\r\n\r\n if (data.component[i].type == \"numeric\") {\r\n data.component[i].value = parseFloat(data.component[i].value).toLocaleString('en');\r\n }\r\n\r\n //pengecekan tanggal\r\n if (data.component[i].type == \"datepicker\") {\r\n if (data.component[i].value.includes(\"BD\")) {\r\n let llsBD = localStorage.getItem(\"BusinessDateRaw\");\r\n let businessDate = new Date();\r\n if (llsBD != null) {\r\n businessDate = new Date(llsBD);\r\n }\r\n var operator = data.component[i].value.charAt(2);\r\n var dateShow = new Date();\r\n if (operator == \"-\") {\r\n var tempMinus = data.component[i].value.split(\"-\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() - numDay);\r\n }\r\n else if (operator == \"+\") {\r\n var tempMinus = data.component[i].value.split(\"+\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() + numDay);\r\n }\r\n var dateText = formatDate(dateShow, 'yyyy-MM-dd', 'en-US')\r\n data.component[i].value = dateText;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n\r\n public getJSON(url: string): Observable<any> {\r\n return this.http.get(url);\r\n }\r\n\r\n public postJSON(url: string, criteria: any = null): Observable<any> {\r\n return this.http.post(url, criteria);\r\n }\r\n\r\n searchClick() {\r\n let order = null;\r\n if (this.configuration.orderby != null) {\r\n order = {\r\n key: this.configuration.orderby.key,\r\n value: this.configuration.orderby.value\r\n }\r\n }\r\n this.pageNow = 1;\r\n this.search(this.apiUrl, this.pageNow, this.pageSize, order, this.arrCrit);\r\n }\r\n\r\n reset() {\r\n this.initiateForm();\r\n }\r\n\r\n search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit: CriteriaObj[] = new Array()) {\r\n var request = new RequestCriteriaObj();\r\n var arrCrit = new Array();\r\n var IsQueryIn = false;\r\n\r\n request.pageNo = pageNo;\r\n request.rowPerPage = rowPerPage;\r\n request.orderBy = orderBy;\r\n request.queryString = this.configuration.querystring;\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n var critObj = new CriteriaObj();\r\n var component = this.myForm.nativeElement[i];\r\n critObj.DataType = component.getAttribute('data-type');\r\n //Ini khusus kalau dari Drop Down\r\n if (component.getAttribute('query-in') != null && component.getAttribute('query-in') == \"true\") {\r\n IsQueryIn = true;\r\n }\r\n else {\r\n IsQueryIn = false;\r\n }\r\n if (component.value != \"\") {\r\n if (component.nodeName == 'SELECT') {\r\n var ddl = component.options;\r\n var text = ddl[ddl.selectedIndex].value;\r\n if (text != \"All\") {\r\n //Kalau Dari Dropdown udah pasti pake Eq\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n critObj.propName = component.name;\r\n critObj.value = text;\r\n arrCrit.push(critObj);\r\n } else if (text == \"All\" && IsQueryIn == true && component.options.length != 0) {\r\n var ddlList = new Array();\r\n for (let x = 0; x < component.options.length; x++) {\r\n if (x != 0) {\r\n ddlList.push(component.options[x].value);\r\n }\r\n }\r\n critObj.restriction = AdInsConstant.RestrictionIn;\r\n critObj.propName = component.name;\r\n critObj.listValue = ddlList;\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n else {\r\n //Kalau ada Percent maka yang dipake nnti adalah Restrictions Like\r\n critObj.propName = component.name;\r\n critObj.value = component.value;\r\n if (component.value.includes(\"%\")) {\r\n critObj.restriction = AdInsConstant.RestrictionLike;\r\n }\r\n //kalau componentnya Date, restrictionsnya lgsg ambil dari property JSONnya\r\n else if (component.getAttribute('data-restriction') != \"\" && component.getAttribute('data-restriction') != null) {\r\n critObj.restriction = component.getAttribute('data-restriction');\r\n if (component.getAttribute('data-type') == 'numeric') {\r\n component.value = parseFloat(component.value.replace(/,/g, ''));\r\n }\r\n }\r\n else {\r\n critObj.restriction = AdInsConstant.RestrictionEq\r\n }\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n }\r\n\r\n if (addCrit != null && addCrit != undefined) {\r\n if (addCrit.length != 0) {\r\n for (var i = 0; i < addCrit.length; i++) {\r\n arrCrit.push(addCrit[i]);\r\n }\r\n } else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n }\r\n else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n\r\n request.criteria = arrCrit;\r\n this.http.post(apiUrl, request).subscribe((response) => {\r\n var qryPaging = {\r\n response: response,\r\n pageNow: pageNo\r\n }\r\n console.log(qryPaging);\r\n this.result.emit(qryPaging);\r\n return response;\r\n });\r\n }\r\n\r\n lessThanFour(): boolean {\r\n if (this.countForm > 3) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n resolveObject(obj: any, url: string, crit: RequestCriteriaObj = null) {\r\n const val = this.postJSON(url, crit);\r\n val.subscribe(tempData => {\r\n obj.itemsUrl = new Array();\r\n obj.itemsUrl = tempData.ReturnObject;\r\n });\r\n }\r\n\r\n transformAmount(element: any) {\r\n this.formattedAmount = parseFloat(element.target.value).toLocaleString('en');\r\n // to show the formatted amount in the textbox.\r\n element.target.value = this.formattedAmount;\r\n }\r\n\r\n transformToDecimal(element: any) {\r\n element.target.value = parseFloat(element.target.value.toString().replace(/,/g, ''));\r\n }\r\n\r\n exportAsXLSX(): void {\r\n var request = new RequestCriteriaObj();\r\n request.pageNo = 1;\r\n request.rowPerPage = 9999;\r\n request.orderBy = null;\r\n request.criteria = [];\r\n request.queryString = this.configuration.querystring;\r\n\r\n this.http.post(this.apiUrl, request).subscribe(\r\n response => {\r\n this.ExcelData = response[\"Data\"];\r\n this.excelService.exportAsExcelFile(this.ExcelData, 'sample');\r\n },\r\n (error) => {\r\n console.log(error);\r\n });\r\n }\r\n\r\n onChangeEvent(optValue, afFilter) {\r\n var jsonComp = this.configuration.component;\r\n\r\n for (var i = 0; i < afFilter.affectedFilter.length; i++) {\r\n for (var j = 0; j < jsonComp.length; j++) {\r\n if (jsonComp[j].name == afFilter.affectedFilter[i]) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n\r\n if (optValue != \"All\") {\r\n var critObj = new CriteriaObj();\r\n critObj.DataType = afFilter.datatype;\r\n critObj.propName = afFilter.name;\r\n critObj.value = optValue;\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n arrayCrit.push(critObj);\r\n }\r\n request.criteria = arrayCrit;\r\n if (jsonComp[j].path != undefined && jsonComp[j].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (jsonComp[j].name == this.searchInput.ddlEnvironments[y].name) {\r\n jsonComp[j].fullpath = this.searchInput.ddlEnvironments[y].environment + jsonComp[j].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n this.resolveObject(jsonComp[j], jsonComp[j].url, request);\r\n }\r\n }\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { UCSearchComponent } from './ucsearch.component';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@NgModule({\r\n declarations: [UCSearchComponent],\r\n imports: [\r\n CommonModule\r\n ],\r\n exports: [UCSearchComponent]\r\n})\r\nexport class UCSearchModule { }\r\n"],"names":["Injectable","XLSX.utils","XLSX.write","FileSaver.saveAs","http","EventEmitter","formatDate","Component","trigger","state","style","transition","animate","HttpClient","Renderer2","Inject","DOCUMENT","ViewChild","Input","Output","NgModule","CommonModule"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ucsearch.umd.js.map","sources":["ng://ucsearch/lib/ucsearch.service.ts","ng://ucsearch/lib/model/InputSearchObj.Model.ts","ng://ucsearch/lib/model/CriteriaObj.model.ts","ng://ucsearch/lib/model/RequestCriteriaObj.model.ts","ng://ucsearch/lib/model/AdInstConstant.ts","ng://ucsearch/lib/services/excel-service/excel-service.ts","ng://ucsearch/lib/ucsearch.component.ts","ng://ucsearch/lib/ucsearch.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UCSearchService {\r\n\r\n constructor() { }\r\n}\r\n","import { CriteriaObj } from \"./CriteriaObj.model\";\r\n\r\nexport class InputSearchObj {\r\n _url: string;\r\n enviromentUrl: string;\r\n title: string;\r\n apiQryPaging: string;\r\n arrCritObj: any;\r\n addCritInput: Array<CriteriaObj>;\r\n ddlEnvironments: Array<EnviObj>;\r\n whereValue: Array<any>;\r\n constructor() {\r\n this._url = \"\";\r\n this.enviromentUrl = \"\";\r\n this.title = \"\";\r\n this.apiQryPaging = \"\";\r\n this.arrCritObj = null;\r\n this.addCritInput = new Array<CriteriaObj>();\r\n this.ddlEnvironments = new Array<EnviObj>();\r\n this.whereValue = new Array<any>();\r\n }\r\n}\r\n\r\nexport class EnviObj {\r\n name: string;\r\n environment: string;\r\n\r\n constructor() {\r\n this.name = \"\";\r\n this.environment = \"\";\r\n }\r\n}","export class CriteriaObj {\r\n propName: string;\r\n restriction: string;\r\n value: string;\r\n low: number;\r\n high: number;\r\n DataType: string;\r\n listValue: Array<any>;\r\n\r\n constructor() {\r\n this.low = 0;\r\n this.high = 0;\r\n this.DataType = 'Text';\r\n }\r\n\r\n}","import { CriteriaObj } from \"./CriteriaObj.model\";\r\n\r\nexport class RequestCriteriaObj{\r\n includeCount:boolean;\r\n includeData:boolean;\r\n pageNo:number;\r\n rowPerPage:number;\r\n orderBy:any;\r\n criteria:CriteriaObj[];\r\n isLoading : boolean;\r\n queryString: any;\r\n rowVersion: any;\r\n\r\n constructor()\r\n {\r\n this.includeCount=true;\r\n this.includeData=true;\r\n this.isLoading = true;\r\n this.queryString = '';\r\n this.rowVersion = '';\r\n }\r\n}","import { formatDate } from \"@angular/common\";\r\n\r\nexport class AdInsConstant {\r\n public static RestrictionBetween = \"Between\"\r\n public static RestrictionLike = \"Like\";\r\n public static RestrictionEq = \"Eq\";\r\n public static RestrictionNeq = \"NEQ\";\r\n public static RestrictionGt = \"GT\";\r\n public static RestrictionGte = \"GTE\";\r\n public static RestrictionLt = \"LT\";\r\n public static RestrictionLte = \"LTE\";\r\n public static RestrictionIn = \"IN\";\r\n public static RestrictionNotIn = \"NotIn\";\r\n public static RestrictionOr = \"Or\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionOrNeq = \"OrNeq\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionIsNull = \"isnull\";\r\n public static RestrictionIsNotNull = \"isnotnull\";\r\n public static RestrictionGTE = \"GTE\";\r\n public static RestrictionLTE = \"LTE\";\r\n public static showData = \"10,50,100\";\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport * as FileSaver from 'file-saver';\r\nimport * as XLSX from 'xlsx';\r\n\r\nconst EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';\r\nconst EXCEL_EXTENSION = '.xlsx';\r\n\r\n@Injectable()\r\nexport class ExcelService {\r\n\r\n constructor() { }\r\n\r\n public exportAsExcelFile(json: any[], excelFileName: string): void {\r\n \r\n const worksheet: XLSX.WorkSheet = XLSX.utils.json_to_sheet(json);\r\n console.log('worksheet',worksheet);\r\n const workbook: XLSX.WorkBook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };\r\n const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });\r\n //const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'buffer' });\r\n this.saveAsExcelFile(excelBuffer, excelFileName);\r\n }\r\n\r\n private saveAsExcelFile(buffer: any, fileName: string): void {\r\n const data: Blob = new Blob([buffer], {\r\n type: EXCEL_TYPE\r\n });\r\n FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);\r\n }\r\n\r\n}","import { Component, OnInit, Input, ViewChild, ElementRef, Inject, Renderer2, EventEmitter, Output } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { formatDate } from '@angular/common';\r\nimport { InputSearchObj } from './model/InputSearchObj.Model';\r\nimport { CriteriaObj } from './model/CriteriaObj.model';\r\nimport { RequestCriteriaObj } from './model/RequestCriteriaObj.model';\r\nimport { AdInsConstant } from './model/AdInstConstant';\r\nimport { DOCUMENT } from '@angular/platform-browser';\r\nimport { ExcelService } from './services/excel-service/excel-service';\r\nimport { trigger, transition, style, animate, state } from '@angular/animations';\r\n\r\n@Component({\r\n selector: 'lib-UCSearch',\r\n templateUrl: './ucsearch.component.html',\r\n styles: [],\r\n providers: [ExcelService],\r\n animations: [\r\n trigger('changeDivSize', [\r\n state('initial', style({\r\n height: '*',\r\n opacity: '1',\r\n })),\r\n state('final', style({\r\n height: '0px',\r\n opacity: '0',\r\n overflow: 'hidden',\r\n })),\r\n transition('initial=>final', animate('300ms')),\r\n transition('final=>initial', animate('300ms'))\r\n ]),\r\n ]\r\n})\r\nexport class UCSearchComponent implements OnInit {\r\n\r\n @ViewChild('formIdSearch') myForm: ElementRef;\r\n @Input() searchInput: InputSearchObj = new InputSearchObj();\r\n @Output() result: EventEmitter<any> = new EventEmitter();\r\n pageSize: any = 10;\r\n pageNow: any = 1;\r\n configuration: any;\r\n exportData: any;\r\n ExcelData: any;\r\n isDataLoaded: boolean = false;\r\n isHidden: boolean = false;\r\n\r\n currentState = 'initial';\r\n\r\n form: FormGroup;\r\n countForm = 0;\r\n formattedAmount = '';\r\n amount = 0;\r\n apiUrl: string;\r\n arrCrit: any;\r\n constructor(private http: HttpClient, private excelService: ExcelService, private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {\r\n }\r\n\r\n changeState() {\r\n this.currentState = this.currentState === 'initial' ? 'final' : 'initial';\r\n this.isHidden = this.isHidden === false ? true : false;\r\n }\r\n\r\n ngOnInit() {\r\n console.log(\"ucsearch\");\r\n this.apiUrl = this.searchInput.enviromentUrl + this.searchInput.apiQryPaging;\r\n this.arrCrit = this.searchInput.arrCritObj;\r\n let js = this._renderer2.createElement('script');\r\n js.text = `\r\n $(document).ready(function(){\r\n $(\"#flip\").click(function(){\r\n $(\"#panel\").slideToggle(\"slow\");\r\n });\r\n });\r\n `;\r\n this._renderer2.appendChild(this._document.body, js);\r\n this.initiateForm();\r\n }\r\n\r\n initiateForm() {\r\n this.getJSON(this.searchInput._url).subscribe(data => {\r\n this.configuration = data;\r\n this.exportData = data.exportExcel;\r\n this.countForm = data.component.length;\r\n this.isDataLoaded = true;\r\n\r\n if (this.searchInput.title != undefined && this.searchInput.title != \"\") {\r\n this.configuration.title = this.searchInput.title;\r\n }\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n //ini kalau datanya di load dari URL\r\n if (data.component[i].isFromURL == true) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n var criteriaObject = new CriteriaObj();\r\n criteriaObject.DataType = \"text\";\r\n criteriaObject.propName = data.component[i].criteriaPropName;\r\n criteriaObject.value = data.component[i].criteriaPropValue;\r\n criteriaObject.restriction = \"eq\";\r\n arrayCrit.push(criteriaObject);\r\n request.criteria = arrayCrit;\r\n request[data.component[i].criteriaPropName] = data.component[i].criteriaPropValue;\r\n\r\n // Pengecekan penggunaan url atau path\r\n if (data.component[i].path != undefined && data.component[i].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (data.component[i].name == this.searchInput.ddlEnvironments[y].name) {\r\n data.component[i].fullpath = this.searchInput.ddlEnvironments[y].environment + data.component[i].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n //lempar objectnya sekalian sama urlnya, nnti di bind di dalem karena masalah di asyncnya\r\n //biar tiap function ada state2nya sendiri\r\n this.resolveObject(data.component[i], data.component[i].fullpath, request);\r\n }\r\n\r\n if (data.component[i].type == \"numeric\") {\r\n data.component[i].value = parseFloat(data.component[i].value).toLocaleString('en');\r\n }\r\n\r\n //pengecekan tanggal\r\n if (data.component[i].type == \"datepicker\") {\r\n if (data.component[i].value.includes(\"BD\")) {\r\n let llsBD = localStorage.getItem(\"BusinessDateRaw\");\r\n let businessDate = new Date();\r\n if (llsBD != null) {\r\n businessDate = new Date(llsBD);\r\n }\r\n var operator = data.component[i].value.charAt(2);\r\n var dateShow = new Date();\r\n if (operator == \"-\") {\r\n var tempMinus = data.component[i].value.split(\"-\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() - numDay);\r\n }\r\n else if (operator == \"+\") {\r\n var tempMinus = data.component[i].value.split(\"+\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() + numDay);\r\n }\r\n var dateText = formatDate(dateShow, 'yyyy-MM-dd', 'en-US')\r\n data.component[i].value = dateText;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n\r\n public getJSON(url: string): Observable<any> {\r\n return this.http.get(url);\r\n }\r\n\r\n public postJSON(url: string, criteria: any = null): Observable<any> {\r\n return this.http.post(url, criteria);\r\n }\r\n\r\n searchClick() {\r\n let order = null;\r\n if (this.configuration.orderby != null) {\r\n order = {\r\n key: this.configuration.orderby.key,\r\n value: this.configuration.orderby.value\r\n }\r\n }\r\n this.pageNow = 1;\r\n this.search(this.apiUrl, this.pageNow, this.pageSize, order, this.arrCrit);\r\n }\r\n\r\n reset() {\r\n this.initiateForm();\r\n }\r\n\r\n search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit: CriteriaObj[] = new Array()) {\r\n var request = new RequestCriteriaObj();\r\n var arrCrit = new Array();\r\n var IsQueryIn = false;\r\n\r\n // Inject whereQuery for where criteria\r\n if (this.searchInput.whereValue.length != 0) {\r\n this.configuration.querystring.whereQuery = this.searchInput.whereValue;\r\n }\r\n request.pageNo = pageNo;\r\n request.rowPerPage = rowPerPage;\r\n request.orderBy = orderBy;\r\n request.queryString = this.configuration.querystring;\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n var critObj = new CriteriaObj();\r\n var component = this.myForm.nativeElement[i];\r\n critObj.DataType = component.getAttribute('data-type');\r\n //Ini khusus kalau dari Drop Down\r\n if (component.getAttribute('query-in') != null && component.getAttribute('query-in') == \"true\") {\r\n IsQueryIn = true;\r\n }\r\n else {\r\n IsQueryIn = false;\r\n }\r\n if (component.value != \"\") {\r\n if (component.nodeName == 'SELECT') {\r\n var ddl = component.options;\r\n var text = ddl[ddl.selectedIndex].value;\r\n if (text != \"All\") {\r\n //Kalau Dari Dropdown udah pasti pake Eq\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n critObj.propName = component.name;\r\n critObj.value = text;\r\n arrCrit.push(critObj);\r\n } else if (text == \"All\" && IsQueryIn == true && component.options.length != 0) {\r\n var ddlList = new Array();\r\n for (let x = 0; x < component.options.length; x++) {\r\n if (x != 0) {\r\n ddlList.push(component.options[x].value);\r\n }\r\n }\r\n critObj.restriction = AdInsConstant.RestrictionIn;\r\n critObj.propName = component.name;\r\n critObj.listValue = ddlList;\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n else {\r\n //Kalau ada Percent maka yang dipake nnti adalah Restrictions Like\r\n critObj.propName = component.name;\r\n critObj.value = component.value;\r\n if (component.value.includes(\"%\")) {\r\n critObj.restriction = AdInsConstant.RestrictionLike;\r\n }\r\n //kalau componentnya Date, restrictionsnya lgsg ambil dari property JSONnya\r\n else if (component.getAttribute('data-restriction') != \"\" && component.getAttribute('data-restriction') != null) {\r\n critObj.restriction = component.getAttribute('data-restriction');\r\n if (component.getAttribute('data-type') == 'numeric') {\r\n component.value = parseFloat(component.value.replace(/,/g, ''));\r\n }\r\n }\r\n else {\r\n critObj.restriction = AdInsConstant.RestrictionEq\r\n }\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n }\r\n\r\n if (addCrit != null && addCrit != undefined) {\r\n if (addCrit.length != 0) {\r\n for (var i = 0; i < addCrit.length; i++) {\r\n arrCrit.push(addCrit[i]);\r\n }\r\n } else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n }\r\n else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n\r\n request.criteria = arrCrit;\r\n this.http.post(apiUrl, request).subscribe((response) => {\r\n var qryPaging = {\r\n response: response,\r\n pageNow: pageNo\r\n }\r\n console.log(qryPaging);\r\n this.result.emit(qryPaging);\r\n return response;\r\n });\r\n }\r\n\r\n lessThanFour(): boolean {\r\n if (this.countForm > 3) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n resolveObject(obj: any, url: string, crit: RequestCriteriaObj = null) {\r\n const val = this.postJSON(url, crit);\r\n val.subscribe(tempData => {\r\n obj.itemsUrl = new Array();\r\n obj.itemsUrl = tempData.ReturnObject;\r\n });\r\n }\r\n\r\n transformAmount(element: any) {\r\n this.formattedAmount = parseFloat(element.target.value).toLocaleString('en');\r\n // to show the formatted amount in the textbox.\r\n element.target.value = this.formattedAmount;\r\n }\r\n\r\n transformToDecimal(element: any) {\r\n element.target.value = parseFloat(element.target.value.toString().replace(/,/g, ''));\r\n }\r\n\r\n exportAsXLSX(): void {\r\n var request = new RequestCriteriaObj();\r\n request.pageNo = 1;\r\n request.rowPerPage = 9999;\r\n request.orderBy = null;\r\n request.criteria = [];\r\n request.queryString = this.configuration.querystring;\r\n\r\n this.http.post(this.apiUrl, request).subscribe(\r\n response => {\r\n this.ExcelData = response[\"Data\"];\r\n this.excelService.exportAsExcelFile(this.ExcelData, 'sample');\r\n },\r\n (error) => {\r\n console.log(error);\r\n });\r\n }\r\n\r\n onChangeEvent(optValue, afFilter) {\r\n var jsonComp = this.configuration.component;\r\n\r\n for (var i = 0; i < afFilter.affectedFilter.length; i++) {\r\n for (var j = 0; j < jsonComp.length; j++) {\r\n if (jsonComp[j].name == afFilter.affectedFilter[i]) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n\r\n if (optValue != \"All\") {\r\n var critObj = new CriteriaObj();\r\n critObj.DataType = afFilter.datatype;\r\n critObj.propName = afFilter.name;\r\n critObj.value = optValue;\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n arrayCrit.push(critObj);\r\n }\r\n request.criteria = arrayCrit;\r\n if (jsonComp[j].path != undefined && jsonComp[j].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (jsonComp[j].name == this.searchInput.ddlEnvironments[y].name) {\r\n jsonComp[j].fullpath = this.searchInput.ddlEnvironments[y].environment + jsonComp[j].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n this.resolveObject(jsonComp[j], jsonComp[j].fullpath, request);\r\n }\r\n }\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { UCSearchComponent } from './ucsearch.component';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@NgModule({\r\n declarations: [UCSearchComponent],\r\n imports: [\r\n CommonModule\r\n ],\r\n exports: [UCSearchComponent]\r\n})\r\nexport class UCSearchModule { }\r\n"],"names":["Injectable","XLSX.utils","XLSX.write","FileSaver.saveAs","http","EventEmitter","formatDate","Component","trigger","state","style","transition","animate","HttpClient","Renderer2","Inject","DOCUMENT","ViewChild","Input","Output","NgModule","CommonModule"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common/http"),require("@angular/platform-browser"),require("file-saver"),require("xlsx"),require("@angular/animations"),require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ucsearch",["exports","@angular/common/http","@angular/platform-browser","file-saver","xlsx","@angular/animations","@angular/core","@angular/common"],e):e(t.ucsearch={},t.ng.common.http,t.ng.platformBrowser,t.FileSaver,t.XLSX,t.ng.animations,t.ng.core,t.ng.common)}(this,function(t,e,n,r,o,i,a,h){"use strict";var s=(l.decorators=[{type:a.Injectable,args:[{providedIn:"root"}]}],l.ctorParameters=function(){return[]},l.ngInjectableDef=a.defineInjectable({factory:function(){return new l},token:l,providedIn:"root"}),l);function l(){}var v=function q(){this.low=0,this.high=0,this.DataType="Text"},g=function b(){this.includeCount=!0,this.includeData=!0,this.isLoading=!0,this.queryString="",this.rowVersion=""},y=(c.RestrictionBetween="Between",c.RestrictionLike="Like",c.RestrictionEq="Eq",c.RestrictionNeq="NEQ",c.RestrictionGt="GT",c.RestrictionGte="GTE",c.RestrictionLt="LT",c.RestrictionLte="LTE",c.RestrictionIn="IN",c.RestrictionNotIn="NotIn",c.RestrictionOr="Or",c.RestrictionOrNeq="OrNeq",c.RestrictionIsNull="isnull",c.RestrictionIsNotNull="isnotnull",c.RestrictionGTE="GTE",c.RestrictionLTE="LTE",c.showData="10,50,100",c);function c(){}var u=(p.prototype.exportAsExcelFile=function(t,e){var n=o.utils.json_to_sheet(t);console.log("worksheet",n);var r={Sheets:{data:n},SheetNames:["data"]},i=o.write(r,{bookType:"xlsx",type:"array"});this.saveAsExcelFile(i,e)},p.prototype.saveAsExcelFile=function(t,e){var n=new Blob([t],{type:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8"});r.saveAs(n,e+"_export_"+(new Date).getTime()+".xlsx")},p.decorators=[{type:a.Injectable}],p.ctorParameters=function(){return[]},p);function p(){}var d=(m.prototype.changeState=function(){this.currentState="initial"===this.currentState?"final":"initial",this.isHidden=!1===this.isHidden},m.prototype.ngOnInit=function(){this.apiUrl=this.searchInput.enviromentUrl+this.searchInput.apiQryPaging,this.arrCrit=this.searchInput.arrCritObj;var t=this._renderer2.createElement("script");t.text='\n $(document).ready(function(){\n $("#flip").click(function(){\n $("#panel").slideToggle("slow");\n });\n });\n ',this._renderer2.appendChild(this._document.body,t),this.initiateForm()},m.prototype.initiateForm=function(){var m=this;this.getJSON(this.searchInput._url).subscribe(function(t){console.log(t),m.configuration=t,m.exportData=t.exportExcel,m.countForm=t.component.length,m.isDataLoaded=!0,m.searchInput.title!=undefined&&""!=m.searchInput.title&&(m.configuration.title=m.searchInput.title);for(var e=0;e<m.countForm;e++){if(1==t.component[e].isFromURL){var n=new g,r=new Array,i=new v;if(i.DataType="text",i.propName=t.component[e].criteriaPropName,i.value=t.component[e].criteriaPropValue,i.restriction="eq",r.push(i),n.criteria=r,n[t.component[e].criteriaPropName]=t.component[e].criteriaPropValue,t.component[e].path!=undefined&&""!=t.component[e].path)if(m.searchInput.ddlEnvironments!=undefined&&0!=m.searchInput.ddlEnvironments.length){for(var o=0;o<m.searchInput.ddlEnvironments.length;o++)if(t.component[e].name==m.searchInput.ddlEnvironments[o].name){t.component[e].fullpath=m.searchInput.ddlEnvironments[o].environment+t.component[e].path;break}}else t.component[e].fullpath=t.component[e].url;else t.component[e].fullpath=t.component[e].url;m.resolveObject(t.component[e],t.component[e].fullpath,n)}if("numeric"==t.component[e].type&&(t.component[e].value=parseFloat(t.component[e].value).toLocaleString("en")),"datepicker"==t.component[e].type&&t.component[e].value.includes("BD")){var a=localStorage.getItem("BusinessDateRaw"),s=new Date;null!=a&&(s=new Date(a));var l=t.component[e].value.charAt(2),c=new Date;if("-"==l){var u=t.component[e].value.split("-",2),p=parseInt(u[1]);c.setDate(s.getDate()-p)}else"+"==l&&(u=t.component[e].value.split("+",2),p=parseInt(u[1]),c.setDate(s.getDate()+p));var d=h.formatDate(c,"yyyy-MM-dd","en-US");t.component[e].value=d}}})},m.prototype.getJSON=function(t){return this.http.get(t)},m.prototype.postJSON=function(t,e){return void 0===e&&(e=null),this.http.post(t,e)},m.prototype.searchClick=function(){var t=null;null!=this.configuration.orderby&&(t={key:this.configuration.orderby.key,value:this.configuration.orderby.value}),this.pageNow=1,this.search(this.apiUrl,this.pageNow,this.pageSize,t,this.arrCrit)},m.prototype.reset=function(){this.initiateForm()},m.prototype.search=function(t,n,e,r,i){var o=this;void 0===i&&(i=new Array);var a=new g,s=new Array,l=!1;a.pageNo=n,a.rowPerPage=e,a.orderBy=r,a.queryString=this.configuration.querystring;for(var c=0;c<this.countForm;c++){var u=new v,p=this.myForm.nativeElement[c];if(u.DataType=p.getAttribute("data-type"),l=null!=p.getAttribute("query-in")&&"true"==p.getAttribute("query-in"),""!=p.value)if("SELECT"==p.nodeName){var d=p.options,m=d[d.selectedIndex].value;if("All"!=m)u.restriction=y.RestrictionEq,u.propName=p.name,u.value=m,s.push(u);else if("All"==m&&1==l&&0!=p.options.length){for(var h=new Array,f=0;f<p.options.length;f++)0!=f&&h.push(p.options[f].value);u.restriction=y.RestrictionIn,u.propName=p.name,u.listValue=h,s.push(u)}}else u.propName=p.name,u.value=p.value,p.value.includes("%")?u.restriction=y.RestrictionLike:""!=p.getAttribute("data-restriction")&&null!=p.getAttribute("data-restriction")?(u.restriction=p.getAttribute("data-restriction"),"numeric"==p.getAttribute("data-type")&&(p.value=parseFloat(p.value.replace(/,/g,"")))):u.restriction=y.RestrictionEq,s.push(u)}if(null!=i&&i!=undefined){if(0!=i.length)for(c=0;c<i.length;c++)s.push(i[c]);else if(null!=this.searchInput.addCritInput||this.searchInput.addCritInput!=undefined)for(c=0;c<this.searchInput.addCritInput.length;c++)s.push(this.searchInput.addCritInput[c])}else if(null!=this.searchInput.addCritInput||this.searchInput.addCritInput!=undefined)for(c=0;c<this.searchInput.addCritInput.length;c++)s.push(this.searchInput.addCritInput[c]);a.criteria=s,this.http.post(t,a).subscribe(function(t){var e={response:t,pageNow:n};return console.log(e),o.result.emit(e),t})},m.prototype.lessThanFour=function(){return!(3<this.countForm)},m.prototype.resolveObject=function(e,t,n){void 0===n&&(n=null),this.postJSON(t,n).subscribe(function(t){e.itemsUrl=new Array,e.itemsUrl=t.ReturnObject})},m.prototype.transformAmount=function(t){this.formattedAmount=parseFloat(t.target.value).toLocaleString("en"),t.target.value=this.formattedAmount},m.prototype.transformToDecimal=function(t){t.target.value=parseFloat(t.target.value.toString().replace(/,/g,""))},m.prototype.exportAsXLSX=function(){var e=this,t=new g;t.pageNo=1,t.rowPerPage=9999,t.orderBy=null,t.criteria=[],t.queryString=this.configuration.querystring,this.http.post(this.apiUrl,t).subscribe(function(t){e.ExcelData=t.Data,e.excelService.exportAsExcelFile(e.ExcelData,"sample")},function(t){console.log(t)})},m.prototype.onChangeEvent=function(t,e){for(var n=this.configuration.component,r=0;r<e.affectedFilter.length;r++)for(var i=0;i<n.length;i++)if(n[i].name==e.affectedFilter[r]){var o=new g,a=new Array;if("All"!=t){var s=new v;s.DataType=e.datatype,s.propName=e.name,s.value=t,s.restriction=y.RestrictionEq,a.push(s)}if(o.criteria=a,n[i].path!=undefined&&""!=n[i].path)if(this.searchInput.ddlEnvironments!=undefined&&0!=this.searchInput.ddlEnvironments.length){for(var l=0;l<this.searchInput.ddlEnvironments.length;l++)if(n[i].name==this.searchInput.ddlEnvironments[l].name){n[i].fullpath=this.searchInput.ddlEnvironments[l].environment+n[i].path;break}}else n[i].fullpath=n[i].url;else n[i].fullpath=n[i].url;this.resolveObject(n[i],n[i].url,o)}},m.decorators=[{type:a.Component,args:[{selector:"lib-UCSearch",template:'\x3c!-- Basic form layout section start --\x3e\r\n<section id="horizontal-form-layouts">\r\n <div class="row text-left">\r\n <div class="col-md-12">\r\n <div class="card">\r\n <div class="card-body">\r\n <div class="px-3">\r\n <form class="form form-horizontal" id="formSearch" #formIdSearch>\r\n <div class="form-body">\r\n <h4 class="form-section font-weight-bold">\r\n <div (click)="changeState()" class="btn no-padding cursor-pointer flip">\r\n <i class="fa" style="font-size: 15px; margin: 0px 0px 5px -15px;" [ngClass]="isHidden ? \'fa-chevron-right\' : \'fa-chevron-down\'"></i>\r\n </div>\r\n {{configuration?.title}} \r\n </h4>\r\n \x3c!-- Ini Digunakan untuk Generate Dynamic Component --\x3e\r\n \x3c!-- [hidden]="isHidden" --\x3e\r\n <div class="panel-active" [@changeDivSize]=currentState>\r\n <div class="row">\r\n <div class="col-md-6 form-group"\r\n *ngFor="let question of configuration?.component">\r\n <div class="col-md-12">\r\n <div class="row">\r\n <label class="col-md-5 no-padding" for="{{question.id}}"\r\n translate>{{question.label}}</label>\r\n <div class="col-md-7 no-padding">\r\n <div *ngIf="question.type==\'textbox\'">\r\n <input type="text" id="{{question.id}}" class="form-control search-form-control"\r\n name="{{question.name}}" value="{{question.value}}"\r\n attr.data-type="{{question.datatype}}" attr.data-restriction="{{question.restriction}}" >\r\n </div>\r\n <div *ngIf="question.type==\'textarea\'">\r\n <textarea type="text" id="{{question.id}}" class="form-control search-form-control"\r\n name="{{question.name}}" attr.data-type="{{question.datatype}}"\r\n value="{{question.value}}"></textarea>\r\n </div>\r\n <div *ngIf="question.type==\'numeric\'">\r\n <input type="text" id="{{question.id}}" (focus)="transformToDecimal($event)"\r\n (blur)="transformAmount($event)" class="form-control search-form-control"\r\n name="{{question.name}}" value="{{question.value}}"\r\n attr.data-restriction="{{question.restriction}}" attr.data-type="{{question.datatype}}">\r\n </div>\r\n \r\n \x3c!-- End Hardcode Lookup didalem--\x3e\r\n <div *ngIf="question.type==\'datepicker\'">\r\n <input type="date" id="{{question.id}}" class="form-control search-form-control btn-lookup"\r\n name="{{question.name}}" value="{{question.value}}" attr.data-type="{{question.datatype}}"\r\n attr.data-restriction="{{question.restriction}}">\r\n </div>\r\n <div *ngIf="question.type==\'dropdown\'">\r\n \x3c!-- Ini kalau datanya tidak di load dari URL --\x3e\r\n <div *ngIf="!question.isFromURL">\r\n <select name="{{question.name}}"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.items" value="{{item.key}}">\r\n {{item.value}}\r\n </option>\r\n </select>\r\n </div>\r\n \x3c!-- Ini kalau datanya di load dari URL --\x3e\r\n <div *ngIf="question.isFromURL">\r\n <div *ngIf="question.isEvent">\r\n <select name="{{question.name}}" (change)="onChangeEvent($event.target.value, question)"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.itemsUrl" value="{{item.Key}}">\r\n {{item.Value}}\r\n </option>\r\n </select>\r\n </div>\r\n <div *ngIf="!question.isEvent">\r\n <select name="{{question.name}}"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.itemsUrl" value="{{item.Key}}">\r\n {{item.Value}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class="col-md-12 no-padding">\r\n <form>\r\n <div class="form-actions right">\r\n <button *ngIf="exportData == true" type="button" (click)="exportAsXLSX()"\r\n class="btn btn-raised btn-success mr-1" translate>\r\n <i class="fa ft-download"></i> Export Excel\r\n </button>\r\n <button type="button" (click)="reset()" class="btn btn-raised btn-warning mr-1" translate>\r\n <i class="fa fa-times"></i> Reset\r\n </button>\r\n <button type="button" (click)="searchClick()" class="btn btn-raised btn-primary" #UCSearchClick translate>\r\n <i class="fa fa-search"></i> Search\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</section>\r\n<br>\r\n\x3c!-- // Basic form layout section end --\x3e',providers:[u],animations:[i.trigger("changeDivSize",[i.state("initial",i.style({height:"*",opacity:"1"})),i.state("final",i.style({height:"0px",opacity:"0",overflow:"hidden"})),i.transition("initial=>final",i.animate("300ms")),i.transition("final=>initial",i.animate("300ms"))])]}]}],m.ctorParameters=function(){return[{type:e.HttpClient},{type:u},{type:a.Renderer2},{type:undefined,decorators:[{type:a.Inject,args:[n.DOCUMENT]}]}]},m.propDecorators={myForm:[{type:a.ViewChild,args:["formIdSearch"]}],searchInput:[{type:a.Input}],result:[{type:a.Output}]},m);function m(t,e,n,r){this.http=t,this.excelService=e,this._renderer2=n,this._document=r,this.result=new a.EventEmitter,this.pageSize=10,this.pageNow=1,this.isDataLoaded=!1,this.isHidden=!1,this.currentState="initial",this.payLoad="",this.countForm=0,this.formattedAmount="",this.amount=0}var f=(I.decorators=[{type:a.NgModule,args:[{declarations:[d],imports:[h.CommonModule],exports:[d]}]}],I);function I(){}t.UCSearchService=s,t.UCSearchComponent=d,t.UCSearchModule=f,t.ɵa=u,Object.defineProperty(t,"__esModule",{value:!0})});
|
|
1
|
+
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common/http"),require("@angular/platform-browser"),require("file-saver"),require("xlsx"),require("@angular/animations"),require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ucsearch",["exports","@angular/common/http","@angular/platform-browser","file-saver","xlsx","@angular/animations","@angular/core","@angular/common"],e):e(t.ucsearch={},t.ng.common.http,t.ng.platformBrowser,t.FileSaver,t.XLSX,t.ng.animations,t.ng.core,t.ng.common)}(this,function(t,e,n,r,o,i,a,m){"use strict";var s=(l.decorators=[{type:a.Injectable,args:[{providedIn:"root"}]}],l.ctorParameters=function(){return[]},l.ngInjectableDef=a.defineInjectable({factory:function(){return new l},token:l,providedIn:"root"}),l);function l(){}var c=function b(){this._url="",this.enviromentUrl="",this.title="",this.apiQryPaging="",this.arrCritObj=null,this.addCritInput=new Array,this.ddlEnvironments=new Array,this.whereValue=new Array},v=function x(){this.low=0,this.high=0,this.DataType="Text"},g=function w(){this.includeCount=!0,this.includeData=!0,this.isLoading=!0,this.queryString="",this.rowVersion=""},y=(u.RestrictionBetween="Between",u.RestrictionLike="Like",u.RestrictionEq="Eq",u.RestrictionNeq="NEQ",u.RestrictionGt="GT",u.RestrictionGte="GTE",u.RestrictionLt="LT",u.RestrictionLte="LTE",u.RestrictionIn="IN",u.RestrictionNotIn="NotIn",u.RestrictionOr="Or",u.RestrictionOrNeq="OrNeq",u.RestrictionIsNull="isnull",u.RestrictionIsNotNull="isnotnull",u.RestrictionGTE="GTE",u.RestrictionLTE="LTE",u.showData="10,50,100",u);function u(){}var p=(d.prototype.exportAsExcelFile=function(t,e){var n=o.utils.json_to_sheet(t);console.log("worksheet",n);var r={Sheets:{data:n},SheetNames:["data"]},i=o.write(r,{bookType:"xlsx",type:"array"});this.saveAsExcelFile(i,e)},d.prototype.saveAsExcelFile=function(t,e){var n=new Blob([t],{type:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8"});r.saveAs(n,e+"_export_"+(new Date).getTime()+".xlsx")},d.decorators=[{type:a.Injectable}],d.ctorParameters=function(){return[]},d);function d(){}var h=(f.prototype.changeState=function(){this.currentState="initial"===this.currentState?"final":"initial",this.isHidden=!1===this.isHidden},f.prototype.ngOnInit=function(){console.log("ucsearch"),this.apiUrl=this.searchInput.enviromentUrl+this.searchInput.apiQryPaging,this.arrCrit=this.searchInput.arrCritObj;var t=this._renderer2.createElement("script");t.text='\n $(document).ready(function(){\n $("#flip").click(function(){\n $("#panel").slideToggle("slow");\n });\n });\n ',this._renderer2.appendChild(this._document.body,t),this.initiateForm()},f.prototype.initiateForm=function(){var h=this;this.getJSON(this.searchInput._url).subscribe(function(t){h.configuration=t,h.exportData=t.exportExcel,h.countForm=t.component.length,h.isDataLoaded=!0,h.searchInput.title!=undefined&&""!=h.searchInput.title&&(h.configuration.title=h.searchInput.title);for(var e=0;e<h.countForm;e++){if(1==t.component[e].isFromURL){var n=new g,r=new Array,i=new v;if(i.DataType="text",i.propName=t.component[e].criteriaPropName,i.value=t.component[e].criteriaPropValue,i.restriction="eq",r.push(i),n.criteria=r,n[t.component[e].criteriaPropName]=t.component[e].criteriaPropValue,t.component[e].path!=undefined&&""!=t.component[e].path)if(h.searchInput.ddlEnvironments!=undefined&&0!=h.searchInput.ddlEnvironments.length){for(var o=0;o<h.searchInput.ddlEnvironments.length;o++)if(t.component[e].name==h.searchInput.ddlEnvironments[o].name){t.component[e].fullpath=h.searchInput.ddlEnvironments[o].environment+t.component[e].path;break}}else t.component[e].fullpath=t.component[e].url;else t.component[e].fullpath=t.component[e].url;h.resolveObject(t.component[e],t.component[e].fullpath,n)}if("numeric"==t.component[e].type&&(t.component[e].value=parseFloat(t.component[e].value).toLocaleString("en")),"datepicker"==t.component[e].type&&t.component[e].value.includes("BD")){var a=localStorage.getItem("BusinessDateRaw"),s=new Date;null!=a&&(s=new Date(a));var l=t.component[e].value.charAt(2),c=new Date;if("-"==l){var u=t.component[e].value.split("-",2),p=parseInt(u[1]);c.setDate(s.getDate()-p)}else"+"==l&&(u=t.component[e].value.split("+",2),p=parseInt(u[1]),c.setDate(s.getDate()+p));var d=m.formatDate(c,"yyyy-MM-dd","en-US");t.component[e].value=d}}})},f.prototype.getJSON=function(t){return this.http.get(t)},f.prototype.postJSON=function(t,e){return void 0===e&&(e=null),this.http.post(t,e)},f.prototype.searchClick=function(){var t=null;null!=this.configuration.orderby&&(t={key:this.configuration.orderby.key,value:this.configuration.orderby.value}),this.pageNow=1,this.search(this.apiUrl,this.pageNow,this.pageSize,t,this.arrCrit)},f.prototype.reset=function(){this.initiateForm()},f.prototype.search=function(t,n,e,r,i){var o=this;void 0===i&&(i=new Array);var a=new g,s=new Array,l=!1;0!=this.searchInput.whereValue.length&&(this.configuration.querystring.whereQuery=this.searchInput.whereValue),a.pageNo=n,a.rowPerPage=e,a.orderBy=r,a.queryString=this.configuration.querystring;for(var c=0;c<this.countForm;c++){var u=new v,p=this.myForm.nativeElement[c];if(u.DataType=p.getAttribute("data-type"),l=null!=p.getAttribute("query-in")&&"true"==p.getAttribute("query-in"),""!=p.value)if("SELECT"==p.nodeName){var d=p.options,h=d[d.selectedIndex].value;if("All"!=h)u.restriction=y.RestrictionEq,u.propName=p.name,u.value=h,s.push(u);else if("All"==h&&1==l&&0!=p.options.length){for(var m=new Array,f=0;f<p.options.length;f++)0!=f&&m.push(p.options[f].value);u.restriction=y.RestrictionIn,u.propName=p.name,u.listValue=m,s.push(u)}}else u.propName=p.name,u.value=p.value,p.value.includes("%")?u.restriction=y.RestrictionLike:""!=p.getAttribute("data-restriction")&&null!=p.getAttribute("data-restriction")?(u.restriction=p.getAttribute("data-restriction"),"numeric"==p.getAttribute("data-type")&&(p.value=parseFloat(p.value.replace(/,/g,"")))):u.restriction=y.RestrictionEq,s.push(u)}if(null!=i&&i!=undefined){if(0!=i.length)for(c=0;c<i.length;c++)s.push(i[c]);else if(null!=this.searchInput.addCritInput||this.searchInput.addCritInput!=undefined)for(c=0;c<this.searchInput.addCritInput.length;c++)s.push(this.searchInput.addCritInput[c])}else if(null!=this.searchInput.addCritInput||this.searchInput.addCritInput!=undefined)for(c=0;c<this.searchInput.addCritInput.length;c++)s.push(this.searchInput.addCritInput[c]);a.criteria=s,this.http.post(t,a).subscribe(function(t){var e={response:t,pageNow:n};return console.log(e),o.result.emit(e),t})},f.prototype.lessThanFour=function(){return!(3<this.countForm)},f.prototype.resolveObject=function(e,t,n){void 0===n&&(n=null),this.postJSON(t,n).subscribe(function(t){e.itemsUrl=new Array,e.itemsUrl=t.ReturnObject})},f.prototype.transformAmount=function(t){this.formattedAmount=parseFloat(t.target.value).toLocaleString("en"),t.target.value=this.formattedAmount},f.prototype.transformToDecimal=function(t){t.target.value=parseFloat(t.target.value.toString().replace(/,/g,""))},f.prototype.exportAsXLSX=function(){var e=this,t=new g;t.pageNo=1,t.rowPerPage=9999,t.orderBy=null,t.criteria=[],t.queryString=this.configuration.querystring,this.http.post(this.apiUrl,t).subscribe(function(t){e.ExcelData=t.Data,e.excelService.exportAsExcelFile(e.ExcelData,"sample")},function(t){console.log(t)})},f.prototype.onChangeEvent=function(t,e){for(var n=this.configuration.component,r=0;r<e.affectedFilter.length;r++)for(var i=0;i<n.length;i++)if(n[i].name==e.affectedFilter[r]){var o=new g,a=new Array;if("All"!=t){var s=new v;s.DataType=e.datatype,s.propName=e.name,s.value=t,s.restriction=y.RestrictionEq,a.push(s)}if(o.criteria=a,n[i].path!=undefined&&""!=n[i].path)if(this.searchInput.ddlEnvironments!=undefined&&0!=this.searchInput.ddlEnvironments.length){for(var l=0;l<this.searchInput.ddlEnvironments.length;l++)if(n[i].name==this.searchInput.ddlEnvironments[l].name){n[i].fullpath=this.searchInput.ddlEnvironments[l].environment+n[i].path;break}}else n[i].fullpath=n[i].url;else n[i].fullpath=n[i].url;this.resolveObject(n[i],n[i].fullpath,o)}},f.decorators=[{type:a.Component,args:[{selector:"lib-UCSearch",template:'\x3c!-- Basic form layout section start --\x3e\r\n<section id="horizontal-form-layouts">\r\n <div class="row text-left">\r\n <div class="col-md-12">\r\n <div class="card">\r\n <div class="card-body">\r\n <div class="px-3">\r\n <form class="form form-horizontal" id="formSearch" #formIdSearch>\r\n <div class="form-body">\r\n <h4 class="form-section font-weight-bold">\r\n <div (click)="changeState()" class="btn no-padding cursor-pointer flip">\r\n <i class="fa" style="font-size: 15px; margin: 0px 0px 5px -15px;" [ngClass]="isHidden ? \'fa-chevron-right\' : \'fa-chevron-down\'"></i>\r\n </div>\r\n {{configuration?.title}} \r\n </h4>\r\n \x3c!-- Ini Digunakan untuk Generate Dynamic Component --\x3e\r\n \x3c!-- [hidden]="isHidden" --\x3e\r\n <div class="panel-active" [@changeDivSize]=currentState>\r\n <div class="row">\r\n <div class="col-md-6 form-group"\r\n *ngFor="let question of configuration?.component">\r\n <div class="col-md-12">\r\n <div class="row">\r\n <label class="col-md-5 no-padding" for="{{question.id}}"\r\n translate>{{question.label}}</label>\r\n <div class="col-md-7 no-padding">\r\n <div *ngIf="question.type==\'textbox\'">\r\n <input type="text" id="{{question.id}}" class="form-control search-form-control"\r\n name="{{question.name}}" value="{{question.value}}"\r\n attr.data-type="{{question.datatype}}" attr.data-restriction="{{question.restriction}}" >\r\n </div>\r\n <div *ngIf="question.type==\'textarea\'">\r\n <textarea type="text" id="{{question.id}}" class="form-control search-form-control"\r\n name="{{question.name}}" attr.data-type="{{question.datatype}}"\r\n value="{{question.value}}"></textarea>\r\n </div>\r\n <div *ngIf="question.type==\'numeric\'">\r\n <input type="text" id="{{question.id}}" (focus)="transformToDecimal($event)"\r\n (blur)="transformAmount($event)" class="form-control search-form-control"\r\n name="{{question.name}}" value="{{question.value}}"\r\n attr.data-restriction="{{question.restriction}}" attr.data-type="{{question.datatype}}">\r\n </div>\r\n \r\n \x3c!-- End Hardcode Lookup didalem--\x3e\r\n <div *ngIf="question.type==\'datepicker\'">\r\n <input type="date" id="{{question.id}}" class="form-control search-form-control btn-lookup"\r\n name="{{question.name}}" value="{{question.value}}" attr.data-type="{{question.datatype}}"\r\n attr.data-restriction="{{question.restriction}}">\r\n </div>\r\n <div *ngIf="question.type==\'dropdown\'">\r\n \x3c!-- Ini kalau datanya tidak di load dari URL --\x3e\r\n <div *ngIf="!question.isFromURL">\r\n <select name="{{question.name}}"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.items" value="{{item.key}}">\r\n {{item.value}}\r\n </option>\r\n </select>\r\n </div>\r\n \x3c!-- Ini kalau datanya di load dari URL --\x3e\r\n <div *ngIf="question.isFromURL">\r\n <div *ngIf="question.isEvent">\r\n <select name="{{question.name}}" (change)="onChangeEvent($event.target.value, question)"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.itemsUrl" value="{{item.Key}}">\r\n {{item.Value}}\r\n </option>\r\n </select>\r\n </div>\r\n <div *ngIf="!question.isEvent">\r\n <select name="{{question.name}}"\r\n class="form-control search-form-control" attr.query-in="{{question.isQueryIn}}" attr.data-type="{{question.datatype}}">\r\n <option *ngIf="!question.isSelectOne" value="All">\r\n All\r\n </option>\r\n <option *ngFor="let item of question?.itemsUrl" value="{{item.Key}}">\r\n {{item.Value}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class="col-md-12 no-padding">\r\n <form>\r\n <div class="form-actions right">\r\n <button *ngIf="exportData == true" type="button" (click)="exportAsXLSX()"\r\n class="btn btn-raised btn-success mr-1" translate>\r\n <i class="fa ft-download"></i> Export Excel\r\n </button>\r\n <button type="button" (click)="reset()" class="btn btn-raised btn-warning mr-1" translate>\r\n <i class="fa fa-times"></i> Reset\r\n </button>\r\n <button type="button" (click)="searchClick()" class="btn btn-raised btn-primary" #UCSearchClick translate>\r\n <i class="fa fa-search"></i> Search\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</section>\r\n<br>\r\n\x3c!-- // Basic form layout section end --\x3e',providers:[p],animations:[i.trigger("changeDivSize",[i.state("initial",i.style({height:"*",opacity:"1"})),i.state("final",i.style({height:"0px",opacity:"0",overflow:"hidden"})),i.transition("initial=>final",i.animate("300ms")),i.transition("final=>initial",i.animate("300ms"))])]}]}],f.ctorParameters=function(){return[{type:e.HttpClient},{type:p},{type:a.Renderer2},{type:undefined,decorators:[{type:a.Inject,args:[n.DOCUMENT]}]}]},f.propDecorators={myForm:[{type:a.ViewChild,args:["formIdSearch"]}],searchInput:[{type:a.Input}],result:[{type:a.Output}]},f);function f(t,e,n,r){this.http=t,this.excelService=e,this._renderer2=n,this._document=r,this.searchInput=new c,this.result=new a.EventEmitter,this.pageSize=10,this.pageNow=1,this.isDataLoaded=!1,this.isHidden=!1,this.currentState="initial",this.countForm=0,this.formattedAmount="",this.amount=0}var I=(q.decorators=[{type:a.NgModule,args:[{declarations:[h],imports:[m.CommonModule],exports:[h]}]}],q);function q(){}t.UCSearchService=s,t.UCSearchComponent=h,t.UCSearchModule=I,t.ɵa=p,Object.defineProperty(t,"__esModule",{value:!0})});
|
|
2
2
|
//# sourceMappingURL=ucsearch.umd.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["ng://ucsearch/lib/ucsearch.service.ts","ng://ucsearch/lib/model/CriteriaObj.Model.ts","ng://ucsearch/lib/model/RequestCriteriaObj.model.ts","ng://ucsearch/lib/model/AdInstConstant.ts","ng://ucsearch/lib/services/excel-service/excel-service.ts","ng://ucsearch/lib/ucsearch.component.ts","ng://ucsearch/lib/ucsearch.module.ts"],"names":["UCSearchService","Injectable","args","providedIn","CriteriaObj","this","low","high","DataType","RequestCriteriaObj","includeCount","includeData","isLoading","queryString","rowVersion","AdInsConstant","RestrictionBetween","RestrictionLike","RestrictionEq","RestrictionNeq","RestrictionGt","RestrictionGte","RestrictionLt","RestrictionLte","RestrictionIn","RestrictionNotIn","RestrictionOr","RestrictionOrNeq","RestrictionIsNull","RestrictionIsNotNull","RestrictionGTE","RestrictionLTE","showData","ExcelService","prototype","exportAsExcelFile","json","excelFileName","worksheet","XLSX.utils","json_to_sheet","console","log","workbook","Sheets","data","SheetNames","excelBuffer","XLSX.write","bookType","type","saveAsExcelFile","buffer","fileName","Blob","FileSaver.saveAs","Date","getTime","UCSearchComponent","changeState","currentState","isHidden","ngOnInit","apiUrl","searchInput","enviromentUrl","apiQryPaging","arrCrit","arrCritObj","js","_renderer2","createElement","text","appendChild","_document","body","initiateForm","_this","getJSON","_url","subscribe","configuration","exportData","exportExcel","countForm","component","length","isDataLoaded","title","undefined","i","isFromURL","request","arrayCrit","Array","criteriaObject","propName","criteriaPropName","value","criteriaPropValue","restriction","push","criteria","path","ddlEnvironments","y","name","fullpath","environment","url","resolveObject","parseFloat","toLocaleString","includes","llsBD","localStorage","getItem","businessDate","operator","charAt","dateShow","tempMinus","split","numDay","parseInt","setDate","getDate","dateText","formatDate","http","get","postJSON","post","searchClick","order","orderby","key","pageNow","search","pageSize","reset","pageNo","rowPerPage","orderBy","addCrit","IsQueryIn","querystring","critObj","myForm","nativeElement","getAttribute","nodeName","ddl","options","selectedIndex","ddlList","x","listValue","replace","addCritInput","response","qryPaging","result","emit","lessThanFour","obj","crit","tempData","itemsUrl","ReturnObject","transformAmount","element","formattedAmount","target","transformToDecimal","toString","exportAsXLSX","ExcelData","excelService","error","onChangeEvent","optValue","afFilter","jsonComp","affectedFilter","j","datatype","Component","selector","template","providers","animations","trigger","state","style","height","opacity","overflow","transition","animate","HttpClient","Renderer2","Inject","DOCUMENT","ViewChild","Input","Output","EventEmitter","payLoad","amount","UCSearchModule","NgModule","declarations","imports","CommonModule","exports"],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UCSearchService {\r\n\r\n constructor() { }\r\n}\r\n","export class CriteriaObj{\r\n propName:string;\r\n restriction:string;\r\n value:string;\r\n low:number;\r\n high:number;\r\n DataType:string;\r\n listValue : Array<any>;\r\n\r\n constructor()\r\n {\r\n this.low=0;\r\n this.high=0;\r\n this.DataType='Text';\r\n }\r\n\r\n}","import { CriteriaObj } from \"../model/CriteriaObj.model\";\r\n\r\nexport class RequestCriteriaObj{\r\n includeCount:boolean;\r\n includeData:boolean;\r\n pageNo:number;\r\n rowPerPage:number;\r\n orderBy:any;\r\n criteria:CriteriaObj[];\r\n isLoading : boolean;\r\n queryString: any;\r\n rowVersion: any;\r\n\r\n constructor()\r\n {\r\n this.includeCount=true;\r\n this.includeData=true;\r\n this.isLoading = true;\r\n this.queryString = '';\r\n this.rowVersion = '';\r\n }\r\n}","import { formatDate } from \"@angular/common\";\r\n\r\nexport class AdInsConstant {\r\n public static RestrictionBetween = \"Between\"\r\n public static RestrictionLike = \"Like\";\r\n public static RestrictionEq = \"Eq\";\r\n public static RestrictionNeq = \"NEQ\";\r\n public static RestrictionGt = \"GT\";\r\n public static RestrictionGte = \"GTE\";\r\n public static RestrictionLt = \"LT\";\r\n public static RestrictionLte = \"LTE\";\r\n public static RestrictionIn = \"IN\";\r\n public static RestrictionNotIn = \"NotIn\";\r\n public static RestrictionOr = \"Or\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionOrNeq = \"OrNeq\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionIsNull = \"isnull\";\r\n public static RestrictionIsNotNull = \"isnotnull\";\r\n public static RestrictionGTE = \"GTE\";\r\n public static RestrictionLTE = \"LTE\";\r\n public static showData = \"10,50,100\";\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport * as FileSaver from 'file-saver';\r\nimport * as XLSX from 'xlsx';\r\n\r\nconst EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';\r\nconst EXCEL_EXTENSION = '.xlsx';\r\n\r\n@Injectable()\r\nexport class ExcelService {\r\n\r\n constructor() { }\r\n\r\n public exportAsExcelFile(json: any[], excelFileName: string): void {\r\n \r\n const worksheet: XLSX.WorkSheet = XLSX.utils.json_to_sheet(json);\r\n console.log('worksheet',worksheet);\r\n const workbook: XLSX.WorkBook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };\r\n const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });\r\n //const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'buffer' });\r\n this.saveAsExcelFile(excelBuffer, excelFileName);\r\n }\r\n\r\n private saveAsExcelFile(buffer: any, fileName: string): void {\r\n const data: Blob = new Blob([buffer], {\r\n type: EXCEL_TYPE\r\n });\r\n FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);\r\n }\r\n\r\n}","import { Component, OnInit, Input, ViewChild, ElementRef, Inject, Renderer2, EventEmitter, Output, ViewEncapsulation } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { formatDate } from '@angular/common';\r\nimport { CriteriaObj } from './model/CriteriaObj.Model';\r\nimport { RequestCriteriaObj } from './model/RequestCriteriaObj.model';\r\nimport { AdInsConstant } from './model/AdInstConstant';\r\nimport { DOCUMENT } from '@angular/platform-browser';\r\nimport { ExcelService } from './services/excel-service/excel-service';\r\nimport { trigger, transition, style, animate, state } from '@angular/animations';\r\n\r\n@Component({\r\n selector: 'lib-UCSearch',\r\n templateUrl: './ucsearch.component.html',\r\n styles: [],\r\n providers: [ExcelService],\r\n animations: [\r\n trigger('changeDivSize', [\r\n state('initial', style({\r\n height: '*',\r\n opacity: '1',\r\n })),\r\n state('final', style({\r\n height: '0px',\r\n opacity: '0',\r\n overflow: 'hidden',\r\n })),\r\n transition('initial=>final', animate('300ms')),\r\n transition('final=>initial', animate('300ms'))\r\n ]),\r\n ]\r\n})\r\nexport class UCSearchComponent implements OnInit {\r\n\r\n @ViewChild('formIdSearch') myForm: ElementRef;\r\n @Input() searchInput: any;\r\n @Output() result: EventEmitter<any> = new EventEmitter();\r\n pageSize: any = 10;\r\n pageNow: any = 1;\r\n tempUrl: string;\r\n server: any;\r\n configuration: any;\r\n itemUrl: any;\r\n exportData: any;\r\n ExcelData: any;\r\n isDataLoaded: boolean = false;\r\n isHidden: boolean = false;\r\n\r\n currentState = 'initial';\r\n\r\n form: FormGroup;\r\n payLoad = '';\r\n countForm = 0;\r\n formattedAmount = '';\r\n amount = 0;\r\n apiUrl: string;\r\n arrCrit: any;\r\n constructor(private http: HttpClient, private excelService: ExcelService, private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {\r\n }\r\n // hide(obj:any){\r\n // var target =event.srcElement;\r\n // // var idAttr = target.attributes.id;\r\n // // var value = idAttr.nodeValue;\r\n // }\r\n\r\n changeState() {\r\n this.currentState = this.currentState === 'initial' ? 'final' : 'initial';\r\n this.isHidden = this.isHidden === false ? true : false;\r\n }\r\n\r\n ngOnInit() {\r\n this.apiUrl = this.searchInput.enviromentUrl + this.searchInput.apiQryPaging;\r\n this.arrCrit = this.searchInput.arrCritObj;\r\n let js = this._renderer2.createElement('script');\r\n js.text = `\r\n $(document).ready(function(){\r\n $(\"#flip\").click(function(){\r\n $(\"#panel\").slideToggle(\"slow\");\r\n });\r\n });\r\n `;\r\n this._renderer2.appendChild(this._document.body, js);\r\n this.initiateForm();\r\n }\r\n\r\n initiateForm() {\r\n this.getJSON(this.searchInput._url).subscribe(data => {\r\n console.log(data);\r\n this.configuration = data;\r\n this.exportData = data.exportExcel;\r\n this.countForm = data.component.length;\r\n this.isDataLoaded = true;\r\n\r\n if (this.searchInput.title != undefined && this.searchInput.title != \"\") {\r\n this.configuration.title = this.searchInput.title;\r\n }\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n //ini kalau datanya di load dari URL\r\n if (data.component[i].isFromURL == true) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n var criteriaObject = new CriteriaObj();\r\n criteriaObject.DataType = \"text\";\r\n criteriaObject.propName = data.component[i].criteriaPropName;\r\n criteriaObject.value = data.component[i].criteriaPropValue;\r\n criteriaObject.restriction = \"eq\";\r\n arrayCrit.push(criteriaObject);\r\n request.criteria = arrayCrit;\r\n request[data.component[i].criteriaPropName] = data.component[i].criteriaPropValue;\r\n\r\n // Pengecekan penggunaan url atau path\r\n if (data.component[i].path != undefined && data.component[i].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (data.component[i].name == this.searchInput.ddlEnvironments[y].name) {\r\n data.component[i].fullpath = this.searchInput.ddlEnvironments[y].environment + data.component[i].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n //lempar objectnya sekalian sama urlnya, nnti di bind di dalem karena masalah di asyncnya\r\n //biar tiap function ada state2nya sendiri\r\n this.resolveObject(data.component[i], data.component[i].fullpath, request);\r\n }\r\n\r\n if (data.component[i].type == \"numeric\") {\r\n data.component[i].value = parseFloat(data.component[i].value).toLocaleString('en');\r\n }\r\n\r\n //pengecekan tanggal\r\n if (data.component[i].type == \"datepicker\") {\r\n if (data.component[i].value.includes(\"BD\")) {\r\n let llsBD = localStorage.getItem(\"BusinessDateRaw\");\r\n let businessDate = new Date();\r\n if (llsBD != null) {\r\n businessDate = new Date(llsBD);\r\n }\r\n var operator = data.component[i].value.charAt(2);\r\n var dateShow = new Date();\r\n if (operator == \"-\") {\r\n var tempMinus = data.component[i].value.split(\"-\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() - numDay);\r\n }\r\n else if (operator == \"+\") {\r\n var tempMinus = data.component[i].value.split(\"+\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() + numDay);\r\n }\r\n var dateText = formatDate(dateShow, 'yyyy-MM-dd', 'en-US')\r\n data.component[i].value = dateText;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n\r\n public getJSON(url: string): Observable<any> {\r\n return this.http.get(url);\r\n }\r\n\r\n public postJSON(url: string, criteria: any = null): Observable<any> {\r\n return this.http.post(url, criteria);\r\n }\r\n\r\n searchClick() {\r\n let order = null;\r\n if (this.configuration.orderby != null) {\r\n order = {\r\n key: this.configuration.orderby.key,\r\n value: this.configuration.orderby.value\r\n }\r\n }\r\n this.pageNow = 1;\r\n this.search(this.apiUrl, this.pageNow, this.pageSize, order, this.arrCrit);\r\n }\r\n\r\n reset() {\r\n this.initiateForm();\r\n }\r\n\r\n search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit: CriteriaObj[] = new Array()) {\r\n var request = new RequestCriteriaObj();\r\n var arrCrit = new Array();\r\n var IsQueryIn = false;\r\n\r\n request.pageNo = pageNo;\r\n request.rowPerPage = rowPerPage;\r\n request.orderBy = orderBy;\r\n request.queryString = this.configuration.querystring;\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n var critObj = new CriteriaObj();\r\n var component = this.myForm.nativeElement[i];\r\n critObj.DataType = component.getAttribute('data-type');\r\n //Ini khusus kalau dari Drop Down\r\n if (component.getAttribute('query-in') != null && component.getAttribute('query-in') == \"true\") {\r\n IsQueryIn = true;\r\n }\r\n else {\r\n IsQueryIn = false;\r\n }\r\n if (component.value != \"\") {\r\n if (component.nodeName == 'SELECT') {\r\n var ddl = component.options;\r\n var text = ddl[ddl.selectedIndex].value;\r\n if (text != \"All\") {\r\n //Kalau Dari Dropdown udah pasti pake Eq\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n critObj.propName = component.name;\r\n critObj.value = text;\r\n arrCrit.push(critObj);\r\n } else if (text == \"All\" && IsQueryIn == true && component.options.length != 0) {\r\n var ddlList = new Array();\r\n for (let x = 0; x < component.options.length; x++) {\r\n if (x != 0) {\r\n ddlList.push(component.options[x].value);\r\n }\r\n }\r\n critObj.restriction = AdInsConstant.RestrictionIn;\r\n critObj.propName = component.name;\r\n critObj.listValue = ddlList;\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n else {\r\n //Kalau ada Percent maka yang dipake nnti adalah Restrictions Like\r\n critObj.propName = component.name;\r\n critObj.value = component.value;\r\n if (component.value.includes(\"%\")) {\r\n critObj.restriction = AdInsConstant.RestrictionLike;\r\n }\r\n //kalau componentnya Date, restrictionsnya lgsg ambil dari property JSONnya\r\n else if (component.getAttribute('data-restriction') != \"\" && component.getAttribute('data-restriction') != null) {\r\n critObj.restriction = component.getAttribute('data-restriction');\r\n if (component.getAttribute('data-type') == 'numeric') {\r\n component.value = parseFloat(component.value.replace(/,/g, ''));\r\n }\r\n }\r\n else {\r\n critObj.restriction = AdInsConstant.RestrictionEq\r\n }\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n }\r\n\r\n if (addCrit != null && addCrit != undefined) {\r\n if (addCrit.length != 0) {\r\n for (var i = 0; i < addCrit.length; i++) {\r\n arrCrit.push(addCrit[i]);\r\n }\r\n } else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n }\r\n else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n\r\n request.criteria = arrCrit;\r\n this.http.post(apiUrl, request).subscribe((response) => {\r\n var qryPaging = {\r\n response: response,\r\n pageNow: pageNo\r\n }\r\n console.log(qryPaging);\r\n this.result.emit(qryPaging);\r\n return response;\r\n });\r\n }\r\n\r\n lessThanFour(): boolean {\r\n if (this.countForm > 3) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n resolveObject(obj: any, url: string, crit: RequestCriteriaObj = null) {\r\n const val = this.postJSON(url, crit);\r\n val.subscribe(tempData => {\r\n obj.itemsUrl = new Array();\r\n obj.itemsUrl = tempData.ReturnObject;\r\n });\r\n }\r\n\r\n transformAmount(element: any) {\r\n this.formattedAmount = parseFloat(element.target.value).toLocaleString('en');\r\n // to show the formatted amount in the textbox.\r\n element.target.value = this.formattedAmount;\r\n }\r\n\r\n transformToDecimal(element: any) {\r\n element.target.value = parseFloat(element.target.value.toString().replace(/,/g, ''));\r\n }\r\n\r\n exportAsXLSX(): void {\r\n var request = new RequestCriteriaObj();\r\n request.pageNo = 1;\r\n request.rowPerPage = 9999;\r\n request.orderBy = null;\r\n request.criteria = [];\r\n request.queryString = this.configuration.querystring;\r\n\r\n this.http.post(this.apiUrl, request).subscribe(\r\n response => {\r\n this.ExcelData = response[\"Data\"];\r\n this.excelService.exportAsExcelFile(this.ExcelData, 'sample');\r\n },\r\n (error) => {\r\n console.log(error);\r\n });\r\n }\r\n\r\n onChangeEvent(optValue, afFilter) {\r\n var jsonComp = this.configuration.component;\r\n\r\n for (var i = 0; i < afFilter.affectedFilter.length; i++) {\r\n for (var j = 0; j < jsonComp.length; j++) {\r\n if (jsonComp[j].name == afFilter.affectedFilter[i]) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n\r\n if (optValue != \"All\") {\r\n var critObj = new CriteriaObj();\r\n critObj.DataType = afFilter.datatype;\r\n critObj.propName = afFilter.name;\r\n critObj.value = optValue;\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n arrayCrit.push(critObj);\r\n }\r\n request.criteria = arrayCrit;\r\n if (jsonComp[j].path != undefined && jsonComp[j].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (jsonComp[j].name == this.searchInput.ddlEnvironments[y].name) {\r\n jsonComp[j].fullpath = this.searchInput.ddlEnvironments[y].environment + jsonComp[j].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n this.resolveObject(jsonComp[j], jsonComp[j].url, request);\r\n }\r\n }\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { UCSearchComponent } from './ucsearch.component';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@NgModule({\r\n declarations: [UCSearchComponent],\r\n imports: [\r\n CommonModule\r\n ],\r\n exports: [UCSearchComponent]\r\n})\r\nexport class UCSearchModule { }\r\n"]}
|
|
1
|
+
{"version":3,"sources":["ng://ucsearch/lib/ucsearch.service.ts","ng://ucsearch/lib/model/InputSearchObj.Model.ts","ng://ucsearch/lib/model/CriteriaObj.model.ts","ng://ucsearch/lib/model/RequestCriteriaObj.model.ts","ng://ucsearch/lib/model/AdInstConstant.ts","ng://ucsearch/lib/services/excel-service/excel-service.ts","ng://ucsearch/lib/ucsearch.component.ts","ng://ucsearch/lib/ucsearch.module.ts"],"names":["UCSearchService","Injectable","args","providedIn","InputSearchObj","this","_url","enviromentUrl","title","apiQryPaging","arrCritObj","addCritInput","Array","ddlEnvironments","whereValue","CriteriaObj","low","high","DataType","RequestCriteriaObj","includeCount","includeData","isLoading","queryString","rowVersion","AdInsConstant","RestrictionBetween","RestrictionLike","RestrictionEq","RestrictionNeq","RestrictionGt","RestrictionGte","RestrictionLt","RestrictionLte","RestrictionIn","RestrictionNotIn","RestrictionOr","RestrictionOrNeq","RestrictionIsNull","RestrictionIsNotNull","RestrictionGTE","RestrictionLTE","showData","ExcelService","prototype","exportAsExcelFile","json","excelFileName","worksheet","XLSX.utils","json_to_sheet","console","log","workbook","Sheets","data","SheetNames","excelBuffer","XLSX.write","bookType","type","saveAsExcelFile","buffer","fileName","Blob","FileSaver.saveAs","Date","getTime","UCSearchComponent","changeState","currentState","isHidden","ngOnInit","apiUrl","searchInput","arrCrit","js","_renderer2","createElement","text","appendChild","_document","body","initiateForm","_this","getJSON","subscribe","configuration","exportData","exportExcel","countForm","component","length","isDataLoaded","undefined","i","isFromURL","request","arrayCrit","criteriaObject","propName","criteriaPropName","value","criteriaPropValue","restriction","push","criteria","path","y","name","fullpath","environment","url","resolveObject","parseFloat","toLocaleString","includes","llsBD","localStorage","getItem","businessDate","operator","charAt","dateShow","tempMinus","split","numDay","parseInt","setDate","getDate","dateText","formatDate","http","get","postJSON","post","searchClick","order","orderby","key","pageNow","search","pageSize","reset","pageNo","rowPerPage","orderBy","addCrit","IsQueryIn","querystring","whereQuery","critObj","myForm","nativeElement","getAttribute","nodeName","ddl","options","selectedIndex","ddlList","x","listValue","replace","response","qryPaging","result","emit","lessThanFour","obj","crit","tempData","itemsUrl","ReturnObject","transformAmount","element","formattedAmount","target","transformToDecimal","toString","exportAsXLSX","ExcelData","excelService","error","onChangeEvent","optValue","afFilter","jsonComp","affectedFilter","j","datatype","Component","selector","template","providers","animations","trigger","state","style","height","opacity","overflow","transition","animate","HttpClient","Renderer2","Inject","DOCUMENT","ViewChild","Input","Output","EventEmitter","amount","UCSearchModule","NgModule","declarations","imports","CommonModule","exports"],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UCSearchService {\r\n\r\n constructor() { }\r\n}\r\n","import { CriteriaObj } from \"./CriteriaObj.model\";\r\n\r\nexport class InputSearchObj {\r\n _url: string;\r\n enviromentUrl: string;\r\n title: string;\r\n apiQryPaging: string;\r\n arrCritObj: any;\r\n addCritInput: Array<CriteriaObj>;\r\n ddlEnvironments: Array<EnviObj>;\r\n whereValue: Array<any>;\r\n constructor() {\r\n this._url = \"\";\r\n this.enviromentUrl = \"\";\r\n this.title = \"\";\r\n this.apiQryPaging = \"\";\r\n this.arrCritObj = null;\r\n this.addCritInput = new Array<CriteriaObj>();\r\n this.ddlEnvironments = new Array<EnviObj>();\r\n this.whereValue = new Array<any>();\r\n }\r\n}\r\n\r\nexport class EnviObj {\r\n name: string;\r\n environment: string;\r\n\r\n constructor() {\r\n this.name = \"\";\r\n this.environment = \"\";\r\n }\r\n}","export class CriteriaObj {\r\n propName: string;\r\n restriction: string;\r\n value: string;\r\n low: number;\r\n high: number;\r\n DataType: string;\r\n listValue: Array<any>;\r\n\r\n constructor() {\r\n this.low = 0;\r\n this.high = 0;\r\n this.DataType = 'Text';\r\n }\r\n\r\n}","import { CriteriaObj } from \"./CriteriaObj.model\";\r\n\r\nexport class RequestCriteriaObj{\r\n includeCount:boolean;\r\n includeData:boolean;\r\n pageNo:number;\r\n rowPerPage:number;\r\n orderBy:any;\r\n criteria:CriteriaObj[];\r\n isLoading : boolean;\r\n queryString: any;\r\n rowVersion: any;\r\n\r\n constructor()\r\n {\r\n this.includeCount=true;\r\n this.includeData=true;\r\n this.isLoading = true;\r\n this.queryString = '';\r\n this.rowVersion = '';\r\n }\r\n}","import { formatDate } from \"@angular/common\";\r\n\r\nexport class AdInsConstant {\r\n public static RestrictionBetween = \"Between\"\r\n public static RestrictionLike = \"Like\";\r\n public static RestrictionEq = \"Eq\";\r\n public static RestrictionNeq = \"NEQ\";\r\n public static RestrictionGt = \"GT\";\r\n public static RestrictionGte = \"GTE\";\r\n public static RestrictionLt = \"LT\";\r\n public static RestrictionLte = \"LTE\";\r\n public static RestrictionIn = \"IN\";\r\n public static RestrictionNotIn = \"NotIn\";\r\n public static RestrictionOr = \"Or\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionOrNeq = \"OrNeq\"; //pastikan ada 1 criteria sebelumnya\r\n public static RestrictionIsNull = \"isnull\";\r\n public static RestrictionIsNotNull = \"isnotnull\";\r\n public static RestrictionGTE = \"GTE\";\r\n public static RestrictionLTE = \"LTE\";\r\n public static showData = \"10,50,100\";\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport * as FileSaver from 'file-saver';\r\nimport * as XLSX from 'xlsx';\r\n\r\nconst EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';\r\nconst EXCEL_EXTENSION = '.xlsx';\r\n\r\n@Injectable()\r\nexport class ExcelService {\r\n\r\n constructor() { }\r\n\r\n public exportAsExcelFile(json: any[], excelFileName: string): void {\r\n \r\n const worksheet: XLSX.WorkSheet = XLSX.utils.json_to_sheet(json);\r\n console.log('worksheet',worksheet);\r\n const workbook: XLSX.WorkBook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };\r\n const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });\r\n //const excelBuffer: any = XLSX.write(workbook, { bookType: 'xlsx', type: 'buffer' });\r\n this.saveAsExcelFile(excelBuffer, excelFileName);\r\n }\r\n\r\n private saveAsExcelFile(buffer: any, fileName: string): void {\r\n const data: Blob = new Blob([buffer], {\r\n type: EXCEL_TYPE\r\n });\r\n FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);\r\n }\r\n\r\n}","import { Component, OnInit, Input, ViewChild, ElementRef, Inject, Renderer2, EventEmitter, Output } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { formatDate } from '@angular/common';\r\nimport { InputSearchObj } from './model/InputSearchObj.Model';\r\nimport { CriteriaObj } from './model/CriteriaObj.model';\r\nimport { RequestCriteriaObj } from './model/RequestCriteriaObj.model';\r\nimport { AdInsConstant } from './model/AdInstConstant';\r\nimport { DOCUMENT } from '@angular/platform-browser';\r\nimport { ExcelService } from './services/excel-service/excel-service';\r\nimport { trigger, transition, style, animate, state } from '@angular/animations';\r\n\r\n@Component({\r\n selector: 'lib-UCSearch',\r\n templateUrl: './ucsearch.component.html',\r\n styles: [],\r\n providers: [ExcelService],\r\n animations: [\r\n trigger('changeDivSize', [\r\n state('initial', style({\r\n height: '*',\r\n opacity: '1',\r\n })),\r\n state('final', style({\r\n height: '0px',\r\n opacity: '0',\r\n overflow: 'hidden',\r\n })),\r\n transition('initial=>final', animate('300ms')),\r\n transition('final=>initial', animate('300ms'))\r\n ]),\r\n ]\r\n})\r\nexport class UCSearchComponent implements OnInit {\r\n\r\n @ViewChild('formIdSearch') myForm: ElementRef;\r\n @Input() searchInput: InputSearchObj = new InputSearchObj();\r\n @Output() result: EventEmitter<any> = new EventEmitter();\r\n pageSize: any = 10;\r\n pageNow: any = 1;\r\n configuration: any;\r\n exportData: any;\r\n ExcelData: any;\r\n isDataLoaded: boolean = false;\r\n isHidden: boolean = false;\r\n\r\n currentState = 'initial';\r\n\r\n form: FormGroup;\r\n countForm = 0;\r\n formattedAmount = '';\r\n amount = 0;\r\n apiUrl: string;\r\n arrCrit: any;\r\n constructor(private http: HttpClient, private excelService: ExcelService, private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {\r\n }\r\n\r\n changeState() {\r\n this.currentState = this.currentState === 'initial' ? 'final' : 'initial';\r\n this.isHidden = this.isHidden === false ? true : false;\r\n }\r\n\r\n ngOnInit() {\r\n console.log(\"ucsearch\");\r\n this.apiUrl = this.searchInput.enviromentUrl + this.searchInput.apiQryPaging;\r\n this.arrCrit = this.searchInput.arrCritObj;\r\n let js = this._renderer2.createElement('script');\r\n js.text = `\r\n $(document).ready(function(){\r\n $(\"#flip\").click(function(){\r\n $(\"#panel\").slideToggle(\"slow\");\r\n });\r\n });\r\n `;\r\n this._renderer2.appendChild(this._document.body, js);\r\n this.initiateForm();\r\n }\r\n\r\n initiateForm() {\r\n this.getJSON(this.searchInput._url).subscribe(data => {\r\n this.configuration = data;\r\n this.exportData = data.exportExcel;\r\n this.countForm = data.component.length;\r\n this.isDataLoaded = true;\r\n\r\n if (this.searchInput.title != undefined && this.searchInput.title != \"\") {\r\n this.configuration.title = this.searchInput.title;\r\n }\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n //ini kalau datanya di load dari URL\r\n if (data.component[i].isFromURL == true) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n var criteriaObject = new CriteriaObj();\r\n criteriaObject.DataType = \"text\";\r\n criteriaObject.propName = data.component[i].criteriaPropName;\r\n criteriaObject.value = data.component[i].criteriaPropValue;\r\n criteriaObject.restriction = \"eq\";\r\n arrayCrit.push(criteriaObject);\r\n request.criteria = arrayCrit;\r\n request[data.component[i].criteriaPropName] = data.component[i].criteriaPropValue;\r\n\r\n // Pengecekan penggunaan url atau path\r\n if (data.component[i].path != undefined && data.component[i].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (data.component[i].name == this.searchInput.ddlEnvironments[y].name) {\r\n data.component[i].fullpath = this.searchInput.ddlEnvironments[y].environment + data.component[i].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n\r\n } else {\r\n data.component[i].fullpath = data.component[i].url;\r\n }\r\n //lempar objectnya sekalian sama urlnya, nnti di bind di dalem karena masalah di asyncnya\r\n //biar tiap function ada state2nya sendiri\r\n this.resolveObject(data.component[i], data.component[i].fullpath, request);\r\n }\r\n\r\n if (data.component[i].type == \"numeric\") {\r\n data.component[i].value = parseFloat(data.component[i].value).toLocaleString('en');\r\n }\r\n\r\n //pengecekan tanggal\r\n if (data.component[i].type == \"datepicker\") {\r\n if (data.component[i].value.includes(\"BD\")) {\r\n let llsBD = localStorage.getItem(\"BusinessDateRaw\");\r\n let businessDate = new Date();\r\n if (llsBD != null) {\r\n businessDate = new Date(llsBD);\r\n }\r\n var operator = data.component[i].value.charAt(2);\r\n var dateShow = new Date();\r\n if (operator == \"-\") {\r\n var tempMinus = data.component[i].value.split(\"-\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() - numDay);\r\n }\r\n else if (operator == \"+\") {\r\n var tempMinus = data.component[i].value.split(\"+\", 2);\r\n var numDay = parseInt(tempMinus[1]);\r\n dateShow.setDate(businessDate.getDate() + numDay);\r\n }\r\n var dateText = formatDate(dateShow, 'yyyy-MM-dd', 'en-US')\r\n data.component[i].value = dateText;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n\r\n public getJSON(url: string): Observable<any> {\r\n return this.http.get(url);\r\n }\r\n\r\n public postJSON(url: string, criteria: any = null): Observable<any> {\r\n return this.http.post(url, criteria);\r\n }\r\n\r\n searchClick() {\r\n let order = null;\r\n if (this.configuration.orderby != null) {\r\n order = {\r\n key: this.configuration.orderby.key,\r\n value: this.configuration.orderby.value\r\n }\r\n }\r\n this.pageNow = 1;\r\n this.search(this.apiUrl, this.pageNow, this.pageSize, order, this.arrCrit);\r\n }\r\n\r\n reset() {\r\n this.initiateForm();\r\n }\r\n\r\n search(apiUrl: string, pageNo: number, rowPerPage: number, orderBy: any, addCrit: CriteriaObj[] = new Array()) {\r\n var request = new RequestCriteriaObj();\r\n var arrCrit = new Array();\r\n var IsQueryIn = false;\r\n\r\n // Inject whereQuery for where criteria\r\n if (this.searchInput.whereValue.length != 0) {\r\n this.configuration.querystring.whereQuery = this.searchInput.whereValue;\r\n }\r\n request.pageNo = pageNo;\r\n request.rowPerPage = rowPerPage;\r\n request.orderBy = orderBy;\r\n request.queryString = this.configuration.querystring;\r\n\r\n for (var i = 0; i < this.countForm; i++) {\r\n var critObj = new CriteriaObj();\r\n var component = this.myForm.nativeElement[i];\r\n critObj.DataType = component.getAttribute('data-type');\r\n //Ini khusus kalau dari Drop Down\r\n if (component.getAttribute('query-in') != null && component.getAttribute('query-in') == \"true\") {\r\n IsQueryIn = true;\r\n }\r\n else {\r\n IsQueryIn = false;\r\n }\r\n if (component.value != \"\") {\r\n if (component.nodeName == 'SELECT') {\r\n var ddl = component.options;\r\n var text = ddl[ddl.selectedIndex].value;\r\n if (text != \"All\") {\r\n //Kalau Dari Dropdown udah pasti pake Eq\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n critObj.propName = component.name;\r\n critObj.value = text;\r\n arrCrit.push(critObj);\r\n } else if (text == \"All\" && IsQueryIn == true && component.options.length != 0) {\r\n var ddlList = new Array();\r\n for (let x = 0; x < component.options.length; x++) {\r\n if (x != 0) {\r\n ddlList.push(component.options[x].value);\r\n }\r\n }\r\n critObj.restriction = AdInsConstant.RestrictionIn;\r\n critObj.propName = component.name;\r\n critObj.listValue = ddlList;\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n else {\r\n //Kalau ada Percent maka yang dipake nnti adalah Restrictions Like\r\n critObj.propName = component.name;\r\n critObj.value = component.value;\r\n if (component.value.includes(\"%\")) {\r\n critObj.restriction = AdInsConstant.RestrictionLike;\r\n }\r\n //kalau componentnya Date, restrictionsnya lgsg ambil dari property JSONnya\r\n else if (component.getAttribute('data-restriction') != \"\" && component.getAttribute('data-restriction') != null) {\r\n critObj.restriction = component.getAttribute('data-restriction');\r\n if (component.getAttribute('data-type') == 'numeric') {\r\n component.value = parseFloat(component.value.replace(/,/g, ''));\r\n }\r\n }\r\n else {\r\n critObj.restriction = AdInsConstant.RestrictionEq\r\n }\r\n arrCrit.push(critObj);\r\n }\r\n }\r\n }\r\n\r\n if (addCrit != null && addCrit != undefined) {\r\n if (addCrit.length != 0) {\r\n for (var i = 0; i < addCrit.length; i++) {\r\n arrCrit.push(addCrit[i]);\r\n }\r\n } else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n }\r\n else if (this.searchInput.addCritInput != null || this.searchInput.addCritInput != undefined) {\r\n for (var i = 0; i < this.searchInput.addCritInput.length; i++) {\r\n arrCrit.push(this.searchInput.addCritInput[i]);\r\n }\r\n }\r\n\r\n request.criteria = arrCrit;\r\n this.http.post(apiUrl, request).subscribe((response) => {\r\n var qryPaging = {\r\n response: response,\r\n pageNow: pageNo\r\n }\r\n console.log(qryPaging);\r\n this.result.emit(qryPaging);\r\n return response;\r\n });\r\n }\r\n\r\n lessThanFour(): boolean {\r\n if (this.countForm > 3) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n resolveObject(obj: any, url: string, crit: RequestCriteriaObj = null) {\r\n const val = this.postJSON(url, crit);\r\n val.subscribe(tempData => {\r\n obj.itemsUrl = new Array();\r\n obj.itemsUrl = tempData.ReturnObject;\r\n });\r\n }\r\n\r\n transformAmount(element: any) {\r\n this.formattedAmount = parseFloat(element.target.value).toLocaleString('en');\r\n // to show the formatted amount in the textbox.\r\n element.target.value = this.formattedAmount;\r\n }\r\n\r\n transformToDecimal(element: any) {\r\n element.target.value = parseFloat(element.target.value.toString().replace(/,/g, ''));\r\n }\r\n\r\n exportAsXLSX(): void {\r\n var request = new RequestCriteriaObj();\r\n request.pageNo = 1;\r\n request.rowPerPage = 9999;\r\n request.orderBy = null;\r\n request.criteria = [];\r\n request.queryString = this.configuration.querystring;\r\n\r\n this.http.post(this.apiUrl, request).subscribe(\r\n response => {\r\n this.ExcelData = response[\"Data\"];\r\n this.excelService.exportAsExcelFile(this.ExcelData, 'sample');\r\n },\r\n (error) => {\r\n console.log(error);\r\n });\r\n }\r\n\r\n onChangeEvent(optValue, afFilter) {\r\n var jsonComp = this.configuration.component;\r\n\r\n for (var i = 0; i < afFilter.affectedFilter.length; i++) {\r\n for (var j = 0; j < jsonComp.length; j++) {\r\n if (jsonComp[j].name == afFilter.affectedFilter[i]) {\r\n var request = new RequestCriteriaObj();\r\n var arrayCrit = new Array();\r\n\r\n if (optValue != \"All\") {\r\n var critObj = new CriteriaObj();\r\n critObj.DataType = afFilter.datatype;\r\n critObj.propName = afFilter.name;\r\n critObj.value = optValue;\r\n critObj.restriction = AdInsConstant.RestrictionEq;\r\n arrayCrit.push(critObj);\r\n }\r\n request.criteria = arrayCrit;\r\n if (jsonComp[j].path != undefined && jsonComp[j].path != \"\") {\r\n if (this.searchInput.ddlEnvironments != undefined && this.searchInput.ddlEnvironments.length != 0) {\r\n for (let y = 0; y < this.searchInput.ddlEnvironments.length; y++) {\r\n if (jsonComp[j].name == this.searchInput.ddlEnvironments[y].name) {\r\n jsonComp[j].fullpath = this.searchInput.ddlEnvironments[y].environment + jsonComp[j].path;\r\n break;\r\n }\r\n }\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n\r\n } else {\r\n jsonComp[j].fullpath = jsonComp[j].url;\r\n }\r\n this.resolveObject(jsonComp[j], jsonComp[j].fullpath, request);\r\n }\r\n }\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { UCSearchComponent } from './ucsearch.component';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@NgModule({\r\n declarations: [UCSearchComponent],\r\n imports: [\r\n CommonModule\r\n ],\r\n exports: [UCSearchComponent]\r\n})\r\nexport class UCSearchModule { }\r\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview added by tsickle
|
|
3
|
+
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
+
*/
|
|
5
|
+
export class CriteriaObj {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.low = 0;
|
|
8
|
+
this.high = 0;
|
|
9
|
+
this.DataType = 'Text';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
if (false) {
|
|
13
|
+
/** @type {?} */
|
|
14
|
+
CriteriaObj.prototype.propName;
|
|
15
|
+
/** @type {?} */
|
|
16
|
+
CriteriaObj.prototype.restriction;
|
|
17
|
+
/** @type {?} */
|
|
18
|
+
CriteriaObj.prototype.value;
|
|
19
|
+
/** @type {?} */
|
|
20
|
+
CriteriaObj.prototype.low;
|
|
21
|
+
/** @type {?} */
|
|
22
|
+
CriteriaObj.prototype.high;
|
|
23
|
+
/** @type {?} */
|
|
24
|
+
CriteriaObj.prototype.DataType;
|
|
25
|
+
/** @type {?} */
|
|
26
|
+
CriteriaObj.prototype.listValue;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3JpdGVyaWFPYmoubW9kZWwuanMiLCJzb3VyY2VSb290Ijoibmc6Ly91Y3NlYXJjaC8iLCJzb3VyY2VzIjpbImxpYi9tb2RlbC9Dcml0ZXJpYU9iai5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsTUFBTSxPQUFPLFdBQVc7SUFTcEI7UUFDSSxJQUFJLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQztRQUNiLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2QsSUFBSSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUM7SUFDM0IsQ0FBQztDQUVKOzs7SUFkRywrQkFBaUI7O0lBQ2pCLGtDQUFvQjs7SUFDcEIsNEJBQWM7O0lBQ2QsMEJBQVk7O0lBQ1osMkJBQWE7O0lBQ2IsK0JBQWlCOztJQUNqQixnQ0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgQ3JpdGVyaWFPYmoge1xyXG4gICAgcHJvcE5hbWU6IHN0cmluZztcclxuICAgIHJlc3RyaWN0aW9uOiBzdHJpbmc7XHJcbiAgICB2YWx1ZTogc3RyaW5nO1xyXG4gICAgbG93OiBudW1iZXI7XHJcbiAgICBoaWdoOiBudW1iZXI7XHJcbiAgICBEYXRhVHlwZTogc3RyaW5nO1xyXG4gICAgbGlzdFZhbHVlOiBBcnJheTxhbnk+O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgICAgIHRoaXMubG93ID0gMDtcclxuICAgICAgICB0aGlzLmhpZ2ggPSAwO1xyXG4gICAgICAgIHRoaXMuRGF0YVR5cGUgPSAnVGV4dCc7XHJcbiAgICB9XHJcblxyXG59Il19
|