champoo
v0.3.3
Published
Lazy loading pretty much everything!
Downloads
7
Maintainers
Readme
Champoo
Champoo is a lazy loader library. By separating conditioners & loaders, it gives you the flexibility to easily load pretty much everything, the lazy way... It is extensible & has a small footprint.
Installation
Node
yarn add champoo
or
npm install champoo
Browser
The package is available as a UMD module: compatible with AMD, CommonJS and exposing a global variable Champoo
in lib/Champoo.js
(less than 1Kb minified and gzipped).
Usage
<link rel="stylesheet" data-lazy data-lazy-conditioner="timeout(1000)" data-lazy-loader="url(https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css, href)" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<img data-lazy data-lazy-conditioner="timeout(2000)" data-lazy-loader="url(https://www.google.com/logos/doodles/2017/mountain-day-2017-5742983679836160-2x.jpg)" />
<img data-lazy data-lazy-conditioner="viewport(100)" data-lazy-loader="url(https://www.google.com/logos/doodles/2017/sir-john-cornforths-100th-birthday-4995374627422208.2-2x.jpg)" />
<iframe data-lazy data-lazy-conditioner="pointer(40,20)" data-lazy-loader="url(https://www.google.com/logos/2011/henson11-hp.html)" scrolling="no" width="900px" height="304px" frameborder="0"></iframe>
<div id="fb-root" data-lazy data-lazy-conditioner="viewport(100)" data-lazy-loader="fb-comments(en_US)" />
<div class="fb-comments" data-href="https://developers.facebook.com/docs/plugins/comments#configurator" data-numposts="1" />
import Champoo from '../es/Champoo';
import { UrlLoader } from '../es/loaders';
import { TimeoutConditioner, ViewportConditioner, MousePointerConditioner } from '../es/conditioners';
import FaceBookCommentsLoader from './FaceBookCommentsLoader';
const champoo = new Champoo({
conditioners: {
timeout: new TimeoutConditioner(),
viewport: new ViewportConditioner(),
pointer: new MousePointerConditioner()
},
loaders: {
'url': new UrlLoader(),
'fb-comments': new FaceBookCommentsLoader()
}
});
champoo.init().then((r) => {
console.log('All lazy elements loaded.', r);
});
Demo
git clone https://github.com/mawrkus/champoo.git
cd champoo
npm install
npm run server:demo
Custom conditioners creation
A conditioner is a simple class having the following interface:
class AmazingConditioner {
/**
* @param {HtmlElement} element
* @param {Array} params The conditioner parameters declared on the HTML element
* @return {Promise}
*/
check({ element, params }) {
return new Promise((resolve, reject) => {
// call resolve() whenever the element meets the condition(s)
// call reject() if there's a problem
});
}
}
By registering it when instantiating Champoo...
const champoo = new Champoo({
conditioners: {
amazing: new AmazingConditioner()
},
loaders: {
// ...
}
});
...you can use it in the HTML:
<img data-lazy data-lazy-conditioner="amazing(1,2,3)" />
Custom loaders creation
A loader is a simple class having the following interface:
class AmazingLoader {
/**
* @param {HtmlElement} element
* @param {Array} params The loader parameters declared on the HTML element
* @return {Promise}
*/
load({ element, params }) {
return new Promise((resolve, reject) => {
// call resolve() when the element has been loaded
// call reject() if there's an error while loading
});
}
}
By registering it when instantiating Champoo...
const champoo = new Champoo({
conditioners: {
// ...
},
loaders: {
amazing: new AmazingLoader()
}
});
...you can use it in the HTML:
<img data-lazy data-lazy-loader="amazing(you,and,me)" />
Contribute
- Fork it:
git clone https://github.com/mawrkus/champoo.git
- Create your feature branch:
git checkout -b feature/my-new-feature
- Commit your changes:
git commit -am 'Added some feature'
- Check the build:
yarn run build
- Push to the branch:
git push origin feature/my-new-feature
- Submit a pull request :D