测试
This commit is contained in:
5
frontend/node_modules/element-plus/es/components/image-viewer/index.d.ts
generated
vendored
Normal file
5
frontend/node_modules/element-plus/es/components/image-viewer/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
import ImageViewer from './src/image-viewer.vue';
|
||||
import type { SFCWithInstall } from 'element-plus/es/utils';
|
||||
export declare const ElImageViewer: SFCWithInstall<typeof ImageViewer>;
|
||||
export default ElImageViewer;
|
||||
export * from './src/image-viewer';
|
||||
8
frontend/node_modules/element-plus/es/components/image-viewer/index.mjs
generated
vendored
Normal file
8
frontend/node_modules/element-plus/es/components/image-viewer/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
import ImageViewer from './src/image-viewer2.mjs';
|
||||
export { imageViewerEmits, imageViewerProps } from './src/image-viewer.mjs';
|
||||
import { withInstall } from '../../utils/vue/install.mjs';
|
||||
|
||||
const ElImageViewer = withInstall(ImageViewer);
|
||||
|
||||
export { ElImageViewer, ElImageViewer as default };
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/image-viewer/index.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/image-viewer/index.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"index.mjs","sources":["../../../../../packages/components/image-viewer/index.ts"],"sourcesContent":["import { withInstall } from '@element-plus/utils'\nimport ImageViewer from './src/image-viewer.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElImageViewer: SFCWithInstall<typeof ImageViewer> =\n withInstall(ImageViewer)\nexport default ElImageViewer\n\nexport * from './src/image-viewer'\n"],"names":[],"mappings":";;;;AAEY,MAAC,aAAa,GAAG,WAAW,CAAC,WAAW;;;;"}
|
||||
42
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.d.ts
generated
vendored
Normal file
42
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.d.ts
generated
vendored
Normal file
@@ -0,0 +1,42 @@
|
||||
import type { Component, ExtractPropTypes, __ExtractPublicPropTypes } from 'vue';
|
||||
import type ImageViewer from './image-viewer.vue';
|
||||
export type ImageViewerAction = 'zoomIn' | 'zoomOut' | 'clockwise' | 'anticlockwise';
|
||||
export declare const imageViewerProps: {
|
||||
readonly urlList: import("element-plus/es/utils").EpPropFinalized<(new (...args: any[]) => string[]) | (() => string[]) | ((new (...args: any[]) => string[]) | (() => string[]))[], unknown, unknown, () => [], boolean>;
|
||||
readonly zIndex: {
|
||||
readonly type: import("vue").PropType<number>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
readonly initialIndex: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0, boolean>;
|
||||
readonly infinite: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly hideOnClickModal: BooleanConstructor;
|
||||
readonly teleported: BooleanConstructor;
|
||||
readonly closeOnPressEscape: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly zoomRate: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1.2, boolean>;
|
||||
readonly scale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1, boolean>;
|
||||
readonly minScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0.2, boolean>;
|
||||
readonly maxScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 7, boolean>;
|
||||
readonly showProgress: BooleanConstructor;
|
||||
readonly crossorigin: {
|
||||
readonly type: import("vue").PropType<import("element-plus/es/utils").EpPropMergeType<(new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials") | ((new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials"))[], unknown, unknown>>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
};
|
||||
export type ImageViewerProps = ExtractPropTypes<typeof imageViewerProps>;
|
||||
export type ImageViewerPropsPublic = __ExtractPublicPropTypes<typeof imageViewerProps>;
|
||||
export declare const imageViewerEmits: {
|
||||
close: () => boolean;
|
||||
error: (evt: Event) => boolean;
|
||||
switch: (index: number) => boolean;
|
||||
rotate: (deg: number) => boolean;
|
||||
};
|
||||
export type ImageViewerEmits = typeof imageViewerEmits;
|
||||
export interface ImageViewerMode {
|
||||
name: string;
|
||||
icon: Component;
|
||||
}
|
||||
export type ImageViewerInstance = InstanceType<typeof ImageViewer> & unknown;
|
||||
56
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.mjs
generated
vendored
Normal file
56
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.mjs
generated
vendored
Normal file
@@ -0,0 +1,56 @@
|
||||
import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
|
||||
import { mutable } from '../../../utils/typescript.mjs';
|
||||
import { isNumber } from '../../../utils/types.mjs';
|
||||
|
||||
const imageViewerProps = buildProps({
|
||||
urlList: {
|
||||
type: definePropType(Array),
|
||||
default: () => mutable([])
|
||||
},
|
||||
zIndex: {
|
||||
type: Number
|
||||
},
|
||||
initialIndex: {
|
||||
type: Number,
|
||||
default: 0
|
||||
},
|
||||
infinite: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
hideOnClickModal: Boolean,
|
||||
teleported: Boolean,
|
||||
closeOnPressEscape: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
zoomRate: {
|
||||
type: Number,
|
||||
default: 1.2
|
||||
},
|
||||
scale: {
|
||||
type: Number,
|
||||
default: 1
|
||||
},
|
||||
minScale: {
|
||||
type: Number,
|
||||
default: 0.2
|
||||
},
|
||||
maxScale: {
|
||||
type: Number,
|
||||
default: 7
|
||||
},
|
||||
showProgress: Boolean,
|
||||
crossorigin: {
|
||||
type: definePropType(String)
|
||||
}
|
||||
});
|
||||
const imageViewerEmits = {
|
||||
close: () => true,
|
||||
error: (evt) => evt instanceof Event,
|
||||
switch: (index) => isNumber(index),
|
||||
rotate: (deg) => isNumber(deg)
|
||||
};
|
||||
|
||||
export { imageViewerEmits, imageViewerProps };
|
||||
//# sourceMappingURL=image-viewer.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"image-viewer.mjs","sources":["../../../../../../packages/components/image-viewer/src/image-viewer.ts"],"sourcesContent":["import {\n buildProps,\n definePropType,\n isNumber,\n mutable,\n} from '@element-plus/utils'\n\nimport type { Component, ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type ImageViewer from './image-viewer.vue'\n\nexport type ImageViewerAction =\n | 'zoomIn'\n | 'zoomOut'\n | 'clockwise'\n | 'anticlockwise'\n\nexport const imageViewerProps = buildProps({\n /**\n * @description preview link list.\n */\n urlList: {\n type: definePropType<string[]>(Array),\n default: () => mutable([] as const),\n },\n /**\n * @description preview backdrop z-index.\n */\n zIndex: {\n type: Number,\n },\n /**\n * @description the initial preview image index, less than or equal to the length of `url-list`.\n */\n initialIndex: {\n type: Number,\n default: 0,\n },\n /**\n * @description whether preview is infinite.\n */\n infinite: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether user can emit close event when clicking backdrop.\n */\n hideOnClickModal: Boolean,\n /**\n * @description whether to append image itself to body. A nested parent element attribute transform should have this attribute set to `true`.\n */\n teleported: Boolean,\n /**\n * @description whether the image-viewer can be closed by pressing ESC.\n */\n closeOnPressEscape: {\n type: Boolean,\n default: true,\n },\n /**\n * @description the zoom rate of the image viewer zoom event.\n */\n zoomRate: {\n type: Number,\n default: 1.2,\n },\n /**\n * @description preview image scale.\n */\n scale: {\n type: Number,\n default: 1,\n },\n /**\n * @description the min scale of the image viewer zoom event.\n */\n minScale: {\n type: Number,\n default: 0.2,\n },\n /**\n * @description the max scale of the image viewer zoom event.\n */\n maxScale: {\n type: Number,\n default: 7,\n },\n /**\n * @description show preview image progress content.\n */\n showProgress: Boolean,\n /**\n * @description set HTML attribute: crossorigin.\n */\n crossorigin: {\n type: definePropType<'anonymous' | 'use-credentials' | ''>(String),\n },\n} as const)\nexport type ImageViewerProps = ExtractPropTypes<typeof imageViewerProps>\nexport type ImageViewerPropsPublic = __ExtractPublicPropTypes<\n typeof imageViewerProps\n>\n\nexport const imageViewerEmits = {\n close: () => true,\n error: (evt: Event) => evt instanceof Event,\n switch: (index: number) => isNumber(index),\n rotate: (deg: number) => isNumber(deg),\n}\nexport type ImageViewerEmits = typeof imageViewerEmits\n\nexport interface ImageViewerMode {\n name: string\n icon: Component\n}\n\nexport type ImageViewerInstance = InstanceType<typeof ImageViewer> & unknown\n"],"names":[],"mappings":";;;;AAMY,MAAC,gBAAgB,GAAG,UAAU,CAAC;AAC3C,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,OAAO,CAAC,EAAE,CAAC;AAC9B,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,gBAAgB,EAAE,OAAO;AAC3B,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,kBAAkB,EAAE;AACtB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,YAAY,EAAE,OAAO;AACvB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,CAAC,EAAE;AACS,MAAC,gBAAgB,GAAG;AAChC,EAAE,KAAK,EAAE,MAAM,IAAI;AACnB,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,KAAK;AACtC,EAAE,MAAM,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACpC,EAAE,MAAM,EAAE,CAAC,GAAG,KAAK,QAAQ,CAAC,GAAG,CAAC;AAChC;;;;"}
|
||||
108
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.vue.d.ts
generated
vendored
Normal file
108
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer.vue.d.ts
generated
vendored
Normal file
@@ -0,0 +1,108 @@
|
||||
import type { ImageViewerAction } from './image-viewer';
|
||||
declare function toggleMode(): void;
|
||||
declare function setActiveItem(index: number): void;
|
||||
declare function prev(): void;
|
||||
declare function next(): void;
|
||||
declare function handleActions(action: ImageViewerAction, options?: {}): void;
|
||||
declare function __VLS_template(): {
|
||||
progress?(_: {
|
||||
activeIndex: number;
|
||||
total: number;
|
||||
}): any;
|
||||
toolbar?(_: {
|
||||
actions: typeof handleActions;
|
||||
prev: typeof prev;
|
||||
next: typeof next;
|
||||
reset: typeof toggleMode;
|
||||
activeIndex: number;
|
||||
setActiveItem: typeof setActiveItem;
|
||||
}): any;
|
||||
"viewer-error"?(_: {
|
||||
activeIndex: number;
|
||||
src: string;
|
||||
}): any;
|
||||
default?(_: {}): any;
|
||||
};
|
||||
declare const __VLS_component: import("vue").DefineComponent<{
|
||||
readonly urlList: import("element-plus/es/utils").EpPropFinalized<(new (...args: any[]) => string[]) | (() => string[]) | ((new (...args: any[]) => string[]) | (() => string[]))[], unknown, unknown, () => [], boolean>;
|
||||
readonly zIndex: {
|
||||
readonly type: import("vue").PropType<number>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
readonly initialIndex: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0, boolean>;
|
||||
readonly infinite: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly hideOnClickModal: BooleanConstructor;
|
||||
readonly teleported: BooleanConstructor;
|
||||
readonly closeOnPressEscape: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly zoomRate: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1.2, boolean>;
|
||||
readonly scale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1, boolean>;
|
||||
readonly minScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0.2, boolean>;
|
||||
readonly maxScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 7, boolean>;
|
||||
readonly showProgress: BooleanConstructor;
|
||||
readonly crossorigin: {
|
||||
readonly type: import("vue").PropType<import("element-plus/es/utils").EpPropMergeType<(new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials") | ((new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials"))[], unknown, unknown>>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
}, {
|
||||
/**
|
||||
* @description manually switch image
|
||||
*/
|
||||
setActiveItem: typeof setActiveItem;
|
||||
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
||||
switch: (index: number) => void;
|
||||
rotate: (deg: number) => void;
|
||||
close: () => void;
|
||||
error: (evt: Event) => void;
|
||||
}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
||||
readonly urlList: import("element-plus/es/utils").EpPropFinalized<(new (...args: any[]) => string[]) | (() => string[]) | ((new (...args: any[]) => string[]) | (() => string[]))[], unknown, unknown, () => [], boolean>;
|
||||
readonly zIndex: {
|
||||
readonly type: import("vue").PropType<number>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
readonly initialIndex: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0, boolean>;
|
||||
readonly infinite: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly hideOnClickModal: BooleanConstructor;
|
||||
readonly teleported: BooleanConstructor;
|
||||
readonly closeOnPressEscape: import("element-plus/es/utils").EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
|
||||
readonly zoomRate: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1.2, boolean>;
|
||||
readonly scale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 1, boolean>;
|
||||
readonly minScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 0.2, boolean>;
|
||||
readonly maxScale: import("element-plus/es/utils").EpPropFinalized<NumberConstructor, unknown, unknown, 7, boolean>;
|
||||
readonly showProgress: BooleanConstructor;
|
||||
readonly crossorigin: {
|
||||
readonly type: import("vue").PropType<import("element-plus/es/utils").EpPropMergeType<(new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials") | ((new (...args: any[]) => "" | "anonymous" | "use-credentials") | (() => "" | "anonymous" | "use-credentials"))[], unknown, unknown>>;
|
||||
readonly required: false;
|
||||
readonly validator: ((val: unknown) => boolean) | undefined;
|
||||
__epPropKey: true;
|
||||
};
|
||||
}>> & {
|
||||
onError?: ((evt: Event) => any) | undefined;
|
||||
onClose?: (() => any) | undefined;
|
||||
onSwitch?: ((index: number) => any) | undefined;
|
||||
onRotate?: ((deg: number) => any) | undefined;
|
||||
}, {
|
||||
readonly scale: number;
|
||||
readonly infinite: import("element-plus/es/utils").EpPropMergeType<BooleanConstructor, unknown, unknown>;
|
||||
readonly teleported: boolean;
|
||||
readonly closeOnPressEscape: import("element-plus/es/utils").EpPropMergeType<BooleanConstructor, unknown, unknown>;
|
||||
readonly initialIndex: number;
|
||||
readonly urlList: string[];
|
||||
readonly zoomRate: number;
|
||||
readonly minScale: number;
|
||||
readonly maxScale: number;
|
||||
readonly hideOnClickModal: boolean;
|
||||
readonly showProgress: boolean;
|
||||
}>;
|
||||
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
||||
export default _default;
|
||||
type __VLS_WithTemplateSlots<T, S> = T & {
|
||||
new (): {
|
||||
$slots: S;
|
||||
};
|
||||
};
|
||||
465
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer2.mjs
generated
vendored
Normal file
465
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer2.mjs
generated
vendored
Normal file
@@ -0,0 +1,465 @@
|
||||
import { defineComponent, markRaw, ref, effectScope, computed, shallowRef, watch, nextTick, onMounted, openBlock, createBlock, unref, withCtx, createVNode, Transition, createElementVNode, normalizeClass, normalizeStyle, withModifiers, createCommentVNode, createElementBlock, Fragment, renderSlot, createTextVNode, toDisplayString, resolveDynamicComponent } from 'vue';
|
||||
import { clamp, useEventListener } from '@vueuse/core';
|
||||
import { throttle } from 'lodash-unified';
|
||||
import ElFocusTrap from '../../focus-trap/src/focus-trap.mjs';
|
||||
import { ElTeleport } from '../../teleport/index.mjs';
|
||||
import { ElIcon } from '../../icon/index.mjs';
|
||||
import { FullScreen, ScaleToOriginal, Close, ArrowLeft, ArrowRight, ZoomOut, ZoomIn, RefreshLeft, RefreshRight } from '@element-plus/icons-vue';
|
||||
import { imageViewerProps, imageViewerEmits } from './image-viewer.mjs';
|
||||
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
||||
import { useLocale } from '../../../hooks/use-locale/index.mjs';
|
||||
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
||||
import { useZIndex } from '../../../hooks/use-z-index/index.mjs';
|
||||
import { getEventCode } from '../../../utils/dom/event.mjs';
|
||||
import { EVENT_CODE } from '../../../constants/aria.mjs';
|
||||
import { keysOf } from '../../../utils/objects.mjs';
|
||||
|
||||
const __default__ = defineComponent({
|
||||
name: "ElImageViewer"
|
||||
});
|
||||
const _sfc_main = /* @__PURE__ */ defineComponent({
|
||||
...__default__,
|
||||
props: imageViewerProps,
|
||||
emits: imageViewerEmits,
|
||||
setup(__props, { expose, emit }) {
|
||||
var _a;
|
||||
const props = __props;
|
||||
const modes = {
|
||||
CONTAIN: {
|
||||
name: "contain",
|
||||
icon: markRaw(FullScreen)
|
||||
},
|
||||
ORIGINAL: {
|
||||
name: "original",
|
||||
icon: markRaw(ScaleToOriginal)
|
||||
}
|
||||
};
|
||||
let stopWheelListener;
|
||||
let prevOverflow = "";
|
||||
const { t } = useLocale();
|
||||
const ns = useNamespace("image-viewer");
|
||||
const { nextZIndex } = useZIndex();
|
||||
const wrapper = ref();
|
||||
const imgRef = ref();
|
||||
const scopeEventListener = effectScope();
|
||||
const scaleClamped = computed(() => {
|
||||
const { scale, minScale, maxScale } = props;
|
||||
return clamp(scale, minScale, maxScale);
|
||||
});
|
||||
const loading = ref(true);
|
||||
const loadError = ref(false);
|
||||
const activeIndex = ref(props.initialIndex);
|
||||
const mode = shallowRef(modes.CONTAIN);
|
||||
const transform = ref({
|
||||
scale: scaleClamped.value,
|
||||
deg: 0,
|
||||
offsetX: 0,
|
||||
offsetY: 0,
|
||||
enableTransition: false
|
||||
});
|
||||
const zIndex = ref((_a = props.zIndex) != null ? _a : nextZIndex());
|
||||
const isSingle = computed(() => {
|
||||
const { urlList } = props;
|
||||
return urlList.length <= 1;
|
||||
});
|
||||
const isFirst = computed(() => activeIndex.value === 0);
|
||||
const isLast = computed(() => activeIndex.value === props.urlList.length - 1);
|
||||
const currentImg = computed(() => props.urlList[activeIndex.value]);
|
||||
const arrowPrevKls = computed(() => [
|
||||
ns.e("btn"),
|
||||
ns.e("prev"),
|
||||
ns.is("disabled", !props.infinite && isFirst.value)
|
||||
]);
|
||||
const arrowNextKls = computed(() => [
|
||||
ns.e("btn"),
|
||||
ns.e("next"),
|
||||
ns.is("disabled", !props.infinite && isLast.value)
|
||||
]);
|
||||
const imgStyle = computed(() => {
|
||||
const { scale, deg, offsetX, offsetY, enableTransition } = transform.value;
|
||||
let translateX = offsetX / scale;
|
||||
let translateY = offsetY / scale;
|
||||
const radian = deg * Math.PI / 180;
|
||||
const cosRadian = Math.cos(radian);
|
||||
const sinRadian = Math.sin(radian);
|
||||
translateX = translateX * cosRadian + translateY * sinRadian;
|
||||
translateY = translateY * cosRadian - offsetX / scale * sinRadian;
|
||||
const style = {
|
||||
transform: `scale(${scale}) rotate(${deg}deg) translate(${translateX}px, ${translateY}px)`,
|
||||
transition: enableTransition ? "transform .3s" : ""
|
||||
};
|
||||
if (mode.value.name === modes.CONTAIN.name) {
|
||||
style.maxWidth = style.maxHeight = "100%";
|
||||
}
|
||||
return style;
|
||||
});
|
||||
const progress = computed(() => `${activeIndex.value + 1} / ${props.urlList.length}`);
|
||||
function hide() {
|
||||
unregisterEventListener();
|
||||
stopWheelListener == null ? void 0 : stopWheelListener();
|
||||
document.body.style.overflow = prevOverflow;
|
||||
emit("close");
|
||||
}
|
||||
function registerEventListener() {
|
||||
const keydownHandler = throttle((e) => {
|
||||
const code = getEventCode(e);
|
||||
switch (code) {
|
||||
case EVENT_CODE.esc:
|
||||
props.closeOnPressEscape && hide();
|
||||
break;
|
||||
case EVENT_CODE.space:
|
||||
toggleMode();
|
||||
break;
|
||||
case EVENT_CODE.left:
|
||||
prev();
|
||||
break;
|
||||
case EVENT_CODE.up:
|
||||
handleActions("zoomIn");
|
||||
break;
|
||||
case EVENT_CODE.right:
|
||||
next();
|
||||
break;
|
||||
case EVENT_CODE.down:
|
||||
handleActions("zoomOut");
|
||||
break;
|
||||
}
|
||||
});
|
||||
const mousewheelHandler = throttle((e) => {
|
||||
const delta = e.deltaY || e.deltaX;
|
||||
handleActions(delta < 0 ? "zoomIn" : "zoomOut", {
|
||||
zoomRate: props.zoomRate,
|
||||
enableTransition: false
|
||||
});
|
||||
});
|
||||
scopeEventListener.run(() => {
|
||||
useEventListener(document, "keydown", keydownHandler);
|
||||
useEventListener(document, "wheel", mousewheelHandler);
|
||||
});
|
||||
}
|
||||
function unregisterEventListener() {
|
||||
scopeEventListener.stop();
|
||||
}
|
||||
function handleImgLoad() {
|
||||
loading.value = false;
|
||||
}
|
||||
function handleImgError(e) {
|
||||
loadError.value = true;
|
||||
loading.value = false;
|
||||
emit("error", e);
|
||||
e.target.alt = t("el.image.error");
|
||||
}
|
||||
function handleMouseDown(e) {
|
||||
if (loading.value || e.button !== 0 || !wrapper.value)
|
||||
return;
|
||||
transform.value.enableTransition = false;
|
||||
const { offsetX, offsetY } = transform.value;
|
||||
const startX = e.pageX;
|
||||
const startY = e.pageY;
|
||||
const dragHandler = throttle((ev) => {
|
||||
transform.value = {
|
||||
...transform.value,
|
||||
offsetX: offsetX + ev.pageX - startX,
|
||||
offsetY: offsetY + ev.pageY - startY
|
||||
};
|
||||
});
|
||||
const removeMousemove = useEventListener(document, "mousemove", dragHandler);
|
||||
useEventListener(document, "mouseup", () => {
|
||||
removeMousemove();
|
||||
});
|
||||
e.preventDefault();
|
||||
}
|
||||
function reset() {
|
||||
transform.value = {
|
||||
scale: scaleClamped.value,
|
||||
deg: 0,
|
||||
offsetX: 0,
|
||||
offsetY: 0,
|
||||
enableTransition: false
|
||||
};
|
||||
}
|
||||
function toggleMode() {
|
||||
if (loading.value || loadError.value)
|
||||
return;
|
||||
const modeNames = keysOf(modes);
|
||||
const modeValues = Object.values(modes);
|
||||
const currentMode = mode.value.name;
|
||||
const index = modeValues.findIndex((i) => i.name === currentMode);
|
||||
const nextIndex = (index + 1) % modeNames.length;
|
||||
mode.value = modes[modeNames[nextIndex]];
|
||||
reset();
|
||||
}
|
||||
function setActiveItem(index) {
|
||||
loadError.value = false;
|
||||
const len = props.urlList.length;
|
||||
activeIndex.value = (index + len) % len;
|
||||
}
|
||||
function prev() {
|
||||
if (isFirst.value && !props.infinite)
|
||||
return;
|
||||
setActiveItem(activeIndex.value - 1);
|
||||
}
|
||||
function next() {
|
||||
if (isLast.value && !props.infinite)
|
||||
return;
|
||||
setActiveItem(activeIndex.value + 1);
|
||||
}
|
||||
function handleActions(action, options = {}) {
|
||||
if (loading.value || loadError.value)
|
||||
return;
|
||||
const { minScale, maxScale } = props;
|
||||
const { zoomRate, rotateDeg, enableTransition } = {
|
||||
zoomRate: props.zoomRate,
|
||||
rotateDeg: 90,
|
||||
enableTransition: true,
|
||||
...options
|
||||
};
|
||||
switch (action) {
|
||||
case "zoomOut":
|
||||
if (transform.value.scale > minScale) {
|
||||
transform.value.scale = Number.parseFloat((transform.value.scale / zoomRate).toFixed(3));
|
||||
}
|
||||
break;
|
||||
case "zoomIn":
|
||||
if (transform.value.scale < maxScale) {
|
||||
transform.value.scale = Number.parseFloat((transform.value.scale * zoomRate).toFixed(3));
|
||||
}
|
||||
break;
|
||||
case "clockwise":
|
||||
transform.value.deg += rotateDeg;
|
||||
emit("rotate", transform.value.deg);
|
||||
break;
|
||||
case "anticlockwise":
|
||||
transform.value.deg -= rotateDeg;
|
||||
emit("rotate", transform.value.deg);
|
||||
break;
|
||||
}
|
||||
transform.value.enableTransition = enableTransition;
|
||||
}
|
||||
function onFocusoutPrevented(event) {
|
||||
var _a2;
|
||||
if (((_a2 = event.detail) == null ? void 0 : _a2.focusReason) === "pointer") {
|
||||
event.preventDefault();
|
||||
}
|
||||
}
|
||||
function onCloseRequested() {
|
||||
if (props.closeOnPressEscape) {
|
||||
hide();
|
||||
}
|
||||
}
|
||||
function wheelHandler(e) {
|
||||
if (!e.ctrlKey)
|
||||
return;
|
||||
if (e.deltaY < 0) {
|
||||
e.preventDefault();
|
||||
return false;
|
||||
} else if (e.deltaY > 0) {
|
||||
e.preventDefault();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
watch(() => scaleClamped.value, (val) => {
|
||||
transform.value.scale = val;
|
||||
});
|
||||
watch(currentImg, () => {
|
||||
nextTick(() => {
|
||||
const $img = imgRef.value;
|
||||
if (!($img == null ? void 0 : $img.complete)) {
|
||||
loading.value = true;
|
||||
}
|
||||
});
|
||||
});
|
||||
watch(activeIndex, (val) => {
|
||||
reset();
|
||||
emit("switch", val);
|
||||
});
|
||||
onMounted(() => {
|
||||
registerEventListener();
|
||||
stopWheelListener = useEventListener("wheel", wheelHandler, {
|
||||
passive: false
|
||||
});
|
||||
prevOverflow = document.body.style.overflow;
|
||||
document.body.style.overflow = "hidden";
|
||||
});
|
||||
expose({
|
||||
setActiveItem
|
||||
});
|
||||
return (_ctx, _cache) => {
|
||||
return openBlock(), createBlock(unref(ElTeleport), {
|
||||
to: "body",
|
||||
disabled: !_ctx.teleported
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createVNode(Transition, {
|
||||
name: "viewer-fade",
|
||||
appear: ""
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createElementVNode("div", {
|
||||
ref_key: "wrapper",
|
||||
ref: wrapper,
|
||||
tabindex: -1,
|
||||
class: normalizeClass(unref(ns).e("wrapper")),
|
||||
style: normalizeStyle({ zIndex: zIndex.value })
|
||||
}, [
|
||||
createVNode(unref(ElFocusTrap), {
|
||||
loop: "",
|
||||
trapped: "",
|
||||
"focus-trap-el": wrapper.value,
|
||||
"focus-start-el": "container",
|
||||
onFocusoutPrevented,
|
||||
onReleaseRequested: onCloseRequested
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createElementVNode("div", {
|
||||
class: normalizeClass(unref(ns).e("mask")),
|
||||
onClick: withModifiers(($event) => _ctx.hideOnClickModal && hide(), ["self"])
|
||||
}, null, 10, ["onClick"]),
|
||||
createCommentVNode(" CLOSE "),
|
||||
createElementVNode("span", {
|
||||
class: normalizeClass([unref(ns).e("btn"), unref(ns).e("close")]),
|
||||
onClick: hide
|
||||
}, [
|
||||
createVNode(unref(ElIcon), null, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(Close))
|
||||
]),
|
||||
_: 1
|
||||
})
|
||||
], 2),
|
||||
createCommentVNode(" ARROW "),
|
||||
!unref(isSingle) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
|
||||
createElementVNode("span", {
|
||||
class: normalizeClass(unref(arrowPrevKls)),
|
||||
onClick: prev
|
||||
}, [
|
||||
createVNode(unref(ElIcon), null, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(ArrowLeft))
|
||||
]),
|
||||
_: 1
|
||||
})
|
||||
], 2),
|
||||
createElementVNode("span", {
|
||||
class: normalizeClass(unref(arrowNextKls)),
|
||||
onClick: next
|
||||
}, [
|
||||
createVNode(unref(ElIcon), null, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(ArrowRight))
|
||||
]),
|
||||
_: 1
|
||||
})
|
||||
], 2)
|
||||
], 64)) : createCommentVNode("v-if", true),
|
||||
_ctx.$slots.progress || _ctx.showProgress ? (openBlock(), createElementBlock("div", {
|
||||
key: 1,
|
||||
class: normalizeClass([unref(ns).e("btn"), unref(ns).e("progress")])
|
||||
}, [
|
||||
renderSlot(_ctx.$slots, "progress", {
|
||||
activeIndex: activeIndex.value,
|
||||
total: _ctx.urlList.length
|
||||
}, () => [
|
||||
createTextVNode(toDisplayString(unref(progress)), 1)
|
||||
])
|
||||
], 2)) : createCommentVNode("v-if", true),
|
||||
createCommentVNode(" ACTIONS "),
|
||||
createElementVNode("div", {
|
||||
class: normalizeClass([unref(ns).e("btn"), unref(ns).e("actions")])
|
||||
}, [
|
||||
createElementVNode("div", {
|
||||
class: normalizeClass(unref(ns).e("actions__inner"))
|
||||
}, [
|
||||
renderSlot(_ctx.$slots, "toolbar", {
|
||||
actions: handleActions,
|
||||
prev,
|
||||
next,
|
||||
reset: toggleMode,
|
||||
activeIndex: activeIndex.value,
|
||||
setActiveItem
|
||||
}, () => [
|
||||
createVNode(unref(ElIcon), {
|
||||
onClick: ($event) => handleActions("zoomOut")
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(ZoomOut))
|
||||
]),
|
||||
_: 1
|
||||
}, 8, ["onClick"]),
|
||||
createVNode(unref(ElIcon), {
|
||||
onClick: ($event) => handleActions("zoomIn")
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(ZoomIn))
|
||||
]),
|
||||
_: 1
|
||||
}, 8, ["onClick"]),
|
||||
createElementVNode("i", {
|
||||
class: normalizeClass(unref(ns).e("actions__divider"))
|
||||
}, null, 2),
|
||||
createVNode(unref(ElIcon), { onClick: toggleMode }, {
|
||||
default: withCtx(() => [
|
||||
(openBlock(), createBlock(resolveDynamicComponent(unref(mode).icon)))
|
||||
]),
|
||||
_: 1
|
||||
}),
|
||||
createElementVNode("i", {
|
||||
class: normalizeClass(unref(ns).e("actions__divider"))
|
||||
}, null, 2),
|
||||
createVNode(unref(ElIcon), {
|
||||
onClick: ($event) => handleActions("anticlockwise")
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(RefreshLeft))
|
||||
]),
|
||||
_: 1
|
||||
}, 8, ["onClick"]),
|
||||
createVNode(unref(ElIcon), {
|
||||
onClick: ($event) => handleActions("clockwise")
|
||||
}, {
|
||||
default: withCtx(() => [
|
||||
createVNode(unref(RefreshRight))
|
||||
]),
|
||||
_: 1
|
||||
}, 8, ["onClick"])
|
||||
])
|
||||
], 2)
|
||||
], 2),
|
||||
createCommentVNode(" CANVAS "),
|
||||
createElementVNode("div", {
|
||||
class: normalizeClass(unref(ns).e("canvas"))
|
||||
}, [
|
||||
loadError.value && _ctx.$slots["viewer-error"] ? renderSlot(_ctx.$slots, "viewer-error", {
|
||||
key: 0,
|
||||
activeIndex: activeIndex.value,
|
||||
src: unref(currentImg)
|
||||
}) : (openBlock(), createElementBlock("img", {
|
||||
ref_key: "imgRef",
|
||||
ref: imgRef,
|
||||
key: unref(currentImg),
|
||||
src: unref(currentImg),
|
||||
style: normalizeStyle(unref(imgStyle)),
|
||||
class: normalizeClass(unref(ns).e("img")),
|
||||
crossorigin: _ctx.crossorigin,
|
||||
onLoad: handleImgLoad,
|
||||
onError: handleImgError,
|
||||
onMousedown: handleMouseDown
|
||||
}, null, 46, ["src", "crossorigin"]))
|
||||
], 2),
|
||||
renderSlot(_ctx.$slots, "default")
|
||||
]),
|
||||
_: 3
|
||||
}, 8, ["focus-trap-el"])
|
||||
], 6)
|
||||
]),
|
||||
_: 3
|
||||
})
|
||||
]),
|
||||
_: 3
|
||||
}, 8, ["disabled"]);
|
||||
};
|
||||
}
|
||||
});
|
||||
var ImageViewer = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "image-viewer.vue"]]);
|
||||
|
||||
export { ImageViewer as default };
|
||||
//# sourceMappingURL=image-viewer2.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer2.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/image-viewer/src/image-viewer2.mjs.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
2
frontend/node_modules/element-plus/es/components/image-viewer/style/css.d.ts
generated
vendored
Normal file
2
frontend/node_modules/element-plus/es/components/image-viewer/style/css.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import 'element-plus/es/components/base/style/css';
|
||||
import 'element-plus/theme-chalk/el-image-viewer.css';
|
||||
3
frontend/node_modules/element-plus/es/components/image-viewer/style/css.mjs
generated
vendored
Normal file
3
frontend/node_modules/element-plus/es/components/image-viewer/style/css.mjs
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import '../../base/style/css.mjs';
|
||||
import 'element-plus/theme-chalk/el-image-viewer.css';
|
||||
//# sourceMappingURL=css.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/image-viewer/style/css.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/image-viewer/style/css.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
||||
2
frontend/node_modules/element-plus/es/components/image-viewer/style/index.d.ts
generated
vendored
Normal file
2
frontend/node_modules/element-plus/es/components/image-viewer/style/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import 'element-plus/es/components/base/style';
|
||||
import 'element-plus/theme-chalk/src/image-viewer.scss';
|
||||
3
frontend/node_modules/element-plus/es/components/image-viewer/style/index.mjs
generated
vendored
Normal file
3
frontend/node_modules/element-plus/es/components/image-viewer/style/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import '../../base/style/index.mjs';
|
||||
import 'element-plus/theme-chalk/src/image-viewer.scss';
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/image-viewer/style/index.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/image-viewer/style/index.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
||||
Reference in New Issue
Block a user