shell bypass 403
"use strict"; var FLIPBOOK = FLIPBOOK || {}; if ("localhost" == location.hostname) { var localpathname = document.location.pathname, localfolder = localpathname.split("/"); FLIPBOOK.urlcustom = "http://localhost/" + localfolder[1] + "/modules/mod_flipbookmaster" } else FLIPBOOK.urlcustom = document.location.origin + "/modules/mod_flipbookmaster"; var PRESENTATION = FLIPBOOK; ! function(a, b) { function N() { M = function(a) { function c(c) { function m() { d.renderRequestPending = !0 } c = c || {}; var d = this; a.call(this, c), d.options = c, d.canvas = b(d.renderer.domElement).addClass("flipbook-3dcanvas"), d.container = c.container, d.container.append(d.canvas), d.type = "PreviewStage", d.mouse = new THREE.Vector2, d.raycaster = new THREE.Raycaster, d.camera.position.set(0, 20, 600), d.camera.lookAt(new THREE.Vector3(0, 0, 0)), d.spotLight.position.set(-220, 330, 550), d.spotLight.castShadow = !H && c.webglShadow, d.spotLight.shadow && (d.spotLight.shadow.bias = -8e-4), d.spotLight.intensity = .22, d.ambientLight.color = new THREE.Color("#888"), d.ambientLight.intensity = 1.45; var e = new THREE.ShadowMaterial; e.opacity = .15, d.ground.material = e, d.ground.position.z = -2, d.orbitControl.maxAzimuthAngle = .4, d.orbitControl.minAzimuthAngle = -.4, d.orbitControl.minPolarAngle = 1.4, d.orbitControl.maxPolarAngle = 2.2, d.orbitControl.mouseButtons.ORBIT = THREE.MOUSE.RIGHT, d.orbitControl.mouseButtons.PAN = -1, d.orbitControl.maxDistance = 5e3, d.orbitControl.minDistance = 50, d.orbitControl.noZoom = !0, d.selectiveRendering = !0, d.orbitControl.zoomSpeed = 5, d.orbitControl.keyPanSpeed = 0, d.orbitControl.center.set(0, 0, 0), d.orbitControl.update(), d.swipe_threshold = H ? 15 : 20; var f = d.cssRenderer = new THREE.CSS3DRenderer; b(f.domElement).css({ position: "absolute", top: 0, pointerEvents: "none" }).addClass("flipbook-3dcanvas flipbook-csscanvas"), d.container[0].appendChild(f.domElement); var g = d.cssScene = new THREE.Scene, h = document.createElement("div"); h.className = "flipbook-page-content flipbook-page-content-left"; var i = document.createElement("div"); i.className = "flipbook-page-content flipbook-page-content-right"; var j = g.divLeft = new THREE.CSS3DObject(h), l = g.divRight = new THREE.CSS3DObject(i); g.add(j), g.add(l), d.resizeCallback = function() { f.setSize(d.canvas.width(), d.canvas.height()) }, window.addEventListener(k.move, m, !1), window.addEventListener("keyup", m, !1), d.dispose = function() { d.clearChild(), d.render(), window.removeEventListener(k.move, m, !1), 1 == d.options.scrollWheel && (d.renderer.domElement.removeEventListener("mousewheel", n, !1), d.renderer.domElement.removeEventListener("DOMMouseScroll", n, !1)), window.removeEventListener("keyup", m, !1), d.renderer.domElement.removeEventListener("mousemove", o, !1), d.renderer.domElement.removeEventListener("touchmove", o, !1), d.renderer.domElement.removeEventListener("mousedown", p, !1), d.renderer.domElement.removeEventListener("touchstart", p, !1), d.renderer.domElement.removeEventListener("mouseup", r, !1), d.renderer.domElement.removeEventListener("touchend", r, !1), d.canvas.remove(), f.domElement.remove(), f = null, d.renderCallback = null, d.orbitControl.dispose(), d.orbitControl = null, d.renderer.dispose(), d.cancelRAF() }, d.renderCallback = function() { TWEEN.getAll().length > 0 && (d.renderRequestPending = !0), TWEEN.update(), f.render(g, d.camera) }; var n = function(a) { var b = 0; if (void 0 !== a.wheelDelta ? b = a.wheelDelta : void 0 !== a.detail && (b = -a.detail), b) { var c = d.previewObject.contentProvider.zoomScale; (b > 0 && 1 == c || b < 0 && c > 1) && a.preventDefault(), d.previewObject.zoom(b > 0 ? 1 : -1) } m() }, o = function(a) { if (d.renderRequestPending = !0, a = E(a), d.isMouseDown && 0 != a.movementX && 0 != a.movementY && (d.isMouseMoving = !0), 1 == d.isMouseDown && 1 == d.previewObject.contentProvider.zoomScale) { var b = a.pageX - d.lastPos; performance.now(), d.lastTime; Math.abs(b) > d.swipe_threshold && (b < 0 ? d.target.next() : d.target.prev(), a.preventDefault(), d.isMouseDown = !1), d.lastPos = a.pageX, d.lastTime = performance.now() } }, p = function(a) { a = E(a), document.activeElement.blur(), d.mouseValue = a.pageX + "," + a.pageY, d.isMouseMoving = !1, d.isMouseDown = !0, d.lastPos = a.pageX, d.lastTime = performance.now() }, q = function(a) { if (d.isMouseDown = !1, 0 !== a.button) return this; var c = a.pageX + "," + a.pageY; if (d.isMouseMoving); else if (c == d.mouseValue) { a = a || window.event, a = b.event.fix(a); var e = d.mouse, f = d.raycaster; e.x = a.offsetX / d.canvas.innerWidth() * 2 - 1, e.y = 1 - a.offsetY / d.canvas.innerHeight() * 2, f.setFromCamera(e, d.camera); var g = f.intersectObjects(d.target instanceof MOCKUP.Bundle ? d.target.children : [d.target], !0); if (g.length > 0) { var h, i = 0; do { h = void 0 !== g[i] ? g[i].object : void 0, i++ } while ((h instanceof THREE.BoxHelper || !(h instanceof MOCKUP.Paper) || 1 == h.isFlipping) && i < g.length); void 0 !== h.userData.object || (h.angles[1] > 90 ? 1 != h.isEdge && d.target.next() : 1 != h.isEdge && d.target.prev()) } } }, r = function(a) { a = E(a), q(a) }; return d.renderer.domElement.addEventListener("mousemove", o, !1), d.renderer.domElement.addEventListener("touchmove", o, !1), d.renderer.domElement.addEventListener("mousedown", p, !1), d.renderer.domElement.addEventListener("touchstart", p, !1), d.renderer.domElement.addEventListener("mouseup", r, !1), d.renderer.domElement.addEventListener("touchend", r, !1), 1 == d.options.scrollWheel && (d.renderer.domElement.addEventListener("mousewheel", n, !1), d.renderer.domElement.addEventListener("DOMMouseScroll", n, !1)), b(d.renderer.domElement).css({ display: "block" }), b(window).trigger("resize"), this } return J(c, a), c.prototype.width = function() { return this.container.width() }, c.prototype.height = function() { return this.container.height() }, c }(MOCKUP.Stage), MOCKUP.PreviewStage = M; var d = function(a) { function b(b, c) { b = b || {}, b.folds = 1, a.call(this, b, c), this.angle = 0, this.isFlipping = !1, this.material.materials[5].transparent = !0, this.material.materials[4].transparent = !0, this.type = "BookPaper" } return J(b, a), b.prototype.tween = function(a, b) { var c = this, d = 1e-5; c.originalStiff = c.stiffness; var e = c.newStiffness, f = G(c.parent), g = b - a, h = a > 90; c.init = { angle: a, angle2: a < 90 ? 0 : 180, stiff: c.originalStiff, index: h ? 1 : 0 }, c.first = { angle: a + g / 4, angle2: 90, stiff: c.originalStiff, index: h ? 1 : .25 }, c.mid = { angle: a + 2 * g / 4, angle2: a < 90 ? 135 : 45, stiff: c.newStiffness, index: .5 }, c.mid2 = { angle: a + 3 * g / 4, angle2: a < 90 ? 180 : 0, stiff: c.newStiffness, index: h ? .25 : 1 }, c.end = { angle: b, angle2: a < 90 ? 180 : 0, stiff: c.newStiffness, index: h ? 0 : 1 }, c.isFlipping = !0; var i = function(a, b) { c.angles[1] = a.angle, c.angles[4] = c.isHard ? a.angle : a.angle2, 1 == c.isHard ? c.stiffness = 0 : (c.stiffness = a.stiff / (e + d) * (c.newStiffness + d), c.stiffness = isNaN(c.stiffness) ? 0 : a.stiff), f && (c.material.materials[5].opacity = c.material.materials[4].opacity = a.index, c.castShadow = a.index > .5), c.updateAngle(!0) }; !h && f && (c.material.materials[5].opacity = c.material.materials[4].opacity = 0, c.castShadow = !1), new TWEEN.Tween(c.init).to({ angle: [c.first.angle, c.mid.angle, c.mid2.angle, c.end.angle], angle2: [c.first.angle2, c.mid.angle2, c.mid2.angle2, c.end.angle2], stiff: [c.first.stiff, c.mid.stiff, c.mid2.stiff, c.end.stiff], index: [c.first.index, c.mid.index, c.mid2.index, c.end.index] }, c.parent.duration).onUpdate(function(a) { i(this, a) }).easing(TWEEN.Easing.Sinusoidal.Out).onComplete(function(a) { c.stiffness = c.newStiffness, c.updateAngle(), c.material.materials[5].opacity = c.material.materials[4].opacity = 1, c.castShadow = !0, c.isFlipping = !1, c.parent && c.parent.refresh && c.parent.refresh() }).start() }, b }(MOCKUP.FlexBoxPaper); MOCKUP.BookPaper = d; var e = function(b) { function d(c, d) { c = c || {}, c.segments = c.segments || 50, this.pageCount = c.pageCount, this.height = c.height, this.width = c.width, this.pageCount = 1 == this.pageCount ? this.pageCount : 2 * Math.ceil(this.pageCount / 2), this.direction = c.direction || a.DIRECTION.LTR, this.startPage = 1, this.endPage = this.pageCount, this.stackCount = c.stackCount || 6, this.materials = [], b.call(this, c, d), this.angles = [0, 0, 0, 0, 0, 0], this.stiffness = c.stiffness || 1.5, this.hardConfig = "none", this._activePage = c.openPage || this.startPage, this.createStack(c), this.pageMode = c.pageMode || (H || this.pageCount <= 2 ? a.PAGE_MODE.SINGLE : a.PAGE_MODE.DOUBLE), this.singlePageMode = c.singlePageMode || (H ? a.SINGLE_PAGE_MODE.BOOKLET : a.SINGLE_PAGE_MODE.ZOOM), this.type = "Book" } return J(d, b), d.prototype.getPageByNumber = function(a) { var b = G(this) ? a : Math.floor((a - 1) / 2); return this.getObjectByName(b.toString()) }, d.prototype.isPageHard = function(a) { return g.isHardPage(this.hardConfig, a, this.pageCount) }, d.prototype.activePage = function(a) { if (void 0 == a) return this._activePage; this.gotoPage(a) }, d.prototype.gotoPage = function(a) { a = parseInt(a, 10), this._activePage = a, this.updatePage(a) }, d.prototype.moveBy = function(a) { var b = this._activePage + a; b = v(b, this.startPage, this.endPage), this.gotoPage(b) }, d.prototype.next = function(b) { void 0 == b && (b = this.direction == a.DIRECTION.RTL ? -this.pageMode : this.pageMode), this.moveBy(b) }, d.prototype.prev = function(b) { void 0 == b && (b = this.direction == a.DIRECTION.RTL ? this.pageMode : -this.pageMode), this.moveBy(b) }, d.prototype.updateAngle = function() { for (var a = this.angles[1], b = this.angles[4], c = b - a, d = this.stackCount, e = 0; e < d; e++) { var f = this.children[e]; f.angles[1] = a + e * c / (100 * d), f.stiffness = this.stiffness, f.updateAngle() } }, d.prototype.refresh = function() { this.updatePage(this._activePage), void 0 !== this.flipCallback && this.flipCallback() }, d.prototype.updatePage = function(b) { var d = this.direction == a.DIRECTION.RTL, e = G(this), g = (C(b), e ? 1 : 2); b = Math.floor(b / g), d && (b = this.pageCount / g - b); var h = this.oldBaseNumber || 0, i = this.pageCount / g, j = this.stackCount, k = .02, l = .4, m = e ? 0 : (.5 - Math.abs(i / 2 - b) / i) / this.stiffness, o = Math.floor(j / 2), p = !1; h > b ? (p = !0, this.children[j - 1].skipFlip = !0, this.children.unshift(this.children.pop())) : h < b && (this.children[0].skipFlip = !0, this.children.push(this.children.shift())), Math.abs(h - b); for (var q = i - b, r = 5 / i, s = r * b / 2, t = r * q / 2, u = s < t ? t : s, v = 0; v < j; v++) { var z, w = this.children[v], y = (w.color, w.angles[1]), A = b - o + v, B = w.isHard = this.isPageHard(A), D = w.name; w.visible = A >= 0 && A < i || e && A == i, void 0 !== this.requestPage && (d && (A = Math.floor(this.pageCount / 2) - A - 1), w.name = A.toString(), w.name != D && 1 == w.visible && (w.textureLoaded = !1, w.frontImage(c.textureLoadFallback), w.frontPageStamp = "-1", w.frontTextureLoaded = !1, w.thumbLoaded = !1, w.backImage(c.textureLoadFallback), w.backPageStamp = "-1", w.backTextureLoaded = !1, this.requestPage())), w.isEdge = !1, 0 == v ? w.depth = s < l ? l : s : v == j - 1 ? w.depth = t < l ? l : t : (w.depth = l, w.isEdge = !1), 1 == w.isFlipping && (w.depth = l), w.position.x = 0; var E = k * v, F = 180 - k * (v - o) + k * v; if (v < o ? (w.newStiffness = B ? 0 : m / (b / i) / 4, z = E, w.position.z = u - (-v + o) * l, 1 == p && (w.position.z -= l)) : (z = F, w.newStiffness = B ? 0 : m / (Math.abs(i - b) / i) / 4, w.position.z = u - (-j + v + o + 1) * l - w.depth), 0 == w.isFlipping) if (Math.abs(y - z) > 20 && 0 == w.skipFlip) { w.depth = l; var H = w.stiffness; H = y > z ? m / (Math.abs(i - b) / i) / 4 : m / (b / i) / 4, w.position.z += l, w.stiffness = isNaN(H) ? w.stiffness : H, w.updateAngle(!0), w.targetStiffness = v < b ? m / (Math.abs(i - b) / i) / 4 : m / (b / i) / 4, w.targetStiffness = isNaN(w.targetStiffness) ? w.stiffness : w.targetStiffness, w.isFlipping = !0, w.tween(y, z), void 0 !== this.preFlipCallback && this.preFlipCallback() } else w.skipFlip = !1, w.newStiffness = isNaN(w.newStiffness) ? 0 : w.newStiffness, w.angles[1] == z && w.stiffness == w.newStiffness && w.depth == w.oldDepth || (w.angles[1] = w.angles[4] = z, w.stiffness = w.newStiffness, w.updateAngle(!0)); e && v < o && 0 == w.isFlipping && (w.visible = !1), w.oldDepth = w.depth; var I = Math.abs(w.geometry.boundingBox.max.x) < Math.abs(w.geometry.boundingBox.min.x) ? w.geometry.boundingBox.max.x : w.geometry.boundingBox.min.x; w.position.x = 1 == w.isEdge && 0 == w.isFlipping ? v < o ? I : -I : 0 } this.oldBaseNumber = b, void 0 !== this.updatePageCallback && this.updatePageCallback() }, d.prototype.createCover = function(a) { a.width = 2 * a.width, this.cover = new MOCKUP.BiFold(a), this.add(this.cover) }, d.prototype.createStack = function(a) { for (var b = "red,green,blue,yellow,orange,black".split(","), c = 0; c < this.stackCount; c++) { a.angles = [, this.stackCount - c], a.stiffness = (this.stackCount - c) / 100; var d = new MOCKUP.BookPaper(a); d.angles[1] = 180, d.index = c, d.updateAngle(), d.textureReady = !1, d.textureRequested = !1, this.add(d), d.color = b[c], d.position.z = -1 * c } }, d.prototype.shininess = function(a) { if (void 0 == a) return this.mainObject.shininess(); this.mainObject.shininess(a) }, d.prototype.bumpScale = function(a) { if (void 0 == a) return this.mainObject.bumpScale(); this.mainObject.bumpScale(a) }, d.prototype.frontImage = function(a) { if (void 0 == a) return this.mainObject.frontImage(); this.mainObject.frontImage(a) }, d.prototype.backImage = function(a) { if (void 0 == a) return this.mainObject.backImage(); this.mainObject.backImage(a) }, d }(MOCKUP.Bundle); MOCKUP.Book = e } a.version = "1.2.7", a.PAGE_MODE = { SINGLE: 1, DOUBLE: 2, AUTO: void 0 }, a.SINGLE_PAGE_MODE = { ZOOM: 1, BOOKLET: 2, AUTO: void 0 }, a.DIRECTION = { LTR: 1, RTL: 2 }, a.CORNERS = { TL: "tl", TR: "tr", BL: "bl", BR: "br", L: "l", R: "r", NONE: void 0 }, a.SOURCE_TYPE = { IMAGE: "image", PDF: "pdf", HTML: "html" }, a.DISPLAY_TYPE = { WEBGL: "3D", HTML: "2D" }, a.PAGE_SIZE = { AUTO: 0, SINGLE: 1, DOUBLEINTERNAL: 2 }; var c = a.defaults = { webgl: !0, webglShadow: !0, soundEnable: !0, height: "100%", autoEnableOutline: !1, autoEnableThumbnail: !1, overwritePDFOutline: !1, enableDownload: !0, duration: 800, direction: a.DIRECTION.LTR, pageMode: a.PAGE_MODE.AUTO, singlePageMode: a.SINGLE_PAGE_MODE.AUTO, backgroundColor: "#fff", forceFit: !0, transparent: !1, hard: "none", annotationClass: "", maxTextureSize: 1600, minTextureSize: 256, icons: { altnext: "fa fa-chevron-right fa-1x", altprev: "fa fa-chevron-right fa-1x", next: "fa fa-chevron-right fa-2x", startPage: "fa fa-angle-double-right", endPage: "fa fa-angle-double-right", prev: "fa fa-chevron-left fa-2x", end: "fa fa-angle-double-right", start: "fa fa-angle-double-left", share: "fa fa-share", help: "fa fa-bars", more: "fa fa-info-circle fa-2x", download: "fa fa-download", zoomin: "fa fa-search-plus fa-2x", zoomout: "fa fa-search-minus fa-2x", fullscreen: "fa fa-arrows-alt fa-2x", fitscreen: "fa fa-arrows-corner", thumbnail: "fa fa-file-text fa-2x", outline: "fa fa fa-file-text-o fa-2x", close: "fa fa-times", doublepage: "fa fa-files-o", singlepage: "fa fa-file-o", sound: "fa fa-volume-down", facebook: "fa fa-facebook", google: "fa fa-google", twitter: "fa fa-twitter", mail: "fa fa-newsletter" }, text: { toggleSound: "Turn on/off Sound", toggleThumbnails: "Toggle Thumbnails", toggleOutline: "Toggle Outline/Bookmark", previousPage: "Previous Page", nextPage: "Next Page", toggleFullscreen: "Toggle Fullscreen", zoomIn: "Zoom In", zoomOut: "Zoom Out", toggleHelp: "Toggle Help", singlePageMode: "Single Page Mode", doublePageMode: "Double Page Mode", downloadPDFFile: "Download PDF File", gotoFirstPage: "Goto First Page", gotoLastPage: "Goto Last Page", share: "Share" }, allControls: "altPrev,pageNumber,altNext,outline,thumbnail,zoomIn,zoomOut,fullScreen,share,more,download,pageMode,startPage,endPage,sound", mainControls: "altPrev,pageNumber,altNext,outline,thumbnail,zoomIn,zoomOut,fullScreen,share,more", hideControls: "", scrollWheel: !0, onCreate: function() {}, onCreateUI: function() {}, onFlip: function() {}, beforeFlip: function() {}, onReady: function() {}, zoomRatio: 1.5, pageSize: a.PAGE_SIZE.AUTO, pdfjsSrc: "js/libs/pdf.min.js", pdfjsCompatibilitySrc: "js/libs/compatibility.js", pdfjsWorkerSrc: "js/libs/pdf.worker.min.js", threejsSrc: "js/libs/three.min.js", mockupjsSrc: "js/libs/mockup.min.js", soundFile: "sound/turn2.mp3", enableDebugLog: !1, canvasToBlob: !0, enableAnnotation: !0, textureLoadFallback: "blank", stiffness: 3, minTopOffset: 30, backgroundImage: "", pageRatio: void 0, defaultPageRatio: 210 / 297, pixelRatio: window.devicePixelRatio || 1 }, d = "WebKitCSSMatrix" in window || document.body && "MozPerspective" in document.body.style, e = "onmousedown" in window, g = (window, a.utils = { drag: { left: 0, right: 1, none: -1 }, mouseEvents: e ? { type: "mouse", start: "mousedown", move: "mousemove", end: "mouseup" } : { type: "touch", start: "touchstart", move: "touchmove", end: "touchend" }, html: { div: "<div/>", img: "<img/>", a: "<a>", input: "<input type='text'/>" }, toRad: function(a) { return a * Math.PI / 180 }, toDeg: function(a) { return 180 * a / Math.PI }, transition: function(a, b) { return a ? b / 1e3 + "s ease-out" : "0s none" }, display: function(a) { return a ? "block" : "none" }, resetTranslate: function() { return p(0, 0) }, translateStr: function(a, b) { return d ? " translate3d(" + a + "px," + b + "px, 0px) " : " translate(" + a + "px, " + b + "px) " }, resetBoxShadow: function() { return "rgba(0, 0, 0, 0) 0px 0px 20px" }, rotateStr: function(a) { return " rotateZ(" + a + "deg) " }, bg: function(a) { return "#fff" + t(a) }, bgImage: function(a) { return void 0 == a || "blank" == a ? "" : " url(" + a + ")" }, src: function(a) { return void 0 !== a ? "" + a : "" }, limitAt: function(a, b, c) { return a < b ? b : a > c ? c : a }, distOrigin: function(a, b) { return Math.sqrt(Math.pow(a, 2) + Math.pow(b, 2)) }, distPoints: function(a, b, c, d) { return Math.sqrt(Math.pow(c - a, 2) + Math.pow(d - b, 2)) }, getVectorAvg: function(a) { return { x: a.map(function(a) { return a.x }).reduce(g.sum) / a.length, y: a.map(function(a) { return a.y }).reduce(g.sum) / a.length } }, sum: function(a, b) { return a + b }, getTouches: function(a, b) { return b = b || { left: 0, top: 0 }, Array.prototype.slice.call(a.touches).map(function(a) { return { x: a.pageX - b.left, y: a.pageY - b.top } }) }, angleByDistance: function(a, b) { var c = b / 2, d = v(a, 0, b); return d < c ? n(Math.asin(d / c)) : 90 + n(Math.asin((d - c) / c)) }, log: function(a) { 1 == c.enableDebugLog && window.console && console.log(a) }, lowerPowerOfTwo: function(a) { return Math.pow(2, Math.floor(Math.log(a) / Math.LN2)) }, nearestPowerOfTwo: function(a, b) { return Math.min(b || 2048, Math.pow(2, Math.ceil(Math.log(a) / Math.LN2))) }, zoomStops: function(a, b, c, d, e) { void 0 == d && (d = 256), void 0 == e && (e = 2048); var f = Math.log(a / d) / Math.log(b); return d * Math.pow(b, void 0 == c ? Math.round(f) : 1 == c ? Math.ceil(f) : Math.floor(f)) }, extendOptions: function(a, c) { return b.extend(!0, {}, a, c) }, getBasePage: function(a) { return 2 * Math.floor(a / 2) }, loadResources: function(b, c, d) { var e = document, f = e.createElement(b), g = e.getElementsByTagName(b)[0]; f.async = !0, d && f.addEventListener("load", function(a) { d(null, a) }, !1), f.src = c, g.parentNode.insertBefore(f, g) }, getScript: function(a, b, c) { function f(a, c) { void 0 != d && (c || !d.readyState || /loaded|complete/.test(d.readyState)) && (d.onload = d.onreadystatechange = null, d = void 0, d = null, c || (b && b(), b = null)) } var d = document.createElement("script"), e = document.body.getElementsByTagName("script")[0]; d.async = 1, d.setAttribute("data-cfasync", !1), void 0 != e ? (e.parentNode.insertBefore(d, e), e = null) : document.body.appendChild(d), d.addEventListener("load", f, !1), d.addEventListener("readystatechange", f, !1), d.addEventListener("complete", f, !1), c && d.addEventListener("error", c, !1), d.src = a + ("MS" == F.dom ? "?" + Math.random(1) : "") }, isHardPage: function(a, b, c, d) { if (void 0 !== a) { if ("cover" == a) return 0 == b || d && 1 == b || b == Math.floor(c / (d ? 1 : 2)) - (d ? 0 : 1); if ("all" == a) return !0; var e = ("," + a + ",").indexOf("," + (2 * b + 1) + ",") > -1, f = ("," + a + ",").indexOf("," + (2 * b + 2) + ",") > -1; return e || f } return !1 }, fixMouseEvent: function(a) { if (a) { var c = a.originalEvent || a; if (c.changedTouches && c.changedTouches.length > 0) { var d = b.event.fix(a), e = c.changedTouches[0]; return d.clientX = e.clientX, d.clientY = e.clientY, d.pageX = e.pageX, d.pageY = e.pageY, d.movementX = e.movementX, d.movementY = e.movementY, d } return a } return a }, hasWebgl: function() { try { var a = document.createElement("canvas"); return !(!window.WebGLRenderingContext || !a.getContext("webgl") && !a.getContext("experimental-webgl")) } catch (a) { return !1 } }(), isBookletMode: function(b) { return b.pageMode == a.PAGE_MODE.SINGLE && b.singlePageMode == a.SINGLE_PAGE_MODE.BOOKLET }, isMobile: function() { var a = !1; return function(b) { (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(b) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(b.substr(0, 4))) && (a = !0) }(navigator.userAgent || navigator.vendor || window.opera), a }(), prefix: function() { var a = window.getComputedStyle(document.documentElement, ""), b = Array.prototype.slice.call(a).join("").match(/-(moz|webkit|ms)-/)[1]; return { dom: "WebKit|Moz|MS".match(new RegExp("(" + b + ")", "i"))[1], lowercase: b, css: "-" + b + "-", js: b[0].toUpperCase() + b.substr(1) } }(), __extends: window && window.__extends || function(a, b) { function d() { this.constructor = a } for (var c in b) b.hasOwnProperty(c) && (a[c] = b[c]); return d.prototype = b.prototype, a.prototype = new d, a.__super = b.prototype, a } }), h = a.SOURCE_TYPE, j = (a.DISPLAY_TYPE, g.drag), k = g.mouseEvents, l = g.html, m = g.toRad, n = g.toDeg, p = (g.transition, g.translateStr), r = (g.resetBoxShadow, g.rotateStr), t = (g.bg, g.bgImage), v = (g.src, g.limitAt), w = g.distOrigin, x = g.distPoints, y = g.angleByDistance, z = g.log, A = g.nearestPowerOfTwo, B = g.extendOptions, C = g.getBasePage, D = g.getScript, E = g.fixMouseEvent, F = g.prefix, G = g.isBookletMode, H = g.isMobile, I = g.hasWebgl, J = g.__extends, K = function(a) { return b.extend(!0, {}, c, a) }, L = function(c, d) { function v(a) { u.removeClass("flipbook-active") } function ia(a) { switch (a.keyCode) { case ha: 1 == h.isFullscreen && h.fullScreen.trigger("click"); break; case W: U = !1; break; case X: T = !1; break; case Y: V = !1; break; case ga: d.prev(); break; case fa: d.next() } } var e = "flipbook-ui", f = "flipbook-ui-wrapper", g = e + "-btn", h = d.ui = b(l.div, { class: e }), i = d.options; h.dispose = function() { c.find("." + g).each(function() { b(this).off() }), s.off(), k.off(), m.off(), n.off(), o.off(), p.off(), q.off(), t.off(), u.off(), B.off(), C.off(), F.off(), G.off(), H.off(), I.off(), J.off(), K.off(), L.off(), M.off(), D.remove(), r.remove(), m.remove(), k.remove(), n.remove(), h.shareBox && (h.shareBox.dispose && h.shareBox.dispose(), h.shareBox = null), document.removeEventListener("keyup", ia, !1), window.removeEventListener("click", v, !1), h.update = null, d = null }; var j = function(a) { return isNaN(a) ? a = d.target._activePage : a < 1 ? a = 1 : a > d.target.pageCount && (a = d.target.pageCount), a }, k = h.next = b(l.div, { class: g + " " + e + "-next " + i.icons.next, title: i.text.nextPage, html: "<span>" + i.text.nextPage + "</span>" }).on("click", function() { d.next() }), m = h.prev = b(l.div, { class: g + " " + e + "-prev " + i.icons.prev, title: i.text.previousPage, html: "<span>" + i.text.previousPage + "</span>" }).on("click", function() { d.prev() }), n = b(l.div, { class: f + " " + e + "-zoom" }), o = h.zoomIn = b(l.div, { class: g + " " + e + "-zoomin " + i.icons.zoomin, title: i.text.zoomIn, html: "<span>" + i.text.zoomIn + "</span>" }).on("click", function() { d.zoom(1), h.update(), d.target.startPoint && d.target.pan && d.target.pan(d.target.startPoint) }), p = h.zoomOut = b(l.div, { class: g + " " + e + "-zoomout " + i.icons.zoomout, title: i.text.zoomOut, html: "<span>" + i.text.zoomOut + "</span>" }).on("click", function() { d.zoom(-1), h.update(), d.target.startPoint && d.target.pan && d.target.pan(d.target.startPoint) }); n.append(o).append(p); var q = h.pageNumber = b(l.div, { class: g + " " + e + "-page" }).on("change", function() { var a = parseInt(h.pageInput.val(), 10); a = j(a), d.gotoPage(a) }).on("keyup", function(a) { if (13 == a.keyCode) { var b = parseInt(h.pageInput.val(), 10); b = j(b), b !== j(d.target._activePage || d._activePage) && d.gotoPage(b) } }); h.pageInput = b('<input id="flipbook_book_page_number" type="text"/>').appendTo(q), h.pageLabel = b('<label for="flipbook_book_page_number"/>').appendTo(q); var r = b(l.div, { class: f + " " + e + "-size" }), s = b(l.div, { class: g + " " + e + "-help " + i.icons.help, title: i.text.toggleHelp, html: "<span>" + i.text.toggleHelp + "</span>" }).on("click", function() {}), t = h.sound = b(l.div, { class: g + " " + e + "-sound " + i.icons.sound, title: i.text.toggleSound, html: "<span>" + i.text.toggleSound + "</span>" }).on("click", function() { i.soundEnable = !i.soundEnable, h.updateSound() }); h.updateSound = function() { 0 == i.soundEnable || "false" == i.soundEnable ? t.addClass("disabled") : t.removeClass("disabled") }, h.updateSound(); var u = h.more = b(l.div, { class: g + " " + e + "-more " + i.icons.more }).on("click", function(a) { u.hasClass("flipbook-active") || (b(this).addClass("flipbook-active"), a.stopPropagation()) }); window.addEventListener("click", v, !1); var w = b(l.div, { class: "more-container" }); if (u.append(w), "string" == typeof i.source && 1 == i.enableDownload) { var x = g + " " + e + "-download " + i.icons.download; (h.download = b('<a download target="_blank" class="' + x + '"><span>' + i.text.downloadPDFFile + "</span></a>")).attr("href", i.source).attr("title", i.text.downloadPDFFile) } document.fullscreenEnabled || document.mozFullScreenEnabled || document.webkitFullscreenEnabled || document.msFullscreenEnabled || c.addClass("flipbook-custom-fullscreen"); var B = h.fullScreen = b(l.div, { class: g + " " + e + "-fullscreen " + i.icons.fullscreen, title: i.text.toggleFullscreen, html: "<span>" + i.text.toggleFullscreen + "</span>" }).on("click", function() { var b = (document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || document.msFullscreenElement, d.container[0]); 1 != h.isFullscreen ? (d.container.addClass("flipbook-fullscreen"), b.requestFullscreen ? b.requestFullscreen() : b.msRequestFullscreen ? b.msRequestFullscreen() : b.mozRequestFullScreen ? b.mozRequestFullScreen() : b.webkitRequestFullscreen && b.webkitRequestFullscreen(), h.isFullscreen = !0) : (d.container.removeClass("flipbook-fullscreen"), h.isFullscreen = !1, document.exitFullscreen ? document.exitFullscreen() : document.msExitFullscreen ? document.msExitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitExitFullscreen && document.webkitExitFullscreen()), setTimeout(function() { d.resize() }, 50) }), C = h.fit = b(l.div, { class: g + " " + e + "-fit " + i.icons.fitscreen }).on("click", function() { b(this).toggleClass("flipbook-button-fit-active") }); r.append(B); var D = b(l.div, { class: f + " " + e + "-controls" }), F = (h.shareBox = new a.Share(c, i), h.share = b(l.div, { class: g + " " + e + "-share " + i.icons.share, title: i.text.share, html: "<span>" + i.text.share + "</span>" }).on("click", function(a) { 1 == h.shareBox.isOpen ? h.shareBox.close() : (h.shareBox.update(d.getURLHash()), h.shareBox.show()) })), G = h.startPage = b(l.div, { class: g + " " + e + "-start " + i.icons.start, title: i.text.gotoFirstPage, html: "<span>" + i.text.gotoFirstPage + "</span>" }).on("click", function() { d.start() }), H = h.endPage = b(l.div, { class: g + " " + e + "-end " + i.icons.end, title: i.text.gotoLastPage, html: "<span>" + i.text.gotoLastPage + "</span>" }).on("click", function() { d.end() }), I = h.pageMode = b(l.div, { class: g + " " + e + "-pagemode " + i.icons.singlepage, html: "<span>" + i.text.singlePageMode + "</span>" }).on("click", function() { var a = b(this); d.setPageMode(!a.hasClass(i.icons.doublepage)) }); d.setPageMode(d.target.pageMode == a.PAGE_MODE.SINGLE); for (var J = h.altPrev = b(l.div, { class: g + " " + e + "-prev " + e + "-alt " + i.icons.prev, title: i.text.previousPage, html: "<span>" + i.text.previousPage + "</span>" }).on("click", function() { d.prev() }), K = h.altNext = b(l.div, { class: g + " " + e + "-next " + e + "-alt " + i.icons.next, title: i.text.nextPage, html: "<span>" + i.text.nextPage + "</span>" }).on("click", function() { d.next() }), L = h.thumbnail = b(l.div, { class: g + " " + e + "-thumbnail " + i.icons.thumbnail, title: i.text.toggleThumbnails, html: "<span>" + i.text.toggleThumbnails + "</span>" }).on("click", function() { var a = b(this); if (d.target.thumbContainer) { d.target.thumbContainer.toggleClass("flipbook-thumb-visible"), a.toggleClass("flipbook-active") } else d.contentProvider.initThumbs(), a.toggleClass("flipbook-active"); a.hasClass("flipbook-active") && a.siblings(".flipbook-active").trigger("click"), h.update(!0) }), M = h.outline = b(l.div, { class: g + " " + e + "-outline " + i.icons.outline, title: i.text.toggleOutline, html: "<span>" + i.text.toggleOutline + "</span>" }).on("click", function() { var a = b(this); if (d.target.outlineContainer) { var c = d.target.outlineContainer; a.toggleClass("flipbook-active"), c.toggleClass("flipbook-outline-visible"), a.hasClass("flipbook-active") && a.siblings(".flipbook-active").trigger("click"), h.update(!0) } }), N = i.allControls.replace(/ /g, "").split(","), O = "," + i.mainControls.replace(/ /g, "") + ",", P = "," + i.hideControls.replace(/ /g, "") + ",", Q = 0; Q < N.length; Q++) { var R = N[Q]; if (P.indexOf("," + R + ",") < 0) { var S = h[R]; void 0 !== S && (O.indexOf("," + R + ",") > -1 ? D.append(S) : "more" !== R && "pageNumber" !== R && w.append(S)) } } c.append(D).append(m).append(k).append(n); var T = !1, U = !1, V = !1, W = 16, X = 17, Y = 18, fa = 39, ga = 37, ha = 27; document.addEventListener("keyup", ia, !1), h.update = function(b) { z("ui update"); var e = d.target, f = j(e._activePage || d._activePage), g = e.pageCount || d.pageCount, i = e.direction == a.DIRECTION.RTL, k = 1 == f || 0 == f, l = f == g; h.next.show(), h.prev.show(), h.altNext.removeClass("disabled"), h.altPrev.removeClass("disabled"), (k && !i || l && i) && (h.prev.hide(), h.altPrev.addClass("disabled")), (l && !i || k && i) && (h.next.hide(), h.altNext.addClass("disabled")), h.pageInput.val(f), h.pageLabel.html(f + "/" + g), c.find(".flipbook-thumb-visible, .flipbook-outline-visible").length > 0 ? c.addClass("flipbook-sidemenu-open") : c.removeClass("flipbook-sidemenu-open"), 1 == b && d.resize(), e.contentProvider.zoomScale == e.contentProvider.maxZoom ? h.zoomIn.addClass("disabled") : h.zoomIn.removeClass("disabled"), 1 == e.contentProvider.zoomScale ? h.zoomOut.addClass("disabled") : h.zoomOut.removeClass("disabled") }, void 0 !== d.target && (d.target.ui = h), void 0 !== i.onCreateUI && i.onCreateUI() }, M = void 0, O = function(c) { function d(b) { function d() { setTimeout(function() { c.resize() }, 50) } b = b || {}, this.type = "PreviewObject"; var c = this; window.addEventListener("resize", d, !1), this.sound = document.createElement("audio"), this.sound.setAttribute("src", b.soundFile + "?ver=" + a.version), this.sound.setAttribute("type", "audio/mpeg"), this.dispose = function() { this.container && this.container.info && this.container.info.remove && this.container.info.remove(), this.target && this.target.dispose && this.target.dispose(), this.target = null, this.stage && this.stage.dispose && this.stage.dispose(), this.stage = null, this.ui && this.ui.dispose && this.ui.dispose(), this.ui = null, this.contentProvider && this.contentProvider.dispose && this.contentProvider.dispose(), this.contentProvider = null, window.removeEventListener("resize", d) } } return d.prototype = { start: function() { this.target.gotoPage(this.target.startPage) }, end: function() { this.target.gotoPage(this.target.endPage) }, next: function() {}, prev: function() {}, zoom: function(a) { this.pendingZoom = !0, this.zoomDelta = a, this.resize(), this.ui.update() }, resize: function() { var c = this; if (void 0 != c.target && void 0 != c.target.ui && void 0 != c.target.contentProvider && void 0 != c.target.contentProvider.viewport && void 0 != c.target.stage) { var n, o, d = this.target.pageMode == a.PAGE_MODE.SINGLE, e = c.container.hasClass("flipbook-floating"), f = c.target, i = f.stage, j = f.contentProvider, k = j.pageRatio, m = (j.zoomViewport, "css" !== f.mode), p = b(window).height(), q = 1 == f.ui.isFullscreen ? p : this.options.height; c.container.height(q), Math.min(c.container.height(), p) == p && (q = p), c.container.height(q), q = c.container.height(), m || (i.css({ top: 0, bottom: 0, right: 0, left: 0, transform: "translate3d(" + c.target.left + "px," + c.target.top + "px,0)" }), f.stageHeight = i.height()), n = i.width(), o = i.height(); var x, y, z, B, r = n - (m ? 100 : 0), s = Math.min(o - (m ? 100 : 0), p), t = Math.floor(d ? r : r / 2), u = Math.floor(t / k); if (x = Math.min(u, s), y = Math.floor(x * k), j.maxZoom = j.zoomViewport.height / x, void 0 == c.zoomValue && (c.zoomValue = 1), 1 == c.pendingZoom && void 0 !== c.zoomDelta) { var D, E = (c.zoomDelta, Math.max(x, y)); c.zoomValue = c.zoomDelta > 0 ? c.zoomValue * c.options.zoomRatio : c.zoomValue / c.options.zoomRatio, c.zoomValue = v(c.zoomValue, 1, j.maxZoom), 1 == c.zoomValue ? j.zoomScale = 1 : (D = x * c.zoomValue, D = g.zoomStops(D, c.options.zoomRatio), j.zoomScale = v(D / E, 1, j.maxZoom)) } B = 1 == j.zoomScale || void 0 == j.zoomScale ? 1 : j.zoomScale, j.checkViewportSize(y, x, B), c.contentSourceType == h.PDF && (y = j.viewport.width / B, x = j.viewport.height / B), 1 != j.zoomScale && this.target.container.addClass("flipbook-zoom-enabled"); c.container.width() < 400 ? c.container.addClass("flipbook-xs") : c.container.removeClass("flipbook-xs"); j.maxZoom; if (m) { var H = c.container.find(".flipbook-ui-controls").height(); (null == H || e) && (H = 0), i.canvas.height(q - H), c.container.hasClass("flipbook-sidemenu-open") && (n -= 220), i.resizeCanvas(n, q - H); var K = f.height, L = n * K / q, N = n / q, O = f.width * (d ? 1 : 2), P = L < O ? O / N : f.height, Q = c.options.minTopOffset + (e ? 60 : 30), R = q / (q - Q); z = 1 / (2 * Math.tan(Math.PI * i.camera.fov * .5 / 180) / (P / (B / R))), i.camera.updateProjectionMatrix(), i.renderRequestPending = !0; var S = Q / 2 - c.options.minTopOffset; c.target.position.y = S * K / (c.container.height() - Q), i.cssScene.position.y = c.target.position.y; var T = 1 == j.zoomScale; i.camera.position.z !== z && 1 == c.pendingZoom ? (void 0 !== c.zoomTween && c.zoomTween.stop(), c.zoomTween = new TWEEN.Tween({ campos: i.camera.position.z, otx: i.orbitControl.target.x, oty: i.orbitControl.target.y, otz: i.orbitControl.target.z }).delay(0).to({ campos: z, otx: 0, oty: 0, otz: 0 }, 100).onUpdate(function() { i.camera.position.z = this.campos, T && (i.orbitControl.target = new THREE.Vector3(this.otx, this.oty, this.otz)), i.orbitControl.update() }).easing(TWEEN.Easing.Linear.None).onComplete(function() { i.camera.position.z = z, 1 == j.zoomScale && (i.camera.position.set(0, 0, z), i.orbitControl.target = new THREE.Vector3(0, 0, 0)), i.orbitControl.update() }).start()) : (1 == j.zoomScale ? (i.camera.position.set(0, 0, z), i.orbitControl.target = new THREE.Vector3(0, 0, 0)) : i.camera.position.z = z, i.orbitControl.update()), i.orbitControl.update(), i.orbitControl.mouseButtons.ORBIT = 1 != B ? -1 : THREE.MOUSE.RIGHT, i.orbitControl.mouseButtons.PAN = 1 != B ? THREE.MOUSE.LEFT : -1 } else if (void 0 !== f) { f.pageWidth = Math.round(y), f.fullWidth = 2 * f.pageWidth, f.height = Math.round(x); var U = f.zoomWidth = Math.floor(y * B), V = f.zoomHeight = Math.floor(x * B), W = f.stage.innerWidth() - f.stage.width(), X = f.stage.innerHeight() - f.stage.height(), Y = f.shiftHeight = v((V - (q - X)) / 2, 0, V), Z = f.shiftWidth = v(1 == B ? 1 : (2 * U - f.container.width() + W) / 2, 0, f.fullWidth * B); 1 == B && (f.left = 0, f.top = 0), f.stage.css({ top: -Y, bottom: -Y, right: -Z, left: -Z, transform: "translate3d(" + f.left + "px," + f.top + "px,0)" }); f.stage.innerHeight(); f.wrapper.css({ width: 2 * U, height: V, marginTop: q - V - X > 0 ? (q - X - V) / 2 : 0 }); var _ = Math.floor(w(y, x)) * B; f.stage.find(".flipbook-page-wrapper").width(_).height(_), f.stage.find(".flipbook-book-page, .flipbook-page-front , .flipbook-page-back, .flipbook-page-fold-inner-shadow").height(V).width(U) } c.checkCenter({ type: "resize" }), 1 == j.zoomScale && this.target.container.removeClass("flipbook-zoom-enabled"), f.thumblist && f.thumblist.reset(b(f.thumblist.container).height()), c.pendingZoom = !1 } }, playSound: function() { try { this.options && 1 == this.options.soundEnable && (this.sound.currentTime = 0, this.sound.play()) } catch (a) {} }, setPageMode: function(b) { 1 == b ? (this.ui.pageMode.addClass(this.options.icons.doublepage), this.ui.pageMode.html("<span>" + this.options.text.doublePageMode + "</span>"), this.ui.pageMode.attr("title", this.options.text.doublePageMode), this.target.pageMode = a.PAGE_MODE.SINGLE) : (this.ui.pageMode.removeClass(this.options.icons.doublepage), this.ui.pageMode.html("<span>" + this.options.text.singlePageMode + "</span>"), this.ui.pageMode.attr("title", this.options.text.singlePageMode), this.target.pageMode = a.PAGE_MODE.DOUBLE), this.target && this.target.singlePageMode == a.SINGLE_PAGE_MODE.BOOKLET && this.target.reset(), this.resize() }, height: function(a) { if (void 0 == a) return this.container.height(); this.options.height = a, this.container.height(a), this.resize() }, checkCenter: function(b) { b = void 0 == b ? {} : b, this.centerType = this.centerType || "start"; var n, c = this.target, d = 0, e = 0, f = 0, h = g.getBasePage(c._activePage), i = c._activePage % 2 == 0, j = c.direction == a.DIRECTION.RTL, k = c.pageMode == a.PAGE_MODE.SINGLE, l = k && c.singlePageMode == a.SINGLE_PAGE_MODE.BOOKLET, m = c.stage.width(); if ("css" == c.mode) n = c.wrapper.width(), d = Math.max((n - m) / 2, 0), e = -n / 4, f = n / 4, 0 == h || l ? (c.wrapper.css({ left: k ? j ? f - d : e - d : j ? f : e }), c.shadow.css({ width: "50%", left: j ? 0 : "50%", transitionDelay: "" })) : h == c.pageCount ? (c.wrapper.css({ left: k ? j ? e - d : f - d : j ? e : f }), c.shadow.css({ width: "50%", left: j ? "50%" : 0, transitionDelay: "" })) : (c.wrapper.css({ left: k ? j ? i ? e - d : f - d : i ? f - d : e - d : 0 }), c.shadow.css({ width: "100%", left: 0, transitionDelay: parseInt(c.duration, 10) + 50 + "ms" })), c.wrapper.css({ transition: "resize" == b.type ? "none" : "" }); else if (void 0 !== c.stage) { var p, o = c.position.x; d = c.width / 4, n = c.width, e = -n / 2, f = n / 2, p = 0 == h || l ? j ? f : e : h == c.pageCount ? j ? e : f : k ? j ? i ? e : f : i ? f : e : 0, p !== this.centerEnd && (this.centerTween = new TWEEN.Tween({ x: o }).delay(0).to({ x: p }, c.duration).onUpdate(function() { c.position.x = this.x, c.stage.cssScene.position.x = this.x }).easing(c.ease).start(), this.centerEnd = p) } }, width: function(a) { if (void 0 == a) return this.container.width(); this.options.width = a, this.container.width(a), this.resize() } }, d }(); a.PreviewObject = O; var P = function(d) { function f(d, e, f, g) { f = f || {}; var i = this; if (i.contentRawSource = d || [c.textureLoadFallback], i.contentSource = i.contentRawSource, i.contentSourceType = void 0, i.minDimension = f.minTextureSize || 256, i.maxDimension = f.maxTextureSize || 2048, i.flipbook = g, i.waitPeriod = 50, i.enableDebug = !1, i.zoomScale = 1, i.maxZoom = 2, i.options = f, i.outline = f.outline, i.links = f.links, i.html = f.html, i.isCrossOrigin = f.isCrossOrigin, i.normalViewport = { height: 297, width: 210, scale: 1 }, i.viewport = { height: 297, width: 210, scale: 1 }, i.zoomViewport = { height: 297, width: 210 }, i.thumbsize = 128, i.cacheIndex = 256, i.cache = [], i.pageRatio = f.pageRatio || i.viewport.width / i.viewport.height, i.textureLoadTimeOut = void 0, i.type = "TextureLibrary", Array === i.contentSource.constructor || Array.isArray(i.contentSource) || i.contentSource instanceof Array) i.contentSourceType = h.IMAGE, i.pageCount = i.contentSource.length, b("<img/>").attr("src", i.contentSource[0]).on("load", function() { i.viewport.height = this.height, i.viewport.width = this.width, i.pageRatio = i.viewport.width / i.viewport.height, i.zoomViewport = { width: (i.pageRatio > 1 ? 1 : i.pageRatio) * i.maxDimension, height: i.maxDimension / (i.pageRatio < 1 ? 1 : i.pageRatio) }, i.linkService = new PDFLinkService, b(this).off(), void 0 != e && e(i), z(this.height + ":" + this.width) }); else if ("string" == typeof i.contentSource || i.contentSource instanceof String) { var j = function() { PDFJS.workerSrc = c.pdfjsWorkerSrc, i.contentSourceType = h.PDF, PDFJS.disableAutoFetch = !0, PDFJS.disableStream = !0, PDFJS.externalLinkTarget = PDFJS.LinkTarget.BLANK; var b = PDFJS.getDocument(i.options.docParameters ? i.options.docParameters : d); b.then(function(c) { i.pdfDocument = c, c.getPage(1).then(function(b) { i.normalViewport = b.getViewport(1), i.viewport = b.getViewport(1), i.viewport.height = i.viewport.height / 10, i.viewport.width = i.viewport.width / 10, i.pageRatio = i.viewport.width / i.viewport.height, i.zoomViewport = { width: (i.pageRatio > 1 ? 1 : i.pageRatio) * i.maxDimension, height: i.maxDimension / (i.pageRatio < 1 ? 1 : i.pageRatio) }, i.refPage = b, c.numPages > 1 ? c.getPage(2).then(function(b) { if (i.options.pageSize == a.PAGE_SIZE.AUTO) { var d = b.getViewport(1); d.width / d.height > 1.5 * i.pageRatio ? (i.options.pageSize = a.PAGE_SIZE.DOUBLEINTERNAL, i.pageCount = 2 * c.numPages - 2) : i.options.pageSize = a.PAGE_SIZE.SINGLE } void 0 != e && e(i) }) : void 0 != e && e(i) }), i.linkService = new PDFLinkService, i.linkService.setDocument(c, null), i.pageCount = c.numPages, i.contentSource = c }, function(b) { var c = "", d = document.createElement("a"); d.href = i.contentSource, d.hostname !== window.location.hostname && (c = "CROSS ORIGIN!! "), i.updateInfo(c + "Cannot access file! " + i.contentSource) }), b.onProgress = function(b) { var c = 100 * b.loaded / b.total; isNaN(c) ? b && b.loaded ? i.updateInfo("Loading PDF " + (Math.ceil(b.loaded / 1e4) / 100).toString() + "MB ...") : i.updateInfo("Loading PDF ...") : i.updateInfo("Loading PDF " + c.toString().split(".")[0] + "% ...") } }, k = function() { c.pdfjsWorkerSrc += "?ver=" + a.version, i.updateInfo("Loading PDF Worker ..."); var d = document.createElement("a"); d.href = c.pdfjsWorkerSrc, d.hostname !== window.location.hostname ? (i.updateInfo("Loading PDF Worker CORS ..."), b.ajax({ url: c.pdfjsWorkerSrc, cache: !0, success: function(b) { c.pdfjsWorkerSrc = a.createObjectURL(b, "text/javascript"), j() } })) : j() }; void 0 == window.PDFJS ? (i.updateInfo("Loading PDF Service ..."), D(c.pdfjsSrc + "?ver=" + a.version, function() { "function" == typeof define && define.amd ? (i.updateInfo("Loading PDF Service (require) ..."), require(["pdfjs-dist/build/pdf"], function(a) { k() })) : k() }, function() { i.updateInfo("Unable to load PDF service..") })) : j() } else console.error("Unknown source type. Please check documentation for help"); return this.dispose = function() { this.targetObject && (this.targetObject.dispose && this.targetObject.dispose(), this.targetObject.processPage = null, this.targetObject.requestPage = null), this.pdfDocument && this.pdfDocument.destroy && this.pdfDocument.destroy(), this.linkService && this.linkService.dispose && this.linkService.dispose(), this.outlineViewer && this.outlineViewer.dispose && this.outlineViewer.dispose(), this.thumblist && this.thumblist.dispose && this.thumblist.dispose(), this.targetObject = null, this.pdfDocument = null, this.linkService = null, this.outlineViewer = null, this.thumblist = null }, this } J(f, d); var e = void 0; return f.prototype.updateInfo = function(a) { this.flipbook && this.flipbook.updateInfo && this.flipbook.updateInfo(a) }, f.prototype.initThumbs = function() { var a = this; void 0 == a.cache[a.thumbsize] && (a.cache[a.thumbsize] = []); var c, d = function() { clearTimeout(c), c = setTimeout(function() { c = setTimeout(e, a.waitPeriod / 2) }, a.waitPeriod) }, e = function() { var e = 0; Date.now() - a.thumblist.lastScrolled < 100 ? e = 1 : (a.targetObject.container.find(".flipbook-thumb-container .flipbook-vrow").each(function() { var c = b(this); if (!c.hasClass("flipbook-thumb-loaded")) { e++; var f = b(this).attr("id").replace("flipbook-thumb", ""); return a.getPage(f, d, !0), c.addClass("flipbook-thumb-loaded"), !1 } }), 0 == e && clearTimeout(c)), e > 0 && d() }; a.thumblist = a.targetObject.thumblist = new ThumbList({ h: 500, addFn: function(a) {}, scrollFn: d, itemHeight: 128, totalRows: a.pageCount, generatorFn: function(a) { var b = document.createElement("div"), c = a + 1; b.id = "flipbook-thumb" + c; var d = document.createElement("div"); return d.innerHTML = c, b.appendChild(d), b } }), a.thumblist.lastScrolled = Date.now(), d(), a.targetObject.thumbContainer = b(a.thumblist.container).addClass("flipbook-thumb-container flipbook-thumb-visible"), a.targetObject.container.append(a.targetObject.thumbContainer), a.thumblist.reset(b(a.thumblist.container).height()), a.targetObject.container.on("click", ".flipbook-thumb-container .flipbook-vrow", function(c) { c.stopPropagation(); var d = b(this).attr("id").replace("flipbook-thumb", ""); a.targetObject.gotoPage(parseInt(d, 10)) }) }, f.prototype.initOutline = function() { function d(b) { if (1 == a.options.overwritePDFOutline && (b = []), b = b || [], a.outline) for (var c = 0; c < a.outline.length; c++) a.outline[c].custom = !0, b && b.push(a.outline[c]); a.outlineViewer.render({ outline: b }) } var a = this, c = b("<div>").addClass("flipbook-outline-container"); a.targetObject.container.append(c), a.targetObject.outlineContainer = c, a.outlineViewer = new BookMarkViewer({ container: c[0], linkService: a.linkService, outlineItemClass: "flipbook-outline-item", outlineToggleClass: "flipbook-outline-toggle", outlineToggleHiddenClass: "flipbook-outlines-hidden" }), a.pdfDocument ? a.pdfDocument.getOutline().then(function(a) { d(a) }) : d([]), 1 == a.options.autoEnableOutline && a.targetObject.ui.outline.trigger("click"), 1 == a.options.autoEnableThumbnail && a.targetObject.ui.thumbnail.trigger("click") }, f.prototype.checkViewportSize = function(a, b, d) { var e = this, f = e.targetObject, i = a * d, j = b * d, k = e.cacheIndex; if (e.contentSourceType == h.PDF) { if (e.cacheIndex = Math.ceil(Math.max(i, j)), 1 !== d && (e.cacheIndex = A(Math.max(i, j)), e.cacheIndex = g.zoomStops(Math.max(i, j), e.options.zoomRatio, k < e.cacheIndex)), e.cacheIndex = v(e.cacheIndex * c.pixelRatio, e.minDimension, e.maxDimension), void 0 == e.cache[e.cacheIndex] && (e.cache[e.cacheIndex] = []), k !== e.cacheIndex) { for (var l = 0; l < f.children.length; l++) { f.children[l] } f.refresh() } e.viewport = "css" == f.mode ? e.refPage.getViewport(j / e.normalViewport.height) : e.refPage.getViewport(300 / e.normalViewport.height), z(e.cacheIndex); var n = f.container.find(".linkAnnotation"), o = e.viewport.clone({ dontFlip: !0 }); n.css({ transform: "matrix(" + o.transform.join(",") + ")" }) } else void 0 == e.cache[e.cacheIndex] && (e.cache[e.cacheIndex] = []) }, f.prototype.getCache = function(a, b) { return 1 == b ? void 0 == this.cache[this.thumbsize] ? void 0 : this.cache[this.thumbsize][a] : void 0 == this.cache[this.cacheIndex] ? void 0 : this.cache[this.cacheIndex][a] }, f.prototype.setCache = function(a, b, c, d) { if (1 == c) void 0 != this.cache[this.thumbsize] && (this.cache[this.thumbsize][a] = b); else { var e = void 0 == d ? this.cacheIndex : d; void 0 != this.cache[e] && (this.cache[e][a] = b) } }, f.prototype.setTarget = function(a) { var b = this; if (void 0 == a) return this.targetObject; this.targetObject = a, a.contentProvider = this, a.container.removeClass("flipbook-loading flipbook-init"), void 0 !== b.linkService && (b.linkService.setViewer(a), b.initOutline()), a.processPage = function(a, d) { a > 0 && a <= b.pageCount ? b.getPage(a, d) : b.setPage(a, c.textureLoadFallback, d) }, a.requestPage = function() { b.review("Request") }, void 0 !== a.resize && a.resize() }, f.prototype.review = function(a) { var b = this; a = a || "timer review", clearTimeout(e), e = setTimeout(function() { e = setTimeout(b.reviewPages, b.waitPeriod / 2, b, a) }, b.waitPeriod) }, f.prototype.reviewPages = function(a, c) { a = a || this; var d = a.targetObject; if (void 0 != d) { var e = G(d); void 0 !== c && z(c); var g, h, f = !1; for (g = 0; g < a.targetObject.children.length; g++) if (h = d.children[g], 1 == h.isFlipping) { f = !0; break } if (0 == f) { var i = d.children.length > 3 ? 3 : d.children.length, k = e ? d._activePage : C(d._activePage); for (a.zoomScale > 1 && (i = 1), g = 0; g < i; g++) { var l = Math.floor(g / 2), m = g % 2 == 0 ? -l * (e ? 1 : 2) : (0 == l ? 1 : l) * (e ? 1 : 2), n = k + m, o = k + m + 1, p = d.getPageByNumber(n), q = d.getPageByNumber(o), r = n + "|" + a.cacheIndex, s = o + "|" + a.cacheIndex, t = 0; if (void 0 !== p && p.frontPageStamp != r && 1 == p.visible && (d.processPage(n, function() { a.review("Batch Call") }), p.frontPageStamp = r, p.frontTextureLoaded = !0, t++), void 0 === q || q.backPageStamp == s || 1 != q.visible || e || (d.processPage(o, function() { a.review("Batch Call") }), q.backPageStamp = s, q.backTextureLoaded = !0, t++), 0 == m && a.annotedPage !== k && "css" !== d.mode && (a.getAnnotations(n), e || a.getAnnotations(o), a.annotedPage = k), t > 0) break } 0 == t && ("css" !== d.mode ? a.setLoading(k) : (a.setLoading(k), a.setLoading(k + 1))) } else if (a.review("Revisit request"), void 0 !== a.annotedPage && "css" !== d.mode) { var u = C(d._activePage); b(d.getContentLayer(u)).html(""), b(d.getContentLayer(u + 1)).html(""), a.annotedPage = void 0 } } }, f.prototype.getPage = function(b, d, e) { function j(b, d, e) { var f = new Image; f.crossOrigin = "Anonymous", f.onload = function() { if (1 == e) { var g = document.createElement("canvas"), h = g.getContext("2d"); g.width = f.width, g.height = f.height, h.drawImage(f, 0, 0), 1 == c.canvasToBlob ? g.toBlob(function(b) { var c = a.createObjectURL(b, "image/jpeg"); void 0 != d && d(c) }, "image/jpeg", .85) : void 0 != d && d(g) } else void 0 != d && d(b); f.onload = null, f = null }, f.src = b, (f.complete || void 0 === f.complete) && (f.src = "", f.src = b) } function k(b, c, d, e) { var g = f.options.forceFit, h = f.options.pageSize == a.PAGE_SIZE.DOUBLEINTERNAL && c > 1 && c < f.pageCount, i = h && g ? 2 : 1, j = g ? b.getViewport(1) : f.normalViewport, k = f.cacheIndex / Math.max(j.width / i, j.height); 1 == f.webgl && (k = A(f.cacheIndex) / (f.pageRatio > 1 ? j.width / i : j.height)); var l = document.createElement("canvas"), m = performance.now(), n = f.cacheIndex, o = l.getContext("2d"); 1 == e && (k = f.thumbsize / f.normalViewport.height), l.height = Math.round(j.height * k), l.width = Math.round(j.width / i * k), "css" == f.targetObject.mode && Math.abs(f.targetObject.zoomHeight - l.height) < 2 && (l.height = f.targetObject.zoomHeight + 0, l.width = f.targetObject.zoomWidth + 0), j = b.getViewport(k), z("rendering " + c + " at " + l.width + "x" + l.height), h && c % 2 == 1 && (j.transform[4] = -l.width); var p = { canvasContext: o, viewport: j }; b.cleanupAfterRender = !0, b.render(p).promise.then(function() { z(performance.now() - m), m = performance.now(), 1 == e || 1 == f.options.canvasToBlob && !0 !== f.webgl ? l.toBlob(function(b) { var g = a.createObjectURL(b, "image/jpeg"); z(performance.now() - m), f.setCache(c, g, e, n), f.setPage(c, g, d, e) }, "image/jpeg", .9) : f.setPage(c, l, d, e), p = null }) } var f = this; b = parseInt(b, 10); var g = f.contentSource; if (b <= 0 && b >= f.pageCount) f.setPage(b, c.textureLoadFallback, d, e); else if (f.contentSourceType == h.PDF) if (void 0 !== f.getCache(b, e)) f.setPage(b, f.getCache(b, e), d, e), z("Page " + b + " loaded from cache"); else { !0 !== e && f.setLoading(b, !0); var i = b; f.options.pageSize == a.PAGE_SIZE.DOUBLEINTERNAL && b > 2 && (i = Math.ceil((b - 1) / 2) + 1), g.getPage(i, e).then(function(a) { k(a, b, d, e) }) } else f.contentSourceType != h.IMAGE && f.contentSourceType != h.HTML || (void 0 !== f.getCache(b, e) ? (f.setPage(b, f.getCache(b, e), d, e), z("Page " + b + " loaded from cache")) : (!0 !== e && f.setLoading(b, !0), void 0 == f.isCrossOrigin ? (f.setCache(b, g[b - 1], e, f.cacheIndex), f.setPage(b, g[b - 1], d, e), void 0 != d && d()) : j(g[b - 1], function(a) { f.setCache(b, a, e, f.cacheIndex), f.setPage(b, a, d, e), void 0 != d && d() }, f.isCrossOrigin))) }, f.prototype.getTargetPage = function(a) {}, f.prototype.setLoading = function(a, c) { if (void 0 !== this.targetObject) if (1 == this.webgl) { var d = this.targetObject.container; 1 == c ? !0 !== d.isLoading && (d.addClass("flipbook-loading"), d.isLoading = !0, z("Loading icon at " + a + " as " + c)) : void 0 !== d.isLoading && (d.removeClass("flipbook-loading"), d.isLoading = void 0, z("Loading icon at " + a + " as " + c)) } else { var e = b(this.targetObject.getContentLayer(a)); void 0 !== e && (1 == c ? e.addClass("flipbook-page-loading") : e.removeClass("flipbook-page-loading")) } }, f.prototype.getAnnotations = function(c) { var d = this; if (0 != d.options.enableAnnotation) { var e = d.targetObject; c = parseInt(c, 10); var f = d.contentSource, g = b(e.getContentLayer(c)); if (g.empty(), c > 0 && c <= d.pageCount) { if (d.contentSourceType == h.PDF) { var j = (C(c), c); d.options.pageSize == a.PAGE_SIZE.DOUBLEINTERNAL && c > 2 && (j = Math.ceil((c - 1) / 2) + 1), f.getPage(j).then(function(a) { void 0 !== g && g.length > 0 && d.setupAnnotations(a, d.viewport, g, c) }) } if (void 0 !== d.links && void 0 !== d.links[c]) for (var k = d.links[c], l = 0; l < k.length; l++) { var m = k[l], n = document.createElement("a"); n.setAttribute("dest", m.dest), n.className = "customLinkAnnotation", n.href = "#" + m.dest, n.onclick = function() { var a = this.getAttribute("dest"); return a && d.linkService.customNavigateTo(a), !1 }, n.style.left = m.x + "%", n.style.top = m.y + "%", n.style.width = m.w + "%", n.style.height = m.h + "%", g[0].appendChild(n) } if (void 0 !== d.html && void 0 !== d.html[c]) { var o = d.html[c]; g.append(b("<div class='customHTMLAnnotation'>").html(o)) } } } }, f.prototype.setPage = function(b, d, e, f) { var g = this, h = g.targetObject; if (1 == f) { g.targetObject.container.find("#flipbook-thumb" + b).css({ backgroundImage: t(d) }) } else { d == c.textureLoadFallback ? z("Fallback on " + b) : "css" == h.mode && g.getAnnotations(b); var j = h.getPageByNumber(b); void 0 !== j ? b % 2 != 0 && h.direction == a.DIRECTION.LTR || b % 2 != 1 && h.direction == a.DIRECTION.RTL || G(g.targetObject) ? (z(b + "rendered to back of " + j.color), j.backImage(d, function() { g.setLoading(b), void 0 != e && e() })) : (z(b + "rendered to front of " + j.color), j.frontImage(d, function() { g.setLoading(b), void 0 != e && e() })) : z("Invalid set request on Page " + b) } }, f.prototype.setupAnnotations = function(c, d, e, f) { if (void 0 != e && 0 != b(e).length) { var g = this; return c.getAnnotations().then(function(h) { if (d = d.clone({ dontFlip: !0 }), g.options.pageSize, a.PAGE_SIZE.DOUBLEINTERNAL, void 0 != e) { e = b(e), 0 == e.find(".annotationDiv").length && e.append(b("<div class='annotationDiv'>")); var i = e.find(".annotationDiv"); i.empty(), g.options.pageSize == a.PAGE_SIZE.DOUBLEINTERNAL && f > 2 && f % 2 == 1 ? i.css({ left: "-100%" }) : 1 == f && i.css({ left: "" }), PDFJS.AnnotationLayer.render({ annotations: h, div: i[0], page: c, viewport: d, linkService: g.linkService }), g.options.annotationClass && "" !== g.options.annotationClass && i.find(" > section").addClass(g.options.annotationClass) } }) } }, f }({}), Q = function() { function d(a) { this.angles = a.angles || [0, 0, 0, 0, 0, 0], this.stiffness = a.angles || .1, this.segments = a.segments || 1, this.initDOM() } function e(a) { var c = a.contentLayer = b(l.div, { class: "flipbook-page-content" }); a.append(c) } return d.prototype = { initDOM: function() { var a = this.element = b(l.div, { class: "flipbook-book-page" }), c = this.wrapper = b(l.div, { class: "flipbook-page-wrapper" }), d = this.front = b(l.div, { class: "flipbook-page-front" }), f = this.back = b(l.div, { class: "flipbook-page-back" }), g = this.foldInnerShadow = b(l.div, { class: "flipbook-page-fold-inner-shadow" }), h = this.foldOuterShadow = b(l.div, { class: "flipbook-page-fold-outer-shadow" }); this.frontIMG = new Image, this.backIMG = new Image, e(d, this.segments, !0), e(f, this.segments, !1), a.append(c).append(h), c.append(d).append(f).append(g) }, updatePoint: function(b) { if (void 0 != b) { var c = void 0 != this.parent.dragPage ? this.parent.dragPage : void 0 != b.page ? b.page : this, d = c.element.width(), e = c.element.height(), f = void 0 !== this.parent.corner ? this.parent.corner : b.corner, g = a.CORNERS, h = c.side == j.right, i = f == g.BL || f == g.BR; b.rx = 1 == h ? 2 * d - b.x : b.x, b.ry = 1 == i ? e - b.y : b.y; var k = Math.atan2(b.ry, b.rx); k = Math.PI / 2 - v(k, 0, m(90)); var l = h ? b.x / 2 : d - b.x / 2, o = b.ry / 2, q = Math.max(0, Math.sin(k - Math.atan2(o, l)) * w(l, o)), s = .5 * w(b.rx, b.ry), t = Math.round(d - q * Math.sin(k)), u = Math.round(q * Math.cos(k)), x = n(k), y = i ? h ? 90 - x + 180 : 180 + x : h ? x : 90 - x, z = i ? h ? 90 - x + 180 : x : h ? x + 180 : y, A = i ? h ? 90 - x : x + 90 : h ? y - 90 : y + 180, B = h ? d - t : t, C = i ? e + u : -u, D = h ? -t : t - d, E = i ? -e - u : u, G = v(.5 * b.distance / d, 0, .5), H = v(.5 * (2 * d - b.rx) / d, .05, .3); c.element.addClass("flipbook-folding"); var I = h ? c.back : c.front, J = h ? c.front : c.back, K = c.foldOuterShadow, L = c.foldInnerShadow; c.wrapper.css({ transform: p(B, C) + r(y) }), I.css({ transform: r(-y) + p(-B, -C) }), J.css({ transform: r(z) + p(D, E), boxShadow: "rgba(0, 0, 0, " + G + ") 0px 0px 20px" }), L.css({ transform: r(z) + p(D, E), opacity: H / 2, backgroundImage: F.css + "linear-gradient( " + A + "deg, rgba(0, 0, 0, 0.25) , rgb(0, 0, 0) " + .7 * s + "px, rgb(255, 255, 255) " + s + "px)" }), K.css({ opacity: H / 2, left: h ? "auto" : 0, right: h ? 0 : "auto", backgroundImage: F.css + "linear-gradient( " + (180 - A) + "deg, rgba(0, 0, 0,0) " + s / 3 + "px, rgb(0, 0, 0) " + s + "px)" }) } }, updateAngle: function(a, b) { var c = 5 * this.element.width(); this.wrapper.css({ perspective: c, perspectiveOrigin: 1 == b ? "0% 50%" : "100% 50%" }), this.front.css({ display: 1 == b ? a <= -90 ? "block" : "none" : a < 90 ? "block" : "none", transform: ("MfS" !== F.dom ? "" : "perspective(" + c + "px) ") + (1 == b ? "translateX(-100%) " : "") + "rotateY(" + ((1 == b ? 180 : 0) + a) + "deg)" }), this.back.css({ display: 1 == b ? a > -90 ? "block" : "none" : a >= 90 ? "block" : "none", transform: ("MSd" !== F.dom ? "" : "perspective(" + c + "px) ") + (0 == b ? "translateX(100%) " : "") + "rotateY(" + ((0 == b ? -180 : 0) + a) + "deg)" }) }, tween: function(b) { var c = this; if (void 0 != c && void 0 != c.parent) { var i, d = G(c.parent), e = c.side == j.right, f = c.parent.corner == a.CORNERS.BL || c.parent.corner == a.CORNERS.BR, g = 1 == c.magnetic, h = f ? c.parent.height : 0, m = 0, n = c.end = c && 1 == c.animateToReset ? { x: e ? c.parent.fullWidth : 0, y: h } : { x: e ? 0 : c.parent.fullWidth, y: h }; c.ease = c.isHard ? TWEEN.Easing.Quadratic.InOut : TWEEN.Easing.Linear.None; var o = c.parent.duration; 1 == c.isHard ? (void 0 != b && (m = y(b.distance, b.fullWidth)), i = c.init = { angle: m * (e ? -1 : 1) }, n = c.end = c && 1 == c.animateToReset ? { angle: e ? 0 : -0 } : { angle: e ? -180 : 180 }) : void 0 == b ? (i = c.init = c && 1 == c.animateToReset ? { x: e ? 0 : c.parent.fullWidth, y: 0 } : { x: e ? c.parent.fullWidth : 0, y: 0 }, c.first = { x: (e ? 3 : 1) * c.parent.fullWidth / 4, y: 0 }, c.mid = { x: (e ? 1 : 3) * c.parent.fullWidth / 4, y: 0 }) : (i = c.init = { x: b.x, y: b.y, opacity: 1 }, c.first = { x: 3 * b.x / 4, y: 3 * b.y / 4, opacity: 1 }, c.mid = { x: b.x / 4, y: b.y / 4, opacity: 1 }, o = c.parent.duration * x(i.x, i.y, n.x, n.y) / c.parent.fullWidth, o = v(o, c.parent.duration / 3, c.parent.duration)), i.index = 0, n.index = 1, c.isFlipping = !0; var p = function(a) { 1 == c.isHard ? c.updateAngle(a.angle, e) : c.updatePoint({ x: a.x, y: a.y }), d && !g && (c.element[0].style.opacity = e ? a.index > .5 ? 2 * (1 - a.index) : 1 : a.index < .5 ? 2 * a.index : 1) }; !e && d && (c.element[0].style.opacity = 0); c.completeTween = c.completeTween || function(b) { c.isFlipping = !1, 1 == c.isHard ? (c.updateAngle(c.end.angle), c.back.css({ display: "block" }), c.front.css({ display: "block" })) : c.updatePoint({ x: c.end.x, y: c.end.y }), c.element[0].style.opacity = 1, !0 !== c.animateToReset ? c.side = c.side == j.right ? j.left : j.right : c.animateToReset = void 0, c.currentTween = void 0, c.pendingPoint = void 0, c.magnetic = !1, c.parent.dragPage = void 0, c.parent.corner = a.CORNERS.NONE, 1 != b && c.parent.refresh() }; 1 == c.isHard ? c.currentTween = new TWEEN.Tween(i).delay(0).to(n, c.parent.duration).onUpdate(function() { p(this) }).easing(c.ease).onComplete(c.completeTween).start() : void 0 == b ? c.currentTween = new TWEEN.Tween(i).delay(0).to(n, c.parent.duration).onUpdate(function() { p(this) }).easing(TWEEN.Easing.Sinusoidal.Out).onComplete(c.completeTween).start() : (c.currentTween = new TWEEN.Tween(i).delay(0).to(n, o).onUpdate(function() { p(this) }).easing(TWEEN.Easing.Sinusoidal.Out).onComplete(c.completeTween), c.currentTween.start()) } }, frontImage: function(a, d) { function f() { e.front.css({ backgroundImage: t(a) }), void 0 !== d && d() } var e = this; "CANVAS" == a.nodeName ? (e.front.find(">canvas").remove(), e.front.append(b(a)), void 0 !== d && d()) : a == c.textureLoadFallback ? f() : (e.frontIMG.onload = f, e.frontIMG.src = a) }, backImage: function(a, d) { function f() { e.back.css({ backgroundImage: t(a) }), void 0 !== d && d() } var e = this; "CANVAS" == a.nodeName ? (e.back.find(">canvas").remove(), e.back.append(b(a)), void 0 !== d && d()) : a == c.textureLoadFallback ? f() : (e.backIMG.onload = f, e.backIMG.src = a) }, updateCSS: function(a) { this.element.css(a) }, resetCSS: function() { this.wrapper.css({ transform: "" }), this.front.css({ transform: "", boxShadow: "" }), this.back.css({ transform: "", boxShadow: "" }) }, clearTween: function(a) { this.currentTween.stop(), this.completeTween(1 == a), this.resetCSS() } }, d }(), R = function(e) { function f(a) { a.parent.container.find(".flipbook-folding").removeClass("flipbook-folding"), a.element.addClass("flipbook-folding") } function h(a) { for (var b = !1, c = 0; c < a.pages.length; c++) { if (1 == a.pages[c].isFlipping) { b = !0; break } } return b } function i(c, e) { function k(a) { i.dragPage != a.page && 1 == a.page.visible && (i.dragPage.clearTween(!0), i.dragPage = a.page, i.corner = a.corner, i.dragPage.pendingPoint = a) } var i = this; i.type = "BookCSS", i.images = c.images || [], i.pageCount = c.pageCount || 2, i.foldSense = 50, i.stackCount = 4, i.mode = "css", i.pages = [], i.duration = c.duration, i.container = b(e), i.options = c, i.drag = j.none, i.pageCount = 1 == i.pageCount ? i.pageCount : 2 * Math.ceil(i.pageCount / 2), i.pageMode = c.pageMode || (H || i.pageCount <= 2 ? a.PAGE_MODE.SINGLE : a.PAGE_MODE.DOUBLE), i.singlePageMode = c.singlePageMode || (H ? a.SINGLE_PAGE_MODE.BOOKLET : a.SINGLE_PAGE_MODE.ZOOM), i.swipe_threshold = H ? 15 : 50, i.direction = c.direction || a.DIRECTION.LTR, i.startPage = 1, i.endPage = i.pageCount, i._activePage = c.openPage || i.startPage, i.hardConfig = c.hard, d = "WebKitCSSMatrix" in window || document.body && "MozPerspective" in document.body.style, i.animateF = function() { TWEEN.getAll().length > 0 ? TWEEN.update() : clearInterval(i.animate) }, i.init(c), i.skipDrag = !1; var l = function(b) { var c = i.eventToPoint(b); if (void 0 !== b.touches && 2 == b.touches.length && void 0 !== i.startTouches) { return } if (!(void 0 !== b.touches && b.touches.length > 1 || void 0 == i.startPoint || void 0 !== i.startTouches)) { var l = i.dragPage || c.page; if (1 !== i.contentProvider.zoomScale) void 0 === b.touches && 1 != i.isPanning || (i.pan(c), b.preventDefault()); else if (!0 !== i.skipDrag) { c.distance; if (!h(i)) { if (void 0 !== i.dragPage || 1 == c.isInside) { void 0 !== i.dragPage ? z("set mouse down move") : (c.y = v(c.y, 1, i.height - 1), c.x = v(c.x, 1, c.fullWidth - 1)); var o = i.corner || c.corner; if (l.isHard) { var p = o == a.CORNERS.BR || o == a.CORNERS.TR, q = y(c.distance, c.fullWidth); l.updateAngle(q * (p ? -1 : 1), p) } else l.updatePoint(c, i); l.magnetic = !0, l.magneticCorner = c.corner, b.preventDefault() } if (void 0 == i.dragPage && void 0 !== l && 0 == c.isInside && 1 == l.magnetic && (l.pendingPoint = c, l.animateToReset = !0, i.corner = l.magneticCorner, i.animatePage(l), l.pendingPoint = void 0, l.magnetic = !1, l.magneticCorner = void 0), 1 == i.isPanning && void 0 == i.dragPage && 1 == i.contentProvider.zoomScale) { var r = c.x - i.lastPos; performance.now(), i.lastTime; Math.abs(r) > i.swipe_threshold && (r < 0 ? i.next() : i.prev(), i.drag = j.none, i.isPanning = !1, b.preventDefault()), i.lastPos = c.x, i.lastTime = performance.now() } } } } }, m = function(b) { if (void 0 !== b.touches && 0 == b.touches.length) { var c = i.contentProvider.zoomScale; (i.lastScale > 1 && c < i.contentProvider.maxZoom || i.lastScale < 1 && c > 1) && i.previewObject.zoom(i.lastScale < 1 ? -1 : 1), i.wrapper.css({ transform: "" }), i.lastScale = void 0, i.startTouches = void 0 } if (i.isPanning = !1, !(void 0 !== b.touches && b.touches.length > 1) && !0 !== i.skipDrag) { var d = i.eventToPoint(b); i.dragPage && (b.preventDefault(), i.dragPage.pendingPoint = d, d.x == i.startPoint.x && d.y == i.startPoint.y && 1 == d.isInside ? i.corner == a.CORNERS.BR || i.corner == a.CORNERS.TR ? (k(d), !0 !== i.dragPage.isFlipping && i.next()) : i.corner != a.CORNERS.BL && i.corner != a.CORNERS.TL || (k(d), !0 !== i.dragPage.isFlipping && i.prev()) : !0 !== i.dragPage.isFlipping && (d.distance > d.fullWidth / 2 ? d.x > d.fullWidth / 2 ? i.prev() : i.next() : (i.dragPage.animateToReset = !0, i.animatePage(i.dragPage))), i.dragPage && (i.dragPage.pendingPoint = void 0, i.dragPage.magnetic = !1)), i.drag = j.none } }, o = function(b) { var c = i.eventToPoint(b), d = b.srcElement || b.originalTarget; i.dragPage && i.dragPage.magnetic || i.wrapper[0].contains(b.target) && 1 == i.contentProvider.zoomScale && c.x == i.startPoint.x && c.y == i.startPoint.y && c.isInsidePage && i.startPoint.page == c.page && !c.page.isFlipping && "A" !== d.nodeName && (0 == i.startPoint.page.side ? (i.corner = a.CORNERS.TL, i.prev(), i.startPoint.page = void 0) : (i.corner = a.CORNERS.TR, i.next(), i.startPoint.page = void 0), i.isPanning = !1) }, p = function(b) { if (void 0 !== b.touches && 2 == b.touches.length && void 0 == i.startTouches && (i.startTouches = g.getTouches(b), i.lastScale = 1), !(void 0 !== b.touches && b.touches.length > 1 || void 0 == b.touches && 0 !== b.button)) { var c = i.eventToPoint(b); i.startPoint = c, i.left = i.left || 0, i.top = i.top || 0, i.isPanning = !0, i.lastPos = c.x, i.lastTime = performance.now(), !0 !== i.skipDrag && (1 != c.isInside || h(i) || (i.startPoint = c, i.drag = c.drag, i.dragPage = c.page, i.corner = c.corner, z(i.corner), f(i.dragPage), c.page.isHard || c.page.updatePoint(c, i), "0" == c.page.name ? i.shadow.css({ width: "50%", left: i.direction == a.DIRECTION.RTL ? 0 : "50%", transitionDelay: "" }) : c.page.name == Math.ceil(i.pageCount / 2) - 1 && i.shadow.css({ width: "50%", left: i.direction == a.DIRECTION.RTL ? "50%" : 0, transitionDelay: "" }))) } }, q = function(a) { var b = 0; void 0 != a.wheelDelta ? b = a.wheelDelta / 120 : void 0 !== a.detail && (b = -a.detail / 3); var c = i.contentProvider.zoomScale, d = i.contentProvider.maxZoom; if (b && (b > 0 && c < d || b < 0 && c > 1)) { a.stopPropagation(), a.preventDefault(); var e = i.eventToPoint(a), f = i.eventToPoint(a), g = { x: i.container.width() / 2, y: i.container.height() / 2 - 23 }; i.previewObject.zoom(b); var h = i.contentProvider.zoomScale; if (c !== h) { var j = h / c; 1 == h ? (i.left = 0, i.top = 0) : (i.left *= j, i.top *= j); var k = (e.raw.x - g.x) * j, l = (e.raw.y - g.y) * j; f.raw.x = g.x + k, f.raw.y = g.y + l, i.startPoint = f, i.pan(e); var m = i.dragPage || e.page; void 0 == i.dragPage && void 0 !== m && 1 == e.isInside && 1 == m.magnetic && (m.pendingPoint = e, m.animateToReset = !0, i.corner = m.magneticCorner, i.animatePage(m), m.pendingPoint = void 0, m.magnetic = !1, m.magneticCorner = void 0) } } }, r = i.container[0], s = i.stage[0]; r && (r.addEventListener("mousemove", l, !1), r.addEventListener("touchmove", l, !1), r.addEventListener("mousedown", p, !1), r.addEventListener("click", o, !1), r.addEventListener("mouseup", m, !1), r.addEventListener("touchend", m, !1), r.addEventListener("touchstart", p, !1), 1 == i.options.scrollWheel && (s.addEventListener("mousewheel", q, !1), s.addEventListener("DOMMouseScroll", q, !1))), this.dispose = function() { r.removeEventListener("mousemove", l, !1), r.removeEventListener("touchmove", l, !1), r.removeEventListener("mousedown", p, !1), r.removeEventListener("click", o, !1), r.removeEventListener("mouseup", m, !1), r.removeEventListener("touchend", m, !1), r.removeEventListener("touchstart", p, !1), 1 == i.options.scrollWheel && (s.removeEventListener("mousewheel", q, !1), s.removeEventListener("DOMMouseScroll", q, !1)), i.flipCallback = null, i.animateF = null, i.stage.remove() } } return J(i, e), i.prototype = { add: function(a) { a instanceof Q ? this.container.append(b(a.element)) : this.container.append(b(a)) }, pan: function(a) { var b = this.startPoint, d = (this.contentProvider.zoomScale, this.left + (a.raw.x - b.raw.x)), e = this.top + (a.raw.y - b.raw.y); this.left = Math.round(v(d, -this.shiftWidth, this.shiftWidth)), this.top = Math.round(v(e, -this.shiftHeight, this.shiftHeight)), this.startPoint = a, this.stage.css({ transform: "translate3d(" + this.left + "px," + this.top + "px,0)" }) }, getPageByNumber: function(a) { for (var c, b = G(this) ? a : Math.floor((a - 1) / 2), d = 0; d < this.pages.length; d++) b == parseInt(this.pages[d].name, 10) && (c = this.pages[d]); return c }, getPageSide: function(b) { var c = this.direction == a.DIRECTION.RTL, d = this.getPageByNumber(b); if (void 0 != d) return G(this) ? d.back : b % 2 == 0 ? c ? d.back : d.front : c ? d.front : d.back }, getContentLayer: function(a) { var b = this.getPageSide(a); return void 0 == b ? void 0 : b.contentLayer } }, i.prototype.init = function(a) { var c = this; c.stage = b(l.div, { class: "flipbook-book-stage" }), c.wrapper = b(l.div, { class: "flipbook-book-wrapper" }), c.shadow = b(l.div, { class: "flipbook-book-shadow" }), c.container.append(c.stage), c.stage.append(c.wrapper), c.wrapper.append(c.shadow), c.createStack(a) }, i.prototype.createStack = function(a) { for (var b = "red,green,blue,yellow,orange,black".split(","), c = 0; c < this.stackCount; c++) { a.angles = [, this.stackCount - c], a.stiffness = (this.stackCount - c) / 100; var d = new Q(a); d.angles[1] = 180, d.index = c, d.parent = this, d.textureReady = !1, d.textureRequested = !1, this.wrapper.append(d.element), d.isFlipping = !1, this.pages.push(d), d.color = b[c] } this.children = this.pages }, i.prototype.isPageHard = function(a) { return g.isHardPage(this.hardConfig, a, this.pageCount, G(this)) }, i.prototype.setDuration = function(a) { this.duration = a }, i.prototype.moveBy = function(a) { var b = this._activePage + a; b = v(b, this.startPage, this.endPage), this.gotoPage(b) }, i.prototype.next = function(b) { void 0 == b && (b = this.direction == a.DIRECTION.RTL ? -this.pageMode : this.pageMode), this.moveBy(b) }, i.prototype.prev = function(b) { void 0 == b && (b = this.direction == a.DIRECTION.RTL ? this.pageMode : -this.pageMode), this.moveBy(b) }, i.prototype.eventToPoint = function(c) { c = E(c); var d = this.wrapper, e = this.pages, f = this.pageWidth, g = this.fullWidth, h = this.height, k = (b(window), { x: c.clientX, y: c.clientY }), l = k.x - d[0].getBoundingClientRect().left, m = k.y - d[0].getBoundingClientRect().top; k.x = k.x - this.container[0].getBoundingClientRect().left, k.y = k.y - this.container[0].getBoundingClientRect().top; var w, n = this.drag == j.none ? l < f ? l : g - l : this.drag == j.left ? l : g - l, o = l < f ? e[this.stackCount / 2 - 1] : e[this.stackCount / 2], p = l < this.foldSense ? j.left : l > g - this.foldSense ? j.right : j.none, q = l, r = m, s = h, t = g, u = this.foldSense, v = a.CORNERS; return w = q >= 0 && q < u ? r >= 0 && r <= u ? v.TL : r >= s - u && r <= s ? v.BL : r > u && r < s - u ? v.L : v.NONE : q >= t - u && q <= t ? r >= 0 && r <= u ? v.TR : r >= s - u && r <= s ? v.BR : r > u && r < s - u ? v.R : v.NONE : v.NONE, { isInsidePage: q >= 0 && q <= t && r >= 0 && r <= s, isInside: w !== v.NONE && w !== v.L && w !== v.R, x: l, y: m, fullWidth: g, rawDistance: g - l, distance: n, page: o, drag: p, foldSense: this.foldSense, event: c, raw: k, corner: w } }, i.prototype.gotoPage = function(a) { a = parseInt(a, 10), this._activePage = a, this.updatePage(a) }, i.prototype.refresh = function() { this.updatePage(this._activePage), void 0 !== this.flipCallback && this.flipCallback() }, i.prototype.updatePage = function(d) { var e = this.direction == a.DIRECTION.RTL, f = G(this), h = (C(d), f ? 1 : 2); d = Math.floor(d / h), e && (d = this.pageCount / h - d); var i = this.oldBaseNumber || 0, k = this.pageCount / h, l = this.stackCount, m = Math.floor(l / 2); i > d ? (this.children[l - 1].skipFlip = !0, this.children.unshift(this.children.pop())) : i < d && (this.children[0].skipFlip = !0, this.children.push(this.children.shift())); for (var n = 0; n < l; n++) { var o = this.children[n]; i !== d && void 0 !== o.currentTween && o.clearTween(!0); var q, p = o.side, r = d - m + n, s = o.name; o.isHard = this.isPageHard(r), o.isHard ? o.element.addClass("flipbook-hard-page") : (o.element.removeClass("flipbook-hard-page"), o.front.css({ display: "block" }), o.back.css({ display: "block" })); b(o.element).attr("pageNumber") != r && (o.front.contentLayer.empty(), o.back.contentLayer.empty()), b(o.element).attr("pageNumber", r), o.visible = r >= 0 && r < k || f && r == k, void 0 !== this.requestPage && 1 == o.visible && (e && (r = Math.floor(this.pageCount / 2) - r - 1), o.name = r.toString(), o.name != s && (o.backTextureLoaded = !1, o.frontTextureLoaded = !1, o.backPageStamp = "-1", o.frontPageStamp = "-1", o.thumbLoaded = !1, o.front.contentLayer.html(""), o.back.contentLayer.html(""), o.frontImage(c.textureLoadFallback), o.backImage(c.textureLoadFallback), this.requestPage())), o.isEdge = !1, 0 == n || n == l - 1 || (o.isEdge = !1), q = n < m ? j.left : j.right, 0 == o.isFlipping && (q !== p && 0 == o.skipFlip ? (this.animatePage(o), void 0 !== this.preFlipCallback && this.preFlipCallback()) : (o.skipFlip = !1, o.element.removeClass("flipbook-flipping flipbook-quick-turn flipbook-folding flipbook-left-side flipbook-right-side"), o.element.addClass(n < m ? "flipbook-left-side" : "flipbook-right-side"), o.side = q)), f && n < m && 0 == o.isFlipping && (o.visible = !1), o.oldDepth = o.depth, o.updateCSS({ display: 1 == o.visible ? "block" : "none", zIndex: 6 + (n < m ? n - m : m - n), transform: "" }), void 0 == o.pendingPoint && o.resetCSS() } 0 == TWEEN.getAll().length && clearInterval(this.animate), b(".quick-hint").html(d), this.oldBaseNumber = d, void 0 !== this.updatePageCallback && this.updatePageCallback() }, i.prototype.animatePage = function(a) { a.element.addClass("flipbook-flipping"), a.isFlipping = !0, void 0 !== this.animate && clearInterval(this.animate), this.animate = setInterval(this.animateF, 30), a.tween(a.pendingPoint) }, i }({}), S = function(d) { function e(c, e, f) { d.call(this, f); var g = this; g.type = "FlipBook", g.container = c, g.options = f, g.options.source = e, g.contentSource = e, void 0 !== f.height && f.height.toString().indexOf("%") < 0 ? g.container.height(Math.min(f.height, b(window).height())) : g.container.height(f.height), g.options.isLightBox && window.dfLightBox.closeButton.addClass(g.options.icons.close), g.options.isLightBox || void 0 === g.container.attr("id") || (g.options.id = g.container.attr("id")), !0 !== g.options.parsed && void 0 != g.options.links && a.parseLinks(g.options.links); var h = g.webgl = 1 == f.webgl && 1 == I; if (c.addClass("flipbook-container flipbook-loading flipbook-init flipbook-floating"), 1 == g.options.transparent && c.addClass("flipbook-transparent"), g.container.info = b(l.div, { class: "loading-info" }).appendTo(g.container).html("Loading..."), (-1 !== navigator.userAgent.indexOf("MSIE") || navigator.appVersion.indexOf("Trident/") > 0) && (g.options.webgl = !1), navigator.userAgent.match(/msie\s[5-9]/i)) return g.container.info.html("Your browser (Internet Explorer) is out of date to run FLIPBOOK Flipbook Plugin. <br><a href='http://browsehappy.com/'>Upgrade to a new one</a>").addClass("flipbook-old-browser"), c.removeClass("flipbook-loading"), g; var i = void 0 == f.backgroundImage || "" == f.backgroundImage ? "" : "url('" + f.backgroundImage + "')"; return g.container.css({ position: "relative", overflow: "hidden", backgroundColor: f.backgroundColor, backgroundImage: i }), g.init(h, e), void 0 !== g.options.onCreate && g.options.onCreate(), g } return J(e, d), e.prototype.init = function(d) { var e = this, f = e.target, g = e.options; if (1 == d) { (function(b) { var d = function() { MOCKUP.defaults.anisotropy = 0, MOCKUP.defaults.groundTexture = "blank", THREE.skipPowerOfTwo = !0, N(), void 0 !== b && b() }; void 0 == window.MOCKUP ? (e.updateInfo("Loading WEBGL 3D ..."), D(c.threejsSrc + "?ver=" + a.version, function() { D(c.mockupjsSrc + "?ver=" + a.version, function() { d() }) })) : d() })(function() { e.container.css({ minHeight: 300, minWidth: 300 }), e.stage = new M(B(e.options, { container: e.container })), e.stage.previewObject = e, e.contentProvider = new P(e.contentSource, function(c) { var g = { pageCount: c.pageCount, stackCount: 6, segments: 20, width: 300 * c.pageRatio, height: 300 }; e.checkOpenPage(), e.target = f = e.stage.target = new MOCKUP.Book(B(e.options, g), e.stage), e.extendtarget(), L(e.container, e), f.ui = e.ui, f.container = e.container, c.webgl = d, c.setTarget(e.target), f.getContentLayer = function(b) { var c = f.direction == a.DIRECTION.RTL, d = e.stage.cssScene.divLeft.element, g = e.stage.cssScene.divRight.element; C(f._activePage); return G(f) ? g : b % 2 == 0 ? c ? g : d : c ? d : g }, f.stage = e.stage, f.flipCallback = function() { e.contentProvider.review("flipCallback"); var d, g, c = C(f._activePage), h = f.getPageByNumber(c), i = f.getPageByNumber(c + 1), j = f.parent.cssScene.divLeft, k = f.parent.cssScene.divRight; f.pageMode, a.PAGE_MODE.SINGLE, f.direction, a.DIRECTION.RTL; void 0 !== h && void 0 !== j && (d = Math.abs(h.geometry.boundingBox.max.x - h.geometry.boundingBox.min.x), g = Math.abs(h.geometry.boundingBox.max.z - h.geometry.boundingBox.min.z), j.rotation.y = .9 * -Math.atan2(g, d), j.position.z = .8 * g, j.position.x = g / 2.5, b(j.element).css({ width: d, left: -d / 2 })), void 0 !== i && void 0 !== k && (d = Math.abs(i.geometry.boundingBox.max.x - i.geometry.boundingBox.min.x), g = Math.abs(i.geometry.boundingBox.max.z - i.geometry.boundingBox.min.z), k.rotation.y = .9 * Math.atan2(g, d), k.position.z = .8 * g, k.position.x = -g / 2.5, b(k.element).css({ width: d, left: d / 2 })), void 0 !== e.options.onFlip && e.options.onFlip() }, f.resize = function() { e.resize() }(), f.updatePageCallback = function() { e.ui.update(), e.checkCenter(), e.stage.renderRequestPending = !0 }; var h = b(e.stage.cssScene.divLeft.element), i = b(e.stage.cssScene.divRight.element); f.preFlipCallback = function() { h.empty(), i.empty(), void 0 !== e.options.beforeFlip && e.options.beforeFlip(), e.playSound() }, b(window).trigger("resize"), h.css({ width: 300 * c.pageRatio, height: 300, left: -300 * c.pageRatio / 2 }), i.css({ width: 300 * c.pageRatio, height: 300, left: 300 * c.pageRatio / 2 }), f.ease = TWEEN.Easing.Cubic.InOut, f.contentProvider = c, f.duration = e.options.duration, f.gotoPage(f._activePage), f.flipCallback(), void 0 !== e.options.onReady && e.options.onReady() }, g, e) }) } else e.contentProvider = new P(e.contentSource, function(a) { var c = { pageCount: a.pageCount }; e.checkOpenPage(), e.target = f = new R(B(e.options, c), e.container), e.target.previewObject = e, e.extendtarget(), L(e.container, e), a.webgl = d, a.setTarget(e.target), a.waitPeriod = 2, f.ease = TWEEN.Easing.Quadratic.InOut, f.duration = e.options.duration, f.container = e.container, f.updatePageCallback = function() { e.ui.update(), e.checkCenter() }, f.gotoPage(f._activePage), f.resize = function() { e.resize() }(), b(window).trigger("resize"), f.flipCallback = function() { e.contentProvider.review("flipCallback"), void 0 !== e.options.onFlip && e.options.onFlip() }, f.preFlipCallback = function() { void 0 !== e.options.beforeFlip && e.options.beforeFlip(), e.playSound() }, void 0 !== e.options.onReady && e.options.onReady() }, g, e) }, e.prototype.extendtarget = function() { var a = this; a.target.reset = function() { for (var b = 0; b < a.target.children.length; b++) { var c = a.target.children[b]; c.skipFlip = !0, c.name = "-2" } a.contentProvider.annotedPage = "-2", a.target.refresh() } }, e.prototype.getURLHash = function() { if (void 0 != this.options.id) { var a = (void 0 !== this.options.slug ? this.options.slug : this.options.id) + "/"; void 0 != this.target && void 0 != this.target._activePage && (a += this.target._activePage + "/"), window.location.hash = a } return window.location.href }, e.prototype.checkOpenPage = function() { if (void 0 != this.options.id) { var a = b("#" + this.options.id); if (a.length > 0 && void 0 !== a.data("page")) { var c = parseInt(a.data("page"), 10); isNaN(c) || (this.options.openPage = c) } } }, e.prototype.end = function() { this.target.gotoPage(this.target.endPage) }, e.prototype.gotoPage = function(a) { this.target.gotoPage(a), void 0 !== this.ui && this.ui.update() }, e.prototype.prev = function() { this.target.prev() }, e.prototype.next = function() { this.target.next() }, e.prototype.updateInfo = function(a) { this.container && this.container.info && this.container.info.html && this.container.info.html(a) }, e }(O); b.fn.extend({ shelf: function() {}, flipBook: function(a, c) { return new S(b(this), a, K(c)) } }) }(FLIPBOOK, jQuery), function(a) { if (a.URL = a.URL || a.webkitURL, a.Blob && a.URL) try { return void new Blob } catch (a) {} var b = a.BlobBuilder || a.WebKitBlobBuilder || a.MozBlobBuilder || function(a) { var b = function(a) { return Object.prototype.toString.call(a).match(/^\[object\s(.*)\]$/)[1] }, c = function() { this.data = [] }, d = function(b, c, d) { this.data = b, this.size = b.length, this.type = c, this.encoding = d }, e = c.prototype, f = d.prototype, g = a.FileReaderSync, h = function(a) { this.code = this[this.name = a] }, i = "NOT_FOUND_ERR SECURITY_ERR ABORT_ERR NOT_READABLE_ERR ENCODING_ERR NO_MODIFICATION_ALLOWED_ERR INVALID_STATE_ERR SYNTAX_ERR".split(" "), j = i.length, k = a.URL || a.webkitURL || a, l = k.createObjectURL, m = k.revokeObjectURL, n = k, o = a.btoa, p = a.atob, q = a.ArrayBuffer, r = a.Uint8Array, s = /^[\w-]+:\/*\[?[\w\.:-]+\]?(?::[0-9]+)?/; for (d.fake = f.fake = !0; j--;) h.prototype[i[j]] = j + 1; return k.createObjectURL || (n = a.URL = function(a) { var c, b = document.createElementNS("http://www.w3.org/1999/xhtml", "a"); return b.href = a, "origin" in b || ("data:" === b.protocol.toLowerCase() ? b.origin = null : (c = a.match(s), b.origin = c && c[1])), b }), n.createObjectURL = function(a) { var c, b = a.type; return null === b && (b = "application/octet-stream"), a instanceof d ? (c = "data:" + b, "base64" === a.encoding ? c + ";base64," + a.data : "URI" === a.encoding ? c + "," + decodeURIComponent(a.data) : o ? c + ";base64," + o(a.data) : c + "," + encodeURIComponent(a.data)) : l ? l.call(k, a) : void 0 }, n.revokeObjectURL = function(a) { "data:" !== a.substring(0, 5) && m && m.call(k, a) }, e.append = function(a) { var c = this.data; if (r && (a instanceof q || a instanceof r)) { for (var e = "", f = new r(a), i = 0, j = f.length; i < j; i++) e += String.fromCharCode(f[i]); c.push(e) } else if ("Blob" === b(a) || "File" === b(a)) { if (!g) throw new h("NOT_READABLE_ERR"); var k = new g; c.push(k.readAsBinaryString(a)) } else a instanceof d ? "base64" === a.encoding && p ? c.push(p(a.data)) : "URI" === a.encoding ? c.push(decodeURIComponent(a.data)) : "raw" === a.encoding && c.push(a.data) : ("string" != typeof a && (a += ""), c.push(unescape(encodeURIComponent(a)))) }, e.getBlob = function(a) { return arguments.length || (a = null), new d(this.data.join(""), a, "raw") }, e.toString = function() { return "[object BlobBuilder]" }, f.slice = function(a, b, c) { var e = arguments.length; return e < 3 && (c = null), new d(this.data.slice(a, e > 1 ? b : this.data.length), c, this.encoding) }, f.toString = function() { return "[object Blob]" }, f.close = function() { this.size = 0, delete this.data }, c }(a); a.Blob = function(a, c) { var d = c ? c.type || "" : "", e = new b; if (a) for (var f = 0, g = a.length; f < g; f++) Uint8Array && a[f] instanceof Uint8Array ? e.append(a[f].buffer) : e.append(a[f]); var h = e.getBlob(d); return !h.slice && h.webkitSlice && (h.slice = h.webkitSlice), h }; var c = Object.getPrototypeOf || function(a) { return a.__proto__ }; a.Blob.prototype = c(new a.Blob) }(window), function(a) { var g, b = a.Uint8Array, c = a.HTMLCanvasElement, d = c && c.prototype, e = /\s*;\s*base64\s*(?:;|$)/i, f = "toDataURL", h = function(a) { for (var k, l, c = a.length, d = new b(c / 4 * 3 | 0), e = 0, f = 0, h = [0, 0], i = 0, j = 0; c--;) l = a.charCodeAt(e++), 255 !== (k = g[l - 43]) && void 0 !== k && (h[1] = h[0], h[0] = l, j = j << 6 | k, 4 === ++i && (d[f++] = j >>> 16, 61 !== h[1] && (d[f++] = j >>> 8), 61 !== h[0] && (d[f++] = j), i = 0)); return d }; b && (g = new b([62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, 0, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51])), c && !d.toBlob && (d.toBlob = function(a, c) { if (c || (c = "image/png"), this.mozGetAsFile) return void a(this.mozGetAsFile("canvas", c)); if (this.msToBlob && /^\s*image\/png\s*(?:$|;)/i.test(c)) return void a(this.msToBlob()); var l, d = Array.prototype.slice.call(arguments, 1), g = this[f].apply(this, d), i = g.indexOf(","), j = g.substring(i + 1), k = e.test(g.substring(0, i)); Blob.fake ? (l = new Blob, l.encoding = k ? "base64" : "URI", l.data = j, l.size = j.length) : b && (l = k ? new Blob([h(j)], { type: c }) : new Blob([decodeURIComponent(j)], { type: c })), a(l) }, d.toDataURLHD ? d.toBlobHD = function() { f = "toDataURLHD"; var a = this.toBlob(); return f = "toDataURL", a } : d.toBlobHD = d.toBlob) }(window), function() { if ("performance" in window == !1 && (window.performance = {}), Date.now = Date.now || function() { return (new Date).getTime() }, "now" in window.performance == !1) { var b = window.performance.timing && window.performance.timing.navigationStart ? window.performance.timing.navigationStart : Date.now(); window.performance.now = function() { return Date.now() - b } } }(), function() { var b = b || function() { var a = []; return { getAll: function() { return a }, removeAll: function() { a = [] }, add: function(b) { a.push(b) }, remove: function(b) { var c = a.indexOf(b); - 1 !== c && a.splice(c, 1) }, update: function(b) { if (0 === a.length) return !1; var c = 0; for (b = void 0 !== b ? b : window.performance.now(); c < a.length;) a[c].update(b) ? c++ : a.splice(c, 1); return !0 } } }(); b.Tween = function(a) { var c = a, d = {}, e = {}, f = {}, g = 1e3, h = 0, i = !1, j = !1, k = !1, l = 0, m = null, n = b.Easing.Linear.None, o = b.Interpolation.Linear, p = [], q = null, r = !1, s = null, t = null, u = null; for (var v in a) d[v] = parseFloat(a[v], 10); this.to = function(a, b) { return void 0 !== b && (g = b), e = a, this }, this.start = function(a) { b.add(this), j = !0, r = !1, m = void 0 !== a ? a : window.performance.now(), m += l; for (var g in e) { if (e[g] instanceof Array) { if (0 === e[g].length) continue; e[g] = [c[g]].concat(e[g]) } void 0 !== d[g] && (d[g] = c[g], d[g] instanceof Array == !1 && (d[g] *= 1), f[g] = d[g] || 0) } return this }, this.stop = function() { return j ? (b.remove(this), j = !1, null !== u && u.call(c), this.stopChainedTweens(), this) : this }, this.stopChainedTweens = function() { for (var a = 0, b = p.length; a < b; a++) p[a].stop() }, this.complete = function() { return j ? (b.remove(this), j = !1, null !== t && t.call(c), this.completeChainedTweens(), this) : this }, this.completeChainedTweens = function() { for (var a = 0, b = p.length; a < b; a++) p[a].complete() }, this.delay = function(a) { return l = a, this }, this.repeat = function(a) { return h = a, this }, this.yoyo = function(a) { return i = a, this }, this.easing = function(a) { return n = void 0 == a ? n : a, this }, this.interpolation = function(a) { return o = a, this }, this.chain = function() { return p = arguments, this }, this.onStart = function(a) { return q = a, this }, this.onUpdate = function(a) { return s = a, this }, this.onComplete = function(a) { return t = a, this }, this.onStop = function(a) { return u = a, this }, this.update = function(a) { var b, j, u; if (a < m) return !0; !1 === r && (null !== q && q.call(c), r = !0), j = (a - m) / g, j = j > 1 ? 1 : j, u = n(j); for (b in e) if (void 0 !== d[b]) { var v = d[b] || 0, w = e[b]; w instanceof Array ? c[b] = o(w, u) : ("string" == typeof w && (w = w.startsWith("+") || w.startsWith("-") ? v + parseFloat(w, 10) : parseFloat(w, 10)), "number" == typeof w && (c[b] = v + (w - v) * u)) } if (null !== s && s.call(c, u), 1 === j) { if (h > 0) { isFinite(h) && h--; for (b in f) { if ("string" == typeof e[b] && (f[b] = f[b] + parseFloat(e[b], 10)), i) { var x = f[b]; f[b] = e[b], e[b] = x } d[b] = f[b] } return i && (k = !k), m = a + l, !0 } null !== t && t.call(c); for (var y = 0, z = p.length; y < z; y++) p[y].start(m + g); return !1 } return !0 } }, b.Easing = { Linear: { None: function(a) { return a } }, Quadratic: { In: function(a) { return a * a }, Out: function(a) { return a * (2 - a) }, InOut: function(a) { return (a *= 2) < 1 ? .5 * a * a : -.5 * (--a * (a - 2) - 1) } }, Quartic: { In: function(a) { return a * a * a * a }, Out: function(a) { return 1 - --a * a * a * a }, InOut: function(a) { return (a *= 2) < 1 ? .5 * a * a * a * a : -.5 * ((a -= 2) * a * a * a - 2) } }, Sinusoidal: { In: function(a) { return 1 - Math.cos(a * Math.PI / 2) }, Out: function(a) { return Math.sin(a * Math.PI / 2) }, InOut: function(a) { return .5 * (1 - Math.cos(Math.PI * a)) } }, Cubic: { In: function(a) { return a * a * a }, Out: function(a) { return --a * a * a + 1 }, InOut: function(a) { return (a *= 2) < 1 ? .5 * a * a * a : .5 * ((a -= 2) * a * a + 2) } } }, b.Interpolation = { Linear: function(a, c) { var d = a.length - 1, e = d * c, f = Math.floor(e), g = b.Interpolation.Utils.Linear; return c < 0 ? g(a[0], a[1], e) : c > 1 ? g(a[d], a[d - 1], d - e) : g(a[f], a[f + 1 > d ? d : f + 1], e - f) }, Bezier: function(a, c) { for (var d = 0, e = a.length - 1, f = Math.pow, g = b.Interpolation.Utils.Bernstein, h = 0; h <= e; h++) d += f(1 - c, e - h) * f(c, h) * a[h] * g(e, h); return d }, Utils: { Linear: function(a, b, c) { return (b - a) * c + a }, Bernstein: function(a, c) { var d = b.Interpolation.Utils.Factorial; return d(a) / d(c) / d(a - c) }, Factorial: function() { var a = [1]; return function(b) { var c = 1; if (a[b]) return a[b]; for (var d = b; d > 1; d--) c *= d; return a[b] = c, c } }(), CatmullRom: function(a, b, c, d, e) { var f = .5 * (c - a), g = .5 * (d - b), h = e * e; return (2 * b - 2 * c + f + g) * (e * h) + (-3 * b + 3 * c - 2 * f - g) * h + f * e + b } } }, window.TWEEN = b }(), FLIPBOOK.createBlob = function(b, c) { if ("undefined" != typeof Blob) return new Blob([b], { type: c }); var d = new MozBlobBuilder; return d.append(b), d.getBlob(c) }, FLIPBOOK.createObjectURL = function() { var b = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; return function(c, d) { if ("undefined" != typeof URL && URL.createObjectURL) { var e = FLIPBOOK.createBlob(c, d); return URL.createObjectURL(e) } for (var f = "data:" + d + ";base64,", g = 0, h = c.length; g < h; g += 3) { var i = 255 & c[g], j = 255 & c[g + 1], k = 255 & c[g + 2], l = i >> 2, m = (3 & i) << 4 | j >> 4, n = g + 1 < h ? (15 & j) << 2 | k >> 6 : 64, o = g + 2 < h ? 63 & k : 64; f += b[l] + b[m] + b[n] + b[o] } return f } }(); var ThumbList = function() { function b(a) { function k(a) { var b = a.target.scrollTop; if (!g.lastRepaintY || Math.abs(b - g.lastRepaintY) >= g.offsetItems * g.itemHeight) { var c = parseInt(b / e, 10) - g.offsetItems; g._renderChunk(g.container, c < 0 ? 0 : c), g.lastRepaintY = b } g.lastScrolled = i = Date.now(), void 0 !== g.scrollFn && g.scrollFn(), a.preventDefault && a.preventDefault() } var c = a && a.w + "px" || "100%", d = a && a.h + "px" || "100%", e = this.itemHeight = a.itemHeight; this.items = a.items, this.generatorFn = a.generatorFn, this.totalRows = a.totalRows || a.items && a.items.length, this.addFn = a.addFn, this.scrollFn = a.scrollFn; var f = b.createScroller(e * this.totalRows); this.container = b.createContainer(c, d), this.container.appendChild(f), this.screenItemsLen = Math.ceil(a.h / e), this.offsetItems = this.screenItemsLen, this.cachedItemsLen = this.screenItemsLen + 2 * this.offsetItems, this._renderChunk(this.container, 0); var g = this; g.lastRepaintY = 0; var i = (this.screenItemsLen, 0); g.dispose = function() { g.container && g.container.parentNode && g.container.parentNode.removeChild(g.container), g.container.removeEventListener("scroll", k) }, g.container.addEventListener("scroll", k) } return b.prototype.reset = function(a) { this.screenItemsLen = Math.ceil(a / this.itemHeight), this.cachedItemsLen = this.screenItemsLen + 2 * this.offsetItems; var b = parseInt(this.lastRepaintY / this.itemHeight, 10) - this.offsetItems; this.needReset = !0, this._renderChunk(this.container, Math.max(b, 0)) }, b.prototype.createRow = function(a) { var b; return this.generatorFn && (b = this.generatorFn(a), b.classList.add("flipbook-vrow"), b.style.position = "absolute", b.style.top = a * this.itemHeight + "px", b.setAttribute("index", a)), b }, b.prototype._renderChunk = function(a, b) { var c = void 0 == this.range; this.range = this.range || { min: 0, max: this.cachedItemsLen }; var d = this.range, e = d.min, f = d.max, g = !!c || b >= e; if (c || b != e || 0 != this.needReset) { var h, i = c ? e : g ? f : b; i = i > this.totalRows ? this.totalRows : i < 0 ? 0 : i; var j = b + this.cachedItemsLen; for (j = j > this.totalRows ? this.totalRows : j, h = i; h < j; h++) g ? a.appendChild(this.createRow(h)) : a.insertBefore(this.createRow(h), a.childNodes[1 + h - i]), void 0 !== this.addFn && this.addFn(h); Math.abs(b - e); if (this.needReset = !1, !c && a.childNodes.length > this.cachedItemsLen + 1) for (var l = g ? 1 : 1 + this.cachedItemsLen, m = l + (j - i), n = m; n > l; n--) a.childNodes[l] && this.container.removeChild(a.childNodes[l]); this.range.min = b, this.range.max = j } }, b.createContainer = function(a, b) { var c = document.createElement("div"); return c.style.width = a, c.style.height = b, c.style.overflow = "auto", c.style.position = "relative", c.style.padding = 0, c }, b.createScroller = function(a) { var b = document.createElement("div"); return b.style.opacity = 0, b.style.position = "absolute", b.style.top = 0, b.style.left = 0, b.style.width = "1px", b.style.height = a + "px", b }, b }(), BookMarkViewer = function() { function b(a) { this.outline = null, this.lastToggleIsShow = !0, this.container = a.container, this.linkService = a.linkService, this.outlineItemClass = a.outlineItemClass || "outlineItem", this.outlineToggleClass = a.outlineToggleClass || "outlineItemToggler", this.outlineToggleHiddenClass = a.outlineToggleHiddenClass || "outlineItemsHidden" } return b.prototype = { dispose: function() { this.container && this.container.parentNode && this.container.parentNode.removeChild(this.container), this.linkService = null }, reset: function() { this.outline = null, this.lastToggleIsShow = !0; for (var b = this.container; b.firstChild;) b.removeChild(b.firstChild) }, _dispatchEvent: function(b) { var c = document.createEvent("CustomEvent"); c.initCustomEvent("outlineloaded", !0, !0, { outlineCount: b }), this.container.dispatchEvent(c) }, _bindLink: function(b, c) { var d = this.linkService; if (1 == c.custom) b.href = d.getCustomDestinationHash(c.dest), b.onclick = function(b) { return d.customNavigateTo(c.dest), !1 }; else { if (c.url) return void PDFJS.addLinkAttributes(b, { url: c.url }); b.href = d.getDestinationHash(c.dest), b.onclick = function(b) { return d.navigateTo(c.dest), !1 } } }, _addToggleButton: function(b) { var c = document.createElement("div"); c.className = this.outlineToggleClass + " " + this.outlineToggleHiddenClass, c.onclick = function(a) { if (a.stopPropagation(), c.classList.toggle(this.outlineToggleHiddenClass), a.shiftKey) { var d = !c.classList.contains(this.outlineToggleHiddenClass); this._toggleOutlineItem(b, d) } }.bind(this), b.insertBefore(c, b.firstChild) }, _toggleOutlineItem: function(b, c) { this.lastToggleIsShow = c; for (var d = b.querySelectorAll("." + this.outlineToggleClass), e = 0, f = d.length; e < f; ++e) d[e].classList[c ? "remove" : "add"](this.outlineToggleHiddenClass) }, toggleOutlineTree: function() { this.outline && this._toggleOutlineItem(this.container, !this.lastToggleIsShow) }, render: function(b) { var c = b && b.outline || null, d = 0; if (this.outline && this.reset(), this.outline = c, c) { for (var e = document.createDocumentFragment(), f = [{ parent: e, items: this.outline }], g = !1; f.length > 0;) for (var h = f.shift(), i = h.custom, j = 0, k = h.items.length; j < k; j++) { var l = h.items[j], m = document.createElement("div"); m.className = this.outlineItemClass; var n = document.createElement("a"); if (void 0 == l.custom && void 0 !== i && (l.custom = i), this._bindLink(n, l), n.textContent = l.title.replace(/\x00/g, ""), m.appendChild(n), l.items && l.items.length > 0) { g = !0, this._addToggleButton(m); var o = document.createElement("div"); o.className = this.outlineItemClass + "s", m.appendChild(o), f.push({ parent: o, custom: l.custom, items: l.items }) } h.parent.appendChild(m), d++ } g && (void 0 != this.container.classList ? this.container.classList.add(this.outlineItemClass + "s") : void 0 != this.container.className && (this.container.className += " picWindow")), this.container.appendChild(e), this._dispatchEvent(d) } } }, b }(), DFLightBox = function(b) { function c(a, c) { this.duration = 300; var d = this; return d.lightboxWrapper = b("<div>").addClass("flipbook-lightbox-wrapper"), d.container = b("<div>").addClass("flipbook-container").appendTo(d.lightboxWrapper), d.controls = b("<div>").addClass("flipbook-lightbox-controls").appendTo(d.lightboxWrapper), d.closeButton = b("<div>").addClass("flipbook-lightbox-close flipbook-ui-btn").on("click", function() { d.close(a) }).appendTo(d.controls), d.lightboxWrapper.append(d.container), d } return c.prototype.show = function(a) { return 0 == this.lightboxWrapper.parent().length && b("body").append(this.lightboxWrapper), this.lightboxWrapper.fadeIn(this.duration, a), this }, c.prototype.close = function(a) { return this.lightboxWrapper.fadeOut(this.duration, a), this }, c }(jQuery); FLIPBOOK.Share = function(b) { function c(a, c) { var d = this, e = "<div>", f = "flipbook-share-button", g = "width=500,height=400"; d.isOpen = !1, d.shareUrl = "", d.wrapper = b('<div class="flipbook-share-wrapper" style="display: none;">').on("click", function(a) { d.close() }), d.box = b('<div class="flipbook-share-box">').on("click", function(a) { a.preventDefault(), a.stopPropagation() }).appendTo(d.wrapper).html('<span class="flipbook-share-title">' + c.text.share + "</span>"), d.urlInput = b('<textarea class="flipbook-share-url">').on("click", function() { b(this).select() }), d.facebook = b(e, { class: f + " flipbook-share-facebook " + c.icons.facebook }).on("click", function(a) { window.open("https://www.facebook.com/sharer/sharer.php?u=" + encodeURIComponent(d.shareUrl), "Sharer", g) }), d.google = b(e, { class: f + " flipbook-share-google " + c.icons.google }).on("click", function(a) { window.open("https://plus.google.com/share?url=" + encodeURIComponent(d.shareUrl), "Sharer", g) }), d.twitter = b(e, { class: f + " flipbook-share-twitter " + c.icons.twitter }).on("click", function(a) { window.open("http://twitter.com/share?url=" + encodeURIComponent(d.shareUrl), "Sharer", g) }), d.box.append(d.urlInput).append(d.facebook).append(d.twitter), b(a).append(d.wrapper) } return c.prototype.show = function() { this.wrapper.fadeIn(300), this.urlInput.val(this.shareUrl), this.urlInput.trigger("click"), this.isOpen = !0 }, c.prototype.dispose = function() { var a = this; a.box.off(), a.google.off(), a.twitter.off(), a.facebook.off(), a.urlInput.off(), a.wrapper.off().remove() }, c.prototype.close = function() { this.wrapper.fadeOut(300), this.isOpen = !1 }, c.prototype.update = function(a) { this.shareUrl = a }, c }(jQuery); var PDFLinkService = function() { function a() { this.baseUrl = null, this.pdfDocument = null, this.pdfViewer = null, this.pdfHistory = null, this._pagesRefCache = null } return a.prototype = { dispose: function() { this.baseUrl = null, this.pdfDocument = null, this.pdfViewer = null, this.pdfHistory = null, this._pagesRefCache = null }, setDocument: function(b, c) { this.baseUrl = c, this.pdfDocument = b, this._pagesRefCache = Object.create(null) }, setViewer: function(b) { this.pdfViewer = b }, setHistory: function(b) { this.pdfHistory = b }, get pagesCount() { return this.pdfDocument.numPages }, get page() { return this.pdfViewer.currentPageNumber }, set page(a) { this.pdfViewer.currentPageNumber = a }, navigateTo: function(b) { var f, c = "", d = this, e = function(a) { var f = a instanceof Object ? d._pagesRefCache[a.num + " " + a.gen + " R"] : a + 1; f ? (f > d.pagesCount && (f = d.pagesCount), d.pdfViewer.gotoPage(f), d.pdfHistory && d.pdfHistory.push({ dest: b, hash: c, page: f })) : d.pdfDocument.getPageIndex(a).then(function(b) { var c = b + 1, f = a.num + " " + a.gen + " R"; d._pagesRefCache[f] = c, e(a) }) }; "string" == typeof b ? (c = b, f = this.pdfDocument.getDestination(b)) : f = Promise.resolve(b), f.then(function(a) { b = a, a instanceof Array && e(a[0]) }) }, customNavigateTo: function(b) { if ("" != b && void 0 != b && "void 0" != b) { var c = void 0; if (isNaN(Math.round(b))) { if ("string" == typeof b && (c = parseInt(b.replace("#", ""), 10), isNaN(c))) return void window.open(b) } else c = b; void 0 !== c && this.pdfViewer.gotoPage(c) } }, getDestinationHash: function(b) { if ("string" == typeof b) return this.getAnchorUrl("#" + escape(b)); if (b instanceof Array) { var c = b[0], d = c instanceof Object ? this._pagesRefCache[c.num + " " + c.gen + " R"] : c + 1; if (d) { var e = this.getAnchorUrl("#page=" + d), f = b[1]; if ("object" == typeof f && "name" in f && "XYZ" === f.name) { var g = b[4] || this.pdfViewer.currentScaleValue, h = parseFloat(g); h && (g = 100 * h), e += "&zoom=" + g, (b[2] || b[3]) && (e += "," + (b[2] || 0) + "," + (b[3] || 0)) } return e } } return this.getAnchorUrl("") }, getCustomDestinationHash: function(b) { return "#" + escape(b) }, getAnchorUrl: function(b) { return (this.baseUrl || "") + b }, setHash: function(b) { if (b.indexOf("=") >= 0) { var c = parseQueryString(b); if ("nameddest" in c) return this.pdfHistory && this.pdfHistory.updateNextHashParam(c.nameddest), void this.navigateTo(c.nameddest); var d, e; if ("page" in c && (d = 0 | c.page || 1), "zoom" in c) { var f = c.zoom.split(","), g = f[0], h = parseFloat(g); - 1 === g.indexOf("Fit") ? e = [null, { name: "XYZ" }, f.length > 1 ? 0 | f[1] : null, f.length > 2 ? 0 | f[2] : null, h ? h / 100 : g] : "Fit" === g || "FitB" === g ? e = [null, { name: g }] : "FitH" === g || "FitBH" === g || "FitV" === g || "FitBV" === g ? e = [null, { name: g }, f.length > 1 ? 0 | f[1] : null] : "FitR" === g ? 5 !== f.length ? console.error("PDFLinkService_setHash: Not enough parameters for 'FitR'.") : e = [null, { name: g }, 0 | f[1], 0 | f[2], 0 | f[3], 0 | f[4]] : console.error("PDFLinkService_setHash: '" + g + "' is not a valid zoom value.") } if (e ? this.pdfViewer.scrollPageIntoView(d || this.page, e) : d && (this.page = d), "pagemode" in c) { var i = document.createEvent("CustomEvent"); i.initCustomEvent("pagemode", !0, !0, { mode: c.pagemode }), this.pdfViewer.container.dispatchEvent(i) } } else /^\d+$/.test(b) ? this.page = b : (this.pdfHistory && this.pdfHistory.updateNextHashParam(unescape(b)), this.navigateTo(unescape(b))) }, executeNamedAction: function(b) { switch (b) { case "GoBack": this.pdfHistory && this.pdfHistory.back(); break; case "GoForward": this.pdfHistory && this.pdfHistory.forward(); break; case "NextPage": this.page++; break; case "PrevPage": this.page--; break; case "LastPage": this.page = this.pagesCount; break; case "FirstPage": this.page = 1 } var c = document.createEvent("CustomEvent"); c.initCustomEvent("namedaction", !0, !0, { action: b }), this.pdfViewer.container.dispatchEvent(c) }, cachePageRef: function(b, c) { var d = c.num + " " + c.gen + " R"; this._pagesRefCache[d] = b } }, a }(); FLIPBOOK.TextLayerBuilder = function() { function b(a) { this.textLayerDiv = a.textLayerDiv, this.renderingDone = !1, this.divContentDone = !1, this.pageIdx = a.pageIndex, this.pageNumber = this.pageIdx + 1, this.matches = [], this.viewport = a.viewport, this.textDivs = [], this.findController = a.findController || null, this.textLayerRenderTask = null, this.enhanceTextSelection = a.enhanceTextSelection, this._bindMouse() } return b.prototype = { _finishRendering: function() { if (this.renderingDone = !0, !this.enhanceTextSelection) { var b = document.createElement("div"); b.className = "endOfContent", this.textLayerDiv.appendChild(b) } }, render: function(b) { if (this.divContentDone && !this.renderingDone) { this.textLayerRenderTask && (this.textLayerRenderTask.cancel(), this.textLayerRenderTask = null), this.textDivs = []; var c = document.createDocumentFragment(); this.textLayerRenderTask = PDFJS.renderTextLayer({ textContent: this.textContent, container: c, viewport: this.viewport, textDivs: this.textDivs, timeout: b, enhanceTextSelection: this.enhanceTextSelection }), this.textLayerRenderTask.promise.then(function() { this.textLayerDiv.appendChild(c), this._finishRendering(), this.updateMatches() }.bind(this), function(a) {}) } }, setTextContent: function(b) { this.textLayerRenderTask && (this.textLayerRenderTask.cancel(), this.textLayerRenderTask = null), this.textContent = b, this.divContentDone = !0 }, convertMatches: function(b, c) { var d = 0, e = 0, f = this.textContent.items, g = f.length - 1, h = null === this.findController ? 0 : this.findController.state.query.length, i = []; if (!b) return i; for (var j = 0, k = b.length; j < k; j++) { for (var l = b[j]; d !== g && l >= e + f[d].str.length;) e += f[d].str.length, d++; d === f.length && console.error("Could not find a matching mapping"); var m = { begin: { divIdx: d, offset: l - e } }; for (l += c ? c[j] : h; d !== g && l > e + f[d].str.length;) e += f[d].str.length, d++; m.end = { divIdx: d, offset: l - e }, i.push(m) } return i }, renderMatches: function(b) { function k(a, b) { var c = a.divIdx; d[c].textContent = "", l(c, 0, a.offset, b) } function l(a, b, e, f) { var g = d[a], h = c[a].str.substring(b, e), i = document.createTextNode(h); if (f) { var j = document.createElement("span"); return j.className = f, j.appendChild(i), void g.appendChild(j) } g.appendChild(i) } if (0 !== b.length) { var c = this.textContent.items, d = this.textDivs, e = null, f = this.pageIdx, g = null !== this.findController && f === this.findController.selected.pageIdx, h = null === this.findController ? -1 : this.findController.selected.matchIdx, i = null !== this.findController && this.findController.state.highlightAll, j = { divIdx: -1, offset: void 0 }, m = h, n = m + 1; if (i) m = 0, n = b.length; else if (!g) return; for (var o = m; o < n; o++) { var p = b[o], q = p.begin, r = p.end, s = g && o === h, t = s ? " selected" : ""; if (this.findController && this.findController.updateMatchPosition(f, o, d, q.divIdx), e && q.divIdx === e.divIdx ? l(e.divIdx, e.offset, q.offset) : (null !== e && l(e.divIdx, e.offset, j.offset), k(q)), q.divIdx === r.divIdx) l(q.divIdx, q.offset, r.offset, "highlight" + t); else { l(q.divIdx, q.offset, j.offset, "highlight begin" + t); for (var u = q.divIdx + 1, v = r.divIdx; u < v; u++) d[u].className = "highlight middle" + t; k(r, "highlight end" + t) } e = r } e && l(e.divIdx, e.offset, j.offset) } }, updateMatches: function() { if (this.renderingDone) { for (var b = this.matches, c = this.textDivs, d = this.textContent.items, e = -1, f = 0, g = b.length; f < g; f++) { for (var h = b[f], i = Math.max(e, h.begin.divIdx), j = i, k = h.end.divIdx; j <= k; j++) { var l = c[j]; l.textContent = d[j].str, l.className = "" } e = h.end.divIdx + 1 } if (null !== this.findController && this.findController.active) { var m, n; null !== this.findController && (m = this.findController.pageMatches[this.pageIdx] || null, n = this.findController.pageMatchesLength ? this.findController.pageMatchesLength[this.pageIdx] || null : null), this.matches = this.convertMatches(m, n), this.renderMatches(this.matches) } } }, _bindMouse: function() { var b = this.textLayerDiv, c = this; b.addEventListener("mousedown", function(a) { if (c.enhanceTextSelection && c.textLayerRenderTask) return void c.textLayerRenderTask.expandTextDivs(!0); var d = b.querySelector(".endOfContent"); if (d) { var e = a.target !== b; if (e = e && "none" !== window.getComputedStyle(d).getPropertyValue("-moz-user-select")) { var f = b.getBoundingClientRect(), g = Math.max(0, (a.pageY - f.top) / f.height); d.style.top = (100 * g).toFixed(2) + "%" } d.classList.add("active") } }), b.addEventListener("mouseup", function(a) { if (c.enhanceTextSelection && c.textLayerRenderTask) return void c.textLayerRenderTask.expandTextDivs(!1); var d = b.querySelector(".endOfContent"); d && (d.style.top = "", d.classList.remove("active")) }) } }, b }(), FLIPBOOK.ConvertPageLinks = function() { for (var e, a = arguments[0] / 100, b = arguments[1] / 100, c = function(c, d, e, f, g) { return { x: c / a, y: d / b, w: e / a, h: f / b, dest: g } }, d = [], f = 2; f < arguments.length; f++) e = arguments[f], d[f - 2] = c.apply(this, e); return d }, FLIPBOOK.parseLinks = function(a) { var b; if (void 0 !== a && a.length > 0) for (var c = 0; c < a.length; c++) void 0 !== (b = a[c]) && void 0 !== b[0] && void 0 == b[0].dest && (b = FLIPBOOK.ConvertPageLinks.apply(this, b), a[c] = b); return a }, function(a) { function b(a) { return "true" == a || 1 == a } function c(a) { void 0 !== a.webgl && (a.webgl = b(a.webgl)), void 0 !== a.enableDownload && (a.enableDownload = b(a.enableDownload)), void 0 !== a.scrollWheel && (a.scrollWheel = b(a.scrollWheel)), void 0 !== a.autoEnableOutline && (a.autoEnableOutline = b(a.autoEnableOutline)), void 0 !== a.autoEnableThumbnail && (a.autoEnableThumbnail = b(a.autoEnableThumbnail)), void 0 !== a.transparent && (a.transparent = b(a.transparent)), void 0 !== a.overwritePDFOutline && (a.overwritePDFOutline = b(a.overwritePDFOutline)), void 0 !== a.soundEnable && (a.soundEnable = b(a.soundEnable)), void 0 !== a.forceFit && (a.forceFit = b(a.forceFit)), void 0 !== a.enableAnnotation && (a.enableAnnotation = b(a.enableAnnotation)), void 0 !== a.webglShadow && (a.webglShadow = b(a.webglShadow)), void 0 !== a.minTopOffset && (a.minTopOffset = parseInt(a.minTopOffset, 10)), void 0 !== a.zoomRatio && (a.zoomRatio = parseFloat(a.zoomRatio, 10)), 0 != a.pageMode && "0" != a.pageMode || (a.pageMode = void 0), 0 != a.singlePageMode && "0" != a.singlePageMode || (a.singlePageMode = void 0) } function d(a) { if (1 != a.parsed) { a.parsed = !0; var b = []; if (c(a), "undefined" != typeof FLIPBOOKWPGlobal && "true" == a.wpOptions) { try { for (var d in a.links) { for (var e = a.links[d], f = [100, 100], g = 0; g < e.length; g++) { for (var h = e[g], i = h.replace("[", "").replace("]", "").split(","), j = [], k = 0; k < 5; k++) j[k] = i[k]; f.push(j) } b[parseInt(d, 10) + 1] = f } } catch (a) { console.error(a.stack) } a.links = FLIPBOOK.parseLinks(b) } else a.links = FLIPBOOK.parseLinks(a.links) } } FLIPBOOK.getOptions = function(b) { b = a(b); var c = b.attr("id"), e = "option_" + c, f = b.attr("source") || b.attr("flipbook-source"); e = void 0 == e || "" == e || void 0 == window[e] ? {} : window[e], e.source = void 0 == f || "" == f ? e.source : f; var g = { webgl: b.attr("webgl"), height: b.attr("height"), soundEnable: b.attr("sound"), transparent: b.attr("transparent"), enableDownload: b.attr("download"), duration: b.attr("duration"), hard: b.attr("hard"), pageMode: b.attr("pagemode"), direction: b.attr("direction"), backgroundColor: b.attr("backgroundcolor"), scrollWheel: b.attr("scrollwheel"), backgroundImage: b.attr("backgroundimage"), minTopOffset: b.attr("mintopoffset"), wpOptions: b.attr("wpoptions") }; return e = a.extend(!0, {}, e, g), d(e), e }, FLIPBOOK.parseBooks = function() { a("._flipbook_button, ._flipbook_thumb, ._flipbook_custom, ._flipbook_book").each(function() { var b = a(this); if ("true" !== (b.attr("parsed") || b.attr("flipbook-parsed"))) if (b.attr("flipbook-parsed", "true"), b.hasClass("_flipbook_book")) { var d = b.attr("id"), e = b.attr("slug"), f = FLIPBOOK.getOptions(b); f.id = d, void 0 !== e && (f.slug = e), d ? window[d.toString()] = a(b).flipBook(f.source, f) : a(b).flipBook(f.source, f) } else if (b.on("click", function() { var b = a(this); window.dfLightBox || (window.dfLightBox = new DFLightBox(function() { window.location.hash = "", window.dfActiveLightBoxBook.dispose(), window.dfActiveLightBoxBook = null })), window.dfLightBox.duration = 500, window.dfActiveLightBoxBook && window.dfActiveLightBoxBook.dispose ? window.dfActiveLightBoxBook.dispose() : window.dfLightBox.show(function() { var c = FLIPBOOK.getOptions(b); c.transparent = !1, c.id = b.attr("id"); var d = b.attr("slug"); var mixedtype = b.attr("mixedtype"); if(0 !== mixedtype && mixedtype == 1 && c.source){ c.source = c.source.split("~"); } void 0 !== d && (c.slug = d), c.isLightBox = !0, window.dfActiveLightBoxBook = a(window.dfLightBox.container).flipBook(c.source, c) }) }), b.hasClass("_flipbook_thumb")) { var g = a("<div class='_flipbook_book-cover'>"), h = b.html(); b.html(""); var j = (a("<span class='_flipbook_book-title'>").html(h).appendTo(g), b.attr("thumb") || b.attr("flipbook-thumb")), k = b.attr("tags") || b.attr("flipbook-tags"); if (k && (k = k.split(","), k.length > 0)) for (var l = 0; l < k.length; l++) b.append("<span class='_flipbook_book-tag'>" + k[l] + "</span>"); void 0 !== j && "" != j.toString().trim() ? g.css({ backgroundImage: "url(" + j + ")" }) : g.addClass("_flipbook_thumb-not-found"), b.append(g) } }) }, a(document).ready(function () { if ("undefined" != typeof urlcustom && (urlcustom.length > 2 && "/" !== urlcustom.slice( - 1) && (urlcustom += "/"), FLIPBOOK.defaults.mockupjsSrc = urlcustom + "js/libs/mockup.min.js", FLIPBOOK.defaults.pdfjsSrc = urlcustom + "js/libs/pdf.min.js", FLIPBOOK.defaults.pdfjsCompatibilitySrc = urlcustom + "js/libs/compatibility.js", FLIPBOOK.defaults.threejsSrc = urlcustom + "js/libs/three.min.js", FLIPBOOK.defaults.pdfjsWorkerSrc = urlcustom + "js/libs/pdf.worker.min.js", FLIPBOOK.defaults.soundFile = urlcustom + "sound/pageturn3.mp3", "undefined" != typeof FLIPBOOKWPGlobal && (c(FLIPBOOKWPGlobal), a.extend(FLIPBOOK.defaults, FLIPBOOKWPGlobal))), FLIPBOOK.preParseHash = window.location.hash, FLIPBOOK.parseBooks(), FLIPBOOK.preParseHash) { var b = FLIPBOOK.preParseHash.split("#")[1].split("/")[0], d = FLIPBOOK.preParseHash.split("#")[1].split("/")[1]; void 0 != d && (d = d.split("/")[0]); var pageno = getQueryString("page"); if(pageno != null){ b = b.split("?")[0]; d = pageno; } var e; e = a("[slug=" + b + "]"), 0 == e.length && (e = a("#" + b)), e.length > 0 && (void 0 != d && e.data("page", d)) if(e.is("._flipbook_button, ._flipbook_thumb, ._flipbook_custom")){ setTimeout(function(){ e.trigger("click"); }, 500); } } }) } (jQuery); var getQueryString = function ( field, url ) { var href = url ? url : window.location.href; var reg = new RegExp( '[?&]' + field + '=([^&#]*)', 'i' ); var string = reg.exec(href); return string ? string[1] : null; };