/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Injectable } from '@angular/core'; import { Http, Headers, URLSearchParams, RequestOptions } from '@angular/http'; import { Observable } from 'rxjs'; import 'rxjs/add/operator/map'; import 'rxjs/add/operator/catch'; import { Router } from '@angular/router'; import * as _ from 'lodash'; import * as is from 'is_js'; import { ResultCode as RESULT_CODE } from '../model/result-code'; import { AppConfigService } from '../app-config/app-config.service'; import { Common } from './common.service'; import { B2bService } from './b2b.service'; import { HttpClient, HttpHeaders } from '@angular/common/http'; export class Request { /** * @param {?} appConfigService * @param {?} httpClient * @param {?} http * @param {?} router * @param {?} common * @param {?} b2bService */ constructor(appConfigService, httpClient, http, router, common, b2bService) { this.appConfigService = appConfigService; this.httpClient = httpClient; this.http = http; this.router = router; this.common = common; this.b2bService = b2bService; this.config = appConfigService.getConfig(); this.api = _.get(this.config, 'apiServers.tomcat.url'); this.system_id = _.get(this.config, 'system_id'); // this.api = 'https://d.gaizers.com/RestAPI'; } /** * fn. get data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น * @param {?} customStoreOptions โยนค่าต่าง ๆ มาในนี้ * @return {?} */ getCustomStore(customStoreOptions) { /** @type {?} */ const url = customStoreOptions.url || ''; /** @type {?} */ const data = customStoreOptions.filter || {}; /** @type {?} */ const loadMode = customStoreOptions.loadMode || 'processed'; /** @type {?} */ const params = new URLSearchParams(); for (const key in data) { if (key === 'filter') { if (data[key] !== '{}') { params.set(key, data[key]); } } else { params.set(key, data[key]); } } console.log('​Request -> getCustomStore -> params', params); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); options.search = params; return this.http.get(this.api + url, options) .map((res) => { /** @type {?} */ const resData = res.json(); console.log('​Request -> getCustomStore -> resData', resData); if (loadMode === 'processed') { return this.fnHandleResponseProcessedMode(resData); } else { return this.fnHandleResponseRawMode(resData); } }) .toPromise() .catch((error) => { console.log('​Request -> getCustomStore -> error', error); if (loadMode === 'processed') { return this.fnHandleErrorProcessedMode(error); } else { return this.fnHandleErrorRawMode(error); } }); } /** * fn. post data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น * @param {?} customStoreOptions โยนค่าต่าง ๆ มาในนี้ * @return {?} */ postCustomStore(customStoreOptions) { return tslib_1.__awaiter(this, void 0, void 0, function* () { /** @type {?} */ const url = customStoreOptions.url || ''; /** @type {?} */ const data = JSON.parse(JSON.stringify(customStoreOptions.filter, this.common.replacer)) || {}; /** @type {?} */ const loadMode = customStoreOptions.loadMode || 'processed'; /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(this.api + url, data, options) .map((res) => { /** @type {?} */ const resData = res.json(); console.log('​Request -> getCustomStore -> resData', resData); if (loadMode === 'processed') { return this.fnHandleResponseProcessedMode(resData); } else { return this.fnHandleResponseRawMode(resData); } }) .toPromise() .catch((error) => { console.log('​Request -> getCustomStore -> error', error); if (loadMode === 'processed') { return this.fnHandleErrorProcessedMode(error); } else { return this.fnHandleErrorRawMode(error); } }); }); } /** * fn. post data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น * @param {?} customStoreOptions โยนค่าต่าง ๆ มาในนี้ * @return {?} */ postCustomStore31(customStoreOptions) { return tslib_1.__awaiter(this, void 0, void 0, function* () { /** @type {?} */ const url = customStoreOptions.url || ''; /** @type {?} */ const data = JSON.parse(JSON.stringify(customStoreOptions.filter, this.common.replacer)) || {}; /** @type {?} */ const loadMode = customStoreOptions.loadMode || 'processed'; /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: 31, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(this.api + url, data, options) .map((res) => { /** @type {?} */ const resData = res.json(); console.log('​Request -> getCustomStore -> resData', resData); if (loadMode === 'processed') { return this.fnHandleResponseProcessedMode(resData); } else { return this.fnHandleResponseRawMode(resData); } }) .toPromise() .catch((error) => { console.log('​Request -> getCustomStore -> error', error); if (loadMode === 'processed') { return this.fnHandleErrorProcessedMode(error); } else { return this.fnHandleErrorRawMode(error); } }); }); } /** * ถ้า getCustomStore แล้ว error กรณี loadMode = 'processed' * @param {?} error * @return {?} */ fnHandleErrorProcessedMode(error) { // alert('ERROR ' + error); console.error('ERROR ' + error); return { data: [], totalCount: 0 }; } /** * ถ้า getCustomStore แล้ว error กรณี loadMode = 'raw' * @param {?} error * @return {?} */ fnHandleErrorRawMode(error) { // alert('ERROR ' + error); console.error('ERROR ' + error); return []; } /** * fn. get data สำหรับดึงข้อมูลทั่วไป * @param {?} url ex /test * @param {?=} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ get(url, data) { /** @type {?} */ const params = new URLSearchParams(); for (const key in data) { if (key === 'filter') { if (data[key] !== '{}') { params.set(key, data[key]); } } else { params.set(key, data[key]); } } console.log('​Request -> getCustomStore -> params', params); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Authorization', 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IlRlc3QiLCJzZXNzaW9uSWQiOiJjNzQwNDdiZi1jNGUwLTQxOTMtOTRiNy1jOGI4M2ViYjhlMGMiLCJpYXQiOjE1NDM5NDYyNDYsImV4cCI6MTU0NDU1MTA0Nn0.5y9f2ZYieRZHhGIMTryxuvsAjJYzvFnWnpcYLk1hSXw'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); options.search = params; return this.http.get(this.api + url, options) .map((res) => { /** @type {?} */ const resData = res.json(); return this.fnHandleResponse(resData); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. get data สำหรับดึงข้อมูลทั่วไป * @param {?} url ex /test * @param {?=} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ get31(url, data) { /** @type {?} */ const params = new URLSearchParams(); for (const key in data) { if (key === 'filter') { if (data[key] !== '{}') { params.set(key, data[key]); } } else { params.set(key, data[key]); } } console.log('​Request -> getCustomStore -> params', params); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: 31, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Authorization', 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IlRlc3QiLCJzZXNzaW9uSWQiOiJjNzQwNDdiZi1jNGUwLTQxOTMtOTRiNy1jOGI4M2ViYjhlMGMiLCJpYXQiOjE1NDM5NDYyNDYsImV4cCI6MTU0NDU1MTA0Nn0.5y9f2ZYieRZHhGIMTryxuvsAjJYzvFnWnpcYLk1hSXw'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); options.search = params; return this.http.get(this.api + url, options) .map((res) => { /** @type {?} */ const resData = res.json(); return this.fnHandleResponse(resData); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. get data สำหรับดึงข้อมูลทั่วไป * @param {?} url ex /test * @param {?=} headers * @return {?} */ getCustom(url, headers) { if (!headers) { headers = new Headers(); } /** @type {?} */ const options = new RequestOptions({ headers: headers }); return this.http.get(url, options) .map((res) => { /** @type {?} */ const resData = res.json(); return this.fnHandleResponse(resData); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. get data สำหรับดึงข้อมูลทั่วไป * @param {?} url ex /test * @param {?=} headers * @return {?} */ getRawResponse(url, headers) { if (!headers) { headers = new Headers(); } /** @type {?} */ const options = new RequestOptions({ headers: headers }); return this.http.get(url, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. delete data สำหรับลบข้อมูลทั่วไป * @param {?} url ex /test * @param {?=} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ delete(url, data) { /** @type {?} */ const params = new URLSearchParams(); for (const key in data) { if (key === 'filter') { if (data[key] !== '{}') { params.set(key, data[key]); } } else { params.set(key, data[key]); } } console.log('​Request -> getCustomStore -> params', params); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); options.search = params; return this.http.delete(this.api + url, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. post data สำหรับสร้างข้อมูลทั่วไป * @param {?} url ex /test * @param {?} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ post(url, data) { data = JSON.parse(JSON.stringify(data, this.common.replacer)); console.log('​post -> data', data); console.log('​post -> data', typeof data); /** @type {?} */ const params = new URLSearchParams(); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Content-Type', 'application/json'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(this.api + url, data, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. post data สำหรับสร้างข้อมูลทั่วไป * @param {?} url ex /test * @param {?} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ post31(url, data) { data = JSON.parse(JSON.stringify(data, this.common.replacer)); console.log('​post -> data', data); console.log('​post -> data', typeof data); /** @type {?} */ const params = new URLSearchParams(); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: 31, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Content-Type', 'application/json'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(this.api + url, data, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. post data สำหรับสร้างข้อมูลทั่วไป * @param {?} url ex /test * @param {?} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ post14(url, data) { data = JSON.parse(JSON.stringify(data, this.common.replacernotrim)); console.log('​post -> data', data); console.log('​post -> data', typeof data); /** @type {?} */ const params = new URLSearchParams(); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Content-Type', 'application/json'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(this.api + url, data, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. post data สำหรับสร้างข้อมูลทั่วไป * @param {?} url ex /test * @param {?} data ค่าต่างที่ต้องการแนบไปกับ API * @param {?=} headers * @return {?} */ postCustom(url, data, headers) { console.log('​post -> data', data); console.log('​post -> data', typeof data); if (!headers) { headers = new Headers(); headers.append('Content-Type', 'application/json'); } /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.post(url, data, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * fn. put data สำหรับอัพเดตข้อมูลทั่วไป * @param {?} url ex /test * @param {?} data ค่าต่างที่ต้องการแนบไปกับ API * @return {?} */ put(url, data) { /** @type {?} */ const params = new URLSearchParams(); /** @type {?} */ let userData = this.b2bService.getVerifyToken(); /** @type {?} */ let headerData = { system_id: this.system_id, department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : "", username: userData.username }; /** @type {?} */ const headers = new Headers(); headers.append('x-Token', '1'); headers.append('x-user-data', this.utoa(JSON.stringify(headerData))); headers.append('Content-Type', 'application/json'); /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.put(this.api + url, data, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); } /** * ถ้า getCustomStore แล้ว success กรณี loadMode = 'processed' * @param {?} resData * @return {?} */ fnHandleResponseProcessedMode(resData) { /** @type {?} */ const customStoreData = { data: [], totalCount: 0 }; /** @type {?} */ let code = ''; /** @type {?} */ let description = ''; /** @type {?} */ let data = []; /** @type {?} */ let rowCount = 0; if (is.array(resData)) { data = resData; rowCount = _.size(data); } else { /** เปลี่ยนไปตามรูปแบบ response */ code = resData.resultCode || ''; description = resData.resultDescription || ''; data = resData.resultData || []; rowCount = resData.rowCount || 0; // เปลี่ยนไปตาม Response /** */ } if (code === RESULT_CODE.ERROR) { console.log('​fnHandleResponseProcessedMode -> RESULT_CODE.ERROR', RESULT_CODE.ERROR); } else if (code === RESULT_CODE.NOT_FOUND) { console.log('​fnHandleResponseProcessedMode -> RESULT_CODE.NOT_FOUND', RESULT_CODE.NOT_FOUND); } else { customStoreData.data = data; customStoreData.totalCount = rowCount; } return customStoreData; } /** * ถ้า getCustomStore แล้ว success กรณี loadMode = 'raw' * @param {?} resData * @return {?} */ fnHandleResponseRawMode(resData) { /** @type {?} */ let code = ''; /** @type {?} */ let description = ''; /** @type {?} */ let data = []; if (is.array(resData)) { data = resData; } else { /** เปลี่ยนไปตามรูปแบบ response */ code = resData.resultCode || ''; description = resData.resultDescription || ''; data = resData.resultData || []; /** */ } if (code === RESULT_CODE.ERROR) { alert('ERROR:' + RESULT_CODE.ERROR); return []; } else if (code === RESULT_CODE.NOT_FOUND) { alert('ERROR:' + RESULT_CODE.NOT_FOUND); return []; } else { return data; } } /** * @param {?} resData * @return {?} */ fnHandleResponse(resData) { /** @type {?} */ let code = ''; /** @type {?} */ let description = ''; /** @type {?} */ let data = []; if (is.array(resData)) { data = resData; } else if (resData.data && is.array(resData.data)) { data = resData.data; } else { /** เปลี่ยนไปตามรูปแบบ response */ code = resData.resultCode || ''; description = resData.resultDescription || ''; data = resData.resultData || []; /** */ } if (code === RESULT_CODE.ERROR) { console.log('​fnHandleResponse -> RESULT_CODE.ERROR', RESULT_CODE.ERROR); return []; } else if (code === RESULT_CODE.NOT_FOUND) { console.log('​fnHandleResponse -> RESULT_CODE.NOT_FOUND', RESULT_CODE.NOT_FOUND); return []; } else { return data; } } /** * fn ดึงข้อมูลเพื่อใช้ใน Dropdown List * @param {?} systemId เลขรหัสระบบที่ต้องการดึง * @param {?} dropDownType ประเภทข้อมูล dropdown ที่ต้องการดึง * @param {?=} code * @return {?} */ getDropDown(systemId, dropDownType, code) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const data = { filter: { system_id: systemId, dropdown_type: dropDownType, code: code }, limit: 1000, offset: 0, order_by: ['id asc'] }; /** @type {?} */ const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_dropdown_search'); if (systemId === 31) { /** @type {?} */ const resData = yield this.post31(urlDropdown, data); return resData.resultData; } else { /** @type {?} */ const resData = yield this.post(urlDropdown, data); return resData.resultData; } } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?=} parentId * @return {?} */ getDepartment(parentId = 0) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const data = { filter: { ref_department_id: parentId }, limit: 1000, offset: 0, order_by: ['name asc'] }; /** @type {?} */ const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_department_search'); /** @type {?} */ const resData = yield this.post(urlDropdown, data); return resData.resultData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @return {?} */ getExtDepartment() { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const data = { filter: {}, limit: 1000, offset: 0, order_by: ['name asc'] }; /** @type {?} */ const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_ext_department_search'); /** @type {?} */ const resData = yield this.post(urlDropdown, data); return resData.resultData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?} system_id * @return {?} */ getCategory(system_id) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const urlStep = _.get(this.config, 'apiServers.tomcat.api.ct_category'); /** @type {?} */ const params = `?_where=(system_id,eq,${system_id})&_sort=seq_no`; /** @type {?} */ const resData = yield this.get(urlStep + params); return resData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?} category_id * @return {?} */ getStepName(category_id) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const urlStep = _.get(this.config, 'apiServers.tomcat.api.ct_step'); /** @type {?} */ const params = `?_where=(category_id,eq,${category_id})&_sort=seq_no`; /** @type {?} */ const resData = yield this.get(urlStep + params); return resData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?} url * @return {?} */ getAttachment(url) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const headers = new Headers(); headers.append('Authorization', 'Basic ' + btoa('APPSOC:123456')); /** @type {?} */ const resData = yield this.getCustom(url, headers); return resData; } catch (error) { console.log('catch -> error', error); return error; } }); } /** * @param {?} url * @param {?} data * @return {?} */ postAttachment(url, data) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const headers = new Headers(); headers.append('Authorization', 'Basic ' + btoa('APPSOC:123456')); headers.append('test', 'test'); /** @type {?} */ const resData = yield this.postCustom(url, data, headers); return resData; } catch (error) { console.log('catch -> error', error); return error; } }); } /** * @return {?} */ getUserLevel() { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ const data = { filter: {}, limit: 1000, offset: 0, order_by: ['level asc'] }; /** @type {?} */ const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_user_level_search'); /** @type {?} */ const resData = yield this.post(urlDropdown, data); return resData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?} table * @param {?} idList * @return {?} */ multipleDeleteMain(table, idList) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ let url = "/" + table.split("_")[0] + "/main"; /** @type {?} */ let deleteObj = {}; deleteObj[table] = []; for (let id of idList) { /** @type {?} */ let tmp = { id: id, action: "delete" }; deleteObj[table].push(tmp); } /** @type {?} */ const resData = yield this.post(url, [deleteObj]); if (resData.resultCode === 20000) { idList = []; } return resData; } catch (error) { console.log('catch -> error', error); return []; } }); } /** * @param {?} url * @return {?} */ getAttachmentLinkToken(url) { return tslib_1.__awaiter(this, void 0, void 0, function* () { return url + '?downloadToken=' + this.b2bService.getAttachmentToken() + '&inline=true'; }); } /** * @param {?} data * @param {?} fieldList * @param {?} modal * @return {?} */ checkSpell(data, fieldList, modal) { return tslib_1.__awaiter(this, void 0, void 0, function* () { /** @type {?} */ let url = "/spellCheck"; /** @type {?} */ let body = {}; for (let field of fieldList) { if (data[field.field]) { body[field.field] = { value: data[field.field], display: field.display }; } } /** @type {?} */ let resData = yield this.post(url, body); /** @type {?} */ let spellCheck = JSON.parse(resData.resultData); if (_.size(spellCheck) === 0) { return true; } else { modal.open(spellCheck); return false; } }); } /** * @param {?} url * @param {?=} headers * @return {?} */ getQualification(url, headers) { return tslib_1.__awaiter(this, void 0, void 0, function* () { if (!headers) { headers = new Headers(); } /** @type {?} */ const options = new RequestOptions({ headers: headers, withCredentials: true }); return this.http.get(url, options) .map((res) => { return res.json(); }) .catch((error) => Observable.throw(error.json().error || 'Server error')).toPromise(); }); } /** * @return {?} */ verifyUserName() { return tslib_1.__awaiter(this, void 0, void 0, function* () { /** @type {?} */ let verifyToken = yield this.b2bService.verify(); if (+verifyToken.resultCode === 20000) { /** @type {?} */ let data = verifyToken.resultData; /** @type {?} */ let phoneBookData = data.phoneBookData && data.phoneBookData.length > 0 ? data.phoneBookData[0] : {}; return phoneBookData.name; } }); } /** * @param {?} str * @return {?} */ utoa(str) { return window.btoa(unescape(encodeURIComponent(str))); } /** * @param {?} api * @return {?} */ downloadImgToBase64(api) { return new Promise((resolve, reject) => tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ let httpOptions = { headers: new HttpHeaders({ "Authorization": "Basic " + btoa('APPSOC:123456') }) }; /** @type {?} */ let blob = yield this.httpClient.get(api, { headers: httpOptions.headers, responseType: "blob" }).toPromise(); /** @type {?} */ let reader = new FileReader(); reader.readAsDataURL(blob); reader.onloadend = function () { /** @type {?} */ var base64data = reader.result; resolve(base64data); }; } catch (err) { console.log(err); resolve(false); } })); } /** * @param {?} api * @return {?} */ downloadView(api) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ let httpOptions = { headers: new HttpHeaders({ "Authorization": "Basic " + btoa('APPSOC:123456') }) }; /** @type {?} */ let blob = yield this.httpClient.get(api, { headers: httpOptions.headers, responseType: "blob" }).toPromise(); /** @type {?} */ let url = window.URL.createObjectURL(blob, { oneTimeOnly: true }); window.open(url, '_blank'); } catch (err) { console.log(err); } }); } /** * @param {?} api * @return {?} */ download(api) { return tslib_1.__awaiter(this, void 0, void 0, function* () { try { /** @type {?} */ let w = window.open(); w.document.writeln(""); /** @type {?} */ let httpOptions = { headers: new HttpHeaders({ "Authorization": "Basic " + btoa('APPSOC:123456') }) }; /** @type {?} */ let blob = yield this.httpClient.get(api, { headers: httpOptions.headers, responseType: "blob" }).toPromise(); /** @type {?} */ let url = window.URL.createObjectURL(blob); w.location.href = url; } catch (err) { console.log(err); } }); } } Request.decorators = [ { type: Injectable } ]; /** @nocollapse */ Request.ctorParameters = () => [ { type: AppConfigService }, { type: HttpClient }, { type: Http }, { type: Router }, { type: Common }, { type: B2bService } ]; if (false) { /** @type {?} */ Request.prototype.config; /** @type {?} */ Request.prototype.api; /** @type {?} */ Request.prototype.system_id; /** @type {?} */ Request.prototype.appConfigService; /** @type {?} */ Request.prototype.httpClient; /** @type {?} */ Request.prototype.http; /** @type {?} */ Request.prototype.router; /** @type {?} */ Request.prototype.common; /** @type {?} */ Request.prototype.b2bService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request.service.js","sourceRoot":"ng://soc-app-library/","sources":["lib/_services/request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {Http, Headers, Response, URLSearchParams, RequestOptions} from '@angular/http';\nimport {Observable} from 'rxjs';\n// import { environment } from '../../../environments/environment';\n// Import RxJs required methods\nimport 'rxjs/add/operator/map';\nimport 'rxjs/add/operator/catch';\nimport {Router} from '@angular/router';\nimport * as _ from 'lodash';\nimport * as is from 'is_js';\nimport {CustomStoreData} from '../model/custom-store-data';\nimport {CustomStoreOptions} from '../model/custom-store-options';\nimport {ResultCode as RESULT_CODE} from '../model/result-code';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport {Common} from './common.service';\nimport {B2bService} from './b2b.service';\nimport {ModalSpellCheckComponent} from '../modal-spell-check/modal-spell-check.component';\nimport {HttpClient, HttpEvent, HttpEventType, HttpHeaders, HttpRequest, HttpResponse} from '@angular/common/http';\n@Injectable()\nexport class Request {\n    config: any;\n    api: any;\n    system_id: any;\n\n    constructor(private appConfigService: AppConfigService, public httpClient: HttpClient, public http: Http, private router: Router, private common: Common, private b2bService: B2bService) {\n        this.config = appConfigService.getConfig();\n        this.api = _.get(this.config, 'apiServers.tomcat.url');\n        this.system_id = _.get(this.config, 'system_id');\n        // this.api = 'https://d.gaizers.com/RestAPI';\n    }\n\n    /**\n     * fn. get data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น\n     * @param customStoreOptions โยนค่าต่าง ๆ มาในนี้\n     */\n    getCustomStore(customStoreOptions: CustomStoreOptions) {\n        const url = customStoreOptions.url || '';\n        const data = customStoreOptions.filter || {};\n        const loadMode = customStoreOptions.loadMode || 'processed';\n        const params: URLSearchParams = new URLSearchParams();\n        for (const key in data) {\n            if (key === 'filter') {\n                if (data[key] !== '{}') {\n                    params.set(key, data[key]);\n                }\n            } else {\n                params.set(key, data[key]);\n            }\n        }\n        console.log('​Request -> getCustomStore -> params', params);\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        options.search = params;\n        return this.http.get(this.api + url, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                console.log('​Request -> getCustomStore -> resData', resData);\n                if (loadMode === 'processed') {\n                    return this.fnHandleResponseProcessedMode(resData);\n                } else {\n                    return this.fnHandleResponseRawMode(resData);\n                }\n            })\n            .toPromise()\n            .catch((error: any) => {\n                console.log('​Request -> getCustomStore -> error', error);\n                if (loadMode === 'processed') {\n                    return this.fnHandleErrorProcessedMode(error);\n                } else {\n                    return this.fnHandleErrorRawMode(error);\n                }\n            });\n\n    }\n\n    /**\n     * fn. post data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น\n     * @param customStoreOptions โยนค่าต่าง ๆ มาในนี้\n     */\n    async postCustomStore(customStoreOptions: CustomStoreOptions) {\n        const url = customStoreOptions.url || '';\n        const data = JSON.parse(JSON.stringify(customStoreOptions.filter, this.common.replacer)) || {};\n        const loadMode = customStoreOptions.loadMode || 'processed';\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(this.api + url, data, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                console.log('​Request -> getCustomStore -> resData', resData);\n                if (loadMode === 'processed') {\n                    return this.fnHandleResponseProcessedMode(resData);\n                } else {\n                    return this.fnHandleResponseRawMode(resData);\n                }\n            })\n            .toPromise()\n            .catch((error: any) => {\n                console.log('​Request -> getCustomStore -> error', error);\n                if (loadMode === 'processed') {\n                    return this.fnHandleErrorProcessedMode(error);\n                } else {\n                    return this.fnHandleErrorRawMode(error);\n                }\n            });\n\n    }\n\n    /**\n     * fn. post data สำหรับดึงข้อมูลสำหรับ Datagrid เท่านั้น\n     * @param customStoreOptions โยนค่าต่าง ๆ มาในนี้\n     */\n    async postCustomStore31(customStoreOptions: CustomStoreOptions) {\n        const url = customStoreOptions.url || '';\n        const data = JSON.parse(JSON.stringify(customStoreOptions.filter, this.common.replacer)) || {};\n        const loadMode = customStoreOptions.loadMode || 'processed';\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: 31,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(this.api + url, data, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                console.log('​Request -> getCustomStore -> resData', resData);\n                if (loadMode === 'processed') {\n                    return this.fnHandleResponseProcessedMode(resData);\n                } else {\n                    return this.fnHandleResponseRawMode(resData);\n                }\n            })\n            .toPromise()\n            .catch((error: any) => {\n                console.log('​Request -> getCustomStore -> error', error);\n                if (loadMode === 'processed') {\n                    return this.fnHandleErrorProcessedMode(error);\n                } else {\n                    return this.fnHandleErrorRawMode(error);\n                }\n            });\n\n    }\n\n    /**\n     * ถ้า getCustomStore แล้ว error กรณี loadMode = 'processed'\n     * @param error\n     */\n    fnHandleErrorProcessedMode(error) {\n        // alert('ERROR ' + error);\n        console.error('ERROR ' + error);\n        return {\n            data: [],\n            totalCount: 0\n        };\n    }\n\n    /**\n     * ถ้า getCustomStore แล้ว error กรณี loadMode = 'raw'\n     * @param error\n     */\n    fnHandleErrorRawMode(error) {\n        // alert('ERROR ' + error);\n        console.error('ERROR ' + error);\n        return [];\n    }\n\n    /**\n     * fn. get data สำหรับดึงข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    get(url, data?) {\n        const params: URLSearchParams = new URLSearchParams();\n        for (const key in data) {\n            if (key === 'filter') {\n                if (data[key] !== '{}') {\n                    params.set(key, data[key]);\n                }\n            } else {\n                params.set(key, data[key]);\n            }\n        }\n        console.log('​Request -> getCustomStore -> params', params);\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Authorization', 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IlRlc3QiLCJzZXNzaW9uSWQiOiJjNzQwNDdiZi1jNGUwLTQxOTMtOTRiNy1jOGI4M2ViYjhlMGMiLCJpYXQiOjE1NDM5NDYyNDYsImV4cCI6MTU0NDU1MTA0Nn0.5y9f2ZYieRZHhGIMTryxuvsAjJYzvFnWnpcYLk1hSXw');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        options.search = params;\n        return this.http.get(this.api + url, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                return this.fnHandleResponse(resData);\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. get data สำหรับดึงข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    get31(url, data?) {\n        const params: URLSearchParams = new URLSearchParams();\n        for (const key in data) {\n            if (key === 'filter') {\n                if (data[key] !== '{}') {\n                    params.set(key, data[key]);\n                }\n            } else {\n                params.set(key, data[key]);\n            }\n        }\n        console.log('​Request -> getCustomStore -> params', params);\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: 31,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Authorization', 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IlRlc3QiLCJzZXNzaW9uSWQiOiJjNzQwNDdiZi1jNGUwLTQxOTMtOTRiNy1jOGI4M2ViYjhlMGMiLCJpYXQiOjE1NDM5NDYyNDYsImV4cCI6MTU0NDU1MTA0Nn0.5y9f2ZYieRZHhGIMTryxuvsAjJYzvFnWnpcYLk1hSXw');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        options.search = params;\n        return this.http.get(this.api + url, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                return this.fnHandleResponse(resData);\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. get data สำหรับดึงข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    getCustom(url, headers?) {\n        if (!headers) {\n            headers = new Headers();\n        }\n        const options = new RequestOptions({headers: headers});\n        return this.http.get(url, options)\n            .map((res: Response) => {\n                const resData = res.json();\n                return this.fnHandleResponse(resData);\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. get data สำหรับดึงข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    getRawResponse(url, headers?) {\n        if (!headers) {\n            headers = new Headers();\n        }\n        const options = new RequestOptions({headers: headers});\n        return this.http.get(url, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. delete data สำหรับลบข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    delete(url, data?) {\n        const params: URLSearchParams = new URLSearchParams();\n        for (const key in data) {\n            if (key === 'filter') {\n                if (data[key] !== '{}') {\n                    params.set(key, data[key]);\n                }\n            } else {\n                params.set(key, data[key]);\n            }\n        }\n        console.log('​Request -> getCustomStore -> params', params);\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        options.search = params;\n        return this.http.delete(this.api + url, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. post data สำหรับสร้างข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    post(url, data) {\n        data = JSON.parse(JSON.stringify(data, this.common.replacer));\n        console.log('​post -> data', data);\n        console.log('​post -> data', typeof data);\n        const params: URLSearchParams = new URLSearchParams();\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Content-Type', 'application/json');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(this.api + url, data, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. post data สำหรับสร้างข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    post31(url, data) {\n        data = JSON.parse(JSON.stringify(data, this.common.replacer));\n        console.log('​post -> data', data);\n        console.log('​post -> data', typeof data);\n        const params: URLSearchParams = new URLSearchParams();\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: 31,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Content-Type', 'application/json');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(this.api + url, data, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n    /**\n     * fn. post data สำหรับสร้างข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    post14(url, data) {\n        data = JSON.parse(JSON.stringify(data, this.common.replacernotrim));\n        console.log('​post -> data', data);\n        console.log('​post -> data', typeof data);\n        const params: URLSearchParams = new URLSearchParams();\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Content-Type', 'application/json');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(this.api + url, data, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n    /**\n     * fn. post data สำหรับสร้างข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    postCustom(url, data, headers?) {\n        console.log('​post -> data', data);\n        console.log('​post -> data', typeof data)\n        if (!headers) {\n            headers = new Headers();\n            headers.append('Content-Type', 'application/json');\n        }\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.post(url, data, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * fn. put data สำหรับอัพเดตข้อมูลทั่วไป\n     * @param url ex /test\n     * @param data ค่าต่างที่ต้องการแนบไปกับ API\n     */\n    put(url, data) {\n        const params: URLSearchParams = new URLSearchParams();\n        let userData = this.b2bService.getVerifyToken();\n        let headerData : any = {\n            system_id: this.system_id,\n            department: userData.phoneBookData && userData.phoneBookData.length > 0 ? userData.phoneBookData[0].dept : \"\",\n            username: userData.username\n        }\n        const headers = new Headers();\n        headers.append('x-Token', '1');\n        headers.append('x-user-data', this.utoa(JSON.stringify(headerData)));\n        headers.append('Content-Type', 'application/json');\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.put(this.api + url, data, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    /**\n     * ถ้า getCustomStore แล้ว success กรณี loadMode = 'processed'\n     * @param resData\n     */\n    fnHandleResponseProcessedMode(resData) {\n        const customStoreData = {\n            data: [],\n            totalCount: 0\n        };\n        let code = '';\n        let description = '';\n        let data = [];\n        let rowCount = 0;\n        if (is.array(resData)) {\n            data = resData;\n            rowCount = _.size(data);\n        } else {\n            /** เปลี่ยนไปตามรูปแบบ response */\n            code = resData.resultCode || '';\n            description = resData.resultDescription || '';\n            data = resData.resultData || [];\n            rowCount = resData.rowCount || 0; // เปลี่ยนไปตาม Response\n            /** */\n        }\n        if (code === RESULT_CODE.ERROR) {\n            console.log('​fnHandleResponseProcessedMode -> RESULT_CODE.ERROR', RESULT_CODE.ERROR);\n        } else if (code === RESULT_CODE.NOT_FOUND) {\n            console.log('​fnHandleResponseProcessedMode -> RESULT_CODE.NOT_FOUND', RESULT_CODE.NOT_FOUND);\n        } else {\n            customStoreData.data = data;\n            customStoreData.totalCount = rowCount;\n        }\n        return customStoreData;\n    }\n\n    /**\n     * ถ้า getCustomStore แล้ว success กรณี loadMode = 'raw'\n     * @param resData\n     */\n    fnHandleResponseRawMode(resData) {\n        let code = '';\n        let description = '';\n        let data = [];\n        if (is.array(resData)) {\n            data = resData;\n        } else {\n            /** เปลี่ยนไปตามรูปแบบ response */\n            code = resData.resultCode || '';\n            description = resData.resultDescription || '';\n            data = resData.resultData || [];\n            /** */\n        }\n        if (code === RESULT_CODE.ERROR) {\n            alert('ERROR:' + RESULT_CODE.ERROR);\n            return [];\n        } else if (code === RESULT_CODE.NOT_FOUND) {\n            alert('ERROR:' + RESULT_CODE.NOT_FOUND);\n            return [];\n        } else {\n            return data;\n        }\n    }\n\n    fnHandleResponse(resData) {\n        let code = '';\n        let description = '';\n        let data = [];\n        if (is.array(resData)) {\n            data = resData;\n        }else if(resData.data && is.array(resData.data)){\n            data = resData.data;\n        } else {\n            /** เปลี่ยนไปตามรูปแบบ response */\n            code = resData.resultCode || '';\n            description = resData.resultDescription || '';\n            data = resData.resultData || [];\n            /** */\n        }\n\n        if (code === RESULT_CODE.ERROR) {\n            console.log('​fnHandleResponse -> RESULT_CODE.ERROR', RESULT_CODE.ERROR);\n            return [];\n        } else if (code === RESULT_CODE.NOT_FOUND) {\n            console.log('​fnHandleResponse -> RESULT_CODE.NOT_FOUND', RESULT_CODE.NOT_FOUND);\n            return [];\n        } else {\n            return data;\n        }\n    }\n\n    /**\n     * fn ดึงข้อมูลเพื่อใช้ใน Dropdown List\n     * @param systemId เลขรหัสระบบที่ต้องการดึง\n     * @param dropDownType ประเภทข้อมูล dropdown ที่ต้องการดึง\n     */\n    async getDropDown(systemId: number, dropDownType: String, code?: String) {\n        try {\n            const data = {\n                filter: {\n                    system_id: systemId,\n                    dropdown_type: dropDownType,\n                    code: code\n                },\n                limit: 1000,\n                offset: 0,\n                order_by: ['id asc']\n            };\n            const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_dropdown_search');\n            if(systemId === 31){\n                const resData = await this.post31(urlDropdown, data);\n                return resData.resultData;\n            }else{\n                const resData = await this.post(urlDropdown, data);\n                return resData.resultData;\n            }\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getDepartment(parentId: number = 0) {\n        try {\n            const data = {\n                filter: {ref_department_id: parentId},\n                limit: 1000,\n                offset: 0,\n                order_by: ['name asc']\n            };\n            const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_department_search');\n            const resData = await this.post(urlDropdown, data);\n            return resData.resultData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getExtDepartment() {\n        try {\n            const data = {\n                filter: {},\n                limit: 1000,\n                offset: 0,\n                order_by: ['name asc']\n            };\n            const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_ext_department_search');\n            const resData = await this.post(urlDropdown, data);\n            return resData.resultData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getCategory(system_id) {\n        try {\n            const urlStep = _.get(this.config, 'apiServers.tomcat.api.ct_category');\n            const params = `?_where=(system_id,eq,${system_id})&_sort=seq_no`;\n            const resData = await this.get(urlStep + params);\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getStepName(category_id) {\n        try {\n            const urlStep = _.get(this.config, 'apiServers.tomcat.api.ct_step');\n            const params = `?_where=(category_id,eq,${category_id})&_sort=seq_no`;\n            const resData = await this.get(urlStep + params);\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getAttachment(url) {\n        try {\n            const headers = new Headers();\n            headers.append('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n            const resData = await this.getCustom(url, headers);\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return error;\n        }\n    }\n\n    async postAttachment(url, data) {\n        try {\n            const headers = new Headers();\n            headers.append('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n            headers.append('test', 'test');\n            const resData = await this.postCustom(url, data, headers);\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return error;\n        }\n    }\n\n    async getUserLevel() {\n        try {\n            const data = {\n                filter: {},\n                limit: 1000,\n                offset: 0,\n                order_by: ['level asc']\n            };\n            const urlDropdown = _.get(this.config, 'apiServers.tomcat.api.ct_user_level_search');\n            const resData = await this.post(urlDropdown, data);\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async multipleDeleteMain(table, idList) {\n        try {\n            let url = \"/\" + table.split(\"_\")[0] + \"/main\";\n            let deleteObj: any = {};\n            deleteObj[table] = [];\n            for (let id of idList) {\n                let tmp = {\n                    id: id,\n                    action: \"delete\"\n                }\n                deleteObj[table].push(tmp);\n            }\n            const resData = await this.post(url, [deleteObj]);\n            if (resData.resultCode === 20000) {\n                idList = [];\n            }\n            return resData;\n        } catch (error) {\n            console.log('catch -> error', error);\n            return [];\n        }\n    }\n\n    async getAttachmentLinkToken(url) {\n        return url + '?downloadToken=' + this.b2bService.getAttachmentToken() +'&inline=true';\n    }\n\n    async checkSpell(data, fieldList, modal: ModalSpellCheckComponent) {\n        let url = \"/spellCheck\";\n        let body: any = {};\n        for (let field of fieldList) {\n            if (data[field.field]) {\n                body[field.field] = {\n                    value: data[field.field],\n                    display: field.display\n                };\n            }\n        }\n        let resData = await this.post(url, body);\n        let spellCheck = JSON.parse(resData.resultData);\n        if (_.size(spellCheck) === 0) {\n            return true;\n        } else {\n            modal.open(spellCheck);\n            return false;\n        }\n    }\n\n    async getQualification(url, headers?) {\n        if (!headers) {\n            headers = new Headers();\n        }\n        const options = new RequestOptions({headers: headers, withCredentials: true});\n        return this.http.get(url, options)\n            .map((res: Response) => {\n                return res.json();\n            })\n            .catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    async verifyUserName() {\n        let verifyToken: any = await this.b2bService.verify();\n        if (+verifyToken.resultCode === 20000) {\n            let data = verifyToken.resultData;\n            let phoneBookData = data.phoneBookData && data.phoneBookData.length > 0 ? data.phoneBookData[0] : {};\n            return phoneBookData.name;\n        }\n    }\n\n    utoa(str) {\n        return window.btoa(unescape(encodeURIComponent(str)));\n    }\n\n    downloadImgToBase64(api) {\n      return new Promise(async (resolve, reject) =>  {\n        try {\n            let httpOptions = {\n                headers: new HttpHeaders({ \"Authorization\": \"Basic \"+btoa('APPSOC:123456') })\n            }\n           let blob = await this.httpClient.get(api, { headers: httpOptions.headers, responseType: \"blob\" }).toPromise()\n           let reader = new FileReader();\n            reader.readAsDataURL(blob);\n            reader.onloadend = function() {\n                var base64data = reader.result;\n                resolve(base64data);\n            }\n        } catch (err) {\n            console.log(err);\n            resolve(false);\n        }\n      });\n    }\n\n    async downloadView(api:any) {\n        try {\n            let httpOptions = {\n                headers: new HttpHeaders({ \"Authorization\": \"Basic \"+btoa('APPSOC:123456') })\n            }\n            let blob = await this.httpClient.get(api, { headers: httpOptions.headers, responseType: \"blob\" }).toPromise()\n            let url = window.URL.createObjectURL(blob, { oneTimeOnly: true })\n             window.open(url,'_blank');\n        } catch (err) {\n          console.log(err);\n        }\n      }\n\n      async download(api:any) {\n          try {\n              let w = window.open()\n              w.document.writeln(\"\")\n              let httpOptions = {\n                  headers: new HttpHeaders({ \"Authorization\": \"Basic \"+btoa('APPSOC:123456') })\n              }\n              let blob = await this.httpClient.get(api, { headers: httpOptions.headers, responseType: \"blob\" }).toPromise()\n              let url = window.URL.createObjectURL(blob)\n              w.location.href = url\n          } catch (err) {\n            console.log(err);\n          }\n        }\n\n}\n"]}