X-Git-Url: http://git.nguyen.vg/gitweb/?a=blobdiff_plain;f=simpleWebSlides.js;h=26ea8e21fcbd5a743fcbaa131f3171b9dfddbf9f;hb=f55977d9f090ee6bbace278733377ff50b7bec3a;hp=134369c23216e99dd7119b30a6e13f33192b3bcb;hpb=d0dbcbd2b3d2020d41e929b17368d1a3ba388937;p=hacks%2FsimpleWebSlides.git diff --git a/simpleWebSlides.js b/simpleWebSlides.js index 134369c..26ea8e2 100644 --- a/simpleWebSlides.js +++ b/simpleWebSlides.js @@ -1,8 +1,61 @@ -var SimpleWebSlides = new function () { - var _self = this; +/* + Namespace object. +*/ + +var SWS = {}; + +/* Utility functions */ +SWS.isUndefined = function (o) { return typeof o == "undefined"; }; + +/* + Representation of intervals of positive integers. + +SWS.Interval = new function (init) { + + var self = this; + self.data = new Array(); + self.parseString(s) { + var elems = s.split("_"); + for(var i = 0; i < elems.length; i++){ + var bounds = elems[i].split("-"); + if (bounds.length > 2) continue; + if (SWS.isUndefined(bounds[1])) bounds[1] = bounds[0]; + if (!(isFinite(bounds[0]) && isFinite(bounds[1]))) continue; + + self.add(+(bounds[0]), +(bounds[1])); + }; + + }; + self.add(x, y) { + if (SWS.isUndefined(y) && isFinite(x)) self.add(x,x); + + + + + }; +5B + + + }; +}; +*/ + +SWS.Presentation = new function () { + + + var self = this; + + var templates = {}; + + //TODO: clean-up; var _total_slides; var _defered_custom = new Array(); var _initialized = false; + var _animations_running = false; + + //Utility functions + + function push_following(t, i, v) { if ((typeof t[i]) == 'undefined') { @@ -24,31 +77,42 @@ var SimpleWebSlides = new function () { function init_canvas(canvas) { - var frames = new Array (); var cur_frame = 0; + var last_frame = canvas.find(".sws-pause").length; + //Add all regular elements to the frame list canvas.find("*").each(function(i) { - - if ($(this).hasClass("pause")) cur_frame++; - push_following(frames, cur_frame, $(this)); - + if ($(this).filter('*[class*="sws-onslide-"]').length) { + } else { + if ($(this).hasClass("sws-pause")) cur_frame++; + var o = {}; + for (var j = cur_frame; j <= last_frame; j++) + o[ "f" + j ] = true; + $(this).data("sws-frame-set", o); + }; }); - canvas.data("frames", { frames: frames, - current: 0, - custom: new Array() }); + + canvas.data("sws-frame-info", { current: 0, + last: last_frame, + custom: new Array() }); }; - _self.getNumSlides = function () { return _total_slides; }; + + //Public methods + self.setTemplate = function (tn, fn) { templates[tn] = fn; }; + + self.getNumSlides = function () { return _total_slides; }; - _self.registerCustom = function (i, f) { + self.registerCustom = function (i, f) { if (_initialized) return; //jQuery does not seem to work well - //on partial doms + //on partal doms + var scripts = document.getElementsByTagName("script"); var current = scripts[scripts.length-1]; - console.log(current); - var slide = $(current).parents(".slide"); + + var slide = $(current).parents(".sws-slide"); if (slide.length == 0) { console.log("no parent ?"); return; @@ -61,171 +125,213 @@ var SimpleWebSlides = new function () { }; if (typeof(Storage)!=="undefined"){ - _self.getCurrentSlide = function () { + self.getCurrentSlide = function () { //unary + casts to integer var i = +(sessionStorage.current_slide); - if (!(i >= 0 && i < _self.getNumSlides())){ + if (!(i >= 0 && i < self.getNumSlides())){ return 0; } else { return i; }; }; - _self.setCurrentSlide = function (i) { + self.setCurrentSlide = function (i) { sessionStorage.current_slide = i; }; } else { var _current_slide = 0; - _self.getCurrentSlide = function () { return current_slide; }; - _self.setCurrentSlide = function (i) { _current_slide = i; }; - - }; - _self.firstSlide = function () { return 0; }; - _self.lastSlide = function () { return _self.getNumSlides() - 1; }; - _self.refresh = function () { - var cur = _self.getCurrentSlide(); - $(".canvas").each (function (i) { - if (i == cur){ - $(this).removeClass("other_slides").addClass("current_slide"); - var info = $(this).data("frames"); - var frames = info.frames; - var upto = info.current; - var custom = info.custom; - for(var j = 0; j < Math.max(frames.length, custom.length); j++) { - for (var k = 0; k < frames[j].length; k++) { - if (j < upto || frames[j][k].hasClass("footer")){ - - frames[j][k].removeClass("inactive_frame").addClass("active_frame"); - - } else if (j == upto) { - - frames[j][k].removeClass("inactive_frame").addClass("current_frame"); - - } else { - frames[j][k].removeClass("active_frame").removeClass("current_frame").addClass("inactive_frame"); - }; - }; - var callbacks; - if (j == upto && (callbacks = custom[j])) { - for (var k = 0; k < callbacks.length; k++) - callbacks[k]($(this)); - }; + self.getCurrentSlide = function () { return current_slide; }; + self.setCurrentSlide = function (i) { _current_slide = i; }; + + }; + self.firstSlide = function () { return 0; }; + self.lastSlide = function () { return self.getNumSlides() - 1; }; + + self.refresh = function () { + var to_slide = $(".sws-canvas")[self.getCurrentSlide()]; + var from_slide = $(".sws-active-slide")[0]; + + if (!(to_slide === from_slide)) { + templates['sws-template-slide-deactivate']( + $(from_slide), + function (o){ + o.removeClass("sws-active-slide") + .addClass("sws-inactive-slide"); + templates['sws-template-slide-activate']( + $(to_slide).removeClass("sws-inactive-slide") + .addClass("sws-active-slide"), + function (_){ + }); + }); + + }; + var info = $(to_slide).data("sws-frame-info"); + var cur = info.current; + var custom = info.custom; + + $(to_slide).find("*").each (function (i) { + var fcur = "f" + cur; + var frameset = $(this).data("sws-frame-set") || {}; + if (frameset[fcur]) { + if (!($(this).hasClass("sws-active-frame"))) { + templates['sws-template-frame-activate']( + $(this).removeClass("sws-inactive-frame") + .addClass("sws-active-frame"), + function (_){ }); + + }; + + } else { + if (!($(this).hasClass("sws-inactive-frame"))) { + templates['sws-template-frame-deactivate']( + $(this), + function (o){ + o.removeClass("sws-active-frame") + .addClass("sws-inactive-frame"); + }); + }; - } else if ($(this).hasClass("current_slide")) { - $(this).removeClass("current_slide").addClass("other_slides"); + }; }); + _animation_running = true; + var callbacks; + + if (callbacks = custom[self.getCurrentFrame()]){ + for (var k = 0; k < callbacks.length; k++) + callbacks[k]($(to_slide)); + }; + $(to_slide).find("*").promise().done(function() { + _animation_running = false; + }); }; - _self.nextSlide = function () { - _self.setCurrentSlide(Math.min(_self.getCurrentSlide()+1, - _self.lastSlide())); + self.nextSlide = function () { + self.setCurrentSlide(Math.min(self.getCurrentSlide()+1, + self.lastSlide())); }; - _self.previousSlide = function () { - _self.setCurrentSlide(Math.max(_self.getCurrentSlide()-1, - _self.firstSlide())); + self.previousSlide = function () { + self.setCurrentSlide(Math.max(self.getCurrentSlide()-1, + self.firstSlide())); }; - _self.getFrameInfo = function () { + self.getFrameInfo = function () { - var i = _self.getCurrentSlide(); - var canvas = $($(".canvas")[i]); - var infos = canvas.data("frames"); + var i = self.getCurrentSlide(); + var canvas = $($(".sws-canvas")[i]); + var infos = canvas.data("sws-frame-info"); return infos; }; - _self.getCurrentFrame = function () { return _self.getFrameInfo().current; }; - _self.setCurrentFrame = function (i) { _self.getFrameInfo().current = i; }; - _self.firstFrame = function () { return 0; }; - _self.lastFrame = function () { return _self.getFrameInfo().frames.length-1; }; + self.getCurrentFrame = function () { return self.getFrameInfo().current; }; + self.setCurrentFrame = function (i) { self.getFrameInfo().current = i; }; + self.firstFrame = function () { return 0; }; + self.lastFrame = function () { return self.getFrameInfo().last; }; - _self.nextFrame = function () { - _self.setCurrentFrame(Math.min(_self.getCurrentFrame()+1, - _self.lastFrame())); + self.nextFrame = function () { + self.setCurrentFrame(Math.min(self.getCurrentFrame()+1, + self.lastFrame())); }; - _self.previousFrame = function () { - _self.setCurrentFrame(Math.max(_self.getCurrentFrame()-1, - _self.firstFrame())); + self.previousFrame = function () { + self.setCurrentFrame(Math.max(self.getCurrentFrame()-1, + self.firstFrame())); }; - _self.next = function () { - var i = _self.getCurrentFrame(); - if (i == _self.lastFrame()) - _self.nextSlide(); + self.next = function () { + var i = self.getCurrentFrame(); + if (i == self.lastFrame()) + self.nextSlide(); else - _self.nextFrame(); + self.nextFrame(); }; - _self.previous = function () { - var i = _self.getCurrentFrame(); - if (i == _self.firstFrame()) - _self.previousSlide(); + self.previous = function () { + var i = self.getCurrentFrame(); + if (i == self.firstFrame()) + self.previousSlide(); else - _self.previousFrame(); + self.previousFrame(); }; - - _self.keyboardHandler = function (event) { - + self.inputHandler = function (event) { + if (_animation_running) return; switch (event.which) { case 36:/* Home */ - _self.firstSlide(); + self.firstSlide(); break; case 35:/* End */ - _self.lastSlide(); + self.lastSlide(); break; case 32: /* space */ case 39: /* -> */ case 1: /* mouse button 1 */ - _self.next(); + self.next(); break; case 34: /* PgDown */ case 78: /* n */ - _self.nextSlide(); + self.nextSlide(); break; case 8: /* backspace */ case 37: /* <- */ - _self.previous(); + self.previous(); break; case 33: /* PgUp */ case 80: /* p */ - _self.previousSlide(); + self.previousSlide(); break; default: return; }; - _self.refresh(); + self.refresh(); + }; + + + function default_footer_template() { + var elem = ''; + return $(elem); }; - var _init = function () { - _total_slides = $(".slide").length; + self.setTemplate('sws-template-footer', function (x) { }); + self.setTemplate('sws-template-frame-activate', function (x, f) {f(x);}); + self.setTemplate('sws-template-frame-deactivate', function (x, f) {f(x);}); + self.setTemplate('sws-template-slide-activate', function (x, f) {f(x);}); + self.setTemplate('sws-template-slide-deactivate', function (x, f) {f(x);}); + + - $(document).keydown(_self.keyboardHandler); - $(document).mousedown(_self.keyboardHandler); + function init () { - var cur = _self.getCurrentSlide(); - $(".slide").each (function (i) { - var elem = ''; - if (!($(this).hasClass("nofooter"))) { - $(this).append($(elem)); + _total_slides = $(".sws-slide").length; + + $(document).keydown(self.inputHandler); + $(document).mousedown(self.inputHandler); + + var cur = self.getCurrentSlide(); + $(".sws-slide").each (function (i) { + if (!($(this).hasClass("sws-option-nofooter"))) { + $(this).append(templates['sws-template-footer']()); }; var par = $(this).parent(); $(this).remove(); - var canvas = $('
'); + var canvas = $('
'); canvas.append($(this)); par.append(canvas); if (i == cur) { - canvas.addClass("current_slide").removeClass("other_slides"); + canvas + .addClass("sws-active-slide") + .removeClass("sws-inacitve-slide"); } else { - canvas.addClass("other_slides").removeClass("current_slide"); + canvas + .addClass("sws-inactive-slide") + .removeClass("sws-active-slide"); }; init_canvas(canvas); @@ -233,23 +339,21 @@ var SimpleWebSlides = new function () { for (var i = 0; i < _defered_custom.length; i++){ var custom = _defered_custom[i]; - var canvas = $(custom.src).parents(".canvas"); + var canvas = $(custom.src).parents(".sws-canvas"); if (canvas.length == 0) continue; canvas = $(canvas[0]); - var info = canvas.data("frames"); + var info = canvas.data("sws-frame-info"); push(info.custom, custom.frame, custom.fn); }; - _self.refresh(); + self.refresh(); _initialized = true; }; - _self.init = function () { - $(document).ready(_init); + self.init = function () { + $(document).ready(init); }; }; - -SimpleWebSlides.init(); \ No newline at end of file