Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pixelandtonic/vuepress-theme-craftdocs
VuePress theme for Craft CMS documentation
https://github.com/pixelandtonic/vuepress-theme-craftdocs
Last synced: about 1 month ago
JSON representation
VuePress theme for Craft CMS documentation
- Host: GitHub
- URL: https://github.com/pixelandtonic/vuepress-theme-craftdocs
- Owner: pixelandtonic
- License: mit
- Created: 2018-05-07T22:10:21.000Z (over 6 years ago)
- Default Branch: develop
- Last Pushed: 2022-12-05T20:46:21.000Z (about 2 years ago)
- Last Synced: 2024-09-19T17:47:58.069Z (3 months ago)
- Language: Vue
- Size: 438 KB
- Stars: 107
- Watchers: 7
- Forks: 15
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-starred - pixelandtonic/vuepress-theme-craftdocs - VuePress theme for Craft CMS documentation (others)
README
# Craft Documentation Theme for VuePress
This is the [VuePress](https://vuepress.vuejs.org/) theme used for [Craft CMS documentation](https://docs.craftcms.com/).
It makes the following changes over the default VuePress theme:
- Adds support for [code language toggles](#code-toggles) and [split page views](#split-views).
- Disables [interpolation](https://vuepress.vuejs.org/guide/using-vue.html#interpolation) for all inline `` tags.
- Improves `` styling.
- Adds `themeConfig` options to tweak sidebar sizing: `smallerSidebarHeadings` and `widerSidebar`. (Each `false` by default.)## Setup
1. [Install](https://vuepress.vuejs.org/guide/getting-started.html) VuePress like normal
2. Require this theme```
yarn add -D vuepress-theme-craftdocs # or npm install -D vuepress-theme-craftdocs
```3. Set these things in `.vuepress/config.js`:
```js
module.exports = {
// ...
theme: "craftdocs",
themeConfig: {
// ...
codeLanguages: {
php: "PHP",
twig: "Twig",
// any other code language labels you want to include in code toggles...
},
},
markdown: {
anchor: { level: [2, 3] },
extendMarkdown(md) {
let markup = require("vuepress-theme-craftdocs/markup");
md.use(markup);
},
},
};
```## Code Toggles
You can create code toggles by wrapping multiple fenced code blocks with a `code` container:
````markdown
::: code```php
echo "Hey, $name";
``````twig
Hey, {{ name }}
```:::
````By default, toggle labels will be pulled from the value in `themeConfig.codeLanguages` that matches the code block’s language. If you want to provide a custom label instead, just type it after the code block language:
````markdown
::: code```php Craft 2
$success = craft()->entries->saveEntry($entry);
``````php Craft 3
$success = Craft::$app->elements->saveElement($entry);
```:::
````
## Split ViewsYou can create split view pages by adding `split: true` to your page’s frontmatter:
```yaml
---
split: true
---
```In split view, any content that contains a horizontal rule (`---`) will be divided into `left` and `right` portions, starting and ending at the closest H2/H3 headings.
```markdown
## Cool HeadingsLeft-side content
---
Right-side content
```In split view, code toggles can share a single page-wide toggle UI, floated at the top of the right-hand content pane. To do this, add a `code` list to your page’s frontmatter:
```yaml
---
split: true
code:
- php
- twig
---
```(Use the same language handles defined by `themeConfig.codeLanguages` in `.vuepress/config.js`.)
## Upgrading from v1.3.x
1. Follow the VuePress [Migration from 0.x](https://vuepress.vuejs.org/miscellaneous/migration-guide.html) guide.
2. Update any custom styles that relied on `.content` to reference `.theme-default-content` instead.
3. If you’re using Algolia DocSearch, make sure your index configuration’s selectors are still valid.