This guide is a modified version of the Gutenberg Project's Getting Started guide
CoBlocks is a Node.js-based project, built primarily in JavaScript.
The first step is to install the latest active LTS release of Node. Once you have Node installed, run these scripts from within your local CoBlocks repository:
yarn install
yarn build
This will build CoBlocks, ready to be used as a WordPress plugin!
If you don't have a local WordPress environment to load CoBlocks in, we can help get that up and running, too.
The quickest way to get up and running is to use the provided Docker setup. If you don't already have it, you'll need to install Docker and Docker Compose.
To install Docker, follow their instructions here for Windows 10 Pro, all other version of Windows, macOS, or Linux.
To install Docker Compose, follow their instructions here, be sure to select your operating system for proper instructions.
Once Docker is installed and running, run this script to install WordPress, and build your local environment:
yarn env install
WordPress will be installed in the wordpress
directory, if you need to access WordPress core files directly, you can find them there.
If you already have WordPress checked out in a different directory, you can use that installation, instead, by running these commands:
export WP_DEVELOP_DIR=/path/to/wordpress-develop
yarn env connect
This will use WordPress' own local environment, and mount your CoBlocks directory as a volume there.
In Windows, you can set the WP_DEVELOP_DIR
environment variable using the appropriate method for your shell:
CMD: set WP_DEVELOP_DIR=/path/to/wordpress-develop
PowerShell: $env:WP_DEVELOP_DIR = "/path/to/wordpress-develop"
Whether you decided to use Docker or an existing local WordPress install, the WordPress installation should now be available at http://localhost:8889
(Username: admin
, Password: password
).
If this port is in use, you can override it using the LOCAL_PORT
environment variable. For example running the below command on your computer will change the URL to
http://localhost:7777
.
Linux/macOS: export LOCAL_PORT=7777
Windows using Command Prompt: setx LOCAL_PORT "7777"
Windows using PowerShell: $env:LOCAL_PORT = "7777"
To shut down this local WordPress instance run yarn env stop
. To start it back up again, run yarn env start
.
WordPress comes with specific debug systems designed to simplify the process as well as standardize code across core, plugins and themes. It is possible to use environment variables (LOCAL_WP_DEBUG
and LOCAL_SCRIPT_DEBUG
) to update a site's configuration constants located in wp-config.php
file. Both flags can be disabled at any time by running the following command:
Example on Linux/MacOS:
LOCAL_SCRIPT_DEBUG=false LOCAL_WP_DEBUG=false yarn env install
By default, both flags will be set to true
.
You might find yourself stuck on a screen stating that "you are running WordPress without JavaScript and CSS files". If you tried installing WordPress via yarn env install
, it probably means that something went wrong during the process. To fix it, try removing the /wordpress
folder and running yarn env install
again.
We recommend configuring your editor to automatically check for syntax and lint errors. This will help you save time as you develop by automatically fixing minor formatting issues. Here are some directions for setting up Visual Studio Code, a popular editor used by many of the core developers, these tools are also available for other editors.
EditorConfig defines a standard configuration for setting up your editor, for example using tabs instead of spaces. You should install the EditorConfig for VS Code extension and it will automatically configure your editor to match the rules defined in .editorconfig.
ESLint statically analyzes the code to find problems. The lint rules are integrated in the continuous integration process and must pass to be able to commit. You should install the ESLint Extension for Visual Studio Code, see eslint docs for more editor integrations.
With the extension installed, ESLint will use the .eslintrc.js file in the root of the CoBlocks repository for formatting rules. It will highlight issues as you develop, you can also set the following preference to fix lint rules on save.
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
},
Prettier is a tool that allows you to define an opinionated format, and automate fixing the code to match that format. Prettier and ESlint are similar, Prettier is more about formatting and style, while ESlint is for detecting coding errors.
To use Prettier, you should install the Prettier - Code formatter extension in Visual Studio Code. You can then configure it to be the default formatter and to automatically fix issues on save, by adding the following to your settings.
"[javascript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true
},
This will use the .prettierrc.js
file in the root folder of the CoBlocks repository and the version of Prettier that is installed in the root node_modules
folder. To test it out prior to PR #18048 being merged, you should:
git switch add/prettier
npm ci
- Edit a JavaScript file and on save it will format it as defined