WP Workflow is a powerful Gulp workflow for making Developing WordPress themes easier and more productive ⌛.
install wp-workflow package globally npm install wp-workflow -g
-
for development:
1- Go to your WP project
wp-content/themes
2- open terminal.
3- runwp-workflow
4- wait untill installing project and answer prompt questions
5- runnpm start
and then start development.
- for production
1- Go to your theme directory.
2- runnpm run build
.
need to work again on it! just run `npm start`
What WP-workflow can do?
- convert sass to css.
- add auto prefixes to css for last 5 versions of browsers "you can edit it in
.browsersistrc
file". - create .map file for css if you are on development mode.
- minify css files and remove .map files while building.
- Compile ES6, and beyond to ES5.
- create .map file for JS if you are on development mode.
- minify js files and remove .map files while building.
- remove console.log and debuggers from JS while building the project.
- Compress static images.
- move compressed static images from src folder to images folder in dest.
- open live server after finish all basic tasks "styles, scripts, images".
- reload server if there is changes in any files or folder.
wp-workflow can prepare your theme for publishing by compressing it in a .zip
file if you want to create that copressed file.
npm run build --prod
.- wait to finish bundling files
- you will be asked for if you want zip file or not choose yes to create copmressd file, "the compressed file will be created in project root".
- if you choose no, wp-workflow will only minify css, js, and images.
If you are working with team in the same project that could be harder if you didn't use clean code guides, and it goes more harder while writing js without any hints in your code and have errors so, wp-workflow foucus on solving these problems by using prettier to standardize the code formating accross the project from developer to another, and by using editor config we try to unificate the basic configurations from editor to another, and to make developing js more easier and prettier as we use eslint to show errors and worning while writing code.
localhost
├── wordpress project
│ └── wp-content
│ ├── themes
│ │ └── theme name
│ │ ├── dest
| | | ├── css
| | | | └──compiled css files
| | | |── js
| | | | └── compiled js files
| | | └── images
| | | └── compiled images
│ | ├── src
│ | | |──sass
│ | | | |── animations
| | | | | └── files.scss
│ | | | |── base
| | | | | └── files.scss
│ | | | |── components
| | | | | |── pages
| | | | | | └── files.scss
| | | | | └── files.scss
│ | | | |── pages
| | | | | └── files.scss
| | | | └── main.scss
| | | ├── scripts
│ | | | |── components
| | | | | |── pages
| | | | | | └── files.js
| | | | | └── files.js
| | | | |── pages
| | | | | └── files.js
| | | | └── main.js
| | | └── images
| | | └── image.png
| | ├── inc
| | | └── php files
| | |
| | ├── templates-parts
| | | └── php files
| | |
| | └── wp templates
| |
│ └── index.php