Create a SQLite database containing data posts from your local pelican files.
pip install pelican-to-sqlite
Once the plugin has been installed you only need to run make html
to create a SQLite database called pelican.db
which will be created in the root of your pelican site.
You will need to add a form to your base.html
template (or similar template depending on your theme). The form that needs to be added looks like this (assuming you use Tailwind):
<section class="relative h-8">
<section class="absolute inset-y-0 right-10 w-128">
<form
class = "pl-4"
<
action="your-action-link-here"
method="get">
<label for="site-search">Search the site:</label>
<input type="search" id="site-search" name="text"
aria-label="Search through site content">
<button class="rounded-full w-16 hover:bg-blue-300">Search</button>
</form>
</section>
In the above, your-action-link-here
should be substituted for the link that you get from your Vercel hosted instance of datasette
.
There are many options to deploy your SQLite database with datasette
. Below describes using Vercel.
First, install datasette
using pip
pip install datasette
Next, install the datasette plugin datasette-publish-vercel
using pip
pip install datasette-publish-vercel
and the Vercel CLI
Once that's done, run vercel login
to login to (or create) an account.
To publish your pelican.db
to Vercel just run:
datasette publish vercel my-database.db
There are several options for outputting to Vercel. See the documentation for more details
The SQLite database produced by this tool is designed to be browsed using Datasette. See my post Adding Search to My Pelican Blog with Datasette for more details on how I implemented it.