Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/DockYard/ember-service-worker-asset-cache


https://github.com/DockYard/ember-service-worker-asset-cache

Last synced: about 2 months ago
JSON representation

Awesome Lists containing this project

README

        

# Ember Service Worker Asset Cache

**[ember-service-worker-asset-cache is built and maintained by DockYard, contact us for expert Ember.js consulting](https://dockyard.com/ember-consulting)**.

_An Ember Service Worker plugin that caches an Ember app's asset files_

By default it caches all files in the `assets` folder.

## F#$& my assets aren't updating in development mode

Turn on the "Update on reload" setting in the `Application > Service Workers`
menu in the Chrome devtools.

## Installation

```
ember install ember-service-worker-asset-cache
```

## Configuration

You can configure extra files to include and if your app's file are on a CDN,
you can configure the CDN url.

The configuration is done in the `ember-cli-build.js` file:

```js
const EmberApp = require('ember-cli/lib/broccoli/ember-app')

module.exports = function(defaults) {
var app = new EmberApp(defaults, {
'asset-cache': {
// which asset files to include, glob paths are allowed!
// defaults to `['assets/**/*']`
include: [
'assets/admin-engine.js',
'fonts/font-awesome.*'
],

// which asset files to exclude, glob paths are allowed!
exclude: [
'**/*.gif'
],

// manually include extra external assets
manual: [
'https://cdn.example.com/foo-library.js'
],

// Changing this version number will bust the cache, but you probably do not
// want to be doing this manually, but rather using `versionStrategy` as
// explained here http://ember-service-worker.com/documentation/configuration/#versioning
version: '1',

// if your files are on a CDN, put the url of your CDN here
// can be absolute or relative
// overwritten by `fingerprint.prepend`
prepend: 'https://cdn.example.com/',

// mode of the fetch request. Use 'no-cors' when you are fetching resources
// cross origin (different domain) that do not send CORS headers
requestMode: 'cors',

// Prevent errors (status of 400 or greater) on a single file
// from not updating other files that have no issues
lenientErrors: false
}
});

return app.toTree();
};
```

*Note that setting `requestMode` to 'no-cors' will have some drawbacks, like not being able to distinguish between
successful and failed responses. Use it only when needed.*

## Authors

* [Marten Schilstra](http://twitter.com/martndemus)

## Versioning

This library follows [Semantic Versioning](http://semver.org)

## Want to help?

Please do! We are always looking to improve this library. Please see our
[Contribution Guidelines](https://github.com/dockyard/ember-service-worker-asset-cache/blob/master/CONTRIBUTING.md)
on how to properly submit issues and pull requests.

## Legal

[DockYard](http://dockyard.com/), Inc. © 2016

[@dockyard](http://twitter.com/dockyard)

[Licensed under the MIT license](http://www.opensource.org/licenses/mit-license.php)