dictDataDialog.vue 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <template>
  2. <div class="sys-dictData-container">
  3. <el-dialog v-model="state.isShowDialog" draggable :close-on-click-modal="false" width="980px">
  4. <template #header>
  5. <div style="color: #fff">
  6. <el-icon size="16" style="margin-right: 3px; display: inline; vertical-align: middle"> <ele-Edit /> </el-icon>
  7. <span> 字典值列表 </span>
  8. </div>
  9. </template>
  10. <el-card shadow="hover" :body-style="{ paddingBottom: '0' }">
  11. <el-form :model="state.queryParams" ref="queryForm" :inline="true">
  12. <el-form-item label="字典值">
  13. <el-input v-model="state.queryParams.value" placeholder="字典值" />
  14. </el-form-item>
  15. <el-form-item label="编码">
  16. <el-input v-model="state.queryParams.code" placeholder="编码" />
  17. </el-form-item>
  18. <el-form-item>
  19. <el-button-group>
  20. <el-button type="primary" icon="ele-Search" @click="handleQuery"> 查询 </el-button>
  21. <el-button icon="ele-Refresh" @click="resetQuery"> 重置 </el-button>
  22. </el-button-group>
  23. </el-form-item>
  24. <el-form-item>
  25. <el-button type="primary" icon="ele-Plus" @click="openAddDictData"> 新增 </el-button>
  26. </el-form-item>
  27. </el-form>
  28. </el-card>
  29. <el-card class="full-table" shadow="hover" style="margin-top: 8px">
  30. <el-table :data="state.dictDataData" style="width: 100%" v-loading="state.loading" border>
  31. <el-table-column type="index" label="序号" width="55" align="center" />
  32. <el-table-column prop="value" label="字典值" header-align="center" min-width="100" show-overflow-tooltip>
  33. <template #default="scope">
  34. <el-tag :type="scope.row.tagType" :style="scope.row.styleSetting" :class="scope.row.classSetting">{{ scope.row.value }}</el-tag>
  35. </template>
  36. </el-table-column>
  37. <el-table-column prop="code" label="编码" header-align="center" min-width="100" show-overflow-tooltip />
  38. <el-table-column prop="status" label="状态" width="70" align="center" show-overflow-tooltip>
  39. <template #default="scope">
  40. <el-tag type="success" v-if="scope.row.status === 1">启用</el-tag>
  41. <el-tag type="danger" v-else>禁用</el-tag>
  42. </template>
  43. </el-table-column>
  44. <el-table-column prop="orderNo" label="排序" width="70" align="center" show-overflow-tooltip />
  45. <el-table-column prop="extData" label="拓展数据" width="90" align="center">
  46. <template #default="scope">
  47. <el-tag type="warning" v-if="scope.row.extData == null || scope.row.extData == ''">空</el-tag>
  48. <el-tag type="success" v-else>有值</el-tag>
  49. </template>
  50. </el-table-column>
  51. <el-table-column label="修改记录" width="100" align="center" show-overflow-tooltip>
  52. <template #default="scope">
  53. <el-popover placement="bottom" width="280" trigger="hover">
  54. <template #reference>
  55. <el-text type="primary">
  56. <el-icon><ele-InfoFilled /></el-icon>详情
  57. </el-text>
  58. </template>
  59. <el-descriptions direction="vertical" :column="2" border>
  60. <el-descriptions-item width="140">
  61. <template #label>
  62. <el-text>
  63. <el-icon><ele-UserFilled /></el-icon>创建者
  64. </el-text>
  65. </template>
  66. <el-tag>{{ scope.row.createUserName ?? '无' }}</el-tag>
  67. </el-descriptions-item>
  68. <el-descriptions-item>
  69. <template #label>
  70. <el-text>
  71. <el-icon><ele-Calendar /></el-icon>创建时间
  72. </el-text>
  73. </template>
  74. <el-tag>{{ scope.row.createTime ?? '无' }}</el-tag>
  75. </el-descriptions-item>
  76. <el-descriptions-item>
  77. <template #label>
  78. <el-text>
  79. <el-icon><ele-UserFilled /></el-icon>修改者
  80. </el-text>
  81. </template>
  82. <el-tag>{{ scope.row.updateUserName ?? '无' }}</el-tag>
  83. </el-descriptions-item>
  84. <el-descriptions-item>
  85. <template #label>
  86. <el-text>
  87. <el-icon><Calendar /></el-icon>修改时间
  88. </el-text>
  89. </template>
  90. <el-tag>{{ scope.row.updateTime ?? '无' }}</el-tag>
  91. </el-descriptions-item>
  92. <el-descriptions-item>
  93. <template #label>
  94. <el-text>
  95. <el-icon><ele-Tickets /></el-icon>备注
  96. </el-text>
  97. </template>
  98. {{ scope.row.remark }}
  99. </el-descriptions-item>
  100. </el-descriptions>
  101. </el-popover>
  102. </template>
  103. </el-table-column>
  104. <el-table-column label="操作" width="140" fixed="right" align="center" show-overflow-tooltip>
  105. <template #default="scope">
  106. <el-button icon="ele-Edit" size="small" text type="primary" @click="openEditDictData(scope.row)"> 编辑 </el-button>
  107. <el-button icon="ele-Delete" size="small" text type="danger" @click="delDictData(scope.row)"> 删除 </el-button>
  108. </template>
  109. </el-table-column>
  110. </el-table>
  111. <el-pagination
  112. v-model:currentPage="state.tableParams.page"
  113. v-model:page-size="state.tableParams.pageSize"
  114. :total="state.tableParams.total"
  115. :page-sizes="[10, 20, 50, 100]"
  116. small
  117. background
  118. @size-change="handleSizeChange"
  119. @current-change="handleCurrentChange"
  120. layout="total, sizes, prev, pager, next, jumper"
  121. />
  122. </el-card>
  123. </el-dialog>
  124. <EditDictData ref="editDictDataRef" :title="state.editDictDataTitle" :dictTypeId="state.queryParams.dictTypeId" @handleQuery="handleQuery" />
  125. </div>
  126. </template>
  127. <script lang="ts" setup name="sysDictData">
  128. import { onMounted, reactive, ref } from 'vue';
  129. import { ElMessageBox, ElMessage } from 'element-plus';
  130. import EditDictData from '/@/views/system/dict/component/editDictData.vue';
  131. import { getAPI } from '/@/utils/axios-utils';
  132. import { SysDictDataApi } from '/@/api-services/api';
  133. import { SysDictData } from '/@/api-services/models';
  134. const editDictDataRef = ref();
  135. const state = reactive({
  136. isShowDialog: false,
  137. loading: false,
  138. dictDataData: [] as Array<SysDictData>,
  139. queryParams: {
  140. value: undefined,
  141. code: undefined,
  142. dictTypeId: 0, // 字典类型Id
  143. },
  144. tableParams: {
  145. page: 1,
  146. pageSize: 20,
  147. total: 0 as any,
  148. },
  149. editDictDataTitle: '',
  150. });
  151. onMounted(async () => {
  152. handleQuery();
  153. });
  154. // 打开弹窗
  155. const openDialog = async (row: any) => {
  156. state.queryParams.dictTypeId = row.id;
  157. handleQuery();
  158. state.isShowDialog = true;
  159. };
  160. // 查询操作
  161. const handleQuery = async () => {
  162. state.loading = true;
  163. let params = Object.assign(state.queryParams, state.tableParams);
  164. var res = await getAPI(SysDictDataApi).apiSysDictDataPagePost(params);
  165. state.dictDataData = res.data.result?.items ?? [];
  166. state.tableParams.total = res.data.result?.total;
  167. state.loading = false;
  168. };
  169. // 重置操作
  170. const resetQuery = () => {
  171. state.queryParams.value = undefined;
  172. state.queryParams.code = undefined;
  173. handleQuery();
  174. };
  175. // 打开新增页面
  176. const openAddDictData = () => {
  177. state.editDictDataTitle = '添加字典值';
  178. editDictDataRef.value.openDialog({ status: 1, orderNo: 100, dictTypeId: state.queryParams.dictTypeId });
  179. };
  180. // 打开编辑页面
  181. const openEditDictData = (row: any) => {
  182. state.editDictDataTitle = '编辑字典值';
  183. editDictDataRef.value.openDialog(row);
  184. };
  185. // 删除
  186. const delDictData = (row: any) => {
  187. ElMessageBox.confirm(`确定删除字典值:【${row.value}】?`, '提示', {
  188. confirmButtonText: '确定',
  189. cancelButtonText: '取消',
  190. type: 'warning',
  191. })
  192. .then(async () => {
  193. await getAPI(SysDictDataApi).apiSysDictDataDeletePost({ id: row.id });
  194. handleQuery();
  195. ElMessage.success('删除成功');
  196. })
  197. .catch(() => {});
  198. };
  199. // 改变页面容量
  200. const handleSizeChange = (val: number) => {
  201. state.tableParams.pageSize = val;
  202. handleQuery();
  203. };
  204. // 改变页码序号
  205. const handleCurrentChange = (val: number) => {
  206. state.tableParams.page = val;
  207. handleQuery();
  208. };
  209. // 导出对象
  210. defineExpose({ openDialog });
  211. </script>