You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

0 lines
21 KiB

3 months ago
  1. {"ast":null,"code":"import { defineComponent, computed, ref, reactive, unref, watch, onBeforeUnmount, h, withModifiers } from 'vue';\nimport { HORIZONTAL, ScrollbarDirKey, SCROLLBAR_MIN_SIZE } from '../defaults.mjs';\nimport { virtualizedScrollbarProps } from '../props.mjs';\nimport { renderThumbStyle } from '../utils.mjs';\nimport { BAR_MAP } from '../../../scrollbar/src/util.mjs';\nimport { useNamespace } from '../../../../hooks/use-namespace/index.mjs';\nimport { cAF, rAF } from '../../../../utils/raf.mjs';\nconst ScrollBar = defineComponent({\n name: \"ElVirtualScrollBar\",\n props: virtualizedScrollbarProps,\n emits: [\"scroll\", \"start-move\", \"stop-move\"],\n setup(props, {\n emit\n }) {\n const GAP = computed(() => props.startGap + props.endGap);\n const nsVirtualScrollbar = useNamespace(\"virtual-scrollbar\");\n const nsScrollbar = useNamespace(\"scrollbar\");\n const trackRef = ref();\n const thumbRef = ref();\n let frameHandle = null;\n let onselectstartStore = null;\n const state = reactive({\n isDragging: false,\n traveled: 0\n });\n const bar = computed(() => BAR_MAP[props.layout]);\n const trackSize = computed(() => props.clientSize - unref(GAP));\n const trackStyle = computed(() => ({\n position: \"absolute\",\n width: `${HORIZONTAL === props.layout ? trackSize.value : props.scrollbarSize}px`,\n height: `${HORIZONTAL === props.layout ? props.scrollbarSize : trackSize.value}px`,\n [ScrollbarDirKey[props.layout]]: \"2px\",\n right: \"2px\",\n bottom: \"2px\",\n borderRadius: \"4px\"\n }));\n const thumbSize = computed(() => {\n const ratio = props.ratio;\n const clientSize = props.clientSize;\n if (ratio >= 100) {\n return Number.POSITIVE_INFINITY;\n }\n if (ratio >= 50) {\n return ratio * clientSize / 100;\n }\n const SCROLLBAR_MAX_SIZE = clientSize / 3;\n return Math.floor(Math.min(Math.max(ratio * clientSize, SCROLLBAR_MIN_SIZE), SCROLLBAR_MAX_SIZE));\n });\n const thumbStyle = computed(() => {\n if (!Number.isFinite(thumbSize.value)) {\n return {\n display: \"none\"\n };\n }\n const thumb = `${thumbSize.value}px`;\n const style = renderThumbStyle({\n bar: bar.value,\n size: thumb,\n move: state.traveled\n }, props.layout);\n return style;\n });\n const totalSteps = computed(() => Math.floor(props.clientSize - thumbSize.value - unref(GAP)));\n const attachEvents = () => {\n window.addEventListener(\"mousemove\", onMouseMove);\n window.addEventListener(\"mouseup\", onMouseUp);\n const thumbEl = unref(thumbRef);\n if (!thumbEl) return;\n onselectstartStore = document.onselectstart;\n document.onselectstart = () => false;\n thumbEl.addEventListener(\"touchmove\", onMouseMove, {\n passive: true\n });\n thumbEl.addEventListener(\"touchend\", onMouseUp);\n };\n const detachEvents = () => {\n window.removeEventListener(\"mousemove\", onMouseMove);\n window.removeEventListener(\"mouseup\", onMouseUp);\n document.onselectstart = onselectstartStore;\n onselectstartStore = null;\n const thumbEl = unref(thumbRef);\n if (!thumbEl) return;\n thumbEl.removeEventListener(\"touchmove\", onMouseMove);\n thumbEl.removeEventListener(\"touchend\", onMouseUp);\n };\n const onThumbMouseDown = e => {\n e.stopImmediatePropagation();\n if (e.ctrlKey || [1, 2].includes(e.button)) {\n return;\n }\n state.isDragging = true;\n state[bar.value.axis] = e.currentTarget[bar.value.offset] - (e[bar.value.client] - e.currentTarget.getBoundingClientRect()[bar.value.direction]);\n emit(\"start-move\");\n attachEvents();\n };\n const onMouseUp = () => {\n state.isDragging = false;\n state[bar.value.axis] = 0;\n emit(\"stop-move\");\n detachEvents();\n };\n const onMouseMove = e => {\n const {\n isDragging\n } = stat