117 lines
2.6 KiB
Vue
117 lines
2.6 KiB
Vue
<template>
|
|
<el-tabs v-model="activeName" tab-position="left" class="h-[calc(100vh-110px)]">
|
|
<el-tab-pane
|
|
v-for="(item, key) in useCode"
|
|
:key="key"
|
|
:label="key"
|
|
:name="key"
|
|
>
|
|
<div
|
|
:id="key"
|
|
class="h-[calc(100vh-110px)] px-5 overflow-y-scroll"
|
|
></div>
|
|
</el-tab-pane>
|
|
</el-tabs>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { Marked } from "marked";
|
|
import { markedHighlight } from "marked-highlight";
|
|
import hljs from 'highlight.js'
|
|
import { ElMessage } from 'element-plus'
|
|
import { onMounted, ref, watchEffect } from 'vue'
|
|
import {useAppStore} from "@/pinia";
|
|
|
|
const appStore = useAppStore()
|
|
|
|
const useCode = ref({})
|
|
|
|
const createKey = [
|
|
"enter.go",
|
|
"gorm_biz.go",
|
|
"router_biz.go",
|
|
"api",
|
|
"router",
|
|
"initialize",
|
|
"gen.go",
|
|
]
|
|
|
|
onMounted(() => {
|
|
const isDarkMode = appStore.config.darkMode === 'dark';
|
|
if (isDarkMode) {
|
|
import('highlight.js/styles/atom-one-dark.css');
|
|
} else {
|
|
import('highlight.js/styles/atom-one-light.css');
|
|
}
|
|
});
|
|
|
|
const props = defineProps({
|
|
previewCode: {
|
|
type: Object,
|
|
default() {
|
|
return {}
|
|
}
|
|
},
|
|
isAdd: {
|
|
type: Boolean,
|
|
default: false
|
|
}
|
|
})
|
|
|
|
watchEffect(() => {
|
|
for (const key in props.previewCode) {
|
|
if (props.isAdd && createKey.some(createKeyItem => key.includes(createKeyItem))) {
|
|
continue;
|
|
}
|
|
useCode.value[key] = props.previewCode[key]
|
|
}
|
|
})
|
|
|
|
const activeName = ref('')
|
|
onMounted(() => {
|
|
const marked = new Marked(
|
|
markedHighlight({
|
|
langPrefix: 'hljs language-',
|
|
highlight(code, lang, info) {
|
|
const language = hljs.getLanguage(lang) ? lang : 'plaintext';
|
|
if (lang === 'vue') {
|
|
return hljs.highlight(code, { language: 'html' }).value;
|
|
}
|
|
return hljs.highlight(code, { language }).value;
|
|
}
|
|
})
|
|
);
|
|
for (const key in useCode.value) {
|
|
if (activeName.value === '') {
|
|
activeName.value = key
|
|
}
|
|
document.getElementById(key).innerHTML = marked.parse(useCode.value[key])
|
|
}
|
|
})
|
|
|
|
const selectText = () => {
|
|
const element = document.getElementById(activeName.value)
|
|
if (document.body.createTextRange) {
|
|
const range = document.body.createTextRange()
|
|
range.moveToElementText(element)
|
|
range.select()
|
|
} else if (window.getSelection) {
|
|
const selection = window.getSelection()
|
|
const range = document.createRange()
|
|
range.selectNodeContents(element)
|
|
selection.removeAllRanges()
|
|
selection.addRange(range)
|
|
} else {
|
|
alert('none')
|
|
}
|
|
}
|
|
const copy = () => {
|
|
selectText()
|
|
document.execCommand('copy')
|
|
ElMessage.success('复制成功')
|
|
}
|
|
|
|
defineExpose({ copy })
|
|
|
|
</script>
|