From 7b001e0ebf682cc05fce0e2eaf712740c18e3aec Mon Sep 17 00:00:00 2001 From: Gaurav Munjal Date: Sun, 7 Oct 2018 12:28:19 -0400 Subject: [PATCH 1/2] Port (but do not reorganize and edit) Asset Compilation --- guides/legacy/asset-compilation.md | 622 +++++++++++++++++++++++++++++ guides/legacy/index.md | 3 + guides/pages.yml | 6 + 3 files changed, 631 insertions(+) create mode 100644 guides/legacy/asset-compilation.md create mode 100644 guides/legacy/index.md diff --git a/guides/legacy/asset-compilation.md b/guides/legacy/asset-compilation.md new file mode 100644 index 0000000..3a056c6 --- /dev/null +++ b/guides/legacy/asset-compilation.md @@ -0,0 +1,622 @@ + + +### Raw Assets + +* `public/assets` vs `app/styles` + +To add images, fonts, or other assets, place them in the `public/assets` directory. For +example, if you place `logo.png` in `public/assets/images`, you can reference it in +templates with `assets/images/logo.png` or in stylesheets with +`url('/assets/images/logo.png')`. + +This functionality of Ember CLI comes from +[broccoli-asset-rev](https://github.com/rickharrison/broccoli-asset-rev). Be +sure to check out all the options and usage notes. + +### JS Transpiling + +Ember CLI automatically transpiles future JavaScript (ES6/ES2015, ES2016 and beyond) into standard ES5 +JavaScript that runs on every browser using [Babel JS](https://babeljs.io) with the [Ember CLI Babel](https://github.com/babel/ember-cli-babel) addon. + +Internally, Ember CLI Babel uses `babel-preset-env`, which figures out which parts of your code +need to be transpiled to ES5 by **analyzing your project's browser support targets**. A `target` is a special keyword +that maps to a [browserlist](https://github.com/ai/browserslist) support rule. These are defined in your +`config/targets.js` file, which [Ember CLI generates](https://github.com/ember-cli/ember-cli/blob/master/blueprints/app/files/config/targets.js) like so: + +```js +/* eslint-env node */ +module.exports = { + browsers: [ + 'ie 9', + 'last 1 Chrome versions', + 'last 1 Firefox versions', + 'last 1 Safari versions' + ] +}; +``` + +(If these values look familiar, they're the same exact values used by the popular [Autoprefixer](https://github.com/postcss/autoprefixer) project.) + +If you need more fine-grained customization over the way that `babel-preset-env` transforms your code, +simply set any of the options found [here](https://github.com/babel/babel-preset-env#options) on your application's `babel` hash in `ember-cli-build.js`. + +For example, if you wanted to explicitly exclude generator function transpilation from your +output, your configuration would look like this: + +```js +// ember-cli-build.js + +/* eslint-env node */ +'use strict'; +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp(defaults, { + babel: { + blacklist: [ + 'es6.arrowFunctions', + 'es6.blockScoping', + 'es6.classes', + 'es6.destructuring', + 'es6.parameters', + 'es6.properties.computed', + // ...more options + ] + } + }); + + //... + return app.toTree(); +}; +``` + +As of Version 2.13, Ember CLI uses Babel 6.X for transpilation. Ember CLI versions prior to 2.13 use Babel Babel 5.X, and you can check its documentation for a comprehensive list of [all available transformations](https://github.com/babel/babel.github.io/blob/5.0.0/docs/usage/transformers/index.md) and [options](https://github.com/babel/babel.github.io/blob/5.0.0/docs/usage/options.md). + +### Minifying + +The compiled css-files are minified by `broccoli-clean-css` or `broccoli-csso`, +if it is installed locally. You can pass minifer-specific options to them using +the `minifyCSS:options` object in your ember-cli-build. Minification is enabled by +default in the production-env and can be disabled using the `minifyCSS:enabled` +switch. + +Similarly, the js-files are minified with `broccoli-uglify-js` in the +production-env by default. You can pass custom options to the minifier via the +`minifyJS:options` object in your ember-cli-build. To enable or disable JS minification +you may supply a boolean value for `minifyJS:enabled`. + +For example, to disable minifying of CSS and JS, add in `ember-cli-build.js`: +```js +// ember-cli-build.js +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp(defaults, { + minifyJS: { + enabled: false + }, + minifyCSS: { + enabled: false + } + }); + + //... + return app.toTree(); +}; +``` + +#### Exclude from minification + +To exclude assets from `dist/assets` from being minificated, one can pass options for +[broccoli-uglify-sourcemap](https://github.com/ef4/broccoli-uglify-sourcemap) like so: + +```js +// ember-cli-build.js +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp(defaults, { + minifyJS: { + options: { + exclude: ["**/vendor.js"] + } + } + }); + + //... + return app.toTree(); +}; +``` + +This would exclude the resulting `vendor.js` file from being minificated. + +### Source Maps + +Ember CLI supports producing source maps for your concatenated and minified JS source files. + +Source maps are configured by the EmberApp `sourcemaps` option, and +are disabled in production by default. Pass `sourcemaps: {enabled: true}` to your EmberApp constructor to enable source maps for javascript. Use the `extensions` option to add other formats, such as coffeescript and CSS: `{extensions: ['js', 'css', 'coffee']}`. JS is supported out-of-the-box. CSS is not currently supported. For other source formats (Sass, Coffee, etc) refer to their addons. + +Default ember-cli-build.js: + +```js +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp({ + sourcemaps: { + enabled: EmberApp.env() !== 'production', + extensions: ['js'] + } + }); + + //... + return app.toTree(); +}; +``` + +### Stylesheets + +Ember CLI supports plain CSS out of the box. You can add your css styles to +`app/styles/app.css` and it will be served at `assets/application-name.css`. + +For example, to add bootstrap in your project you need to do the following: +```bash +bower install bootstrap --save +``` + +In `ember-cli-build.js` add the following: +```js +app.import('bower_components/bootstrap/dist/css/bootstrap.css'); +``` +it's going to tell [Broccoli](https://github.com/broccolijs/broccoli) that we want +this file to be concatenated with our `vendor.css` file. + +To use a CSS preprocessor, you'll need to install the appropriate +[Broccoli](https://github.com/broccolijs/broccoli) plugin. When using a +preprocessor, Broccoli is configured to look for an `app.less`, `app.scss`, `app.sass`, +or `app.styl` manifest file in `app/styles`. This manifest should import any +additional stylesheets. + +All your preprocessed stylesheets will be compiled into one file and served at +`assets/application-name.css`. + +If you would like to change this behavior, or compile to multiple output +stylesheets, you can adjust the [Output Paths +Configuration](#configuring-output-paths) + +#### CSS + +To use plain CSS with `app.css`: + +* Write your styles in `app.css` and/or organize your CSS into multiple + stylesheet files and import these files with `@import` from within `app.css`. +* [CSS `@import` + statements](https://developer.mozilla.org/en-US/docs/Web/CSS/@import) (e.g. + `@import 'typography.css';`) must be valid CSS, meaning `@import` statements + *must* precede all other rules and so be placed at the *top* of `app.css`. + +To process your imports and replace them with the contents of their files, +add in `ember-cli-build.js`: +```js +// ember-cli-build.js +var EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + var app = new EmberApp(defaults, { + minifyCSS: { + options: { processImport: true } + } + }); + + //... + return app.toTree(); +}; +``` + +Which will cause the following to happen: + +* In the production build, the `@import` statements are replaced with the + contents of their files and the final minified, concatenated single CSS file + is built to `dist/assets/yourappname-FINGERPRINT_GOES_HERE.css`. +* Any individual CSS files are also built and minified into `dist/assets/` in + case you need them as standalone stylesheets. +* Relative pathing gets changed (how to customize?) + +Example `app.css` with valid `@import` usage: + +```css +/* @imports must appear at top of stylesheet to be valid CSS */ +@import 'typography.css'; +@import 'forms.css'; + +/* Any CSS rules must go *after* any @imports */ +.first-css-rule { + color: red; +} +... +``` + +#### CSS Preprocessors + +To use one of the following preprocessors, all you need to do is install the appropriate NPM module. +The respective files will be picked up and processed automatically. + +#### LESS + +To enable [LESS](http://lesscss.org/), you'll need to add +[ember-cli-less](https://github.com/gdub22/ember-cli-less) to +your NPM modules. + +```bash +ember install ember-cli-less +``` + +#### SCSS/SASS + +To enable [SCSS/SASS](http://sass-lang.com/), you'll need to +install the [ember-cli-sass](https://github.com/aexmachina/ember-cli-sass) addon +to your project *(defaults to .scss, .sass allowed via configuration)*. + +```bash +ember install ember-cli-sass +``` + +You can configure your project to use .sass in your `ember-cli-build.js`: + +```js +// ember-cli-build.js +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp({ + sassOptions: { + extension: 'sass' + } + }); + + //... + return app.toTree(); +}; +``` + +#### Compass + +To use [Compass](http://compass-style.org/) with your ember-cli app, install +[ember-cli-compass-compiler](https://github.com/quaertym/ember-cli-compass-compiler) addon using NPM. + +```bash +ember install ember-cli-compass-compiler +``` + +#### Stylus + +To enable [Stylus](http://learnboost.github.io/stylus/), you must first add +[ember-cli-stylus](https://github.com/drewcovi/ember-cli-stylus) to your NPM +modules: + +```bash +ember install ember-cli-stylus +``` + +### CoffeeScript + +To enable [CoffeeScript](http://coffeescript.org/), you must +first add [ember-cli-coffeescript](https://github.com/kimroen/ember-cli-coffeescript) to your +NPM modules: + +```bash +ember install ember-cli-coffeescript +``` + +The modified `package.json` should be checked into source control. CoffeeScript +can be used in your app's source and in tests, just use the `.coffee` extension +on any file. We recommend using version >= 1.16.0 of ember-cli-coffeescript to avoid the need +to escape `import` and `export` statements. + +Note that earlier versions of the transpiler had explicit support for +CoffeeScript, but that support has been removed. + +### EmberScript + +To enable [EmberScript](http://emberscript.com), you must +first add [broccoli-ember-script](https://github.com/aradabaugh/broccoli-ember-script) to your +NPM modules: + +```bash +npm install broccoli-ember-script --save-dev +``` + +Note that the ES6 module transpiler is not directly supported with Emberscript, +to allow use of ES6 modules use the `` ` `` character to escape raw Javascript +similar to the CoffeeScript example above. + +### Emblem + +For [Emblem](http://emblemjs.com/), run the following commands: + +```bash +ember install ember-cli-emblem +``` + +If you're using the older broccoli-emblem-compiler addon, you need to switch to +ember-cli-emblem. The older broccoli-emblem-compiler compiles directly to JS +instead of Handlebars and therefore is broken on all newer version of HTMLBars. + +### Fingerprinting and CDN URLs + +Fingerprinting is done using the addon +[broccoli-asset-rev](https://github.com/rickharrison/broccoli-asset-rev) +(which is included by default). + +When the environment is production (e.g. `ember build --environment=production`), +the addon will automatically fingerprint your js, css, png, jpg, and gif assets +by appending an md5 checksum to the end of their filename +(e.g. `assets/yourapp-9c2cbd818d09a4a742406c6cb8219b3b.js`). In addition, your +html, js, and css files will be re-written to include the new name. There are +a few options you can pass in to `EmberApp` in your `ember-cli-build.js` to customize +this behavior. + +* `enabled` - Default: `app.env === 'production'` - Boolean. Enables fingerprinting +if true. **True by default if current environment is production.** +* `exclude` - Default: `[]` - An array of strings. If a filename contains any +item in the exclude array, it will not be fingerprinted. +* `ignore` - Default: `[]` - An array of strings. If a filename contains any item in the +ignore array, the contents of the file will not be processed for fingerprinting. +* `extensions` - Default: `['js', 'css', 'png', 'jpg', 'gif', 'map']` - The file types +to add md5 checksums. +* `prepend` - Default: `''` - A string to prepend to all of the assets. Useful +for CDN urls like `https://subdomain.cloudfront.net/` +* `replaceExtensions` - Default: `['html', 'css', 'js']` - The file types to +replace source code with new checksum file names. +* `customHash` - When specified, this is appended to fingerprinted filenames instead +of the md5. Pass `null` to suppress the hash, which can be useful when using `prepend`. + +As an example, this `ember-cli-build` will exclude any file in the fonts/169929 +directory as well as add a cloudfront domain to each fingerprinted asset. + +```js +// ember-cli-build.js +const EmberApp = require('ember-cli/lib/broccoli/ember-app'); + +module.exports = function(defaults) { + let app = new EmberApp({ + fingerprint: { + exclude: ['fonts/169929'], + prepend: 'https://subdomain.cloudfront.net/' + } + }); + + //... + return app.toTree(); +}; +``` + +The end result will turn + +```html +