Skip to content

Base template for WordPress setup using Composer, ACF, Timber, and SCSS

Notifications You must be signed in to change notification settings

OneMohrTime/timber-starter-theme

Repository files navigation

OneMohrTime Timber Starter Theme

Overview

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.

Features

  • 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.

Requirements

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

Installation

1. Git the Repository

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'

2. Install WordPress

ZIP Install

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.

WP-CLI Install

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"

3. Set Up DDEV

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.

4. Install Node.js Dependencies

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
    ...
}

5. Install Composer Dependencies

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 ../../..

6. Install the required WordPress plugins

Advanced Custom Fields Pro

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 & Widgets

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.

Yoast SEO

Automate technical SEO and make optimizing content a breeze with the most popular WordPress SEO plugin.

Additional (highly recommended)

7. Build!

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

8. Admin

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.

Additional Credits

The missing image placeholder is from the Mackinaw Bridge by fellow NMU Wildcat Riley Crawford