zarm
Version:
基于 React 的移动端UI库
132 lines (108 loc) • 5.27 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireWildcard(require("react"));
var _bem = require("@zarm-design/bem");
var _handleFileInfo = _interopRequireDefault(require("./utils/handleFileInfo"));
var _configProvider = require("../config-provider");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) { if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } } return n.default = e, t && t.set(e, n), n; }
/**
* 设置选择前的方法,获取选择文件的相关信息,需要时可以对图片进行压缩、改变图片尺寸。
*
* multiple: 默认为 false,设置为 true 之后一次可以选择多张,onChange 事件调用之后返回一个数组,
* 不设置或者设置为 false,onChange 事件调用之后返回一个对象。
* disabled: 传递之后不可以点击上传,整个选择组件会设置为半透明状态,透明度为 0.5。
* quality: 没有默认值,不设置不会进行压缩。
* accept: 设置选择的文件类型,默认为所有类型,只有文件类型为图片(image/*)的时候会有本地预览图。
* onChange: () => { file, fileType, fileSize, fileName, thumbnail }。
* onBeforeSelect: () => boolean,返回 false 的时候阻止后续的选择事件。
*/
var FilePicker = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var fileRef = ref || /*#__PURE__*/_react.default.createRef();
var _React$useContext = _react.default.useContext(_configProvider.ConfigContext),
prefixCls = _React$useContext.prefixCls;
var bem = (0, _bem.createBEM)('file-picker', {
prefixCls: prefixCls
});
var className = props.className,
multiple = props.multiple,
accept = props.accept,
capture = props.capture,
disabled = props.disabled,
children = props.children,
onBeforeSelect = props.onBeforeSelect,
onChange = props.onChange,
quality = props.quality,
restProps = (0, _objectWithoutProperties2.default)(props, ["className", "multiple", "accept", "capture", "disabled", "children", "onBeforeSelect", "onChange", "quality"]);
var cls = bem([{
disabled: disabled
}, className]);
var handleClick = (0, _react.useCallback)(function () {
fileRef === null || fileRef === void 0 ? void 0 : fileRef.current.click();
}, [fileRef]);
var handleDefaultInput = (0, _react.useCallback)(function (e) {
// 防止选择同一张图片两次造成 onChange 事件不触发
e.currentTarget.value = '';
if (typeof onBeforeSelect !== 'function') {
return;
} // 阻止 input onChange 默认事件
if (onBeforeSelect() === false || disabled) {
e.preventDefault();
}
}, [onBeforeSelect, disabled]);
var handleChange = function handleChange(e) {
var files = [].slice.call(e.target.files);
var fileList = [];
var getFileInfo = function getFileInfo(data) {
if (multiple) {
fileList.push(data);
if (files.length === fileList.length && typeof onChange === 'function') {
onChange(fileList);
}
} else {
typeof onChange === 'function' && onChange(data);
}
};
if (files) {
files.map(function (file) {
return (0, _handleFileInfo.default)({
file: file,
quality: quality
}, getFileInfo);
});
}
};
var content = /*#__PURE__*/(0, _react.cloneElement)(children, {
onClick: handleClick,
className: [children.props.className, 'needsclick'].filter(Boolean).join(' ') // 修复加载fastClick库后引起的合成事件问题
});
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
className: cls
}, restProps), /*#__PURE__*/_react.default.createElement("input", {
className: bem('input'),
type: "file",
ref: fileRef,
accept: accept,
multiple: multiple,
capture: capture,
onClick: handleDefaultInput,
onChange: handleChange
}), content);
});
FilePicker.displayName = 'FilePicker';
FilePicker.defaultProps = {
disabled: false,
multiple: false,
onBeforeSelect: function onBeforeSelect() {
return true;
}
};
var _default = FilePicker;
exports.default = _default;
;