Skip to content

WordPress starter theme with Timber, Tailwind, and Alpine.js.

License

Notifications You must be signed in to change notification settings

netm/jackpine

 
 

Repository files navigation

Jackpine Logo

Jackpine

Release License Last Commit Issues Gitter

Jackpine is a WordPress starter theme based on Timber with modern developer tooling.

We love WordPress 💖. It's how many of us got our start. However, it's an old content management system, and efforts to keep things backwards-compatible have meant that developers had to put up with a subpar experience. Recently, theme frameworks like Gantry, Genesis, and Timber have breathed new life into the theme development space. We think Jackpine is the next step.

When you develop a theme based on Jackpine, you get the following setup out-of-the-box:

  • Timber, a library that lets you create WordPress templates using the Twig templating engine
  • Tailwind CSS for rapidly building beautiful designs
  • Alpine.js for adding reactivity to your frontend
  • wpack.io, an awesome tool for asset bundling with Webpack and live reloading with Browsersync (designed specifically for WordPress)
  • Composer and Yarn for modern dependency management

Because Jackpine is based on Timber, you have access to all of their helper classes. As a bonus, Timber plays nice with Advanced Custom Fields, allowing you to build themes for complex use cases.

Jackpine is a great starting point for any WordPress developer or team who is looking to create themes quicker and easier using a modern workflow. It's deliberately opinionated when it comes to tooling, with deliberately unopinionated base styling (so you can build whatever you want on top of it).

Jackpine is 100% free and open source and released under the MIT license.

🏗 Installation

Installing and configuring Jackpine for local development is pretty straightforward:

  1. Clone the repository (or download the zip and extract it) into your wp-content/themes directory. Feel free to rename the folder to whatever you want for your site. Note: If you rename the theme folder, make sure to also change the slug option in the wpack.io config to match.
  2. In the console, run composer install and yarn install to install your dependencies.
  3. Configure the wpack.io server by running yarn run bootstrap and answering the questions.
  4. Activate your theme in the WordPress admin panel by going to Appearance > Themes.

Now you're set to build your theme!

🔨Development

The old way of developing a WordPress theme involved mixing HTML elements with PHP business logic. Timber separates those concerns through the use of Twig template files.

  • Modify the appearance of pages by editing the Twig files.
  • Style HTML elements by making use of Tailwind CSS's utility classes.
  • Add reactivity to components with Alpine.js.

To create page-specific templates, simply create a Twig file in the templates/pages directory called page-{slug}.twig, where slug is the title of your page. The template file will automatically be detected and applied.

Otherwise, the PHP files function just as they would in any other WordPress theme.

style.css is used only for your theme metadata.

Throughout the theme development process, you'll want to consult the docs for Timber, Twig, Tailwind CSS, Alpine.js, and wpack.io.

🖥 Development Server

Just run yarn run start to start the development server. You can tell wpack to manually recompile by pressing "r" at any time. Pressing "q" will force-quit.

Browsersync will expose an IP address that can be used by other devices on your network. This is really useful for previewing how your site will look on different-sized devices.

🚀 Deployment

To package your finished theme for deployment:

  1. Build your production assets bundle by running yarn run build.
  2. Run yarn run archive to create a zip file of your theme.
  3. Locate the zip file in the package directory and upload it to your server.

Advanced:

If you have additional files that need to go in the zip file that wpack generates, you can specify them in the packageFiles section of your wpackio.project.js file.

Tailwind CSS includes PurgeCSS. It's set up to check your Twig files and detect which classes you've used, and include only the necessary ones in your production bundle. You can adjust these settings in tailwind.config.js.

💖 Contributing

If you're interested in contributing to Jackpine as an open source project, feel free to check out our Contributor Guidelines and jump in! You can support Jackpine in other ways, too, like:

⭐ Starring this project in GitHub

🤝 Sharing themes you've built with Jackpine with us, so we can showcase them

🐥 Tweeting about Jackpine and mentioning it to your friends and colleagues

🧙‍♂️ Answering questions in GitHub issues the support channel on our Gitter


🌲 Jackpine was originally created by Aedon Tanner and Dylan Layne Tanner of 45° North Ventures.

Special thanks goes to the creators of Timber, Tailwind CSS, Alpine.js, and wpack.io for their awesome work.

About

WordPress starter theme with Timber, Tailwind, and Alpine.js.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 45.1%
  • Twig 43.6%
  • JavaScript 9.5%
  • CSS 1.3%
  • SCSS 0.5%