Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bymattlee/bymattlee-wp-starter-theme

A starter boilerplate WordPress theme powered by Gulp, Tailwind CSS, rollup.js, Alpine.js and Highway.
https://github.com/bymattlee/bymattlee-wp-starter-theme

alphinejs babel boilerplate browsersync es6 gulp highwayjs js modules rollup scss-files starter-wordpress-theme tailwindcss utility-classes wordpress yarn

Last synced: 2 months ago
JSON representation

A starter boilerplate WordPress theme powered by Gulp, Tailwind CSS, rollup.js, Alpine.js and Highway.

Awesome Lists containing this project

README

        

[![ByMattLee](http://hosted.bymattlee.com/github/bymattlee-logo.png)](http://bymattlee.com)

# ByMattLee WP Starter Theme

A starter boilerplate WordPress theme featuring [Gulp](https://gulpjs.com/), [Tailwind CSS](https://tailwindcss.com/), [rollup.js](https://rollupjs.org/), [Alpine.js](https://alpinejs.dev/) and [Taxi.js](https://taxi.js.org/).

---

## Installation

##### 1. Install Node 16.17.1 LTS:

##### 2. Install Yarn:

##### 3. Install all dependencies

```
$ yarn
```

---

## Configuration

##### Update Gulp Config

All Gulp settings can be found in `gulpfile.babel.js/config.js`. To connect BrowserSync to the local development environment to enable browser reload, update `browserSync.proxy` to local development address.

---

## Use

##### Build Files For Development And Initialize Watch

```
$ yarn dev
```

##### Build Files For Staging

```
$ yarn stage
```

##### Build Files For Production

```
$ yarn prod
```

---

## General Features

- Features [Gulp](https://gulpjs.com/) as the build pipeline that compiles styles and scripts, and optimizes assets
- Browser reload when PHP, JS, image, SVG or asset files are updated
- Styles are injected when SCSS files are updated

##### WordPress

- Includes base WordPress template files and optimized theme setup
- Advanced Custom Fields PRO plugin is recommended to create custom fields and Option pages. Default settings can be imported from `acf-global-options.json`

##### Styles

- Features [Tailwind CSS](https://tailwindcss.com/), a utility-first framework
- Includes linter (Stylelint), autoprefixer, minification and sourcemap creation
- SCSS files are located in `assets/src/scss`
- `main.scss` in `assets/src/scss` serves as the base that includes the other dependent SASS files
- `main.scss` gets compiled to `assets/dist/css/main.min.css`
- `.stylelintrc` contains the settings for Stylelint
- Info about class namespacing can be found in `src/assets/scss/main.scss`
- Unused CSS (PurgeCSS) will be removed in staging and production builds

##### Scripts

- Features [rollup.js](https://rollupjs.org/guide/en/) as the module bundler
- Includes linting (ESLint), concatenation, minification and sourcemap creation
- Includes [Taxi.js](https://taxi.js.org/) for seamless page transitions
- Includes a custom framework for reuseable content animations
- Includes [Alpine.js](https://alpinejs.dev/) for declarative DOM manipulation
- `main.js` in `src/assets/js` serves as the main JS file that includes and runs all components and will be compiled to `dist/assets/js/main.min.js`
- All local components should be placed in `src/assets/js/components`
- All vendor JS can be manually added to `src/assets/js/vendors` if not found on Yarn
- `.eslintrc` contains the settings for ESLint

##### Images

- Place all unoptimized images in the `assets/src/images` directory
- They will then be optimized and placed in `assets/dist/images`

##### SVGS

- Place all SVG files in the `assets/src/svg` directory
- They will then be optimized and added to a sprite at `assets/dist/svg/sprite.svg`

##### Other Assets

- All assets (fonts, videos, swfs, etc) under `assets/src` will be copied to `assets/dist` on build

---

## Tailwind CSS Notes

- All Tailwind settings can be found in `./tailwind.config.js`
- Most styles should be written as utility classes in the template markup but custom SCSS can be used for unique properties and/or magic numbers
- Utilize the [`@apply`](https://tailwindcss.com/docs/functions-and-directives#apply) directive when writing custom SCSS for efficiency:

```scss
svg {
@apply u-inline-block u-fill-current;
}
```

- Tailwind settings can be accessed with the [`theme()`](https://tailwindcss.com/docs/functions-and-directives#theme) function:

```scss
.button {
animation-duration: theme('transitionDuration.normal');
}
```

- Media queries can be used with the shorthand `screen()` function:

```scss
.button {
margin-right: 2.8rem;
@screen sm {
margin-right: 4.2rem;
}
}
```

---

## Contact

- Matt Lee - `@bymattlee` on most platforms
- Visit my website at [bymattlee.com](https://bymattlee.com)

[![Twitter Follow](https://img.shields.io/twitter/follow/bymattlee?style=social)](https://twitter.com/bymattlee)