Skip to content

Commit

Permalink
Add docs about Webpack Encore.
Browse files Browse the repository at this point in the history
  • Loading branch information
bellisk committed Mar 12, 2019
1 parent 8f11613 commit 79d41d6
Showing 1 changed file with 63 additions and 0 deletions.
63 changes: 63 additions & 0 deletions source/documentation/basic-project.md
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,69 @@ generating the site.
With this option passed, `{{ site.url }}/about` will now be generated as
`http://my.dev.host/blog-skelton/output_dev/about` instead of `/about`.

## CSS and JavaScript

It is best practice to combine all your CSS files and all your JavaScript files
into single files. That way they are simple to include in your templates and
create less overhead for the browser loading the page. The recommended way to
combine assets is with Symfony's
[Webpack Encore](https://symfony.com/doc/current/frontend.html).

The [Blog Skeleton](https://github.com/sculpin/sculpin-blog-skeleton) project
uses Encore to manage assets. If you're setting up your project with Sculpin
directly, not using the skeleton, install Encore using the
[setup instructions](https://symfony.com/doc/current/frontend/encore/installation.html).

The rest of this section assumes that you are using Encore, with a
configuration like
[in the skeleton](https://github.com/sculpin/sculpin-blog-skeleton/blob/master/webpack.config.js).

Put your CSS and JS assets in the directory `source/assets/` as shown.

|-- source/
`-- assets/
|-- css/
| `-- app.css
`-- js/
`-- app.js

The app's main CSS file should be `source/assets/css/app.css`.
You can add more CSS files in the same directory if necessary and require them
in your JavaScript files to use them.

Encore can also support Sass, and the Blog Skeleton is set up to use it. See
the relevant
[Encore docs](https://symfony.com/doc/current/frontend/encore/simple-example.html#using-sass-less-stylus)
for more details.

The app's main JavaScript file is `source/assets/js/app.js`. Make sure that it
is added in the `webpack.config.js` configuration file. You can add further
JavaScript files and require them in `app.js`, and `require` other libraries as
necessary.

Build the assets using the command:

yarn encore dev --watch

Encore will then compile all the CSS into the `build/app.css` file and all the
JavaScript, including library code, into the `build/app.js` file.

Include the stylesheet link and script tag in your templates (in `_views/`):

```html
<head>
<link rel="stylesheet" href="{{ site.url }}/build/app.css">
</head>
```

```html
<body>
(all your other content)

<script src="{{ site.url }}/build/runtime.js"></script>
</body>
```

## Environments

Sculpin knows the `dev` and `prod` environment. They allow you to have
Expand Down

0 comments on commit 79d41d6

Please sign in to comment.