{"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  const syncing = ref(false)\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    syncing.value = true\n\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    setTimeout(() => {\n      syncing.value = false\n    }, 0)\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    syncing,\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","syncing","ref","contentEl","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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"}