π¨ DEPRECATION WARNING π¨
Dear Community,
We'd like to share some updates regarding the future maintenance of this repository:
Our team is small, and our availability will be reduced in the upcoming times. As such, we decided to deprecate this repository. This means we won't be updating the package to be compatible with VuePress v2.
We still accept bug fixes from the community but no more enhancements.
Seeking immediate support? Please join us on our Discord channel.
Meilisearch | Meilisearch Cloud | Documentation | Discord | Roadmap | Website | FAQ
β‘ The Meilisearch plugin for VuePress
Meilisearch VuePress is a Meilisearch plugin for VuePress.
Meilisearch is an open-source search engine. Discover what Meilisearch is!
If you don't use VuePress for your documentation, but you still need a search bar, you might check out this front-end SDK.
- β‘ Supercharge your Meilisearch experience
- Usage
- Compatibility with Meilisearch
- Development Workflow and Contributing
- Related Repositories
Say goodbye to server deployment and manual updates with Meilisearch Cloud. No credit card required.
The goal of this plugin is to provide very easy integration of a search bar into your own VuePress documentation. To make that possible, you need to gather your website content in advance, and index it in a Meilisearch instance.
Luckily, we provide all the tools that you need, and can help you through the whole process, if you follow this guide π
As a first introduction, you might only want to test this plugin without connecting it to your website.
You can do it by running the VuePress playground provided in this repository:
yarn install
yarn playground
Then, open your browser on the indicated URL and test the search bar π
The data comes from Meilisearch documentation.
Type create an indxe
to live the Meilisearch experience with the typo tolerance.
In your VuePress project:
yarn add vuepress-plugin-meilisearch
# or
npm install vuepress-plugin-meilisearch
In your config.js
file:
module.exports = {
plugins: [
[
'vuepress-plugin-meilisearch',
{
hostUrl: 'https://mymeilisearch.com',
apiKey: 'XXX',
indexUid: 'docs'
}
]
]
}
WARNING: Since the configuration file is public, we recommend providing the Meilisearch public key, which is enough to perform searches.
Read more about Meilisearch authentication.
module.exports = {
plugins: [
[
'vuepress-plugin-meilisearch',
{
hostUrl: 'https://mymeilisearch.com', // Mandatory
apiKey: 'XXX', // Mandatory
indexUid: 'docs-test', // Mandatory
placeholder: 'Search as you type...', // Default: ""
maxSuggestions: 10, // Default: 5
hotKeys: [], // Default: ['s', '/']
cropLength: 50, // Default: 30
layout: 'simple', // Default: "columns"
debug: true, // Default: false
enableDarkMode: 'auto' // Default: false
}
]
]
}
You can enable dark mode by adding enableDarkMode: 'auto'
to your configuration file.
To override the default theme of the search bar, you can edit your .vuepress/styles/palette.styl
file.
A few variables are available:
$accentDarkColor
$inputDarkBgColor
$textDarkColor
$borderDarkColor
$dropdownBgDarkColor
You can also find an example in our playground's palette.styl
file
This package guarantees compatibility with version v1.x of Meilisearch, but some features may not be present. Please check the issues for more info.
Any new contribution is more than welcome in this project!
If you want to know more about the development workflow or want to contribute, please visit our contributing guidelines for detailed instructions!
- docs-searchbar.js: the library used to display the dropdown of this plugin. It can be useful if you want a search bar for your documentation but you don't use VuePress.
- docs-scraper: the scraper used to scrap websites pages and automatically index the content in Meilisearch.
Meilisearch provides and maintains many SDKs and Integration tools like this one. We want to provide everyone with an amazing search experience for any kind of project. If you want to contribute, make suggestions, or just know what's going on right now, visit us in the integration-guides repository.