upload-dragger2.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. require('../../../hooks/index.js');
  5. require('../../../tokens/index.js');
  6. var error = require('../../../utils/error.js');
  7. var uploadDragger = require('./upload-dragger.js');
  8. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  9. var upload = require('../../../tokens/upload.js');
  10. var index = require('../../../hooks/use-namespace/index.js');
  11. var index$1 = require('../../../hooks/use-common-props/index.js');
  12. const _hoisted_1 = ["onDrop", "onDragover"];
  13. const COMPONENT_NAME = "ElUploadDrag";
  14. const __default__ = vue.defineComponent({
  15. name: COMPONENT_NAME
  16. });
  17. const _sfc_main = /* @__PURE__ */ vue.defineComponent({
  18. ...__default__,
  19. props: uploadDragger.uploadDraggerProps,
  20. emits: uploadDragger.uploadDraggerEmits,
  21. setup(__props, { emit }) {
  22. const uploaderContext = vue.inject(upload.uploadContextKey);
  23. if (!uploaderContext) {
  24. error.throwError(COMPONENT_NAME, "usage: <el-upload><el-upload-dragger /></el-upload>");
  25. }
  26. const ns = index.useNamespace("upload");
  27. const dragover = vue.ref(false);
  28. const disabled = index$1.useDisabled();
  29. const onDrop = (e) => {
  30. if (disabled.value)
  31. return;
  32. dragover.value = false;
  33. const files = Array.from(e.dataTransfer.files);
  34. const accept = uploaderContext.accept.value;
  35. if (!accept) {
  36. emit("file", files);
  37. return;
  38. }
  39. const filesFiltered = files.filter((file) => {
  40. const { type, name } = file;
  41. const extension = name.includes(".") ? `.${name.split(".").pop()}` : "";
  42. const baseType = type.replace(/\/.*$/, "");
  43. return accept.split(",").map((type2) => type2.trim()).filter((type2) => type2).some((acceptedType) => {
  44. if (acceptedType.startsWith(".")) {
  45. return extension === acceptedType;
  46. }
  47. if (/\/\*$/.test(acceptedType)) {
  48. return baseType === acceptedType.replace(/\/\*$/, "");
  49. }
  50. if (/^[^/]+\/[^/]+$/.test(acceptedType)) {
  51. return type === acceptedType;
  52. }
  53. return false;
  54. });
  55. });
  56. emit("file", filesFiltered);
  57. };
  58. const onDragover = () => {
  59. if (!disabled.value)
  60. dragover.value = true;
  61. };
  62. return (_ctx, _cache) => {
  63. return vue.openBlock(), vue.createElementBlock("div", {
  64. class: vue.normalizeClass([vue.unref(ns).b("dragger"), vue.unref(ns).is("dragover", dragover.value)]),
  65. onDrop: vue.withModifiers(onDrop, ["prevent"]),
  66. onDragover: vue.withModifiers(onDragover, ["prevent"]),
  67. onDragleave: _cache[0] || (_cache[0] = vue.withModifiers(($event) => dragover.value = false, ["prevent"]))
  68. }, [
  69. vue.renderSlot(_ctx.$slots, "default")
  70. ], 42, _hoisted_1);
  71. };
  72. }
  73. });
  74. var UploadDragger = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/upload/src/upload-dragger.vue"]]);
  75. exports["default"] = UploadDragger;
  76. //# sourceMappingURL=upload-dragger2.js.map