update 系统功能列表全部加上列宽

This commit is contained in:
2021-06-28 18:18:59 +08:00
parent 6dceac060d
commit 54955e26e5
14 changed files with 544 additions and 432 deletions

View File

@@ -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>