Files
element-plus/packages/components/table-v2/src/utils.ts
JeremyWuuuuu 658d396ff7 feat(components): [virtual-list] renderers
- Add Footer renderer.
- Add footer rendering for table-v2.
- Update table-v2.scss for footer rendering.
- Update utils typing.
2022-04-21 16:37:07 +08:00

34 lines
947 B
TypeScript

import { h, isVNode } from 'vue'
import { addUnit, isArray, isFunction } from '@element-plus/utils'
import type { CSSProperties, Component, Slot } from 'vue'
const sumReducer = (sum: number, num: number) => sum + num
export const sum = (listLike: number | number[]) => {
return isArray(listLike) ? listLike.reduce(sumReducer, 0) : listLike
}
export const tryCall = <T>(
fLike: T,
params: T extends (...args: infer K) => unknown ? K : any,
defaultRet = {}
) => {
return isFunction(fLike) ? fLike(params) : fLike ?? defaultRet
}
export const enforceUnit = (style: CSSProperties) => {
;(['width', 'maxWidth', 'minWidth', 'height'] as const).forEach((key) => {
style[key] = addUnit(style[key])
})
return style
}
export const componentToSlot = <T>(
ComponentLike: JSX.Element | ((props: T) => Component<T>) | undefined
) =>
isVNode(ComponentLike)
? (props: T) => h(ComponentLike, props)
: (ComponentLike as Slot)