Browse Source

👣 提供ant原生表格组件模板基本完成

master
wangxiang 3 years ago
parent
commit
de9de6d8a7
  1. 199
      kicc-ui/src/views/system/config/ConfigModal.vue
  2. 27
      kicc-ui/src/views/system/config/index.vue

199
kicc-ui/src/views/system/config/ConfigModal.vue

@ -1,64 +1,157 @@ @@ -1,64 +1,157 @@
<template>
<BasicModal
v-bind="$attrs"
@register="registerModal"
@ok="handleSubmit"
width="720px">
<BasicForm @register="registerForm" />
<BasicModal v-bind="$attrs"
:width="720"
@register="registerModal"
@ok="handleSubmit"
>
<AForm ref="formElRef"
:model="state.modelRef"
:rules="state.rulesRef"
>
<AFormItem v-bind="validateInfos.name"
label="参数名称"
name="name"
>
<a-input v-model:value="state.modelRef.name"/>
</AFormItem>
<AFormItem v-bind="validateInfos.key"
name="key"
label="参数键名"
>
<Input v-model:value="state.modelRef.key"/>
</AFormItem>
<AFormItem v-bind="validateInfos.value"
name="value"
label="参数键值"
>
<Input v-model:value="state.modelRef.value"/>
</AFormItem>
<AFormItem v-bind="validateInfos.isSys"
name="isSys"
label="系统内置"
>
<ARadioGroup v-model:value="state.modelRef.isSys">
<ARadio value="0"></ARadio>
<ARadio value="1"></ARadio>
</ARadioGroup>
</AFormItem>
<AFormItem v-bind="validateInfos.remarks"
name="remarks"
label="备注"
>
<ATextarea v-model:value="state.modelRef.remarks"/>
</AFormItem>
</AForm>
</BasicModal>
</template>
<script lang="ts">
import { defineComponent, ref, unref } from 'vue';
import {BasicModal, ModalProps, useModalInner} from '/@/components/Modal';
import { BasicForm, useForm } from '/@/components/Form/index';
import { formSchema } from './config.data';
//import { set } from '/@/api/platform/system/controller/config';
<script lang="ts" setup>
/**
* 提供模板规范代码参考,请尽量保证编写代码风格跟模板规范代码一致
* 采用ant-design-vue表格表单组件编写,采用 setup 写法
* 当vben的BasicTable跟BasicForm组件不能满足一些特殊需求时,需要写原生ant-design-vue组件时,请严格参考此处代码
* 当前原生ant-design-vue表格表单组件模板,目前已经与系统项目配置高度集成,系统配置发生修改时组件也会产生对应的变化
* 目前是基于vben的BasicTable跟BasicForm组件重写出一套ant-design-vue原生表格表单组件模板
* 注意:不会强依赖vben的BasicTable跟BasicForm组件,只会依赖一些简单容易逻辑不复杂的功能,复杂的功能不会依赖,降低耦合,提升此模板的可扩展性
* Copyright © 2020-2022 <a href="http://www.entfrm.com/">entfrm</a> All rights reserved.
* author entfrm开发团队-王翔
*/
import { reactive } from 'vue';
import { Form, Textarea, Radio } from 'ant-design-vue';
import { BasicModal, ModalProps, useModalInner } from '/@/components/Modal';
import { getConfig, addConfig, editConfig } from '/@/api/platform/system/controller/config';
export default defineComponent({
name: 'ConfigModal',
components: { BasicModal, BasicForm },
emits: ['success', 'register'],
setup(_, { emit }) {
const isUpdate = ref(true);
/** 类型规范统一声明定义区域 */
interface WindowState {
tag: string;
modelRef: {
id: string;
name: string;
key: string;
value: string;
isSys: string;
remarks: string;
};
rulesRef: Recordable;
}
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm({
labelWidth: 100,
schemas: formSchema,
showActionButtonGroup: false,
baseColProps: { span: 24 }
});
/** 通用变量统一声明区域 */
const AForm = Form;
const AFormItem = Form.Item;
const ATextarea = Textarea;
const ARadio = Radio;
const ARadioGroup = Radio.Group;
const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => {
await resetFields();
const props: Partial<ModalProps> = { confirmLoading: false };
isUpdate.value = !!data?.isUpdate;
if (unref(isUpdate)) {
await setFieldsValue({
...data.record,
});
props.title = "编辑参数";
}else {
props.title = "新增参数";
}
setModalProps(props);
});
const useForm = AForm.useForm;
const state = reactive<WindowState>({
tag: '',
modelRef: {
id: undefined!,
name: undefined!,
key: undefined!,
value: undefined!,
isSys: '0',
remarks: undefined!
},
rulesRef: {
name: [
{ required: true, whitespace: true, message: '参数名称不能为空', validateTrigger: 'blur' }
],
key: [
{ required: true, whitespace: true, message: '参数键名不能为空', validateTrigger: 'blur' }
],
value: [
{ required: true, whitespace: true, message: '参数键值不能为空', validateTrigger: 'blur' }
]
}
});
/** https://v3.cn.vuejs.org/api/options-data.html#emits */
const emit = defineEmits(['success', 'register']);
const { resetFields, clearValidate, validate, validateInfos } = useForm(state.modelRef, state.rulesRef);
const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data: WindowInnerData = { _tag: '' })=> {
//
resetFields();
clearValidate();
//
state.tag = data._tag;
const configId = data.record?.id;
const props: Partial<ModalProps> = { confirmLoading: false };
// tag
switch (state.tag) {
case 'add':
props.title = '新增配置参数';
break;
case 'edit':
props.title = '编辑配置参数';
const result = await getConfig(configId);
state.modelRef = result;
break;
}
// :
setModalProps(props);
});
async function handleSubmit() {
try {
const values = await validate();
setModalProps({ confirmLoading: true });
await set(values);
closeModal();
emit('success');
} finally {
setModalProps({ confirmLoading: false });
/** 处理弹出框提交 */
async function handleSubmit() {
try {
//
const formData = await validate();
//
setModalProps({ confirmLoading: true });
// tag
switch (state.tag) {
case 'add':
await addConfig(formData);
break;
case 'edit':
await editConfig(formData);
break;
}
//
closeModal();
emit('success');
} finally {
setModalProps({ confirmLoading: false });
}
}
return { registerModal, registerForm, handleSubmit };
},
});
</script>

27
kicc-ui/src/views/system/config/index.vue

@ -150,6 +150,8 @@ @@ -150,6 +150,8 @@
</div>
</template>
</ATable>
<!--弹出窗体区域-->
<ConfigModal @register="registerModal" @success="handleRefreshTable"/>
</div>
</template>
<script lang="ts" setup>
@ -360,35 +362,36 @@ @@ -360,35 +362,36 @@
getList();
}
/** 新增按钮操作,行内新增与工具栏局域新增通用 */
function handleAdd() {
/*openModal(true,{isUpdate: false });*/
openModal(true,{ _tag: 'add' });
}
/** 编辑按钮操作,行内编辑 */
function handleEdit(record?: Recordable) {
/*record = record || { id: toRaw(state.ids) };
openModal(true, { isUpdate: true, record });*/
record = record || { id: toRaw(getSelectRowKeys()) };
openModal(true, { _tag: 'edit', record });
}
/** 删除按钮操作,行内删除 */
async function handleDel(record?: Recordable) {
/*const ids = record?.id || toRaw(state.ids);
const ids = record?.id || toRaw(getSelectRowKeys());
createConfirm({
iconType: 'warning',
title: '警告',
content: `是否确认删除参数编号为${ids}参数吗?`,
onOk: async () => {
await remove({ids: ids});
await delConfig(ids);
createMessage.success('删除成功!');
handleSuccess();
handleRefreshTable();
}
});*/
});
}
/** 处理表格刷新 */
function handleRefreshTable() {
clearSelectedRowKeys();
getList();
}
</script>

Loading…
Cancel
Save