⚡️ GITHUB: ★ 1767 ⑂ 303 →
📟 Learn to build CLI DevTools, like WPGulp with me at NodeCLI.com.
[![GitHub](https://img.shields.io/wordpress/v/akismet.svg?colorA=D14543&colorB=21759B&maxAge=2592000&style=flat&label=WordPress)](https://github.com/ahmadawais/WPGulp/) [![emoji-log](https://img.shields.io/badge/🚀%20Emoji-Log-gray.svg?colorA=D14543&colorB=21759B&style=flat)](https://github.com/ahmadawais/Emoji-Log/) [![GitHub stars](https://img.shields.io/github/stars/ahmadawais/WPGulp.svg?style=social&label=Stars)](https://github.com/ahmadawais/WPGulp/stargazers) [![GitHub followers](https://img.shields.io/github/followers/ahmadawais.svg?style=social&label=Follow)](https://github.com/ahmadawais?tab=followers) [![Tweet for help](https://img.shields.io/twitter/follow/mrahmadawais.svg?style=social&label=Tweet%20@MrAhmadAwais)](https://twitter.com/mrahmadawais/) [![VSCode.pro](https://img.shields.io/badge/Supported%20by-VSCode%20Power%20User%20Course%20%E2%86%92-gray.svg?colorA=D14543&colorB=21759B)](https://VSCode.pro "This open source project is supported by VSCode.pro")
WPGulp (WordPress Gulp) 🎯 An advanced & extensively documented Gulp WordPress workflow. Kick-start a build-workflow for your WordPress plugins and themes with Gulp. |
|
A FOSS (Free & Open Source Software) project. Maintained by @AhmadAwais. |
THAT™
WPGulp
is an advanced & extensively documented Gulp.js
+ WordPress
workflow. It can help you kick-start a build-workflow for your WordPress plugins and themes with Gulp.js
, save you a lot of grunt work time, follow the DRY (Don't Repeat Yourself) principle, and #0CJS
Zero-config JavaScript startup but still configurable via wpgulp.config.js
file. It is:
💻 DEV ENVIRONMENT
- Live reload browser with BrowserSync
- Hotloading styles with CSS Injection
🎨 STYLES
- Sass to CSS conversion
- Merging media queries
- Error handling
- Auto-prefixing
- Minification
- Sourcemaps
🌋 JavaScript
- Concatenation
- Minification/uglification
- Separate vendor and custom JS files handling
🌁 IMAGES
- Minification/optimization of images
- File types:
.png
,.jpg
,.jpeg
,.gif
,.svg
💯 TRANSLATION
- Generates
.pot
translation file for i18n and l10n
👀 WATCHING
- For changes in files to recompile
- File types:
.css
,.html
,.php
,.js
Run step #1
, #2
, and #3
quickly in one go — Run inside local WP install's theme/plugin folder E.g. /wp.local/wp-content/plugins/your-plugin
or /wp.local/wp-content/themes/your-theme
directory.
# 1— Install WPGulp in your WordPress theme/plugin.
npx wpgulp
# 2— Now configure variables inside the `wpgulp.config.js` file.
# 3— Start your npm build workflow.
npm start
(npx is a package runner tool that comes with npm 5.2+ and higher).
🎛 If you want to study the detailed installation of step
#1
,#2
, and#3
— then take a look at the steps below.
STEP #0
— Don't have Node.js
+ npm
installed? Read this. (CLICK TO EXPAND!)STEP #1
— Download the Required FilesIt'll take a couple of minutes to install.
npx wpgulp
(npx is a package runner tool that comes with npm 5.2+ and higher).
⚠️ I'm assuming that there are no previously present similar files in the root of your folder. Otherwise, you need to merge these very carefully. E.g. You can include the
scripts
,devDependencies
in your currentpackage.json
file and so on for other files. If you run the above command all similar files will be overwritten.
STEP #2
— Editing the Project VariablesConfigure the project paths and other variables inside the wpgulp.config.js
file. This is a compulsory step.
STEP #3
— Start your projectOnce the installation is done, you can open your project (WordPress plugin/theme) folder and run the start script.
npm start
# To stop press CTRL (⌃) + C
OPTIONAL STEP #4
— More Scripts/TasksTo optimize images and generate WP POT translation file, or generate a RTL stylesheet you can run the following commands
# To optimize images.
npm run images
# To generate WP POT translation file.
npm run translate
# To generate RTL stylesheets and Sourcemap.
npm run styles-rtl
# To generate theme/plugin zip file without extranious files.
npm run zip
npx install-wpgulp
it will overwrite all the wpgulp files.npm install
commands in the root folder of your WordPress plugin/theme.Read what's 📦 new, 👌 improved, 🐛 fixed, and if 📖 docs got updated.
👉 Go read the entire changelog at this link — WPGulp Changelog →
Nothing's ever complete, so bear with us while we keep iterating towards a better future.
'Coz every night I lie in bed The brightest colors fill my head A million dreams are keeping me awake I think of what the world could be A vision of the one I see A million dreams is all it's gonna take A million dreams for the world we're gonna make ...
... listen to → A million dreams!
Me (Ahmad Awais) and my incredible wife (Maedah Batool) are two engineers who fell in love with open source and then with each other. You can read more about me here. If you or your company use any of my projects or like what I’m doing then consider backing me. I'm in this for the long run. An open-source developer advocate.
This repository is part of the NodeCLI.com course.
After building hundreds of developer automation tools used by millions of developers, I am sharing exactly how you can do it yourself with minimum effective effort. Learn to build Node.js & JavaScript based CLI (Command Line Interface) apps. Automate the grunt work, do more in less time, impress your manager, and help the community. → I'm sharing it all in this online video course. Node CLI Automation without wasting a 1,000 hours →
This open source project is maintained by the help of awesome businesses listed below. What? Read more about it →
MIT © Ahmad Awais.
This project is inspired by the work of many awesome developers especially those who contribute to this project, Gulp.js, Babel, and many other dependencies as listed in the package.json
file. FOSS (Free & Open Source Software) for the win.
ahmadawais | MaedahBatool | akmur | marianrick | asharirfan | JeremyEnglert |
ajitbohra | noplanman | cdils | selrond | EugenioPetulla | FrankM1 |
isaacdanielanderson | JeffMatson | AdnanMuhib | mauryaratan | richtabor | saqibameen |
slushman |
You must be logged in to post a comment.
says:
This repository is awesome. Thank you for sharing and maintaining it!
says:
Glad you liked it, Kevin. More to come 🙂
says:
Great work. Thanks for sharing it with us!
says:
Glad you liked it. That’s very kind of you to say! 💯
says:
Thanks for the post .. a query it is possible for Browser-Sync to run domains on the server example: “http //: franzarmas.com” ??? Or does it only work locally ???
says:
You can read about that in its official documentation. Just Google about it. It’s called tunneling where you can tunnel your localhost to the web.
says:
Would it be possible to just delete the “translation related” portion of the gulpfile.js? Or will it break the rest of the code. I don’t need it and it just confuses me about what I’m supposed to put in there.
I’m talking about this part only:
// Translation related.
var text_domain = ‘WPGULP’; // Your textdomain here.
var destFile = ‘GULP.pot’; // Name of the transalation file.
var packageName = ‘WPGULP’; // Package name.
var bugReport = ‘https://whatever/’; // Where can users report bugs.
var lastTranslator = ‘Ahmad Awais ‘; // Last translator Email ID.
var team = ‘WPTie ‘; // Team’s Email ID.
var translatePath = ‘./languages’ // Where to save the translation files.
says:
It is completely optional. You are free to delete or just not use it.
says:
Hey Ahmad, this is a really great resource. I’m very thankful for your time and effort in maintaining this project 🙂
says:
I’m glad you liked it. I’ve been planning a huge update for WPGulp. Hang in there 🙂 And do subscribe at https://WPTakeaway.club/ for the update.