index.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. <template>
  2. <div class="p-2">
  3. <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave">
  4. <div v-show="showSearch" class="mb-[10px]">
  5. <el-card shadow="hover">
  6. <el-form ref="queryFormRef" :model="queryParams" :inline="true">
  7. <el-form-item label="数据源" prop="dataName">
  8. <el-select v-model="queryParams.dataName" filterable clearable placeholder="请选择/输入数据源名称">
  9. <el-option key="" label="全部" value="" />
  10. <el-option v-for="item in dataNameList" :key="item" :label="item" :value="item"> </el-option>
  11. </el-select>
  12. </el-form-item>
  13. <el-form-item label="表名称" prop="tableName">
  14. <el-input v-model="queryParams.tableName" placeholder="请输入表名称" clearable @keyup.enter="handleQuery" />
  15. </el-form-item>
  16. <el-form-item label="表描述" prop="tableComment">
  17. <el-input v-model="queryParams.tableComment" placeholder="请输入表描述" clearable @keyup.enter="handleQuery" />
  18. </el-form-item>
  19. <el-form-item label="创建时间" style="width: 308px">
  20. <el-date-picker
  21. v-model="dateRange"
  22. value-format="YYYY-MM-DD"
  23. type="daterange"
  24. range-separator="-"
  25. start-placeholder="开始日期"
  26. end-placeholder="结束日期"
  27. ></el-date-picker>
  28. </el-form-item>
  29. <el-form-item>
  30. <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
  31. <el-button icon="Refresh" @click="resetQuery">重置</el-button>
  32. </el-form-item>
  33. </el-form>
  34. </el-card>
  35. </div>
  36. </transition>
  37. <el-card shadow="hover">
  38. <template #header>
  39. <el-row :gutter="10" class="mb8">
  40. <el-col :span="1.5">
  41. <el-button v-hasPermi="['tool:gen:code']" type="primary" plain icon="Download" @click="handleGenTable()">生成</el-button>
  42. </el-col>
  43. <el-col :span="1.5">
  44. <el-button v-hasPermi="['tool:gen:import']" type="info" plain icon="Upload" @click="openImportTable">导入</el-button>
  45. </el-col>
  46. <el-col :span="1.5">
  47. <el-button v-hasPermi="['tool:gen:edit']" type="success" plain icon="Edit" :disabled="single" @click="handleEditTable()">修改</el-button>
  48. </el-col>
  49. <el-col :span="1.5">
  50. <el-button v-hasPermi="['tool:gen:remove']" type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()">
  51. 删除
  52. </el-button>
  53. </el-col>
  54. <right-toolbar v-model:show-search="showSearch" @query-table="getList"></right-toolbar>
  55. </el-row>
  56. </template>
  57. <el-table v-loading="loading" :data="tableList" @selection-change="handleSelectionChange">
  58. <el-table-column type="selection" align="center" width="55"></el-table-column>
  59. <el-table-column label="序号" type="index" width="50" align="center">
  60. <template #default="scope">
  61. <span>{{ (queryParams.pageNum - 1) * queryParams.pageSize + scope.$index + 1 }}</span>
  62. </template>
  63. </el-table-column>
  64. <el-table-column label="数据源" align="center" prop="dataName" :show-overflow-tooltip="true" />
  65. <el-table-column label="表名称" align="center" prop="tableName" :show-overflow-tooltip="true" />
  66. <el-table-column label="表描述" align="center" prop="tableComment" :show-overflow-tooltip="true" />
  67. <el-table-column label="实体" align="center" prop="className" :show-overflow-tooltip="true" />
  68. <el-table-column label="创建时间" align="center" prop="createTime" width="160" />
  69. <el-table-column label="更新时间" align="center" prop="updateTime" width="160" />
  70. <el-table-column label="操作" align="center" width="330" class-name="small-padding fixed-width">
  71. <template #default="scope">
  72. <el-tooltip content="预览" placement="top">
  73. <el-button v-hasPermi="['tool:gen:preview']" link type="primary" icon="View" @click="handlePreview(scope.row)"></el-button>
  74. </el-tooltip>
  75. <el-tooltip content="编辑" placement="top">
  76. <el-button v-hasPermi="['tool:gen:edit']" link type="primary" icon="Edit" @click="handleEditTable(scope.row)"></el-button>
  77. </el-tooltip>
  78. <el-tooltip content="删除" placement="top">
  79. <el-button v-hasPermi="['tool:gen:remove']" link type="primary" icon="Delete" @click="handleDelete(scope.row)"></el-button>
  80. </el-tooltip>
  81. <el-tooltip content="同步" placement="top">
  82. <el-button v-hasPermi="['tool:gen:edit']" link type="primary" icon="Refresh" @click="handleSynchDb(scope.row)"></el-button>
  83. </el-tooltip>
  84. <el-tooltip content="生成代码" placement="top">
  85. <el-button v-hasPermi="['tool:gen:code']" link type="primary" icon="Download" @click="handleGenTable(scope.row)"></el-button>
  86. </el-tooltip>
  87. </template>
  88. </el-table-column>
  89. </el-table>
  90. <pagination v-show="total > 0" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" :total="total" @pagination="getList" />
  91. </el-card>
  92. <!-- 预览界面 -->
  93. <el-dialog v-model="dialog.visible" :title="dialog.title" width="80%" top="5vh" append-to-body class="scrollbar">
  94. <el-tabs v-model="preview.activeName">
  95. <el-tab-pane
  96. v-for="(value, key) in preview.data"
  97. :key="value"
  98. :label="key.substring(key.lastIndexOf('/') + 1, key.indexOf('.vm'))"
  99. :name="key.substring(key.lastIndexOf('/') + 1, key.indexOf('.vm'))"
  100. >
  101. <el-link v-copyText="value" v-copyText:callback="copyTextSuccess" :underline="false" icon="DocumentCopy" style="float: right">
  102. &nbsp;复制
  103. </el-link>
  104. <pre>{{ value }}</pre>
  105. </el-tab-pane>
  106. </el-tabs>
  107. </el-dialog>
  108. <import-table ref="importRef" @ok="handleQuery" />
  109. </div>
  110. </template>
  111. <script setup name="Gen" lang="ts">
  112. import {delTable, genCode, getDataNames, listTable, previewTable, synchDb} from '@/api/tool/gen';
  113. import {TableQuery, TableVO} from '@/api/tool/gen/types';
  114. import router from '@/router';
  115. import ImportTable from './importTable.vue';
  116. const route = useRoute();
  117. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  118. const tableList = ref<TableVO[]>([]);
  119. const loading = ref(true);
  120. const showSearch = ref(true);
  121. const ids = ref<Array<string | number>>([]);
  122. const single = ref(true);
  123. const multiple = ref(true);
  124. const total = ref(0);
  125. const dateRange = ref<[DateModelType, DateModelType]>(['', '']);
  126. const uniqueId = ref('');
  127. const dataNameList = ref<Array<string>>([]);
  128. const queryFormRef = ref<ElFormInstance>();
  129. const importRef = ref<InstanceType<typeof ImportTable>>();
  130. const queryParams = ref<TableQuery>({
  131. pageNum: 1,
  132. pageSize: 10,
  133. tableName: '',
  134. tableComment: '',
  135. dataName: ''
  136. });
  137. const preview = ref<{
  138. data: Record<string, string>;
  139. activeName: string;
  140. }>({
  141. data: {},
  142. activeName: 'domain.java'
  143. });
  144. const dialog = reactive<DialogOption>({
  145. visible: false,
  146. title: '代码预览'
  147. });
  148. /** 查询多数据源名称 */
  149. const getDataNameList = async () => {
  150. const res = await getDataNames();
  151. dataNameList.value = res.data;
  152. };
  153. /** 查询表集合 */
  154. const getList = async () => {
  155. loading.value = true;
  156. const res = await listTable(proxy?.addDateRange(queryParams.value, dateRange.value));
  157. tableList.value = res.rows;
  158. total.value = res.total;
  159. loading.value = false;
  160. };
  161. /** 搜索按钮操作 */
  162. const handleQuery = () => {
  163. queryParams.value.pageNum = 1;
  164. getList();
  165. };
  166. /** 生成代码操作 */
  167. const handleGenTable = async (row?: TableVO) => {
  168. const tbIds = row?.tableId || ids.value;
  169. if (tbIds == '') {
  170. proxy?.$modal.msgError('请选择要生成的数据');
  171. return;
  172. }
  173. if (row?.genType === '1') {
  174. await genCode(row.tableId);
  175. proxy?.$modal.msgSuccess('成功生成到自定义路径:' + row.genPath);
  176. } else {
  177. proxy?.$download.zip('/tool/gen/batchGenCode?tableIdStr=' + tbIds, 'ruoyi.zip');
  178. }
  179. };
  180. /** 同步数据库操作 */
  181. const handleSynchDb = async (row: TableVO) => {
  182. const tableId = row.tableId;
  183. await proxy?.$modal.confirm('确认要强制同步"' + row.tableName + '"表结构吗?');
  184. await synchDb(tableId);
  185. proxy?.$modal.msgSuccess('同步成功');
  186. };
  187. /** 打开导入表弹窗 */
  188. const openImportTable = () => {
  189. importRef.value?.show(queryParams.value.dataName);
  190. };
  191. /** 重置按钮操作 */
  192. const resetQuery = () => {
  193. dateRange.value = ['', ''];
  194. queryFormRef.value?.resetFields();
  195. handleQuery();
  196. };
  197. /** 预览按钮 */
  198. const handlePreview = async (row: TableVO) => {
  199. const res = await previewTable(row.tableId);
  200. preview.value.data = res.data;
  201. dialog.visible = true;
  202. preview.value.activeName = 'domain.java';
  203. };
  204. /** 复制代码成功 */
  205. const copyTextSuccess = () => {
  206. proxy?.$modal.msgSuccess('复制成功');
  207. };
  208. // 多选框选中数据
  209. const handleSelectionChange = (selection: TableVO[]) => {
  210. ids.value = selection.map((item) => item.tableId);
  211. single.value = selection.length != 1;
  212. multiple.value = !selection.length;
  213. };
  214. /** 修改按钮操作 */
  215. const handleEditTable = (row?: TableVO) => {
  216. const tableId = row?.tableId || ids.value[0];
  217. router.push({ path: '/tool/gen-edit/index/' + tableId, query: { pageNum: queryParams.value.pageNum } });
  218. };
  219. /** 删除按钮操作 */
  220. const handleDelete = async (row?: TableVO) => {
  221. const tableIds = row?.tableId || ids.value;
  222. await proxy?.$modal.confirm('是否确认删除表编号为"' + tableIds + '"的数据项?');
  223. await delTable(tableIds);
  224. await getList();
  225. proxy?.$modal.msgSuccess('删除成功');
  226. };
  227. onMounted(() => {
  228. const time = route.query.t;
  229. if (time != null && time != uniqueId.value) {
  230. uniqueId.value = time as string;
  231. queryParams.value.pageNum = Number(route.query.pageNum);
  232. dateRange.value = ['', ''];
  233. queryFormRef.value?.resetFields();
  234. getList();
  235. }
  236. getDataNameList();
  237. });
  238. </script>