ant-design/components/upload/utils.tsx

58 lines
1.3 KiB
TypeScript
Raw Normal View History

import { RcFile, UploadFile } from './interface';
2017-11-20 16:43:25 +08:00
export function T() {
return true;
}
// Fix IE file.status problem
// via coping a new Object
export function fileToObject(file: RcFile): UploadFile {
return {
lastModified: file.lastModified,
lastModifiedDate: file.lastModifiedDate,
name: file.name,
size: file.size,
type: file.type,
percent: 0,
uid: file.uid,
originFileObj: file,
2017-11-20 16:43:25 +08:00
} as UploadFile;
}
/**
* Progress percent: 0.1 -> 0.98
* - for ie
*/
export function genPercentAdd() {
let k = 0.1;
const i = 0.01;
const end = 0.98;
2017-11-20 16:43:25 +08:00
return function (s: number) {
let start = s;
if (start >= end) {
return start;
}
start += k;
k = k - i;
if (k < 0.001) {
k = 0.001;
}
return start * 100;
};
}
2017-11-20 16:43:25 +08:00
export function getFileItem(file: UploadFile, fileList: UploadFile[]) {
const matchKey = file.uid !== undefined ? 'uid' : 'name';
return fileList.filter(item => item[matchKey] === file[matchKey])[0];
}
2017-11-20 16:43:25 +08:00
export function removeFileItem(file: UploadFile, fileList: UploadFile[]) {
const matchKey = file.uid !== undefined ? 'uid' : 'name';
const removed = fileList.filter(item => item[matchKey] !== file[matchKey]);
if (removed.length === fileList.length) {
return null;
}
return removed;
}