UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

76 lines (72 loc) 3.69 kB
/** * xdesign v1.0.6 * (c) 2023 xdesign * @license MIT */ import _defineProperty from '@babel/runtime/helpers/defineProperty'; import { defineComponent, toRefs, createVNode, Fragment } from 'vue'; import useDrag from '../hooks/useDrag.js'; import { commonProps } from '../constants.js'; import { useContent } from '../../hooks/tnode.js'; import '../../_common/js/upload/utils.js'; import '../../_common/js/log/log.js'; import 'lodash/isFunction'; import 'lodash/camelCase'; import 'lodash/kebabCase'; import '../../utils/render-tnode.js'; import 'lodash/isEmpty'; import 'lodash/isString'; import 'lodash/isObject'; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } var CustomFile = defineComponent({ name: "UploadCustomFile", props: _objectSpread(_objectSpread({}, commonProps), {}, { dragEvents: Object, draggable: Boolean, dragContent: Function, trigger: Function, triggerUpload: Function, childrenNode: [String, Function] }), setup: function setup(props, _ref) { var slots = _ref.slots; var _toRefs = toRefs(props), classPrefix = _toRefs.classPrefix, displayFiles = _toRefs.displayFiles, accept = _toRefs.accept; var drag = useDrag(props.dragEvents, accept); var dragActive = drag.dragActive; var renderContent = useContent(); var renderDragContent = function renderDragContent() { var _props$childrenNode; var params = { dragActive: dragActive.value || false, files: displayFiles.value }; return createVNode("div", { "class": "".concat(classPrefix.value, "-upload__dragger ").concat(classPrefix.value, "-upload__dragger-center"), "onDrop": drag.handleDrop, "onDragenter": drag.handleDragenter, "onDragover": drag.handleDragover, "onDragleave": drag.handleDragleave, "onClick": props.triggerUpload }, [createVNode("div", { "class": "".concat(classPrefix.value, "-upload__trigger") }, [renderContent("dragContent", "trigger", { params: params }) || ((_props$childrenNode = props.childrenNode) === null || _props$childrenNode === void 0 ? void 0 : _props$childrenNode.call(props, params))])]); }; return function () { var _props$childrenNode2, _slots$default; return createVNode(Fragment, null, [props.draggable ? renderDragContent() : createVNode("div", { "class": "".concat(classPrefix.value, "-upload__trigger"), "onClick": props.triggerUpload }, [((_props$childrenNode2 = props.childrenNode) === null || _props$childrenNode2 === void 0 ? void 0 : _props$childrenNode2.call(props, { files: displayFiles.value })) || ((_slots$default = slots["default"]) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots))])]); }; } }); export { CustomFile as default }; //# sourceMappingURL=custom-file.js.map