导入配置页面
parent
88d833d30f
commit
d546b71385
File diff suppressed because it is too large
Load Diff
|
|
@ -0,0 +1,39 @@
|
|||
import request from '@/utils/request'
|
||||
|
||||
export function add(data) {
|
||||
return request({
|
||||
url: 'api/excelConfig',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
export function del(ids) {
|
||||
return request({
|
||||
url: 'api/excelConfig/',
|
||||
method: 'delete',
|
||||
data: ids
|
||||
})
|
||||
}
|
||||
|
||||
export function edit(data) {
|
||||
return request({
|
||||
url: 'api/excelConfig',
|
||||
method: 'put',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
export function getColumns(tableName) {
|
||||
return request({
|
||||
url: 'api/generator/columns?tableName=' + tableName,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
export function getTables() {
|
||||
return request({
|
||||
url: 'api/generator/tablesList',
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
export default { add, edit, del, getColumns, getTables }
|
||||
|
|
@ -31,4 +31,4 @@ export function edit(data) {
|
|||
})
|
||||
}
|
||||
|
||||
export default { add, edit, del }
|
||||
export default { add, edit, del, getDicts }
|
||||
|
|
|
|||
|
|
@ -52,6 +52,19 @@
|
|||
>
|
||||
{{$t('crud.export')}}
|
||||
</el-button>
|
||||
<el-upload
|
||||
v-if="crud.optShow.import"
|
||||
:loading="crud.downloadLoading"
|
||||
class="upload-demo"
|
||||
:action="baseApi+'/api/excelConfig/import?tableName='+permission.import"
|
||||
:file-list="fileList"
|
||||
:on-success=handleSuccess
|
||||
:on-error="handleError"
|
||||
style="float: right;padding-left: 5px"
|
||||
:headers="headers"
|
||||
:show-file-list="true">
|
||||
<el-button size="mini" type="success" v-permission="permission.import" icon="el-icon-upload">导入</el-button>
|
||||
</el-upload>
|
||||
<!--右侧-->
|
||||
<slot name="right"/>
|
||||
</span>
|
||||
|
|
@ -88,7 +101,7 @@
|
|||
:indeterminate="allColumnsSelectedIndeterminate"
|
||||
@change="handleCheckAllChange"
|
||||
>
|
||||
{{$t('crud.check_all')}}
|
||||
全选
|
||||
</el-checkbox>
|
||||
<el-checkbox
|
||||
v-for="item in tableColumns"
|
||||
|
|
@ -103,9 +116,7 @@
|
|||
size="mini"
|
||||
type="warning" plain
|
||||
@click="postToTableConfig()"
|
||||
><span>
|
||||
{{$t('crud.save')}}
|
||||
</span></el-button>
|
||||
><span>保存</span></el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
|||
|
|
@ -31,19 +31,19 @@
|
|||
</div>
|
||||
<!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
|
||||
<crudOperation :permission="permission" :tableKey="this.$options.name">
|
||||
<el-upload
|
||||
<!-- <el-upload
|
||||
class="upload-demo"
|
||||
ref="upload"
|
||||
slot='right'
|
||||
style="float: right;padding-left: 5px"
|
||||
:action="baseApi+'/api/point/import_point'"
|
||||
:action="baseApi+'/api/excelConfig/import'"
|
||||
:file-list="fileList"
|
||||
:on-success=handleSuccess
|
||||
:on-error="handleError"
|
||||
:headers="headers"
|
||||
:show-file-list="true">
|
||||
<el-button size="mini" type="success" v-permission="permission.import" icon="el-icon-upload">导入</el-button>
|
||||
</el-upload>
|
||||
</el-upload>-->
|
||||
</crudOperation>
|
||||
<!-- 呼叫空车 -->
|
||||
<el-dialog title="地标点绑定" :visible.sync="callEmptyCarStatus" width="400px">
|
||||
|
|
@ -238,7 +238,8 @@ export default {
|
|||
edit: false,
|
||||
del: false,
|
||||
reset: true,
|
||||
download: true
|
||||
download: true,
|
||||
import: true
|
||||
},
|
||||
queryOnPresenterCreated: true
|
||||
})
|
||||
|
|
|
|||
|
|
@ -0,0 +1,265 @@
|
|||
<template>
|
||||
<div v-if="query.tableName === ''">
|
||||
<div class="my-code">点击查看详情</div>
|
||||
</div>
|
||||
<div v-else>
|
||||
<div class="app-container">
|
||||
<!--工具栏-->
|
||||
<div class="head-container">
|
||||
<!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
|
||||
<crudOperation :permission="permission" :tableKey="this.$options.name"/>
|
||||
<!--表单组件-->
|
||||
<el-dialog :close-on-click-modal="false" :before-close="crud.cancelCU" :visible.sync="crud.status.cu > 0" :title="crud.status.title" width="600px">
|
||||
<el-form :inline="true" ref="form" :model="form" :rules="rules" size="small" label-width="100px">
|
||||
<el-form-item label="数据库表名" prop="tableName">
|
||||
<!-- <el-input v-model="form.tableName" style="width: 370px;" />-->
|
||||
<el-select v-model="form.tableName" style="width: 370px" placeholder="请选择" clearable>
|
||||
<el-option
|
||||
v-for="item in dict.per_table_config"
|
||||
:key="item.value"
|
||||
:label="item.value"
|
||||
:value="item.value"
|
||||
>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="字段名" prop="tableColumnName">
|
||||
<el-select v-model="form.tableColumnName" filterable style="width: 270px" placeholder="请选择">
|
||||
<el-option
|
||||
v-for="item in columnsList"
|
||||
:key="item.columnName"
|
||||
:label="item.columnName"
|
||||
:value="item.columnName"
|
||||
>
|
||||
<span style="float: left">{{ item.columnName }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.remark }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item prop="onlyFlag">
|
||||
<el-checkbox v-model="form.onlyFlag">唯一标识</el-checkbox>
|
||||
</el-form-item>
|
||||
<el-form-item label="字段类型" prop="tableColumnType">
|
||||
<el-select v-model="form.tableColumnType" style="width: 370px" placeholder="请选择" clearable>
|
||||
<el-option
|
||||
v-for="item in dict.excel_columns_type"
|
||||
:key="item.value"
|
||||
:label="item.value"
|
||||
:value="item.value"
|
||||
>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="Excel列名" prop="excelColumnName">
|
||||
<el-input v-model="form.excelColumnName" style="width: 370px;" />
|
||||
</el-form-item>
|
||||
<el-form-item label="默认值">
|
||||
<el-input v-model="form.defaultValue" style="width: 370px;" />
|
||||
</el-form-item>
|
||||
<el-form-item label="关联表">
|
||||
<!-- <el-input v-model="form.keyFlag" style="width: 370px;" />-->
|
||||
<el-radio-group v-model="form.glbType">
|
||||
<el-radio :label="1" v-model="form.glbType" @click.native.prevent="clickitem(1)">外键</el-radio>
|
||||
<el-radio :label="2" v-model="form.glbType" @click.native.prevent="clickitem(2)">字典</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.glbType==1" label="外键表名" prop="keyTableName">
|
||||
<el-select v-model="form.ecKey.tableName" @change="getKeyColumns(form.ecKey.tableName)" filterable style="width: 370px" placeholder="请选择">
|
||||
<el-option
|
||||
v-for="item in tablesList"
|
||||
:key="item.tableName"
|
||||
:label="item.tableName"
|
||||
:value="item.tableName"
|
||||
>
|
||||
<span style="float: left">{{ item.tableName }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.remark }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.glbType==1" label="表字段" prop="keyColumnName">
|
||||
<el-select v-model="form.ecKey.tableColumnName" filterable style="width: 370px" placeholder="请选择">
|
||||
<el-option
|
||||
v-for="item in keyColumnsList"
|
||||
:key="item.columnName"
|
||||
:label="item.columnName"
|
||||
:value="item.columnName"
|
||||
>
|
||||
<span style="float: left">{{ item.columnName }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.remark }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.glbType==1" label="字段类型" prop="keyColumnType">
|
||||
<el-select v-model="form.ecKey.tableColumnType" style="width: 370px" placeholder="请选择" clearable>
|
||||
<el-option
|
||||
v-for="item in dict.excel_columns_type"
|
||||
:key="item.value"
|
||||
:label="item.value"
|
||||
:value="item.value"
|
||||
>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.glbType==1" label="映射字段" prop="keyName">
|
||||
<el-select v-model="form.ecKey.keyName" filterable style="width: 370px" placeholder="请选择">
|
||||
<el-option
|
||||
v-for="item in keyColumnsList"
|
||||
:key="item.columnName"
|
||||
:label="item.columnName"
|
||||
:value="item.columnName"
|
||||
>
|
||||
<span style="float: left">{{ item.columnName }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.remark }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.glbType==2" label="关联字典">
|
||||
<el-select filterable v-model="form.dictName" style="width: 370px" placeholder="请选择" clearable>
|
||||
<el-option
|
||||
v-for="item in keyDictList"
|
||||
:key="item.name"
|
||||
:label="item.name"
|
||||
:value="item.name"
|
||||
>
|
||||
<span style="float: left">{{ item.name }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.description }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
|
||||
</el-form>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="text" @click="crud.cancelCU">取消</el-button>
|
||||
<el-button :loading="crud.status.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
<!--表格渲染-->
|
||||
<el-table ref="table" v-loading="crud.loading" :data="crud.data" :height="crud.tableHeight" size="small" style="width: 100%;" @selection-change="crud.selectionChangeHandler">
|
||||
<el-table-column prop="tableColumnName" label="字段名" />
|
||||
<el-table-column prop="tableColumnType" label="字段类型" />
|
||||
<el-table-column prop="excelColumnName" label="列名" />
|
||||
<el-table-column prop="onlyFlag" label="是否唯一">
|
||||
<template slot-scope="scope">
|
||||
<span v-if="scope.row.onlyFlag==true">是</span>
|
||||
<span v-if="scope.row.onlyFlag==false">否</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column prop="dictName" label="关联字典" />
|
||||
<el-table-column prop="ecKey.tableName" label="关联表名" />
|
||||
<el-table-column prop="ecKey.keyName" label="映射字段" />
|
||||
<el-table-column prop="ecKey.tableColumnName" label="关联字段" />
|
||||
<el-table-column prop="ecKey.tableColumnType" label="类型" />
|
||||
<el-table-column fixed="right" v-if="checkPer(['admin','excelConfig:edit','excelConfig:del'])" label="操作" width="150px" align="center">
|
||||
<template slot-scope="scope">
|
||||
<udOperation
|
||||
:data="scope.row"
|
||||
:permission="permission"
|
||||
/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!--分页组件-->
|
||||
<pagination />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import crudExcelConfig, {getColumns, getTables} from '@/api/excelConfig'
|
||||
import CRUD, { presenter, header, form, crud } from '@crud/crud'
|
||||
import rrOperation from '@crud/RR.operation'
|
||||
import crudOperation from '@crud/CRUD.operation'
|
||||
import udOperation from '@crud/UD.operation'
|
||||
import pagination from '@crud/Pagination'
|
||||
import {getPoints} from "@/api/point";
|
||||
import crudDict, {getDicts} from '@/api/system/dict'
|
||||
|
||||
const defaultForm = { id: null, excelColumnName: null, tableColumnName: null, tableColumnType: null,glbType:0, onlyFlag: false,dictName: null,ecKey: { tableName:null,keyName:null,tableColumnName:null,tableColumnType: null }}
|
||||
export default {
|
||||
name: 'ExcelColumnConfig',
|
||||
components: { pagination, crudOperation, rrOperation, udOperation },
|
||||
mixins: [presenter(), header(),
|
||||
form(function() {
|
||||
return Object.assign({ tableName: this.tableName}, defaultForm)
|
||||
}),
|
||||
crud()],
|
||||
dicts:['per_table_config','excel_columns_type'],
|
||||
cruds() {
|
||||
return CRUD({ title: '导入配置', url: 'api/excelConfig', idField: 'id', sort: 'id,desc', crudMethod: { ...crudExcelConfig }, optShow: {
|
||||
add: false,
|
||||
edit: false,
|
||||
del: false,
|
||||
reset: false,
|
||||
download: false,
|
||||
import: false
|
||||
},queryOnPresenterCreated: false})
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
tableName: null,
|
||||
columnsList:[],
|
||||
keyColumnsList:[],
|
||||
tablesList:[],
|
||||
keyDictList:[],
|
||||
permission: {
|
||||
add: ['admin', 'excelConfig:add'],
|
||||
edit: ['admin', 'excelConfig:edit'],
|
||||
del: ['admin', 'excelConfig:del']
|
||||
},
|
||||
rules: {
|
||||
tableName: [
|
||||
{ required: true, message: '不能为空', trigger: 'blur' }
|
||||
],
|
||||
tableColumnName: [
|
||||
{ required: true, message: '不能为空', trigger: 'blur' }
|
||||
],
|
||||
tableColumnType: [
|
||||
{ required: true, message: '不能为空', trigger: 'blur' }
|
||||
]
|
||||
}}
|
||||
},
|
||||
methods: {
|
||||
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
return true
|
||||
},
|
||||
// 查询数据库字段
|
||||
getColumns(tableName) {
|
||||
getColumns(tableName).then(res => {
|
||||
this.columnsList = res.content
|
||||
})
|
||||
},
|
||||
// 查询数据库字段
|
||||
getKeyColumns(tableName) {
|
||||
getColumns(tableName).then(res => {
|
||||
this.keyColumnsList = res.content
|
||||
})
|
||||
},
|
||||
// 查询suo数据库表
|
||||
getTables() {
|
||||
getTables().then(res => {
|
||||
this.tablesList = res.content
|
||||
})
|
||||
},
|
||||
// 查询全部字典
|
||||
getKeyDicts() {
|
||||
crudDict.getDicts().then(res => {
|
||||
this.keyDictList = res
|
||||
})
|
||||
},
|
||||
clickitem (e) {
|
||||
e === this.$refs.form.model.glbType ? this.$refs.form.model.glbType = 0 : this.$refs.form.model.glbType = e
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.getKeyDicts();
|
||||
this.getTables();
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
|
|
@ -0,0 +1,172 @@
|
|||
<template>
|
||||
<div class="app-container">
|
||||
<!--表单组件-->
|
||||
<el-dialog :close-on-click-modal="false" :before-close="crud.cancelCU" :visible.sync="crud.status.cu > 0" :title="crud.status.title" width="500px">
|
||||
<el-form ref="form" :model="form" :rules="rules" size="small" label-width="80px">
|
||||
<el-form-item label="权限" prop="label">
|
||||
<el-input v-model="form.label" style="width: 370px;" />
|
||||
</el-form-item>
|
||||
<el-form-item label="表名" prop="value">
|
||||
<el-select v-model="form.value" filterable style="width: 370px" placeholder="请选择">
|
||||
<el-option
|
||||
v-for="item in tablesList"
|
||||
:key="item.tableName"
|
||||
:label="item.tableName"
|
||||
:value="item.tableName"
|
||||
>
|
||||
<span style="float: left">{{ item.tableName }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.remark }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="描述" prop="description">
|
||||
<el-input v-model="form.description" style="width: 370px;" />
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="text" @click="crud.cancelCU">取消</el-button>
|
||||
<el-button :loading="crud.status.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
<el-row :gutter="10">
|
||||
<el-col :xs="24" :sm="24" :md="10" :lg="10" :xl="11" style="margin-bottom: 10px">
|
||||
<el-card class="box-card">
|
||||
<!--工具栏-->
|
||||
<div class="head-container">
|
||||
<!--工具栏-->
|
||||
<div class="head-container">
|
||||
<div v-if="crud.props.searchToggle">
|
||||
<!-- 搜索 -->
|
||||
<el-input v-model="query.blurry" clearable size="small" placeholder="输入名称或者描述搜索" style="width: 200px;" class="filter-item" @keyup.enter.native="crud.toQuery" />
|
||||
<rrOperation />
|
||||
</div>
|
||||
<crudOperation :permission="permission" :tableKey="this.$options.name"/>
|
||||
</div>
|
||||
<!--表格渲染-->
|
||||
<el-table ref="table" v-loading="crud.loading" :data="crud.data" :height="crud.tableHeight" size="small" style="width: 100%;" @selection-change="crud.selectionChangeHandler" @current-change="handleCurrentChange">
|
||||
<el-table-column prop="label" label="权限" />
|
||||
<el-table-column prop="value" label="表名" />
|
||||
<el-table-column prop="description" label="描述" />
|
||||
<el-table-column fixed="right" v-if="checkPer(['admin','dictDetail:edit','dictDetail:del'])" label="操作" width="150px" align="center">
|
||||
<template slot-scope="scope">
|
||||
<udOperation
|
||||
:data="scope.row"
|
||||
:permission="permission"
|
||||
/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!--分页组件-->
|
||||
<pagination />
|
||||
</div>
|
||||
</el-card>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="24" :md="14" :lg="14" :xl="13">
|
||||
<el-card class="box-card">
|
||||
<div slot="header" class="clearfix">
|
||||
<span>字段配置</span>
|
||||
<el-button
|
||||
v-if="checkPer(['admin','excelConfig:add']) && this.$refs.excelConfig && this.$refs.excelConfig.tableName"
|
||||
class="filter-item"
|
||||
size="mini"
|
||||
style="float: right;padding: 8px 12px"
|
||||
type="primary"
|
||||
icon="el-icon-plus"
|
||||
@click="$refs.excelConfig && $refs.excelConfig.crud.toAdd()"
|
||||
>新增</el-button>
|
||||
</div>
|
||||
<excelConfig ref="excelConfig" :permission="permission" />
|
||||
</el-card>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import crudDictDetail from '@/api/system/dictDetail'
|
||||
import CRUD, { presenter, header, form, crud } from '@crud/crud'
|
||||
import rrOperation from '@crud/RR.operation'
|
||||
import crudOperation from '@crud/CRUD.operation'
|
||||
import udOperation from '@crud/UD.operation'
|
||||
import pagination from '@crud/Pagination'
|
||||
import excelConfig from './excelConfig'
|
||||
import {getTables} from "@/api/excelConfig";
|
||||
|
||||
const defaultForm = { id: null,description:null, dict: {name:"per_table_config"}, label: null, value: null, dictSort: null, createBy: null, updateBy: null, createTime: null, updateTime: null }
|
||||
export default {
|
||||
name: 'DictDetail',
|
||||
components: { pagination, crudOperation, rrOperation, udOperation, excelConfig },
|
||||
mixins: [presenter(), header(), form(defaultForm), crud()],
|
||||
cruds() {
|
||||
return CRUD({ title: '权限关联', url: 'api/dictDetail',query: { dictName: 'per_table_config' }, sort: 'id,desc',
|
||||
crudMethod: { ...crudDictDetail },
|
||||
optShow: {
|
||||
add: true,
|
||||
edit: false,
|
||||
del: false,
|
||||
reset: false
|
||||
}})
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
tablesList: [],
|
||||
permission: {
|
||||
add: ['admin', 'dictDetail:add'],
|
||||
edit: ['admin', 'dictDetail:edit'],
|
||||
del: ['admin', 'dictDetail:del']
|
||||
},
|
||||
rules: {
|
||||
label: [
|
||||
{ required: true, message: '字典标签不能为空', trigger: 'blur' }
|
||||
],
|
||||
value: [
|
||||
{ required: true, message: '字典值不能为空', trigger: 'blur' }
|
||||
]
|
||||
} }
|
||||
},
|
||||
methods: {
|
||||
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
return true
|
||||
},
|
||||
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
return true
|
||||
},
|
||||
// 获取数据前设置好接口地址
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
if (this.$refs.excelConfig) {
|
||||
this.$refs.excelConfig.query.tableName = ''
|
||||
}
|
||||
return true
|
||||
},
|
||||
// 选中数据后将选中数据的信息传到另一张表 查询
|
||||
handleCurrentChange(val) {
|
||||
if (val) {
|
||||
this.$refs.excelConfig.query.tableName = val.value
|
||||
this.$refs.excelConfig.tableName = val.value
|
||||
this.$refs.excelConfig.crud.toQuery()
|
||||
this.$refs.excelConfig.getColumns(val.value)
|
||||
}
|
||||
},
|
||||
// 编辑前将子表明细临时清空,避免日志入库数据过长
|
||||
[CRUD.HOOK.beforeToEdit](crud, form) {
|
||||
// 将角色的菜单清空,避免日志入库数据过长
|
||||
form.excelConfig = null
|
||||
},
|
||||
// 查询suo数据库表
|
||||
getTables() {
|
||||
getTables().then(res => {
|
||||
this.tablesList = res.content
|
||||
})
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.getTables();
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
Loading…
Reference in New Issue