From e8edfdadb561cd83bf6e1c3e00d55b8cc2aee6d5 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期一, 17 十月 2022 17:57:34 +0800 Subject: [PATCH] 2022-10-17 --- src/templates/formtabconfig/settingform/index.jsx | 360 +++++++++++++++++++++++++++++++---------------------------- 1 files changed, 191 insertions(+), 169 deletions(-) diff --git a/src/templates/formtabconfig/settingform/index.jsx b/src/templates/formtabconfig/settingform/index.jsx index 24ce02c..bc10e56 100644 --- a/src/templates/formtabconfig/settingform/index.jsx +++ b/src/templates/formtabconfig/settingform/index.jsx @@ -1,52 +1,75 @@ import React, {Component} from 'react' import PropTypes from 'prop-types' -import { Form, Row, Col, Input, Radio, Select, Tooltip, Icon, notification } from 'antd' +import { Form, Row, Col, Input, Radio, Select, Tooltip, notification, InputNumber } from 'antd' +import { QuestionCircleOutlined } from '@ant-design/icons' + import { formRule } from '@/utils/option.js' +import Utils from '@/utils/utils.js' import './index.scss' const { TextArea } = Input class SettingForm extends Component { static propTpyes = { - dict: PropTypes.object, // 瀛楀吀椤� menu: PropTypes.object, - data: PropTypes.object, config: PropTypes.object, - columns: PropTypes.array, - usefulFields: PropTypes.array + inputSubmit: PropTypes.any // 鍥炶溅鎻愪氦浜嬩欢 } state = { - interType: this.props.data.interType || 'inner', - columns: this.props.columns.filter(item => item.field && item.type !== 'colspan'), - currentTabs: null, - selectTabs: [] + interType: (this.props.config.setting && this.props.config.setting.interType) || 'inner', + columns: null, + usefulFields: [], + interReadonly: false, } UNSAFE_componentWillMount() { - const { config, data } = this.props - let _tabs = [] - let _select = [] - let _tabMap = new Map() + const { config } = this.props - config.tabgroups.forEach(groupname => { - config[groupname].forEach(tab => { - if (tab.origin) return - - _tabs.push(tab) - _tabMap.set(tab.uuid, true) + let _columns = [] + let _setting = config.setting + + try { + config.groups.forEach(group => { + let list = group.sublist.filter(item => item.field) + _columns = [..._columns, ...list] }) - }) - data.subtabs && data.subtabs.forEach(tabId => { - if (_tabMap.has(tabId)) { - _select.push(tabId) + let _colMap = new Map() + _columns = _columns.filter(item => { + if (_colMap.has(item.field)) { + return false + } else { + _colMap.set(item.field, true) + return true + } + }) + } catch (e) { + notification.warning({ + top: 92, + message: '鑿滃崟淇℃伅閿欒锛�', + duration: 5 + }) + } + + let usefulFields = sessionStorage.getItem('permFuncField') + if (usefulFields) { + try { + usefulFields = JSON.parse(usefulFields) + } catch (e) { + usefulFields = [] } - }) + } else { + usefulFields = [] + } this.setState({ - currentTabs: _tabs, - selectTabs: _select + columns: _columns, + setting: _setting, + interType: _setting.interType || 'inner', + interReadonly: _setting.sysInterface === 'true', + datatype: _setting.datatype || 'maintable', + usefulFields }) } @@ -55,18 +78,18 @@ return new Promise((resolve, reject) => { this.props.form.validateFieldsAndScroll((err, values) => { if (!err) { - values.actionfixed = values.actionfixed === 'true' - values.columnfixed = values.columnfixed === 'true' + let error = Utils.verifySql(values.dataresource) - if (values.interType === 'inner' && !values.innerFunc && !values.dataresource) { + if (error) { notification.warning({ top: 92, - message: '璇疯嚜瀹氫箟鍑芥暟鎴栧~鍐欐暟鎹簮锛�', - duration: 10 + message: '鏁版嵁婧愪腑涓嶅彲浣跨敤' + error, + duration: 5 }) - } else { - resolve(values) + return } + + resolve(values) } else { reject(err) } @@ -74,23 +97,79 @@ }) } + onSysChange = (e) => { + if (e.target.value === 'true') { + this.props.form.setFieldsValue({ + interface: window.GLOB.mainSystemApi || '' + }) + this.setState({ + interReadonly: true + }) + } else { + this.setState({ + interReadonly: false + }) + } + } + onChange = (e) => { this.setState({ interType: e.target.value + }, () => { + if (e.target.value === 'inner') return + + let _type = this.props.form.getFieldValue('sysInterface') + if (_type === 'true') { + this.props.form.setFieldsValue({ + interface: window.GLOB.mainSystemApi || '' + }) + this.setState({ + interReadonly: true + }) + } else { + this.setState({ + interReadonly: false + }) + } }) } - selectChange = (val) => { - // let _order = this.props.form.getFieldValue('order') - this.props.form.setFieldsValue({ - order: `${val} desc` + sourceChange = (e) => { + const { interType } = this.state + + this.setState({ + datatype: e.target.value + }, () => { + if (interType === 'inner') return + + let _type = this.props.form.getFieldValue('sysInterface') + if (_type === 'true') { + this.props.form.setFieldsValue({ + interface: window.GLOB.mainSystemApi || '' + }) + this.setState({ + interReadonly: true + }) + } else { + this.setState({ + interReadonly: false + }) + } }) + } + + handleSubmit = (e) => { + e.preventDefault() + + if (this.props.inputSubmit) { + this.props.inputSubmit() + } } render() { - const { data, dict, menu, usefulFields } = this.props + const { menu } = this.props const { getFieldDecorator } = this.props.form - const { interType, columns, selectTabs } = this.state + const { interType, setting, datatype, usefulFields } = this.state const formItemLayout = { labelCol: { @@ -103,17 +182,6 @@ } } - let primaryKey = data.primaryKey - if (primaryKey) { - let field = columns.filter(column => column.field === primaryKey) - if (field.length !== 1) { - primaryKey = '' - } - } - if (!primaryKey && columns.length === 0) { - primaryKey = 'ID' - } - let str = '^(' + usefulFields.join('|') + ')' let _patten = new RegExp(str + formRule.func.innerPattern + '$', 'g') @@ -123,73 +191,103 @@ <Col span={12}> <Form.Item label="琛ㄥ悕"> {getFieldDecorator('tableName', { - initialValue: data.tableName, + initialValue: setting.tableName, rules: [ { required: true, - message: dict['form.required.input'] + '琛ㄥ悕!' + message: '璇疯緭鍏ヨ〃鍚�!' }, { - max: formRule.input.max, - message: formRule.input.message + max: 50, + message: '琛ㄥ悕鏈�闀夸负50涓瓧绗�!' } ] - })(<Input placeholder="" autoComplete="off" />)} + })(<Input placeholder="" autoComplete="off" onPressEnter={this.handleSubmit} />)} </Form.Item> </Col> <Col span={12}> - <Form.Item label="琛ㄦ牸灞炴��"> - {getFieldDecorator('tableType', { - initialValue: data.tableType + <Form.Item label="鍒楁暟"> + {getFieldDecorator('cols', { + initialValue: setting.cols || '2' })( - <Select - getPopupContainer={() => document.getElementById('commontable-setting-form')} - > - <Select.Option value="">涓嶅彲閫�</Select.Option> - <Select.Option value="radio">鍗曢��</Select.Option> - <Select.Option value="checkbox">澶氶��</Select.Option> + <Select> + <Select.Option value="1">1鍒�</Select.Option> + <Select.Option value="2">2鍒�</Select.Option> + <Select.Option value="3">3鍒�</Select.Option> + <Select.Option value="4">4鍒�</Select.Option> </Select> )} </Form.Item> </Col> <Col span={12}> - <Form.Item label={dict['header.form.intertype']}> - {getFieldDecorator('interType', { - initialValue: data.interType || 'inner' + <Form.Item label="鏁版嵁鏉ユ簮"> + {getFieldDecorator('datatype', { + initialValue: setting.datatype || 'query' })( - <Radio.Group onChange={this.onChange}> - <Radio value="inner">{dict['header.form.interface.inner']}</Radio> - <Radio value="outer">{dict['header.form.interface.outer']}</Radio> + <Radio.Group onChange={this.sourceChange}> + <Radio value="maintable">涓昏〃</Radio> + <Radio value="query">鏌ヨ</Radio> </Radio.Group> )} </Form.Item> </Col> - {interType === 'outer' ? <Col span={12}> - <Form.Item label={dict['header.form.interface']}> + <Col span={12}> + <Form.Item label="涓婚敭"> + {getFieldDecorator('primaryKey', { + initialValue: setting.primaryKey + })(<Input placeholder="" autoComplete="off" disabled/>)} + </Form.Item> + </Col> + {datatype === 'query' ? <Col span={12}> + <Form.Item label="鎺ュ彛绫诲瀷"> + {getFieldDecorator('interType', { + initialValue: interType + })( + <Radio.Group onChange={this.onChange}> + <Radio value="inner">鍐呴儴</Radio> + <Radio value="outer">澶栭儴</Radio> + </Radio.Group> + )} + </Form.Item> + </Col> : null} + {datatype === 'query' && interType === 'outer' ? <Col span={12}> + <Form.Item label="绯荤粺鎺ュ彛"> + {getFieldDecorator('sysInterface', { + initialValue: setting.sysInterface || 'false' + })( + <Radio.Group onChange={this.onSysChange}> + <Radio value="true">鏄�</Radio> + <Radio value="false">鍚�</Radio> + </Radio.Group> + )} + </Form.Item> + </Col> : null} + {datatype === 'query' && interType === 'outer' ? <Col span={12}> + <Form.Item label="鎺ュ彛鍦板潃"> {getFieldDecorator('interface', { - initialValue: data.interface || '', + initialValue: setting.sysInterface === 'true' ? (window.GLOB.mainSystemApi || '') : (setting.interface || ''), rules: [ { required: true, - message: dict['form.required.input'] + dict['header.form.interface'] + '!' + message: '璇疯緭鍏ユ帴鍙e湴鍧�!' }, { max: formRule.input.max, message: formRule.input.message } ] - })(<Input placeholder="" autoComplete="off" />)} + })(<Input placeholder="" autoComplete="off" disabled={this.state.interReadonly} onPressEnter={this.handleSubmit} />)} </Form.Item> </Col> : null} - {interType !== 'outer' ? <Col span={12}> + {datatype === 'query' && interType !== 'outer' ? <Col span={12}> <Form.Item label={ <Tooltip placement="topLeft" overlayClassName="middle" title={`鍙嚜瀹氫箟鏁版嵁澶勭悊鍑芥暟锛屽嚱鏁板悕绉伴渶浠�${usefulFields.join(', ')}绛夊瓧绗﹀紑濮嬶紱鏈缃椂浼氳皟鐢ㄧ郴缁熷嚱鏁帮紝浣跨敤绯荤粺鍑芥暟闇�瀹屽杽鏁版嵁婧愩�俙}> - <Icon type="question-circle" /> - {dict['header.form.innerFunc']} + <QuestionCircleOutlined className="mk-form-tip" /> + 鍐呴儴鍑芥暟 </Tooltip> }> {getFieldDecorator('innerFunc', { - initialValue: data.innerFunc || '', + initialValue: setting.innerFunc || '', rules: [ { pattern: _patten, @@ -199,37 +297,25 @@ message: formRule.func.maxMessage } ] - })(<Input placeholder="" autoComplete="off" />)} + })(<Input placeholder="" autoComplete="off" onPressEnter={this.handleSubmit} />)} </Form.Item> </Col> : null} - {interType !== 'outer' ? <Col span={24}> + {datatype === 'query' && interType !== 'outer' ? <Col span={24}> <Form.Item help={'鏁版嵁ID锛�' + menu.MenuID} label={ <Tooltip placement="topLeft" title="浣跨敤绯荤粺鍑芥暟鏃讹紝闇�濉啓鏁版嵁婧愶紝鑷畾涔夊嚱鏁版椂锛屽彲蹇界暐銆�"> - <Icon type="question-circle" /> - {'鏁版嵁婧�'} + <QuestionCircleOutlined className="mk-form-tip" /> + 鏁版嵁婧� </Tooltip> } className="textarea"> {getFieldDecorator('dataresource', { - initialValue: data.dataresource + initialValue: setting.dataresource })(<TextArea rows={4} />)} </Form.Item> </Col> : null} - <Col span={12}> - <Form.Item label="鍥哄畾鎸夐挳"> - {getFieldDecorator('actionfixed', { - initialValue: data.actionfixed ? 'true' : 'false' - })( - <Select> - <Select.Option value="true">鏄�</Select.Option> - <Select.Option value="false">鍚�</Select.Option> - </Select> - )} - </Form.Item> - </Col> - {interType === 'outer' ? <Col span={12}> - <Form.Item label={dict['header.form.outerFunc']}> + {datatype === 'query' && interType === 'outer' ? <Col span={12}> + <Form.Item label="澶栭儴鍑芥暟"> {getFieldDecorator('outerFunc', { - initialValue: data.outerFunc || '', + initialValue: setting.outerFunc || '', rules: [ { pattern: formRule.func.pattern, @@ -239,88 +325,24 @@ message: formRule.func.maxMessage } ] - })(<Input placeholder="" autoComplete="off" />)} + })(<Input placeholder="" autoComplete="off" onPressEnter={this.handleSubmit} />)} </Form.Item> </Col> : null} <Col span={12}> - <Form.Item label="鍥哄畾鍒�"> - {getFieldDecorator('columnfixed', { - initialValue: data.columnfixed ? 'true' : 'false' - })( - <Select> - <Select.Option value="true">鏄�</Select.Option> - <Select.Option value="false">鍚�</Select.Option> - </Select> - )} - </Form.Item> - </Col> - <Col span={12}> - <Form.Item label="涓婚敭"> - {getFieldDecorator('primaryKey', { - initialValue: primaryKey - })( - <Select - getPopupContainer={() => document.getElementById('commontable-setting-form')} - onChange={this.selectChange} - > - <Select.Option key='unset' value="">涓嶈缃�</Select.Option> - {columns.length === 0 ? - <Select.Option key='id' value="ID">ID</Select.Option> : null - } - {columns.map((option, index) => - <Select.Option id={option.uuid} title={option.label} key={index} value={option.field}>{option.label}</Select.Option> - )} - </Select> - )} - </Form.Item> - </Col> - <Col span={12}> - <Form.Item label="榛樿鎺掑簭"> - {getFieldDecorator('order', { - initialValue: data.order || (primaryKey ? primaryKey + ' desc' : ''), - rules: [ - { - required: true, - message: dict['form.required.input'] + '榛樿鎺掑簭瀛楁!' - }, - { - max: formRule.input.max, - message: formRule.input.message - } - ] - })(<Input placeholder="ID asc, UID desc" autoComplete="off" />)} + <Form.Item label="瀹藉害"> + {getFieldDecorator('width', { + initialValue: setting.width || 100 + })(<InputNumber min={10} max={100} precision={0} />)} </Form.Item> </Col> <Col span={12}> <Form.Item label="鍒濆鍖�"> {getFieldDecorator('onload', { - initialValue: data.onload || 'true' + initialValue: setting.onload || 'true' })( <Select> <Select.Option value="true">鍔犺浇鏁版嵁</Select.Option> <Select.Option value="false">涓嶅姞杞芥暟鎹�</Select.Option> - </Select> - )} - </Form.Item> - </Col> - <Col span={12}> - <Form.Item label={ - <Tooltip placement="topLeft" title="涓昏〃鍙�夊彇鍏宠仈鏍囩锛屾爣绛惧叧鑱斿悗锛屼富琛ㄦ暟鎹垏鎹㈡椂锛屼笅绾ф爣绛句細璺熼殢涓昏〃涓婚敭鍊煎彉鍖栥��"> - <Icon type="question-circle" /> - {'涓嬬骇鏍囩'} - </Tooltip> - }> - {getFieldDecorator('subtabs', { - initialValue: selectTabs - })( - <Select - mode="multiple" - style={{ width: '100%' }} - placeholder="Please select" - > - {this.state.currentTabs.map((option, index) => - <Select.Option id={option.uuid} title={option.label} key={index} value={option.uuid}>{option.label}</Select.Option> - )} </Select> )} </Form.Item> -- Gitblit v1.8.0