@dimerapp/docs-theme
The docs theme provides ready to use Edge templates, CSS and frontend JavaScript to create a documentation layout. This package must be used with @dimerapp/content package.
Usage
Install the package from npm packages registry.
npm i @dimerapp/docs-theme
Register the docsTheme
with the edge template engine. The docsTheme
plugin registers a set of templates under the docs
namespace.
Some of the templates relies on the edge-uikit
. So make sure to also and configure the edge-uikit
.
import { Edge } from 'edge.js'
import uiKit from 'edge-uikit'
import { docsTheme } from '@dimerapp/docs-theme'
const edge = new Edge()
edge.use(uiKit)
edge.use(docsTheme)
Once done, you use the following components to render the docs header, sidebar, table of contents and the main content.
@component('docs::header', config)
@slot('logo')
AdonisJS
@end
@slot('logoMobile')
AdonisJS - Mobile logo
@end
@end
<section>
@!component('docs::sidebar', {
collapsible: true,
sections: sidebarSections
})
<main layout-main>
@component('docs::content')
@!component('docs::doc_errors', { messages: file.messages })
@!component('dimer_contents', { nodes: file.ast.children, pipeline })~
@end
@if(file.toc)
@component('docs::toc')
@!component('dimer_element', { node: file.toc, pipeline })~
@end
@end
</main>
</section>
Including styles and scripts
You may import the styles and scripts as follows.
@import '@dimerapp/docs-theme/styles';
import docsearch from '@docsearch/js'
import { initAlpinePlugins, initSearch } from '@dimerapp/docs-theme/scripts'
Alpine.plugin(initAlpinePlugins)
Alpine.plugin(initSearch(docsearch))