ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
632 lines • 49 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: upload-btn.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __values } from "tslib";
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { ENTER } from '@angular/cdk/keycodes';
import { HttpClient, HttpEventType, HttpHeaders, HttpRequest, HttpResponse } from '@angular/common/http';
import { Component, ElementRef, Input, Optional, ViewChild, ViewEncapsulation } from '@angular/core';
import { warn } from 'ng-zorro-antd/core/logger';
import { Observable, of, Subscription } from 'rxjs';
import { map, switchMap } from 'rxjs/operators';
var NzUploadBtnComponent = /** @class */ (function () {
function NzUploadBtnComponent(http) {
this.http = http;
this.reqs = {};
this.destroy = false;
if (!http) {
throw new Error("Not found 'HttpClient', You can import 'HttpClientModule' in your root module.");
}
}
/**
* @return {?}
*/
NzUploadBtnComponent.prototype.onClick = /**
* @return {?}
*/
function () {
if (this.options.disabled || !this.options.openFileDialogOnClick) {
return;
}
((/** @type {?} */ (this.file.nativeElement))).click();
};
/**
* @param {?} e
* @return {?}
*/
NzUploadBtnComponent.prototype.onKeyDown = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (this.options.disabled) {
return;
}
if (e.key === 'Enter' || e.keyCode === ENTER) {
this.onClick();
}
};
// skip safari bug
// skip safari bug
/**
* @param {?} e
* @return {?}
*/
NzUploadBtnComponent.prototype.onFileDrop =
// skip safari bug
/**
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
if (this.options.disabled || e.type === 'dragover') {
e.preventDefault();
return;
}
if (this.options.directory) {
this.traverseFileTree((/** @type {?} */ (e.dataTransfer)).items);
}
else {
/** @type {?} */
var files = Array.prototype.slice
.call((/** @type {?} */ (e.dataTransfer)).files)
.filter((/**
* @param {?} file
* @return {?}
*/
function (file) { return _this.attrAccept(file, _this.options.accept); }));
if (files.length) {
this.uploadFiles(files);
}
}
e.preventDefault();
};
/**
* @param {?} e
* @return {?}
*/
NzUploadBtnComponent.prototype.onChange = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (this.options.disabled) {
return;
}
/** @type {?} */
var hie = (/** @type {?} */ (e.target));
this.uploadFiles((/** @type {?} */ (hie.files)));
hie.value = '';
};
/**
* @private
* @param {?} files
* @return {?}
*/
NzUploadBtnComponent.prototype.traverseFileTree = /**
* @private
* @param {?} files
* @return {?}
*/
function (files) {
var e_1, _a;
var _this = this;
/** @type {?} */
var _traverseFileTree = (/**
* @param {?} item
* @param {?} path
* @return {?}
*/
function (item, path) {
if (item.isFile) {
item.file((/**
* @param {?} file
* @return {?}
*/
function (file) {
if (_this.attrAccept(file, _this.options.accept)) {
_this.uploadFiles([file]);
}
}));
}
else if (item.isDirectory) {
/** @type {?} */
var dirReader = item.createReader();
dirReader.readEntries((/**
* @param {?} entries
* @return {?}
*/
function (entries) {
var e_2, _a;
try {
for (var entries_1 = __values(entries), entries_1_1 = entries_1.next(); !entries_1_1.done; entries_1_1 = entries_1.next()) {
var entrieItem = entries_1_1.value;
_traverseFileTree(entrieItem, "" + path + item.name + "/");
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (entries_1_1 && !entries_1_1.done && (_a = entries_1.return)) _a.call(entries_1);
}
finally { if (e_2) throw e_2.error; }
}
}));
}
});
try {
for (var _b = __values((/** @type {?} */ (files))), _c = _b.next(); !_c.done; _c = _b.next()) {
var file = _c.value;
_traverseFileTree(file.webkitGetAsEntry(), '');
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
};
/**
* @private
* @param {?} file
* @param {?=} acceptedFiles
* @return {?}
*/
NzUploadBtnComponent.prototype.attrAccept = /**
* @private
* @param {?} file
* @param {?=} acceptedFiles
* @return {?}
*/
function (file, acceptedFiles) {
if (file && acceptedFiles) {
/** @type {?} */
var acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(',');
/** @type {?} */
var fileName_1 = '' + file.name;
/** @type {?} */
var mimeType_1 = '' + file.type;
/** @type {?} */
var baseMimeType_1 = mimeType_1.replace(/\/.*$/, '');
return acceptedFilesArray.some((/**
* @param {?} type
* @return {?}
*/
function (type) {
/** @type {?} */
var validType = type.trim();
if (validType.charAt(0) === '.') {
return (fileName_1.toLowerCase().indexOf(validType.toLowerCase(), fileName_1.toLowerCase().length - validType.toLowerCase().length) !== -1);
}
else if (/\/\*$/.test(validType)) {
// This is something like a image/* mime type
return baseMimeType_1 === validType.replace(/\/.*$/, '');
}
return mimeType_1 === validType;
}));
}
return true;
};
/**
* @private
* @param {?} file
* @return {?}
*/
NzUploadBtnComponent.prototype.attachUid = /**
* @private
* @param {?} file
* @return {?}
*/
function (file) {
if (!file.uid) {
file.uid = Math.random().toString(36).substring(2);
}
return file;
};
/**
* @param {?} fileList
* @return {?}
*/
NzUploadBtnComponent.prototype.uploadFiles = /**
* @param {?} fileList
* @return {?}
*/
function (fileList) {
var _this = this;
/** @type {?} */
var filters$ = of(Array.prototype.slice.call(fileList));
if (this.options.filters) {
this.options.filters.forEach((/**
* @param {?} f
* @return {?}
*/
function (f) {
filters$ = filters$.pipe(switchMap((/**
* @param {?} list
* @return {?}
*/
function (list) {
/** @type {?} */
var fnRes = f.fn(list);
return fnRes instanceof Observable ? fnRes : of(fnRes);
})));
}));
}
filters$.subscribe((/**
* @param {?} list
* @return {?}
*/
function (list) {
list.forEach((/**
* @param {?} file
* @return {?}
*/
function (file) {
_this.attachUid(file);
_this.upload(file, list);
}));
}), (/**
* @param {?} e
* @return {?}
*/
function (e) {
warn("Unhandled upload filter error", e);
}));
};
/**
* @private
* @param {?} file
* @param {?} fileList
* @return {?}
*/
NzUploadBtnComponent.prototype.upload = /**
* @private
* @param {?} file
* @param {?} fileList
* @return {?}
*/
function (file, fileList) {
var _this = this;
if (!this.options.beforeUpload) {
return this.post(file);
}
/** @type {?} */
var before = this.options.beforeUpload(file, fileList);
if (before instanceof Observable) {
before.subscribe((/**
* @param {?} processedFile
* @return {?}
*/
function (processedFile) {
/** @type {?} */
var processedFileType = Object.prototype.toString.call(processedFile);
if (processedFileType === '[object File]' || processedFileType === '[object Blob]') {
_this.attachUid(processedFile);
_this.post(processedFile);
}
else if (typeof processedFile === 'boolean' && processedFile !== false) {
_this.post(file);
}
}), (/**
* @param {?} e
* @return {?}
*/
function (e) {
warn("Unhandled upload beforeUpload error", e);
}));
}
else if (before !== false) {
return this.post(file);
}
};
/**
* @private
* @param {?} file
* @return {?}
*/
NzUploadBtnComponent.prototype.post = /**
* @private
* @param {?} file
* @return {?}
*/
function (file) {
var _this = this;
if (this.destroy) {
return;
}
/** @type {?} */
var process$ = of(file);
/** @type {?} */
var opt = this.options;
var uid = file.uid;
var action = opt.action, data = opt.data, headers = opt.headers, transformFile = opt.transformFile;
/** @type {?} */
var args = {
action: typeof action === 'string' ? action : '',
name: opt.name,
headers: headers,
file: file,
postFile: file,
data: data,
withCredentials: opt.withCredentials,
onProgress: opt.onProgress
? (/**
* @param {?} e
* @return {?}
*/
function (e) {
(/** @type {?} */ (opt.onProgress))(e, file);
})
: undefined,
onSuccess: (/**
* @param {?} ret
* @param {?} xhr
* @return {?}
*/
function (ret, xhr) {
_this.clean(uid);
(/** @type {?} */ (opt.onSuccess))(ret, file, xhr);
}),
onError: (/**
* @param {?} xhr
* @return {?}
*/
function (xhr) {
_this.clean(uid);
(/** @type {?} */ (opt.onError))(xhr, file);
})
};
if (typeof action === 'function') {
/** @type {?} */
var actionResult_1 = ((/** @type {?} */ (action)))(file);
if (actionResult_1 instanceof Observable) {
process$ = process$.pipe(switchMap((/**
* @return {?}
*/
function () { return actionResult_1; })), map((/**
* @param {?} res
* @return {?}
*/
function (res) {
args.action = res;
return file;
})));
}
else {
args.action = actionResult_1;
}
}
if (typeof transformFile === 'function') {
/** @type {?} */
var transformResult_1 = transformFile(file);
process$ = process$.pipe(switchMap((/**
* @return {?}
*/
function () { return (transformResult_1 instanceof Observable ? transformResult_1 : of(transformResult_1)); })));
}
if (typeof data === 'function') {
/** @type {?} */
var dataResult_1 = ((/** @type {?} */ (data)))(file);
if (dataResult_1 instanceof Observable) {
process$ = process$.pipe(switchMap((/**
* @return {?}
*/
function () { return dataResult_1; })), map((/**
* @param {?} res
* @return {?}
*/
function (res) {
args.data = res;
return file;
})));
}
else {
args.data = dataResult_1;
}
}
if (typeof headers === 'function') {
/** @type {?} */
var headersResult_1 = ((/** @type {?} */ (headers)))(file);
if (headersResult_1 instanceof Observable) {
process$ = process$.pipe(switchMap((/**
* @return {?}
*/
function () { return headersResult_1; })), map((/**
* @param {?} res
* @return {?}
*/
function (res) {
args.headers = res;
return file;
})));
}
else {
args.headers = headersResult_1;
}
}
process$.subscribe((/**
* @param {?} newFile
* @return {?}
*/
function (newFile) {
args.postFile = newFile;
/** @type {?} */
var req$ = (opt.customRequest || _this.xhr).call(_this, args);
if (!(req$ instanceof Subscription)) {
warn("Must return Subscription type in '[nzCustomRequest]' property");
}
_this.reqs[uid] = req$;
(/** @type {?} */ (opt.onStart))(file);
}));
};
/**
* @private
* @param {?} args
* @return {?}
*/
NzUploadBtnComponent.prototype.xhr = /**
* @private
* @param {?} args
* @return {?}
*/
function (args) {
var _this = this;
/** @type {?} */
var formData = new FormData();
if (args.data) {
Object.keys(args.data).map((/**
* @param {?} key
* @return {?}
*/
function (key) {
formData.append(key, (/** @type {?} */ (args.data))[key]);
}));
}
formData.append((/** @type {?} */ (args.name)), (/** @type {?} */ (args.postFile)));
if (!args.headers) {
args.headers = {};
}
if (args.headers['X-Requested-With'] !== null) {
args.headers['X-Requested-With'] = "XMLHttpRequest";
}
else {
delete args.headers['X-Requested-With'];
}
/** @type {?} */
var req = new HttpRequest('POST', (/** @type {?} */ (args.action)), formData, {
reportProgress: true,
withCredentials: args.withCredentials,
headers: new HttpHeaders(args.headers)
});
return this.http.request(req).subscribe((/**
* @param {?} event
* @return {?}
*/
function (event) {
if (event.type === HttpEventType.UploadProgress) {
if ((/** @type {?} */ (event.total)) > 0) {
((/** @type {?} */ (event))).percent = (event.loaded / (/** @type {?} */ (event.total))) * 100;
}
(/** @type {?} */ (args.onProgress))(event, args.file);
}
else if (event instanceof HttpResponse) {
(/** @type {?} */ (args.onSuccess))(event.body, args.file, event);
}
}), (/**
* @param {?} err
* @return {?}
*/
function (err) {
_this.abort(args.file);
(/** @type {?} */ (args.onError))(err, args.file);
}));
};
/**
* @private
* @param {?} uid
* @return {?}
*/
NzUploadBtnComponent.prototype.clean = /**
* @private
* @param {?} uid
* @return {?}
*/
function (uid) {
/** @type {?} */
var req$ = this.reqs[uid];
if (req$ instanceof Subscription) {
req$.unsubscribe();
}
delete this.reqs[uid];
};
/**
* @param {?=} file
* @return {?}
*/
NzUploadBtnComponent.prototype.abort = /**
* @param {?=} file
* @return {?}
*/
function (file) {
var _this = this;
if (file) {
this.clean(file && file.uid);
}
else {
Object.keys(this.reqs).forEach((/**
* @param {?} uid
* @return {?}
*/
function (uid) { return _this.clean(uid); }));
}
};
/**
* @return {?}
*/
NzUploadBtnComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy = true;
this.abort();
};
NzUploadBtnComponent.decorators = [
{ type: Component, args: [{
selector: '[nz-upload-btn]',
exportAs: 'nzUploadBtn',
template: "<input\n type=\"file\"\n #file\n (change)=\"onChange($event)\"\n [attr.accept]=\"options.accept\"\n [attr.directory]=\"options.directory ? 'directory' : null\"\n [attr.webkitdirectory]=\"options.directory ? 'webkitdirectory' : null\"\n [multiple]=\"options.multiple\"\n style=\"display: none;\"\n/>\n<ng-content></ng-content>\n",
host: {
'[attr.tabindex]': '"0"',
'[attr.role]': '"button"',
'[class.ant-upload]': 'true',
'[class.ant-upload-disabled]': 'options.disabled',
'(click)': 'onClick()',
'(keydown)': 'onKeyDown($event)',
'(drop)': 'onFileDrop($event)',
'(dragover)': 'onFileDrop($event)'
},
preserveWhitespaces: false,
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
NzUploadBtnComponent.ctorParameters = function () { return [
{ type: HttpClient, decorators: [{ type: Optional }] }
]; };
NzUploadBtnComponent.propDecorators = {
file: [{ type: ViewChild, args: ['file', { static: false },] }],
options: [{ type: Input }]
};
return NzUploadBtnComponent;
}());
export { NzUploadBtnComponent };
if (false) {
/** @type {?} */
NzUploadBtnComponent.prototype.reqs;
/**
* @type {?}
* @private
*/
NzUploadBtnComponent.prototype.destroy;
/** @type {?} */
NzUploadBtnComponent.prototype.file;
/** @type {?} */
NzUploadBtnComponent.prototype.options;
/**
* @type {?}
* @private
*/
NzUploadBtnComponent.prototype.http;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-btn.component.js","sourceRoot":"ng://ng-zorro-antd/upload/","sources":["upload-btn.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { ENTER } from '@angular/cdk/keycodes';\nimport { HttpClient, HttpEvent, HttpEventType, HttpHeaders, HttpRequest, HttpResponse } from '@angular/common/http';\nimport { Component, ElementRef, Input, OnDestroy, Optional, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { warn } from 'ng-zorro-antd/core/logger';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { Observable, of, Subscription } from 'rxjs';\nimport { map, switchMap } from 'rxjs/operators';\n\nimport { UploadFile, UploadXHRArgs, ZipButtonOptions } from './interface';\n\n@Component({\n  selector: '[nz-upload-btn]',\n  exportAs: 'nzUploadBtn',\n  templateUrl: './upload-btn.component.html',\n  host: {\n    '[attr.tabindex]': '\"0\"',\n    '[attr.role]': '\"button\"',\n    '[class.ant-upload]': 'true',\n    '[class.ant-upload-disabled]': 'options.disabled',\n    '(click)': 'onClick()',\n    '(keydown)': 'onKeyDown($event)',\n    '(drop)': 'onFileDrop($event)',\n    '(dragover)': 'onFileDrop($event)'\n  },\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None\n})\nexport class NzUploadBtnComponent implements OnDestroy {\n  reqs: { [key: string]: Subscription } = {};\n  private destroy = false;\n  @ViewChild('file', { static: false }) file: ElementRef;\n  @Input() options: ZipButtonOptions;\n  onClick(): void {\n    if (this.options.disabled || !this.options.openFileDialogOnClick) {\n      return;\n    }\n    (this.file.nativeElement as HTMLInputElement).click();\n  }\n\n  onKeyDown(e: KeyboardEvent): void {\n    if (this.options.disabled) {\n      return;\n    }\n    if (e.key === 'Enter' || e.keyCode === ENTER) {\n      this.onClick();\n    }\n  }\n\n  // skip safari bug\n  onFileDrop(e: DragEvent): void {\n    if (this.options.disabled || e.type === 'dragover') {\n      e.preventDefault();\n      return;\n    }\n    if (this.options.directory) {\n      this.traverseFileTree(e.dataTransfer!.items);\n    } else {\n      const files: File[] = Array.prototype.slice\n        .call(e.dataTransfer!.files)\n        .filter((file: File) => this.attrAccept(file, this.options.accept));\n      if (files.length) {\n        this.uploadFiles(files);\n      }\n    }\n\n    e.preventDefault();\n  }\n\n  onChange(e: Event): void {\n    if (this.options.disabled) {\n      return;\n    }\n    const hie = e.target as HTMLInputElement;\n    this.uploadFiles(hie.files!);\n    hie.value = '';\n  }\n\n  private traverseFileTree(files: DataTransferItemList): void {\n    const _traverseFileTree = (item: NzSafeAny, path: string) => {\n      if (item.isFile) {\n        item.file((file: File) => {\n          if (this.attrAccept(file, this.options.accept)) {\n            this.uploadFiles([file]);\n          }\n        });\n      } else if (item.isDirectory) {\n        const dirReader = item.createReader();\n\n        dirReader.readEntries((entries: NzSafeAny) => {\n          for (const entrieItem of entries) {\n            _traverseFileTree(entrieItem, `${path}${item.name}/`);\n          }\n        });\n      }\n    };\n\n    for (const file of files as NzSafeAny) {\n      _traverseFileTree(file.webkitGetAsEntry(), '');\n    }\n  }\n\n  private attrAccept(file: File, acceptedFiles?: string | string[]): boolean {\n    if (file && acceptedFiles) {\n      const acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(',');\n      const fileName = '' + file.name;\n      const mimeType = '' + file.type;\n      const baseMimeType = mimeType.replace(/\\/.*$/, '');\n\n      return acceptedFilesArray.some(type => {\n        const validType = type.trim();\n        if (validType.charAt(0) === '.') {\n          return (\n            fileName.toLowerCase().indexOf(validType.toLowerCase(), fileName.toLowerCase().length - validType.toLowerCase().length) !== -1\n          );\n        } else if (/\\/\\*$/.test(validType)) {\n          // This is something like a image/* mime type\n          return baseMimeType === validType.replace(/\\/.*$/, '');\n        }\n        return mimeType === validType;\n      });\n    }\n    return true;\n  }\n\n  private attachUid(file: UploadFile): UploadFile {\n    if (!file.uid) {\n      file.uid = Math.random().toString(36).substring(2);\n    }\n    return file;\n  }\n\n  uploadFiles(fileList: FileList | File[]): void {\n    let filters$: Observable<UploadFile[]> = of(Array.prototype.slice.call(fileList));\n    if (this.options.filters) {\n      this.options.filters.forEach(f => {\n        filters$ = filters$.pipe(\n          switchMap(list => {\n            const fnRes = f.fn(list);\n            return fnRes instanceof Observable ? fnRes : of(fnRes);\n          })\n        );\n      });\n    }\n    filters$.subscribe(\n      list => {\n        list.forEach((file: UploadFile) => {\n          this.attachUid(file);\n          this.upload(file, list);\n        });\n      },\n      e => {\n        warn(`Unhandled upload filter error`, e);\n      }\n    );\n  }\n\n  private upload(file: UploadFile, fileList: UploadFile[]): void {\n    if (!this.options.beforeUpload) {\n      return this.post(file);\n    }\n    const before = this.options.beforeUpload(file, fileList);\n    if (before instanceof Observable) {\n      before.subscribe(\n        (processedFile: UploadFile) => {\n          const processedFileType = Object.prototype.toString.call(processedFile);\n          if (processedFileType === '[object File]' || processedFileType === '[object Blob]') {\n            this.attachUid(processedFile);\n            this.post(processedFile);\n          } else if (typeof processedFile === 'boolean' && processedFile !== false) {\n            this.post(file);\n          }\n        },\n        e => {\n          warn(`Unhandled upload beforeUpload error`, e);\n        }\n      );\n    } else if (before !== false) {\n      return this.post(file);\n    }\n  }\n\n  private post(file: UploadFile): void {\n    if (this.destroy) {\n      return;\n    }\n    let process$: Observable<string | Blob | File | UploadFile> = of(file);\n    const opt = this.options;\n    const { uid } = file;\n    const { action, data, headers, transformFile } = opt;\n\n    const args: UploadXHRArgs = {\n      action: typeof action === 'string' ? action : '',\n      name: opt.name,\n      headers,\n      file,\n      postFile: file,\n      data,\n      withCredentials: opt.withCredentials,\n      onProgress: opt.onProgress\n        ? e => {\n            opt.onProgress!(e, file);\n          }\n        : undefined,\n      onSuccess: (ret, xhr) => {\n        this.clean(uid);\n        opt.onSuccess!(ret, file, xhr);\n      },\n      onError: xhr => {\n        this.clean(uid);\n        opt.onError!(xhr, file);\n      }\n    };\n\n    if (typeof action === 'function') {\n      const actionResult = (action as (file: UploadFile) => string | Observable<string>)(file);\n      if (actionResult instanceof Observable) {\n        process$ = process$.pipe(\n          switchMap(() => actionResult),\n          map(res => {\n            args.action = res;\n            return file;\n          })\n        );\n      } else {\n        args.action = actionResult;\n      }\n    }\n\n    if (typeof transformFile === 'function') {\n      const transformResult = transformFile(file);\n      process$ = process$.pipe(switchMap(() => (transformResult instanceof Observable ? transformResult : of(transformResult))));\n    }\n\n    if (typeof data === 'function') {\n      const dataResult = (data as (file: UploadFile) => {} | Observable<{}>)(file);\n      if (dataResult instanceof Observable) {\n        process$ = process$.pipe(\n          switchMap(() => dataResult),\n          map(res => {\n            args.data = res;\n            return file;\n          })\n        );\n      } else {\n        args.data = dataResult;\n      }\n    }\n\n    if (typeof headers === 'function') {\n      const headersResult = (headers as (file: UploadFile) => {} | Observable<{}>)(file);\n      if (headersResult instanceof Observable) {\n        process$ = process$.pipe(\n          switchMap(() => headersResult),\n          map(res => {\n            args.headers = res;\n            return file;\n          })\n        );\n      } else {\n        args.headers = headersResult;\n      }\n    }\n\n    process$.subscribe(newFile => {\n      args.postFile = newFile;\n      const req$ = (opt.customRequest || this.xhr).call(this, args);\n      if (!(req$ instanceof Subscription)) {\n        warn(`Must return Subscription type in '[nzCustomRequest]' property`);\n      }\n      this.reqs[uid] = req$;\n      opt.onStart!(file);\n    });\n  }\n\n  private xhr(args: UploadXHRArgs): Subscription {\n    const formData = new FormData();\n\n    if (args.data) {\n      Object.keys(args.data).map(key => {\n        formData.append(key, args.data![key]);\n      });\n    }\n\n    formData.append(args.name!, args.postFile as NzSafeAny);\n\n    if (!args.headers) {\n      args.headers = {};\n    }\n    if (args.headers['X-Requested-With'] !== null) {\n      args.headers['X-Requested-With'] = `XMLHttpRequest`;\n    } else {\n      delete args.headers['X-Requested-With'];\n    }\n    const req = new HttpRequest('POST', args.action!, formData, {\n      reportProgress: true,\n      withCredentials: args.withCredentials,\n      headers: new HttpHeaders(args.headers)\n    });\n    return this.http.request(req).subscribe(\n      (event: HttpEvent<NzSafeAny>) => {\n        if (event.type === HttpEventType.UploadProgress) {\n          if (event.total! > 0) {\n            (event as NzSafeAny).percent = (event.loaded / event.total!) * 100;\n          }\n          args.onProgress!(event, args.file);\n        } else if (event instanceof HttpResponse) {\n          args.onSuccess!(event.body, args.file, event);\n        }\n      },\n      err => {\n        this.abort(args.file);\n        args.onError!(err, args.file);\n      }\n    );\n  }\n\n  private clean(uid: string): void {\n    const req$ = this.reqs[uid];\n    if (req$ instanceof Subscription) {\n      req$.unsubscribe();\n    }\n    delete this.reqs[uid];\n  }\n\n  abort(file?: UploadFile): void {\n    if (file) {\n      this.clean(file && file.uid);\n    } else {\n      Object.keys(this.reqs).forEach(uid => this.clean(uid));\n    }\n  }\n\n  constructor(@Optional() private http: HttpClient) {\n    if (!http) {\n      throw new Error(`Not found 'HttpClient', You can import 'HttpClientModule' in your root module.`);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy = true;\n    this.abort();\n  }\n}\n"]}