2020-11-17 17:02:42 +08:00
|
|
|
<template>
|
|
|
|
|
<div class="p-4">
|
2021-06-05 14:11:00 +08:00
|
|
|
<BasicTable @register="registerTable" @edit-change="onEditChange">
|
2020-11-17 17:02:42 +08:00
|
|
|
<template #action="{ record, column }">
|
|
|
|
|
<TableAction :actions="createActions(record, column)" />
|
|
|
|
|
</template>
|
|
|
|
|
</BasicTable>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
<script lang="ts">
|
|
|
|
|
import { defineComponent, ref } from 'vue';
|
|
|
|
|
import {
|
|
|
|
|
BasicTable,
|
|
|
|
|
useTable,
|
|
|
|
|
TableAction,
|
|
|
|
|
BasicColumn,
|
|
|
|
|
ActionItem,
|
|
|
|
|
EditRecordRow,
|
|
|
|
|
} from '/@/components/Table';
|
2020-12-31 21:24:47 +08:00
|
|
|
import { optionsListApi } from '/@/api/demo/select';
|
2020-11-17 17:02:42 +08:00
|
|
|
|
|
|
|
|
import { demoListApi } from '/@/api/demo/table';
|
2021-07-19 00:51:02 +08:00
|
|
|
const optionsData = ref([]);
|
|
|
|
|
|
2020-11-17 17:02:42 +08:00
|
|
|
const columns: BasicColumn[] = [
|
|
|
|
|
{
|
2020-12-31 21:24:47 +08:00
|
|
|
title: '输入框',
|
|
|
|
|
dataIndex: 'name',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponentProps: {
|
|
|
|
|
prefix: '$',
|
|
|
|
|
},
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 150,
|
2020-12-31 21:24:47 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '默认输入状态',
|
|
|
|
|
dataIndex: 'name7',
|
|
|
|
|
editRow: true,
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 150,
|
2020-12-31 21:24:47 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '输入框校验',
|
|
|
|
|
dataIndex: 'name1',
|
|
|
|
|
editRow: true,
|
2021-05-26 23:06:07 +08:00
|
|
|
align: 'left',
|
2020-12-31 21:24:47 +08:00
|
|
|
// 默认必填校验
|
|
|
|
|
editRule: true,
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 150,
|
2020-12-31 21:24:47 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '输入框函数校验',
|
|
|
|
|
dataIndex: 'name2',
|
|
|
|
|
editRow: true,
|
2021-05-26 23:06:07 +08:00
|
|
|
align: 'right',
|
2020-12-31 21:24:47 +08:00
|
|
|
editRule: async (text) => {
|
|
|
|
|
if (text === '2') {
|
|
|
|
|
return '不能输入该值';
|
|
|
|
|
}
|
|
|
|
|
return '';
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '数字输入框',
|
2020-11-17 17:02:42 +08:00
|
|
|
dataIndex: 'id',
|
2020-12-31 21:24:47 +08:00
|
|
|
editRow: true,
|
|
|
|
|
editRule: true,
|
|
|
|
|
editComponent: 'InputNumber',
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 150,
|
2020-11-17 17:02:42 +08:00
|
|
|
},
|
|
|
|
|
{
|
2020-12-31 21:24:47 +08:00
|
|
|
title: '下拉框',
|
|
|
|
|
dataIndex: 'name3',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponent: 'Select',
|
|
|
|
|
editComponentProps: {
|
|
|
|
|
options: [
|
|
|
|
|
{
|
|
|
|
|
label: 'Option1',
|
|
|
|
|
value: '1',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
label: 'Option2',
|
|
|
|
|
value: '2',
|
|
|
|
|
},
|
2021-07-15 18:05:13 +08:00
|
|
|
{
|
|
|
|
|
label: 'Option3',
|
|
|
|
|
value: '3',
|
|
|
|
|
},
|
2020-12-31 21:24:47 +08:00
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
width: 200,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '远程下拉',
|
|
|
|
|
dataIndex: 'name4',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponent: 'ApiSelect',
|
|
|
|
|
editComponentProps: {
|
|
|
|
|
api: optionsListApi,
|
2021-07-15 18:05:13 +08:00
|
|
|
resultField: 'list',
|
|
|
|
|
labelField: 'name',
|
|
|
|
|
valueField: 'id',
|
2021-07-19 00:51:02 +08:00
|
|
|
onOptionsChange(options) {
|
|
|
|
|
optionsData.value = options;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
editValueMap(value: any) {
|
|
|
|
|
const found = optionsData.value.find((option) => option.id === value);
|
|
|
|
|
if (found) {
|
|
|
|
|
return found.name;
|
|
|
|
|
} else {
|
|
|
|
|
return value;
|
|
|
|
|
}
|
2020-12-31 21:24:47 +08:00
|
|
|
},
|
|
|
|
|
width: 200,
|
|
|
|
|
},
|
2021-05-26 21:47:31 +08:00
|
|
|
{
|
|
|
|
|
title: '日期选择',
|
|
|
|
|
dataIndex: 'date',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponent: 'DatePicker',
|
|
|
|
|
editComponentProps: {
|
|
|
|
|
valueFormat: 'YYYY-MM-DD',
|
|
|
|
|
format: 'YYYY-MM-DD',
|
|
|
|
|
},
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 150,
|
2021-05-26 21:47:31 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '时间选择',
|
|
|
|
|
dataIndex: 'time',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponent: 'TimePicker',
|
|
|
|
|
editComponentProps: {
|
|
|
|
|
valueFormat: 'HH:mm',
|
|
|
|
|
format: 'HH:mm',
|
|
|
|
|
},
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 100,
|
2021-05-26 21:47:31 +08:00
|
|
|
},
|
2020-12-31 21:24:47 +08:00
|
|
|
{
|
|
|
|
|
title: '勾选框',
|
|
|
|
|
dataIndex: 'name5',
|
|
|
|
|
editRow: true,
|
|
|
|
|
|
|
|
|
|
editComponent: 'Checkbox',
|
|
|
|
|
editValueMap: (value) => {
|
|
|
|
|
return value ? '是' : '否';
|
|
|
|
|
},
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 100,
|
2020-12-31 21:24:47 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '开关',
|
|
|
|
|
dataIndex: 'name6',
|
|
|
|
|
editRow: true,
|
|
|
|
|
editComponent: 'Switch',
|
|
|
|
|
editValueMap: (value) => {
|
|
|
|
|
return value ? '开' : '关';
|
|
|
|
|
},
|
2021-05-26 23:06:07 +08:00
|
|
|
width: 100,
|
2020-11-17 17:02:42 +08:00
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
export default defineComponent({
|
2021-01-28 23:28:50 +08:00
|
|
|
components: { BasicTable, TableAction },
|
2020-11-17 17:02:42 +08:00
|
|
|
setup() {
|
|
|
|
|
const currentEditKeyRef = ref('');
|
|
|
|
|
const [registerTable] = useTable({
|
|
|
|
|
title: '可编辑行示例',
|
2021-06-05 14:11:00 +08:00
|
|
|
titleHelpMessage: [
|
|
|
|
|
'本例中修改[数字输入框]这一列时,同一行的[远程下拉]列的当前编辑数据也会同步发生改变',
|
|
|
|
|
],
|
2020-11-17 17:02:42 +08:00
|
|
|
api: demoListApi,
|
|
|
|
|
columns: columns,
|
|
|
|
|
showIndexColumn: false,
|
|
|
|
|
actionColumn: {
|
|
|
|
|
width: 160,
|
|
|
|
|
title: 'Action',
|
|
|
|
|
dataIndex: 'action',
|
|
|
|
|
slots: { customRender: 'action' },
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
function handleEdit(record: EditRecordRow) {
|
|
|
|
|
currentEditKeyRef.value = record.key;
|
2020-12-31 21:24:47 +08:00
|
|
|
record.onEdit?.(true);
|
2020-11-17 17:02:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function handleCancel(record: EditRecordRow) {
|
|
|
|
|
currentEditKeyRef.value = '';
|
2021-02-04 00:20:48 +08:00
|
|
|
record.onEdit?.(false, false);
|
2020-11-17 17:02:42 +08:00
|
|
|
}
|
|
|
|
|
|
2020-12-31 21:24:47 +08:00
|
|
|
async function handleSave(record: EditRecordRow) {
|
|
|
|
|
const pass = await record.onEdit?.(false, true);
|
|
|
|
|
if (pass) {
|
|
|
|
|
currentEditKeyRef.value = '';
|
|
|
|
|
}
|
2020-11-17 17:02:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createActions(record: EditRecordRow, column: BasicColumn): ActionItem[] {
|
|
|
|
|
if (!record.editable) {
|
|
|
|
|
return [
|
|
|
|
|
{
|
|
|
|
|
label: '编辑',
|
|
|
|
|
disabled: currentEditKeyRef.value ? currentEditKeyRef.value !== record.key : false,
|
|
|
|
|
onClick: handleEdit.bind(null, record),
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
return [
|
|
|
|
|
{
|
|
|
|
|
label: '保存',
|
|
|
|
|
onClick: handleSave.bind(null, record, column),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
label: '取消',
|
|
|
|
|
popConfirm: {
|
|
|
|
|
title: '是否取消编辑',
|
|
|
|
|
confirm: handleCancel.bind(null, record, column),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-05 14:11:00 +08:00
|
|
|
function onEditChange({ column, value, record }) {
|
|
|
|
|
// 本例
|
|
|
|
|
if (column.dataIndex === 'id') {
|
|
|
|
|
record.editValueRefs.name4.value = `${value}`;
|
|
|
|
|
}
|
|
|
|
|
console.log(column, value, record);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-17 17:02:42 +08:00
|
|
|
return {
|
|
|
|
|
registerTable,
|
|
|
|
|
handleEdit,
|
|
|
|
|
createActions,
|
2021-06-05 14:11:00 +08:00
|
|
|
onEditChange,
|
2020-11-17 17:02:42 +08:00
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
</script>
|