In the previous section, we shared a little bit about what Greenwood is and the high level goals of this guide. Now we are ready to help you start your first project!
In this section, we will kick off our Greenwood project by:
npm
scripts for local developmentThis guide assumes you are starting from an empty directory (
git init
being the exception). We recommend going through this guide once to understand the basics and from there, you can explore our documentation to learn more about all of Greenwood's capabilities.
With Greenwood installed, you will be able to use its CLI to power the development of your project though automated scripts and configuration.
First thing we need to do is generate a package.json file so we can install Greenwood. The easist way to do that is by running npm init
from the root directory of where you want to start your project:
# hit enter to accept all defaults, or provide your own values
$ npm init
Now we can install Greenwood
$ npm install @greenwood/cli --save-dev
All set!
With Greenwood installed, let's create a couple of npm scripts so that we can automate our development workflows with easy to remember commands.
In package.json, edit the scripts
section accordingly by adding:
{
"scripts": {
"...": "....",
"build": "greenwood build",
"start": "greenwood develop"
}
},
Now, you'll be able to do two things:
npm start
- Start a local development server with file watching and live reloading.npm run build
- Generate a static build of the project that you can upload to a web server.You can go ahead and try out both of these tasks now, and you should see Greenwood's default generated output, letting you know you've set everything up correctly.
You can rename
build
andstart
to whatever you like, but this is what will be used for the sake of this guide.
OK, almost there! Let's quickly review what a basic project structure will look like. At this point, your project should look something like this:
.
├── node_modules/
├── package-lock.json
└── package.json
As we get ready to move onto the next section, your project will need a "workspace", which is basically just the name of the directory where your project files will go. For now, let's just use Greenwood's default, which is src/. After creating that directory, this is what your project structure should look like:
.
├── node_modules/
├── package-lock.json
├── package.json
└── src/
At this point, if you are in
git
repository, it might be a good time to create a .gitignore file and add the following directories:.greenwood/
,node_modules/
andpublic/
.
Ok, now what we have our project ready, there's just one last thing to review before we jump right in, but we promise it will be quick. Please head on over to the next section in our guide to learn about Greenwood's key concepts.