221 lines
7.0 KiB
Vue
221 lines
7.0 KiB
Vue
<template>
|
||
<el-container>
|
||
<el-main>
|
||
<el-card shadow="never">
|
||
<el-tabs tab-position="top" >
|
||
<el-tab-pane label="列配置">
|
||
<sc-form-table v-model="column" :addTemplate="addTemplate" placeholder="请添加列数据">
|
||
<el-table-column prop="label" label="显示名称" width="180">
|
||
<template #default="scope">
|
||
<el-input v-model="scope.row.label" placeholder="请输入内容"></el-input>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column prop="prop" label="字段名" width="180">
|
||
<template #default="scope">
|
||
<el-input v-model="scope.row.prop" placeholder="请输入内容"></el-input>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column prop="width" label="宽度" width="180">
|
||
<template #default="scope">
|
||
<el-input v-model="scope.row.width" placeholder="请输入内容"></el-input>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column prop="isEdit" label="加入编辑" width="80" align="center">
|
||
<template #default="scope">
|
||
<el-checkbox v-model="scope.row.isEdit"></el-checkbox>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column prop="isSearch" label="加入搜索" width="80" align="center">
|
||
<template #default="scope">
|
||
<el-checkbox v-model="scope.row.isSearch"></el-checkbox>
|
||
</template>
|
||
</el-table-column>
|
||
</sc-form-table>
|
||
</el-tab-pane>
|
||
<el-tab-pane label="基础配置">
|
||
<el-row>
|
||
<el-col :xl="12" :lg="8">
|
||
<el-form :model="base" label-width="80px">
|
||
<el-form-item label="name">
|
||
<el-input v-model="base.name"></el-input>
|
||
<div class="el-form-item-msg">系统唯一且与路由别名一致,否则导致缓存失效。</div>
|
||
</el-form-item>
|
||
<el-form-item label="rowKey">
|
||
<el-input v-model="base.rowKey"></el-input>
|
||
<div class="el-form-item-msg">表格唯一标识,编辑保存和删除将传递rowKey</div>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-col>
|
||
</el-row>
|
||
</el-tab-pane>
|
||
<el-tab-pane label="API路径配置">
|
||
<el-alert title="$API 映射文件: @/api/index.js 统一接口管理器, 所以需提前配置好API对象." type="warning" style="margin:0 0 20px 0;"></el-alert>
|
||
<el-row>
|
||
<el-col :xl="12" :lg="8">
|
||
<el-form :model="api" label-width="80px">
|
||
<el-form-item label="获取列表">
|
||
<el-input v-model="api.list">
|
||
<template #prepend>$API.</template>
|
||
</el-input>
|
||
</el-form-item>
|
||
<el-form-item label="新增">
|
||
<el-input v-model="api.add">
|
||
<template #prepend>$API.</template>
|
||
</el-input>
|
||
</el-form-item>
|
||
<el-form-item label="保存">
|
||
<el-input v-model="api.save">
|
||
<template #prepend>$API.</template>
|
||
</el-input>
|
||
</el-form-item>
|
||
<el-form-item label="查询详细">
|
||
<el-input v-model="api.show">
|
||
<template #prepend>$API.</template>
|
||
</el-input>
|
||
</el-form-item>
|
||
<el-form-item label="删除">
|
||
<el-input v-model="api.del">
|
||
<template #prepend>$API.</template>
|
||
</el-input>
|
||
</el-form-item>
|
||
</el-form>
|
||
</el-col>
|
||
</el-row>
|
||
</el-tab-pane>
|
||
</el-tabs>
|
||
</el-card>
|
||
<pre style="margin-top: 50px;display: none;">{{ code }}</pre>
|
||
</el-main>
|
||
<el-footer>
|
||
<el-dropdown style="margin-right: 15px;">
|
||
<el-button type="primary" icon="el-icon-download" :loading="downloadcodeLoading">下载VUE文件</el-button>
|
||
<template #dropdown>
|
||
<el-dropdown-menu>
|
||
<el-dropdown-item @click="downloadListCode">下载 index.vue</el-dropdown-item>
|
||
<el-dropdown-item @click="downloadSaveCode">下载 save.vue</el-dropdown-item>
|
||
</el-dropdown-menu>
|
||
</template>
|
||
</el-dropdown>
|
||
<el-dropdown>
|
||
<el-button type="primary" plain icon="el-icon-top-right" :loading="showcodeLoading">预览代码</el-button>
|
||
<template #dropdown>
|
||
<el-dropdown-menu>
|
||
<el-dropdown-item @click="showListCode">预览 index.vue</el-dropdown-item>
|
||
<el-dropdown-item @click="showSaveCode">预览 save.vue</el-dropdown-item>
|
||
</el-dropdown-menu>
|
||
</template>
|
||
</el-dropdown>
|
||
</el-footer>
|
||
</el-container>
|
||
|
||
|
||
<el-dialog title="代码预览" v-model="codeVisible" width="60%" append-to-body destroy-on-close>
|
||
<el-alert title="需将VUE文件放置views文件夹,路由匹配组件的路径下,如文件名为index.vue可不需要写文件名" type="success" show-icon style="margin-bottom: 20px;"></el-alert>
|
||
<pre contenteditable class="code">{{ code }}</pre>
|
||
<template #footer>
|
||
<el-button type="primary" @click="codeVisible = false">确 定</el-button>
|
||
</template>
|
||
</el-dialog>
|
||
|
||
</template>
|
||
|
||
<script>
|
||
import template from '@/utils/template.js'
|
||
|
||
export default {
|
||
name: 'autocode-list',
|
||
data() {
|
||
return {
|
||
codeVisible: false,
|
||
showcodeLoading: false,
|
||
downloadcodeLoading: false,
|
||
code: '',
|
||
base: {
|
||
name: "",
|
||
rowKey: "id"
|
||
},
|
||
api: {
|
||
list: '',
|
||
add: '',
|
||
save: '',
|
||
show: '',
|
||
del: ''
|
||
},
|
||
column: [],
|
||
addTemplate: {
|
||
label: "",
|
||
prop: "",
|
||
width: "100",
|
||
isSearch: false,
|
||
isEdit: false
|
||
}
|
||
}
|
||
},
|
||
mounted(){
|
||
|
||
},
|
||
methods: {
|
||
//列表预览
|
||
async showListCode(){
|
||
this.showcodeLoading = true;
|
||
await this.getListTpl()
|
||
this.showcodeLoading = false;
|
||
this.codeVisible=true;
|
||
},
|
||
//获取列表模板文件
|
||
async getListTpl(){
|
||
var data = {
|
||
createDate:new Date().toLocaleString(),
|
||
base: this.base,
|
||
column: this.column,
|
||
api: this.api
|
||
}
|
||
var tpl = await this.$HTTP.get('code/list/index.vue')
|
||
this.code = template(tpl, data)
|
||
},
|
||
//详细预览
|
||
async showSaveCode(){
|
||
this.showcodeLoading = true;
|
||
await this.getSaveTpl()
|
||
this.showcodeLoading = false;
|
||
this.codeVisible=true;
|
||
},
|
||
//获取详细模板文件
|
||
async getSaveTpl(){
|
||
var data = {
|
||
createDate:new Date().toLocaleString(),
|
||
base: this.base,
|
||
column: this.column.filter(item => item.isEdit===true),
|
||
api: this.api
|
||
}
|
||
var tpl = await this.$HTTP.get('code/list/save.vue')
|
||
this.code = template(tpl, data)
|
||
},
|
||
async downloadListCode(){
|
||
this.downloadcodeLoading = true;
|
||
await this.getListTpl()
|
||
this.downloadcodeLoading = false;
|
||
this.createFile(this.code, 'index.vue')
|
||
},
|
||
async downloadSaveCode(){
|
||
this.downloadcodeLoading = true;
|
||
await this.getSaveTpl()
|
||
this.downloadcodeLoading = false;
|
||
this.createFile(this.code, 'save.vue')
|
||
},
|
||
//创建文件并下载
|
||
createFile(row, name){
|
||
const element = document.createElement('a')
|
||
element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(row))
|
||
element.setAttribute('download', name)
|
||
element.style.display = 'none'
|
||
element.click()
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style scoped>
|
||
.code {height:400px;overflow: auto;background: #333;color: #999;padding:20px;font-size: 14px;font-family: "consolas";line-height: 1.5;}
|
||
</style>
|