33 lines
1.1 KiB
TypeScript
33 lines
1.1 KiB
TypeScript
import type { ClientConfig } from 'vuepress/client'
|
|
import { defineMermaidConfig } from '@vuepress/plugin-markdown-chart/client'
|
|
import { defineAsyncComponent, h } from 'vue'
|
|
import { Layout } from 'vuepress-theme-plume/client'
|
|
import VPPostItem from 'vuepress-theme-plume/components/Posts/VPPostItem.vue'
|
|
import PageContextMenu from 'vuepress-theme-plume/features/PageContextMenu.vue'
|
|
import { defineClientConfig } from 'vuepress/client'
|
|
import AsideNav from '~/components/AsideNav.vue'
|
|
import { setupThemeColors } from '~/composables/theme-colors.js'
|
|
|
|
defineMermaidConfig({
|
|
class: {
|
|
hideEmptyMembersBox: true,
|
|
},
|
|
look: 'handDrawn',
|
|
})
|
|
|
|
export default defineClientConfig({
|
|
enhance({ app }) {
|
|
app.component('VPPostItem', VPPostItem)
|
|
app.component('TintPlate', defineAsyncComponent(() => import('vuepress-theme-plume/components/background/TintPlate.vue')))
|
|
},
|
|
setup() {
|
|
setupThemeColors()
|
|
},
|
|
layouts: {
|
|
Layout: h(Layout, null, {
|
|
'aside-outline-after': () => h(AsideNav),
|
|
'doc-title-after': () => h(PageContextMenu),
|
|
}),
|
|
},
|
|
}) as ClientConfig
|