| <template> | 
|   <div ref="boxOutWrap" class="boxOutWrap"> | 
|     <div ref="boxForm" class="boxForm"> | 
|       <a-card :bordered="false" v-show="indexOpenShow" :bodyStyle="tstyle"> | 
|         <a-spin :spinning="Loading"> | 
|           <div class="table-page-search-wrapper" v-if="hasPerm('codeGenerate:page')"> | 
|             <a-form layout="inline"> | 
|               <a-row :gutter="48"> | 
|                 <a-col :md="8" :sm="24"> | 
|                   <a-form-item label="表名称"> | 
|                     <a-input v-model="queryParam.tableName" allow-clear placeholder="请输入表名称" /> | 
|                   </a-form-item> | 
|                 </a-col> | 
|                 <a-col :md="8" :sm="24"> | 
|                   <a-form-item label="业务名"> | 
|                     <a-input v-model="queryParam.busName" allow-clear placeholder="请输入业务名" /> | 
|                   </a-form-item> | 
|                 </a-col> | 
|                 <a-col :md="8" :sm="24"> | 
|                   <a-button type="primary" @click="$refs.table.refresh(true)">查询</a-button> | 
|                   <a-button style="margin-left: 8px" @click="() => (queryParam = {})">重置</a-button> | 
|                 </a-col> | 
|               </a-row> | 
|             </a-form> | 
|           </div> | 
|         </a-spin> | 
|       </a-card> | 
|     </div> | 
|     <a-card :bordered="false" v-show="indexOpenShow"> | 
|       <a-spin :spinning="Loading"> | 
|         <s-table | 
|           ref="table" | 
|           :scroll="{ x: true, y: tableHeight }" | 
|           :columns="columns" | 
|           :data="loadData" | 
|           :alert="true" | 
|           :rowKey="record => record.id" | 
|           :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }" | 
|         > | 
|           <div slot="operator" v-if="hasPerm('codeGenerate:add')"> | 
|             <div ref="actionBar" class="actionBar"> | 
|               <a-button type="primary" v-if="hasPerm('codeGenerate:add')" icon="plus" @click="$refs.addForm.add()" | 
|                 >新增</a-button | 
|               > | 
|             </div> | 
|           </div> | 
|           <span slot="isOnlyQueryscopedSlots" slot-scope="text"> | 
|             <div v-if="text === true"> | 
|               <a-tag color="green">是</a-tag> | 
|             </div> | 
|             <div v-else-if="text == false"> | 
|               <a-tag color="volcano">否</a-tag> | 
|             </div> | 
|             <div v-else=""></div> | 
|           </span> | 
|           <span slot="databaseName" slot-scope="text"> | 
|             <ellipsis :length="20" tooltip>{{ text }}</ellipsis> | 
|           </span> | 
|           <span slot="tableName" slot-scope="text"> | 
|             <ellipsis :length="20" tooltip>{{ text }}</ellipsis> | 
|           </span> | 
|           <span slot="busName" slot-scope="text"> | 
|             <ellipsis :length="20" tooltip>{{ text }}</ellipsis> | 
|           </span> | 
|           <span slot="nameSpace" slot-scope="text"> | 
|             <ellipsis :length="25" tooltip>{{ text }}</ellipsis> | 
|           </span> | 
|           <!--<span slot="className" slot-scope="text"> | 
|             <ellipsis :length="10" tooltip>{{ text }}</ellipsis> | 
|           </span> --> | 
|           <!--<span slot="tableComment" slot-scope="text"> | 
|             <ellipsis :length="10" tooltip>{{ text }}</ellipsis> | 
|           </span> --> | 
|           <!-- <span slot="tablePrefix" slot-scope="text"> | 
|             <ellipsis :length="10" tooltip>{{ 'yes_or_no' | dictType(text) }}</ellipsis> | 
|           </span> --> | 
|           <span slot="generateType" slot-scope="text"> | 
|             <ellipsis :length="20" tooltip>{{ 'code_gen_create_type' | dictType(text) }}</ellipsis> | 
|           </span> | 
|           <span slot="action" slot-scope="text, record"> | 
|             <span v-if="record.generateType === '1'"> | 
|               <a v-if="hasPerm('codeGenerate:runDown')" @click="runDownCodeGenerate(record)">开始生成</a> | 
|             </span> | 
|             <span v-else> | 
|               <a-popconfirm | 
|                 v-if="hasPerm('codeGenerate:runLocal')" | 
|                 placement="topRight" | 
|                 title="确定生成代码到zip包?" | 
|                 @confirm="() => runDownCodeGenerate(record)" | 
|               > | 
|                 <a> 生成到zip包</a> | 
|               </a-popconfirm> | 
|               <a-divider type="vertical" /> | 
|               <a-popconfirm | 
|                 v-if="hasPerm('codeGenerate:runLocal')" | 
|                 placement="topRight" | 
|                 title="确定生成代码到本项目?" | 
|                 @confirm="() => runLocalCodeGenerate(record)" | 
|               > | 
|                 <a> 生成到本项目</a> | 
|               </a-popconfirm> | 
|             </span> | 
|             <a-divider | 
|               type="vertical" | 
|               v-if=" | 
|                 hasPerm('codeGenerate:config') & hasPerm('codeGenerate:runLocal') || hasPerm('codeGenerate:runDown') | 
|               " | 
|             /> | 
|             <a style="color:green" v-if="hasPerm('codeGenerate:config')" @click="indexConfigOpen(record)">配置</a> | 
|             <a-divider type="vertical" v-if="hasPerm('codeGenerate:config') & hasPerm('codeGenerate:edit')" /> | 
|             <a-popconfirm | 
|               v-if="hasPerm('codeGenerate:resetconfig')" | 
|               placement="topRight" | 
|               title="重置会清除您已经配置的内容,确认要重置配置吗?" | 
|               @confirm="() => resetConfig(record)" | 
|             > | 
|               <a style="color:green">重置配置</a> | 
|             </a-popconfirm> | 
|   | 
|             <a-divider type="vertical" v-if="hasPerm('codeGenerate:config') & hasPerm('codeGenerate:edit')" /> | 
|             <a style="color:blue" v-if="hasPerm('codeGenerate:edit')" @click="$refs.editForm.edit(record)">编辑</a> | 
|             <a-divider type="vertical" v-if="hasPerm('codeGenerate:edit') & hasPerm('codeGenerate:delete')" /> | 
|             <a-popconfirm | 
|               v-if="hasPerm('codeGenerate:delete')" | 
|               placement="topRight" | 
|               title="确认删除?" | 
|               @confirm="() => codeGenerateDelete(record)" | 
|             > | 
|               <a style="color:blue">删除</a> | 
|             </a-popconfirm> | 
|           </span> | 
|         </s-table> | 
|         <add-form ref="addForm" @ok="handleOk" v-if="hasPerm('codeGenerate:add')" /> | 
|         <edit-form ref="editForm" @ok="handleOk" v-if="hasPerm('codeGenerate:edit')" /> | 
|       </a-spin> | 
|     </a-card> | 
|     <index-config ref="indexConfig" @ok="handleResetOpen" v-if="hasPerm('codeGenerate:config')" /> | 
|   </div> | 
| </template> | 
| <script> | 
| import { STable, Ellipsis } from '@/components' | 
| import setTableHtMixin from '@/mixins/handleTableHt.js' | 
| import { | 
|   codeGeneratePage, | 
|   codeGenerateDelete, | 
|   codeGenerateRunDown, | 
|   codeGenerateRunLocal, | 
|   codeGenerateRefresh | 
| } from '@/api/modular/gen/codeGenerateManage' | 
| import addForm from './addForm' | 
| import editForm from './editForm' | 
| import indexConfig from './indexConfig' | 
|   | 
| export default { | 
|   mixins: [setTableHtMixin], | 
|   components: { | 
|     indexConfig, | 
|     STable, | 
|     Ellipsis, | 
|     addForm, | 
|     editForm | 
|   }, | 
|   data() { | 
|     return { | 
|       // 查询参数 | 
|       queryParam: {}, | 
|       // 表头 | 
|       columns: [ | 
|         { | 
|           title: '序号', | 
|           width: '60px', | 
|           align: 'center', | 
|           customRender: (text, record, index) => `${index + 1}` | 
|         }, | 
|         { | 
|           title: '库名称', | 
|           dataIndex: 'databaseName', | 
|           scopedSlots: { customRender: 'databaseName' }, | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '160px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '160px' //最小列宽设置 | 
|               } | 
|             } | 
|           } | 
|         }, | 
|         { | 
|           title: '表名称', | 
|           dataIndex: 'tableName', | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           scopedSlots: { customRender: 'tableName' } | 
|         }, | 
|         { | 
|           title: '业务名', | 
|           dataIndex: 'busName', | 
|           scopedSlots: { customRender: 'busName' }, | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           } | 
|         }, | 
|         { | 
|           title: '命名空间', | 
|           dataIndex: 'nameSpace', | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           scopedSlots: { customRender: 'nameSpace' } | 
|         }, | 
|         { | 
|           title: '模块路径', | 
|           dataIndex: 'moduleName', | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '120px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           scopedSlots: { customRender: 'moduleName' } | 
|         }, | 
|         { | 
|           title: '前端项目名', | 
|           dataIndex: 'frontProName', | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 width: '120px', //最小列宽设置 | 
|                 display: 'inline-block' | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 width: '120px', //最小列宽设置 | 
|                 display: 'inline-block' | 
|               } | 
|             } | 
|           }, | 
|           scopedSlots: { customRender: 'frontProName' } | 
|         }, | 
|         // { | 
|         //   title: '类名', | 
|         //   dataIndex: 'className', | 
|         //   scopedSlots: { customRender: 'className' } | 
|         // }, | 
|         // { | 
|         //   title: '功能名', | 
|         //   dataIndex: 'tableComment', | 
|         //   scopedSlots: { customRender: 'tableComment' } | 
|         // }, | 
|         { | 
|           title: '作者姓名', | 
|           dataIndex: 'authorName', | 
|           customHeaderCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '100px' //最小列宽设置 | 
|               } | 
|             } | 
|           }, | 
|           customCell: () => { | 
|             return { | 
|               style: { | 
|                 'min-width': '100px' //最小列宽设置 | 
|               } | 
|             } | 
|           } | 
|         }, | 
|         // { | 
|         //   title: '表前缀移除', | 
|         //   dataIndex: 'tablePrefix', | 
|         //   scopedSlots: { customRender: 'tablePrefix' } | 
|         // }, | 
|         // { | 
|         //   title: '生成方式', | 
|         //   dataIndex: 'generateType', | 
|         //   scopedSlots: { customRender: 'generateType' }, | 
|         // }, | 
|         { | 
|           title: '是否只是查询', | 
|           align: 'center', | 
|           width: '120px', | 
|           sorter: true, | 
|           dataIndex: 'isOnlyQuery', | 
|           scopedSlots: { customRender: 'isOnlyQueryscopedSlots' } | 
|         } | 
|       ], | 
|       tstyle: { 'padding-bottom': '0px', 'margin-bottom': '10px' }, | 
|       loadData: parameter => { | 
|         return codeGeneratePage(Object.assign(parameter, this.queryParam)).then(res => { | 
|           return res.data | 
|         }) | 
|       }, | 
|       selectedRowKeys: [], | 
|       selectedRows: [], | 
|       Loading: false, | 
|       jdbcDriverList: [], | 
|       indexOpenShow: true | 
|     } | 
|   }, | 
|   created() { | 
|     if (this.hasPerm('codeGenerate:edit') || this.hasPerm('codeGenerate:delete')) { | 
|       this.columns.push({ | 
|         title: '操作', | 
|         width: '220px', | 
|         dataIndex: 'action', | 
|         scopedSlots: { customRender: 'action' } | 
|       }) | 
|     } | 
|     this.handleTableHt() //设置主表表格高度 | 
|     window.addEventListener( | 
|       'resize', | 
|       () => { | 
|         this.handleTableHt() // 监听屏幕大小改变表格高度 | 
|       }, | 
|       false | 
|     ) | 
|   }, | 
|   methods: { | 
|     /** | 
|      * 开始生成代码(生成压缩包) | 
|      */ | 
|     runDownCodeGenerate(record) { | 
|       this.Loading = true | 
|       codeGenerateRunDown({ id: record.id }) | 
|         .then(res => { | 
|           this.Loading = false | 
|   | 
|           this.downloadfile(res) | 
|         }) | 
|         .catch(err => { | 
|           debugger | 
|           this.Loading = false | 
|           this.$message.error('下载错误:获取文件流错误-' + err.message) | 
|         }) | 
|     }, | 
|     downloadfile(res) { | 
|       var blob = new Blob([res.data], { type: 'application/octet-stream;charset=UTF-8' }) | 
|       var contentDisposition = res.headers['content-disposition'] | 
|       var patt = new RegExp('filename=([^;]+\\.[^\\.;]+);*') | 
|       var result = patt.exec(contentDisposition) | 
|       var filename = result[1] | 
|       var downloadElement = document.createElement('a') | 
|       var href = window.URL.createObjectURL(blob) // 创建下载的链接 | 
|       var reg = /^["](.*)["]$/g | 
|       downloadElement.style.display = 'none' | 
|       downloadElement.href = href | 
|       downloadElement.download = decodeURI(filename.replace(reg, '$1')) // 下载后文件名 | 
|       document.body.appendChild(downloadElement) | 
|       downloadElement.click() // 点击下载 | 
|       document.body.removeChild(downloadElement) // 下载完成移除元素 | 
|       window.URL.revokeObjectURL(href) | 
|     }, | 
|     /** | 
|      * 开始生成代码(本地项目) | 
|      */ | 
|     runLocalCodeGenerate(record) { | 
|       codeGenerateRunLocal(record).then(res => { | 
|         if (res.success) { | 
|           this.$message.success('生成成功') | 
|           this.$refs.table.refresh() | 
|         } else { | 
|           this.$message.error('生成失败:' + res.message) | 
|         } | 
|       }) | 
|     }, | 
|     /** | 
|      * 删除 | 
|      */ | 
|     codeGenerateDelete(record) { | 
|       this.Loading = true | 
|       codeGenerateDelete([{ id: record.id }]) | 
|         .then(res => { | 
|           if (res.success) { | 
|             this.$message.success('删除成功') | 
|             this.$refs.table.refresh() | 
|           } else { | 
|             this.$message.error('删除失败:' + res.message) | 
|           } | 
|         }) | 
|         .catch(err => { | 
|           this.$message.error('删除错误:' + err.message) | 
|         }) | 
|         .finally(res => { | 
|           this.Loading = false | 
|         }) | 
|     }, | 
|     /** | 
|      * 重置配置 | 
|      */ | 
|     resetConfig(record) { | 
|       this.Loading = true | 
|       codeGenerateRefresh(record.id) | 
|         .then(res => { | 
|           if (res.success) { | 
|             this.$message.success('重置配置成功') | 
|             this.$refs.table.refresh() | 
|           } else { | 
|             this.$message.error('重置配置失败:' + res.message) | 
|           } | 
|         }) | 
|         .catch(err => { | 
|           this.$message.error('重置配置错误:' + err.message) | 
|         }) | 
|         .finally(res => { | 
|           this.Loading = false | 
|         }) | 
|     }, | 
|     /** | 
|      * 打开配置界面 | 
|      */ | 
|     indexConfigOpen(record) { | 
|       this.indexOpenShow = false | 
|       this.$refs.indexConfig.open(record) | 
|       //不再调用该方法,用于处理保存配置的bug 【Editby shaocx,2024-04-11】 | 
|       /* | 
|       codeGenerateRefresh(record.id).then((res) => { | 
|         this.$refs.indexConfig.open(record) | 
|       }) | 
|       //*/ | 
|     }, | 
|     /** | 
|      * 详细配置界面返回 | 
|      */ | 
|     handleResetOpen() { | 
|       this.indexOpenShow = true | 
|       this.$refs.table.refresh() | 
|     }, | 
|     /** | 
|      * 其他界面返回 | 
|      */ | 
|     handleOk() { | 
|       this.$refs.table.refresh() | 
|     }, | 
|     onSelectChange(selectedRowKeys, selectedRows) { | 
|       this.selectedRowKeys = selectedRowKeys | 
|       this.selectedRows = selectedRows | 
|     } | 
|   } | 
| } | 
| </script> | 
| <style lang="less"> | 
| .table-operator { | 
|   margin-bottom: 18px; | 
| } | 
| button { | 
|   margin-right: 8px; | 
| } | 
| </style> |