更新
This commit is contained in:
@@ -1,19 +0,0 @@
|
|||||||
import axios from 'axios'
|
|
||||||
|
|
||||||
const service = axios.create()
|
|
||||||
|
|
||||||
export function Commits(page) {
|
|
||||||
return service({
|
|
||||||
url:
|
|
||||||
'https://api.github.com/repos/flipped-aurora/gin-vue-admin/commits?page=' +
|
|
||||||
page,
|
|
||||||
method: 'get'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
export function Members() {
|
|
||||||
return service({
|
|
||||||
url: 'https://api.github.com/orgs/FLIPPED-AURORA/members',
|
|
||||||
method: 'get'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
import service from '@/utils/request'
|
|
||||||
// @Tags InitDB
|
|
||||||
// @Summary 初始化用户数据库
|
|
||||||
// @Produce application/json
|
|
||||||
// @Param data body request.InitDB true "初始化数据库参数"
|
|
||||||
// @Success 200 {string} string "{"code":0,"data":{},"msg":"自动创建数据库成功"}"
|
|
||||||
// @Router /init/initdb [post]
|
|
||||||
export const initDB = (data) => {
|
|
||||||
return service({
|
|
||||||
url: '/init/initdb',
|
|
||||||
method: 'post',
|
|
||||||
data,
|
|
||||||
donNotShowLoading: true
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// @Tags CheckDB
|
|
||||||
// @Summary 初始化用户数据库
|
|
||||||
// @Produce application/json
|
|
||||||
// @Success 200 {string} string "{"code":0,"data":{},"msg":"探测完成"}"
|
|
||||||
// @Router /init/checkdb [post]
|
|
||||||
export const checkDB = () => {
|
|
||||||
return service({
|
|
||||||
url: '/init/checkdb',
|
|
||||||
method: 'post'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
import service from '@/utils/request'
|
|
||||||
// @Tags systrm
|
|
||||||
// @Summary 获取配置文件内容
|
|
||||||
// @Security ApiKeyAuth
|
|
||||||
// @Produce application/json
|
|
||||||
// @Success 200 {string} string "{"success":true,"data":{},"msg":"返回成功"}"
|
|
||||||
// @Router /system/getSystemConfig [post]
|
|
||||||
export const getSystemConfig = () => {
|
|
||||||
return service({
|
|
||||||
url: '/system/getSystemConfig',
|
|
||||||
method: 'post'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// @Tags system
|
|
||||||
// @Summary 设置配置文件内容
|
|
||||||
// @Security ApiKeyAuth
|
|
||||||
// @Produce application/json
|
|
||||||
// @Param data body sysModel.System true
|
|
||||||
// @Success 200 {string} string "{"success":true,"data":{},"msg":"返回成功"}"
|
|
||||||
// @Router /system/setSystemConfig [post]
|
|
||||||
export const setSystemConfig = (data) => {
|
|
||||||
return service({
|
|
||||||
url: '/system/setSystemConfig',
|
|
||||||
method: 'post',
|
|
||||||
data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// @Tags system
|
|
||||||
// @Summary 获取服务器运行状态
|
|
||||||
// @Security ApiKeyAuth
|
|
||||||
// @Produce application/json
|
|
||||||
// @Success 200 {string} string "{"success":true,"data":{},"msg":"返回成功"}"
|
|
||||||
// @Router /system/getServerInfo [post]
|
|
||||||
export const getSystemState = () => {
|
|
||||||
return service({
|
|
||||||
url: '/system/getServerInfo',
|
|
||||||
method: 'post',
|
|
||||||
donNotShowLoading: true
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 重载服务
|
|
||||||
* @param data
|
|
||||||
* @returns {*}
|
|
||||||
*/
|
|
||||||
export const reloadSystem = (data) => {
|
|
||||||
return service({
|
|
||||||
url: '/system/reloadSystem',
|
|
||||||
method: 'post',
|
|
||||||
data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -15,31 +15,13 @@ const routes = [
|
|||||||
name: 'Login',
|
name: 'Login',
|
||||||
component: () => import('@/view/login/index.vue')
|
component: () => import('@/view/login/index.vue')
|
||||||
},
|
},
|
||||||
// {
|
|
||||||
// path: '/largeScreen',
|
|
||||||
// name: 'LargeScreen',
|
|
||||||
// meta: {
|
|
||||||
// title: '智能用电云平台',
|
|
||||||
// client: true,
|
|
||||||
// defaultMenu: true
|
|
||||||
// },
|
|
||||||
// component: () => import('@/view/largeScreen/index.vue')
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// path: '/largeScreen2',
|
|
||||||
// name: 'largeScreen2',
|
|
||||||
// meta: {
|
|
||||||
// title: 'largeScreen2',
|
|
||||||
// },
|
|
||||||
// component: () => import('@/view/largeScreen2/index.vue')
|
|
||||||
// },
|
|
||||||
{
|
{
|
||||||
path: '/:catchAll(.*)',
|
path: '/:catchAll(.*)',
|
||||||
meta: {
|
meta: {
|
||||||
closeTab: true
|
closeTab: true
|
||||||
},
|
},
|
||||||
component: () => import('@/view/error/index.vue')
|
component: () => import('@/view/error/index.vue')
|
||||||
},
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
const router = createRouter({
|
const router = createRouter({
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
import { useRoute } from 'vue-router'
|
|
||||||
import { reactive } from 'vue'
|
|
||||||
export const useBtnAuth = () => {
|
|
||||||
const route = useRoute()
|
|
||||||
return route.meta.btns || reactive({})
|
|
||||||
}
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
import { emitter } from '@/utils/bus.js'
|
|
||||||
|
|
||||||
export const closeThisPage = () => {
|
|
||||||
emitter.emit('closeThisPage')
|
|
||||||
}
|
|
||||||
@@ -1,44 +0,0 @@
|
|||||||
// 对Date的扩展,将 Date 转化为指定格式的String
|
|
||||||
// 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,
|
|
||||||
// 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
|
|
||||||
// (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
|
|
||||||
// (new Date()).Format("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18
|
|
||||||
// eslint-disable-next-line no-extend-native
|
|
||||||
Date.prototype.Format = function(fmt) {
|
|
||||||
const o = {
|
|
||||||
'M+': this.getMonth() + 1, // 月份
|
|
||||||
'd+': this.getDate(), // 日
|
|
||||||
'h+': this.getHours(), // 小时
|
|
||||||
'm+': this.getMinutes(), // 分
|
|
||||||
's+': this.getSeconds(), // 秒
|
|
||||||
'q+': Math.floor((this.getMonth() + 3) / 3), // 季度
|
|
||||||
'S': this.getMilliseconds() // 毫秒
|
|
||||||
}
|
|
||||||
const reg = /(y+)/
|
|
||||||
if (reg.test(fmt)) {
|
|
||||||
const t = reg.exec(fmt)[1]
|
|
||||||
fmt = fmt.replace(
|
|
||||||
t,
|
|
||||||
(this.getFullYear() + '').substring(4 - t.length)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
for (let k in o) {
|
|
||||||
const regx = new RegExp('(' + k + ')')
|
|
||||||
if (regx.test(fmt)) {
|
|
||||||
const t = regx.exec(fmt)[1]
|
|
||||||
fmt = fmt.replace(
|
|
||||||
t,
|
|
||||||
t.length === 1 ? o[k] : ('00' + o[k]).substring(('' + o[k]).length)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return fmt
|
|
||||||
}
|
|
||||||
|
|
||||||
export function formatTimeToStr(times, pattern) {
|
|
||||||
let d = new Date(times).Format('yyyy-MM-dd hh:mm:ss')
|
|
||||||
if (pattern) {
|
|
||||||
d = new Date(times).Format(pattern)
|
|
||||||
}
|
|
||||||
return d.toLocaleString()
|
|
||||||
}
|
|
||||||
@@ -74,12 +74,7 @@ export const getDict = async (
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 字典文字展示方法
|
// 字典文字展示方法
|
||||||
export const showDictLabel = (
|
export const showDictLabel = (dict, code, keyCode = 'value', valueCode = 'label') => {
|
||||||
dict,
|
|
||||||
code,
|
|
||||||
keyCode = 'value',
|
|
||||||
valueCode = 'label'
|
|
||||||
) => {
|
|
||||||
if (!dict) {
|
if (!dict) {
|
||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,20 +0,0 @@
|
|||||||
export const downloadImage = (imgsrc, name) => {
|
|
||||||
// 下载图片地址和图片名
|
|
||||||
var image = new Image()
|
|
||||||
image.setAttribute('crossOrigin', 'anonymous')
|
|
||||||
image.onload = function () {
|
|
||||||
var canvas = document.createElement('canvas')
|
|
||||||
canvas.width = image.width
|
|
||||||
canvas.height = image.height
|
|
||||||
var context = canvas.getContext('2d')
|
|
||||||
context.drawImage(image, 0, 0, image.width, image.height)
|
|
||||||
var url = canvas.toDataURL('image/png') // 得到图片的base64编码数据
|
|
||||||
|
|
||||||
var a = document.createElement('a') // 生成一个a元素
|
|
||||||
var event = new MouseEvent('click') // 创建一个单击事件
|
|
||||||
a.download = name || 'photo' // 设置图片名称
|
|
||||||
a.href = url // 将生成的URL设置为a.href属性
|
|
||||||
a.dispatchEvent(event) // 触发a的单击事件
|
|
||||||
}
|
|
||||||
image.src = imgsrc
|
|
||||||
}
|
|
||||||
@@ -1,4 +1,3 @@
|
|||||||
import { formatTimeToStr } from '@/utils/date'
|
|
||||||
import { getDict } from '@/utils/dictionary'
|
import { getDict } from '@/utils/dictionary'
|
||||||
import { ref } from 'vue'
|
import { ref } from 'vue'
|
||||||
|
|
||||||
@@ -9,34 +8,26 @@ export const formatBoolean = (bool) => {
|
|||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export const formatDate = (time) => {
|
|
||||||
if (time !== null && time !== '') {
|
|
||||||
var date = new Date(time)
|
|
||||||
return formatTimeToStr(date, 'yyyy-MM-dd hh:mm:ss')
|
|
||||||
} else {
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const filterDict = (value, options) => {
|
export const filterDict = (value, options) => {
|
||||||
// 递归查找函数
|
// 递归查找函数
|
||||||
const findInOptions = (opts, targetValue) => {
|
const findInOptions = (opts, targetValue) => {
|
||||||
if (!opts || !Array.isArray(opts)) return null
|
if (!opts || !Array.isArray(opts)) return null
|
||||||
|
|
||||||
for (const item of opts) {
|
for (const item of opts) {
|
||||||
if (item.value === targetValue) {
|
if (item.value === targetValue) {
|
||||||
return item
|
return item
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item.children && Array.isArray(item.children)) {
|
if (item.children && Array.isArray(item.children)) {
|
||||||
const found = findInOptions(item.children, targetValue)
|
const found = findInOptions(item.children, targetValue)
|
||||||
if (found) return found
|
if (found) return found
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
const rowLabel = findInOptions(options, value)
|
const rowLabel = findInOptions(options, value)
|
||||||
return rowLabel && rowLabel.label
|
return rowLabel && rowLabel.label
|
||||||
}
|
}
|
||||||
@@ -45,30 +36,30 @@ export const filterDataSource = (dataSource, value) => {
|
|||||||
// 递归查找函数
|
// 递归查找函数
|
||||||
const findInDataSource = (data, targetValue) => {
|
const findInDataSource = (data, targetValue) => {
|
||||||
if (!data || !Array.isArray(data)) return null
|
if (!data || !Array.isArray(data)) return null
|
||||||
|
|
||||||
for (const item of data) {
|
for (const item of data) {
|
||||||
// 检查当前项是否匹配
|
// 检查当前项是否匹配
|
||||||
if (item.value === targetValue) {
|
if (item.value === targetValue) {
|
||||||
return item
|
return item
|
||||||
}
|
}
|
||||||
|
|
||||||
// 如果有children属性,递归查找
|
// 如果有children属性,递归查找
|
||||||
if (item.children && Array.isArray(item.children)) {
|
if (item.children && Array.isArray(item.children)) {
|
||||||
const found = findInDataSource(item.children, targetValue)
|
const found = findInDataSource(item.children, targetValue)
|
||||||
if (found) return found
|
if (found) return found
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Array.isArray(value)) {
|
if (Array.isArray(value)) {
|
||||||
return value.map((item) => {
|
return value.map((item) => {
|
||||||
const rowLabel = findInDataSource(dataSource, item)
|
const rowLabel = findInDataSource(dataSource, item)
|
||||||
return rowLabel?.label
|
return rowLabel?.label
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
const rowLabel = findInDataSource(dataSource, value)
|
const rowLabel = findInDataSource(dataSource, value)
|
||||||
return rowLabel?.label
|
return rowLabel?.label
|
||||||
}
|
}
|
||||||
@@ -78,8 +69,7 @@ export const getDictFunc = async (type) => {
|
|||||||
return dicts
|
return dicts
|
||||||
}
|
}
|
||||||
|
|
||||||
const path =
|
const path = import.meta.env.VITE_BASE_PATH + ':' + import.meta.env.VITE_SERVER_PORT + '/'
|
||||||
import.meta.env.VITE_BASE_PATH + ':' + import.meta.env.VITE_SERVER_PORT + '/'
|
|
||||||
export const ReturnArrImg = (arr) => {
|
export const ReturnArrImg = (arr) => {
|
||||||
const imgArr = []
|
const imgArr = []
|
||||||
if (arr instanceof Array) {
|
if (arr instanceof Array) {
|
||||||
@@ -144,10 +134,7 @@ export const setBodyPrimaryColor = (primaryColor, darkMode) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
document.documentElement.style.setProperty('--el-color-primary', primaryColor)
|
document.documentElement.style.setProperty('--el-color-primary', primaryColor)
|
||||||
document.documentElement.style.setProperty(
|
document.documentElement.style.setProperty('--el-color-primary-bg', addOpacityToColor(primaryColor, 0.4))
|
||||||
'--el-color-primary-bg',
|
|
||||||
addOpacityToColor(primaryColor, 0.4)
|
|
||||||
)
|
|
||||||
for (let times = 1; times <= 2; times++) {
|
for (let times = 1; times <= 2; times++) {
|
||||||
document.documentElement.style.setProperty(
|
document.documentElement.style.setProperty(
|
||||||
`--el-color-primary-dark-${times}`,
|
`--el-color-primary-dark-${times}`,
|
||||||
@@ -160,10 +147,7 @@ export const setBodyPrimaryColor = (primaryColor, darkMode) => {
|
|||||||
fmtColorFunc(primaryColor, times / 10)
|
fmtColorFunc(primaryColor, times / 10)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
document.documentElement.style.setProperty(
|
document.documentElement.style.setProperty(`--el-menu-hover-bg-color`, addOpacityToColor(primaryColor, 0.2))
|
||||||
`--el-menu-hover-bg-color`,
|
|
||||||
addOpacityToColor(primaryColor, 0.2)
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const baseUrl = ref(import.meta.env.VITE_BASE_API)
|
const baseUrl = ref(import.meta.env.VITE_BASE_API)
|
||||||
@@ -178,7 +162,7 @@ export const CreateUUID = () => {
|
|||||||
d += performance.now()
|
d += performance.now()
|
||||||
}
|
}
|
||||||
return '00000000-0000-0000-0000-000000000000'.replace(/0/g, (c) => {
|
return '00000000-0000-0000-0000-000000000000'.replace(/0/g, (c) => {
|
||||||
const r = (d + Math.random() * 16) % 16 | 0 // d是随机种子
|
const r = ((d + Math.random() * 16) % 16) | 0 // d是随机种子
|
||||||
d = Math.floor(d / 16)
|
d = Math.floor(d / 16)
|
||||||
return (c === '0' ? r : (r & 0x3) | 0x8).toString(16)
|
return (c === '0' ? r : (r & 0x3) | 0x8).toString(16)
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,14 +0,0 @@
|
|||||||
import { useParamsStore } from '@/pinia/modules/params'
|
|
||||||
/*
|
|
||||||
* 获取参数方法 使用示例 getParams('key').then(res) 或者 async函数下 const res = await getParams('key')
|
|
||||||
* const res = ref('')
|
|
||||||
* const fun = async () => {
|
|
||||||
* res.value = await getParams('test')
|
|
||||||
* }
|
|
||||||
* fun()
|
|
||||||
*/
|
|
||||||
export const getParams = async(key) => {
|
|
||||||
const paramsStore = useParamsStore()
|
|
||||||
await paramsStore.getParams(key)
|
|
||||||
return paramsStore.paramsMap[key]
|
|
||||||
}
|
|
||||||
@@ -4,17 +4,7 @@
|
|||||||
<div class="flex flex-col items-center text-2xl gap-4">
|
<div class="flex flex-col items-center text-2xl gap-4">
|
||||||
<img class="w-1/3" src="../../assets/404.png" />
|
<img class="w-1/3" src="../../assets/404.png" />
|
||||||
<p class="text-lg">页面被神秘力量吸走了</p>
|
<p class="text-lg">页面被神秘力量吸走了</p>
|
||||||
<p class="text-lg">
|
<p class="text-lg">常见问题为当前此角色无当前路由,如果确定要使用本路由,请到角色管理进行分配</p>
|
||||||
常见问题为当前此角色无当前路由,如果确定要使用本路由,请到角色管理进行分配
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
项目地址:<a
|
|
||||||
href="https://github.com/flipped-aurora/gin-vue-admin"
|
|
||||||
target="_blank"
|
|
||||||
class="text-blue-600"
|
|
||||||
>https://github.com/flipped-aurora/gin-vue-admin</a
|
|
||||||
>
|
|
||||||
</p>
|
|
||||||
<el-button @click="toDashboard">返回首页</el-button>
|
<el-button @click="toDashboard">返回首页</el-button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -36,9 +26,9 @@
|
|||||||
try {
|
try {
|
||||||
router.push({ name: userStore.userInfo.authority.defaultRouter })
|
router.push({ name: userStore.userInfo.authority.defaultRouter })
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
emitter.emit('show-error', {
|
emitter.emit('show-error', {
|
||||||
code: '401',
|
code: '401',
|
||||||
message: "检测到其他用户修改了路由权限,请重新登录",
|
message: '检测到其他用户修改了路由权限,请重新登录',
|
||||||
fn: () => {
|
fn: () => {
|
||||||
userStore.ClearStorage()
|
userStore.ClearStorage()
|
||||||
router.push({ name: 'Login', replace: true })
|
router.push({ name: 'Login', replace: true })
|
||||||
|
|||||||
@@ -1,334 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div
|
|
||||||
class="rounded-lg flex items-center justify-evenly w-full h-full relative md:w-screen md:h-screen md:bg-[#194bfb] overflow-hidden"
|
|
||||||
>
|
|
||||||
<div class="rounded-md w-full h-full flex items-center justify-center overflow-hidden">
|
|
||||||
<div class="oblique h-[130%] w-3/5 bg-white dark:bg-slate-900 transform -rotate-12 absolute -ml-80" />
|
|
||||||
<div v-if="!page.showForm" :class="[page.showReadme ? 'slide-out-right' : 'slide-in-fwd-top']">
|
|
||||||
<div class="text-lg">
|
|
||||||
<div class="font-sans text-4xl font-bold text-center mb-4 dark:text-white">GIN-VUE-ADMIN</div>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">初始化须知</p>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">1.您需有用一定的VUE和GOLANG基础</p>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">
|
|
||||||
2.请您确认是否已经阅读过<a
|
|
||||||
class="text-blue-600 font-bold"
|
|
||||||
href="https://www.gin-vue-admin.com"
|
|
||||||
target="_blank"
|
|
||||||
>官方文档</a
|
|
||||||
>
|
|
||||||
<a class="text-blue-600 font-bold" href="https://www.bilibili.com/video/BV1kv4y1g7nT?p=2" target="_blank"
|
|
||||||
>初始化视频</a
|
|
||||||
>
|
|
||||||
</p>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">3.请您确认是否了解后续的配置流程</p>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">
|
|
||||||
4.如果您使用mysql数据库,请确认数据库引擎为<span class="text-red-600 font-bold text-3xl ml-2">innoDB</span>
|
|
||||||
</p>
|
|
||||||
<p class="text-gray-600 dark:text-gray-300 mb-2">注:开发组不为文档中书写过的内容提供无偿服务</p>
|
|
||||||
<p class="flex items-center justify-between mt-8">
|
|
||||||
<el-button type="primary" size="large" @click="goDoc"> 阅读文档 </el-button>
|
|
||||||
<el-button type="primary" size="large" @click="showNext"> 我已确认 </el-button>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div v-if="page.showForm" :class="[page.showForm ? 'slide-in-left' : 'slide-out-right']" class="w-96">
|
|
||||||
<el-form ref="formRef" :model="form" label-width="100px" size="large">
|
|
||||||
<el-form-item label="管理员密码">
|
|
||||||
<el-input v-model="form.adminPassword" placeholder="admin账号的默认密码"></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="数据库类型">
|
|
||||||
<el-select v-model="form.dbType" placeholder="请选择" class="w-full" @change="changeDB">
|
|
||||||
<el-option key="mysql" label="mysql" value="mysql" />
|
|
||||||
<el-option key="pgsql" label="pgsql" value="pgsql" />
|
|
||||||
<el-option key="oracle" label="oracle" value="oracle" />
|
|
||||||
<el-option key="mssql" label="mssql" value="mssql" />
|
|
||||||
<el-option key="sqlite" label="sqlite" value="sqlite" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType !== 'sqlite'" label="host">
|
|
||||||
<el-input v-model="form.host" placeholder="请输入数据库链接" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType !== 'sqlite'" label="port">
|
|
||||||
<el-input v-model="form.port" placeholder="请输入数据库端口" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType !== 'sqlite'" label="userName">
|
|
||||||
<el-input v-model="form.userName" placeholder="请输入数据库用户名" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType !== 'sqlite'" label="password">
|
|
||||||
<el-input v-model="form.password" placeholder="请输入数据库密码(没有则为空)" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="dbName">
|
|
||||||
<el-input v-model="form.dbName" placeholder="请输入数据库名称" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType === 'sqlite'" label="dbPath">
|
|
||||||
<el-input v-model="form.dbPath" placeholder="请输入sqlite数据库文件存放路径" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.dbType === 'pgsql'" label="template">
|
|
||||||
<el-input v-model="form.template" placeholder="请输入postgresql指定template" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item>
|
|
||||||
<div style="text-align: right">
|
|
||||||
<el-button type="primary" @click="onSubmit">立即初始化</el-button>
|
|
||||||
</div>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="hidden md:block w-1/2 h-full float-right bg-[#194bfb]">
|
|
||||||
<img class="h-full" src="@/assets/login_right_banner.jpg" alt="banner" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
// @ts-ignore
|
|
||||||
import { initDB } from '@/api/initdb'
|
|
||||||
import { reactive, ref } from 'vue'
|
|
||||||
import { ElLoading, ElMessage, ElMessageBox } from 'element-plus'
|
|
||||||
import { useRouter } from 'vue-router'
|
|
||||||
|
|
||||||
defineOptions({
|
|
||||||
name: 'Init'
|
|
||||||
})
|
|
||||||
|
|
||||||
const router = useRouter()
|
|
||||||
|
|
||||||
const page = reactive({
|
|
||||||
showReadme: false,
|
|
||||||
showForm: false
|
|
||||||
})
|
|
||||||
|
|
||||||
const showNext = () => {
|
|
||||||
page.showReadme = false
|
|
||||||
setTimeout(() => {
|
|
||||||
page.showForm = true
|
|
||||||
}, 20)
|
|
||||||
}
|
|
||||||
|
|
||||||
const goDoc = () => {
|
|
||||||
window.open('https://www.gin-vue-admin.com/guide/start-quickly/env.html')
|
|
||||||
}
|
|
||||||
|
|
||||||
const out = ref(false)
|
|
||||||
|
|
||||||
const form = reactive({
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'mysql',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '3306',
|
|
||||||
userName: 'root',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
|
|
||||||
const changeDB = (val) => {
|
|
||||||
switch (val) {
|
|
||||||
case 'mysql':
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
reAdminPassword: '',
|
|
||||||
dbType: 'mysql',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '3306',
|
|
||||||
userName: 'root',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
break
|
|
||||||
case 'pgsql':
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'pgsql',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '5432',
|
|
||||||
userName: 'postgres',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: '',
|
|
||||||
template: 'template0'
|
|
||||||
})
|
|
||||||
break
|
|
||||||
case 'oracle':
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'oracle',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '1521',
|
|
||||||
userName: 'oracle',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
break
|
|
||||||
case 'mssql':
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'mssql',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '1433',
|
|
||||||
userName: 'mssql',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
break
|
|
||||||
case 'sqlite':
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'sqlite',
|
|
||||||
host: '',
|
|
||||||
port: '',
|
|
||||||
userName: '',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
Object.assign(form, {
|
|
||||||
adminPassword: '123456',
|
|
||||||
dbType: 'mysql',
|
|
||||||
host: '127.0.0.1',
|
|
||||||
port: '3306',
|
|
||||||
userName: 'root',
|
|
||||||
password: '',
|
|
||||||
dbName: 'gva',
|
|
||||||
dbPath: ''
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const onSubmit = async () => {
|
|
||||||
if (form.adminPassword.length < 6) {
|
|
||||||
ElMessage({
|
|
||||||
type: 'error',
|
|
||||||
message: '密码长度不能小于6位'
|
|
||||||
})
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
const loading = ElLoading.service({
|
|
||||||
lock: true,
|
|
||||||
text: '正在初始化数据库,请稍候',
|
|
||||||
spinner: 'loading',
|
|
||||||
background: 'rgba(0, 0, 0, 0.7)'
|
|
||||||
})
|
|
||||||
try {
|
|
||||||
const res = await initDB(form)
|
|
||||||
if (res.code === 0) {
|
|
||||||
out.value = true
|
|
||||||
ElMessage({
|
|
||||||
type: 'success',
|
|
||||||
message: res.msg
|
|
||||||
})
|
|
||||||
|
|
||||||
// 显示AI助手配置提示弹窗
|
|
||||||
ElMessageBox.confirm(
|
|
||||||
'已经完成基础数据库初始化!建议先进行编辑器AI助手配置,以获得更好的开发体验。',
|
|
||||||
'配置完成',
|
|
||||||
{
|
|
||||||
confirmButtonText: '查看AI配置文档',
|
|
||||||
cancelButtonText: '稍后配置',
|
|
||||||
type: 'success',
|
|
||||||
center: true
|
|
||||||
}
|
|
||||||
)
|
|
||||||
.then(() => {
|
|
||||||
// 点击确认按钮,打开AI配置文档
|
|
||||||
window.open('https://www.gin-vue-admin.com/guide/server/mcp.html', '_blank')
|
|
||||||
router.push({ name: 'Login' })
|
|
||||||
})
|
|
||||||
.catch(() => {
|
|
||||||
// 点击取消按钮或关闭弹窗,直接跳转到登录页
|
|
||||||
router.push({ name: 'Login' })
|
|
||||||
})
|
|
||||||
}
|
|
||||||
loading.close()
|
|
||||||
} catch (_) {
|
|
||||||
loading.close()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.slide-in-fwd-top {
|
|
||||||
-webkit-animation: slide-in-fwd-top 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
|
|
||||||
animation: slide-in-fwd-top 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
|
|
||||||
}
|
|
||||||
.slide-out-right {
|
|
||||||
-webkit-animation: slide-out-right 0.5s cubic-bezier(0.55, 0.085, 0.68, 0.53) both;
|
|
||||||
animation: slide-out-right 0.5s cubic-bezier(0.55, 0.085, 0.68, 0.53) both;
|
|
||||||
}
|
|
||||||
.slide-in-left {
|
|
||||||
-webkit-animation: slide-in-left 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
|
|
||||||
animation: slide-in-left 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
|
|
||||||
}
|
|
||||||
@-webkit-keyframes slide-in-fwd-top {
|
|
||||||
0% {
|
|
||||||
transform: translateZ(-1400px) translateY(-800px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateZ(0) translateY(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@keyframes slide-in-fwd-top {
|
|
||||||
0% {
|
|
||||||
transform: translateZ(-1400px) translateY(-800px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateZ(0) translateY(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@-webkit-keyframes slide-out-right {
|
|
||||||
0% {
|
|
||||||
transform: translateX(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateX(1000px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@keyframes slide-out-right {
|
|
||||||
0% {
|
|
||||||
transform: translateX(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateX(1000px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@-webkit-keyframes slide-in-left {
|
|
||||||
0% {
|
|
||||||
transform: translateX(-1000px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateX(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@keyframes slide-in-left {
|
|
||||||
0% {
|
|
||||||
transform: translateX(-1000px);
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
transform: translateX(0);
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media (max-width: 750px) {
|
|
||||||
.form {
|
|
||||||
width: 94vw !important;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -283,10 +283,6 @@
|
|||||||
)
|
)
|
||||||
|
|
||||||
const initPage = () => {
|
const initPage = () => {
|
||||||
// 全局监听 关闭当前页面函数
|
|
||||||
emitter.on('closeThisPage', () => {
|
|
||||||
removeTab(getFmtString(route))
|
|
||||||
})
|
|
||||||
// 全局监听 关闭所有页面函数
|
// 全局监听 关闭所有页面函数
|
||||||
emitter.on('closeAllPage', () => {
|
emitter.on('closeAllPage', () => {
|
||||||
closeAll()
|
closeAll()
|
||||||
|
|||||||
@@ -56,15 +56,6 @@
|
|||||||
>登 录</el-button
|
>登 录</el-button
|
||||||
>
|
>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<!-- <el-form-item class="mb-6">
|
|
||||||
<el-button
|
|
||||||
class="shadow shadow-active h-11 w-full"
|
|
||||||
type="primary"
|
|
||||||
size="large"
|
|
||||||
@click="checkInit"
|
|
||||||
>前往初始化</el-button
|
|
||||||
>
|
|
||||||
</el-form-item> -->
|
|
||||||
</el-form>
|
</el-form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -73,13 +64,11 @@
|
|||||||
<img class="h-full" src="@/assets/new-background.jpg" alt="banner" />
|
<img class="h-full" src="@/assets/new-background.jpg" alt="banner" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { captcha } from '@/api/user'
|
import { captcha } from '@/api/user'
|
||||||
import { checkDB } from '@/api/initdb'
|
|
||||||
import { reactive, ref } from 'vue'
|
import { reactive, ref } from 'vue'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import { useRouter } from 'vue-router'
|
import { useRouter } from 'vue-router'
|
||||||
@@ -181,20 +170,4 @@
|
|||||||
return true
|
return true
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// 跳转初始化
|
|
||||||
const checkInit = async () => {
|
|
||||||
const res = await checkDB()
|
|
||||||
if (res.code === 0) {
|
|
||||||
if (res.data?.needInit) {
|
|
||||||
userStore.NeedInit()
|
|
||||||
await router.push({ name: 'Init' })
|
|
||||||
} else {
|
|
||||||
ElMessage({
|
|
||||||
type: 'info',
|
|
||||||
message: '已配置数据库信息,无法初始化'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
Reference in New Issue
Block a user