xdesign-vue-next
Version:
XDesign Component for vue-next
76 lines (72 loc) • 3.69 kB
JavaScript
/**
* 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