From c76e56d9cc6f8f5e93aaf355b269ec8cac8c6b95 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期六, 15 二月 2020 02:18:10 +0800 Subject: [PATCH] 2020-02-15 --- src/templates/formtabconfig/settingform/index.jsx | 127 +++++++++++++++++++++++++++--------------- 1 files changed, 82 insertions(+), 45 deletions(-) diff --git a/src/templates/formtabconfig/settingform/index.jsx b/src/templates/formtabconfig/settingform/index.jsx index c724b8b..15b044f 100644 --- a/src/templates/formtabconfig/settingform/index.jsx +++ b/src/templates/formtabconfig/settingform/index.jsx @@ -19,11 +19,12 @@ columns: null, currentTabs: null, selectTabs: [], - interReadonly: false + interReadonly: false, + primaryKey: '' } UNSAFE_componentWillMount() { - const { config, menu } = this.props + const { config } = this.props let _tabs = [] let _select = [] @@ -32,9 +33,6 @@ let _setting = config.setting try { - if (menu && menu.LongParam) { - _columns = menu.LongParam.columns.filter(item => item.field && item.type !== 'colspan') - } config.groups.forEach(group => { let list = group.sublist.filter(item => item.field) _columns = [..._columns, ...list] @@ -72,12 +70,30 @@ } }) + let primaryKey = _setting.primaryKey + if (primaryKey) { + let field = _columns.filter(column => column.field === primaryKey) + if (field.length !== 1) { + primaryKey = '' + } + } + if (!primaryKey) { + _columns.forEach(col => { + if (col.field.toLowerCase() === 'id') { + primaryKey = col.field + } + }) + } + this.setState({ currentTabs: _tabs, selectTabs: _select, columns: _columns, setting: _setting, - interReadonly: _setting.sysInterface === 'true' + interType: _setting.interType || 'inner', + interReadonly: _setting.sysInterface === 'true', + datatype: _setting.datatype || 'maintable', + primaryKey: primaryKey }) } @@ -131,10 +147,34 @@ }) } + 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 || window.GLOB.subSystemApi + }) + this.setState({ + interReadonly: true + }) + } else { + this.setState({ + interReadonly: false + }) + } + }) + } + render() { const { dict, usefulFields, menu } = this.props const { getFieldDecorator } = this.props.form - const { interType, columns, selectTabs, setting } = this.state + const { interType, columns, selectTabs, setting, datatype, primaryKey } = this.state const formItemLayout = { labelCol: { @@ -145,17 +185,6 @@ xs: { span: 24 }, sm: { span: 16 } } - } - - let primaryKey = setting.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('|') + ')' @@ -195,9 +224,37 @@ </Form.Item> </Col> <Col span={12}> + <Form.Item label={dict['header.menu.datasource']}> + {getFieldDecorator('datatype', { + initialValue: setting.datatype || 'maintable' + })( + <Radio.Group onChange={this.sourceChange}> + <Radio value="maintable">{dict['header.menu.maintable']}</Radio> + <Radio value="query">{dict['header.menu.query']}</Radio> + </Radio.Group> + )} + </Form.Item> + </Col> + {datatype === 'query' ? <Col span={12}> + <Form.Item label="涓婚敭"> + {getFieldDecorator('primaryKey', { + initialValue: primaryKey || '' + })( + <Select + getPopupContainer={() => document.getElementById('commontable-setting-form')} + > + <Select.Option key='unset' value="">鏈缃�</Select.Option> + {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> : null} + {datatype === 'query' ? <Col span={12}> <Form.Item label={dict['header.form.intertype']}> {getFieldDecorator('interType', { - initialValue: setting.interType || 'inner' + initialValue: interType })( <Radio.Group onChange={this.onChange}> <Radio value="inner">{dict['header.form.interface.inner']}</Radio> @@ -205,8 +262,8 @@ </Radio.Group> )} </Form.Item> - </Col> - {interType === 'outer' ? <Col span={12}> + </Col> : null} + {datatype === 'query' && interType === 'outer' ? <Col span={12}> <Form.Item label={dict['header.form.sysInterface']}> {getFieldDecorator('sysInterface', { initialValue: setting.sysInterface || 'false' @@ -218,7 +275,7 @@ )} </Form.Item> </Col> : null} - {interType === 'outer' ? <Col span={12}> + {datatype === 'query' && interType === 'outer' ? <Col span={12}> <Form.Item label={dict['header.form.interface']}> {getFieldDecorator('interface', { initialValue: setting.sysInterface === 'true' ? (window.GLOB.mainSystemApi || window.GLOB.subSystemApi) : (setting.interface || ''), @@ -235,7 +292,7 @@ })(<Input placeholder="" autoComplete="off" disabled={this.state.interReadonly} />)} </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" /> @@ -256,7 +313,7 @@ })(<Input placeholder="" autoComplete="off" />)} </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" /> @@ -268,7 +325,7 @@ })(<TextArea rows={4} />)} </Form.Item> </Col> : null} - {interType === 'outer' ? <Col span={12}> + {datatype === 'query' && interType === 'outer' ? <Col span={12}> <Form.Item label={dict['header.form.outerFunc']}> {getFieldDecorator('outerFunc', { initialValue: setting.outerFunc || '', @@ -284,26 +341,6 @@ })(<Input placeholder="" autoComplete="off" />)} </Form.Item> </Col> : null} - - <Col span={12}> - <Form.Item label="涓婚敭"> - {getFieldDecorator('primaryKey', { - initialValue: primaryKey - })( - <Select - getPopupContainer={() => document.getElementById('commontable-setting-form')} - > - <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={ <Tooltip placement="topLeft" title="涓昏〃鍙�夊彇鍏宠仈鏍囩锛屾爣绛惧叧鑱斿悗锛屼富琛ㄦ暟鎹垏鎹㈡椂锛屼笅绾ф爣绛句細璺熼殢涓昏〃涓婚敭鍊煎彉鍖栥��"> -- Gitblit v1.8.0