#search manage keyword modify

This commit is contained in:
chenhua 2020-11-19 00:05:12 +08:00
parent 6da49c1f40
commit 5ff01f8e12
2 changed files with 417 additions and 450 deletions

View File

@ -1,15 +1,20 @@
import React, { PureComponent, Fragment } from 'react'; import React, { PureComponent, Fragment } from 'react';
import { connect } from 'dva'; import { connect } from 'dva';
import { import {
Row, Row,
Col, Col,
Card, Card,
Form, Form,
Input, Input,
Button, Button,
Modal, Modal,
message, message,
Divider, Divider,
Icon,
DatePicker,
TimePicker,
Select,
Popover,
} from 'antd'; } from 'antd';
import StandardTable from '@/components/StandardTable'; import StandardTable from '@/components/StandardTable';
import PageHeaderWrapper from '@/components/PageHeaderWrapper'; import PageHeaderWrapper from '@/components/PageHeaderWrapper';
@ -18,6 +23,11 @@ import styles from '../../List/TableList.less';
const FormItem = Form.Item; const FormItem = Form.Item;
const { TextArea } = Input; const { TextArea } = Input;
const fieldLabels = {
keyword_type: '关键词分类'
};
const CreateForm = Form.create()(props => { const CreateForm = Form.create()(props => {
const { modalVisible, form, handleAdd, handleModalVisible } = props; const { modalVisible, form, handleAdd, handleModalVisible } = props;
@ -35,65 +45,75 @@ const CreateForm = Form.create()(props => {
visible={modalVisible} visible={modalVisible}
width={640} width={640}
onOk={okHandle} onOk={okHandle}
onCancel={() => handleModalVisible()} onCancel={() => handleModalVisible()}>
> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="关键词">
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板名称">
{form.getFieldDecorator('name', { {form.getFieldDecorator('name', {
rules: [{ required: true, message: '请输入至少五个字符的名称!', min: 5 }], rules: [{ required: true, message: '请输入至少一个字符的名称!', min: 1 }],
})(<Input placeholder="请输入名称" />)} })(<Input placeholder="请输入关键词" />)}
</FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板设置">
{form.getFieldDecorator('settings', {
rules: [{ required: true }],
})(<TextArea
style={{ minHeight: 24 }}
placeholder="请输入"
rows={9}
/>)}
</FormItem> </FormItem>
<Form.Item labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label='关键词分类'>
{form.getFieldDecorator('keyword_type', {
rules: [{ required: true, message: '请选择关键词类型' }],
})(
<Select labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} placeholder="请选择关键词类型">
<Option value="keyun">敏感词</Option>
<Option value="huoyun">提示词</Option>
<Option value="xianlu1">同义词</Option>
<Option value="xianlu2">过滤词</Option>
<Option value="xianlu3">停用词</Option>
<Option value="xianlu4">保留词</Option>
<Option value="xianlu5">纠错词</Option>
<Option value="xianlu6">相关搜索</Option>
<Option value="xianlu7">热点词管理</Option>
</Select>
)}
</Form.Item>
</Modal> </Modal>
); );
}); });
const UpdateForm = Form.create()(props => { const UpdateForm = Form.create()(props => {
const { updateModalVisible, handleUpdateModalVisible, handleUpdate,values,form } = props; const { updateModalVisible, handleUpdateModalVisible, handleUpdate,values,form } = props;
const okHandle = () => { const okHandle = () => {
form.validateFields((err, fieldsValue) => { form.validateFields((err, fieldsValue) => {
if (err) return; if (err) return;
form.resetFields(); form.resetFields();
handleUpdate(fieldsValue); handleUpdate(fieldsValue);
}); });
}; };
return ( return (
<Modal <Modal destroyOnClose title="新增关键词" visible={updateModalVisible} width={640} onOk={okHandle}
destroyOnClose onCancel={() => handleUpdateModalVisible()}>
title="模板设置"
visible={updateModalVisible} <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="关键词">
width={640} {form.getFieldDecorator('keyword', {
onOk={okHandle} initialValue: values.nakeywordme,
onCancel={() => handleUpdateModalVisible()} rules: [{ required: true, message: '请输入至少一个字符的名称!', min: 1 }],
> })(<Input placeholder="请输入关键词" />)}
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板名称">
{form.getFieldDecorator('name', {
initialValue: values.name,
rules: [{ required: true, message: '请输入至少五个字符的名称!', min: 5 }],
})(<Input placeholder="请输入名称" />)}
</FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板设置">
{form.getFieldDecorator('settings', {
initialValue: values.processors,
rules: [{ required: true }],
})(<TextArea
style={{ minHeight: 24 }}
placeholder="请输入"
rows={9}
/>)}
</FormItem> </FormItem>
<Form.Item labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label={fieldLabels.keyword_type}>
{form.getFieldDecorator('keyword_type', {
rules: [{ required: true, message: '请选择关键词类型' }],
})(
<Select placeholder="请选择关键词类型">
<Option value="keyun">敏感词</Option>
<Option value="huoyun">提示词</Option>
<Option value="xianlu">同义词</Option>
<Option value="xianlu">过滤词</Option>
<Option value="xianlu">停用词</Option>
<Option value="xianlu">保留词</Option>
<Option value="xianlu">纠错词</Option>
<Option value="xianlu">相关搜索</Option>
<Option value="xianlu">热点词管理</Option>
</Select>
)}
</Form.Item>
</Modal> </Modal>
); );
}); });
/* eslint react/no-multi-comp:0 */ /* eslint react/no-multi-comp:0 */
@connect(({ pipeline, loading }) => ({ @connect(({ pipeline, loading }) => ({
@ -110,111 +130,66 @@ class Common extends PureComponent {
formValues: {}, formValues: {},
updateFormValues: {}, updateFormValues: {},
}; };
//index template detail example
// {
// ".ml-state" : {
// "order" : 0,
// "version" : 7090199,
// "index_patterns" : [
// ".ml-state*"
// ],
// "settings" : {
// "index" : {
// "hidden" : "true",
// "lifecycle" : {
// "name" : "ml-size-based-ilm-policy",
// "rollover_alias" : ".ml-state-write"
// },
// "auto_expand_replicas" : "0-1"
// }
// },
// "mappings" : {
// "_meta" : {
// "version" : "7090199"
// },
// "enabled" : false
// },
// "aliases" : { }
// }
// }
datasource = ` datasource = `
[ [
{ {
"name" : "filebeat-7.9.1", "keyword" : "验收标准",
"index_patterns" : "[filebeat-7.9.1-*]", "type" : "停用词"
"order" : "1",
"version" : null,
"composed_of" : ""
}, },
{ {
"name" : "apm-7.9.1-span", "keyword" : "桥梁施工技术规范",
"index_patterns" : "[apm-7.9.1-span*]", "type" : "停用词"
"order" : "2", },{
"version" : null, "keyword" : "路规",
"composed_of" : "" "type" : "停用词"
},{
"keyword" : "遂规",
"type" : "热点词"
}, },
{ {
"name" : ".lists-default", "keyword" : "铁路技术管理规则",
"index_patterns" : "[.lists-default-*]", "type" : "热点词"
"order" : "0", },{
"version" : null, "keyword" : "行车组织规则",
"composed_of" : "" "type" : "热点词"
}, },
{ {
"name" : ".monitoring-es", "keyword" : "铁路交通事故调查处理规则",
"index_patterns" : "[.monitoring-es-7-*]", "type" : "热点词"
"order" : "0",
"version" : "7000199",
"composed_of" : ""
},
{
"name" : ".monitoring-beats",
"index_patterns" : "[.monitoring-beats-7-*]",
"order" : "0",
"version" : "7000199",
"composed_of" : ""
}]`; }]`;
columns = [ columns = [
{ {
title: '模板名称', title: '关键词名称',
dataIndex: 'name', dataIndex: 'keyword',
}, },
{ {
title: '模式', title: '关键词分类',
dataIndex: 'index_patterns', dataIndex: 'type',
},
{
title: 'order',
dataIndex: 'order'
},
{
title: '版本',
dataIndex: 'version'
}, },
{ {
title: '操作', title: '操作',
render: (text, record) => ( render: (text, record) => (
<Fragment> <Fragment>
<a onClick={() => this.handleUpdateModalVisible(true, record)}>设置</a> <a onClick={() => this.handleUpdateModalVisible(true, record)}>修改</a>
<Divider type="vertical" /> <Divider type="vertical" />
<a onClick={() => { <a onClick={() => {
this.state.selectedRows.push(record); this.state.selectedRows.push(record);
this.handleDeleteClick(); this.handleDeleteClick();
}}>删除</a> }}>删除</a>
</Fragment> </Fragment>
), ),
}, },
]; ];
componentDidMount() { componentDidMount() {
const { dispatch } = this.props; const { dispatch } = this.props;
// dispatch({ // dispatch({
// type: 'pipeline/fetch', // type: 'pipeline/fetch',
// }); // });
} }
handleStandardTableChange = (pagination, filtersArg, sorter) => { handleStandardTableChange = (pagination, filtersArg, sorter) => {
const { dispatch } = this.props; const { dispatch } = this.props;
const { formValues } = this.state; const { formValues } = this.state;
@ -238,9 +213,9 @@ class Common extends PureComponent {
type: 'pipeline/fetch', type: 'pipeline/fetch',
payload: params, payload: params,
}); });
}; };
handleFormReset = () => { handleFormReset = () => {
const { form, dispatch } = this.props; const { form, dispatch } = this.props;
form.resetFields(); form.resetFields();
this.setState({ this.setState({
@ -250,9 +225,9 @@ class Common extends PureComponent {
type: 'pipeline/fetch', type: 'pipeline/fetch',
payload: {}, payload: {},
}); });
}; };
handleDeleteClick = e => { handleDeleteClick = e => {
const { dispatch } = this.props; const { dispatch } = this.props;
const { selectedRows } = this.state; const { selectedRows } = this.state;
@ -268,15 +243,15 @@ class Common extends PureComponent {
}); });
}, },
}); });
}; };
handleSelectRows = rows => { handleSelectRows = rows => {
this.setState({ this.setState({
selectedRows: rows, selectedRows: rows,
}); });
}; };
handleSearch = e => { handleSearch = e => {
e.preventDefault(); e.preventDefault();
const { dispatch, form } = this.props; const { dispatch, form } = this.props;
@ -298,22 +273,22 @@ class Common extends PureComponent {
payload: values, payload: values,
}); });
}); });
}; };
handleModalVisible = flag => { handleModalVisible = flag => {
this.setState({ this.setState({
modalVisible: !!flag, modalVisible: !!flag,
}); });
}; };
handleUpdateModalVisible = (flag, record) => { handleUpdateModalVisible = (flag, record) => {
this.setState({ this.setState({
updateModalVisible: !!flag, updateModalVisible: !!flag,
updateFormValues: record || {}, updateFormValues: record || {},
}); });
}; };
handleAdd = fields => { handleAdd = fields => {
const { dispatch } = this.props; const { dispatch } = this.props;
dispatch({ dispatch({
type: 'pipeline/add', type: 'pipeline/add',
@ -326,9 +301,9 @@ class Common extends PureComponent {
message.success('添加成功'); message.success('添加成功');
this.handleModalVisible(); this.handleModalVisible();
}; };
handleUpdate = fields => { handleUpdate = fields => {
const { dispatch } = this.props; const { dispatch } = this.props;
dispatch({ dispatch({
type: 'pipeline/update', type: 'pipeline/update',
@ -341,18 +316,37 @@ class Common extends PureComponent {
message.success('修改成功'); message.success('修改成功');
this.handleUpdateModalVisible(); this.handleUpdateModalVisible();
}; };
renderSimpleForm() { renderSimpleForm() {
const { const {
form: { getFieldDecorator }, form: { getFieldDecorator },
} = this.props; } = this.props;
return ( return (
<Form onSubmit={this.handleSearch} layout="inline"> <Form onSubmit={this.handleSearch} layout="inline">
<Row gutter={{ md: 8, lg: 24, xl: 48 }}> <Row gutter={{ md: 8, lg: 24, xl: 48 }}>
<Col lg={6} md={12} sm={24}>
<Form.Item label={fieldLabels.keyword_type}>
{getFieldDecorator('keyword_type', {
rules: [{ required: true, message: '请选择关键词类型' }],
})(
<Select placeholder="请选择关键词类型">
<Option value="keyun">敏感词</Option>
<Option value="huoyun">提示词</Option>
<Option value="xianlu">同义词</Option>
<Option value="xianlu">过滤词</Option>
<Option value="xianlu">停用词</Option>
<Option value="xianlu">保留词</Option>
<Option value="xianlu">纠错词</Option>
<Option value="xianlu">相关搜索</Option>
<Option value="xianlu">热点词管理</Option>
</Select>
)}
</Form.Item>
</Col>
<Col md={8} sm={24}> <Col md={8} sm={24}>
<FormItem label="模板名称"> <FormItem label="关键词">
{getFieldDecorator('name')(<Input placeholder="请输入" />)} {getFieldDecorator('name')(<Input placeholder="请输入关键词" />)}
</FormItem> </FormItem>
</Col> </Col>
<Col md={8} sm={24}> <Col md={8} sm={24}>
@ -367,14 +361,14 @@ class Common extends PureComponent {
</Col> </Col>
</Row> </Row>
</Form> </Form>
); );
} }
renderForm() { renderForm() {
return this.renderSimpleForm(); return this.renderSimpleForm();
} }
render() { render() {
const data = { const data = {
list: JSON.parse(this.datasource), list: JSON.parse(this.datasource),
pagination: { pagination: {
@ -397,7 +391,7 @@ class Common extends PureComponent {
<div className={styles.tableListForm}>{this.renderForm()}</div> <div className={styles.tableListForm}>{this.renderForm()}</div>
<div className={styles.tableListOperator}> <div className={styles.tableListOperator}>
<Button icon="plus" type="primary" onClick={() => this.handleModalVisible(true)}> <Button icon="plus" type="primary" onClick={() => this.handleModalVisible(true)}>
新建 新增关键词
</Button> </Button>
{selectedRows.length > 0 && ( {selectedRows.length > 0 && (
<span> <span>
@ -426,5 +420,4 @@ class Common extends PureComponent {
); );
} }
} }
export default Common; export default Common;

View File

@ -10,6 +10,11 @@ import {
Modal, Modal,
message, message,
Divider, Divider,
Icon,
DatePicker,
TimePicker,
Select,
Popover,
} from 'antd'; } from 'antd';
import StandardTable from '@/components/StandardTable'; import StandardTable from '@/components/StandardTable';
import PageHeaderWrapper from '@/components/PageHeaderWrapper'; import PageHeaderWrapper from '@/components/PageHeaderWrapper';
@ -18,7 +23,10 @@ import styles from '../../List/TableList.less';
const FormItem = Form.Item; const FormItem = Form.Item;
const { TextArea } = Input; const { TextArea } = Input;
const fieldLabels = {
keyword_type: '关键词分类'
};
const CreateForm = Form.create()(props => { const CreateForm = Form.create()(props => {
const { modalVisible, form, handleAdd, handleModalVisible } = props; const { modalVisible, form, handleAdd, handleModalVisible } = props;
const okHandle = () => { const okHandle = () => {
@ -35,24 +43,25 @@ const CreateForm = Form.create()(props => {
visible={modalVisible} visible={modalVisible}
width={640} width={640}
onOk={okHandle} onOk={okHandle}
onCancel={() => handleModalVisible()} onCancel={() => handleModalVisible()}>
> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="关键词">
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板名称">
{form.getFieldDecorator('name', { {form.getFieldDecorator('name', {
rules: [{ required: true, message: '请输入至少五个字符的名称!', min: 5 }], rules: [{ required: true, message: '请输入至少一个字符的名称!', min: 1 }],
})(<Input placeholder="请输入名称" />)} })(<Input placeholder="请输入关键词" />)}
</FormItem> </FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板设置"> <Form.Item labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label='关键词分类'>
{form.getFieldDecorator('settings', { {form.getFieldDecorator('keyword_type', {
rules: [{ required: true }], rules: [{ required: true, message: '请选择关键词类型' }],
})(<TextArea })(
style={{ minHeight: 24 }} <Select placeholder="请选择关键词类型">
placeholder="请输入" <Option value="keyun">客运</Option>
rows={9} <Option value="huoyun">货运</Option>
/>)} <Option value="xianlu">线路</Option>
</FormItem> </Select>
)}
</Form.Item>
</Modal> </Modal>
); );
}); });
const UpdateForm = Form.create()(props => { const UpdateForm = Form.create()(props => {
@ -67,32 +76,29 @@ const UpdateForm = Form.create()(props => {
}; };
return ( return (
<Modal <Modal destroyOnClose title="新增关键词" visible={updateModalVisible} width={640} onOk={okHandle}
destroyOnClose onCancel={() => handleUpdateModalVisible()}>
title="模板设置"
visible={updateModalVisible} <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="关键词">
width={640} {form.getFieldDecorator('keyword', {
onOk={okHandle} initialValue: values.nakeywordme,
onCancel={() => handleUpdateModalVisible()} rules: [{ required: true, message: '请输入至少一个字符的名称!', min: 1 }],
> })(<Input placeholder="请输入关键词" />)}
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板名称"> </FormItem>
{form.getFieldDecorator('name', {
initialValue: values.name, <Form.Item labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label={fieldLabels.keyword_type}>
rules: [{ required: true, message: '请输入至少五个字符的名称!', min: 5 }], {form.getFieldDecorator('keyword_type', {
})(<Input placeholder="请输入名称" />)} rules: [{ required: true, message: '请选择关键词类型' }],
</FormItem> })(
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="模板设置"> <Select placeholder="请选择关键词类型">
{form.getFieldDecorator('settings', { <Option value="keyun">客运</Option>
initialValue: values.processors, <Option value="huoyun">货运</Option>
rules: [{ required: true }], <Option value="xianlu">线路</Option>
})(<TextArea </Select>
style={{ minHeight: 24 }} )}
placeholder="请输入" </Form.Item>
rows={9}
/>)}
</FormItem>
</Modal> </Modal>
); );
}); });
/* eslint react/no-multi-comp:0 */ /* eslint react/no-multi-comp:0 */
@ -110,93 +116,48 @@ class Professional extends PureComponent {
formValues: {}, formValues: {},
updateFormValues: {}, updateFormValues: {},
}; };
//index template detail example
// {
// ".ml-state" : {
// "order" : 0,
// "version" : 7090199,
// "index_patterns" : [
// ".ml-state*"
// ],
// "settings" : {
// "index" : {
// "hidden" : "true",
// "lifecycle" : {
// "name" : "ml-size-based-ilm-policy",
// "rollover_alias" : ".ml-state-write"
// },
// "auto_expand_replicas" : "0-1"
// }
// },
// "mappings" : {
// "_meta" : {
// "version" : "7090199"
// },
// "enabled" : false
// },
// "aliases" : { }
// }
// }
datasource = ` datasource = `
[ [
{ {
"name" : "filebeat-7.9.1", "keyword" : "验收标准",
"index_patterns" : "[filebeat-7.9.1-*]", "type" : "客运"
"order" : "1",
"version" : null,
"composed_of" : ""
}, },
{ {
"name" : "apm-7.9.1-span", "keyword" : "桥梁施工技术规范",
"index_patterns" : "[apm-7.9.1-span*]", "type" : "客运"
"order" : "2", },{
"version" : null, "keyword" : "路规",
"composed_of" : "" "type" : "客运"
},{
"keyword" : "遂规",
"type" : "客运"
}, },
{ {
"name" : ".lists-default", "keyword" : "铁路技术管理规则",
"index_patterns" : "[.lists-default-*]", "type" : "客运"
"order" : "0", },{
"version" : null, "keyword" : "行车组织规则",
"composed_of" : "" "type" : "客运"
}, },
{ {
"name" : ".monitoring-es", "keyword" : "铁路交通事故调查处理规则",
"index_patterns" : "[.monitoring-es-7-*]", "type" : "客运"
"order" : "0",
"version" : "7000199",
"composed_of" : ""
},
{
"name" : ".monitoring-beats",
"index_patterns" : "[.monitoring-beats-7-*]",
"order" : "0",
"version" : "7000199",
"composed_of" : ""
}]`; }]`;
columns = [ columns = [
{ {
title: '模板名称', title: '关键词名称',
dataIndex: 'name', dataIndex: 'keyword',
}, },
{ {
title: '模式', title: '关键词分类',
dataIndex: 'index_patterns', dataIndex: 'type',
},
{
title: 'order',
dataIndex: 'order'
},
{
title: '版本',
dataIndex: 'version'
}, },
{ {
title: '操作', title: '操作',
render: (text, record) => ( render: (text, record) => (
<Fragment> <Fragment>
<a onClick={() => this.handleUpdateModalVisible(true, record)}>设置</a> <a onClick={() => this.handleUpdateModalVisible(true, record)}>修改</a>
<Divider type="vertical" /> <Divider type="vertical" />
<a onClick={() => { <a onClick={() => {
this.state.selectedRows.push(record); this.state.selectedRows.push(record);
@ -350,9 +311,22 @@ class Professional extends PureComponent {
return ( return (
<Form onSubmit={this.handleSearch} layout="inline"> <Form onSubmit={this.handleSearch} layout="inline">
<Row gutter={{ md: 8, lg: 24, xl: 48 }}> <Row gutter={{ md: 8, lg: 24, xl: 48 }}>
<Col lg={6} md={12} sm={24}>
<Form.Item label={fieldLabels.keyword_type}>
{getFieldDecorator('keyword_type', {
rules: [{ required: true, message: '请选择关键词类型' }],
})(
<Select placeholder="请选择关键词类型">
<Option value="keyun">客运</Option>
<Option value="huoyun">货运</Option>
<Option value="xianlu">线路</Option>
</Select>
)}
</Form.Item>
</Col>
<Col md={8} sm={24}> <Col md={8} sm={24}>
<FormItem label="模板名称"> <FormItem label="关键词">
{getFieldDecorator('name')(<Input placeholder="请输入" />)} {getFieldDecorator('name')(<Input placeholder="请输入关键词" />)}
</FormItem> </FormItem>
</Col> </Col>
<Col md={8} sm={24}> <Col md={8} sm={24}>
@ -397,7 +371,7 @@ class Professional extends PureComponent {
<div className={styles.tableListForm}>{this.renderForm()}</div> <div className={styles.tableListForm}>{this.renderForm()}</div>
<div className={styles.tableListOperator}> <div className={styles.tableListOperator}>
<Button icon="plus" type="primary" onClick={() => this.handleModalVisible(true)}> <Button icon="plus" type="primary" onClick={() => this.handleModalVisible(true)}>
增关键词
</Button> </Button>
{selectedRows.length > 0 && ( {selectedRows.length > 0 && (
<span> <span>