import XEUtils from 'xe-utils' import { addClass, removeClass } from '../../ui/src/dom' const rowMoveCls = 'row--drag-move' const colMoveClass = 'col--drag-move' /** * 上下拖拽 */ export function moveRowAnimateToTb (elemList: NodeListOf | HTMLDivElement[], offsetTop: number) { XEUtils.arrayEach(elemList, trEl => { trEl.style.transform = `translateY(${offsetTop}px)` }) requestAnimationFrame(() => { XEUtils.arrayEach(elemList, trEl => { addClass(trEl, rowMoveCls) trEl.style.transform = '' }) }) } export function clearRowAnimate (elem: HTMLElement | undefined) { setTimeout(() => { if (elem) { XEUtils.arrayEach(elem.querySelectorAll(`.vxe-body--row.${rowMoveCls}`), elem => removeClass(elem, rowMoveCls)) } }, 500) } /** * 左右拖拽 */ export function moveColAnimateToLr (elemList: NodeListOf | HTMLDivElement[], offsetLeft: number) { XEUtils.arrayEach(elemList, trEl => { trEl.style.transform = `translateX(${offsetLeft}px)` }) requestAnimationFrame(() => { XEUtils.arrayEach(elemList, trEl => { addClass(trEl, colMoveClass) trEl.style.transform = '' }) }) } export function clearColAnimate (elem: HTMLElement | undefined) { setTimeout(() => { if (elem) { XEUtils.arrayEach(elem.querySelectorAll(`.vxe-table--column.${colMoveClass}`), elem => removeClass(elem, colMoveClass)) } }, 500) }