Generate responsive HTML picture elements powered by on-the-fly Filestack image conversions.
Table of Contents
What is Adaptive
Adaptive is a tool which allow Filestack users to combine the power of on-the-fly image processing with the latest standard for responsive web images.
This library ships with a built-in virtual DOM adapter powered by hyperx, which allows you to simply call picture(source, options, renderer)
, where renderer can be any DOM builder supported by hyperx (e.g React.createElement). If renderer is not provided then picture will default to returning plain DOM.
Features
- Focus on usability and performance
- Works with Filestack handles, storage aliases and external urls
- Support for different sizes and formats in srcSet
- Allows you to add some image transformations
- Easily integrable with external virtual DOM renderers
Usage
Browser
You can find the newest version at https://static.filestackapi.com/adaptive/1.3.0/adaptive.min.js
Output:
SRI
Subresource Integrity (SRI) is a security feature that enables browsers to verify that files they fetch (for example, from a CDN) are delivered without unexpected manipulation. It works by allowing you to provide a cryptographic hash that a fetched file must match
To obtain sri hashes for adaptive library check manifest.json file on CDN:
https://static.filestackapi.com/adaptive/{LIBRARY_VERSION}/manifest.json
<script src="//static.filestackapi.com/adaptive/{LIBRARY_VERSION}/adaptive.min.js" integrity="{FILE_HASH}" crossorigin="anonymous"></script>
Where {LIBRARY_VERSION}
is currently used library version and {FILE_HASH}
is one of the hashes from integrity field in manifest.json file
Node (react example)
npm install filestack-adaptive
;;; // Need to spread children parameter to prevent React key warningsconst createElement = { return React;}; const options = alt: 'windsurfer' sizes: fallback: '100vw' ;const tree = ;ReactDOM;
Use with JSX
In a case of need to create your own <picture/>
element you can call makePictureTree directly in your JSX
;; { return sources; } { return <img ...imageObj />; } { const tree = ; return <picture> treesources && this this </picture> ; } ;
Storage aliases and external urls
You can also use Filestack storage alias or external urls as an image source:
Image width and pixel density
When the image width is known it will generate a srcset for HiDPI screens at 2x. More densities can be specified
by passing an array to the resolutions
option, e.g. resolutions: ['1x', '2x', '3x']
.
const options = alt: 'windsurfer' width: '768px';;
Output:
Webcomponent
Adaptive now supports webcomponent. Supported options: src, width, alt, cname, policy, signature, keys, resolutions
<fs-adaptive src="NxW2v528S9W6K1l5LnFS" width="769px" alt="windsurfer" ></fs-adaptive>
Output:
Using width descriptors
You can specify generated widths by using resolutions
, which takes an array
of numbers or strings (e.g. 540
or '540w'
).
const options = alt: 'windsurfer' sizes: '(min-width: 1080px)': '100vw' fallback: '90vw' resolutions: 540 1080;;
Output:
WebP support
WebP can be used when it's supported by the browser. Filestack will take care of the image conversion and cache it on the delivery network for future requests.
const options = alt: 'windsurfer' formats: 'webp' 'jpg' // order matters!;;
Output:
Custom CNAME
In order to use custom cname for generated file links just use cname option:
const options = cname: 'fs.test123.com';;
Output:
Transformations support
Adaptive also supports Filestack transformations. Available options are listed in doc:
https://www.filestack.com/docs/image-transformations
const options = alt: 'windsurfer' width: 400 transforms: blur: amount: 5 border: true // use default options of border transformation ;;
Output:
Disable validator
To speed up generating of final output (useful when you have a bunch of images on your site) you can optionally disable validation of transformation params by passing additional prop in options:
const options = ... useValidator: false ...
Development
To install and work on Adaptiv locally:
git clone git@github.com:filestack/adaptive.gitcd adaptivenpm install
To create build directory:
npm run build
This newly created directory contains
build/├── browser/ # for the UMD module (usable in HTML script tags) └── index.umd.js #├── main/ # for the CommonJS module ├── ... # └── index.js # └── module/ # for the ES Module (suitable for bundlers like Webpack and Rollup) ├── ... # └── index.js #
Documentation
For more info about available methods and options check browser documentation:
https://filestack.github.io/adaptive/
Contributing
We follow the conventional commits specification to ensure consistent commit messages and changelog formatting.
Future
Adaptive is joining an ecosystem already populated with many utilities for responsive images. We want to remain flexible while still having some opinions on how to implement picture elements using Filestack conversions, and we know it is hard to cover every use case. Contributions and ideas are welcome that would help improve the usefulness of this library.
Current ideas:
- LQIP using the Filestack blur transformation
- Compress HiDPI images using Filestack compress task
- Implement art direction with Filestack crop
- Develop a PostHTML transform for post-processing HTML using
makePictureTree