function loadApp() {
var flipbook = $('.sample-docs');
// Check if the CSS was already loaded
if (flipbook.width()==0 || flipbook.height()==0) { setTimeout(loadApp, 10); return; }
// Mousewheel
$('#book-zoom').mousewheel(function(event, delta, deltaX, deltaY) {
var data = $(this).data(), step = 30, flipbook = $('.sample-docs'), actualPos = $('#slider').slider('value')*step;
if (typeof(data.scrollX)==='undefined') { data.scrollX = actualPos; data.scrollPage = flipbook.turn('page'); }
data.scrollX = Math.min($( "#slider" ).slider('option', 'max')*step, Math.max(0, data.scrollX + deltaX));
var actualView = Math.round(data.scrollX/step), page = Math.min(flipbook.turn('pages'), Math.max(1, actualView*2 - 2));
if ($.inArray(data.scrollPage, flipbook.turn('view', page))==-1) { data.scrollPage = page; flipbook.turn('page', page); }
if (data.scrollTimer) clearInterval(data.scrollTimer);
data.scrollTimer = setTimeout(function(){ data.scrollX = undefined; data.scrollPage = undefined; data.scrollTimer = undefined; }, 1000);
});
// Slider
$( "#slider" ).slider({ min: 1, max: 100,
start: function(event, ui) { if (!window._thumbPreview) {
_thumbPreview = $('<div />', {'class': 'thumbnail'}).html('');setPreview(ui.value); _thumbPreview.appendTo($(ui.handle)); } else setPreview(ui.value);
moveBar(false); },
slide: function(event, ui) { setPreview(ui.value); },
stop: function() { if (window._thumbPreview) _thumbPreview.removeClass('show');
$('.sample-docs').turn('page', Math.max(1, $(this).slider('value')*2 - 2)); } });
// URIs
Hash.on('^page\/([0-9]*)$', { yep: function(path, parts) { var page = parts[1];
if (page!==undefined) { if ($('.sample-docs').turn('is')) $('.sample-docs').turn('page', page); }
}, nop: function(path) {
if ($('.sample-docs').turn('is')) $('.sample-docs').turn('page', 1); } });
// Arrows
$(document).keydown(function(e){
var previous = 37, next = 39; //Get the two arrows keyCodes to change page switch (e.keyCode) { case previous:
$('.sample-docs').turn('previous');
break; case next:
$('.sample-docs').turn('next');
break; }
});
// Create the flipbook
flipbook.turn({ elevation: 50, acceleration: false, //True for touch screens gradients: true, autoCenter: true, duration: 1000, pages: 30, when: {
turning: function(e, page, view) {
var book = $(this), currentPage = book.turn('page'), pages = book.turn('pages');
console.log(book.turn('pages')); console.log(page);
if (currentPage > 3){
if(currentPage < pages-3) {
if (page == 1) { book.turn('page', 2).turn('stop').turn('page', page); e.preventDefault(); return; } else if (page == pages) { book.turn('page', pages-1).turn('stop').turn('page', page); e.preventDefault(); return; } } } else if (page > 3){
if(page < pages-3) {
if (currentPage == 1) { book.turn('page', 2).turn('stop').turn('page', page); e.preventDefault(); return; } else if (currentPage == pages) { book.turn('page', pages-1).turn('stop').turn('page', page); e.preventDefault(); return; }
}
}
Hash.go('page/'+page).update();
//Hide tabs on first and last pages if (page == 1 || page == pages) $('.sample-docs .tabs').hide();
},
turned: function(e, page, view) {
var book = $(this);
$('#slider').slider('value', getViewNumber(book, page));
$('.sample-docs .tabs').fadeIn(500); //This is the new line instead of the functionality below about whether the tabs are going to be displayed on #page/1
if(page != book.turn('pages')){ $('.sample-docs .tabs').fadeIn(500); }
else $('.sample-docs .tabs').hide();
book.turn('center'); updateTabs();
},
start: function(e, pageObj) {
moveBar(true);
},
end: function(e, pageObj) {
var book = $(this);
setTimeout(function() { $('#slider').slider('value', getViewNumber(book)); }, 1);
moveBar(false);
},
missing: function (e, pages) {
for (var i = 0; i < pages.length; i++) addPage(pages[i], $(this));
} } });//. turn('page', 0);
$('#slider').slider('option', 'max', numberOfViews(flipbook));
flipbook.addClass('animated');
// Show canvas
$('#canvas').css({visibility: 'visible'}); }
// Hide canvas
$('#canvas').css({visibility: 'hidden'});
loadApp();