feat: enhance layout resolution

pull/5176/head
Shigma 2 weeks ago committed by GitHub
parent d7bb03776f
commit 4ee09556b9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -12,8 +12,6 @@ const { isHome, hasSidebar } = useLayout()
function resolveLayout(name: string) {
const component = resolveComponent(name)
// resolveComponent returns the component if registered,
// or the name string if not found
return typeof component === 'string' ? null : component
}
</script>
@ -26,53 +24,41 @@ function resolveLayout(name: string) {
>
<slot name="not-found" v-if="page.isNotFound"><NotFound /></slot>
<template v-else-if="frontmatter.layout === 'page'">
<component v-if="resolveLayout('page')" :is="resolveLayout('page')!" />
<VPPage v-else>
<template #page-top><slot name="page-top" /></template>
<template #page-bottom><slot name="page-bottom" /></template>
</VPPage>
</template>
<VPPage v-else-if="frontmatter.layout === 'page' && !resolveLayout('page')">
<template #page-top><slot name="page-top" /></template>
<template #page-bottom><slot name="page-bottom" /></template>
</VPPage>
<template v-else-if="frontmatter.layout === 'home'">
<component v-if="resolveLayout('home')" :is="resolveLayout('home')!" />
<VPHome v-else>
<template #home-hero-before><slot name="home-hero-before" /></template>
<template #home-hero-info-before><slot name="home-hero-info-before" /></template>
<template #home-hero-info><slot name="home-hero-info" /></template>
<template #home-hero-info-after><slot name="home-hero-info-after" /></template>
<template #home-hero-actions-after><slot name="home-hero-actions-after" /></template>
<template #home-hero-actions-before-actions><slot name="home-hero-actions-before-actions" /></template>
<template #home-hero-image><slot name="home-hero-image" /></template>
<template #home-hero-after><slot name="home-hero-after" /></template>
<template #home-features-before><slot name="home-features-before" /></template>
<template #home-features-after><slot name="home-features-after" /></template>
</VPHome>
</template>
<VPHome v-else-if="frontmatter.layout === 'home' && !resolveLayout('home')">
<template #home-hero-before><slot name="home-hero-before" /></template>
<template #home-hero-info-before><slot name="home-hero-info-before" /></template>
<template #home-hero-info><slot name="home-hero-info" /></template>
<template #home-hero-info-after><slot name="home-hero-info-after" /></template>
<template #home-hero-actions-after><slot name="home-hero-actions-after" /></template>
<template #home-hero-actions-before-actions><slot name="home-hero-actions-before-actions" /></template>
<template #home-hero-image><slot name="home-hero-image" /></template>
<template #home-hero-after><slot name="home-hero-after" /></template>
<template #home-features-before><slot name="home-features-before" /></template>
<template #home-features-after><slot name="home-features-after" /></template>
</VPHome>
<template v-else-if="frontmatter.layout === 'doc' || !frontmatter.layout">
<component v-if="resolveLayout('doc')" :is="resolveLayout('doc')!" />
<VPDoc v-else>
<template #doc-top><slot name="doc-top" /></template>
<template #doc-bottom><slot name="doc-bottom" /></template>
<VPDoc v-else-if="(!frontmatter.layout || frontmatter.layout === 'doc') && !resolveLayout('doc')">
<template #doc-top><slot name="doc-top" /></template>
<template #doc-bottom><slot name="doc-bottom" /></template>
<template #doc-footer-before><slot name="doc-footer-before" /></template>
<template #doc-before><slot name="doc-before" /></template>
<template #doc-after><slot name="doc-after" /></template>
<template #doc-footer-before><slot name="doc-footer-before" /></template>
<template #doc-before><slot name="doc-before" /></template>
<template #doc-after><slot name="doc-after" /></template>
<template #aside-top><slot name="aside-top" /></template>
<template #aside-outline-before><slot name="aside-outline-before" /></template>
<template #aside-outline-after><slot name="aside-outline-after" /></template>
<template #aside-ads-before><slot name="aside-ads-before" /></template>
<template #aside-ads-after><slot name="aside-ads-after" /></template>
<template #aside-bottom><slot name="aside-bottom" /></template>
</VPDoc>
</template>
<template #aside-top><slot name="aside-top" /></template>
<template #aside-outline-before><slot name="aside-outline-before" /></template>
<template #aside-outline-after><slot name="aside-outline-after" /></template>
<template #aside-ads-before><slot name="aside-ads-before" /></template>
<template #aside-ads-after><slot name="aside-ads-after" /></template>
<template #aside-bottom><slot name="aside-bottom" /></template>
</VPDoc>
<component
v-else
:is="frontmatter.layout"
/>
<component v-else :is="frontmatter.layout || 'doc'" />
</div>
</template>

Loading…
Cancel
Save