Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahmadawais/create-guten-block
π¦ A zero-configuration #0CJS developer toolkit for building WordPress Gutenberg block plugins.
https://github.com/ahmadawais/create-guten-block
gutenberg wordpress wordpress-gutenberg wordpress-plugin zero-configuration
Last synced: about 1 month ago
JSON representation
π¦ A zero-configuration #0CJS developer toolkit for building WordPress Gutenberg block plugins.
- Host: GitHub
- URL: https://github.com/ahmadawais/create-guten-block
- Owner: ahmadawais
- License: mit
- Archived: true
- Created: 2017-12-20T09:45:01.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-10-10T02:27:34.000Z (about 2 years ago)
- Last Synced: 2024-09-22T21:33:14.101Z (about 2 months ago)
- Topics: gutenberg, wordpress, wordpress-gutenberg, wordpress-plugin, zero-configuration
- Language: JavaScript
- Homepage: https://Awais.dev/cgb-post
- Size: 1.2 MB
- Stars: 3,152
- Watchers: 85
- Forks: 327
- Open Issues: 107
-
Metadata Files:
- Readme: readme.md
- Changelog: changelog.md
- Contributing: contributing.md
- Funding: .github/FUNDING.yml
- License: license
- Code of conduct: code-of-conduct.md
Awesome Lists containing this project
- awesome-gutenberg - Create Guten Block - A zero-configuration developer toolkit for building Gutenberg block plugins (Uncategorized / Uncategorized)
- awesome-wordpress - Create Guten Block - A zero configuration toolkit for building Gutenberg block plugins. (Gutenberg)
README
> [Archived and looking for active maintainers](https://github.com/ahmadawais/create-guten-block/issues/307). Check out [`@wordpress/create-block`](https://developer.wordpress.org/block-editor/reference-guides/packages/packages-create-block/).
`create-guten-block` is _zero configuration dev-toolkit_ (#0CJS) to develop WordPress Gutenberg blocks in a matter of minutes without configuring `React`, `webpack`, `ES6/7/8/Next`, `ESLint`, `Babel`, etc.
[![DOWNLOADS](https://img.shields.io/npm/dt/create-guten-block?label=DOWNLOADS%20%20%E2%9D%AF&colorA=216AFF&colorB=216AFF&style=flat)](https://www.npmjs.com/package/create-guten-block) [![Learn Node.js CLI Automation](https://img.shields.io/badge/-NodeCLI.com%20%E2%86%92-gray.svg?colorB=216AFF&style=flat)](https://nodecli.com/?utm_source=GitHubFOSS) [![Follow @MrAhmadAwais on Twitter](https://img.shields.io/badge/FOLLOW%20@MRAHMADAWAIS%20%E2%86%92-gray.svg?colorA=216AFF&colorB=216AFF&style=flat)](https://twitter.com/mrahmadawais/)
# π¦ `create-guten-block`
>`create-guten-block` is _zero configuration dev-toolkit_ (#0CJS) to develop WordPress Gutenberg blocks in a matter of minutes without configuring `React`, `webpack`, `ES6/7/8/Next`, `ESLint`, `Babel`, etc.
Create Guten Block is not like other [starter-kits](https://github.com/ahmadawais/wpgulp) or [boilerplates](https://github.com/ahmadawais/Gutenberg-boilerplate). It's a developer's toolbox which is continuously updated. Since it has zero-configuration, you can always update it without any changes in your code.
`create-guten-block` is:
- π₯ Versioned β
- π€ Updatable β
- π Set of sane-defaults β
- π ONE single `cgb-scripts` dependency β
- π― [100s of WordPress plugins built with `create-guten-block`](plugins.md) β
[![Start](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/rocket.png)](/)
## GETTING STARTED!
Let's create a WordPress block plugin...
#### β‘οΈ Quick Overview
Run step `#1` and `#2` quickly in one go β Run inside local WP install E.g. `/wp.local/wp-content/plugins/` directory.
```sh
npx create-guten-block my-block
cd my-block
npm start
```([npx](https://medium.com/@maybekatz/introducing-npx-an-npm-package-runner-55f7d4bd282b) comes with npm 5.2+ and higher, see [instructions for older npm versions](https://gist.github.com/ahmadawais/e4c69b22561c7079c9d99faba90e3b23))
> π _If you want to study the detailed installation of step `#1` and `#2` β then take a look at the steps below_.
STEP #0 β Don't have
Node.js
+npm
installed? Read this. (CLICK TO EXPAND!)In case you are an absolute beginner to the world of `Node.js`, JavaScript, and `npm` packages β all you need to do is go to the Node's site [download + install](https://nodejs.org/en/download/) Node on your system. This will install both `Node.js` and `npm`, i.e., node package manager β the command line interface of Node.js.
You can verify the install by opening your terminal app and typing...
```sh
node -v
# Results into v9.1.0 β make sure you have Node >= 8 installed.npm -v
# Results into 5.6.0 β make sure you have npm >= 5.3 installed.
```### β STEP #1
All you have to do is run the following command and it will create a WordPress block plugin. It's done by installing and running the `create-guten-block` command and providing it with a unique name for a WordPress plugin that will get created.
> β οΈ Make sure run this command in your local WordPress install's plugins folder i.e. `/local_dev_site.tld/wp-content/plugins/` folder β since this command will produce a WordPress plugin that you can go to `WP Admin` βΆοΈ `Plugins` to activate.
```sh
npx create-guten-block my-block
```([npx](https://medium.com/@maybekatz/introducing-npx-an-npm-package-runner-55f7d4bd282b) comes with npm 5.2+ and higher, see [instructions for older npm versions](https://gist.github.com/ahmadawais/e4c69b22561c7079c9d99faba90e3b23))
[![npx block](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/cgb1.gif)](/)
_It'll take a couple of minutes to install._
>Youβll need to have Node >= 8 and npm >= 5.3 on your local development machine (but itβs not required on the server). You can use [nvm](https://github.com/creationix/nvm#installation) (macOS/Linux) or [nvm-windows](https://github.com/coreybutler/nvm-windows#node-version-manager-nvm-for-windows) to easily switch Node versions between different projects.
It will create a directory called `my-block` inside the current folder.
Inside that directory, it will generate the initial project structure and install the transitive dependencies:```sh
INSIDE: /local_dev_site.tld/wp-content/plugins/my-blockβββ .gitignore
βββ plugin.php
βββ package.json
βββ readme.md
|
βββ dist
| βββ blocks.build.js
| βββ blocks.editor.build.css
| βββ blocks.style.build.css
|
βββ src
βββ block
| βββ block.js
| βββ editor.scss
| βββ style.scss
|
βββ blocks.js
βββ common.scss
βββ init.php
```No configuration or complicated folder structures, just the files you need to build your app.
### β STEP #2
Once the installation is done, you can open your project folder and run the start script.
_Let's do that._
```sh
cd my-block
npm start
```_You can also use `yarn start` if that's your jam_.
[![cgb-npm-start](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/cgb2.gif)](/)
This runs the plugin in development mode. To produce production code run `npm run build`.
You will see the build messages, errors, and lint warnings in the console.>And just like that, you're building your next WordPress plugin with Gutenberg, React.js, ES 6/7/8/Next, transpiled with Babel, which also has ESLint configurations for your code editor to pick up and use automatically.
[![More](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/workflow.png)](/)
### Workflow!
There are just three scripts that you can use in your `create-guten-block` workflow. With these three scripts, you can develop, build, and eject your plugin.
#### π `npm start`
- Use to compile and run the block in development mode.
- Watches for any changes and reports back any errors in your code.#### π `npm run build`
- Use to build production code for your block inside `dist` folder.
- Runs once and reports back the gzip file sizes of the produced code.#### π `npm run eject`
- Use to eject your plugin out of `create-guten-block`.
- Provides all the configurations so you can customize the project as you want.
- It's a one-way street, `eject` and you have to maintain everything yourself.
- You don't normally have to `eject` a project because by ejecting you lose the connection with `create-guten-block` and from there onwards you have to update and maintain all the dependencies on your own._That's about it._
[![included](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/included.png)](/)
## Whatβs Included?
Your environment will have everything you need to build a modern next-gen WordPress Gutenberg plugin:
- React, JSX, and ES6 syntax support.
- webpack dev/production build process behind the scene.
- Language extras beyond ES6 like the object spread operator.
- Auto-prefixed CSS, so you donβt need `-webkit` or other prefixes.
- A build script to bundle JS, CSS, and images for production with source-maps.
- Hassle-free updates for the above tools with a single dependency `cgb-scripts`.The tradeoff is that **these tools are preconfigured to work in a specific way**. If your project needs more customization, you can ["eject"](https://github.com/ahmadawais/create-guten-block#--npm-run-eject) and customize it, but then you will need to maintain this configuration.
[![Philosophy](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/philosophy.png)](/)
## Philosophy
- **One Dependency:** There is just one build dependency. It uses webpack, Babel, ESLint, and other amazing projects, but provides a cohesive curated experience on top of them.
- **No Configuration Required:** You don't need to configure anything. A reasonably good configuration of both development and production builds is handled for you so you can focus on writing code.
- **No Lock-In:** You can `eject` to a custom setup at any time. Run a single command, and all the configuration and build dependencies will be moved directly into your project, so you can pick up right where you left off.
[![Why](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/why.png)](/)
## Why `create-guten-block`?
Well, it's really hard to configure things like webpack, React, ES 6/7/8/Next, ESLint, Babel, etc. before you even start writing a Hello World Gutenberg block. Then there's the fact that you have to maintain and constantly update your configuration with all the new tools and growth in the JavaScript community.
`create-guten-block` hides all this configuration away in an optimized package that we call `cgb-scripts`. This package is the only dependency in your projects. We keep `cgb-scripts` up to date while you go ahead and create the next best WordPress themes and plugins.
[![tldr](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/tldr.png)](/)
## TL;DR
>Too long, didn't read? Here's a shorter version.
Open the terminal app and run the following commands.
- π° **Install/Create**: `npx create-guten-block my-block` β Run inside local WP install E.g. `/wp.local/wp-content/plugins/` directory.
- π **Browse**: `cd my-block` β Open the newly created plugin directory.
- β»οΈ **Run**: `npm start` β For development.
- π¦ **Run**: `npm run build` β For production build.
- β **Run**: `npm run eject` β To customize, update, and maintain all by yourself.Create-Guten-Block has been tested to work on macOS, but must also work on Windows, and Linux.
If something doesnβt work, kindly file [an issue β](https://github.com/ahmadawais/create-guten-block/issues/new)
[![update](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/update.png)](/)
## Updating to New Releases
Create Guten Block is divided into two packages:
1. **`create-guten-block`** is a command-line utility that you use to create new WP Gutenberg plugins.
1. **`cgb-scripts`** is a development dependency in the generated plugin projects.You never need to update `create-guten-block` itself as it's run via [`npx`](https://medium.com/@maybekatz/introducing-npx-an-npm-package-runner-55f7d4bd282b) and it delegates all the setup to `cgb-scripts`.
When you run `create-guten-block`, it always creates the project with the latest version of `cgb-scripts` so youβll get all the new features and improvements in newly created plugins automatically.
To update an existing project to a new version of `cgb-scripts`, open the [changelog](https://github.com/ahmadawais/create-guten-block#changelog), find the version youβre currently on (check package.json in your plugin's folder if youβre not sure), and apply the migration instructions for the newer versions.
In most cases bumping the `cgb-scripts` version in package.json and running `npm install` in this folder should be enough, but itβs good to consult the [changelog](https://github.com/ahmadawais/create-guten-block#changelog) for potential breaking changes.
We commit to keeping the breaking changes minimal so you can upgrade `cgb-scripts` painlessly.
[![Log](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/changelog.png)](/)
## Changelog
Read what's π¦ new, π improved, π fixed, and if π docs got updated.
π Go read the entire changelog at this link β [CGB Changelog β](https://github.com/ahmadawais/create-guten-block/blob/master/changelog.md)
Nothing's ever complete, so bear with us while we keep iterating towards a better future.
> ```html
> '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!](https://www.youtube.com/watch?v=pSQk-4fddDI)_
[![Hello](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/hello.png)](/)
#### **Hello, we're [The Dev Couple](https://TheDevCouple.com)**!
Me ([Ahmad Awais](https://twitter.com/mrahmadawais/)) and my incredible wife ([Maedah Batool](https://twitter.com/MaedahBatool/)) are two engineers who fell in love with open source and then with each other. You can read more [about me here](https://ahmadawais.com/about). 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.
[![Ahmad on Twitter](https://img.shields.io/twitter/follow/mrahmadawais.svg?style=social&label=Follow%20@MrAhmadAwais)](https://twitter.com/mrahmadawais/)
### [NodeCLI.com][n] β Learn to build Node.js CLI Automation
> This repository is part of the [NodeCLI.com][n] 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][n] β[![Node CLI](https://img.shields.io/badge/-NodeCLI.com%20%E2%86%92-gray.svg?colorB=488640&style=flat)][n]
[n]: https://NodeCLI.com?utm_source=github&utm_medium=referral&utm_campaign=ahmadawais/create-guten-block
[![Awais on Twitter](https://raw.githubusercontent.com/ahmadawais/stuff/master/sponsor/sponsor.jpg)](https://github.com/AhmadAwais/sponsor)
[![Partners](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/backers.png)](/)
### Project Backers & [TheDevCouple Partners](https://TheDevCouple.com/partners) β‘οΈ
This FOSS (free and open source software) project is updated and maintained with the help of awesome businesses listed below. Without the support from these amazing companies/individuals, this project would not have been possible.
β _What/How? [Read more about it β](https://TheDevCouple.com/partners)_
[![Thanks](https://raw.githubusercontent.com/ahmadawais/stuff/master/fix/license.png)](/)
## License & Attribution
- MIT Β© [Ahmad Awais](https://twitter.com/MrAhmadAwais/).
- [Code of Conduct](code-of-conduct.md).
Β (follow) TO STAY UP TO DATE ON FREE & OPEN SOURCE SOFTWARE
Β (follow) TO GET ONE DEV MINUTE DAILY HOT TIPS & TROLLS
Β (subscribe) TO TECH TALKS & ONE DEV MINUTE VIDEOS
Β (read) MOSTLY LONG FORM TECHNICAL ARTICLES
Β (connect) WITH THE LINKEDIN PROFILE Y'ALL
This project is inspired by the work of more people than I could mention here. But thank you, [Dan Abramov](https://twitter.com/dan_abramov) for Create React App, [Andrew Clark](https://twitter.com/acdlite), and [Christopher Chedeau](https://twitter.com/vjeux), [Sophie Alpert](https://twitter.com/sophiebits) from React.js team, [Kent C. Dodds](https://twitter.com/kentcdodds) for his open source evangelism, WordPress Core Contributors, [Gary](https://twitter.com/GaryPendergast) for keeping everyone sane, [Gutenberg](https://github.com/wordpress/gutenberg) developers [Matias](https://twitter.com/matias_ventura), [Riad](https://github.com/youknowriad), [Andrew](https://github.com/aduth), [Ella](https://twitter.com/ellaiseulde), [Joen](https://github.com/jasmussen), [Tammie](https://twitter.com/karmatosed), [Greg](https://twitter.com/gziolo) and contributors, and other WordPress community members like [Zac](https://twitter.com/zgordon) for his [course on Gutenberg](https://ahmda.ws/ZacGutenbergCourse), and also my friend [Morten](https://twitter.com/mor10) for all the #Guten-motivation, [Icons8](https://icons8.com/) for the awesome icons, [Maedah](https://twitter.com/MaedahBatool/) for managing this project, and to everyone I forgot.
_Follow me π on Twitter for more updates and questions_ β [![Tweet to say Hi](https://img.shields.io/twitter/follow/mrahmadawais.svg?style=social&label=Tweet%20@MrAhmadAwais)](https://twitter.com/mrahmadawais/)
For anything else, tweet at @MrAhmadAwais
I have released a video course to help you learn how to create projects just like this one. Node.js and JavaScript based automation dev-tools and Command-line CLIs β Learn to build Node.js CLIS β
VSCode
I have released a video course to help you become a better developer β Become a VSCode Power User β
VSCode
[![VSCode](https://img.shields.io/badge/-VSCode.pro%20%E2%86%92-gray.svg?colorB=4D2AFF&style=flat)](https://VSCode.pro/?utm_source=github&utm_medium=referral&utm_campaign=ahmadawais/create-guten-block)
[![Ahmad on Twitter](https://img.shields.io/twitter/follow/mrahmadawais.svg?style=social&label=Follow%20@MrAhmadAwais)](https://twitter.com/mrahmadawais/)