update 系统功能列表全部加上列宽
This commit is contained in:
@@ -14,20 +14,19 @@ const apiAction = {
|
||||
add: api.sysDictDataAdd,
|
||||
edit: api.sysDictDataEdit,
|
||||
delete: api.sysDictDataDelete,
|
||||
deleteBatch: api.sysDictDataDeleteBatch
|
||||
deleteBatch: api.sysDictDataDeleteBatch,
|
||||
}
|
||||
|
||||
// 用于弹窗标题
|
||||
const name = '字典值'
|
||||
|
||||
export default class index extends Component {
|
||||
|
||||
state = {
|
||||
codes: {
|
||||
commonStatus: []
|
||||
commonStatus: [],
|
||||
},
|
||||
|
||||
selectedRowKeys: []
|
||||
selectedRowKeys: [],
|
||||
}
|
||||
|
||||
// 表格实例
|
||||
@@ -45,7 +44,7 @@ export default class index extends Component {
|
||||
dataIndex: 'value',
|
||||
sorter: true,
|
||||
width: 200,
|
||||
render: (text, record, index) =>
|
||||
render: (text, record, index) => (
|
||||
<Form.Item
|
||||
name={[index, 'value']}
|
||||
rules={[{ required: true, message: '请输入文本' }]}
|
||||
@@ -53,13 +52,14 @@ export default class index extends Component {
|
||||
>
|
||||
<Input autoComplete="off" placeholder="请输入文本" />
|
||||
</Form.Item>
|
||||
),
|
||||
},
|
||||
{
|
||||
title: '字典值',
|
||||
dataIndex: 'code',
|
||||
sorter: true,
|
||||
width: 200,
|
||||
render: (text, record, index) =>
|
||||
render: (text, record, index) => (
|
||||
<Form.Item
|
||||
name={[index, 'code']}
|
||||
rules={[{ required: true, message: '请输入文本' }]}
|
||||
@@ -67,18 +67,19 @@ export default class index extends Component {
|
||||
>
|
||||
<Input autoComplete="off" placeholder="请输入字典值" />
|
||||
</Form.Item>
|
||||
),
|
||||
},
|
||||
{
|
||||
title: '扩展值',
|
||||
dataIndex: 'extCode',
|
||||
width: 80,
|
||||
align: 'center',
|
||||
render: (text, record, index) =>
|
||||
render: (text, record, index) => (
|
||||
<>
|
||||
<Form.Item name={[index, 'extCode']} className="hidden">
|
||||
<Input type="hidden" />
|
||||
</Form.Item>
|
||||
{auth('sysDictData:edit') ?
|
||||
{auth('sysDictData:edit') ? (
|
||||
<a
|
||||
onClick={() => this.onOpen(this.jsonForm, record)}
|
||||
style={{
|
||||
@@ -87,50 +88,58 @@ export default class index extends Component {
|
||||
transform: 'scaleY(.85)',
|
||||
color: 'transparent',
|
||||
backgroundImage: 'linear-gradient(135deg, #007bff, #52c41a)',
|
||||
WebkitBackgroundClip: 'text'
|
||||
WebkitBackgroundClip: 'text',
|
||||
}}
|
||||
>JSON</a>
|
||||
:
|
||||
>
|
||||
JSON
|
||||
</a>
|
||||
) : (
|
||||
<>{text}</>
|
||||
}
|
||||
)}
|
||||
</>
|
||||
),
|
||||
},
|
||||
{
|
||||
title: '排序',
|
||||
dataIndex: 'sort',
|
||||
sorter: true,
|
||||
width: 100,
|
||||
render: (text, record, index) => <Form.Item name={[index, 'sort']} className="mb-none">
|
||||
<InputNumber
|
||||
max={1000}
|
||||
min={0}
|
||||
step={1}
|
||||
className="w-100-p"
|
||||
autoComplete="off"
|
||||
placeholder="排序"
|
||||
/>
|
||||
</Form.Item>
|
||||
render: (text, record, index) => (
|
||||
<Form.Item name={[index, 'sort']} className="mb-none">
|
||||
<InputNumber
|
||||
max={1000}
|
||||
min={0}
|
||||
step={1}
|
||||
className="w-100-p"
|
||||
autoComplete="off"
|
||||
placeholder="排序"
|
||||
/>
|
||||
</Form.Item>
|
||||
),
|
||||
defaultSortOrder: 'ascend',
|
||||
},
|
||||
{
|
||||
title: '备注',
|
||||
dataIndex: 'remark',
|
||||
sorter: true,
|
||||
render: (text, record, index) => <Form.Item name={[index, 'remark']} className="mb-none">
|
||||
<Input autoComplete="off" placeholder="请输入备注" />
|
||||
</Form.Item>
|
||||
render: (text, record, index) => (
|
||||
<Form.Item name={[index, 'remark']} className="mb-none">
|
||||
<Input autoComplete="off" placeholder="请输入备注" />
|
||||
</Form.Item>
|
||||
),
|
||||
},
|
||||
{
|
||||
title: '状态',
|
||||
dataIndex: 'status',
|
||||
sorter: true,
|
||||
width: 80,
|
||||
render: text => this.bindCodeValue(text, 'common_status')
|
||||
}
|
||||
render: text => this.bindCodeValue(text, 'common_status'),
|
||||
},
|
||||
]
|
||||
|
||||
/**
|
||||
* 构造函数,在渲染前动态添加操作字段等
|
||||
* @param {*} props
|
||||
* @param {*} props
|
||||
*/
|
||||
constructor(props) {
|
||||
super(props)
|
||||
@@ -142,27 +151,28 @@ export default class index extends Component {
|
||||
title: '操作',
|
||||
width: 150,
|
||||
dataIndex: 'actions',
|
||||
render: (text, record, index) => (<QueryTableActions>
|
||||
{
|
||||
record.id !== -1 ?
|
||||
render: (text, record, index) => (
|
||||
<QueryTableActions>
|
||||
{record.id !== -1 ? (
|
||||
<Auth auth="sysDictData:edit">
|
||||
<a onClick={() => this.onEdit(index)}>保存编辑</a>
|
||||
</Auth>
|
||||
:
|
||||
) : (
|
||||
<Auth auth="sysDictData:add">
|
||||
<a onClick={() => this.onAdd(index)}>保存新增</a>
|
||||
</Auth>
|
||||
}
|
||||
<Auth auth="sysDictData:delete">
|
||||
<Popconfirm
|
||||
placement="topRight"
|
||||
title="是否确认删除"
|
||||
onConfirm={() => this.onDelete(record)}
|
||||
>
|
||||
<a>删除</a>
|
||||
</Popconfirm>
|
||||
</Auth>
|
||||
</QueryTableActions>)
|
||||
)}
|
||||
<Auth auth="sysDictData:delete">
|
||||
<Popconfirm
|
||||
placement="topRight"
|
||||
title="是否确认删除"
|
||||
onConfirm={() => this.onDelete(record)}
|
||||
>
|
||||
<a>删除</a>
|
||||
</Popconfirm>
|
||||
</Auth>
|
||||
</QueryTableActions>
|
||||
),
|
||||
})
|
||||
}
|
||||
}
|
||||
@@ -171,9 +181,9 @@ export default class index extends Component {
|
||||
* 阻止外部组件引发的渲染,提升性能
|
||||
* 可自行添加渲染条件
|
||||
* [必要]
|
||||
* @param {*} props
|
||||
* @param {*} state
|
||||
* @returns
|
||||
* @param {*} props
|
||||
* @param {*} state
|
||||
* @returns
|
||||
*/
|
||||
shouldComponentUpdate(props, state) {
|
||||
return !isEqual(this.state, state)
|
||||
@@ -186,26 +196,28 @@ export default class index extends Component {
|
||||
componentDidMount() {
|
||||
this.table.current.onLoading()
|
||||
getDictData('common_status').then(res => {
|
||||
this.setState({
|
||||
codes: res
|
||||
}, () => {
|
||||
this.table.current.onLoadData()
|
||||
})
|
||||
this.setState(
|
||||
{
|
||||
codes: res,
|
||||
},
|
||||
() => {
|
||||
this.table.current.onLoadData()
|
||||
}
|
||||
)
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 调用加载数据接口,可在调用前对query进行处理
|
||||
* [异步,必要]
|
||||
* @param {*} params
|
||||
* @param {*} query
|
||||
* @returns
|
||||
* @param {*} params
|
||||
* @param {*} query
|
||||
* @returns
|
||||
*/
|
||||
loadData = async (params, query) => {
|
||||
|
||||
query = {
|
||||
...query,
|
||||
typeId: this.props.type.id
|
||||
typeId: this.props.type.id,
|
||||
}
|
||||
|
||||
const { data } = await apiAction.page({
|
||||
@@ -225,15 +237,15 @@ export default class index extends Component {
|
||||
|
||||
/**
|
||||
* 绑定字典数据
|
||||
* @param {*} code
|
||||
* @param {*} name
|
||||
* @returns
|
||||
* @param {*} code
|
||||
* @param {*} name
|
||||
* @returns
|
||||
*/
|
||||
bindCodeValue(code, name) {
|
||||
name = toCamelCase(name)
|
||||
const codes = this.state.codes[name]
|
||||
if (codes) {
|
||||
const c = codes.find((p) => p.code == code)
|
||||
const c = codes.find(p => p.code == code)
|
||||
if (c) {
|
||||
return c.value
|
||||
}
|
||||
@@ -243,20 +255,20 @@ export default class index extends Component {
|
||||
|
||||
/**
|
||||
* 打开新增/编辑弹窗
|
||||
* @param {*} modal
|
||||
* @param {*} record
|
||||
* @param {*} modal
|
||||
* @param {*} record
|
||||
*/
|
||||
onOpen(modal, record) {
|
||||
modal.current.open({
|
||||
record
|
||||
record,
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 对表格上的操作进行统一处理
|
||||
* [异步]
|
||||
* @param {*} action
|
||||
* @param {*} successMessage
|
||||
* @param {*} action
|
||||
* @param {*} successMessage
|
||||
*/
|
||||
async onAction(action, successMessage, reload = true) {
|
||||
const table = this.table.current
|
||||
@@ -276,13 +288,10 @@ export default class index extends Component {
|
||||
|
||||
/**
|
||||
* 删除
|
||||
* @param {*} record
|
||||
* @param {*} record
|
||||
*/
|
||||
onDelete(record) {
|
||||
this.onAction(
|
||||
apiAction.delete(record),
|
||||
'删除成功'
|
||||
)
|
||||
this.onAction(apiAction.delete(record), '删除成功')
|
||||
}
|
||||
|
||||
//#region 自定义方法
|
||||
@@ -295,12 +304,12 @@ export default class index extends Component {
|
||||
typeId: this.props.type.id,
|
||||
sort: 100,
|
||||
status: 0,
|
||||
remark: null
|
||||
remark: null,
|
||||
}
|
||||
const index = this.table.current.onAddRow(record)
|
||||
if (index !== false) {
|
||||
this.form.current.setFieldsValue({
|
||||
[index]: record
|
||||
[index]: record,
|
||||
})
|
||||
}
|
||||
}
|
||||
@@ -318,10 +327,7 @@ export default class index extends Component {
|
||||
const record = form.getFieldsValue([index])[index]
|
||||
// 为了正常显示checkbox,默认给id赋予了-1,在这里删除id以表示新增
|
||||
record.id = undefined
|
||||
this.onAction(
|
||||
apiAction.add(record),
|
||||
'新增成功'
|
||||
)
|
||||
this.onAction(apiAction.add(record), '新增成功')
|
||||
}
|
||||
|
||||
async onEdit(index) {
|
||||
@@ -335,21 +341,14 @@ export default class index extends Component {
|
||||
}
|
||||
}
|
||||
const record = form.getFieldsValue([index])[index]
|
||||
this.onAction(
|
||||
apiAction.edit(record),
|
||||
'编辑成功',
|
||||
false
|
||||
)
|
||||
this.onAction(apiAction.edit(record), '编辑成功', false)
|
||||
}
|
||||
|
||||
async onDeleteBatch() {
|
||||
await this.onAction(
|
||||
apiAction.deleteBatch(this.state.selectedRowKeys),
|
||||
'删除成功'
|
||||
)
|
||||
await this.onAction(apiAction.deleteBatch(this.state.selectedRowKeys), '删除成功')
|
||||
|
||||
this.setState({
|
||||
selectedRowKeys: []
|
||||
selectedRowKeys: [],
|
||||
})
|
||||
}
|
||||
|
||||
@@ -360,8 +359,8 @@ export default class index extends Component {
|
||||
index = dataSource.indexOf(data)
|
||||
this.form.current.setFieldsValue({
|
||||
[index]: {
|
||||
extCode
|
||||
}
|
||||
extCode,
|
||||
},
|
||||
})
|
||||
dataSource[index].extCode = extCode
|
||||
table.setState({ dataSource })
|
||||
@@ -369,7 +368,6 @@ export default class index extends Component {
|
||||
//#endregion
|
||||
|
||||
render() {
|
||||
|
||||
const { selectedRowKeys } = this.state
|
||||
|
||||
return (
|
||||
@@ -387,9 +385,9 @@ export default class index extends Component {
|
||||
rowSelection={{
|
||||
selectedRowKeys,
|
||||
onChange: selectedRowKeys => this.setState({ selectedRowKeys }),
|
||||
getCheckboxProps: (record) => ({
|
||||
disabled: record.id === -1
|
||||
})
|
||||
getCheckboxProps: record => ({
|
||||
disabled: record.id === -1,
|
||||
}),
|
||||
}}
|
||||
query={
|
||||
<Auth auth="sysDictData:page">
|
||||
@@ -409,28 +407,27 @@ export default class index extends Component {
|
||||
title="是否确认批量删除"
|
||||
onConfirm={() => this.onDeleteBatch()}
|
||||
>
|
||||
<Button disabled={!selectedRowKeys.length} danger>批量删除</Button>
|
||||
<Button disabled={!selectedRowKeys.length} danger>
|
||||
批量删除
|
||||
</Button>
|
||||
</Popconfirm>
|
||||
</Auth>
|
||||
}
|
||||
footer={
|
||||
() =>
|
||||
<Auth auth="sysDictData:add">
|
||||
<Button
|
||||
block
|
||||
icon={<AntIcon type="plus" />}
|
||||
onClick={() => this.onAddRow()}
|
||||
>新增{name}</Button>
|
||||
</Auth>
|
||||
}
|
||||
footer={() => (
|
||||
<Auth auth="sysDictData:add">
|
||||
<Button
|
||||
block
|
||||
icon={<AntIcon type="plus" />}
|
||||
onClick={() => this.onAddRow()}
|
||||
>
|
||||
新增{name}
|
||||
</Button>
|
||||
</Auth>
|
||||
)}
|
||||
/>
|
||||
</Card>
|
||||
|
||||
<ModalForm
|
||||
title="编辑"
|
||||
action={this.onSaveExtCode}
|
||||
ref={this.jsonForm}
|
||||
>
|
||||
<ModalForm title="编辑" action={this.onSaveExtCode} ref={this.jsonForm}>
|
||||
<FormBody />
|
||||
</ModalForm>
|
||||
</Container>
|
||||
|
||||
Reference in New Issue
Block a user