/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ViewChild, Input, Output, EventEmitter } from '@angular/core';
import { AppConfigService } from '../app-config/app-config.service';
import { DxDataGridComponent } from 'devextreme-angular';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { ModalAttachmentComponent } from '../modal-attachment/modal-attachment.component';
import * as _ from 'lodash';
import { CreateAlertComponent } from '../alert/alert.component';
import { B2bService } from '../_services/b2b.service';
import { ModalAttachmentViewComponent } from '../modal-attachment-view/modal-attachment-view.component';
export class AttachmentListComponent {
/**
* @param {?} appConfigService
* @param {?} request
* @param {?} common
* @param {?} b2b
*/
constructor(appConfigService, request, common, b2b) {
this.appConfigService = appConfigService;
this.request = request;
this.common = common;
this.b2b = b2b;
this.mode = 'CREATE';
this.type = 2;
this.showImage = false;
this.onLoaded = new EventEmitter();
this.onClickScan = new EventEmitter();
this.onClickDelete = new EventEmitter();
this.columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];
this.attachmentList = [];
this.dxgridPageSize = 10;
this.allowedPageSizes1 = 10;
this.allowedPageSizes2 = 25;
this.allowedPageSizes3 = 50;
this.allowedPageSizes4 = 100;
this.customers = [];
this.lastStep = '';
this.deleteIdList = [];
this.dsAttachment = [];
this.selectedAttachment = [];
this.tmpId = -1;
this.classifieds = 0;
this.username_caption = 'ผู้บันทึก/ผู้นำเข้า';
this.config = appConfigService.getConfig();
}
/**
* @return {?}
*/
ngOnInit() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
setTimeout(() => tslib_1.__awaiter(this, void 0, void 0, function* () {
this.downloadToken = yield this.b2b.getAttachmentToken();
}), 500);
if (this.mode !== "CREATE") {
this.getAttachmentList();
}
});
}
/**
* @return {?}
*/
getAttachmentList() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
console.log('getAttachmentList', this.attachmentList, this.option.username_caption);
/** @type {?} */
let filter = {
filter: {
ref_table: this.option.data.ref_table,
ref_id: this.option.data.ref_id,
system_id: this.option.data.system_id
},
order_by: ["order_no"]
};
if (this.option.data.result_table_id)
filter.filter.result_table_id = this.option.data.result_table_id;
/** @type {?} */
const data = yield this.request.post('/search/rc_attachment_prop', filter);
this.attachmentList = data.resultData;
this.classifieds = 0;
for (let i of this.attachmentList) {
if (i.is_classifieds) {
this.classifieds++;
}
}
console.log('getAttachmentList', this.attachmentList);
this.onLoaded.emit();
});
}
/**
* @param {?} data
* @return {?}
*/
addAttachmentList(data) {
data.id = this.tmpId;
this.tmpId--;
if (this.b2b.getVerifyToken().phoneBookData && this.b2b.getVerifyToken().phoneBookData.length > 0) {
data.username = this.b2b.getVerifyToken().username;
data.recorder_name = this.b2b.getVerifyToken().phoneBookData[0].name;
}
data.action = "add";
if (data.is_classifieds) {
this.classifieds++;
}
this.attachmentList.push(data);
console.log('getAttachmentList', this.attachmentList);
}
/**
* @param {?} data
* @return {?}
*/
editAttachmentList(data) {
for (let i = 0; i < this.attachmentList.length; i++) {
if (this.attachmentList[i].id === data.id) {
if (data.is_classifieds && !this.attachmentList[i].is_classifieds) {
this.classifieds++;
}
else if (!data.is_classifieds && this.attachmentList[i].is_classifieds) {
this.classifieds--;
}
this.attachmentList[i] = data;
}
}
console.log('getAttachmentList', this.attachmentList);
}
/**
* @param {?} data
* @return {?}
*/
getRowIndex(data) {
if (!data.data) {
return '';
}
data.data.order_no = data.component.pageIndex() * data.component.pageSize() + data.rowIndex + 1;
return data.data.order_no;
}
/**
* @return {?}
*/
clickAdd() {
this.option.mode = 'CREATE';
if (this.attachmentModal) {
this.attachmentModal.open(this.option);
}
else {
this.modalAttachment.open(this.option);
}
}
/**
* @param {?} data
* @return {?}
*/
clickEdit(data) {
console.log('clickEdit', data);
/** @type {?} */
let fileName = data.filename;
/** @type {?} */
let fileType = fileName.substring(fileName.length - 3, fileName.length);
console.log('fileType', fileType);
if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {
/** @type {?} */
const editData = _.cloneDeep(this.option);
editData.data = data;
editData.mode = 'EDIT';
editData.downloadToken = this.downloadToken;
this.onClickScan.emit(editData);
}
else {
/** @type {?} */
const editData = _.cloneDeep(this.option);
editData.data = data;
editData.mode = 'EDIT';
editData.downloadToken = this.downloadToken;
if (this.attachmentModal) {
this.attachmentModal.open(editData);
}
else {
this.modalAttachment.open(editData);
}
}
}
/**
* @param {?} data
* @return {?}
*/
clickView(data) {
/** @type {?} */
let fileName = data.filename;
/** @type {?} */
let fileType = fileName.substring(fileName.length - 3, fileName.length);
console.log('fileType', fileType);
if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {
/** @type {?} */
const viewData = _.cloneDeep(this.option);
viewData.data = data;
viewData.mode = 'VIEW';
this.onClickScan.emit(viewData);
}
else {
/** @type {?} */
const viewData = _.cloneDeep(this.option);
viewData.data = data;
viewData.mode = 'VIEW';
viewData.downloadToken = this.downloadToken;
if (this.attachmentViewModal) {
this.attachmentViewModal.open(viewData);
}
else {
this.modalAttachmentView.open(viewData);
}
}
}
/**
* @param {?} data
* @return {?}
*/
clickMoveUp(data) {
/** @type {?} */
let tmp = this.attachmentList[data.rowIndex];
this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex - 1];
this.attachmentList[data.rowIndex - 1] = tmp;
}
/**
* @param {?} data
* @return {?}
*/
clickMoveDown(data) {
/** @type {?} */
let tmp = this.attachmentList[data.rowIndex];
this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex + 1];
this.attachmentList[data.rowIndex + 1] = tmp;
}
/**
* @param {?} data
* @return {?}
*/
clickDownload(data) {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
window.open(data.url + "?downloadToken=" + this.downloadToken);
});
}
/**
* @return {?}
*/
getLastStep() {
return this.lastStep;
}
/**
* START DELETE
* @param {?} idList
* @return {?}
*/
fnClickDelete(idList) {
this.onClickDelete.emit();
this.deleteIdList = idList;
if (this.deleteIdList.length > 0) {
this.confirmDelete();
}
}
/**
* @return {?}
*/
confirmDelete() {
this.goAlert('', '', 'myModalDeleteAttachment');
}
/**
* @param {?} userTitle
* @param {?} userMessage
* @param {?} modalId
* @return {?}
*/
goAlert(userTitle, userMessage, modalId) {
/** @type {?} */
const dataAlert = {
'modalId': modalId,
'userTitle': userTitle,
'userMessage': userMessage
};
if (this.alertModal) {
this.alertModal.openModal(dataAlert);
}
else {
this.myModal.openModal(dataAlert);
}
}
/**
* @param {?} e
* @return {?}
*/
onCellPrepared(e) {
if (e.rowType === 'data') {
e.cellElement.accessKey = e.column.caption;
}
}
/**
* @return {?}
*/
fnDeleteMultiple() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
console.log("this.deleteIdList", this.deleteIdList);
console.log("this.attachmentList before", this.attachmentList);
for (let id of this.deleteIdList) {
for (let i = this.attachmentList.length - 1; i >= 0; i--) {
if (this.attachmentList[i].id === id) {
if (this.attachmentList[i].is_classifieds) {
this.classifieds--;
}
this.attachmentList.splice(i, 1);
}
}
}
console.log("this.attachmentList after", this.attachmentList);
});
}
/**
* @return {?}
*/
onClickBack() {
console.log("clickback");
}
/**
* @param {?} data
* @return {?}
*/
getImageLink(data) {
return data.url + "?downloadToken=" + this.downloadToken;
}
/**
* @return {?}
*/
scan() {
this.option.mode = 'CREATE';
this.onClickScan.emit(this.option);
}
}
AttachmentListComponent.decorators = [
{ type: Component, args: [{
selector: 'soc-attachment-list',
template: "
\n
\n
\n \n \n \n \n \n \n
\n
\n \n
\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
![]()
\n
\n \n {{getRowIndex(data)}}\n
\n \n \n
\n
\n
\n\n\n\n\n\n"
}] }
];
/** @nocollapse */
AttachmentListComponent.ctorParameters = () => [
{ type: AppConfigService },
{ type: Request },
{ type: Common },
{ type: B2bService }
];
AttachmentListComponent.propDecorators = {
mode: [{ type: Input }],
type: [{ type: Input }],
option: [{ type: Input }],
showImage: [{ type: Input }],
alertModal: [{ type: Input }],
attachmentModal: [{ type: Input }],
attachmentViewModal: [{ type: Input }],
onLoaded: [{ type: Output }],
onClickScan: [{ type: Output }],
onClickDelete: [{ type: Output }],
dxDataGridAttachmentList: [{ type: ViewChild, args: ['dxDataGridAttachmentList',] }],
modalAttachment: [{ type: ViewChild, args: ['modalAttachment',] }],
modalAttachmentView: [{ type: ViewChild, args: ['modalAttachmentView',] }],
myModal: [{ type: ViewChild, args: ['myModal',] }]
};
if (false) {
/** @type {?} */
AttachmentListComponent.prototype.mode;
/** @type {?} */
AttachmentListComponent.prototype.type;
/** @type {?} */
AttachmentListComponent.prototype.option;
/** @type {?} */
AttachmentListComponent.prototype.showImage;
/** @type {?} */
AttachmentListComponent.prototype.alertModal;
/** @type {?} */
AttachmentListComponent.prototype.attachmentModal;
/** @type {?} */
AttachmentListComponent.prototype.attachmentViewModal;
/** @type {?} */
AttachmentListComponent.prototype.onLoaded;
/** @type {?} */
AttachmentListComponent.prototype.onClickScan;
/** @type {?} */
AttachmentListComponent.prototype.onClickDelete;
/** @type {?} */
AttachmentListComponent.prototype.dxDataGridAttachmentList;
/** @type {?} */
AttachmentListComponent.prototype.modalAttachment;
/** @type {?} */
AttachmentListComponent.prototype.modalAttachmentView;
/** @type {?} */
AttachmentListComponent.prototype.myModal;
/** @type {?} */
AttachmentListComponent.prototype.columns;
/** @type {?} */
AttachmentListComponent.prototype.attachmentList;
/** @type {?} */
AttachmentListComponent.prototype.th;
/** @type {?} */
AttachmentListComponent.prototype.dxgridPageSize;
/** @type {?} */
AttachmentListComponent.prototype.allowedPageSizes1;
/** @type {?} */
AttachmentListComponent.prototype.allowedPageSizes2;
/** @type {?} */
AttachmentListComponent.prototype.allowedPageSizes3;
/** @type {?} */
AttachmentListComponent.prototype.allowedPageSizes4;
/** @type {?} */
AttachmentListComponent.prototype.customers;
/** @type {?} */
AttachmentListComponent.prototype.url;
/** @type {?} */
AttachmentListComponent.prototype.lastStep;
/** @type {?} */
AttachmentListComponent.prototype.config;
/** @type {?} */
AttachmentListComponent.prototype.deleteIdList;
/** @type {?} */
AttachmentListComponent.prototype.dsAttachment;
/** @type {?} */
AttachmentListComponent.prototype.selectedAttachment;
/** @type {?} */
AttachmentListComponent.prototype.tmpId;
/** @type {?} */
AttachmentListComponent.prototype.classifieds;
/** @type {?} */
AttachmentListComponent.prototype.downloadToken;
/** @type {?} */
AttachmentListComponent.prototype.username_caption;
/** @type {?} */
AttachmentListComponent.prototype.appConfigService;
/** @type {?} */
AttachmentListComponent.prototype.request;
/** @type {?} */
AttachmentListComponent.prototype.common;
/** @type {?} */
AttachmentListComponent.prototype.b2b;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-list.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/attachment-list/attachment-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, Input, Output, EventEmitter } from '@angular/core';\nimport { ModalStepComponent } from '../modal-step/modal-step.component';\nimport { AppConfigService } from '../app-config/app-config.service';\nimport { DxDataGridComponent } from 'devextreme-angular';\nimport { Request } from '../_services/request.service';\nimport { Common } from '../_services/common.service';\nimport { ModalStepViewComponent } from '../modal-step-view/modal-step-view.component';\nimport { ModalAttachmentComponent } from '../modal-attachment/modal-attachment.component';\nimport * as _ from 'lodash';\nimport { CreateAlertComponent } from '../alert/alert.component';\nimport { B2bService } from '../_services/b2b.service';\nimport { ModalAttachmentViewComponent } from '../modal-attachment-view/modal-attachment-view.component';\n\n@Component({\n    selector: 'soc-attachment-list',\n    templateUrl: './attachment-list.component.html'\n})\nexport class AttachmentListComponent implements OnInit {\n\n    @Input() mode: 'CREATE' | 'EDIT' | 'VIEW' = 'CREATE';\n    @Input() type: number = 2;\n    @Input() option: any;\n    @Input() showImage: boolean = false;\n    @Input() alertModal: CreateAlertComponent;\n    @Input() attachmentModal: ModalAttachmentComponent;\n    @Input() attachmentViewModal: ModalAttachmentViewComponent;\n    @Output() onLoaded = new EventEmitter();\n    @Output() onClickScan = new EventEmitter();\n    @Output() onClickDelete = new EventEmitter();\n    @ViewChild('dxDataGridAttachmentList')\n    dxDataGridAttachmentList: DxDataGridComponent;\n    // @ViewChild('modalStep')\n    // modalStep: ModalStepComponent;\n    @ViewChild('modalAttachment')\n    modalAttachment: ModalAttachmentComponent;\n    @ViewChild('modalAttachmentView')\n    modalAttachmentView: ModalAttachmentViewComponent;\n    @ViewChild('myModal') myModal;\n\n    columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];\n    attachmentList: any = [];\n    th;\n    dxgridPageSize = 10;\n    allowedPageSizes1 = 10;\n    allowedPageSizes2 = 25;\n    allowedPageSizes3 = 50;\n    allowedPageSizes4 = 100;\n    customers = [];\n    url;\n    lastStep = '';\n    config: any;\n    deleteIdList = [];\n    dsAttachment = [];\n    selectedAttachment = [];\n    tmpId = -1;\n    classifieds = 0;\n    downloadToken;\n    username_caption = 'ผู้บันทึก/ผู้นำเข้า'\n    constructor(\n        private appConfigService: AppConfigService,\n        private request: Request,\n        private common: Common,\n        private b2b: B2bService\n    ) {\n        this.config = appConfigService.getConfig();\n    }\n\n    async ngOnInit() {\n        setTimeout(async () => {\n            this.downloadToken = await this.b2b.getAttachmentToken();\n        }, 500)\n        if (this.mode !== \"CREATE\") {\n            this.getAttachmentList();\n        }\n    }\n    async getAttachmentList() {\n\n        console.log('getAttachmentList', this.attachmentList, this.option.username_caption);\n        let filter: any = {\n            filter: {\n                ref_table: this.option.data.ref_table,\n                ref_id: this.option.data.ref_id,\n                system_id: this.option.data.system_id\n            },\n            order_by: [\"order_no\"]\n        }\n        if (this.option.data.result_table_id) filter.filter.result_table_id = this.option.data.result_table_id;\n        const data = await this.request.post('/search/rc_attachment_prop', filter);\n        this.attachmentList = data.resultData;\n        this.classifieds = 0;\n        for (let i of this.attachmentList) {\n            if (i.is_classifieds) {\n                this.classifieds++;\n            }\n        }\n        console.log('getAttachmentList', this.attachmentList);\n        this.onLoaded.emit();\n    }\n\n    addAttachmentList(data) {\n        data.id = this.tmpId;\n        this.tmpId--;\n        if (this.b2b.getVerifyToken().phoneBookData && this.b2b.getVerifyToken().phoneBookData.length > 0) {\n            data.username = this.b2b.getVerifyToken().username;\n            data.recorder_name = this.b2b.getVerifyToken().phoneBookData[0].name;\n        }\n        data.action = \"add\";\n        if (data.is_classifieds) {\n            this.classifieds++;\n        }\n        this.attachmentList.push(data);\n        console.log('getAttachmentList', this.attachmentList);\n    }\n\n    editAttachmentList(data) {\n        for (let i = 0; i < this.attachmentList.length; i++) {\n            if (this.attachmentList[i].id === data.id) {\n                if (data.is_classifieds && !this.attachmentList[i].is_classifieds) {\n                    this.classifieds++;\n                } else if (!data.is_classifieds && this.attachmentList[i].is_classifieds) {\n                    this.classifieds--;\n                }\n                this.attachmentList[i] = data;\n            }\n        }\n        console.log('getAttachmentList', this.attachmentList);\n    }\n\n    getRowIndex(data) {\n        if (!data.data) {\n            return '';\n        }\n        data.data.order_no = data.component.pageIndex() * data.component.pageSize() + data.rowIndex + 1;\n        return data.data.order_no;\n    }\n    clickAdd() {\n        this.option.mode = 'CREATE';\n        if (this.attachmentModal) {\n            this.attachmentModal.open(this.option);\n        } else {\n            this.modalAttachment.open(this.option);\n        }\n    }\n    clickEdit(data) {\n        console.log('clickEdit', data)\n        let fileName = data.filename\n        let fileType = fileName.substring(fileName.length - 3, fileName.length)\n        console.log('fileType', fileType)\n        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {\n            const editData = _.cloneDeep(this.option);\n            editData.data = data;\n            editData.mode = 'EDIT';\n            editData.downloadToken = this.downloadToken;\n            this.onClickScan.emit(editData);\n        } else {\n\n            const editData = _.cloneDeep(this.option);\n            editData.data = data;\n            editData.mode = 'EDIT';\n            editData.downloadToken = this.downloadToken;\n            if (this.attachmentModal) {\n                this.attachmentModal.open(editData);\n            } else {\n                this.modalAttachment.open(editData);\n            }\n        }\n\n    }\n    clickView(data) {\n        let fileName = data.filename\n        let fileType = fileName.substring(fileName.length - 3, fileName.length)\n        console.log('fileType', fileType)\n        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {\n            const viewData = _.cloneDeep(this.option);\n            viewData.data = data;\n            viewData.mode = 'VIEW';\n            this.onClickScan.emit(viewData);\n        } else {\n            const viewData = _.cloneDeep(this.option);\n            viewData.data = data;\n            viewData.mode = 'VIEW';\n            viewData.downloadToken = this.downloadToken;\n            if (this.attachmentViewModal) {\n                this.attachmentViewModal.open(viewData);\n            } else {\n                this.modalAttachmentView.open(viewData);\n            }\n        }\n    }\n    clickMoveUp(data) {\n        let tmp = this.attachmentList[data.rowIndex];\n        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex - 1];\n        this.attachmentList[data.rowIndex - 1] = tmp;\n    }\n    clickMoveDown(data) {\n        let tmp = this.attachmentList[data.rowIndex];\n        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex + 1];\n        this.attachmentList[data.rowIndex + 1] = tmp;\n    }\n    async clickDownload(data) {\n        window.open(data.url + \"?downloadToken=\" + this.downloadToken);\n    }\n    getLastStep() {\n        return this.lastStep;\n    }\n    /** START DELETE */\n    fnClickDelete(idList: any[]) {\n        this.onClickDelete.emit();\n        this.deleteIdList = idList;\n        if (this.deleteIdList.length > 0) {\n            this.confirmDelete();\n        }\n    }\n    confirmDelete() {\n        this.goAlert('', '', 'myModalDeleteAttachment');\n    }\n\n    goAlert(userTitle, userMessage, modalId) {\n        const dataAlert = {\n            'modalId': modalId,\n            'userTitle': userTitle,\n            'userMessage': userMessage\n        };\n        if (this.alertModal) {\n            this.alertModal.openModal(dataAlert);\n        } else {\n            this.myModal.openModal(dataAlert);\n        }\n    }\n\n    onCellPrepared(e) {\n        if (e.rowType === 'data') {\n            e.cellElement.accessKey = e.column.caption;\n        }\n    }\n\n    async fnDeleteMultiple() {\n        console.log(\"this.deleteIdList\", this.deleteIdList);\n        console.log(\"this.attachmentList before\", this.attachmentList);\n        for (let id of this.deleteIdList) {\n            for (let i = this.attachmentList.length - 1; i >= 0; i--) {\n                if (this.attachmentList[i].id === id) {\n                    if (this.attachmentList[i].is_classifieds) {\n                        this.classifieds--;\n                    }\n                    this.attachmentList.splice(i, 1);\n                }\n            }\n        }\n        console.log(\"this.attachmentList after\", this.attachmentList);\n    }\n    onClickBack() {\n        console.log(\"clickback\");\n    }\n\n    getImageLink(data) {\n        return data.url + \"?downloadToken=\" + this.downloadToken;\n    }\n\n    scan() {\n        this.option.mode = 'CREATE';\n        this.onClickScan.emit(this.option);\n    }\n\n}\n"]}