UNPKG

bespoke

Version:

DIY Presentation Micro-Framework

143 lines (111 loc) 3.64 kB
/*! * Bespoke.js v0.4.0 * * Copyright 2014, Mark Dalgleish * This content is released under the MIT license * http://mit-license.org/markdalgleish */ (function(moduleName, window) { var from = function(selectorOrElement, selectedPlugins) { var parent = selectorOrElement.nodeType === 1 ? selectorOrElement : document.querySelector(selectorOrElement), slides = [].filter.call(parent.children, function(el) { return el.nodeName !== 'SCRIPT'; }), activeSlide = slides[0], listeners = {}, activate = function(index, customData) { if (!slides[index]) { return; } fire('deactivate', createEventData(activeSlide, customData)); activeSlide = slides[index]; slides.map(deactivate); fire('activate', createEventData(activeSlide, customData)); addClass(activeSlide, 'active'); removeClass(activeSlide, 'inactive'); }, deactivate = function(el, index) { var offset = index - slides.indexOf(activeSlide), offsetClass = offset > 0 ? 'after' : 'before'; ['before(-\\d+)?', 'after(-\\d+)?', 'active', 'inactive'].map(removeClass.bind(null, el)); el !== activeSlide && ['inactive', offsetClass, offsetClass + '-' + Math.abs(offset)].map(addClass.bind(null, el)); }, slide = function(index, customData) { if (arguments.length) { fire('slide', createEventData(slides[index], customData)) && activate(index, customData); } else { return slides.indexOf(activeSlide); } }, step = function(offset, customData) { var slideIndex = slides.indexOf(activeSlide) + offset; fire(offset > 0 ? 'next' : 'prev', createEventData(activeSlide, customData)) && activate(slideIndex, customData); }, on = function(eventName, callback) { (listeners[eventName] || (listeners[eventName] = [])).push(callback); return function() { listeners[eventName] = listeners[eventName].filter(function(listener) { return listener !== callback; }); }; }, fire = function(eventName, eventData) { return (listeners[eventName] || []) .reduce(function(notCancelled, callback) { return notCancelled && callback(eventData) !== false; }, true); }, createEventData = function(el, eventData) { eventData = eventData || {}; eventData.index = slides.indexOf(el); eventData.slide = el; return eventData; }, deck = { on: on, fire: fire, slide: slide, next: step.bind(null, 1), prev: step.bind(null, -1), parent: parent, slides: slides }; addClass(parent, 'parent'); slides.map(function(el) { addClass(el, 'slide'); }); for (var pluginName in selectedPlugins) { if (!plugins[pluginName]) { throw Error('Missing plugin: ' + moduleName + '-' + pluginName); } selectedPlugins[pluginName] !== false && plugins[pluginName](deck, selectedPlugins[pluginName]); } activate(0); decks.push(deck); return deck; }, decks = [], plugins = {}, addClass = function(el, cls) { el.classList.add(moduleName + '-' + cls); }, removeClass = function(el, cls) { el.className = el.className .replace(RegExp(moduleName + '-' + cls +'(\\s|$)', 'g'), ' ') .trim(); }, callOnAllDecks = function(method) { return function() { var args = arguments; decks.map(function(deck) { deck[method].apply(null, args); }); }; }; window[moduleName] = { from: from, slide: callOnAllDecks('slide'), next: callOnAllDecks('next'), prev: callOnAllDecks('prev'), plugins: plugins }; }('bespoke', window));