admin 菜单添加 search 操作
parent
8f15e2c508
commit
b95c61e2d9
|
@ -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,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -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>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue