| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389 |
- import { VxeUI } from '../../../ui';
- import { formatText } from '../../../ui/src/utils';
- import { getTpImg, addClass, removeClass, hasControlKey } from '../../../ui/src/dom';
- import { errLog } from '../../../ui/src/log';
- import XEUtils from 'xe-utils';
- const { getI18n, getIcon, renderEmptyElement } = VxeUI;
- function showDropTip($xeTableCustomPanel, evnt, optEl, showLine, dragPos) {
- const customPanelInternalData = $xeTableCustomPanel.internalData;
- const bodyWrapperElem = $xeTableCustomPanel.$refs.refBodyWrapperElem;
- if (!bodyWrapperElem) {
- return;
- }
- const customBodyElem = $xeTableCustomPanel.$refs.refCustomBodyElem;
- if (!customBodyElem) {
- return;
- }
- const { prevDragToChild } = customPanelInternalData;
- const bodyWrapperRect = bodyWrapperElem.getBoundingClientRect();
- const customBodyRect = customBodyElem.getBoundingClientRect();
- const dragLineEl = $xeTableCustomPanel.$refs.refDragLineElem;
- if (optEl) {
- if (dragLineEl) {
- if (showLine) {
- const optRect = optEl.getBoundingClientRect();
- dragLineEl.style.display = 'block';
- dragLineEl.style.left = `${Math.max(0, customBodyRect.x - bodyWrapperRect.x)}px`;
- dragLineEl.style.top = `${Math.max(1, optRect.y + bodyWrapperElem.scrollTop - bodyWrapperRect.y)}px`;
- dragLineEl.style.height = `${optRect.height}px`;
- dragLineEl.style.width = `${optRect.width}px`;
- dragLineEl.setAttribute('drag-pos', dragPos);
- dragLineEl.setAttribute('drag-to-child', prevDragToChild ? 'y' : 'n');
- }
- else {
- dragLineEl.style.display = '';
- }
- }
- }
- else {
- if (dragLineEl) {
- dragLineEl.style.display = 'node';
- }
- }
- const dragTipEl = $xeTableCustomPanel.$refs.refDragTipElem;
- if (dragTipEl) {
- dragTipEl.style.display = 'block';
- dragTipEl.style.top = `${Math.min(bodyWrapperElem.clientHeight + bodyWrapperElem.scrollTop - dragTipEl.clientHeight, evnt.clientY + bodyWrapperElem.scrollTop - bodyWrapperRect.y)}px`;
- dragTipEl.style.left = `${Math.min(bodyWrapperElem.clientWidth + bodyWrapperElem.scrollLeft - dragTipEl.clientWidth, evnt.clientX + bodyWrapperElem.scrollLeft - bodyWrapperRect.x)}px`;
- dragTipEl.setAttribute('drag-status', showLine ? (prevDragToChild ? 'sub' : 'normal') : 'disabled');
- }
- }
- function hideDropTip($xeTableCustomPanel) {
- const dragTipEl = $xeTableCustomPanel.$refs.refDragTipElem;
- const dragLineEl = $xeTableCustomPanel.$refs.refDragLineElem;
- if (dragTipEl) {
- dragTipEl.style.display = '';
- }
- if (dragLineEl) {
- dragLineEl.style.display = '';
- }
- }
- const renderDragTip = (h, $xeTableCustomPanel) => {
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const { dragTipText } = customPanelReactData;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- return h('div', {}, [
- h('div', {
- ref: 'refDragLineElem',
- class: ['vxe-table-custom-popup--drag-line', {
- 'is--guides': columnDragOpts.showGuidesStatus
- }]
- }),
- h('div', {
- ref: 'refDragTipElem',
- class: 'vxe-table-custom-popup--drag-tip'
- }, [
- h('div', {
- class: 'vxe-table-custom-popup--drag-tip-wrapper'
- }, [
- h('div', {
- class: 'vxe-table-custom-popup--drag-tip-status'
- }, [
- h('span', {
- class: ['vxe-table-custom-popup--drag-tip-normal-status', getIcon().TABLE_DRAG_STATUS_ROW]
- }),
- h('span', {
- class: ['vxe-table-custom-popup--drag-tip-sub-status', getIcon().TABLE_DRAG_STATUS_SUB_ROW]
- }),
- h('span', {
- class: ['vxe-table-custom-popup--drag-tip-group-status', getIcon().TABLE_DRAG_STATUS_AGG_GROUP]
- }),
- h('span', {
- class: ['vxe-table-custom-popup--drag-tip-values-status', getIcon().TABLE_DRAG_STATUS_AGG_VALUES]
- }),
- h('span', {
- class: ['vxe-table-custom-popup--drag-tip-disabled-status', getIcon().TABLE_DRAG_DISABLED]
- })
- ]),
- h('div', {
- class: 'vxe-table-custom-popup--drag-tip-content'
- }, `${dragTipText || ''}`)
- ])
- ])
- ]);
- };
- const renderSimplePanel = (h, _vm) => {
- const VxeUIButtonComponent = VxeUI.getComponent('VxeButton');
- const props = _vm;
- const $xeTable = _vm.$xeTable;
- const tableProps = $xeTable;
- const tableReactData = $xeTable;
- const $xeGrid = $xeTable.$xeGrid;
- const $xeGantt = $xeTable.$xeGantt;
- const { customStore } = props;
- const { treeConfig, rowGroupConfig, aggregateConfig } = tableProps;
- const { isCustomStatus, customColumnList } = tableReactData;
- const customOpts = $xeTable.computeCustomOpts;
- const { immediate } = customOpts;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- const { maxHeight } = customStore;
- const { checkMethod, visibleMethod, allowVisible, allowSort, allowFixed, trigger, placement } = customOpts;
- const isMaxFixedColumn = $xeTable.computeIsMaxFixedColumn;
- const { isCrossDrag } = columnDragOpts;
- const slots = customOpts.slots || {};
- const headerSlot = slots.header;
- const topSlot = slots.top;
- const bottomSlot = slots.bottom;
- const defaultSlot = slots.default;
- const footerSlot = slots.footer;
- const colVNs = [];
- const customWrapperOns = {};
- const isAllChecked = customStore.isAll;
- const isAllIndeterminate = customStore.isIndeterminate;
- // hover 触发
- if (trigger === 'hover') {
- customWrapperOns.mouseenter = _vm.handleWrapperMouseenterEvent;
- customWrapperOns.mouseleave = _vm.handleWrapperMouseleaveEvent;
- }
- const params = {
- $table: $xeTable,
- $grid: $xeGrid,
- $gantt: $xeGantt,
- columns: customColumnList,
- isAllChecked,
- isAllIndeterminate,
- isCustomStatus
- };
- XEUtils.eachTree(customColumnList, (column, index, items, path, parent) => {
- const isVisible = visibleMethod ? visibleMethod({ $table: $xeTable, column }) : true;
- if (isVisible) {
- const isChecked = column.renderVisible;
- const isIndeterminate = column.halfVisible;
- const isColGroup = column.children && column.children.length;
- const colTitle = formatText(column.getTitle(), 1);
- const isDisabled = checkMethod ? !checkMethod({ $table: $xeTable, column }) : false;
- const isHidden = !isChecked;
- colVNs.push(h('li', {
- key: column.id,
- attrs: {
- colid: column.id
- },
- class: ['vxe-table-custom--option', `level--${column.level}`, {
- 'is--hidden': isDisabled || isHidden,
- 'is--group': isColGroup
- }],
- on: {
- dragstart: _vm.sortDragstartEvent,
- dragend: _vm.sortDragendEvent,
- dragover: _vm.sortDragoverEvent
- }
- }, [
- allowVisible
- ? h('div', {
- class: ['vxe-table-custom--checkbox-option', {
- 'is--checked': isChecked,
- 'is--indeterminate': isIndeterminate,
- 'is--disabled': isDisabled
- }],
- attrs: {
- title: getI18n('vxe.custom.setting.colVisible')
- },
- on: {
- click: (evnt) => {
- if (!isDisabled) {
- _vm.changeCheckboxOption(column, evnt);
- }
- }
- }
- }, [
- h('span', {
- class: ['vxe-checkbox--icon', isIndeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : (isChecked ? getIcon().TABLE_CHECKBOX_CHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED)]
- })
- ])
- : renderEmptyElement($xeTable),
- h('div', {
- class: 'vxe-table-custom--name-option'
- }, [
- allowSort && ((isCrossDrag ? immediate : false) || column.level === 1)
- ? h('div', {
- class: 'vxe-table-custom--sort-option'
- }, [
- h('span', {
- class: ['vxe-table-custom--sort-btn', {
- 'is--disabled': isDisabled || isHidden
- }],
- attrs: {
- title: getI18n('vxe.custom.setting.sortHelpTip')
- },
- on: isDisabled || isHidden
- ? {}
- : {
- mousedown: _vm.sortMousedownEvent,
- mouseup: _vm.sortMouseupEvent
- }
- }, [
- h('i', {
- class: getIcon().TABLE_CUSTOM_SORT
- })
- ])
- ])
- : renderEmptyElement($xeTable),
- column.type === 'html'
- ? h('div', {
- key: '1',
- class: 'vxe-table-custom--checkbox-label',
- domProps: {
- innerHTML: colTitle
- }
- })
- : h('div', {
- key: '0',
- class: 'vxe-table-custom--checkbox-label',
- attrs: {
- title: colTitle
- }
- }, colTitle)
- ]),
- !parent && allowFixed
- ? h('div', {
- class: 'vxe-table-custom--fixed-option'
- }, [
- h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- icon: column.renderFixed === 'left' ? getIcon().TOOLBAR_TOOLS_FIXED_LEFT_ACTIVE : getIcon().TOOLBAR_TOOLS_FIXED_LEFT,
- status: column.renderFixed === 'left' ? 'primary' : '',
- disabled: isDisabled || isHidden || (isMaxFixedColumn && !column.renderFixed),
- title: getI18n(column.renderFixed === 'left' ? 'vxe.toolbar.cancelFixed' : 'vxe.toolbar.fixedLeft')
- },
- on: {
- click: ({ $event }) => {
- _vm.changeFixedOption(column, 'left', $event);
- }
- }
- }),
- h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- icon: column.renderFixed === 'right' ? getIcon().TOOLBAR_TOOLS_FIXED_RIGHT_ACTIVE : getIcon().TOOLBAR_TOOLS_FIXED_RIGHT,
- status: column.renderFixed === 'right' ? 'primary' : '',
- disabled: isDisabled || isHidden || (isMaxFixedColumn && !column.renderFixed),
- title: getI18n(column.renderFixed === 'right' ? 'vxe.toolbar.cancelFixed' : 'vxe.toolbar.fixedRight')
- },
- on: {
- click: ({ $event }) => {
- _vm.changeFixedOption(column, 'right', $event);
- }
- }
- })
- ])
- : renderEmptyElement($xeTable)
- ]));
- }
- });
- return h('div', {
- ref: 'refElem',
- key: 'simple',
- class: ['vxe-table-custom-wrapper', `placement--${placement}`, {
- 'is--active': customStore.visible
- }],
- style: maxHeight && !['left', 'right'].includes(placement || '')
- ? {
- maxHeight: `${maxHeight}px`
- }
- : {}
- }, customStore.visible
- ? [
- h('div', {
- ref: 'refBodyWrapperElem',
- class: 'vxe-table-custom-simple--body-wrapper'
- }, [
- !treeConfig && (aggregateConfig || rowGroupConfig) && $xeTable.getPivotTableAggregateSimplePanel
- ? h($xeTable.getPivotTableAggregateSimplePanel(), {
- props: {
- customStore
- }
- })
- : renderEmptyElement($xeTable),
- h('div', {
- ref: 'refCustomBodyElem',
- class: 'vxe-table-custom--handle-wrapper'
- }, [
- h('div', {
- class: 'vxe-table-custom--header'
- }, headerSlot
- ? $xeTable.callSlot(headerSlot, params, h)
- : [
- h('ul', {
- class: 'vxe-table-custom--panel-list'
- }, [
- h('li', {
- class: 'vxe-table-custom--option'
- }, [
- allowVisible
- ? h('div', {
- class: ['vxe-table-custom--checkbox-option', {
- 'is--checked': isAllChecked,
- 'is--indeterminate': isAllIndeterminate
- }],
- attrs: {
- title: getI18n('vxe.table.allTitle')
- },
- on: {
- click: _vm.allOptionEvent
- }
- }, [
- h('span', {
- class: ['vxe-checkbox--icon', isAllIndeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : (isAllChecked ? getIcon().TABLE_CHECKBOX_CHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED)]
- }),
- h('span', {
- class: 'vxe-checkbox--label'
- }, getI18n('vxe.toolbar.customAll'))
- ])
- : h('span', {
- class: 'vxe-checkbox--label'
- }, getI18n('vxe.table.customTitle'))
- ])
- ])
- ]),
- h('div', {
- class: 'vxe-table-custom--body'
- }, [
- topSlot
- ? h('div', {
- class: 'vxe-table-custom--panel-top'
- }, $xeTable.callSlot(topSlot, params, h))
- : renderEmptyElement($xeTable),
- defaultSlot
- ? h('div', {
- class: 'vxe-table-custom--panel-body'
- }, $xeTable.callSlot(defaultSlot, params, h))
- : h('transition-group', {
- class: 'vxe-table-custom--panel-list',
- props: {
- name: 'vxe-table-custom--list',
- tag: 'ul'
- },
- on: customWrapperOns
- }, colVNs),
- bottomSlot
- ? h('div', {
- class: 'vxe-table-custom--panel-bottom'
- }, $xeTable.callSlot(bottomSlot, params, h))
- : renderEmptyElement($xeTable)
- ]),
- customOpts.showFooter
- ? h('div', {
- class: 'vxe-table-custom--footer'
- }, footerSlot
- ? $xeTable.callSlot(footerSlot, params, h)
- : [
- h('div', {
- class: 'vxe-table-custom--footer-buttons'
- }, [
- h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- content: customOpts.resetButtonText || getI18n('vxe.table.customRestore'),
- disabled: !isCustomStatus
- },
- on: {
- click: _vm.resetCustomEvent
- }
- }),
- immediate
- ? h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- content: customOpts.closeButtonText || getI18n('vxe.table.customClose')
- },
- on: {
- click: _vm.cancelCloseEvent
- }
- })
- : h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- content: customOpts.resetButtonText || getI18n('vxe.table.customCancel')
- },
- on: {
- click: _vm.cancelCustomEvent
- }
- }),
- immediate
- ? renderEmptyElement($xeTable)
- : h(VxeUIButtonComponent, {
- props: {
- mode: 'text',
- status: 'primary',
- content: customOpts.confirmButtonText || getI18n('vxe.table.customConfirm')
- },
- on: {
- click: _vm.confirmCustomEvent
- }
- })
- ])
- ])
- : null
- ]),
- renderDragTip(h, _vm)
- ])
- ]
- : []);
- };
- const renderPopupPanel = (h, $xeTableCustomPanel) => {
- const VxeUIModalComponent = VxeUI.getComponent('VxeModal');
- const VxeUIDrawerComponent = VxeUI.getComponent('VxeDrawer');
- const VxeUIButtonComponent = VxeUI.getComponent('VxeButton');
- const VxeUINumberInputComponent = VxeUI.getComponent('VxeNumberInput');
- const _vm = $xeTableCustomPanel;
- const props = $xeTableCustomPanel;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableProps = $xeTable;
- const tableReactData = $xeTable;
- const $xeGrid = $xeTable.$xeGrid;
- const $xeGantt = $xeTable.$xeGantt;
- const { customStore } = props;
- const { treeConfig, rowGroupConfig, aggregateConfig, resizable: allResizable } = tableProps;
- const { isCustomStatus, customColumnList } = tableReactData;
- const customOpts = $xeTable.computeCustomOpts;
- const { immediate } = customOpts;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- const { mode, modalOptions, drawerOptions, allowVisible, allowSort, allowFixed, allowResizable, checkMethod, visibleMethod } = customOpts;
- const columnOpts = $xeTable.computeColumnOpts;
- const { maxFixedSize } = columnOpts;
- const resizableOpts = $xeTable.computeResizableOpts;
- const { minWidth: reMinWidth, maxWidth: reMaxWidth } = resizableOpts;
- const modalOpts = Object.assign({}, modalOptions);
- const drawerOpts = Object.assign({}, drawerOptions);
- const isMaxFixedColumn = $xeTable.computeIsMaxFixedColumn;
- const { isCrossDrag } = columnDragOpts;
- const slots = customOpts.slots || {};
- const headerSlot = slots.header;
- const topSlot = slots.top;
- const bottomSlot = slots.bottom;
- const defaultSlot = slots.default;
- const footerSlot = slots.footer;
- const trVNs = [];
- const isAllChecked = customStore.isAll;
- const isAllIndeterminate = customStore.isIndeterminate;
- const params = {
- $table: $xeTable,
- $grid: $xeGrid,
- $gantt: $xeGantt,
- columns: customColumnList,
- isAllChecked,
- isAllIndeterminate,
- isCustomStatus
- };
- XEUtils.eachTree(customColumnList, (column, index, items, path, parent) => {
- const isVisible = visibleMethod ? visibleMethod({ $table: $xeTable, column }) : true;
- if (isVisible) {
- // 默认继承调整宽度
- let customMinWidth = 0;
- let customMaxWidth = 0;
- if (allowResizable) {
- const resizeParams = {
- $table: $xeTable,
- column,
- columnIndex: index,
- $columnIndex: index,
- $rowIndex: -1
- };
- if (reMinWidth) {
- customMinWidth = XEUtils.toNumber(XEUtils.isFunction(reMinWidth) ? reMinWidth(resizeParams) : reMinWidth);
- }
- if (reMaxWidth) {
- customMaxWidth = XEUtils.toNumber(XEUtils.isFunction(reMaxWidth) ? reMaxWidth(resizeParams) : reMaxWidth);
- }
- }
- const isChecked = column.renderVisible;
- const isIndeterminate = column.halfVisible;
- const colTitle = formatText(column.getTitle(), 1);
- const isColGroup = column.children && column.children.length;
- const isDisabled = checkMethod ? !checkMethod({ $table: $xeTable, column }) : false;
- const isHidden = !isChecked;
- trVNs.push(h('tr', {
- key: column.id,
- attrs: {
- colid: column.id
- },
- class: [`vxe-table-custom-popup--row level--${column.level}`, {
- 'is--group': isColGroup
- }],
- on: {
- dragstart: _vm.sortDragstartEvent,
- dragend: _vm.sortDragendEvent,
- dragover: _vm.sortDragoverEvent
- }
- }, [
- allowVisible
- ? h('td', {
- class: 'vxe-table-custom-popup--column-item col--visible'
- }, [
- h('div', {
- class: ['vxe-table-custom--checkbox-option', {
- 'is--checked': isChecked,
- 'is--indeterminate': isIndeterminate,
- 'is--disabled': isDisabled
- }],
- attrs: {
- title: getI18n('vxe.custom.setting.colVisible')
- },
- on: {
- click: (evnt) => {
- if (!isDisabled) {
- _vm.changeCheckboxOption(column, evnt);
- }
- }
- }
- }, [
- h('span', {
- class: ['vxe-checkbox--icon', isIndeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : (isChecked ? getIcon().TABLE_CHECKBOX_CHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED)]
- })
- ])
- ])
- : renderEmptyElement($xeTable),
- h('td', {
- class: 'vxe-table-custom-popup--column-item col--name'
- }, [
- h('div', {
- class: 'vxe-table-custom-popup--name'
- }, [
- allowSort
- ? ((isCrossDrag ? immediate : false) || column.level === 1
- ? h('div', {
- class: ['vxe-table-custom-popup--column-sort-btn', {
- 'is--disabled': isDisabled || isHidden
- }],
- attrs: {
- title: getI18n('vxe.custom.setting.sortHelpTip')
- },
- on: (isDisabled || isHidden
- ? {}
- : {
- mousedown: _vm.sortMousedownEvent,
- mouseup: _vm.sortMouseupEvent
- })
- }, [
- h('i', {
- class: getIcon().TABLE_CUSTOM_SORT
- })
- ])
- : h('div', {
- class: 'vxe-table-custom-popup--column-sort-placeholder'
- }))
- : renderEmptyElement($xeTable),
- column.type === 'html'
- ? h('div', {
- key: '1',
- class: 'vxe-table-custom-popup--title',
- domProps: {
- innerHTML: colTitle
- }
- })
- : h('div', {
- key: '0',
- class: 'vxe-table-custom-popup--title',
- attrs: {
- title: colTitle
- }
- }, colTitle)
- ])
- ]),
- allowResizable
- ? h('td', {
- class: 'vxe-table-custom-popup--column-item col--resizable'
- }, [
- ((column.children && column.children.length) ||
- !(XEUtils.isBoolean(column.resizable) ? column.resizable : (columnOpts.resizable || allResizable)))
- ? h('span', '-')
- : (VxeUINumberInputComponent
- ? h(VxeUINumberInputComponent, {
- props: {
- type: 'integer',
- immediate: false,
- disabled: isDisabled || isHidden,
- value: column.renderResizeWidth,
- min: customMinWidth || undefined,
- max: customMaxWidth || undefined
- },
- on: {
- modelValue(value) {
- column.renderResizeWidth = Math.max(0, Number(value));
- },
- change() {
- _vm.changeColumnWidth(column);
- }
- }
- })
- : renderEmptyElement($xeTableCustomPanel))
- ])
- : renderEmptyElement($xeTable),
- allowFixed
- ? h('td', {
- class: 'vxe-table-custom-popup--column-item col--fixed'
- }, [
- parent
- ? h('span', '-')
- : h('vxe-radio-group', {
- props: {
- value: column.renderFixed || '',
- type: 'button',
- size: 'mini',
- disabled: isDisabled || isHidden,
- options: [
- { label: getI18n('vxe.custom.setting.fixedLeft'), value: 'left', disabled: isDisabled || isHidden || isMaxFixedColumn },
- { label: getI18n('vxe.custom.setting.fixedUnset'), value: '', disabled: isDisabled || isHidden },
- { label: getI18n('vxe.custom.setting.fixedRight'), value: 'right', disabled: isDisabled || isHidden || isMaxFixedColumn }
- ]
- },
- on: {
- change({ label, $event }) {
- _vm.changeFixedOption(column, label, $event);
- }
- }
- })
- ])
- : renderEmptyElement($xeTable)
- ]));
- }
- });
- const scopedSlots = {
- default: () => {
- return h('div', {
- ref: 'refBodyWrapperElem',
- class: 'vxe-table-custom-popup--body-wrapper'
- }, defaultSlot
- ? $xeTable.callSlot(defaultSlot, params, h)
- : [
- h('div', {
- ref: 'refCustomBodyElem',
- class: 'vxe-table-custom-popup--handle-wrapper'
- }, [
- topSlot
- ? h('div', {
- class: 'vxe-table-custom-popup--table-top'
- }, $xeTable.callSlot(topSlot, params, h))
- : renderEmptyElement($xeTable),
- h('div', {
- class: 'vxe-table-custom-popup--table-wrapper'
- }, [
- h('table', {}, [
- h('colgroup', {}, [
- allowVisible
- ? h('col', {
- class: 'vxe-table-custom-popup--table-col-seq'
- })
- : renderEmptyElement($xeTable),
- h('col', {
- class: 'vxe-table-custom-popup--table-col-title'
- }),
- allowResizable
- ? h('col', {
- class: 'vxe-table-custom-popup--table-col-width'
- })
- : renderEmptyElement($xeTable),
- allowFixed
- ? h('col', {
- class: 'vxe-table-custom-popup--table-col-fixed'
- })
- : renderEmptyElement($xeTable)
- ]),
- h('thead', {}, [
- h('tr', {}, [
- allowVisible
- ? h('th', {}, [
- h('div', {
- class: ['vxe-table-custom--checkbox-option', {
- 'is--checked': isAllChecked,
- 'is--indeterminate': isAllIndeterminate
- }],
- attrs: {
- title: getI18n('vxe.table.allTitle')
- },
- on: {
- click: _vm.allOptionEvent
- }
- }, [
- h('span', {
- class: ['vxe-checkbox--icon', isAllIndeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : (isAllChecked ? getIcon().TABLE_CHECKBOX_CHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED)]
- }),
- h('span', {
- class: 'vxe-checkbox--label'
- }, getI18n('vxe.toolbar.customAll'))
- ])
- ])
- : renderEmptyElement($xeTable),
- h('th', {}, getI18n('vxe.custom.setting.colTitle')),
- allowResizable
- ? h('th', {}, getI18n('vxe.custom.setting.colResizable'))
- : renderEmptyElement($xeTable),
- allowFixed
- ? h('th', {}, getI18n(`vxe.custom.setting.${maxFixedSize ? 'colFixedMax' : 'colFixed'}`, [maxFixedSize]))
- : renderEmptyElement($xeTable)
- ])
- ]),
- h('transition-group', {
- class: 'vxe-table-custom--panel-list',
- props: {
- tag: 'tbody',
- name: 'vxe-table-custom--list'
- }
- }, trVNs)
- ])
- ]),
- bottomSlot
- ? h('div', {
- class: 'vxe-table-custom-popup--table-bottom'
- }, $xeTable.callSlot(bottomSlot, params, h))
- : renderEmptyElement($xeTable),
- renderDragTip(h, _vm)
- ]),
- !treeConfig && (aggregateConfig || rowGroupConfig) && $xeTable.getPivotTableAggregatePopupPanel
- ? h($xeTable.getPivotTableAggregatePopupPanel(), {
- props: {
- customStore
- }
- })
- : renderEmptyElement($xeTable)
- ]);
- },
- footer: () => {
- if (footerSlot) {
- return $xeTable.callSlot(footerSlot, params, h);
- }
- return h('div', {
- class: 'vxe-table-custom-popup--footer'
- }, [
- h(VxeUIButtonComponent, {
- props: {
- content: customOpts.resetButtonText || getI18n('vxe.custom.cstmRestore'),
- disabled: !isCustomStatus
- },
- on: {
- click: _vm.resetCustomEvent
- }
- }),
- immediate
- ? h(VxeUIButtonComponent, {
- props: {
- content: customOpts.resetButtonText || getI18n('vxe.table.customClose')
- },
- on: {
- click: _vm.cancelCloseEvent
- }
- })
- : h(VxeUIButtonComponent, {
- props: {
- content: customOpts.resetButtonText || getI18n('vxe.custom.cstmCancel')
- },
- on: {
- click: _vm.cancelCustomEvent
- }
- }),
- immediate
- ? renderEmptyElement($xeTable)
- : h(VxeUIButtonComponent, {
- props: {
- status: 'primary',
- content: customOpts.confirmButtonText || getI18n('vxe.custom.cstmConfirm')
- },
- on: {
- click: _vm.confirmCustomEvent
- }
- })
- ]);
- }
- };
- if (headerSlot) {
- scopedSlots.header = () => $xeTable.callSlot(headerSlot, params, h);
- }
- if (mode === 'drawer') {
- return VxeUIDrawerComponent
- ? h(VxeUIDrawerComponent, {
- key: 'drawer',
- props: {
- className: ['vxe-table-custom-drawer-wrapper', 'vxe-table--ignore-clear', drawerOpts.className || ''].join(' '),
- value: customStore.visible,
- title: drawerOpts.title || getI18n('vxe.custom.cstmTitle'),
- width: drawerOpts.width || Math.min(880, Math.floor(document.documentElement.clientWidth * 0.6)),
- position: drawerOpts.position,
- resize: !!drawerOpts.resize,
- escClosable: !!drawerOpts.escClosable,
- maskClosable: !!drawerOpts.maskClosable,
- destroyOnClose: true,
- showFooter: true
- },
- on: {
- input(value) {
- customStore.visible = value;
- }
- },
- scopedSlots
- })
- : renderEmptyElement($xeTableCustomPanel);
- }
- return VxeUIModalComponent
- ? h(VxeUIModalComponent, {
- key: 'modal',
- props: {
- className: ['vxe-table-custom-popup-wrapper', 'vxe-table--ignore-clear', modalOpts.className || ''].join(' '),
- value: customStore.visible,
- title: modalOpts.title || getI18n('vxe.custom.cstmTitle'),
- width: modalOpts.width || Math.min(880, document.documentElement.clientWidth),
- minWidth: modalOpts.minWidth || 700,
- height: modalOpts.height || Math.min(680, document.documentElement.clientHeight),
- minHeight: modalOpts.minHeight || 400,
- showZoom: modalOpts.showZoom,
- showMaximize: modalOpts.showMaximize,
- showMinimize: modalOpts.showMinimize,
- mask: modalOpts.mask,
- lockView: modalOpts.lockView,
- resize: modalOpts.resize,
- escClosable: !!modalOpts.escClosable,
- maskClosable: !!modalOpts.maskClosable,
- destroyOnClose: true,
- showFooter: true
- },
- on: {
- input(value) {
- customStore.visible = value;
- }
- },
- scopedSlots
- })
- : renderEmptyElement($xeTableCustomPanel);
- };
- export default {
- name: 'VxeTableCustomPanel',
- props: {
- customStore: {
- type: Object,
- default: () => ({})
- }
- },
- provide() {
- const $xeTableCustomPanel = this;
- return {
- $xeTableCustomPanel
- };
- },
- inject: {
- $xeTable: {
- default: null
- }
- },
- data() {
- const reactData = {
- dragCol: null,
- dragGroupField: null,
- dragAggFnCol: null,
- dragTipText: ''
- };
- const internalData = {
- // prevDragCol: undefined,
- // prevDragGroupField: undefined,
- // prevDragAggFnColid: undefined,
- // prevDragToChild: false,
- // prevDragPos: null
- };
- return {
- reactData,
- internalData
- };
- },
- computed: {},
- created() {
- const $xeTableCustomPanel = this;
- const VxeUIModalComponent = VxeUI.getComponent('VxeModal');
- const VxeUIDrawerComponent = VxeUI.getComponent('VxeDrawer');
- const VxeUIButtonComponent = VxeUI.getComponent('VxeButton');
- const VxeUINumberInputComponent = VxeUI.getComponent('VxeNumberInput');
- const VxeUIRadioGroupComponent = VxeUI.getComponent('VxeRadioGroup');
- $xeTableCustomPanel.$nextTick(() => {
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const { customOpts } = $xeTable;
- const { mode } = customOpts;
- if (!VxeUIModalComponent && (mode === 'modal')) {
- errLog('vxe.error.reqComp', ['vxe-modal']);
- }
- if (!VxeUIDrawerComponent && (mode === 'drawer')) {
- errLog('vxe.error.reqComp', ['vxe-drawer']);
- }
- if (!VxeUIButtonComponent) {
- errLog('vxe.error.reqComp', ['vxe-button']);
- }
- if (!VxeUINumberInputComponent) {
- errLog('vxe.error.reqComp', ['vxe-number-input']);
- }
- if (!VxeUIRadioGroupComponent) {
- errLog('vxe.error.reqComp', ['vxe-radio-group']);
- }
- });
- },
- render(h) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const customOpts = $xeTable.computeCustomOpts;
- if (['modal', 'drawer', 'popup'].includes(`${customOpts.mode}`)) {
- return renderPopupPanel(h, $xeTableCustomPanel);
- }
- return renderSimplePanel(h, $xeTableCustomPanel);
- },
- methods: {
- handleWrapperMouseenterEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const { customStore } = this;
- customStore.activeWrapper = true;
- $xeTable.customOpenEvent(evnt);
- },
- handleWrapperMouseleaveEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const props = $xeTableCustomPanel;
- const { customStore } = props;
- customStore.activeWrapper = false;
- setTimeout(() => {
- if (!customStore.activeBtn && !customStore.activeWrapper) {
- $xeTable.customCloseEvent(evnt);
- }
- }, 300);
- },
- getStoreData() {
- return {};
- },
- confirmCustomEvent({ $event }) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- tableReactData.isCustomStatus = true;
- $xeTable.saveCustom();
- $xeTable.closeCustom();
- $xeTable.emitCustomEvent('confirm', $event);
- },
- cancelCloseEvent({ $event }) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- $xeTable.closeCustom();
- $xeTable.emitCustomEvent('close', $event);
- },
- cancelCustomEvent({ $event }) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- $xeTable.cancelCustom();
- $xeTable.closeCustom();
- $xeTable.emitCustomEvent('cancel', $event);
- },
- handleResetCustomEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- $xeTable.resetCustom(true);
- $xeTable.closeCustom();
- $xeTable.emitCustomEvent('reset', evnt);
- },
- resetCustomEvent(evnt) {
- if (VxeUI.modal) {
- VxeUI.modal.confirm({
- content: getI18n('vxe.custom.cstmConfirmRestore'),
- className: 'vxe-table--ignore-clear',
- escClosable: true
- }).then(type => {
- if (type === 'confirm') {
- this.handleResetCustomEvent(evnt);
- }
- });
- }
- else {
- this.handleResetCustomEvent(evnt);
- }
- },
- handleOptionCheck(column) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- const { customColumnList } = tableReactData;
- const matchObj = XEUtils.findTree(customColumnList, item => item === column);
- if (matchObj && matchObj.parent) {
- const { parent } = matchObj;
- if (parent.children && parent.children.length) {
- parent.renderVisible = parent.children.every((column) => column.renderVisible);
- parent.halfVisible = !parent.renderVisible && parent.children.some((column) => column.renderVisible || column.halfVisible);
- this.handleOptionCheck(parent);
- }
- }
- },
- changeCheckboxOption(column, evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- const isChecked = !column.renderVisible;
- const customOpts = $xeTable.computeCustomOpts;
- if (customOpts.immediate) {
- XEUtils.eachTree([column], (item) => {
- item.visible = isChecked;
- item.renderVisible = isChecked;
- item.halfVisible = false;
- });
- tableReactData.isCustomStatus = true;
- $xeTable.handleCustom();
- $xeTable.saveCustomStore('update:visible');
- }
- else {
- XEUtils.eachTree([column], (item) => {
- item.renderVisible = isChecked;
- item.halfVisible = false;
- });
- }
- this.handleOptionCheck(column);
- $xeTable.checkCustomStatus();
- $xeTable.dispatchEvent('custom-visible-change', { column, checked: isChecked }, evnt);
- },
- changeColumnWidth(column) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- const customOpts = $xeTable.computeCustomOpts;
- if (customOpts.immediate) {
- if (column.renderResizeWidth !== column.renderWidth) {
- column.resizeWidth = column.renderResizeWidth;
- column.renderWidth = column.renderResizeWidth;
- tableReactData.isCustomStatus = true;
- $xeTable.handleCustom();
- $xeTable.saveCustomStore('update:width');
- }
- }
- },
- changeFixedOption(column, colFixed, evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- const isMaxFixedColumn = $xeTable.computeIsMaxFixedColumn;
- const customOpts = $xeTable.computeCustomOpts;
- let targetFixed = null;
- if (customOpts.immediate) {
- if (column.renderFixed === colFixed) {
- targetFixed = '';
- XEUtils.eachTree([column], col => {
- col.fixed = '';
- col.renderFixed = '';
- });
- }
- else {
- if (!isMaxFixedColumn || column.renderFixed) {
- targetFixed = colFixed;
- XEUtils.eachTree([column], col => {
- col.fixed = colFixed;
- col.renderFixed = colFixed;
- });
- }
- }
- tableReactData.isCustomStatus = true;
- $xeTable.handleCustom();
- $xeTable.saveCustomStore('update:fixed');
- }
- else {
- if (column.renderFixed === colFixed) {
- targetFixed = '';
- XEUtils.eachTree([column], col => {
- col.renderFixed = '';
- });
- }
- else {
- if (!isMaxFixedColumn || column.renderFixed) {
- targetFixed = colFixed;
- XEUtils.eachTree([column], col => {
- col.renderFixed = colFixed;
- });
- }
- }
- }
- if (targetFixed !== null) {
- $xeTable.dispatchEvent('custom-fixed-change', { column, fixed: targetFixed }, evnt);
- }
- },
- allOptionEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableReactData = $xeTable;
- const { customStore } = tableReactData;
- const isAll = !customStore.isAll;
- $xeTable.toggleCustomAllCheckbox();
- $xeTable.dispatchEvent('custom-visible-all', { checked: isAll }, evnt);
- },
- updateColDropTipContent() {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const { dragCol } = customPanelReactData;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- const { tooltipMethod } = columnDragOpts;
- let tipContent = '';
- if (tooltipMethod) {
- const dtParams = {
- $table: $xeTable,
- column: dragCol
- };
- tipContent = `${tooltipMethod(dtParams) || ''}`;
- }
- else {
- tipContent = getI18n('vxe.custom.cstmDragTarget', [dragCol && dragCol.type !== 'html' ? dragCol.getTitle() : '']);
- }
- customPanelReactData.dragTipText = tipContent;
- },
- sortMousedownEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const btnEl = evnt.currentTarget;
- const cellEl = btnEl.parentElement;
- const tdEl = cellEl.parentElement;
- const trEl = tdEl.parentElement;
- const colid = trEl.getAttribute('colid');
- const column = $xeTable.getColumnById(colid);
- trEl.draggable = true;
- customPanelReactData.dragCol = column;
- customPanelReactData.dragGroupField = null;
- customPanelReactData.dragAggFnCol = null;
- this.updateColDropTipContent();
- addClass(trEl, 'active--drag-origin');
- },
- sortMouseupEvent(evnt) {
- const $xeTableCustomPanel = this;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const btnEl = evnt.currentTarget;
- const cellEl = btnEl.parentElement;
- const tdEl = cellEl.parentElement;
- const trEl = tdEl.parentElement;
- hideDropTip($xeTableCustomPanel);
- trEl.draggable = false;
- customPanelReactData.dragCol = null;
- customPanelReactData.dragGroupField = null;
- customPanelReactData.dragAggFnCol = null;
- removeClass(trEl, 'active--drag-origin');
- },
- sortDragstartEvent(evnt) {
- const $xeTableCustomPanel = this;
- const customPanelInternalData = $xeTableCustomPanel.internalData;
- if (evnt.dataTransfer) {
- evnt.dataTransfer.setDragImage(getTpImg(), 0, 0);
- }
- customPanelInternalData.prevDragGroupField = null;
- customPanelInternalData.prevDragAggFnColid = null;
- },
- sortDragendEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const tableProps = $xeTable;
- const tableReactData = $xeTable;
- const tableInternalData = $xeTable;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const customPanelInternalData = $xeTableCustomPanel.internalData;
- const { mouseConfig } = tableProps;
- const { customColumnList } = tableReactData;
- const { collectColumn } = tableInternalData;
- const customOpts = $xeTable.computeCustomOpts;
- const { immediate } = customOpts;
- const trEl = evnt.currentTarget;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- const { isCrossDrag, isSelfToChildDrag, isToChildDrag, dragEndMethod } = columnDragOpts;
- const { dragCol } = customPanelReactData;
- const { prevDragCol, prevDragGroupField, prevDragAggFnColid, prevDragPos, prevDragToChild } = customPanelInternalData;
- const dragOffsetIndex = prevDragPos === 'bottom' ? 1 : 0;
- if (prevDragGroupField || prevDragAggFnColid) {
- if ($xeTable.handlePivotTableAggregatePanelDragendEvent) {
- $xeTable.handlePivotTableAggregatePanelDragendEvent(evnt);
- }
- }
- else if (prevDragCol && dragCol) {
- // 判断是否有拖动
- if (prevDragCol !== dragCol) {
- const dragColumn = dragCol;
- const newColumn = prevDragCol;
- Promise.resolve(dragEndMethod
- ? dragEndMethod({
- oldColumn: dragColumn,
- newColumn,
- dragColumn,
- dragPos: prevDragPos,
- dragToChild: !!prevDragToChild,
- offsetIndex: dragOffsetIndex
- })
- : true).then((status) => {
- if (!status) {
- return;
- }
- let oafIndex = -1;
- let nafIndex = -1;
- const oldAllMaps = {};
- XEUtils.eachTree([dragColumn], column => {
- oldAllMaps[column.id] = column;
- });
- let isSelfToChildStatus = false;
- // 只有实时拖拽支持跨层级
- if (immediate) {
- if (dragColumn.parentId && newColumn.parentId) {
- // 子到子
- if (!isCrossDrag) {
- return;
- }
- if (oldAllMaps[newColumn.id]) {
- isSelfToChildStatus = true;
- if (!(isCrossDrag && isSelfToChildDrag)) {
- if (VxeUI.modal) {
- VxeUI.modal.message({
- status: 'error',
- content: getI18n('vxe.error.treeDragChild')
- });
- }
- return;
- }
- }
- }
- else if (dragColumn.parentId) {
- // 子到根
- if (!isCrossDrag) {
- return;
- }
- }
- else if (newColumn.parentId) {
- // 根到子
- if (!isCrossDrag) {
- return;
- }
- if (oldAllMaps[newColumn.id]) {
- isSelfToChildStatus = true;
- if (!(isCrossDrag && isSelfToChildDrag)) {
- if (VxeUI.modal) {
- VxeUI.modal.message({
- status: 'error',
- content: getI18n('vxe.error.treeDragChild')
- });
- }
- return;
- }
- }
- }
- else {
- // 根到根
- }
- const oldewMatchRest = XEUtils.findTree(collectColumn, item => item.id === dragColumn.id);
- // 改变层级
- if (isSelfToChildStatus && (isCrossDrag && isSelfToChildDrag)) {
- if (oldewMatchRest) {
- const { items: oCols, index: oIndex } = oldewMatchRest;
- const childList = dragColumn.children || [];
- childList.forEach(column => {
- column.parentId = dragColumn.parentId;
- });
- oCols.splice(oIndex, 1, ...childList);
- dragColumn.children = [];
- }
- }
- else {
- if (oldewMatchRest) {
- const { items: oCols, index: oIndex, parent: oParent } = oldewMatchRest;
- oCols.splice(oIndex, 1);
- if (!oParent) {
- oafIndex = oIndex;
- }
- }
- }
- const newMatchRest = XEUtils.findTree(collectColumn, item => item.id === newColumn.id);
- if (newMatchRest) {
- const { items: nCols, index: nIndex, parent: nParent } = newMatchRest;
- // 转子级
- if ((isCrossDrag && isToChildDrag) && prevDragToChild) {
- dragColumn.parentId = newColumn.id;
- newColumn.children = (newColumn.children || []).concat([dragColumn]);
- }
- else {
- dragColumn.parentId = newColumn.parentId;
- nCols.splice(nIndex + dragOffsetIndex, 0, dragColumn);
- }
- if (!nParent) {
- nafIndex = nIndex;
- }
- }
- XEUtils.eachTree(collectColumn, (column, index, items, path, parent) => {
- if (!parent) {
- const sortIndex = index + 1;
- column.renderSortNumber = sortIndex;
- }
- });
- }
- else {
- oafIndex = XEUtils.findIndexOf(customColumnList, item => item.id === dragColumn.id);
- customColumnList.splice(oafIndex, 1);
- nafIndex = XEUtils.findIndexOf(customColumnList, item => item.id === newColumn.id);
- customColumnList.splice(nafIndex + dragOffsetIndex, 0, dragColumn);
- }
- if (mouseConfig) {
- if ($xeTable.clearSelected) {
- $xeTable.clearSelected();
- }
- if ($xeTable.clearCellAreas) {
- $xeTable.clearCellAreas();
- $xeTable.clearCopyCellArea();
- }
- }
- const csParams = {
- oldColumn: dragColumn,
- newColumn,
- dragColumn,
- dragPos: prevDragPos,
- offsetIndex: dragOffsetIndex,
- _index: {
- newIndex: nafIndex,
- oldIndex: oafIndex
- }
- };
- $xeTable.dispatchEvent('custom-sort-change', csParams, evnt);
- $xeTable.dispatchEvent('column-dragend', csParams, evnt);
- if (immediate) {
- tableReactData.customColumnList = collectColumn.slice(0);
- $xeTable.handleColDragSwapColumn();
- }
- }).catch(() => {
- });
- }
- }
- hideDropTip($xeTableCustomPanel);
- customPanelReactData.dragCol = null;
- customPanelReactData.dragGroupField = null;
- customPanelReactData.dragAggFnCol = null;
- customPanelInternalData.prevDragGroupField = null;
- customPanelInternalData.prevDragAggFnColid = null;
- trEl.draggable = false;
- trEl.removeAttribute('drag-pos');
- removeClass(trEl, 'active--drag-target');
- removeClass(trEl, 'active--drag-origin');
- },
- sortDragoverEvent(evnt) {
- const $xeTableCustomPanel = this;
- const $xeTable = $xeTableCustomPanel.$xeTable;
- const customPanelReactData = $xeTableCustomPanel.reactData;
- const customPanelInternalData = $xeTableCustomPanel.internalData;
- const { dragCol } = customPanelReactData;
- const customOpts = $xeTable.computeCustomOpts;
- const { immediate } = customOpts;
- const columnDragOpts = $xeTable.computeColumnDragOpts;
- const { isCrossDrag, isToChildDrag } = columnDragOpts;
- const optEl = evnt.currentTarget;
- const isControlKey = hasControlKey(evnt);
- const colid = optEl.getAttribute('colid');
- const column = $xeTable.getColumnById(colid);
- customPanelInternalData.prevDragGroupField = null;
- customPanelInternalData.prevDragAggFnColid = null;
- // 是否移入有效列
- if (column && (isCrossDrag || column.level === 1)) {
- evnt.preventDefault();
- const offsetY = evnt.clientY - optEl.getBoundingClientRect().y;
- const dragPos = offsetY < optEl.clientHeight / 2 ? 'top' : 'bottom';
- if (!dragCol ||
- (dragCol && dragCol.id === column.id) ||
- (!isCrossDrag && column.level > 1) ||
- (!immediate && column.level > 1)) {
- showDropTip($xeTableCustomPanel, evnt, optEl, false, dragPos);
- return;
- }
- customPanelInternalData.prevDragToChild = !!((isCrossDrag && isToChildDrag) && isControlKey && immediate);
- customPanelInternalData.prevDragCol = column;
- customPanelInternalData.prevDragPos = dragPos;
- showDropTip($xeTableCustomPanel, evnt, optEl, true, dragPos);
- }
- }
- }
- };
|