增加 swagger、druid、skywalking、admin 的自定义路径
parent
1ba37bfca4
commit
789ac414e9
|
@ -1,45 +1,37 @@
|
||||||
<template>
|
<template>
|
||||||
<ContentWrap title="数据库文档">
|
<ContentWrap title="数据库文档">
|
||||||
<!-- 操作工具栏 -->
|
|
||||||
<div class="mb-10px">
|
<div class="mb-10px">
|
||||||
<XButton
|
<el-button type="primary" plain @click="handleExport('HTML')">
|
||||||
type="primary"
|
<Icon icon="ep:download" /> 导出 HTML
|
||||||
preIcon="ep:download"
|
</el-button>
|
||||||
:title="t('action.export') + ' HTML'"
|
<el-button type="primary" plain @click="handleExport('Word')">
|
||||||
@click="handleExport('HTML')"
|
<Icon icon="ep:download" /> 导出 Word
|
||||||
/>
|
</el-button>
|
||||||
<XButton
|
<el-button type="primary" plain @click="handleExport('Markdown')">
|
||||||
type="primary"
|
<Icon icon="ep:download" /> 导出 Markdown
|
||||||
preIcon="ep:download"
|
</el-button>
|
||||||
:title="t('action.export') + ' Word'"
|
|
||||||
@click="handleExport('Word')"
|
|
||||||
/>
|
|
||||||
<XButton
|
|
||||||
type="primary"
|
|
||||||
preIcon="ep:download"
|
|
||||||
:title="t('action.export') + ' Markdown'"
|
|
||||||
@click="handleExport('Markdown')"
|
|
||||||
/>
|
|
||||||
</div>
|
</div>
|
||||||
<IFrame v-if="!loding" v-loading="loding" :src="src" />
|
<IFrame v-if="!loading" v-loading="loading" :src="src" />
|
||||||
</ContentWrap>
|
</ContentWrap>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts" name="DbDoc">
|
<script setup lang="ts" name="DbDoc">
|
||||||
import download from '@/utils/download'
|
import download from '@/utils/download'
|
||||||
|
|
||||||
import * as DbDocApi from '@/api/infra/dbDoc'
|
import * as DbDocApi from '@/api/infra/dbDoc'
|
||||||
|
|
||||||
const { t } = useI18n() // 国际化
|
const loading = ref(true) // 是否加载中
|
||||||
const src = ref('')
|
const src = ref('') // HTML 的地址
|
||||||
const loding = ref(true)
|
|
||||||
/** 页面加载 */
|
/** 页面加载 */
|
||||||
const init = async () => {
|
const init = async () => {
|
||||||
const res = await DbDocApi.exportHtmlApi()
|
try {
|
||||||
let blob = new Blob([res], { type: 'text/html' })
|
const data = await DbDocApi.exportHtmlApi()
|
||||||
let blobUrl = window.URL.createObjectURL(blob)
|
const blob = new Blob([data], { type: 'text/html' })
|
||||||
src.value = blobUrl
|
src.value = window.URL.createObjectURL(blob)
|
||||||
loding.value = false
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 处理导出 */
|
/** 处理导出 */
|
||||||
const handleExport = async (type: string) => {
|
const handleExport = async (type: string) => {
|
||||||
if (type === 'HTML') {
|
if (type === 'HTML') {
|
||||||
|
@ -55,6 +47,8 @@ const handleExport = async (type: string) => {
|
||||||
download.markdown(res, '数据库文档.md')
|
download.markdown(res, '数据库文档.md')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** 初始化 */
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
await init()
|
await init()
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,9 +1,23 @@
|
||||||
<template>
|
<template>
|
||||||
<ContentWrap>
|
<ContentWrap>
|
||||||
<IFrame :src="src" />
|
<IFrame v-if="!loading" :src="url" />
|
||||||
</ContentWrap>
|
</ContentWrap>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts" name="Druid">
|
<script setup lang="ts" name="Druid">
|
||||||
const BASE_URL = import.meta.env.VITE_BASE_URL
|
import * as ConfigApi from '@/api/infra/config'
|
||||||
const src = ref(BASE_URL + '/druid/index.html')
|
|
||||||
|
const loading = ref(true) // 是否加载中
|
||||||
|
const url = ref(import.meta.env.VITE_BASE_URL + '/druid/index.html')
|
||||||
|
|
||||||
|
/** 初始化 */
|
||||||
|
onMounted(async () => {
|
||||||
|
try {
|
||||||
|
const data = await ConfigApi.getConfigKey('url.druid')
|
||||||
|
if (data && data.length > 0) {
|
||||||
|
url.value = data
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,9 +1,23 @@
|
||||||
<template>
|
<template>
|
||||||
<ContentWrap>
|
<ContentWrap>
|
||||||
<IFrame :src="src" />
|
<IFrame v-if="!loading" v-loading="loading" :src="src" />
|
||||||
</ContentWrap>
|
</ContentWrap>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts" name="AdminServer">
|
<script setup lang="ts" name="AdminServer">
|
||||||
const BASE_URL = import.meta.env.VITE_BASE_URL
|
import * as ConfigApi from '@/api/infra/config'
|
||||||
const src = ref(BASE_URL + '/admin/applications')
|
|
||||||
|
const loading = ref(true) // 是否加载中
|
||||||
|
const src = ref(import.meta.env.VITE_BASE_URL + '/admin/applications')
|
||||||
|
|
||||||
|
/** 初始化 */
|
||||||
|
onMounted(async () => {
|
||||||
|
try {
|
||||||
|
const data = await ConfigApi.getConfigKey('url.spring-boot-admin')
|
||||||
|
if (data && data.length > 0) {
|
||||||
|
src.value = data
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,8 +1,23 @@
|
||||||
<template>
|
<template>
|
||||||
<ContentWrap>
|
<ContentWrap>
|
||||||
<IFrame :src="src" />
|
<IFrame v-if="!loading" v-loading="loading" :src="src" />
|
||||||
</ContentWrap>
|
</ContentWrap>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts" name="Skywalking">
|
<script setup lang="ts" name="Skywalking">
|
||||||
|
import * as ConfigApi from '@/api/infra/config'
|
||||||
|
|
||||||
|
const loading = ref(true) // 是否加载中
|
||||||
const src = ref('http://skywalking.shop.iocoder.cn')
|
const src = ref('http://skywalking.shop.iocoder.cn')
|
||||||
|
|
||||||
|
/** 初始化 */
|
||||||
|
onMounted(async () => {
|
||||||
|
try {
|
||||||
|
const data = await ConfigApi.getConfigKey('url.skywalking')
|
||||||
|
if (data && data.length > 0) {
|
||||||
|
src.value = data
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -4,7 +4,21 @@
|
||||||
</ContentWrap>
|
</ContentWrap>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts" name="Swagger">
|
<script setup lang="ts" name="Swagger">
|
||||||
const BASE_URL = import.meta.env.VITE_BASE_URL
|
import * as ConfigApi from '@/api/infra/config'
|
||||||
// const src = ref(BASE_URL + '/doc.html')
|
|
||||||
const src = ref(BASE_URL + '/swagger-ui')
|
const loading = ref(true) // 是否加载中
|
||||||
|
const src = ref(import.meta.env.VITE_BASE_URL + '/doc.html') // Knife4j UI
|
||||||
|
// const src = ref(import.meta.env.VITE_BASE_URL + '/swagger-ui') // Swagger UI
|
||||||
|
|
||||||
|
/** 初始化 */
|
||||||
|
onMounted(async () => {
|
||||||
|
try {
|
||||||
|
const data = await ConfigApi.getConfigKey('url.swagger')
|
||||||
|
if (data && data.length > 0) {
|
||||||
|
src.value = data
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
Loading…
Reference in New Issue