Blame view

esm5/lib/modal-image-upload/modal-image-upload.component.js 29.5 KB
75f29219   Anan Sangthongtum   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { HttpClient, HttpEventType, HttpHeaders, HttpRequest, HttpResponse } from '@angular/common/http';
import { Observable } from 'rxjs';
import { ModalDirective } from 'ngx-bootstrap';
import { AppConfigService } from '../app-config/app-config.service';
import * as _ from 'lodash';
var ModalImageUploadComponent = /** @class */ (function () {
    function ModalImageUploadComponent(appConfigService, request, common, http) {
        var _this = this;
        this.appConfigService = appConfigService;
        this.request = request;
        this.common = common;
        this.http = http;
        this.upLoadType = [{ title: "File", type: 1 }, { title: "Scan", type: 2 }, { title: "Link", type: 3 }, { title: "QR Code", type: 3 }];
        this.systemId = '0';
        this.RelatedAgency = 'SOC';
        this.RecordId = '0';
        this.Subject = '-';
        this.TypeId = '0';
        this.popupTitle = 'เลือกรูปประจำตัว';
        this.uploaded = new EventEmitter();
        this.onSubmit = new EventEmitter();
        // @ViewChild('myModal') myModal;
        this.fileList = [];
        this.uploadHeaders = {
            "Authorization": "Basic " + btoa("APPSOC:123456")
        };
        this.loading = false;
        this.beforeUpload = function (file, _fileList) {
            return new Observable(function (observer) {
                /** @type {?} */
                var whitelist = [
                    'application/pdf',
                    'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
                    'application/vnd.ms-excel',
                    'application/vnd.msexcel',
                    'application/csv',
                    'text/csv',
                    'application/msword',
                    'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
                    'application/vnd.ms-powerpoint',
                    'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
                    'application/vnd.openxmlformats-officedocument.presentationml.presentation',
                    'text/plain',
                    'text/comma-separated-values',
                    'text/anytext',
                    'image/png',
                    'image/jpeg',
                    'image/gif',
                    'image/bmp'
                ];
                /** @type {?} */
                var isWhitelist = (file && whitelist.indexOf(file.type) > -1);
                if (!isWhitelist) {
                    setTimeout(function () {
                        _this.fileList = [{
                                uid: '999',
                                name: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',
                                status: 'error',
                                response: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',
                                url: null
                            }];
                    }, 50);
                    observer.complete();
                    return;
                }
                /** @type {?} */
                var isLt30M = /** @type {?} */ ((file.size)) / 1024 / 1024 < 30;
                if (!isLt30M) {
                    _this.fileList = [{
                            uid: '999',
                            name: 'File must smaller than 30MB!',
                            status: 'error',
                            response: 'File must smaller than 30MB!',
                            url: null
                        }];
                    observer.complete();
                    return;
                }
                observer.next(isWhitelist && isLt30M);
                observer.complete();
            });
        };
        this.customReq = function (item) {
            /** @type {?} */
            var formData = new FormData();
            // tslint:disable-next-line:no-any
            formData.append('FileData', /** @type {?} */ (item.file));
            formData.append('SystemId', '' + _this.systemId);
            formData.append('RelatedAgency', _this.RelatedAgency);
            formData.append('RecordId', _this.RecordId);
            formData.append('Subject', _this.Subject);
            formData.append('TypeId', _this.TypeId);
            /** @type {?} */
            var headers = new HttpHeaders();
            headers = headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));
            /** @type {?} */
            var req = new HttpRequest('POST', item.action, formData, {
                reportProgress: true,
                headers: headers
            });
            // req.headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));
            return _this.http.request(req).subscribe(function (event) {
                if (event.type === HttpEventType.UploadProgress) {
                    if (event.total > 0) {
                        (/** @type {?} */ (event)).percent = event.loaded / event.total * 100;
                    }
                    item.onProgress(event, item.file);
                }
                else if (event instanceof HttpResponse) {
                    // console.log("event.body",event.body);
                    // let res = JSON.parse(event.body);
                    if (_this.fileList && _this.fileList.length > 1) {
                        _this.fileList = [_this.fileList[_this.fileList.length - 1]];
                    }
                    _this.uploaded.emit(event.body);
                    _this.data = event.body;
                    item.onSuccess(event.body, item.file, event);
                }
            }, function (err) {
                item.onError(err, item.file);
            });
        };
        this.config = appConfigService.getConfig();
        this.url = _.get(this.config, 'apiServers.alfresco.url') || "https://203.154.32.126:2585/api/mfec/Alfresco";
    }
    /**
     * @return {?}
     */
    ModalImageUploadComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
    };
    /**
     * @param {?} file
     * @return {?}
     */
    ModalImageUploadComponent.prototype.onUploaded = /**
     * @param {?} file
     * @return {?}
     */
    function (file) {
        var _this = this;
        console.log("file", file);
        /** @type {?} */
        var res = JSON.parse(file.request.response);
        this.request.getAttachmentLinkToken(this.url + '/' + res.uuid).then(function (url) {
            _this.avatarUrl = url;
        });
        this.uploaded.emit(res);
    };
    /**
     * @return {?}
     */
    ModalImageUploadComponent.prototype.clearValue = /**
     * @return {?}
     */
    function () {
        this.fileList = [];
    };
    /**
     * @return {?}
     */
    ModalImageUploadComponent.prototype.closeModal = /**
     * @return {?}
     */
    function () {
        this.modal.hide();
        this.data = null;
        this.fileList = [];
    };
    /**
     * @return {?}
     */
    ModalImageUploadComponent.prototype.clickSubmit = /**
     * @return {?}
     */
    function () {
        this.onSubmit.emit(this.data);
        this.modal.hide();
        this.data = null;
        this.fileList = [];
    };
    ModalImageUploadComponent.decorators = [
        { type: Component, args: [{
                    selector: 'modal-image-upload',
                    template: "<div class=\"modal fade\" bsModal #modal=\"bs-modal\" [config]=\"{backdrop: 'static'}\"\n     tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"dialog-static-name1\">\n    <div class=\"modal-dialog modal-md\">\n        <div class=\"modal-content\">\n            <div class=\"modal-header\">\n                <h4 id=\"dialog-static-name\" class=\"modal-title pull-left\">{{popupTitle}}</h4>\n                <button type=\"button\" class=\"close pull-right\" aria-label=\"Close\" (click)=\"closeModal()\">\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n            </div>\n\n            <div class=\"modal-body\">\n                <form class=\"m-form m-form--state m-form--fit m-form--label-align-right\" (ngSubmit)=\"clickSubmit()\">\n                    <div class=\"ibox-body\">\n                        <div class=\"col-sm-12\" style=\"text-align: center\">\n                            <br>\n                            <nz-upload nzType=\"drag\"\n                                       [nzAction]=\"url\"\n                                       [nzCustomRequest]=\"customReq\"\n                                       nzFileType=\"image/png,image/jpeg,image/gif,image/bmp\"\n                                       [(nzFileList)]=\"fileList\"\n                                       [nzBeforeUpload]=\"beforeUpload\"\n                                       >\n                                <!--<nz-upload nzType=\"drag\"-->\n                                <!--nzAction=\"https://203.154.32.126:2585/api/mfec/Alfresco\"-->\n                                <!--&gt;-->\n                                <a nz-button>\n                                    <i nz-icon type=\"upload\"></i><span>Click to Upload</span>\n                                </a>\n                            </nz-upload>\n                            <br>\n                        </div>\n                        <div class=\"col-sm-12\" style=\"text-align: center\" *ngIf=\"avatarUrl\">\n                            <div class=\"avatar-box\">\n                                <img [src]=\"avatarUrl\" alt=\"\">\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"m-portlet__foot m-portlet__foot--fit text-right\">\n                        <div class=\"m-form__actions\">\n                            <button type=\"submit\" class=\"btn btn-success btn-md btn-md-save\">\n                                \u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01\n                            </button>\n                            <button type=\"reset\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"closeModal()\">\n                                \u0E22\u0E01\u0E40\u0E25\u0E34\u0E01\n                            </button>\n                        </div>\n                    </div>\n                </form>\n            </div>\n        </div>\n    </div>\n</div>\n",
                    styles: ["\n    :host ::ng-deep .avatar-uploader > .ant-upload, :host ::ng-deep .avatar {\n      width: 128px;\n      height: 128px;\n    }\n    :host ::ng-deep .ant-upload-select-picture-card i {\n      font-size: 32px;\n      color: #999;\n    }\n    :host ::ng-deep .ant-upload-select-picture-card .ant-upload-text {\n      margin-top: 8px;\n      color: #666;\n    }\n  "]
                }] }
    ];
    /** @nocollapse */
    ModalImageUploadComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: Common },
        { type: HttpClient }
    ]; };
    ModalImageUploadComponent.propDecorators = {
        modal: [{ type: ViewChild, args: ['modal',] }],
        upLoadType: [{ type: Input }],
        systemId: [{ type: Input }],
        RelatedAgency: [{ type: Input }],
        RecordId: [{ type: Input }],
        Subject: [{ type: Input }],
        TypeId: [{ type: Input }],
        downloadToken: [{ type: Input }],
        popupTitle: [{ type: Input }],
        uploaded: [{ type: Output }],
        onSubmit: [{ type: Output }]
    };
    return ModalImageUploadComponent;
}());
export { ModalImageUploadComponent };
if (false) {
    /** @type {?} */
    ModalImageUploadComponent.prototype.modal;
    /** @type {?} */
    ModalImageUploadComponent.prototype.upLoadType;
    /** @type {?} */
    ModalImageUploadComponent.prototype.systemId;
    /** @type {?} */
    ModalImageUploadComponent.prototype.RelatedAgency;
    /** @type {?} */
    ModalImageUploadComponent.prototype.RecordId;
    /** @type {?} */
    ModalImageUploadComponent.prototype.Subject;
    /** @type {?} */
    ModalImageUploadComponent.prototype.TypeId;
    /** @type {?} */
    ModalImageUploadComponent.prototype.downloadToken;
    /** @type {?} */
    ModalImageUploadComponent.prototype.popupTitle;
    /** @type {?} */
    ModalImageUploadComponent.prototype.uploaded;
    /** @type {?} */
    ModalImageUploadComponent.prototype.onSubmit;
    /** @type {?} */
    ModalImageUploadComponent.prototype.fileList;
    /** @type {?} */
    ModalImageUploadComponent.prototype.uploadHeaders;
    /** @type {?} */
    ModalImageUploadComponent.prototype.loading;
    /** @type {?} */
    ModalImageUploadComponent.prototype.avatarUrl;
    /** @type {?} */
    ModalImageUploadComponent.prototype.data;
    /** @type {?} */
    ModalImageUploadComponent.prototype.config;
    /** @type {?} */
    ModalImageUploadComponent.prototype.url;
    /** @type {?} */
    ModalImageUploadComponent.prototype.beforeUpload;
    /** @type {?} */
    ModalImageUploadComponent.prototype.customReq;
    /** @type {?} */
    ModalImageUploadComponent.prototype.appConfigService;
    /** @type {?} */
    ModalImageUploadComponent.prototype.request;
    /** @type {?} */
    ModalImageUploadComponent.prototype.common;
    /** @type {?} */
    ModalImageUploadComponent.prototype.http;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-image-upload.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/modal-image-upload/modal-image-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport { Request } from '../_services/request.service';\nimport {Common} from '../_services/common.service';\nimport {UploadXHRArgs} from 'ng-zorro-antd';\nimport {HttpClient, HttpEvent, HttpEventType, HttpHeaders, HttpRequest, HttpResponse} from '@angular/common/http';\nimport { NzMessageService, } from 'ng-zorro-antd';\nimport { Observable, Observer,throwError } from 'rxjs';\nimport {Subscription} from 'rxjs/Rx';\nimport {ModalDirective} from 'ngx-bootstrap';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport * as _ from 'lodash';\n// import { NzMessageService } from 'ng-zorro-antd/message';\n// import { UploadFile } from 'ng-zorro-antd/upload';\n@Component({\n    selector: 'modal-image-upload',\n    templateUrl: './modal-image-upload.component.html',\n    styles: [\n        `\n    :host ::ng-deep .avatar-uploader > .ant-upload, :host ::ng-deep .avatar {\n      width: 128px;\n      height: 128px;\n    }\n    :host ::ng-deep .ant-upload-select-picture-card i {\n      font-size: 32px;\n      color: #999;\n    }\n    :host ::ng-deep .ant-upload-select-picture-card .ant-upload-text {\n      margin-top: 8px;\n      color: #666;\n    }\n  `\n    ]\n})\nexport class ModalImageUploadComponent implements OnInit {\n\n    @ViewChild('modal') modal: ModalDirective;\n    @Input() upLoadType: any = [{title:\"File\",type:1},{title:\"Scan\",type:2},{title:\"Link\",type:3},{title:\"QR Code\",type:3}];\n    @Input() systemId: any = '0';\n    @Input() RelatedAgency: any = 'SOC';\n    @Input() RecordId: any = '0';\n    @Input() Subject: any = '-';\n    @Input() TypeId: any = '0';\n    @Input() downloadToken: any ;\n    @Input() popupTitle = 'เลือกรูปประจำตัว' ;\n    @Output() uploaded = new EventEmitter();\n    @Output() onSubmit = new EventEmitter();\n    // @ViewChild('myModal') myModal;\n    fileList:any = [];\n    uploadHeaders:any = {\n        \"Authorization\": \"Basic \"+btoa(\"APPSOC:123456\")\n    };\n    loading = false;\n    avatarUrl: string;\n    data;\n    config;\n    url;\n    constructor(private appConfigService: AppConfigService,private request: Request, public common: Common, private http: HttpClient) {\n        this.config = appConfigService.getConfig();\n        this.url = _.get(this.config, 'apiServers.alfresco.url') || \"https://203.154.32.126:2585/api/mfec/Alfresco\";\n    }\n\n    ngOnInit() {\n\n    }\n    onUploaded(file){\n        console.log(\"file\",file);\n        let res = JSON.parse(file.request.response);\n        this.request.getAttachmentLinkToken(this.url+'/'+res.uuid).then(url => {\n            this.avatarUrl = url;\n        });\n        this.uploaded.emit(res);\n    }\n\n    beforeUpload = (file: any, _fileList: any) =>  {\n        return new Observable((observer: any) => {\n          let whitelist = [\n              'application/pdf',\n              'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n              'application/vnd.ms-excel',\n              'application/vnd.msexcel',\n              'application/csv',\n              'text/csv',\n              'application/msword',\n              'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n              'application/vnd.ms-powerpoint',\n              'application/vnd.openxmlformats-officedocument.presentationml.slideshow',\n              'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n              'text/plain',\n              'text/comma-separated-values',\n              'text/anytext',\n              'image/png',\n              'image/jpeg',\n              'image/gif',\n              'image/bmp'\n\n            ];\n          const isWhitelist = (file && whitelist.indexOf(file.type) > -1)\n          if(!isWhitelist){\n              setTimeout(() => {\n                this.fileList = [ {\n                      uid: '999',\n                      name: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',\n                      status: 'error',\n                      response: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',\n                      url: null\n                    }]\n              }, 50);\n              observer.complete();\n              return;\n          }\n\n          const isLt30M = file.size! / 1024 / 1024 < 30;\n          if (!isLt30M) {\n            this.fileList = [ {\n                  uid: '999',\n                  name: 'File must smaller than 30MB!',\n                  status: 'error',\n                  response: 'File must smaller than 30MB!',\n                  url: null\n                }]\n            observer.complete();\n            return;\n          }\n\n          observer.next(isWhitelist && isLt30M);\n          observer.complete();\n        });\n      };\n\n\n    customReq = (item: UploadXHRArgs) => {\n        const formData = new FormData();\n        // tslint:disable-next-line:no-any\n        formData.append('FileData', item.file as any);\n        formData.append('SystemId', ''+this.systemId);\n        formData.append('RelatedAgency', this.RelatedAgency);\n        formData.append('RecordId', this.RecordId);\n        formData.append('Subject', this.Subject);\n        formData.append('TypeId', this.TypeId);\n        let headers = new HttpHeaders();\n        headers = headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n        let req = new HttpRequest('POST', item.action, formData, {\n            reportProgress : true,\n            headers: headers\n        });\n        // req.headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n        return this.http.request(req).subscribe(\n            (event: HttpEvent<{}>) => {\n                if (event.type === HttpEventType.UploadProgress) {\n                    if (event.total > 0) {\n                        (event as any).percent = event.loaded / event.total * 100;\n                    }\n                    item.onProgress(event, item.file);\n                } else if (event instanceof HttpResponse) {\n                    // console.log(\"event.body\",event.body);\n                    // let res = JSON.parse(event.body);\n                    if(this.fileList && this.fileList.length > 1){\n                      this.fileList = [this.fileList[this.fileList.length-1]]\n                    }\n                    this.uploaded.emit(event.body);\n                    this.data = event.body;\n                    item.onSuccess(event.body, item.file, event);\n                }\n            }, (err) => {\n                item.onError(err, item.file);\n            });\n    }\n\n    public clearValue(){\n        this.fileList = [];\n    }\n\n    closeModal() {\n        this.modal.hide();\n        this.data = null;\n        this.fileList = [];\n    }\n\n    clickSubmit(){\n        this.onSubmit.emit(this.data);\n        this.modal.hide();\n        this.data = null;\n        this.fileList = [];\n    }\n\n}\n"]}