Skip to content

Latest commit

 

History

History
116 lines (74 loc) · 6.59 KB

getting-started.md

File metadata and controls

116 lines (74 loc) · 6.59 KB

Getting Started

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.

Local Environment

Step 1: Installing a Local Environment

Quickest Method: Using Docker

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

Alternative Method: Using an Existing Local WordPress 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"

Step 2: Accessing and Configuring the Local WordPress Install

Accessing the Local WordPress Install

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.

Toggling Debug Systems

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.

Troubleshooting

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.

Developer Tools

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

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

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

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:

  1. git switch add/prettier
  2. npm ci
  3. Edit a JavaScript file and on save it will format it as defined