From dcd660c86dba586c1b78c0530ddee7c1dc093ee6 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期四, 25 四月 2024 17:51:15 +0800 Subject: [PATCH] 2024-04-25 --- src/menu/components/share/pastecomponent/index.jsx | 124 +++++++++++++++++++---------------------- 1 files changed, 58 insertions(+), 66 deletions(-) diff --git a/src/menu/components/share/pastecomponent/index.jsx b/src/menu/components/share/pastecomponent/index.jsx index b0c79bb..a96fa09 100644 --- a/src/menu/components/share/pastecomponent/index.jsx +++ b/src/menu/components/share/pastecomponent/index.jsx @@ -7,7 +7,7 @@ import Utils from '@/utils/utils.js' import MKEmitter from '@/utils/events.js' import asyncComponent from '@/utils/asyncComponent' -import './index.scss' +// import './index.scss' const PasteForm = asyncComponent(() => import('@/templates/zshare/pasteform')) @@ -21,19 +21,8 @@ visible: false } - handleMenuClick = () => { - this.setState({visible: true}) - } - - resetconfig = (item, copyBtns, config) => { + resetconfig = (item, config) => { let _uuid = Utils.getuuid() - - if (item.OpenType === 'popview') { - let _cell = fromJS(item).toJS() - _cell.$originUuid = _cell.uuid - _cell.uuid = _uuid - copyBtns.set(_uuid, _cell) - } if (item.uuid) { item.uuid = _uuid @@ -67,6 +56,11 @@ item.setting.width = item.setting.width || 6 delete item.$cardType + if (config.type === 'carousel') { + delete item.setting.linkbtn + delete item.backElements + } + if (item.elements) { item.elements = item.elements.map(cell => { cell.uuid = Utils.getuuid() @@ -80,48 +74,27 @@ }) } } else if (item.copyType === 'cols') { - let loopCol = (col) => { - col.subcols = col.subcols.map(c => { - c.uuid = Utils.getuuid() + let loopCol = (cols) => { + return cols.map(col => { + col.uuid = Utils.getuuid() - if (c.type === 'colspan' && c.subcols) { - c = loopCol(c) - } else if (c.type === 'custom' && c.elements) { - c.elements = c.elements.map(cell => { + if (col.type === 'action') { + col.type = 'custom' + } + + if (col.type === 'colspan' && col.subcols) { + col.subcols = loopCol(col.subcols) + } else if (col.type === 'custom' && col.elements) { + col.elements = col.elements.map(cell => { cell.uuid = Utils.getuuid() return cell }) } - return c + return col }) - - return col } - item.cols = item.cols.map(_item => { - _item.uuid = Utils.getuuid() - if (_item.type === 'colspan' && _item.subcols) { - _item = loopCol(_item) - } else if (_item.type === 'custom' && _item.elements) { - _item.elements = _item.elements.map(cell => { - cell.uuid = Utils.getuuid() - return cell - }) - } else if (_item.type === 'action' && _item.elements) { - _item.elements = _item.elements.map(cell => { - let _uuid = Utils.getuuid() - if (cell.OpenType === 'popview') { - let _cell = fromJS(cell).toJS() - _cell.$originUuid = _cell.uuid - _cell.uuid = _uuid - copyBtns.set(_uuid, _cell) - } - cell.uuid = _uuid - return cell - }) - } - return _item - }) + item.cols = loopCol(item.cols) } return item @@ -130,33 +103,36 @@ pasteSubmit = () => { const { options } = this.props this.pasteFormRef.handleConfirm().then(res => { - if (!options.includes(res.copyType)) { notification.warning({ top: 92, message: '閰嶇疆淇℃伅鏍煎紡閿欒锛�', duration: 5 }) return } + if (!this.props.config) { + this.props.updateConfig(res) + this.setState({visible: false}) + return + } + + if (res.copyType === 'editcols') { + res.copyType = 'cols' + } + let type = res.copyType let config = fromJS(this.props.config).toJS() - let copyBtns = new Map() - res = this.resetconfig(res, copyBtns, config) + res = this.resetconfig(res, config) delete res.copyType - - copyBtns = [...copyBtns.values()] - - if (copyBtns.length > 0) { - MKEmitter.emit('copyButtons', copyBtns) - } if (config.type === 'form') { this.props.updateConfig(res) this.setState({visible: false}) return } else if (type === 'action') { - config.action = config.action || [] - config.action = config.action.filter(item => !item.origin) - + if (res.style) { + delete res.style.width + delete res.style.float + } if (['line', 'bar', 'scatter'].includes(config.type) && !['excelOut', 'excelIn'].includes(res.OpenType)) { notification.warning({ top: 92, message: '鍥捐〃涓笉鏀寔姝ょ被鎸夐挳锛�', duration: 5 }) return @@ -196,16 +172,32 @@ } else if (type === 'cols') { config.cols = config.cols.filter(col => !col.origin) - let keys = config.cols.map(col => (col.field || '$empty')) - - res.cols.forEach(col => { - if (!keys.includes(col.field)) { - config.cols.push(col) + if ((config.subtype === 'normaltable' || config.subtype === 'editable') && res.cols.length === 1) { + config.cols.push(...res.cols) + } else { + let keys = config.cols.map(col => (col.field || '$empty')) + + let cols = [] + res.cols.forEach(col => { + if (!col.field || !keys.includes(col.field)) { + cols.push(col) + } + }) + + if (cols.length === 0) { + notification.warning({ + top: 92, + message: '鏄剧ず鍒楀凡瀛樺湪锛�', + duration: 5 + }) + return + } else { + config.cols.push(...cols) } - }) + } } - this.props.updateConfig(config) + this.props.updateConfig(config, type) this.setState({visible: false}) notification.success({ -- Gitblit v1.8.0