2022-12-12 01:08:28 +00:00
|
|
|
import { w as withInstall } from "../badge/index2.js";
|
|
|
|
import { defineComponent, computed, useSlots, getCurrentInstance, watch, ref, onMounted, nextTick, onUnmounted, openBlock, createElementBlock, normalizeClass, createElementVNode, withModifiers, unref, renderSlot, createBlock, withCtx, createTextVNode, toDisplayString, createVNode, Fragment, renderList } from "vue";
|
2023-11-03 03:48:11 +00:00
|
|
|
import { a as _sfc_main$2, l as layer } from "../_chunks/@layui/index.js";
|
2022-12-12 01:08:28 +00:00
|
|
|
import { t as templateRef } from "../_chunks/@vueuse/index.js";
|
|
|
|
import { _ as _sfc_main$1 } from "../button/index2.js";
|
|
|
|
import { C as Cropper } from "../_chunks/cropperjs/index.js";
|
|
|
|
import { u as useI18n } from "../datePicker/index2.js";
|
2022-11-14 03:59:26 +00:00
|
|
|
import "../_chunks/dayjs/index.js";
|
|
|
|
import "../_chunks/@umijs/index.js";
|
|
|
|
import "../input/index2.js";
|
|
|
|
import "../dropdownMenu/index2.js";
|
|
|
|
import "../dropdown/index2.js";
|
|
|
|
import "../_chunks/vue-i18n/index.js";
|
|
|
|
import "../_chunks/@intlify/index.js";
|
|
|
|
import "../_chunks/@vue/index.js";
|
2022-12-12 01:08:28 +00:00
|
|
|
var index = /* @__PURE__ */ (() => '/*!\n * Cropper.js v1.5.12\n * https://fengyuanchen.github.io/cropperjs\n *\n * Copyright 2015-present Chen Fengyuan\n * Released under the MIT license\n *\n * Date: 2021-06-12T08:00:11.623Z\n */.cropper-container{direction:ltr;font-size:0;line-height:0;position:relative;-ms-touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.cropper-container img{image-orientation:0deg;display:block;height:100%;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}.cropper-canvas,.cropper-crop-box,.cropper-drag-box,.cropper-modal,.cropper-wrap-box{bottom:0;left:0;position:absolute;right:0;top:0}.cropper-canvas,.cropper-wrap-box{overflow:hidden}.cropper-drag-box{background-color:#fff;opacity:0}.cropper-modal{background-color:#000;opacity:.5}.cropper-view-box{display:block;height:100%;outline:1px solid #39f;outline-color:#3399ffbf;overflow:hidden;width:100%}.cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}.cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:33.33333%;left:0;top:33.33333%;width:100%}.cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:33.33333%;top:0;width:33.33333%}.cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}.cropper-center:after,.cropper-center:before{background-color:#eee;content:" ";display:block;position:absolute}.cropper-center:before{height:1px;left:-3px;top:0;width:7px}.cropper-center:after{height:7px;left:0;top:-3px;width:1px}.cropper-face,.cropper-line,.cropper-point{display:block;height:100%;opacity:.1;position:absolute;width:100%}.cropper-face{background-color:#fff;left:0;top:0}.cropper-line{background-color:#39f}.cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}.cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}.cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}.cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}.cropper-point{background-color:#39f;height:5px;opacity:.75;width:5px}.cropper-point.point-e{cursor:ew-resize;margin-top:-3px;right:-3px;top:50%}.cropper-point.point-n{cursor:ns-resize;left:50%;margin-left:-3px;top:-3px}.cropper-point.point-w{cursor:ew-resize;left:-3px;margin-top:-3px;top:50%}.cropper-point.point-s{bottom:-3px;cursor:s-resize;left:50%;margin-left:-3px}.cropper-point.point-ne{cursor:nesw-resize;right:-3px;top:-3px}.cropper-point.point-nw{cursor:nwse-resize;left:-3px;top:-3px}.cropper-point.point-sw{bottom:-3px;cursor:nesw-resize;left:-3px}.cropper-point.point-se{bottom:-3px;cursor:nwse-resize;height:20px;opacity:1;right:-3px;width:20px}@media (min-width:768px){.cropper-point.point-se{height:15px;width:15px}}@media (min-width:992px){.cropper-point.point-se{height:10px;width:10px}}@media (min-width:1200px){.cropper-point.point-se{height:5px;opacity:.75;width:5px}}.cropper-point.point-se:before{background-color:#39f;bottom:-50%;content:" ";display:block;height:200%;opacity:0;position:absolute;right:-50%;width:200%}.cropper-invisible{opacity:0}.cropper-bg{background-image:url()}.cropper-hide{display:block;height:0;position:absolute;width:0}.cropper-hidden{display:none!important}.cropper-move{cursor:move}.cropper-crop{cursor:crosshair}.cropper-disabled .cropper-drag-box,.cropper-disabled .cropper-face,.cropper-disabled .cropper-line,.cropper-disabled .cropper-point{cursor:not-allowed}:root{--button-primary-text-color: #fff;--button-primary-background-color: var(--global-primary-color);--button-primary-border-color: var(--global-primary-color);--button-normal-text-color: #fff;--button-normal-background-color: var(--global-normal-color);--button-normal-border-color: var(--global-normal-color);--button-
|
|
|
|
const _hoisted_1 = ["name", "field", "multiple", "accept", "disabled"];
|
|
|
|
const _hoisted_2 = { key: 0 };
|
|
|
|
const _hoisted_3 = ["onClick"];
|
|
|
|
const _hoisted_4 = ["onClick"];
|
|
|
|
const _hoisted_5 = /* @__PURE__ */ createElementVNode("i", { class: "layui-icon" }, "\uE67C", -1);
|
|
|
|
const _hoisted_6 = /* @__PURE__ */ createElementVNode("div", {
|
|
|
|
class: "layui-hide",
|
|
|
|
id: "uploadDemoView"
|
|
|
|
}, [
|
|
|
|
/* @__PURE__ */ createElementVNode("hr"),
|
|
|
|
/* @__PURE__ */ createElementVNode("img", {
|
|
|
|
src: "",
|
|
|
|
alt: "\u4E0A\u4F20\u6210\u529F\u540E\u6E32\u67D3",
|
|
|
|
style: { "max-width": "196px" }
|
|
|
|
})
|
|
|
|
], -1);
|
|
|
|
const _hoisted_7 = ["src", "id"];
|
|
|
|
const __default__ = {
|
|
|
|
name: "LayUpload"
|
|
|
|
};
|
|
|
|
const _sfc_main = defineComponent({
|
|
|
|
...__default__,
|
|
|
|
props: {
|
|
|
|
url: null,
|
|
|
|
data: null,
|
|
|
|
headers: null,
|
|
|
|
acceptMime: { default: "MIME_type" },
|
|
|
|
field: { default: "file" },
|
|
|
|
size: { default: 0 },
|
|
|
|
multiple: { type: Boolean, default: false },
|
|
|
|
number: { default: 0 },
|
|
|
|
drag: { type: Boolean, default: false },
|
|
|
|
disabled: { type: Boolean, default: false },
|
|
|
|
disabledPreview: { type: Boolean, default: false },
|
|
|
|
cut: { type: Boolean, default: false },
|
|
|
|
cutOptions: { default: void 0 },
|
|
|
|
text: null,
|
|
|
|
dragText: null,
|
|
|
|
modelValue: { default: null },
|
|
|
|
auto: { type: Boolean, default: true }
|
|
|
|
},
|
|
|
|
emits: [
|
|
|
|
"choose",
|
|
|
|
"chooseAfter",
|
|
|
|
"before",
|
|
|
|
"done",
|
|
|
|
"error",
|
|
|
|
"cutdone",
|
|
|
|
"cutcancel",
|
|
|
|
"update:modelValue"
|
|
|
|
],
|
|
|
|
setup(__props, { emit }) {
|
|
|
|
const props = __props;
|
|
|
|
const getCutDownResult = () => {
|
|
|
|
if (_cropper) {
|
|
|
|
const canvas = _cropper.getCroppedCanvas();
|
|
|
|
let imgData = canvas.toDataURL('"image/png"');
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
let orgInfo = activeUploadFiles.value[0];
|
|
|
|
emit("cutdone", Object.assign({ currentTimeStamp, cutResult: imgData, orginal: orgInfo }));
|
|
|
|
let newFile = dataURLtoFile(imgData);
|
|
|
|
if (!props.auto) {
|
|
|
|
emit("update:modelValue", [newFile]);
|
|
|
|
clearLightCutEffect();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
commonUploadTransaction([newFile]);
|
|
|
|
nextTick(() => clearAllCutEffect());
|
|
|
|
} else {
|
|
|
|
errorF(cutInitErrorMsg.value);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const closeCutDownModal = () => {
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
emit("cutcancel", Object.assign({ currentTimeStamp }));
|
|
|
|
nextTick(() => clearAllCutEffect());
|
|
|
|
};
|
|
|
|
const clearAllCutEffect = () => {
|
|
|
|
activeUploadFiles.value = [];
|
|
|
|
activeUploadFilesImgs.value = [];
|
|
|
|
innerCutVisible.value = false;
|
|
|
|
orgFileInput.value.value = "";
|
|
|
|
_cropper = null;
|
|
|
|
};
|
|
|
|
const clearLightCutEffect = () => {
|
|
|
|
activeUploadFiles.value = [];
|
|
|
|
activeUploadFilesImgs.value = [];
|
|
|
|
innerCutVisible.value = false;
|
|
|
|
_cropper = null;
|
|
|
|
};
|
|
|
|
const { t } = useI18n();
|
|
|
|
const text = computed(() => {
|
|
|
|
return props.text ? props.text : t("upload.text");
|
|
|
|
});
|
|
|
|
const dragText = computed(() => {
|
|
|
|
return props.dragText ? props.dragText : t("upload.dragText");
|
|
|
|
});
|
|
|
|
const defaultErrorMsg = computed(() => t("upload.defaultErrorMsg"));
|
|
|
|
const urlErrorMsg = computed(() => t("upload.urlErrorMsg"));
|
|
|
|
const numberErrorMsg = computed(() => t("upload.numberErrorMsg"));
|
|
|
|
const occurFileSizeErrorMsg = computed(() => t("upload.occurFileSizeErrorMsg"));
|
|
|
|
const cutInitErrorMsg = computed(() => t("upload.cutInitErrorMsg"));
|
|
|
|
const uploadSuccess = computed(() => t("upload.uploadSuccess"));
|
|
|
|
const startUploadMsg = computed(() => t("upload.startUploadMsg"));
|
|
|
|
const cannotSupportCutMsg = computed(() => t("upload.cannotSupportCutMsg"));
|
|
|
|
const title = computed(() => t("upload.title"));
|
|
|
|
const confirmBtn = computed(() => t("upload.confirmBtn"));
|
|
|
|
const cancelBtn = computed(() => t("upload.cancelBtn"));
|
|
|
|
let defaultCutLayerOption = computed(() => {
|
|
|
|
return {
|
|
|
|
type: "component",
|
|
|
|
title: title.value,
|
|
|
|
shade: true,
|
|
|
|
shadeClose: true,
|
|
|
|
area: ["640px", "640px"],
|
|
|
|
btn: [
|
|
|
|
{ text: confirmBtn.value, callback: getCutDownResult },
|
|
|
|
{ text: cancelBtn.value, callback: closeCutDownModal }
|
|
|
|
]
|
|
|
|
};
|
|
|
|
});
|
|
|
|
const slot = useSlots();
|
|
|
|
slot.default && slot.default();
|
|
|
|
getCurrentInstance();
|
|
|
|
watch(() => props.modelValue, () => {
|
|
|
|
if (!props.modelValue) {
|
|
|
|
clearAllCutEffect();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
const isDragEnter = ref(false);
|
|
|
|
const activeUploadFiles = ref([]);
|
|
|
|
const activeUploadFilesImgs = ref([]);
|
|
|
|
const orgFileInput = templateRef("orgFileInput");
|
|
|
|
let _cropper = null;
|
|
|
|
let computedCutLayerOption;
|
|
|
|
if (props.cutOptions && props.cutOptions.layerOption) {
|
|
|
|
computedCutLayerOption = computed(() => Object.assign(defaultCutLayerOption, props.cutOptions.layerOption));
|
|
|
|
} else {
|
|
|
|
computedCutLayerOption = computed(() => defaultCutLayerOption.value);
|
|
|
|
}
|
|
|
|
const innerCutVisible = ref(false);
|
|
|
|
const localUploadTransaction = (option) => {
|
|
|
|
const { url, files } = option;
|
|
|
|
let formData = new FormData();
|
|
|
|
if (url.length <= 5) {
|
|
|
|
errorF(urlErrorMsg.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (Array.isArray(files) && files.length > 0) {
|
|
|
|
for (let i = 0; i < files.length; i++) {
|
|
|
|
let _file = files[i];
|
|
|
|
formData.append(props.field + "[" + i + "]", _file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (props.data && props.data instanceof Object) {
|
|
|
|
let _requestDate = props.data;
|
|
|
|
for (const key in _requestDate) {
|
|
|
|
formData.append(key, _requestDate[key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let utimer = window.setTimeout(() => {
|
|
|
|
localUpload({ url, formData }, function() {
|
|
|
|
clearTimeout(utimer);
|
|
|
|
});
|
|
|
|
}, 200);
|
|
|
|
};
|
|
|
|
const dataURLtoFile = (dataurl) => {
|
|
|
|
let arr = dataurl.split(",");
|
|
|
|
let mime = "";
|
|
|
|
if (arr.length > 0) {
|
|
|
|
mime = arr[0].match(/:(.*?);/)[1];
|
|
|
|
}
|
|
|
|
let bstr = atob(arr[1]);
|
|
|
|
let n = bstr.length;
|
|
|
|
let u8arr = new Uint8Array(n);
|
|
|
|
while (n--) {
|
|
|
|
u8arr[n] = bstr.charCodeAt(n);
|
|
|
|
}
|
|
|
|
return new Blob([u8arr], { type: mime });
|
|
|
|
};
|
|
|
|
const errorF = (errorText) => {
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
let errorMsg = errorText ? errorText : defaultErrorMsg;
|
|
|
|
errorMsg = `layui-vue:${errorMsg}`;
|
|
|
|
console.warn(errorMsg);
|
|
|
|
layer.msg(errorMsg, { icon: 2, time: 1e3 }, function(res) {
|
|
|
|
});
|
|
|
|
emit("error", Object.assign({ currentTimeStamp, msg: errorMsg }));
|
|
|
|
};
|
|
|
|
const localUpload = (option, callback) => {
|
|
|
|
let xhr = new XMLHttpRequest();
|
|
|
|
let url = option.url;
|
|
|
|
let formData = option.formData;
|
|
|
|
const cb = callback;
|
|
|
|
xhr.onreadystatechange = function() {
|
|
|
|
let currentTimeStamp2 = new Date().valueOf();
|
|
|
|
if (xhr.readyState === 1) {
|
|
|
|
if (xhr.status >= 200 && xhr.status <= 300 || xhr.status === 304 || xhr.status == 0) {
|
|
|
|
let successText = startUploadMsg.value;
|
|
|
|
emit("before", Object.assign({ currentTimeStamp: currentTimeStamp2, msg: successText, ...option }));
|
|
|
|
}
|
|
|
|
} else if (xhr.readyState === 4) {
|
|
|
|
let successText = xhr.responseText ? xhr.responseText : uploadSuccess;
|
|
|
|
if (xhr.status >= 200 && xhr.status <= 300 || xhr.status === 304 || xhr.status == 0) {
|
|
|
|
let data = xhr.responseText;
|
|
|
|
emit("done", { currentTimeStamp: currentTimeStamp2, msg: successText, data });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
xhr.open("post", url, true);
|
|
|
|
if (props.headers) {
|
|
|
|
for (let key in props.headers) {
|
|
|
|
xhr.setRequestHeader(key, props.headers[key]);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
xhr.setRequestHeader("Accept", "application/json, text/javascript");
|
|
|
|
}
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
emit("before", Object.assign(option, currentTimeStamp));
|
|
|
|
xhr.send(formData);
|
|
|
|
if (cb && typeof cb == "function") {
|
|
|
|
cb();
|
|
|
|
}
|
|
|
|
clearAllCutEffect();
|
|
|
|
};
|
|
|
|
const filetoDataURL = (file, fn) => {
|
|
|
|
const reader = new FileReader();
|
|
|
|
reader.onloadend = function(e) {
|
|
|
|
fn(e.target.result);
|
|
|
|
};
|
|
|
|
reader.readAsDataURL(file);
|
|
|
|
};
|
|
|
|
const uploadChange = (e) => {
|
|
|
|
e.preventDefault();
|
|
|
|
const _files = [...e.target.files || e.dataTransfer.files];
|
|
|
|
if (props.multiple && props.number != 0 && props.number < _files.length) {
|
|
|
|
errorF(numberErrorMsg.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (props.size && props.size != 0) {
|
|
|
|
for (let i = 0; i < _files.length; i++) {
|
|
|
|
let _file = _files[i];
|
|
|
|
let _size = _file.size;
|
|
|
|
if (_size > props.size * 1024) {
|
|
|
|
errorF(occurFileSizeErrorMsg.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for (let item of _files) {
|
|
|
|
activeUploadFiles.value.push(item);
|
|
|
|
filetoDataURL(item, function(res) {
|
|
|
|
activeUploadFilesImgs.value.push(res);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
let arm1 = props.cut && props.acceptMime.indexOf("image") != -1 && props.multiple == false;
|
|
|
|
let arm2 = props.cut && props.acceptMime.indexOf("image") != -1 && props.multiple == true;
|
|
|
|
if (arm1) {
|
|
|
|
innerCutVisible.value = true;
|
|
|
|
setTimeout(() => {
|
|
|
|
let _imgs = document.getElementsByClassName("_lay_upload_img");
|
|
|
|
if (_imgs && _imgs.length > 0) {
|
|
|
|
let _img = _imgs[0];
|
|
|
|
_cropper = new Cropper(_img, {
|
|
|
|
aspectRatio: 16 / 9
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
clearAllCutEffect();
|
|
|
|
}
|
|
|
|
}, 200);
|
|
|
|
} else {
|
|
|
|
if (arm2) {
|
|
|
|
console.warn(cannotSupportCutMsg.value);
|
|
|
|
}
|
|
|
|
if (!props.auto) {
|
|
|
|
emit("update:modelValue", _files);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
commonUploadTransaction(_files);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const commonUploadTransaction = (_files) => {
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
let successText = uploadSuccess;
|
|
|
|
if (props.url) {
|
|
|
|
localUploadTransaction({
|
|
|
|
url: props.url,
|
|
|
|
files: _files
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
emit("done", { currentTimeStamp, msg: successText, data: _files });
|
|
|
|
clearAllCutEffect();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const chooseFile = () => {
|
|
|
|
let _target = orgFileInput.value;
|
|
|
|
if (_target) {
|
|
|
|
_target.click();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const clickOrgInput = () => {
|
|
|
|
let currentTimeStamp = new Date().valueOf();
|
|
|
|
emit("choose", currentTimeStamp);
|
|
|
|
};
|
|
|
|
const dragRef = ref();
|
|
|
|
function dragEnter(e) {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
function dragOver(e) {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
onMounted(() => {
|
|
|
|
nextTick(() => {
|
|
|
|
if (dragRef.value) {
|
|
|
|
dragRef.value.addEventListener("dragenter", dragEnter, false);
|
|
|
|
dragRef.value.addEventListener("dragover", dragOver, false);
|
|
|
|
dragRef.value.addEventListener("drop", uploadChange, false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
onUnmounted(() => {
|
|
|
|
if (dragRef.value) {
|
|
|
|
dragRef.value.removeEventListener("dragenter");
|
|
|
|
dragRef.value.removeEventListener("dragover");
|
|
|
|
dragRef.value.removeEventListener("drop");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return (_ctx, _cache) => {
|
|
|
|
return openBlock(), createElementBlock("div", {
|
|
|
|
class: normalizeClass(["layui-upload layui-upload-wrap", __props.disabledPreview ? "layui-upload-file-disabled" : ""])
|
|
|
|
}, [
|
|
|
|
createElementVNode("input", {
|
|
|
|
type: "file",
|
|
|
|
class: "layui-upload-file",
|
|
|
|
ref_key: "orgFileInput",
|
|
|
|
ref: orgFileInput,
|
|
|
|
name: __props.field,
|
|
|
|
field: __props.field,
|
|
|
|
multiple: __props.multiple,
|
|
|
|
accept: __props.acceptMime,
|
|
|
|
disabled: __props.disabled,
|
|
|
|
onClick: clickOrgInput,
|
|
|
|
onChange: uploadChange
|
|
|
|
}, null, 40, _hoisted_1),
|
|
|
|
!__props.drag ? (openBlock(), createElementBlock("div", _hoisted_2, [
|
|
|
|
createElementVNode("div", {
|
|
|
|
class: "layui-upload-btn-box",
|
|
|
|
onClick: withModifiers(chooseFile, ["stop"])
|
|
|
|
}, [
|
|
|
|
unref(slot).default ? renderSlot(_ctx.$slots, "default", {
|
|
|
|
key: 0,
|
|
|
|
disabled: __props.disabled
|
|
|
|
}) : (openBlock(), createBlock(_sfc_main$1, {
|
|
|
|
key: 1,
|
|
|
|
type: "primary",
|
|
|
|
disabled: __props.disabled
|
|
|
|
}, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
createTextVNode(toDisplayString(unref(text)), 1)
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
}, 8, ["disabled"]))
|
|
|
|
], 8, _hoisted_3)
|
|
|
|
])) : (openBlock(), createElementBlock("div", {
|
|
|
|
key: 1,
|
|
|
|
ref_key: "dragRef",
|
|
|
|
ref: dragRef,
|
|
|
|
class: normalizeClass([
|
|
|
|
"layui-upload-drag",
|
|
|
|
__props.disabled ? "layui-upload-drag-disable" : isDragEnter.value ? "layui-upload-drag-draging" : ""
|
|
|
|
]),
|
|
|
|
onClick: withModifiers(chooseFile, ["stop"])
|
|
|
|
}, [
|
|
|
|
_hoisted_5,
|
|
|
|
createElementVNode("p", null, toDisplayString(unref(dragText)), 1),
|
|
|
|
_hoisted_6
|
|
|
|
], 10, _hoisted_4)),
|
|
|
|
createVNode(unref(_sfc_main$2), {
|
|
|
|
modelValue: innerCutVisible.value,
|
|
|
|
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => innerCutVisible.value = $event),
|
|
|
|
title: unref(computedCutLayerOption).title,
|
|
|
|
move: unref(computedCutLayerOption).move,
|
|
|
|
resize: unref(computedCutLayerOption).resize,
|
|
|
|
shade: unref(computedCutLayerOption).shade,
|
|
|
|
shadeClose: unref(computedCutLayerOption).shadeClose,
|
|
|
|
shadeOpacity: unref(computedCutLayerOption).shadeOpacity,
|
|
|
|
zIndex: unref(computedCutLayerOption).zIndex,
|
|
|
|
btnAlign: unref(computedCutLayerOption).btnAlign,
|
|
|
|
area: unref(computedCutLayerOption).area,
|
|
|
|
anim: unref(computedCutLayerOption).anim,
|
|
|
|
isOutAnim: unref(computedCutLayerOption).isOutAnim,
|
|
|
|
btn: unref(computedCutLayerOption).btn,
|
|
|
|
onClose: clearAllCutEffect
|
|
|
|
}, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
(openBlock(true), createElementBlock(Fragment, null, renderList(activeUploadFilesImgs.value, (base64str, index2) => {
|
|
|
|
return openBlock(), createElementBlock("div", {
|
|
|
|
class: "copper-container",
|
|
|
|
key: `file${index2}`
|
|
|
|
}, [
|
|
|
|
createElementVNode("img", {
|
|
|
|
src: base64str,
|
|
|
|
id: `_lay_upload_img${index2}`,
|
|
|
|
class: "_lay_upload_img"
|
|
|
|
}, null, 8, _hoisted_7)
|
|
|
|
]);
|
|
|
|
}), 128))
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
}, 8, ["modelValue", "title", "move", "resize", "shade", "shadeClose", "shadeOpacity", "zIndex", "btnAlign", "area", "anim", "isOutAnim", "btn"]),
|
|
|
|
createElementVNode("div", {
|
|
|
|
class: normalizeClass(["layui-upload-list", __props.disabledPreview ? "layui-upload-list-disabled" : ""])
|
|
|
|
}, [
|
|
|
|
renderSlot(_ctx.$slots, "preview")
|
|
|
|
], 2)
|
|
|
|
], 2);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
const component = withInstall(_sfc_main);
|
|
|
|
export { component as default };
|