2.0.0 • Published 2 years ago

@html-next/flexi-sustain v2.0.0

Weekly downloads
32
License
MIT
Repository
github
Last release
2 years ago

Flexi

npm version

Release Notes

Changelog

Installation

ember install @html-next/flexi-sustain

Support, Questions, Collaboration

Join the Ember community on Discord

Sustain

Sustain allows you to recycle a component instance across layout and route boundaries.

A sustain is essentially a "marker" for where a particular component instance is able to be reused. It allows you to explicitly declare what features of your app can be "recycled".

Sustain improves the performance of your app by reducing the amount of work your app needs to do. Instead of tearing down one instance and creating an entirely new instance, sustain seamlessly swaps a component instance's location as layouts and routes transition from one position to the next.

{{sustain <path-to-sustain> model}}

Only one instance of the sustainable is alive and rendered at a time, but if you are animating from one location to another you can choose to leave behind a copy.

{{sustain <path-to-sustain> model copy=true}}

By default, a sustain is destroyed when it has gone unused for one minute. You can alter this expiration. A value of 0 will cause the sustain to live forever.

{{sustain <path-to-sustain> expires=<time-in-ms>}}

If you would like to use the same layout for multiple sustain instances, on the same page, you can specify a label. This allows unique instances of the same layout, which update from route to route or layout to layout, but do not overwrite previous sustains in the same template.

{{sustain my-path label='foo'}}
{{sustain my-path label='bar'}}