Caution
This Theme is under development
This is a simple Bootstrap based theme with 3 layouts and an optional sidebar. This theme has a light and a dark mode.
This package contains these simplified templates that only serve demonstrational purposes:
- The
page.php
template represents a basic page with a navbar, a content area and a sidebar with menu. - The
post.php
template contains a filterable and sortable pagelist that can be used as a skeleton for blogs or portfolios. - The
blog.php
template demonstrates the usage of session variables and theset
function.
Also included is a navbar with some options
☝️ To see those templates in action while playing around just apply them to any page in your installation!
This template detecte the operation system prefert dark or light mode and use it.
<script>
(function () {
const htmlElement = document.querySelector("html")
if(htmlElement.getAttribute("data-bs-theme") === 'auto') {
function updateTheme() {
document.querySelector("html").setAttribute("data-bs-theme",
window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light")
}
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', updateTheme)
updateTheme()
}
})();
</script>
You can disable the feature in the settings.
-
It's a good practice to start developing a new package outside of the Automad packages directory. Therefore change to some directory outside of Automad where you want to develop your new theme. Let's assume you want to put your package into a directory called
dev
within your home folder.cd ~/dev
-
Create new skeleton theme in your
dev
directory using Composer.composer create-project automad/theme-skeleton my-theme
-
Change to the new theme directory and edit the
composer.json
andtheme.json
files. VS Code is used here as the editor. At least change the vendor and theme name.cd my-theme code composer.json
Also edit the name in
theme.json
.code theme.json
-
Now change to your Automad root directory. For example
~/Sites/automad-site
.cd ~/Sites/automad-site
-
Edit the
composer.json
file of the Automad installation.code composer.json
Add the following snippet to Automad's composer file (note the path to your package).
{ ... "repositories": [ { "type": "path", "url": "~/dev/my-theme" } ], ... }
-
Still in the Automad directory run the following Composer command.
composer require my-vendor/my-theme:@dev
Now your theme is available in Automad and you can start developing your templates. After all the setup it's now time to create a repository for your theme.
When developing is done, it's time to publish your work.
-
Init new Git repository and commit files.
cd ~/dev/my-theme git init git add . git commit -m "First commit"
-
Create a first release tag for your finished theme following the semantic versioning scheme.
git tag -a 1.0.0 -m "my version 1.0.0"
-
Create a new repository on GitHub.
-
Now, add its URL as a remote to your local repository and push changes. When creating a repository, the URL will be printed on the GitHub page.
git remote add origin /remote/URL/of/your/new/repo git push -u origin master
Now it's time to submit your theme package to Packagist. After succseffuly registering it, it will automatically show up in the package browser.
In case you prefer to start developing a theme or extension without reading the full documention, the Cheat Sheets are a good point to start.