1028 lines
28 KiB
Vue
1028 lines
28 KiB
Vue
<template>
|
||
<div>
|
||
<warning-bar
|
||
href="https://www.bilibili.com/video/BV1kv4y1g7nT?p=3"
|
||
title="此功能为开发环境使用,不建议发布到生产,具体使用效果请看视频https://www.bilibili.com/video/BV1kv4y1g7nT?p=3"
|
||
/>
|
||
<!-- 从数据库直接获取字段 -->
|
||
<div class="gva-search-box">
|
||
<el-collapse
|
||
v-model="activeNames"
|
||
class="mb-3"
|
||
>
|
||
<el-collapse-item name="1">
|
||
<template #title>
|
||
<div class="text-xl pl-4 flex items-center">
|
||
点这里从现有数据库创建代码
|
||
<el-icon>
|
||
<pointer />
|
||
</el-icon>
|
||
</div>
|
||
</template>
|
||
<el-form
|
||
ref="getTableForm"
|
||
style="margin-top:24px"
|
||
:inline="true"
|
||
:model="dbform"
|
||
label-width="120px"
|
||
>
|
||
<el-form-item
|
||
label="业务库"
|
||
prop="selectDBtype"
|
||
>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:需要提前到db-list自行配置多数据库,如未配置需配置后重启服务方可使用。(此处可选择对应库表,可理解为从哪个库选择表)"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 业务库 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-select
|
||
v-model="dbform.businessDB"
|
||
clearable
|
||
placeholder="选择业务库"
|
||
@change="getDbFunc"
|
||
>
|
||
<el-option
|
||
v-for="item in dbList"
|
||
:key="item.aliasName"
|
||
:value="item.aliasName"
|
||
:label="item.aliasName"
|
||
:disabled="item.disable"
|
||
>
|
||
<div>
|
||
<span>{{ item.aliasName }}</span>
|
||
<span style="float:right;color:#8492a6;font-size:13px">{{ item.dbName }}</span>
|
||
</div>
|
||
</el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="数据库名"
|
||
prop="structName"
|
||
>
|
||
<el-select
|
||
v-model="dbform.dbName"
|
||
clearable
|
||
style="width:194px"
|
||
filterable
|
||
placeholder="请选择数据库"
|
||
@change="getTableFunc"
|
||
>
|
||
<el-option
|
||
v-for="item in dbOptions"
|
||
:key="item.database"
|
||
:label="item.database"
|
||
:value="item.database"
|
||
/>
|
||
</el-select>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="表名"
|
||
prop="structName"
|
||
>
|
||
<el-select
|
||
v-model="dbform.tableName"
|
||
:disabled="!dbform.dbName"
|
||
style="width:194px"
|
||
filterable
|
||
placeholder="请选择表"
|
||
>
|
||
<el-option
|
||
v-for="item in tableOptions"
|
||
:key="item.tableName"
|
||
:label="item.tableName"
|
||
:value="item.tableName"
|
||
/>
|
||
</el-select>
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<el-button
|
||
type="primary"
|
||
@click="getColumnFunc"
|
||
>使用此表创建</el-button>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-collapse-item>
|
||
</el-collapse>
|
||
</div>
|
||
<div class="gva-search-box">
|
||
<!-- 初始版本自动化代码工具 -->
|
||
<el-form
|
||
ref="autoCodeForm"
|
||
:rules="rules"
|
||
:model="form"
|
||
label-width="120px"
|
||
:inline="true"
|
||
>
|
||
<el-form-item
|
||
label="Struct名称"
|
||
prop="structName"
|
||
>
|
||
<el-input
|
||
v-model="form.structName"
|
||
placeholder="首字母自动转换大写"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="TableName"
|
||
prop="tableName"
|
||
>
|
||
<el-input
|
||
v-model="form.tableName"
|
||
placeholder="指定表名(非必填)"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item
|
||
prop="abbreviation"
|
||
>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="简称会作为入参对象名和路由group"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> Struct简称 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-input
|
||
v-model="form.abbreviation"
|
||
placeholder="请输入Struct简称"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="Struct中文名称"
|
||
prop="description"
|
||
>
|
||
<el-input
|
||
v-model="form.description"
|
||
placeholder="中文描述作为自动api描述"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item
|
||
prop="packageName"
|
||
>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="生成文件的默认名称(建议为驼峰格式,首字母小写,如sysXxxXxxx)"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 文件名称 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-input
|
||
v-model="form.packageName"
|
||
placeholder="请输入文件名称"
|
||
@blur="toLowerCaseFunc(form,'packageName')"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="Package(包)"
|
||
prop="package"
|
||
>
|
||
<el-select
|
||
v-model="form.package"
|
||
>
|
||
<el-option
|
||
v-for="item in pkgs"
|
||
:key="item.ID"
|
||
:value="item.packageName"
|
||
:label="item.packageName"
|
||
/>
|
||
</el-select>
|
||
<el-icon
|
||
class="cursor-pointer ml-2 text-gray-600"
|
||
@click="getPkgs"
|
||
><refresh /></el-icon>
|
||
<el-icon
|
||
class="cursor-pointer ml-2 text-gray-600"
|
||
@click="goPkgs"
|
||
><document-add /></el-icon>
|
||
</el-form-item>
|
||
<el-form-item
|
||
label="业务库"
|
||
prop="businessDB"
|
||
>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:需要提前到db-list自行配置多数据库,此项为空则会使用gva本库创建自动化代码(global.GVA_DB),填写后则会创建指定库的代码(global.MustGetGlobalDBByDBName(dbname))"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 业务库 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-select
|
||
v-model="form.businessDB"
|
||
placeholder="选择业务库"
|
||
>
|
||
<el-option
|
||
v-for="item in dbList"
|
||
:key="item.aliasName"
|
||
:value="item.aliasName"
|
||
:label="item.aliasName"
|
||
:disabled="item.disable"
|
||
>
|
||
<div>
|
||
<span>{{ item.aliasName }}</span>
|
||
<span style="float:right;color:#8492a6;font-size:13px">{{ item.dbName }}</span>
|
||
</div>
|
||
</el-option>
|
||
</el-select>
|
||
</el-form-item>
|
||
<div>
|
||
<el-form-item>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:会自动在结构体global.Model其中包含主键和软删除相关操作配置"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 使用GVA结构 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-checkbox
|
||
v-model="form.gvaModel"
|
||
@change="useGva"
|
||
/>
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:会自动在结构体添加 created_by updated_by deleted_by,方便用户进行资源权限控制"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 创建资源标识 <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-checkbox v-model="form.autoCreateResource" />
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:把自动生成的API注册进数据库"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 自动创建API <el-icon><QuestionFilled /></el-icon> </div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-checkbox v-model="form.autoCreateApiToSql" />
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:把自动生成的菜单注册进数据库"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 自动创建菜单 <el-icon><QuestionFilled /></el-icon></div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-checkbox v-model="form.autoCreateMenuToSql" />
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<template #label>
|
||
<el-tooltip
|
||
content="注:自动迁移生成的文件到yaml配置的对应位置"
|
||
placement="bottom"
|
||
effect="light"
|
||
>
|
||
<div> 自动移动文件 <el-icon><QuestionFilled /></el-icon></div>
|
||
</el-tooltip>
|
||
</template>
|
||
<el-checkbox v-model="form.autoMoveFile" />
|
||
</el-form-item>
|
||
</div>
|
||
</el-form>
|
||
</div>
|
||
<!-- 组件列表 -->
|
||
<div class="gva-table-box">
|
||
<div class="gva-btn-list">
|
||
<el-button
|
||
type="primary"
|
||
@click="editAndAddField()"
|
||
>新增字段</el-button>
|
||
</div>
|
||
<el-table :data="form.fields">
|
||
<el-table-column
|
||
align="left"
|
||
type="index"
|
||
label="序列"
|
||
width="60"
|
||
/>
|
||
|
||
<el-table-column
|
||
align="left"
|
||
type="index"
|
||
label="主键"
|
||
width="60"
|
||
>
|
||
<template #default="{row}">
|
||
<el-checkbox v-model="row.primaryKey" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="fieldName"
|
||
label="字段名称"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.fieldName" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="fieldDesc"
|
||
label="中文名"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.fieldDesc" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="require"
|
||
label="必填"
|
||
>
|
||
<template #default="{row}"> <el-checkbox v-model="row.require" /></template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="sort"
|
||
label="排序"
|
||
>
|
||
<template #default="{row}"> <el-checkbox v-model="row.sort" /> </template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="fieldJson"
|
||
width="160px"
|
||
label="字段Json"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.fieldJson" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="fieldType"
|
||
label="字段类型"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-select
|
||
v-model="row.fieldType"
|
||
style="width:100%"
|
||
placeholder="请选择字段类型"
|
||
clearable
|
||
>
|
||
<el-option
|
||
v-for="item in typeOptions"
|
||
:key="item.value"
|
||
:label="item.label"
|
||
:value="item.value"
|
||
/>
|
||
</el-select>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="dataTypeLong"
|
||
label="数据库字段长度"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.dataTypeLong" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="columnName"
|
||
label="数据库字段"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.columnName" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="comment"
|
||
label="数据库字段描述"
|
||
width="160"
|
||
>
|
||
<template #default="{row}">
|
||
<el-input v-model="row.comment" />
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
prop="fieldSearchType"
|
||
label="搜索条件"
|
||
width="130"
|
||
>
|
||
<template #default="{row}">
|
||
<el-select
|
||
v-model="row.fieldSearchType"
|
||
style="width:100%"
|
||
placeholder="请选择字段查询条件"
|
||
clearable
|
||
:disabled="row.fieldType!=='json'"
|
||
>
|
||
<el-option
|
||
v-for="item in typeSearchOptions"
|
||
:key="item.value"
|
||
:label="item.label"
|
||
:value="item.value"
|
||
:disabled="
|
||
(row.fieldType!=='string'&&item.value==='LIKE')||
|
||
((row.fieldType!=='int'&&row.fieldType!=='time.Time'&&row.fieldType!=='float64')&&(item.value==='BETWEEN' || item.value==='NOT BETWEEN'))
|
||
"
|
||
/>
|
||
</el-select>
|
||
</template>
|
||
|
||
</el-table-column>
|
||
<el-table-column
|
||
align="left"
|
||
label="操作"
|
||
width="300"
|
||
fixed="right"
|
||
>
|
||
<template #default="scope">
|
||
<el-button
|
||
|
||
type="primary"
|
||
link
|
||
icon="edit"
|
||
@click="editAndAddField(scope.row)"
|
||
>高级编辑</el-button>
|
||
<el-button
|
||
|
||
type="primary"
|
||
link
|
||
:disabled="scope.$index === 0"
|
||
@click="moveUpField(scope.$index)"
|
||
>上移</el-button>
|
||
<el-button
|
||
|
||
type="primary"
|
||
link
|
||
:disabled="(scope.$index + 1) === form.fields.length"
|
||
@click="moveDownField(scope.$index)"
|
||
>下移</el-button>
|
||
<el-button
|
||
type="primary"
|
||
link
|
||
icon="delete"
|
||
@click="deleteField(scope.$index)"
|
||
>删除</el-button>
|
||
</template>
|
||
</el-table-column>
|
||
</el-table>
|
||
<!-- 组件列表 -->
|
||
<div class="gva-btn-list justify-end mt-4">
|
||
<el-button
|
||
type="primary"
|
||
@click="enterForm(true)"
|
||
>预览代码</el-button>
|
||
<el-button
|
||
type="primary"
|
||
@click="enterForm(false)"
|
||
>生成代码</el-button>
|
||
</div>
|
||
</div>
|
||
<!-- 组件弹窗 -->
|
||
<el-drawer
|
||
v-model="dialogFlag"
|
||
size="70%"
|
||
:show-close="false"
|
||
>
|
||
<template #title>
|
||
<div class="flex justify-between items-center">
|
||
<span class="text-lg">组件内容</span>
|
||
<div>
|
||
<el-button @click="closeDialog">取 消</el-button>
|
||
<el-button
|
||
type="primary"
|
||
@click="enterDialog"
|
||
>确 定</el-button>
|
||
</div>
|
||
</div>
|
||
</template>
|
||
|
||
<FieldDialog
|
||
v-if="dialogFlag"
|
||
ref="fieldDialogNode"
|
||
:dialog-middle="dialogMiddle"
|
||
:type-options="typeOptions"
|
||
:type-search-options="typeSearchOptions"
|
||
/>
|
||
|
||
</el-drawer>
|
||
|
||
<el-drawer
|
||
v-model="previewFlag"
|
||
size="60%"
|
||
:show-close="false"
|
||
>
|
||
|
||
<template #title>
|
||
<div class="flex justify-between items-center">
|
||
<span class="text-lg">操作栏</span>
|
||
<div>
|
||
<el-button
|
||
type="primary"
|
||
@click="selectText"
|
||
>全选</el-button>
|
||
<el-button
|
||
type="primary"
|
||
@click="copy"
|
||
>复制</el-button>
|
||
</div>
|
||
</div>
|
||
</template>
|
||
<PreviewCodeDialog
|
||
v-if="previewFlag"
|
||
ref="previewNode"
|
||
:preview-code="preViewCode"
|
||
/>
|
||
</el-drawer>
|
||
</div>
|
||
</template>
|
||
|
||
<script setup>
|
||
|
||
import FieldDialog from '@/view/systemTools/autoCode/component/fieldDialog.vue'
|
||
import PreviewCodeDialog from '@/view/systemTools/autoCode/component/previewCodeDialg.vue'
|
||
import { toUpperCase, toHump, toSQLLine, toLowerCase } from '@/utils/stringFun'
|
||
import { createTemp, getDB, getTable, getColumn, preview, getMeta, getPackageApi } from '@/api/autoCode'
|
||
import { getDict } from '@/utils/dictionary'
|
||
import { ref, reactive, watch, toRaw } from 'vue'
|
||
import { useRoute, useRouter } from 'vue-router'
|
||
import { ElMessage, ElMessageBox } from 'element-plus'
|
||
import WarningBar from '@/components/warningBar/warningBar.vue'
|
||
|
||
defineOptions({
|
||
name: 'AutoCode'
|
||
})
|
||
const gormModelList = ['id', 'created_at', 'updated_at', 'deleted_at']
|
||
|
||
const typeOptions = ref([
|
||
{
|
||
label: '字符串',
|
||
value: 'string'
|
||
},
|
||
{
|
||
label: '富文本',
|
||
value: 'richtext'
|
||
},
|
||
{
|
||
label: '整型',
|
||
value: 'int'
|
||
},
|
||
{
|
||
label: '布尔值',
|
||
value: 'bool'
|
||
},
|
||
{
|
||
label: '浮点型',
|
||
value: 'float64'
|
||
},
|
||
{
|
||
label: '时间',
|
||
value: 'time.Time'
|
||
},
|
||
{
|
||
label: '枚举',
|
||
value: 'enum'
|
||
},
|
||
{
|
||
label: '单图片(字符串)',
|
||
value: 'picture',
|
||
},
|
||
{
|
||
label: '多图片(json字符串)',
|
||
value: 'pictures',
|
||
},
|
||
{
|
||
label: '视频(字符串)',
|
||
value: 'video',
|
||
},
|
||
{
|
||
label: '文件(json字符串)',
|
||
value: 'file',
|
||
},
|
||
{
|
||
label: 'JSON',
|
||
value: 'json',
|
||
}
|
||
])
|
||
|
||
const typeSearchOptions = ref([
|
||
{
|
||
label: '=',
|
||
value: '='
|
||
},
|
||
{
|
||
label: '<>',
|
||
value: '<>'
|
||
},
|
||
{
|
||
label: '>',
|
||
value: '>'
|
||
},
|
||
{
|
||
label: '<',
|
||
value: '<'
|
||
},
|
||
{
|
||
label: 'LIKE',
|
||
value: 'LIKE'
|
||
},
|
||
{
|
||
label: 'BETWEEN',
|
||
value: 'BETWEEN'
|
||
},
|
||
{
|
||
label: 'NOT BETWEEN',
|
||
value: 'NOT BETWEEN'
|
||
}
|
||
])
|
||
|
||
const fieldTemplate = {
|
||
fieldName: '',
|
||
fieldDesc: '',
|
||
fieldType: '',
|
||
dataType: '',
|
||
fieldJson: '',
|
||
columnName: '',
|
||
dataTypeLong: '',
|
||
comment: '',
|
||
require: false,
|
||
sort: false,
|
||
errorText: '',
|
||
primaryKey: false,
|
||
clearable: true,
|
||
fieldSearchType: '',
|
||
dictType: ''
|
||
}
|
||
const route = useRoute()
|
||
const router = useRouter()
|
||
const activeNames = reactive([])
|
||
const preViewCode = ref({})
|
||
const dbform = ref({
|
||
businessDB: '',
|
||
dbName: '',
|
||
tableName: ''
|
||
})
|
||
const tableOptions = ref([])
|
||
const addFlag = ref('')
|
||
const fdMap = ref({})
|
||
const form = ref({
|
||
structName: '',
|
||
tableName: '',
|
||
packageName: '',
|
||
package: '',
|
||
abbreviation: '',
|
||
description: '',
|
||
businessDB: '',
|
||
autoCreateApiToSql: true,
|
||
autoCreateMenuToSql: true,
|
||
autoMoveFile: true,
|
||
gvaModel: true,
|
||
autoCreateResource: false,
|
||
fields: []
|
||
})
|
||
const rules = ref({
|
||
structName: [
|
||
{ required: true, message: '请输入结构体名称', trigger: 'blur' }
|
||
],
|
||
abbreviation: [
|
||
{ required: true, message: '请输入结构体简称', trigger: 'blur' }
|
||
],
|
||
description: [
|
||
{ required: true, message: '请输入结构体描述', trigger: 'blur' }
|
||
],
|
||
packageName: [
|
||
{
|
||
required: true,
|
||
message: '文件名称:sysXxxxXxxx',
|
||
trigger: 'blur'
|
||
}
|
||
],
|
||
package: [
|
||
{ required: true, message: '请选择package', trigger: 'blur' }
|
||
]
|
||
})
|
||
const dialogMiddle = ref({})
|
||
const bk = ref({})
|
||
const dialogFlag = ref(false)
|
||
const previewFlag = ref(false)
|
||
|
||
const useGva = (e) => {
|
||
if (e && form.value.fields.length) {
|
||
ElMessageBox.confirm(
|
||
'如果您开启GVA默认结构,会自动添加ID,CreatedAt,UpdatedAt,DeletedAt字段,此行为将自动清除您目前在下方创建的重名字段,是否继续?',
|
||
'注意',
|
||
{
|
||
confirmButtonText: '继续',
|
||
cancelButtonText: '取消',
|
||
type: 'warning',
|
||
}
|
||
)
|
||
.then(() => {
|
||
form.value.fields = form.value.fields.filter(item => !gormModelList.some(gormfd => gormfd === item.columnName))
|
||
})
|
||
.catch(() => {
|
||
form.value.gvaModel = false
|
||
})
|
||
}
|
||
}
|
||
|
||
const toLowerCaseFunc = (form, key) => {
|
||
form[key] = toLowerCase(form[key])
|
||
}
|
||
const previewNode = ref(null)
|
||
const selectText = () => {
|
||
previewNode.value.selectText()
|
||
}
|
||
const copy = () => {
|
||
previewNode.value.copy()
|
||
}
|
||
const editAndAddField = (item) => {
|
||
dialogFlag.value = true
|
||
if (item) {
|
||
addFlag.value = 'edit'
|
||
bk.value = JSON.parse(JSON.stringify(item))
|
||
dialogMiddle.value = item
|
||
} else {
|
||
addFlag.value = 'add'
|
||
dialogMiddle.value = JSON.parse(JSON.stringify(fieldTemplate))
|
||
}
|
||
}
|
||
const moveUpField = (index) => {
|
||
if (index === 0) {
|
||
return
|
||
}
|
||
const oldUpField = form.value.fields[index - 1]
|
||
form.value.fields.splice(index - 1, 1)
|
||
form.value.fields.splice(index, 0, oldUpField)
|
||
}
|
||
const moveDownField = (index) => {
|
||
const fCount = form.value.fields.length
|
||
if (index === fCount - 1) {
|
||
return
|
||
}
|
||
const oldDownField = form.value.fields[index + 1]
|
||
form.value.fields.splice(index + 1, 1)
|
||
form.value.fields.splice(index, 0, oldDownField)
|
||
}
|
||
|
||
const fieldDialogNode = ref(null)
|
||
const enterDialog = () => {
|
||
fieldDialogNode.value.fieldDialogFrom.validate(valid => {
|
||
if (valid) {
|
||
dialogMiddle.value.fieldName = toUpperCase(
|
||
dialogMiddle.value.fieldName
|
||
)
|
||
if (addFlag.value === 'add') {
|
||
form.value.fields.push(dialogMiddle.value)
|
||
}
|
||
dialogFlag.value = false
|
||
} else {
|
||
return false
|
||
}
|
||
})
|
||
}
|
||
const closeDialog = () => {
|
||
if (addFlag.value === 'edit') {
|
||
dialogMiddle.value = bk.value
|
||
}
|
||
dialogFlag.value = false
|
||
}
|
||
const deleteField = (index) => {
|
||
ElMessageBox.confirm('确定要删除吗?', '提示', {
|
||
confirmButtonText: '确定',
|
||
cancelButtonText: '取消',
|
||
type: 'warning'
|
||
}).then(async() => {
|
||
form.value.fields.splice(index, 1)
|
||
})
|
||
}
|
||
const autoCodeForm = ref(null)
|
||
const enterForm = async(isPreview) => {
|
||
if (form.value.fields.length <= 0) {
|
||
ElMessage({
|
||
type: 'error',
|
||
message: '请填写至少一个field'
|
||
})
|
||
return false
|
||
}
|
||
|
||
if (!form.value.gvaModel && form.value.fields.every(item => !item.primaryKey)) {
|
||
ElMessage({
|
||
type: 'error',
|
||
message: '您至少需要创建一个主键才能保证自动化代码的可行性'
|
||
})
|
||
return false
|
||
}
|
||
|
||
if (
|
||
form.value.fields.some(item => item.fieldName === form.value.structName)
|
||
) {
|
||
ElMessage({
|
||
type: 'error',
|
||
message: '存在与结构体同名的字段'
|
||
})
|
||
return false
|
||
}
|
||
|
||
if (form.value.package === form.value.abbreviation) {
|
||
ElMessage({
|
||
type: 'error',
|
||
message: 'package和结构体简称不可同名'
|
||
})
|
||
return false
|
||
}
|
||
|
||
autoCodeForm.value.validate(async valid => {
|
||
if (valid) {
|
||
for (const key in form.value) {
|
||
if (typeof form.value[key] === 'string') {
|
||
form.value[key] = form.value[key].trim()
|
||
}
|
||
}
|
||
form.value.structName = toUpperCase(form.value.structName)
|
||
form.value.tableName = form.value.tableName.replace(' ', '')
|
||
if (!form.value.tableName) {
|
||
form.value.tableName = toSQLLine(toLowerCase(form.value.structName))
|
||
}
|
||
if (form.value.structName === form.value.abbreviation) {
|
||
ElMessage({
|
||
type: 'error',
|
||
message: 'structName和struct简称不能相同'
|
||
})
|
||
return false
|
||
}
|
||
form.value.humpPackageName = toSQLLine(form.value.packageName)
|
||
if (isPreview) {
|
||
const data = await preview(form.value)
|
||
preViewCode.value = data.data.autoCode
|
||
previewFlag.value = true
|
||
} else {
|
||
const data = await createTemp(form.value)
|
||
if (data.headers?.success === 'false') {
|
||
return
|
||
}
|
||
if (form.value.autoMoveFile) {
|
||
ElMessage({
|
||
type: 'success',
|
||
message: '自动化代码创建成功,自动移动成功'
|
||
})
|
||
return
|
||
}
|
||
ElMessage({
|
||
type: 'success',
|
||
message: '自动化代码创建成功,正在下载'
|
||
})
|
||
const blob = new Blob([data])
|
||
const fileName = 'ginvueadmin.zip'
|
||
if ('download' in document.createElement('a')) {
|
||
// 不是IE浏览器
|
||
const url = window.URL.createObjectURL(blob)
|
||
const link = document.createElement('a')
|
||
link.style.display = 'none'
|
||
link.href = url
|
||
link.setAttribute('download', fileName)
|
||
document.body.appendChild(link)
|
||
link.click()
|
||
document.body.removeChild(link) // 下载完成移除元素
|
||
window.URL.revokeObjectURL(url) // 释放掉blob对象
|
||
} else {
|
||
// IE 10+
|
||
window.navigator.msSaveBlob(blob, fileName)
|
||
}
|
||
}
|
||
} else {
|
||
return false
|
||
}
|
||
})
|
||
}
|
||
|
||
const dbList = ref([])
|
||
const dbOptions = ref([])
|
||
|
||
const getDbFunc = async() => {
|
||
dbform.value.dbName = ''
|
||
dbform.value.tableName = ''
|
||
const res = await getDB({ businessDB: dbform.value.businessDB })
|
||
if (res.code === 0) {
|
||
dbOptions.value = res.data.dbs
|
||
dbList.value = res.data.dbList
|
||
}
|
||
}
|
||
const getTableFunc = async() => {
|
||
const res = await getTable({ businessDB: dbform.value.businessDB, dbName: dbform.value.dbName })
|
||
if (res.code === 0) {
|
||
tableOptions.value = res.data.tables
|
||
}
|
||
dbform.value.tableName = ''
|
||
}
|
||
|
||
const getColumnFunc = async() => {
|
||
const res = await getColumn(dbform.value)
|
||
if (res.code === 0) {
|
||
let dbtype = ''
|
||
if (dbform.value.businessDB !== '') {
|
||
const dbtmp = dbList.value.find(item => item.aliasName === dbform.value.businessDB)
|
||
const dbraw = toRaw(dbtmp)
|
||
dbtype = dbraw.dbtype
|
||
}
|
||
const tbHump = toHump(dbform.value.tableName)
|
||
form.value.structName = toUpperCase(tbHump)
|
||
form.value.tableName = dbform.value.tableName
|
||
form.value.packageName = tbHump
|
||
form.value.abbreviation = tbHump
|
||
form.value.description = tbHump + '表'
|
||
form.value.autoCreateApiToSql = true
|
||
form.value.autoMoveFile = true
|
||
form.value.fields = []
|
||
res.data.columns &&
|
||
res.data.columns.forEach(item => {
|
||
if (!form.value.gvaModel || (!gormModelList.some(gormfd => gormfd === item.columnName))) {
|
||
const fbHump = toHump(item.columnName)
|
||
form.value.fields.push({
|
||
fieldName: toUpperCase(fbHump),
|
||
fieldDesc: item.columnComment || fbHump + '字段',
|
||
fieldType: fdMap.value[item.dataType],
|
||
dataType: item.dataType,
|
||
fieldJson: fbHump,
|
||
primaryKey: item.primaryKey,
|
||
dataTypeLong: item.dataTypeLong && item.dataTypeLong.split(',')[0],
|
||
columnName: dbtype === 'oracle' ? item.columnName.toUpperCase() : item.columnName,
|
||
comment: item.columnComment,
|
||
require: false,
|
||
errorText: '',
|
||
clearable: true,
|
||
fieldSearchType: '',
|
||
dictType: ''
|
||
})
|
||
}
|
||
})
|
||
}
|
||
}
|
||
const setFdMap = async() => {
|
||
const fdTypes = ['string', 'int', 'bool', 'float64', 'time.Time']
|
||
fdTypes.forEach(async fdtype => {
|
||
const res = await getDict(fdtype)
|
||
res && res.forEach(item => {
|
||
fdMap.value[item.label] = fdtype
|
||
})
|
||
})
|
||
}
|
||
const getAutoCodeJson = async(id) => {
|
||
const res = await getMeta({ id: Number(id) })
|
||
if (res.code === 0) {
|
||
form.value = JSON.parse(res.data.meta)
|
||
}
|
||
}
|
||
|
||
const pkgs = ref([])
|
||
const getPkgs = async() => {
|
||
const res = await getPackageApi()
|
||
if (res.code === 0) {
|
||
pkgs.value = res.data.pkgs
|
||
}
|
||
}
|
||
|
||
const goPkgs = () => {
|
||
router.push({ name: 'autoPkg' })
|
||
}
|
||
|
||
const init = () => {
|
||
getDbFunc()
|
||
setFdMap()
|
||
getPkgs()
|
||
const id = route.params.id
|
||
if (id) {
|
||
getAutoCodeJson(id)
|
||
}
|
||
}
|
||
init()
|
||
|
||
watch(() => route.params.id, () => {
|
||
if (route.name === 'autoCodeEdit') {
|
||
init()
|
||
}
|
||
})
|
||
|
||
</script>
|