index.vue 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <template>
  2. <div class="sys-user-reg-way-container">
  3. <el-card shadow="hover" :body-style="{ padding: 5 }" v-auth="'sysUserRegWay:list'">
  4. <el-form :model="state.queryParams" ref="queryForm" :inline="true">
  5. <el-form-item label="租户" v-if="userStore.userInfos.accountType == 999">
  6. <TenantSelect v-model="state.queryParams.tenantId" clearable />
  7. </el-form-item>
  8. <el-form-item label="关键字">
  9. <el-input v-model="state.queryParams.keyword" placeholder="关键字" clearable />
  10. </el-form-item>
  11. <el-form-item label="名称">
  12. <el-input v-model="state.queryParams.name" placeholder="名称" clearable />
  13. </el-form-item>
  14. <el-form-item>
  15. <el-button-group>
  16. <el-button type="primary" icon="ele-Search" @click="handleQuery"> 查询
  17. </el-button>
  18. <el-button icon="ele-Refresh" @click="resetQuery"> 重置 </el-button>
  19. </el-button-group>
  20. </el-form-item>
  21. <el-form-item>
  22. <el-button type="primary" icon="ele-Plus" @click="openAddRegWay" v-auth="'sysUserRegWay:add'"> 新增
  23. </el-button>
  24. </el-form-item>
  25. </el-form>
  26. </el-card>
  27. <el-card class="full-table" shadow="hover" style="margin-top: 5px">
  28. <el-table :data="state.regWayData" style="width: 100%" v-loading="state.loading" border>
  29. <el-table-column type="index" label="序号" width="55" align="center" fixed />
  30. <el-table-column prop="name" label="名称" align="center" show-overflow-tooltip />
  31. <el-table-column prop="orgName" label="机构" align="center" show-overflow-tooltip />
  32. <el-table-column prop="roleName" label="角色" align="center" show-overflow-tooltip />
  33. <el-table-column prop="posName" label="职位" align="center" show-overflow-tooltip />
  34. <el-table-column prop="orderNo" label="排序" width="70" show-overflow-tooltip />
  35. <el-table-column label="修改记录" width="100" align="center" show-overflow-tooltip>
  36. <template #default="scope">
  37. <ModifyRecord :data="scope.row" />
  38. </template>
  39. </el-table-column>
  40. <el-table-column label="操作" width="200" fixed="right" align="center" show-overflow-tooltip v-if="auths(['sysUserRegWay:update', 'sysUserRegWay:delete'])">
  41. <template #default="scope">
  42. <el-button icon="ele-Edit" size="small" text type="primary" @click="openEditRegWay(scope.row)" v-auth="'sysUserRegWay:update'"> 编辑 </el-button>
  43. <el-button icon="ele-Delete" size="small" text type="danger" @click="delRegWay(scope.row)" v-auth="'sysUserRegWay:delete'"> 删除 </el-button>
  44. </template>
  45. </el-table-column>
  46. </el-table>
  47. </el-card>
  48. <EditRegWay ref="editRegWayRef" :title="state.editRegWayTitle" @handleQuery="handleQuery" />
  49. </div>
  50. </template>
  51. <script lang="ts" setup name="sysUserRegWay">
  52. import { onMounted, reactive, ref } from 'vue';
  53. import { ElMessageBox, ElMessage } from 'element-plus';
  54. import { getAPI } from '/@/utils/axios-utils';
  55. import { UserRegWayOutput } from '/@/api-services/models';
  56. import { SysUserRegWayApi} from '/@/api-services/api';
  57. import { auths } from "/@/utils/authFunction";
  58. import { useUserInfo } from "/@/stores/userInfo";
  59. import EditRegWay from './component/editRegWay.vue';
  60. import ModifyRecord from '/@/components/table/modifyRecord.vue';
  61. import TenantSelect from '/@/views/system/tenant/component/tenantSelect.vue';
  62. const userStore = useUserInfo();
  63. const editRegWayRef = ref<InstanceType<typeof EditRegWay>>();
  64. const state = reactive({
  65. loading: false,
  66. regWayData: [] as Array<UserRegWayOutput>,
  67. queryParams: {
  68. name: undefined,
  69. keyword: undefined,
  70. tenantId: undefined,
  71. },
  72. editRegWayTitle: '',
  73. });
  74. onMounted(async () => {
  75. if (userStore.userInfos.accountType == 999) {
  76. state.queryParams.tenantId = userStore.userInfos.currentTenantId as any;
  77. }
  78. handleQuery();
  79. });
  80. // 查询操作
  81. const handleQuery = async () => {
  82. state.loading = true;
  83. state.regWayData = await getAPI(SysUserRegWayApi).apiSysUserRegWayListPost(state.queryParams).then(res => res.data.result ?? []);
  84. state.loading = false;
  85. };
  86. // 重置操作
  87. const resetQuery = () => {
  88. state.queryParams.name = undefined;
  89. state.queryParams.keyword = undefined;
  90. state.queryParams.tenantId = undefined;
  91. handleQuery();
  92. };
  93. // 打开新增页面
  94. const openAddRegWay = () => {
  95. state.editRegWayTitle = '添加注册方案';
  96. editRegWayRef.value?.openDialog({ tenantId: state.queryParams.tenantId, orderNo: 100 });
  97. };
  98. // 打开编辑页面
  99. const openEditRegWay = (row: any) => {
  100. state.editRegWayTitle = '编辑注册方案';
  101. editRegWayRef.value?.openDialog(row);
  102. };
  103. // 删除
  104. const delRegWay = (row: any) => {
  105. ElMessageBox.confirm(`确定删除方案:【${row.name}】?`, '提示', {
  106. confirmButtonText: '确定',
  107. cancelButtonText: '取消',
  108. type: 'warning',
  109. }).then(async () => {
  110. await getAPI(SysUserRegWayApi).apiSysUserRegWayDeletePost({ id: row.id });
  111. handleQuery();
  112. ElMessage.success('删除成功');
  113. }).catch(() => { });
  114. };
  115. </script>