This WordPress starter theme is built on top of Timber and DDEV to provide a robust and flexible foundation for creating modern, maintainable, and performant WordPress websites. It was written by @onemohrtime, with a LOT of inspiration and education from @bgrrtt.
You can also use the WordPress theme alone, without the environment.
- Timber Integration: Leverages the power of the Timber library to separate PHP and HTML, allowing for clean and readable templating using the Twig language.
- DDEV Environment: Easily set up your local development environment with DDEV for a seamless and containerized development experience.
- Semantic HTML: Ensures semantic and accessible HTML markup.
- Responsive Design: Includes a responsive and mobile-friendly design out-of-the-box.
We'll be working with the latest and greatest WordPress templating system, make sure you have:
This project also assumes that you have:
It's highly recommended that you have:
- Git Flow for maintaining git history
- WP-CLI for WordPress shortcuts
- n or NVM for Node version management
git clone git@github.com:OneMohrTime/timber-starter-theme.git
cd timber-starter-theme
I would highly suggest having Git Flow installed as well. There's also a little cheatsheet to explain it.
brew install git-flow # optional
git flow init -d # add the `-d` flag for 'defaults'
Download the latest version of WordPress from the official website. Extract the ZIP file and move the contents into the root of your project directory. We will deal with the wp-config.php
in the DDEV step.
If you have WP-CLI installed, you can quickly download and configure WordPress by running the following commands:
wp core download
# we'll be configuring the environment in DDEV, otherwise you could continue on...
# wp config create --dbname=your_db_name --dbuser=your_db_user --dbpass=your_db_password --dbhost=your_db_host
# wp db create
# wp core install --url="your_site_url" --title="Your Site Title" --admin_user="admin" --admin_password="admin_password" --admin_email="admin_email"
Ensure you have DDEV installed (mine is set up through Docker). If you have a website URL in mind already, alter the first line of .ddev/config.yaml
to be the domain name, without ".com".
name: timber-wordpress # this will become timber-wordpress.ddev.site
Then, run:
ddev start
Your site (with the default WordPress theme) should now be viewable at https://timber-wordpress.ddev.site
. You should also see a wp-config-ddev.php
in the root folder. You can now continue with the WordPress installation.
Make sure you are using the version of Node.js specified in the .n-node-version
or .nvmrc
.
npm install --legacy-peer-deps
*Note: the flag --legacy-peer-deps
is necessary for npm run watch
packages. If you'd like to install without the flag, remove the two browser-sync packages.
"devDependencies": {
"browser-sync": "^X.X.X", # remove
"browser-sync-webpack-plugin": "^X.X.X", # remove
...
}
Some developers prefer to have Timber installed as a theme dependency, so they would run this command from the theme root (ex: /wp-content/themes/my-theme/). I'm one of those developers, so run:
cd wp-content/themes/timber-starter-theme
composer install
# go back to root directory for next commands
cd ../../..
To install ACF Pro, first, download the ZIP file from your ACF account and install it by uploading it on the Plugins page.
Classic Editor is an official plugin maintained by the WordPress team that restores the previous (“classic”) WordPress editor and the “Edit Post” screen. It makes it possible to use plugins that extend that screen, add old-style meta boxes, or otherwise depend on the previous editor.
Classic Widgets is an official plugin maintained by the WordPress team that restores the previous ("classic") WordPress widgets settings screens.
Automate technical SEO and make optimizing content a breeze with the most popular WordPress SEO plugin.
From here, you can compile your assets with:
# Compile, watch for any changes, immediately recompile
npm run watch
# Compile for local environments. Can also be `npm run dev`
npm run development
# Compile for prodcution environments. Can also be `npm run prod` or `npm run build`
npm run production
First, activate the necessary plugins on the Plugins tab.
- Required: Advacnced Custom Fields PRO
- Required: Classic Editor
- Required: Classic Widgets
- Required: Yoast SEO
- Recommended: Google Site Kit
- Recommended: RealFaviconGenerator
- Recommended: Redirection
- Recommended: WordPress Updater
Second, you're going to want to sync the Advanced Custom Fields, from our theme root directory acf-json/
. This can be found within the ACF tab.
Update some of the website's main settings. These are not required, but are recommended—especially if you're going to be uploading this database to production.
- Add a favicon and choose your timezone here
- Set a home page and news/blog page here
- Set thumbnails to 320×320, uncheck crop thumbnails ...,
set medium to 768×768,
uncheck organize media... here - Set permalinks to Post Name, or your own custom configuration here
Activate your new theme in Appearances > Themes.
The missing image placeholder is from the Mackinaw Bridge by fellow NMU Wildcat Riley Crawford