UNPKG

zent

Version:

一套前端设计语言和基于React的实现

57 lines (56 loc) 3.44 kB
import { __assign, __extends } from "tslib"; import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime"; import cn from 'classnames'; import AbstractMultiUpload from './components/AbstractMultiUpload'; import NormalUploadList from './components/normal/List'; import NormalUploadTrigger from './components/normal/Trigger'; import { DEFAULT_ENABLE_MULTIPLE, DEFAULT_MAX_AMOUNT, DEFAULT_MAX_SIZE, FILE_UPLOAD_STATUS, } from './constants'; import { formatFileSize } from './utils/format-file-size'; import { getTipsContent } from './utils/get-tips-content'; import { I18nReceiver } from '../i18n'; import { createBaseNewUploadFileItem } from './utils/create-new-upload-file-item'; var Upload = (function (_super) { __extends(Upload, _super); function Upload() { return _super !== null && _super.apply(this, arguments) || this; } Upload.prototype.createNewUploadFileItem = function (file) { return createBaseNewUploadFileItem(file); }; Upload.prototype.renderTips = function () { var _a = this.props, tips = _a.tips, maxSize = _a.maxSize; var config = __assign(__assign({}, this.props), { formattedMaxSize: formatFileSize(maxSize) }); var tipsContent = getTipsContent(tips, config); return (tipsContent && _jsx("div", __assign({ className: "zent-file-upload-tips", "data-zv": '10.0.17' }, { children: tipsContent }), void 0)); }; Upload.prototype.renderUploadList = function (i18n) { var _a = this.props, sortable = _a.sortable, pagination = _a.pagination, pageSize = _a.pageSize, customUploadItem = _a.customUploadItem; return (_jsx(NormalUploadList, { i18n: i18n, fileList: this.fileList, onRetry: this.retryUploadItem, onDelete: this.deleteUploadItem, onSortChange: this.updateFileList, sortable: sortable, pagination: pagination, pageSize: pageSize, customUploadItem: customUploadItem }, void 0)); }; Upload.prototype.renderTrigger = function (i18n) { var _a = this .props, accept = _a.accept, maxAmount = _a.maxAmount, maxSize = _a.maxSize, multiple = _a.multiple, disabled = _a.disabled; var fileList = this.state.fileList; return (_jsx(NormalUploadTrigger, { i18n: i18n, accept: accept, maxAmount: maxAmount, maxSize: maxSize, multiple: multiple, disabled: disabled, remainAmount: this.remainAmount, fileList: fileList, onAddFile: this.onTriggerUploadFile, onError: this.emitOnError }, void 0)); }; Upload.prototype.render = function () { var _this = this; var className = this.props.className; return (_jsx(I18nReceiver, __assign({ componentName: "Upload" }, { children: function (i18n) { return (_jsxs("div", __assign({ className: cn('zent-file-upload', className), "data-zv": '10.0.17' }, { children: [_this.renderUploadList(i18n), _jsxs("div", __assign({ className: "zent-file-upload-trigger-wrapper", "data-zv": '10.0.17' }, { children: [_this.renderTrigger(i18n), _this.renderTips()] }), void 0)] }), void 0)); } }), void 0)); }; Upload.defaultProps = { maxAmount: DEFAULT_MAX_AMOUNT, maxSize: DEFAULT_MAX_SIZE, multiple: DEFAULT_ENABLE_MULTIPLE, manualUpload: false, sortable: false, pageSize: 5, pagination: false, }; Upload.FILE_UPLOAD_STATUS = FILE_UPLOAD_STATUS; return Upload; }(AbstractMultiUpload)); export { Upload }; export default Upload;