Skip to content

A containerized development environment to create a WordPress theme based on the Timber starter theme - uses Bootstrap4, Sass, Browsersync, Gulp build automation and Twig templates, to kick-start your WordPress theme development - Contributions welcome...

Notifications You must be signed in to change notification settings

EarthmanWeb/Docker-WordPress-Timber-Twig-Gulp-theme-generator

Repository files navigation

Getting Started with this repo

System Prerequisites:

At the time of creation this works (on MacOS Mojave) with the following installed:

Docker: version 19.03.13

Composer: version 1.10.13 - Installed globally

Node (installed using Homebrew): version 14.13.0

Yarn: version 1.22.5

Gulp 4: Install globally with Yarn using: yarn global add [email protected]

Git clone:

Clone the repo to your local file system. You know how to do this. If you don't, you're in the wrong place.


WordPress Timber Theme Development

1. Docker WordPress / DB Environment Setup:

In your terminal, navigate to the project directory, then use the commands..

docker-compose up

...not detached from terminal output - view output from all containers - use Ctrl-C to stop all containers

OR

docker-compose up -d && docker attach docker-local-wordpress-dev_wordpress_1

...detaches terminal output from all containers, but then re-attach to the WordPress container to view NGINX server output only

OR

docker-compose up -d

...detaches from all containers (no terminal output) - use command in #6 below to stop


2. Build Theme:

** NOTE: Make sure Docker is running (see #1 above) and wait until all Docker tasks are complete - This could take awhile, go grab a coffee, and then look for the final message:
SUCCESS: WP-CLI setup commands completed.
...THEN:

***If you didn't detach the docker-compose command in Step #1, then you will need to open a new terminal in the project folder to run these commands:

a. Change to app folder: cd app

b. Install node modules: yarn install

c. Run build task: gulp build

...this builds the theme to the /build folder which is also an alias for the WordPress /wp-content/themes/ folder - Don't bother changing these files, they WILL get overwritten by step d. below

After the build task is done, you can jump down to #3 to just view the site, or if you want to start developing, then also...

d. Run watch task: gulp watch

...this will sync your changes to the files in the /app/src folder with browser at localhost:3000 - use Ctrl-C to exit watch task


3. Activate WordPress Theme

a. Log into WP at: http://localhost:8000/wp-admin : admin : p4ssw0rd!

b. Go to: http://localhost:8000/wp-admin/themes.php

c. Click 'activate' on the custom theme


4. Links to local resources:

WordPress frontend:
WordPress Admin
Browsersync admin:
WordPress with browsersync:

5. Build production files

***If you didn't detach the docker-compose command in Step #1, then you will need to open a new terminal in the project folder to run these commands:

a. Change to app folder: cd app

b. Create distribution build: gulp dist

c. Build files will be located in /dist folder


6. Stop Docker Containers:

In the project directory: docker-compose stop


7. Tear down and clean up:

WARNING: THIS WILL DELETE ALL PERSISTENT DATA, CONTAINERS, IMAGES, NETWORKS, AND BUILD FILES

In the project directory: docker-compose down && docker volume prune && docker image prune -a && docker network prune && rm -R ./wp-content && rm -R ./app/node_modules && rm -R ./build && rm -R ./dist

About

A containerized development environment to create a WordPress theme based on the Timber starter theme - uses Bootstrap4, Sass, Browsersync, Gulp build automation and Twig templates, to kick-start your WordPress theme development - Contributions welcome...

Resources

Stars

Watchers

Forks

Packages

No packages published