admin 菜单添加 search 操作

pull/1/head
sin 2019-05-03 18:55:23 +08:00
parent 8f15e2c508
commit b95c61e2d9
2 changed files with 78 additions and 32 deletions

View File

@ -1,11 +1,27 @@
import { message } from 'antd'; import { message } from 'antd';
import { addResource, updateResource, deleteResource, resourceTree } from '../../services/admin'; import { addResource, updateResource, deleteResource, resourceTree } from '../../services/admin';
const buildSelectTree = list => {
return list.map(item => {
let children = [];
if (item.children) {
children = buildSelectTree(item.children);
}
return {
title: item.displayName,
value: item.displayName,
key: item.id,
children,
};
});
};
export default { export default {
namespace: 'resourceList', namespace: 'resourceList',
state: { state: {
list: [], list: [],
selectTree: [],
}, },
effects: { effects: {
@ -47,18 +63,19 @@ export default {
message.info('查询成功!'); message.info('查询成功!');
yield put({ yield put({
type: 'treeSuccess', type: 'treeSuccess',
payload: { payload: response.data,
list: response.data,
},
}); });
}, },
}, },
reducers: { reducers: {
treeSuccess(state, { payload }) { treeSuccess(state, { payload }) {
const resultData = payload;
const selectTree = buildSelectTree(resultData);
return { return {
...state, ...state,
...payload, list: resultData,
selectTree,
}; };
}, },
}, },

View File

@ -3,18 +3,39 @@
import React, { PureComponent, Fragment } from 'react'; import React, { PureComponent, Fragment } from 'react';
import { connect } from 'dva'; import { connect } from 'dva';
import moment from 'moment'; import moment from 'moment';
import { Card, Form, Input, Select, Button, Modal, message, Table, Divider } from 'antd'; import {
Card,
Form,
Input,
Select,
Button,
Modal,
message,
Table,
TreeSelect,
Radio,
Divider,
} from 'antd';
import PageHeaderWrapper from '@/components/PageHeaderWrapper'; import PageHeaderWrapper from '@/components/PageHeaderWrapper';
import styles from './ResourceList.less'; import styles from './ResourceList.less';
const RadioGroup = Radio.Group;
const FormItem = Form.Item; const FormItem = Form.Item;
const { Option } = Select; const { Option } = Select;
const types = ['未知', '菜单', '链接']; const types = ['未知', '菜单', '链接'];
// 添加 form 表单 // 添加 form 表单
const CreateForm = Form.create()(props => { const CreateForm = Form.create()(props => {
const { modalVisible, form, handleAdd, handleModalVisible, modalType, initValues } = props; const {
modalVisible,
form,
handleAdd,
handleModalVisible,
modalType,
initValues,
selectTree,
} = props;
const okHandle = () => { const okHandle = () => {
form.validateFields((err, fieldsValue) => { form.validateFields((err, fieldsValue) => {
@ -43,47 +64,54 @@ const CreateForm = Form.create()(props => {
okText={okText} okText={okText}
onCancel={() => handleModalVisible()} onCancel={() => handleModalVisible()}
> >
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="菜单展示名"> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="类型">
{form.getFieldDecorator('displayName', { {form.getFieldDecorator('displayName', {
rules: [{ required: true, message: '选择类型!', min: 2 }],
initialValue: initValues.type || 1,
})(
<RadioGroup>
<Radio value={1}>菜单</Radio>
<Radio value={2}>按钮</Radio>
</RadioGroup>
)}
</FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="名称">
{form.getFieldDecorator('type', {
rules: [{ required: true, message: '请输入菜单展示名字!', min: 2 }], rules: [{ required: true, message: '请输入菜单展示名字!', min: 2 }],
initialValue: initValues.displayName, initialValue: initValues.displayName,
})(<Input placeholder="请输入" />)} })(<Input placeholder="显示名称" />)}
</FormItem> </FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="操作"> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="菜单KEY">
{form.getFieldDecorator('handler', {
initialValue: initValues.handler,
})(<Input placeholder="请输入" />)}
</FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="资源名字">
{form.getFieldDecorator('name', { {form.getFieldDecorator('name', {
rules: [{ required: true, message: '请输入资源名字!' }], rules: [{ required: true, message: '请输入资源名字!' }],
initialValue: initValues.name, initialValue: initValues.name,
})(<Input placeholder="请输入" />)} })(<Input placeholder="菜单KEY 如:用户 USER" />)}
</FormItem> </FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="父级资源编号"> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="操作/路由">
{form.getFieldDecorator('handler', {
initialValue: initValues.handler,
})(<Input placeholder="操作/路由" />)}
</FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="父级菜单">
{form.getFieldDecorator('pid', { {form.getFieldDecorator('pid', {
rules: [{ required: true, message: '请输入父级编号!' }], rules: [{ required: true, message: '请输入父级编号!' }],
initialValue: initValues.pid, initialValue: initValues.pid,
})(<Input placeholder="请输入" />)} })(
<span>根节点为 0</span> <TreeSelect
showSearch
style={{ width: 300 }}
dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}
treeData={selectTree}
placeholder="选择父级菜单"
/>
)}
</FormItem> </FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="排序"> <FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="菜单排序">
{form.getFieldDecorator('sort', { {form.getFieldDecorator('sort', {
rules: [{ required: true, message: '请输入菜单排序!' }], rules: [{ required: true, message: '请输入菜单排序!' }],
initialValue: initValues.sort, initialValue: initValues.sort,
})(<Input placeholder="请输入" />)} })(<Input placeholder="请输入" />)}
</FormItem> </FormItem>
<FormItem labelCol={{ span: 5 }} wrapperCol={{ span: 15 }} label="资源类型">
{form.getFieldDecorator('type', {
rules: [{ required: true, message: '请选择资源类型!' }],
initialValue: 1,
})(
<Select showSearch style={selectStyle} placeholder="请选择">
<Option value={1}>菜单</Option>
<Option value={2}>Url</Option>
</Select>
)}
</FormItem>
</Modal> </Modal>
); );
}); });
@ -167,7 +195,8 @@ class ResourceList extends PureComponent {
} }
render() { render() {
const { list } = this.props; const { list, resourceList } = this.props;
const { selectTree } = resourceList;
const { modalVisible, modalType, initValues } = this.state; const { modalVisible, modalType, initValues } = this.state;
const parentMethods = { const parentMethods = {
handleAdd: this.handleAdd, handleAdd: this.handleAdd,
@ -247,7 +276,7 @@ class ResourceList extends PureComponent {
</div> </div>
<Table defaultExpandAllRows={true} columns={columns} dataSource={list} rowKey="id" /> <Table defaultExpandAllRows={true} columns={columns} dataSource={list} rowKey="id" />
</Card> </Card>
<CreateForm {...parentMethods} modalVisible={modalVisible} /> <CreateForm {...parentMethods} selectTree={selectTree} modalVisible={modalVisible} />
</PageHeaderWrapper> </PageHeaderWrapper>
); );
} }