From 20185ab64a165df51515d9fa1c9b12a7a8c55f59 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期五, 07 四月 2023 23:11:04 +0800 Subject: [PATCH] 2023-04-07 --- src/menu/components/card/cardcomponent/index.jsx | 74 ++++++++++++++++++++++++++++++++++-- 1 files changed, 69 insertions(+), 5 deletions(-) diff --git a/src/menu/components/card/cardcomponent/index.jsx b/src/menu/components/card/cardcomponent/index.jsx index c4bb5f3..db2c7f5 100644 --- a/src/menu/components/card/cardcomponent/index.jsx +++ b/src/menu/components/card/cardcomponent/index.jsx @@ -12,8 +12,10 @@ import MKEmitter from '@/utils/events.js' import './index.scss' +const { confirm } = Modal + const NormalForm = asyncIconComponent(() => import('@/components/normalform')) -const CardCellComponent = asyncComponent(() => import('../cardcellcomponent')) +const CardCellComponent = asyncComponent(() => import('@/menu/components/card/cardcellcomponent')) const CopyComponent = asyncIconComponent(() => import('@/menu/components/share/copycomponent')) const PasteController = asyncIconComponent(() => import('@/components/paste')) @@ -129,6 +131,10 @@ newcard.datatype = 'dynamic' newcard.height = 1 + if (card.$cardType === 'extendCard' && card.setting.cardRole === 'header') { + newcard.datatype = 'static' + } + // 娉ㄥ唽浜嬩欢-娣诲姞鍏冪礌 MKEmitter.emit('cardAddElement', card.uuid, newcard) } @@ -188,6 +194,39 @@ updateSetting = (res) => { const { card, side, appType } = this.state + if (card.$cardType === 'extendCard' && res.cardRole === 'header') { + let _card = {...card, setting: res} + + let originLength = _card.elements.length + _card.elements = _card.elements.filter(item => item.eleType === 'text') + _card.backElements = [] + + delete _card.menus + + if (_card.elements.length < originLength) { + const that = this + + confirm({ + title: '琛ㄦ牸澶翠粎鏀寔鏂囨湰锛岀‘瀹氳鍒囨崲鍗$墖瑙掕壊鍚�?', + content: '', + okText: '纭畾', + cancelText: '鍙栨秷', + onOk() { + that.setState({ card: _card, side: '', elements: fromJS(_card.elements).toJS() }, () => { + that.setState({ side: 'front' }) + }) + that.props.updateElement(_card) + }, + onCancel() {} + }) + } else { + this.setState({ card: _card, side: 'front' }) + this.props.updateElement(_card) + } + + return + } + if (appType === '' && res.menu) { let list = null try { @@ -237,6 +276,11 @@ let _uuid = Utils.getuuid() + if (card.$cardType === 'extendCard' && card.setting.cardRole === 'header' && element.eleType !== 'text') { + resolve({status: false, message: '琛ㄦ牸澶翠粎鏀寔鏂囨湰鍏冪礌锛�'}) + return + } + if (element.copyType === 'action') { element.eleType = 'button' } @@ -311,16 +355,36 @@ } _style = resetStyle(_style) + let checkAll = '' + if ((cards.subtype === 'datacard' || cards.subtype === 'dualdatacard') && card.$cardType === 'extendCard') { + checkAll = card.setting.checkAll === 'show' ? ' mk-checkable mk-extend-card' : '' + if (checkAll && cards.wrap.selStyle === 'check square') { + checkAll = ' mk-checkable square mk-extend-card' + } + } else if (cards.subtype === 'datacard') { + if (cards.wrap.selStyle === 'check') { + checkAll = ' mk-checkable' + } else if (cards.wrap.selStyle === 'check square') { + checkAll = ' mk-checkable square' + } + } + + let tablerole = '' + if (card.$cardType === 'extendCard' && card.setting.cardRole === 'header') { + tablerole = ' mk-table-header' + } + return ( <Col span={card.setting.width || 6}> - <div className={'card-item ' + (card.setting.btnControl || '')} style={_style} onDoubleClick={(e) => {e.stopPropagation(); this.doubleClickCard()}} id={card.uuid}> + <div className={'card-item ' + (card.setting.btnControl || '') + checkAll + tablerole} style={_style} onDoubleClick={(e) => {e.stopPropagation(); this.doubleClickCard()}} id={card.uuid}> + <span className="circle-select"></span> <CardCellComponent cards={cards} cardCell={card} side={side} elements={elements} updateElement={this.updateCard}/> <div className="card-control" onDoubleClick={(e) => e.stopPropagation()}> <Popover overlayClassName="mk-popover-control-wrap" mouseLeaveDelay={0.2} mouseEnterDelay={0.2} content={ <div className="mk-popover-control"> <PlusOutlined className="plus" title="娣诲姞鍏冪礌" onClick={this.addElement} /> - <PlusSquareOutlined className="plus" title="娣诲姞鎸夐挳" onClick={this.addButton} /> - <NormalForm title="鍗$墖璁剧疆" width={800} update={this.updateSetting} getForms={this.getSettingForms}> + {!tablerole ? <PlusSquareOutlined className="plus" title="娣诲姞鎸夐挳" onClick={this.addButton} /> : null} + <NormalForm title={cards.subtype === 'datacard' && card.$cardType !== 'extendCard' ? '寰幆鍗$墖璁剧疆' : '灞炴�у崱鐗囪缃�'} width={950} update={this.updateSetting} getForms={this.getSettingForms}> <EditOutlined className="edit" title="缂栬緫"/> </NormalForm> <CopyComponent type="cardcell" card={card}/> @@ -338,7 +402,7 @@ {card.setting.type === 'multi' ? <Switch size="small" onClick={this.changeSide} defaultChecked /> : null} </div> } trigger="hover"> - <ToolOutlined /> + <ToolOutlined style={cards.subtype === 'datacard' && card.$cardType === 'extendCard' ? {color: '#26C281'} : null}/> </Popover> </div> </div> -- Gitblit v1.8.0