element-plus
Version:
A Component Library for Vue 3
1 lines • 21.8 kB
Source Map (JSON)
{"version":3,"file":"build-list.mjs","sources":["../../../../../../../packages/components/virtual-list/src/builders/build-list.ts"],"sourcesContent":["import {\n computed,\n defineComponent,\n getCurrentInstance,\n ref,\n nextTick,\n onMounted,\n onUpdated,\n resolveDynamicComponent,\n h,\n unref,\n} from 'vue'\nimport { hasOwn } from '@vue/shared'\n\nimport { isNumber, isString } from '@element-plus/utils/util'\nimport isServer from '@element-plus/utils/isServer'\n\nimport { useCache } from '../hooks/use-cache'\nimport useWheel from '../hooks/use-wheel'\nimport Scrollbar from '../components/scrollbar'\nimport { getScrollDir, isHorizontal, getRTLOffsetType } from '../utils'\nimport { virtualizedListProps } from '../props'\nimport {\n AUTO_ALIGNMENT,\n BACKWARD,\n FORWARD,\n RTL,\n HORIZONTAL,\n ITEM_RENDER_EVT,\n SCROLL_EVT,\n RTL_OFFSET_NAG,\n RTL_OFFSET_POS_DESC,\n} from '../defaults'\n\nimport type { VNode, CSSProperties, Slot, VNodeChild } from 'vue'\nimport type { ListConstructorProps, Alignment } from '../types'\nimport type { VirtualizedListProps } from '../props'\n\nconst createList = ({\n name,\n getOffset,\n getItemSize,\n getItemOffset,\n getEstimatedTotalSize,\n getStartIndexForOffset,\n getStopIndexForStartIndex,\n initCache,\n clearCache,\n validateProps,\n}: ListConstructorProps<VirtualizedListProps>) => {\n return defineComponent({\n name: name ?? 'ElVirtualList',\n props: virtualizedListProps,\n emits: [ITEM_RENDER_EVT, SCROLL_EVT],\n setup(props, { emit, expose }) {\n validateProps(props)\n const instance = getCurrentInstance()!\n const dynamicSizeCache = ref(initCache(props, instance))\n\n const getItemStyleCache = useCache()\n // refs\n // here windowRef and innerRef can be type of HTMLElement\n // or user defined component type, depends on the type passed\n // by user\n const windowRef = ref<HTMLElement>()\n const innerRef = ref<HTMLElement>()\n const scrollbarRef = ref()\n const states = ref({\n isScrolling: false,\n scrollDir: 'forward',\n scrollOffset: isNumber(props.initScrollOffset)\n ? props.initScrollOffset\n : 0,\n updateRequested: false,\n isScrollbarDragging: false,\n scrollbarAlwaysOn: props.scrollbarAlwaysOn,\n })\n\n // computed\n const itemsToRender = computed(() => {\n const { total, cache } = props\n const { isScrolling, scrollDir, scrollOffset } = unref(states)\n\n if (total === 0) {\n return [0, 0, 0, 0]\n }\n\n const startIndex = getStartIndexForOffset(\n props,\n scrollOffset,\n unref(dynamicSizeCache)\n )\n const stopIndex = getStopIndexForStartIndex(\n props,\n startIndex,\n scrollOffset,\n unref(dynamicSizeCache)\n )\n\n const cacheBackward =\n !isScrolling || scrollDir === BACKWARD ? Math.max(1, cache) : 1\n const cacheForward =\n !isScrolling || scrollDir === FORWARD ? Math.max(1, cache) : 1\n\n return [\n Math.max(0, startIndex - cacheBackward),\n Math.max(0, Math.min(total! - 1, stopIndex + cacheForward)),\n startIndex,\n stopIndex,\n ]\n })\n\n const estimatedTotalSize = computed(() =>\n getEstimatedTotalSize(props, unref(dynamicSizeCache))\n )\n\n const _isHorizontal = computed(() => isHorizontal(props.layout))\n\n const windowStyle = computed(() => [\n {\n position: 'relative',\n overflow: 'hidden',\n WebkitOverflowScrolling: 'touch',\n willChange: 'transform',\n },\n {\n direction: props.direction,\n height: isNumber(props.height) ? `${props.height}px` : props.height,\n width: isNumber(props.width) ? `${props.width}px` : props.width,\n },\n props.style,\n ])\n\n const innerStyle = computed(() => {\n const size = unref(estimatedTotalSize)\n const horizontal = unref(_isHorizontal)\n return {\n height: horizontal ? '100%' : `${size}px`,\n pointerEvents: unref(states).isScrolling ? 'none' : undefined,\n width: horizontal ? `${size}px` : '100%',\n }\n })\n\n const clientSize = computed(() =>\n _isHorizontal.value ? props.width : props.height\n )\n\n // methods\n const { onWheel } = useWheel(\n {\n atStartEdge: computed(() => states.value.scrollOffset <= 0),\n atEndEdge: computed(\n () => states.value.scrollOffset >= estimatedTotalSize.value\n ),\n layout: computed(() => props.layout),\n },\n (offset) => {\n ;(\n scrollbarRef.value as any as {\n onMouseUp: () => void\n }\n ).onMouseUp?.()\n scrollTo(\n Math.min(\n states.value.scrollOffset + offset,\n estimatedTotalSize.value - (clientSize.value as number)\n )\n )\n }\n )\n\n const emitEvents = () => {\n const { total } = props\n\n if (total! > 0) {\n const [cacheStart, cacheEnd, visibleStart, visibleEnd] =\n unref(itemsToRender)\n emit(ITEM_RENDER_EVT, cacheStart, cacheEnd, visibleStart, visibleEnd)\n }\n\n const { scrollDir, scrollOffset, updateRequested } = unref(states)\n emit(SCROLL_EVT, scrollDir, scrollOffset, updateRequested)\n }\n\n const scrollVertically = (e: Event) => {\n const { clientHeight, scrollHeight, scrollTop } =\n e.currentTarget as HTMLElement\n const _states = unref(states)\n if (_states.scrollOffset === scrollTop) {\n return\n }\n\n const scrollOffset = Math.max(\n 0,\n Math.min(scrollTop, scrollHeight - clientHeight)\n )\n\n states.value = {\n ..._states,\n isScrolling: true,\n scrollDir: getScrollDir(_states.scrollOffset, scrollOffset),\n scrollOffset,\n updateRequested: false,\n }\n\n nextTick(resetIsScrolling)\n }\n\n const scrollHorizontally = (e: Event) => {\n const { clientWidth, scrollLeft, scrollWidth } =\n e.currentTarget as HTMLElement\n const _states = unref(states)\n\n if (_states.scrollOffset === scrollLeft) {\n return\n }\n\n const { direction } = props\n\n let scrollOffset = scrollLeft\n\n if (direction === RTL) {\n // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n switch (getRTLOffsetType()) {\n case RTL_OFFSET_NAG: {\n scrollOffset = -scrollLeft\n break\n }\n case RTL_OFFSET_POS_DESC: {\n scrollOffset = scrollWidth - clientWidth - scrollLeft\n break\n }\n }\n }\n\n scrollOffset = Math.max(\n 0,\n Math.min(scrollOffset, scrollWidth - clientWidth)\n )\n\n states.value = {\n ..._states,\n isScrolling: true,\n scrollDir: getScrollDir(_states.scrollOffset, scrollOffset),\n scrollOffset,\n updateRequested: false,\n }\n\n nextTick(resetIsScrolling)\n }\n\n const onScroll = (e: Event) => {\n unref(_isHorizontal) ? scrollHorizontally(e) : scrollVertically(e)\n emitEvents()\n }\n\n const onScrollbarScroll = (distanceToGo: number, totalSteps: number) => {\n const offset =\n ((estimatedTotalSize.value - (clientSize.value as number)) /\n totalSteps) *\n distanceToGo\n scrollTo(\n Math.min(\n estimatedTotalSize.value - (clientSize.value as number),\n offset\n )\n )\n }\n\n const scrollTo = (offset: number) => {\n offset = Math.max(offset, 0)\n\n if (offset === unref(states).scrollOffset) {\n return\n }\n\n states.value = {\n ...unref(states),\n scrollOffset: offset,\n scrollDir: getScrollDir(unref(states).scrollOffset, offset),\n updateRequested: true,\n }\n\n nextTick(resetIsScrolling)\n }\n\n const scrollToItem = (\n idx: number,\n alignment: Alignment = AUTO_ALIGNMENT\n ) => {\n const { scrollOffset } = unref(states)\n\n idx = Math.max(0, Math.min(idx, props.total! - 1))\n scrollTo(\n getOffset(\n props,\n idx,\n alignment,\n scrollOffset,\n unref(dynamicSizeCache)\n )\n )\n }\n\n const getItemStyle = (idx: number) => {\n const { direction, itemSize, layout } = props\n\n const itemStyleCache = getItemStyleCache.value(\n clearCache && itemSize,\n clearCache && layout,\n clearCache && direction\n )\n\n let style: CSSProperties\n if (hasOwn(itemStyleCache, String(idx))) {\n style = itemStyleCache[idx]\n } else {\n const offset = getItemOffset(props, idx, unref(dynamicSizeCache))\n const size = getItemSize(props, idx, unref(dynamicSizeCache))\n const horizontal = unref(_isHorizontal)\n\n const isRtl = direction === RTL\n const offsetHorizontal = horizontal ? offset : 0\n itemStyleCache[idx] = style = {\n position: 'absolute',\n left: isRtl ? undefined : `${offsetHorizontal}px`,\n right: isRtl ? `${offsetHorizontal}px` : undefined,\n top: !horizontal ? `${offset}px` : 0,\n height: !horizontal ? `${size}px` : '100%',\n width: horizontal ? `${size}px` : '100%',\n }\n }\n\n return style\n }\n\n // TODO:\n // perf optimization here, reset isScrolling with debounce.\n\n const resetIsScrolling = () => {\n // timer = null\n\n states.value.isScrolling = false\n nextTick(() => {\n getItemStyleCache.value(-1, null, null)\n })\n }\n\n const resetScrollTop = () => {\n const window = windowRef.value\n if (window) {\n window.scrollTop = 0\n }\n }\n\n // life cycles\n onMounted(() => {\n if (isServer) return\n const { initScrollOffset } = props\n const windowElement = unref(windowRef)\n if (isNumber(initScrollOffset) && windowElement) {\n if (unref(_isHorizontal)) {\n windowElement.scrollLeft = initScrollOffset\n } else {\n windowElement.scrollTop = initScrollOffset\n }\n }\n\n emitEvents()\n })\n\n onUpdated(() => {\n const { direction, layout } = props\n const { scrollOffset, updateRequested } = unref(states)\n const windowElement = unref(windowRef)\n\n if (updateRequested && windowElement) {\n if (layout === HORIZONTAL) {\n if (direction === RTL) {\n // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // So we need to determine which browser behavior we're dealing with, and mimic it.\n switch (getRTLOffsetType()) {\n case 'negative': {\n windowElement.scrollLeft = -scrollOffset\n break\n }\n case 'positive-ascending': {\n windowElement.scrollLeft = scrollOffset\n break\n }\n default: {\n const { clientWidth, scrollWidth } = windowElement\n windowElement.scrollLeft =\n scrollWidth - clientWidth - scrollOffset\n break\n }\n }\n } else {\n windowElement.scrollLeft = scrollOffset\n }\n } else {\n windowElement.scrollTop = scrollOffset\n }\n }\n })\n\n const api = {\n clientSize,\n estimatedTotalSize,\n windowStyle,\n windowRef,\n innerRef,\n innerStyle,\n itemsToRender,\n scrollbarRef,\n states,\n getItemStyle,\n onScroll,\n onScrollbarScroll,\n onWheel,\n scrollTo,\n scrollToItem,\n resetScrollTop,\n }\n\n expose({\n windowRef,\n innerRef,\n getItemStyleCache,\n scrollTo,\n scrollToItem,\n resetScrollTop,\n states,\n })\n\n return api\n },\n\n render(ctx: any) {\n const {\n $slots,\n className,\n clientSize,\n containerElement,\n data,\n getItemStyle,\n innerElement,\n itemsToRender,\n innerStyle,\n layout,\n total,\n onScroll,\n onScrollbarScroll,\n onWheel,\n states,\n useIsScrolling,\n windowStyle,\n } = ctx\n\n const [start, end] = itemsToRender\n\n const Container = resolveDynamicComponent(containerElement)\n const Inner = resolveDynamicComponent(innerElement)\n\n const children = [] as VNodeChild[]\n\n if (total > 0) {\n for (let i = start; i <= end; i++) {\n children.push(\n ($slots.default as Slot)?.({\n data,\n key: i,\n index: i,\n isScrolling: useIsScrolling ? states.isScrolling : undefined,\n style: getItemStyle(i),\n })\n )\n }\n }\n\n const InnerNode = [\n h(\n Inner as VNode,\n {\n style: innerStyle,\n ref: 'innerRef',\n },\n !isString(Inner)\n ? {\n default: () => children,\n }\n : children\n ),\n ]\n\n const scrollbar = h(Scrollbar, {\n ref: 'scrollbarRef',\n clientSize,\n layout,\n onScroll: onScrollbarScroll,\n ratio: (clientSize * 100) / this.estimatedTotalSize,\n scrollFrom:\n states.scrollOffset / (this.estimatedTotalSize - clientSize),\n total,\n })\n\n const listContainer = h(\n Container as VNode,\n {\n class: className,\n style: windowStyle,\n onScroll,\n onWheel,\n ref: 'windowRef',\n key: 0,\n },\n !isString(Container) ? { default: () => [InnerNode] } : [InnerNode]\n )\n\n return h(\n 'div',\n {\n key: 0,\n class: [\n 'el-vl__wrapper',\n states.scrollbarAlwaysOn ? 'always-on' : '',\n ],\n },\n [listContainer, scrollbar]\n )\n },\n })\n}\n\nexport default createList\n"],"names":["Scrollbar"],"mappings":"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"}