
* feat: 自动化代码增加json导出和导入功能 * feat: 自动化代码前端可见分为Table和Form分别选中 * feature: 调整代码预览为左边栏模式的tabs。 * feat: 增加方法自动添加前端api * feat: 自动化生成前端支持详情功能 * feat: 增加自动创建可控权限按钮功能 * fixed: 顶栏样式菜单样式细节bug修复 * fixed: 修改视频地址 * fixed: 自动获取表结构和数据库表列结构保持一致 * fixed: casbin 设置空权限无需调用 AddPolicies 方法 (#1850) * feat:对象存储支持配置Cloudflare R2 (#1849) * fixed:设为首页和菜单勾选互为必选 --------- Co-authored-by: SliverHorn <503551462@qq.com> Co-authored-by: 千石 <CN_QianShi@hotmail.com> * feat: 复杂数据类型的查询将不会生成查询语句,会以string形式接收参数,用户自行实现复杂查询逻辑。 * feat: 创建新角色默认携带字典和长传权限。 禁止删除有首页占用的菜单。 不允许切换至无首页的角色。 自动化代码创建失败将返回错误信息。 * feat: 当package或plugin结构异常时候,阻止创建自动化代码。 --------- Co-authored-by: krank <emosick@qq.com> Co-authored-by: SliverHorn <503551462@qq.com> Co-authored-by: 千石 <CN_QianShi@hotmail.com>
83 lines
1.8 KiB
Vue
83 lines
1.8 KiB
Vue
<template>
|
|
<el-tabs v-model="activeName" tab-position="left" class="h-[calc(100vh-110px)]">
|
|
<el-tab-pane
|
|
v-for="(item, key) in previewCode"
|
|
:key="key"
|
|
:label="key"
|
|
:name="key"
|
|
>
|
|
<div
|
|
:id="key"
|
|
class="h-[calc(100vh-110px)] bg-white px-5 overflow-y-scroll"
|
|
/>
|
|
</el-tab-pane>
|
|
</el-tabs>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { marked } from 'marked'
|
|
import hljs from 'highlight.js'
|
|
import 'highlight.js/styles/atom-one-dark.css'
|
|
import { ElMessage } from 'element-plus'
|
|
import { onMounted, ref } from 'vue'
|
|
|
|
const props = defineProps({
|
|
previewCode: {
|
|
type: Object,
|
|
default() {
|
|
return {}
|
|
}
|
|
}
|
|
})
|
|
|
|
const activeName = ref('')
|
|
onMounted(() => {
|
|
marked.setOptions({
|
|
renderer: new marked.Renderer(),
|
|
highlight: function(code) {
|
|
return hljs.highlightAuto(code).value
|
|
},
|
|
pedantic: false,
|
|
gfm: true,
|
|
tables: true,
|
|
breaks: false,
|
|
sanitize: false,
|
|
smartLists: true,
|
|
smartypants: false,
|
|
xhtml: false,
|
|
langPrefix: 'hljs language-'
|
|
})
|
|
for (const key in props.previewCode) {
|
|
if (activeName.value === '') {
|
|
activeName.value = key
|
|
}
|
|
document.getElementById(key).innerHTML = marked(props.previewCode[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>
|