vexip-ui
Version:
A Vue 3 UI library, Highly customizability, full TypeScript, performance pretty good
1 lines • 11.2 kB
Source Map (JSON)
{"version":3,"file":"hooks.mjs","sources":["../../../components/native-scroll/hooks.ts"],"sourcesContent":["import { computed, onMounted, reactive, ref, watch } from 'vue'\n\nimport { isHiddenElement, useManualRef, useMounted, useRtl } from '@vexip-ui/hooks'\nimport { boundRange, debounce, debounceMinor, isElement, multipleFixed } from '@vexip-ui/utils'\nimport { animateScrollTo } from './helper'\n\nimport type { Ref } from 'vue'\nimport type { NativeScrollMode } from './symbol'\n\nexport function useScrollWrapper({\n mode,\n disabled,\n appear,\n scrollX,\n scrollY,\n onResize,\n onBeforeRefresh,\n onAfterRefresh,\n}: {\n mode: Ref<NativeScrollMode>,\n disabled: Ref<boolean>,\n appear: Ref<boolean>,\n // width: Ref<number | string>,\n // height: Ref<number | string>,\n scrollX: Ref<number>,\n scrollY: Ref<number>,\n onResize?: (entity: ResizeObserverEntry) => void,\n onBeforeRefresh?: () => void,\n onAfterRefresh?: () => void,\n}) {\n const { manualRef, triggerUpdate } = useManualRef()\n\n const { isRtl } = useRtl()\n\n const contentEl = ref<HTMLElement>()\n\n const content = reactive({\n el: contentEl,\n scrollWidth: 0,\n offsetWidth: 0,\n scrollHeight: 0,\n offsetHeight: 0,\n })\n\n // 当前滚动位置\n const x = manualRef(0)\n const y = manualRef(0)\n\n const percentX = manualRef(0)\n const percentY = manualRef(0)\n\n const xScrollLimit = computed(() => {\n return content.el ? content.scrollWidth - content.offsetWidth : 0\n })\n const yScrollLimit = computed(() => {\n return content.el ? content.scrollHeight - content.offsetHeight : 0\n })\n const enableXScroll = computed(() => {\n return (\n !disabled.value &&\n mode.value !== 'vertical' &&\n !!content.el &&\n content.scrollWidth > content.offsetWidth\n )\n })\n const enableYScroll = computed(() => {\n return (\n !disabled.value &&\n mode.value !== 'horizontal' &&\n !!content.el &&\n content.scrollHeight > content.offsetHeight\n )\n })\n const xBarLength = computed(() => {\n if (content.el) {\n return boundRange((content.offsetWidth / (content.scrollWidth || 1)) * 100, 5, 99)\n }\n\n return 35\n })\n const yBarLength = computed(() => {\n if (content.el) {\n return boundRange((content.offsetHeight / (content.scrollHeight || 1)) * 100, 5, 99)\n }\n\n return 35\n })\n\n watch(contentEl, () => {\n computeContentSize()\n })\n watch(scrollX, value => {\n setScrollX(value)\n })\n watch(scrollY, value => {\n setScrollY(value)\n })\n\n function setScrollX(value: number) {\n x.value = boundRange(value, 0, xScrollLimit.value)\n syncScroll()\n }\n\n function setScrollY(value: number) {\n y.value = boundRange(value, 0, yScrollLimit.value)\n syncScroll()\n }\n\n function syncScroll() {\n if (content.el) {\n content.el.scrollTo({\n top: y.value,\n left: isRtl.value ? -x.value : x.value,\n behavior: 'instant',\n })\n }\n }\n\n const { isMounted } = useMounted()\n\n function computeContentSize() {\n if (!content.el || isHiddenElement(content.el)) return\n\n content.scrollWidth = content.el.scrollWidth\n content.offsetWidth = content.el.offsetWidth\n content.scrollHeight = content.el.scrollHeight\n content.offsetHeight = content.el.offsetHeight\n\n if (mode.value !== 'vertical') {\n setScrollX(!isMounted.value && appear.value ? scrollX.value : x.value || 0)\n }\n\n if (mode.value !== 'horizontal') {\n setScrollY(!isMounted.value && appear.value ? scrollY.value : y.value || 0)\n }\n\n computePercent()\n triggerUpdate()\n }\n\n function computePercent() {\n if (content.el) {\n percentX.value = isRtl.value\n ? -multipleFixed(x.value / (xScrollLimit.value || 1), 100, 2)\n : multipleFixed(x.value / (xScrollLimit.value || 1), 100, 2)\n percentY.value = multipleFixed(y.value / (yScrollLimit.value || 1), 100, 2)\n }\n }\n\n function handleResize(entity: ResizeObserverEntry) {\n refresh()\n onResize?.(entity)\n }\n\n onMounted(() => {\n refresh()\n\n if (appear.value) {\n scrollTo(scrollX.value, scrollY.value)\n }\n })\n\n const refresh = debounceMinor(() => {\n return new Promise<void>(resolve => {\n if (typeof onBeforeRefresh === 'function') {\n onBeforeRefresh()\n }\n\n computeContentSize()\n setTimeout(() => {\n if (typeof onAfterRefresh === 'function') {\n onAfterRefresh()\n }\n\n resolve()\n }, 0)\n })\n })\n\n function scrollTo(clientX: number, clientY: number, duration = 500) {\n return new Promise<void>(resolve => {\n if (!content.el) return\n\n if (!enableXScroll.value || Math.abs(x.value - clientX) < 0.01) {\n clientX = x.value\n }\n\n if (!enableYScroll.value || Math.abs(y.value - clientY) < 0.01) {\n clientY = y.value\n }\n\n animateScrollTo({\n duration,\n el: content.el,\n xFrom: x.value,\n xTo: boundRange(clientX, 0, xScrollLimit.value),\n yFrom: y.value,\n yTo: boundRange(clientY, 0, yScrollLimit.value),\n callback: resolve,\n })\n })\n }\n\n function scrollBy(deltaX: number, deltaY: number, duration = 500) {\n return scrollTo(x.value + deltaX, y.value + deltaY, duration)\n }\n\n function scrollToElement(el: string | Element, duration?: number, offset = 0) {\n if (!content.el) return Promise.resolve()\n\n if (typeof el === 'string') {\n el = content.el.querySelector(el)!\n }\n\n if (!isElement(el)) return Promise.resolve()\n\n const wrapperRect = content.el.getBoundingClientRect()\n const elRect = el.getBoundingClientRect()\n\n let clientX = 0\n let clientY = 0\n\n if (mode.value !== 'vertical') {\n clientX = elRect.left - wrapperRect.left + offset\n }\n\n if (mode.value !== 'horizontal') {\n clientY = elRect.top - wrapperRect.top + offset\n }\n\n return scrollTo(clientX, clientY, duration)\n }\n\n return {\n contentEl,\n\n content,\n x,\n y,\n percentX,\n percentY,\n xScrollLimit,\n yScrollLimit,\n enableXScroll,\n enableYScroll,\n xBarLength,\n yBarLength,\n\n handleResize: debounce(handleResize),\n setScrollX,\n setScrollY,\n computePercent,\n refresh,\n scrollTo,\n scrollBy,\n scrollToElement,\n triggerUpdate,\n }\n}\n"],"names":["useScrollWrapper","mode","disabled","appear","scrollX","scrollY","onResize","onBeforeRefresh","onAfterRefresh","manualRef","triggerUpdate","useManualRef","isRtl","useRtl","contentEl","ref","content","reactive","x","y","percentX","percentY","xScrollLimit","computed","yScrollLimit","enableXScroll","enableYScroll","xBarLength","boundRange","yBarLength","watch","computeContentSize","value","setScrollX","setScrollY","syncScroll","isMounted","useMounted","isHiddenElement","computePercent","multipleFixed","handleResize","entity","refresh","onMounted","scrollTo","debounceMinor","resolve","clientX","clientY","duration","animateScrollTo","scrollBy","deltaX","deltaY","scrollToElement","el","offset","isElement","wrapperRect","elRect","debounce"],"mappings":"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"}