|
@@ -0,0 +1,188 @@
|
|
|
|
|
+<template>
|
|
|
|
|
+ <div>
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ <TitleCommon v-model="cardaddDrawer" :type="currentFormType" :pagesize="props.currentPageSize"
|
|
|
|
|
+ :pagenumber="props.currentPage" :drawer="cardaddDrawer" @find-data-by-name="SearchDataByName"
|
|
|
|
|
+ @submit-drawer="AddData" @add-form="ClickAddData" @handle-close="CloseDrawer" @clear-data="ClearData">
|
|
|
|
|
+ </TitleCommon>
|
|
|
|
|
+
|
|
|
|
|
+ <div class="table" style="margin-top: 20px;">
|
|
|
|
|
+ <el-table style="width: 100%" :data="tableData" highlight-current-row>
|
|
|
|
|
+ <el-table-column :label="currentFormType + `名称`" width="250" prop="name" />
|
|
|
|
|
+ <el-table-column :label="currentFormType + `代码`" width="200" prop="code" />
|
|
|
|
|
+
|
|
|
|
|
+ <el-table-column prop="status" label="状态" width="150">
|
|
|
|
|
+ <template #default="scope">
|
|
|
|
|
+ <el-tag v-if="scope.row.status === 0" type="success">正常</el-tag>
|
|
|
|
|
+ <el-tag v-else type="danger">异常</el-tag>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+
|
|
|
|
|
+ <el-table-column label="备注" width="200" prop="remark" />
|
|
|
|
|
+ <el-table-column label="创建时间" width="250" prop="createdAt" />
|
|
|
|
|
+ <el-table-column label="操作" width="200">
|
|
|
|
|
+ <template #default="scoped">
|
|
|
|
|
+ <el-button size="small" @click="deleteTableData(scoped.row)">删除</el-button>
|
|
|
|
|
+ <el-button size="small" @click="ShowEditDrawer(scoped.row)">编辑</el-button>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ </el-table>
|
|
|
|
|
+
|
|
|
|
|
+ <el-pagination v-model:currentPage="props.currentPage" v-model:currentPageSize="props.currentPageSize"
|
|
|
|
|
+ :page-sizes="[10, 20, 50, 100, 200]" layout="total,sizes,prev,pager,next,jumper" :total="total"
|
|
|
|
|
+ @size-change="handeSizeChange" @current-change="handleCurrentPageChange"
|
|
|
|
|
+ style="margin-left: 600px; margin-top: 20px" />
|
|
|
|
|
+ </div>
|
|
|
|
|
+
|
|
|
|
|
+ <el-drawer v-model="cardeditDrawer" direction="rtl" :title="currentType" :before-close="handleClose">
|
|
|
|
|
+ <DrawerCommonVue :detail="props.drawerFormData" v-if="currentdrawerFormData" @submit-drawer="submitDrawer" />
|
|
|
|
|
+ </el-drawer>
|
|
|
|
|
+
|
|
|
|
|
+ </div>
|
|
|
|
|
+</template>
|
|
|
|
|
+
|
|
|
|
|
+<script setup lang="ts">
|
|
|
|
|
+import { onMounted, ref, watch } from 'vue';
|
|
|
|
|
+import { ElDrawer, ElMessageBox, } from 'element-plus';
|
|
|
|
|
+import DrawerCommonVue, { FormModelCommon } from './DrawerCommon.vue';
|
|
|
|
|
+import TitleCommon from './TitleCommon.vue';
|
|
|
|
|
+import { Records } from '@/api/template/template';
|
|
|
|
|
+
|
|
|
|
|
+const currentFormType = ref('场景');
|
|
|
|
|
+
|
|
|
|
|
+export type CreateType = '添加模板' | '修改模板';
|
|
|
|
|
+export interface TableModel {
|
|
|
|
|
+ id: number;
|
|
|
|
|
+ name: string;
|
|
|
|
|
+ code: string;
|
|
|
|
|
+ status: number;
|
|
|
|
|
+ remark: string;
|
|
|
|
|
+ createAt: string;
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+export interface ModelCommon {
|
|
|
|
|
+ drawerFormData: FormModelCommon | null
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+const props = defineProps<{ adddrawer: boolean, editdrawer: boolean, total: number, currentPage: number, currentPageSize: number, tableData: Records[], drawerFormData: FormModelCommon }>();
|
|
|
|
|
+const currentType = ref<CreateType>('添加模板');
|
|
|
|
|
+const currentdrawerFormData = ref<FormModelCommon>({} as FormModelCommon);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+const emit = defineEmits(['ClearData', 'ClickAddData', 'CloseDrawer', 'ShowEditDrawer', 'AddData', 'SearchDataByName', 'deleteTableData', 'submitDrawer', 'handeSizeChange', 'handleCurrentPageChange', 'GetData'])
|
|
|
|
|
+const cardeditDrawer = ref(false);
|
|
|
|
|
+const cardaddDrawer = ref(false);
|
|
|
|
|
+
|
|
|
|
|
+watch(
|
|
|
|
|
+ () => props.editdrawer,
|
|
|
|
|
+ (newdrawer) => {
|
|
|
|
|
+ console.log('cardcommon-editdrawer0', cardeditDrawer.value);
|
|
|
|
|
+ cardeditDrawer.value = newdrawer;
|
|
|
|
|
+ console.log('cardcommon-editdrawer1', cardeditDrawer.value);
|
|
|
|
|
+ },
|
|
|
|
|
+ { immediate: true },
|
|
|
|
|
+);
|
|
|
|
|
+
|
|
|
|
|
+watch(
|
|
|
|
|
+ () => props.adddrawer,
|
|
|
|
|
+ (newdrawer) => {
|
|
|
|
|
+ console.log('cardcommon-adddrawer0', cardaddDrawer.value);
|
|
|
|
|
+ cardaddDrawer.value = newdrawer;
|
|
|
|
|
+ console.log('cardcommon-adddrawer1', cardaddDrawer.value);
|
|
|
|
|
+ },
|
|
|
|
|
+ { immediate: true },
|
|
|
|
|
+);
|
|
|
|
|
+
|
|
|
|
|
+watch(
|
|
|
|
|
+ () => props.drawerFormData,
|
|
|
|
|
+ (newdrawerFormData) => {
|
|
|
|
|
+ console.log('cardcommon-drawerFormData0', currentdrawerFormData.value);
|
|
|
|
|
+ currentdrawerFormData.value = newdrawerFormData;
|
|
|
|
|
+ console.log('cardcommon-drawerFormData1', currentdrawerFormData.value);
|
|
|
|
|
+ },
|
|
|
|
|
+ { immediate: true },
|
|
|
|
|
+);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+function handeSizeChange(val: number) {
|
|
|
|
|
+ emit('handeSizeChange', val)
|
|
|
|
|
+}
|
|
|
|
|
+function handleCurrentPageChange(val: number) {
|
|
|
|
|
+ emit('handleCurrentPageChange', val)
|
|
|
|
|
+
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+function deleteTableData(row: TableModel) {
|
|
|
|
|
+
|
|
|
|
|
+ emit('deleteTableData', row)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// 编辑数据弹框
|
|
|
|
|
+function ShowEditDrawer(row: TableModel) {
|
|
|
|
|
+ emit('ShowEditDrawer', row);
|
|
|
|
|
+
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// 弹框关闭事件
|
|
|
|
|
+const handleClose = (done: () => void) => {
|
|
|
|
|
+ ElMessageBox.confirm('是否确认关闭?')
|
|
|
|
|
+ .then(() => {
|
|
|
|
|
+ done();
|
|
|
|
|
+ CloseDrawer();
|
|
|
|
|
+
|
|
|
|
|
+ })
|
|
|
|
|
+ .catch(() => {
|
|
|
|
|
+ // catch error
|
|
|
|
|
+ });
|
|
|
|
|
+
|
|
|
|
|
+};
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+// 编辑提交数据
|
|
|
|
|
+function submitDrawer(data) {
|
|
|
|
|
+ emit('submitDrawer', data);
|
|
|
|
|
+
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+// 查询数据列表
|
|
|
|
|
+function GetData(currentPage: number, currentPageSize: number) {
|
|
|
|
|
+ emit('GetData', currentPage, currentPageSize)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// 根据名称找到数据
|
|
|
|
|
+function SearchDataByName(data) {
|
|
|
|
|
+ emit('SearchDataByName', data)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+function ClickAddData() {
|
|
|
|
|
+ emit('ClickAddData');
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// 添加数据
|
|
|
|
|
+function AddData(data) {
|
|
|
|
|
+ emit('AddData', data);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+function CloseDrawer() {
|
|
|
|
|
+ emit('CloseDrawer');
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+function ClearData() {
|
|
|
|
|
+ emit('ClearData');
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+onMounted(() => {
|
|
|
|
|
+ GetData(props.currentPage, props.currentPageSize);
|
|
|
|
|
+
|
|
|
|
|
+});
|
|
|
|
|
+</script>
|
|
|
|
|
+
|
|
|
|
|
+<style scoped></style>
|