From 606b0b991748740179fa37448f645e6e9c7f1c41 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期日, 24 一月 2021 19:17:38 +0800 Subject: [PATCH] 2021-01-24 --- src/templates/sharecomponent/settingcomponent/settingform/simplescript/index.jsx | 104 +++++++++++++++++++++++++++++++-------------------- 1 files changed, 63 insertions(+), 41 deletions(-) diff --git a/src/templates/sharecomponent/settingcomponent/settingform/simplescript/index.jsx b/src/templates/sharecomponent/settingcomponent/settingform/simplescript/index.jsx index a559a1f..391053d 100644 --- a/src/templates/sharecomponent/settingcomponent/settingform/simplescript/index.jsx +++ b/src/templates/sharecomponent/settingcomponent/settingform/simplescript/index.jsx @@ -1,11 +1,12 @@ import React, {Component} from 'react' import PropTypes from 'prop-types' import { fromJS } from 'immutable' -import { Form, Row, Col, Icon, Button, notification, Select, Popconfirm, Typography } from 'antd' +import { Form, Row, Col, Icon, Button, notification, Select, Popconfirm, Typography, Modal } from 'antd' import moment from 'moment' import Utils from '@/utils/utils.js' import Api from '@/api' +import SettingUtils from '../utils' import CodeMirror from '@/templates/zshare/codemirror' import asyncComponent from '@/utils/asyncComponent' import './index.scss' @@ -19,7 +20,7 @@ setting: PropTypes.object, // 璁剧疆 scripts: PropTypes.array, // 鑷畾涔夎剼鏈垪琛� searches: PropTypes.array, // 鎼滅储鏉′欢 - defaultSql: PropTypes.string, // 榛樿sql + regoptions: PropTypes.any, // 姝e垯鏇挎崲 scriptsChange: PropTypes.func, // 鑷畾涔夎剼鏈垏鎹㈡椂楠岃瘉 scriptsUpdate: PropTypes.func // 琛ㄥ崟 } @@ -90,26 +91,32 @@ const { searches, scripts } = this.props let _usefulFields = [] - searches.forEach(item => { - if (!item.field) return - if (item.type === 'group') { - if (item.transfer === 'true') { + + if (searches) { + searches.forEach(item => { + if (!item.field) return + if (item.type === 'group') { + if (item.transfer === 'true') { + _usefulFields.push(item.field) + } + _usefulFields.push(item.datefield) + _usefulFields.push(item.datefield + '1') + } else if (['dateweek', 'datemonth', 'daterange'].includes(item.type)) { + _usefulFields.push(item.field) + _usefulFields.push(item.field + '1') + } else if (_usefulFields.includes(item.field)) { + _usefulFields.push(item.field + '1') + } else { _usefulFields.push(item.field) } - _usefulFields.push(item.datefield) - _usefulFields.push(item.datefield + '1') - } else if (['dateweek', 'datemonth', 'daterange'].includes(item.type)) { - _usefulFields.push(item.field) - _usefulFields.push(item.field + '1') - } else if (_usefulFields.includes(item.field)) { - _usefulFields.push(item.field + '1') - } else { - _usefulFields.push(item.field) - } - }) + }) + _usefulFields = _usefulFields.join(', ') + } else { + _usefulFields = null + } this.setState({ - usefulFields: _usefulFields.join(', '), + usefulFields: _usefulFields, scripts: fromJS(scripts).toJS() }) } @@ -140,7 +147,6 @@ let _item = { name: item.funcname, value: window.decodeURIComponent(window.atob(item.longparam)) - // value: Utils.UnformatOptions(item.longparam) } return _item }) @@ -249,24 +255,39 @@ _scripts.push(values) } + let param = { + func: 's_debug_sql', + exec_type: 'y', + LText: SettingUtils.getCustomDebugSql(_scripts, this.props.regoptions) + } + param.LText = Utils.formatOptions(param.LText) + param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss') + param.secretkey = Utils.encrypt('', param.timestamp) + this.setState({loading: true}) - this.props.scriptsChange(_scripts).then(res => { - this.setState({ - loading: false, - scripts: _scripts, - editItem: null - }) - - this.props.scriptsUpdate(_scripts) - this.props.form.setFieldsValue({ - sql: '' - }) - }, () => { - this.setState({loading: false}) + Api.getLocalConfig(param).then(result => { + if (result.status) { + this.setState({ + loading: false, + scripts: _scripts, + editItem: null + }) + + this.props.scriptsUpdate(_scripts) + this.props.form.setFieldsValue({ + sql: '' + }) + } else { + this.setState({loading: false}) + Modal.error({ + title: result.message + }) + } }) } selectScript = (value, option) => { + if (!value || !option) return let _sql = this.props.form.getFieldValue('sql') if (_sql) { _sql = _sql + ` @@ -344,7 +365,7 @@ } render() { - const { setting, defaultSql, scripts } = this.props + const { setting, scripts } = this.props const { getFieldDecorator } = this.props.form const { usefulFields, scriptsColumns, systemScripts } = this.state const formItemLayout = { @@ -362,29 +383,30 @@ <div className="modal-menu-setting-script"> <Form {...formItemLayout}> <Row gutter={24}> - {setting.tableName ? <Col span={8}> - <Form.Item label={'琛ㄥ悕'} style={{whiteSpace: 'nowrap', margin: 0}}> - {setting.tableName} + <Col span={8}> + <Form.Item label={'鍥炶皟琛ㄥ悕'} style={{whiteSpace: 'nowrap', margin: 0}}> + {setting.cbTable} </Form.Item> - </Col> : null} + </Col> <Col span={16}> <Form.Item label={'鎶ラ敊瀛楁'} style={{margin: 0}}> ErrorCode, retmsg </Form.Item> </Col> - <Col span={24} className="sqlfield"> + {usefulFields ? <Col span={24} className="sqlfield"> <Form.Item label={'鍙敤瀛楁'}> - id, bid, loginuid, sessionuid, userid, username, fullname, appkey, time_id, orderBy{setting.laypage === 'true' ? ', pageSize, pageIndex': ''}{usefulFields ? ', ' + usefulFields : ''} + id, bid, loginuid, sessionuid, userid, username, fullname, appkey, time_id{usefulFields ? ', ' + usefulFields : ''} </Form.Item> - </Col> + </Col> : null} <Col span={10} className="quick-add"> <Form.Item label={'蹇嵎娣诲姞'} style={{marginBottom: 0}}> <Select + allowClear showSearch filterOption={(input, option) => option.props.children.toLowerCase().indexOf(input.toLowerCase()) >= 0} onChange={this.selectScript} > - <Select.Option key="default" value={defaultSql}>榛樿sql</Select.Option> + {!usefulFields ? <Select.Option key="default" value={`declare @${setting.cbTable} table (mk_api_key nvarchar(100))`}>榛樿sql</Select.Option> : null} {systemScripts.map((option, i) => <Select.Option style={{whiteSpace: 'normal'}} key={i} value={option.value}>{option.name}</Select.Option> )} -- Gitblit v1.8.0