From 1a11f7115e61c548f9ffc77d0a9e504307ca71b2 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期二, 24 八月 2021 18:37:20 +0800 Subject: [PATCH] 2021-08-24 --- src/tabviews/custom/components/form/normal-form/index.jsx | 101 ++++++++++++++++++++++---------------------------- 1 files changed, 45 insertions(+), 56 deletions(-) diff --git a/src/tabviews/custom/components/form/normal-form/index.jsx b/src/tabviews/custom/components/form/normal-form/index.jsx index 59b40f1..54a0d90 100644 --- a/src/tabviews/custom/components/form/normal-form/index.jsx +++ b/src/tabviews/custom/components/form/normal-form/index.jsx @@ -44,7 +44,7 @@ let _data = null let _sync = false - + if (config.wrap.datatype !== 'static') { _sync = config.setting.sync === 'true' @@ -76,6 +76,14 @@ group.subButton.$forbid = true group.subButton.OpenType = 'formSubmit' group.subButton.execError = 'never' + + if (group.subButton.enable === 'false') { + group.subButton.style.display = 'none' + } + + if (group.prevButton.enable === 'false' && group.subButton.enable === 'false' && group.nextButton.enable === 'false') { + group.$button = 'no-button' + } group.fields = group.fields.map(cell => { // 鏁版嵁婧恠ql璇彞锛岄澶勭悊锛屾潈闄愰粦鍚嶅崟瀛楁璁剧疆涓洪殣钘忚〃鍗� @@ -178,7 +186,7 @@ if (config.uuid !== menuId) return - this.loadData(null, 'refresh') + this.loadData('refresh') } /** @@ -187,7 +195,7 @@ * @param {*} position // 鍒锋柊浣嶇疆 * @param {*} btn // 鎵ц鐨勬寜閽� */ - refreshByButtonResult = (menuId, position, btn) => { + refreshByButtonResult = (menuId, position, btn, id) => { const { config, group } = this.state if (group.uuid !== menuId) return @@ -197,10 +205,14 @@ } if (config.wrap.datatype !== 'static' && config.setting) { - this.loadData(btn) - } else { - this.execSuccess(btn) + this.loadData() } + + if (id) { + MKEmitter.emit('resetSelectLine', config.uuid, id, '') + } + + this.execSuccess(btn, id) } resetParentParam = (MenuID, id) => { @@ -213,7 +225,7 @@ } } - execSuccess = (btn) => { + execSuccess = (btn, id) => { const { config, group } = this.state if (config.subcards.length > group.sort) { @@ -235,8 +247,9 @@ let newtab = { ...menu, selected: true, - param: {} + param: {$BID: id || ''} } + let tabs = this.props.tabviews.filter((tab, i) => { tab.selected = false return tab.MenuID !== newtab.MenuID @@ -253,35 +266,21 @@ } } - async loadData (btn, type) { + async loadData (type) { const { mainSearch, menuType } = this.props const { config, arr_field, BID, group } = this.state if (config.wrap.datatype === 'static' || (config.setting.supModule && !BID)) { this.setState({ - data: {}, - loading: false + data: {} }) - btn && this.execSuccess(btn) return } - let searches = [] - if (config.setting.useMSearch && mainSearch && mainSearch.length > 0) { // 涓昏〃鎼滅储鏉′欢 - let keys = searches.map(item => item.key) - mainSearch.forEach(item => { - if (!keys.includes(item.key)) { - searches.push(item) - } - }) - } + let searches = config.setting.useMSearch && mainSearch ? mainSearch : [] - let requireFields = searches.filter(item => item.required && (!item.value || item.value.length === 0)) + let requireFields = searches.filter(item => item.required && item.value === '') if (requireFields.length > 0) { - this.setState({ - loading: false - }) - btn && this.execSuccess(btn) return } @@ -295,34 +294,25 @@ let result = await Api.genericInterface(param) if (result.status) { let _data = result.data && result.data[0] ? result.data[0] : {} + let _group = group - if (btn) { - this.setState({ - data: _data || {}, - loading: false - }) - this.execSuccess(btn) - } else { - let _group = group - - if (type === 'refresh') { - _group = config.subcards[0] - } - - if (config.wrap.statusControl && _data[config.wrap.statusControl]) { - let _status = _data[config.wrap.statusControl] - let _groups = config.subcards.filter(item => item.setting.status === _status)[0] - _group = _groups || _group - } - this.setState({ - group: null, - step: _group.sort - 1, - data: _data || {}, - loading: false - }, () => { - this.setState({group: _group}) - }) + if (type === 'refresh') { + _group = config.subcards[0] } + + if (config.wrap.statusControl && _data[config.wrap.statusControl]) { + let _status = _data[config.wrap.statusControl] + let _groups = config.subcards.filter(item => item.setting.status === _status)[0] + _group = _groups || _group + } + this.setState({ + group: null, + step: _group.sort - 1, + data: _data || {}, + loading: false + }, () => { + this.setState({group: _group}) + }) } else { this.setState({ loading: false, @@ -332,7 +322,6 @@ message: result.message, duration: 10 }) - btn && this.execSuccess(btn) } } @@ -392,11 +381,11 @@ dict={dict} data={data} action={group} - inputSubmit={this.handleOk} + inputSubmit={() => this.mkFormSubmit(group.uuid)} wrappedComponentRef={(inst) => this.formRef = inst} /> : null} - {group && data ? <div className="mk-form-action"> - {group.sort !== 1 ? <Button type="link" className="prev" onClick={this.prevStep} style={group.prevButton.style}>{group.prevButton.label}</Button> : null} + {group && data ? <div className={'mk-form-action ' + (group.$button || '')}> + {group.sort !== 1 && group.prevButton.enable !== 'false' ? <Button type="link" className="prev" onClick={this.prevStep} style={group.prevButton.style}>{group.prevButton.label}</Button> : null} <NormalButton BID={BID} position="form" -- Gitblit v1.8.0