Directory

include-fragment-element - Vaadin Add-on Directory

A Client Side Includes tag include-fragment-element - Vaadin Add-on Directory
# <include-fragment> element A Client Side Includes tag. ## Installation ``` $ npm install --save include-fragment-element ``` ## Usage All `include-fragment` elements must have a `src` attribute from which to retrieve an HTML element fragment. The initial page load should include fallback content to be displayed if the resource could not be fetched immediately. ```js import 'include-fragment-element' ``` **Original** ``` html

Loading tip…

``` On page load, the `include-fragment` element fetches the URL, the response is parsed into an HTML element, which replaces the `include-fragment` element entirely. **Result** ``` html

You look nice today

``` The server must respond with an HTML fragment to replace the `include-fragment` element. It should not contain _another_ `include-fragment` element or the server will be polled in an infinite loop. ### Errors If the URL fails to load, the `include-fragment` element is left in the page and tagged with an `is-error` CSS class that can be used for styling. ### Events Request lifecycle events are dispatched on the `` element. - `loadstart` - The server fetch has started. - `load` - The request completed successfully. - `error` - The request failed. - `loadend` - The request has completed. ```js const loader = document.querySelector('include-fragment') const container = loader.parentElement loader.addEventListener('loadstart', () => container.classList.add('is-loading')) loader.addEventListener('loadend', () => container.classList.remove('is-loading')) loader.addEventListener('load', () => container.classList.add('is-success')) loader.addEventListener('error', () => container.classList.add('is-error')) ``` ### Options Attribute | Options | Description --- | --- | --- `src` | URL string | Required URL from which to load the replacement HTML element fragment. ### Deferred loading The request for replacement markup from the server starts when the `src` attribute becomes available on the `` element. Most often this will happen at page load when the element is rendered. However, if we omit the `src` attribute until some later time, we can defer loading the content at all. The [``][menu] element uses this technique to defer loading menu content until the menu is first opened. [menu]: https://github.com/github/details-menu-element ## Patterns Deferring the display of markup is typically done in the following usage patterns. - A user action begins a slow running background job on the server, like backing up files stored on the server. While the backup job is running, a progress bar is shown to the user. When it's complete, the include-fragment element is replaced with a link to the backup files. - The first time a user visits a page that contains a time-consuming piece of markup to generate, a loading indicator is displayed. When the markup is finished building on the server, it's stored in memcache and sent to the browser to replace the include-fragment loader. Subsequent visits to the page render the cached markup directly, without going through a include-fragment element. ## Relation to Server Side Includes This declarative approach is very similar to [SSI](http://en.wikipedia.org/wiki/Server_Side_Includes) or [ESI](http://en.wikipedia.org/wiki/Edge_Side_Includes) directives. In fact, an edge implementation could replace the markup before its actually delivered to the client. ``` html

Counting commits…

``` A proxy may attempt to fetch and replace the fragment if the request finishes before the timeout. Otherwise the tag is delivered to the client. This library only implements the client side aspect. ## Browser support Browsers without native [custom element support][support] require a [polyfill][]. Legacy browsers require various other polyfills. See [`examples/index.html`][example] for details. [example]: https://github.com/github/include-fragment-element/blob/master/examples/index.html#L5-L14 - Chrome - Firefox - Safari - Microsoft Edge [support]: https://caniuse.com/#feat=custom-elementsv1 [polyfill]: https://github.com/webcomponents/custom-elements ## Development ``` npm install npm test ``` ## License Distributed under the MIT license. See LICENSE for details.