@prose-reader/core 0.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cfi.d.ts +74 -0
- package/dist/constants.d.ts +5 -0
- package/dist/context.d.ts +48 -0
- package/dist/createReaderWithEnhancer.d.ts +2242 -0
- package/dist/enhancers/accessibility.d.ts +2 -0
- package/dist/enhancers/chrome.d.ts +2 -0
- package/dist/enhancers/composeEnhancer.d.ts +21 -0
- package/dist/enhancers/firefox.d.ts +2 -0
- package/dist/enhancers/fonts.d.ts +12 -0
- package/dist/enhancers/hotkeys.d.ts +2 -0
- package/dist/enhancers/layoutEnhancer/createMovingSafePan$.d.ts +3 -0
- package/dist/enhancers/layoutEnhancer/layoutEnhancer.d.ts +10 -0
- package/dist/enhancers/links.d.ts +12 -0
- package/dist/enhancers/media.d.ts +2 -0
- package/dist/enhancers/navigation.d.ts +5 -0
- package/dist/enhancers/pagination.d.ts +46 -0
- package/dist/enhancers/progression.d.ts +15 -0
- package/dist/enhancers/resources/index.d.ts +2 -0
- package/dist/enhancers/resources/indexedDB.d.ts +6 -0
- package/dist/enhancers/resources/resourcesManager.d.ts +6 -0
- package/dist/enhancers/theme.d.ts +22 -0
- package/dist/enhancers/types.d.ts +28 -0
- package/dist/enhancers/utils.d.ts +6 -0
- package/dist/enhancers/webkit.d.ts +2 -0
- package/dist/enhancers/zoom.d.ts +16 -0
- package/dist/frames.d.ts +5 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +701 -0
- package/dist/index.js.LICENSE.txt +385 -0
- package/dist/index.js.map +1 -0
- package/dist/pagination.d.ts +65 -0
- package/dist/reader.d.ts +63 -0
- package/dist/report.d.ts +26 -0
- package/dist/selection.d.ts +6 -0
- package/dist/settings.d.ts +37 -0
- package/dist/spine/cfiLocator.d.ts +257 -0
- package/dist/spine/createSpine.d.ts +896 -0
- package/dist/spine/eventsHelper.d.ts +11 -0
- package/dist/spine/locationResolver.d.ts +479 -0
- package/dist/spine/navigationResolver.d.ts +48 -0
- package/dist/spine/viewportNavigator/manualViewportNavigator.d.ts +99 -0
- package/dist/spine/viewportNavigator/panViewportNavigator.d.ts +50 -0
- package/dist/spine/viewportNavigator/scrollViewportNavigator.d.ts +23 -0
- package/dist/spine/viewportNavigator/viewportNavigator.d.ts +85 -0
- package/dist/spineItem/commonSpineItem.d.ts +160 -0
- package/dist/spineItem/createSpineItem.d.ts +458 -0
- package/dist/spineItem/frameItem/createFrame$.d.ts +1 -0
- package/dist/spineItem/frameItem/createFrameManipulator.d.ts +5 -0
- package/dist/spineItem/frameItem/createHtmlPageFromResource.d.ts +2 -0
- package/dist/spineItem/frameItem/frameItem.d.ts +49 -0
- package/dist/spineItem/frameItem/loader.d.ts +27 -0
- package/dist/spineItem/index.d.ts +458 -0
- package/dist/spineItem/locationResolver.d.ts +27 -0
- package/dist/spineItem/navigationResolver.d.ts +23 -0
- package/dist/spineItem/prePaginatedSpineItem.d.ts +223 -0
- package/dist/spineItem/reflowableSpineItem.d.ts +222 -0
- package/dist/spineItem/trackers.d.ts +34 -0
- package/dist/spineItemManager.d.ts +264 -0
- package/dist/tryEnhancer/compose.d.ts +20 -0
- package/dist/tryEnhancer/createReader.d.ts +3 -0
- package/dist/tryEnhancer/enhancer.d.ts +24 -0
- package/dist/tryEnhancer/index.d.ts +1 -0
- package/dist/types/Hook.d.ts +70 -0
- package/dist/types/index.d.ts +16 -0
- package/dist/utils/compose.d.ts +8 -0
- package/dist/utils/contentType.d.ts +2 -0
- package/dist/utils/dom.d.ts +19 -0
- package/dist/utils/manifest.d.ts +2 -0
- package/dist/utils/objects.d.ts +6 -0
- package/dist/utils/objects.test.d.ts +1 -0
- package/dist/utils/rxjs.d.ts +4 -0
- package/dist/utils/url.d.ts +1 -0
- package/package.json +44 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,701 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
3
|
+
* This devtool is neither made for production nor for readable output files.
|
|
4
|
+
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
5
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
6
|
+
* or disable the default devtool with "devtool: false".
|
|
7
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
8
|
+
*/
|
|
9
|
+
/******/ (() => { // webpackBootstrap
|
|
10
|
+
/******/ "use strict";
|
|
11
|
+
/******/ var __webpack_modules__ = ({
|
|
12
|
+
|
|
13
|
+
/***/ "./src/cfi.ts":
|
|
14
|
+
/*!********************!*\
|
|
15
|
+
!*** ./src/cfi.ts ***!
|
|
16
|
+
\********************/
|
|
17
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
18
|
+
|
|
19
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"CFI\": () => (/* binding */ CFI),\n/* harmony export */ \"extractProseMetadataFromCfi\": () => (/* binding */ extractProseMetadataFromCfi)\n/* harmony export */ });\n\nconst ELEMENT_NODE = Node.ELEMENT_NODE;\nconst TEXT_NODE = Node.TEXT_NODE;\nconst CDATA_SECTION_NODE = Node.CDATA_SECTION_NODE;\nfunction cfiEscape(str) {\n return str.replace(/[\\[\\]\\^,();]/g, `^$&`);\n}\nfunction matchAll(str, regExp, add) {\n add = add || 0;\n const matches = [];\n let offset = 0;\n let m;\n do {\n m = str.match(regExp);\n if (!m)\n break;\n matches.push(m.index + add);\n offset += m.index + m.length;\n str = str.slice(m.index + m.length);\n } while (offset < str.length);\n return matches;\n}\nfunction closest(a, n) {\n let minDiff;\n let closest;\n let i, diff;\n for (i = 0; i < a.length; i++) {\n diff = Math.abs(a[i] - n);\n if (!i || diff < minDiff) {\n diff = minDiff;\n closest = a[i];\n }\n }\n return closest;\n}\nfunction calcSiblingCount(nodes, n, offset) {\n let count = 0;\n let lastWasElement;\n let prevOffset = 0;\n let firstNode = true;\n let i, node;\n for (i = 0; i < nodes.length; i++) {\n node = nodes[i];\n if (node.nodeType === ELEMENT_NODE) {\n if (lastWasElement || firstNode) {\n count += 2;\n firstNode = false;\n }\n else {\n count++;\n }\n if (n === node) {\n if (node.tagName.toLowerCase() === `img`) {\n return { count, offset };\n }\n else {\n return { count };\n }\n }\n prevOffset = 0;\n lastWasElement = true;\n }\n else if (node.nodeType === TEXT_NODE ||\n node.nodeType === CDATA_SECTION_NODE) {\n if (lastWasElement || firstNode) {\n count++;\n firstNode = false;\n }\n if (n === node) {\n return { count, offset: offset + prevOffset };\n }\n prevOffset += node.textContent.length;\n lastWasElement = false;\n }\n else {\n continue;\n }\n }\n throw new Error(`The specified node was not found in the array of siblings`);\n}\nfunction compareTemporal(a, b) {\n const isA = (typeof a === `number`);\n const isB = (typeof b === `number`);\n if (!isA && !isB)\n return 0;\n if (!isA && isB)\n return -1;\n if (isA && !isB)\n return 1;\n return (a || 0.0) - (b || 0.0);\n}\nfunction compareSpatial(a, b) {\n if (!a && !b)\n return 0;\n if (!a && b)\n return -1;\n if (a && !b)\n return 1;\n const diff = (a.y || 0) - (b.y || 0);\n if (diff)\n return diff;\n return (a.x || 0) - (b.x || 0);\n}\nclass CFI {\n constructor(str, opts) {\n this.isRange = false;\n this.opts = Object.assign({\n flattenRange: false,\n stricter: true\n }, opts || {});\n this.cfi = str;\n this.parts = [];\n const isCFI = /^epubcfi\\((.*)\\)$/;\n str = str.trim();\n const m = str.match(isCFI);\n if (!m)\n throw new Error(`Not a valid CFI`);\n if (m.length < 2)\n return;\n str = m[1] || ``;\n let parsed, offset, newDoc;\n let subParts = [];\n let sawComma = 0;\n while (str.length) {\n ({ parsed, offset, newDoc } = this.parse(str));\n if (!parsed || offset === null)\n throw new Error(`Parsing failed`);\n if (sawComma && newDoc)\n throw new Error(`CFI is a range that spans multiple documents. This is not allowed`);\n subParts.push(parsed);\n if (newDoc || str.length - offset <= 0) {\n if (sawComma === 2) {\n this.to = subParts;\n }\n else {\n this.parts.push(subParts);\n }\n subParts = [];\n }\n str = str.slice(offset);\n if (str[0] === `,`) {\n if (sawComma === 0) {\n if (subParts.length) {\n this.parts.push(subParts);\n }\n subParts = [];\n }\n else if (sawComma === 1) {\n if (subParts.length) {\n this.from = subParts;\n }\n subParts = [];\n }\n str = str.slice(1);\n sawComma++;\n }\n }\n if (this.from && this.from.length) {\n if (this.opts.flattenRange || !this.to || !this.to.length) {\n this.parts = this.parts.concat(this.from);\n delete this.from;\n delete this.to;\n }\n else {\n this.isRange = true;\n }\n }\n if (this.opts.stricter) {\n this.removeIllegalOpts();\n }\n }\n removeIllegalOpts(parts) {\n if (!parts) {\n if (this.from) {\n this.removeIllegalOpts(this.from);\n if (!this.to)\n return;\n parts = this.to;\n }\n else {\n parts = this.parts;\n }\n }\n let i, j, part, subpart;\n for (i = 0; i < parts.length; i++) {\n part = parts[i];\n for (j = 0; j < part.length - 1; j++) {\n subpart = part[j];\n delete subpart.temporal;\n delete subpart.spatial;\n delete subpart.offset;\n delete subpart.textLocationAssertion;\n }\n }\n }\n static generatePart(node, offset, extra) {\n void (extra);\n let cfi = ``;\n let o;\n while (node.parentNode) {\n o = calcSiblingCount(node.parentNode.childNodes, node, offset);\n if (!cfi && o.offset)\n cfi = `:` + o.offset;\n cfi = `/` + o.count + ((node.id) ? `[` + cfiEscape(node.id) + `]` : ``) + cfi;\n node = node.parentNode;\n }\n return cfi;\n }\n static generate(node, offset, extra) {\n let cfi;\n if (Array.isArray(node)) {\n const strs = [];\n for (const o of node) {\n strs.push(this.generatePart(o.node, o.offset, extra));\n }\n cfi = strs.join(`!`);\n }\n else {\n cfi = this.generatePart(node, offset, extra);\n }\n if (extra)\n cfi += extra;\n return `epubcfi(` + cfi + `)`;\n }\n static toParsed(cfi) {\n if (typeof cfi === `string`) {\n }\n if (cfi.isRange) {\n return cfi.getFrom();\n }\n else {\n return cfi.get();\n }\n }\n static comparePath(a, b) {\n const max = Math.max(a.length, b.length);\n let i, cA, cB, diff;\n for (i = 0; i < max; i++) {\n cA = a[i];\n cB = b[i];\n if (!cA)\n return -1;\n if (!cB)\n return 1;\n diff = this.compareParts(cA, cB);\n if (diff)\n return diff;\n }\n return 0;\n }\n static sort(a) {\n a.sort((a, b) => {\n return this.compare(a, b);\n });\n }\n static compare(a, b) {\n let oA = a.get();\n let oB = b.get();\n if (a.isRange || b.isRange) {\n if (a.isRange && b.isRange) {\n const diff = this.comparePath(oA.from, oB.from);\n if (diff)\n return diff;\n return this.comparePath(oA.to, oB.to);\n }\n if (a.isRange)\n oA = oA.from;\n if (b.isRange)\n oB = oB.from;\n return this.comparePath(oA, oB);\n }\n else {\n return this.comparePath(oA, oB);\n }\n }\n static compareParts(a, b) {\n const max = Math.max(a.length, b.length);\n let i, cA, cB, diff;\n for (i = 0; i < max; i++) {\n cA = a[i];\n cB = b[i];\n if (!cA)\n return -1;\n if (!cB)\n return 1;\n diff = cA.nodeIndex - cB.nodeIndex;\n if (diff)\n return diff;\n if (cA.nodeIndex === 0) {\n return 0;\n }\n if (i < max - 1)\n continue;\n if (cA.nodeIndex % 2 === 0) {\n diff = compareTemporal(cA.temporal, cB.temporal);\n if (diff)\n return diff;\n diff = compareSpatial(cA.spatial, cB.spatial);\n if (diff)\n return diff;\n }\n diff = (cA.offset || 0) - (cB.offset || 0);\n if (diff)\n return diff;\n }\n return 0;\n }\n decodeEntities(dom, str) {\n try {\n const el = dom.createElement(`textarea`);\n el.innerHTML = str;\n return el.value || ``;\n }\n catch (err) {\n return str;\n }\n }\n trueLength(dom, str) {\n return this.decodeEntities(dom, str).length;\n }\n getFrom() {\n if (!this.isRange)\n throw new Error(`Trying to get beginning of non-range CFI`);\n if (!this.from) {\n return this.deepClone(this.parts);\n }\n const parts = this.deepClone(this.parts);\n parts[parts.length - 1] = parts[parts.length - 1].concat(this.from);\n return parts;\n }\n getTo() {\n if (!this.isRange)\n throw new Error(`Trying to get end of non-range CFI`);\n const parts = this.deepClone(this.parts);\n parts[parts.length - 1] = parts[parts.length - 1].concat(this.to);\n return parts;\n }\n get() {\n if (this.isRange) {\n return {\n from: this.getFrom(),\n to: this.getTo(),\n isRange: true\n };\n }\n return this.deepClone(this.parts);\n }\n parseSideBias(o, loc) {\n if (!loc)\n return;\n const m = loc.trim().match(/^(.*);s=([ba])$/);\n if (!m || m.length < 3) {\n if (typeof o.textLocationAssertion === `object`) {\n o.textLocationAssertion.post = loc;\n }\n else {\n o.textLocationAssertion = loc;\n }\n return;\n }\n if (m[1]) {\n if (typeof o.textLocationAssertion === `object`) {\n o.textLocationAssertion.post = m[1];\n }\n else {\n o.textLocationAssertion = m[1];\n }\n }\n if (m[2] === `a`) {\n o.sideBias = `after`;\n }\n else {\n o.sideBias = `before`;\n }\n }\n parseSpatialRange(range) {\n if (!range)\n return undefined;\n const m = range.trim().match(/^([\\d\\.]+):([\\d\\.]+)$/);\n if (!m || m.length < 3)\n return undefined;\n const o = {\n x: parseInt(m[1]),\n y: parseInt(m[2])\n };\n if (typeof o.x !== `number` || typeof o.y !== `number`) {\n return undefined;\n }\n return o;\n }\n parse(cfi) {\n const o = {};\n const isNumber = /[\\d]/;\n let f;\n let state;\n let prevState;\n let cur, escape;\n let seenColon = false;\n let seenSlash = false;\n let i;\n for (i = 0; i <= cfi.length; i++) {\n if (i < cfi.length) {\n cur = cfi[i];\n }\n else {\n cur = ``;\n }\n if (cur === `^` && !escape) {\n escape = true;\n continue;\n }\n if (state === `/`) {\n if (cur.match(isNumber)) {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n escape = false;\n continue;\n }\n else {\n if (f) {\n o.nodeIndex = parseInt(f);\n f = null;\n }\n prevState = state;\n state = null;\n }\n }\n if (state === `:`) {\n if (cur.match(isNumber)) {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n escape = false;\n continue;\n }\n else {\n if (f) {\n o.offset = parseInt(f);\n f = null;\n }\n prevState = state;\n state = null;\n }\n }\n if (state === `@`) {\n let done = false;\n if (cur.match(isNumber) || cur === `.` || cur === `:`) {\n if (cur === `:`) {\n if (!seenColon) {\n seenColon = true;\n }\n else {\n done = true;\n }\n }\n }\n else {\n done = true;\n }\n if (!done) {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n escape = false;\n continue;\n }\n else {\n prevState = state;\n state = null;\n if (f && seenColon)\n o.spatial = this.parseSpatialRange(f);\n f = null;\n }\n }\n if (state === `~`) {\n if (cur.match(isNumber) || cur === `.`) {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n escape = false;\n continue;\n }\n else {\n if (f) {\n o.temporal = parseFloat(f);\n }\n prevState = state;\n state = null;\n f = null;\n }\n }\n if (!state) {\n if (cur === `!`) {\n i++;\n state = cur;\n break;\n }\n if (cur === `,`) {\n break;\n }\n if (cur === `/`) {\n if (seenSlash) {\n break;\n }\n else {\n seenSlash = true;\n prevState = state;\n state = cur;\n escape = false;\n continue;\n }\n }\n if (cur === `:` || cur === `~` || cur === `@`) {\n if (this.opts.stricter) {\n if (cur === `:` && (typeof o.temporal !== `undefined` || typeof o.spatial !== `undefined`)) {\n break;\n }\n if ((cur === `~` || cur === `@`) && (typeof o.offset !== `undefined`)) {\n break;\n }\n }\n prevState = state;\n state = cur;\n escape = false;\n seenColon = false;\n continue;\n }\n if (cur === `[` && !escape && prevState === `:`) {\n prevState = state;\n state = `[`;\n escape = false;\n continue;\n }\n if (cur === `[` && !escape && prevState === `/`) {\n prevState = state;\n state = `nodeID`;\n escape = false;\n continue;\n }\n }\n if (state === `[`) {\n if (cur === `]` && !escape) {\n prevState = state;\n state = null;\n this.parseSideBias(o, f);\n f = null;\n }\n else if (cur === `,` && !escape) {\n o.textLocationAssertion = {};\n if (f) {\n o.textLocationAssertion.pre = f;\n }\n f = null;\n }\n else {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n }\n escape = false;\n continue;\n }\n if (state === `nodeID`) {\n if (cur === `]` && !escape) {\n prevState = state;\n state = null;\n o.nodeID = f;\n f = null;\n }\n else {\n if (!f) {\n f = cur;\n }\n else {\n f += cur;\n }\n }\n escape = false;\n continue;\n }\n escape = false;\n }\n if (!o.nodeIndex && o.nodeIndex !== 0)\n throw new Error(`Missing child node index in CFI`);\n return { parsed: o, offset: i, newDoc: (state === `!`) };\n }\n getChildNodeByCFIIndex(dom, parentNode, index, offset) {\n const children = parentNode.childNodes;\n if (!children.length)\n return { node: parentNode, offset: 0 };\n if (index <= 0) {\n return { node: children[0], relativeToNode: `before`, offset: 0 };\n }\n let cfiCount = 0;\n let lastChild;\n let i, child;\n for (i = 0; i < children.length; i++) {\n child = children[i];\n switch (child.nodeType) {\n case ELEMENT_NODE:\n if (cfiCount % 2 === 0) {\n cfiCount += 2;\n if (cfiCount >= index) {\n if (child.tagName.toLowerCase() === `img` && offset) {\n return { node: child, offset };\n }\n return { node: child, offset: 0 };\n }\n }\n else {\n cfiCount += 1;\n if (cfiCount === index) {\n if (child.tagName.toLowerCase() === `img` && offset) {\n return { node: child, offset };\n }\n return { node: child, offset: 0 };\n }\n else if (cfiCount > index) {\n if (!lastChild) {\n return { node: parentNode, offset: 0 };\n }\n return { node: lastChild, offset: this.trueLength(dom, lastChild.textContent) };\n }\n }\n lastChild = child;\n break;\n case TEXT_NODE:\n case CDATA_SECTION_NODE:\n if (cfiCount === 0 || cfiCount % 2 === 0) {\n cfiCount += 1;\n }\n else {\n }\n if (cfiCount === index) {\n const trueLength = this.trueLength(dom, child.textContent);\n if (offset >= trueLength) {\n offset -= trueLength;\n }\n else {\n return { node: child, offset: offset };\n }\n }\n lastChild = child;\n break;\n default:\n continue;\n }\n }\n if (index > cfiCount) {\n const o = { relativeToNode: `after`, offset: 0 };\n if (!lastChild) {\n o.node = parentNode;\n }\n else {\n o.node = lastChild;\n }\n if (this.isTextNode(o.node)) {\n o.offset = this.trueLength(dom, o.node.textContent.length);\n }\n return o;\n }\n }\n isTextNode(node) {\n if (!node)\n return false;\n if (node.nodeType === TEXT_NODE || node.nodeType === CDATA_SECTION_NODE) {\n return true;\n }\n return false;\n }\n correctOffset(dom, node, offset, assertion) {\n let curNode = node;\n let matchStr;\n if (typeof assertion === `string`) {\n matchStr = this.decodeEntities(dom, assertion);\n }\n else {\n assertion.pre = this.decodeEntities(dom, assertion.pre);\n assertion.post = this.decodeEntities(dom, assertion.post);\n matchStr = assertion.pre + `.` + assertion.post;\n }\n if (!(this.isTextNode(node))) {\n return { node, offset: 0 };\n }\n while (this.isTextNode(curNode.previousSibling)) {\n curNode = curNode.previousSibling;\n }\n const startNode = curNode;\n let str;\n const nodeLengths = [];\n let txt = ``;\n let i = 0;\n while (this.isTextNode(curNode)) {\n str = this.decodeEntities(dom, curNode.textContent);\n nodeLengths[i] = str.length;\n txt += str;\n if (!curNode.nextSibling)\n break;\n curNode = curNode.nextSibling;\n i++;\n }\n const matchOffset = (assertion.pre) ? assertion.pre.length : 0;\n const m = matchAll(txt, new RegExp(matchStr), matchOffset);\n if (!m.length)\n return { node, offset };\n let newOffset = closest(m, offset);\n if (curNode === node && newOffset === offset) {\n return { node, offset };\n }\n i = 0;\n curNode = startNode;\n while (newOffset >= nodeLengths[i]) {\n newOffset -= nodeLengths[i];\n if (newOffset < 0)\n return { node, offset };\n const nodeOffsets = [];\n if (!curNode.nextSibling || i + 1 >= nodeOffsets.length)\n return { node, offset };\n i++;\n curNode = curNode.nextSibling;\n }\n return { node: curNode, offset: newOffset };\n }\n resolveNode(index, subparts, dom, opts) {\n opts = Object.assign({}, opts || {});\n if (!dom)\n throw new Error(`Missing DOM argument`);\n let startNode;\n if (index === 0) {\n startNode = dom.querySelector(`package`);\n }\n if (!startNode) {\n for (const n of dom.childNodes) {\n if (n.nodeType === ELEMENT_NODE) {\n startNode = n;\n break;\n }\n }\n }\n startNode = dom;\n if (!startNode)\n throw new Error(`Document incompatible with CFIs`);\n let node = startNode;\n let startFrom = 0;\n let i;\n let subpart;\n for (i = subparts.length - 1; i >= 0; i--) {\n subpart = subparts[i];\n if (!opts.ignoreIDs && subpart.nodeID && (node = dom.getElementById(subpart.nodeID))) {\n startFrom = i + 1;\n break;\n }\n }\n if (!node) {\n node = startNode;\n }\n let o = { node, offset: 0 };\n let nodeIndex;\n for (i = startFrom; i < subparts.length; i++) {\n subpart = subparts[i];\n if (subpart) {\n o = this.getChildNodeByCFIIndex(dom, o.node, subpart.nodeIndex, subpart.offset);\n if (subpart.textLocationAssertion) {\n o = this.correctOffset(dom, o.node, subpart.offset, subpart.textLocationAssertion);\n }\n }\n }\n return o;\n }\n resolveURI(index, dom, opts) {\n opts = opts || {};\n if (index < 0 || index > this.parts.length - 2) {\n throw new Error(`index is out of bounds`);\n }\n const subparts = this.parts[index];\n if (!subparts)\n throw new Error(`Missing CFI part for index: ` + index);\n const o = this.resolveNode(index, subparts, dom, opts);\n let node = o.node;\n const tagName = node.tagName.toLowerCase();\n if (tagName === `itemref` &&\n node.parentNode.tagName.toLowerCase() === `spine`) {\n const idref = node.getAttribute(`idref`);\n if (!idref)\n throw new Error(`Referenced node had not 'idref' attribute`);\n node = dom.getElementById(idref);\n if (!node)\n throw new Error(`Specified node is missing from manifest`);\n const href = node.getAttribute(`href`);\n if (!href)\n throw new Error(`Manifest item is missing href attribute`);\n return href;\n }\n if (tagName === `iframe` || tagName === `embed`) {\n const src = node.getAttribute(`src`);\n if (!src)\n throw new Error(tagName + ` element is missing 'src' attribute`);\n return src;\n }\n if (tagName === `object`) {\n const data = node.getAttribute(`data`);\n if (!data)\n throw new Error(tagName + ` element is missing 'data' attribute`);\n return data;\n }\n if (tagName === `image` || tagName === `use`) {\n const href = node.getAttribute(`xlink:href`);\n if (!href)\n throw new Error(tagName + ` element is missing 'xlink:href' attribute`);\n return href;\n }\n throw new Error(`No URI found`);\n }\n deepClone(o) {\n return JSON.parse(JSON.stringify(o));\n }\n resolveLocation(dom, parts) {\n const index = parts.length - 1;\n const subparts = parts[index];\n if (!subparts)\n throw new Error(`Missing CFI part for index: ` + index);\n const o = this.resolveNode(index, subparts, dom);\n const lastPart = this.deepClone(subparts[subparts.length - 1]);\n delete lastPart.nodeIndex;\n if (!lastPart.offset)\n delete o.offset;\n return Object.assign(Object.assign({}, lastPart), o);\n }\n resolveLast(dom, opts) {\n opts = Object.assign({\n range: false\n }, opts || {});\n if (!this.isRange) {\n return this.resolveLocation(dom, this.parts);\n }\n if (opts.range) {\n const range = dom.createRange();\n const from = this.getFrom();\n if (from.relativeToNode === `before`) {\n range.setStartBefore(from.node, from.offset);\n }\n else if (from.relativeToNode === `after`) {\n range.setStartAfter(from.node, from.offset);\n }\n else {\n range.setStart(from.node, from.offset);\n }\n const to = this.getTo();\n if (to.relativeToNode === `before`) {\n range.setEndBefore(to.node, to.offset);\n }\n else if (to.relativeToNode === `after`) {\n range.setEndAfter(to.node, to.offset);\n }\n else {\n range.setEnd(to.node, to.offset);\n }\n return range;\n }\n return {\n from: this.resolveLocation(dom, this.getFrom()),\n to: this.resolveLocation(dom, this.getTo()),\n isRange: true\n };\n }\n resolve(doc, opts) {\n return this.resolveLast(doc, opts);\n }\n}\n\nconst extractProseMetadataFromCfi = (cfi) => {\n var _a, _b;\n const [itemId] = ((_a = cfi\n .match(/\\|(\\[prose\\~anchor[^\\]]*\\])+/ig)) === null || _a === void 0 ? void 0 : _a.map(s => s.replace(/\\|\\[prose\\~anchor\\~/, ``)\n .replace(/\\]/, ``))) || [];\n const [offset] = ((_b = cfi\n .match(/\\|(\\[prose\\~offset[^\\]]*\\])+/ig)) === null || _b === void 0 ? void 0 : _b.map(s => s.replace(/\\|\\[prose\\~offset\\~/, ``)\n .replace(/\\]/, ``))) || [];\n const cleanedCfi = cfi.replace(/\\|(\\[prose\\~[^\\]]*\\~[^\\]]*\\])+/ig, ``);\n const foundOffset = parseInt(offset || ``);\n return {\n cleanedCfi,\n itemId: itemId ? decodeURIComponent(itemId) : itemId,\n offset: isNaN(foundOffset) ? undefined : foundOffset\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/cfi.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/cfi.ts?7c23"],"sourcesContent":["/* eslint no-useless-escape: \"off\" */\n/**\n * @see https://github.com/fread-ink/epub-cfi-resolver\n * @latest a0d7e4e39d5b4adc9150e006e0b6d7af9513ae27\n */\n'use strict'\n\nconst ELEMENT_NODE = Node.ELEMENT_NODE\nconst TEXT_NODE = Node.TEXT_NODE\nconst CDATA_SECTION_NODE = Node.CDATA_SECTION_NODE\n\nfunction cfiEscape (str: string) {\n  return str.replace(/[\\[\\]\\^,();]/g, `^$&`)\n}\n\n// Get indices of all matches of regExp in str\n// if `add` is non-null, add it to the matched indices\nfunction matchAll (str: string, regExp: any, add: any) {\n  add = add || 0\n  const matches = []\n  let offset = 0\n  let m\n  do {\n    m = str.match(regExp)\n    if (!m) break\n    matches.push(m.index + add)\n    // @ts-ignore\n    offset += m.index + m.length\n    // @ts-ignore\n    str = str.slice(m.index + m.length)\n  } while (offset < str.length)\n\n  return matches\n}\n\n// Get the number in a that has the smallest diff to n\nfunction closest (a: any[], n: number) {\n  let minDiff\n  let closest\n  let i, diff\n  for (i = 0; i < a.length; i++) {\n    diff = Math.abs(a[i] - n)\n    // @ts-ignore\n    if (!i || diff < minDiff) {\n      diff = minDiff\n      closest = a[i]\n    }\n  }\n  return closest\n}\n\n// Given a set of nodes that are all children\n// and a reference to one of those nodes\n// calculate the count/index of the node\n// according to the CFI spec.\n// Also re-calculate offset if supplied and relevant\nfunction calcSiblingCount (nodes: globalThis.NodeListOf<globalThis.ChildNode>, n: number, offset: number) {\n  let count = 0\n  let lastWasElement\n  let prevOffset = 0\n  let firstNode = true\n  let i, node\n  for (i = 0; i < nodes.length; i++) {\n    node = nodes[i]\n    // @ts-ignore\n    if (node.nodeType === ELEMENT_NODE) {\n      if (lastWasElement || firstNode) {\n        count += 2\n        firstNode = false\n      } else {\n        count++\n      }\n\n      // @ts-ignore\n      if (n === node) {\n        // @ts-ignore\n        if (node.tagName.toLowerCase() === `img`) {\n          return { count, offset }\n        } else {\n          return { count }\n        }\n      }\n      prevOffset = 0\n      lastWasElement = true\n      // @ts-ignore\n    } else if (node.nodeType === TEXT_NODE ||\n      // @ts-ignore\n      node.nodeType === CDATA_SECTION_NODE) {\n      if (lastWasElement || firstNode) {\n        count++\n        firstNode = false\n      }\n\n      // @ts-ignore\n      if (n === node) {\n        return { count, offset: offset + prevOffset }\n      }\n\n      // @ts-ignore\n      prevOffset += node.textContent.length\n      lastWasElement = false\n    } else {\n      continue\n    }\n  }\n  throw new Error(`The specified node was not found in the array of siblings`)\n}\n\nfunction compareTemporal (a: number, b: number) {\n  const isA = (typeof a === `number`)\n  const isB = (typeof b === `number`)\n\n  if (!isA && !isB) return 0\n  if (!isA && isB) return -1\n  if (isA && !isB) return 1\n\n  return (a || 0.0) - (b || 0.0)\n}\n\nfunction compareSpatial (a: any, b: any) {\n  if (!a && !b) return 0\n  if (!a && b) return -1\n  if (a && !b) return 1\n\n  const diff = (a.y || 0) - (b.y || 0)\n  if (diff) return diff\n\n  return (a.x || 0) - (b.x || 0)\n}\n\nclass CFI {\n  isRange: boolean = false\n  parts: {}[]\n  opts: {}\n  cfi: string\n\n  constructor (str: string, opts: {}) {\n    this.opts = Object.assign({\n      // If CFI is a Simple Range, pretend it isn't\n      // by parsing only the start of the range\n      flattenRange: false,\n      // Strip temporal, spatial, offset and textLocationAssertion\n      // from places where they don't make sense\n      stricter: true\n    }, opts || {})\n\n    this.cfi = str\n    this.parts = []\n    const isCFI = /^epubcfi\\((.*)\\)$/\n\n    str = str.trim()\n    const m = str.match(isCFI)\n    if (!m) throw new Error(`Not a valid CFI`)\n    if (m.length < 2) return // Empty CFI\n\n    str = m[1] || ``\n\n    let parsed, offset, newDoc\n    let subParts = []\n    let sawComma = 0\n    while (str.length) {\n      ({ parsed, offset, newDoc } = this.parse(str))\n      if (!parsed || offset === null) throw new Error(`Parsing failed`)\n      if (sawComma && newDoc) throw new Error(`CFI is a range that spans multiple documents. This is not allowed`)\n\n      subParts.push(parsed)\n\n      // Handle end of string\n      if (newDoc || str.length - offset <= 0) {\n        // Handle end if this was a range\n        if (sawComma === 2) {\n          // @ts-ignore\n          this.to = subParts\n        } else { // not a range\n          this.parts.push(subParts)\n        }\n        subParts = []\n      }\n\n      str = str.slice(offset)\n\n      // Handle Simple Ranges\n      if (str[0] === `,`) {\n        if (sawComma === 0) {\n          if (subParts.length) {\n            this.parts.push(subParts)\n          }\n          subParts = []\n        } else if (sawComma === 1) {\n          if (subParts.length) {\n            // @ts-ignore\n            this.from = subParts\n          }\n          subParts = []\n        }\n        str = str.slice(1)\n        sawComma++\n      }\n    }\n    // @ts-ignore\n    if (this.from && this.from.length) {\n      // @ts-ignore\n      if (this.opts.flattenRange || !this.to || !this.to.length) {\n        // @ts-ignore\n        this.parts = this.parts.concat(this.from)\n        // @ts-ignore\n        delete this.from\n        // @ts-ignore\n        delete this.to\n      } else {\n        this.isRange = true\n      }\n    }\n    // @ts-ignore\n    if (this.opts.stricter) {\n      // @ts-ignore\n      this.removeIllegalOpts()\n    }\n  }\n\n  removeIllegalOpts (parts: any[]) {\n    if (!parts) {\n      // @ts-ignore\n      if (this.from) {\n        // @ts-ignore\n        this.removeIllegalOpts(this.from)\n        // @ts-ignore\n        if (!this.to) return\n        // @ts-ignore\n        parts = this.to\n      } else {\n        parts = this.parts\n      }\n    }\n\n    let i, j, part, subpart\n    for (i = 0; i < parts.length; i++) {\n      part = parts[i]\n      for (j = 0; j < part.length - 1; j++) {\n        subpart = part[j]\n        delete subpart.temporal\n        delete subpart.spatial\n        delete subpart.offset\n        delete subpart.textLocationAssertion\n      }\n    }\n  }\n\n  static generatePart (node: Element | Node, offset?: number, extra?: {}) {\n    /* eslint-disable-next-line no-void */\n    void (extra)\n    let cfi = ``\n    let o\n    while (node.parentNode) {\n      // @ts-ignore\n      o = calcSiblingCount(node.parentNode.childNodes, node, offset)\n      if (!cfi && o.offset) cfi = `:` + o.offset\n\n      // @ts-ignore\n      cfi = `/` + o.count + ((node.id) ? `[` + cfiEscape(node.id) + `]` : ``) + cfi\n\n      // debugger\n      node = node.parentNode\n    }\n\n    return cfi\n  }\n\n  static generate (node: Node, offset?: number, extra?: {}) {\n    let cfi\n\n    if (Array.isArray(node)) {\n      const strs = []\n      for (const o of node) {\n        strs.push(this.generatePart(o.node, o.offset, extra))\n      }\n      cfi = strs.join(`!`)\n    } else {\n      cfi = this.generatePart(node, offset, extra)\n    }\n\n    if (extra) cfi += extra\n\n    return `epubcfi(` + cfi + `)`\n  }\n\n  static toParsed (cfi: any) {\n    if (typeof cfi === `string`) {\n      // cif = new this(cfi)\n    }\n    if (cfi.isRange) {\n      return cfi.getFrom()\n    } else {\n      return cfi.get()\n    }\n  }\n\n  // Takes two CFI paths and compares them\n  static comparePath (a: any[], b: any[]) {\n    const max = Math.max(a.length, b.length)\n\n    let i, cA, cB, diff\n    for (i = 0; i < max; i++) {\n      cA = a[i]\n      cB = b[i]\n      if (!cA) return -1\n      if (!cB) return 1\n\n      diff = this.compareParts(cA, cB)\n      if (diff) return diff\n    }\n    return 0\n  }\n\n  // Sort an array of CFI objects\n  static sort (a: any) {\n    // @ts-ignore\n    a.sort((a, b) => {\n      return this.compare(a, b)\n    })\n  }\n\n  // Takes two CFI objects and compares them.\n  static compare (a: any, b: any) {\n    let oA = a.get()\n    let oB = b.get()\n    if (a.isRange || b.isRange) {\n      if (a.isRange && b.isRange) {\n        const diff = this.comparePath(oA.from, oB.from)\n        if (diff) return diff\n        return this.comparePath(oA.to, oB.to)\n      }\n      if (a.isRange) oA = oA.from\n      if (b.isRange) oB = oB.from\n\n      return this.comparePath(oA, oB)\n    } else { // neither a nor b is a range\n      return this.comparePath(oA, oB)\n    }\n  }\n\n  // Takes two parsed path parts (assuming path is split on '!') and compares them.\n  static compareParts (a: any, b: any) {\n    const max = Math.max(a.length, b.length)\n\n    let i, cA, cB, diff\n    for (i = 0; i < max; i++) {\n      cA = a[i]\n      cB = b[i]\n      if (!cA) return -1\n      if (!cB) return 1\n\n      diff = cA.nodeIndex - cB.nodeIndex\n      if (diff) return diff\n\n      // The paths must be equal if the \"before the first node\" syntax is used\n      // and this must be the last subpart (assuming a valid CFI)\n      if (cA.nodeIndex === 0) {\n        return 0\n      }\n\n      // Don't bother comparing offsets, temporals or spatials\n      // unless we're on the last element, since they're not\n      // supposed to be on elements other than the last\n      if (i < max - 1) continue\n\n      // Only compare spatials or temporals for element nodes\n      if (cA.nodeIndex % 2 === 0) {\n        diff = compareTemporal(cA.temporal, cB.temporal)\n        if (diff) return diff\n\n        diff = compareSpatial(cA.spatial, cB.spatial)\n        if (diff) return diff\n      }\n\n      diff = (cA.offset || 0) - (cB.offset || 0)\n      if (diff) return diff\n    }\n    return 0\n  }\n\n  decodeEntities (dom: Document, str: string) {\n    try {\n      const el = dom.createElement(`textarea`)\n      el.innerHTML = str\n      return el.value || ``\n    } catch (err) {\n      // TODO fall back to simpler decode?\n      // e.g. regex match for stuff like &#160; and &nbsp;\n      return str\n    }\n  }\n\n  // decode HTML/XML entities and compute length\n  trueLength (dom: Document, str: string) {\n    return this.decodeEntities(dom, str).length\n  }\n\n  getFrom () {\n    if (!this.isRange) throw new Error(`Trying to get beginning of non-range CFI`)\n    // @ts-ignore\n    if (!this.from) {\n      return this.deepClone(this.parts)\n    }\n    const parts = this.deepClone(this.parts)\n    // @ts-ignore\n    parts[parts.length - 1] = parts[parts.length - 1].concat(this.from)\n    return parts\n  }\n\n  getTo () {\n    if (!this.isRange) throw new Error(`Trying to get end of non-range CFI`)\n    const parts = this.deepClone(this.parts)\n    // @ts-ignore\n    parts[parts.length - 1] = parts[parts.length - 1].concat(this.to)\n    return parts\n  }\n\n  get () {\n    if (this.isRange) {\n      return {\n        from: this.getFrom(),\n        to: this.getTo(),\n        isRange: true\n      }\n    }\n    return this.deepClone(this.parts)\n  }\n\n  parseSideBias (o: any, loc: any) {\n    if (!loc) return\n    const m = loc.trim().match(/^(.*);s=([ba])$/)\n    if (!m || m.length < 3) {\n      if (typeof o.textLocationAssertion === `object`) {\n        o.textLocationAssertion.post = loc\n      } else {\n        o.textLocationAssertion = loc\n      }\n      return\n    }\n    if (m[1]) {\n      if (typeof o.textLocationAssertion === `object`) {\n        o.textLocationAssertion.post = m[1]\n      } else {\n        o.textLocationAssertion = m[1]\n      }\n    }\n\n    if (m[2] === `a`) {\n      o.sideBias = `after`\n    } else {\n      o.sideBias = `before`\n    }\n  }\n\n  parseSpatialRange (range: any) {\n    if (!range) return undefined\n    const m = range.trim().match(/^([\\d\\.]+):([\\d\\.]+)$/)\n    if (!m || m.length < 3) return undefined\n    const o = {\n      x: parseInt(m[1]),\n      y: parseInt(m[2])\n    }\n    if (typeof o.x !== `number` || typeof o.y !== `number`) {\n      return undefined\n    }\n    return o\n  }\n\n  parse (cfi: any) {\n    const o = {}\n    const isNumber = /[\\d]/\n    let f\n    let state\n    let prevState\n    let cur, escape\n    let seenColon = false\n    let seenSlash = false\n    let i\n    for (i = 0; i <= cfi.length; i++) {\n      if (i < cfi.length) {\n        cur = cfi[i]\n      } else {\n        cur = ``\n      }\n      if (cur === `^` && !escape) {\n        escape = true\n        continue\n      }\n\n      if (state === `/`) {\n        if (cur.match(isNumber)) {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n          escape = false\n          continue\n        } else {\n          if (f) {\n            // @ts-ignore\n            o.nodeIndex = parseInt(f)\n            f = null\n          }\n          prevState = state\n          state = null\n        }\n      }\n\n      if (state === `:`) {\n        if (cur.match(isNumber)) {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n          escape = false\n          continue\n        } else {\n          if (f) {\n            // @ts-ignore\n            o.offset = parseInt(f)\n            f = null\n          }\n          prevState = state\n          state = null\n        }\n      }\n\n      if (state === `@`) {\n        let done = false\n        if (cur.match(isNumber) || cur === `.` || cur === `:`) {\n          if (cur === `:`) {\n            if (!seenColon) {\n              seenColon = true\n            } else {\n              done = true\n            }\n          }\n        } else {\n          done = true\n        }\n        if (!done) {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n          escape = false\n          continue\n        } else {\n          prevState = state\n          state = null\n          // @ts-ignore\n          if (f && seenColon) o.spatial = this.parseSpatialRange(f)\n          f = null\n        }\n      }\n\n      if (state === `~`) {\n        if (cur.match(isNumber) || cur === `.`) {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n          escape = false\n          continue\n        } else {\n          if (f) {\n            // @ts-ignore\n            o.temporal = parseFloat(f)\n          }\n          prevState = state\n          state = null\n          f = null\n        }\n      }\n\n      if (!state) {\n        if (cur === `!`) {\n          i++\n          state = cur\n          break\n        }\n\n        if (cur === `,`) {\n          break\n        }\n\n        if (cur === `/`) {\n          if (seenSlash) {\n            break\n          } else {\n            seenSlash = true\n            prevState = state\n            state = cur\n            escape = false\n            continue\n          }\n        }\n\n        if (cur === `:` || cur === `~` || cur === `@`) {\n          // @ts-ignore\n          if (this.opts.stricter) {\n            // We've already had a temporal or spatial indicator\n            // and offset does not make sense and the same time\n            // @ts-ignore\n            if (cur === `:` && (typeof o.temporal !== `undefined` || typeof o.spatial !== `undefined`)) {\n              break\n            }\n            // We've already had an offset\n            // and temporal or spatial do not make sense at the same time\n            // @ts-ignore\n            if ((cur === `~` || cur === `@`) && (typeof o.offset !== `undefined`)) {\n              break\n            }\n          }\n          prevState = state\n          state = cur\n          escape = false\n          seenColon = false // only relevant for '@'\n          continue\n        }\n\n        if (cur === `[` && !escape && prevState === `:`) {\n          prevState = state\n          state = `[`\n          escape = false\n          continue\n        }\n\n        if (cur === `[` && !escape && prevState === `/`) {\n          prevState = state\n          state = `nodeID`\n          escape = false\n          continue\n        }\n      }\n\n      if (state === `[`) {\n        if (cur === `]` && !escape) {\n          prevState = state\n          state = null\n          this.parseSideBias(o, f)\n          f = null\n        } else if (cur === `,` && !escape) {\n          // @ts-ignore\n          o.textLocationAssertion = {}\n          if (f) {\n            // @ts-ignore\n            o.textLocationAssertion.pre = f\n          }\n          f = null\n        } else {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n        }\n        escape = false\n        continue\n      }\n\n      if (state === `nodeID`) {\n        if (cur === `]` && !escape) {\n          prevState = state\n          state = null\n          // @ts-ignore\n          o.nodeID = f\n          f = null\n        } else {\n          if (!f) {\n            f = cur\n          } else {\n            f += cur\n          }\n        }\n        escape = false\n        continue\n      }\n\n      escape = false\n    }\n\n    // @ts-ignore\n    if (!o.nodeIndex && o.nodeIndex !== 0) throw new Error(`Missing child node index in CFI`)\n\n    return { parsed: o, offset: i, newDoc: (state === `!`) }\n  }\n\n  // The CFI counts child nodes differently from the DOM\n  // Retrieve the child of parentNode at the specified index\n  // according to the CFI standard way of counting\n  getChildNodeByCFIIndex (dom: Document, parentNode: Element, index: number, offset: number) {\n    // console.log(`getChildNodeByCFIIndex`, { parentNode, index, offset })\n    const children = parentNode.childNodes\n    if (!children.length) return { node: parentNode, offset: 0 }\n\n    // index is pointing to the virtual node before the first node\n    // as defined in the CFI spec\n    if (index <= 0) {\n      return { node: children[0], relativeToNode: `before`, offset: 0 }\n    }\n\n    let cfiCount = 0\n    let lastChild\n    let i, child\n\n    // console.log(children, children.length)\n    for (i = 0; i < children.length; i++) {\n      child = children[i]\n      // @ts-ignore\n      switch (child.nodeType) {\n        case ELEMENT_NODE:\n\n          // If the previous node was also an element node\n          // then we have to pretend there was a text node in between\n          // the current and previous nodes (according to the CFI spec)\n          // so we increment cfiCount by two\n          if (cfiCount % 2 === 0) {\n            cfiCount += 2\n            if (cfiCount >= index) {\n              // @ts-ignore\n              if (child.tagName.toLowerCase() === `img` && offset) {\n                return { node: child, offset }\n              }\n              return { node: child, offset: 0 }\n            }\n          } else { // Previous node was a text node\n            cfiCount += 1\n            if (cfiCount === index) {\n              // @ts-ignore\n              if (child.tagName.toLowerCase() === `img` && offset) {\n                return { node: child, offset }\n              }\n\n              return { node: child, offset: 0 }\n\n              // This happens when offset into the previous text node was greater\n              // than the number of characters in that text node\n              // So we return a position at the end of the previous text node\n            } else if (cfiCount > index) {\n              if (!lastChild) {\n                return { node: parentNode, offset: 0 }\n              }\n              // @ts-ignore\n              return { node: lastChild, offset: this.trueLength(dom, lastChild.textContent) }\n            }\n          }\n          lastChild = child\n          break\n        case TEXT_NODE:\n        case CDATA_SECTION_NODE:\n          // console.log('TEXT')\n          // If this is the first node or the previous node was an element node\n          if (cfiCount === 0 || cfiCount % 2 === 0) {\n            cfiCount += 1\n          } else {\n            // If previous node was a text node then they should be combined\n            // so we count them as one, meaning we don't increment the count\n          }\n\n          if (cfiCount === index) {\n            // If offset is greater than the length of the current text node\n            // then we assume that the next node will also be a text node\n            // and that we'll be combining them with the current node\n            // @ts-ignore\n            const trueLength = this.trueLength(dom, child.textContent)\n\n            if (offset >= trueLength) {\n              offset -= trueLength\n            } else {\n              return { node: child, offset: offset }\n            }\n          }\n          lastChild = child\n          break\n        default:\n          continue\n      }\n    }\n\n    // console.log(lastChild, index, cfiCount)\n\n    // index is pointing to the virtual node after the last child\n    // as defined in the CFI spec\n    if (index > cfiCount) {\n      const o = { relativeToNode: `after`, offset: 0 }\n      if (!lastChild) {\n        // @ts-ignore\n        o.node = parentNode\n      } else {\n        // @ts-ignore\n        o.node = lastChild\n      }\n      // @ts-ignore\n      if (this.isTextNode(o.node)) {\n        // @ts-ignore\n        o.offset = this.trueLength(dom, o.node.textContent.length)\n      }\n      return o\n    }\n  }\n\n  isTextNode (node: Element) {\n    if (!node) return false\n    if (node.nodeType === TEXT_NODE || node.nodeType === CDATA_SECTION_NODE) {\n      return true\n    }\n    return false\n  }\n\n  // Use a Text Location Assertion to correct and offset\n  correctOffset (dom: Document, node: Element, offset: number, assertion: any) {\n    let curNode = node\n    let matchStr: string | undefined\n\n    if (typeof assertion === `string`) {\n      matchStr = this.decodeEntities(dom, assertion)\n    } else {\n      assertion.pre = this.decodeEntities(dom, assertion.pre)\n      assertion.post = this.decodeEntities(dom, assertion.post)\n      matchStr = assertion.pre + `.` + assertion.post\n    }\n\n    if (!(this.isTextNode(node))) {\n      return { node, offset: 0 }\n    }\n\n    // @ts-ignore\n    while (this.isTextNode(curNode.previousSibling)) {\n      // @ts-ignore\n      curNode = curNode.previousSibling\n    }\n\n    const startNode = curNode\n    let str\n    const nodeLengths = []\n    let txt = ``\n    let i = 0\n    while (this.isTextNode(curNode)) {\n      // @ts-ignore\n      str = this.decodeEntities(dom, curNode.textContent)\n      nodeLengths[i] = str.length\n      txt += str\n\n      if (!curNode.nextSibling) break\n      // @ts-ignore\n      curNode = curNode.nextSibling\n      i++\n    }\n\n    // Find all matches to the Text Location Assertion\n    const matchOffset = (assertion.pre) ? assertion.pre.length : 0\n    const m = matchAll(txt, new RegExp(matchStr), matchOffset)\n    if (!m.length) return { node, offset }\n\n    // Get the match that has the closest offset to the existing offset\n    let newOffset = closest(m, offset)\n\n    if (curNode === node && newOffset === offset) {\n      return { node, offset }\n    }\n\n    i = 0\n    curNode = startNode\n    // @ts-ignore\n    while (newOffset >= nodeLengths[i]) {\n      // @ts-ignore\n      newOffset -= nodeLengths[i]\n      if (newOffset < 0) return { node, offset }\n\n      const nodeOffsets = [] // added because original code has nodeOffsets undefined. @see https://github.com/fread-ink/epub-cfi-resolver/blob/master/index.js#L826\n\n      if (!curNode.nextSibling || i + 1 >= nodeOffsets.length) return { node, offset }\n      i++\n      // @ts-ignore\n      curNode = curNode.nextSibling\n    }\n\n    return { node: curNode, offset: newOffset }\n  }\n\n  resolveNode (index: number, subparts: { nodeIndex: number, nodeID?: string, offset?: number }[], dom: Document, opts: {}) {\n    opts = Object.assign({}, opts || {})\n    if (!dom) throw new Error(`Missing DOM argument`)\n\n    // Traverse backwards until a subpart with a valid ID is found\n    // or the first subpart is reached\n    let startNode\n    if (index === 0) {\n      startNode = dom.querySelector(`package`)\n    }\n\n    if (!startNode) {\n      for (const n of dom.childNodes) {\n        if (n.nodeType === ELEMENT_NODE) {\n          // if (n.nodeType === Node.DOCUMENT_NODE) {\n          startNode = n\n          break\n        }\n      }\n    }\n\n    // custom\n    startNode = dom\n\n    // debugger\n    if (!startNode) throw new Error(`Document incompatible with CFIs`)\n\n    let node = startNode\n    let startFrom = 0\n    let i\n    let subpart: typeof subparts[number] | undefined\n    for (i = subparts.length - 1; i >= 0; i--) {\n      subpart = subparts[i]\n      // @ts-ignore\n      if (!opts.ignoreIDs && subpart.nodeID && (node = dom.getElementById(subpart.nodeID))) {\n        startFrom = i + 1\n        break\n      }\n    }\n\n    // console.log(startNode, startFrom)\n\n    if (!node) {\n      node = startNode\n    }\n\n    let o = { node, offset: 0 }\n\n    let nodeIndex\n    for (i = startFrom; i < subparts.length; i++) {\n      subpart = subparts[i]\n\n      if (subpart) {\n        // console.log(o, dom, o.node, subpart.nodeIndex, subpart.offset)\n        // @ts-ignore\n        o = this.getChildNodeByCFIIndex(dom, o.node, subpart.nodeIndex, subpart.offset)\n\n        // @ts-ignore\n        if (subpart.textLocationAssertion) {\n          // console.log(subparts, subpart, o)\n          // @ts-ignore\n          o = this.correctOffset(dom, o.node, subpart.offset, subpart.textLocationAssertion)\n        }\n      }\n    }\n\n    return o\n  }\n\n  // Each part of a CFI (as separated by '!')\n  // references a separate HTML/XHTML/XML document.\n  // This function takes an index specifying the part\n  // of the CFI and the appropriate Document or XMLDocument\n  // that is referenced by the specified part of the CFI\n  // and returns the URI for the document referenced by\n  // the next part of the CFI\n  // If the opt `ignoreIDs` is true then IDs\n  // will not be used while resolving\n  resolveURI (index: number, dom: Document, opts: { ignoreIDs?: boolean }) {\n    opts = opts || {}\n    if (index < 0 || index > this.parts.length - 2) {\n      throw new Error(`index is out of bounds`)\n    }\n\n    const subparts = this.parts[index]\n    if (!subparts) throw new Error(`Missing CFI part for index: ` + index)\n\n    // @ts-ignore\n    const o = this.resolveNode(index, subparts, dom, opts)\n    // debugger\n    let node = o.node\n\n    // @ts-ignore\n    const tagName = node.tagName.toLowerCase()\n    if (tagName === `itemref` &&\n      // @ts-ignore\n      node.parentNode.tagName.toLowerCase() === `spine`) {\n      // @ts-ignore\n      const idref = node.getAttribute(`idref`)\n      if (!idref) throw new Error(`Referenced node had not 'idref' attribute`)\n      // @ts-ignore\n      node = dom.getElementById(idref)\n      if (!node) throw new Error(`Specified node is missing from manifest`)\n      // @ts-ignore\n      const href = node.getAttribute(`href`)\n      if (!href) throw new Error(`Manifest item is missing href attribute`)\n\n      return href\n    }\n\n    if (tagName === `iframe` || tagName === `embed`) {\n      // @ts-ignore\n      const src = node.getAttribute(`src`)\n      if (!src) throw new Error(tagName + ` element is missing 'src' attribute`)\n      return src\n    }\n\n    if (tagName === `object`) {\n      // @ts-ignore\n      const data = node.getAttribute(`data`)\n      if (!data) throw new Error(tagName + ` element is missing 'data' attribute`)\n      return data\n    }\n\n    if (tagName === `image` || tagName === `use`) {\n      // @ts-ignore\n      const href = node.getAttribute(`xlink:href`)\n      if (!href) throw new Error(tagName + ` element is missing 'xlink:href' attribute`)\n      return href\n    }\n\n    throw new Error(`No URI found`)\n  }\n\n  deepClone (o: any) {\n    return JSON.parse(JSON.stringify(o))\n  }\n\n  resolveLocation (dom: Document, parts: {}[]) {\n    const index = parts.length - 1\n    const subparts = parts[index]\n    if (!subparts) throw new Error(`Missing CFI part for index: ` + index)\n\n    // @ts-ignore\n    const o = this.resolveNode(index, subparts, dom)\n\n    // @ts-ignore\n    const lastPart = this.deepClone(subparts[subparts.length - 1])\n\n    delete lastPart.nodeIndex\n    // @ts-ignore\n    if (!lastPart.offset) delete o.offset\n\n    return { ...lastPart, ...o }\n  }\n\n  // Takes the Document or XMLDocument for the final\n  // document referenced by the CFI\n  // and returns the node and offset into that node\n  resolveLast (dom: Document, opts: {}): string | {} {\n    opts = Object.assign({\n      range: false\n    }, opts || {})\n\n    if (!this.isRange) {\n      return this.resolveLocation(dom, this.parts)\n    }\n\n    // @ts-ignore\n    if (opts.range) {\n      const range = dom.createRange()\n      const from = this.getFrom()\n      if (from.relativeToNode === `before`) {\n        // @ts-ignore\n        range.setStartBefore(from.node, from.offset)\n      } else if (from.relativeToNode === `after`) {\n        // @ts-ignore\n        range.setStartAfter(from.node, from.offset)\n      } else {\n        range.setStart(from.node, from.offset)\n      }\n\n      const to = this.getTo()\n      if (to.relativeToNode === `before`) {\n        // @ts-ignore\n        range.setEndBefore(to.node, to.offset)\n      } else if (to.relativeToNode === `after`) {\n        // @ts-ignore\n        range.setEndAfter(to.node, to.offset)\n      } else {\n        range.setEnd(to.node, to.offset)\n      }\n\n      return range\n    }\n\n    return {\n      from: this.resolveLocation(dom, this.getFrom()),\n      to: this.resolveLocation(dom, this.getTo()),\n      isRange: true\n    }\n  }\n\n  resolve (doc: Document, opts: {}): { node: Node, offset?: number } | { node?: undefined, offset?: number } {\n    // @ts-ignore\n    return this.resolveLast(doc, opts)\n  }\n}\n\nexport {\n  CFI\n}\n\nexport const extractProseMetadataFromCfi = (cfi: string): {\n  cleanedCfi: string,\n  itemId?: string\n  offset?: number\n} => {\n  const [itemId] = cfi\n    .match(/\\|(\\[prose\\~anchor[^\\]]*\\])+/ig)\n    ?.map(s => s.replace(/\\|\\[prose\\~anchor\\~/, ``)\n      .replace(/\\]/, ``)) || []\n  const [offset] = cfi\n    .match(/\\|(\\[prose\\~offset[^\\]]*\\])+/ig)\n    ?.map(s => s.replace(/\\|\\[prose\\~offset\\~/, ``)\n      .replace(/\\]/, ``)) || []\n  const cleanedCfi = cfi.replace(/\\|(\\[prose\\~[^\\]]*\\~[^\\]]*\\])+/ig, ``)\n  const foundOffset = parseInt(offset || ``)\n\n  return {\n    cleanedCfi,\n    itemId: itemId ? decodeURIComponent(itemId) : itemId,\n    offset: isNaN(foundOffset) ? undefined : foundOffset\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/cfi.ts\n");
|
|
20
|
+
|
|
21
|
+
/***/ }),
|
|
22
|
+
|
|
23
|
+
/***/ "./src/constants.ts":
|
|
24
|
+
/*!**************************!*\
|
|
25
|
+
!*** ./src/constants.ts ***!
|
|
26
|
+
\**************************/
|
|
27
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
28
|
+
|
|
29
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"__UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY\": () => (/* binding */ __UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY),\n/* harmony export */ \"PROSE_READER_NAMESPACE\": () => (/* binding */ PROSE_READER_NAMESPACE),\n/* harmony export */ \"VIEWPORT_ADJUSTMENT_THROTTLE\": () => (/* binding */ VIEWPORT_ADJUSTMENT_THROTTLE),\n/* harmony export */ \"PAGINATION_UPDATE_AFTER_VIEWPORT_ADJUSTMENT_DEBOUNCE\": () => (/* binding */ PAGINATION_UPDATE_AFTER_VIEWPORT_ADJUSTMENT_DEBOUNCE),\n/* harmony export */ \"ITEM_EXTENSION_VALID_FOR_FRAME_SRC\": () => (/* binding */ ITEM_EXTENSION_VALID_FOR_FRAME_SRC)\n/* harmony export */ });\nconst __UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY = `__UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT`;\nconst PROSE_READER_NAMESPACE = `@prose-reader/core`;\nconst VIEWPORT_ADJUSTMENT_THROTTLE = 0;\nconst PAGINATION_UPDATE_AFTER_VIEWPORT_ADJUSTMENT_DEBOUNCE = 200;\nconst ITEM_EXTENSION_VALID_FOR_FRAME_SRC = [`.xhtml`, `.html`, `.htm`];\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY29uc3RhbnRzLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQU8sTUFBTSw0Q0FBNEMsR0FBRywwQ0FBMEM7QUFDL0YsTUFBTSxzQkFBc0IsR0FBRyxvQkFBb0I7QUFDbkQsTUFBTSw0QkFBNEIsR0FBRyxDQUFDO0FBQ3RDLE1BQU0sb0RBQW9ELEdBQUcsR0FBRztBQUNoRSxNQUFNLGtDQUFrQyxHQUFHLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxNQUFNLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvY29uc3RhbnRzLnRzPzg1ZWUiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IF9fVU5TQUZFX1JFRkVSRU5DRV9PUklHSU5BTF9JRlJBTUVfRVZFTlRfS0VZID0gYF9fVU5TQUZFX1JFRkVSRU5DRV9PUklHSU5BTF9JRlJBTUVfRVZFTlRgXG5leHBvcnQgY29uc3QgUFJPU0VfUkVBREVSX05BTUVTUEFDRSA9IGBAcHJvc2UtcmVhZGVyL2NvcmVgXG5leHBvcnQgY29uc3QgVklFV1BPUlRfQURKVVNUTUVOVF9USFJPVFRMRSA9IDBcbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX1VQREFURV9BRlRFUl9WSUVXUE9SVF9BREpVU1RNRU5UX0RFQk9VTkNFID0gMjAwXG5leHBvcnQgY29uc3QgSVRFTV9FWFRFTlNJT05fVkFMSURfRk9SX0ZSQU1FX1NSQyA9IFtgLnhodG1sYCwgYC5odG1sYCwgYC5odG1gXVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/constants.ts\n");
|
|
30
|
+
|
|
31
|
+
/***/ }),
|
|
32
|
+
|
|
33
|
+
/***/ "./src/context.ts":
|
|
34
|
+
/*!************************!*\
|
|
35
|
+
!*** ./src/context.ts ***!
|
|
36
|
+
\************************/
|
|
37
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
38
|
+
|
|
39
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createContext\": () => (/* binding */ createContext)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _settings__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./settings */ \"./src/settings.ts\");\n\n\n\nconst createContext = (initialSettings) => {\n let manifest;\n let loadOptions;\n const hasVerticalWritingSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(false);\n const loadSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const visibleAreaRect = {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n const horizontalMargin = 24;\n const verticalMargin = 20;\n const marginTop = 0;\n const marginBottom = 0;\n const destroy$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const settings = (0,_settings__WEBPACK_IMPORTED_MODULE_2__.createSettings)(initialSettings);\n const shouldDisplaySpread = () => {\n const { height, width } = visibleAreaRect;\n const isLandscape = width > height;\n if (settings.getSettings().forceSinglePageMode)\n return false;\n if ((manifest === null || manifest === void 0 ? void 0 : manifest.renditionFlow) === `scrolled-continuous`)\n return false;\n if (!isLandscape && (manifest === null || manifest === void 0 ? void 0 : manifest.renditionSpread) === `portrait`) {\n return true;\n }\n return (isLandscape &&\n ((manifest === null || manifest === void 0 ? void 0 : manifest.renditionSpread) === undefined ||\n (manifest === null || manifest === void 0 ? void 0 : manifest.renditionSpread) === `auto` ||\n (manifest === null || manifest === void 0 ? void 0 : manifest.renditionSpread) === `landscape` ||\n (manifest === null || manifest === void 0 ? void 0 : manifest.renditionSpread) === `both`));\n };\n const load = (newManifest, newLoadOptions) => {\n manifest = newManifest;\n loadOptions = newLoadOptions;\n settings.recompute({ manifest, hasVerticalWritingSubject: hasVerticalWritingSubject$.value });\n loadSubject$.next(newManifest);\n };\n const isRTL = () => {\n return (manifest === null || manifest === void 0 ? void 0 : manifest.readingDirection) === `rtl`;\n };\n const setHasVerticalWriting = () => hasVerticalWritingSubject$.next(true);\n hasVerticalWritingSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.skip)(1), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n settings.recompute({ manifest, hasVerticalWritingSubject: hasVerticalWritingSubject$.value });\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroy$))\n .subscribe();\n const destroy = () => {\n settings.destroy();\n loadSubject$.complete();\n destroy$.next();\n destroy$.complete();\n hasVerticalWritingSubject$.complete();\n };\n return {\n load,\n isRTL,\n areAllItemsPrePaginated: () => areAllItemsPrePaginated(manifest),\n destroy,\n getLoadOptions: () => loadOptions,\n getCalculatedInnerMargin: () => 0,\n getVisibleAreaRect: () => visibleAreaRect,\n shouldDisplaySpread,\n setHasVerticalWriting,\n setVisibleAreaRect: (x, y, width, height) => {\n visibleAreaRect.width = width;\n visibleAreaRect.height = height - marginTop - marginBottom;\n visibleAreaRect.x = x;\n visibleAreaRect.y = y;\n },\n getManifest: () => manifest,\n getReadingDirection: () => manifest === null || manifest === void 0 ? void 0 : manifest.readingDirection,\n getPageSize: () => {\n return {\n width: shouldDisplaySpread()\n ? visibleAreaRect.width / 2\n : visibleAreaRect.width,\n height: visibleAreaRect.height\n };\n },\n getSettings: settings.getSettings,\n setSettings: (data) => settings.setSettings(data, {\n hasVerticalWritingSubject: hasVerticalWritingSubject$.value,\n manifest\n }),\n $: {\n hasVerticalWriting$: hasVerticalWritingSubject$\n .asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)()),\n destroy$: destroy$\n .asObservable(),\n settings$: settings.$.settings$,\n load$: loadSubject$\n .asObservable()\n }\n };\n};\nconst areAllItemsPrePaginated = (manifest) => !(manifest === null || manifest === void 0 ? void 0 : manifest.spineItems.some(item => item.renditionLayout === `reflowable`));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/context.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/context.ts?ae15"],"sourcesContent":["import { BehaviorSubject, Subject } from \"rxjs\"\nimport { distinctUntilChanged, takeUntil, tap, skip } from \"rxjs/operators\"\nimport { LoadOptions } from \"./types\"\nimport { Manifest } from \"@prose-reader/shared\"\nimport { createSettings } from \"./settings\"\n\nexport type ContextObservableEvents = {}\n\nexport const createContext = (initialSettings: Parameters<typeof createSettings>[0]) => {\n  let manifest: Manifest | undefined\n  let loadOptions: LoadOptions | undefined\n  const hasVerticalWritingSubject$ = new BehaviorSubject(false)\n  const loadSubject$ = new Subject<Manifest>()\n  const visibleAreaRect = {\n    width: 0,\n    height: 0,\n    x: 0,\n    y: 0\n  }\n  const horizontalMargin = 24\n  const verticalMargin = 20\n  const marginTop = 0\n  const marginBottom = 0\n  const destroy$ = new Subject<void>()\n  const settings = createSettings(initialSettings)\n\n  /**\n   * Global spread behavior\n   * @see http://idpf.org/epub/fxl/#property-spread\n   * @todo user setting\n   */\n  const shouldDisplaySpread = () => {\n    const { height, width } = visibleAreaRect\n    const isLandscape = width > height\n\n    if (settings.getSettings().forceSinglePageMode) return false\n\n    /**\n     * For now we don't support spread for reflowable & scrollable content since\n     * two items could have different height, resulting in weird stuff.\n     */\n    if (manifest?.renditionFlow === `scrolled-continuous`) return false\n\n    // portrait only\n    if (!isLandscape && manifest?.renditionSpread === `portrait`) {\n      return true\n    }\n\n    // default auto behavior\n    return (\n      isLandscape &&\n      (\n        manifest?.renditionSpread === undefined ||\n        manifest?.renditionSpread === `auto` ||\n        manifest?.renditionSpread === `landscape` ||\n        manifest?.renditionSpread === `both`\n      )\n    )\n  }\n\n  const load = (newManifest: Manifest, newLoadOptions: LoadOptions) => {\n    manifest = newManifest\n    loadOptions = newLoadOptions\n\n    settings.recompute({ manifest, hasVerticalWritingSubject: hasVerticalWritingSubject$.value })\n\n    loadSubject$.next(newManifest)\n  }\n\n  /**\n   * RTL only makes sense for horizontal scrolling\n   */\n  const isRTL = () => {\n    return manifest?.readingDirection === `rtl`\n  }\n\n  const setHasVerticalWriting = () => hasVerticalWritingSubject$.next(true)\n\n  /**\n   * Some behavior may trigger settings to change\n   */\n  hasVerticalWritingSubject$\n    .pipe(\n      skip(1),\n      distinctUntilChanged(),\n      tap(() => {\n        settings.recompute({ manifest, hasVerticalWritingSubject: hasVerticalWritingSubject$.value })\n      }),\n      takeUntil(destroy$)\n    )\n    .subscribe()\n\n  const destroy = () => {\n    settings.destroy()\n    loadSubject$.complete()\n    destroy$.next()\n    destroy$.complete()\n    hasVerticalWritingSubject$.complete()\n  }\n\n  return {\n    load,\n    isRTL,\n    areAllItemsPrePaginated: () => areAllItemsPrePaginated(manifest),\n    destroy,\n    getLoadOptions: () => loadOptions,\n    getCalculatedInnerMargin: () => 0,\n    getVisibleAreaRect: () => visibleAreaRect,\n    shouldDisplaySpread,\n    setHasVerticalWriting,\n    setVisibleAreaRect: (\n      x: number,\n      y: number,\n      width: number,\n      height: number\n    ) => {\n      // visibleAreaRect.width = width - horizontalMargin * 2\n      visibleAreaRect.width = width\n      visibleAreaRect.height = height - marginTop - marginBottom\n      visibleAreaRect.x = x\n      visibleAreaRect.y = y\n\n      // if (this.useChromiumRubyBugSafeInnerMargin) {\n      //   this.visibleAreaRect.height =\n      //     this.visibleAreaRect.height - this.getCalculatedInnerMargin()\n      // }\n    },\n    getManifest: () => manifest,\n    getReadingDirection: () => manifest?.readingDirection,\n    getPageSize: () => {\n      return {\n        width: shouldDisplaySpread()\n          ? visibleAreaRect.width / 2\n          : visibleAreaRect.width,\n        height: visibleAreaRect.height\n      }\n    },\n    getSettings: settings.getSettings,\n    setSettings: (data: Parameters<typeof settings.setSettings>[0]) => settings.setSettings(data, {\n      hasVerticalWritingSubject: hasVerticalWritingSubject$.value,\n      manifest\n    }),\n    $: {\n      hasVerticalWriting$: hasVerticalWritingSubject$\n        .asObservable()\n        .pipe(distinctUntilChanged()),\n      destroy$: destroy$\n        .asObservable(),\n      settings$: settings.$.settings$,\n      load$: loadSubject$\n        .asObservable()\n    }\n  }\n}\n\nexport type Context = ReturnType<typeof createContext>\n\nconst areAllItemsPrePaginated = (manifest: Manifest | undefined) => !manifest?.spineItems.some(item => item.renditionLayout === `reflowable`)\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/context.ts\n");
|
|
40
|
+
|
|
41
|
+
/***/ }),
|
|
42
|
+
|
|
43
|
+
/***/ "./src/createReaderWithEnhancer.ts":
|
|
44
|
+
/*!*****************************************!*\
|
|
45
|
+
!*** ./src/createReaderWithEnhancer.ts ***!
|
|
46
|
+
\*****************************************/
|
|
47
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
48
|
+
|
|
49
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createReaderWithEnhancer\": () => (/* binding */ createReaderWithEnhancer)\n/* harmony export */ });\n/* harmony import */ var _enhancers_chrome__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./enhancers/chrome */ \"./src/enhancers/chrome.ts\");\n/* harmony import */ var _enhancers_fonts__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./enhancers/fonts */ \"./src/enhancers/fonts.ts\");\n/* harmony import */ var _enhancers_hotkeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./enhancers/hotkeys */ \"./src/enhancers/hotkeys.ts\");\n/* harmony import */ var _enhancers_layoutEnhancer_layoutEnhancer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./enhancers/layoutEnhancer/layoutEnhancer */ \"./src/enhancers/layoutEnhancer/layoutEnhancer.ts\");\n/* harmony import */ var _enhancers_links__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./enhancers/links */ \"./src/enhancers/links.ts\");\n/* harmony import */ var _enhancers_navigation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./enhancers/navigation */ \"./src/enhancers/navigation.ts\");\n/* harmony import */ var _enhancers_pagination__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./enhancers/pagination */ \"./src/enhancers/pagination.ts\");\n/* harmony import */ var _enhancers_theme__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./enhancers/theme */ \"./src/enhancers/theme.ts\");\n/* harmony import */ var _enhancers_composeEnhancer__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./enhancers/composeEnhancer */ \"./src/enhancers/composeEnhancer.ts\");\n/* harmony import */ var _enhancers_zoom__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./enhancers/zoom */ \"./src/enhancers/zoom.ts\");\n/* harmony import */ var _reader__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./reader */ \"./src/reader.ts\");\n/* harmony import */ var _enhancers_utils__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./enhancers/utils */ \"./src/enhancers/utils.ts\");\n/* harmony import */ var _enhancers_resources__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./enhancers/resources */ \"./src/enhancers/resources/index.ts\");\n/* harmony import */ var _enhancers_media__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./enhancers/media */ \"./src/enhancers/media.ts\");\n/* harmony import */ var _enhancers_progression__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./enhancers/progression */ \"./src/enhancers/progression.ts\");\n/* harmony import */ var _enhancers_accessibility__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./enhancers/accessibility */ \"./src/enhancers/accessibility.ts\");\n/* harmony import */ var _enhancers_webkit__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./enhancers/webkit */ \"./src/enhancers/webkit.ts\");\nvar __rest = (undefined && undefined.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst withPublicApiOnly = (reader) => {\n const { context, manipulateContainer, manipulateSpineItems, getFocusedSpineItemIndex, getCurrentNavigationPosition, getSpineItem, locator, getAbsolutePositionOf, generateCfi, resolveCfi, getCfiMetaInformation, spine } = reader, exposedReader = __rest(reader, [\"context\", \"manipulateContainer\", \"manipulateSpineItems\", \"getFocusedSpineItemIndex\", \"getCurrentNavigationPosition\", \"getSpineItem\", \"locator\", \"getAbsolutePositionOf\", \"generateCfi\", \"resolveCfi\", \"getCfiMetaInformation\", \"spine\"]);\n return exposedReader;\n};\nconst internalEnhancer = (0,_enhancers_composeEnhancer__WEBPACK_IMPORTED_MODULE_8__.composeEnhancer)(_enhancers_progression__WEBPACK_IMPORTED_MODULE_14__.progressionEnhancer, _enhancers_pagination__WEBPACK_IMPORTED_MODULE_6__.paginationEnhancer, _enhancers_hotkeys__WEBPACK_IMPORTED_MODULE_2__.hotkeysEnhancer, _enhancers_theme__WEBPACK_IMPORTED_MODULE_7__.themeEnhancer, _enhancers_navigation__WEBPACK_IMPORTED_MODULE_5__.navigationEnhancer, _enhancers_chrome__WEBPACK_IMPORTED_MODULE_0__.chromeEnhancer, _enhancers_media__WEBPACK_IMPORTED_MODULE_13__.mediaEnhancer, _enhancers_zoom__WEBPACK_IMPORTED_MODULE_9__.zoomEnhancer, _enhancers_layoutEnhancer_layoutEnhancer__WEBPACK_IMPORTED_MODULE_3__.layoutEnhancer, _enhancers_utils__WEBPACK_IMPORTED_MODULE_11__.utilsEnhancer, _enhancers_resources__WEBPACK_IMPORTED_MODULE_12__.resourcesEnhancer, _enhancers_accessibility__WEBPACK_IMPORTED_MODULE_15__.accessibilityEnhancer, _enhancers_links__WEBPACK_IMPORTED_MODULE_4__.linksEnhancer, _enhancers_fonts__WEBPACK_IMPORTED_MODULE_1__.fontsEnhancer, _enhancers_webkit__WEBPACK_IMPORTED_MODULE_16__.webkitEnhancer);\nfunction createReaderWithEnhancer(options, enhancer) {\n if (!enhancer) {\n const enhancedCreateReader = internalEnhancer(_reader__WEBPACK_IMPORTED_MODULE_10__.createReader);\n return withPublicApiOnly(enhancedCreateReader(options));\n }\n const finalEnhancer = (0,_enhancers_composeEnhancer__WEBPACK_IMPORTED_MODULE_8__.composeEnhancer)(internalEnhancer, enhancer);\n const enhancedCreateReader = finalEnhancer(_reader__WEBPACK_IMPORTED_MODULE_10__.createReader);\n return withPublicApiOnly(enhancedCreateReader(options));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY3JlYXRlUmVhZGVyV2l0aEVuaGFuY2VyLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQW1EO0FBQ0Y7QUFDSTtBQUNxQjtBQUN6QjtBQUNVO0FBQ0E7QUFDVjtBQUNpRDtBQUVuRDtBQUMyQztBQUN6QztBQUNRO0FBQ1I7QUFDWTtBQUNJO0FBQ2Q7QUFRbkQsTUFBTSxpQkFBaUIsR0FBRyxDQUFzRCxNQUFXLEVBQUUsRUFBRTtJQUM3RixNQUFNLEVBQ0osT0FBTyxFQUVQLG1CQUFtQixFQUNuQixvQkFBb0IsRUFDcEIsd0JBQXdCLEVBQ3hCLDRCQUE0QixFQUM1QixZQUFZLEVBQ1osT0FBTyxFQUNQLHFCQUFxQixFQUNyQixXQUFXLEVBQ1gsVUFBVSxFQUNWLHFCQUFxQixFQUNyQixLQUFLLEtBRUgsTUFBTSxFQURMLGFBQWEsVUFDZCxNQUFNLEVBZkoseU9BZUwsQ0FBUztJQUVWLE9BQU8sYUFBYTtBQUN0QixDQUFDO0FBS0QsTUFBTSxnQkFBZ0IsR0FBRywyRUFBZSxDQUN0Qyx3RUFBbUIsRUFFakIscUVBQWtCLEVBQ2xCLCtEQUFlLEVBQ2YsMkRBQWEsRUFDYixxRUFBa0IsRUFDbEIsNkRBQWMsRUFDZCw0REFBYSxFQUNiLHlEQUFZLEVBQ1osb0ZBQWMsRUFDZCw0REFBYSxFQUNiLG9FQUFpQixFQUNqQiw0RUFBcUIsRUFDckIsMkRBQWEsRUFDYiwyREFBYSxFQUNiLDhEQUFjLENBQ2pCO0FBaUNNLFNBQVMsd0JBQXdCLENBQ3RDLE9BQXNFLEVBQ3RFLFFBQXVCO0lBRXZCLElBQUksQ0FBQyxRQUFRLEVBQUU7UUFDYixNQUFNLG9CQUFvQixHQUFHLGdCQUFnQixDQUFDLGtEQUFvQixDQUFDO1FBRW5FLE9BQU8saUJBQWlCLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLENBQUM7S0FDeEQ7SUFFRCxNQUFNLGFBQWEsR0FBRywyRUFBZSxDQUFDLGdCQUFnQixFQUFFLFFBQVEsQ0FBQztJQUdqRSxNQUFNLG9CQUFvQixHQUFHLGFBQWEsQ0FBQyxrREFBb0IsQ0FBQztJQVFoRSxPQUFPLGlCQUFpQixDQUFDLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQ3pELENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvY3JlYXRlUmVhZGVyV2l0aEVuaGFuY2VyLnRzP2Y3MWYiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY2hyb21lRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9jaHJvbWUnXG5pbXBvcnQgeyBmb250c0VuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvZm9udHMnXG5pbXBvcnQgeyBob3RrZXlzRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9ob3RrZXlzJ1xuaW1wb3J0IHsgbGF5b3V0RW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9sYXlvdXRFbmhhbmNlci9sYXlvdXRFbmhhbmNlcidcbmltcG9ydCB7IGxpbmtzRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9saW5rcydcbmltcG9ydCB7IG5hdmlnYXRpb25FbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL25hdmlnYXRpb24nXG5pbXBvcnQgeyBwYWdpbmF0aW9uRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9wYWdpbmF0aW9uJ1xuaW1wb3J0IHsgdGhlbWVFbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL3RoZW1lJ1xuaW1wb3J0IHsgQ29tcG9zYWJsZUVuaGFuY2VyLCBDb21wb3NlRW5oYW5jZXIsIGNvbXBvc2VFbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL2NvbXBvc2VFbmhhbmNlcidcbmltcG9ydCB7IEVuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvdHlwZXMnXG5pbXBvcnQgeyB6b29tRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy96b29tJ1xuaW1wb3J0IHsgY3JlYXRlUmVhZGVyIGFzIGNyZWF0ZUludGVybmFsUmVhZGVyLCBSZWFkZXIgYXMgUmVhZGVyUHVibGljQXBpIH0gZnJvbSAnLi9yZWFkZXInXG5pbXBvcnQgeyB1dGlsc0VuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvdXRpbHMnXG5pbXBvcnQgeyByZXNvdXJjZXNFbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL3Jlc291cmNlcydcbmltcG9ydCB7IG1lZGlhRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9tZWRpYSdcbmltcG9ydCB7IHByb2dyZXNzaW9uRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy9wcm9ncmVzc2lvbidcbmltcG9ydCB7IGFjY2Vzc2liaWxpdHlFbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL2FjY2Vzc2liaWxpdHknXG5pbXBvcnQgeyB3ZWJraXRFbmhhbmNlciB9IGZyb20gJy4vZW5oYW5jZXJzL3dlYmtpdCdcbmltcG9ydCB7IEFub255bW91c1N1YmplY3QgfSBmcm9tICdyeGpzL2ludGVybmFsL1N1YmplY3QnXG5cbi8qKlxuICogT25seSBleHBvc2UgYSBzdWJzZXQgb2YgcmVhZGVyIEFQSSBpbiBvcmRlciB0byBwcm90ZWN0IGFnYWluc3RcbiAqIHdyb25nIG1hbmlwdWxhdGlvbi5cbiAqIFRvIGFjY2VzcyB0aGUgZXh0ZW5kZWQgQVBJLCBjcmVhdGUgYW4gZW5oYW5jZXIuXG4gKi9cbmNvbnN0IHdpdGhQdWJsaWNBcGlPbmx5ID0gPEFwaSBleHRlbmRzIHsgW2tleSBpbiBrZXlvZiBSZWFkZXJQdWJsaWNBcGldOiBhbnkgfT4ocmVhZGVyOiBBcGkpID0+IHtcbiAgY29uc3Qge1xuICAgIGNvbnRleHQsXG4gICAgLy8gaW5uZXJQYWdpbmF0aW9uLFxuICAgIG1hbmlwdWxhdGVDb250YWluZXIsXG4gICAgbWFuaXB1bGF0ZVNwaW5lSXRlbXMsXG4gICAgZ2V0Rm9jdXNlZFNwaW5lSXRlbUluZGV4LFxuICAgIGdldEN1cnJlbnROYXZpZ2F0aW9uUG9zaXRpb24sXG4gICAgZ2V0U3BpbmVJdGVtLFxuICAgIGxvY2F0b3IsXG4gICAgZ2V0QWJzb2x1dGVQb3NpdGlvbk9mLFxuICAgIGdlbmVyYXRlQ2ZpLFxuICAgIHJlc29sdmVDZmksXG4gICAgZ2V0Q2ZpTWV0YUluZm9ybWF0aW9uLFxuICAgIHNwaW5lLFxuICAgIC4uLmV4cG9zZWRSZWFkZXJcbiAgfSA9IHJlYWRlclxuXG4gIHJldHVybiBleHBvc2VkUmVhZGVyXG59XG5cbnR5cGUgUmVhZGVyUHVibGljQXBpV2l0aFNhZmVFeHBvc2VkS2V5cyA9IFJldHVyblR5cGU8dHlwZW9mIHdpdGhQdWJsaWNBcGlPbmx5PlxudHlwZSBSZW1vdmVkS2V5c09ubHkgPSBrZXlvZiBPbWl0PFJlYWRlclB1YmxpY0FwaSwga2V5b2YgUmVhZGVyUHVibGljQXBpV2l0aFNhZmVFeHBvc2VkS2V5cz5cblxuY29uc3QgaW50ZXJuYWxFbmhhbmNlciA9IGNvbXBvc2VFbmhhbmNlcihcbiAgcHJvZ3Jlc3Npb25FbmhhbmNlclxuICAvLyBAcmVxdWlyZXMgcHJvZ3Jlc3Npb25FbmhhbmNlclxuICAsIHBhZ2luYXRpb25FbmhhbmNlclxuICAsIGhvdGtleXNFbmhhbmNlclxuICAsIHRoZW1lRW5oYW5jZXJcbiAgLCBuYXZpZ2F0aW9uRW5oYW5jZXJcbiAgLCBjaHJvbWVFbmhhbmNlclxuICAsIG1lZGlhRW5oYW5jZXJcbiAgLCB6b29tRW5oYW5jZXJcbiAgLCBsYXlvdXRFbmhhbmNlclxuICAsIHV0aWxzRW5oYW5jZXJcbiAgLCByZXNvdXJjZXNFbmhhbmNlclxuICAsIGFjY2Vzc2liaWxpdHlFbmhhbmNlclxuICAsIGxpbmtzRW5oYW5jZXJcbiAgLCBmb250c0VuaGFuY2VyXG4gICwgd2Via2l0RW5oYW5jZXJcbilcblxudHlwZSBXaXRob3V0UHJpdmF0ZUFwaTxFPiA9IE9taXQ8RSwgUmVtb3ZlZEtleXNPbmx5IHwgYF9fZGVidWdgIHwgYF9fQVBJYCB8IGBfX091dHB1dFNldHRpbmdzYD5cbnR5cGUgRW5oYW5jZXJPcHRpb25zPEUgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBhbnk+ID0gUGFyYW1ldGVyczxSZXR1cm5UeXBlPEU+PlswXVxudHlwZSBFbmhhbmNlckV4cG9zZWRBcGk8RSBleHRlbmRzICguLi5hcmdzOiBhbnkpID0+IGFueT4gPSBSZXR1cm5UeXBlPFJldHVyblR5cGU8RT4+XG5cbmV4cG9ydCB0eXBlIENvcmVFbmhhbmNlciA9IHR5cGVvZiBpbnRlcm5hbEVuaGFuY2VyXG5cbmV4cG9ydCB0eXBlIENvcmVFbmhhbmNlckRlcGVuZHNPbiA9IChjcmVhdGVSZWFkZXI6IFBhcmFtZXRlcnM8Q29yZUVuaGFuY2VyPlswXSkgPT4gKG9wdGlvbnM6IEVuaGFuY2VyT3B0aW9uczxDb3JlRW5oYW5jZXI+KSA9PiBFbmhhbmNlckV4cG9zZWRBcGk8Q29yZUVuaGFuY2VyPlxuXG5leHBvcnQgdHlwZSBFeHRlcm5hbEVuaGFuY2VyPFxuICBPcHRpb25zID0ge30sXG4gIEFwaSA9IHt9LFxuICBTZXR0aW5ncyA9IHt9LFxuICBPdXRwdXRTZXR0aW5ncyA9IFNldHRpbmdzLFxuICBEZXBlbmRzT24gZXh0ZW5kcyAoY3JlYXRlUmVhZGVyOiBhbnkpID0+IChvcHRpb25zOiBhbnkpID0+IGFueSA9IENvcmVFbmhhbmNlckRlcGVuZHNPblxuICA+ID0gRW5oYW5jZXI8XG4gICAgT3B0aW9ucyxcbiAgICBBcGksXG4gICAgU2V0dGluZ3MsXG4gICAgT3V0cHV0U2V0dGluZ3MsXG4gICAgRGVwZW5kc09uXG4gID5cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlYWRlcldpdGhFbmhhbmNlcihcbiAgb3B0aW9uczogRW5oYW5jZXJPcHRpb25zPENvcmVFbmhhbmNlcj5cbik6IFdpdGhvdXRQcml2YXRlQXBpPEVuaGFuY2VyRXhwb3NlZEFwaTxDb3JlRW5oYW5jZXI+PlxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVhZGVyV2l0aEVuaGFuY2VyPFVzZXJFbmhhbmNlciBleHRlbmRzIENvbXBvc2FibGVFbmhhbmNlcj4oXG4gIG9wdGlvbnM6IEVuaGFuY2VyT3B0aW9uczxVc2VyRW5oYW5jZXI+ICYgRW5oYW5jZXJPcHRpb25zPENvcmVFbmhhbmNlcj4sXG4gIGVuaGFuY2VyOiBVc2VyRW5oYW5jZXJcbik6IFdpdGhvdXRQcml2YXRlQXBpPEVuaGFuY2VyRXhwb3NlZEFwaTxDb21wb3NlRW5oYW5jZXI8dHlwZW9mIGludGVybmFsRW5oYW5jZXIsIFVzZXJFbmhhbmNlcj4+PlxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVhZGVyV2l0aEVuaGFuY2VyPFVzZXJFbmhhbmNlciBleHRlbmRzIENvbXBvc2FibGVFbmhhbmNlcj4gKFxuICBvcHRpb25zOiBFbmhhbmNlck9wdGlvbnM8VXNlckVuaGFuY2VyPiAmIEVuaGFuY2VyT3B0aW9uczxDb3JlRW5oYW5jZXI+LFxuICBlbmhhbmNlcj86IFVzZXJFbmhhbmNlclxuKSB7XG4gIGlmICghZW5oYW5jZXIpIHtcbiAgICBjb25zdCBlbmhhbmNlZENyZWF0ZVJlYWRlciA9IGludGVybmFsRW5oYW5jZXIoY3JlYXRlSW50ZXJuYWxSZWFkZXIpXG5cbiAgICByZXR1cm4gd2l0aFB1YmxpY0FwaU9ubHkoZW5oYW5jZWRDcmVhdGVSZWFkZXIob3B0aW9ucykpXG4gIH1cblxuICBjb25zdCBmaW5hbEVuaGFuY2VyID0gY29tcG9zZUVuaGFuY2VyKGludGVybmFsRW5oYW5jZXIsIGVuaGFuY2VyKVxuICAvLyBjb25zdCBmaW5hbEVuaGFuY2VyID0gY29tcG9zZUVuaGFuY2VyKGVuaGFuY2VyKVxuICAvLyBjb25zdCBmaW5hbEVuaGFuY2VyID0gY29tcG9zZUVuaGFuY2VyKGVuaGFuY2VyLCBpbnRlcm5hbEVuaGFuY2VyKVxuICBjb25zdCBlbmhhbmNlZENyZWF0ZVJlYWRlciA9IGZpbmFsRW5oYW5jZXIoY3JlYXRlSW50ZXJuYWxSZWFkZXIpXG5cbiAgLy8gZW5oYW5jZXIoY3JlYXRlSW50ZXJuYWxSZWFkZXIgYXMgYW55KShvcHRpb25zKS5cbiAgLy8gaW50ZXJuYWxFbmhhbmNlcihjcmVhdGVJbnRlcm5hbFJlYWRlcikob3B0aW9ucykuJC5wYWdpbmF0aW9uJFxuICAvLyBpbnRlcm5hbEVuaGFuY2VyKGNyZWF0ZUludGVybmFsUmVhZGVyKShvcHRpb25zKS5fX0FQSSEuJC5wYWdpbmF0aW9uJFxuICAvLyBmaW5hbEVuaGFuY2VyKGNyZWF0ZUludGVybmFsUmVhZGVyKShvcHRpb25zKS5cbiAgLy8gY29uc3QgcyA9IGZpbmFsRW5oYW5jZXIoY3JlYXRlSW50ZXJuYWxSZWFkZXIpKG9wdGlvbnMpLl9fQVBJXG4gIC8vIHMhLlxuICByZXR1cm4gd2l0aFB1YmxpY0FwaU9ubHkoZW5oYW5jZWRDcmVhdGVSZWFkZXIob3B0aW9ucykpXG59XG5cbmV4cG9ydCB0eXBlIFJlYWRlcjxFIGV4dGVuZHMgQ29tcG9zYWJsZUVuaGFuY2VyIHwgdm9pZCA9IHZvaWQ+ID0gRSBleHRlbmRzIENvbXBvc2FibGVFbmhhbmNlclxuICA/IFdpdGhvdXRQcml2YXRlQXBpPEVuaGFuY2VyRXhwb3NlZEFwaTxDb21wb3NlRW5oYW5jZXI8Q29yZUVuaGFuY2VyLCBFPj4+XG4gIDogV2l0aG91dFByaXZhdGVBcGk8RW5oYW5jZXJFeHBvc2VkQXBpPENvcmVFbmhhbmNlcj4+XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/createReaderWithEnhancer.ts\n");
|
|
50
|
+
|
|
51
|
+
/***/ }),
|
|
52
|
+
|
|
53
|
+
/***/ "./src/enhancers/accessibility.ts":
|
|
54
|
+
/*!****************************************!*\
|
|
55
|
+
!*** ./src/enhancers/accessibility.ts ***!
|
|
56
|
+
\****************************************/
|
|
57
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
58
|
+
|
|
59
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"accessibilityEnhancer\": () => (/* binding */ accessibilityEnhancer)\n/* harmony export */ });\nconst accessibilityEnhancer = (next) => (options) => {\n const reader = next(options);\n const observer = new IntersectionObserver((entries) => {\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n entry.target.removeAttribute(`tab-index`);\n }\n else {\n entry.target.setAttribute(`tab-index`, `-1`);\n }\n });\n }, {});\n reader.registerHook(`item.onLoad`, ({ addStyle, frame }) => {\n var _a;\n addStyle(`prose-reader-accessibility`, `\n :focus-visible {\n ${``}\n outline: -webkit-focus-ring-color auto 1px;\n }\n `);\n const links = (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.body.querySelectorAll(`a`);\n links === null || links === void 0 ? void 0 : links.forEach(link => {\n observer.observe(link);\n });\n return () => {\n links === null || links === void 0 ? void 0 : links.forEach(link => {\n observer.unobserve(link);\n });\n };\n });\n return Object.assign({}, reader);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL2FjY2Vzc2liaWxpdHkudHMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUtPLE1BQU0scUJBQXFCLEdBRTdCLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO0lBQ3pCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7SUFFNUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxvQkFBb0IsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO1FBQ3BELE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDdEIsSUFBSSxLQUFLLENBQUMsY0FBYyxFQUFFO2dCQUN4QixLQUFLLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxXQUFXLENBQUM7YUFDMUM7aUJBQU07Z0JBQ0wsS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQzthQUM3QztRQUNILENBQUMsQ0FBQztJQUNKLENBQUMsRUFBRSxFQUNGLENBQUM7SUFFRixNQUFNLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUU7O1FBQ3pELFFBQVEsQ0FBQyw0QkFBNEIsRUFBRTs7VUFLakMsRUFBRTs7O0tBR1AsQ0FBQztRQUVGLE1BQU0sS0FBSyxHQUFHLFdBQUssQ0FBQyxlQUFlLDBDQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUM7UUFFL0QsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNwQixRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztRQUN4QixDQUFDLENBQUM7UUFFRixPQUFPLEdBQUcsRUFBRTtZQUNWLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ3BCLFFBQVEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO1lBQzFCLENBQUMsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDLENBQUM7SUFFRix5QkFDSyxNQUFNLEVBQ1Y7QUFDSCxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL2VuaGFuY2Vycy9hY2Nlc3NpYmlsaXR5LnRzPzRjMzAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRW5oYW5jZXIgfSBmcm9tIFwiLi90eXBlc1wiXG5cbi8qKlxuICpcbiAqL1xuZXhwb3J0IGNvbnN0IGFjY2Vzc2liaWxpdHlFbmhhbmNlcjogRW5oYW5jZXI8e30sIHtcblxufT4gPSAobmV4dCkgPT4gKG9wdGlvbnMpID0+IHtcbiAgY29uc3QgcmVhZGVyID0gbmV4dChvcHRpb25zKVxuXG4gIGNvbnN0IG9ic2VydmVyID0gbmV3IEludGVyc2VjdGlvbk9ic2VydmVyKChlbnRyaWVzKSA9PiB7XG4gICAgZW50cmllcy5mb3JFYWNoKGVudHJ5ID0+IHtcbiAgICAgIGlmIChlbnRyeS5pc0ludGVyc2VjdGluZykge1xuICAgICAgICBlbnRyeS50YXJnZXQucmVtb3ZlQXR0cmlidXRlKGB0YWItaW5kZXhgKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZW50cnkudGFyZ2V0LnNldEF0dHJpYnV0ZShgdGFiLWluZGV4YCwgYC0xYClcbiAgICAgIH1cbiAgICB9KVxuICB9LCB7XG4gIH0pXG5cbiAgcmVhZGVyLnJlZ2lzdGVySG9vayhgaXRlbS5vbkxvYWRgLCAoeyBhZGRTdHlsZSwgZnJhbWUgfSkgPT4ge1xuICAgIGFkZFN0eWxlKGBwcm9zZS1yZWFkZXItYWNjZXNzaWJpbGl0eWAsIGBcbiAgICAgIDpmb2N1cy12aXNpYmxlIHtcbiAgICAgICAgJHsvKlxuICAgICAgICAgIFNvbWUgZXB1YnMgcmVtb3ZlIHRoZSBvdXRsaW5lLCB0aGlzIGlzIG5vdCBnb29kIHByYWN0aWNlIHNpbmNlIGl0IHJlZHVjZSBhY2Nlc3NpYmlsaXR5LlxuICAgICAgICAgIFdlIHdpbGwgdHJ5IHRvIHJlc3RvcmUgaXQgYnkgZm9yY2UuXG4gICAgICAgICovYGB9XG4gICAgICAgIG91dGxpbmU6IC13ZWJraXQtZm9jdXMtcmluZy1jb2xvciBhdXRvIDFweDtcbiAgICAgIH1cbiAgICBgKVxuXG4gICAgY29uc3QgbGlua3MgPSBmcmFtZS5jb250ZW50RG9jdW1lbnQ/LmJvZHkucXVlcnlTZWxlY3RvckFsbChgYWApXG5cbiAgICBsaW5rcz8uZm9yRWFjaChsaW5rID0+IHtcbiAgICAgIG9ic2VydmVyLm9ic2VydmUobGluaylcbiAgICB9KVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGxpbmtzPy5mb3JFYWNoKGxpbmsgPT4ge1xuICAgICAgICBvYnNlcnZlci51bm9ic2VydmUobGluaylcbiAgICAgIH0pXG4gICAgfVxuICB9KVxuXG4gIHJldHVybiB7XG4gICAgLi4ucmVhZGVyXG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/enhancers/accessibility.ts\n");
|
|
60
|
+
|
|
61
|
+
/***/ }),
|
|
62
|
+
|
|
63
|
+
/***/ "./src/enhancers/chrome.ts":
|
|
64
|
+
/*!*********************************!*\
|
|
65
|
+
!*** ./src/enhancers/chrome.ts ***!
|
|
66
|
+
\*********************************/
|
|
67
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
68
|
+
|
|
69
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"chromeEnhancer\": () => (/* binding */ chromeEnhancer)\n/* harmony export */ });\nconst SHOULD_NOT_LAYOUT = false;\nconst chromeEnhancer = (next) => (options) => {\n const reader = next(options);\n reader.manipulateContainer((container) => {\n const onScroll = () => {\n if (reader.context.getSettings().computedPageTurnMode === `controlled`) {\n container.scrollTo(0, 0);\n }\n };\n container.addEventListener(`scroll`, onScroll);\n return SHOULD_NOT_LAYOUT;\n });\n reader.registerHook(`item.onLoad`, ({ frame }) => {\n var _a;\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.body.setAttribute(`tabindex`, `-1`);\n });\n return reader;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL2Nocm9tZS50cy5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBRUEsTUFBTSxpQkFBaUIsR0FBRyxLQUFLO0FBS3hCLE1BQU0sY0FBYyxHQUV0QixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtJQUN6QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBMEI1QixNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtRQUN2QyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7WUFDcEIsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLG9CQUFvQixLQUFLLFlBQVksRUFBRTtnQkFDdEUsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO2FBQ3pCO1FBQ0gsQ0FBQztRQU9ELFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDO1FBYzlDLE9BQU8saUJBQWlCO0lBQzFCLENBQUMsQ0FBQztJQUVGLE1BQU0sQ0FBQyxZQUFZLENBQUMsYUFBYSxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFOztRQU0vQyxXQUFLLENBQUMsZUFBZSwwQ0FBRSxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUM7SUFDNUQsQ0FBQyxDQUFDO0lBaUJGLE9BQU8sTUFBTTtBQUNmLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL2Nocm9tZS50cz8zMWYwIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVuaGFuY2VyIH0gZnJvbSBcIi4vdHlwZXNcIlxuXG5jb25zdCBTSE9VTERfTk9UX0xBWU9VVCA9IGZhbHNlXG5cbi8qKlxuICogQWxsIGZpeGVzIHJlbGF0aXZlIHRvIGNocm9tZXNcbiAqL1xuZXhwb3J0IGNvbnN0IGNocm9tZUVuaGFuY2VyOiBFbmhhbmNlcjx7fSwge1xuXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG5cbiAgLyoqXG4gICAqIFRoaXMgZWxlbWVudCBpcyB1c2VkIHRvIGZvcmNlIGEgcmVmcmVzaCBvZiBhIHNjcmVlbiBpbiBvcmRlciB0byBmaXggdGhlXG4gICAqIGZyb3plbiBzY3JlZW4gdGhhdCBoYXBwZW5zIHdpdGggY2hyb21lLlxuICAgKiBUaGUgYnVnIGlzIHdlaXJkIGFuZCBJIGhhdmUgeWV0IHRvIGV4cGxhaW4gaXQgY29ycmVjdGx5LCB3aGF0IGhhcHBlbnNcbiAgICogaXMgdGhhdCBzb21ldGltZSB3aGVuIG1vdmluZyB0aGUgeC1heGlzIG9uIG5hdmlnYXRpb24sIHRoZSBzY3JlZW4gd2lsbCBzdGlsbCBkaXNwbGF5XG4gICAqIHRoZSBvbGQgc2NyZWVuLCBhcyBpZiBpdCB3YXMgZnJvemVuLiBHZW5lcmFsbHkgYW55IGludGVyYWN0aW9uIHdpdGggdGhlIHBhZ2Ugd2lsbCB1bmZyZWV6ZVxuICAgKiB0aGUgc2NyZWVuIGFuZCB0aGUgbmV3IGlmcmFtZSB3aWxsIGJlIGRpc3BsYXllZC4gSXQgYWxzbyBoYXBwZW5zIHdpdGhpbiB0aGUgc2FtZSBpZnJhbWUuXG4gICAqIFNvIGZhciBpdCBzZWVtcyB0byBiZSBkdWUgdG8gc2NhbGluZyBhbmQgeC1heGlzIG1vdmluZy5cbiAgICogVG8gZW5zdXJlIHRoZSBzY3JlZW4gZG9lcyBub3QgZnJlZXplIHdlIGFyZSBtb3ZpbmcgYSAxOjEgc3F1YXJlIGluICYgb3V0IG9mIHRoZSBzY3JlZW4uXG4gICAqIFRoYXQgd2F5IGNocm9tZSBpcyBcImZvcmNlZFwiIHRvIHJlZnJlc2ggdGhlIHNjcmVlbi5cbiAgICpcbiAgICogQHRvZG9cbiAgICogY2hlY2sgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL3dpbGwtY2hhbmdlIHdpdGggd2lsbC1jaGFuZ2U6IHRyYW5zZm9ybVxuICAgKiB0byBzZWUgaWYgaXQgZG9lcyByZWZyZXNoIGFsbCB0aGUgdGltZSBpdHNlbGYuXG4gICAqXG4gICAqIEB0b2RvXG4gICAqIHVzZSB0cmFuc2Zvcm0gYW5kIHRyYW5zbGF0ZSByYXRoZXIgdGhhbiBjaGFuZ2luZyB0b3Agc28gaXQgb25seSBhZmZlY3QgY29tcG9zaXRlIGxheWVyIHJhdGhlciB0aGFuIHBhaW50XG4gICAqIEBzZWUgaHR0cHM6Ly93d3cuYWxnb2xpYS5jb20vYmxvZy9lbmdpbmVlcmluZy9wZXJmb3JtYW50LXdlYi1hbmltYXRpb25zL1xuICAgKlxuICAgKiBAaW1wb3J0YW50XG4gICAqIFRoaXMgaXMgZGlzYWJsZWQgZm9yIG5vdyBhcyByZW1vdmluZyB3aWxsLWNoYW5nZSBvbiBjb250YWluZXIgc2VlbXMgdG8gZml4IHRoZSBpc3N1ZVxuICAgKi9cbiAgLy8gbGV0IHNjcmVlbkZvcmNlUmVmcmVzaEVsdDogSFRNTERpdkVsZW1lbnQgfCB1bmRlZmluZWQgPSB1bmRlZmluZWRcblxuICByZWFkZXIubWFuaXB1bGF0ZUNvbnRhaW5lcigoY29udGFpbmVyKSA9PiB7XG4gICAgY29uc3Qgb25TY3JvbGwgPSAoKSA9PiB7XG4gICAgICBpZiAocmVhZGVyLmNvbnRleHQuZ2V0U2V0dGluZ3MoKS5jb21wdXRlZFBhZ2VUdXJuTW9kZSA9PT0gYGNvbnRyb2xsZWRgKSB7XG4gICAgICAgIGNvbnRhaW5lci5zY3JvbGxUbygwLCAwKVxuICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEZvciBzb21lIHJlYXNvbiBJIGhhdmUgeWV0IHRvIGZpbmQsIGNocm9tZSB3aWxsIGZvcmNlIHNjcm9sbCB4LWF4aXMgb24gdGhlIGNvbnRhaW5lclxuICAgICAqIHdoZW5ldmVyIHRoZSB1c2VyIHNlbGVjdCB0ZXh0IGFuZCBkcmFnIGl0IHRvIHRoZSBlZGdlcy4gVGhpcyBpcyBub3QgYSBzY3JvbGwgaW5zaWRlIHRoZSBpZnJhbWVcbiAgICAgKiBidXQgYSBzY3JvbGwgb24gdGhlIGNvbnRhaW5lciBpdHNlbGYuLlxuICAgICAqL1xuICAgIGNvbnRhaW5lci5hZGRFdmVudExpc3RlbmVyKGBzY3JvbGxgLCBvblNjcm9sbClcblxuICAgIC8vIHNjcmVlbkZvcmNlUmVmcmVzaEVsdCA9IGNvbnRhaW5lci5vd25lckRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2RpdicpXG4gICAgLy8gc2NyZWVuRm9yY2VSZWZyZXNoRWx0LnN0eWxlLmNzc1RleHQgPSBgXG4gICAgLy8gICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgLy8gICBiYWNrZ3JvdW5kLWNvbG9yOiBibGFjaztcbiAgICAvLyAgIGxlZnQ6IDA7XG4gICAgLy8gICB0b3A6IC0xcHg7XG4gICAgLy8gICB3aWR0aDogMXB4O1xuICAgIC8vICAgaGVpZ2h0OiAxcHg7XG4gICAgLy8gYFxuXG4gICAgLy8gY29udGFpbmVyLmFwcGVuZENoaWxkKHNjcmVlbkZvcmNlUmVmcmVzaEVsdClcblxuICAgIHJldHVybiBTSE9VTERfTk9UX0xBWU9VVFxuICB9KVxuXG4gIHJlYWRlci5yZWdpc3Rlckhvb2soYGl0ZW0ub25Mb2FkYCwgKHsgZnJhbWUgfSkgPT4ge1xuICAgIC8qKlxuICAgICAqIERpc2FibGUgdG91Y2ggdG8gc2VhcmNoIG9uIGZpcnN0IHRleHQgdG91Y2ggLyBjbGljay4gVGhpcyBkb2VzIG5vdCBwcmV2ZW50XG4gICAgICogaXQgd2hlbiBzZWxlY3RpbmcgdGV4dC4gSXQgbmVlZHMgdG8gYmUgdHVybmVkIG9mZiBieSB0aGUgdXNlci5cbiAgICAgKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVycy5nb29nbGUuY29tL3dlYi91cGRhdGVzLzIwMTUvMTAvdGFwLXRvLXNlYXJjaFxuICAgICAqL1xuICAgIGZyYW1lLmNvbnRlbnREb2N1bWVudD8uYm9keS5zZXRBdHRyaWJ1dGUoYHRhYmluZGV4YCwgYC0xYClcbiAgfSlcblxuICAvLyBjb25zdCBmb3JjZVNjcmVlblJlZnJlc2gkID0gcmVhZGVyLiQuJFxuICAvLyAgIC5waXBlKFxuICAvLyAgICAgLy8gZmlsdGVyKGV2ZW50ID0+IGV2ZW50LnR5cGUgPT09IGBvbk5hdmlnYXRpb25DaGFuZ2VgKSxcbiAgLy8gICAgIHRhcCgoKSA9PiB7XG4gIC8vICAgICAgIC8vIHNjcmVlbkZvcmNlUmVmcmVzaEVsdD8uc3R5bGUuc2V0UHJvcGVydHkoYHRvcGAsIGAwcHhgKVxuICAvLyAgICAgICAvLyByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAvLyAgICAgICAvLyAgIHNjcmVlbkZvcmNlUmVmcmVzaEVsdD8uc3R5bGUuc2V0UHJvcGVydHkoYHRvcGAsIGAtMXB4YClcbiAgLy8gICAgICAgLy8gfSlcbiAgLy8gICAgIH0pXG4gIC8vICAgKVxuXG4gIC8vIG1lcmdlKGZvcmNlU2NyZWVuUmVmcmVzaCQpXG4gIC8vICAgLnBpcGUodGFrZVVudGlsKHJlYWRlci4kLmRlc3Ryb3kkKSlcbiAgLy8gICAuc3Vic2NyaWJlKClcblxuICByZXR1cm4gcmVhZGVyXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/enhancers/chrome.ts\n");
|
|
70
|
+
|
|
71
|
+
/***/ }),
|
|
72
|
+
|
|
73
|
+
/***/ "./src/enhancers/composeEnhancer.ts":
|
|
74
|
+
/*!******************************************!*\
|
|
75
|
+
!*** ./src/enhancers/composeEnhancer.ts ***!
|
|
76
|
+
\******************************************/
|
|
77
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
78
|
+
|
|
79
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"composeEnhancer\": () => (/* binding */ composeEnhancer)\n/* harmony export */ });\n/* harmony import */ var _utils_compose__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/compose */ \"./src/utils/compose.ts\");\n\nfunction composeEnhancer(...funcs) {\n return (0,_utils_compose__WEBPACK_IMPORTED_MODULE_0__.compose)(...funcs);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/composeEnhancer.ts.js","mappings":";;;;;AAC0C;AA0GnC,SAAS,eAAe,CAAC,GAAG,KAAY;IAC7C,OAAO,uDAAO,CAAC,GAAG,KAAK,CAAC;AAC1B,CAAC","sources":["webpack://@prose-reader/core/./src/enhancers/composeEnhancer.ts?f3e1"],"sourcesContent":["import { Enhancer, ExtractApi, ExtractHiddenApi, ExtractOptions } from \"./types\"\nimport { compose } from \"../utils/compose\"\n\nexport type ComposableEnhancer = (createReader: any) => (options: any) => {setSettings?: any, __OutputSettings?: any}\n\nexport type ComposeEnhancer<\n  A extends ComposableEnhancer = Enhancer,\n  B extends ComposableEnhancer = Enhancer,\n  C extends ComposableEnhancer = Enhancer,\n  D extends ComposableEnhancer = Enhancer,\n  E extends ComposableEnhancer = Enhancer,\n  F extends ComposableEnhancer = Enhancer,\n  G extends ComposableEnhancer = Enhancer,\n  H extends ComposableEnhancer = Enhancer,\n  I extends ComposableEnhancer = Enhancer,\n  J extends ComposableEnhancer = Enhancer,\n  K extends ComposableEnhancer = Enhancer,\n  L extends ComposableEnhancer = Enhancer,\n  M extends ComposableEnhancer = Enhancer,\n  N extends ComposableEnhancer = Enhancer,\n  O extends ComposableEnhancer = Enhancer,\n  > =\n  Enhancer<\n    & ExtractOptions<A>\n    & ExtractOptions<B>\n    & ExtractOptions<C>\n    & ExtractOptions<D>\n    & ExtractOptions<E>\n    & ExtractOptions<F>\n    & ExtractOptions<G>\n    & ExtractOptions<H>\n    & ExtractOptions<I>\n    & ExtractOptions<J>\n    & ExtractOptions<K>\n    & ExtractOptions<L>\n    & ExtractOptions<M>\n    & ExtractOptions<N>\n    & ExtractOptions<O>,\n    // ModifyDeep<\n    //   ModifyDeep<\n    //     ExtractHiddenApi<A>,\n    //     ExtractHiddenApi<B>\n    //   >,\n    //   ExtractHiddenApi<C>\n    // >\n    ExtractHiddenApi<A>\n    & ExtractHiddenApi<B>\n    & ExtractHiddenApi<C>\n    & ExtractHiddenApi<D>\n    & ExtractHiddenApi<E>\n    & ExtractHiddenApi<F>\n    & ExtractHiddenApi<G>\n    & ExtractHiddenApi<H>\n    & ExtractHiddenApi<I>\n    & ExtractHiddenApi<J>\n    & ExtractHiddenApi<K>\n    & ExtractHiddenApi<L>\n    & ExtractHiddenApi<M>\n    & ExtractHiddenApi<N>\n    & ExtractHiddenApi<O>,\n    & Parameters<ExtractApi<A>[`setSettings`]>[0]\n    & Parameters<ExtractApi<B>[`setSettings`]>[0]\n    & Parameters<ExtractApi<C>[`setSettings`]>[0]\n    & Parameters<ExtractApi<D>[`setSettings`]>[0]\n    & Parameters<ExtractApi<E>[`setSettings`]>[0]\n    & Parameters<ExtractApi<F>[`setSettings`]>[0]\n    & Parameters<ExtractApi<G>[`setSettings`]>[0]\n    & Parameters<ExtractApi<H>[`setSettings`]>[0]\n    & Parameters<ExtractApi<I>[`setSettings`]>[0]\n    & Parameters<ExtractApi<J>[`setSettings`]>[0]\n    & Parameters<ExtractApi<K>[`setSettings`]>[0]\n    & Parameters<ExtractApi<L>[`setSettings`]>[0]\n    & Parameters<ExtractApi<M>[`setSettings`]>[0]\n    & Parameters<ExtractApi<N>[`setSettings`]>[0]\n    & Parameters<ExtractApi<O>[`setSettings`]>[0],\n    & ExtractApi<A>[`__OutputSettings`]\n    & ExtractApi<B>[`__OutputSettings`]\n    & ExtractApi<C>[`__OutputSettings`]\n    & ExtractApi<D>[`__OutputSettings`]\n    & ExtractApi<E>[`__OutputSettings`]\n    & ExtractApi<F>[`__OutputSettings`]\n    & ExtractApi<G>[`__OutputSettings`]\n    & ExtractApi<H>[`__OutputSettings`]\n    & ExtractApi<I>[`__OutputSettings`]\n    & ExtractApi<J>[`__OutputSettings`]\n    & ExtractApi<K>[`__OutputSettings`]\n    & ExtractApi<L>[`__OutputSettings`]\n    & ExtractApi<M>[`__OutputSettings`]\n    & ExtractApi<N>[`__OutputSettings`]\n    & ExtractApi<O>[`__OutputSettings`]\n  >\n\nexport function composeEnhancer<A extends ComposableEnhancer>(a: A): ComposeEnhancer<A>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer>(a: A, b: B): ComposeEnhancer<A, B>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer>(a: A, b: B, c: C): ComposeEnhancer<A, B, C>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer>(a: A, b: B, c: C, d: D): ComposeEnhancer<A, B, C, D>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E): ComposeEnhancer<A, B, C, D, E>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F): ComposeEnhancer<A, B, C, D, E, F>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G): ComposeEnhancer<A, B, C, D, E, F, G>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H): ComposeEnhancer<A, B, C, D, E, F, G, H>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I): ComposeEnhancer<A, B, C, D, E, F, G, H, I>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer, K extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J, k: K): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J, K>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer, K extends ComposableEnhancer, L extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J, k: K, l: L): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J, K, L>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer, K extends ComposableEnhancer, L extends ComposableEnhancer, M extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J, k: K, l: L, m: M): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J, K, L, M>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer, K extends ComposableEnhancer, L extends ComposableEnhancer, M extends ComposableEnhancer, N extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J, k: K, l: L, m: M, n: N): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J, K, L, M, N>\nexport function composeEnhancer<A extends ComposableEnhancer, B extends ComposableEnhancer, C extends ComposableEnhancer, D extends ComposableEnhancer, E extends ComposableEnhancer, F extends ComposableEnhancer, G extends ComposableEnhancer, H extends ComposableEnhancer, I extends ComposableEnhancer, J extends ComposableEnhancer, K extends ComposableEnhancer, L extends ComposableEnhancer, M extends ComposableEnhancer, N extends ComposableEnhancer, O extends ComposableEnhancer>(a: A, b: B, c: C, d: D, e: E, f: F, g: G, h: H, i: I, j: J, k: K, l: L, m: M, n: N, o: O): ComposeEnhancer<A, B, C, D, E, F, G, H, I, J, K, L, M, N, O>\nexport function composeEnhancer(...funcs: any[]) {\n  return compose(...funcs)\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/composeEnhancer.ts\n");
|
|
80
|
+
|
|
81
|
+
/***/ }),
|
|
82
|
+
|
|
83
|
+
/***/ "./src/enhancers/fonts.ts":
|
|
84
|
+
/*!********************************!*\
|
|
85
|
+
!*** ./src/enhancers/fonts.ts ***!
|
|
86
|
+
\********************************/
|
|
87
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
88
|
+
|
|
89
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"fontsEnhancer\": () => (/* binding */ fontsEnhancer)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\nvar __rest = (undefined && undefined.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\nconst FONT_WEIGHT = [100, 200, 300, 400, 500, 600, 700, 800, 900];\nconst FONT_JUSTIFICATION = [`center`, `left`, `right`, `justify`];\nconst fontsEnhancer = (next) => (_a) => {\n var { fontScale = 1, lineHeight = `publisher`, fontWeight = `publisher`, fontJustification = `publisher` } = _a, options = __rest(_a, [\"fontScale\", \"lineHeight\", \"fontWeight\", \"fontJustification\"]);\n const settingsSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject({\n fontScale,\n lineHeight,\n fontWeight,\n fontJustification\n });\n const reader = next(options);\n const getStyle = () => `\n ${``}\n body {\n ${settingsSubject$.value.fontScale !== 1\n ? `font-size: ${settingsSubject$.value.fontScale}em !important;`\n : ``}\n ${settingsSubject$.value.lineHeight !== `publisher`\n ? `line-height: ${settingsSubject$.value.lineHeight} !important;`\n : ``}\n ${settingsSubject$.value.fontWeight !== `publisher`\n ? `font-weight: ${settingsSubject$.value.fontWeight} !important;`\n : ``}\n ${settingsSubject$.value.fontJustification !== `publisher`\n ? `text-align: ${settingsSubject$.value.fontJustification} !important;`\n : ``}\n }\n `;\n const applyChangeToSpineItem = (requireLayout) => {\n reader.manipulateSpineItems(({ removeStyle, addStyle, item }) => {\n if (item.renditionLayout !== `pre-paginated`) {\n removeStyle(`prose-reader-fonts`);\n addStyle(`prose-reader-fonts`, getStyle());\n }\n return requireLayout;\n });\n };\n reader.registerHook(`item.onLoad`, ({ removeStyle, addStyle, item }) => {\n if (item.renditionLayout !== `pre-paginated`) {\n removeStyle(`prose-reader-fonts`);\n addStyle(`prose-reader-fonts`, getStyle());\n }\n });\n const shouldRequireLayout = (source) => source\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.pairwise)(), (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.map)(([old, latest]) => {\n if (latest.fontScale !== old.fontScale)\n return true;\n if (latest.lineHeight !== old.lineHeight)\n return true;\n return false;\n }));\n settingsSubject$.asObservable()\n .pipe(shouldRequireLayout, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(applyChangeToSpineItem), (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.takeUntil)(reader.$.destroy$))\n .subscribe();\n return Object.assign(Object.assign({}, reader), { setSettings: (settings) => {\n const { fontJustification = settingsSubject$.value.fontJustification, fontScale = settingsSubject$.value.fontScale, fontWeight = settingsSubject$.value.fontWeight, lineHeight = settingsSubject$.value.lineHeight } = settings, passthroughSettings = __rest(settings, [\"fontJustification\", \"fontScale\", \"fontWeight\", \"lineHeight\"]);\n if (hasOneKey(settings, [`fontJustification`, `fontScale`, `fontWeight`, `lineHeight`])) {\n settingsSubject$.next({ fontJustification, fontScale, fontWeight, lineHeight });\n }\n reader.setSettings(passthroughSettings);\n }, $: Object.assign(Object.assign({}, reader.$), { settings$: (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.combineLatest)([reader.$.settings$, settingsSubject$])\n .pipe((0,rxjs__WEBPACK_IMPORTED_MODULE_0__.map)(([innerSettings, settings]) => (Object.assign(Object.assign({}, innerSettings), settings)))) }) });\n};\nconst hasOneKey = (obj, keys) => keys.some(key => key in obj);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/fonts.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/enhancers/fonts.ts?a597"],"sourcesContent":["import { BehaviorSubject, combineLatest, map, Observable, ObservedValueOf, takeUntil } from \"rxjs\"\nimport { tap, pairwise } from \"rxjs/operators\"\nimport { Enhancer } from \"./types\"\n\nconst FONT_WEIGHT = [100, 200, 300, 400, 500, 600, 700, 800, 900] as const\nconst FONT_JUSTIFICATION = [`center`, `left`, `right`, `justify`] as const\n\ntype Options = {\n  /**\n   * @description\n   * Scale the font size. 1 means use default publisher/browser font size, 2 means 200%\n   * 0.5 50%, etc\n   */\n  fontScale?: number,\n  /**\n   * @description\n   * Set the line height of the text. The default value is 1\n   */\n  lineHeight?: number | `publisher`,\n  /**\n   * @description\n   * Set font weight of text\n   */\n  fontWeight?: typeof FONT_WEIGHT[number] | `publisher`,\n  /**\n   * @description\n   * Set text align justification\n   */\n  fontJustification?: typeof FONT_JUSTIFICATION[number] | `publisher`,\n}\n\ntype OutputOptions = Required<Options>\n\n/**\n * @important\n * We don't apply font scaling on pre-paginated because it could potentially\n * break publisher scaling. Since it's specifically made for the given fixed layout\n * we should trust the publisher and not break its rendering.\n * @see 9781250213662\n *\n * Setting the font scale on body still has a chance to break publisher potential\n * font size on body if they already use something.\n * @see 9782714493743\n */\nexport const fontsEnhancer: Enhancer<Options, {}, Options, OutputOptions> = (next) => ({\n  fontScale = 1,\n  lineHeight = `publisher`,\n  fontWeight = `publisher`,\n  fontJustification = `publisher`,\n  ...options\n}) => {\n  const settingsSubject$ = new BehaviorSubject<OutputOptions>({\n    fontScale,\n    lineHeight,\n    fontWeight,\n    fontJustification\n  })\n  const reader = next(options)\n\n  const getStyle = () => `\n    ${/*\n      Ideally, we would like to use !important but it could break publisher specific\n      cases.\n      Also right now we do not apply it to * since it would also break publisher\n      more specific scaling down the tree.\n\n      body *:not([class^=\"mjx-\"]) {\n    */``}\n    body {\n      ${settingsSubject$.value.fontScale !== 1\n      ? `font-size: ${settingsSubject$.value.fontScale}em !important;`\n      : ``}\n      ${settingsSubject$.value.lineHeight !== `publisher`\n      ? `line-height: ${settingsSubject$.value.lineHeight} !important;`\n      : ``}\n      ${settingsSubject$.value.fontWeight !== `publisher`\n      ? `font-weight: ${settingsSubject$.value.fontWeight} !important;`\n      : ``}\n      ${settingsSubject$.value.fontJustification !== `publisher`\n      ? `text-align: ${settingsSubject$.value.fontJustification} !important;`\n      : ``}\n    }\n  `\n\n  /**\n   * Programmatically update every loaded items\n   */\n  const applyChangeToSpineItem = (requireLayout: boolean) => {\n    reader.manipulateSpineItems(({ removeStyle, addStyle, item }) => {\n      if (item.renditionLayout !== `pre-paginated`) {\n        removeStyle(`prose-reader-fonts`)\n        addStyle(`prose-reader-fonts`, getStyle())\n      }\n\n      return requireLayout\n    })\n  }\n\n  /**\n   * Make sure we apply the style to any new item loaded.\n   */\n  reader.registerHook(`item.onLoad`, ({ removeStyle, addStyle, item }) => {\n    if (item.renditionLayout !== `pre-paginated`) {\n      removeStyle(`prose-reader-fonts`)\n      addStyle(`prose-reader-fonts`, getStyle())\n    }\n  })\n\n  const shouldRequireLayout = <T extends ObservedValueOf<typeof settingsSubject$>>(source: Observable<T>) => source\n    .pipe(\n      pairwise(),\n      map(([old, latest]) => {\n        if (latest.fontScale !== old.fontScale) return true\n        if (latest.lineHeight !== old.lineHeight) return true\n\n        return false\n      })\n    )\n\n  settingsSubject$.asObservable()\n    .pipe(\n      shouldRequireLayout,\n      tap(applyChangeToSpineItem),\n      takeUntil(reader.$.destroy$)\n    )\n    .subscribe()\n\n  return {\n    ...reader,\n    /**\n     * Absorb current enhancer settings and passthrough the rest to reader\n     */\n    setSettings: (settings) => {\n      const {\n        fontJustification = settingsSubject$.value.fontJustification,\n        fontScale = settingsSubject$.value.fontScale,\n        fontWeight = settingsSubject$.value.fontWeight,\n        lineHeight = settingsSubject$.value.lineHeight,\n        ...passthroughSettings\n      } = settings\n\n      if (hasOneKey(settings, [`fontJustification`, `fontScale`, `fontWeight`, `lineHeight`])) {\n        settingsSubject$.next({ fontJustification, fontScale, fontWeight, lineHeight })\n      }\n      reader.setSettings(passthroughSettings)\n    },\n    $: {\n      ...reader.$,\n      /**\n       * Combine reader settings with enhancer settings\n       */\n      settings$: combineLatest([reader.$.settings$, settingsSubject$])\n        .pipe(\n          map(([innerSettings, settings]) => ({\n            ...innerSettings,\n            ...settings\n          }))\n        )\n    }\n  }\n}\n\nconst hasOneKey = <Obj, Key extends keyof Obj>(obj: Obj, keys: Key[]) => keys.some(key => key in obj)\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/fonts.ts\n");
|
|
90
|
+
|
|
91
|
+
/***/ }),
|
|
92
|
+
|
|
93
|
+
/***/ "./src/enhancers/hotkeys.ts":
|
|
94
|
+
/*!**********************************!*\
|
|
95
|
+
!*** ./src/enhancers/hotkeys.ts ***!
|
|
96
|
+
\**********************************/
|
|
97
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
98
|
+
|
|
99
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"hotkeysEnhancer\": () => (/* binding */ hotkeysEnhancer)\n/* harmony export */ });\nconst hotkeysEnhancer = (next) => (options) => {\n const reader = next(options);\n const onKeyPress = (e) => {\n if (e.key === `ArrowRight`) {\n reader.turnRight();\n }\n if (e.key === `ArrowLeft`) {\n reader.turnLeft();\n }\n };\n document.addEventListener(`keyup`, onKeyPress);\n reader.registerHook(`item.onLoad`, ({ frame }) => {\n var _a;\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.addEventListener(`keyup`, onKeyPress);\n return () => {\n var _a;\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.removeEventListener(`keyup`, onKeyPress);\n };\n });\n const destroy = () => {\n document.removeEventListener(`keyup`, onKeyPress);\n reader.destroy();\n };\n return Object.assign(Object.assign({}, reader), { destroy });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL2hvdGtleXMudHMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUVPLE1BQU0sZUFBZSxHQUFxQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtJQUNyRSxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBRTVCLE1BQU0sVUFBVSxHQUFHLENBQUMsQ0FBZ0IsRUFBRSxFQUFFO1FBQ3RDLElBQUksQ0FBQyxDQUFDLEdBQUcsS0FBSyxZQUFZLEVBQUU7WUFDMUIsTUFBTSxDQUFDLFNBQVMsRUFBRTtTQUNuQjtRQUVELElBQUksQ0FBQyxDQUFDLEdBQUcsS0FBSyxXQUFXLEVBQUU7WUFDekIsTUFBTSxDQUFDLFFBQVEsRUFBRTtTQUNsQjtJQUNILENBQUM7SUFFRCxRQUFRLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQztJQUU5QyxNQUFNLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRTs7UUFDL0MsV0FBSyxDQUFDLGVBQWUsMENBQUUsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQztRQUU1RCxPQUFPLEdBQUcsRUFBRTs7WUFDVixXQUFLLENBQUMsZUFBZSwwQ0FBRSxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDO1FBQ2pFLENBQUM7SUFDSCxDQUFDLENBQUM7SUFFRixNQUFNLE9BQU8sR0FBRyxHQUFHLEVBQUU7UUFDbkIsUUFBUSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUM7UUFDakQsTUFBTSxDQUFDLE9BQU8sRUFBRTtJQUNsQixDQUFDO0lBRUQsdUNBQ0ssTUFBTSxLQUNULE9BQU8sSUFDUjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL2hvdGtleXMudHM/NWNhYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmhhbmNlciB9IGZyb20gXCIuL3R5cGVzXCJcblxuZXhwb3J0IGNvbnN0IGhvdGtleXNFbmhhbmNlcjogRW5oYW5jZXI8e30sIHt9PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG5cbiAgY29uc3Qgb25LZXlQcmVzcyA9IChlOiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgaWYgKGUua2V5ID09PSBgQXJyb3dSaWdodGApIHtcbiAgICAgIHJlYWRlci50dXJuUmlnaHQoKVxuICAgIH1cblxuICAgIGlmIChlLmtleSA9PT0gYEFycm93TGVmdGApIHtcbiAgICAgIHJlYWRlci50dXJuTGVmdCgpXG4gICAgfVxuICB9XG5cbiAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihga2V5dXBgLCBvbktleVByZXNzKVxuXG4gIHJlYWRlci5yZWdpc3Rlckhvb2soYGl0ZW0ub25Mb2FkYCwgKHsgZnJhbWUgfSkgPT4ge1xuICAgIGZyYW1lLmNvbnRlbnREb2N1bWVudD8uYWRkRXZlbnRMaXN0ZW5lcihga2V5dXBgLCBvbktleVByZXNzKVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGZyYW1lLmNvbnRlbnREb2N1bWVudD8ucmVtb3ZlRXZlbnRMaXN0ZW5lcihga2V5dXBgLCBvbktleVByZXNzKVxuICAgIH1cbiAgfSlcblxuICBjb25zdCBkZXN0cm95ID0gKCkgPT4ge1xuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoYGtleXVwYCwgb25LZXlQcmVzcylcbiAgICByZWFkZXIuZGVzdHJveSgpXG4gIH1cblxuICByZXR1cm4ge1xuICAgIC4uLnJlYWRlcixcbiAgICBkZXN0cm95XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/enhancers/hotkeys.ts\n");
|
|
100
|
+
|
|
101
|
+
/***/ }),
|
|
102
|
+
|
|
103
|
+
/***/ "./src/enhancers/layoutEnhancer/createMovingSafePan$.ts":
|
|
104
|
+
/*!**************************************************************!*\
|
|
105
|
+
!*** ./src/enhancers/layoutEnhancer/createMovingSafePan$.ts ***!
|
|
106
|
+
\**************************************************************/
|
|
107
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
108
|
+
|
|
109
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createMovingSafePan$\": () => (/* binding */ createMovingSafePan$)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n\n\nconst SHOULD_NOT_LAYOUT = false;\nconst createMovingSafePan$ = (reader) => {\n let iframeOverlayForAnimationsElement;\n reader.manipulateContainer((container) => {\n iframeOverlayForAnimationsElement = container.ownerDocument.createElement(`div`);\n iframeOverlayForAnimationsElement.style.cssText = `\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n visibility: hidden;\n `;\n container.appendChild(iframeOverlayForAnimationsElement);\n return SHOULD_NOT_LAYOUT;\n });\n const createResetLock$ = (source) => (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.scheduled)(source, rxjs__WEBPACK_IMPORTED_MODULE_0__.animationFrameScheduler)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n iframeOverlayForAnimationsElement === null || iframeOverlayForAnimationsElement === void 0 ? void 0 : iframeOverlayForAnimationsElement.style.setProperty(`visibility`, `hidden`);\n }));\n const viewportFree$ = reader.$.viewportState$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(data => data === `free`));\n const viewportBusy$ = reader.$.viewportState$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(data => data === `busy`));\n const lockAfterViewportBusy$ = viewportBusy$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n iframeOverlayForAnimationsElement === null || iframeOverlayForAnimationsElement === void 0 ? void 0 : iframeOverlayForAnimationsElement.style.setProperty(`visibility`, `visible`);\n }));\n const resetLockViewportFree$ = createResetLock$(viewportFree$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n const pageTurnMode$ = reader.context.$.settings$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => reader.context.getSettings().computedPageTurnMode), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)());\n const handleViewportLock$ = pageTurnMode$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)((mode) => mode === `controlled`\n ? lockAfterViewportBusy$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => resetLockViewportFree$))\n : createResetLock$((0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(undefined))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(reader.$.destroy$));\n return handleViewportLock$;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL2xheW91dEVuaGFuY2VyL2NyZWF0ZU1vdmluZ1NhZmVQYW4kLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQXlFO0FBQzBCO0FBR25HLE1BQU0saUJBQWlCLEdBQUcsS0FBSztBQVl4QixNQUFNLG9CQUFvQixHQUFHLENBQUMsTUFBYyxFQUFFLEVBQUU7SUFDckQsSUFBSSxpQ0FBNkQ7SUFFakUsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7UUFDdkMsaUNBQWlDLEdBQUcsU0FBUyxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDO1FBQ2hGLGlDQUFpQyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUc7Ozs7Ozs7S0FPakQ7UUFDRCxTQUFTLENBQUMsV0FBVyxDQUFDLGlDQUFpQyxDQUFDO1FBRXhELE9BQU8saUJBQWlCO0lBQzFCLENBQUMsQ0FBQztJQUVGLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBSSxNQUFxQixFQUFFLEVBQUUsQ0FBQywrQ0FBUyxDQUFDLE1BQU0sRUFBRSx5REFBdUIsQ0FBQztTQUM5RixJQUFJLENBQ0gsbURBQUcsQ0FBQyxHQUFHLEVBQUU7UUFDUCxpQ0FBaUMsYUFBakMsaUNBQWlDLHVCQUFqQyxpQ0FBaUMsQ0FBRSxLQUFLLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRSxRQUFRLENBQUM7SUFDOUUsQ0FBQyxDQUFDLENBQ0g7SUFFSCxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsc0RBQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsQ0FBQztJQUNuRixNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsc0RBQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsQ0FBQztJQUVuRixNQUFNLHNCQUFzQixHQUFHLGFBQWE7U0FDekMsSUFBSSxDQUNILG1EQUFHLENBQUMsR0FBRyxFQUFFO1FBQ1AsaUNBQWlDLGFBQWpDLGlDQUFpQyx1QkFBakMsaUNBQWlDLENBQUUsS0FBSyxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsU0FBUyxDQUFDO0lBQy9FLENBQUMsQ0FBQyxDQUNIO0lBRUgsTUFBTSxzQkFBc0IsR0FBRyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUM7U0FDM0QsSUFBSSxDQUNILG9EQUFJLENBQUMsQ0FBQyxDQUFDLENBQ1I7SUFFSCxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTO1NBQzdDLElBQUksQ0FDSCxtREFBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUMsb0JBQW9CLENBQUMsRUFDNUQsb0VBQW9CLEVBQUUsQ0FDdkI7SUFFSCxNQUFNLG1CQUFtQixHQUFHLGFBQWE7U0FDdEMsSUFBSSxDQUNILHlEQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyxZQUFZO1FBQ3ZDLENBQUMsQ0FBQyxzQkFBc0I7YUFDckIsSUFBSSxDQUNILHlEQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsc0JBQXNCLENBQUMsQ0FDeEM7UUFDSCxDQUFDLENBQUMsZ0JBQWdCLENBQUMsd0NBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUNsQyxFQUNELHlEQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FDN0I7SUFFSCxPQUFPLG1CQUFtQjtBQUM1QixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL2VuaGFuY2Vycy9sYXlvdXRFbmhhbmNlci9jcmVhdGVNb3ZpbmdTYWZlUGFuJC50cz8yMWM3Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuaW1hdGlvbkZyYW1lU2NoZWR1bGVyLCBPYnNlcnZhYmxlLCBvZiwgc2NoZWR1bGVkIH0gZnJvbSBcInJ4anNcIlxuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciwgbWFwLCBzd2l0Y2hNYXAsIHRha2UsIHRha2VVbnRpbCwgdGFwIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCJcbmltcG9ydCB7IFJlYWRlciB9IGZyb20gXCIuLi8uLi9yZWFkZXJcIlxuXG5jb25zdCBTSE9VTERfTk9UX0xBWU9VVCA9IGZhbHNlXG5cbi8qKlxuICogRm9yIHNvbWUgcmVhc29uIChidWcgLyBleHBlY3RlZCAvIGVuZ2luZSBsYXlvdXQgb3B0aW1pemF0aW9uKSB3aGVuIHRoZSB2aWV3cG9ydCBpcyBiZWluZyBhbmltYXRlZCBjbGlja2luZyBpbnNpZGUgaWZyYW1lXG4gKiBzb21ldGltZXMgcmV0dXJucyBpbnZhbGlkIGNsaWVudFggdmFsdWUuIFRoaXMgbWVhbnMgdGhhdCB3aGVuIHJhcGlkbHkgKG9yIG5vdCkgY2xpY2tpbmcgZHVyaW5nIGFuaW1hdGlvbiBvbiBpZnJhbWUgd2lsbCBvZnRlblxuICogdGltZSByZXR1cm5zIGludmFsaWQgdmFsdWUuIEluIG9yZGVyIHRvIHJlZHVjZSBwb3RlbnRpYWwgdW53YW50ZWQgYmVoYXZpb3Igb24gY29uc3VtZXIgc2lkZSwgd2UgdGVtcG9yYXJpbHkgaGlkZSB0aGUgaWZyYW1lIGJlaGluZFxuICogYW4gb3ZlcmxheS4gVGhhdCB3YXkgdGhlIG92ZXJsYXkgdGFrZSBvdmVyIGZvciB0aGUgcG9pbnRlciBldmVudCBhbmQgd2UgYWxsIGdvb2QuXG4gKlxuICogQGltcG9ydGFudFxuICogVGhpcyBvYnZpb3VzbHkgYmxvY2sgYW55IGludGVyYWN0aW9uIHdpdGggaWZyYW1lIGJ1dCB0aGVyZSBzaG91bGQgbm90IGJlIHN1Y2ggaW50ZXJhY3Rpb24gd2l0aCBpZnJhbWUgaW4gdGhlb3J5LlxuICogVGhlb3JldGljYWxseSBpZiB1c2VyIGRlY2lkZSB0byBpbnRlcmFjdCBkdXJpbmcgdGhlIGFuaW1hdGlvbiB0aGF0J3MgZWl0aGVyIHRvIHN0b3AgaXQgb3Igc3dpcGUgdGhlIHBhZ2VzLlxuICovXG5leHBvcnQgY29uc3QgY3JlYXRlTW92aW5nU2FmZVBhbiQgPSAocmVhZGVyOiBSZWFkZXIpID0+IHtcbiAgbGV0IGlmcmFtZU92ZXJsYXlGb3JBbmltYXRpb25zRWxlbWVudDogSFRNTERpdkVsZW1lbnQgfCB1bmRlZmluZWRcblxuICByZWFkZXIubWFuaXB1bGF0ZUNvbnRhaW5lcigoY29udGFpbmVyKSA9PiB7XG4gICAgaWZyYW1lT3ZlcmxheUZvckFuaW1hdGlvbnNFbGVtZW50ID0gY29udGFpbmVyLm93bmVyRG9jdW1lbnQuY3JlYXRlRWxlbWVudChgZGl2YClcbiAgICBpZnJhbWVPdmVybGF5Rm9yQW5pbWF0aW9uc0VsZW1lbnQuc3R5bGUuY3NzVGV4dCA9IGBcbiAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgIGxlZnQ6IDA7XG4gICAgICB0b3A6IDA7XG4gICAgICB3aWR0aDogMTAwJTtcbiAgICAgIGhlaWdodDogMTAwJTtcbiAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgICBgXG4gICAgY29udGFpbmVyLmFwcGVuZENoaWxkKGlmcmFtZU92ZXJsYXlGb3JBbmltYXRpb25zRWxlbWVudClcblxuICAgIHJldHVybiBTSE9VTERfTk9UX0xBWU9VVFxuICB9KVxuXG4gIGNvbnN0IGNyZWF0ZVJlc2V0TG9jayQgPSA8VD4oc291cmNlOiBPYnNlcnZhYmxlPFQ+KSA9PiBzY2hlZHVsZWQoc291cmNlLCBhbmltYXRpb25GcmFtZVNjaGVkdWxlcilcbiAgICAucGlwZShcbiAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgIGlmcmFtZU92ZXJsYXlGb3JBbmltYXRpb25zRWxlbWVudD8uc3R5bGUuc2V0UHJvcGVydHkoYHZpc2liaWxpdHlgLCBgaGlkZGVuYClcbiAgICAgIH0pXG4gICAgKVxuXG4gIGNvbnN0IHZpZXdwb3J0RnJlZSQgPSByZWFkZXIuJC52aWV3cG9ydFN0YXRlJC5waXBlKGZpbHRlcihkYXRhID0+IGRhdGEgPT09IGBmcmVlYCkpXG4gIGNvbnN0IHZpZXdwb3J0QnVzeSQgPSByZWFkZXIuJC52aWV3cG9ydFN0YXRlJC5waXBlKGZpbHRlcihkYXRhID0+IGRhdGEgPT09IGBidXN5YCkpXG5cbiAgY29uc3QgbG9ja0FmdGVyVmlld3BvcnRCdXN5JCA9IHZpZXdwb3J0QnVzeSRcbiAgICAucGlwZShcbiAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgIGlmcmFtZU92ZXJsYXlGb3JBbmltYXRpb25zRWxlbWVudD8uc3R5bGUuc2V0UHJvcGVydHkoYHZpc2liaWxpdHlgLCBgdmlzaWJsZWApXG4gICAgICB9KVxuICAgIClcblxuICBjb25zdCByZXNldExvY2tWaWV3cG9ydEZyZWUkID0gY3JlYXRlUmVzZXRMb2NrJCh2aWV3cG9ydEZyZWUkKVxuICAgIC5waXBlKFxuICAgICAgdGFrZSgxKVxuICAgIClcblxuICBjb25zdCBwYWdlVHVybk1vZGUkID0gcmVhZGVyLmNvbnRleHQuJC5zZXR0aW5ncyRcbiAgICAucGlwZShcbiAgICAgIG1hcCgoKSA9PiByZWFkZXIuY29udGV4dC5nZXRTZXR0aW5ncygpLmNvbXB1dGVkUGFnZVR1cm5Nb2RlKSxcbiAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKClcbiAgICApXG5cbiAgY29uc3QgaGFuZGxlVmlld3BvcnRMb2NrJCA9IHBhZ2VUdXJuTW9kZSRcbiAgICAucGlwZShcbiAgICAgIHN3aXRjaE1hcCgobW9kZSkgPT4gbW9kZSA9PT0gYGNvbnRyb2xsZWRgXG4gICAgICAgID8gbG9ja0FmdGVyVmlld3BvcnRCdXN5JFxuICAgICAgICAgIC5waXBlKFxuICAgICAgICAgICAgc3dpdGNoTWFwKCgpID0+IHJlc2V0TG9ja1ZpZXdwb3J0RnJlZSQpXG4gICAgICAgICAgKVxuICAgICAgICA6IGNyZWF0ZVJlc2V0TG9jayQob2YodW5kZWZpbmVkKSlcbiAgICAgICksXG4gICAgICB0YWtlVW50aWwocmVhZGVyLiQuZGVzdHJveSQpXG4gICAgKVxuXG4gIHJldHVybiBoYW5kbGVWaWV3cG9ydExvY2skXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/enhancers/layoutEnhancer/createMovingSafePan$.ts\n");
|
|
110
|
+
|
|
111
|
+
/***/ }),
|
|
112
|
+
|
|
113
|
+
/***/ "./src/enhancers/layoutEnhancer/layoutEnhancer.ts":
|
|
114
|
+
/*!********************************************************!*\
|
|
115
|
+
!*** ./src/enhancers/layoutEnhancer/layoutEnhancer.ts ***!
|
|
116
|
+
\********************************************************/
|
|
117
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
118
|
+
|
|
119
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"layoutEnhancer\": () => (/* binding */ layoutEnhancer)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _createMovingSafePan$__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createMovingSafePan$ */ \"./src/enhancers/layoutEnhancer/createMovingSafePan$.ts\");\n/* harmony import */ var _utils_rxjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../utils/rxjs */ \"./src/utils/rxjs.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../utils/objects */ \"./src/utils/objects.ts\");\nvar __rest = (undefined && undefined.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\n\n\n\nconst SHOULD_NOT_LAYOUT = false;\nconst layoutEnhancer = (next) => (_a) => {\n var { pageHorizontalMargin = 24, pageVerticalMargin = 24 } = _a, options = __rest(_a, [\"pageHorizontalMargin\", \"pageVerticalMargin\"]);\n const reader = next(options);\n const settingsSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject({\n pageHorizontalMargin,\n pageVerticalMargin\n });\n reader.registerHook(`onViewportOffsetAdjust`, () => {\n let hasRedrawn = false;\n reader.manipulateSpineItems(({ frame }) => {\n if (!hasRedrawn && frame) {\n void (frame.getBoundingClientRect().left);\n hasRedrawn = true;\n }\n return SHOULD_NOT_LAYOUT;\n });\n });\n reader.registerHook(`item.onLayoutBeforeMeasurment`, ({ frame, minimumWidth, item, isImageType }) => {\n var _a, _b;\n const { pageHorizontalMargin = 0, pageVerticalMargin = 0 } = settingsSubject$.value;\n const pageSize = reader.context.getPageSize();\n if (item.renditionLayout === `reflowable` &&\n frame.getIsReady() &&\n !isImageType() &&\n !frame.getViewportDimensions()) {\n let columnWidth = pageSize.width - (pageHorizontalMargin * 2);\n const columnHeight = pageSize.height - (pageVerticalMargin * 2);\n let width = pageSize.width - (pageHorizontalMargin * 2);\n let columnGap = pageHorizontalMargin * 2;\n if (frame.isUsingVerticalWriting()) {\n width = minimumWidth - (pageHorizontalMargin * 2);\n columnWidth = columnHeight;\n columnGap = pageVerticalMargin * 2;\n }\n (_a = frame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.removeStyle(`prose-layout-enhancer-css`);\n (_b = frame.getManipulableFrame()) === null || _b === void 0 ? void 0 : _b.addStyle(`prose-layout-enhancer-css`, `\n body {\n width: ${width}px !important;\n margin: ${pageVerticalMargin}px ${pageHorizontalMargin}px !important;\n column-gap: ${columnGap}px !important;\n column-width: ${columnWidth}px !important;\n height: ${columnHeight}px !important;\n }\n img, video, audio, object, svg {\n max-width: ${columnWidth}px !important;\n max-height: ${columnHeight}px !important;\n }\n table {\n max-width: ${columnWidth}px !important;\n }\n td {\n max-width: ${columnWidth}px;\n }\n `);\n }\n });\n let observer;\n if (options.layoutAutoResize === `container`) {\n observer = new ResizeObserver(() => {\n reader === null || reader === void 0 ? void 0 : reader.layout();\n });\n observer.observe(options.containerElement);\n }\n const movingSafePan$ = (0,_createMovingSafePan$__WEBPACK_IMPORTED_MODULE_2__.createMovingSafePan$)(reader);\n movingSafePan$.subscribe();\n settingsSubject$\n .pipe((0,_utils_rxjs__WEBPACK_IMPORTED_MODULE_3__.mapKeysTo)([`pageHorizontalMargin`, `pageVerticalMargin`]), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_4__.isShallowEqual), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.skip)(1), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n reader.spine.layout();\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(reader.$.destroy$))\n .subscribe();\n return Object.assign(Object.assign({}, reader), { destroy: () => {\n reader.destroy();\n observer === null || observer === void 0 ? void 0 : observer.disconnect();\n }, setSettings: (_a) => {\n var { pageVerticalMargin, pageHorizontalMargin } = _a, rest = __rest(_a, [\"pageVerticalMargin\", \"pageHorizontalMargin\"]);\n if (pageHorizontalMargin !== undefined || pageVerticalMargin !== undefined) {\n settingsSubject$.next({\n pageHorizontalMargin: pageHorizontalMargin !== null && pageHorizontalMargin !== void 0 ? pageHorizontalMargin : settingsSubject$.value.pageHorizontalMargin,\n pageVerticalMargin: pageVerticalMargin !== null && pageVerticalMargin !== void 0 ? pageVerticalMargin : settingsSubject$.value.pageVerticalMargin\n });\n }\n reader.setSettings(rest);\n }, $: Object.assign(Object.assign({}, reader.$), { settings$: (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.combineLatest)([reader.$.settings$, settingsSubject$.asObservable()])\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(([innerSettings, settings]) => (Object.assign(Object.assign({}, innerSettings), settings)))) }) });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/layoutEnhancer/layoutEnhancer.ts.js","mappings":";;;;;;;;;;;;;;;;;;;;;;AAAqD;AAC2B;AAEnB;AACjB;AACQ;AAEpD,MAAM,iBAAiB,GAAG,KAAK;AASxB,MAAM,cAAc,GAOa,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAkE,EAAE,EAAE;QAAtE,EAAE,oBAAoB,GAAG,EAAE,EAAE,kBAAkB,GAAG,EAAE,OAAc,EAAT,OAAO,cAAhE,8CAAkE,CAAF;IACjH,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;IAC5B,MAAM,gBAAgB,GAAG,IAAI,iDAAe,CAAiB;QAC3D,oBAAoB;QACpB,kBAAkB;KACnB,CAAC;IAEF,MAAM,CAAC,YAAY,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACjD,IAAI,UAAU,GAAG,KAAK;QAwBtB,MAAM,CAAC,oBAAoB,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;YACxC,IAAI,CAAC,UAAU,IAAI,KAAK,EAAE;gBAExB,KAAK,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC;gBACzC,UAAU,GAAG,IAAI;aAClB;YAED,OAAO,iBAAiB;QAC1B,CAAC,CAAC;IACJ,CAAC,CAAC;IAMF,MAAM,CAAC,YAAY,CAAC,+BAA+B,EAAE,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE;;QAClG,MAAM,EAAE,oBAAoB,GAAG,CAAC,EAAE,kBAAkB,GAAG,CAAC,EAAE,GAAG,gBAAgB,CAAC,KAAK;QACnF,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE;QAE7C,IACE,IAAI,CAAC,eAAe,KAAK,YAAY;YACrC,KAAK,CAAC,UAAU,EAAE;YAClB,CAAC,WAAW,EAAE;YACd,CAAC,KAAK,CAAC,qBAAqB,EAAE,EAC9B;YACA,IAAI,WAAW,GAAG,QAAQ,CAAC,KAAK,GAAG,CAAC,oBAAoB,GAAG,CAAC,CAAC;YAC7D,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,kBAAkB,GAAG,CAAC,CAAC;YAC/D,IAAI,KAAK,GAAG,QAAQ,CAAC,KAAK,GAAG,CAAC,oBAAoB,GAAG,CAAC,CAAC;YACvD,IAAI,SAAS,GAAG,oBAAoB,GAAG,CAAC;YAExC,IAAI,KAAK,CAAC,sBAAsB,EAAE,EAAE;gBAClC,KAAK,GAAG,YAAY,GAAG,CAAC,oBAAoB,GAAG,CAAC,CAAC;gBACjD,WAAW,GAAG,YAAY;gBAC1B,SAAS,GAAG,kBAAkB,GAAG,CAAC;aACnC;YAED,WAAK,CAAC,mBAAmB,EAAE,0CAAE,WAAW,CAAC,2BAA2B,CAAC;YACrE,WAAK,CAAC,mBAAmB,EAAE,0CAAE,QAAQ,CAAC,2BAA2B,EAAE;;mBAEtD,KAAK;oBACJ,kBAAkB,MAAM,oBAAoB;wBACxC,SAAS;0BACP,WAAW;oBACjB,YAAY;;;uBAGT,WAAW;wBACV,YAAY;;;uBAGb,WAAW;;;uBAGX,WAAW;;OAE3B,CAAC;SACH;IACH,CAAC,CAAC;IAWF,IAAI,QAAoC;IAExC,IAAI,OAAO,CAAC,gBAAgB,KAAK,WAAW,EAAE;QAC5C,QAAQ,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE;YACjC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,EAAE;QAClB,CAAC,CAAC;QACF,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC;KAC3C;IAED,MAAM,cAAc,GAAG,2EAAoB,CAAC,MAAM,CAAC;IAEnD,cAAc,CAAC,SAAS,EAAE;IAE1B,gBAAgB;SACb,IAAI,CACH,sDAAS,CAAC,CAAC,sBAAsB,EAAE,oBAAoB,CAAC,CAAC,EACzD,oEAAoB,CAAC,0DAAc,CAAC,EACpC,oDAAI,CAAC,CAAC,CAAC,EACP,mDAAG,CAAC,GAAG,EAAE;QACP,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;IACvB,CAAC,CAAC,EACF,yDAAS,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC7B;SACA,SAAS,EAAE;IAEd,uCACK,MAAM,KACT,OAAO,EAAE,GAAG,EAAE;YACZ,MAAM,CAAC,OAAO,EAAE;YAChB,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,UAAU,EAAE;QACxB,CAAC,EACD,WAAW,EAAE,CAAC,EAAqD,EAAE,EAAE;gBAAzD,EAAE,kBAAkB,EAAE,oBAAoB,OAAW,EAAN,IAAI,cAAnD,8CAAqD,CAAF;YAC/D,IAAI,oBAAoB,KAAK,SAAS,IAAI,kBAAkB,KAAK,SAAS,EAAE;gBAC1E,gBAAgB,CAAC,IAAI,CAAC;oBACpB,oBAAoB,EAAE,oBAAoB,aAApB,oBAAoB,cAApB,oBAAoB,GAAI,gBAAgB,CAAC,KAAK,CAAC,oBAAoB;oBACzF,kBAAkB,EAAE,kBAAkB,aAAlB,kBAAkB,cAAlB,kBAAkB,GAAI,gBAAgB,CAAC,KAAK,CAAC,kBAAkB;iBACpF,CAAC;aACH;YAED,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC;QAC1B,CAAC,EACD,CAAC,kCACI,MAAM,CAAC,CAAC,KACX,SAAS,EAAE,mDAAa,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,gBAAgB,CAAC,YAAY,EAAE,CAAC,CAAC;iBAC5E,IAAI,CACH,mDAAG,CAAC,CAAC,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,iCAC9B,aAAa,GACb,QAAQ,EACX,CAAC,CACJ,OAEN;AACH,CAAC","sources":["webpack://@prose-reader/core/./src/enhancers/layoutEnhancer/layoutEnhancer.ts?4db3"],"sourcesContent":["import { BehaviorSubject, combineLatest } from \"rxjs\"\nimport { distinctUntilChanged, map, takeUntil, tap, skip } from \"rxjs/operators\"\nimport { Enhancer } from \"../types\"\nimport { createMovingSafePan$ } from \"./createMovingSafePan$\"\nimport { mapKeysTo } from \"../../utils/rxjs\"\nimport { isShallowEqual } from \"../../utils/objects\"\n\nconst SHOULD_NOT_LAYOUT = false\n\ntype SettingsInput = {\n  pageHorizontalMargin?: number,\n  pageVerticalMargin?: number,\n}\n\ntype SettingsOutput = Required<SettingsInput>\n\nexport const layoutEnhancer: Enhancer<SettingsInput & {\n  /**\n   * Can be used to let the reader automatically resize.\n   * `container`: observe and resize the reader whenever the container resize.\n   * `false`: do not automatically resize.\n   */\n  layoutAutoResize?: `container` | false\n}, {}, SettingsInput, SettingsOutput> = (next) => ({ pageHorizontalMargin = 24, pageVerticalMargin = 24, ...options }) => {\n  const reader = next(options)\n  const settingsSubject$ = new BehaviorSubject<SettingsOutput>({\n    pageHorizontalMargin,\n    pageVerticalMargin\n  })\n\n  reader.registerHook(`onViewportOffsetAdjust`, () => {\n    let hasRedrawn = false\n\n    /**\n     * When adjusting the offset, there is a chance that pointer event being dispatched right after\n     * have a wrong `clientX` / `pageX` etc. This is because even if the iframe left value (once requested) is correct,\n     * it does not seem to have been correctly taken by the browser when creating the event.\n     * What we do here is that after a viewport adjustment we immediately force a reflow on the engine.\n     *\n     * @example\n     * [pointer event] -> clientX = 50, left = 0, translated clientX = 50 (CORRECT)\n     * [translate viewport] -> left = +100px\n     * [pointer event] -> clientX = ~50, left = -100, translated clientX = ~-50 (INCORRECT)\n     * [pointer event] -> clientX = 150, left = -100, translated clientX = 50 (CORRECT)\n     *\n     * For some reason the engine must be doing some optimization and unfortunately the first pointer event gets the clientX wrong.\n     *\n     * The bug can be observed by commenting this code, using CPU slowdown and increasing the throttle on the adjustment stream.\n     * The bug seems to affect only chrome / firefox. Nor safari.\n     *\n     * Also we only need to use `getBoundingClientRect` once.\n     *\n     * @todo\n     * Consider creating a bug ticket on both chromium and gecko projects.\n     */\n    reader.manipulateSpineItems(({ frame }) => {\n      if (!hasRedrawn && frame) {\n        /* eslint-disable-next-line no-void */\n        void (frame.getBoundingClientRect().left)\n        hasRedrawn = true\n      }\n\n      return SHOULD_NOT_LAYOUT\n    })\n  })\n\n  /**\n   * Apply margins to frame item\n   * @todo memoize\n   */\n  reader.registerHook(`item.onLayoutBeforeMeasurment`, ({ frame, minimumWidth, item, isImageType }) => {\n    const { pageHorizontalMargin = 0, pageVerticalMargin = 0 } = settingsSubject$.value\n    const pageSize = reader.context.getPageSize()\n\n    if (\n      item.renditionLayout === `reflowable` &&\n      frame.getIsReady() &&\n      !isImageType() &&\n      !frame.getViewportDimensions()\n    ) {\n      let columnWidth = pageSize.width - (pageHorizontalMargin * 2)\n      const columnHeight = pageSize.height - (pageVerticalMargin * 2)\n      let width = pageSize.width - (pageHorizontalMargin * 2)\n      let columnGap = pageHorizontalMargin * 2\n\n      if (frame.isUsingVerticalWriting()) {\n        width = minimumWidth - (pageHorizontalMargin * 2)\n        columnWidth = columnHeight\n        columnGap = pageVerticalMargin * 2\n      }\n\n      frame.getManipulableFrame()?.removeStyle(`prose-layout-enhancer-css`)\n      frame.getManipulableFrame()?.addStyle(`prose-layout-enhancer-css`, `\n        body {\n          width: ${width}px !important;\n          margin: ${pageVerticalMargin}px ${pageHorizontalMargin}px !important;\n          column-gap: ${columnGap}px !important;\n          column-width: ${columnWidth}px !important;\n          height: ${columnHeight}px !important;\n        }\n        img, video, audio, object, svg {\n          max-width: ${columnWidth}px !important;\n          max-height: ${columnHeight}px !important;\n        }\n        table {\n          max-width: ${columnWidth}px !important;\n        }\n        td {\n          max-width: ${columnWidth}px;\n        }\n      `)\n    }\n  })\n\n  // @todo fix the panstart issue\n  // @todo maybe increasing the hammer distance before triggering pan as well\n  // reader.registerHook(`item.onLoad`, ({frame}) => {\n  //   frame.contentDocument?.body.addEventListener(`contextmenu`, e => {\n  //     console.log(`ad`)\n  //     e.preventDefault()\n  //   })\n  // })\n\n  let observer: ResizeObserver | undefined\n\n  if (options.layoutAutoResize === `container`) {\n    observer = new ResizeObserver(() => {\n      reader?.layout()\n    })\n    observer.observe(options.containerElement)\n  }\n\n  const movingSafePan$ = createMovingSafePan$(reader)\n\n  movingSafePan$.subscribe()\n\n  settingsSubject$\n    .pipe(\n      mapKeysTo([`pageHorizontalMargin`, `pageVerticalMargin`]),\n      distinctUntilChanged(isShallowEqual),\n      skip(1),\n      tap(() => {\n        reader.spine.layout()\n      }),\n      takeUntil(reader.$.destroy$)\n    )\n    .subscribe()\n\n  return {\n    ...reader,\n    destroy: () => {\n      reader.destroy()\n      observer?.disconnect()\n    },\n    setSettings: ({ pageVerticalMargin, pageHorizontalMargin, ...rest }) => {\n      if (pageHorizontalMargin !== undefined || pageVerticalMargin !== undefined) {\n        settingsSubject$.next({\n          pageHorizontalMargin: pageHorizontalMargin ?? settingsSubject$.value.pageHorizontalMargin,\n          pageVerticalMargin: pageVerticalMargin ?? settingsSubject$.value.pageVerticalMargin\n        })\n      }\n\n      reader.setSettings(rest)\n    },\n    $: {\n      ...reader.$,\n      settings$: combineLatest([reader.$.settings$, settingsSubject$.asObservable()])\n        .pipe(\n          map(([innerSettings, settings]) => ({\n            ...innerSettings,\n            ...settings\n          }))\n        )\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/layoutEnhancer/layoutEnhancer.ts\n");
|
|
120
|
+
|
|
121
|
+
/***/ }),
|
|
122
|
+
|
|
123
|
+
/***/ "./src/enhancers/links.ts":
|
|
124
|
+
/*!********************************!*\
|
|
125
|
+
!*** ./src/enhancers/links.ts ***!
|
|
126
|
+
\********************************/
|
|
127
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
128
|
+
|
|
129
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"linksEnhancer\": () => (/* binding */ linksEnhancer)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n\n\nconst linksEnhancer = (next) => (options) => {\n const reader = next(options);\n const subject = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const handleNavigationForClick = (element) => {\n var _a;\n if (!element.href)\n return;\n const hrefUrl = new URL(element.href);\n const hrefWithoutAnchor = `${hrefUrl.origin}${hrefUrl.pathname}`;\n const hasExistingSpineItem = (_a = reader.context.getManifest()) === null || _a === void 0 ? void 0 : _a.spineItems.some(item => item.href === hrefWithoutAnchor);\n if (hasExistingSpineItem) {\n reader.goToUrl(hrefUrl);\n }\n };\n reader.registerHook(`item.onLoad`, ({ frame }) => {\n if (frame.contentDocument) {\n Array.from(frame.contentDocument.querySelectorAll(`a`)).forEach(element => element.addEventListener(`click`, (e) => {\n if (e.target && `style` in e.target && `ELEMENT_NODE` in e.target) {\n _report__WEBPACK_IMPORTED_MODULE_1__.Report.warn(`prevented click on`, element, e);\n e.preventDefault();\n handleNavigationForClick(element);\n subject.next({ event: `linkClicked`, data: element });\n }\n }));\n }\n });\n return Object.assign(Object.assign({}, reader), { $: Object.assign(Object.assign({}, reader.$), { links$: subject.asObservable() }) });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL2xpbmtzLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBMEM7QUFDUjtBQUszQixNQUFNLGFBQWEsR0FJckIsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7SUFDekIsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUM1QixNQUFNLE9BQU8sR0FBRyxJQUFJLHlDQUFPLEVBQWU7SUFFMUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLE9BQTBCLEVBQUUsRUFBRTs7UUFDOUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJO1lBQUUsT0FBTTtRQUV6QixNQUFNLE9BQU8sR0FBRyxJQUFJLEdBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQ3JDLE1BQU0saUJBQWlCLEdBQUcsR0FBRyxPQUFPLENBQUMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLEVBQUU7UUFFaEUsTUFBTSxvQkFBb0IsR0FBRyxZQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSwwQ0FBRSxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksS0FBSyxpQkFBaUIsQ0FBQztRQUNuSCxJQUFJLG9CQUFvQixFQUFFO1lBQ3hCLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDO1NBQ3hCO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxZQUFZLENBQUMsYUFBYSxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFO1FBQy9DLElBQUksS0FBSyxDQUFDLGVBQWUsRUFBRTtZQUN6QixLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ2pILElBQUksQ0FBQyxDQUFDLE1BQU0sSUFBSSxPQUFPLElBQUksQ0FBQyxDQUFDLE1BQU0sSUFBSSxjQUFjLElBQUksQ0FBQyxDQUFDLE1BQU0sRUFBRTtvQkFDakUsZ0RBQVcsQ0FBQyxvQkFBb0IsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO29CQUM3QyxDQUFDLENBQUMsY0FBYyxFQUFFO29CQUNsQix3QkFBd0IsQ0FBQyxPQUFPLENBQUM7b0JBQ2pDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztpQkFDdEQ7WUFDSCxDQUFDLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQyxDQUFDO0lBRUYsdUNBQ0ssTUFBTSxLQUNULENBQUMsa0NBQ0ksTUFBTSxDQUFDLENBQUMsS0FDWCxNQUFNLEVBQUUsT0FBTyxDQUFDLFlBQVksRUFBRSxPQUVqQztBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL2xpbmtzLnRzP2NhZjAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gXCJyeGpzXCJcbmltcG9ydCB7IFJlcG9ydCB9IGZyb20gXCIuLi9yZXBvcnRcIlxuaW1wb3J0IHsgRW5oYW5jZXIgfSBmcm9tIFwiLi90eXBlc1wiXG5cbnR5cGUgU3ViamVjdERhdGEgPSB7IGV2ZW50OiBgbGlua0NsaWNrZWRgLCBkYXRhOiBIVE1MQW5jaG9yRWxlbWVudCB9XG5cbmV4cG9ydCBjb25zdCBsaW5rc0VuaGFuY2VyOiBFbmhhbmNlcjx7fSwge1xuICAkOiB7XG4gICAgbGlua3MkOiBPYnNlcnZhYmxlPFN1YmplY3REYXRhPlxuICB9XG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG4gIGNvbnN0IHN1YmplY3QgPSBuZXcgU3ViamVjdDxTdWJqZWN0RGF0YT4oKVxuXG4gIGNvbnN0IGhhbmRsZU5hdmlnYXRpb25Gb3JDbGljayA9IChlbGVtZW50OiBIVE1MQW5jaG9yRWxlbWVudCkgPT4ge1xuICAgIGlmICghZWxlbWVudC5ocmVmKSByZXR1cm5cblxuICAgIGNvbnN0IGhyZWZVcmwgPSBuZXcgVVJMKGVsZW1lbnQuaHJlZilcbiAgICBjb25zdCBocmVmV2l0aG91dEFuY2hvciA9IGAke2hyZWZVcmwub3JpZ2lufSR7aHJlZlVybC5wYXRobmFtZX1gXG4gICAgLy8gaW50ZXJuYWwgbGluaywgd2UgY2FuIGhhbmRsZVxuICAgIGNvbnN0IGhhc0V4aXN0aW5nU3BpbmVJdGVtID0gcmVhZGVyLmNvbnRleHQuZ2V0TWFuaWZlc3QoKT8uc3BpbmVJdGVtcy5zb21lKGl0ZW0gPT4gaXRlbS5ocmVmID09PSBocmVmV2l0aG91dEFuY2hvcilcbiAgICBpZiAoaGFzRXhpc3RpbmdTcGluZUl0ZW0pIHtcbiAgICAgIHJlYWRlci5nb1RvVXJsKGhyZWZVcmwpXG4gICAgfVxuICB9XG5cbiAgcmVhZGVyLnJlZ2lzdGVySG9vayhgaXRlbS5vbkxvYWRgLCAoeyBmcmFtZSB9KSA9PiB7XG4gICAgaWYgKGZyYW1lLmNvbnRlbnREb2N1bWVudCkge1xuICAgICAgQXJyYXkuZnJvbShmcmFtZS5jb250ZW50RG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbChgYWApKS5mb3JFYWNoKGVsZW1lbnQgPT4gZWxlbWVudC5hZGRFdmVudExpc3RlbmVyKGBjbGlja2AsIChlKSA9PiB7XG4gICAgICAgIGlmIChlLnRhcmdldCAmJiBgc3R5bGVgIGluIGUudGFyZ2V0ICYmIGBFTEVNRU5UX05PREVgIGluIGUudGFyZ2V0KSB7XG4gICAgICAgICAgUmVwb3J0Lndhcm4oYHByZXZlbnRlZCBjbGljayBvbmAsIGVsZW1lbnQsIGUpXG4gICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpXG4gICAgICAgICAgaGFuZGxlTmF2aWdhdGlvbkZvckNsaWNrKGVsZW1lbnQpXG4gICAgICAgICAgc3ViamVjdC5uZXh0KHsgZXZlbnQ6IGBsaW5rQ2xpY2tlZGAsIGRhdGE6IGVsZW1lbnQgfSlcbiAgICAgICAgfVxuICAgICAgfSkpXG4gICAgfVxuICB9KVxuXG4gIHJldHVybiB7XG4gICAgLi4ucmVhZGVyLFxuICAgICQ6IHtcbiAgICAgIC4uLnJlYWRlci4kLFxuICAgICAgbGlua3MkOiBzdWJqZWN0LmFzT2JzZXJ2YWJsZSgpXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/enhancers/links.ts\n");
|
|
130
|
+
|
|
131
|
+
/***/ }),
|
|
132
|
+
|
|
133
|
+
/***/ "./src/enhancers/media.ts":
|
|
134
|
+
/*!********************************!*\
|
|
135
|
+
!*** ./src/enhancers/media.ts ***!
|
|
136
|
+
\********************************/
|
|
137
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
138
|
+
|
|
139
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"mediaEnhancer\": () => (/* binding */ mediaEnhancer)\n/* harmony export */ });\nconst mediaEnhancer = (next) => (options) => {\n const reader = next(options);\n const frameObserver = new IntersectionObserver((entries) => {\n entries.forEach(entry => {\n var _a;\n const frame = entry.target;\n const audios = Array.from(((_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.body.getElementsByTagName(`audio`)) || []);\n if (!entry.isIntersecting) {\n audios.forEach(audioElement => {\n audioElement.pause();\n audioElement.currentTime = 0;\n });\n }\n else {\n audios.forEach(audioElement => {\n if (audioElement.hasAttribute(`autoplay`) && audioElement.paused && audioElement.readyState >= 2) {\n audioElement.play().catch(console.error);\n }\n });\n }\n });\n }, {\n threshold: 0.01\n });\n const elementObserver = new IntersectionObserver((entries) => {\n entries.forEach(entry => {\n if (entry.target.tagName === `video`) {\n const video = entry.target;\n if (!entry.isIntersecting) {\n video.pause();\n video.currentTime = 0;\n }\n else {\n if (video.hasAttribute(`autoplay`)) {\n if (video.paused && video.readyState >= 2) {\n video.play().catch(console.error);\n }\n }\n }\n }\n });\n }, {\n threshold: 0.5\n });\n reader.registerHook(`item.onLoad`, ({ frame }) => {\n var _a;\n frameObserver.observe(frame);\n const videos = (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.body.getElementsByTagName(`video`);\n const unobserveElements = Array.from(videos || []).map(element => {\n elementObserver.observe(element);\n return () => elementObserver.unobserve(element);\n });\n return () => {\n frameObserver.unobserve(frame);\n unobserveElements.forEach(unobserve => unobserve());\n };\n });\n const destroy = () => {\n frameObserver.disconnect();\n elementObserver.disconnect();\n reader.destroy();\n };\n return Object.assign(Object.assign({}, reader), { destroy });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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QUVGLE9BQU8sR0FBRyxFQUFFO1lBQ1YsYUFBYSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDOUIsaUJBQWlCLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDckQsQ0FBQztJQUNILENBQUMsQ0FBQztJQUVGLE1BQU0sT0FBTyxHQUFHLEdBQUcsRUFBRTtRQUNuQixhQUFhLENBQUMsVUFBVSxFQUFFO1FBQzFCLGVBQWUsQ0FBQyxVQUFVLEVBQUU7UUFDNUIsTUFBTSxDQUFDLE9BQU8sRUFBRTtJQUNsQixDQUFDO0lBRUQsdUNBQ0ssTUFBTSxLQUNULE9BQU8sSUFDUjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL21lZGlhLnRzP2M3ZjAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRW5oYW5jZXIgfSBmcm9tIFwiLi90eXBlc1wiXG5cbmV4cG9ydCBjb25zdCBtZWRpYUVuaGFuY2VyOiBFbmhhbmNlcjx7fSwge1xuXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG5cbiAgY29uc3QgZnJhbWVPYnNlcnZlciA9IG5ldyBJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllcykgPT4ge1xuICAgIGVudHJpZXMuZm9yRWFjaChlbnRyeSA9PiB7XG4gICAgICBjb25zdCBmcmFtZSA9IGVudHJ5LnRhcmdldCBhcyBIVE1MSUZyYW1lRWxlbWVudFxuICAgICAgY29uc3QgYXVkaW9zID0gQXJyYXkuZnJvbShmcmFtZS5jb250ZW50RG9jdW1lbnQ/LmJvZHkuZ2V0RWxlbWVudHNCeVRhZ05hbWUoYGF1ZGlvYCkgfHwgW10pXG5cbiAgICAgIGlmICghZW50cnkuaXNJbnRlcnNlY3RpbmcpIHtcbiAgICAgICAgYXVkaW9zLmZvckVhY2goYXVkaW9FbGVtZW50ID0+IHtcbiAgICAgICAgICBhdWRpb0VsZW1lbnQucGF1c2UoKVxuICAgICAgICAgIGF1ZGlvRWxlbWVudC5jdXJyZW50VGltZSA9IDBcbiAgICAgICAgfSlcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGF1ZGlvcy5mb3JFYWNoKGF1ZGlvRWxlbWVudCA9PiB7XG4gICAgICAgICAgaWYgKGF1ZGlvRWxlbWVudC5oYXNBdHRyaWJ1dGUoYGF1dG9wbGF5YCkgJiYgYXVkaW9FbGVtZW50LnBhdXNlZCAmJiBhdWRpb0VsZW1lbnQucmVhZHlTdGF0ZSA+PSAyKSB7XG4gICAgICAgICAgICBhdWRpb0VsZW1lbnQucGxheSgpLmNhdGNoKGNvbnNvbGUuZXJyb3IpXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfVxuICAgIH0pXG4gIH0sIHtcbiAgICB0aHJlc2hvbGQ6IDAuMDFcbiAgfSlcblxuICBjb25zdCBlbGVtZW50T2JzZXJ2ZXIgPSBuZXcgSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoKGVudHJpZXMpID0+IHtcbiAgICBlbnRyaWVzLmZvckVhY2goZW50cnkgPT4ge1xuICAgICAgaWYgKGVudHJ5LnRhcmdldC50YWdOYW1lID09PSBgdmlkZW9gKSB7XG4gICAgICAgIGNvbnN0IHZpZGVvID0gZW50cnkudGFyZ2V0IGFzIEhUTUxWaWRlb0VsZW1lbnRcbiAgICAgICAgaWYgKCFlbnRyeS5pc0ludGVyc2VjdGluZykge1xuICAgICAgICAgIHZpZGVvLnBhdXNlKClcbiAgICAgICAgICB2aWRlby5jdXJyZW50VGltZSA9IDBcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBpZiAodmlkZW8uaGFzQXR0cmlidXRlKGBhdXRvcGxheWApKSB7XG4gICAgICAgICAgICAvLyB0aGlzIGNhbiBmYWlsIHdoZW4gd2UgcGxheSB0aGUgZmlyc3QgdGltZSBkdWUgdG8gdXNlciBub3QgaGF2aW5nIGludGVyYWN0ZWQgd2l0aFxuICAgICAgICAgICAgLy8gZG9jdW1lbnQgeWV0LiBCcm93c2VycyBwb2xpY3kuIGF1dG9wbGF5IHdpbGwgcGxheSBpdCB0aGUgZmlyc3QgdGltZSBhbnl3YXkuXG4gICAgICAgICAgICBpZiAodmlkZW8ucGF1c2VkICYmIHZpZGVvLnJlYWR5U3RhdGUgPj0gMikge1xuICAgICAgICAgICAgICB2aWRlby5wbGF5KCkuY2F0Y2goY29uc29sZS5lcnJvcilcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KVxuICB9LCB7XG4gICAgdGhyZXNob2xkOiAwLjVcbiAgfSlcblxuICByZWFkZXIucmVnaXN0ZXJIb29rKGBpdGVtLm9uTG9hZGAsICh7IGZyYW1lIH0pID0+IHtcbiAgICBmcmFtZU9ic2VydmVyLm9ic2VydmUoZnJhbWUpXG5cbiAgICBjb25zdCB2aWRlb3MgPSBmcmFtZS5jb250ZW50RG9jdW1lbnQ/LmJvZHkuZ2V0RWxlbWVudHNCeVRhZ05hbWUoYHZpZGVvYClcblxuICAgIGNvbnN0IHVub2JzZXJ2ZUVsZW1lbnRzID0gQXJyYXkuZnJvbSh2aWRlb3MgfHwgW10pLm1hcChlbGVtZW50ID0+IHtcbiAgICAgIGVsZW1lbnRPYnNlcnZlci5vYnNlcnZlKGVsZW1lbnQpXG5cbiAgICAgIHJldHVybiAoKSA9PiBlbGVtZW50T2JzZXJ2ZXIudW5vYnNlcnZlKGVsZW1lbnQpXG4gICAgfSlcblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBmcmFtZU9ic2VydmVyLnVub2JzZXJ2ZShmcmFtZSlcbiAgICAgIHVub2JzZXJ2ZUVsZW1lbnRzLmZvckVhY2godW5vYnNlcnZlID0+IHVub2JzZXJ2ZSgpKVxuICAgIH1cbiAgfSlcblxuICBjb25zdCBkZXN0cm95ID0gKCkgPT4ge1xuICAgIGZyYW1lT2JzZXJ2ZXIuZGlzY29ubmVjdCgpXG4gICAgZWxlbWVudE9ic2VydmVyLmRpc2Nvbm5lY3QoKVxuICAgIHJlYWRlci5kZXN0cm95KClcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgLi4ucmVhZGVyLFxuICAgIGRlc3Ryb3lcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/enhancers/media.ts\n");
|
|
140
|
+
|
|
141
|
+
/***/ }),
|
|
142
|
+
|
|
143
|
+
/***/ "./src/enhancers/navigation.ts":
|
|
144
|
+
/*!*************************************!*\
|
|
145
|
+
!*** ./src/enhancers/navigation.ts ***!
|
|
146
|
+
\*************************************/
|
|
147
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
148
|
+
|
|
149
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"navigationEnhancer\": () => (/* binding */ navigationEnhancer)\n/* harmony export */ });\nconst navigationEnhancer = (next) => (options) => {\n const reader = next(options);\n const goToNextSpineItem = () => {\n var _a, _b;\n const focusedSpineItemIndex = reader.getFocusedSpineItemIndex() || 0;\n const { end = focusedSpineItemIndex } = reader.locator.getSpineItemsFromReadingOrderPosition(reader.getCurrentNavigationPosition()) || {};\n const numberOfSpineItems = (_b = (_a = reader.context.getManifest()) === null || _a === void 0 ? void 0 : _a.spineItems.length) !== null && _b !== void 0 ? _b : 0;\n const nextItem = end + 1;\n if (nextItem < numberOfSpineItems) {\n reader.goToSpineItem(nextItem);\n }\n };\n const goToPreviousSpineItem = () => {\n const focusedSpineItemIndex = reader.getFocusedSpineItemIndex() || 0;\n const { begin = focusedSpineItemIndex } = reader.locator.getSpineItemsFromReadingOrderPosition(reader.getCurrentNavigationPosition()) || {};\n const nextItem = begin - 1;\n if (nextItem >= 0) {\n reader.goToSpineItem(nextItem);\n }\n };\n return Object.assign(Object.assign({}, reader), { goToLeftSpineItem: () => {\n if (reader.context.isRTL()) {\n return goToNextSpineItem();\n }\n return goToPreviousSpineItem();\n }, goToRightSpineItem: () => {\n if (reader.context.isRTL()) {\n return goToPreviousSpineItem();\n }\n return goToNextSpineItem();\n } });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL25hdmlnYXRpb24udHMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUtPLE1BQU0sa0JBQWtCLEdBRzFCLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO0lBQ3pCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7SUFFNUIsTUFBTSxpQkFBaUIsR0FBRyxHQUFHLEVBQUU7O1FBQzdCLE1BQU0scUJBQXFCLEdBQUcsTUFBTSxDQUFDLHdCQUF3QixFQUFFLElBQUksQ0FBQztRQUNwRSxNQUFNLEVBQUUsR0FBRyxHQUFHLHFCQUFxQixFQUFFLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxxQ0FBcUMsQ0FBQyxNQUFNLENBQUMsNEJBQTRCLEVBQUUsQ0FBQyxJQUFJLEVBQUU7UUFDekksTUFBTSxrQkFBa0IsR0FBRyxrQkFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsMENBQUUsVUFBVSxDQUFDLE1BQU0sbUNBQUksQ0FBQztRQUMvRSxNQUFNLFFBQVEsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUN4QixJQUFJLFFBQVEsR0FBRyxrQkFBa0IsRUFBRTtZQUNqQyxNQUFNLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQztTQUMvQjtJQUNILENBQUM7SUFFRCxNQUFNLHFCQUFxQixHQUFHLEdBQUcsRUFBRTtRQUNqQyxNQUFNLHFCQUFxQixHQUFHLE1BQU0sQ0FBQyx3QkFBd0IsRUFBRSxJQUFJLENBQUM7UUFDcEUsTUFBTSxFQUFFLEtBQUssR0FBRyxxQkFBcUIsRUFBRSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMscUNBQXFDLENBQUMsTUFBTSxDQUFDLDRCQUE0QixFQUFFLENBQUMsSUFBSSxFQUFFO1FBQzNJLE1BQU0sUUFBUSxHQUFHLEtBQUssR0FBRyxDQUFDO1FBQzFCLElBQUksUUFBUSxJQUFJLENBQUMsRUFBRTtZQUNqQixNQUFNLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQztTQUMvQjtJQUNILENBQUM7SUFFRCx1Q0FDSyxNQUFNLEtBQ1QsaUJBQWlCLEVBQUUsR0FBRyxFQUFFO1lBQ3RCLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDMUIsT0FBTyxpQkFBaUIsRUFBRTthQUMzQjtZQUVELE9BQU8scUJBQXFCLEVBQUU7UUFDaEMsQ0FBQyxFQUNELGtCQUFrQixFQUFFLEdBQUcsRUFBRTtZQUN2QixJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQzFCLE9BQU8scUJBQXFCLEVBQUU7YUFDL0I7WUFFRCxPQUFPLGlCQUFpQixFQUFFO1FBQzVCLENBQUMsSUFDRjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL25hdmlnYXRpb24udHM/Y2VlNSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE9mZmVyIGV4dHJhIGNvbnZlbmllbnQgbWV0aG9kcyBmb3IgbmF2aWdhdGlvbi5cbiAqL1xuaW1wb3J0IHsgRW5oYW5jZXIgfSBmcm9tIFwiLi90eXBlc1wiXG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0aW9uRW5oYW5jZXI6IEVuaGFuY2VyPHt9LCB7XG4gIGdvVG9MZWZ0U3BpbmVJdGVtOiAoKSA9PiB2b2lkLFxuICBnb1RvUmlnaHRTcGluZUl0ZW06ICgpID0+IHZvaWQsXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG5cbiAgY29uc3QgZ29Ub05leHRTcGluZUl0ZW0gPSAoKSA9PiB7XG4gICAgY29uc3QgZm9jdXNlZFNwaW5lSXRlbUluZGV4ID0gcmVhZGVyLmdldEZvY3VzZWRTcGluZUl0ZW1JbmRleCgpIHx8IDBcbiAgICBjb25zdCB7IGVuZCA9IGZvY3VzZWRTcGluZUl0ZW1JbmRleCB9ID0gcmVhZGVyLmxvY2F0b3IuZ2V0U3BpbmVJdGVtc0Zyb21SZWFkaW5nT3JkZXJQb3NpdGlvbihyZWFkZXIuZ2V0Q3VycmVudE5hdmlnYXRpb25Qb3NpdGlvbigpKSB8fCB7fVxuICAgIGNvbnN0IG51bWJlck9mU3BpbmVJdGVtcyA9IHJlYWRlci5jb250ZXh0LmdldE1hbmlmZXN0KCk/LnNwaW5lSXRlbXMubGVuZ3RoID8/IDBcbiAgICBjb25zdCBuZXh0SXRlbSA9IGVuZCArIDFcbiAgICBpZiAobmV4dEl0ZW0gPCBudW1iZXJPZlNwaW5lSXRlbXMpIHtcbiAgICAgIHJlYWRlci5nb1RvU3BpbmVJdGVtKG5leHRJdGVtKVxuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGdvVG9QcmV2aW91c1NwaW5lSXRlbSA9ICgpID0+IHtcbiAgICBjb25zdCBmb2N1c2VkU3BpbmVJdGVtSW5kZXggPSByZWFkZXIuZ2V0Rm9jdXNlZFNwaW5lSXRlbUluZGV4KCkgfHwgMFxuICAgIGNvbnN0IHsgYmVnaW4gPSBmb2N1c2VkU3BpbmVJdGVtSW5kZXggfSA9IHJlYWRlci5sb2NhdG9yLmdldFNwaW5lSXRlbXNGcm9tUmVhZGluZ09yZGVyUG9zaXRpb24ocmVhZGVyLmdldEN1cnJlbnROYXZpZ2F0aW9uUG9zaXRpb24oKSkgfHwge31cbiAgICBjb25zdCBuZXh0SXRlbSA9IGJlZ2luIC0gMVxuICAgIGlmIChuZXh0SXRlbSA+PSAwKSB7XG4gICAgICByZWFkZXIuZ29Ub1NwaW5lSXRlbShuZXh0SXRlbSlcbiAgICB9XG4gIH1cblxuICByZXR1cm4ge1xuICAgIC4uLnJlYWRlcixcbiAgICBnb1RvTGVmdFNwaW5lSXRlbTogKCkgPT4ge1xuICAgICAgaWYgKHJlYWRlci5jb250ZXh0LmlzUlRMKCkpIHtcbiAgICAgICAgcmV0dXJuIGdvVG9OZXh0U3BpbmVJdGVtKClcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGdvVG9QcmV2aW91c1NwaW5lSXRlbSgpXG4gICAgfSxcbiAgICBnb1RvUmlnaHRTcGluZUl0ZW06ICgpID0+IHtcbiAgICAgIGlmIChyZWFkZXIuY29udGV4dC5pc1JUTCgpKSB7XG4gICAgICAgIHJldHVybiBnb1RvUHJldmlvdXNTcGluZUl0ZW0oKVxuICAgICAgfVxuXG4gICAgICByZXR1cm4gZ29Ub05leHRTcGluZUl0ZW0oKVxuICAgIH1cbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/enhancers/navigation.ts\n");
|
|
150
|
+
|
|
151
|
+
/***/ }),
|
|
152
|
+
|
|
153
|
+
/***/ "./src/enhancers/pagination.ts":
|
|
154
|
+
/*!*************************************!*\
|
|
155
|
+
!*** ./src/enhancers/pagination.ts ***!
|
|
156
|
+
\*************************************/
|
|
157
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
158
|
+
|
|
159
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"paginationEnhancer\": () => (/* binding */ paginationEnhancer),\n/* harmony export */ \"buildChapterInfoFromSpineItem\": () => (/* binding */ buildChapterInfoFromSpineItem)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _pagination__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../pagination */ \"./src/pagination.ts\");\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/objects */ \"./src/utils/objects.ts\");\n\n\n\n\n\nconst NAMESPACE = `paginationEnhancer`;\nconst report = _report__WEBPACK_IMPORTED_MODULE_3__.Report.namespace(NAMESPACE);\nconst paginationEnhancer = (next) => (options) => {\n const reader = next(options);\n const chaptersInfo = {};\n const getChapterInfo = (item) => {\n const manifest = reader.context.getManifest();\n return item && manifest && buildChapterInfoFromSpineItem(manifest, item);\n };\n const mapPaginationInfoToExtendedInfo = (paginationInfo) => {\n var _a;\n const context = reader.context;\n const beginItem = paginationInfo.beginSpineItemIndex !== undefined\n ? reader.getSpineItem(paginationInfo.beginSpineItemIndex)\n : undefined;\n const endItem = paginationInfo.endSpineItemIndex !== undefined\n ? reader.getSpineItem(paginationInfo.endSpineItemIndex)\n : undefined;\n return {\n beginPageIndexInChapter: paginationInfo.beginPageIndex,\n beginNumberOfPagesInChapter: paginationInfo.beginNumberOfPages,\n beginChapterInfo: beginItem ? chaptersInfo[beginItem.item.id] : undefined,\n beginSpineItemIndex: paginationInfo.beginSpineItemIndex,\n beginCfi: paginationInfo.beginCfi,\n beginSpineItemReadingDirection: beginItem === null || beginItem === void 0 ? void 0 : beginItem.getReadingDirection(),\n endChapterInfo: endItem ? chaptersInfo[endItem.item.id] : undefined,\n endPageIndexInChapter: paginationInfo.endPageIndex,\n endNumberOfPagesInChapter: paginationInfo.endNumberOfPages,\n endSpineItemIndex: paginationInfo.endSpineItemIndex,\n endSpineItemReadingDirection: endItem === null || endItem === void 0 ? void 0 : endItem.getReadingDirection(),\n endCfi: paginationInfo.endCfi,\n percentageEstimateOfBook: endItem\n ? reader.progression.getPercentageEstimate(context, (_a = paginationInfo.endSpineItemIndex) !== null && _a !== void 0 ? _a : 0, paginationInfo.endNumberOfPages, paginationInfo.endPageIndex || 0, reader.getCurrentViewportPosition(), endItem)\n : 0,\n isUsingSpread: context.shouldDisplaySpread()\n };\n };\n const getSpineItemNumberOfPages = (spineItem) => {\n const writingMode = spineItem.spineItemFrame.getWritingMode();\n const { width, height } = spineItem.getElementDimensions();\n if (writingMode === `vertical-rl`) {\n return (0,_pagination__WEBPACK_IMPORTED_MODULE_2__.getNumberOfPages)(height, reader.context.getPageSize().height);\n }\n return (0,_pagination__WEBPACK_IMPORTED_MODULE_2__.getNumberOfPages)(width, reader.context.getPageSize().width);\n };\n const getTotalNumberOfPages = () => {\n const numberOfPagesPerItems = reader.getSpineItems().map((item) => {\n return getSpineItemNumberOfPages(item);\n }, 0);\n const totalNumberOfPages = numberOfPagesPerItems\n .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, 0);\n return {\n numberOfPagesPerItems,\n totalNumberOfPages\n };\n };\n const mapPaginationInfoToTotalPagesInfo = ({ endSpineItemIndex, endPageIndex, beginSpineItemIndex, beginPageIndex }) => {\n const { totalNumberOfPages, numberOfPagesPerItems } = getTotalNumberOfPages();\n return {\n beginAbsolutePageIndex: numberOfPagesPerItems\n .slice(0, beginSpineItemIndex)\n .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, beginPageIndex !== null && beginPageIndex !== void 0 ? beginPageIndex : 0),\n endAbsolutePageIndex: numberOfPagesPerItems\n .slice(0, endSpineItemIndex)\n .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, endPageIndex !== null && endPageIndex !== void 0 ? endPageIndex : 0),\n numberOfTotalPages: totalNumberOfPages\n };\n };\n reader.registerHook(`item.onCreated`, ({ item }) => {\n chaptersInfo[item.id] = getChapterInfo(item);\n return () => { };\n });\n const paginationExtendedInfo = reader.$.pagination$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(mapPaginationInfoToExtendedInfo), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_4__.isShallowEqual));\n const totalPages$ = reader.$.layout$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.debounceTime)(10, rxjs__WEBPACK_IMPORTED_MODULE_0__.animationFrameScheduler), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(reader.$.pagination$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(([, paginationInfo]) => mapPaginationInfoToTotalPagesInfo(paginationInfo)), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_4__.isShallowEqual), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.startWith)({\n beginAbsolutePageIndex: 0,\n endAbsolutePageIndex: 0,\n numberOfTotalPages: 0\n }));\n return Object.assign(Object.assign({}, reader), { $: Object.assign(Object.assign({}, reader.$), { pagination$: (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.combineLatest)([paginationExtendedInfo, totalPages$])\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(([a, b]) => (Object.assign(Object.assign({}, a), b))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)((data) => {\n report.log(`pagination`, data);\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.shareReplay)(1)) }) });\n};\nconst buildChapterInfoFromSpineItem = (manifest, item) => {\n const { path } = item;\n return getChapterInfo(path, manifest.nav.toc);\n};\nconst getChapterInfo = (path, tocItems) => {\n return tocItems.reduce((acc, tocItem) => {\n const indexOfHash = tocItem.path.indexOf(`#`);\n const tocItemPathWithoutAnchor = indexOfHash > 0 ? tocItem.path.substr(0, indexOfHash) : tocItem.path;\n if (path.endsWith(tocItemPathWithoutAnchor)) {\n return {\n title: tocItem.title,\n path: tocItem.path\n };\n }\n const subInfo = getChapterInfo(path, tocItem.contents);\n if (subInfo) {\n return {\n subChapter: subInfo,\n title: tocItem.title,\n path: tocItem.path\n };\n }\n return acc;\n }, undefined);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/pagination.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/enhancers/pagination.ts?a3a5"],"sourcesContent":["import { animationFrameScheduler, combineLatest, Observable, ObservedValueOf } from \"rxjs\"\nimport { map, debounceTime, tap, startWith, shareReplay, distinctUntilChanged, withLatestFrom } from \"rxjs/operators\"\nimport { Enhancer } from \"./types\"\nimport { SpineItem } from \"../spineItem/createSpineItem\"\nimport { Manifest } from \"../types\"\nimport { progressionEnhancer } from \"./progression\"\nimport { getNumberOfPages } from \"../pagination\"\nimport { Report } from \"../report\"\nimport { isShallowEqual } from \"../utils/objects\"\n\nconst NAMESPACE = `paginationEnhancer`\n\nconst report = Report.namespace(NAMESPACE)\n\n/**\n * @todo\n * Using recursive here provoke this error\n * https://www.google.com/search?q=recursive+Exported+variable+has+or+is+using+namefrom+external+module+but+cannot+be+named.&rlz=1C5CHFA_en&sxsrf=AOaemvK4craypli45-fXfFRdfO82ibGRog%3A1631106978791&ei=orc4YZPUL-6tmAWJgKT4Dw&oq=recursive+Exported+variable+has+or+is+using+namefrom+external+module+but+cannot+be+named.&gs_lcp=Cgdnd3Mtd2l6EAM6BwgAEEcQsANKBAhBGABQjgdYjgdgtQtoAnACeACAAWGIAWGSAQExmAEAoAEByAEIwAEB&sclient=gws-wiz&ved=0ahUKEwiTrb6Au-_yAhXuFqYKHQkACf8Q4dUDCA4&uact=5\n * My guess is that something is wrong and I have too many recursive / inferred types everywhere and especially on the enhancer thingy.\n */\ntype ChapterInfo = {\n  title: string\n  subChapter?: {\n    title: string\n    subChapter?: {\n      title: string\n      subChapter?: {\n        title: string\n        path: string\n      },\n      path: string\n    },\n    path: string\n  },\n  path: string\n}\n\ntype PaginationInfo = {\n  beginChapterInfo: ChapterInfo | undefined\n  beginPageIndexInChapter: number | undefined,\n  beginNumberOfPagesInChapter: number | undefined,\n  beginSpineItemIndex: number | undefined,\n  beginCfi: string | undefined,\n  beginSpineItemReadingDirection: `rtl` | `ltr` | undefined,\n  beginAbsolutePageIndex: number | undefined,\n  endChapterInfo: ChapterInfo | undefined\n  endPageIndexInChapter: number | undefined,\n  endNumberOfPagesInChapter: number | undefined,\n  endSpineItemIndex: number | undefined,\n  endCfi: string | undefined,\n  endSpineItemReadingDirection: `rtl` | `ltr` | undefined,\n  endAbsolutePageIndex: number | undefined,\n  percentageEstimateOfBook: number | undefined,\n  /**\n   * @warning\n   * This value is only correct for pre-paginated books and or\n   * if you preload the entire book in case of reflow. This is because\n   * items get loaded unloaded when navigating through the book, meaning\n   * we cannot measure the number of pages accurately.\n   */\n  numberOfTotalPages: number | undefined,\n  isUsingSpread: boolean,\n  // numberOfSpineItems: number | undefined\n}\n\nexport const paginationEnhancer: Enhancer<{}, {\n  $: {\n    pagination$: Observable<PaginationInfo>\n  }\n}, {}, {}, typeof progressionEnhancer> = (next) => (options) => {\n  const reader = next(options)\n  const chaptersInfo: { [key: string]: ChapterInfo | undefined } = {}\n\n  const getChapterInfo = (item: Manifest[`spineItems`][number]) => {\n    const manifest = reader.context.getManifest()\n    return item && manifest && buildChapterInfoFromSpineItem(manifest, item)\n  }\n\n  const mapPaginationInfoToExtendedInfo = (paginationInfo: ObservedValueOf<typeof reader[`$`][`pagination$`]>) => {\n    const context = reader.context\n    const beginItem = paginationInfo.beginSpineItemIndex !== undefined\n      ? reader.getSpineItem(paginationInfo.beginSpineItemIndex)\n      : undefined\n    const endItem = paginationInfo.endSpineItemIndex !== undefined\n      ? reader.getSpineItem(paginationInfo.endSpineItemIndex)\n      : undefined\n\n    return {\n      beginPageIndexInChapter: paginationInfo.beginPageIndex,\n      beginNumberOfPagesInChapter: paginationInfo.beginNumberOfPages,\n      beginChapterInfo: beginItem ? chaptersInfo[beginItem.item.id] : undefined,\n      // chapterIndex: number;\n      // pages: number;\n      // pageIndexInBook: number;\n      // pageIndexInChapter: number;\n      // pagesOfChapter: number;\n      // pagePercentageInChapter: number;\n      // offsetPercentageInChapter: number;\n      // domIndex: number;\n      // charOffset: number;\n      // serializeString?: string;\n      beginSpineItemIndex: paginationInfo.beginSpineItemIndex,\n      // spineItemPath: beginItem?.item.path,\n      // spineItemId: beginItem?.item.id,\n      beginCfi: paginationInfo.beginCfi,\n      beginSpineItemReadingDirection: beginItem?.getReadingDirection(),\n      endChapterInfo: endItem ? chaptersInfo[endItem.item.id] : undefined,\n      endPageIndexInChapter: paginationInfo.endPageIndex,\n      endNumberOfPagesInChapter: paginationInfo.endNumberOfPages,\n      endSpineItemIndex: paginationInfo.endSpineItemIndex,\n      // spineItemPath: endItem?.item.path,\n      // spineItemId: endItem?.item.id,\n      endSpineItemReadingDirection: endItem?.getReadingDirection(),\n      endCfi: paginationInfo.endCfi,\n      // end: ReadingLocation;\n      // spineItemReadingDirection: focusedSpineItem?.getReadingDirection(),\n      /**\n       * This percentage is based of the weight (kb) of every items and the number of pages.\n       * It is not accurate but gives a general good idea of the overall progress.\n       * It is recommended to use this progress only for reflow books. For pre-paginated books\n       * the number of pages and current index can be used instead since 1 page = 1 chapter.\n       */\n      percentageEstimateOfBook: endItem\n        ? reader.progression.getPercentageEstimate(\n          context,\n          paginationInfo.endSpineItemIndex ?? 0,\n          paginationInfo.endNumberOfPages,\n          paginationInfo.endPageIndex || 0,\n          reader.getCurrentViewportPosition(),\n          endItem\n        )\n        : 0,\n      isUsingSpread: context.shouldDisplaySpread()\n      // chaptersOfBook: number;\n      // chapter: string;\n      // hasNextChapter: (reader.spine.spineItemIndex || 0) < (manifest.readingOrder.length - 1),\n      // hasPreviousChapter: (reader.spine.spineItemIndex || 0) < (manifest.readingOrder.length - 1),\n      // numberOfSpineItems: context.getManifest()?.readingOrder.length,\n    }\n  }\n\n  const getSpineItemNumberOfPages = (spineItem: SpineItem) => {\n    // pre-paginated always are only one page\n    // if (!spineItem.isReflowable) return 1\n\n    const writingMode = spineItem.spineItemFrame.getWritingMode()\n    const { width, height } = spineItem.getElementDimensions()\n\n    if (writingMode === `vertical-rl`) {\n      return getNumberOfPages(height, reader.context.getPageSize().height)\n    }\n\n    return getNumberOfPages(width, reader.context.getPageSize().width)\n  }\n\n  const getTotalNumberOfPages = () => {\n    const numberOfPagesPerItems = reader.getSpineItems().map((item) => {\n      return getSpineItemNumberOfPages(item)\n    }, 0)\n\n    const totalNumberOfPages = numberOfPagesPerItems\n      .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, 0)\n\n    return {\n      numberOfPagesPerItems,\n      totalNumberOfPages\n    }\n    // @todo trigger change to pagination info (+ memo if number is same)\n  }\n\n  const mapPaginationInfoToTotalPagesInfo = ({ endSpineItemIndex, endPageIndex, beginSpineItemIndex, beginPageIndex }: ObservedValueOf<typeof reader[`$`][`pagination$`]>) => {\n    const { totalNumberOfPages, numberOfPagesPerItems } = getTotalNumberOfPages()\n\n    return {\n      beginAbsolutePageIndex: numberOfPagesPerItems\n        .slice(0, beginSpineItemIndex)\n        .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, beginPageIndex ?? 0),\n      endAbsolutePageIndex: numberOfPagesPerItems\n        .slice(0, endSpineItemIndex)\n        .reduce((acc, numberOfPagesForItem) => acc + numberOfPagesForItem, endPageIndex ?? 0),\n      /**\n       * This may be not accurate for reflowable due to dynamic load / unload.\n       */\n      numberOfTotalPages: totalNumberOfPages\n    }\n  }\n\n  reader.registerHook(`item.onCreated`, ({ item }) => {\n    chaptersInfo[item.id] = getChapterInfo(item)\n\n    return () => { }\n  })\n\n  const paginationExtendedInfo = reader.$.pagination$\n    .pipe(\n      map(mapPaginationInfoToExtendedInfo),\n      distinctUntilChanged(isShallowEqual)\n    )\n\n  const totalPages$ = reader.$.layout$\n    .pipe(\n      debounceTime(10, animationFrameScheduler),\n      withLatestFrom(reader.$.pagination$),\n      map(([, paginationInfo]) => mapPaginationInfoToTotalPagesInfo(paginationInfo)),\n      distinctUntilChanged(isShallowEqual),\n      startWith({\n        beginAbsolutePageIndex: 0,\n        endAbsolutePageIndex: 0,\n        numberOfTotalPages: 0\n      })\n    )\n\n  return {\n    ...reader,\n    $: {\n      ...reader.$,\n      pagination$: combineLatest([paginationExtendedInfo, totalPages$])\n        .pipe(\n          map(([a, b]) => ({ ...a, ...b })),\n          tap((data) => {\n            report.log(`pagination`, data)\n          }),\n          shareReplay(1)\n        )\n    }\n  }\n}\n\nexport const buildChapterInfoFromSpineItem = (manifest: Manifest, item: Manifest[`spineItems`][number]) => {\n  const { path } = item\n\n  return getChapterInfo(path, manifest.nav.toc)\n}\n\nconst getChapterInfo = (path: string, tocItems: Manifest[`nav`][`toc`]): ChapterInfo | undefined => {\n  return tocItems.reduce((acc: ChapterInfo | undefined, tocItem) => {\n    const indexOfHash = tocItem.path.indexOf(`#`)\n    const tocItemPathWithoutAnchor = indexOfHash > 0 ? tocItem.path.substr(0, indexOfHash) : tocItem.path\n    if (path.endsWith(tocItemPathWithoutAnchor)) {\n      return {\n        title: tocItem.title,\n        path: tocItem.path\n      }\n    }\n\n    const subInfo = getChapterInfo(path, tocItem.contents)\n\n    if (subInfo) {\n      return {\n        subChapter: subInfo,\n        title: tocItem.title,\n        path: tocItem.path\n      }\n    }\n\n    return acc\n  }, undefined)\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/pagination.ts\n");
|
|
160
|
+
|
|
161
|
+
/***/ }),
|
|
162
|
+
|
|
163
|
+
/***/ "./src/enhancers/progression.ts":
|
|
164
|
+
/*!**************************************!*\
|
|
165
|
+
!*** ./src/enhancers/progression.ts ***!
|
|
166
|
+
\**************************************/
|
|
167
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
168
|
+
|
|
169
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"progressionEnhancer\": () => (/* binding */ progressionEnhancer)\n/* harmony export */ });\nconst progressionEnhancer = (next) => (options) => {\n const reader = next(options);\n const getPercentageEstimate = (context, currentSpineIndex, numberOfPages, pageIndex, currentPosition, currentItem) => {\n var _a, _b, _c, _d, _e, _f;\n const isGloballyPrePaginated = ((_a = context.getManifest()) === null || _a === void 0 ? void 0 : _a.renditionLayout) === `pre-paginated`;\n const readingOrderLength = ((_b = context.getManifest()) === null || _b === void 0 ? void 0 : _b.spineItems.length) || 0;\n const estimateBeforeThisItem = ((_c = context.getManifest()) === null || _c === void 0 ? void 0 : _c.spineItems.slice(0, currentSpineIndex).reduce((acc, item) => acc + item.progressionWeight, 0)) || 0;\n const currentItemWeight = ((_e = (_d = context.getManifest()) === null || _d === void 0 ? void 0 : _d.spineItems[currentSpineIndex]) === null || _e === void 0 ? void 0 : _e.progressionWeight) || 0;\n let progressWithinThisItem = (pageIndex + 1) * (currentItemWeight / numberOfPages);\n if (!isGloballyPrePaginated && currentItem.isReflowable && !currentItem.isReady()) {\n progressWithinThisItem = 0;\n }\n let totalProgress = estimateBeforeThisItem + progressWithinThisItem;\n if (((_f = context.getManifest()) === null || _f === void 0 ? void 0 : _f.renditionFlow) === `scrolled-continuous`) {\n if (currentItem.isReady()) {\n progressWithinThisItem = getScrollPercentageWithinItem(context, currentPosition, currentItem);\n }\n else {\n progressWithinThisItem = 0;\n }\n totalProgress = getTotalProgressFromPercentages(estimateBeforeThisItem, currentItemWeight, progressWithinThisItem);\n }\n if ((currentSpineIndex === readingOrderLength - 1) && (pageIndex === numberOfPages - 1) && totalProgress > 0.99) {\n return 1;\n }\n return totalProgress;\n };\n const getTotalProgressFromPercentages = (estimateBeforeThisItem, currentItemWeight, progressWithinThisItem) => {\n return estimateBeforeThisItem + (currentItemWeight * progressWithinThisItem);\n };\n const getScrollPercentageWithinItem = (context, currentPosition, currentItem) => {\n const { height, width } = currentItem.getElementDimensions();\n const { topStart, leftStart } = reader.getAbsolutePositionOf(currentItem);\n if (context.getSettings().computedPageTurnDirection === `vertical`) {\n return Math.max(0, Math.min(1, ((currentPosition.y - topStart) + context.getVisibleAreaRect().height) / height));\n }\n else {\n return Math.max(0, Math.min(1, ((currentPosition.x - leftStart) + context.getVisibleAreaRect().width) / width));\n }\n };\n return Object.assign(Object.assign({}, reader), { progression: {\n getPercentageEstimate,\n getScrollPercentageWithinItem\n } });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/progression.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/enhancers/progression.ts?6024"],"sourcesContent":["import { Context } from \"../context\"\nimport { Enhancer } from \"./types\"\nimport { SpineItem } from \"../spineItem/createSpineItem\"\n\n/**\n * Help dealing with progression through the book\n */\nexport const progressionEnhancer: Enhancer<{}, {\n  progression: {\n    getPercentageEstimate: (\n      context: Context,\n      currentSpineIndex: number,\n      numberOfPages: number,\n      pageIndex: number,\n      currentPosition: { x: number, y: number },\n      currentItem: SpineItem\n    ) => number,\n    getScrollPercentageWithinItem: (context: Context, currentPosition: { x: number, y: number }, currentItem: SpineItem) => number\n  }\n}> = (next) => (options) => {\n  const reader = next(options)\n\n  const getPercentageEstimate = (\n    context: Context,\n    currentSpineIndex: number,\n    numberOfPages: number,\n    pageIndex: number,\n    currentPosition: { x: number, y: number },\n    currentItem: SpineItem\n  ) => {\n    const isGloballyPrePaginated = context.getManifest()?.renditionLayout === `pre-paginated`\n    const readingOrderLength = context.getManifest()?.spineItems.length || 0\n    const estimateBeforeThisItem = context.getManifest()?.spineItems\n      .slice(0, currentSpineIndex)\n      .reduce((acc, item) => acc + item.progressionWeight, 0) || 0\n    const currentItemWeight = context.getManifest()?.spineItems[currentSpineIndex]?.progressionWeight || 0\n    // const nextItem = context.manifest.readingOrder[currentSpineIndex + 1]\n    // const nextItemWeight = nextItem ? nextItem.progressionWeight : 1\n    // const progressWeightGap = (currentItemWeight + estimateBeforeThisItem) - estimateBeforeThisItem\n\n    let progressWithinThisItem = (pageIndex + 1) * (currentItemWeight / numberOfPages)\n\n    if (!isGloballyPrePaginated && currentItem.isReflowable && !currentItem.isReady()) {\n      progressWithinThisItem = 0\n    }\n\n    let totalProgress = estimateBeforeThisItem + progressWithinThisItem\n\n    if (context.getManifest()?.renditionFlow === `scrolled-continuous`) {\n      if (currentItem.isReady()) {\n        progressWithinThisItem = getScrollPercentageWithinItem(context, currentPosition, currentItem)\n      } else {\n        // that way we avoid having a progress of 1 just because the item is not loaded and cover all screen due to smaller size.\n        // Therefore it effectively prevent jump from 30% to 25% for example.\n        progressWithinThisItem = 0\n      }\n      totalProgress = getTotalProgressFromPercentages(estimateBeforeThisItem, currentItemWeight, progressWithinThisItem)\n    }\n\n    // because the rounding of weight use a lot of decimals we will end up with\n    // something like 0.999878 for the last page\n    if ((currentSpineIndex === readingOrderLength - 1) && (pageIndex === numberOfPages - 1) && totalProgress > 0.99) {\n      return 1\n    }\n\n    return totalProgress\n  }\n\n  const getTotalProgressFromPercentages = (estimateBeforeThisItem: number, currentItemWeight: number, progressWithinThisItem: number) => {\n    return estimateBeforeThisItem + (currentItemWeight * progressWithinThisItem)\n  }\n\n  const getScrollPercentageWithinItem = (context: Context, currentPosition: { x: number, y: number }, currentItem: SpineItem) => {\n    const { height, width } = currentItem.getElementDimensions()\n\n    const { topStart, leftStart } = reader.getAbsolutePositionOf(currentItem)\n\n    if (context.getSettings().computedPageTurnDirection === `vertical`) {\n      return Math.max(0, Math.min(1, ((currentPosition.y - topStart) + context.getVisibleAreaRect().height) / height))\n    } else {\n      return Math.max(0, Math.min(1, ((currentPosition.x - leftStart) + context.getVisibleAreaRect().width) / width))\n    }\n  }\n\n  return {\n    ...reader,\n    progression: {\n      getPercentageEstimate,\n      getScrollPercentageWithinItem\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/progression.ts\n");
|
|
170
|
+
|
|
171
|
+
/***/ }),
|
|
172
|
+
|
|
173
|
+
/***/ "./src/enhancers/resources/index.ts":
|
|
174
|
+
/*!******************************************!*\
|
|
175
|
+
!*** ./src/enhancers/resources/index.ts ***!
|
|
176
|
+
\******************************************/
|
|
177
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
178
|
+
|
|
179
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"resourcesEnhancer\": () => (/* binding */ resourcesEnhancer)\n/* harmony export */ });\n/* harmony import */ var _resourcesManager__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./resourcesManager */ \"./src/enhancers/resources/resourcesManager.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\nconst resourcesEnhancer = (next) => (options) => {\n const reader = next(options);\n const resourceManager = (0,_resourcesManager__WEBPACK_IMPORTED_MODULE_0__.createResourcesManager)(reader.context);\n const load = (manifest, loadOptions) => {\n reader.load(manifest, Object.assign({}, loadOptions));\n };\n reader.registerHook(`item.onGetResource`, (fetcher) => (item) => __awaiter(void 0, void 0, void 0, function* () {\n return resourceManager.get(item, fetcher);\n }));\n const destroy = () => {\n resourceManager.destroy();\n reader.destroy();\n };\n return Object.assign(Object.assign({}, reader), { destroy,\n load });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL3Jlc291cmNlcy9pbmRleC50cy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7OztBQUMyRDtBQUVwRCxNQUFNLGlCQUFpQixHQUV6QixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtJQUN6QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQzVCLE1BQU0sZUFBZSxHQUFHLHlFQUFzQixDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7SUFNOUQsTUFBTSxJQUFJLEdBQXVCLENBQUMsUUFBUSxFQUFFLFdBQVcsRUFBRSxFQUFFO1FBQ3pELE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxvQkFDZixXQUFXLEVBQ2Q7SUFDSixDQUFDO0lBRUQsTUFBTSxDQUFDLFlBQVksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBTyxJQUFJLEVBQUUsRUFBRTtRQUNwRSxPQUFPLGVBQWUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQztJQUMzQyxDQUFDLEVBQUM7SUFFRixNQUFNLE9BQU8sR0FBRyxHQUFHLEVBQUU7UUFDbkIsZUFBZSxDQUFDLE9BQU8sRUFBRTtRQUN6QixNQUFNLENBQUMsT0FBTyxFQUFFO0lBQ2xCLENBQUM7SUFFRCx1Q0FDSyxNQUFNLEtBQ1QsT0FBTztRQUNQLElBQUksSUFDTDtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZW5oYW5jZXJzL3Jlc291cmNlcy9pbmRleC50cz9lOTNmIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVuaGFuY2VyIH0gZnJvbSBcIi4uL3R5cGVzXCJcbmltcG9ydCB7IGNyZWF0ZVJlc291cmNlc01hbmFnZXIgfSBmcm9tIFwiLi9yZXNvdXJjZXNNYW5hZ2VyXCJcblxuZXhwb3J0IGNvbnN0IHJlc291cmNlc0VuaGFuY2VyOiBFbmhhbmNlcjx7fSwge1xuXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG4gIGNvbnN0IHJlc291cmNlTWFuYWdlciA9IGNyZWF0ZVJlc291cmNlc01hbmFnZXIocmVhZGVyLmNvbnRleHQpXG5cbiAgLyoqXG4gICAqIFdlIHdpbGwgc2VydmUgcmVzb3VyY2VzIGZyb20gY2FjaGUgaWYgdGhleSBleGlzdCBvdGhlcndpc2UgZmV0Y2ggaXQgbm9ybWFsbHkuXG4gICAqIFRoZSByZXNvdXJjZSBtYW5hZ2VyIHVzZSB0aGUgcHJvdmlkZWQgdXNlciBvcHRpb24gdG8gZmV0Y2ggcmVzb3VyY2UgaWYgaXQgZXhpc3RzXG4gICAqL1xuICBjb25zdCBsb2FkOiB0eXBlb2YgcmVhZGVyLmxvYWQgPSAobWFuaWZlc3QsIGxvYWRPcHRpb25zKSA9PiB7XG4gICAgcmVhZGVyLmxvYWQobWFuaWZlc3QsIHtcbiAgICAgIC4uLmxvYWRPcHRpb25zXG4gICAgfSlcbiAgfVxuXG4gIHJlYWRlci5yZWdpc3Rlckhvb2soYGl0ZW0ub25HZXRSZXNvdXJjZWAsIChmZXRjaGVyKSA9PiBhc3luYyAoaXRlbSkgPT4ge1xuICAgIHJldHVybiByZXNvdXJjZU1hbmFnZXIuZ2V0KGl0ZW0sIGZldGNoZXIpXG4gIH0pXG5cbiAgY29uc3QgZGVzdHJveSA9ICgpID0+IHtcbiAgICByZXNvdXJjZU1hbmFnZXIuZGVzdHJveSgpXG4gICAgcmVhZGVyLmRlc3Ryb3koKVxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZWFkZXIsXG4gICAgZGVzdHJveSxcbiAgICBsb2FkXG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/enhancers/resources/index.ts\n");
|
|
180
|
+
|
|
181
|
+
/***/ }),
|
|
182
|
+
|
|
183
|
+
/***/ "./src/enhancers/resources/indexedDB.ts":
|
|
184
|
+
/*!**********************************************!*\
|
|
185
|
+
!*** ./src/enhancers/resources/indexedDB.ts ***!
|
|
186
|
+
\**********************************************/
|
|
187
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
188
|
+
|
|
189
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"openDatabase\": () => (/* binding */ openDatabase)\n/* harmony export */ });\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nconst createDatabase = (db) => {\n const put = (key, data) => {\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([`store`], `readwrite`);\n transaction.onerror = function (event) {\n reject(event);\n };\n transaction.oncomplete = function () {\n resolve();\n };\n const objectStore = transaction.objectStore(`store`);\n const listener = objectStore.put(data, key);\n listener.onsuccess = () => {\n resolve();\n };\n listener.onerror = (event) => {\n reject(event);\n };\n });\n };\n const get = (key) => {\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([`store`], `readwrite`);\n const objectStore = transaction.objectStore(`store`);\n const request = objectStore.get(key);\n request.onsuccess = () => {\n let value = request.result;\n if (value === undefined) {\n value = null;\n }\n resolve(value);\n };\n transaction.onerror = function () {\n reject(request.error);\n };\n });\n };\n const remove = (key) => {\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([`store`], `readwrite`);\n const objectStore = transaction.objectStore(`store`);\n const request = objectStore.delete(key);\n transaction.onerror = function () {\n reject(request.error);\n };\n transaction.oncomplete = function () {\n resolve();\n };\n transaction.onabort = function () {\n var _a;\n const err = request.error\n ? request.error\n : (_a = request.transaction) === null || _a === void 0 ? void 0 : _a.error;\n reject(err);\n };\n });\n };\n const keys = () => {\n return new Promise((resolve, reject) => {\n const transaction = db.transaction([`store`], `readonly`);\n transaction.onerror = function (event) {\n reject(event);\n };\n const objectStore = transaction.objectStore(`store`);\n const request = objectStore.openKeyCursor();\n const keys = [];\n request.onsuccess = () => {\n const cursor = request.result;\n if (!cursor) {\n resolve(keys);\n return;\n }\n keys.push(cursor.key);\n cursor.continue();\n };\n request.onerror = () => {\n reject(request.error);\n };\n });\n };\n return {\n put,\n keys,\n get,\n remove\n };\n};\nconst openDatabase = (name) => __awaiter(void 0, void 0, void 0, function* () {\n return new Promise((resolve, reject) => {\n const request = window.indexedDB.open(name);\n request.onerror = function (event) {\n reject(event);\n };\n request.onsuccess = function () {\n resolve(createDatabase(request.result));\n };\n request.onupgradeneeded = () => {\n request.result.createObjectStore(`store`);\n };\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/resources/indexedDB.ts.js","mappings":";;;;;;;;;;;;;AAAA,MAAM,cAAc,GAAG,CAAC,EAA0B,EAAE,EAAE;IACpD,MAAM,GAAG,GAAG,CAAC,GAAW,EAAE,IAAU,EAAE,EAAE;QACtC,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3C,MAAM,WAAW,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,EAAE,WAAW,CAAC;YAE1D,WAAW,CAAC,OAAO,GAAG,UAAU,KAAK;gBACnC,MAAM,CAAC,KAAK,CAAC;YACf,CAAC;YAED,WAAW,CAAC,UAAU,GAAG;gBACvB,OAAO,EAAE;YACX,CAAC;YAED,MAAM,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC;YACpD,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC;YAE3C,QAAQ,CAAC,SAAS,GAAG,GAAG,EAAE;gBACxB,OAAO,EAAE;YACX,CAAC;YAED,QAAQ,CAAC,OAAO,GAAG,CAAC,KAAK,EAAE,EAAE;gBAC3B,MAAM,CAAC,KAAK,CAAC;YACf,CAAC;QACH,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,GAAG,GAAG,CAAC,GAAW,EAAE,EAAE;QAC1B,OAAO,IAAI,OAAO,CAAc,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAClD,MAAM,WAAW,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,EAAE,WAAW,CAAC;YAC1D,MAAM,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC;YACpD,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC;YAEpC,OAAO,CAAC,SAAS,GAAG,GAAG,EAAE;gBACvB,IAAI,KAAK,GAAG,OAAO,CAAC,MAAM;gBAC1B,IAAI,KAAK,KAAK,SAAS,EAAE;oBACvB,KAAK,GAAG,IAAI;iBACb;gBACD,OAAO,CAAC,KAAK,CAAC;YAChB,CAAC;YAED,WAAW,CAAC,OAAO,GAAG;gBACpB,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;YACvB,CAAC;QACH,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,MAAM,GAAG,CAAC,GAA2B,EAAE,EAAE;QAC7C,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3C,MAAM,WAAW,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,EAAE,WAAW,CAAC;YAE1D,MAAM,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC;YACpD,MAAM,OAAO,GAAG,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC;YAEvC,WAAW,CAAC,OAAO,GAAG;gBACpB,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;YACvB,CAAC;YAED,WAAW,CAAC,UAAU,GAAG;gBACvB,OAAO,EAAE;YACX,CAAC;YAID,WAAW,CAAC,OAAO,GAAG;;gBACpB,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK;oBACvB,CAAC,CAAC,OAAO,CAAC,KAAK;oBACf,CAAC,CAAC,aAAO,CAAC,WAAW,0CAAE,KAAK;gBAC9B,MAAM,CAAC,GAAG,CAAC;YACb,CAAC;QACH,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,IAAI,GAAG,GAAG,EAAE;QAChB,OAAO,IAAI,OAAO,CAA2B,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC/D,MAAM,WAAW,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,EAAE,UAAU,CAAC;YAEzD,WAAW,CAAC,OAAO,GAAG,UAAU,KAAK;gBACnC,MAAM,CAAC,KAAK,CAAC;YACf,CAAC;YAMD,MAAM,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC;YACpD,MAAM,OAAO,GAAG,WAAW,CAAC,aAAa,EAAE;YAC3C,MAAM,IAAI,GAA6B,EAAE;YAEzC,OAAO,CAAC,SAAS,GAAG,GAAG,EAAE;gBACvB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM;gBAE7B,IAAI,CAAC,MAAM,EAAE;oBACX,OAAO,CAAC,IAAI,CAAC;oBACb,OAAM;iBACP;gBAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACrB,MAAM,CAAC,QAAQ,EAAE;YACnB,CAAC;YAED,OAAO,CAAC,OAAO,GAAG,GAAG,EAAE;gBACrB,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;YACvB,CAAC;QACH,CAAC,CAAC;IACJ,CAAC;IAED,OAAO;QACL,GAAG;QACH,IAAI;QACJ,GAAG;QACH,MAAM;KACP;AACH,CAAC;AAEM,MAAM,YAAY,GAAG,CAAO,IAAY,EAAE,EAAE;IACjD,OAAO,IAAI,OAAO,CAAoC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACxE,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC;QAE3C,OAAO,CAAC,OAAO,GAAG,UAAU,KAAK;YAC/B,MAAM,CAAC,KAAK,CAAC;QACf,CAAC;QAED,OAAO,CAAC,SAAS,GAAG;YAClB,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC;QAED,OAAO,CAAC,eAAe,GAAG,GAAG,EAAE;YAC7B,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC;QAC3C,CAAC;IACH,CAAC,CAAC;AACJ,CAAC","sources":["webpack://@prose-reader/core/./src/enhancers/resources/indexedDB.ts?5eca"],"sourcesContent":["const createDatabase = (db: globalThis.IDBDatabase) => {\n  const put = (key: string, data: Blob) => {\n    return new Promise<void>((resolve, reject) => {\n      const transaction = db.transaction([`store`], `readwrite`)\n\n      transaction.onerror = function (event) {\n        reject(event)\n      }\n\n      transaction.oncomplete = function () {\n        resolve()\n      }\n\n      const objectStore = transaction.objectStore(`store`)\n      const listener = objectStore.put(data, key)\n\n      listener.onsuccess = () => {\n        resolve()\n      }\n\n      listener.onerror = (event) => {\n        reject(event)\n      }\n    })\n  }\n\n  const get = (key: string) => {\n    return new Promise<Blob | null>((resolve, reject) => {\n      const transaction = db.transaction([`store`], `readwrite`)\n      const objectStore = transaction.objectStore(`store`)\n      const request = objectStore.get(key)\n\n      request.onsuccess = () => {\n        let value = request.result\n        if (value === undefined) {\n          value = null\n        }\n        resolve(value)\n      }\n\n      transaction.onerror = function () {\n        reject(request.error)\n      }\n    })\n  }\n\n  const remove = (key: globalThis.IDBValidKey) => {\n    return new Promise<void>((resolve, reject) => {\n      const transaction = db.transaction([`store`], `readwrite`)\n\n      const objectStore = transaction.objectStore(`store`)\n      const request = objectStore.delete(key)\n\n      transaction.onerror = function () {\n        reject(request.error)\n      }\n\n      transaction.oncomplete = function () {\n        resolve()\n      }\n\n      // The request will be also be aborted if we've exceeded our storage\n      // space.\n      transaction.onabort = function () {\n        const err = request.error\n          ? request.error\n          : request.transaction?.error\n        reject(err)\n      }\n    })\n  }\n\n  const keys = () => {\n    return new Promise<globalThis.IDBValidKey[]>((resolve, reject) => {\n      const transaction = db.transaction([`store`], `readonly`)\n\n      transaction.onerror = function (event) {\n        reject(event)\n      }\n\n      // transaction.oncomplete = function () {\n      //   resolve()\n      // };\n\n      const objectStore = transaction.objectStore(`store`)\n      const request = objectStore.openKeyCursor()\n      const keys: globalThis.IDBValidKey[] = []\n\n      request.onsuccess = () => {\n        const cursor = request.result\n\n        if (!cursor) {\n          resolve(keys)\n          return\n        }\n\n        keys.push(cursor.key)\n        cursor.continue()\n      }\n\n      request.onerror = () => {\n        reject(request.error)\n      }\n    })\n  }\n\n  return {\n    put,\n    keys,\n    get,\n    remove\n  }\n}\n\nexport const openDatabase = async (name: string) => {\n  return new Promise<ReturnType<typeof createDatabase>>((resolve, reject) => {\n    const request = window.indexedDB.open(name)\n\n    request.onerror = function (event) {\n      reject(event)\n    }\n\n    request.onsuccess = function () {\n      resolve(createDatabase(request.result))\n    }\n\n    request.onupgradeneeded = () => {\n      request.result.createObjectStore(`store`)\n    }\n  })\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/resources/indexedDB.ts\n");
|
|
190
|
+
|
|
191
|
+
/***/ }),
|
|
192
|
+
|
|
193
|
+
/***/ "./src/enhancers/resources/resourcesManager.ts":
|
|
194
|
+
/*!*****************************************************!*\
|
|
195
|
+
!*** ./src/enhancers/resources/resourcesManager.ts ***!
|
|
196
|
+
\*****************************************************/
|
|
197
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
198
|
+
|
|
199
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createResourcesManager\": () => (/* binding */ createResourcesManager)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../report */ \"./src/report.ts\");\n/* harmony import */ var _indexedDB__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./indexedDB */ \"./src/enhancers/resources/indexedDB.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\nconst createResourcesManager = (context) => {\n let uniqueID = Date.now().toString();\n const cache$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const retrieveItem = (itemIndexOrId) => {\n var _a, _b;\n if (typeof itemIndexOrId === `string` || typeof itemIndexOrId === `object`) {\n const id = typeof itemIndexOrId === `object` ? itemIndexOrId.id : undefined;\n return (_a = context.getManifest()) === null || _a === void 0 ? void 0 : _a.spineItems.find((entry) => entry.id === id);\n }\n else {\n return (_b = context.getManifest()) === null || _b === void 0 ? void 0 : _b.spineItems[itemIndexOrId];\n }\n };\n const get = (itemIndexOrId, fetchResource) => __awaiter(void 0, void 0, void 0, function* () {\n const item = retrieveItem(itemIndexOrId);\n if (!item)\n return new Response(`Item not found`, { status: 404 });\n const db = yield (0,_indexedDB__WEBPACK_IMPORTED_MODULE_3__.openDatabase)(`prose-reader`);\n const cacheData = yield db.get(`${uniqueID}_${item.id}`);\n if (cacheData) {\n return new Response(cacheData, { status: 200 });\n }\n const data = (fetchResource && (yield fetchResource(item))) || (yield fetch(item.href));\n cache(item, data.clone());\n return data;\n });\n const cache = (itemIndexOrId, data) => {\n cache$.next({ id: itemIndexOrId, data });\n };\n cache$.asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)(({ id, data }) => {\n const item = retrieveItem(id);\n if (!item)\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)((0,rxjs__WEBPACK_IMPORTED_MODULE_0__.forkJoin)([(0,_indexedDB__WEBPACK_IMPORTED_MODULE_3__.openDatabase)(`prose-reader`), (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(data.blob())]))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(([db, blob]) => {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(db.put(`${uniqueID}_${item.id}`, blob));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.catchError)(error => {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.error(error);\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n const onLoad$ = context.$.load$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n uniqueID = Date.now().toString();\n }));\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(onLoad$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(`Cleanup up old cache...`);\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)((0,_indexedDB__WEBPACK_IMPORTED_MODULE_3__.openDatabase)(`prose-reader`))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(db => (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(db.keys())\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(keys => keys.filter(key => !key.toString().startsWith(uniqueID))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)((keysToRemove) => {\n const promises = keysToRemove.map(key => db.remove(key));\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(Promise.all(promises));\n }))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.catchError)(error => {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.error(error);\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n const destroy = () => {\n cache$.complete();\n };\n return {\n get,\n destroy\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/resources/resourcesManager.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/enhancers/resources/resourcesManager.ts?be38"],"sourcesContent":["/**\n * @todo web worker\n */\nimport { EMPTY, forkJoin, from, merge, Subject } from \"rxjs\"\nimport { catchError, map, mergeMap, switchMap, takeUntil, tap } from \"rxjs/operators\"\nimport { Context } from \"../../context\"\nimport { Report } from \"../../report\"\nimport { Manifest } from \"../../types\"\nimport { openDatabase } from \"./indexedDB\"\n\nexport const createResourcesManager = (context: Context) => {\n  let uniqueID = Date.now().toString()\n  const cache$ = new Subject<{ id: number | Pick<Manifest[`spineItems`][number], `id`>, data: Response }>()\n\n  const retrieveItem = (itemIndexOrId: number | Pick<Manifest[`spineItems`][number], `id`>) => {\n    if (typeof itemIndexOrId === `string` || typeof itemIndexOrId === `object`) {\n      const id = typeof itemIndexOrId === `object` ? itemIndexOrId.id : undefined\n      return context.getManifest()?.spineItems.find((entry) => entry.id === id)\n    } else {\n      return context.getManifest()?.spineItems[itemIndexOrId]\n    }\n  }\n\n  const get = async (itemIndexOrId: number | Pick<Manifest[`spineItems`][number], `id`>, fetchResource?: (item: Manifest[`spineItems`][number]) => Promise<Response>) => {\n    const item = retrieveItem(itemIndexOrId)\n\n    if (!item) return new Response(`Item not found`, { status: 404 })\n\n    const db = await openDatabase(`prose-reader`)\n    const cacheData = await db.get(`${uniqueID}_${item.id}`)\n\n    if (cacheData) {\n      return new Response(cacheData, { status: 200 })\n    }\n\n    const data = (fetchResource && await fetchResource(item)) || await fetch(item.href)\n\n    cache(item, data.clone())\n\n    return data\n  }\n\n  const cache = (itemIndexOrId: number | Pick<Manifest[`spineItems`][number], `id`>, data: Response) => {\n    cache$.next({ id: itemIndexOrId, data })\n  }\n\n  cache$.asObservable()\n    .pipe(\n      mergeMap(({ id, data }) => {\n        const item = retrieveItem(id)\n\n        if (!item) return EMPTY\n\n        return from(forkJoin([openDatabase(`prose-reader`), from(data.blob())]))\n          .pipe(\n            switchMap(([db, blob]) => {\n              return from(db.put(`${uniqueID}_${item.id}`, blob))\n            }),\n            catchError(error => {\n              Report.error(error)\n\n              return EMPTY\n            })\n          )\n      }),\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  const onLoad$ = context.$.load$\n    .pipe(\n      tap(() => {\n        uniqueID = Date.now().toString()\n      })\n    )\n\n  /**\n   * Cleanup old cache on startup if needed\n   * @todo\n   * do on first time and only then on subsequent load\n   */\n  merge(onLoad$)\n    .pipe(\n      switchMap(() => {\n        Report.log(`Cleanup up old cache...`)\n\n        return from(openDatabase(`prose-reader`))\n          .pipe(\n            switchMap(db =>\n              from(db.keys())\n                .pipe(\n                  map(keys => keys.filter(key => !key.toString().startsWith(uniqueID))),\n                  switchMap((keysToRemove) => {\n                    const promises = keysToRemove.map(key => db.remove(key))\n\n                    return from(Promise.all(promises))\n                  })\n                )\n            ),\n            catchError(error => {\n              Report.error(error)\n\n              return EMPTY\n            })\n          )\n      }),\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  const destroy = () => {\n    cache$.complete()\n  }\n\n  return {\n    get,\n    destroy\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/resources/resourcesManager.ts\n");
|
|
200
|
+
|
|
201
|
+
/***/ }),
|
|
202
|
+
|
|
203
|
+
/***/ "./src/enhancers/theme.ts":
|
|
204
|
+
/*!********************************!*\
|
|
205
|
+
!*** ./src/enhancers/theme.ts ***!
|
|
206
|
+
\********************************/
|
|
207
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
208
|
+
|
|
209
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"themeEnhancer\": () => (/* binding */ themeEnhancer)\n/* harmony export */ });\nconst defaultThemes = [\n {\n name: `bright`,\n backgroundColor: `white`\n },\n {\n name: `sepia`,\n backgroundColor: `#eaddc7`,\n foregroundColor: `black`\n },\n {\n name: `night`,\n backgroundColor: `#191717`,\n foregroundColor: `#f1ebeb`\n }\n];\nconst themeEnhancer = (next) => (options) => {\n const { theme } = options;\n const reader = next(options);\n let currentTheme = theme;\n const getStyle = () => {\n const foundTheme = defaultThemes.find(entry => entry.name === currentTheme);\n return `\n body {\n ${foundTheme !== undefined\n ? `background-color: ${foundTheme.backgroundColor} !important;`\n : ``}\n }\n ${(foundTheme === null || foundTheme === void 0 ? void 0 : foundTheme.foregroundColor)\n ? `\n body * {\n ${``}\n color: ${foundTheme.foregroundColor};\n }\n `\n : ``}\n `;\n };\n const applyChangeToSpineItemElement = ({ container, loadingElement }) => {\n const foundTheme = defaultThemes.find(entry => entry.name === currentTheme);\n if (foundTheme) {\n container.style.setProperty(`background-color`, foundTheme.backgroundColor);\n loadingElement.style.setProperty(`background-color`, foundTheme.backgroundColor);\n }\n return () => { };\n };\n const applyChangeToSpineItem = () => {\n reader.manipulateSpineItems(({ removeStyle, addStyle, container, loadingElement }) => {\n removeStyle(`prose-reader-theme`);\n addStyle(`prose-reader-theme`, getStyle());\n applyChangeToSpineItemElement({ container, loadingElement });\n return false;\n });\n };\n reader.registerHook(`item.onLoad`, ({ removeStyle, addStyle }) => {\n removeStyle(`prose-reader-theme`);\n addStyle(`prose-reader-theme`, getStyle());\n });\n reader.registerHook(`item.onCreated`, applyChangeToSpineItemElement);\n return Object.assign(Object.assign({}, reader), { setTheme: (theme) => {\n currentTheme = theme;\n applyChangeToSpineItem();\n }, getTheme: () => currentTheme });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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QzdCO0FBQ0gsQ0FBQyIsInNvdXJjZXMiOlsid2VicGFjazovL0Bwcm9zZS1yZWFkZXIvY29yZS8uL3NyYy9lbmhhbmNlcnMvdGhlbWUudHM/ZjViOCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmhhbmNlciB9IGZyb20gXCIuL3R5cGVzXCJcblxuY29uc3QgZGVmYXVsdFRoZW1lcyA9IFtcbiAge1xuICAgIG5hbWU6IGBicmlnaHRgIGFzIGNvbnN0LFxuICAgIGJhY2tncm91bmRDb2xvcjogYHdoaXRlYFxuICB9LFxuICB7XG4gICAgbmFtZTogYHNlcGlhYCBhcyBjb25zdCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IGAjZWFkZGM3YCxcbiAgICBmb3JlZ3JvdW5kQ29sb3I6IGBibGFja2BcbiAgfSxcbiAge1xuICAgIG5hbWU6IGBuaWdodGAgYXMgY29uc3QsXG4gICAgYmFja2dyb3VuZENvbG9yOiBgIzE5MTcxN2AsXG4gICAgZm9yZWdyb3VuZENvbG9yOiBgI2YxZWJlYmBcbiAgfVxuXVxuXG5leHBvcnQgdHlwZSBUaGVtZSA9ICh0eXBlb2YgZGVmYXVsdFRoZW1lc1tudW1iZXJdKVtgbmFtZWBdXG5cbmV4cG9ydCBjb25zdCB0aGVtZUVuaGFuY2VyOiBFbmhhbmNlcjx7XG4gIHRoZW1lPzogVGhlbWUsXG59LCB7XG4gIHNldFRoZW1lOiAodGhlbWU6IFRoZW1lIHwgdW5kZWZpbmVkKSA9PiB2b2lkLFxuICBnZXRUaGVtZTogKCkgPT4gVGhlbWUgfCB1bmRlZmluZWQsXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCB7IHRoZW1lIH0gPSBvcHRpb25zXG4gIGNvbnN0IHJlYWRlciA9IG5leHQob3B0aW9ucylcbiAgbGV0IGN1cnJlbnRUaGVtZSA9IHRoZW1lXG5cbiAgY29uc3QgZ2V0U3R5bGUgPSAoKSA9PiB7XG4gICAgY29uc3QgZm91bmRUaGVtZSA9IGRlZmF1bHRUaGVtZXMuZmluZChlbnRyeSA9PiBlbnRyeS5uYW1lID09PSBjdXJyZW50VGhlbWUpXG5cbiAgICByZXR1cm4gYFxuICAgICAgYm9keSB7XG4gICAgICAgICR7Zm91bmRUaGVtZSAhPT0gdW5kZWZpbmVkXG4gICAgICAgID8gYGJhY2tncm91bmQtY29sb3I6ICR7Zm91bmRUaGVtZS5iYWNrZ3JvdW5kQ29sb3J9ICFpbXBvcnRhbnQ7YFxuICAgICAgICA6IGBgfVxuICAgICAgfVxuICAgICAgJHtmb3VuZFRoZW1lPy5mb3JlZ3JvdW5kQ29sb3JcbiAgICAgICAgPyBgXG4gICAgICAgICAgYm9keSAqIHtcbiAgICAgICAgICAgICR7LypcbiAgICAgICAgICAgICAgSWRlYWxseSwgd2Ugd291bGQgbGlrZSB0byB1c2UgIWltcG9ydGFudCBidXQgaXQgY291bGQgYnJlYWsgcHVibGlzaGVyIHNwZWNpZmljXG4gICAgICAgICAgICAgIGNhc2VzXG4gICAgICAgICAgICAqL2BgfVxuICAgICAgICAgICAgY29sb3I6ICR7Zm91bmRUaGVtZS5mb3JlZ3JvdW5kQ29sb3J9O1xuICAgICAgICAgIH1cbiAgICAgICAgYFxuICAgICAgICA6IGBgfVxuICAgIGBcbiAgfVxuXG4gIGNvbnN0IGFwcGx5Q2hhbmdlVG9TcGluZUl0ZW1FbGVtZW50ID0gKHsgY29udGFpbmVyLCBsb2FkaW5nRWxlbWVudCB9OiB7IGNvbnRhaW5lcjogSFRNTEVsZW1lbnQsIGxvYWRpbmdFbGVtZW50OiBIVE1MRWxlbWVudCB9KSA9PiB7XG4gICAgY29uc3QgZm91bmRUaGVtZSA9IGRlZmF1bHRUaGVtZXMuZmluZChlbnRyeSA9PiBlbnRyeS5uYW1lID09PSBjdXJyZW50VGhlbWUpXG4gICAgaWYgKGZvdW5kVGhlbWUpIHtcbiAgICAgIGNvbnRhaW5lci5zdHlsZS5zZXRQcm9wZXJ0eShgYmFja2dyb3VuZC1jb2xvcmAsIGZvdW5kVGhlbWUuYmFja2dyb3VuZENvbG9yKVxuICAgICAgbG9hZGluZ0VsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoYGJhY2tncm91bmQtY29sb3JgLCBmb3VuZFRoZW1lLmJhY2tncm91bmRDb2xvcilcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge31cbiAgfVxuXG4gIGNvbnN0IGFwcGx5Q2hhbmdlVG9TcGluZUl0ZW0gPSAoKSA9PiB7XG4gICAgcmVhZGVyLm1hbmlwdWxhdGVTcGluZUl0ZW1zKCh7IHJlbW92ZVN0eWxlLCBhZGRTdHlsZSwgY29udGFpbmVyLCBsb2FkaW5nRWxlbWVudCB9KSA9PiB7XG4gICAgICByZW1vdmVTdHlsZShgcHJvc2UtcmVhZGVyLXRoZW1lYClcbiAgICAgIGFkZFN0eWxlKGBwcm9zZS1yZWFkZXItdGhlbWVgLCBnZXRTdHlsZSgpKVxuICAgICAgYXBwbHlDaGFuZ2VUb1NwaW5lSXRlbUVsZW1lbnQoeyBjb250YWluZXIsIGxvYWRpbmdFbGVtZW50IH0pXG5cbiAgICAgIHJldHVybiBmYWxzZVxuICAgIH0pXG4gIH1cblxuICAvKipcbiAgICogTWFrZSBzdXJlIHRvIGFwcGx5IHRoZW1lIG9uIGl0ZW0gbG9hZFxuICAgKi9cbiAgcmVhZGVyLnJlZ2lzdGVySG9vayhgaXRlbS5vbkxvYWRgLCAoeyByZW1vdmVTdHlsZSwgYWRkU3R5bGUgfSkgPT4ge1xuICAgIHJlbW92ZVN0eWxlKGBwcm9zZS1yZWFkZXItdGhlbWVgKVxuICAgIGFkZFN0eWxlKGBwcm9zZS1yZWFkZXItdGhlbWVgLCBnZXRTdHlsZSgpKVxuICB9KVxuXG4gIC8qKlxuICAgKiBNYWtlIHN1cmUgdG8gYXBwbHkgdGhlbWUgb24gaXRlbSBjb250YWluZXIgKGZpeGVkIGxheW91dClcbiAgICogJiBsb2FkaW5nIGVsZW1lbnRcbiAgICovXG4gIHJlYWRlci5yZWdpc3Rlckhvb2soYGl0ZW0ub25DcmVhdGVkYCwgYXBwbHlDaGFuZ2VUb1NwaW5lSXRlbUVsZW1lbnQpXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZWFkZXIsXG4gICAgc2V0VGhlbWU6ICh0aGVtZTogVGhlbWUgfCB1bmRlZmluZWQpID0+IHtcbiAgICAgIGN1cnJlbnRUaGVtZSA9IHRoZW1lXG4gICAgICBhcHBseUNoYW5nZVRvU3BpbmVJdGVtKClcbiAgICB9LFxuICAgIGdldFRoZW1lOiAoKSA9PiBjdXJyZW50VGhlbWVcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/enhancers/theme.ts\n");
|
|
210
|
+
|
|
211
|
+
/***/ }),
|
|
212
|
+
|
|
213
|
+
/***/ "./src/enhancers/utils.ts":
|
|
214
|
+
/*!********************************!*\
|
|
215
|
+
!*** ./src/enhancers/utils.ts ***!
|
|
216
|
+
\********************************/
|
|
217
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
218
|
+
|
|
219
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"utilsEnhancer\": () => (/* binding */ utilsEnhancer)\n/* harmony export */ });\n/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/dom */ \"./src/utils/dom.ts\");\n\nconst utilsEnhancer = (next) => (options) => {\n const reader = next(options);\n const isOrIsWithinValidLink = (target) => {\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_0__.isHtmlElement)(target)) {\n const link = target.nodeName === `a` ? target : target.closest(`a`);\n if (link === null || link === void 0 ? void 0 : link.getAttribute(`href`)) {\n return true;\n }\n }\n return false;\n };\n return Object.assign(Object.assign({}, reader), { utils: {\n isOrIsWithinValidLink\n } });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL3V0aWxzLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQzRDO0FBRXJDLE1BQU0sYUFBYSxHQUlyQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtJQUN6QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBRTVCLE1BQU0scUJBQXFCLEdBQUcsQ0FBQyxNQUF1QixFQUFFLEVBQUU7UUFDeEQsSUFBSSx5REFBYSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3pCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxRQUFRLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDO1lBQ25FLElBQUksSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDOUIsT0FBTyxJQUFJO2FBQ1o7U0FDRjtRQUVELE9BQU8sS0FBSztJQUNkLENBQUM7SUFFRCx1Q0FDSyxNQUFNLEtBQ1QsS0FBSyxFQUFFO1lBQ0wscUJBQXFCO1NBQ3RCLElBQ0Y7QUFDSCxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL2VuaGFuY2Vycy91dGlscy50cz82MGViIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVuaGFuY2VyIH0gZnJvbSBcIi4vdHlwZXNcIlxuaW1wb3J0IHsgaXNIdG1sRWxlbWVudCB9IGZyb20gXCIuLi91dGlscy9kb21cIlxuXG5leHBvcnQgY29uc3QgdXRpbHNFbmhhbmNlcjogRW5oYW5jZXI8e30sIHtcbiAgdXRpbHM6IHtcbiAgICBpc09ySXNXaXRoaW5WYWxpZExpbms6ICh0YXJnZXQ6IEV2ZW50W2B0YXJnZXRgXSkgPT4gYm9vbGVhblxuICB9XG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICBjb25zdCByZWFkZXIgPSBuZXh0KG9wdGlvbnMpXG5cbiAgY29uc3QgaXNPcklzV2l0aGluVmFsaWRMaW5rID0gKHRhcmdldDogRXZlbnRbYHRhcmdldGBdKSA9PiB7XG4gICAgaWYgKGlzSHRtbEVsZW1lbnQodGFyZ2V0KSkge1xuICAgICAgY29uc3QgbGluayA9IHRhcmdldC5ub2RlTmFtZSA9PT0gYGFgID8gdGFyZ2V0IDogdGFyZ2V0LmNsb3Nlc3QoYGFgKVxuICAgICAgaWYgKGxpbms/LmdldEF0dHJpYnV0ZShgaHJlZmApKSB7XG4gICAgICAgIHJldHVybiB0cnVlXG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICByZXR1cm4ge1xuICAgIC4uLnJlYWRlcixcbiAgICB1dGlsczoge1xuICAgICAgaXNPcklzV2l0aGluVmFsaWRMaW5rXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/enhancers/utils.ts\n");
|
|
220
|
+
|
|
221
|
+
/***/ }),
|
|
222
|
+
|
|
223
|
+
/***/ "./src/enhancers/webkit.ts":
|
|
224
|
+
/*!*********************************!*\
|
|
225
|
+
!*** ./src/enhancers/webkit.ts ***!
|
|
226
|
+
\*********************************/
|
|
227
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
228
|
+
|
|
229
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"webkitEnhancer\": () => (/* binding */ webkitEnhancer)\n/* harmony export */ });\nconst IS_SAFARI = navigator.userAgent.indexOf(``) > -1 && navigator.userAgent.indexOf(`Chrome`) <= -1;\nconst webkitEnhancer = (next) => (options) => {\n const transformFlickerFixHooks = [\n {\n name: `spine.onBeforeContainerCreated`,\n fn: element => {\n element.style.cssText = `\n ${element.style.cssText}\n -webkit-transform-style: preserve-3d;\n `;\n return element;\n }\n },\n {\n name: `item.onBeforeContainerCreated`,\n fn: element => {\n element.style.cssText = `\n ${element.style.cssText}\n -webkit-transform-style: preserve-3d;\n -webkit-backface-visibility: hidden;\n `;\n return element;\n }\n }\n ];\n const reader = next(Object.assign(Object.assign({}, options), IS_SAFARI && {\n hooks: [...options.hooks || [], ...transformFlickerFixHooks]\n }));\n return reader;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZW5oYW5jZXJzL3dlYmtpdC50cy5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBTUEsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBSzlGLE1BQU0sY0FBYyxHQUV0QixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtJQU16QixNQUFNLHdCQUF3QixHQUE0QjtRQUN4RDtZQUNFLElBQUksRUFBRSxnQ0FBZ0M7WUFDdEMsRUFBRSxFQUFFLE9BQU8sQ0FBQyxFQUFFO2dCQUNaLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHO1lBQ3BCLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTzs7U0FFeEI7Z0JBRUQsT0FBTyxPQUFPO1lBQ2hCLENBQUM7U0FDRjtRQUNEO1lBQ0UsSUFBSSxFQUFFLCtCQUErQjtZQUNyQyxFQUFFLEVBQUUsT0FBTyxDQUFDLEVBQUU7Z0JBQ1osT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUc7WUFDcEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPOzs7U0FHeEI7Z0JBRUQsT0FBTyxPQUFPO1lBQ2hCLENBQUM7U0FDRjtLQUNGO0lBRUQsTUFBTSxNQUFNLEdBQUcsSUFBSSxpQ0FDZCxPQUFPLEdBQ1AsU0FBUyxJQUFJO1FBQ2QsS0FBSyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxJQUFJLEVBQUUsRUFBRSxHQUFHLHdCQUF3QixDQUFDO0tBQzdELEVBQ0Q7SUFFRixPQUFPLE1BQU07QUFDZixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL2VuaGFuY2Vycy93ZWJraXQudHM/YmQ4OSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmhhbmNlciB9IGZyb20gXCIuL3R5cGVzXCJcblxuLyoqXG4gKiBJZGVhbGx5IHdlIHdhbnQgdG8gdGFyZ2V0IGFsbCB3ZWJraXQgYnJvd3NlciBidXQgYWZhaWsgdGhlcmUgYXJlIG5vIHJlbGlhYmxlIHdheSB0byBkbyBpdC5cbiAqIFdlIHdpbGwgZml4IGF0IGxlYXN0IHNhZmFyaVxuICovXG5jb25zdCBJU19TQUZBUkkgPSBuYXZpZ2F0b3IudXNlckFnZW50LmluZGV4T2YoYGApID4gLTEgJiYgbmF2aWdhdG9yLnVzZXJBZ2VudC5pbmRleE9mKGBDaHJvbWVgKSA8PSAtMVxuXG4vKipcbiAqIEFsbCBmaXhlcyByZWxhdGl2ZSB0byB3ZWJraXRcbiAqL1xuZXhwb3J0IGNvbnN0IHdlYmtpdEVuaGFuY2VyOiBFbmhhbmNlcjx7fSwge1xuXG59PiA9IChuZXh0KSA9PiAob3B0aW9ucykgPT4ge1xuICAvKipcbiAgICogVGhlc2UgaG9va3MgYXJlIHVzZWQgdG8gZml4IHRoZSBmbGlja2VyaW5nIG9uIHNhZmFyaSB0aGF0IG9jY3VycyB3aGVuIHVzaW5nIHRyYW5zZm9ybVxuICAgKiBhbmQgbW9yZSBnZW5lcmFsbHkgR1BVIHRyYW5zZm9ybWF0aW9uLiBJIGFtIG5vdCBzdXJlIHdoYXQgaXMgdGhlIGltcGFjdCBvbiBwZXJmb3JtYW5jZSBzb1xuICAgKiB3ZSBvbmx5IHVzZSB0aGVtIG9uIG5lZWRlZCBlbmdpbmUgKHdlYmtpdCkuXG4gICAqL1xuICBjb25zdCB0cmFuc2Zvcm1GbGlja2VyRml4SG9va3M6IHR5cGVvZiBvcHRpb25zW2Bob29rc2BdID0gW1xuICAgIHtcbiAgICAgIG5hbWU6IGBzcGluZS5vbkJlZm9yZUNvbnRhaW5lckNyZWF0ZWRgLFxuICAgICAgZm46IGVsZW1lbnQgPT4ge1xuICAgICAgICBlbGVtZW50LnN0eWxlLmNzc1RleHQgPSBgXG4gICAgICAgICAgJHtlbGVtZW50LnN0eWxlLmNzc1RleHR9XG4gICAgICAgICAgLXdlYmtpdC10cmFuc2Zvcm0tc3R5bGU6IHByZXNlcnZlLTNkO1xuICAgICAgICBgXG5cbiAgICAgICAgcmV0dXJuIGVsZW1lbnRcbiAgICAgIH1cbiAgICB9LFxuICAgIHtcbiAgICAgIG5hbWU6IGBpdGVtLm9uQmVmb3JlQ29udGFpbmVyQ3JlYXRlZGAsXG4gICAgICBmbjogZWxlbWVudCA9PiB7XG4gICAgICAgIGVsZW1lbnQuc3R5bGUuY3NzVGV4dCA9IGBcbiAgICAgICAgICAke2VsZW1lbnQuc3R5bGUuY3NzVGV4dH1cbiAgICAgICAgICAtd2Via2l0LXRyYW5zZm9ybS1zdHlsZTogcHJlc2VydmUtM2Q7XG4gICAgICAgICAgLXdlYmtpdC1iYWNrZmFjZS12aXNpYmlsaXR5OiBoaWRkZW47XG4gICAgICAgIGBcblxuICAgICAgICByZXR1cm4gZWxlbWVudFxuICAgICAgfVxuICAgIH1cbiAgXVxuXG4gIGNvbnN0IHJlYWRlciA9IG5leHQoe1xuICAgIC4uLm9wdGlvbnMsXG4gICAgLi4uSVNfU0FGQVJJICYmIHtcbiAgICAgIGhvb2tzOiBbLi4ub3B0aW9ucy5ob29rcyB8fCBbXSwgLi4udHJhbnNmb3JtRmxpY2tlckZpeEhvb2tzXVxuICAgIH1cbiAgfSlcblxuICByZXR1cm4gcmVhZGVyXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/enhancers/webkit.ts\n");
|
|
230
|
+
|
|
231
|
+
/***/ }),
|
|
232
|
+
|
|
233
|
+
/***/ "./src/enhancers/zoom.ts":
|
|
234
|
+
/*!*******************************!*\
|
|
235
|
+
!*** ./src/enhancers/zoom.ts ***!
|
|
236
|
+
\*******************************/
|
|
237
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
238
|
+
|
|
239
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"zoomEnhancer\": () => (/* binding */ zoomEnhancer)\n/* harmony export */ });\nconst SHOULD_NOT_LAYOUT = false;\nconst zoomEnhancer = (next) => (options) => {\n const reader = next(options);\n let imageMagnifierContainer;\n let imgLastPosition = { x: 0, y: 0 };\n let movingLastDelta = { x: 0, y: 0 };\n let lastScale = 1;\n const enter = (imgElement) => {\n reader.manipulateContainer((container) => {\n imageMagnifierContainer = container.ownerDocument.createElement(`div`);\n imageMagnifierContainer.style.cssText = `\n top: 0;\n left: 0;\n display: block;\n position: absolute;\n z-index: 1;\n background: black;\n width: 100%;\n height: 100%;\n `;\n const clonedImgElement = imgElement.cloneNode();\n clonedImgElement.src = imgElement.src;\n clonedImgElement.style.setProperty(`height`, `100%`);\n clonedImgElement.style.setProperty(`width`, `100%`);\n clonedImgElement.style.setProperty(`object-fit`, `contain`);\n clonedImgElement.style.setProperty(`pointer-events`, `none`);\n imageMagnifierContainer.appendChild(clonedImgElement);\n container.appendChild(imageMagnifierContainer);\n imgLastPosition = { x: 0, y: 0 };\n lastScale = 1;\n return SHOULD_NOT_LAYOUT;\n });\n };\n const exit = () => {\n reader.manipulateContainer(() => {\n imageMagnifierContainer === null || imageMagnifierContainer === void 0 ? void 0 : imageMagnifierContainer.remove();\n imageMagnifierContainer = undefined;\n return SHOULD_NOT_LAYOUT;\n });\n };\n const move = (delta, { isFirst, isLast }) => {\n const imgElement = imageMagnifierContainer === null || imageMagnifierContainer === void 0 ? void 0 : imageMagnifierContainer.querySelector(`img`);\n if (isFirst) {\n movingLastDelta = { x: 0, y: 0 };\n }\n if (delta) {\n const correctedX = delta.x - ((movingLastDelta === null || movingLastDelta === void 0 ? void 0 : movingLastDelta.x) || 0);\n const correctedY = delta.y - ((movingLastDelta === null || movingLastDelta === void 0 ? void 0 : movingLastDelta.y) || 0);\n imgLastPosition = { x: imgLastPosition.x + correctedX, y: imgLastPosition.y + correctedY };\n imgElement === null || imgElement === void 0 ? void 0 : imgElement.style.setProperty(`transform`, `translate3d(${imgLastPosition.x}px, ${imgLastPosition.y}px, 0px) scale3d(${lastScale}, ${lastScale}, 1)`);\n movingLastDelta = delta;\n }\n if (isLast) {\n movingLastDelta = undefined;\n }\n };\n const scale = (scale) => {\n const imgElement = imageMagnifierContainer === null || imageMagnifierContainer === void 0 ? void 0 : imageMagnifierContainer.querySelector(`img`);\n const roundedScale = Math.ceil(scale * 100) / 100;\n const newScale = Math.max(roundedScale, 1);\n if (roundedScale < 1) {\n imgLastPosition = { x: 0, y: 0 };\n }\n imgElement === null || imgElement === void 0 ? void 0 : imgElement.style.setProperty(`transform`, `translate3d(${imgLastPosition.x}px, ${imgLastPosition.y}px, 0px) scale3d(${newScale}, ${newScale}, 1)`);\n lastScale = newScale;\n };\n const isEnabled = () => !!imageMagnifierContainer;\n const destroy = () => {\n imageMagnifierContainer === null || imageMagnifierContainer === void 0 ? void 0 : imageMagnifierContainer.remove();\n imageMagnifierContainer = undefined;\n reader.destroy();\n };\n return Object.assign(Object.assign({}, reader), { destroy, zoom: {\n enter,\n exit,\n move,\n isEnabled,\n scale\n } });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/enhancers/zoom.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/enhancers/zoom.ts?80d4"],"sourcesContent":["import { Enhancer } from \"./types\"\n\nconst SHOULD_NOT_LAYOUT = false\n\n/**\n *\n */\nexport const zoomEnhancer: Enhancer<{}, {\n  zoom: {\n    enter: (imgElement: HTMLImageElement) => void\n    exit: () => void,\n    move: (position: { x: number, y: number } | undefined, details: { isFirst: boolean, isLast: boolean }) => void,\n    isEnabled: () => boolean,\n    scale: (scale: number) => void,\n  }\n}> = (next) => (options) => {\n  const reader = next(options)\n  let imageMagnifierContainer: HTMLDivElement | undefined\n  let imgLastPosition: { x: number, y: number } = { x: 0, y: 0 }\n  let movingLastDelta: { x: number, y: number } | undefined = { x: 0, y: 0 }\n  let lastScale = 1\n\n  const enter = (imgElement: HTMLImageElement) => {\n    reader.manipulateContainer((container) => {\n      imageMagnifierContainer = container.ownerDocument.createElement(`div`)\n      imageMagnifierContainer.style.cssText = `\n        top: 0;\n        left: 0;\n        display: block;\n        position: absolute;\n        z-index: 1;\n        background: black;\n        width: 100%;\n        height: 100%;\n      `\n      const clonedImgElement = imgElement.cloneNode() as HTMLImageElement\n      clonedImgElement.src = imgElement.src\n      clonedImgElement.style.setProperty(`height`, `100%`)\n      clonedImgElement.style.setProperty(`width`, `100%`)\n      clonedImgElement.style.setProperty(`object-fit`, `contain`)\n      // convenient so that user does not trigger zoom again if for example he is listening to press\n      // on img element. Any press event on the zoom container will not have the img as target.\n      clonedImgElement.style.setProperty(`pointer-events`, `none`)\n\n      imageMagnifierContainer.appendChild(clonedImgElement)\n      container.appendChild(imageMagnifierContainer)\n\n      imgLastPosition = { x: 0, y: 0 }\n      lastScale = 1\n\n      return SHOULD_NOT_LAYOUT\n    })\n  }\n\n  const exit = () => {\n    reader.manipulateContainer(() => {\n      imageMagnifierContainer?.remove()\n      imageMagnifierContainer = undefined\n\n      return SHOULD_NOT_LAYOUT\n    })\n  }\n\n  const move = (delta: { x: number, y: number } | undefined, { isFirst, isLast }: { isFirst: boolean, isLast: boolean }) => {\n    const imgElement = imageMagnifierContainer?.querySelector(`img`)\n\n    if (isFirst) {\n      movingLastDelta = { x: 0, y: 0 }\n    }\n\n    if (delta) {\n      const correctedX = delta.x - (movingLastDelta?.x || 0)\n      const correctedY = delta.y - (movingLastDelta?.y || 0)\n\n      imgLastPosition = { x: imgLastPosition.x + correctedX, y: imgLastPosition.y + correctedY }\n\n      imgElement?.style.setProperty(`transform`, `translate3d(${imgLastPosition.x}px, ${imgLastPosition.y}px, 0px) scale3d(${lastScale}, ${lastScale}, 1)`)\n\n      movingLastDelta = delta\n    }\n\n    if (isLast) {\n      movingLastDelta = undefined\n    }\n  }\n\n  const scale = (scale: number) => {\n    const imgElement = imageMagnifierContainer?.querySelector(`img`)\n    const roundedScale = Math.ceil(scale * 100) / 100\n    const newScale = Math.max(roundedScale, 1)\n\n    // if user zoom out that much, we reset img position\n    if (roundedScale < 1) {\n      imgLastPosition = { x: 0, y: 0 }\n    }\n\n    imgElement?.style.setProperty(`transform`, `translate3d(${imgLastPosition.x}px, ${imgLastPosition.y}px, 0px) scale3d(${newScale}, ${newScale}, 1)`)\n    lastScale = newScale\n  }\n\n  const isEnabled = () => !!imageMagnifierContainer\n\n  const destroy = () => {\n    imageMagnifierContainer?.remove()\n    imageMagnifierContainer = undefined\n    reader.destroy()\n  }\n\n  return {\n    ...reader,\n    destroy,\n    zoom: {\n      enter,\n      exit,\n      move,\n      isEnabled,\n      scale\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/enhancers/zoom.ts\n");
|
|
240
|
+
|
|
241
|
+
/***/ }),
|
|
242
|
+
|
|
243
|
+
/***/ "./src/frames.ts":
|
|
244
|
+
/*!***********************!*\
|
|
245
|
+
!*** ./src/frames.ts ***!
|
|
246
|
+
\***********************/
|
|
247
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
248
|
+
|
|
249
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createRemoveStyleHelper\": () => (/* binding */ createRemoveStyleHelper),\n/* harmony export */ \"createAddStyleHelper\": () => (/* binding */ createAddStyleHelper),\n/* harmony export */ \"getAttributeValueFromString\": () => (/* binding */ getAttributeValueFromString),\n/* harmony export */ \"getOriginalFrameEventFromDocumentEvent\": () => (/* binding */ getOriginalFrameEventFromDocumentEvent),\n/* harmony export */ \"attachOriginalFrameEventToDocumentEvent\": () => (/* binding */ attachOriginalFrameEventToDocumentEvent)\n/* harmony export */ });\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ \"./src/constants.ts\");\n\nconst createRemoveStyleHelper = (frameElement) => (id) => {\n if (frameElement &&\n frameElement.contentDocument &&\n frameElement.contentDocument.head) {\n const styleElement = frameElement.contentDocument.getElementById(id);\n if (styleElement) {\n styleElement.remove();\n }\n }\n};\nconst createAddStyleHelper = (frameElement) => (id, style, prepend = false) => {\n if (frameElement &&\n frameElement.contentDocument &&\n frameElement.contentDocument.head) {\n const userStyle = document.createElement(`style`);\n userStyle.id = id;\n userStyle.innerHTML = style;\n if (prepend) {\n frameElement.contentDocument.head.prepend(userStyle);\n }\n else {\n frameElement.contentDocument.head.appendChild(userStyle);\n }\n }\n};\nconst getAttributeValueFromString = (string, key) => {\n const regExp = new RegExp(key + `\\\\s*=\\\\s*([0-9.]+)`, `i`);\n const match = string.match(regExp) || [];\n const firstMatch = match[1] || `0`;\n return (match && parseFloat(firstMatch)) || 0;\n};\nconst getOriginalFrameEventFromDocumentEvent = (event) => {\n return event[_constants__WEBPACK_IMPORTED_MODULE_0__.__UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY];\n};\nconst attachOriginalFrameEventToDocumentEvent = (event, frameEvent) => {\n Object.defineProperty(event, _constants__WEBPACK_IMPORTED_MODULE_0__.__UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY, { value: frameEvent, enumerable: true });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvZnJhbWVzLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUEwRTtBQUVuRSxNQUFNLHVCQUF1QixHQUFHLENBQUMsWUFBMkMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFVLEVBQUUsRUFBRTtJQUNyRyxJQUNFLFlBQVk7UUFDWixZQUFZLENBQUMsZUFBZTtRQUM1QixZQUFZLENBQUMsZUFBZSxDQUFDLElBQUksRUFDakM7UUFDQSxNQUFNLFlBQVksR0FBRyxZQUFZLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7UUFDcEUsSUFBSSxZQUFZLEVBQUU7WUFDaEIsWUFBWSxDQUFDLE1BQU0sRUFBRTtTQUN0QjtLQUNGO0FBQ0gsQ0FBQztBQUVNLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxZQUEyQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQVUsRUFBRSxLQUFhLEVBQUUsT0FBTyxHQUFHLEtBQUssRUFBRSxFQUFFO0lBQ2xJLElBQ0UsWUFBWTtRQUNaLFlBQVksQ0FBQyxlQUFlO1FBQzVCLFlBQVksQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUNqQztRQUNBLE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDO1FBQ2pELFNBQVMsQ0FBQyxFQUFFLEdBQUcsRUFBRTtRQUNqQixTQUFTLENBQUMsU0FBUyxHQUFHLEtBQUs7UUFDM0IsSUFBSSxPQUFPLEVBQUU7WUFDWCxZQUFZLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDO1NBQ3JEO2FBQU07WUFDTCxZQUFZLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDO1NBQ3pEO0tBQ0Y7QUFDSCxDQUFDO0FBRU0sTUFBTSwyQkFBMkIsR0FBRyxDQUFDLE1BQWMsRUFBRSxHQUFXLEVBQUUsRUFBRTtJQUN6RSxNQUFNLE1BQU0sR0FBRyxJQUFJLE1BQU0sQ0FBQyxHQUFHLEdBQUcsb0JBQW9CLEVBQUUsR0FBRyxDQUFDO0lBQzFELE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRTtJQUN4QyxNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksR0FBRztJQUVsQyxPQUFPLENBQUMsS0FBSyxJQUFJLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUM7QUFDL0MsQ0FBQztBQUVNLE1BQU0sc0NBQXNDLEdBQUcsQ0FBa0IsS0FBUSxFQUFpQixFQUFFO0lBRWpHLE9BQU8sS0FBSyxDQUFDLG9GQUE0QyxDQUFDO0FBQzVELENBQUM7QUFFTSxNQUFNLHVDQUF1QyxHQUFHLENBQWtCLEtBQVEsRUFBRSxVQUFhLEVBQUUsRUFBRTtJQUNsRyxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxvRkFBNEMsRUFBRSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDO0FBQ3JILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvZnJhbWVzLnRzPzE0MzYiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgX19VTlNBRkVfUkVGRVJFTkNFX09SSUdJTkFMX0lGUkFNRV9FVkVOVF9LRVkgfSBmcm9tIFwiLi9jb25zdGFudHNcIlxuXG5leHBvcnQgY29uc3QgY3JlYXRlUmVtb3ZlU3R5bGVIZWxwZXIgPSAoZnJhbWVFbGVtZW50OiBIVE1MSUZyYW1lRWxlbWVudCB8IHVuZGVmaW5lZCkgPT4gKGlkOiBzdHJpbmcpID0+IHtcbiAgaWYgKFxuICAgIGZyYW1lRWxlbWVudCAmJlxuICAgIGZyYW1lRWxlbWVudC5jb250ZW50RG9jdW1lbnQgJiZcbiAgICBmcmFtZUVsZW1lbnQuY29udGVudERvY3VtZW50LmhlYWRcbiAgKSB7XG4gICAgY29uc3Qgc3R5bGVFbGVtZW50ID0gZnJhbWVFbGVtZW50LmNvbnRlbnREb2N1bWVudC5nZXRFbGVtZW50QnlJZChpZClcbiAgICBpZiAoc3R5bGVFbGVtZW50KSB7XG4gICAgICBzdHlsZUVsZW1lbnQucmVtb3ZlKClcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUFkZFN0eWxlSGVscGVyID0gKGZyYW1lRWxlbWVudDogSFRNTElGcmFtZUVsZW1lbnQgfCB1bmRlZmluZWQpID0+IChpZDogc3RyaW5nLCBzdHlsZTogc3RyaW5nLCBwcmVwZW5kID0gZmFsc2UpID0+IHtcbiAgaWYgKFxuICAgIGZyYW1lRWxlbWVudCAmJlxuICAgIGZyYW1lRWxlbWVudC5jb250ZW50RG9jdW1lbnQgJiZcbiAgICBmcmFtZUVsZW1lbnQuY29udGVudERvY3VtZW50LmhlYWRcbiAgKSB7XG4gICAgY29uc3QgdXNlclN0eWxlID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChgc3R5bGVgKVxuICAgIHVzZXJTdHlsZS5pZCA9IGlkXG4gICAgdXNlclN0eWxlLmlubmVySFRNTCA9IHN0eWxlXG4gICAgaWYgKHByZXBlbmQpIHtcbiAgICAgIGZyYW1lRWxlbWVudC5jb250ZW50RG9jdW1lbnQuaGVhZC5wcmVwZW5kKHVzZXJTdHlsZSlcbiAgICB9IGVsc2Uge1xuICAgICAgZnJhbWVFbGVtZW50LmNvbnRlbnREb2N1bWVudC5oZWFkLmFwcGVuZENoaWxkKHVzZXJTdHlsZSlcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGdldEF0dHJpYnV0ZVZhbHVlRnJvbVN0cmluZyA9IChzdHJpbmc6IHN0cmluZywga2V5OiBzdHJpbmcpID0+IHtcbiAgY29uc3QgcmVnRXhwID0gbmV3IFJlZ0V4cChrZXkgKyBgXFxcXHMqPVxcXFxzKihbMC05Ll0rKWAsIGBpYClcbiAgY29uc3QgbWF0Y2ggPSBzdHJpbmcubWF0Y2gocmVnRXhwKSB8fCBbXVxuICBjb25zdCBmaXJzdE1hdGNoID0gbWF0Y2hbMV0gfHwgYDBgXG5cbiAgcmV0dXJuIChtYXRjaCAmJiBwYXJzZUZsb2F0KGZpcnN0TWF0Y2gpKSB8fCAwXG59XG5cbmV4cG9ydCBjb25zdCBnZXRPcmlnaW5hbEZyYW1lRXZlbnRGcm9tRG9jdW1lbnRFdmVudCA9IDxFIGV4dGVuZHMgRXZlbnQ+KGV2ZW50OiBFKTogRSB8IHVuZGVmaW5lZCA9PiB7XG4gIC8vIEB0cy1pZ25vcmVcbiAgcmV0dXJuIGV2ZW50W19fVU5TQUZFX1JFRkVSRU5DRV9PUklHSU5BTF9JRlJBTUVfRVZFTlRfS0VZXVxufVxuXG5leHBvcnQgY29uc3QgYXR0YWNoT3JpZ2luYWxGcmFtZUV2ZW50VG9Eb2N1bWVudEV2ZW50ID0gPEUgZXh0ZW5kcyBFdmVudD4oZXZlbnQ6IEUsIGZyYW1lRXZlbnQ6IEUpID0+IHtcbiAgT2JqZWN0LmRlZmluZVByb3BlcnR5KGV2ZW50LCBfX1VOU0FGRV9SRUZFUkVOQ0VfT1JJR0lOQUxfSUZSQU1FX0VWRU5UX0tFWSwgeyB2YWx1ZTogZnJhbWVFdmVudCwgZW51bWVyYWJsZTogdHJ1ZSB9KVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/frames.ts\n");
|
|
250
|
+
|
|
251
|
+
/***/ }),
|
|
252
|
+
|
|
253
|
+
/***/ "./src/index.ts":
|
|
254
|
+
/*!**********************!*\
|
|
255
|
+
!*** ./src/index.ts ***!
|
|
256
|
+
\**********************/
|
|
257
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
258
|
+
|
|
259
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"compose\": () => (/* reexport safe */ _utils_compose__WEBPACK_IMPORTED_MODULE_1__.compose),\n/* harmony export */ \"createReader\": () => (/* reexport safe */ _createReaderWithEnhancer__WEBPACK_IMPORTED_MODULE_0__.createReaderWithEnhancer),\n/* harmony export */ \"Report\": () => (/* reexport safe */ _report__WEBPACK_IMPORTED_MODULE_2__.Report),\n/* harmony export */ \"composeEnhancer\": () => (/* reexport safe */ _enhancers_composeEnhancer__WEBPACK_IMPORTED_MODULE_3__.composeEnhancer),\n/* harmony export */ \"groupBy\": () => (/* reexport safe */ _utils_objects__WEBPACK_IMPORTED_MODULE_4__.groupBy),\n/* harmony export */ \"isShallowEqual\": () => (/* reexport safe */ _utils_objects__WEBPACK_IMPORTED_MODULE_4__.isShallowEqual)\n/* harmony export */ });\n/* harmony import */ var _createReaderWithEnhancer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createReaderWithEnhancer */ \"./src/createReaderWithEnhancer.ts\");\n/* harmony import */ var _utils_compose__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./utils/compose */ \"./src/utils/compose.ts\");\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./report */ \"./src/report.ts\");\n/* harmony import */ var _enhancers_composeEnhancer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./enhancers/composeEnhancer */ \"./src/enhancers/composeEnhancer.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./utils/objects */ \"./src/utils/objects.ts\");\n\n\n\n\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvaW5kZXgudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7QUFLbUM7QUFJTTtBQVV4QztBQWFnQztBQUU0QjtBQUNKIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL2luZGV4LnRzP2ZmYjQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY3JlYXRlUmVhZGVyV2l0aEVuaGFuY2VyIGFzIGNyZWF0ZVJlYWRlcixcbiAgUmVhZGVyLFxuICBDb3JlRW5oYW5jZXIsXG4gIEV4dGVybmFsRW5oYW5jZXIgYXMgRW5oYW5jZXJcbn0gZnJvbSAnLi9jcmVhdGVSZWFkZXJXaXRoRW5oYW5jZXInXG5pbXBvcnQgeyBjcmVhdGVTZWxlY3Rpb24gfSBmcm9tICcuL3NlbGVjdGlvbidcbi8vIGltcG9ydCB7IEVuaGFuY2VyIGFzIElubmVyRW5oYW5jZXIgfSBmcm9tICcuL2VuaGFuY2Vycy90eXBlcydcbi8vIGV4cG9ydCB7IEVuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvdHlwZXMnXG5leHBvcnQgeyBjb21wb3NlIH0gZnJvbSAnLi91dGlscy9jb21wb3NlJ1xuZXhwb3J0IHsgQ29tcG9zZUVuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvY29tcG9zZUVuaGFuY2VyJ1xuXG5leHBvcnQgeyBNYW5pZmVzdCB9IGZyb20gJy4vdHlwZXMnXG5cbmV4cG9ydCB7XG4gIGNyZWF0ZVJlYWRlcixcbiAgUmVhZGVyLFxuICBFbmhhbmNlclxuICAvLyBDb3JlRW5oYW5jZXJcbn1cblxuLy8gZXhwb3J0IHR5cGUgRW5oYW5jZXI8XG4vLyAgIE9wdGlvbnMgPSB7fSxcbi8vICAgQXBpID0ge30sXG4vLyAgIFNldHRpbmdzID0ge30sXG4vLyAgIE91dHB1dFNldHRpbmdzID0gU2V0dGluZ3MsXG4vLyAgIC8vIERlcGVuZHNPbiBleHRlbmRzIEVuaGFuY2VyID0gUmVhZGVyV2l0aEVuaGFuY2VyRW5oYW5jZXJcbi8vICAgRGVwZW5kc09uIGV4dGVuZHMgUmVhZGVyV2l0aEVuaGFuY2VyRW5oYW5jZXIgPSBSZWFkZXJXaXRoRW5oYW5jZXJFbmhhbmNlclxuLy8gPiA9IElubmVyRW5oYW5jZXI8T3B0aW9ucywgQXBpLCBTZXR0aW5ncywgT3V0cHV0U2V0dGluZ3MsIERlcGVuZHNPbj5cblxuZXhwb3J0IHR5cGUgUmVhZGVyU2VsZWN0aW9uID0gUmV0dXJuVHlwZTx0eXBlb2YgY3JlYXRlU2VsZWN0aW9uPlxuXG5leHBvcnQgeyBSZXBvcnQgfSBmcm9tICcuL3JlcG9ydCdcblxuZXhwb3J0IHsgY29tcG9zZUVuaGFuY2VyIH0gZnJvbSAnLi9lbmhhbmNlcnMvY29tcG9zZUVuaGFuY2VyJ1xuZXhwb3J0IHsgZ3JvdXBCeSwgaXNTaGFsbG93RXF1YWwgfSBmcm9tICcuL3V0aWxzL29iamVjdHMnXG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/index.ts\n");
|
|
260
|
+
|
|
261
|
+
/***/ }),
|
|
262
|
+
|
|
263
|
+
/***/ "./src/pagination.ts":
|
|
264
|
+
/*!***************************!*\
|
|
265
|
+
!*** ./src/pagination.ts ***!
|
|
266
|
+
\***************************/
|
|
267
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
268
|
+
|
|
269
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createPagination\": () => (/* binding */ createPagination),\n/* harmony export */ \"getItemOffsetFromPageIndex\": () => (/* binding */ getItemOffsetFromPageIndex),\n/* harmony export */ \"getNumberOfPages\": () => (/* binding */ getNumberOfPages),\n/* harmony export */ \"getClosestValidOffsetFromApproximateOffsetInPages\": () => (/* binding */ getClosestValidOffsetFromApproximateOffsetInPages)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./report */ \"./src/report.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils/objects */ \"./src/utils/objects.ts\");\n\n\n\nconst NAMESPACE = `pagination`;\nconst createPagination = ({ context }) => {\n const paginationSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject({\n beginPageIndex: undefined,\n beginNumberOfPages: 0,\n beginCfi: undefined,\n beginSpineItemIndex: undefined,\n endPageIndex: undefined,\n endNumberOfPages: 0,\n endCfi: undefined,\n endSpineItemIndex: undefined\n });\n const getSpineItemNumberOfPages = (spineItem) => {\n const writingMode = spineItem.spineItemFrame.getWritingMode();\n const { width, height } = spineItem.getElementDimensions();\n if (writingMode === `vertical-rl`) {\n return getNumberOfPages(height, context.getPageSize().height);\n }\n return getNumberOfPages(width, context.getPageSize().width);\n };\n const getInfoForUpdate = (info) => {\n const numberOfPages = getSpineItemNumberOfPages(info.spineItem);\n const cfi = undefined;\n return {\n numberOfPages,\n pageIndex: info.pageIndex,\n cfi: info.cfi\n };\n };\n const updateBeginAndEnd = _report__WEBPACK_IMPORTED_MODULE_1__.Report.measurePerformance(`${NAMESPACE} updateBeginAndEnd`, 1, (begin, end) => {\n const beginInfo = getInfoForUpdate(begin);\n const endInfo = getInfoForUpdate(end);\n const newValues = {\n beginPageIndex: beginInfo.pageIndex,\n beginNumberOfPages: beginInfo.numberOfPages,\n beginCfi: beginInfo.cfi,\n beginSpineItemIndex: begin.spineItemIndex,\n endPageIndex: endInfo.pageIndex,\n endNumberOfPages: endInfo.numberOfPages,\n endCfi: endInfo.cfi,\n endSpineItemIndex: end.spineItemIndex\n };\n paginationSubject$.next(Object.assign(Object.assign({}, paginationSubject$.value), newValues));\n }, { disable: true });\n const getInfo = () => paginationSubject$.value;\n const info$ = paginationSubject$\n .asObservable()\n .pipe((0,rxjs__WEBPACK_IMPORTED_MODULE_0__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_2__.isShallowEqual));\n const destroy = () => {\n paginationSubject$.complete();\n };\n return {\n destroy,\n updateBeginAndEnd,\n getInfo,\n $: {\n info$\n }\n };\n};\nconst getItemOffsetFromPageIndex = (pageWidth, pageIndex, itemWidth) => {\n const lastPageOffset = itemWidth - pageWidth;\n const logicalOffset = (itemWidth * (pageIndex * pageWidth)) / itemWidth;\n return Math.max(0, Math.min(lastPageOffset, logicalOffset));\n};\nconst getNumberOfPages = (itemWidth, pageWidth) => {\n if ((pageWidth || 0) === 0 || (itemWidth || 0) === 0)\n return 1;\n return Math.floor(Math.max(1, itemWidth / pageWidth));\n};\nconst getClosestValidOffsetFromApproximateOffsetInPages = (offset, pageWidth, itemWidth) => {\n const numberOfPages = getNumberOfPages(itemWidth, pageWidth);\n const offsetValues = [...Array(numberOfPages)].map((_, i) => i * pageWidth);\n if (offset >= (numberOfPages * pageWidth))\n return offsetValues[offsetValues.length - 1] || 0;\n return offsetValues.find(offsetRange => offset < (offsetRange + pageWidth)) || 0;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/pagination.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/pagination.ts?b3df"],"sourcesContent":["import { BehaviorSubject, distinctUntilChanged } from \"rxjs\"\nimport { Context } from \"./context\"\nimport { SpineItem } from \"./spineItem/createSpineItem\"\nimport { SpineItemManager } from \"./spineItemManager\"\nimport { Report } from \"./report\"\nimport { isShallowEqual } from \"./utils/objects\"\n\nconst NAMESPACE = `pagination`\n\ntype PaginationInfo = {\n  beginPageIndex: number | undefined\n  beginNumberOfPages: number\n  beginCfi: string | undefined\n  beginSpineItemIndex: number | undefined\n  endPageIndex: number | undefined\n  endNumberOfPages: number\n  endCfi: string | undefined\n  endSpineItemIndex: number | undefined\n}\n\nexport const createPagination = ({ context }: { context: Context, spineItemManager: SpineItemManager }) => {\n  const paginationSubject$ = new BehaviorSubject<PaginationInfo>({\n    beginPageIndex: undefined,\n    beginNumberOfPages: 0,\n    beginCfi: undefined,\n    beginSpineItemIndex: undefined,\n    endPageIndex: undefined,\n    endNumberOfPages: 0,\n    endCfi: undefined,\n    endSpineItemIndex: undefined\n  })\n\n  const getSpineItemNumberOfPages = (spineItem: SpineItem) => {\n    // pre-paginated always are only one page\n    // if (!spineItem.isReflowable) return 1\n\n    const writingMode = spineItem.spineItemFrame.getWritingMode()\n    const { width, height } = spineItem.getElementDimensions()\n\n    if (writingMode === `vertical-rl`) {\n      return getNumberOfPages(height, context.getPageSize().height)\n    }\n\n    return getNumberOfPages(width, context.getPageSize().width)\n  }\n\n  const getInfoForUpdate = (info: {\n    spineItem: SpineItem,\n    // spineItemPosition: { x: number, y: number },\n    pageIndex: number,\n    cfi: string | undefined,\n    options: {\n      isAtEndOfChapter?: boolean,\n      // cfi?: string\n    }\n  }) => {\n    const numberOfPages = getSpineItemNumberOfPages(info.spineItem)\n    // const pageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(info.spineItemPosition, info.spineItem)\n    const cfi: string | undefined = undefined\n\n    // @todo update pagination cfi whenever iframe is ready (cause even offset may not change but we still need to get the iframe for cfi)\n    // @todo update cfi also whenever a resize occurs in the iframe\n    // - load\n    // - font loaded\n    // - resize\n    // future changes would potentially only be resize (easy to track) and font size family change.\n    // to track that we can have a hidden text element and track it and send event back\n    // console.warn(typeof info.options.cfi)\n    // if (info.options.cfi === undefined) {\n    //   cfi = spineItemLocator.getCfi(pageIndex, info.spineItem)\n    //   Report.log(`pagination`, `cfi`, pageIndex, cfi)\n    // } else {\n    //   cfi = info.options.cfi\n    // }\n\n    // cfi = info.options.cfi\n\n    return {\n      numberOfPages,\n      pageIndex: info.pageIndex,\n      cfi: info.cfi\n    }\n  }\n\n  const updateBeginAndEnd = Report.measurePerformance(`${NAMESPACE} updateBeginAndEnd`, 1, (\n    begin: Parameters<typeof getInfoForUpdate>[0] & {\n      spineItemIndex: number,\n    },\n    end: Parameters<typeof getInfoForUpdate>[0] & {\n      spineItemIndex: number,\n    }\n  ) => {\n    const beginInfo = getInfoForUpdate(begin)\n    const endInfo = getInfoForUpdate(end)\n\n    const newValues = {\n      beginPageIndex: beginInfo.pageIndex,\n      beginNumberOfPages: beginInfo.numberOfPages,\n      beginCfi: beginInfo.cfi,\n      beginSpineItemIndex: begin.spineItemIndex,\n      endPageIndex: endInfo.pageIndex,\n      endNumberOfPages: endInfo.numberOfPages,\n      endCfi: endInfo.cfi,\n      endSpineItemIndex: end.spineItemIndex\n    }\n\n    paginationSubject$.next({\n      ...paginationSubject$.value,\n      ...newValues\n    })\n  }, { disable: true })\n\n  const getInfo = () => paginationSubject$.value\n\n  const info$ = paginationSubject$\n    .asObservable()\n    .pipe(\n      distinctUntilChanged(isShallowEqual)\n    )\n\n  const destroy = () => {\n    paginationSubject$.complete()\n  }\n\n  return {\n    destroy,\n    updateBeginAndEnd,\n    getInfo,\n    $: {\n      info$\n    }\n  }\n}\n\nexport type Pagination = ReturnType<typeof createPagination>\n\nexport const getItemOffsetFromPageIndex = (pageWidth: number, pageIndex: number, itemWidth: number) => {\n  const lastPageOffset = itemWidth - pageWidth\n  const logicalOffset = (itemWidth * (pageIndex * pageWidth)) / itemWidth\n\n  return Math.max(0, Math.min(lastPageOffset, logicalOffset))\n}\n\nexport const getNumberOfPages = (itemWidth: number, pageWidth: number) => {\n  if ((pageWidth || 0) === 0 || (itemWidth || 0) === 0) return 1\n  return Math.floor(Math.max(1, itemWidth / pageWidth))\n}\n\nexport const getClosestValidOffsetFromApproximateOffsetInPages = (offset: number, pageWidth: number, itemWidth: number) => {\n  const numberOfPages = getNumberOfPages(itemWidth, pageWidth)\n  const offsetValues = [...Array(numberOfPages)].map((_, i) => i * pageWidth)\n\n  if (offset >= (numberOfPages * pageWidth)) return offsetValues[offsetValues.length - 1] || 0\n\n  return offsetValues.find(offsetRange => offset < (offsetRange + pageWidth)) || 0\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/pagination.ts\n");
|
|
270
|
+
|
|
271
|
+
/***/ }),
|
|
272
|
+
|
|
273
|
+
/***/ "./src/reader.ts":
|
|
274
|
+
/*!***********************!*\
|
|
275
|
+
!*** ./src/reader.ts ***!
|
|
276
|
+
\***********************/
|
|
277
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
278
|
+
|
|
279
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createReader\": () => (/* binding */ createReader)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./report */ \"./src/report.ts\");\n/* harmony import */ var _context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./context */ \"./src/context.ts\");\n/* harmony import */ var _pagination__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./pagination */ \"./src/pagination.ts\");\n/* harmony import */ var _spine_createSpine__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./spine/createSpine */ \"./src/spine/createSpine.ts\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _spineItemManager__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./spineItemManager */ \"./src/spineItemManager.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./utils/objects */ \"./src/utils/objects.ts\");\nvar __rest = (undefined && undefined.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\n\n\n\n\n\n\nconst IFRAME_EVENT_BRIDGE_ELEMENT_ID = `proseReaderIframeEventBridgeElement`;\nconst createReader = (_a) => {\n var { containerElement, hooks: initialHooks } = _a, settings = __rest(_a, [\"containerElement\", \"hooks\"]);\n const stateSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject({\n supportedPageTurnAnimation: [`fade`, `none`, `slide`],\n supportedPageTurnMode: [`controlled`, `scrollable`],\n supportedPageTurnDirection: [`horizontal`, `vertical`],\n supportedComputedPageTurnDirection: [`horizontal`, `vertical`]\n });\n const readySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const destroy$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const selectionSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const hooksSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(initialHooks || []);\n const context = (0,_context__WEBPACK_IMPORTED_MODULE_2__.createContext)(settings);\n const spineItemManager = (0,_spineItemManager__WEBPACK_IMPORTED_MODULE_6__.createSpineItemManager)({ context });\n const pagination = (0,_pagination__WEBPACK_IMPORTED_MODULE_3__.createPagination)({ context, spineItemManager });\n const element = createWrapperElement(containerElement);\n const iframeEventBridgeElement = createIframeEventBridgeElement(containerElement);\n const spine = (0,_spine_createSpine__WEBPACK_IMPORTED_MODULE_4__.createSpine)({\n parentElement: element,\n iframeEventBridgeElement,\n context,\n pagination,\n spineItemManager,\n hooks$: hooksSubject$\n });\n containerElement.appendChild(element);\n element.appendChild(iframeEventBridgeElement);\n const layout = () => {\n const dimensions = {\n width: containerElement.offsetWidth,\n height: containerElement.offsetHeight\n };\n const margin = 0;\n const marginTop = 0;\n const marginBottom = 0;\n const isReflow = true;\n const containerElementWidth = dimensions.width;\n const containerElementEvenWidth = containerElementWidth % 2 === 0 || isReflow\n ? containerElementWidth\n : containerElementWidth - 1;\n element.style.setProperty(`overflow`, `hidden`);\n element.style.height = `${dimensions.height - marginTop - marginBottom}px`;\n element.style.width = `${containerElementEvenWidth - 2 * margin}px`;\n if (margin > 0 || marginTop > 0 || marginBottom > 0) {\n element.style.margin = `${marginTop}px ${margin}px ${marginBottom}px`;\n }\n const elementRect = element.getBoundingClientRect();\n context.setVisibleAreaRect(elementRect.x, elementRect.y, containerElementEvenWidth, dimensions.height);\n spine.layout();\n };\n const load = (manifest, loadOptions = {}) => {\n if (context.getManifest()) {\n _report__WEBPACK_IMPORTED_MODULE_1__.Report.warn(`loading a new book is not supported yet`);\n return;\n }\n _report__WEBPACK_IMPORTED_MODULE_1__.Report.log(`load`, { manifest, loadOptions });\n context.load(manifest, loadOptions);\n layout();\n if (!loadOptions.cfi) {\n spine.viewportNavigator.goToSpineItem(0, { animate: false });\n }\n else {\n spine.viewportNavigator.goToCfi(loadOptions.cfi, { animate: false });\n }\n readySubject$.next();\n };\n const registerHook = (name, fn) => {\n hooksSubject$.next([...hooksSubject$.getValue(), { name, fn }]);\n };\n const manipulateContainer = (cb) => {\n cb(element);\n };\n spine.$.$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.tap)(event => {\n if (event.type === `onSelectionChange`) {\n selectionSubject$.next(event.data);\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.takeUntil)(destroy$))\n .subscribe();\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(context.$.load$, context.$.settings$, context.$.hasVerticalWriting$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.mapTo)(undefined), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.withLatestFrom)(context.$.hasVerticalWriting$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.map)(([, hasVerticalWriting]) => {\n const settings = context.getSettings();\n const manifest = context.getManifest();\n return {\n hasVerticalWriting,\n renditionFlow: manifest === null || manifest === void 0 ? void 0 : manifest.renditionFlow,\n renditionLayout: manifest === null || manifest === void 0 ? void 0 : manifest.renditionLayout,\n computedPageTurnMode: settings.computedPageTurnMode\n };\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_7__.isShallowEqual), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.map)(({ hasVerticalWriting, renditionFlow, renditionLayout, computedPageTurnMode }) => (Object.assign(Object.assign({}, stateSubject$.value), { supportedPageTurnMode: renditionFlow === `scrolled-continuous`\n ? [`scrollable`]\n : !context.areAllItemsPrePaginated() ? [`controlled`] : [`controlled`, `scrollable`], supportedPageTurnAnimation: renditionFlow === `scrolled-continuous` || computedPageTurnMode === `scrollable`\n ? [`none`]\n : hasVerticalWriting\n ? [`fade`, `none`]\n : [`fade`, `none`, `slide`], supportedPageTurnDirection: computedPageTurnMode === `scrollable`\n ? [`vertical`]\n : renditionLayout === `reflowable`\n ? [`horizontal`]\n : [`horizontal`, `vertical`] }))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.takeUntil)(destroy$))\n .subscribe(stateSubject$);\n const destroy = () => {\n hooksSubject$.next([]);\n hooksSubject$.complete();\n pagination.destroy();\n context.destroy();\n spine === null || spine === void 0 ? void 0 : spine.destroy();\n element.remove();\n iframeEventBridgeElement.remove();\n readySubject$.complete();\n stateSubject$.complete();\n selectionSubject$.complete();\n destroy$.next();\n destroy$.complete();\n };\n const reader = {\n context,\n registerHook,\n spine,\n manipulateSpineItems: spine.manipulateSpineItems,\n manipulateContainer,\n moveTo: spine.viewportNavigator.moveTo,\n turnLeft: spine.viewportNavigator.turnLeft,\n turnRight: spine.viewportNavigator.turnRight,\n goToPageOfCurrentChapter: spine.viewportNavigator.goToPageOfCurrentChapter,\n goToPage: spine.viewportNavigator.goToPage,\n goToUrl: spine.viewportNavigator.goToUrl,\n goToCfi: spine.viewportNavigator.goToCfi,\n goToSpineItem: spine.viewportNavigator.goToSpineItem,\n getFocusedSpineItemIndex: spineItemManager.getFocusedSpineItemIndex,\n getSpineItem: spineItemManager.get,\n getSpineItems: spineItemManager.getAll,\n getAbsolutePositionOf: spineItemManager.getAbsolutePositionOf,\n getSelection: spine.getSelection,\n isSelecting: spine.isSelecting,\n normalizeEventForViewport: spine.normalizeEventForViewport,\n getCfiMetaInformation: spine.cfiLocator.getCfiMetaInformation,\n resolveCfi: spine.cfiLocator.resolveCfi,\n generateCfi: spine.cfiLocator.generateFromRange,\n locator: spine.locator,\n getCurrentNavigationPosition: spine.viewportNavigator.getCurrentNavigationPosition,\n getCurrentViewportPosition: spine.viewportNavigator.getCurrentViewportPosition,\n layout,\n load,\n destroy,\n setSettings: context.setSettings,\n $: {\n pagination$: pagination.$.info$,\n settings$: context.$.settings$,\n state$: stateSubject$.asObservable(),\n ready$: readySubject$.asObservable(),\n selection$: selectionSubject$.asObservable(),\n viewportState$: spine.$.viewportState$,\n layout$: spine.$.layout$,\n destroy$\n },\n __debug: {\n pagination,\n context,\n spineItemManager\n }\n };\n return reader;\n};\nconst createWrapperElement = (containerElement) => {\n const element = containerElement.ownerDocument.createElement(`div`);\n element.style.cssText = `\n background-color: white;\n position: relative;\n `;\n return element;\n};\nconst createIframeEventBridgeElement = (containerElement) => {\n const iframeEventBridgeElement = containerElement.ownerDocument.createElement(`div`);\n iframeEventBridgeElement.id = IFRAME_EVENT_BRIDGE_ELEMENT_ID;\n iframeEventBridgeElement.style.cssText = `\n position: absolute;\n height: 100%;\n width: 100%;\n top: 0;\n left: 0;\n z-index: -1;\n `;\n return iframeEventBridgeElement;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/reader.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/reader.ts?98c6"],"sourcesContent":["import { BehaviorSubject, merge, Observable, ObservedValueOf, Subject } from \"rxjs\"\nimport { Report } from \"./report\"\nimport { createContext as createBookContext } from \"./context\"\nimport { createPagination, Pagination } from \"./pagination\"\nimport { createSpine, Spine } from \"./spine/createSpine\"\nimport { LoadOptions, Manifest } from \"./types\"\nimport { __UNSAFE_REFERENCE_ORIGINAL_IFRAME_EVENT_KEY } from \"./constants\"\nimport { takeUntil, tap, distinctUntilChanged, withLatestFrom, mapTo, map } from \"rxjs/operators\"\nimport { createSelection } from \"./selection\"\nimport { createSpineItemManager, SpineItemManager } from \"./spineItemManager\"\nimport { Hook, RegisterHook } from \"./types/Hook\"\nimport { isShallowEqual } from \"./utils/objects\"\n\ntype Context = ReturnType<typeof createBookContext>\ntype ContextSettings = Parameters<Context[`setSettings`]>[0]\n\nconst IFRAME_EVENT_BRIDGE_ELEMENT_ID = `proseReaderIframeEventBridgeElement`\n\ntype CreateReaderOptions = {\n  hooks?: Hook[]\n  containerElement: HTMLElement,\n} & Pick<\n  ContextSettings,\n  | `forceSinglePageMode`\n  | `pageTurnAnimation`\n  | `pageTurnDirection`\n  | `pageTurnMode`\n>\n\nexport type Reader = {\n  // innerPagination: Pagination,\n  context: Context,\n  registerHook: RegisterHook,\n  spine: Spine,\n  manipulateSpineItems: Spine[`manipulateSpineItems`],\n  manipulateContainer: (cb: (container: HTMLElement) => boolean) => void,\n  moveTo: Spine[`viewportNavigator`][`moveTo`],\n  turnLeft: Spine[`viewportNavigator`][`turnLeft`],\n  turnRight: Spine[`viewportNavigator`][`turnRight`],\n  goToPageOfCurrentChapter: Spine[`viewportNavigator`][`goToPageOfCurrentChapter`],\n  goToPage: Spine[`viewportNavigator`][`goToPage`],\n  goToUrl: Spine[`viewportNavigator`][`goToUrl`],\n  goToCfi: Spine[`viewportNavigator`][`goToCfi`],\n  goToSpineItem: Spine[`viewportNavigator`][`goToSpineItem`],\n  getFocusedSpineItemIndex: SpineItemManager[`getFocusedSpineItemIndex`],\n  getSpineItem: SpineItemManager[`get`],\n  getSpineItems: SpineItemManager[`getAll`],\n  getAbsolutePositionOf: SpineItemManager[`getAbsolutePositionOf`],\n  getSelection: Spine[`getSelection`],\n  isSelecting: Spine[`isSelecting`],\n  normalizeEventForViewport: Spine[`normalizeEventForViewport`],\n  getCfiMetaInformation: Spine[`cfiLocator`][`getCfiMetaInformation`],\n  resolveCfi: Spine[`cfiLocator`][`resolveCfi`],\n  generateCfi: Spine[`cfiLocator`][`generateFromRange`],\n  locator: Spine[`locator`],\n  getCurrentNavigationPosition: Spine[`viewportNavigator`][`getCurrentNavigationPosition`],\n  getCurrentViewportPosition: Spine[`viewportNavigator`][`getCurrentViewportPosition`],\n  layout: () => void,\n  load: (manifest: Manifest, loadOptions?: LoadOptions) => void,\n  destroy: () => void,\n  setSettings: Context[`setSettings`],\n  $: {\n    pagination$: Pagination[`$`][`info$`]\n    settings$: Context[`$`][`settings$`],\n    state$: Observable<{\n      supportedPageTurnAnimation: NonNullable<ContextSettings[`pageTurnAnimation`]>[]\n      supportedPageTurnMode: NonNullable<ContextSettings[`pageTurnMode`]>[]\n      supportedPageTurnDirection: NonNullable<ContextSettings[`pageTurnDirection`]>[]\n      supportedComputedPageTurnDirection: NonNullable<ContextSettings[`pageTurnDirection`]>[]\n    }>,\n    /**\n     * Dispatched when the reader has loaded a book and is displayed a book.\n     * Using navigation API and getting information about current content will\n     * have an effect.\n     * It can typically be used to hide a loading indicator.\n     */\n    ready$: Observable<void>,\n    /**\n     * Dispatched when a change in selection happens\n     */\n    selection$: Observable<ReturnType<typeof createSelection> | null>,\n    viewportState$: Spine[`$`][`viewportState$`],\n    layout$: Spine[`$`][`layout$`],\n    destroy$: Observable<void>,\n  },\n}\n\nexport const createReader = ({ containerElement, hooks: initialHooks, ...settings }: CreateReaderOptions): Reader => {\n  const stateSubject$ = new BehaviorSubject<{\n    supportedPageTurnAnimation: NonNullable<ContextSettings[`pageTurnAnimation`]>[]\n    supportedPageTurnMode: NonNullable<ContextSettings[`pageTurnMode`]>[]\n    supportedPageTurnDirection: NonNullable<ContextSettings[`pageTurnDirection`]>[]\n    supportedComputedPageTurnDirection: NonNullable<ContextSettings[`pageTurnDirection`]>[]\n  }>({\n    supportedPageTurnAnimation: [`fade`, `none`, `slide`],\n    supportedPageTurnMode: [`controlled`, `scrollable`],\n    supportedPageTurnDirection: [`horizontal`, `vertical`],\n    supportedComputedPageTurnDirection: [`horizontal`, `vertical`]\n  })\n  const readySubject$ = new Subject<void>()\n  const destroy$ = new Subject<void>()\n  const selectionSubject$ = new Subject<ReturnType<typeof createSelection> | null>()\n  const hooksSubject$ = new BehaviorSubject<Hook[]>(initialHooks || [])\n  const context = createBookContext(settings)\n  const spineItemManager = createSpineItemManager({ context })\n  const pagination = createPagination({ context, spineItemManager })\n  const element = createWrapperElement(containerElement)\n  const iframeEventBridgeElement = createIframeEventBridgeElement(containerElement)\n  const spine = createSpine({\n    parentElement: element,\n    iframeEventBridgeElement,\n    context,\n    pagination,\n    spineItemManager,\n    hooks$: hooksSubject$\n  })\n\n  containerElement.appendChild(element)\n  element.appendChild(iframeEventBridgeElement)\n\n  const layout = () => {\n    const dimensions = {\n      width: containerElement.offsetWidth,\n      height: containerElement.offsetHeight\n    }\n    const margin = 0\n    const marginTop = 0\n    const marginBottom = 0\n    const isReflow = true // @todo\n    const containerElementWidth = dimensions.width\n    const containerElementEvenWidth =\n      containerElementWidth % 2 === 0 || isReflow\n        ? containerElementWidth\n        : containerElementWidth - 1 // @todo careful with the -1, dunno why it's here yet\n\n    element.style.setProperty(`overflow`, `hidden`)\n    element.style.height = `${dimensions.height - marginTop - marginBottom}px`\n    element.style.width = `${containerElementEvenWidth - 2 * margin}px`\n\n    if (margin > 0 || marginTop > 0 || marginBottom > 0) {\n      element.style.margin = `${marginTop}px ${margin}px ${marginBottom}px`\n    }\n    const elementRect = element.getBoundingClientRect()\n\n    context.setVisibleAreaRect(\n      elementRect.x,\n      elementRect.y,\n      containerElementEvenWidth,\n      dimensions.height\n    )\n\n    spine.layout()\n  }\n\n  const load = (\n    manifest: Manifest,\n    loadOptions: LoadOptions = {}\n  ) => {\n    if (context.getManifest()) {\n      Report.warn(`loading a new book is not supported yet`)\n\n      return\n    }\n\n    Report.log(`load`, { manifest, loadOptions })\n\n    context.load(manifest, loadOptions)\n\n    // manifest.readingOrder.forEach((_, index) => resourcesManager.cache(index))\n\n    layout()\n\n    if (!loadOptions.cfi) {\n      spine.viewportNavigator.goToSpineItem(0, { animate: false })\n    } else {\n      spine.viewportNavigator.goToCfi(loadOptions.cfi, { animate: false })\n    }\n\n    readySubject$.next()\n  }\n\n  const registerHook: RegisterHook = (name, fn) => {\n    hooksSubject$.next([...hooksSubject$.getValue(), { name, fn } as Hook])\n  }\n\n  const manipulateContainer = (cb: (container: HTMLElement) => boolean) => {\n    // @todo re-layout based on return\n    cb(element)\n  }\n\n  spine.$.$\n    .pipe(\n      tap(event => {\n        if (event.type === `onSelectionChange`) {\n          selectionSubject$.next(event.data)\n        }\n      }),\n      takeUntil(destroy$)\n    )\n    .subscribe()\n\n  merge(\n    context.$.load$,\n    context.$.settings$,\n    context.$.hasVerticalWriting$\n  )\n    .pipe(\n      mapTo(undefined),\n      withLatestFrom(context.$.hasVerticalWriting$),\n      map(([, hasVerticalWriting]) => {\n        const settings = context.getSettings()\n        const manifest = context.getManifest()\n\n        return {\n          hasVerticalWriting,\n          renditionFlow: manifest?.renditionFlow,\n          renditionLayout: manifest?.renditionLayout,\n          computedPageTurnMode: settings.computedPageTurnMode\n        }\n      }),\n      distinctUntilChanged(isShallowEqual),\n      map(({ hasVerticalWriting, renditionFlow, renditionLayout, computedPageTurnMode }): ObservedValueOf<typeof stateSubject$> => ({\n        ...stateSubject$.value,\n        supportedPageTurnMode:\n          renditionFlow === `scrolled-continuous`\n            ? [`scrollable`]\n            : !context.areAllItemsPrePaginated() ? [`controlled`] : [`controlled`, `scrollable`],\n        supportedPageTurnAnimation:\n          renditionFlow === `scrolled-continuous` || computedPageTurnMode === `scrollable`\n            ? [`none`]\n            : hasVerticalWriting\n              ? [`fade`, `none`]\n              : [`fade`, `none`, `slide`],\n        supportedPageTurnDirection:\n          computedPageTurnMode === `scrollable`\n            ? [`vertical`]\n            : renditionLayout === `reflowable`\n              ? [`horizontal`]\n              : [`horizontal`, `vertical`]\n      })),\n      takeUntil(destroy$)\n    )\n    .subscribe(stateSubject$)\n\n  /**\n   * Free up resources, and dispose the whole reader.\n   * You should call this method if you leave the reader.\n   *\n   * This is not possible to use any of the reader features once it\n   * has been destroyed. If you need to open a new book you need to\n   * either create a new reader or call `load` with a different manifest\n   * instead of destroying it.\n   */\n  const destroy = () => {\n    hooksSubject$.next([])\n    hooksSubject$.complete()\n    pagination.destroy()\n    context.destroy()\n    spine?.destroy()\n    element.remove()\n    iframeEventBridgeElement.remove()\n    readySubject$.complete()\n    stateSubject$.complete()\n    selectionSubject$.complete()\n    destroy$.next()\n    destroy$.complete()\n  }\n\n  const reader = {\n    // innerPagination: pagination,\n    // pagination,\n    context,\n    registerHook,\n    spine,\n    manipulateSpineItems: spine.manipulateSpineItems,\n    manipulateContainer,\n    moveTo: spine.viewportNavigator.moveTo,\n    turnLeft: spine.viewportNavigator.turnLeft,\n    turnRight: spine.viewportNavigator.turnRight,\n    goToPageOfCurrentChapter: spine.viewportNavigator.goToPageOfCurrentChapter,\n    goToPage: spine.viewportNavigator.goToPage,\n    goToUrl: spine.viewportNavigator.goToUrl,\n    goToCfi: spine.viewportNavigator.goToCfi,\n    goToSpineItem: spine.viewportNavigator.goToSpineItem,\n    getFocusedSpineItemIndex: spineItemManager.getFocusedSpineItemIndex,\n    getSpineItem: spineItemManager.get,\n    getSpineItems: spineItemManager.getAll,\n    getAbsolutePositionOf: spineItemManager.getAbsolutePositionOf,\n    getSelection: spine.getSelection,\n    isSelecting: spine.isSelecting,\n    normalizeEventForViewport: spine.normalizeEventForViewport,\n    getCfiMetaInformation: spine.cfiLocator.getCfiMetaInformation,\n    resolveCfi: spine.cfiLocator.resolveCfi,\n    generateCfi: spine.cfiLocator.generateFromRange,\n    locator: spine.locator,\n    getCurrentNavigationPosition: spine.viewportNavigator.getCurrentNavigationPosition,\n    getCurrentViewportPosition: spine.viewportNavigator.getCurrentViewportPosition,\n    layout,\n    load,\n    destroy,\n    setSettings: context.setSettings,\n    $: {\n      pagination$: pagination.$.info$,\n      settings$: context.$.settings$,\n      state$: stateSubject$.asObservable(),\n      /**\n       * Dispatched when the reader has loaded a book and is displayed a book.\n       * Using navigation API and getting information about current content will\n       * have an effect.\n       * It can typically be used to hide a loading indicator.\n       */\n      ready$: readySubject$.asObservable(),\n      /**\n       * Dispatched when a change in selection happens\n       */\n      selection$: selectionSubject$.asObservable(),\n      viewportState$: spine.$.viewportState$,\n      layout$: spine.$.layout$,\n      destroy$\n    },\n    __debug: {\n      pagination,\n      context,\n      spineItemManager\n    }\n  }\n\n  return reader\n}\n\nconst createWrapperElement = (containerElement: HTMLElement) => {\n  const element = containerElement.ownerDocument.createElement(`div`)\n  element.style.cssText = `\n    background-color: white;\n    position: relative;\n  `\n\n  return element\n}\n\nconst createIframeEventBridgeElement = (containerElement: HTMLElement) => {\n  const iframeEventBridgeElement = containerElement.ownerDocument.createElement(`div`)\n  iframeEventBridgeElement.id = IFRAME_EVENT_BRIDGE_ELEMENT_ID\n  iframeEventBridgeElement.style.cssText = `\n    position: absolute;\n    height: 100%;\n    width: 100%;\n    top: 0;\n    left: 0;\n    z-index: -1;\n  `\n\n  return iframeEventBridgeElement\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/reader.ts\n");
|
|
280
|
+
|
|
281
|
+
/***/ }),
|
|
282
|
+
|
|
283
|
+
/***/ "./src/report.ts":
|
|
284
|
+
/*!***********************!*\
|
|
285
|
+
!*** ./src/report.ts ***!
|
|
286
|
+
\***********************/
|
|
287
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
288
|
+
|
|
289
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Report\": () => (/* binding */ Report)\n/* harmony export */ });\nconst ROOT_NAMESPACE = `@prose-reader/core`;\nconst wrap = (str) => `[${str}]`;\nconst time = (name, targetDuration = 0) => {\n let tick = 0;\n const t0 = performance.now();\n return () => {\n tick++;\n const t1 = performance.now();\n Report.logMetric({ name: `${name} - tick ${tick}`, duration: t1 - t0 }, targetDuration);\n };\n};\nconst createReport = (namespace) => ({\n log: (...data) => {\n if (window.__PROSE_READER_DEBUG) {\n if (namespace)\n console.log(wrap(ROOT_NAMESPACE), wrap(namespace), ...data);\n else\n console.log(wrap(ROOT_NAMESPACE), ...data);\n }\n },\n warn: (...data) => {\n if (window.__PROSE_READER_DEBUG) {\n if (namespace)\n console.warn(wrap(ROOT_NAMESPACE), wrap(namespace), ...data);\n else\n console.warn(wrap(ROOT_NAMESPACE), ...data);\n }\n },\n error: (...data) => {\n console.error(...data);\n },\n time,\n logMetric: (performanceEntry, targetDuration = 0) => {\n if (window.__PROSE_READER_DEBUG) {\n if (performanceEntry.duration <= targetDuration) {\n }\n else {\n console.warn(`[prose-reader] [metric] `, `${performanceEntry.name} took ${performanceEntry.duration}ms which is above the ${targetDuration}ms target for this function`);\n }\n }\n },\n measurePerformance: (name, targetDuration = 10, functionToMeasure, { disable } = {}) => {\n if (disable || !window.__PROSE_READER_DEBUG)\n return functionToMeasure;\n return (...args) => {\n const t0 = performance.now();\n const response = functionToMeasure(...args);\n if (response && response.then) {\n return response.then((res) => {\n const t1 = performance.now();\n Report.logMetric({ name, duration: t1 - t0 }, targetDuration);\n return res;\n });\n }\n const t1 = performance.now();\n Report.logMetric({ name, duration: t1 - t0 }, targetDuration);\n return response;\n };\n }\n});\nconst Report = (Object.assign(Object.assign({}, createReport()), { namespace: (namespace) => createReport(namespace) }));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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LEdBQVEsRUFBRSxFQUFFO29CQUNoQyxNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFO29CQUM1QixNQUFNLENBQUMsU0FBUyxDQUFDLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsY0FBYyxDQUFDO29CQUM3RCxPQUFPLEdBQUc7Z0JBQ1osQ0FBQyxDQUFDO2FBQ0g7WUFFRCxNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFO1lBQzVCLE1BQU0sQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxjQUFjLENBQUM7WUFFN0QsT0FBTyxRQUFRO1FBQ2pCLENBQUM7SUFDSCxDQUFDO0NBQ0YsQ0FBQztBQUVLLE1BQU0sTUFBTSxHQUFHLGlDQUNqQixZQUFZLEVBQUUsS0FDakIsU0FBUyxFQUFFLENBQUMsU0FBaUIsRUFBRSxFQUFFLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxJQUN6RCIsInNvdXJjZXMiOlsid2VicGFjazovL0Bwcm9zZS1yZWFkZXIvY29yZS8uL3NyYy9yZXBvcnQudHM/MDRhMCJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBST09UX05BTUVTUEFDRSA9IGBAcHJvc2UtcmVhZGVyL2NvcmVgXG5cbmNvbnN0IHdyYXAgPSAoc3RyOiBzdHJpbmcpID0+IGBbJHtzdHJ9XWBcblxuY29uc3QgdGltZSA9IChuYW1lOiBzdHJpbmcsIHRhcmdldER1cmF0aW9uID0gMCkgPT4ge1xuICBsZXQgdGljayA9IDBcbiAgY29uc3QgdDAgPSBwZXJmb3JtYW5jZS5ub3coKVxuICAvLyBjb25zdCB0MCA9IERhdGUubm93KClcbiAgLy8gY29uc29sZS50aW1lKG5hbWUpXG5cbiAgcmV0dXJuICgpID0+IHtcbiAgICB0aWNrKytcbiAgICBjb25zdCB0MSA9IHBlcmZvcm1hbmNlLm5vdygpXG4gICAgLy8gY29uc3QgdDEgPSBEYXRlLm5vdygpXG4gICAgLy8gY29uc29sZS50aW1lRW5kKG5hbWUpXG4gICAgUmVwb3J0LmxvZ01ldHJpYyh7IG5hbWU6IGAke25hbWV9IC0gdGljayAke3RpY2t9YCwgZHVyYXRpb246IHQxIC0gdDAgfSwgdGFyZ2V0RHVyYXRpb24pXG4gIH1cbn1cblxuY29uc3QgY3JlYXRlUmVwb3J0ID0gKG5hbWVzcGFjZT86IHN0cmluZykgPT4gKHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgbG9nOiAoLi4uZGF0YTogYW55W10pID0+IHtcbiAgICBpZiAod2luZG93Ll9fUFJPU0VfUkVBREVSX0RFQlVHKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgaWYgKG5hbWVzcGFjZSkgY29uc29sZS5sb2cod3JhcChST09UX05BTUVTUEFDRSksIHdyYXAobmFtZXNwYWNlKSwgLi4uZGF0YSlcbiAgICAgIGVsc2UgY29uc29sZS5sb2cod3JhcChST09UX05BTUVTUEFDRSksIC4uLmRhdGEpXG4gICAgfVxuICB9LFxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICB3YXJuOiAoLi4uZGF0YTogYW55W10pID0+IHtcbiAgICBpZiAod2luZG93Ll9fUFJPU0VfUkVBREVSX0RFQlVHKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgaWYgKG5hbWVzcGFjZSkgY29uc29sZS53YXJuKHdyYXAoUk9PVF9OQU1FU1BBQ0UpLCB3cmFwKG5hbWVzcGFjZSksIC4uLmRhdGEpXG4gICAgICBlbHNlIGNvbnNvbGUud2Fybih3cmFwKFJPT1RfTkFNRVNQQUNFKSwgLi4uZGF0YSlcbiAgICB9XG4gIH0sXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIGVycm9yOiAoLi4uZGF0YTogYW55W10pID0+IHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgIGNvbnNvbGUuZXJyb3IoLi4uZGF0YSlcbiAgfSxcbiAgLy8gdGltZTogKGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkKSA9PiB7XG4gIC8vICAgaWYgKHdpbmRvdy5fX1BST1NFX1JFQURFUl9ERUJVRykge1xuICAvLyAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgLy8gICAgIGNvbnNvbGUudGltZShgW3Byb3NlLXJlYWRlcl0gW21ldHJpY10gJHtsYWJlbH1gKTtcbiAgLy8gICB9XG4gIC8vIH0sXG4gIC8vIHRpbWVFbmQ6IChsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZCkgPT4ge1xuICAvLyAgIGlmICh3aW5kb3cuX19QUk9TRV9SRUFERVJfREVCVUcpIHtcbiAgLy8gICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gIC8vICAgICBjb25zb2xlLnRpbWVFbmQoYFtwcm9zZS1yZWFkZXJdIFttZXRyaWNdICR7bGFiZWx9YCk7XG4gIC8vICAgfVxuICAvLyB9LFxuICB0aW1lLFxuICBsb2dNZXRyaWM6IChwZXJmb3JtYW5jZUVudHJ5OiBQZXJmb3JtYW5jZUVudHJ5IHwgeyBuYW1lOiBzdHJpbmc7IGR1cmF0aW9uOiBudW1iZXIgfSwgdGFyZ2V0RHVyYXRpb24gPSAwKSA9PiB7XG4gICAgLy8gY29uc3QgZHVyYXRpb24gPSB0eXBlb2YgcGVyZm9ybWFuY2VFbnRyeSA9PT0gJ251bWJlcicgPyBwZXJmb3JtYW5jZUVudHJ5IDogcGVyZm9ybWFuY2VFbnRyeS5kdXJhdGlvbjtcbiAgICBpZiAod2luZG93Ll9fUFJPU0VfUkVBREVSX0RFQlVHKSB7XG4gICAgICBpZiAocGVyZm9ybWFuY2VFbnRyeS5kdXJhdGlvbiA8PSB0YXJnZXREdXJhdGlvbikge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgICAvLyBjb25zb2xlLmxvZyhgW3Byb3NlLXJlYWRlcl0gW21ldHJpY10gYCwgYCR7cGVyZm9ybWFuY2VFbnRyeS5uYW1lfSB0b29rICR7ZHVyYXRpb259bXNgKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgICBgW3Byb3NlLXJlYWRlcl0gW21ldHJpY10gYCxcbiAgICAgICAgICBgJHtwZXJmb3JtYW5jZUVudHJ5Lm5hbWV9IHRvb2sgJHtwZXJmb3JtYW5jZUVudHJ5LmR1cmF0aW9ufW1zIHdoaWNoIGlzIGFib3ZlIHRoZSAke3RhcmdldER1cmF0aW9ufW1zIHRhcmdldCBmb3IgdGhpcyBmdW5jdGlvbmBcbiAgICAgICAgKVxuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgbWVhc3VyZVBlcmZvcm1hbmNlOiA8RiBleHRlbmRzICguLi5hcmdzOiBhbnlbXSkgPT4gYW55PihuYW1lOiBzdHJpbmcsIHRhcmdldER1cmF0aW9uID0gMTAsIGZ1bmN0aW9uVG9NZWFzdXJlOiBGLCB7IGRpc2FibGUgfTogeyBkaXNhYmxlPzogYm9vbGVhbiB9ID0ge30pID0+IHtcbiAgICBpZiAoZGlzYWJsZSB8fCAhd2luZG93Ll9fUFJPU0VfUkVBREVSX0RFQlVHKSByZXR1cm4gZnVuY3Rpb25Ub01lYXN1cmVcblxuICAgIHJldHVybiAoLi4uYXJnczogUGFyYW1ldGVyczxGPik6IFJldHVyblR5cGU8Rj4gPT4ge1xuICAgICAgY29uc3QgdDAgPSBwZXJmb3JtYW5jZS5ub3coKVxuXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBmdW5jdGlvblRvTWVhc3VyZSguLi4oYXJncyBhcyBhbnkpKVxuXG4gICAgICBpZiAocmVzcG9uc2UgJiYgcmVzcG9uc2UudGhlbikge1xuICAgICAgICByZXR1cm4gcmVzcG9uc2UudGhlbigocmVzOiBhbnkpID0+IHtcbiAgICAgICAgICBjb25zdCB0MSA9IHBlcmZvcm1hbmNlLm5vdygpXG4gICAgICAgICAgUmVwb3J0LmxvZ01ldHJpYyh7IG5hbWUsIGR1cmF0aW9uOiB0MSAtIHQwIH0sIHRhcmdldER1cmF0aW9uKVxuICAgICAgICAgIHJldHVybiByZXNcbiAgICAgICAgfSlcbiAgICAgIH1cblxuICAgICAgY29uc3QgdDEgPSBwZXJmb3JtYW5jZS5ub3coKVxuICAgICAgUmVwb3J0LmxvZ01ldHJpYyh7IG5hbWUsIGR1cmF0aW9uOiB0MSAtIHQwIH0sIHRhcmdldER1cmF0aW9uKVxuXG4gICAgICByZXR1cm4gcmVzcG9uc2VcbiAgICB9XG4gIH1cbn0pXG5cbmV4cG9ydCBjb25zdCBSZXBvcnQgPSAoe1xuICAuLi5jcmVhdGVSZXBvcnQoKSxcbiAgbmFtZXNwYWNlOiAobmFtZXNwYWNlOiBzdHJpbmcpID0+IGNyZWF0ZVJlcG9ydChuYW1lc3BhY2UpXG59KVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/report.ts\n");
|
|
290
|
+
|
|
291
|
+
/***/ }),
|
|
292
|
+
|
|
293
|
+
/***/ "./src/selection.ts":
|
|
294
|
+
/*!**************************!*\
|
|
295
|
+
!*** ./src/selection.ts ***!
|
|
296
|
+
\**************************/
|
|
297
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
298
|
+
|
|
299
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createSelection\": () => (/* binding */ createSelection)\n/* harmony export */ });\n/* harmony import */ var _cfi__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./cfi */ \"./src/cfi.ts\");\n\nconst createSelection = (selection, item) => {\n const text = selection.toString();\n return {\n toString: () => text,\n getAnchorCfi: () => {\n if (selection.anchorNode) {\n return _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI.generate(selection.anchorNode, selection.anchorOffset, `|[prose~anchor~${encodeURIComponent(item.id)}]`);\n }\n },\n getFocusCfi: () => {\n if (selection.focusNode) {\n return _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI.generate(selection.focusNode, selection.focusOffset, `|[prose~anchor~${encodeURIComponent(item.id)}]`);\n }\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc2VsZWN0aW9uLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQTJCO0FBR3BCLE1BQU0sZUFBZSxHQUFHLENBQUMsU0FBb0IsRUFBRSxJQUFvQyxFQUFFLEVBQUU7SUFDNUYsTUFBTSxJQUFJLEdBQUcsU0FBUyxDQUFDLFFBQVEsRUFBRTtJQUVqQyxPQUFPO1FBQ0wsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUk7UUFDcEIsWUFBWSxFQUFFLEdBQUcsRUFBRTtZQUNqQixJQUFJLFNBQVMsQ0FBQyxVQUFVLEVBQUU7Z0JBQ3hCLE9BQU8sOENBQVksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyxZQUFZLEVBQUUsa0JBQWtCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDO2FBQ3BIO1FBQ0gsQ0FBQztRQUNELFdBQVcsRUFBRSxHQUFHLEVBQUU7WUFDaEIsSUFBSSxTQUFTLENBQUMsU0FBUyxFQUFFO2dCQUN2QixPQUFPLDhDQUFZLENBQUMsU0FBUyxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsV0FBVyxFQUFFLGtCQUFrQixrQkFBa0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQzthQUNsSDtRQUNILENBQUM7S0FDRjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvc2VsZWN0aW9uLnRzP2QzN2YiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ0ZJIH0gZnJvbSBcIi4vY2ZpXCJcbmltcG9ydCB7IE1hbmlmZXN0IH0gZnJvbSBcIi4vdHlwZXNcIlxuXG5leHBvcnQgY29uc3QgY3JlYXRlU2VsZWN0aW9uID0gKHNlbGVjdGlvbjogU2VsZWN0aW9uLCBpdGVtOiBNYW5pZmVzdFtgc3BpbmVJdGVtc2BdW251bWJlcl0pID0+IHtcbiAgY29uc3QgdGV4dCA9IHNlbGVjdGlvbi50b1N0cmluZygpXG5cbiAgcmV0dXJuIHtcbiAgICB0b1N0cmluZzogKCkgPT4gdGV4dCxcbiAgICBnZXRBbmNob3JDZmk6ICgpID0+IHtcbiAgICAgIGlmIChzZWxlY3Rpb24uYW5jaG9yTm9kZSkge1xuICAgICAgICByZXR1cm4gQ0ZJLmdlbmVyYXRlKHNlbGVjdGlvbi5hbmNob3JOb2RlLCBzZWxlY3Rpb24uYW5jaG9yT2Zmc2V0LCBgfFtwcm9zZX5hbmNob3J+JHtlbmNvZGVVUklDb21wb25lbnQoaXRlbS5pZCl9XWApXG4gICAgICB9XG4gICAgfSxcbiAgICBnZXRGb2N1c0NmaTogKCkgPT4ge1xuICAgICAgaWYgKHNlbGVjdGlvbi5mb2N1c05vZGUpIHtcbiAgICAgICAgcmV0dXJuIENGSS5nZW5lcmF0ZShzZWxlY3Rpb24uZm9jdXNOb2RlLCBzZWxlY3Rpb24uZm9jdXNPZmZzZXQsIGB8W3Byb3NlfmFuY2hvcn4ke2VuY29kZVVSSUNvbXBvbmVudChpdGVtLmlkKX1dYClcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/selection.ts\n");
|
|
300
|
+
|
|
301
|
+
/***/ }),
|
|
302
|
+
|
|
303
|
+
/***/ "./src/settings.ts":
|
|
304
|
+
/*!*************************!*\
|
|
305
|
+
!*** ./src/settings.ts ***!
|
|
306
|
+
\*************************/
|
|
307
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
308
|
+
|
|
309
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createSettings\": () => (/* binding */ createSettings)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./report */ \"./src/report.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils/objects */ \"./src/utils/objects.ts\");\n\n\n\n\nconst createSettings = (initialSettings) => {\n const mergedSettings = Object.assign({ forceSinglePageMode: false, pageTurnAnimation: `none`, computedPageTurnAnimation: `none`, pageTurnDirection: `horizontal`, computedPageTurnDirection: `horizontal`, pageTurnAnimationDuration: undefined, computedPageTurnAnimationDuration: 0, pageTurnMode: `controlled`, computedPageTurnMode: `controlled`, computedSnapAnimationDuration: 300 }, initialSettings);\n updateComputedSettings(undefined, mergedSettings, false);\n const settingsSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(mergedSettings);\n const setSettings = (newSettings, options) => {\n if (Object.keys(newSettings).length === 0)\n return;\n const newMergedSettings = Object.assign(Object.assign({}, settingsSubject$.value), newSettings);\n updateComputedSettings(options.manifest, newMergedSettings, options.hasVerticalWritingSubject);\n settingsSubject$.next(newMergedSettings);\n };\n const recompute = (options) => {\n const newMergedSettings = Object.assign({}, settingsSubject$.value);\n updateComputedSettings(options.manifest, newMergedSettings, options.hasVerticalWritingSubject);\n settingsSubject$.next(newMergedSettings);\n };\n const destroy = () => {\n settingsSubject$.complete();\n };\n return {\n getSettings: () => settingsSubject$.value,\n setSettings,\n recompute,\n destroy,\n $: {\n settings$: settingsSubject$\n .asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_3__.isShallowEqual))\n }\n };\n};\nconst areAllItemsPrePaginated = (manifest) => !(manifest === null || manifest === void 0 ? void 0 : manifest.spineItems.some(item => item.renditionLayout === `reflowable`));\nconst updateComputedSettings = (newManifest, settings, hasVerticalWriting) => {\n settings.computedPageTurnDirection = settings.pageTurnDirection;\n settings.computedPageTurnAnimation = settings.pageTurnAnimation;\n settings.computedPageTurnMode = `controlled`;\n if ((newManifest === null || newManifest === void 0 ? void 0 : newManifest.renditionFlow) === `scrolled-continuous`) {\n settings.computedPageTurnMode = `scrollable`;\n settings.computedPageTurnDirection = `vertical`;\n }\n else if (newManifest && settings.pageTurnMode === `scrollable` && (newManifest.renditionLayout !== `pre-paginated` || !areAllItemsPrePaginated(newManifest))) {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.warn(`pageTurnMode ${settings.pageTurnMode} incompatible with current book, switching back to default`);\n settings.computedPageTurnAnimation = `none`;\n settings.computedPageTurnMode = `controlled`;\n }\n else if (settings.pageTurnMode === `scrollable`) {\n settings.computedPageTurnMode = `scrollable`;\n settings.computedPageTurnDirection = `vertical`;\n }\n if (hasVerticalWriting && settings.computedPageTurnAnimation === `slide`) {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.warn(`pageTurnAnimation ${settings.computedPageTurnAnimation} incompatible with current book, switching back to default`);\n settings.computedPageTurnAnimation = `none`;\n }\n if (settings.computedPageTurnMode === `scrollable`) {\n settings.computedPageTurnAnimationDuration = 0;\n settings.computedPageTurnAnimation = `none`;\n }\n else {\n settings.computedPageTurnAnimationDuration = settings.pageTurnAnimationDuration !== undefined\n ? settings.pageTurnAnimationDuration\n : 2000;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/settings.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/settings.ts?8b99"],"sourcesContent":["import { BehaviorSubject } from \"rxjs\"\nimport { distinctUntilChanged } from \"rxjs/operators\"\nimport { Manifest } from \"./types\"\nimport { Report } from \"./report\"\nimport { isShallowEqual } from \"./utils/objects\"\n\nexport type PublicSettings = {\n  forceSinglePageMode: boolean,\n  pageTurnAnimation: `none` | `fade` | `slide`,\n  pageTurnAnimationDuration: undefined | number\n  pageTurnDirection: `vertical` | `horizontal`,\n  pageTurnMode: `controlled` | `scrollable`,\n}\n\n/**\n * Represent the settings that are derived from user settings.\n * Because some of the user settings can sometime be invalid based on some\n * context we need to use the computed one internally.\n * For example if the user decide to use horizontal page turn direction with scrolled content\n * we will overwrite it and force it to vertical (granted we only support vertical).\n */\ntype InnerSettings = PublicSettings & {\n  computedPageTurnMode: PublicSettings[`pageTurnMode`],\n  computedPageTurnDirection: PublicSettings[`pageTurnDirection`],\n  computedPageTurnAnimation: PublicSettings[`pageTurnAnimation`],\n  computedPageTurnAnimationDuration: number,\n  computedSnapAnimationDuration: number,\n}\n\nexport const createSettings = (initialSettings: Partial<PublicSettings>) => {\n  const mergedSettings: InnerSettings = {\n    forceSinglePageMode: false,\n    pageTurnAnimation: `none`,\n    computedPageTurnAnimation: `none`,\n    pageTurnDirection: `horizontal`,\n    computedPageTurnDirection: `horizontal`,\n    pageTurnAnimationDuration: undefined,\n    computedPageTurnAnimationDuration: 0,\n    pageTurnMode: `controlled`,\n    computedPageTurnMode: `controlled`,\n    computedSnapAnimationDuration: 300,\n    ...initialSettings\n  }\n\n  updateComputedSettings(undefined, mergedSettings, false)\n\n  const settingsSubject$ = new BehaviorSubject(mergedSettings)\n\n  const setSettings = (newSettings: Partial<PublicSettings>, options: { hasVerticalWritingSubject: boolean, manifest: Manifest | undefined }) => {\n    if (Object.keys(newSettings).length === 0) return\n\n    const newMergedSettings = { ...settingsSubject$.value, ...newSettings }\n\n    updateComputedSettings(options.manifest, newMergedSettings, options.hasVerticalWritingSubject)\n\n    settingsSubject$.next(newMergedSettings)\n  }\n\n  const recompute = (options: { hasVerticalWritingSubject: boolean, manifest: Manifest | undefined }) => {\n    const newMergedSettings = { ...settingsSubject$.value }\n\n    updateComputedSettings(options.manifest, newMergedSettings, options.hasVerticalWritingSubject)\n\n    settingsSubject$.next(newMergedSettings)\n  }\n\n  const destroy = () => {\n    settingsSubject$.complete()\n  }\n\n  return {\n    getSettings: () => settingsSubject$.value,\n    setSettings,\n    recompute,\n    destroy,\n    $: {\n      settings$: settingsSubject$\n        .asObservable()\n        .pipe(distinctUntilChanged(isShallowEqual))\n    }\n  }\n}\n\nconst areAllItemsPrePaginated = (manifest: Manifest | undefined) => !manifest?.spineItems.some(item => item.renditionLayout === `reflowable`)\n\nconst updateComputedSettings = (newManifest: Manifest | undefined, settings: InnerSettings, hasVerticalWriting: boolean) => {\n  settings.computedPageTurnDirection = settings.pageTurnDirection\n  settings.computedPageTurnAnimation = settings.pageTurnAnimation\n  settings.computedPageTurnMode = `controlled`\n\n  // We force scroll mode for some books\n  if (newManifest?.renditionFlow === `scrolled-continuous`) {\n    settings.computedPageTurnMode = `scrollable`\n    settings.computedPageTurnDirection = `vertical`\n  } else if (newManifest && settings.pageTurnMode === `scrollable` && (newManifest.renditionLayout !== `pre-paginated` || !areAllItemsPrePaginated(newManifest))) {\n    Report.warn(`pageTurnMode ${settings.pageTurnMode} incompatible with current book, switching back to default`)\n    settings.computedPageTurnAnimation = `none`\n    settings.computedPageTurnMode = `controlled`\n  } else if (settings.pageTurnMode === `scrollable`) {\n    settings.computedPageTurnMode = `scrollable`\n    settings.computedPageTurnDirection = `vertical`\n  }\n\n  // some settings are not available for vertical writing\n  if (hasVerticalWriting && settings.computedPageTurnAnimation === `slide`) {\n    Report.warn(`pageTurnAnimation ${settings.computedPageTurnAnimation} incompatible with current book, switching back to default`)\n    settings.computedPageTurnAnimation = `none`\n  }\n\n  // for now we only support animation none for scrollable\n  if (settings.computedPageTurnMode === `scrollable`) {\n    settings.computedPageTurnAnimationDuration = 0\n    settings.computedPageTurnAnimation = `none`\n  } else {\n    settings.computedPageTurnAnimationDuration = settings.pageTurnAnimationDuration !== undefined\n      ? settings.pageTurnAnimationDuration\n      : 2000\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/settings.ts\n");
|
|
310
|
+
|
|
311
|
+
/***/ }),
|
|
312
|
+
|
|
313
|
+
/***/ "./src/spine/cfiLocator.ts":
|
|
314
|
+
/*!*********************************!*\
|
|
315
|
+
!*** ./src/spine/cfiLocator.ts ***!
|
|
316
|
+
\*********************************/
|
|
317
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
318
|
+
|
|
319
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createCfiLocator\": () => (/* binding */ createCfiLocator)\n/* harmony export */ });\n/* harmony import */ var _cfi__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../cfi */ \"./src/cfi.ts\");\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n\n\nconst createCfiLocator = ({ spineItemManager, spineItemLocator }) => {\n const getItemAnchor = (spineItem) => `|[prose~anchor~${encodeURIComponent(spineItem.item.id)}]`;\n const getCfi = _report__WEBPACK_IMPORTED_MODULE_1__.Report.measurePerformance(`getCfi`, 10, (pageIndex, spineItem) => {\n var _a, _b, _c;\n const nodeOrRange = spineItemLocator.getFirstNodeOrRangeAtPage(pageIndex, spineItem);\n const doc = (_c = (_b = (_a = spineItem.spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame) === null || _b === void 0 ? void 0 : _b.contentWindow) === null || _c === void 0 ? void 0 : _c.document;\n const itemAnchor = getItemAnchor(spineItem);\n const offset = `|[prose~offset~${(nodeOrRange === null || nodeOrRange === void 0 ? void 0 : nodeOrRange.offset) || 0}]`;\n if (nodeOrRange && doc) {\n const cfiString = _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI.generate(nodeOrRange.node, 0, `${itemAnchor}${offset}`);\n return cfiString;\n }\n return getRootCfi(spineItem);\n });\n const getRootCfi = (spineItem) => {\n const itemAnchor = getItemAnchor(spineItem);\n return `epubcfi(/0${itemAnchor}) `;\n };\n const getSpineItemFromCfi = (cfi) => {\n const { itemId } = (0,_cfi__WEBPACK_IMPORTED_MODULE_0__.extractProseMetadataFromCfi)(cfi);\n if (itemId) {\n const { itemId } = (0,_cfi__WEBPACK_IMPORTED_MODULE_0__.extractProseMetadataFromCfi)(cfi);\n const spineItem = (itemId ? spineItemManager.get(itemId) : undefined) || spineItemManager.get(0);\n return spineItem;\n }\n return undefined;\n };\n const getCfiMetaInformation = (cfi) => {\n const spineItem = getSpineItemFromCfi(cfi);\n if (spineItem) {\n return {\n spineItemIndex: spineItemManager.getSpineItemIndex(spineItem)\n };\n }\n return undefined;\n };\n const resolveCfi = (cfiString) => {\n var _a, _b, _c;\n if (!cfiString)\n return undefined;\n const spineItem = getSpineItemFromCfi(cfiString);\n const spineItemIndex = spineItemManager.getSpineItemIndex(spineItem) || 0;\n if (!spineItem)\n return undefined;\n const { cleanedCfi, offset } = (0,_cfi__WEBPACK_IMPORTED_MODULE_0__.extractProseMetadataFromCfi)(cfiString);\n const cfi = new _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI(cleanedCfi, {});\n const doc = (_c = (_b = (_a = spineItem.spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame) === null || _b === void 0 ? void 0 : _b.contentWindow) === null || _c === void 0 ? void 0 : _c.document;\n console.warn(doc);\n if (doc) {\n try {\n const { node, offset: resolvedOffset } = cfi.resolve(doc, {});\n console.warn(`ASSDF`, node, resolvedOffset);\n return { node, offset: offset !== null && offset !== void 0 ? offset : resolvedOffset, spineItemIndex };\n }\n catch (e) {\n _report__WEBPACK_IMPORTED_MODULE_1__.Report.error(e);\n return {\n spineItemIndex\n };\n }\n }\n return {\n spineItemIndex\n };\n };\n const generateFromRange = ({ startNode, start, end, endNode }, item) => {\n const startCFI = _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI.generate(startNode, start, `|[prose~anchor~${encodeURIComponent(item.id)}]`);\n const endCFI = _cfi__WEBPACK_IMPORTED_MODULE_0__.CFI.generate(endNode, end, `|[prose~anchor~${encodeURIComponent(item.id)}]`);\n return { start: startCFI, end: endCFI };\n };\n return {\n getSpineItemFromCfi,\n getCfiMetaInformation,\n getCfi,\n getRootCfi,\n resolveCfi,\n generateFromRange\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/cfiLocator.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/cfiLocator.ts?28ac"],"sourcesContent":["import { CFI, extractProseMetadataFromCfi } from \"../cfi\"\nimport { Context } from \"../context\"\nimport { SpineItem } from \"../spineItem/createSpineItem\"\nimport { createLocationResolver } from \"../spineItem/locationResolver\"\nimport { SpineItemManager } from \"../spineItemManager\"\nimport { Report } from \"../report\"\nimport { Manifest } from \"../types\"\n\nexport const createCfiLocator = ({ spineItemManager, spineItemLocator }: {\n  spineItemManager: SpineItemManager,\n  context: Context,\n  spineItemLocator: ReturnType<typeof createLocationResolver>\n}) => {\n  const getItemAnchor = (spineItem: SpineItem) => `|[prose~anchor~${encodeURIComponent(spineItem.item.id)}]`\n\n  /**\n   * Heavy cfi hookup. Use it to have a refined, precise cfi anchor. It requires the content to be loaded otherwise\n   * it will return a root cfi.\n   *\n   * @todo optimize\n   */\n  const getCfi = Report.measurePerformance(`getCfi`, 10, (pageIndex: number, spineItem: SpineItem) => {\n    const nodeOrRange = spineItemLocator.getFirstNodeOrRangeAtPage(pageIndex, spineItem)\n    const doc = spineItem.spineItemFrame.getManipulableFrame()?.frame?.contentWindow?.document\n\n    const itemAnchor = getItemAnchor(spineItem)\n    // because the current cfi library does not works well with offset we are just using custom\n    // format and do it manually after resolving the node\n    // @see https://github.com/fread-ink/epub-cfi-resolver/issues/8\n    const offset = `|[prose~offset~${nodeOrRange?.offset || 0}]`\n\n    if (nodeOrRange && doc) {\n      const cfiString = CFI.generate(nodeOrRange.node, 0, `${itemAnchor}${offset}`)\n\n      return cfiString\n    }\n\n    return getRootCfi(spineItem)\n  })\n\n  /**\n   * Very light cfi lookup. Use it when you need to anchor user to correct item\n   * but do not want to have heavy dom lookup. This is useful as pre-cfi before the content\n   * is loaded for example.\n   */\n  const getRootCfi = (spineItem: SpineItem) => {\n    const itemAnchor = getItemAnchor(spineItem)\n\n    return `epubcfi(/0${itemAnchor}) `\n  }\n\n  const getSpineItemFromCfi = (cfi: string) => {\n    const { itemId } = extractProseMetadataFromCfi(cfi)\n\n    if (itemId) {\n      const { itemId } = extractProseMetadataFromCfi(cfi)\n      const spineItem = (itemId ? spineItemManager.get(itemId) : undefined) || spineItemManager.get(0)\n\n      return spineItem\n    }\n\n    return undefined\n  }\n\n  const getCfiMetaInformation = (cfi: string) => {\n    const spineItem = getSpineItemFromCfi(cfi)\n\n    if (spineItem) {\n      return {\n        spineItemIndex: spineItemManager.getSpineItemIndex(spineItem)\n      }\n    }\n\n    return undefined\n  }\n\n  /**\n   * Returns the node and offset for the given cfi.\n   */\n  const resolveCfi = (cfiString: string) => {\n    if (!cfiString) return undefined\n\n    const spineItem = getSpineItemFromCfi(cfiString)\n    const spineItemIndex = spineItemManager.getSpineItemIndex(spineItem) || 0\n\n    if (!spineItem) return undefined\n\n    const { cleanedCfi, offset } = extractProseMetadataFromCfi(cfiString)\n    const cfi = new CFI(cleanedCfi, {})\n\n    const doc = spineItem.spineItemFrame.getManipulableFrame()?.frame?.contentWindow?.document\n\n    console.warn(doc)\n\n    if (doc) {\n      try {\n        const { node, offset: resolvedOffset } = cfi.resolve(doc, {})\n\n        console.warn(`ASSDF`, node, resolvedOffset)\n        return { node, offset: offset ?? resolvedOffset, spineItemIndex }\n      } catch (e) {\n        Report.error(e)\n\n        return {\n          spineItemIndex\n        }\n      }\n    }\n\n    return {\n      spineItemIndex\n    }\n  }\n\n  // const resolveCfi = (cfi: string) => {\n  //   const { spineItemIndex = -1 } = getCfiMetaInformation(cfi) || {}\n  //   const spineItem = spineItemManager.get(spineItemIndex)\n\n  //   if (spineItem) {\n  //     let position: { x: number, y: number } | undefined = undefined\n  //     const { node, offset = 0 } = spineItemLocator.resolveCfi(cfi, spineItem) || {}\n  //     if (node) {\n  //       position = spineItemLocator.getSpineItemPositionFromNode(node, offset, spineItem)\n  //     }\n  //     const pageIndex = position ? spineItemLocator.getSpineItemPageIndexFromPosition(position, spineItem) : undefined\n\n  //     return {\n  //       spineItemIndex,\n  //       pageIndex,\n  //       node,\n  //       offset,\n  //     }\n  //   }\n\n  //   return undefined\n  // }\n\n  /**\n   * @todo the package does not support creating for range at the moment @see https://github.com/fread-ink/epub-cfi-resolver/issues/3\n   * so we use two cfi for start and end.\n   */\n  const generateFromRange = ({ startNode, start, end, endNode }: { startNode: Node, start: number, endNode: Node, end: number }, item: Manifest[`spineItems`][number]) => {\n    const startCFI = CFI.generate(startNode, start, `|[prose~anchor~${encodeURIComponent(item.id)}]`)\n    const endCFI = CFI.generate(endNode, end, `|[prose~anchor~${encodeURIComponent(item.id)}]`)\n\n    return { start: startCFI, end: endCFI }\n  }\n\n  return {\n    getSpineItemFromCfi,\n    getCfiMetaInformation,\n    getCfi,\n    getRootCfi,\n    resolveCfi,\n    generateFromRange\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/cfiLocator.ts\n");
|
|
320
|
+
|
|
321
|
+
/***/ }),
|
|
322
|
+
|
|
323
|
+
/***/ "./src/spine/createSpine.ts":
|
|
324
|
+
/*!**********************************!*\
|
|
325
|
+
!*** ./src/spine/createSpine.ts ***!
|
|
326
|
+
\**********************************/
|
|
327
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
328
|
+
|
|
329
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createSpine\": () => (/* binding */ createSpine)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n/* harmony import */ var _viewportNavigator_viewportNavigator__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./viewportNavigator/viewportNavigator */ \"./src/spine/viewportNavigator/viewportNavigator.ts\");\n/* harmony import */ var _spineItem_createSpineItem__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../spineItem/createSpineItem */ \"./src/spineItem/createSpineItem.ts\");\n/* harmony import */ var _spineItem_locationResolver__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../spineItem/locationResolver */ \"./src/spineItem/locationResolver.ts\");\n/* harmony import */ var _locationResolver__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./locationResolver */ \"./src/spine/locationResolver.ts\");\n/* harmony import */ var _cfiLocator__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./cfiLocator */ \"./src/spine/cfiLocator.ts\");\n/* harmony import */ var _eventsHelper__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./eventsHelper */ \"./src/spine/eventsHelper.ts\");\n/* harmony import */ var _selection__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../selection */ \"./src/selection.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../utils/objects */ \"./src/utils/objects.ts\");\n/* harmony import */ var _utils_rxjs__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../utils/rxjs */ \"./src/utils/rxjs.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\n\n\n\n\n\n\nconst NAMESPACE = `spine`;\nconst createSpine = ({ parentElement, context, pagination, iframeEventBridgeElement, spineItemManager, hooks$ }) => {\n const layoutSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const subject = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const doc = parentElement.ownerDocument;\n const containerElement = createContainerElement(doc, hooks$);\n parentElement.appendChild(containerElement);\n const spineItemLocator = (0,_spineItem_locationResolver__WEBPACK_IMPORTED_MODULE_5__.createLocationResolver)({ context });\n const locator = (0,_locationResolver__WEBPACK_IMPORTED_MODULE_6__.createLocationResolver)({ context, spineItemManager, spineItemLocator });\n const cfiLocator = (0,_cfiLocator__WEBPACK_IMPORTED_MODULE_7__.createCfiLocator)({ spineItemManager, context, spineItemLocator });\n const viewportNavigator = (0,_viewportNavigator_viewportNavigator__WEBPACK_IMPORTED_MODULE_3__.createViewportNavigator)({ context, pagination, spineItemManager, element: containerElement, cfiLocator, locator, hooks$ });\n const eventsHelper = (0,_eventsHelper__WEBPACK_IMPORTED_MODULE_8__.createEventsHelper)({ context, spineItemManager, iframeEventBridgeElement, locator });\n let selectionSubscription;\n let hookDestroyItemOnCreateFunctions = [];\n const reload = () => {\n var _a;\n (_a = context.getManifest()) === null || _a === void 0 ? void 0 : _a.spineItems.map((resource) => __awaiter(void 0, void 0, void 0, function* () {\n const spineItem = (0,_spineItem_createSpineItem__WEBPACK_IMPORTED_MODULE_4__.createSpineItem)({\n item: resource,\n containerElement: containerElement,\n iframeEventBridgeElement,\n context,\n hooks$,\n viewportState$: viewportNavigator.$.state$\n });\n spineItemManager.add(spineItem);\n }));\n hooks$.getValue().forEach(hook => {\n if (hook.name === `item.onCreated`) {\n spineItemManager.getAll().forEach(item => {\n const destroyFnOrStream = hook.fn({\n container: item.element,\n loadingElement: item.loadingElement,\n item: item.item\n });\n if (destroyFnOrStream) {\n if (`subscribe` in destroyFnOrStream) {\n hookDestroyItemOnCreateFunctions.push(destroyFnOrStream.subscribe());\n }\n else {\n hookDestroyItemOnCreateFunctions.push(destroyFnOrStream);\n }\n }\n });\n }\n });\n };\n const manipulateSpineItems = (cb) => {\n let shouldLayout = false;\n spineItemManager.getAll().forEach((item, index) => {\n shouldLayout = item.manipulateSpineItem((opts) => cb(Object.assign({ index }, opts))) || shouldLayout;\n });\n if (shouldLayout) {\n spineItemManager.layout();\n }\n };\n context.$.load$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(reload), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n const layoutOnSettingChanges$ = context.$.settings$\n .pipe((0,_utils_rxjs__WEBPACK_IMPORTED_MODULE_11__.mapKeysTo)([`computedPageTurnDirection`, `computedPageTurnMode`]), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(_utils_objects__WEBPACK_IMPORTED_MODULE_10__.isShallowEqual), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.skip)(1));\n const waitForViewportFree$ = viewportNavigator.$.state$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(v => v === `free`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n const layout$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(layoutSubject$, layoutOnSettingChanges$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n containerElement.style.overflow = `hidden`;\n containerElement.style.overflowY = `scroll`;\n }\n else {\n containerElement.style.removeProperty(`overflow`);\n containerElement.style.removeProperty(`overflowY`);\n }\n viewportNavigator.layout();\n spineItemManager.layout();\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)());\n layout$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n const adjustPagination$ = (position) => {\n return waitForViewportFree$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(_report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`${NAMESPACE} adjustPagination`, 1, () => {\n var _a, _b;\n const spineItemsFromPosition = locator.getSpineItemsFromReadingOrderPosition(position);\n const beginSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.begin) : undefined;\n const endSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.end) : undefined;\n const beginLastCfi = pagination.getInfo().beginCfi;\n const endLastCfi = pagination.getInfo().endCfi;\n const shouldUpdateBeginCfi = pagination.getInfo().beginSpineItemIndex !== (spineItemsFromPosition === null || spineItemsFromPosition === void 0 ? void 0 : spineItemsFromPosition.begin) ||\n beginLastCfi === undefined ||\n (beginLastCfi === null || beginLastCfi === void 0 ? void 0 : beginLastCfi.startsWith(`epubcfi(/0`));\n const shouldUpdateEndCfi = pagination.getInfo().endSpineItemIndex !== (spineItemsFromPosition === null || spineItemsFromPosition === void 0 ? void 0 : spineItemsFromPosition.end) ||\n endLastCfi === undefined ||\n (endLastCfi === null || endLastCfi === void 0 ? void 0 : endLastCfi.startsWith(`epubcfi(/0`));\n if (beginSpineItem && endSpineItem && spineItemsFromPosition) {\n const beginPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.beginPosition, beginSpineItem);\n const beginPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem);\n const endPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.endPosition, endSpineItem);\n const endPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem);\n pagination.updateBeginAndEnd({\n spineItem: beginSpineItem,\n spineItemIndex: (_a = spineItemManager.getSpineItemIndex(beginSpineItem)) !== null && _a !== void 0 ? _a : 0,\n pageIndex: spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem),\n cfi: shouldUpdateBeginCfi ? cfiLocator.getCfi(beginPageIndex, beginSpineItem) : beginLastCfi,\n options: {\n isAtEndOfChapter: false\n }\n }, {\n spineItem: endSpineItem,\n spineItemIndex: (_b = spineItemManager.getSpineItemIndex(endSpineItem)) !== null && _b !== void 0 ? _b : 0,\n pageIndex: spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem),\n cfi: shouldUpdateEndCfi ? cfiLocator.getCfi(endPageIndex, endSpineItem) : endLastCfi,\n options: {\n isAtEndOfChapter: false\n }\n });\n }\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `adjustPagination$`);\n }, { disable: true })));\n };\n const adjustNavigationAfterLayout$ = spineItemManager.$.layout$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => waitForViewportFree$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => {\n const focusedSpineItem = spineItemManager.getFocusedSpineItem();\n if (!focusedSpineItem)\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n return viewportNavigator.adjustNavigation(focusedSpineItem);\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(viewportNavigator.$.navigation$))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)());\n adjustNavigationAfterLayout$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ adjustedSpinePosition }) => {\n return adjustPagination$(adjustedSpinePosition)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(viewportNavigator.$.navigation$));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(spineItemManager.$.focus$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)((event) => {\n const spineItem = event.data;\n const fingerTracker$ = spineItem.fingerTracker.$;\n const selectionTracker$ = spineItem.selectionTracker.$;\n selectionSubscription === null || selectionSubscription === void 0 ? void 0 : selectionSubscription.unsubscribe();\n selectionSubscription = (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(selectionTracker$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(event => event.event === `selectionchange`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(event => {\n subject.next({ type: `onSelectionChange`, data: event.data ? (0,_selection__WEBPACK_IMPORTED_MODULE_9__.createSelection)(event.data, spineItem.item) : null });\n })), selectionTracker$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(({ event }) => event === `selectstart`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(_ => fingerTracker$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(({ event }) => event === `fingermove`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.debounce)(() => (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.interval)(1000)), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(fingerTracker$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(({ event }) => event === `fingerout`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n }))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(({ data }) => {\n if (data) {\n }\n })))))\n .subscribe();\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.catchError)(e => {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.error(e);\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$)))\n .subscribe();\n const itemUpdateOnNavigation$ = viewportNavigator.$.navigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)((data) => {\n var _a, _b;\n const time = _report__WEBPACK_IMPORTED_MODULE_2__.Report.time(`${NAMESPACE} navigation`, 1);\n const currentSpineItem = spineItemManager.getFocusedSpineItem();\n const spineItemsFromPosition = locator.getSpineItemsFromReadingOrderPosition(data.position);\n let beginSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.begin) : undefined;\n let endSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.end) : undefined;\n beginSpineItem = beginSpineItem || currentSpineItem;\n endSpineItem = endSpineItem || currentSpineItem;\n const spineItemToFocus = data.position.spineItem || beginSpineItem;\n if (spineItemToFocus && spineItemToFocus !== currentSpineItem) {\n spineItemManager.focus(spineItemToFocus);\n }\n else if (!spineItemToFocus) {\n spineItemManager.focus(0);\n }\n if (spineItemToFocus && beginSpineItem && endSpineItem && spineItemsFromPosition) {\n const lastExpectedNavigation = viewportNavigator.getLastUserExpectedNavigation();\n const beginItemIndex = (_a = spineItemManager.getSpineItemIndex(beginSpineItem)) !== null && _a !== void 0 ? _a : 0;\n const beginPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.beginPosition, beginSpineItem);\n const beginPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem);\n const endPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.endPosition, endSpineItem);\n const endPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem);\n const endItemIndex = (_b = spineItemManager.getSpineItemIndex(endSpineItem)) !== null && _b !== void 0 ? _b : 0;\n console.warn(`HERE`, pagination.getInfo(), beginItemIndex);\n pagination.updateBeginAndEnd({\n spineItem: beginSpineItem,\n spineItemIndex: beginItemIndex,\n pageIndex: beginPageIndex,\n cfi: (lastExpectedNavigation === null || lastExpectedNavigation === void 0 ? void 0 : lastExpectedNavigation.type) === `navigate-from-cfi` && spineItemToFocus === beginSpineItem\n ? lastExpectedNavigation.data\n : data.triggeredBy === `adjust` && context.getSettings().computedPageTurnMode === `controlled`\n ? pagination.getInfo().beginCfi\n : beginItemIndex !== pagination.getInfo().beginSpineItemIndex\n ? cfiLocator.getRootCfi(beginSpineItem)\n : cfiLocator.getRootCfi(beginSpineItem),\n options: {\n isAtEndOfChapter: false\n }\n }, {\n spineItem: endSpineItem,\n spineItemIndex: endItemIndex,\n pageIndex: endPageIndex,\n cfi: (lastExpectedNavigation === null || lastExpectedNavigation === void 0 ? void 0 : lastExpectedNavigation.type) === `navigate-from-cfi` && spineItemToFocus === endSpineItem\n ? lastExpectedNavigation.data\n : data.triggeredBy === `adjust` && context.getSettings().computedPageTurnMode === `controlled`\n ? pagination.getInfo().endCfi\n : endItemIndex !== pagination.getInfo().endSpineItemIndex\n ? cfiLocator.getRootCfi(endSpineItem)\n : cfiLocator.getRootCfi(endSpineItem),\n options: {\n isAtEndOfChapter: false\n }\n });\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `itemUpdateOnNavigation$`, { spineItemHasChanged: spineItemToFocus !== currentSpineItem, item: spineItemToFocus, spineItemToFocus, index: spineItemManager.getSpineItemIndex(spineItemToFocus), offset: data, endSpineItem, beginSpineItem, lastExpectedNavigation, spineItemsFromPosition });\n }\n time();\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$));\n itemUpdateOnNavigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)((data) => {\n return adjustPagination$(data.position)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(spineItemManager.$.layout$));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(itemUpdateOnNavigation$, adjustNavigationAfterLayout$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => {\n return waitForViewportFree$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => {\n const focusedSpineItemIndex = spineItemManager.getFocusedSpineItemIndex();\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `update contents`, { focusedSpineItemIndex });\n if (focusedSpineItemIndex === undefined)\n return;\n const { begin = focusedSpineItemIndex, end = focusedSpineItemIndex } = locator.getSpineItemsFromReadingOrderPosition(viewportNavigator.getCurrentNavigationPosition()) || {};\n if (begin !== focusedSpineItemIndex && end !== focusedSpineItemIndex) {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.warn(`Current viewport is not in sync with focus item, load from focus item rather than viewport`);\n spineItemManager.loadContents([focusedSpineItemIndex, focusedSpineItemIndex]);\n }\n else {\n spineItemManager.loadContents([begin, end]);\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$)).subscribe();\n return {\n viewportNavigator,\n element: containerElement,\n locator,\n spineItemLocator,\n cfiLocator,\n normalizeEventForViewport: eventsHelper.normalizeEventForViewport,\n manipulateSpineItems,\n layout: () => layoutSubject$.next(),\n destroy: () => {\n viewportNavigator.destroy();\n hookDestroyItemOnCreateFunctions.forEach((fn) => {\n if (`unsubscribe` in fn) {\n fn.unsubscribe();\n }\n else {\n fn();\n }\n });\n hookDestroyItemOnCreateFunctions = [];\n spineItemManager.destroy();\n selectionSubscription === null || selectionSubscription === void 0 ? void 0 : selectionSubscription.unsubscribe();\n containerElement.remove();\n },\n isSelecting: () => { var _a; return (_a = spineItemManager.getFocusedSpineItem()) === null || _a === void 0 ? void 0 : _a.selectionTracker.isSelecting(); },\n getSelection: () => { var _a; return (_a = spineItemManager.getFocusedSpineItem()) === null || _a === void 0 ? void 0 : _a.selectionTracker.getSelection(); },\n $: {\n $: subject.asObservable(),\n viewportState$: viewportNavigator.$.state$,\n layout$: spineItemManager.$.layout$\n }\n };\n};\nconst createContainerElement = (doc, hooks$) => {\n const element = doc.createElement(`div`);\n element.style.cssText = `\n height: 100%;\n position: relative;\n `;\n element.style.transformOrigin = `0 0`;\n return hooks$.getValue().reduce((element, hook) => {\n if (hook.name === `spine.onBeforeContainerCreated`) {\n return hook.fn(element);\n }\n return element;\n }, element);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/createSpine.ts.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAqF;AACiD;AACpG;AAE6C;AAEjB;AACkC;AAErC;AACZ;AACI;AACL;AAEG;AAER;AAEzC,MAAM,SAAS,GAAG,OAAO;AASlB,MAAM,WAAW,GAAG,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,wBAAwB,EAAE,gBAAgB,EAAE,MAAM,EAOnH,EAAE,EAAE;IACH,MAAM,cAAc,GAAG,IAAI,yCAAO,EAAQ;IAC1C,MAAM,OAAO,GAAG,IAAI,yCAAO,EAAS;IACpC,MAAM,GAAG,GAAG,aAAa,CAAC,aAAa;IACvC,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,GAAG,EAAE,MAAM,CAAC;IAC5D,aAAa,CAAC,WAAW,CAAC,gBAAgB,CAAC;IAC3C,MAAM,gBAAgB,GAAG,mFAAsB,CAAC,EAAE,OAAO,EAAE,CAAC;IAC5D,MAAM,OAAO,GAAG,yEAAsB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;IACvF,MAAM,UAAU,GAAG,6DAAgB,CAAC,EAAE,gBAAgB,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;IACpF,MAAM,iBAAiB,GAAG,6FAAuB,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;IACpJ,MAAM,YAAY,GAAG,iEAAkB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,OAAO,EAAE,CAAC;IACzG,IAAI,qBAA+C;IACnD,IAAI,gCAAgC,GAAoC,EAAE;IAK1E,MAAM,MAAM,GAAG,GAAG,EAAE;;QAClB,aAAO,CAAC,WAAW,EAAE,0CAAE,UAAU,CAAC,GAAG,CAAC,CAAO,QAAQ,EAAE,EAAE;YACvD,MAAM,SAAS,GAAG,2EAAe,CAAC;gBAChC,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,gBAAgB;gBAClC,wBAAwB;gBACxB,OAAO;gBACP,MAAM;gBACN,cAAc,EAAE,iBAAiB,CAAC,CAAC,CAAC,MAAM;aAC3C,CAAC;YACF,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC;QACjC,CAAC,EAAC;QACF,MAAM,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE;gBAClC,gBAAgB,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBACvC,MAAM,iBAAiB,GAAG,IAAI,CAAC,EAAE,CAAC;wBAChC,SAAS,EAAE,IAAI,CAAC,OAAO;wBACvB,cAAc,EAAE,IAAI,CAAC,cAAc;wBACnC,IAAI,EAAE,IAAI,CAAC,IAAI;qBAChB,CAAC;oBACF,IAAI,iBAAiB,EAAE;wBACrB,IAAI,WAAW,IAAI,iBAAiB,EAAE;4BACpC,gCAAgC,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,CAAC;yBACrE;6BAAM;4BACL,gCAAgC,CAAC,IAAI,CAAC,iBAAiB,CAAC;yBACzD;qBACF;gBACH,CAAC,CAAC;aACH;QACH,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,oBAAoB,GAAG,CAAC,EAAuF,EAAE,EAAE;QACvH,IAAI,YAAY,GAAG,KAAK;QACxB,gBAAgB,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAChD,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,iBAAG,KAAK,IAAK,IAAI,EAAG,CAAC,IAAI,YAAY;QAC3F,CAAC,CAAC;QAEF,IAAI,YAAY,EAAE;YAChB,gBAAgB,CAAC,MAAM,EAAE;SAC1B;IACH,CAAC;IAED,OAAO,CAAC,CAAC,CAAC,KAAK;SACZ,IAAI,CACH,mDAAG,CAAC,MAAM,CAAC,EACX,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B;SACA,SAAS,EAAE;IAUd,MAAM,uBAAuB,GAAG,OAAO,CAAC,CAAC,CAAC,SAAS;SAChD,IAAI,CACH,uDAAS,CAAC,CAAC,2BAA2B,EAAE,sBAAsB,CAAC,CAAC,EAChE,oEAAoB,CAAC,2DAAc,CAAC,EACpC,oDAAI,CAAC,CAAC,CAAC,CACR;IAEH,MAAM,oBAAoB,GAAG,iBAAiB,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,sDAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,EAAE,oDAAI,CAAC,CAAC,CAAC,CAAC;IAEhG,MAAM,OAAO,GAAG,2CAAK,CAAC,cAAc,EAAE,uBAAuB,CAAC;SAC3D,IAAI,CACH,mDAAG,CAAC,GAAG,EAAE;QACP,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,oBAAoB,KAAK,YAAY,EAAE;YAC/D,gBAAgB,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ;YAC1C,gBAAgB,CAAC,KAAK,CAAC,SAAS,GAAG,QAAQ;SAC5C;aAAM;YACL,gBAAgB,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC;YACjD,gBAAgB,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;SACnD;QAED,iBAAiB,CAAC,MAAM,EAAE;QAC1B,gBAAgB,CAAC,MAAM,EAAE;IAC3B,CAAC,CAAC,EACF,qDAAK,EAAE,CACR;IAEH,OAAO;SACJ,IAAI,CACH,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B;SACA,SAAS,EAAE;IAYd,MAAM,iBAAiB,GAAG,CAAC,QAAiC,EAAE,EAAE;QAC9D,OAAO,oBAAoB;aACxB,IAAI,CACH,mDAAG,CAAC,8DAAyB,CAAC,GAAG,SAAS,mBAAmB,EAAE,CAAC,EAAE,GAAG,EAAE;;YACrE,MAAM,sBAAsB,GAAG,OAAO,CAAC,qCAAqC,CAAC,QAAQ,CAAC;YACtF,MAAM,cAAc,GAAG,sBAAsB,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;YAC9G,MAAM,YAAY,GAAG,sBAAsB,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC1G,MAAM,YAAY,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC,QAAQ;YAClD,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC,MAAM;YAE9C,MAAM,oBAAoB,GACxB,UAAU,CAAC,OAAO,EAAE,CAAC,mBAAmB,MAAK,sBAAsB,aAAtB,sBAAsB,uBAAtB,sBAAsB,CAAE,KAAK;gBAC1E,YAAY,KAAK,SAAS;iBAC1B,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,UAAU,CAAC,YAAY,CAAC;YAExC,MAAM,kBAAkB,GACtB,UAAU,CAAC,OAAO,EAAE,CAAC,iBAAiB,MAAK,sBAAsB,aAAtB,sBAAsB,uBAAtB,sBAAsB,CAAE,GAAG;gBACtE,UAAU,KAAK,SAAS;iBACxB,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,UAAU,CAAC,YAAY,CAAC;YAEtC,IAAI,cAAc,IAAI,YAAY,IAAI,sBAAsB,EAAE;gBAC5D,MAAM,aAAa,GAAG,OAAO,CAAC,qCAAqC,CAAC,sBAAsB,CAAC,aAAa,EAAE,cAAc,CAAC;gBACzH,MAAM,cAAc,GAAG,gBAAgB,CAAC,iCAAiC,CAAC,aAAa,EAAE,cAAc,CAAC;gBACxG,MAAM,WAAW,GAAG,OAAO,CAAC,qCAAqC,CAAC,sBAAsB,CAAC,WAAW,EAAE,YAAY,CAAC;gBACnH,MAAM,YAAY,GAAG,gBAAgB,CAAC,iCAAiC,CAAC,WAAW,EAAE,YAAY,CAAC;gBAElG,UAAU,CAAC,iBAAiB,CAAC;oBAC3B,SAAS,EAAE,cAAc;oBACzB,cAAc,EAAE,sBAAgB,CAAC,iBAAiB,CAAC,cAAc,CAAC,mCAAI,CAAC;oBACvE,SAAS,EAAE,gBAAgB,CAAC,iCAAiC,CAAC,aAAa,EAAE,cAAc,CAAC;oBAC5F,GAAG,EAAE,oBAAoB,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,YAAY;oBAC5F,OAAO,EAAE;wBACP,gBAAgB,EAAE,KAAK;qBACxB;iBACF,EAAE;oBACD,SAAS,EAAE,YAAY;oBACvB,cAAc,EAAE,sBAAgB,CAAC,iBAAiB,CAAC,YAAY,CAAC,mCAAI,CAAC;oBACrE,SAAS,EAAE,gBAAgB,CAAC,iCAAiC,CAAC,WAAW,EAAE,YAAY,CAAC;oBACxF,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,UAAU;oBACpF,OAAO,EAAE;wBACP,gBAAgB,EAAE,KAAK;qBACxB;iBACF,CAAC;aACH;YAED,+CAAU,CAAC,SAAS,EAAE,mBAAmB,CAAC;QAC5C,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CACvB;IACL,CAAC;IA0BD,MAAM,4BAA4B,GAAG,gBAAgB,CAAC,CAAC,CAAC,OAAO;SAC5D,IAAI,CAmBH,yDAAS,CAAC,GAAG,EAAE,CACb,oBAAoB;SACjB,IAAI,CACH,yDAAS,CAAC,GAAG,EAAE;QACb,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,mBAAmB,EAAE;QAE/D,IAAI,CAAC,gBAAgB;YAAE,OAAO,uCAAK;QAEnC,OAAO,iBAAiB,CAAC,gBAAgB,CAAC,gBAAgB,CAAC;IAC7D,CAAC,CAAC,EACF,yDAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC,WAAW,CAAC,CAC3C,CACJ,EACD,qDAAK,EAAE,CACR;IAEH,4BAA4B;SACzB,IAAI,CACH,yDAAS,CAAC,CAAC,EAAE,qBAAqB,EAAE,EAAE,EAAE;QACtC,OAAO,iBAAiB,CAAC,qBAAqB,CAAC;aAC5C,IAAI,CACH,yDAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC,WAAW,CAAC,CAC3C;IACL,CAAC,CAAC,EACF,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B;SACA,SAAS,EAAE;IAEd,2CAAK,CACH,gBAAgB,CAAC,CAAC,CAAC,MAAM;SACtB,IAAI,CACH,mDAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAGZ,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI;QAC5B,MAAM,cAAc,GAAG,SAAS,CAAC,aAAa,CAAC,CAAC;QAChD,MAAM,iBAAiB,GAAG,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAEtD,qBAAqB,aAArB,qBAAqB,uBAArB,qBAAqB,CAAE,WAAW,EAAE;QACpC,qBAAqB,GAAG,2CAAK,CAC3B,iBAAiB;aACd,IAAI,CACH,sDAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,iBAAiB,CAAC,EAClD,mDAAG,CAAC,KAAK,CAAC,EAAE;YACV,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,2DAAe,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACpH,CAAC,CAAC,CACH,EACH,iBAAiB;aACd,IAAI,CACH,sDAAM,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,aAAa,CAAC,EAC9C,yDAAS,CAAC,CAAC,CAAC,EAAE,CAAC,cAAc;aAC1B,IAAI,CACH,sDAAM,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC,EAC7C,wDAAQ,CAAC,GAAG,EAAE,CAAC,8CAAQ,CAAC,IAAI,CAAC,CAAC,EAC9B,yDAAS,CAAC,cAAc;aACrB,IAAI,CACH,sDAAM,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,WAAW,CAAC,EAC5C,mDAAG,CAAC,GAAG,EAAE;QAET,CAAC,CAAC,CACH,CACF,EACD,mDAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;YAEf,IAAI,IAAI,EAAE;aAOT;QACH,CAAC,CAAC,CACH,CACF,CACF,CACJ;aACE,SAAS,EAAE;IAChB,CAAC,CAAC,EACF,0DAAU,CAAC,CAAC,CAAC,EAAE;QACb,iDAAY,CAAC,CAAC,CAAC;QAEf,OAAO,uCAAK;IACd,CAAC,CAAC,EACF,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B,CACJ;SACE,SAAS,EAAE;IAEd,MAAM,uBAAuB,GAAG,iBAAiB,CAAC,CAAC,CAAC,WAAW;SAC5D,IAAI,CACH,mDAAG,CAAC,CAAC,IAAI,EAAE,EAAE;;QACX,MAAM,IAAI,GAAG,gDAAW,CAAC,GAAG,SAAS,aAAa,EAAE,CAAC,CAAC;QACtD,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,mBAAmB,EAAE;QAC/D,MAAM,sBAAsB,GAAG,OAAO,CAAC,qCAAqC,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC3F,IAAI,cAAc,GAAG,sBAAsB,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;QAC5G,IAAI,YAAY,GAAG,sBAAsB,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;QACxG,cAAc,GAAG,cAAc,IAAI,gBAAgB;QACnD,YAAY,GAAG,YAAY,IAAI,gBAAgB;QAK/C,MAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,IAAI,cAAc;QAElE,IAAI,gBAAgB,IAAI,gBAAgB,KAAK,gBAAgB,EAAE;YAC7D,gBAAgB,CAAC,KAAK,CAAC,gBAAgB,CAAC;SACzC;aAAM,IAAI,CAAC,gBAAgB,EAAE;YAE5B,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;SAC1B;QAED,IAAI,gBAAgB,IAAI,cAAc,IAAI,YAAY,IAAI,sBAAsB,EAAE;YAChF,MAAM,sBAAsB,GAAG,iBAAiB,CAAC,6BAA6B,EAAE;YAChF,MAAM,cAAc,GAAG,sBAAgB,CAAC,iBAAiB,CAAC,cAAc,CAAC,mCAAI,CAAC;YAC9E,MAAM,aAAa,GAAG,OAAO,CAAC,qCAAqC,CAAC,sBAAsB,CAAC,aAAa,EAAE,cAAc,CAAC;YACzH,MAAM,cAAc,GAAG,gBAAgB,CAAC,iCAAiC,CAAC,aAAa,EAAE,cAAc,CAAC;YACxG,MAAM,WAAW,GAAG,OAAO,CAAC,qCAAqC,CAAC,sBAAsB,CAAC,WAAW,EAAE,YAAY,CAAC;YACnH,MAAM,YAAY,GAAG,gBAAgB,CAAC,iCAAiC,CAAC,WAAW,EAAE,YAAY,CAAC;YAClG,MAAM,YAAY,GAAG,sBAAgB,CAAC,iBAAiB,CAAC,YAAY,CAAC,mCAAI,CAAC;YAE1E,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,OAAO,EAAE,EAAE,cAAc,CAAC;YAE1D,UAAU,CAAC,iBAAiB,CAAC;gBAC3B,SAAS,EAAE,cAAc;gBACzB,cAAc,EAAE,cAAc;gBAC9B,SAAS,EAAE,cAAc;gBAazB,GAAG,EACD,uBAAsB,aAAtB,sBAAsB,uBAAtB,sBAAsB,CAAE,IAAI,MAAK,mBAAmB,IAAI,gBAAgB,KAAK,cAAc;oBACzF,CAAC,CAAC,sBAAsB,CAAC,IAAI;oBAC7B,CAAC,CAAC,IAAI,CAAC,WAAW,KAAK,QAAQ,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,oBAAoB,KAAK,YAAY;wBAC5F,CAAC,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,QAAQ;wBAC/B,CAAC,CAAC,cAAc,KAAK,UAAU,CAAC,OAAO,EAAE,CAAC,mBAAmB;4BAC3D,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,cAAc,CAAC;4BAEvC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,cAAc,CAAC;gBAC/C,OAAO,EAAE;oBACP,gBAAgB,EAAE,KAAK;iBACxB;aACF,EAAE;gBACD,SAAS,EAAE,YAAY;gBACvB,cAAc,EAAE,YAAY;gBAC5B,SAAS,EAAE,YAAY;gBACvB,GAAG,EAAE,uBAAsB,aAAtB,sBAAsB,uBAAtB,sBAAsB,CAAE,IAAI,MAAK,mBAAmB,IAAI,gBAAgB,KAAK,YAAY;oBAC5F,CAAC,CAAC,sBAAsB,CAAC,IAAI;oBAC7B,CAAC,CAAC,IAAI,CAAC,WAAW,KAAK,QAAQ,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,oBAAoB,KAAK,YAAY;wBAC5F,CAAC,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,MAAM;wBAC7B,CAAC,CAAC,YAAY,KAAK,UAAU,CAAC,OAAO,EAAE,CAAC,iBAAiB;4BACvD,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,YAAY,CAAC;4BAErC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,YAAY,CAAC;gBAC3C,OAAO,EAAE;oBACP,gBAAgB,EAAE,KAAK;iBACxB;aACF,CAAC;YAEF,+CAAU,CAAC,SAAS,EAAE,yBAAyB,EAAE,EAAE,mBAAmB,EAAE,gBAAgB,KAAK,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,cAAc,EAAE,sBAAsB,EAAE,sBAAsB,EAAE,CAAC;SACpT;QAED,IAAI,EAAE;IACR,CAAC,CAAC,EACF,qDAAK,EAAE,EACP,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B;IAOH,uBAAuB;SACpB,IAAI,CACH,yDAAS,CAAC,CAAC,IAAI,EAAE,EAAE;QACjB,OAAO,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC;aACpC,IAAI,CACH,yDAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,CACtC;IACL,CAAC,CAAC,EACF,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B;SACA,SAAS,EAAE;IAiBd,2CAAK,CAMH,uBAAuB,EAKvB,4BAA4B,CAC7B;SACE,IAAI,CACH,yDAAS,CAAC,GAAG,EAAE;QACb,OAAO,oBAAoB;aACxB,IAAI,CACH,mDAAG,CAAC,GAAG,EAAE;YACP,MAAM,qBAAqB,GAAG,gBAAgB,CAAC,wBAAwB,EAAE;YAEzE,+CAAU,CAAC,SAAS,EAAE,iBAAiB,EAAE,EAAE,qBAAqB,EAAE,CAAC;YAEnE,IAAI,qBAAqB,KAAK,SAAS;gBAAE,OAAM;YAE/C,MAAM,EAAE,KAAK,GAAG,qBAAqB,EAAE,GAAG,GAAG,qBAAqB,EAAE,GAAG,OAAO,CAAC,qCAAqC,CAAC,iBAAiB,CAAC,4BAA4B,EAAE,CAAC,IAAI,EAAE;YAE5K,IAAI,KAAK,KAAK,qBAAqB,IAAI,GAAG,KAAK,qBAAqB,EAAE;gBACpE,gDAAW,CAAC,4FAA4F,CAAC;gBACzG,gBAAgB,CAAC,YAAY,CAAC,CAAC,qBAAqB,EAAE,qBAAqB,CAAC,CAAC;aAC9E;iBAAM;gBACL,gBAAgB,CAAC,YAAY,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;aAC5C;QACH,CAAC,CAAC,EACF,oDAAI,CAAC,CAAC,CAAC,CACR;IACL,CAAC,CAAC,EACF,yDAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAC9B,CAAC,SAAS,EAAE;IAEf,OAAO;QACL,iBAAiB;QACjB,OAAO,EAAE,gBAAgB;QACzB,OAAO;QACP,gBAAgB;QAChB,UAAU;QACV,yBAAyB,EAAE,YAAY,CAAC,yBAAyB;QACjE,oBAAoB;QACpB,MAAM,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,IAAI,EAAE;QACnC,OAAO,EAAE,GAAG,EAAE;YACZ,iBAAiB,CAAC,OAAO,EAAE;YAC3B,gCAAgC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;gBAC9C,IAAI,aAAa,IAAI,EAAE,EAAE;oBACvB,EAAE,CAAC,WAAW,EAAE;iBACjB;qBAAM;oBACL,EAAE,EAAE;iBACL;YACH,CAAC,CAAC;YACF,gCAAgC,GAAG,EAAE;YACrC,gBAAgB,CAAC,OAAO,EAAE;YAC1B,qBAAqB,aAArB,qBAAqB,uBAArB,qBAAqB,CAAE,WAAW,EAAE;YACpC,gBAAgB,CAAC,MAAM,EAAE;QAC3B,CAAC;QACD,WAAW,EAAE,GAAG,EAAE,WAAC,6BAAgB,CAAC,mBAAmB,EAAE,0CAAE,gBAAgB,CAAC,WAAW,EAAE;QACzF,YAAY,EAAE,GAAG,EAAE,WAAC,6BAAgB,CAAC,mBAAmB,EAAE,0CAAE,gBAAgB,CAAC,YAAY,EAAE;QAC3F,CAAC,EAAE;YACD,CAAC,EAAE,OAAO,CAAC,YAAY,EAAE;YACzB,cAAc,EAAE,iBAAiB,CAAC,CAAC,CAAC,MAAM;YAC1C,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,OAAO;SACpC;KACF;AACH,CAAC;AAED,MAAM,sBAAsB,GAAG,CAAC,GAAa,EAAE,MAA+B,EAAE,EAAE;IAChF,MAAM,OAAO,GAAgB,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC;IACrD,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG;;;GAGvB;IAUD,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK;IAErC,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE;QAChD,IAAI,IAAI,CAAC,IAAI,KAAK,gCAAgC,EAAE;YAClD,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;SACxB;QAED,OAAO,OAAO;IAChB,CAAC,EAAE,OAAO,CAAC;AACb,CAAC","sources":["webpack://@prose-reader/core/./src/spine/createSpine.ts?27ad"],"sourcesContent":["import { BehaviorSubject, EMPTY, interval, merge, Subject, Subscription } from \"rxjs\"\nimport { catchError, debounce, distinctUntilChanged, filter, map, share, skip, switchMap, take, takeUntil, tap } from \"rxjs/operators\"\nimport { Report } from \"../report\"\nimport { Context } from \"../context\"\nimport { createViewportNavigator } from \"./viewportNavigator/viewportNavigator\"\nimport { Pagination } from \"../pagination\"\nimport { createSpineItem } from \"../spineItem/createSpineItem\"\nimport { createLocationResolver as createSpineItemLocator } from \"../spineItem/locationResolver\"\nimport { SpineItemManager } from \"../spineItemManager\"\nimport { createLocationResolver } from \"./locationResolver\"\nimport { createCfiLocator } from \"./cfiLocator\"\nimport { createEventsHelper } from \"./eventsHelper\"\nimport { createSelection } from \"../selection\"\nimport { ViewportNavigationEntry } from \"./navigationResolver\"\nimport { isShallowEqual } from \"../utils/objects\"\nimport { Hook } from \"../types/Hook\"\nimport { mapKeysTo } from \"../utils/rxjs\"\n\nconst NAMESPACE = `spine`\n\ntype SpineItem = ReturnType<typeof createSpineItem>\ntype RequireLayout = boolean\ntype ManipulableSpineItemCallback = Parameters<SpineItem[`manipulateSpineItem`]>[0]\ntype ManipulableSpineItemCallbackPayload = Parameters<ManipulableSpineItemCallback>[0]\n\ntype Event = { type: `onSelectionChange`, data: ReturnType<typeof createSelection> | null }\n\nexport const createSpine = ({ parentElement, context, pagination, iframeEventBridgeElement, spineItemManager, hooks$ }: {\n  parentElement: HTMLElement,\n  iframeEventBridgeElement: HTMLElement,\n  context: Context,\n  pagination: Pagination,\n  spineItemManager: SpineItemManager,\n  hooks$: BehaviorSubject<Hook[]>\n}) => {\n  const layoutSubject$ = new Subject<void>()\n  const subject = new Subject<Event>()\n  const doc = parentElement.ownerDocument\n  const containerElement = createContainerElement(doc, hooks$)\n  parentElement.appendChild(containerElement)\n  const spineItemLocator = createSpineItemLocator({ context })\n  const locator = createLocationResolver({ context, spineItemManager, spineItemLocator })\n  const cfiLocator = createCfiLocator({ spineItemManager, context, spineItemLocator })\n  const viewportNavigator = createViewportNavigator({ context, pagination, spineItemManager, element: containerElement, cfiLocator, locator, hooks$ })\n  const eventsHelper = createEventsHelper({ context, spineItemManager, iframeEventBridgeElement, locator })\n  let selectionSubscription: Subscription | undefined\n  let hookDestroyItemOnCreateFunctions: ((() => void) | Subscription)[] = []\n\n  /**\n   * @todo handle reload\n   */\n  const reload = () => {\n    context.getManifest()?.spineItems.map(async (resource) => {\n      const spineItem = createSpineItem({\n        item: resource,\n        containerElement: containerElement,\n        iframeEventBridgeElement,\n        context,\n        hooks$,\n        viewportState$: viewportNavigator.$.state$\n      })\n      spineItemManager.add(spineItem)\n    })\n    hooks$.getValue().forEach(hook => {\n      if (hook.name === `item.onCreated`) {\n        spineItemManager.getAll().forEach(item => {\n          const destroyFnOrStream = hook.fn({\n            container: item.element,\n            loadingElement: item.loadingElement,\n            item: item.item\n          })\n          if (destroyFnOrStream) {\n            if (`subscribe` in destroyFnOrStream) {\n              hookDestroyItemOnCreateFunctions.push(destroyFnOrStream.subscribe())\n            } else {\n              hookDestroyItemOnCreateFunctions.push(destroyFnOrStream)\n            }\n          }\n        })\n      }\n    })\n  }\n\n  const manipulateSpineItems = (cb: (payload: ManipulableSpineItemCallbackPayload & { index: number }) => RequireLayout) => {\n    let shouldLayout = false\n    spineItemManager.getAll().forEach((item, index) => {\n      shouldLayout = item.manipulateSpineItem((opts) => cb({ index, ...opts })) || shouldLayout\n    })\n\n    if (shouldLayout) {\n      spineItemManager.layout()\n    }\n  }\n\n  context.$.load$\n    .pipe(\n      tap(reload),\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  /**\n   * Watch for settings update that require changes\n   * on this layer.\n   *\n   * @important\n   * Try not to have duplicate with other lower components that also listen to settings change and re-layout\n   * on the same settings.\n   */\n  const layoutOnSettingChanges$ = context.$.settings$\n    .pipe(\n      mapKeysTo([`computedPageTurnDirection`, `computedPageTurnMode`]),\n      distinctUntilChanged(isShallowEqual),\n      skip(1)\n    )\n\n  const waitForViewportFree$ = viewportNavigator.$.state$.pipe(filter(v => v === `free`), take(1))\n\n  const layout$ = merge(layoutSubject$, layoutOnSettingChanges$)\n    .pipe(\n      tap(() => {\n        if (context.getSettings().computedPageTurnMode === `scrollable`) {\n          containerElement.style.overflow = `hidden`\n          containerElement.style.overflowY = `scroll`\n        } else {\n          containerElement.style.removeProperty(`overflow`)\n          containerElement.style.removeProperty(`overflowY`)\n        }\n\n        viewportNavigator.layout()\n        spineItemManager.layout()\n      }),\n      share()\n    )\n\n  layout$\n    .pipe(\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  /**\n   * This adjustment is used to update the pagination with the most up to date values we can.\n   * It needs to be ran only when viewport is free because some operation such as looking up cfi can\n   * be really heavy.\n   *\n   * The cfi will only be updated if it needs to be:\n   * - cfi is a root target\n   * - cfi is undefined\n   * - items are different\n   */\n  const adjustPagination$ = (position: ViewportNavigationEntry) => {\n    return waitForViewportFree$\n      .pipe(\n        tap(Report.measurePerformance(`${NAMESPACE} adjustPagination`, 1, () => {\n          const spineItemsFromPosition = locator.getSpineItemsFromReadingOrderPosition(position)\n          const beginSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.begin) : undefined\n          const endSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.end) : undefined\n          const beginLastCfi = pagination.getInfo().beginCfi\n          const endLastCfi = pagination.getInfo().endCfi\n\n          const shouldUpdateBeginCfi =\n            pagination.getInfo().beginSpineItemIndex !== spineItemsFromPosition?.begin ||\n            beginLastCfi === undefined ||\n            beginLastCfi?.startsWith(`epubcfi(/0`)\n\n          const shouldUpdateEndCfi =\n            pagination.getInfo().endSpineItemIndex !== spineItemsFromPosition?.end ||\n            endLastCfi === undefined ||\n            endLastCfi?.startsWith(`epubcfi(/0`)\n\n          if (beginSpineItem && endSpineItem && spineItemsFromPosition) {\n            const beginPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.beginPosition, beginSpineItem)\n            const beginPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem)\n            const endPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.endPosition, endSpineItem)\n            const endPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem)\n\n            pagination.updateBeginAndEnd({\n              spineItem: beginSpineItem,\n              spineItemIndex: spineItemManager.getSpineItemIndex(beginSpineItem) ?? 0,\n              pageIndex: spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem),\n              cfi: shouldUpdateBeginCfi ? cfiLocator.getCfi(beginPageIndex, beginSpineItem) : beginLastCfi,\n              options: {\n                isAtEndOfChapter: false\n              }\n            }, {\n              spineItem: endSpineItem,\n              spineItemIndex: spineItemManager.getSpineItemIndex(endSpineItem) ?? 0,\n              pageIndex: spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem),\n              cfi: shouldUpdateEndCfi ? cfiLocator.getCfi(endPageIndex, endSpineItem) : endLastCfi,\n              options: {\n                isAtEndOfChapter: false\n              }\n            })\n          }\n\n          Report.log(NAMESPACE, `adjustPagination$`)\n        }, { disable: true }))\n      )\n  }\n\n  /**\n   * Use cases covered by this observer\n   * - Layout changed for items\n   *  - viewport is free\n   *    - we adjust the navigation\n   *    - we update the pagination\n   *  - viewport is busy (ongoing navigation, animation, etc)\n   *    - we wait for viewport free\n   *    - we adjust pagination\n   *    - we update pagination\n   *\n   * Once navigation is adjusted we update the pagination regardless if the\n   * adjustment was needed or not. This is because the layout may have change. In some case, the content\n   * may have changed but by change the viewport position is still the same. It does not mean the actual content\n   * is the same.\n   *\n   * @important\n   * Adjustment and pagination update are cancelled as soon as another navigation happens. (it will already be handled there).\n   * adjustNavigation$ can trigger a navigation if adjustment is needed which will in term cancel the inner stream.\n   *\n   * @todo\n   * Right now we react to literally every layout and some time we might not need to update pagination (ex pre-paginated element got unload).\n   * Maybe we should only listen to current items visible only ?\n   */\n  const adjustNavigationAfterLayout$ = spineItemManager.$.layout$\n    .pipe(\n      /**\n       * @important\n       * Careful with using debounce / throttle here since it can decrease user experience\n       * when layout happens it can means an item before the current one has been unloaded, at current code\n       * we unload and size back each item to the screen so it will have the effect of flicker for user.\n       * Consider this workflow:\n       * - user navigate to page 2\n       * - viewport move to item 2\n       * - page 1 unload and goes back from 2000px to 500px\n       * - layout triggered\n       * - viewport is now on an item far after item 2 because item 1 shrink (PROBLEM)\n       * - sometime after viewport is adjusted back to item 2.\n       *\n       * Two solution to fix this issue:\n       * - maybe later try to implement a different strategy and never shrink back item unless they are loaded\n       * - do not use debounce / throttle and navigate back to the item right on the same tick\n       */\n      // debounceTime(10, animationFrameScheduler),\n      switchMap(() =>\n        waitForViewportFree$\n          .pipe(\n            switchMap(() => {\n              const focusedSpineItem = spineItemManager.getFocusedSpineItem()\n\n              if (!focusedSpineItem) return EMPTY\n\n              return viewportNavigator.adjustNavigation(focusedSpineItem)\n            }),\n            takeUntil(viewportNavigator.$.navigation$)\n          )\n      ),\n      share()\n    )\n\n  adjustNavigationAfterLayout$\n    .pipe(\n      switchMap(({ adjustedSpinePosition }) => {\n        return adjustPagination$(adjustedSpinePosition)\n          .pipe(\n            takeUntil(viewportNavigator.$.navigation$)\n          )\n      }),\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  merge(\n    spineItemManager.$.focus$\n      .pipe(\n        tap((event) => {\n          // @todo track tail as well (selection, finger etc)\n\n          const spineItem = event.data\n          const fingerTracker$ = spineItem.fingerTracker.$\n          const selectionTracker$ = spineItem.selectionTracker.$\n\n          selectionSubscription?.unsubscribe()\n          selectionSubscription = merge(\n            selectionTracker$\n              .pipe(\n                filter(event => event.event === `selectionchange`),\n                tap(event => {\n                  subject.next({ type: `onSelectionChange`, data: event.data ? createSelection(event.data, spineItem.item) : null })\n                })\n              ),\n            selectionTracker$\n              .pipe(\n                filter(({ event }) => event === `selectstart`),\n                switchMap(_ => fingerTracker$\n                  .pipe(\n                    filter(({ event }) => event === `fingermove`),\n                    debounce(() => interval(1000)),\n                    takeUntil(fingerTracker$\n                      .pipe(\n                        filter(({ event }) => event === `fingerout`),\n                        tap(() => {\n\n                        })\n                      )\n                    ),\n                    tap(({ data }) => {\n                      // console.log(data)\n                      if (data) {\n                        // const fingerPosition = translateFramePositionIntoPage(context, pagination, data, spineItem)\n                        // if (fingerPosition.x >= context.getPageSize().width) {\n                        //   viewportNavigator.turnRight({ allowSpineItemChange: false })\n                        // } else if (fingerPosition.x <= context.getPageSize().width) {\n                        //   viewportNavigator.turnLeft({ allowSpineItemChange: false })\n                        // }\n                      }\n                    })\n                  )\n                )\n              )\n          )\n            .subscribe()\n        }),\n        catchError(e => {\n          Report.error(e)\n\n          return EMPTY\n        }),\n        takeUntil(context.$.destroy$)\n      )\n  )\n    .subscribe()\n\n  const itemUpdateOnNavigation$ = viewportNavigator.$.navigation$\n    .pipe(\n      tap((data) => {\n        const time = Report.time(`${NAMESPACE} navigation`, 1)\n        const currentSpineItem = spineItemManager.getFocusedSpineItem()\n        const spineItemsFromPosition = locator.getSpineItemsFromReadingOrderPosition(data.position)\n        let beginSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.begin) : undefined\n        let endSpineItem = spineItemsFromPosition ? spineItemManager.get(spineItemsFromPosition.end) : undefined\n        beginSpineItem = beginSpineItem || currentSpineItem\n        endSpineItem = endSpineItem || currentSpineItem\n\n        // In theory the item to focus should be either begin or end. This is because the navigation should at least take us on top\n        // of it. However this is the theory, due to wrong layout / missing adjustment it could be different.\n        // In case of no item to focus is detected we will just fallback to 0\n        const spineItemToFocus = data.position.spineItem || beginSpineItem\n\n        if (spineItemToFocus && spineItemToFocus !== currentSpineItem) {\n          spineItemManager.focus(spineItemToFocus)\n        } else if (!spineItemToFocus) {\n          // we default to item 0 so if anything wrong happens during navigation we can fallback to a valid item\n          spineItemManager.focus(0)\n        }\n\n        if (spineItemToFocus && beginSpineItem && endSpineItem && spineItemsFromPosition) {\n          const lastExpectedNavigation = viewportNavigator.getLastUserExpectedNavigation()\n          const beginItemIndex = spineItemManager.getSpineItemIndex(beginSpineItem) ?? 0\n          const beginPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.beginPosition, beginSpineItem)\n          const beginPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(beginPosition, beginSpineItem)\n          const endPosition = locator.getSpineItemPositionFromSpinePosition(spineItemsFromPosition.endPosition, endSpineItem)\n          const endPageIndex = spineItemLocator.getSpineItemPageIndexFromPosition(endPosition, endSpineItem)\n          const endItemIndex = spineItemManager.getSpineItemIndex(endSpineItem) ?? 0\n\n          console.warn(`HERE`, pagination.getInfo(), beginItemIndex)\n\n          pagination.updateBeginAndEnd({\n            spineItem: beginSpineItem,\n            spineItemIndex: beginItemIndex,\n            pageIndex: beginPageIndex,\n            /**\n             * Because the start of a navigation may involve animations and interactions we don't resolve heavy CFI here.\n             * We do want to have certain information correct in the pagination right after a navigation (same tick) but we just\n             * defer heavy non vital stuff for later.\n             * There are only 4 different cfi update at this stage:\n             * - navigation comes from cfi, we simply affect the cfi to the pagination\n             * - navigation comes from adjustment with controlled mode, we don't update the cfi, just pass the previous one\n             * - navigation comes from adjustment with free mode, we will update with root cfi if needed because we could be on new page\n             * - navigation is not from adjustment, this means we are on either new page or new reading item, we use light cfi with root (no dom lookup)\n             *\n             * The cfi is later adjusted with heavy dom lookup once the viewport is free.\n             */\n            cfi:\n              lastExpectedNavigation?.type === `navigate-from-cfi` && spineItemToFocus === beginSpineItem\n                ? lastExpectedNavigation.data\n                : data.triggeredBy === `adjust` && context.getSettings().computedPageTurnMode === `controlled`\n                  ? pagination.getInfo().beginCfi\n                  : beginItemIndex !== pagination.getInfo().beginSpineItemIndex\n                    ? cfiLocator.getRootCfi(beginSpineItem)\n                    // @todo check ?\n                    : cfiLocator.getRootCfi(beginSpineItem),\n            options: {\n              isAtEndOfChapter: false\n            }\n          }, {\n            spineItem: endSpineItem,\n            spineItemIndex: endItemIndex,\n            pageIndex: endPageIndex,\n            cfi: lastExpectedNavigation?.type === `navigate-from-cfi` && spineItemToFocus === endSpineItem\n              ? lastExpectedNavigation.data\n              : data.triggeredBy === `adjust` && context.getSettings().computedPageTurnMode === `controlled`\n                ? pagination.getInfo().endCfi\n                : endItemIndex !== pagination.getInfo().endSpineItemIndex\n                  ? cfiLocator.getRootCfi(endSpineItem)\n                  // @todo check ?\n                  : cfiLocator.getRootCfi(endSpineItem),\n            options: {\n              isAtEndOfChapter: false\n            }\n          })\n\n          Report.log(NAMESPACE, `itemUpdateOnNavigation$`, { spineItemHasChanged: spineItemToFocus !== currentSpineItem, item: spineItemToFocus, spineItemToFocus, index: spineItemManager.getSpineItemIndex(spineItemToFocus), offset: data, endSpineItem, beginSpineItem, lastExpectedNavigation, spineItemsFromPosition })\n        }\n\n        time()\n      }),\n      share(),\n      takeUntil(context.$.destroy$)\n    )\n\n  /**\n   * Adjust heavier pagination once the navigation and items are updated.\n   * This is also cancelled if the layout changes, because the layout will\n   * trigger a new navigation adjustment and pagination again.\n   */\n  itemUpdateOnNavigation$\n    .pipe(\n      switchMap((data) => {\n        return adjustPagination$(data.position)\n          .pipe(\n            takeUntil(spineItemManager.$.layout$)\n          )\n      }),\n      takeUntil(context.$.destroy$)\n    )\n    .subscribe()\n\n  /**\n   * Loading and unloading content has two important issues that need to be considered\n   * - For reflow book it will un-sync the viewport\n   * - Loading / unload is CPU intensive.\n   *\n   * Because of theses two reason we only load/unload when the adjustment is done. This ensure a smooth transition for the second point.\n   * For the first point it avoid having content being un-sync while the transition is happening. That way we avoid a new chapter\n   * to suddenly being displayed under the transition. The first issue is only a problem for reflow book as paginated will not\n   * un-sync the viewport.\n   * The flow for the first point is as follow:\n   * [navigate] -> [transition] -> [new position] -> [iframe unload/load] -> (eventual adjustment).\n   *\n   * It would ne nice to be able to load/unload without having to worry about viewport mis-adjustment but due to the current iframe and viewport\n   * layout method we have to take it into consideration.\n   */\n  merge(\n    /**\n     * We want to update content after navigation since we are at a different place.\n     * We also wait for navigated items to be updated so that we have access to correct focus.\n     * which is why we use this observer rather than `navigation$`.\n     */\n    itemUpdateOnNavigation$,\n    /**\n     * This one make sure we also listen for layout change and that we execute the code once the navigation\n     * has been adjusted (whether it's needed or not).\n     */\n    adjustNavigationAfterLayout$\n  )\n    .pipe(\n      switchMap(() => {\n        return waitForViewportFree$\n          .pipe(\n            map(() => {\n              const focusedSpineItemIndex = spineItemManager.getFocusedSpineItemIndex()\n\n              Report.log(NAMESPACE, `update contents`, { focusedSpineItemIndex })\n\n              if (focusedSpineItemIndex === undefined) return\n\n              const { begin = focusedSpineItemIndex, end = focusedSpineItemIndex } = locator.getSpineItemsFromReadingOrderPosition(viewportNavigator.getCurrentNavigationPosition()) || {}\n\n              if (begin !== focusedSpineItemIndex && end !== focusedSpineItemIndex) {\n                Report.warn(`Current viewport is not in sync with focus item, load from focus item rather than viewport`)\n                spineItemManager.loadContents([focusedSpineItemIndex, focusedSpineItemIndex])\n              } else {\n                spineItemManager.loadContents([begin, end])\n              }\n            }),\n            take(1)\n          )\n      }),\n      takeUntil(context.$.destroy$)\n    ).subscribe()\n\n  return {\n    viewportNavigator,\n    element: containerElement,\n    locator,\n    spineItemLocator,\n    cfiLocator,\n    normalizeEventForViewport: eventsHelper.normalizeEventForViewport,\n    manipulateSpineItems,\n    layout: () => layoutSubject$.next(),\n    destroy: () => {\n      viewportNavigator.destroy()\n      hookDestroyItemOnCreateFunctions.forEach((fn) => {\n        if (`unsubscribe` in fn) {\n          fn.unsubscribe()\n        } else {\n          fn()\n        }\n      })\n      hookDestroyItemOnCreateFunctions = []\n      spineItemManager.destroy()\n      selectionSubscription?.unsubscribe()\n      containerElement.remove()\n    },\n    isSelecting: () => spineItemManager.getFocusedSpineItem()?.selectionTracker.isSelecting(),\n    getSelection: () => spineItemManager.getFocusedSpineItem()?.selectionTracker.getSelection(),\n    $: {\n      $: subject.asObservable(),\n      viewportState$: viewportNavigator.$.state$,\n      layout$: spineItemManager.$.layout$\n    }\n  }\n}\n\nconst createContainerElement = (doc: Document, hooks$: BehaviorSubject<Hook[]>) => {\n  const element: HTMLElement = doc.createElement(`div`)\n  element.style.cssText = `\n    height: 100%;\n    position: relative;\n  `\n  /**\n   * Beware of this property, do not try to change anything else or remove it.\n   * This is early forced optimization and is used for this specific context.\n   * @see https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n   *\n   * @important\n   * This seems to be responsible for the screen freeze issue\n   */\n  // element.style.willChange = `transform`\n  element.style.transformOrigin = `0 0`\n\n  return hooks$.getValue().reduce((element, hook) => {\n    if (hook.name === `spine.onBeforeContainerCreated`) {\n      return hook.fn(element)\n    }\n\n    return element\n  }, element)\n}\n\nexport type Spine = ReturnType<typeof createSpine>\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/createSpine.ts\n");
|
|
330
|
+
|
|
331
|
+
/***/ }),
|
|
332
|
+
|
|
333
|
+
/***/ "./src/spine/eventsHelper.ts":
|
|
334
|
+
/*!***********************************!*\
|
|
335
|
+
!*** ./src/spine/eventsHelper.ts ***!
|
|
336
|
+
\***********************************/
|
|
337
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
338
|
+
|
|
339
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createEventsHelper\": () => (/* binding */ createEventsHelper)\n/* harmony export */ });\n/* harmony import */ var _frames__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frames */ \"./src/frames.ts\");\n/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/dom */ \"./src/utils/dom.ts\");\n\n\nconst createEventsHelper = ({ iframeEventBridgeElement, locator }) => {\n const normalizeEventForViewport = (event) => {\n var _a;\n const eventIsComingFromBridge = event.target === iframeEventBridgeElement;\n const iframeOriginalEvent = (0,_frames__WEBPACK_IMPORTED_MODULE_0__.getOriginalFrameEventFromDocumentEvent)(event);\n const originalFrame = (_a = iframeOriginalEvent === null || iframeOriginalEvent === void 0 ? void 0 : iframeOriginalEvent.view) === null || _a === void 0 ? void 0 : _a.frameElement;\n if (!eventIsComingFromBridge || !iframeOriginalEvent || !originalFrame)\n return event;\n const spineItem = locator.getSpineItemFromIframe(originalFrame);\n if (!spineItem)\n return event;\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isPointerEvent)(event)) {\n const { clientX, clientY } = spineItem.translateFramePositionIntoPage(event);\n const newEvent = new PointerEvent(event.type, Object.assign(Object.assign({}, event), { clientX,\n clientY }));\n Object.defineProperty(newEvent, `target`, { value: iframeOriginalEvent.target, enumerable: true });\n return newEvent;\n }\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isMouseEvent)(event)) {\n const { clientX, clientY } = spineItem.translateFramePositionIntoPage(event);\n const newEvent = new MouseEvent(event.type, Object.assign(Object.assign({}, event), { clientX,\n clientY }));\n Object.defineProperty(newEvent, `target`, { value: iframeOriginalEvent.target, enumerable: true });\n return newEvent;\n }\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isTouchEvent)(event)) {\n const touches = Array.from(event.touches).map((touch) => {\n const { clientX, clientY } = spineItem.translateFramePositionIntoPage(touch);\n return new Touch({\n identifier: touch.identifier,\n target: touch.target,\n clientX,\n clientY\n });\n });\n const newEvent = new TouchEvent(event.type, {\n touches,\n changedTouches: touches,\n targetTouches: touches\n });\n Object.defineProperty(newEvent, `target`, { value: iframeOriginalEvent.target, enumerable: true });\n return newEvent;\n }\n return event;\n };\n return {\n normalizeEventForViewport\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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RCxPQUFPO1FBQ0wseUJBQXlCO0tBQzFCO0FBQ0gsQ0FBQyIsInNvdXJjZXMiOlsid2VicGFjazovL0Bwcm9zZS1yZWFkZXIvY29yZS8uL3NyYy9zcGluZS9ldmVudHNIZWxwZXIudHM/ZTJhNiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIi4uL2NvbnRleHRcIlxuaW1wb3J0IHsgZ2V0T3JpZ2luYWxGcmFtZUV2ZW50RnJvbURvY3VtZW50RXZlbnQgfSBmcm9tIFwiLi4vZnJhbWVzXCJcbmltcG9ydCB7IFNwaW5lSXRlbU1hbmFnZXIgfSBmcm9tIFwiLi4vc3BpbmVJdGVtTWFuYWdlclwiXG5pbXBvcnQgeyBpc01vdXNlRXZlbnQsIGlzUG9pbnRlckV2ZW50LCBpc1RvdWNoRXZlbnQgfSBmcm9tIFwiLi4vdXRpbHMvZG9tXCJcbmltcG9ydCB7IGNyZWF0ZUxvY2F0aW9uUmVzb2x2ZXIgfSBmcm9tIFwiLi9sb2NhdGlvblJlc29sdmVyXCJcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUV2ZW50c0hlbHBlciA9ICh7IGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudCwgbG9jYXRvciB9OiB7XG4gIGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudDogSFRNTEVsZW1lbnQsXG4gIHNwaW5lSXRlbU1hbmFnZXI6IFNwaW5lSXRlbU1hbmFnZXIsXG4gIGNvbnRleHQ6IENvbnRleHQsXG4gIGxvY2F0b3I6IFJldHVyblR5cGU8dHlwZW9mIGNyZWF0ZUxvY2F0aW9uUmVzb2x2ZXI+XG59KSA9PiB7XG4gIGNvbnN0IG5vcm1hbGl6ZUV2ZW50Rm9yVmlld3BvcnQgPSA8RSBleHRlbmRzIChNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCB8IFBvaW50ZXJFdmVudCk+KGV2ZW50OiBFKSA9PiB7XG4gICAgY29uc3QgZXZlbnRJc0NvbWluZ0Zyb21CcmlkZ2UgPSBldmVudC50YXJnZXQgPT09IGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudFxuICAgIGNvbnN0IGlmcmFtZU9yaWdpbmFsRXZlbnQgPSBnZXRPcmlnaW5hbEZyYW1lRXZlbnRGcm9tRG9jdW1lbnRFdmVudChldmVudClcbiAgICBjb25zdCBvcmlnaW5hbEZyYW1lID0gaWZyYW1lT3JpZ2luYWxFdmVudD8udmlldz8uZnJhbWVFbGVtZW50XG5cbiAgICBpZiAoIWV2ZW50SXNDb21pbmdGcm9tQnJpZGdlIHx8ICFpZnJhbWVPcmlnaW5hbEV2ZW50IHx8ICFvcmlnaW5hbEZyYW1lKSByZXR1cm4gZXZlbnRcblxuICAgIGNvbnN0IHNwaW5lSXRlbSA9IGxvY2F0b3IuZ2V0U3BpbmVJdGVtRnJvbUlmcmFtZShvcmlnaW5hbEZyYW1lKVxuXG4gICAgaWYgKCFzcGluZUl0ZW0pIHJldHVybiBldmVudFxuXG4gICAgaWYgKGlzUG9pbnRlckV2ZW50KGV2ZW50KSkge1xuICAgICAgY29uc3QgeyBjbGllbnRYLCBjbGllbnRZIH0gPSBzcGluZUl0ZW0udHJhbnNsYXRlRnJhbWVQb3NpdGlvbkludG9QYWdlKGV2ZW50KVxuXG4gICAgICBjb25zdCBuZXdFdmVudCA9IG5ldyBQb2ludGVyRXZlbnQoZXZlbnQudHlwZSwge1xuICAgICAgICAuLi5ldmVudCxcbiAgICAgICAgY2xpZW50WCxcbiAgICAgICAgY2xpZW50WVxuICAgICAgfSkgYXMgRVxuXG4gICAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkobmV3RXZlbnQsIGB0YXJnZXRgLCB7IHZhbHVlOiBpZnJhbWVPcmlnaW5hbEV2ZW50LnRhcmdldCwgZW51bWVyYWJsZTogdHJ1ZSB9KVxuXG4gICAgICByZXR1cm4gbmV3RXZlbnRcbiAgICB9XG5cbiAgICBpZiAoaXNNb3VzZUV2ZW50KGV2ZW50KSkge1xuICAgICAgY29uc3QgeyBjbGllbnRYLCBjbGllbnRZIH0gPSBzcGluZUl0ZW0udHJhbnNsYXRlRnJhbWVQb3NpdGlvbkludG9QYWdlKGV2ZW50KVxuXG4gICAgICBjb25zdCBuZXdFdmVudCA9IG5ldyBNb3VzZUV2ZW50KGV2ZW50LnR5cGUsIHtcbiAgICAgICAgLi4uZXZlbnQsXG4gICAgICAgIGNsaWVudFgsXG4gICAgICAgIGNsaWVudFlcbiAgICAgIH0pIGFzIEVcblxuICAgICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KG5ld0V2ZW50LCBgdGFyZ2V0YCwgeyB2YWx1ZTogaWZyYW1lT3JpZ2luYWxFdmVudC50YXJnZXQsIGVudW1lcmFibGU6IHRydWUgfSlcblxuICAgICAgcmV0dXJuIG5ld0V2ZW50XG4gICAgfVxuXG4gICAgaWYgKGlzVG91Y2hFdmVudChldmVudCkpIHtcbiAgICAgIGNvbnN0IHRvdWNoZXMgPSBBcnJheS5mcm9tKGV2ZW50LnRvdWNoZXMpLm1hcChcbiAgICAgICAgKHRvdWNoKSA9PiB7XG4gICAgICAgICAgY29uc3QgeyBjbGllbnRYLCBjbGllbnRZIH0gPSBzcGluZUl0ZW0udHJhbnNsYXRlRnJhbWVQb3NpdGlvbkludG9QYWdlKHRvdWNoKVxuXG4gICAgICAgICAgcmV0dXJuIG5ldyBUb3VjaCh7XG4gICAgICAgICAgICBpZGVudGlmaWVyOiB0b3VjaC5pZGVudGlmaWVyLFxuICAgICAgICAgICAgdGFyZ2V0OiB0b3VjaC50YXJnZXQsXG4gICAgICAgICAgICBjbGllbnRYLFxuICAgICAgICAgICAgY2xpZW50WVxuICAgICAgICAgIH0pXG4gICAgICAgIH1cbiAgICAgIClcblxuICAgICAgY29uc3QgbmV3RXZlbnQgPSBuZXcgVG91Y2hFdmVudChldmVudC50eXBlLCB7XG4gICAgICAgIHRvdWNoZXMsXG4gICAgICAgIGNoYW5nZWRUb3VjaGVzOiB0b3VjaGVzLFxuICAgICAgICB0YXJnZXRUb3VjaGVzOiB0b3VjaGVzXG4gICAgICB9KSBhcyBFXG5cbiAgICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShuZXdFdmVudCwgYHRhcmdldGAsIHsgdmFsdWU6IGlmcmFtZU9yaWdpbmFsRXZlbnQudGFyZ2V0LCBlbnVtZXJhYmxlOiB0cnVlIH0pXG5cbiAgICAgIHJldHVybiBuZXdFdmVudFxuICAgIH1cblxuICAgIHJldHVybiBldmVudFxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBub3JtYWxpemVFdmVudEZvclZpZXdwb3J0XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/spine/eventsHelper.ts\n");
|
|
340
|
+
|
|
341
|
+
/***/ }),
|
|
342
|
+
|
|
343
|
+
/***/ "./src/spine/locationResolver.ts":
|
|
344
|
+
/*!***************************************!*\
|
|
345
|
+
!*** ./src/spine/locationResolver.ts ***!
|
|
346
|
+
\***************************************/
|
|
347
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
348
|
+
|
|
349
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createLocationResolver\": () => (/* binding */ createLocationResolver)\n/* harmony export */ });\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n\nconst createLocationResolver = ({ spineItemManager, context, spineItemLocator }) => {\n const getSpineItemPositionFromSpinePosition = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`getSpineItemPositionFromSpinePosition`, 10, (position, spineItem) => {\n const { leftEnd, leftStart, topStart, topEnd } = spineItemManager.getAbsolutePositionOf(spineItem);\n if (context.isRTL()) {\n return {\n x: (leftEnd - position.x) - context.getPageSize().width,\n y: Math.max(0, position.y - topStart)\n };\n }\n return {\n x: Math.max(0, position.x - leftStart),\n y: Math.max(0, position.y - topStart)\n };\n }, { disable: true });\n const getSpinePositionFromSpineItemPosition = (spineItemPosition, spineItem) => {\n const { leftEnd, leftStart, topStart, topEnd } = spineItemManager.getAbsolutePositionOf(spineItem);\n if (context.isRTL()) {\n return {\n x: (leftEnd - spineItemPosition.x) - context.getPageSize().width,\n y: topStart + spineItemPosition.y\n };\n }\n return {\n x: leftStart + spineItemPosition.x,\n y: topStart + spineItemPosition.y\n };\n };\n const getSpineItemFromPosition = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`getSpineItemFromOffset`, 10, (position) => {\n const spineItem = spineItemManager.getSpineItemAtPosition(position);\n return spineItem;\n }, { disable: true });\n const getSpinePositionFromSpineItem = (spineItem) => {\n return getSpinePositionFromSpineItemPosition({ x: 0, y: 0 }, spineItem);\n };\n const getSpinePositionFromSpineItemAnchor = (anchor, spineItem) => {\n const spineItemOffset = spineItemLocator.getSpineItemOffsetFromAnchor(anchor, spineItem);\n const position = getSpinePositionFromSpineItemPosition({ x: spineItemOffset, y: 0 }, spineItem);\n return position;\n };\n const getSpineItemsFromReadingOrderPosition = (position) => {\n var _a;\n const beginItem = getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem();\n const beginItemIndex = spineItemManager.getSpineItemIndex(beginItem);\n if (beginItemIndex === undefined)\n return undefined;\n let endPosition = position;\n if (context.shouldDisplaySpread()) {\n endPosition = { x: position.x + context.getPageSize().width, y: position.y };\n }\n const endItemIndex = (_a = spineItemManager.getSpineItemIndex(getSpineItemFromPosition(endPosition) || spineItemManager.getFocusedSpineItem())) !== null && _a !== void 0 ? _a : beginItemIndex;\n const [left = beginItemIndex, right = beginItemIndex] = [beginItemIndex, endItemIndex].sort((a, b) => a - b);\n return {\n begin: beginItemIndex,\n beginPosition: position,\n end: endItemIndex,\n endPosition: endPosition,\n left,\n right\n };\n };\n const getSpineItemFromIframe = (iframe) => {\n return spineItemManager.getAll().find(item => item.spineItemFrame.getFrameElement() === iframe);\n };\n const getSpineItemPageIndexFromNode = (node, offset, spineItemOrIndex) => {\n if (typeof spineItemOrIndex === `number`) {\n const spineItem = spineItemManager.get(spineItemOrIndex);\n return spineItem ? spineItemLocator.getSpineItemPageIndexFromNode(node, offset || 0, spineItem) : undefined;\n }\n return spineItemLocator.getSpineItemPageIndexFromNode(node, offset || 0, spineItemOrIndex);\n };\n return {\n getSpinePositionFromSpineItemPosition,\n getSpinePositionFromSpineItem,\n getSpinePositionFromSpineItemAnchor,\n getSpineItemPositionFromSpinePosition,\n getSpineItemFromPosition,\n getSpineItemFromIframe,\n getSpineItemPageIndexFromNode,\n getSpineItemsFromReadingOrderPosition\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/locationResolver.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/locationResolver.ts?d41d"],"sourcesContent":["import { Context } from \"../context\"\nimport { SpineItem } from \"../spineItem/createSpineItem\"\nimport { createLocationResolver as createSpineItemLocator } from \"../spineItem/locationResolver\"\nimport { SpineItemManager } from \"../spineItemManager\"\nimport { Report } from \"../report\"\n\ntype SpinePosition = { x: number, y: number }\ntype SpineItemPosition = { x: number, y: number, outsideOfBoundaries?: boolean }\n\nexport const createLocationResolver = ({ spineItemManager, context, spineItemLocator }: {\n  spineItemManager: SpineItemManager,\n  context: Context,\n  spineItemLocator: ReturnType<typeof createSpineItemLocator>\n}) => {\n  const getSpineItemPositionFromSpinePosition = Report.measurePerformance(`getSpineItemPositionFromSpinePosition`, 10, (position: SpinePosition, spineItem: SpineItem): SpineItemPosition => {\n    const { leftEnd, leftStart, topStart, topEnd } = spineItemManager.getAbsolutePositionOf(spineItem)\n\n    /**\n     * For this case the global offset move from right to left but this specific item\n     * reads from left to right. This means that when the offset is at the start of the item\n     * it is in fact at his end. This behavior can be observed in `haruko` about chapter.\n     * @example\n     * <---------------------------------------------------- global offset\n     * item offset ------------------>\n     * [item2 (page0 - page1 - page2)] [item1 (page1 - page0)] [item0 (page0)]\n     */\n    // if (context.isRTL() && itemReadingDirection === 'ltr') {\n    //   return (end - readingOrderViewOffset) - context.getPageSize().width\n    // }\n\n    if (context.isRTL()) {\n      return {\n        x: (leftEnd - position.x) - context.getPageSize().width,\n        // y: (topEnd - position.y) - context.getPageSize().height,\n        y: Math.max(0, position.y - topStart)\n      }\n    }\n\n    return {\n      /**\n       * when using spread the item could be on the right and therefore will be negative\n       * @example\n       * 400 (position = viewport), page of 200\n       * 400 - 600 = -200.\n       * However we can assume we are at 0, because we in fact can see the beginning of the item\n       */\n      x: Math.max(0, position.x - leftStart),\n      y: Math.max(0, position.y - topStart)\n    }\n  }, { disable: true })\n\n  /**\n   * Be careful when using with spread with RTL, this will return the position for one page size. This is in order to prevent wrong position when\n   * an item is not taking the entire spread. That way we always have a valid position for the given item. However you need to adjust it\n   * when on spread mode to be sure to position the viewport on the edge.\n   *\n   * @example\n   * [    item-a   |   item-a   ]\n   * 400          200           0\n   * will return 200, which probably needs to be adjusted as 0\n   */\n  const getSpinePositionFromSpineItemPosition = (spineItemPosition: SpineItemPosition, spineItem: SpineItem): SpinePosition => {\n    const { leftEnd, leftStart, topStart, topEnd } = spineItemManager.getAbsolutePositionOf(spineItem)\n\n    /**\n     * For this case the global offset move from right to left but this specific item\n     * reads from left to right. This means that when the offset is at the start of the item\n     * it is in fact at his end. This behavior can be observed in `haruko` about chapter.\n     * @example\n     * <---------------------------------------------------- global offset\n     * item offset ------------------>\n     * [item2 (page0 - page1 - page2)] [item1 (page1 - page0)] [item0 (page0)]\n     */\n    // if (context.isRTL() && itemReadingDirection === 'ltr') {\n    //   return (end - spineItemOffset) - context.getPageSize().width\n    // }\n\n    if (context.isRTL()) {\n      return {\n        x: (leftEnd - spineItemPosition.x) - context.getPageSize().width,\n        // y: (topEnd - spineItemPosition.y) - context.getPageSize().height,\n        y: topStart + spineItemPosition.y\n      }\n    }\n\n    // console.warn({ leftEnd, leftStart, topStart, topEnd })\n    return {\n      x: leftStart + spineItemPosition.x,\n      y: topStart + spineItemPosition.y\n    }\n  }\n\n  /**\n   * This will retrieve the closest item to the x / y position edge relative to the reading direction.\n   */\n  const getSpineItemFromPosition = Report.measurePerformance(`getSpineItemFromOffset`, 10, (position: SpinePosition) => {\n    const spineItem = spineItemManager.getSpineItemAtPosition(position)\n\n    return spineItem\n  }, { disable: true })\n\n  const getSpinePositionFromSpineItem = (spineItem: SpineItem) => {\n    return getSpinePositionFromSpineItemPosition({ x: 0, y: 0 }, spineItem)\n  }\n\n  const getSpinePositionFromSpineItemAnchor = (anchor: string, spineItem: SpineItem) => {\n    const spineItemOffset = spineItemLocator.getSpineItemOffsetFromAnchor(anchor, spineItem)\n\n    const position = getSpinePositionFromSpineItemPosition({ x: spineItemOffset, y: 0 }, spineItem)\n\n    return position\n  }\n\n  const getSpineItemsFromReadingOrderPosition = (position: SpinePosition): {\n    left: number,\n    right: number,\n    begin: number,\n    beginPosition: SpinePosition\n    end: number\n    endPosition: SpinePosition\n  } | undefined => {\n    const beginItem = getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem()\n    const beginItemIndex = spineItemManager.getSpineItemIndex(beginItem)\n\n    if (beginItemIndex === undefined) return undefined\n\n    let endPosition = position\n\n    if (context.shouldDisplaySpread()) {\n      endPosition = { x: position.x + context.getPageSize().width, y: position.y }\n    }\n\n    const endItemIndex = spineItemManager.getSpineItemIndex(\n      getSpineItemFromPosition(endPosition) || spineItemManager.getFocusedSpineItem()\n    ) ?? beginItemIndex\n\n    const [left = beginItemIndex, right = beginItemIndex] = [beginItemIndex, endItemIndex].sort((a, b) => a - b)\n    // const [left = beginItemIndex, right = beginItemIndex] = [beginItemIndex, endItemIndex].sort()\n\n    return {\n      begin: beginItemIndex,\n      beginPosition: position,\n      end: endItemIndex,\n      endPosition: endPosition,\n      left,\n      right\n    }\n  }\n\n  const getSpineItemFromIframe = (iframe: Element) => {\n    return spineItemManager.getAll().find(item => item.spineItemFrame.getFrameElement() === iframe)\n  }\n\n  const getSpineItemPageIndexFromNode = (node: Node, offset: number | undefined, spineItemOrIndex: SpineItem | number) => {\n    if (typeof spineItemOrIndex === `number`) {\n      const spineItem = spineItemManager.get(spineItemOrIndex)\n      return spineItem ? spineItemLocator.getSpineItemPageIndexFromNode(node, offset || 0, spineItem) : undefined\n    }\n\n    return spineItemLocator.getSpineItemPageIndexFromNode(node, offset || 0, spineItemOrIndex)\n  }\n\n  return {\n    getSpinePositionFromSpineItemPosition,\n    getSpinePositionFromSpineItem,\n    getSpinePositionFromSpineItemAnchor,\n    getSpineItemPositionFromSpinePosition,\n    getSpineItemFromPosition,\n    getSpineItemFromIframe,\n    getSpineItemPageIndexFromNode,\n    getSpineItemsFromReadingOrderPosition\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/locationResolver.ts\n");
|
|
350
|
+
|
|
351
|
+
/***/ }),
|
|
352
|
+
|
|
353
|
+
/***/ "./src/spine/navigationResolver.ts":
|
|
354
|
+
/*!*****************************************!*\
|
|
355
|
+
!*** ./src/spine/navigationResolver.ts ***!
|
|
356
|
+
\*****************************************/
|
|
357
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
358
|
+
|
|
359
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createNavigationResolver\": () => (/* binding */ createNavigationResolver)\n/* harmony export */ });\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n/* harmony import */ var _spineItem_navigationResolver__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../spineItem/navigationResolver */ \"./src/spineItem/navigationResolver.ts\");\n\n\nconst NAMESPACE = `spineNavigator`;\nconst createNavigationResolver = ({ context, spineItemManager, cfiLocator, locator }) => {\n const spineItemNavigator = (0,_spineItem_navigationResolver__WEBPACK_IMPORTED_MODULE_1__.createNavigationResolver)({ context });\n const arePositionsDifferent = (a, b) => a.x !== b.x || a.y !== b.y;\n const areNavigationDifferent = (a, b) => arePositionsDifferent(a, b) || ((!!a.spineItem && !!b.spineItem) && (a.spineItem !== b.spineItem));\n const wrapPositionWithSafeEdge = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`${NAMESPACE} wrapPositionWithSafeEdge`, 1, (position) => {\n const lastSpineItem = spineItemManager.get(spineItemManager.getLength() - 1);\n const distanceOfLastSpineItem = spineItemManager.getAbsolutePositionOf(lastSpineItem || 0);\n const maximumXOffset = distanceOfLastSpineItem.leftEnd - context.getPageSize().width;\n const maximumYOffset = distanceOfLastSpineItem.topEnd - context.getPageSize().height;\n return {\n x: Math.min(Math.max(0, position.x), maximumXOffset),\n y: Math.min(Math.max(0, position.y), maximumYOffset)\n };\n }, { disable: true });\n const getAdjustedPositionForSpread = ({ x, y }) => {\n const isOffsetNotAtEdge = (x % context.getVisibleAreaRect().width) !== 0;\n const correctedX = isOffsetNotAtEdge ? x - context.getPageSize().width : x;\n return { x: correctedX, y };\n };\n const getNavigationForCfi = (cfi) => {\n const spineItem = cfiLocator.getSpineItemFromCfi(cfi);\n const { node, offset = 0 } = cfiLocator.resolveCfi(cfi) || {};\n if (!spineItem) {\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.warn(NAMESPACE, `unable to detect item id from cfi ${cfi}`);\n }\n else {\n const spineItemNavigation = node ? spineItemNavigator.getNavigationFromNode(spineItem, node, offset) : { x: 0, y: 0 };\n const readingPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem);\n return Object.assign(Object.assign({}, getAdjustedPositionForSpread(readingPosition)), { spineItem });\n }\n return { x: 0, y: 0 };\n };\n const getNavigationForPage = (pageIndex, spineItem) => {\n if (!spineItem) {\n const xPositionForPageIndex = pageIndex * context.getPageSize().width;\n return getNavigationForPosition({ x: xPositionForPageIndex, y: 0 });\n }\n const spineItemNavigation = spineItemNavigator.getNavigationForPage(pageIndex, spineItem);\n const readingOffset = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem);\n return getAdjustedPositionForSpread(readingOffset);\n };\n const getNavigationForLastPage = (spineItem) => {\n const spineItemNavigation = spineItemNavigator.getNavigationForLastPage(spineItem);\n const position = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem);\n return getAdjustedPositionForSpread(position);\n };\n const getNavigationForSpineIndexOrId = (indexOrId) => {\n const spineItem = spineItemManager.get(indexOrId);\n if (spineItem) {\n const position = locator.getSpinePositionFromSpineItem(spineItem);\n return Object.assign(Object.assign({}, getAdjustedPositionForSpread(position)), { spineItem });\n }\n return { x: 0, y: 0 };\n };\n const getNavigationForRightSinglePage = (position) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n const spineItem = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem();\n const defaultNavigation = position;\n if (!spineItem) {\n return defaultNavigation;\n }\n const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(position, spineItem);\n const spineItemNavigationForRightPage = spineItemNavigator.getNavigationForRightPage(spineItemPosition, spineItem);\n const isNewNavigationInCurrentItem = !spineItemPosition.outsideOfBoundaries && arePositionsDifferent(spineItemNavigationForRightPage, spineItemPosition);\n if (!isNewNavigationInCurrentItem) {\n return wrapPositionWithSafeEdge(context.isRTL()\n ? pageTurnDirection === `horizontal`\n ? { x: position.x - context.getPageSize().width, y: 0 }\n : { y: position.y + context.getPageSize().height, x: 0 }\n : pageTurnDirection === `horizontal`\n ? { x: position.x + context.getPageSize().width, y: 0 }\n : { y: position.y + context.getPageSize().height, x: 0 });\n }\n else {\n const readingOrderPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigationForRightPage, spineItem);\n return readingOrderPosition;\n }\n };\n const getNavigationForLeftSinglePage = (position) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n const spineItem = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem();\n const defaultNavigation = Object.assign(Object.assign({}, position), { spineItem });\n if (!spineItem) {\n return defaultNavigation;\n }\n const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(position, spineItem);\n const spineItemNavigation = spineItemNavigator.getNavigationForLeftPage(spineItemPosition, spineItem);\n const isNewNavigationInCurrentItem = !spineItemPosition.outsideOfBoundaries && arePositionsDifferent(spineItemNavigation, spineItemPosition);\n if (!isNewNavigationInCurrentItem) {\n return wrapPositionWithSafeEdge(context.isRTL()\n ? pageTurnDirection === `horizontal`\n ? { x: position.x + context.getPageSize().width, y: 0 }\n : { y: position.y - context.getPageSize().height, x: 0 }\n : pageTurnDirection === `horizontal`\n ? { x: position.x - context.getPageSize().width, y: 0 }\n : { y: position.y - context.getPageSize().height, x: 0 });\n }\n else {\n const readingOrderPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem);\n return readingOrderPosition;\n }\n };\n const getNavigationForRightPage = (position) => {\n const spineItemOnPosition = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem();\n let navigation = getNavigationForRightSinglePage(position);\n if ((spineItemOnPosition === null || spineItemOnPosition === void 0 ? void 0 : spineItemOnPosition.isUsingVerticalWriting()) && position.x === navigation.x) {\n return getAdjustedPositionForSpread(navigation);\n }\n if (context.shouldDisplaySpread()) {\n if ((spineItemOnPosition === null || spineItemOnPosition === void 0 ? void 0 : spineItemOnPosition.isUsingVerticalWriting()) && position.x !== navigation.x) {\n return getAdjustedPositionForSpread(wrapPositionWithSafeEdge(context.isRTL()\n ? Object.assign(Object.assign({}, navigation), { x: navigation.x - context.getPageSize().width }) : Object.assign(Object.assign({}, navigation), { x: navigation.x + context.getPageSize().width })));\n }\n if (context.getSettings().computedPageTurnDirection === `vertical` && position.y !== navigation.y) {\n return getAdjustedPositionForSpread(navigation);\n }\n navigation = getNavigationForRightSinglePage(navigation);\n }\n return getAdjustedPositionForSpread(navigation);\n };\n const getNavigationForLeftPage = (position) => {\n const spineItemOnPosition = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem();\n let navigation = getNavigationForLeftSinglePage(position);\n if ((spineItemOnPosition === null || spineItemOnPosition === void 0 ? void 0 : spineItemOnPosition.isUsingVerticalWriting()) && position.x === navigation.x) {\n return getAdjustedPositionForSpread(navigation);\n }\n if (context.shouldDisplaySpread()) {\n if ((spineItemOnPosition === null || spineItemOnPosition === void 0 ? void 0 : spineItemOnPosition.isUsingVerticalWriting()) && position.x !== navigation.x) {\n return getAdjustedPositionForSpread(wrapPositionWithSafeEdge(context.isRTL()\n ? Object.assign(Object.assign({}, navigation), { x: navigation.x + context.getPageSize().width }) : Object.assign(Object.assign({}, navigation), { x: navigation.x - context.getPageSize().width })));\n }\n if (context.getSettings().computedPageTurnDirection === `vertical` && position.y !== navigation.y) {\n return getAdjustedPositionForSpread(navigation);\n }\n navigation = getNavigationForLeftSinglePage(navigation);\n }\n return getAdjustedPositionForSpread(navigation);\n };\n const getNavigationForUrl = (url) => {\n var _a;\n let validUrl;\n try {\n validUrl = url instanceof URL ? url : new URL(url);\n }\n catch (e) {\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.error(e);\n }\n if (validUrl) {\n const urlWithoutAnchor = `${validUrl.origin}${validUrl.pathname}`;\n const existingSpineItem = (_a = context.getManifest()) === null || _a === void 0 ? void 0 : _a.spineItems.find(item => item.href === urlWithoutAnchor);\n if (existingSpineItem) {\n const spineItem = spineItemManager.get(existingSpineItem.id);\n if (spineItem) {\n const position = getNavigationForAnchor(validUrl.hash, spineItem);\n return Object.assign(Object.assign({}, getAdjustedPositionForSpread(position)), { url: validUrl });\n }\n }\n }\n return undefined;\n };\n const getNavigationForAnchor = (anchor, spineItem) => {\n const position = locator.getSpinePositionFromSpineItemAnchor(anchor, spineItem);\n return getAdjustedPositionForSpread(position);\n };\n const getNavigationForPosition = (viewportPosition) => {\n const spineItem = locator.getSpineItemFromPosition(viewportPosition);\n if (spineItem) {\n const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(viewportPosition, spineItem);\n const spineItemValidPosition = spineItemNavigator.getNavigationForPosition(spineItem, spineItemPosition);\n const viewportNavigation = locator.getSpinePositionFromSpineItemPosition(spineItemValidPosition, spineItem);\n return getAdjustedPositionForSpread(viewportNavigation);\n }\n return { x: 0, y: 0 };\n };\n const getMostPredominantNavigationForPosition = (viewportPosition) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n const triggerPercentage = 0.5;\n const triggerXPosition = pageTurnDirection === `horizontal`\n ? viewportPosition.x + (context.getVisibleAreaRect().width * triggerPercentage)\n : 0;\n const triggerYPosition = pageTurnDirection === `horizontal`\n ? 0\n : viewportPosition.y + (context.getVisibleAreaRect().height * triggerPercentage);\n const midScreenPositionSafePosition = wrapPositionWithSafeEdge({ x: triggerXPosition, y: triggerYPosition });\n return getNavigationForPosition(midScreenPositionSafePosition);\n };\n const isNavigationGoingForwardFrom = (to, from) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n if (pageTurnDirection === `vertical`) {\n return to.y > from.y;\n }\n return to.x > from.x;\n };\n return {\n getNavigationForCfi,\n getNavigationForPage,\n getNavigationForLastPage,\n getNavigationForSpineIndexOrId,\n getNavigationForRightPage,\n getNavigationForLeftPage,\n getNavigationForUrl,\n getNavigationForAnchor,\n getNavigationForPosition,\n getMostPredominantNavigationForPosition,\n wrapPositionWithSafeEdge,\n isNavigationGoingForwardFrom,\n areNavigationDifferent,\n arePositionsDifferent\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/navigationResolver.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/navigationResolver.ts?b722"],"sourcesContent":["import { Report } from \"../report\"\nimport { Context } from \"../context\"\nimport { SpineItemManager } from \"../spineItemManager\"\nimport { SpineItem } from \"../spineItem/createSpineItem\"\nimport { createNavigationResolver as createSpineItemNavigator } from \"../spineItem/navigationResolver\"\nimport { createLocationResolver } from \"./locationResolver\"\nimport { createCfiLocator } from \"./cfiLocator\"\n\nexport type ViewportNavigationEntry = { x: number, y: number, spineItem?: SpineItem }\ntype ViewportPosition = { x: number, y: number }\ntype SpineItemPosition = { x: number, y: number }\n\nconst NAMESPACE = `spineNavigator`\n\nexport const createNavigationResolver = ({ context, spineItemManager, cfiLocator, locator }: {\n  context: Context,\n  spineItemManager: SpineItemManager,\n  cfiLocator: ReturnType<typeof createCfiLocator>,\n  locator: ReturnType<typeof createLocationResolver>\n}) => {\n  const spineItemNavigator = createSpineItemNavigator({ context })\n\n  const arePositionsDifferent = (a: ViewportNavigationEntry, b: ViewportNavigationEntry) => a.x !== b.x || a.y !== b.y\n\n  const areNavigationDifferent = (a: ViewportNavigationEntry, b: ViewportNavigationEntry) => arePositionsDifferent(a, b) || ((!!a.spineItem && !!b.spineItem) && (a.spineItem !== b.spineItem))\n\n  const wrapPositionWithSafeEdge = Report.measurePerformance(`${NAMESPACE} wrapPositionWithSafeEdge`, 1, (position: SpineItemPosition) => {\n    // @todo use container width instead to increase performances\n    const lastSpineItem = spineItemManager.get(spineItemManager.getLength() - 1)\n    const distanceOfLastSpineItem = spineItemManager.getAbsolutePositionOf(lastSpineItem || 0)\n    const maximumXOffset = distanceOfLastSpineItem.leftEnd - context.getPageSize().width\n    const maximumYOffset = distanceOfLastSpineItem.topEnd - context.getPageSize().height\n\n    return {\n      x: Math.min(Math.max(0, position.x), maximumXOffset),\n      y: Math.min(Math.max(0, position.y), maximumYOffset)\n    }\n  }, { disable: true })\n\n  const getAdjustedPositionForSpread = ({ x, y }: ViewportNavigationEntry): ViewportNavigationEntry => {\n    const isOffsetNotAtEdge = (x % context.getVisibleAreaRect().width) !== 0\n    const correctedX = isOffsetNotAtEdge ? x - context.getPageSize().width : x\n\n    return { x: correctedX, y }\n  }\n\n  const getNavigationForCfi = (cfi: string): ViewportNavigationEntry => {\n    const spineItem = cfiLocator.getSpineItemFromCfi(cfi)\n    const { node, offset = 0 } = cfiLocator.resolveCfi(cfi) || {}\n\n    if (!spineItem) {\n      Report.warn(NAMESPACE, `unable to detect item id from cfi ${cfi}`)\n    } else {\n      const spineItemNavigation = node ? spineItemNavigator.getNavigationFromNode(spineItem, node, offset) : { x: 0, y: 0 }\n      const readingPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem)\n\n      // very important to always return a reading item since we want to focus on that particular one\n      return { ...getAdjustedPositionForSpread(readingPosition), spineItem }\n    }\n\n    return { x: 0, y: 0 }\n  }\n\n  const getNavigationForPage = (pageIndex: number, spineItem?: SpineItem): ViewportNavigationEntry => {\n    // lookup for entire book\n    // This is reliable for pre-paginated, do not use it for reflowable book\n    if (!spineItem) {\n      const xPositionForPageIndex = pageIndex * context.getPageSize().width\n      return getNavigationForPosition({ x: xPositionForPageIndex, y: 0 })\n    }\n\n    const spineItemNavigation = spineItemNavigator.getNavigationForPage(pageIndex, spineItem)\n    const readingOffset = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem)\n\n    return getAdjustedPositionForSpread(readingOffset)\n  }\n\n  const getNavigationForLastPage = (spineItem: SpineItem): ViewportNavigationEntry => {\n    const spineItemNavigation = spineItemNavigator.getNavigationForLastPage(spineItem)\n    const position = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem)\n\n    return getAdjustedPositionForSpread(position)\n  }\n\n  const getNavigationForSpineIndexOrId = (indexOrId: number | string): ViewportNavigationEntry => {\n    const spineItem = spineItemManager.get(indexOrId)\n    if (spineItem) {\n      const position = locator.getSpinePositionFromSpineItem(spineItem)\n\n      return { ...getAdjustedPositionForSpread(position), spineItem }\n    }\n\n    return { x: 0, y: 0 }\n  }\n\n  const getNavigationForRightSinglePage = (position: SpineItemPosition): ViewportNavigationEntry => {\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n    const spineItem = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem()\n    const defaultNavigation = position\n\n    if (!spineItem) {\n      return defaultNavigation\n    }\n\n    // translate viewport position into reading item local position\n    const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(position, spineItem)\n    // get reading item local position for right page\n    const spineItemNavigationForRightPage = spineItemNavigator.getNavigationForRightPage(spineItemPosition, spineItem)\n    // check both position to see if we moved out of it\n    const isNewNavigationInCurrentItem = !spineItemPosition.outsideOfBoundaries && arePositionsDifferent(spineItemNavigationForRightPage, spineItemPosition)\n\n    // console.warn({ spineItemPosition, spineItemNavigationForRightPage, isNewNavigationInCurrentItem })\n    if (!isNewNavigationInCurrentItem) {\n      return wrapPositionWithSafeEdge(\n        context.isRTL()\n          ? pageTurnDirection === `horizontal`\n            ? { x: position.x - context.getPageSize().width, y: 0 }\n            : { y: position.y + context.getPageSize().height, x: 0 }\n          : pageTurnDirection === `horizontal`\n            ? { x: position.x + context.getPageSize().width, y: 0 }\n            : { y: position.y + context.getPageSize().height, x: 0 }\n      )\n    } else {\n      const readingOrderPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigationForRightPage, spineItem)\n\n      return readingOrderPosition\n    }\n  }\n\n  const getNavigationForLeftSinglePage = (position: SpineItemPosition): ViewportNavigationEntry => {\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n    const spineItem = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem()\n    const defaultNavigation = { ...position, spineItem }\n\n    if (!spineItem) {\n      return defaultNavigation\n    }\n\n    const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(position, spineItem)\n    const spineItemNavigation = spineItemNavigator.getNavigationForLeftPage(spineItemPosition, spineItem)\n    const isNewNavigationInCurrentItem = !spineItemPosition.outsideOfBoundaries && arePositionsDifferent(spineItemNavigation, spineItemPosition)\n\n    if (!isNewNavigationInCurrentItem) {\n      return wrapPositionWithSafeEdge(\n        context.isRTL()\n          ? pageTurnDirection === `horizontal`\n            ? { x: position.x + context.getPageSize().width, y: 0 }\n            : { y: position.y - context.getPageSize().height, x: 0 }\n          : pageTurnDirection === `horizontal`\n            ? { x: position.x - context.getPageSize().width, y: 0 }\n            : { y: position.y - context.getPageSize().height, x: 0 }\n      )\n    } else {\n      const readingOrderPosition = locator.getSpinePositionFromSpineItemPosition(spineItemNavigation, spineItem)\n\n      return readingOrderPosition\n    }\n  }\n\n  /**\n   * Very naive approach for spread. It could be optimized but by using this approach\n   * we do not add complexity to the code and use the current logic to handle it correctly.\n   *\n   * @important\n   * Special case for vertical content, read content\n   */\n  const getNavigationForRightPage = (position: SpineItemPosition): ViewportNavigationEntry => {\n    const spineItemOnPosition = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem()\n\n    let navigation = getNavigationForRightSinglePage(position)\n\n    // when we move withing vertical content, because only y moves, we don't need two navigation\n    if (spineItemOnPosition?.isUsingVerticalWriting() && position.x === navigation.x) {\n      return getAdjustedPositionForSpread(navigation)\n    }\n\n    if (context.shouldDisplaySpread()) {\n      // in case of spread the entire screen is taken as one real page for vertical content\n      // in order to move out from it we add an extra page width.\n      // using `getNavigationForLeftSinglePage` again would keep x as it is and wrongly move y\n      // for the next item in case it's also a vertical content\n      if (spineItemOnPosition?.isUsingVerticalWriting() && position.x !== navigation.x) {\n        return getAdjustedPositionForSpread(\n          wrapPositionWithSafeEdge(\n            context.isRTL()\n              ? {\n                  ...navigation,\n                  x: navigation.x - context.getPageSize().width\n                }\n              : {\n                  ...navigation,\n                  x: navigation.x + context.getPageSize().width\n                }\n          )\n        )\n      }\n\n      /**\n       * In vase we move vertically and the y is already different, we don't need a second navigation\n       * since we already jumped to a new screen\n       */\n      if (context.getSettings().computedPageTurnDirection === `vertical` && position.y !== navigation.y) {\n        return getAdjustedPositionForSpread(navigation)\n      }\n\n      navigation = getNavigationForRightSinglePage(navigation)\n    }\n\n    return getAdjustedPositionForSpread(navigation)\n  }\n\n  /**\n   * Very naive approach for spread. It could be optimized but by using this approach\n   * we do not add complexity to the code and use the current logic to handle it correctly.\n   *\n   * @important\n   * Special case for vertical content, read content\n   */\n  const getNavigationForLeftPage = (position: SpineItemPosition): ViewportNavigationEntry => {\n    const spineItemOnPosition = locator.getSpineItemFromPosition(position) || spineItemManager.getFocusedSpineItem()\n\n    let navigation = getNavigationForLeftSinglePage(position)\n\n    // when we move withing vertical content, because only y moves, we don't need two navigation\n    if (spineItemOnPosition?.isUsingVerticalWriting() && position.x === navigation.x) {\n      return getAdjustedPositionForSpread(navigation)\n    }\n\n    if (context.shouldDisplaySpread()) {\n      // in case of spread the entire screen is taken as one real page for vertical content\n      // in order to move out from it we add an extra page width.\n      // using `getNavigationForLeftSinglePage` again would keep x as it is and wrongly move y\n      // for the next item in case it's also a vertical content\n      if (spineItemOnPosition?.isUsingVerticalWriting() && position.x !== navigation.x) {\n        return getAdjustedPositionForSpread(\n          wrapPositionWithSafeEdge(\n            context.isRTL()\n              ? { ...navigation, x: navigation.x + context.getPageSize().width }\n              : { ...navigation, x: navigation.x - context.getPageSize().width }\n          )\n        )\n      }\n\n      /**\n       * In vase we move vertically and the y is already different, we don't need a second navigation\n       * since we already jumped to a new screen\n       */\n      if (context.getSettings().computedPageTurnDirection === `vertical` && position.y !== navigation.y) {\n        return getAdjustedPositionForSpread(navigation)\n      }\n\n      navigation = getNavigationForLeftSinglePage(navigation)\n    }\n\n    return getAdjustedPositionForSpread(navigation)\n  }\n\n  const getNavigationForUrl = (url: string | URL): ViewportNavigationEntry & { url: URL } | undefined => {\n    let validUrl: URL | undefined\n    try {\n      validUrl = url instanceof URL ? url : new URL(url)\n    } catch (e) {\n      Report.error(e)\n    }\n    if (validUrl) {\n      const urlWithoutAnchor = `${validUrl.origin}${validUrl.pathname}`\n      const existingSpineItem = context.getManifest()?.spineItems.find(item => item.href === urlWithoutAnchor)\n      if (existingSpineItem) {\n        const spineItem = spineItemManager.get(existingSpineItem.id)\n        if (spineItem) {\n          const position = getNavigationForAnchor(validUrl.hash, spineItem)\n\n          return { ...getAdjustedPositionForSpread(position), url: validUrl }\n        }\n      }\n    }\n\n    return undefined\n  }\n\n  const getNavigationForAnchor = (anchor: string, spineItem: SpineItem) => {\n    const position = locator.getSpinePositionFromSpineItemAnchor(anchor, spineItem)\n\n    return getAdjustedPositionForSpread(position)\n  }\n\n  const getNavigationForPosition = (viewportPosition: ViewportPosition) => {\n    const spineItem = locator.getSpineItemFromPosition(viewportPosition)\n\n    if (spineItem) {\n      const spineItemPosition = locator.getSpineItemPositionFromSpinePosition(viewportPosition, spineItem)\n      const spineItemValidPosition = spineItemNavigator.getNavigationForPosition(spineItem, spineItemPosition)\n      const viewportNavigation = locator.getSpinePositionFromSpineItemPosition(spineItemValidPosition, spineItem)\n\n      return getAdjustedPositionForSpread(viewportNavigation)\n    }\n\n    return { x: 0, y: 0 }\n  }\n\n  /**\n   * Useful when you want to get a navigation from a scroll position. It uses trigger points so it will\n   * try to get the most visible / relevant element as navigation reference\n   */\n  const getMostPredominantNavigationForPosition = (viewportPosition: ViewportPosition) => {\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n    // @todo movingForward does not work same with free-scroll, try to find a reliable way to detect\n    // const movingForward = navigator.isNavigationGoingForwardFrom(navigation, currentNavigationPosition)\n    // const triggerPercentage = movingForward ? 0.7 : 0.3\n    const triggerPercentage = 0.5\n    const triggerXPosition = pageTurnDirection === `horizontal`\n      ? viewportPosition.x + (context.getVisibleAreaRect().width * triggerPercentage)\n      : 0\n    const triggerYPosition = pageTurnDirection === `horizontal`\n      ? 0\n      : viewportPosition.y + (context.getVisibleAreaRect().height * triggerPercentage)\n    const midScreenPositionSafePosition = wrapPositionWithSafeEdge({ x: triggerXPosition, y: triggerYPosition })\n    return getNavigationForPosition(midScreenPositionSafePosition)\n  }\n\n  const isNavigationGoingForwardFrom = (to: ViewportPosition, from: ViewportPosition) => {\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n\n    if (pageTurnDirection === `vertical`) {\n      return to.y > from.y\n    }\n\n    return to.x > from.x\n  }\n\n  return {\n    getNavigationForCfi,\n    getNavigationForPage,\n    getNavigationForLastPage,\n    getNavigationForSpineIndexOrId,\n    getNavigationForRightPage,\n    getNavigationForLeftPage,\n    getNavigationForUrl,\n    getNavigationForAnchor,\n    getNavigationForPosition,\n    getMostPredominantNavigationForPosition,\n    wrapPositionWithSafeEdge,\n    isNavigationGoingForwardFrom,\n    areNavigationDifferent,\n    arePositionsDifferent\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/navigationResolver.ts\n");
|
|
360
|
+
|
|
361
|
+
/***/ }),
|
|
362
|
+
|
|
363
|
+
/***/ "./src/spine/viewportNavigator/manualViewportNavigator.ts":
|
|
364
|
+
/*!****************************************************************!*\
|
|
365
|
+
!*** ./src/spine/viewportNavigator/manualViewportNavigator.ts ***!
|
|
366
|
+
\****************************************************************/
|
|
367
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
368
|
+
|
|
369
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createManualViewportNavigator\": () => (/* binding */ createManualViewportNavigator)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../report */ \"./src/report.ts\");\n\n\n\nconst NAMESPACE = `manualViewportNavigator`;\nconst createManualViewportNavigator = ({ navigator, spineItemManager, currentNavigationSubject$, locator, context }) => {\n const stateSubject$ = (new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(`end`));\n const navigationTriggerSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const turnLeft = ({ allowSpineItemChange = true } = {}) => navigationTriggerSubject$.next({ type: `leftPage`, data: { allowSpineItemChange } });\n const turnRight = ({ allowSpineItemChange = true } = {}) => {\n navigationTriggerSubject$.next({ type: `rightPage`, data: { allowSpineItemChange } });\n };\n const goToPageOfCurrentChapter = (pageIndex) => navigationTriggerSubject$.next({ type: `chapterPage`, data: { pageIndex } });\n const goToPage = (pageIndex) => navigationTriggerSubject$.next({ type: `pageIndex`, data: { pageIndex } });\n const goToCfi = (cfi, options = { animate: true }) => navigationTriggerSubject$.next({ type: `cfi`, data: Object.assign({ cfi }, options) });\n const goToUrl = (url) => navigationTriggerSubject$.next({ type: `url`, data: url });\n const goToSpineItem = (indexOrId, options = { animate: true }) => {\n navigationTriggerSubject$.next({ type: `spineItem`, data: Object.assign({ indexOrId }, options) });\n };\n const urlNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `url`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ data }) => {\n const navigation = navigator.getNavigationForUrl(data);\n if (navigation) {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { animate: true, lastUserExpectedNavigation: { type: `navigate-from-anchor`, data: navigation.url.hash } }));\n }\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }));\n const spineItemNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `spineItem`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ data: { animate, indexOrId } }) => {\n const navigation = navigator.getNavigationForSpineIndexOrId(indexOrId);\n const lastUserExpectedNavigation = { type: `navigate-from-previous-item` };\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `goToSpineItem`, { indexOrId, animate, navigation });\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { animate, lastUserExpectedNavigation }));\n }));\n const cfiNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `cfi`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(({ data: { animate, cfi } }) => {\n const navigation = navigator.getNavigationForCfi(cfi);\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `goToCfi`, { cfi, animate, navigation });\n return (Object.assign(Object.assign({}, navigation), { animate, lastUserExpectedNavigation: { type: `navigate-from-cfi`, data: cfi } }));\n }));\n const chapterPageNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `chapterPage`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ data: { pageIndex } }) => {\n const spineItem = spineItemManager.getFocusedSpineItem();\n if (spineItem) {\n const navigation = navigator.getNavigationForPage(pageIndex, spineItem);\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { lastUserExpectedNavigation: undefined, animate: true }));\n }\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }));\n const pageNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `pageIndex`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(_ => {\n var _a;\n if (((_a = context.getManifest()) === null || _a === void 0 ? void 0 : _a.renditionLayout) === `reflowable`) {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.warn(`This method only works for pre-paginated content`);\n return false;\n }\n return true;\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ data: { pageIndex } }) => {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigator.getNavigationForPage(pageIndex)), { lastUserExpectedNavigation: undefined, animate: true }));\n }));\n const turnPageTo$ = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`turnTo`, 10, (navigation, { allowSpineItemChange = true } = {}) => {\n const currentSpineItem = spineItemManager.getFocusedSpineItem();\n if (!currentSpineItem)\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n const newSpineItem = locator.getSpineItemFromPosition(navigation) || currentSpineItem;\n const spineItemHasChanged = newSpineItem !== currentSpineItem;\n if (spineItemHasChanged) {\n if (allowSpineItemChange) {\n if (spineItemManager.comparePositionOf(newSpineItem, currentSpineItem) === `before`) {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { lastUserExpectedNavigation: { type: `navigate-from-next-item` }, animate: true }));\n }\n else {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { lastUserExpectedNavigation: { type: `navigate-from-previous-item` }, animate: true }));\n }\n }\n }\n else {\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, navigation), { lastUserExpectedNavigation: undefined, animate: true }));\n }\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n });\n const leftPageNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `leftPage`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(currentNavigationSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(([{ data: { allowSpineItemChange } }, currentNavigation]) => {\n const navigation = navigator.getNavigationForLeftPage(currentNavigation);\n return turnPageTo$(navigation, { allowSpineItemChange });\n }));\n const rightPageNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `rightPage`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(currentNavigationSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(([{ data: { allowSpineItemChange } }, currentNavigation]) => {\n const navigation = navigator.getNavigationForRightPage(currentNavigation);\n return turnPageTo$(navigation, { allowSpineItemChange });\n }));\n const navigation$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(urlNavigation$, spineItemNavigation$, chapterPageNavigation$, leftPageNavigation$, rightPageNavigation$, (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(cfiNavigation$, pageNavigation$))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(currentNavigationSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(([navigation, currentNavigation]) => navigator.areNavigationDifferent(navigation, currentNavigation)), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(([navigation]) => navigation));\n return {\n destroy: () => { },\n adjustReadingOffset: (_) => {\n return false;\n },\n turnLeft,\n turnRight,\n goToCfi,\n goToPageOfCurrentChapter,\n goToSpineItem,\n goToUrl,\n goToPage,\n $: {\n state$: stateSubject$.asObservable(),\n navigation$\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/viewportNavigator/manualViewportNavigator.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/viewportNavigator/manualViewportNavigator.ts?bfda"],"sourcesContent":["import { BehaviorSubject, EMPTY, merge, of, Subject } from \"rxjs\"\nimport { filter, map, switchMap, tap, withLatestFrom } from \"rxjs/operators\"\nimport { Context } from \"../../context\"\nimport { SpineItemManager } from \"../../spineItemManager\"\nimport { Report } from \"../../report\"\nimport { createNavigationResolver, ViewportNavigationEntry } from \"../navigationResolver\"\nimport { createLocationResolver } from \"../locationResolver\"\n\nconst NAMESPACE = `manualViewportNavigator`\n\ntype UrlNavigation = { type: `url`, data: string | URL }\ntype SpineItemNavigation = { type: `spineItem`, data: { indexOrId: number | string, animate: boolean } }\ntype CfiNavigation = { type: `cfi`, data: { cfi: string, animate: boolean } }\ntype ChapterPageNavigation = { type: `chapterPage`, data: { pageIndex: number } }\ntype PageIndexNavigation = { type: `pageIndex`, data: { pageIndex: number } }\ntype LeftPageNavigation = { type: `leftPage`, data: { allowSpineItemChange: boolean } }\ntype RightPageNavigation = { type: `rightPage`, data: { allowSpineItemChange: boolean } }\n\nexport const createManualViewportNavigator = ({ navigator, spineItemManager, currentNavigationSubject$, locator, context }: {\n  context: Context,\n  element: HTMLElement,\n  navigator: ReturnType<typeof createNavigationResolver>,\n  currentNavigationSubject$: BehaviorSubject<ViewportNavigationEntry>,\n  spineItemManager: SpineItemManager,\n  locator: ReturnType<typeof createLocationResolver>,\n}) => {\n  const stateSubject$ = (new BehaviorSubject<`start` | `end`>(`end`))\n  const navigationTriggerSubject$ = new Subject<\n    | UrlNavigation\n    | SpineItemNavigation\n    | CfiNavigation\n    | ChapterPageNavigation\n    | PageIndexNavigation\n    | LeftPageNavigation\n    | RightPageNavigation\n  >()\n\n  const turnLeft = ({ allowSpineItemChange = true }: { allowSpineItemChange?: boolean } = {}) =>\n    navigationTriggerSubject$.next({ type: `leftPage`, data: { allowSpineItemChange } })\n\n  const turnRight = ({ allowSpineItemChange = true }: { allowSpineItemChange?: boolean } = {}) => {\n    navigationTriggerSubject$.next({ type: `rightPage`, data: { allowSpineItemChange } })\n  }\n\n  // @todo it's wrong because we can be in two different chapter on same page for spread\n  const goToPageOfCurrentChapter = (pageIndex: number) =>\n    navigationTriggerSubject$.next({ type: `chapterPage`, data: { pageIndex } })\n\n  const goToPage = (pageIndex: number) =>\n    navigationTriggerSubject$.next({ type: `pageIndex`, data: { pageIndex } })\n\n  const goToCfi = (cfi: string, options: { animate: boolean } = { animate: true }) =>\n    navigationTriggerSubject$.next({ type: `cfi`, data: { cfi, ...options } })\n\n  const goToUrl = (url: string | URL) =>\n    navigationTriggerSubject$.next({ type: `url`, data: url })\n\n  const goToSpineItem = (indexOrId: number | string, options: { animate: boolean } = { animate: true }) => {\n    navigationTriggerSubject$.next({ type: `spineItem`, data: { indexOrId, ...options } })\n  }\n\n  const urlNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is UrlNavigation => e.type === `url`),\n      switchMap(({ data }) => {\n        const navigation = navigator.getNavigationForUrl(data)\n\n        if (navigation) {\n          return of({ ...navigation, animate: true, lastUserExpectedNavigation: { type: `navigate-from-anchor` as const, data: navigation.url.hash } })\n        }\n\n        return EMPTY\n      })\n    )\n\n  const spineItemNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is SpineItemNavigation => e.type === `spineItem`),\n      switchMap(({ data: { animate, indexOrId } }) => {\n        const navigation = navigator.getNavigationForSpineIndexOrId(indexOrId)\n\n        // always want to be at the beginning of the item\n        const lastUserExpectedNavigation = { type: `navigate-from-previous-item` as const }\n\n        Report.log(NAMESPACE, `goToSpineItem`, { indexOrId, animate, navigation })\n\n        return of({ ...navigation, animate, lastUserExpectedNavigation })\n      })\n    )\n\n  const cfiNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is CfiNavigation => e.type === `cfi`),\n      map(({ data: { animate, cfi } }) => {\n        const navigation = navigator.getNavigationForCfi(cfi)\n\n        Report.log(NAMESPACE, `goToCfi`, { cfi, animate, navigation })\n\n        return ({\n          ...navigation, animate, lastUserExpectedNavigation: { type: `navigate-from-cfi` as const, data: cfi }\n        })\n      })\n    )\n\n  const chapterPageNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is ChapterPageNavigation => e.type === `chapterPage`),\n      switchMap(({ data: { pageIndex } }) => {\n        const spineItem = spineItemManager.getFocusedSpineItem()\n\n        if (spineItem) {\n          const navigation = navigator.getNavigationForPage(pageIndex, spineItem)\n\n          return of({ ...navigation, lastUserExpectedNavigation: undefined, animate: true })\n        }\n\n        return EMPTY\n      })\n    )\n\n  const pageNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is PageIndexNavigation => e.type === `pageIndex`),\n      filter(_ => {\n        if (context.getManifest()?.renditionLayout === `reflowable`) {\n          Report.warn(`This method only works for pre-paginated content`)\n          return false\n        }\n\n        return true\n      }),\n      switchMap(({ data: { pageIndex } }) => {\n        return of({\n          ...navigator.getNavigationForPage(pageIndex),\n          lastUserExpectedNavigation: undefined,\n          animate: true\n        })\n      })\n    )\n\n  const turnPageTo$ = Report.measurePerformance(`turnTo`, 10, (navigation: ViewportNavigationEntry, { allowSpineItemChange = true }: { allowSpineItemChange?: boolean } = {}) => {\n    const currentSpineItem = spineItemManager.getFocusedSpineItem()\n\n    if (!currentSpineItem) return EMPTY\n\n    const newSpineItem = locator.getSpineItemFromPosition(navigation) || currentSpineItem\n    const spineItemHasChanged = newSpineItem !== currentSpineItem\n\n    if (spineItemHasChanged) {\n      if (allowSpineItemChange) {\n        if (spineItemManager.comparePositionOf(newSpineItem, currentSpineItem) === `before`) {\n          return of({ ...navigation, lastUserExpectedNavigation: { type: `navigate-from-next-item` as const }, animate: true })\n        } else {\n          return of({ ...navigation, lastUserExpectedNavigation: { type: `navigate-from-previous-item` as const }, animate: true })\n        }\n      }\n    } else {\n      return of({ ...navigation, lastUserExpectedNavigation: undefined, animate: true })\n    }\n\n    return EMPTY\n  })\n\n  const leftPageNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is LeftPageNavigation => e.type === `leftPage`),\n      withLatestFrom(currentNavigationSubject$),\n      switchMap(([{ data: { allowSpineItemChange } }, currentNavigation]) => {\n        const navigation = navigator.getNavigationForLeftPage(currentNavigation)\n\n        return turnPageTo$(navigation, { allowSpineItemChange })\n      })\n    )\n\n  const rightPageNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is RightPageNavigation => e.type === `rightPage`),\n      withLatestFrom(currentNavigationSubject$),\n      switchMap(([{ data: { allowSpineItemChange } }, currentNavigation]) => {\n        const navigation = navigator.getNavigationForRightPage(currentNavigation)\n\n        return turnPageTo$(navigation, { allowSpineItemChange })\n      })\n    )\n\n  const navigation$ = merge(\n    urlNavigation$,\n    spineItemNavigation$,\n    chapterPageNavigation$,\n    leftPageNavigation$,\n    rightPageNavigation$,\n    // for some reason after too much item ts complains\n    merge(\n      cfiNavigation$,\n      pageNavigation$\n    )\n  )\n    .pipe(\n      /**\n       * Ideally when manually navigating we expect the navigation to be different from the previous one.\n       * This is because manual navigation is not used with scroll where you can move within the same item. A manual\n       * navigation would theoretically always move to different items.\n       */\n      withLatestFrom(currentNavigationSubject$),\n      filter(([navigation, currentNavigation]) => navigator.areNavigationDifferent(navigation, currentNavigation)),\n      map(([navigation]) => navigation)\n    )\n\n  return {\n    destroy: () => { },\n    adjustReadingOffset: (_: { x: number, y: number }) => {\n      return false\n    },\n    turnLeft,\n    turnRight,\n    goToCfi,\n    goToPageOfCurrentChapter,\n    goToSpineItem,\n    goToUrl,\n    goToPage,\n    $: {\n      state$: stateSubject$.asObservable(),\n      navigation$\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/viewportNavigator/manualViewportNavigator.ts\n");
|
|
370
|
+
|
|
371
|
+
/***/ }),
|
|
372
|
+
|
|
373
|
+
/***/ "./src/spine/viewportNavigator/panViewportNavigator.ts":
|
|
374
|
+
/*!*************************************************************!*\
|
|
375
|
+
!*** ./src/spine/viewportNavigator/panViewportNavigator.ts ***!
|
|
376
|
+
\*************************************************************/
|
|
377
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
378
|
+
|
|
379
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createPanViewportNavigator\": () => (/* binding */ createPanViewportNavigator)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../report */ \"./src/report.ts\");\n\n\n\nconst NAMESPACE = `panViewportNavigator`;\nconst createPanViewportNavigator = ({ getCurrentViewportPosition, navigator, spineItemManager, locator, context, currentNavigationSubject$ }) => {\n const navigationTriggerSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const stateSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(`end`);\n let movingLastDelta = { x: 0, y: 0 };\n let movingLastPosition = { x: 0, y: 0 };\n const moveToSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const moveTo = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`${NAMESPACE} moveTo`, 5, (delta, { final, start } = {}) => {\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.warn(`pan control is not available on free page turn mode`);\n return;\n }\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n if (start) {\n stateSubject$.next(`start`);\n movingLastDelta = { x: 0, y: 0 };\n movingLastPosition = getCurrentViewportPosition();\n }\n let navigation = currentNavigationSubject$.value;\n if (delta) {\n const correctedX = delta.x - ((movingLastDelta === null || movingLastDelta === void 0 ? void 0 : movingLastDelta.x) || 0);\n const correctedY = delta.y - ((movingLastDelta === null || movingLastDelta === void 0 ? void 0 : movingLastDelta.y) || 0);\n navigation = navigator.wrapPositionWithSafeEdge({\n x: pageTurnDirection === `horizontal`\n ? context.isRTL()\n ? movingLastPosition.x + correctedX\n : movingLastPosition.x - correctedX\n : 0,\n y: pageTurnDirection === `horizontal` ? 0 : movingLastPosition.y - correctedY\n });\n movingLastDelta = delta;\n }\n else {\n navigation = getCurrentViewportPosition();\n }\n movingLastPosition = navigation;\n if (final) {\n movingLastDelta = { x: 0, y: 0 };\n snapTo({\n from: currentNavigationSubject$.value,\n to: navigation,\n pan: movingLastPosition\n });\n stateSubject$.next(`end`);\n return;\n }\n moveToSubject$.next({ position: navigation });\n }, { disable: false });\n const snapTo = (data) => {\n navigationTriggerSubject$.next({ type: `snap`, data });\n };\n const getLastUserExpectedNavigation = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`turnTo`, 10, (navigation, { allowSpineItemChange = true } = {}) => {\n const currentSpineItem = spineItemManager.getFocusedSpineItem();\n if (!currentSpineItem)\n return undefined;\n const newSpineItem = locator.getSpineItemFromPosition(navigation) || currentSpineItem;\n const spineItemHasChanged = newSpineItem !== currentSpineItem;\n if (spineItemHasChanged) {\n if (allowSpineItemChange) {\n if (spineItemManager.comparePositionOf(newSpineItem, currentSpineItem) === `before`) {\n return { type: `navigate-from-next-item` };\n }\n else {\n return { type: `navigate-from-previous-item` };\n }\n }\n }\n else {\n return undefined;\n }\n });\n const snapNavigation$ = navigationTriggerSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)((e) => e.type === `snap`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(({ data: { from, to } }) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n const movingForward = navigator.isNavigationGoingForwardFrom(to, from);\n const triggerPercentage = movingForward ? 0.7 : 0.3;\n const triggerXPosition = pageTurnDirection === `horizontal`\n ? to.x + (context.getVisibleAreaRect().width * triggerPercentage)\n : 0;\n const triggerYPosition = pageTurnDirection === `horizontal`\n ? 0\n : to.y + (context.getVisibleAreaRect().height * triggerPercentage);\n const midScreenPositionSafePosition = navigator.wrapPositionWithSafeEdge({ x: triggerXPosition, y: triggerYPosition });\n const finalNavigation = navigator.getNavigationForPosition(midScreenPositionSafePosition);\n const lastUserExpectedNavigation = getLastUserExpectedNavigation(finalNavigation);\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(Object.assign(Object.assign({}, finalNavigation), { lastUserExpectedNavigation }));\n }));\n const destroy = () => {\n moveToSubject$.complete();\n stateSubject$.complete();\n };\n return {\n moveTo,\n destroy,\n adjustReadingOffset: (_) => {\n return false;\n },\n $: {\n moveToSubject$,\n state$: stateSubject$.asObservable(),\n navigation$: (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(snapNavigation$)\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/viewportNavigator/panViewportNavigator.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/viewportNavigator/panViewportNavigator.ts?d1fe"],"sourcesContent":["import { BehaviorSubject, merge, of, Subject } from \"rxjs\"\nimport { filter, switchMap } from \"rxjs/operators\"\nimport { Context } from \"../../context\"\nimport { SpineItemManager } from \"../../spineItemManager\"\nimport { Report } from \"../../report\"\nimport { createNavigationResolver, ViewportNavigationEntry } from \"../navigationResolver\"\nimport { createLocationResolver } from \"../locationResolver\"\nimport { ViewportPosition } from \"../../types\"\n\nconst NAMESPACE = `panViewportNavigator`\n\ntype SnapNavigation = { type: `snap`, data: { from: ViewportNavigationEntry, to: ViewportNavigationEntry, pan: { x: number, y: number } } }\n\nexport const createPanViewportNavigator = ({ getCurrentViewportPosition, navigator, spineItemManager, locator, context, currentNavigationSubject$ }: {\n  context: Context,\n  element: HTMLElement,\n  navigator: ReturnType<typeof createNavigationResolver>,\n  currentNavigationSubject$: BehaviorSubject<ViewportNavigationEntry>,\n  spineItemManager: SpineItemManager,\n  locator: ReturnType<typeof createLocationResolver>,\n  getCurrentViewportPosition: () => ViewportPosition\n}) => {\n  const navigationTriggerSubject$ = new Subject<\n    | SnapNavigation\n  >()\n  const stateSubject$ = new BehaviorSubject<`end` | `start`>(`end`)\n  let movingLastDelta = { x: 0, y: 0 }\n  let movingLastPosition = { x: 0, y: 0 }\n  const moveToSubject$ = new Subject<{ position: ViewportNavigationEntry }>()\n\n  /**\n   * @prototype\n   */\n  const moveTo = Report.measurePerformance(`${NAMESPACE} moveTo`, 5, (delta: { x: number, y: number } | undefined, { final, start }: { start?: boolean, final?: boolean } = {}) => {\n    if (context.getSettings().computedPageTurnMode === `scrollable`) {\n      Report.warn(`pan control is not available on free page turn mode`)\n      return\n    }\n\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n\n    if (start) {\n      stateSubject$.next(`start`)\n      movingLastDelta = { x: 0, y: 0 }\n      movingLastPosition = getCurrentViewportPosition()\n    }\n\n    let navigation = currentNavigationSubject$.value\n\n    if (delta) {\n      const correctedX = delta.x - (movingLastDelta?.x || 0)\n      const correctedY = delta.y - (movingLastDelta?.y || 0)\n\n      navigation = navigator.wrapPositionWithSafeEdge({\n        x: pageTurnDirection === `horizontal`\n          ? context.isRTL()\n            ? movingLastPosition.x + correctedX\n            : movingLastPosition.x - correctedX\n          : 0,\n        y: pageTurnDirection === `horizontal` ? 0 : movingLastPosition.y - correctedY\n      })\n\n      movingLastDelta = delta\n    } else {\n      navigation = getCurrentViewportPosition()\n    }\n\n    movingLastPosition = navigation\n\n    if (final) {\n      movingLastDelta = { x: 0, y: 0 }\n\n      snapTo({\n        from: currentNavigationSubject$.value,\n        to: navigation,\n        pan: movingLastPosition\n      })\n      stateSubject$.next(`end`)\n\n      return\n    }\n\n    moveToSubject$.next({ position: navigation })\n  }, { disable: false })\n\n  const snapTo = (data: SnapNavigation[`data`]) => {\n    navigationTriggerSubject$.next({ type: `snap`, data })\n  }\n\n  const getLastUserExpectedNavigation = Report.measurePerformance(`turnTo`, 10, (navigation: ViewportNavigationEntry, { allowSpineItemChange = true }: { allowSpineItemChange?: boolean } = {}) => {\n    const currentSpineItem = spineItemManager.getFocusedSpineItem()\n\n    if (!currentSpineItem) return undefined\n\n    const newSpineItem = locator.getSpineItemFromPosition(navigation) || currentSpineItem\n    const spineItemHasChanged = newSpineItem !== currentSpineItem\n\n    if (spineItemHasChanged) {\n      if (allowSpineItemChange) {\n        if (spineItemManager.comparePositionOf(newSpineItem, currentSpineItem) === `before`) {\n          return { type: `navigate-from-next-item` as const }\n        } else {\n          return { type: `navigate-from-previous-item` as const }\n        }\n      }\n    } else {\n      return undefined\n    }\n  })\n\n  const snapNavigation$ = navigationTriggerSubject$\n    .pipe(\n      filter((e): e is SnapNavigation => e.type === `snap`),\n      switchMap(({ data: { from, to } }) => {\n        const pageTurnDirection = context.getSettings().computedPageTurnDirection\n        const movingForward = navigator.isNavigationGoingForwardFrom(to, from)\n        const triggerPercentage = movingForward ? 0.7 : 0.3\n        const triggerXPosition = pageTurnDirection === `horizontal`\n          ? to.x + (context.getVisibleAreaRect().width * triggerPercentage)\n          : 0\n        const triggerYPosition = pageTurnDirection === `horizontal`\n          ? 0\n          : to.y + (context.getVisibleAreaRect().height * triggerPercentage)\n        const midScreenPositionSafePosition = navigator.wrapPositionWithSafeEdge({ x: triggerXPosition, y: triggerYPosition })\n        const finalNavigation = navigator.getNavigationForPosition(midScreenPositionSafePosition)\n        const lastUserExpectedNavigation = getLastUserExpectedNavigation(finalNavigation)\n\n        // @todo return an animation interpolation based on the distance\n\n        return of({ ...finalNavigation, lastUserExpectedNavigation })\n      })\n    )\n\n  const destroy = () => {\n    moveToSubject$.complete()\n    stateSubject$.complete()\n  }\n\n  return {\n    moveTo,\n    destroy,\n    adjustReadingOffset: (_: { x: number, y: number }) => {\n      return false\n    },\n    $: {\n      moveToSubject$,\n      state$: stateSubject$.asObservable(),\n      navigation$: merge(\n        snapNavigation$\n      )\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/viewportNavigator/panViewportNavigator.ts\n");
|
|
380
|
+
|
|
381
|
+
/***/ }),
|
|
382
|
+
|
|
383
|
+
/***/ "./src/spine/viewportNavigator/scrollViewportNavigator.ts":
|
|
384
|
+
/*!****************************************************************!*\
|
|
385
|
+
!*** ./src/spine/viewportNavigator/scrollViewportNavigator.ts ***!
|
|
386
|
+
\****************************************************************/
|
|
387
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
388
|
+
|
|
389
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createScrollViewportNavigator\": () => (/* binding */ createScrollViewportNavigator)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n\n\nconst SCROLL_FINISHED_DEBOUNCE_TIMEOUT = 200;\nconst createScrollViewportNavigator = ({ context, element, navigator, currentNavigationSubject$ }) => {\n let lastScrollWasProgrammaticallyTriggered = false;\n const onlyUserScrollFilter = (source) => source.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(() => {\n if (lastScrollWasProgrammaticallyTriggered) {\n lastScrollWasProgrammaticallyTriggered = false;\n return false;\n }\n return true;\n }));\n const adjustReadingOffset = ({ x, y }) => {\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n lastScrollWasProgrammaticallyTriggered = true;\n element.scrollTo({ left: x, top: y });\n return true;\n }\n return false;\n };\n const runOnFreePageTurnModeOnly$ = (source) => context.$.settings$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => context.getSettings().computedPageTurnMode), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)((mode) => (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.iif)(() => mode === `controlled`, rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY, source)));\n const userScroll$ = runOnFreePageTurnModeOnly$((0,rxjs__WEBPACK_IMPORTED_MODULE_0__.fromEvent)(element, `scroll`))\n .pipe(onlyUserScrollFilter, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$));\n const navigationOnScroll$ = userScroll$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.debounceTime)(SCROLL_FINISHED_DEBOUNCE_TIMEOUT, rxjs__WEBPACK_IMPORTED_MODULE_0__.animationFrameScheduler), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(currentNavigationSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)(() => {\n const navigation = navigator.getMostPredominantNavigationForPosition({ x: element.scrollLeft, y: element.scrollTop });\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)({ position: navigation, animate: false, lastUserExpectedNavigation: undefined });\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)());\n const userScrollEnd$ = userScroll$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.debounceTime)(SCROLL_FINISHED_DEBOUNCE_TIMEOUT, rxjs__WEBPACK_IMPORTED_MODULE_0__.animationFrameScheduler), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$));\n const state$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(userScroll$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => `start`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)()), userScrollEnd$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => `end`)))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.startWith)(`end`));\n return {\n destroy: () => { },\n adjustReadingOffset,\n $: {\n state$,\n navigation$: navigationOnScroll$\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc3BpbmUvdmlld3BvcnROYXZpZ2F0b3Ivc2Nyb2xsVmlld3BvcnROYXZpZ2F0b3IudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBdUk7QUFDTTtBQUk3SSxNQUFNLGdDQUFnQyxHQUFHLEdBQUc7QUFFckMsTUFBTSw2QkFBNkIsR0FBRyxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUseUJBQXlCLEVBS3JHLEVBQUUsRUFBRTtJQUNILElBQUksc0NBQXNDLEdBQUcsS0FBSztJQUVsRCxNQUFNLG9CQUFvQixHQUFHLENBQUksTUFBcUIsRUFBaUIsRUFBRSxDQUN2RSxNQUFNLENBQUMsSUFBSSxDQUFDLHNEQUFNLENBQUMsR0FBRyxFQUFFO1FBQ3RCLElBQUksc0NBQXNDLEVBQUU7WUFDMUMsc0NBQXNDLEdBQUcsS0FBSztZQUM5QyxPQUFPLEtBQUs7U0FDYjtRQUVELE9BQU8sSUFBSTtJQUNiLENBQUMsQ0FBQyxDQUFDO0lBRUwsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBNEIsRUFBRSxFQUFFO1FBQ2pFLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLG9CQUFvQixLQUFLLFlBQVksRUFBRTtZQUMvRCxzQ0FBc0MsR0FBRyxJQUFJO1lBQzdDLE9BQU8sQ0FBQyxRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUVyQyxPQUFPLElBQUk7U0FDWjtRQUVELE9BQU8sS0FBSztJQUNkLENBQUM7SUFFRCxNQUFNLDBCQUEwQixHQUFHLENBQUksTUFBcUIsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTO1NBQ2pGLElBQUksQ0FDSCxtREFBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQyxFQUNyRCxvRUFBb0IsRUFBRSxFQUN0Qix5REFBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDakIseUNBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLEtBQUssWUFBWSxFQUFFLHVDQUFLLEVBQUUsTUFBTSxDQUFDLENBQ2hELENBQ0Y7SUFFSCxNQUFNLFdBQVcsR0FBRywwQkFBMEIsQ0FBQywrQ0FBUyxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQztTQUN6RSxJQUFJLENBQ0gsb0JBQW9CLEVBQ3BCLHFEQUFLLEVBQUUsRUFDUCx5REFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQzlCO0lBRUgsTUFBTSxtQkFBbUIsR0FBRyxXQUFXO1NBQ3BDLElBQUksQ0FDSCw0REFBWSxDQUFDLGdDQUFnQyxFQUFFLHlEQUF1QixDQUFDLEVBQ3ZFLDhEQUFjLENBQUMseUJBQXlCLENBQUMsRUFDekMseURBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDYixNQUFNLFVBQVUsR0FBRyxTQUFTLENBQUMsdUNBQXVDLENBQUMsRUFBRSxDQUFDLEVBQUUsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDLEVBQUUsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBTXJILE9BQU8sd0NBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSwwQkFBMEIsRUFBRSxTQUFTLEVBQUUsQ0FBQztJQUM1RixDQUFDLENBQUMsRUFDRixxREFBSyxFQUFFLENBQ1I7SUFFSCxNQUFNLGNBQWMsR0FBRyxXQUFXO1NBQy9CLElBQUksQ0FDSCw0REFBWSxDQUFDLGdDQUFnQyxFQUFFLHlEQUF1QixDQUFDLEVBQ3ZFLHFEQUFLLEVBQUUsRUFDUCx5REFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQzlCO0lBRUgsTUFBTSxNQUFNLEdBQUcsMkNBQUssQ0FDbEIsV0FBVztTQUNSLElBQUksQ0FDSCxtREFBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQWdCLENBQUMsRUFDM0Isb0VBQW9CLEVBQUUsQ0FDdkIsRUFDSCxjQUFjO1NBQ1gsSUFBSSxDQUNILG1EQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBYyxDQUFDLENBQzFCLENBQ0o7U0FDRSxJQUFJLENBQ0gseURBQVMsQ0FBQyxLQUFLLENBQUMsQ0FDakI7SUFFSCxPQUFPO1FBQ0wsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUM7UUFDbEIsbUJBQW1CO1FBQ25CLENBQUMsRUFBRTtZQUNELE1BQU07WUFDTixXQUFXLEVBQUUsbUJBQW1CO1NBQ2pDO0tBQ0Y7QUFDSCxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL3NwaW5lL3ZpZXdwb3J0TmF2aWdhdG9yL3Njcm9sbFZpZXdwb3J0TmF2aWdhdG9yLnRzP2Q5YzciXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0aW9uRnJhbWVTY2hlZHVsZXIsIEJlaGF2aW9yU3ViamVjdCwgRU1QVFksIGZyb21FdmVudCwgaWlmLCBtZXJnZSwgTW9ub1R5cGVPcGVyYXRvckZ1bmN0aW9uLCBPYnNlcnZhYmxlLCBvZiB9IGZyb20gXCJyeGpzXCJcbmltcG9ydCB7IGRlYm91bmNlVGltZSwgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciwgbWFwLCBzaGFyZSwgc3dpdGNoTWFwLCB0YWtlVW50aWwsIHdpdGhMYXRlc3RGcm9tLCBzdGFydFdpdGgsIHRhcCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiXG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIi4uLy4uL2NvbnRleHRcIlxuaW1wb3J0IHsgY3JlYXRlTmF2aWdhdGlvblJlc29sdmVyLCBWaWV3cG9ydE5hdmlnYXRpb25FbnRyeSB9IGZyb20gXCIuLi9uYXZpZ2F0aW9uUmVzb2x2ZXJcIlxuXG5jb25zdCBTQ1JPTExfRklOSVNIRURfREVCT1VOQ0VfVElNRU9VVCA9IDIwMFxuXG5leHBvcnQgY29uc3QgY3JlYXRlU2Nyb2xsVmlld3BvcnROYXZpZ2F0b3IgPSAoeyBjb250ZXh0LCBlbGVtZW50LCBuYXZpZ2F0b3IsIGN1cnJlbnROYXZpZ2F0aW9uU3ViamVjdCQgfToge1xuICBjb250ZXh0OiBDb250ZXh0LFxuICBlbGVtZW50OiBIVE1MRWxlbWVudCxcbiAgbmF2aWdhdG9yOiBSZXR1cm5UeXBlPHR5cGVvZiBjcmVhdGVOYXZpZ2F0aW9uUmVzb2x2ZXI+LFxuICBjdXJyZW50TmF2aWdhdGlvblN1YmplY3QkOiBCZWhhdmlvclN1YmplY3Q8Vmlld3BvcnROYXZpZ2F0aW9uRW50cnk+XG59KSA9PiB7XG4gIGxldCBsYXN0U2Nyb2xsV2FzUHJvZ3JhbW1hdGljYWxseVRyaWdnZXJlZCA9IGZhbHNlXG5cbiAgY29uc3Qgb25seVVzZXJTY3JvbGxGaWx0ZXIgPSA8VD4oc291cmNlOiBPYnNlcnZhYmxlPFQ+KTogT2JzZXJ2YWJsZTxUPiA9PlxuICAgIHNvdXJjZS5waXBlKGZpbHRlcigoKSA9PiB7XG4gICAgICBpZiAobGFzdFNjcm9sbFdhc1Byb2dyYW1tYXRpY2FsbHlUcmlnZ2VyZWQpIHtcbiAgICAgICAgbGFzdFNjcm9sbFdhc1Byb2dyYW1tYXRpY2FsbHlUcmlnZ2VyZWQgPSBmYWxzZVxuICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRydWVcbiAgICB9KSlcblxuICBjb25zdCBhZGp1c3RSZWFkaW5nT2Zmc2V0ID0gKHsgeCwgeSB9OiB7IHg6IG51bWJlciwgeTogbnVtYmVyIH0pID0+IHtcbiAgICBpZiAoY29udGV4dC5nZXRTZXR0aW5ncygpLmNvbXB1dGVkUGFnZVR1cm5Nb2RlID09PSBgc2Nyb2xsYWJsZWApIHtcbiAgICAgIGxhc3RTY3JvbGxXYXNQcm9ncmFtbWF0aWNhbGx5VHJpZ2dlcmVkID0gdHJ1ZVxuICAgICAgZWxlbWVudC5zY3JvbGxUbyh7IGxlZnQ6IHgsIHRvcDogeSB9KVxuXG4gICAgICByZXR1cm4gdHJ1ZVxuICAgIH1cblxuICAgIHJldHVybiBmYWxzZVxuICB9XG5cbiAgY29uc3QgcnVuT25GcmVlUGFnZVR1cm5Nb2RlT25seSQgPSA8VD4oc291cmNlOiBPYnNlcnZhYmxlPFQ+KSA9PiBjb250ZXh0LiQuc2V0dGluZ3MkXG4gICAgLnBpcGUoXG4gICAgICBtYXAoKCkgPT4gY29udGV4dC5nZXRTZXR0aW5ncygpLmNvbXB1dGVkUGFnZVR1cm5Nb2RlKSxcbiAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICAgICBzd2l0Y2hNYXAoKG1vZGUpID0+XG4gICAgICAgIGlpZigoKSA9PiBtb2RlID09PSBgY29udHJvbGxlZGAsIEVNUFRZLCBzb3VyY2UpXG4gICAgICApXG4gICAgKVxuXG4gIGNvbnN0IHVzZXJTY3JvbGwkID0gcnVuT25GcmVlUGFnZVR1cm5Nb2RlT25seSQoZnJvbUV2ZW50KGVsZW1lbnQsIGBzY3JvbGxgKSlcbiAgICAucGlwZShcbiAgICAgIG9ubHlVc2VyU2Nyb2xsRmlsdGVyLFxuICAgICAgc2hhcmUoKSxcbiAgICAgIHRha2VVbnRpbChjb250ZXh0LiQuZGVzdHJveSQpXG4gICAgKVxuXG4gIGNvbnN0IG5hdmlnYXRpb25PblNjcm9sbCQgPSB1c2VyU2Nyb2xsJFxuICAgIC5waXBlKFxuICAgICAgZGVib3VuY2VUaW1lKFNDUk9MTF9GSU5JU0hFRF9ERUJPVU5DRV9USU1FT1VULCBhbmltYXRpb25GcmFtZVNjaGVkdWxlciksXG4gICAgICB3aXRoTGF0ZXN0RnJvbShjdXJyZW50TmF2aWdhdGlvblN1YmplY3QkKSxcbiAgICAgIHN3aXRjaE1hcCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IG5hdmlnYXRpb24gPSBuYXZpZ2F0b3IuZ2V0TW9zdFByZWRvbWluYW50TmF2aWdhdGlvbkZvclBvc2l0aW9uKHsgeDogZWxlbWVudC5zY3JvbGxMZWZ0LCB5OiBlbGVtZW50LnNjcm9sbFRvcCB9KVxuICAgICAgICAvKipcbiAgICAgICAgICogQmVjYXVzZSBzY3JvbGwgbmF2aWdhdGlvbiBpcyBhbHdheXMgZGlmZmVyZW50OiB3ZSBjYW4gc2Nyb2xsIHRocm91Z2ggdGhlIHNhbWUgaXRlbSBidXQgYXQgZGlmZmVyZW50IHByb2dyZXNzXG4gICAgICAgICAqIHdlIGFsd2F5cyByZXR1cm4gc29tZXRoaW5nIGZyb20gdGhlIG9ic2VydmFibGUuIFNvIGZvciBleGFtcGxlIGlmIHdlIGhhdmUgb25seSBvbmUgbG9uZyBoZWlnaHQgaXRlbSAod2VidG9vbilcbiAgICAgICAgICogd2UgYXJlIGFibGUgdG8gdXBkYXRlIHRoZSBnZW5lcmFsIHByb2dyZXNzXG4gICAgICAgICAqL1xuICAgICAgICByZXR1cm4gb2YoeyBwb3NpdGlvbjogbmF2aWdhdGlvbiwgYW5pbWF0ZTogZmFsc2UsIGxhc3RVc2VyRXhwZWN0ZWROYXZpZ2F0aW9uOiB1bmRlZmluZWQgfSlcbiAgICAgIH0pLFxuICAgICAgc2hhcmUoKVxuICAgIClcblxuICBjb25zdCB1c2VyU2Nyb2xsRW5kJCA9IHVzZXJTY3JvbGwkXG4gICAgLnBpcGUoXG4gICAgICBkZWJvdW5jZVRpbWUoU0NST0xMX0ZJTklTSEVEX0RFQk9VTkNFX1RJTUVPVVQsIGFuaW1hdGlvbkZyYW1lU2NoZWR1bGVyKSxcbiAgICAgIHNoYXJlKCksXG4gICAgICB0YWtlVW50aWwoY29udGV4dC4kLmRlc3Ryb3kkKVxuICAgIClcblxuICBjb25zdCBzdGF0ZSQgPSBtZXJnZShcbiAgICB1c2VyU2Nyb2xsJFxuICAgICAgLnBpcGUoXG4gICAgICAgIG1hcCgoKSA9PiBgc3RhcnRgIGFzIGNvbnN0KSxcbiAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKVxuICAgICAgKSxcbiAgICB1c2VyU2Nyb2xsRW5kJFxuICAgICAgLnBpcGUoXG4gICAgICAgIG1hcCgoKSA9PiBgZW5kYCBhcyBjb25zdClcbiAgICAgIClcbiAgKVxuICAgIC5waXBlKFxuICAgICAgc3RhcnRXaXRoKGBlbmRgKVxuICAgIClcblxuICByZXR1cm4ge1xuICAgIGRlc3Ryb3k6ICgpID0+IHsgfSxcbiAgICBhZGp1c3RSZWFkaW5nT2Zmc2V0LFxuICAgICQ6IHtcbiAgICAgIHN0YXRlJCxcbiAgICAgIG5hdmlnYXRpb24kOiBuYXZpZ2F0aW9uT25TY3JvbGwkXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/spine/viewportNavigator/scrollViewportNavigator.ts\n");
|
|
390
|
+
|
|
391
|
+
/***/ }),
|
|
392
|
+
|
|
393
|
+
/***/ "./src/spine/viewportNavigator/viewportNavigator.ts":
|
|
394
|
+
/*!**********************************************************!*\
|
|
395
|
+
!*** ./src/spine/viewportNavigator/viewportNavigator.ts ***!
|
|
396
|
+
\**********************************************************/
|
|
397
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
398
|
+
|
|
399
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createViewportNavigator\": () => (/* binding */ createViewportNavigator)\n/* harmony export */ });\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../report */ \"./src/report.ts\");\n/* harmony import */ var _navigationResolver__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../navigationResolver */ \"./src/spine/navigationResolver.ts\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _scrollViewportNavigator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./scrollViewportNavigator */ \"./src/spine/viewportNavigator/scrollViewportNavigator.ts\");\n/* harmony import */ var _manualViewportNavigator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./manualViewportNavigator */ \"./src/spine/viewportNavigator/manualViewportNavigator.ts\");\n/* harmony import */ var _panViewportNavigator__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./panViewportNavigator */ \"./src/spine/viewportNavigator/panViewportNavigator.ts\");\n\n\n\n\n\n\n\nconst NAMESPACE = `viewportNavigator`;\nconst createViewportNavigator = ({ spineItemManager, context, pagination, element, cfiLocator, locator, hooks$ }) => {\n let currentViewportPositionMemoUnused;\n let currentNavigationPosition = { x: -1, y: 0 };\n const currentNavigationSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_2__.BehaviorSubject(currentNavigationPosition);\n const navigator = (0,_navigationResolver__WEBPACK_IMPORTED_MODULE_1__.createNavigationResolver)({ context, spineItemManager, cfiLocator, locator });\n const adjustNavigationSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_2__.Subject();\n const getCurrentViewportPosition = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`${NAMESPACE} getCurrentViewportPosition`, 1, () => {\n if (currentViewportPositionMemoUnused && (currentViewportPositionMemoUnused === null || currentViewportPositionMemoUnused === void 0 ? void 0 : currentViewportPositionMemoUnused.x) !== (~~(Math.abs(element.getBoundingClientRect().x) * 10) / 10)) {\n }\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n const newValue = { x: element.scrollLeft, y: element.scrollTop };\n currentViewportPositionMemoUnused = newValue;\n return currentViewportPositionMemoUnused;\n }\n const { x, y } = element.getBoundingClientRect();\n const newValue = {\n x: ~~(Math.abs(x) * 10) / 10,\n y: ~~(Math.abs(y) * 10) / 10\n };\n currentViewportPositionMemoUnused = newValue;\n return currentViewportPositionMemoUnused;\n });\n const panViewportNavigator = (0,_panViewportNavigator__WEBPACK_IMPORTED_MODULE_6__.createPanViewportNavigator)({\n context,\n element,\n navigator,\n spineItemManager,\n locator,\n getCurrentViewportPosition,\n currentNavigationSubject$\n });\n const scrollViewportNavigator = (0,_scrollViewportNavigator__WEBPACK_IMPORTED_MODULE_4__.createScrollViewportNavigator)({ context, element, navigator, currentNavigationSubject$ });\n const manualViewportNavigator = (0,_manualViewportNavigator__WEBPACK_IMPORTED_MODULE_5__.createManualViewportNavigator)({ context, element, navigator, currentNavigationSubject$, spineItemManager, locator });\n const viewportNavigators = [scrollViewportNavigator, panViewportNavigator, manualViewportNavigator];\n const viewportNavigatorsSharedState$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(...viewportNavigators.map(({ $: { state$ } }) => state$));\n let lastUserExpectedNavigation;\n const makeItHot = (source$) => {\n source$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.takeUntil)(context.$.destroy$)).subscribe();\n return source$;\n };\n const adjustReadingOffset = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`adjustReadingOffset`, 2, ({ x, y }, hooks) => {\n currentViewportPositionMemoUnused = undefined;\n const isAdjusted = viewportNavigators.reduce((isAdjusted, navigator) => {\n return navigator.adjustReadingOffset({ x, y }) || isAdjusted;\n }, false);\n if (!isAdjusted) {\n if (context.isRTL()) {\n element.style.transform = `translate3d(${x}px, -${y}px, 0)`;\n }\n else {\n element.style.transform = `translate3d(-${x}px, -${y}px, 0)`;\n }\n }\n hooks.forEach(hook => {\n if (hook.name === `onViewportOffsetAdjust`) {\n hook.fn();\n }\n });\n }, { disable: true });\n const adjustNavigation = (spineItem) => {\n const lastCfi = pagination.getInfo().beginCfi;\n let adjustedSpinePosition = currentNavigationPosition;\n const offsetInSpineItem = 0;\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n adjustedSpinePosition = navigator.getMostPredominantNavigationForPosition(getCurrentViewportPosition());\n }\n else if ((lastUserExpectedNavigation === null || lastUserExpectedNavigation === void 0 ? void 0 : lastUserExpectedNavigation.type) === `navigate-from-cfi`) {\n adjustedSpinePosition = navigator.getNavigationForCfi(lastUserExpectedNavigation.data);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-cfi`, `use last cfi`);\n }\n else if ((lastUserExpectedNavigation === null || lastUserExpectedNavigation === void 0 ? void 0 : lastUserExpectedNavigation.type) === `navigate-from-next-item`) {\n adjustedSpinePosition = navigator.getNavigationForLastPage(spineItem);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-next-item`, {});\n }\n else if ((lastUserExpectedNavigation === null || lastUserExpectedNavigation === void 0 ? void 0 : lastUserExpectedNavigation.type) === `navigate-from-previous-item`) {\n adjustedSpinePosition = navigator.getNavigationForPage(0, spineItem);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-previous-item`, {});\n }\n else if ((lastUserExpectedNavigation === null || lastUserExpectedNavigation === void 0 ? void 0 : lastUserExpectedNavigation.type) === `navigate-from-anchor`) {\n const anchor = lastUserExpectedNavigation.data;\n adjustedSpinePosition = navigator.getNavigationForAnchor(anchor, spineItem);\n }\n else if (lastCfi) {\n adjustedSpinePosition = navigator.getNavigationForCfi(lastCfi);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, `use last cfi`);\n }\n else {\n const currentPageIndex = pagination.getInfo().beginPageIndex || 0;\n adjustedSpinePosition = navigator.getNavigationForPage(currentPageIndex, spineItem);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, `use guess strategy`, {});\n }\n const areDifferent = navigator.arePositionsDifferent(adjustedSpinePosition, currentNavigationPosition);\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.log(NAMESPACE, `adjustNavigation`, { areDifferent, offsetInSpineItem, expectedSpineOffset: adjustedSpinePosition, currentNavigationPosition, lastUserExpectedNavigation });\n if (areDifferent) {\n adjustNavigationSubject$.next({ position: adjustedSpinePosition, animate: false });\n }\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.of)({ previousNavigationPosition: currentNavigationPosition, adjustedSpinePosition, areDifferent });\n };\n const layout = () => {\n currentViewportPositionMemoUnused = undefined;\n if (context.getSettings().computedPageTurnMode === `scrollable`) {\n element.style.removeProperty(`transform`);\n element.style.removeProperty(`transition`);\n }\n };\n const navigation$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(panViewportNavigator.$.navigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)((event) => (Object.assign(Object.assign({}, event), { position: { x: event.x, y: event.y, spineItem: event.spineItem }, animation: `snap`, triggeredBy: `manual` })))), manualViewportNavigator.$.navigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)((event) => (Object.assign(Object.assign({}, event), { position: { x: event.x, y: event.y, spineItem: event.spineItem }, animation: event.animate ? `turn` : false, triggeredBy: `manual` })))), adjustNavigationSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)((event) => (Object.assign(Object.assign({}, event), { triggeredBy: `adjust`, animation: event.animate ? `turn` : false })))), scrollViewportNavigator.$.navigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)((event) => (Object.assign(Object.assign({}, event), { triggeredBy: `scroll`, animation: event.animate ? `turn` : false })))))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)((event) => {\n if (`lastUserExpectedNavigation` in event) {\n lastUserExpectedNavigation = event.lastUserExpectedNavigation;\n }\n currentNavigationPosition = event.position;\n currentNavigationSubject$.next(currentNavigationPosition);\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.takeUntil)(context.$.destroy$));\n const navigationWhichRequireManualAdjust$ = navigation$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.filter)(({ triggeredBy }) => {\n if (triggeredBy === `scroll` ||\n (context.getSettings().computedPageTurnMode === `scrollable` && triggeredBy === `adjust`)) {\n return false;\n }\n else {\n return true;\n }\n }));\n const manualAdjust$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(panViewportNavigator.$.moveToSubject$.asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)(event => (Object.assign(Object.assign({}, event), { animation: false })))), navigationWhichRequireManualAdjust$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)(({ animation, position }) => {\n const shouldAnimate = !(!animation ||\n (animation === `turn` && context.getSettings().computedPageTurnAnimation === `none`));\n return {\n type: `manualAdjust`,\n shouldAnimate,\n animation,\n position\n };\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.share)());\n const processManualAdjust$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(manualAdjust$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.startWith)(undefined), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.pairwise)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)(([prevEvent, currentEvent]) => {\n if ((prevEvent === null || prevEvent === void 0 ? void 0 : prevEvent.type) === `manualAdjust` && (currentEvent === null || currentEvent === void 0 ? void 0 : currentEvent.type) !== `manualAdjust`) {\n element.style.setProperty(`transition`, `none`);\n element.style.setProperty(`opacity`, `1`);\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.switchMap)(([, currentEvent]) => {\n if ((currentEvent === null || currentEvent === void 0 ? void 0 : currentEvent.type) !== `manualAdjust`)\n return rxjs__WEBPACK_IMPORTED_MODULE_2__.EMPTY;\n const animationDuration = currentEvent.animation === `snap`\n ? context.getSettings().computedSnapAnimationDuration\n : context.getSettings().computedPageTurnAnimationDuration;\n const pageTurnAnimation = currentEvent.animation === `snap`\n ? `slide`\n : context.getSettings().computedPageTurnAnimation;\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.of)(currentEvent)\n .pipe(currentEvent.shouldAnimate ? (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.delay)(1, rxjs__WEBPACK_IMPORTED_MODULE_2__.animationFrameScheduler) : rxjs__WEBPACK_IMPORTED_MODULE_2__.identity, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)((data) => {\n const noAdjustmentNeeded = false;\n if (data.shouldAnimate && !noAdjustmentNeeded) {\n if (pageTurnAnimation === `fade`) {\n element.style.setProperty(`transition`, `opacity ${animationDuration / 2}ms`);\n element.style.setProperty(`opacity`, `0`);\n }\n else if (currentEvent.animation === `snap` || pageTurnAnimation === `slide`) {\n element.style.setProperty(`transition`, `transform ${animationDuration}ms`);\n element.style.setProperty(`opacity`, `1`);\n }\n }\n else {\n element.style.setProperty(`transition`, `none`);\n element.style.setProperty(`opacity`, `1`);\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.withLatestFrom)(hooks$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)(([data, hooks]) => {\n if (pageTurnAnimation !== `fade`) {\n adjustReadingOffset(data.position, hooks);\n }\n }), currentEvent.shouldAnimate ? (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.delay)(animationDuration / 2, rxjs__WEBPACK_IMPORTED_MODULE_2__.animationFrameScheduler) : rxjs__WEBPACK_IMPORTED_MODULE_2__.identity, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)(([data, hooks]) => {\n if (pageTurnAnimation === `fade`) {\n adjustReadingOffset(data.position, hooks);\n element.style.setProperty(`opacity`, `1`);\n }\n }), currentEvent.shouldAnimate ? (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.delay)(animationDuration / 2, rxjs__WEBPACK_IMPORTED_MODULE_2__.animationFrameScheduler) : rxjs__WEBPACK_IMPORTED_MODULE_2__.identity, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.tap)(([data, hooks]) => {\n if (pageTurnAnimation === `fade`) {\n adjustReadingOffset(data.position, hooks);\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.takeUntil)(viewportNavigatorsSharedState$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.filter)(state => state === `start`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.skip)(1))));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.takeUntil)(context.$.destroy$));\n const adjustmentState$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)((0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(manualAdjust$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)(() => `start`)), (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.merge)(processManualAdjust$)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)(() => `end`)));\n const state$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_2__.combineLatest)([\n ...viewportNavigators.map(({ $: { state$ } }) => state$),\n adjustmentState$\n ])\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.map)((states) => states.every(state => state === `end`) ? `free` : `busy`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.distinctUntilChanged)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_3__.shareReplay)(1), makeItHot);\n const destroy = () => {\n adjustNavigationSubject$.complete();\n viewportNavigators.forEach(navigator => navigator.destroy());\n };\n return {\n destroy,\n layout,\n getCurrentNavigationPosition: () => currentNavigationPosition,\n getCurrentViewportPosition,\n turnLeft: manualViewportNavigator.turnLeft,\n turnRight: manualViewportNavigator.turnRight,\n goToPage: manualViewportNavigator.goToPage,\n goToSpineItem: manualViewportNavigator.goToSpineItem,\n goToUrl: manualViewportNavigator.goToUrl,\n goToCfi: manualViewportNavigator.goToCfi,\n goToPageOfCurrentChapter: manualViewportNavigator.goToPageOfCurrentChapter,\n adjustNavigation,\n moveTo: panViewportNavigator.moveTo,\n getLastUserExpectedNavigation: () => lastUserExpectedNavigation,\n $: {\n state$,\n navigation$\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spine/viewportNavigator/viewportNavigator.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spine/viewportNavigator/viewportNavigator.ts?b33a"],"sourcesContent":["import { Report } from \"../../report\"\nimport { Context } from \"../../context\"\nimport { Pagination } from \"../../pagination\"\nimport { SpineItemManager } from \"../../spineItemManager\"\nimport { createLocationResolver } from \"../locationResolver\"\nimport { createNavigationResolver, ViewportNavigationEntry } from \"../navigationResolver\"\nimport { animationFrameScheduler, BehaviorSubject, combineLatest, EMPTY, identity, merge, Observable, of, Subject } from \"rxjs\"\nimport { SpineItem } from \"../../spineItem/createSpineItem\"\nimport { delay, distinctUntilChanged, filter, map, pairwise, share, shareReplay, startWith, switchMap, takeUntil, tap, withLatestFrom, skip } from \"rxjs/operators\"\nimport { createCfiLocator } from \"../cfiLocator\"\nimport { createScrollViewportNavigator } from \"./scrollViewportNavigator\"\nimport { createManualViewportNavigator } from \"./manualViewportNavigator\"\nimport { Hook } from \"../../types/Hook\"\nimport { createPanViewportNavigator } from \"./panViewportNavigator\"\n\nconst NAMESPACE = `viewportNavigator`\n\nexport const createViewportNavigator = ({ spineItemManager, context, pagination, element, cfiLocator, locator, hooks$ }: {\n  spineItemManager: SpineItemManager,\n  pagination: Pagination,\n  context: Context,\n  element: HTMLElement,\n  cfiLocator: ReturnType<typeof createCfiLocator>\n  locator: ReturnType<typeof createLocationResolver>,\n  hooks$: Observable<Hook[]>\n}) => {\n  let currentViewportPositionMemoUnused: { x: number, y: number } | undefined\n  /**\n   * This position correspond to the current navigation position.\n   * This is always sync with navigation and adjustment but IS NOT necessarily\n   * synced with current viewport. This is because viewport can be animated.\n   * This value may be used to adjust / get current valid info about what should be visible.\n   * This DOES NOT reflect necessarily what is visible for the user at instant T.\n   */\n  let currentNavigationPosition: ViewportNavigationEntry = { x: -1, y: 0 }\n  const currentNavigationSubject$ = new BehaviorSubject(currentNavigationPosition)\n  const navigator = createNavigationResolver({ context, spineItemManager, cfiLocator, locator })\n  const adjustNavigationSubject$ = new Subject<{ position: ViewportNavigationEntry, animate: boolean }>()\n\n  /**\n   * Keep in mind that the viewport position IS NOT necessarily the current navigation position.\n   * Because there could be an animation running the viewport may be late. To retrieve the current position\n   * use the dedicated property.\n   */\n  const getCurrentViewportPosition = Report.measurePerformance(`${NAMESPACE} getCurrentViewportPosition`, 1, () => {\n    if (currentViewportPositionMemoUnused && currentViewportPositionMemoUnused?.x !== (~~(Math.abs(element.getBoundingClientRect().x) * 10) / 10)) {\n      // console.error(`FOOOOO`, currentViewportPositionMemo?.x, ~~(Math.abs(element.getBoundingClientRect().x) * 10) / 10)\n    }\n    // if (currentViewportPositionMemo) return currentViewportPositionMemo\n\n    if (context.getSettings().computedPageTurnMode === `scrollable`) {\n      const newValue = { x: element.scrollLeft, y: element.scrollTop }\n      currentViewportPositionMemoUnused = newValue\n\n      return currentViewportPositionMemoUnused\n    }\n\n    const { x, y } = element.getBoundingClientRect()\n\n    const newValue = {\n      // we want to round to first decimal because it's possible to have half pixel\n      // however browser engine can also gives back x.yyyy based on their precision\n      // @see https://stackoverflow.com/questions/13847053/difference-between-and-math-floor for ~~\n      x: ~~(Math.abs(x) * 10) / 10,\n      y: ~~(Math.abs(y) * 10) / 10\n    }\n    currentViewportPositionMemoUnused = newValue\n\n    return currentViewportPositionMemoUnused\n  })\n\n  const panViewportNavigator = createPanViewportNavigator({\n    context,\n    element,\n    navigator,\n    spineItemManager,\n    locator,\n    getCurrentViewportPosition,\n    currentNavigationSubject$\n  })\n  const scrollViewportNavigator = createScrollViewportNavigator({ context, element, navigator, currentNavigationSubject$ })\n  const manualViewportNavigator = createManualViewportNavigator({ context, element, navigator, currentNavigationSubject$, spineItemManager, locator })\n\n  const viewportNavigators = [scrollViewportNavigator, panViewportNavigator, manualViewportNavigator]\n  const viewportNavigatorsSharedState$ = merge(...viewportNavigators.map(({ $: { state$ } }) => state$))\n\n  let lastUserExpectedNavigation:\n    | undefined\n    // always adjust at the first page\n    | { type: `navigate-from-previous-item` }\n    // always adjust at the last page\n    | { type: `navigate-from-next-item` }\n    // always adjust using this cfi\n    | { type: `navigate-from-cfi`, data: string }\n    // always adjust using this anchor\n    | { type: `navigate-from-anchor`, data: string }\n\n  const makeItHot = <T>(source$: Observable<T>) => {\n    source$.pipe(takeUntil(context.$.destroy$)).subscribe()\n\n    return source$\n  }\n\n  /**\n   * @see https://stackoverflow.com/questions/22111256/translate3d-vs-translate-performance\n   * for remark about flicker / fonts smoothing\n   */\n  const adjustReadingOffset = Report.measurePerformance(`adjustReadingOffset`, 2, ({ x, y }: { x: number, y: number }, hooks: Hook[]) => {\n    currentViewportPositionMemoUnused = undefined\n\n    const isAdjusted = viewportNavigators.reduce((isAdjusted, navigator) => {\n      return navigator.adjustReadingOffset({ x, y }) || isAdjusted\n    }, false)\n\n    if (!isAdjusted) {\n      if (context.isRTL()) {\n        element.style.transform = `translate3d(${x}px, -${y}px, 0)`\n      } else {\n        element.style.transform = `translate3d(-${x}px, -${y}px, 0)`\n      }\n    }\n\n    hooks.forEach(hook => {\n      if (hook.name === `onViewportOffsetAdjust`) {\n        hook.fn()\n      }\n    })\n  }, { disable: true })\n\n  /**\n   * Verify that current offset is within the current reading item and is at\n   * desired pagination.\n   * If it is not, then we adjust the offset.\n   * The offset could be wrong in the case of there has been re-layout.\n   * In this case we always need to make sure to be synchronized with pagination.\n   * Pagination is in theory always right because when we move the offset we directly update\n   * the pagination. It's after, when re-layout happens for various reason that the page can be at\n   * the wrong offset\n   * @todo this is being called a lot, try to optimize\n   */\n  const adjustNavigation = (spineItem: SpineItem) => {\n    // @todo we should get the cfi of focused item, if focused item is not inside pagination then go to spine index\n    const lastCfi = pagination.getInfo().beginCfi\n    let adjustedSpinePosition = currentNavigationPosition\n    const offsetInSpineItem = 0\n\n    if (context.getSettings().computedPageTurnMode === `scrollable`) {\n      adjustedSpinePosition = navigator.getMostPredominantNavigationForPosition(getCurrentViewportPosition())\n    } else if (lastUserExpectedNavigation?.type === `navigate-from-cfi`) {\n      /**\n     * When `navigate-from-cfi` we always try to retrieve offset from cfi node and navigate\n     * to there\n     */\n      adjustedSpinePosition = navigator.getNavigationForCfi(lastUserExpectedNavigation.data)\n      Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-cfi`, `use last cfi`)\n    } else if (lastUserExpectedNavigation?.type === `navigate-from-next-item`) {\n      /**\n       * When `navigate-from-next-item` we always try to get the offset of the last page, that way\n       * we ensure reader is always redirected to last page\n       */\n      adjustedSpinePosition = navigator.getNavigationForLastPage(spineItem)\n      Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-next-item`, {})\n    } else if (lastUserExpectedNavigation?.type === `navigate-from-previous-item`) {\n      /**\n       * When `navigate-from-previous-item'`\n       * we always try stay on the first page of the item\n       */\n      adjustedSpinePosition = navigator.getNavigationForPage(0, spineItem)\n      Report.log(NAMESPACE, `adjustNavigation`, `navigate-from-previous-item`, {})\n    } else if (lastUserExpectedNavigation?.type === `navigate-from-anchor`) {\n      /**\n       * When `navigate-from-anchor` we just stay on the current reading item and try to get\n       * the offset of that anchor.\n       */\n      const anchor = lastUserExpectedNavigation.data\n      adjustedSpinePosition = navigator.getNavigationForAnchor(anchor, spineItem)\n    } else if (lastCfi) {\n      // @todo, ignore cfi if the current focus item\n      /**\n       * When there is no last navigation then we first look for any existing CFI. If there is a cfi we try to retrieve\n       * the offset and navigate the user to it\n       * @todo handle vertical writing, we are always redirected to page 1 currently\n       */\n      adjustedSpinePosition = navigator.getNavigationForCfi(lastCfi)\n      Report.log(NAMESPACE, `adjustNavigation`, `use last cfi`)\n    } else {\n      // @todo we should get the page index of the focused item, if focus item is not inside pagination then go to spine index\n      /**\n       * Last resort case, there is no CFI so we check the current page and try to navigate to the closest one\n       */\n      // @todo get x of first visible element and try to get the page for this element\n      // using the last page is not accurate since we could have less pages\n      const currentPageIndex = pagination.getInfo().beginPageIndex || 0\n      adjustedSpinePosition = navigator.getNavigationForPage(currentPageIndex, spineItem)\n      Report.log(NAMESPACE, `adjustNavigation`, `use guess strategy`, {})\n    }\n\n    const areDifferent = navigator.arePositionsDifferent(adjustedSpinePosition, currentNavigationPosition)\n\n    Report.log(NAMESPACE, `adjustNavigation`, { areDifferent, offsetInSpineItem, expectedSpineOffset: adjustedSpinePosition, currentNavigationPosition, lastUserExpectedNavigation })\n\n    if (areDifferent) {\n      adjustNavigationSubject$.next({ position: adjustedSpinePosition, animate: false })\n    }\n\n    return of({ previousNavigationPosition: currentNavigationPosition, adjustedSpinePosition, areDifferent })\n  }\n\n  const layout = () => {\n    currentViewportPositionMemoUnused = undefined\n\n    if (context.getSettings().computedPageTurnMode === `scrollable`) {\n      element.style.removeProperty(`transform`)\n      element.style.removeProperty(`transition`)\n    }\n  }\n\n  const navigation$: Observable<{\n    position: { x: number, y: number, spineItem?: SpineItem },\n    triggeredBy: `manual` | `adjust` | `scroll`,\n    animation: false | `turn` | `snap`\n  }> = merge(\n    panViewportNavigator.$.navigation$\n      .pipe(\n        map((event) => ({\n          ...event,\n          position: { x: event.x, y: event.y, spineItem: event.spineItem },\n          animation: `snap` as const,\n          triggeredBy: `manual` as const\n        }))\n      ),\n    manualViewportNavigator.$.navigation$\n      .pipe(\n        map((event) => ({\n          ...event,\n          position: { x: event.x, y: event.y, spineItem: event.spineItem },\n          animation: event.animate ? `turn` as const : false as false,\n          triggeredBy: `manual` as const\n        }))\n      ),\n    adjustNavigationSubject$\n      .pipe(\n        map((event) => ({\n          ...event,\n          triggeredBy: `adjust` as const,\n          animation: event.animate ? `turn` as const : false as false\n        }))\n      ),\n    scrollViewportNavigator.$.navigation$\n      .pipe(\n        map((event) => ({\n          ...event,\n          triggeredBy: `scroll` as const,\n          animation: event.animate ? `turn` as const : false as false\n        }))\n      )\n  )\n    .pipe(\n      tap((event) => {\n        if (`lastUserExpectedNavigation` in event) {\n          lastUserExpectedNavigation = event.lastUserExpectedNavigation\n        }\n        currentNavigationPosition = event.position\n        currentNavigationSubject$.next(currentNavigationPosition)\n      }),\n      share(),\n      takeUntil(context.$.destroy$)\n    )\n\n  /**\n   * Typically all manual navigation (user turn, user end of pan, etc).\n   * We try to filter out all navigation that are asynchrone such as scrolling.\n   * This is because we do not want to trigger adjust for them since they already adjust\n   * the viewport on their own.\n   */\n  const navigationWhichRequireManualAdjust$ = navigation$\n    .pipe(\n      filter(({ triggeredBy }) => {\n        if (\n          triggeredBy === `scroll` ||\n          (context.getSettings().computedPageTurnMode === `scrollable` && triggeredBy === `adjust`)\n        ) {\n          return false\n        } else {\n          return true\n        }\n      })\n    )\n\n  const manualAdjust$ = merge(\n    panViewportNavigator.$.moveToSubject$.asObservable()\n      .pipe(\n        map(event => ({ ...event, animation: false as false }))\n      ),\n    navigationWhichRequireManualAdjust$\n  )\n    .pipe(\n      map(({ animation, position }) => {\n        const shouldAnimate =\n          !(\n            !animation ||\n            (animation === `turn` && context.getSettings().computedPageTurnAnimation === `none`)\n          )\n\n        return {\n          type: `manualAdjust` as const,\n          shouldAnimate,\n          animation,\n          position\n        }\n      }),\n      share()\n    )\n\n  const processManualAdjust$ = merge(\n    manualAdjust$\n  )\n    .pipe(\n      startWith(undefined),\n      pairwise(),\n      tap(([prevEvent, currentEvent]) => {\n        // cleanup potential previous manual adjust\n        if (prevEvent?.type === `manualAdjust` && currentEvent?.type !== `manualAdjust`) {\n          element.style.setProperty(`transition`, `none`)\n          element.style.setProperty(`opacity`, `1`)\n        }\n      }),\n      switchMap(([, currentEvent]) => {\n        if (currentEvent?.type !== `manualAdjust`) return EMPTY\n\n        const animationDuration = currentEvent.animation === `snap`\n          ? context.getSettings().computedSnapAnimationDuration\n          : context.getSettings().computedPageTurnAnimationDuration\n        const pageTurnAnimation = currentEvent.animation === `snap`\n          ? `slide` as const\n          : context.getSettings().computedPageTurnAnimation\n\n        return of(currentEvent)\n          .pipe(\n            /**\n             * @important\n             * Optimization:\n             * When the adjustment does not need animation it means we want to be there as fast as possible\n             * One example is when we adjust position after layout. In this case we don't want to have flicker or see\n             * anything for x ms while we effectively adjust. We want it to be immediate.\n             * However when user is repeatedly turning page, we can improve smoothness by delaying a bit the adjustment\n             */\n            currentEvent.shouldAnimate ? delay(1, animationFrameScheduler) : identity,\n            tap((data) => {\n              // const noAdjustmentNeeded = !areNavigationDifferent(data.position, getCurrentViewportPosition())\n              const noAdjustmentNeeded = false\n\n              if (data.shouldAnimate && !noAdjustmentNeeded) {\n                if (pageTurnAnimation === `fade`) {\n                  element.style.setProperty(`transition`, `opacity ${animationDuration / 2}ms`)\n                  element.style.setProperty(`opacity`, `0`)\n                } else if (currentEvent.animation === `snap` || pageTurnAnimation === `slide`) {\n                  element.style.setProperty(`transition`, `transform ${animationDuration}ms`)\n                  element.style.setProperty(`opacity`, `1`)\n                }\n              } else {\n                element.style.setProperty(`transition`, `none`)\n                element.style.setProperty(`opacity`, `1`)\n              }\n            }),\n            /**\n             * @important\n             * We always need to adjust the reading offset. Even if the current viewport value\n             * is the same as the payload position. This is because an already running animation could\n             * be active, meaning the viewport is still adjusting itself (after animation duration). So we\n             * need to adjust to anchor to the payload position. This is because we use viewport computed position,\n             * not the value set by `setProperty`\n             */\n            withLatestFrom(hooks$),\n            tap(([data, hooks]) => {\n              if (pageTurnAnimation !== `fade`) {\n                adjustReadingOffset(data.position, hooks)\n              }\n            }),\n            currentEvent.shouldAnimate ? delay(animationDuration / 2, animationFrameScheduler) : identity,\n            tap(([data, hooks]) => {\n              if (pageTurnAnimation === `fade`) {\n                adjustReadingOffset(data.position, hooks)\n                element.style.setProperty(`opacity`, `1`)\n              }\n            }),\n            currentEvent.shouldAnimate ? delay(animationDuration / 2, animationFrameScheduler) : identity,\n            tap(([data, hooks]) => {\n              if (pageTurnAnimation === `fade`) {\n                adjustReadingOffset(data.position, hooks)\n              }\n            }),\n            takeUntil(\n              viewportNavigatorsSharedState$.pipe(\n                filter(state => state === `start`),\n                skip(1)\n              )\n            )\n          )\n      }),\n      share(),\n      takeUntil(context.$.destroy$)\n    )\n\n  /**\n   * Observe the state of adjustment.\n   * This is used to know whether the viewport is being adjusted by whatever means.\n   */\n  const adjustmentState$ = merge(\n    merge(manualAdjust$)\n      .pipe(\n        map(() => `start` as const)\n      ),\n    merge(\n      processManualAdjust$\n    )\n      .pipe(\n        map(() => `end` as const)\n      )\n  )\n\n  /**\n   * Observe the viewport state.\n   * Some actions such as adjustment, user pan moving, etc set the viewport as busy because they require\n   * high responsiveness in order to avoid stuttering or fps drop. This observable let you know when is\n   * a good time to perform heavy operation.\n   *\n   * @returns\n   * free means the viewport is not moving so it's safe to do computation\n   * busy means the viewport is either controlled or animated, etc.\n   */\n  const state$ = combineLatest([\n    ...viewportNavigators.map(({ $: { state$ } }) => state$),\n    adjustmentState$\n  ])\n    .pipe(\n      map((states) => states.every(state => state === `end`) ? `free` : `busy`),\n      distinctUntilChanged(),\n      shareReplay(1),\n      /**\n       * @important\n       * Since state$ is being updated from navigation$ and other exported streams we need it to be\n       * hot so it always have the correct value no matter when someone subscribe later.\n       * We cannot wait for the cold stream to start after a navigation already happened for example.\n       */\n      makeItHot\n    )\n\n  const destroy = () => {\n    adjustNavigationSubject$.complete()\n    viewportNavigators.forEach(navigator => navigator.destroy())\n  }\n\n  return {\n    destroy,\n    layout,\n    getCurrentNavigationPosition: () => currentNavigationPosition,\n    getCurrentViewportPosition,\n    turnLeft: manualViewportNavigator.turnLeft,\n    turnRight: manualViewportNavigator.turnRight,\n    goToPage: manualViewportNavigator.goToPage,\n    goToSpineItem: manualViewportNavigator.goToSpineItem,\n    goToUrl: manualViewportNavigator.goToUrl,\n    goToCfi: manualViewportNavigator.goToCfi,\n    goToPageOfCurrentChapter: manualViewportNavigator.goToPageOfCurrentChapter,\n    adjustNavigation,\n    moveTo: panViewportNavigator.moveTo,\n    getLastUserExpectedNavigation: () => lastUserExpectedNavigation,\n    $: {\n      state$,\n      navigation$\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spine/viewportNavigator/viewportNavigator.ts\n");
|
|
400
|
+
|
|
401
|
+
/***/ }),
|
|
402
|
+
|
|
403
|
+
/***/ "./src/spineItem/commonSpineItem.ts":
|
|
404
|
+
/*!******************************************!*\
|
|
405
|
+
!*** ./src/spineItem/commonSpineItem.ts ***!
|
|
406
|
+
\******************************************/
|
|
407
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
408
|
+
|
|
409
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createCommonSpineItem\": () => (/* binding */ createCommonSpineItem)\n/* harmony export */ });\n/* harmony import */ var _frameItem_frameItem__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frameItem/frameItem */ \"./src/spineItem/frameItem/frameItem.ts\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _trackers__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./trackers */ \"./src/spineItem/trackers.ts\");\n/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/dom */ \"./src/utils/dom.ts\");\n/* harmony import */ var _frames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../frames */ \"./src/frames.ts\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_5__);\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\nconst pointerEvents = [\n `pointercancel`,\n `pointerdown`,\n `pointerenter`,\n `pointerleave`,\n `pointermove`,\n `pointerout`,\n `pointerover`,\n `pointerup`\n];\nconst mouseEvents = [\n `mousedown`,\n `mouseup`,\n `mouseenter`,\n `mouseleave`,\n `mousemove`,\n `mouseout`,\n `mouseover`\n];\nconst passthroughEvents = [...pointerEvents, ...mouseEvents];\nconst createCommonSpineItem = ({ item, context, parentElement, iframeEventBridgeElement, hooks$, viewportState$ }) => {\n var _a;\n const destroySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_1__.Subject();\n const isReflowable = false;\n const contentLayoutChangeSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_1__.Subject();\n const containerElement = createContainerElement(parentElement, item, hooks$);\n const loadingElement = createLoadingElement(parentElement, item, context);\n const overlayElement = createOverlayElement(parentElement, item);\n const fingerTracker = (0,_trackers__WEBPACK_IMPORTED_MODULE_2__.createFingerTracker)();\n const selectionTracker = (0,_trackers__WEBPACK_IMPORTED_MODULE_2__.createSelectionTracker)();\n const frameHooks = createFrameHooks(iframeEventBridgeElement, fingerTracker, selectionTracker);\n const spineItemFrame = (0,_frameItem_frameItem__WEBPACK_IMPORTED_MODULE_0__.createFrameItem)({\n parent: containerElement,\n item,\n context,\n fetchResource: (_a = context.getLoadOptions()) === null || _a === void 0 ? void 0 : _a.fetchResource,\n hooks$: hooks$.asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.map)(hooks => [...hooks, ...frameHooks])),\n viewportState$\n });\n containerElement.appendChild(loadingElement);\n containerElement.appendChild(overlayElement);\n parentElement.appendChild(containerElement);\n let memoizedElementDimensions;\n const getElementDimensions = () => {\n if (memoizedElementDimensions) {\n return memoizedElementDimensions;\n }\n const rect = containerElement.getBoundingClientRect();\n const normalizedValues = Object.assign(Object.assign({}, rect), { width: Math.round(rect.width * 10) / 10, height: Math.round(rect.height * 10) / 10 });\n memoizedElementDimensions = normalizedValues;\n return memoizedElementDimensions;\n };\n const isImageType = () => { var _a; return (_a = item.mediaType) === null || _a === void 0 ? void 0 : _a.startsWith(`image/`); };\n const injectStyle = (cssText) => {\n var _a, _b;\n (_a = spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.removeStyle(`prose-reader-css`);\n (_b = spineItemFrame.getManipulableFrame()) === null || _b === void 0 ? void 0 : _b.addStyle(`prose-reader-css`, cssText);\n };\n const adjustPositionOfElement = ({ right, left, top }) => {\n if (right !== undefined) {\n containerElement.style.right = `${right}px`;\n }\n else {\n containerElement.style.removeProperty(`right`);\n }\n if (left !== undefined) {\n containerElement.style.left = `${left}px`;\n }\n else {\n containerElement.style.removeProperty(`left`);\n }\n if (top !== undefined) {\n containerElement.style.top = `${top}px`;\n }\n else {\n containerElement.style.removeProperty(`top`);\n }\n };\n const getViewPortInformation = () => {\n var _a;\n const { width: pageWidth, height: pageHeight } = context.getPageSize();\n const viewportDimensions = spineItemFrame.getViewportDimensions();\n const frameElement = (_a = spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame;\n if (containerElement && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentDocument) && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentWindow) && viewportDimensions) {\n const computedWidthScale = pageWidth / viewportDimensions.width;\n const computedScale = Math.min(computedWidthScale, pageHeight / viewportDimensions.height);\n return { computedScale, computedWidthScale, viewportDimensions };\n }\n return Object.assign({ computedScale: 1, computedWidthScale: 1 }, viewportDimensions);\n };\n const loadContent = () => spineItemFrame.load();\n const unloadContent = () => spineItemFrame.unload();\n const getBoundingRectOfElementFromSelector = (selector) => {\n var _a, _b, _c, _d, _e;\n const frame = (_a = spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame;\n if (frame && selector) {\n if (selector.startsWith(`#`)) {\n return (_c = (_b = frame.contentDocument) === null || _b === void 0 ? void 0 : _b.getElementById(selector.replace(`#`, ``))) === null || _c === void 0 ? void 0 : _c.getBoundingClientRect();\n }\n return (_e = (_d = frame.contentDocument) === null || _d === void 0 ? void 0 : _d.querySelector(selector)) === null || _e === void 0 ? void 0 : _e.getBoundingClientRect();\n }\n };\n const setLayoutDirty = () => {\n memoizedElementDimensions = undefined;\n };\n const layout = ({ height, width }) => {\n containerElement.style.width = `${width}px`;\n containerElement.style.height = `${height}px`;\n loadingElement.style.setProperty(`max-width`, `${context.getVisibleAreaRect().width}px`);\n setLayoutDirty();\n };\n const translateFramePositionIntoPage = (position) => {\n var _a;\n const { left = 0, top = 0 } = ((_a = spineItemFrame.getFrameElement()) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect()) || {};\n const { computedScale = 1 } = getViewPortInformation() || {};\n const adjustedX = position.clientX * computedScale + left;\n const adjustedY = position.clientY * computedScale + top;\n return {\n clientX: adjustedX,\n clientY: adjustedY\n };\n };\n const getResource = () => __awaiter(void 0, void 0, void 0, function* () {\n const loadOptions = context.getLoadOptions();\n const lastFetch = (_) => {\n if (loadOptions === null || loadOptions === void 0 ? void 0 : loadOptions.fetchResource) {\n return loadOptions.fetchResource(item);\n }\n return fetch(item.href);\n };\n const finalFetch = hooks$.getValue().reduce((acc, hook) => {\n if (hook.name === `item.onGetResource`) {\n return hook.fn(acc);\n }\n return acc;\n }, lastFetch);\n return yield finalFetch(item);\n });\n const manipulateSpineItem = (cb) => {\n const manipulableFrame = spineItemFrame.getManipulableFrame();\n if (manipulableFrame)\n return cb(Object.assign(Object.assign({}, manipulableFrame), { container: containerElement, loadingElement, item, overlayElement }));\n return cb({ container: containerElement, loadingElement, item, frame: undefined, removeStyle: () => { }, addStyle: () => { }, overlayElement });\n };\n const executeOnLayoutBeforeMeasurmentHook = (options) => hooks$.getValue().forEach(hook => {\n if (hook.name === `item.onLayoutBeforeMeasurment`) {\n hook.fn(Object.assign({ frame: spineItemFrame, container: containerElement, item,\n isImageType }, options));\n }\n });\n spineItemFrame.$.contentLayoutChange$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.withLatestFrom)(spineItemFrame.$.isReady$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.takeUntil)(destroySubject$))\n .subscribe(([data, isReady]) => {\n if (data.isFirstLayout && isReady) {\n loadingElement.style.visibility = `hidden`;\n }\n contentLayoutChangeSubject$.next({ isFirstLayout: data.isFirstLayout, isReady });\n });\n spineItemFrame.$.unload$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.tap)(() => {\n if (loadingElement && loadingElement.style.visibility !== `visible`) {\n loadingElement.style.visibility = `visible`;\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_5__.takeUntil)(destroySubject$))\n .subscribe();\n return {\n load: () => {\n setLayoutDirty();\n },\n layout,\n adjustPositionOfElement,\n createLoadingElement,\n getElementDimensions,\n getHtmlFromResource: spineItemFrame.getHtmlFromResource,\n getResource,\n translateFramePositionIntoPage,\n setLayoutDirty,\n injectStyle,\n loadContent,\n unloadContent,\n spineItemFrame,\n element: containerElement,\n loadingElement,\n isReflowable,\n getBoundingRectOfElementFromSelector,\n getViewPortInformation,\n isImageType,\n isReady: spineItemFrame.getIsReady,\n destroy: () => {\n destroySubject$.next();\n loadingElement.onload = () => { };\n loadingElement.remove();\n containerElement.remove();\n spineItemFrame === null || spineItemFrame === void 0 ? void 0 : spineItemFrame.destroy();\n fingerTracker.destroy();\n selectionTracker.destroy();\n destroySubject$.complete();\n },\n isUsingVerticalWriting: () => { var _a; return (_a = spineItemFrame.getWritingMode()) === null || _a === void 0 ? void 0 : _a.startsWith(`vertical`); },\n getReadingDirection: () => {\n return spineItemFrame.getReadingDirection() || context.getReadingDirection();\n },\n manipulateSpineItem,\n executeOnLayoutBeforeMeasurmentHook,\n selectionTracker,\n fingerTracker,\n $: {\n contentLayoutChangeSubject$: contentLayoutChangeSubject$.asObservable(),\n loaded$: spineItemFrame.$.loaded$\n }\n };\n};\nconst createContainerElement = (containerElement, item, hooks$) => {\n const element = containerElement.ownerDocument.createElement(`div`);\n element.classList.add(`spineItem`);\n element.classList.add(`spineItem-${item.renditionLayout}`);\n element.style.cssText = `\n position: absolute;\n overflow: hidden;\n `;\n return hooks$.getValue().reduce((element, hook) => {\n if (hook.name === `item.onBeforeContainerCreated`) {\n return hook.fn(element);\n }\n return element;\n }, element);\n};\nconst createLoadingElement = (containerElement, item, context) => {\n const loadingElement = containerElement.ownerDocument.createElement(`div`);\n loadingElement.classList.add(`loading`);\n loadingElement.style.cssText = `\n height: 100%;\n width: 100%;\n max-width: ${context.getVisibleAreaRect().width}px;\n text-align: center;\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n position: absolute;\n left: 0;\n top: 0;\n background-color: white;\n `;\n const logoElement = containerElement.ownerDocument.createElement(`div`);\n logoElement.innerText = `prose`;\n logoElement.style.cssText = `\n font-size: 4em;\n color: #cacaca;\n `;\n const detailsElement = containerElement.ownerDocument.createElement(`div`);\n detailsElement.innerText = `loading ${item.id}`;\n detailsElement.style.cssText = `\n font-size: 1.2em;\n color: rgb(202, 202, 202);\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n max-width: 300px;\n width: 80%;\n `;\n loadingElement.appendChild(logoElement);\n loadingElement.appendChild(detailsElement);\n return loadingElement;\n};\nconst createOverlayElement = (containerElement, item) => {\n const element = containerElement.ownerDocument.createElement(`div`);\n element.classList.add(`spineItemOverlay`);\n element.classList.add(`spineItemOverlay-${item.renditionLayout}`);\n element.style.cssText = `\n position: absolute;\n width: 100%;\n height: 100%;\n pointer-events: none;\n background-color: transparent;\n `;\n return element;\n};\nconst createFrameHooks = (iframeEventBridgeElement, fingerTracker, selectionTracker) => {\n return [\n {\n name: `item.onLoad`,\n fn: ({ frame }) => {\n const unregister = passthroughEvents.map(event => {\n var _a;\n const listener = (e) => {\n let convertedEvent = e;\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_3__.isPointerEvent)(e)) {\n convertedEvent = new PointerEvent(e.type, e);\n }\n if ((0,_utils_dom__WEBPACK_IMPORTED_MODULE_3__.isMouseEvent)(e)) {\n convertedEvent = new MouseEvent(e.type, e);\n }\n if (convertedEvent !== e) {\n (0,_frames__WEBPACK_IMPORTED_MODULE_4__.attachOriginalFrameEventToDocumentEvent)(convertedEvent, e);\n iframeEventBridgeElement.dispatchEvent(convertedEvent);\n }\n };\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.addEventListener(event, listener);\n return () => {\n var _a;\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.removeEventListener(event, listener);\n };\n });\n selectionTracker.track(frame);\n fingerTracker.track(frame);\n return () => {\n unregister.forEach(cb => cb());\n };\n }\n }\n ];\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/commonSpineItem.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItem/commonSpineItem.ts?84d7"],"sourcesContent":["import { Context } from \"../context\"\nimport { createFrameItem, SpineItemFrame } from \"./frameItem/frameItem\"\nimport { Manifest } from \"../types\"\nimport { BehaviorSubject, Observable, Subject } from \"rxjs\"\nimport { createFingerTracker, createSelectionTracker } from \"./trackers\"\nimport { isMouseEvent, isPointerEvent } from \"../utils/dom\"\nimport { attachOriginalFrameEventToDocumentEvent } from \"../frames\"\nimport { Hook } from \"../types/Hook\"\nimport { map, takeUntil, tap, withLatestFrom } from \"rxjs/operators\"\nimport { createFrameManipulator } from \"./frameItem/createFrameManipulator\"\n\nconst pointerEvents = [\n  `pointercancel` as const,\n  `pointerdown` as const,\n  `pointerenter` as const,\n  `pointerleave` as const,\n  `pointermove` as const,\n  `pointerout` as const,\n  `pointerover` as const,\n  `pointerup` as const\n]\n\nconst mouseEvents = [\n  `mousedown` as const,\n  `mouseup` as const,\n  `mouseenter` as const,\n  `mouseleave` as const,\n  `mousemove` as const,\n  `mouseout` as const,\n  `mouseover` as const\n]\n\nconst passthroughEvents = [...pointerEvents, ...mouseEvents]\n\nexport const createCommonSpineItem = ({ item, context, parentElement, iframeEventBridgeElement, hooks$, viewportState$ }: {\n  item: Manifest[`spineItems`][number],\n  parentElement: HTMLElement,\n  iframeEventBridgeElement: HTMLElement,\n  context: Context,\n  hooks$: BehaviorSubject<Hook[]>,\n  viewportState$: Observable<`free` | `busy`>\n}) => {\n  const destroySubject$ = new Subject<void>()\n  const isReflowable = false\n  const contentLayoutChangeSubject$ = new Subject<{ isFirstLayout: boolean, isReady: boolean }>()\n  const containerElement = createContainerElement(parentElement, item, hooks$)\n  const loadingElement = createLoadingElement(parentElement, item, context)\n  const overlayElement = createOverlayElement(parentElement, item)\n  const fingerTracker = createFingerTracker()\n  const selectionTracker = createSelectionTracker()\n  const frameHooks = createFrameHooks(iframeEventBridgeElement, fingerTracker, selectionTracker)\n  const spineItemFrame = createFrameItem({\n    parent: containerElement,\n    item,\n    context,\n    fetchResource: context.getLoadOptions()?.fetchResource,\n    hooks$: hooks$.asObservable()\n      .pipe(\n        map(hooks => [...hooks, ...frameHooks])\n      ),\n    viewportState$\n  })\n  // let layoutInformation: { blankPagePosition: `before` | `after` | `none`, minimumWidth: number } = { blankPagePosition: `none`, minimumWidth: context.getPageSize().width }\n\n  containerElement.appendChild(loadingElement)\n  containerElement.appendChild(overlayElement)\n  parentElement.appendChild(containerElement)\n\n  // Do not memoize x,y,top,left as they change relatively to the viewport all the time\n  let memoizedElementDimensions: { width: number, height: number } | undefined\n\n  // @todo use spine item manager global layout reference if possible\n  // @todo getAbsolutePositionOf (for width and height)\n  const getElementDimensions = () => {\n    if (memoizedElementDimensions) {\n      return memoizedElementDimensions\n    }\n\n    const rect = containerElement.getBoundingClientRect()\n    const normalizedValues = {\n      ...rect,\n      // we want to round to first decimal because it's possible to have half pixel\n      // however browser engine can also gives back x.yyyy based on their precision\n      width: Math.round(rect.width * 10) / 10,\n      height: Math.round(rect.height * 10) / 10\n    }\n\n    memoizedElementDimensions = normalizedValues\n\n    return memoizedElementDimensions\n  }\n\n  /**\n   * Detect the type of resource (independently of rendition flow).\n   * If an image is detected for reflowable for example we may want to display\n   * things accordingly.\n   */\n  const isImageType = () => item.mediaType?.startsWith(`image/`)\n\n  const injectStyle = (cssText: string) => {\n    spineItemFrame.getManipulableFrame()?.removeStyle(`prose-reader-css`)\n    spineItemFrame.getManipulableFrame()?.addStyle(`prose-reader-css`, cssText)\n  }\n\n  const adjustPositionOfElement = ({ right, left, top }: { right?: number, left?: number, top?: number }) => {\n    if (right !== undefined) {\n      containerElement.style.right = `${right}px`\n    } else {\n      containerElement.style.removeProperty(`right`)\n    }\n    if (left !== undefined) {\n      containerElement.style.left = `${left}px`\n    } else {\n      containerElement.style.removeProperty(`left`)\n    }\n    if (top !== undefined) {\n      containerElement.style.top = `${top}px`\n    } else {\n      containerElement.style.removeProperty(`top`)\n    }\n  }\n\n  const getViewPortInformation = () => {\n    const { width: pageWidth, height: pageHeight } = context.getPageSize()\n    const viewportDimensions = spineItemFrame.getViewportDimensions()\n    const frameElement = spineItemFrame.getManipulableFrame()?.frame\n    if (containerElement && frameElement?.contentDocument && frameElement?.contentWindow && viewportDimensions) {\n      const computedWidthScale = pageWidth / viewportDimensions.width\n      const computedScale = Math.min(computedWidthScale, pageHeight / viewportDimensions.height)\n\n      return { computedScale, computedWidthScale, viewportDimensions }\n    }\n\n    return { computedScale: 1, computedWidthScale: 1, ...viewportDimensions }\n  }\n\n  const loadContent = () => spineItemFrame.load()\n\n  const unloadContent = () => spineItemFrame.unload()\n\n  const getBoundingRectOfElementFromSelector = (selector: string) => {\n    const frame = spineItemFrame.getManipulableFrame()?.frame\n    if (frame && selector) {\n      if (selector.startsWith(`#`)) {\n        return frame.contentDocument?.getElementById(selector.replace(`#`, ``))?.getBoundingClientRect()\n      }\n      return frame.contentDocument?.querySelector(selector)?.getBoundingClientRect()\n    }\n  }\n\n  const setLayoutDirty = () => {\n    memoizedElementDimensions = undefined\n  }\n\n  // const layout = ({ height, width, ...newLayoutInformation }: { height: number, width: number } & typeof layoutInformation) => {\n  const layout = ({ height, width }: { height: number, width: number }) => {\n    containerElement.style.width = `${width}px`\n    containerElement.style.height = `${height}px`\n\n    loadingElement.style.setProperty(`max-width`, `${context.getVisibleAreaRect().width}px`)\n\n    // layoutInformation = newLayoutInformation\n\n    setLayoutDirty()\n\n    // hooks$.getValue().forEach(hook => {\n    //   if (hook.name === `item.onLayout`) {\n    //     hook.fn({ frame: spineItemFrame.getFrameElement(), container: containerElement, loadingElement, item, overlayElement })\n    //   }\n    // })\n  }\n\n  const translateFramePositionIntoPage = (position: { clientX: number, clientY: number }) => {\n    // Here we use getBoundingClientRect meaning we will get relative value for left / top based on current\n    // window (viewport). This is handy because we can easily get the translated x/y without any extra information\n    // such as page index, etc. However this might be a bit less performance to request heavily getBoundingClientRect\n    const { left = 0, top = 0 } = spineItemFrame.getFrameElement()?.getBoundingClientRect() || {}\n    const { computedScale = 1 } = getViewPortInformation() || {}\n    const adjustedX = position.clientX * computedScale + left\n    const adjustedY = position.clientY * computedScale + top\n\n    return {\n      clientX: adjustedX,\n      clientY: adjustedY\n    }\n  }\n\n  const getResource = async () => {\n    const loadOptions = context.getLoadOptions()\n    const lastFetch = (_: Manifest[`spineItems`][number]) => {\n      if (loadOptions?.fetchResource) {\n        return loadOptions.fetchResource(item)\n      }\n\n      return fetch(item.href)\n    }\n\n    const finalFetch = hooks$.getValue().reduce((acc, hook) => {\n      if (hook.name === `item.onGetResource`) {\n        return hook.fn(acc)\n      }\n\n      return acc\n    }, lastFetch)\n\n    return await finalFetch(item)\n  }\n\n  const manipulateSpineItem = (\n    cb: (options: {\n      container: HTMLElement,\n      loadingElement: HTMLElement,\n      item: Manifest[`spineItems`][number],\n      overlayElement: HTMLDivElement,\n    } & (ReturnType<typeof createFrameManipulator> | { frame: undefined, removeStyle: (id: string) => void, addStyle: (id: string, style: string) => void })) => boolean\n  ) => {\n    const manipulableFrame = spineItemFrame.getManipulableFrame()\n\n    if (manipulableFrame) return cb({ ...manipulableFrame, container: containerElement, loadingElement, item, overlayElement })\n\n    return cb({ container: containerElement, loadingElement, item, frame: undefined, removeStyle: () => { }, addStyle: () => { }, overlayElement })\n  }\n\n  const executeOnLayoutBeforeMeasurmentHook = (options: { minimumWidth: number }) => hooks$.getValue().forEach(hook => {\n    if (hook.name === `item.onLayoutBeforeMeasurment`) {\n      hook.fn({\n        frame: spineItemFrame,\n        container: containerElement,\n        item,\n        isImageType,\n        ...options\n      })\n    }\n  })\n\n  spineItemFrame.$.contentLayoutChange$\n    .pipe(\n      withLatestFrom(spineItemFrame.$.isReady$),\n      takeUntil(destroySubject$)\n    )\n    .subscribe(([data, isReady]) => {\n      if (data.isFirstLayout && isReady) {\n        loadingElement.style.visibility = `hidden`\n      }\n      contentLayoutChangeSubject$.next({ isFirstLayout: data.isFirstLayout, isReady })\n    })\n\n  spineItemFrame.$.unload$\n    .pipe(\n      tap(() => {\n        if (loadingElement && loadingElement.style.visibility !== `visible`) {\n          loadingElement.style.visibility = `visible`\n        }\n      }),\n      takeUntil(destroySubject$)\n    )\n    .subscribe()\n\n  return {\n    load: () => {\n      setLayoutDirty()\n    },\n    layout,\n    adjustPositionOfElement,\n    createLoadingElement,\n    getElementDimensions,\n    getHtmlFromResource: spineItemFrame.getHtmlFromResource,\n    getResource,\n    translateFramePositionIntoPage,\n    setLayoutDirty,\n    injectStyle,\n    loadContent,\n    unloadContent,\n    spineItemFrame,\n    element: containerElement,\n    loadingElement,\n    isReflowable,\n    getBoundingRectOfElementFromSelector,\n    getViewPortInformation,\n    isImageType,\n    isReady: spineItemFrame.getIsReady,\n    destroy: () => {\n      destroySubject$.next()\n      loadingElement.onload = () => { }\n      loadingElement.remove()\n      containerElement.remove()\n      spineItemFrame?.destroy()\n      fingerTracker.destroy()\n      selectionTracker.destroy()\n      destroySubject$.complete()\n    },\n    isUsingVerticalWriting: () => spineItemFrame.getWritingMode()?.startsWith(`vertical`),\n    getReadingDirection: () => {\n      return spineItemFrame.getReadingDirection() || context.getReadingDirection()\n    },\n    manipulateSpineItem,\n    executeOnLayoutBeforeMeasurmentHook,\n    selectionTracker,\n    fingerTracker,\n    $: {\n      contentLayoutChangeSubject$: contentLayoutChangeSubject$.asObservable(),\n      loaded$: spineItemFrame.$.loaded$\n    }\n  }\n}\n\nconst createContainerElement = (containerElement: HTMLElement, item: Manifest[`spineItems`][number], hooks$: BehaviorSubject<Hook[]>) => {\n  const element: HTMLElement = containerElement.ownerDocument.createElement(`div`)\n  element.classList.add(`spineItem`)\n  element.classList.add(`spineItem-${item.renditionLayout}`)\n  element.style.cssText = `\n    position: absolute;\n    overflow: hidden;\n  `\n\n  return hooks$.getValue().reduce((element, hook) => {\n    if (hook.name === `item.onBeforeContainerCreated`) {\n      return hook.fn(element)\n    }\n\n    return element\n  }, element)\n}\n\n/**\n * We use iframe for loading element mainly to be able to use share hooks / manipulation\n * with iframe. That way the loading element always match whatever style is applied to iframe.\n */\nconst createLoadingElement = (containerElement: HTMLElement, item: Manifest[`spineItems`][number], context: Context) => {\n  const loadingElement = containerElement.ownerDocument.createElement(`div`)\n  loadingElement.classList.add(`loading`)\n  loadingElement.style.cssText = `\n    height: 100%;\n    width: 100%;\n    max-width: ${context.getVisibleAreaRect().width}px;\n    text-align: center;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    flex-direction: column;\n    position: absolute;\n    left: 0;\n    top: 0;\n    background-color: white;\n  `\n\n  const logoElement = containerElement.ownerDocument.createElement(`div`)\n  logoElement.innerText = `prose`\n  logoElement.style.cssText = `\n    font-size: 4em;\n    color: #cacaca;\n  `\n  const detailsElement = containerElement.ownerDocument.createElement(`div`)\n  detailsElement.innerText = `loading ${item.id}`\n  detailsElement.style.cssText = `\n    font-size: 1.2em;\n    color: rgb(202, 202, 202);\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    overflow: hidden;\n    max-width: 300px;\n    width: 80%;\n  `\n  loadingElement.appendChild(logoElement)\n  loadingElement.appendChild(detailsElement)\n\n  return loadingElement\n}\n\nconst createOverlayElement = (containerElement: HTMLElement, item: Manifest[`spineItems`][number]) => {\n  const element = containerElement.ownerDocument.createElement(`div`)\n  element.classList.add(`spineItemOverlay`)\n  element.classList.add(`spineItemOverlay-${item.renditionLayout}`)\n  element.style.cssText = `\n    position: absolute;\n    width: 100%;\n    height: 100%;\n    pointer-events: none;\n    background-color: transparent;\n  `\n\n  return element\n}\n\nconst createFrameHooks = (iframeEventBridgeElement: HTMLElement, fingerTracker: ReturnType<typeof createFingerTracker>, selectionTracker: ReturnType<typeof createSelectionTracker>): Hook[] => {\n  return [\n    {\n      name: `item.onLoad`,\n      fn: ({ frame }) => {\n        /**\n         * Register event listener for all mouse/pointer event in order to\n         * passthrough events to main document\n         */\n        const unregister = passthroughEvents.map(event => {\n          const listener = (e: MouseEvent | PointerEvent) => {\n            let convertedEvent = e\n\n            if (isPointerEvent(e)) {\n              convertedEvent = new PointerEvent(e.type, e)\n            }\n\n            if (isMouseEvent(e)) {\n              convertedEvent = new MouseEvent(e.type, e)\n            }\n\n            if (convertedEvent !== e) {\n              attachOriginalFrameEventToDocumentEvent(convertedEvent, e)\n              iframeEventBridgeElement.dispatchEvent(convertedEvent)\n            }\n          }\n\n          frame.contentDocument?.addEventListener(event, listener)\n\n          return () => {\n            frame.contentDocument?.removeEventListener(event, listener)\n          }\n        })\n\n        selectionTracker.track(frame)\n        fingerTracker.track(frame)\n\n        return () => {\n          unregister.forEach(cb => cb())\n        }\n      }\n    }\n  ]\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/commonSpineItem.ts\n");
|
|
410
|
+
|
|
411
|
+
/***/ }),
|
|
412
|
+
|
|
413
|
+
/***/ "./src/spineItem/createSpineItem.ts":
|
|
414
|
+
/*!******************************************!*\
|
|
415
|
+
!*** ./src/spineItem/createSpineItem.ts ***!
|
|
416
|
+
\******************************************/
|
|
417
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
418
|
+
|
|
419
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createSpineItem\": () => (/* binding */ createSpineItem)\n/* harmony export */ });\n/* harmony import */ var _prePaginatedSpineItem__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./prePaginatedSpineItem */ \"./src/spineItem/prePaginatedSpineItem.ts\");\n/* harmony import */ var _reflowableSpineItem__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./reflowableSpineItem */ \"./src/spineItem/reflowableSpineItem.ts\");\n\n\nconst createSpineItem = ({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ }) => {\n let spineItem;\n if (item.renditionLayout === `pre-paginated`) {\n spineItem = (0,_prePaginatedSpineItem__WEBPACK_IMPORTED_MODULE_0__.createPrePaginatedSpineItem)({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ });\n }\n else {\n spineItem = (0,_reflowableSpineItem__WEBPACK_IMPORTED_MODULE_1__.createReflowableSpineItem)({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ });\n }\n return Object.assign({ item }, spineItem);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc3BpbmVJdGVtL2NyZWF0ZVNwaW5lSXRlbS50cy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFJcUU7QUFDSjtBQU0xRCxNQUFNLGVBQWUsR0FBRyxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLEVBQUUsY0FBYyxFQU9qSCxFQUFFLEVBQUU7SUFDSixJQUFJLFNBQXdHO0lBRTVHLElBQUksSUFBSSxDQUFDLGVBQWUsS0FBSyxlQUFlLEVBQUU7UUFDNUMsU0FBUyxHQUFHLG1GQUEyQixDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLENBQUM7S0FDL0g7U0FBTTtRQUNMLFNBQVMsR0FBRywrRUFBeUIsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLGNBQWMsRUFBRSxDQUFDO0tBQzdIO0lBRUQsdUJBQ0UsSUFBSSxJQUNELFNBQVMsRUFDYjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvc3BpbmVJdGVtL2NyZWF0ZVNwaW5lSXRlbS50cz9iNTQ2Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCJcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiLi4vY29udGV4dFwiXG5pbXBvcnQgeyBNYW5pZmVzdCB9IGZyb20gXCIuLi90eXBlc1wiXG5pbXBvcnQgeyBIb29rIH0gZnJvbSBcIi4uL3R5cGVzL0hvb2tcIlxuaW1wb3J0IHsgY3JlYXRlUHJlUGFnaW5hdGVkU3BpbmVJdGVtIH0gZnJvbSBcIi4vcHJlUGFnaW5hdGVkU3BpbmVJdGVtXCJcbmltcG9ydCB7IGNyZWF0ZVJlZmxvd2FibGVTcGluZUl0ZW0gfSBmcm9tIFwiLi9yZWZsb3dhYmxlU3BpbmVJdGVtXCJcblxuZXhwb3J0IHR5cGUgU3BpbmVJdGVtID0ge1xuICBpdGVtOiBNYW5pZmVzdFtgc3BpbmVJdGVtc2BdW251bWJlcl0sXG59ICYgKFJldHVyblR5cGU8dHlwZW9mIGNyZWF0ZVByZVBhZ2luYXRlZFNwaW5lSXRlbT4gfCBSZXR1cm5UeXBlPHR5cGVvZiBjcmVhdGVSZWZsb3dhYmxlU3BpbmVJdGVtPilcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVNwaW5lSXRlbSA9ICh7IGl0ZW0sIGNvbnRleHQsIGNvbnRhaW5lckVsZW1lbnQsIGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudCwgaG9va3MkLCB2aWV3cG9ydFN0YXRlJCB9OiB7XG4gIGl0ZW06IE1hbmlmZXN0W2BzcGluZUl0ZW1zYF1bbnVtYmVyXSxcbiAgY29udGFpbmVyRWxlbWVudDogSFRNTEVsZW1lbnQsXG4gIGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudDogSFRNTEVsZW1lbnQsXG4gIGNvbnRleHQ6IENvbnRleHQsXG4gIGhvb2tzJDogQmVoYXZpb3JTdWJqZWN0PEhvb2tbXT4sXG4gIHZpZXdwb3J0U3RhdGUkOiBPYnNlcnZhYmxlPGBmcmVlYCB8IGBidXN5YD5cbiB9KSA9PiB7XG4gIGxldCBzcGluZUl0ZW06IFJldHVyblR5cGU8dHlwZW9mIGNyZWF0ZVByZVBhZ2luYXRlZFNwaW5lSXRlbT4gfCBSZXR1cm5UeXBlPHR5cGVvZiBjcmVhdGVSZWZsb3dhYmxlU3BpbmVJdGVtPlxuXG4gIGlmIChpdGVtLnJlbmRpdGlvbkxheW91dCA9PT0gYHByZS1wYWdpbmF0ZWRgKSB7XG4gICAgc3BpbmVJdGVtID0gY3JlYXRlUHJlUGFnaW5hdGVkU3BpbmVJdGVtKHsgaXRlbSwgY29udGV4dCwgY29udGFpbmVyRWxlbWVudCwgaWZyYW1lRXZlbnRCcmlkZ2VFbGVtZW50LCBob29rcyQsIHZpZXdwb3J0U3RhdGUkIH0pXG4gIH0gZWxzZSB7XG4gICAgc3BpbmVJdGVtID0gY3JlYXRlUmVmbG93YWJsZVNwaW5lSXRlbSh7IGl0ZW0sIGNvbnRleHQsIGNvbnRhaW5lckVsZW1lbnQsIGlmcmFtZUV2ZW50QnJpZGdlRWxlbWVudCwgaG9va3MkLCB2aWV3cG9ydFN0YXRlJCB9KVxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBpdGVtLFxuICAgIC4uLnNwaW5lSXRlbVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/spineItem/createSpineItem.ts\n");
|
|
420
|
+
|
|
421
|
+
/***/ }),
|
|
422
|
+
|
|
423
|
+
/***/ "./src/spineItem/frameItem/createFrame$.ts":
|
|
424
|
+
/*!*************************************************!*\
|
|
425
|
+
!*** ./src/spineItem/frameItem/createFrame$.ts ***!
|
|
426
|
+
\*************************************************/
|
|
427
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
428
|
+
|
|
429
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createFrame$\": () => (/* binding */ createFrame$)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../report */ \"./src/report.ts\");\n\n\nconst createFrame$ = _report__WEBPACK_IMPORTED_MODULE_1__.Report.measurePerformance(`SpineItemFrame createFrame`, Infinity, () => {\n const frame = document.createElement(`iframe`);\n frame.frameBorder = `no`;\n frame.tabIndex = 0;\n frame.setAttribute(`sandbox`, `allow-same-origin allow-scripts`);\n frame.scrolling = `no`;\n frame.style.cssText = `\n visibility: hidden;\n overflow: hidden;\n background-color: transparent;\n border: 0px none transparent;\n padding: 0px;\n transition: opacity 300ms;\n opacity: 0;\n `;\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(frame);\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc3BpbmVJdGVtL2ZyYW1lSXRlbS9jcmVhdGVGcmFtZSQudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUF5QjtBQUNZO0FBRTlCLE1BQU0sWUFBWSxHQUFHLDhEQUF5QixDQUFDLDRCQUE0QixFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUU7SUFHakcsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUM7SUFDOUMsS0FBSyxDQUFDLFdBQVcsR0FBRyxJQUFJO0lBQ3hCLEtBQUssQ0FBQyxRQUFRLEdBQUcsQ0FBQztJQUNsQixLQUFLLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxpQ0FBaUMsQ0FBQztJQUNoRSxLQUFLLENBQUMsU0FBUyxHQUFHLElBQUk7SUFDdEIsS0FBSyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUc7Ozs7Ozs7O0dBUXJCO0lBRUQsT0FBTyx3Q0FBRSxDQUFDLEtBQUssQ0FBQztBQUNsQixDQUFDLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvc3BpbmVJdGVtL2ZyYW1lSXRlbS9jcmVhdGVGcmFtZSQudHM/ODk1NCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBvZiB9IGZyb20gXCJyeGpzXCJcbmltcG9ydCB7IFJlcG9ydCB9IGZyb20gXCIuLi8uLi9yZXBvcnRcIlxuXG5leHBvcnQgY29uc3QgY3JlYXRlRnJhbWUkID0gUmVwb3J0Lm1lYXN1cmVQZXJmb3JtYW5jZShgU3BpbmVJdGVtRnJhbWUgY3JlYXRlRnJhbWVgLCBJbmZpbml0eSwgKCkgPT4ge1xuICAvLyB3ZSBmb3JjZSB1bmRlZmluZWQgYmVjYXVzZSBvdGhlcndpc2UgdGhlIGxvYWQgbWV0aG9kIHdpbGwgYmVsaWV2ZSBpdCdzIGRlZmluZWQgYWZ0ZXIgdGhpcyBjYWxsIGJ1dCB0aGUgY29kZSBpcyBhc3luYyBhbmRcbiAgLy8gdGhlIGlmcmFtZSBjb3VsZCBiZSB1bmRlZmluZWQgbGF0ZXJcbiAgY29uc3QgZnJhbWUgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KGBpZnJhbWVgKVxuICBmcmFtZS5mcmFtZUJvcmRlciA9IGBub2BcbiAgZnJhbWUudGFiSW5kZXggPSAwXG4gIGZyYW1lLnNldEF0dHJpYnV0ZShgc2FuZGJveGAsIGBhbGxvdy1zYW1lLW9yaWdpbiBhbGxvdy1zY3JpcHRzYClcbiAgZnJhbWUuc2Nyb2xsaW5nID0gYG5vYFxuICBmcmFtZS5zdHlsZS5jc3NUZXh0ID0gYFxuICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICAgIGJvcmRlcjogMHB4IG5vbmUgdHJhbnNwYXJlbnQ7XG4gICAgcGFkZGluZzogMHB4O1xuICAgIHRyYW5zaXRpb246IG9wYWNpdHkgMzAwbXM7XG4gICAgb3BhY2l0eTogMDtcbiAgYFxuXG4gIHJldHVybiBvZihmcmFtZSlcbn0pXG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/spineItem/frameItem/createFrame$.ts\n");
|
|
430
|
+
|
|
431
|
+
/***/ }),
|
|
432
|
+
|
|
433
|
+
/***/ "./src/spineItem/frameItem/createFrameManipulator.ts":
|
|
434
|
+
/*!***********************************************************!*\
|
|
435
|
+
!*** ./src/spineItem/frameItem/createFrameManipulator.ts ***!
|
|
436
|
+
\***********************************************************/
|
|
437
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
438
|
+
|
|
439
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createFrameManipulator\": () => (/* binding */ createFrameManipulator)\n/* harmony export */ });\n/* harmony import */ var _frames__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../frames */ \"./src/frames.ts\");\n\nconst createFrameManipulator = (frameElement) => ({\n frame: frameElement,\n removeStyle: (0,_frames__WEBPACK_IMPORTED_MODULE_0__.createRemoveStyleHelper)(frameElement),\n addStyle: (0,_frames__WEBPACK_IMPORTED_MODULE_0__.createAddStyleHelper)(frameElement)\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc3BpbmVJdGVtL2ZyYW1lSXRlbS9jcmVhdGVGcmFtZU1hbmlwdWxhdG9yLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQTRFO0FBRXJFLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxZQUErQixFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzFFLEtBQUssRUFBRSxZQUFZO0lBQ25CLFdBQVcsRUFBRSxnRUFBdUIsQ0FBQyxZQUFZLENBQUM7SUFDbEQsUUFBUSxFQUFFLDZEQUFvQixDQUFDLFlBQVksQ0FBQztDQUM3QyxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL3NwaW5lSXRlbS9mcmFtZUl0ZW0vY3JlYXRlRnJhbWVNYW5pcHVsYXRvci50cz84YjJhIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUFkZFN0eWxlSGVscGVyLCBjcmVhdGVSZW1vdmVTdHlsZUhlbHBlciB9IGZyb20gXCIuLi8uLi9mcmFtZXNcIlxuXG5leHBvcnQgY29uc3QgY3JlYXRlRnJhbWVNYW5pcHVsYXRvciA9IChmcmFtZUVsZW1lbnQ6IEhUTUxJRnJhbWVFbGVtZW50KSA9PiAoe1xuICBmcmFtZTogZnJhbWVFbGVtZW50LFxuICByZW1vdmVTdHlsZTogY3JlYXRlUmVtb3ZlU3R5bGVIZWxwZXIoZnJhbWVFbGVtZW50KSxcbiAgYWRkU3R5bGU6IGNyZWF0ZUFkZFN0eWxlSGVscGVyKGZyYW1lRWxlbWVudClcbn0pXG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/spineItem/frameItem/createFrameManipulator.ts\n");
|
|
440
|
+
|
|
441
|
+
/***/ }),
|
|
442
|
+
|
|
443
|
+
/***/ "./src/spineItem/frameItem/createHtmlPageFromResource.ts":
|
|
444
|
+
/*!***************************************************************!*\
|
|
445
|
+
!*** ./src/spineItem/frameItem/createHtmlPageFromResource.ts ***!
|
|
446
|
+
\***************************************************************/
|
|
447
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
448
|
+
|
|
449
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createHtmlPageFromResource\": () => (/* binding */ createHtmlPageFromResource)\n/* harmony export */ });\n/* harmony import */ var _utils_contentType__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../utils/contentType */ \"./src/utils/contentType.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../utils/objects */ \"./src/utils/objects.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\nconst createHtmlPageFromResource = (resourceResponse, item) => __awaiter(void 0, void 0, void 0, function* () {\n if (typeof resourceResponse === `string`)\n return resourceResponse;\n const contentType = (0,_utils_contentType__WEBPACK_IMPORTED_MODULE_0__.parseContentType)(resourceResponse.headers.get(`Content-Type`) || ``) || (0,_utils_contentType__WEBPACK_IMPORTED_MODULE_0__.detectContentType)(item.href);\n if ([`image/jpg`, `image/jpeg`, `image/png`, `image/webp`].some(mime => mime === contentType)) {\n const data = yield (0,_utils_objects__WEBPACK_IMPORTED_MODULE_1__.getBase64FromBlob)(yield resourceResponse.blob());\n return `\n <html>\n <head>\n <meta name=\"viewport\" content=\"width=device-width, minimum-scale=0.1\">\n </head>\n <body style=\"margin: 0px;\" tab-index=\"-1;\">\n <img\n src=\"${data}\"\n style=\"max-width: 100%;height:100%;object-fit:contain;\"\n >\n </body>\n </html>\n `;\n }\n if ([`text/plain`].some(mime => mime === contentType)) {\n const data = yield resourceResponse.text();\n return `\n <!DOCTYPE html>\n <html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:epub=\"http://www.idpf.org/2007/ops\" xml:lang=\"en\" lang=\"en\">\n <head>\n <style>\n pre {\n white-space: pre;\n white-space: pre-wrap;\n word-wrap: break-word;\n }\n </style>\n </head>\n <body>\n <pre>${data}</pre>\n </body>\n </html>\n `;\n }\n const content = yield resourceResponse.text();\n return content;\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvc3BpbmVJdGVtL2ZyYW1lSXRlbS9jcmVhdGVIdG1sUGFnZUZyb21SZXNvdXJjZS50cy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFDNkU7QUFDdEI7QUFLaEQsTUFBTSwwQkFBMEIsR0FBRyxDQUFPLGdCQUFtQyxFQUFFLElBQW9DLEVBQUUsRUFBRTtJQUM1SCxJQUFJLE9BQU8sZ0JBQWdCLEtBQUssUUFBUTtRQUFFLE9BQU8sZ0JBQWdCO0lBRWpFLE1BQU0sV0FBVyxHQUFHLG9FQUFnQixDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDLElBQUkscUVBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztJQUV4SCxJQUFJLENBQUMsV0FBVyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFdBQVcsQ0FBQyxFQUFFO1FBQzdGLE1BQU0sSUFBSSxHQUFHLE1BQU0saUVBQWlCLENBQUMsTUFBTSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUVuRSxPQUFPOzs7Ozs7O21CQU9RLElBQUk7Ozs7O1NBS2Q7S0FDTjtJQUVELElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssV0FBVyxDQUFDLEVBQUU7UUFDckQsTUFBTSxJQUFJLEdBQUcsTUFBTSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUU7UUFFMUMsT0FBTzs7Ozs7Ozs7Ozs7OztpQkFhTSxJQUFJOzs7S0FHaEI7S0FDRjtJQUVELE1BQU0sT0FBTyxHQUFHLE1BQU0sZ0JBQWdCLENBQUMsSUFBSSxFQUFFO0lBSTdDLE9BQU8sT0FBTztBQUNoQixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL3NwaW5lSXRlbS9mcmFtZUl0ZW0vY3JlYXRlSHRtbFBhZ2VGcm9tUmVzb3VyY2UudHM/YmY0NSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYW5pZmVzdCB9IGZyb20gXCIuLi8uLi90eXBlc1wiXG5pbXBvcnQgeyBkZXRlY3RDb250ZW50VHlwZSwgcGFyc2VDb250ZW50VHlwZSB9IGZyb20gXCIuLi8uLi91dGlscy9jb250ZW50VHlwZVwiXG5pbXBvcnQgeyBnZXRCYXNlNjRGcm9tQmxvYiB9IGZyb20gXCIuLi8uLi91dGlscy9vYmplY3RzXCJcblxuLyoqXG4gKiBEb2N1bWVudCBpcyBhcHBsaWNhdGlvbi94aHRtbCt4bWxcbiAqL1xuZXhwb3J0IGNvbnN0IGNyZWF0ZUh0bWxQYWdlRnJvbVJlc291cmNlID0gYXN5bmMgKHJlc291cmNlUmVzcG9uc2U6IFJlc3BvbnNlIHwgc3RyaW5nLCBpdGVtOiBNYW5pZmVzdFtgc3BpbmVJdGVtc2BdW251bWJlcl0pID0+IHtcbiAgaWYgKHR5cGVvZiByZXNvdXJjZVJlc3BvbnNlID09PSBgc3RyaW5nYCkgcmV0dXJuIHJlc291cmNlUmVzcG9uc2VcblxuICBjb25zdCBjb250ZW50VHlwZSA9IHBhcnNlQ29udGVudFR5cGUocmVzb3VyY2VSZXNwb25zZS5oZWFkZXJzLmdldChgQ29udGVudC1UeXBlYCkgfHwgYGApIHx8IGRldGVjdENvbnRlbnRUeXBlKGl0ZW0uaHJlZilcblxuICBpZiAoW2BpbWFnZS9qcGdgLCBgaW1hZ2UvanBlZ2AsIGBpbWFnZS9wbmdgLCBgaW1hZ2Uvd2VicGBdLnNvbWUobWltZSA9PiBtaW1lID09PSBjb250ZW50VHlwZSkpIHtcbiAgICBjb25zdCBkYXRhID0gYXdhaXQgZ2V0QmFzZTY0RnJvbUJsb2IoYXdhaXQgcmVzb3VyY2VSZXNwb25zZS5ibG9iKCkpXG5cbiAgICByZXR1cm4gYFxuICAgICAgPGh0bWw+XG4gICAgICAgIDxoZWFkPlxuICAgICAgICAgIDxtZXRhIG5hbWU9XCJ2aWV3cG9ydFwiIGNvbnRlbnQ9XCJ3aWR0aD1kZXZpY2Utd2lkdGgsIG1pbmltdW0tc2NhbGU9MC4xXCI+XG4gICAgICAgIDwvaGVhZD5cbiAgICAgICAgPGJvZHkgc3R5bGU9XCJtYXJnaW46IDBweDtcIiB0YWItaW5kZXg9XCItMTtcIj5cbiAgICAgICAgICA8aW1nXG4gICAgICAgICAgICBzcmM9XCIke2RhdGF9XCJcbiAgICAgICAgICAgIHN0eWxlPVwibWF4LXdpZHRoOiAxMDAlO2hlaWdodDoxMDAlO29iamVjdC1maXQ6Y29udGFpbjtcIlxuICAgICAgICAgID5cbiAgICAgICAgPC9ib2R5PlxuICAgICAgPC9odG1sPlxuICAgICAgICBgXG4gIH1cblxuICBpZiAoW2B0ZXh0L3BsYWluYF0uc29tZShtaW1lID0+IG1pbWUgPT09IGNvbnRlbnRUeXBlKSkge1xuICAgIGNvbnN0IGRhdGEgPSBhd2FpdCByZXNvdXJjZVJlc3BvbnNlLnRleHQoKVxuXG4gICAgcmV0dXJuIGBcbiAgICAgIDwhRE9DVFlQRSBodG1sPlxuICAgICAgPGh0bWwgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sXCIgeG1sbnM6ZXB1Yj1cImh0dHA6Ly93d3cuaWRwZi5vcmcvMjAwNy9vcHNcIiB4bWw6bGFuZz1cImVuXCIgbGFuZz1cImVuXCI+XG4gICAgICAgIDxoZWFkPlxuICAgICAgICAgIDxzdHlsZT5cbiAgICAgICAgICAgIHByZSB7XG4gICAgICAgICAgICAgIHdoaXRlLXNwYWNlOiBwcmU7XG4gICAgICAgICAgICAgIHdoaXRlLXNwYWNlOiBwcmUtd3JhcDtcbiAgICAgICAgICAgICAgd29yZC13cmFwOiBicmVhay13b3JkO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIDwvc3R5bGU+XG4gICAgICAgIDwvaGVhZD5cbiAgICAgICAgPGJvZHk+XG4gICAgICAgICAgPHByZT4ke2RhdGF9PC9wcmU+XG4gICAgICAgIDwvYm9keT5cbiAgICAgIDwvaHRtbD5cbiAgICBgXG4gIH1cblxuICBjb25zdCBjb250ZW50ID0gYXdhaXQgcmVzb3VyY2VSZXNwb25zZS50ZXh0KClcblxuICAvLyByZXR1cm4gY29udGVudC5yZXBsYWNlKGA8aGVhZD5gLCBgPGhlYWQ+PGJhc2UgeG1sbnMgaHJlZj1cIiR7aXRlbS5ocmVmfVwiIC8+YClcblxuICByZXR1cm4gY29udGVudFxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/spineItem/frameItem/createHtmlPageFromResource.ts\n");
|
|
450
|
+
|
|
451
|
+
/***/ }),
|
|
452
|
+
|
|
453
|
+
/***/ "./src/spineItem/frameItem/frameItem.ts":
|
|
454
|
+
/*!**********************************************!*\
|
|
455
|
+
!*** ./src/spineItem/frameItem/frameItem.ts ***!
|
|
456
|
+
\**********************************************/
|
|
457
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
458
|
+
|
|
459
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createFrameItem\": () => (/* binding */ createFrameItem)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _frames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../frames */ \"./src/frames.ts\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _loader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./loader */ \"./src/spineItem/frameItem/loader.ts\");\n/* harmony import */ var _createFrameManipulator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createFrameManipulator */ \"./src/spineItem/frameItem/createFrameManipulator.ts\");\n/* harmony import */ var _createHtmlPageFromResource__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createHtmlPageFromResource */ \"./src/spineItem/frameItem/createHtmlPageFromResource.ts\");\n\n\n\n\n\n\nconst createFrameItem = ({ item, parent, fetchResource, context, hooks$, viewportState$ }) => {\n const destroySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const { $: { unload$, loaded$, isLoaded$, isReady$, unloaded$, frameElement$, ready$ }, load, unload, destroy: loaderDestroy, getComputedStyleAfterLoad } = (0,_loader__WEBPACK_IMPORTED_MODULE_3__.createLoader)({ context, hooks$, item, parent, fetchResource, viewportState$ });\n const isLoadedSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(false);\n const isReadySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(false);\n isLoaded$.subscribe(isLoadedSubject$);\n isReady$.subscribe(isReadySubject$);\n const getManipulableFrame = () => {\n const frame = frameElement$.getValue();\n if (isLoadedSubject$.value && frame) {\n return (0,_createFrameManipulator__WEBPACK_IMPORTED_MODULE_4__.createFrameManipulator)(frame);\n }\n };\n const getViewportDimensions = () => {\n const frame = frameElement$.getValue();\n if (frame && (frame === null || frame === void 0 ? void 0 : frame.contentDocument)) {\n const doc = frame.contentDocument;\n const viewPortMeta = doc.querySelector(`meta[name='viewport']`);\n if (viewPortMeta) {\n const viewPortMetaInfos = viewPortMeta.getAttribute(`content`);\n if (viewPortMetaInfos) {\n const width = (0,_frames__WEBPACK_IMPORTED_MODULE_1__.getAttributeValueFromString)(viewPortMetaInfos, `width`);\n const height = (0,_frames__WEBPACK_IMPORTED_MODULE_1__.getAttributeValueFromString)(viewPortMetaInfos, `height`);\n if (width > 0 && height > 0) {\n return {\n width: width,\n height: height\n };\n }\n else {\n return undefined;\n }\n }\n }\n }\n return undefined;\n };\n const getWritingMode = () => {\n var _a;\n return (_a = getComputedStyleAfterLoad()) === null || _a === void 0 ? void 0 : _a.writingMode;\n };\n const isUsingVerticalWriting = () => {\n var _a;\n return !!((_a = getWritingMode()) === null || _a === void 0 ? void 0 : _a.startsWith(`vertical`));\n };\n const getHtmlFromResource = (response) => {\n return (0,_createHtmlPageFromResource__WEBPACK_IMPORTED_MODULE_5__.createHtmlPageFromResource)(response, item);\n };\n const contentLayoutChange$ = (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(unloaded$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_2__.map)(() => ({ isFirstLayout: false }))), ready$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_2__.map)(() => ({ isFirstLayout: true }))));\n const destroy = () => {\n unload();\n loaderDestroy();\n destroySubject$.next();\n destroySubject$.complete();\n };\n return {\n getIsLoaded: () => isLoadedSubject$.value,\n getIsReady: () => isReadySubject$.value,\n getViewportDimensions,\n getFrameElement: () => frameElement$.getValue(),\n getHtmlFromResource,\n load,\n unload,\n staticLayout: (size) => {\n const frame = frameElement$.getValue();\n if (frame) {\n frame.style.width = `${size.width}px`;\n frame.style.height = `${size.height}px`;\n if (context.getSettings().computedPageTurnMode !== `scrollable`) {\n frame.setAttribute(`tab-index`, `0`);\n }\n }\n },\n getManipulableFrame,\n getReadingDirection: () => {\n var _a;\n const writingMode = getWritingMode();\n if (writingMode === `vertical-rl`) {\n return `rtl`;\n }\n const direction = (_a = getComputedStyleAfterLoad()) === null || _a === void 0 ? void 0 : _a.direction;\n if ([`ltr`, `rtl`].includes(direction || ``))\n return direction;\n return undefined;\n },\n isUsingVerticalWriting,\n getWritingMode,\n destroy,\n $: {\n unload$: unload$,\n unloaded$: unloaded$,\n loaded$,\n ready$,\n isReady$: isReadySubject$.asObservable(),\n contentLayoutChange$\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/frameItem/frameItem.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItem/frameItem/frameItem.ts?1fac"],"sourcesContent":["import { BehaviorSubject, merge, Observable, Subject } from \"rxjs\"\nimport { Manifest } from \"../../types\"\nimport { Context } from \"../../context\"\nimport { getAttributeValueFromString } from \"../../frames\"\nimport { Hook } from \"../../types/Hook\"\nimport { map } from \"rxjs/operators\"\nimport { createLoader } from \"./loader\"\nimport { createFrameManipulator } from \"./createFrameManipulator\"\nimport { createHtmlPageFromResource } from \"./createHtmlPageFromResource\"\n\nexport const createFrameItem = ({ item, parent, fetchResource, context, hooks$, viewportState$ }: {\n  parent: HTMLElement,\n  item: Manifest[`spineItems`][number],\n  context: Context,\n  fetchResource?: (item: Manifest[`spineItems`][number]) => Promise<Response>,\n  hooks$: Observable<Hook[]>,\n  viewportState$: Observable<`free` | `busy`>\n}) => {\n  const destroySubject$ = new Subject<void>()\n\n  const {\n    $: {\n      unload$,\n      loaded$,\n      isLoaded$,\n      isReady$,\n      unloaded$,\n      frameElement$,\n      ready$\n    },\n    load,\n    unload,\n    destroy: loaderDestroy,\n    getComputedStyleAfterLoad\n  } = createLoader({ context, hooks$, item, parent, fetchResource, viewportState$ })\n\n  const isLoadedSubject$ = new BehaviorSubject(false)\n  const isReadySubject$ = new BehaviorSubject(false)\n\n  isLoaded$.subscribe(isLoadedSubject$)\n  isReady$.subscribe(isReadySubject$)\n\n  const getManipulableFrame = () => {\n    const frame = frameElement$.getValue()\n    if (isLoadedSubject$.value && frame) {\n      return createFrameManipulator(frame)\n    }\n  }\n\n  // @todo memoize\n  const getViewportDimensions = () => {\n    const frame = frameElement$.getValue()\n\n    if (frame && frame?.contentDocument) {\n      const doc = frame.contentDocument\n      const viewPortMeta = doc.querySelector(`meta[name='viewport']`)\n      if (viewPortMeta) {\n        const viewPortMetaInfos = viewPortMeta.getAttribute(`content`)\n        if (viewPortMetaInfos) {\n          const width = getAttributeValueFromString(viewPortMetaInfos, `width`)\n          const height = getAttributeValueFromString(viewPortMetaInfos, `height`)\n          if (width > 0 && height > 0) {\n            return {\n              width: width,\n              height: height\n            }\n          } else {\n            return undefined\n          }\n        }\n      }\n    }\n\n    return undefined\n  }\n\n  const getWritingMode = () => {\n    return getComputedStyleAfterLoad()?.writingMode as `vertical-rl` | `horizontal-tb` | undefined\n  }\n\n  const isUsingVerticalWriting = () => {\n    return !!getWritingMode()?.startsWith(`vertical`)\n  }\n\n  const getHtmlFromResource = (response: Response) => {\n    return createHtmlPageFromResource(response, item)\n  }\n\n  const contentLayoutChange$ = merge(\n    unloaded$\n      .pipe(\n        map(() => ({ isFirstLayout: false }))\n      ),\n    ready$\n      .pipe(\n        map(() => ({ isFirstLayout: true }))\n      )\n  )\n\n  const destroy = () => {\n    unload()\n    loaderDestroy()\n    destroySubject$.next()\n    destroySubject$.complete()\n  }\n\n  return {\n    getIsLoaded: () => isLoadedSubject$.value,\n    getIsReady: () => isReadySubject$.value,\n    getViewportDimensions,\n    getFrameElement: () => frameElement$.getValue(),\n    getHtmlFromResource,\n    load,\n    unload,\n    /**\n     * Upward layout is used when the parent wants to manipulate the iframe without triggering\n     * `layout` event. This is a particular case needed for iframe because the parent can layout following\n     * an iframe `layout` event. Because the parent `layout` may change some of iframe properties we do not\n     * want the iframe to trigger a new `layout` even and have infinite loop.\n     */\n    staticLayout: (size: { width: number, height: number }) => {\n      const frame = frameElement$.getValue()\n      if (frame) {\n        frame.style.width = `${size.width}px`\n        frame.style.height = `${size.height}px`\n\n        if (context.getSettings().computedPageTurnMode !== `scrollable`) {\n          // @todo see what's the impact\n          frame.setAttribute(`tab-index`, `0`)\n        }\n      }\n    },\n    // @todo block access, only public API to manipulate / get information (in order to memo / optimize)\n    // manipulate() with cb and return boolean whether re-layout or not\n    getManipulableFrame,\n    getReadingDirection: (): `ltr` | `rtl` | undefined => {\n      const writingMode = getWritingMode()\n      if (writingMode === `vertical-rl`) {\n        return `rtl`\n      }\n\n      const direction = getComputedStyleAfterLoad()?.direction\n      if ([`ltr`, `rtl`].includes(direction || ``)) return direction as (`ltr` | `rtl`)\n\n      return undefined\n    },\n    isUsingVerticalWriting,\n    getWritingMode,\n    destroy,\n    $: {\n      unload$: unload$,\n      unloaded$: unloaded$,\n      loaded$,\n      ready$,\n      isReady$: isReadySubject$.asObservable(),\n      /**\n       * This is used as upstream layout change. This event is being listened to by upper app\n       * in order to layout again and adjust every element based on the new content.\n       */\n      contentLayoutChange$\n    }\n  }\n}\n\nexport type SpineItemFrame = ReturnType<typeof createFrameItem>\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/frameItem/frameItem.ts\n");
|
|
460
|
+
|
|
461
|
+
/***/ }),
|
|
462
|
+
|
|
463
|
+
/***/ "./src/spineItem/frameItem/loader.ts":
|
|
464
|
+
/*!*******************************************!*\
|
|
465
|
+
!*** ./src/spineItem/frameItem/loader.ts ***!
|
|
466
|
+
\*******************************************/
|
|
467
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
468
|
+
|
|
469
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createLoader\": () => (/* binding */ createLoader)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../.. */ \"./src/index.ts\");\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../constants */ \"./src/constants.ts\");\n/* harmony import */ var _createFrame$__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createFrame$ */ \"./src/spineItem/frameItem/createFrame$.ts\");\n/* harmony import */ var _createFrameManipulator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createFrameManipulator */ \"./src/spineItem/frameItem/createFrameManipulator.ts\");\n/* harmony import */ var _createHtmlPageFromResource__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createHtmlPageFromResource */ \"./src/spineItem/frameItem/createHtmlPageFromResource.ts\");\n\n\n\n\n\n\n\nconst isOnLoadHook = (hook) => hook.name === `item.onLoad`;\nconst createLoader = ({ item, parent, fetchResource, hooks$, context, viewportState$ }) => {\n const destroySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const loadSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const unloadSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const frameElementSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(undefined);\n const isLoadedSubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(false);\n const isReadySubject$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.BehaviorSubject(false);\n let onLoadHookReturns = [];\n let computedStyleAfterLoad;\n const makeItHot = (source$) => {\n source$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$)).subscribe();\n return source$;\n };\n const getHtmlFromResource = (response) => {\n return (0,_createHtmlPageFromResource__WEBPACK_IMPORTED_MODULE_6__.createHtmlPageFromResource)(response, item);\n };\n const waitForViewportFree$ = viewportState$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(v => v === `free`), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n const unload$ = unloadSubject$.asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(frameElementSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(([_, frame]) => !!frame), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(([, frame]) => {\n onLoadHookReturns.forEach(fn => {\n if (fn && `unsubscribe` in fn) {\n fn.unsubscribe();\n }\n else if (fn) {\n fn();\n }\n });\n onLoadHookReturns = [];\n frame === null || frame === void 0 ? void 0 : frame.remove();\n frameElementSubject$.next(undefined);\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroySubject$));\n const load$ = loadSubject$.asObservable()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(isLoadedSubject$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.filter)(([_, isLoaded]) => !isLoaded), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.exhaustMap)(() => {\n return (0,_createFrame$__WEBPACK_IMPORTED_MODULE_4__.createFrame$)()\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)((frame) => waitForViewportFree$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mapTo)(frame))), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)((frame) => {\n parent.appendChild(frame);\n frameElementSubject$.next(frame);\n if (!fetchResource &&\n item.href.startsWith(window.location.origin) &&\n ((item.mediaType && [`application/xhtml+xml`, `application/xml`, `text/html`, `text/xml`].includes(item.mediaType)) ||\n (!item.mediaType && (_constants__WEBPACK_IMPORTED_MODULE_3__.ITEM_EXTENSION_VALID_FOR_FRAME_SRC.some(extension => item.href.endsWith(extension)))))) {\n frame === null || frame === void 0 ? void 0 : frame.setAttribute(`src`, item.href);\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(frame);\n }\n else {\n const fetchFn = fetchResource || (() => fetch(item.href));\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(fetchFn(item))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)((response) => getHtmlFromResource(response)), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)((htmlDoc) => {\n frame === null || frame === void 0 ? void 0 : frame.setAttribute(`srcdoc`, htmlDoc);\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.map)(() => frame));\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)((frame) => {\n if (!frame)\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n frame.setAttribute(`sandbox`, `allow-same-origin allow-scripts`);\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.fromEvent)(frame, `load`)\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.take)(1), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.withLatestFrom)(hooks$), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mergeMap)(([_, hooks]) => {\n var _a, _b;\n const body = (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.body;\n if (!body) {\n ___WEBPACK_IMPORTED_MODULE_2__.Report.error(`Something went wrong on iframe load ${item.id}`);\n return rxjs__WEBPACK_IMPORTED_MODULE_0__.EMPTY;\n }\n frame.setAttribute(`role`, `main`);\n if ((frame === null || frame === void 0 ? void 0 : frame.contentDocument) && body) {\n computedStyleAfterLoad = (_b = frame === null || frame === void 0 ? void 0 : frame.contentWindow) === null || _b === void 0 ? void 0 : _b.getComputedStyle(body);\n }\n if (context.getSettings().computedPageTurnMode !== `scrollable`) {\n frame.setAttribute(`tab-index`, `0`);\n }\n const manipulableFrame = (0,_createFrameManipulator__WEBPACK_IMPORTED_MODULE_5__.createFrameManipulator)(frame);\n onLoadHookReturns = hooks\n .filter(isOnLoadHook)\n .map(hook => {\n const hookReturn = hook.fn(Object.assign(Object.assign({}, manipulableFrame), { item }));\n if (hookReturn && `subscribe` in hookReturn) {\n return hookReturn.subscribe();\n }\n return hookReturn;\n });\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(frame);\n }));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(unloadSubject$));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), makeItHot, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroySubject$));\n const ready$ = load$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.switchMap)((frame) => {\n var _a;\n return (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.from)(((_a = frame === null || frame === void 0 ? void 0 : frame.contentDocument) === null || _a === void 0 ? void 0 : _a.fonts.ready) || (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.of)(undefined))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(unloadSubject$));\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.share)(), makeItHot, (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroySubject$));\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(load$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mapTo)(true)), unloadSubject$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mapTo)(false)))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroySubject$))\n .subscribe(isLoadedSubject$);\n (0,rxjs__WEBPACK_IMPORTED_MODULE_0__.merge)(ready$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mapTo)(true)), unloadSubject$.pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.mapTo)(false)))\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.distinctUntilChanged)(), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(destroySubject$))\n .subscribe(isReadySubject$);\n unload$.subscribe();\n return {\n load: () => loadSubject$.next(),\n unload: () => unloadSubject$.next(),\n destroy: () => {\n loadSubject$.complete();\n unloadSubject$.complete();\n frameElementSubject$.complete();\n destroySubject$.next();\n destroySubject$.complete();\n isReadySubject$.complete();\n isLoadedSubject$.complete();\n },\n getComputedStyleAfterLoad: () => computedStyleAfterLoad,\n $: {\n load$: loadSubject$.asObservable(),\n unload$: unloadSubject$.asObservable(),\n loaded$: load$,\n isLoaded$: isLoadedSubject$.asObservable(),\n isReady$: isReadySubject$.asObservable(),\n ready$: ready$,\n unloaded$: unload$,\n frameElement$: frameElementSubject$\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/frameItem/loader.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItem/frameItem/loader.ts?48c5"],"sourcesContent":["import { BehaviorSubject, EMPTY, from, fromEvent, isObservable, merge, Observable, of, Subject, Subscription } from \"rxjs\"\nimport { exhaustMap, filter, map, mapTo, mergeMap, share, take, takeUntil, delay, tap, withLatestFrom, switchMap, distinctUntilChanged } from \"rxjs/operators\"\nimport { Report } from \"../..\"\nimport { ITEM_EXTENSION_VALID_FOR_FRAME_SRC } from \"../../constants\"\nimport { Context } from \"../../context\"\nimport { Manifest } from \"../../types\"\nimport { Hook } from \"../../types/Hook\"\nimport { createFrame$ } from \"./createFrame$\"\nimport { createFrameManipulator } from \"./createFrameManipulator\"\nimport { createHtmlPageFromResource } from \"./createHtmlPageFromResource\"\n\nconst isOnLoadHook = (hook: Hook): hook is Extract<Hook, { name: `item.onLoad` }> => hook.name === `item.onLoad`\n\nexport const createLoader = ({ item, parent, fetchResource, hooks$, context, viewportState$ }: {\n  item: Manifest[`spineItems`][number],\n  parent: HTMLElement,\n  fetchResource?: (item: Manifest[`spineItems`][number]) => Promise<Response>,\n  hooks$: Observable<Hook[]>,\n  context: Context,\n  viewportState$: Observable<`free` | `busy`>\n}) => {\n  const destroySubject$ = new Subject<void>()\n  const loadSubject$ = new Subject<void>()\n  const unloadSubject$ = new Subject<void>()\n  const frameElementSubject$ = new BehaviorSubject<HTMLIFrameElement | undefined>(undefined)\n  const isLoadedSubject$ = new BehaviorSubject(false)\n  const isReadySubject$ = new BehaviorSubject(false)\n  let onLoadHookReturns: ((() => void) | Subscription | void)[] = []\n  let computedStyleAfterLoad: CSSStyleDeclaration | undefined\n\n  const makeItHot = <T>(source$: Observable<T>) => {\n    source$.pipe(takeUntil(context.$.destroy$)).subscribe()\n\n    return source$\n  }\n\n  const getHtmlFromResource = (response: Response) => {\n    return createHtmlPageFromResource(response, item)\n  }\n\n  const waitForViewportFree$ = viewportState$.pipe(filter(v => v === `free`), take(1))\n\n  const unload$ = unloadSubject$.asObservable()\n    .pipe(\n      // @todo remove iframe when viewport is free\n      // @todo use takeUntil(load$) when it's the case to cancel\n      withLatestFrom(frameElementSubject$),\n      filter(([_, frame]) => !!frame),\n      map(([, frame]) => {\n        onLoadHookReturns.forEach(fn => {\n          if (fn && `unsubscribe` in fn) {\n            fn.unsubscribe()\n          } else if (fn) {\n            fn()\n          }\n        })\n        onLoadHookReturns = []\n        frame?.remove()\n        frameElementSubject$.next(undefined)\n      }),\n      share(),\n      takeUntil(destroySubject$)\n    )\n\n  /**\n   * Observable for loading the frame\n   */\n  const load$ = loadSubject$.asObservable()\n    .pipe(\n      withLatestFrom(isLoadedSubject$),\n      filter(([_, isLoaded]) => !isLoaded),\n      // let's ignore later load as long as the first one still runs\n      exhaustMap(() => {\n        return createFrame$()\n          .pipe(\n            mergeMap((frame) => waitForViewportFree$.pipe(mapTo(frame))),\n            mergeMap((frame) => {\n              parent.appendChild(frame)\n\n              frameElementSubject$.next(frame)\n\n              /**\n               * Because of the bug with iframe and sw, we should not use srcdoc and sw together for\n               * html document. This is because resources will not pass through SW. IF `fetchResource` is being\n               * used the user should be aware of the limitation. We use srcdoc for everything except if we detect\n               * an html document and same origin. Hopefully that bug gets fixed one day.\n               * @see https://bugs.chromium.org/p/chromium/issues/detail?id=880768\n               */\n              if (\n                !fetchResource &&\n                item.href.startsWith(window.location.origin) &&\n                (\n                  // we have an encoding and it's a valid html\n                  (item.mediaType && [`application/xhtml+xml`, `application/xml`, `text/html`, `text/xml`].includes(item.mediaType)) ||\n                  // no encoding ? then try to detect html\n                  (!item.mediaType && (ITEM_EXTENSION_VALID_FOR_FRAME_SRC.some(extension => item.href.endsWith(extension))))\n                )\n              ) {\n                frame?.setAttribute(`src`, item.href)\n\n                return of(frame)\n              } else {\n                const fetchFn = fetchResource || (() => fetch(item.href))\n\n                return from(fetchFn(item))\n                  .pipe(\n                    mergeMap((response) => getHtmlFromResource(response)),\n                    tap((htmlDoc) => {\n                      frame?.setAttribute(`srcdoc`, htmlDoc)\n                    }),\n                    map(() => frame)\n                  )\n              }\n            }),\n            mergeMap((frame) => {\n              if (!frame) return EMPTY\n\n              frame.setAttribute(`sandbox`, `allow-same-origin allow-scripts`)\n\n              return fromEvent(frame, `load`)\n                .pipe(\n                  take(1),\n                  withLatestFrom(hooks$),\n                  mergeMap(([_, hooks]) => {\n                    const body: HTMLElement | undefined | null = frame.contentDocument?.body\n\n                    if (!body) {\n                      Report.error(`Something went wrong on iframe load ${item.id}`)\n\n                      return EMPTY\n                    }\n                    // console.log(frame.contentDocument?.head.childNodes)\n                    // console.log(frame.contentDocument?.body.childNodes)\n\n                    // const script = frame.contentDocument?.createElement(`script`)\n                    // // script?.setAttribute(`src`, `https://fred-wang.github.io/mathml.css/mspace.js`)\n                    // // script?.setAttribute(`src`, `https://fred-wang.github.io/mathjax.js/mpadded-min.js`)\n                    // // script?.setAttribute(`src`, `https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js`)\n                    // // script?.setAttribute(`src`, `https://cdn.jsdelivr.net/npm/mathjax@2/MathJax.js?config=TeX-AMS-MML_CHTML`)\n                    // if (script) {\n                    //   // console.log(frame.contentDocument?.head.childNodes)\n                    //   // console.log(frame.contentDocument?.body.childNodes)\n                    //   // frame.contentDocument?.head.appendChild(script)\n                    // }\n\n                    frame.setAttribute(`role`, `main`)\n\n                    if (frame?.contentDocument && body) {\n                      computedStyleAfterLoad = frame?.contentWindow?.getComputedStyle(body)\n                    }\n\n                    if (context.getSettings().computedPageTurnMode !== `scrollable`) {\n                      // @todo see what's the impact\n                      frame.setAttribute(`tab-index`, `0`)\n                    }\n\n                    const manipulableFrame = createFrameManipulator(frame)\n\n                    onLoadHookReturns = hooks\n                      .filter(isOnLoadHook)\n                      .map(hook => {\n                        const hookReturn = hook.fn({\n                          ...manipulableFrame,\n                          item\n                        })\n\n                        if (hookReturn && `subscribe` in hookReturn) {\n                          return hookReturn.subscribe()\n                        }\n\n                        return hookReturn\n                      })\n\n                    // we conveniently wait for all the hooks so that the dom is correctly prepared\n                    // in addition to be ready.\n                    // domReadySubject$.next(frame)\n\n                    return of(frame)\n                  })\n                )\n            }),\n            // we stop loading as soon as unload is requested\n            takeUntil(unloadSubject$)\n          )\n      }),\n      share(),\n      makeItHot,\n      takeUntil(destroySubject$)\n    )\n\n  /**\n   * Observable for when the frame is:\n   * - loaded\n   * - ready\n   */\n  const ready$ = load$\n    .pipe(\n      switchMap((frame) =>\n        from(frame?.contentDocument?.fonts.ready || of(undefined))\n          .pipe(\n            takeUntil(unloadSubject$)\n          )\n      ),\n      share(),\n      makeItHot,\n      takeUntil(destroySubject$)\n    )\n\n  merge(load$.pipe(mapTo(true)), unloadSubject$.pipe(mapTo(false)))\n    .pipe(\n      distinctUntilChanged(),\n      takeUntil(destroySubject$)\n    )\n    .subscribe(isLoadedSubject$)\n\n  merge(ready$.pipe(mapTo(true)), unloadSubject$.pipe(mapTo(false)))\n    .pipe(\n      distinctUntilChanged(),\n      takeUntil(destroySubject$)\n    )\n    .subscribe(isReadySubject$)\n\n  unload$.subscribe()\n\n  return {\n    load: () => loadSubject$.next(),\n    unload: () => unloadSubject$.next(),\n    destroy: () => {\n      loadSubject$.complete()\n      unloadSubject$.complete()\n      frameElementSubject$.complete()\n      destroySubject$.next()\n      destroySubject$.complete()\n      isReadySubject$.complete()\n      isLoadedSubject$.complete()\n    },\n    getComputedStyleAfterLoad: () => computedStyleAfterLoad,\n    $: {\n      load$: loadSubject$.asObservable(),\n      unload$: unloadSubject$.asObservable(),\n      loaded$: load$,\n      isLoaded$: isLoadedSubject$.asObservable(),\n      isReady$: isReadySubject$.asObservable(),\n      ready$: ready$,\n      unloaded$: unload$,\n      frameElement$: frameElementSubject$\n    }\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/frameItem/loader.ts\n");
|
|
470
|
+
|
|
471
|
+
/***/ }),
|
|
472
|
+
|
|
473
|
+
/***/ "./src/spineItem/locationResolver.ts":
|
|
474
|
+
/*!*******************************************!*\
|
|
475
|
+
!*** ./src/spineItem/locationResolver.ts ***!
|
|
476
|
+
\*******************************************/
|
|
477
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
478
|
+
|
|
479
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createLocationResolver\": () => (/* binding */ createLocationResolver)\n/* harmony export */ });\n/* harmony import */ var _pagination__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../pagination */ \"./src/pagination.ts\");\n/* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/dom */ \"./src/utils/dom.ts\");\n\n\nconst createLocationResolver = ({ context }) => {\n const getSpineItemPositionFromPageIndex = (pageIndex, spineItem) => {\n const { width: itemWidth, height: itemHeight } = spineItem.getElementDimensions();\n const itemReadingDirection = spineItem.getReadingDirection();\n if (spineItem.isUsingVerticalWriting()) {\n const ltrRelativeOffset = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getItemOffsetFromPageIndex)(context.getPageSize().height, pageIndex, itemHeight);\n return {\n x: 0,\n y: ltrRelativeOffset\n };\n }\n const ltrRelativeOffset = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getItemOffsetFromPageIndex)(context.getPageSize().width, pageIndex, itemWidth);\n if (itemReadingDirection === `rtl`) {\n return {\n x: (itemWidth - ltrRelativeOffset) - context.getPageSize().width,\n y: 0\n };\n }\n return {\n x: ltrRelativeOffset,\n y: 0\n };\n };\n const getSpineItemPageIndexFromPosition = (position, spineItem) => {\n const { width: itemWidth, height: itemHeight } = spineItem.getElementDimensions();\n const itemReadingDirection = spineItem.getReadingDirection();\n const pageWidth = context.getPageSize().width;\n const pageHeight = context.getPageSize().height;\n let offsetNormalizedForLtr = Math.min(itemWidth, Math.max(0, position.x));\n if (itemReadingDirection === `rtl`) {\n offsetNormalizedForLtr = (itemWidth - offsetNormalizedForLtr) - context.getPageSize().width;\n }\n if (spineItem.isUsingVerticalWriting()) {\n const numberOfPages = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getNumberOfPages)(itemHeight, pageHeight);\n return getPageFromOffset(position.y, pageHeight, numberOfPages);\n }\n else {\n const numberOfPages = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getNumberOfPages)(itemWidth, pageWidth);\n const pageIndex = getPageFromOffset(offsetNormalizedForLtr, pageWidth, numberOfPages);\n return pageIndex;\n }\n };\n const getSpineItemOffsetFromAnchor = (anchor, spineItem) => {\n var _a;\n const itemWidth = (((_a = spineItem.getElementDimensions()) === null || _a === void 0 ? void 0 : _a.width) || 0);\n const pageWidth = context.getPageSize().width;\n const anchorElementBoundingRect = spineItem.getBoundingRectOfElementFromSelector(anchor);\n const offsetOfAnchor = (anchorElementBoundingRect === null || anchorElementBoundingRect === void 0 ? void 0 : anchorElementBoundingRect.x) || 0;\n return (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getClosestValidOffsetFromApproximateOffsetInPages)(offsetOfAnchor, pageWidth, itemWidth);\n };\n const getSpineItemPositionFromNode = (node, offset, spineItem) => {\n var _a;\n let offsetOfNodeInSpineItem;\n if ((node === null || node === void 0 ? void 0 : node.nodeName) === `img` || ((node === null || node === void 0 ? void 0 : node.textContent) === `` && node.nodeType === Node.ELEMENT_NODE)) {\n offsetOfNodeInSpineItem = node.getBoundingClientRect().x;\n }\n else if (node) {\n const range = node ? (0,_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getRangeFromNode)(node, offset) : undefined;\n offsetOfNodeInSpineItem = (range === null || range === void 0 ? void 0 : range.getBoundingClientRect().x) || offsetOfNodeInSpineItem;\n }\n const spineItemWidth = ((_a = spineItem.getElementDimensions()) === null || _a === void 0 ? void 0 : _a.width) || 0;\n const pageWidth = context.getPageSize().width;\n if (offsetOfNodeInSpineItem) {\n const val = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getClosestValidOffsetFromApproximateOffsetInPages)(offsetOfNodeInSpineItem, pageWidth, spineItemWidth);\n return { x: val, y: 0 };\n }\n return undefined;\n };\n const getFirstNodeOrRangeAtPage = (pageIndex, spineItem) => {\n var _a, _b, _c;\n const pageSize = context.getPageSize();\n const frame = (_b = (_a = spineItem.spineItemFrame) === null || _a === void 0 ? void 0 : _a.getManipulableFrame()) === null || _b === void 0 ? void 0 : _b.frame;\n if (((_c = frame === null || frame === void 0 ? void 0 : frame.contentWindow) === null || _c === void 0 ? void 0 : _c.document) &&\n frame.contentWindow.document.body !== null) {\n const { x: left, y: top } = getSpineItemPositionFromPageIndex(pageIndex, spineItem);\n const viewport = {\n left,\n right: left + pageSize.width,\n top,\n bottom: top + pageSize.height\n };\n const res = (0,_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getFirstVisibleNodeForViewport)(frame.contentWindow.document, viewport);\n return res;\n }\n return undefined;\n };\n const getSpineItemClosestPositionFromUnsafePosition = (unsafePosition, spineItem) => {\n const { width, height } = spineItem.getElementDimensions();\n const adjustedPosition = {\n x: (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getClosestValidOffsetFromApproximateOffsetInPages)(unsafePosition.x, context.getPageSize().width, width),\n y: (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getClosestValidOffsetFromApproximateOffsetInPages)(unsafePosition.y, context.getPageSize().height, height)\n };\n return adjustedPosition;\n };\n const getSpineItemPageIndexFromNode = (node, offset, spineItem) => {\n const position = getSpineItemPositionFromNode(node, offset, spineItem);\n return position ? getSpineItemPageIndexFromPosition(position, spineItem) : undefined;\n };\n const getPageFromOffset = (offset, pageWidth, numberOfPages) => {\n const offsetValues = [...Array(numberOfPages)].map((_, i) => i * pageWidth);\n if (offset <= 0)\n return 0;\n if (offset >= (numberOfPages * pageWidth))\n return numberOfPages - 1;\n return Math.max(0, offsetValues.findIndex(offsetRange => offset < (offsetRange + pageWidth)));\n };\n return {\n getSpineItemPositionFromNode,\n getSpineItemPositionFromPageIndex,\n getSpineItemOffsetFromAnchor,\n getSpineItemPageIndexFromPosition,\n getSpineItemPageIndexFromNode,\n getSpineItemClosestPositionFromUnsafePosition,\n getFirstNodeOrRangeAtPage\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/locationResolver.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItem/locationResolver.ts?f2a5"],"sourcesContent":["import { Context } from \"../context\"\nimport { getItemOffsetFromPageIndex, getClosestValidOffsetFromApproximateOffsetInPages, getNumberOfPages } from \"../pagination\"\nimport { SpineItem } from \"./createSpineItem\"\nimport { getFirstVisibleNodeForViewport, getRangeFromNode } from \"../utils/dom\"\n\ntype SpineItemPosition = { x: number, y: number }\n\nexport const createLocationResolver = ({ context }: {\n  context: Context,\n}) => {\n  const getSpineItemPositionFromPageIndex = (pageIndex: number, spineItem: SpineItem): SpineItemPosition => {\n    const { width: itemWidth, height: itemHeight } = spineItem.getElementDimensions()\n    const itemReadingDirection = spineItem.getReadingDirection()\n\n    if (spineItem.isUsingVerticalWriting()) {\n      const ltrRelativeOffset = getItemOffsetFromPageIndex(context.getPageSize().height, pageIndex, itemHeight)\n\n      return {\n        x: 0,\n        y: ltrRelativeOffset\n      }\n    }\n\n    const ltrRelativeOffset = getItemOffsetFromPageIndex(context.getPageSize().width, pageIndex, itemWidth)\n\n    if (itemReadingDirection === `rtl`) {\n      return {\n        x: (itemWidth - ltrRelativeOffset) - context.getPageSize().width,\n        y: 0\n      }\n    }\n\n    return {\n      x: ltrRelativeOffset,\n      y: 0\n    }\n  }\n\n  /**\n   * @important\n   * This calculation takes blank page into account, the iframe could be only one page but with a blank page\n   * positioned before. Resulting on two page index possible values (0 & 1).\n   */\n  const getSpineItemPageIndexFromPosition = (position: SpineItemPosition, spineItem: SpineItem) => {\n    const { width: itemWidth, height: itemHeight } = spineItem.getElementDimensions()\n    const itemReadingDirection = spineItem.getReadingDirection()\n    const pageWidth = context.getPageSize().width\n    const pageHeight = context.getPageSize().height\n\n    let offsetNormalizedForLtr = Math.min(itemWidth, Math.max(0, position.x))\n\n    if (itemReadingDirection === `rtl`) {\n      offsetNormalizedForLtr = (itemWidth - offsetNormalizedForLtr) - context.getPageSize().width\n    }\n\n    if (spineItem.isUsingVerticalWriting()) {\n      const numberOfPages = getNumberOfPages(itemHeight, pageHeight)\n\n      return getPageFromOffset(position.y, pageHeight, numberOfPages)\n    } else {\n      const numberOfPages = getNumberOfPages(itemWidth, pageWidth)\n      const pageIndex = getPageFromOffset(offsetNormalizedForLtr, pageWidth, numberOfPages)\n\n      return pageIndex\n    }\n  }\n\n  const getSpineItemOffsetFromAnchor = (anchor: string, spineItem: SpineItem) => {\n    const itemWidth = (spineItem.getElementDimensions()?.width || 0)\n    const pageWidth = context.getPageSize().width\n    const anchorElementBoundingRect = spineItem.getBoundingRectOfElementFromSelector(anchor)\n\n    const offsetOfAnchor = anchorElementBoundingRect?.x || 0\n\n    return getClosestValidOffsetFromApproximateOffsetInPages(offsetOfAnchor, pageWidth, itemWidth)\n  }\n\n  const getSpineItemPositionFromNode = (node: Node, offset: number, spineItem: SpineItem) => {\n    let offsetOfNodeInSpineItem: number | undefined\n\n    // for some reason `img` does not work with range (x always = 0)\n    if (node?.nodeName === `img` || (node?.textContent === `` && node.nodeType === Node.ELEMENT_NODE)) {\n      offsetOfNodeInSpineItem = (node as HTMLElement).getBoundingClientRect().x\n    } else if (node) {\n      const range = node ? getRangeFromNode(node, offset) : undefined\n      offsetOfNodeInSpineItem = range?.getBoundingClientRect().x || offsetOfNodeInSpineItem\n    }\n\n    const spineItemWidth = spineItem.getElementDimensions()?.width || 0\n    const pageWidth = context.getPageSize().width\n\n    if (offsetOfNodeInSpineItem) {\n      const val = getClosestValidOffsetFromApproximateOffsetInPages(offsetOfNodeInSpineItem, pageWidth, spineItemWidth)\n\n      // @todo vertical\n      return { x: val, y: 0 }\n    }\n\n    return undefined\n  }\n\n  /**\n   * @todo handle vertical\n   */\n  const getFirstNodeOrRangeAtPage = (pageIndex: number, spineItem: SpineItem) => {\n    const pageSize = context.getPageSize()\n    const frame = spineItem.spineItemFrame?.getManipulableFrame()?.frame\n\n    if (\n      frame?.contentWindow?.document &&\n      // very important because it is being used by next functions\n      frame.contentWindow.document.body !== null\n    ) {\n      // @todo handle vertical jp\n      // top seems ok but left is not, it should probably not be 0 or something\n      const { x: left, y: top } = getSpineItemPositionFromPageIndex(pageIndex, spineItem)\n      const viewport = {\n        left,\n        right: left + pageSize.width,\n        top,\n        bottom: top + pageSize.height\n      }\n\n      const res = getFirstVisibleNodeForViewport(frame.contentWindow.document, viewport)\n\n      return res\n    }\n\n    return undefined\n  }\n\n  const getSpineItemClosestPositionFromUnsafePosition = (unsafePosition: SpineItemPosition, spineItem: SpineItem) => {\n    const { width, height } = spineItem.getElementDimensions()\n\n    const adjustedPosition = {\n      x: getClosestValidOffsetFromApproximateOffsetInPages(unsafePosition.x, context.getPageSize().width, width),\n      y: getClosestValidOffsetFromApproximateOffsetInPages(unsafePosition.y, context.getPageSize().height, height)\n    }\n\n    return adjustedPosition\n  }\n\n  const getSpineItemPageIndexFromNode = (node: Node, offset: number, spineItem: SpineItem) => {\n    const position = getSpineItemPositionFromNode(node, offset, spineItem)\n\n    return position ? getSpineItemPageIndexFromPosition(position, spineItem) : undefined\n  }\n\n  const getPageFromOffset = (offset: number, pageWidth: number, numberOfPages: number) => {\n    const offsetValues = [...Array(numberOfPages)].map((_, i) => i * pageWidth)\n\n    if (offset <= 0) return 0\n\n    if (offset >= (numberOfPages * pageWidth)) return numberOfPages - 1\n\n    return Math.max(0, offsetValues.findIndex(offsetRange => offset < (offsetRange + pageWidth)))\n  }\n\n  return {\n    getSpineItemPositionFromNode,\n    getSpineItemPositionFromPageIndex,\n    getSpineItemOffsetFromAnchor,\n    getSpineItemPageIndexFromPosition,\n    getSpineItemPageIndexFromNode,\n    getSpineItemClosestPositionFromUnsafePosition,\n    getFirstNodeOrRangeAtPage\n  }\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/locationResolver.ts\n");
|
|
480
|
+
|
|
481
|
+
/***/ }),
|
|
482
|
+
|
|
483
|
+
/***/ "./src/spineItem/navigationResolver.ts":
|
|
484
|
+
/*!*********************************************!*\
|
|
485
|
+
!*** ./src/spineItem/navigationResolver.ts ***!
|
|
486
|
+
\*********************************************/
|
|
487
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
488
|
+
|
|
489
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createNavigationResolver\": () => (/* binding */ createNavigationResolver)\n/* harmony export */ });\n/* harmony import */ var _pagination__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../pagination */ \"./src/pagination.ts\");\n/* harmony import */ var _locationResolver__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./locationResolver */ \"./src/spineItem/locationResolver.ts\");\n\n\nconst createNavigationResolver = ({ context }) => {\n const spineItemLocator = (0,_locationResolver__WEBPACK_IMPORTED_MODULE_1__.createLocationResolver)({ context });\n const getNavigationForLeftPage = (position, spineItem) => {\n let nextPotentialPosition = {\n x: position.x - context.getPageSize().width,\n y: position.y\n };\n if (spineItem.isUsingVerticalWriting()) {\n nextPotentialPosition = {\n x: position.x,\n y: position.y + context.getPageSize().height\n };\n }\n return spineItemLocator.getSpineItemClosestPositionFromUnsafePosition(nextPotentialPosition, spineItem);\n };\n const getNavigationForRightPage = (position, spineItem) => {\n let nextPotentialPosition = {\n x: position.x + context.getPageSize().width,\n y: position.y\n };\n if (spineItem.isUsingVerticalWriting()) {\n nextPotentialPosition = {\n x: position.x,\n y: position.y - context.getPageSize().height\n };\n }\n return spineItemLocator.getSpineItemClosestPositionFromUnsafePosition(nextPotentialPosition, spineItem);\n };\n const getNavigationForLastPage = (spineItem) => {\n if (spineItem.isUsingVerticalWriting()) {\n const pageHeight = context.getPageSize().height;\n const numberOfPages = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getNumberOfPages)(spineItem.getElementDimensions().height, pageHeight);\n return getNavigationForPage(numberOfPages - 1, spineItem);\n }\n else {\n const pageWidth = context.getPageSize().width;\n const numberOfPages = (0,_pagination__WEBPACK_IMPORTED_MODULE_0__.getNumberOfPages)(spineItem.getElementDimensions().width, pageWidth);\n return getNavigationForPage(numberOfPages - 1, spineItem);\n }\n };\n const getNavigationForPage = (pageIndex, spineItem) => {\n const currentViewport = spineItemLocator.getSpineItemPositionFromPageIndex(pageIndex, spineItem);\n return currentViewport;\n };\n const getNavigationFromNode = (spineItem, node, offset) => {\n const position = spineItemLocator.getSpineItemPositionFromNode(node, offset, spineItem);\n return position || { x: 0, y: 0 };\n };\n const getNavigationForPosition = (spineItem, position) => {\n const potentiallyCorrectedPosition = spineItemLocator.getSpineItemClosestPositionFromUnsafePosition(position, spineItem);\n return potentiallyCorrectedPosition;\n };\n return {\n getNavigationForLeftPage,\n getNavigationForRightPage,\n getNavigationForLastPage,\n getNavigationForPage,\n getNavigationForPosition,\n getNavigationFromNode\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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LElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUU7SUFDbkMsQ0FBQztJQUVELE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxTQUFvQixFQUFFLFFBQTJCLEVBQUUsRUFBRTtRQUNyRixNQUFNLDRCQUE0QixHQUFHLGdCQUFnQixDQUFDLDZDQUE2QyxDQUFDLFFBQVEsRUFBRSxTQUFTLENBQUM7UUFFeEgsT0FBTyw0QkFBNEI7SUFDckMsQ0FBQztJQUVELE9BQU87UUFDTCx3QkFBd0I7UUFDeEIseUJBQXlCO1FBQ3pCLHdCQUF3QjtRQUN4QixvQkFBb0I7UUFDcEIsd0JBQXdCO1FBQ3hCLHFCQUFxQjtLQUN0QjtBQUNILENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvc3BpbmVJdGVtL25hdmlnYXRpb25SZXNvbHZlci50cz8yN2NiIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNwaW5lSXRlbSB9IGZyb20gXCIuL2NyZWF0ZVNwaW5lSXRlbVwiXG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIi4uL2NvbnRleHRcIlxuaW1wb3J0IHsgZ2V0TnVtYmVyT2ZQYWdlcyB9IGZyb20gXCIuLi9wYWdpbmF0aW9uXCJcbmltcG9ydCB7IGNyZWF0ZUxvY2F0aW9uUmVzb2x2ZXIgfSBmcm9tIFwiLi9sb2NhdGlvblJlc29sdmVyXCJcblxudHlwZSBTcGluZUl0ZW1Qb3NpdGlvbiA9IHsgeDogbnVtYmVyLCB5OiBudW1iZXIgfVxuXG5leHBvcnQgY29uc3QgY3JlYXRlTmF2aWdhdGlvblJlc29sdmVyID0gKHsgY29udGV4dCB9OiB7IGNvbnRleHQ6IENvbnRleHQgfSkgPT4ge1xuICBjb25zdCBzcGluZUl0ZW1Mb2NhdG9yID0gY3JlYXRlTG9jYXRpb25SZXNvbHZlcih7IGNvbnRleHQgfSlcblxuICBjb25zdCBnZXROYXZpZ2F0aW9uRm9yTGVmdFBhZ2UgPSAocG9zaXRpb246IFNwaW5lSXRlbVBvc2l0aW9uLCBzcGluZUl0ZW06IFNwaW5lSXRlbSk6IFNwaW5lSXRlbVBvc2l0aW9uID0+IHtcbiAgICBsZXQgbmV4dFBvdGVudGlhbFBvc2l0aW9uID0ge1xuICAgICAgeDogcG9zaXRpb24ueCAtIGNvbnRleHQuZ2V0UGFnZVNpemUoKS53aWR0aCxcbiAgICAgIHk6IHBvc2l0aW9uLnlcbiAgICB9XG5cbiAgICBpZiAoc3BpbmVJdGVtLmlzVXNpbmdWZXJ0aWNhbFdyaXRpbmcoKSkge1xuICAgICAgbmV4dFBvdGVudGlhbFBvc2l0aW9uID0ge1xuICAgICAgICB4OiBwb3NpdGlvbi54LFxuICAgICAgICB5OiBwb3NpdGlvbi55ICsgY29udGV4dC5nZXRQYWdlU2l6ZSgpLmhlaWdodFxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzcGluZUl0ZW1Mb2NhdG9yLmdldFNwaW5lSXRlbUNsb3Nlc3RQb3NpdGlvbkZyb21VbnNhZmVQb3NpdGlvbihuZXh0UG90ZW50aWFsUG9zaXRpb24sIHNwaW5lSXRlbSlcbiAgfVxuXG4gIGNvbnN0IGdldE5hdmlnYXRpb25Gb3JSaWdodFBhZ2UgPSAocG9zaXRpb246IFNwaW5lSXRlbVBvc2l0aW9uLCBzcGluZUl0ZW06IFNwaW5lSXRlbSk6IFNwaW5lSXRlbVBvc2l0aW9uID0+IHtcbiAgICBsZXQgbmV4dFBvdGVudGlhbFBvc2l0aW9uID0ge1xuICAgICAgeDogcG9zaXRpb24ueCArIGNvbnRleHQuZ2V0UGFnZVNpemUoKS53aWR0aCxcbiAgICAgIHk6IHBvc2l0aW9uLnlcbiAgICB9XG5cbiAgICBpZiAoc3BpbmVJdGVtLmlzVXNpbmdWZXJ0aWNhbFdyaXRpbmcoKSkge1xuICAgICAgbmV4dFBvdGVudGlhbFBvc2l0aW9uID0ge1xuICAgICAgICB4OiBwb3NpdGlvbi54LFxuICAgICAgICB5OiBwb3NpdGlvbi55IC0gY29udGV4dC5nZXRQYWdlU2l6ZSgpLmhlaWdodFxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzcGluZUl0ZW1Mb2NhdG9yLmdldFNwaW5lSXRlbUNsb3Nlc3RQb3NpdGlvbkZyb21VbnNhZmVQb3NpdGlvbihuZXh0UG90ZW50aWFsUG9zaXRpb24sIHNwaW5lSXRlbSlcbiAgfVxuXG4gIGNvbnN0IGdldE5hdmlnYXRpb25Gb3JMYXN0UGFnZSA9IChzcGluZUl0ZW06IFNwaW5lSXRlbSk6IFNwaW5lSXRlbVBvc2l0aW9uID0+IHtcbiAgICBpZiAoc3BpbmVJdGVtLmlzVXNpbmdWZXJ0aWNhbFdyaXRpbmcoKSkge1xuICAgICAgY29uc3QgcGFnZUhlaWdodCA9IGNvbnRleHQuZ2V0UGFnZVNpemUoKS5oZWlnaHRcbiAgICAgIGNvbnN0IG51bWJlck9mUGFnZXMgPSBnZXROdW1iZXJPZlBhZ2VzKHNwaW5lSXRlbS5nZXRFbGVtZW50RGltZW5zaW9ucygpLmhlaWdodCwgcGFnZUhlaWdodClcbiAgICAgIHJldHVybiBnZXROYXZpZ2F0aW9uRm9yUGFnZShudW1iZXJPZlBhZ2VzIC0gMSwgc3BpbmVJdGVtKVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwYWdlV2lkdGggPSBjb250ZXh0LmdldFBhZ2VTaXplKCkud2lkdGhcbiAgICAgIGNvbnN0IG51bWJlck9mUGFnZXMgPSBnZXROdW1iZXJPZlBhZ2VzKHNwaW5lSXRlbS5nZXRFbGVtZW50RGltZW5zaW9ucygpLndpZHRoLCBwYWdlV2lkdGgpXG4gICAgICByZXR1cm4gZ2V0TmF2aWdhdGlvbkZvclBhZ2UobnVtYmVyT2ZQYWdlcyAtIDEsIHNwaW5lSXRlbSlcbiAgICB9XG4gIH1cblxuICBjb25zdCBnZXROYXZpZ2F0aW9uRm9yUGFnZSA9IChwYWdlSW5kZXg6IG51bWJlciwgc3BpbmVJdGVtOiBTcGluZUl0ZW0pOiBTcGluZUl0ZW1Qb3NpdGlvbiA9PiB7XG4gICAgY29uc3QgY3VycmVudFZpZXdwb3J0ID0gc3BpbmVJdGVtTG9jYXRvci5nZXRTcGluZUl0ZW1Qb3NpdGlvbkZyb21QYWdlSW5kZXgocGFnZUluZGV4LCBzcGluZUl0ZW0pXG5cbiAgICByZXR1cm4gY3VycmVudFZpZXdwb3J0XG4gIH1cblxuICBjb25zdCBnZXROYXZpZ2F0aW9uRnJvbU5vZGUgPSAoc3BpbmVJdGVtOiBTcGluZUl0ZW0sIG5vZGU6IE5vZGUsIG9mZnNldDogbnVtYmVyKSA9PiB7XG4gICAgY29uc3QgcG9zaXRpb24gPSBzcGluZUl0ZW1Mb2NhdG9yLmdldFNwaW5lSXRlbVBvc2l0aW9uRnJvbU5vZGUobm9kZSwgb2Zmc2V0LCBzcGluZUl0ZW0pXG5cbiAgICByZXR1cm4gcG9zaXRpb24gfHwgeyB4OiAwLCB5OiAwIH1cbiAgfVxuXG4gIGNvbnN0IGdldE5hdmlnYXRpb25Gb3JQb3NpdGlvbiA9IChzcGluZUl0ZW06IFNwaW5lSXRlbSwgcG9zaXRpb246IFNwaW5lSXRlbVBvc2l0aW9uKSA9PiB7XG4gICAgY29uc3QgcG90ZW50aWFsbHlDb3JyZWN0ZWRQb3NpdGlvbiA9IHNwaW5lSXRlbUxvY2F0b3IuZ2V0U3BpbmVJdGVtQ2xvc2VzdFBvc2l0aW9uRnJvbVVuc2FmZVBvc2l0aW9uKHBvc2l0aW9uLCBzcGluZUl0ZW0pXG5cbiAgICByZXR1cm4gcG90ZW50aWFsbHlDb3JyZWN0ZWRQb3NpdGlvblxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBnZXROYXZpZ2F0aW9uRm9yTGVmdFBhZ2UsXG4gICAgZ2V0TmF2aWdhdGlvbkZvclJpZ2h0UGFnZSxcbiAgICBnZXROYXZpZ2F0aW9uRm9yTGFzdFBhZ2UsXG4gICAgZ2V0TmF2aWdhdGlvbkZvclBhZ2UsXG4gICAgZ2V0TmF2aWdhdGlvbkZvclBvc2l0aW9uLFxuICAgIGdldE5hdmlnYXRpb25Gcm9tTm9kZVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/spineItem/navigationResolver.ts\n");
|
|
490
|
+
|
|
491
|
+
/***/ }),
|
|
492
|
+
|
|
493
|
+
/***/ "./src/spineItem/prePaginatedSpineItem.ts":
|
|
494
|
+
/*!************************************************!*\
|
|
495
|
+
!*** ./src/spineItem/prePaginatedSpineItem.ts ***!
|
|
496
|
+
\************************************************/
|
|
497
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
498
|
+
|
|
499
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createPrePaginatedSpineItem\": () => (/* binding */ createPrePaginatedSpineItem)\n/* harmony export */ });\n/* harmony import */ var _commonSpineItem__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./commonSpineItem */ \"./src/spineItem/commonSpineItem.ts\");\n\nconst createPrePaginatedSpineItem = ({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ }) => {\n const commonSpineItem = (0,_commonSpineItem__WEBPACK_IMPORTED_MODULE_0__.createCommonSpineItem)({ context, item, parentElement: containerElement, iframeEventBridgeElement, hooks$, viewportState$ });\n const spineItemFrame = commonSpineItem.spineItemFrame;\n const getDimensions = () => {\n const pageSize = context.getPageSize();\n const pageWidth = pageSize.width;\n const columnHeight = pageSize.height;\n const columnWidth = pageWidth;\n return { columnHeight, columnWidth };\n };\n const applySize = ({ blankPagePosition, minimumWidth, spreadPosition }) => {\n var _a;\n const { width: pageWidth, height: pageHeight } = context.getPageSize();\n const { viewportDimensions, computedScale } = commonSpineItem.getViewPortInformation();\n const visibleArea = context.getVisibleAreaRect();\n const frameElement = (_a = spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame;\n if ((spineItemFrame === null || spineItemFrame === void 0 ? void 0 : spineItemFrame.getIsLoaded()) && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentDocument) && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentWindow)) {\n const contentWidth = pageWidth;\n const contentHeight = visibleArea.height + context.getCalculatedInnerMargin();\n const cssLink = buildDocumentStyle(Object.assign(Object.assign({}, getDimensions()), { enableTouch: context.getSettings().computedPageTurnMode !== `scrollable`, spreadPosition }), viewportDimensions);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`visibility`, `visible`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`opacity`, `1`);\n if (viewportDimensions) {\n commonSpineItem.injectStyle(cssLink);\n spineItemFrame.staticLayout({\n width: viewportDimensions.width,\n height: viewportDimensions.height\n });\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`--scale`, `${computedScale}`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`position`, `absolute`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`top`, `50%`);\n if (spreadPosition === `left`) {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`right`, `0`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`left`);\n }\n else if (blankPagePosition === `before` && context.isRTL()) {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`right`, `50%`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`left`);\n }\n else if (spreadPosition === `right`) {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`left`, `0`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`right`);\n }\n else {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`left`, blankPagePosition === `before`\n ? context.isRTL() ? `25%` : `75%`\n : blankPagePosition === `after`\n ? context.isRTL() ? `75%` : `25%`\n : `50%`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`right`);\n }\n const transformTranslateX = spreadPosition !== `none`\n ? `0`\n : `-50%`;\n const transformOriginX = (spreadPosition === `right` && blankPagePosition !== `before`)\n ? `left`\n : (spreadPosition === `left` || (blankPagePosition === `before` && context.isRTL()))\n ? `right`\n : `center`;\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`transform`, `translate(${transformTranslateX}, -50%) scale(${computedScale})`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`transform-origin`, `${transformOriginX} center`);\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n }\n else {\n commonSpineItem.injectStyle(cssLink);\n spineItemFrame.staticLayout({\n width: contentWidth,\n height: contentHeight\n });\n if (blankPagePosition === `before`) {\n if (context.isRTL()) {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`margin-right`, `${pageWidth}px`);\n }\n else {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`margin-left`, `${pageWidth}px`);\n }\n }\n else {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`margin-left`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.removeProperty(`margin-right`);\n }\n }\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n commonSpineItem.layout({ width: minimumWidth, height: contentHeight });\n return { width: minimumWidth, height: contentHeight };\n }\n else {\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n commonSpineItem.layout({ width: minimumWidth, height: pageHeight });\n }\n return { width: minimumWidth, height: pageHeight };\n };\n const layout = (layoutInformation) => {\n return applySize(layoutInformation);\n };\n return Object.assign(Object.assign({}, commonSpineItem), { layout });\n};\nconst buildDocumentStyle = ({ columnWidth, enableTouch, spreadPosition }, viewportDimensions) => {\n return `\n body {\n \n }\n body {\n margin: 0;\n ${!viewportDimensions\n ? `\n display: flex;\n justify-content: ${spreadPosition === `left` ? `flex-end` : spreadPosition === `right` ? `flex-start` : `center`};\n `\n : ``}\n }\n ${``}\n html, body {\n height: 100%;\n width: 100%;\n }\n ${``}\n html, body {\n -max-width: ${columnWidth}px !important;\n }\n ${``}\n html, body {\n ${enableTouch\n ? `\n touch-action: none\n `\n : ``}\n }\n ${``}\n img {\n user-select: none;\n -webkit-user-drag: none;\n -khtml-user-drag: none;\n -moz-user-drag: none;\n -o-user-drag: none;\n user-drag: none;\n ${``}\n display: flex;\n ${``}\n ${!viewportDimensions\n ? `\n -width: 100%;\n max-width: 100%;\n height:100%;\n object-fit:contain;\n `\n : ``}\n }\n `;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/prePaginatedSpineItem.ts.js","mappings":";;;;;AAIyD;AAElD,MAAM,2BAA2B,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,EAAE,cAAc,EAO9H,EAAE,EAAE;IACH,MAAM,eAAe,GAAG,uEAAqB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC;IACnJ,MAAM,cAAc,GAAG,eAAe,CAAC,cAAc;IAErD,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE;QACtC,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK;QAChC,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM;QACpC,MAAM,WAAW,GAAG,SAAS;QAE7B,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE;IACtC,CAAC;IAED,MAAM,SAAS,GAAG,CAAC,EAAE,iBAAiB,EAAE,YAAY,EAAE,cAAc,EAAuH,EAAE,EAAE;;QAC7L,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,WAAW,EAAE;QACtE,MAAM,EAAE,kBAAkB,EAAE,aAAa,EAAE,GAAG,eAAe,CAAC,sBAAsB,EAAE;QACtF,MAAM,WAAW,GAAG,OAAO,CAAC,kBAAkB,EAAE;QAChD,MAAM,YAAY,GAAG,oBAAc,CAAC,mBAAmB,EAAE,0CAAE,KAAK;QAEhE,IAAI,eAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,WAAW,EAAE,MAAI,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,eAAe,MAAI,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,aAAa,GAAE;YACjG,MAAM,YAAY,GAAG,SAAS;YAC9B,MAAM,aAAa,GAAG,WAAW,CAAC,MAAM,GAAG,OAAO,CAAC,wBAAwB,EAAE;YAE7E,MAAM,OAAO,GAAG,kBAAkB,iCAC7B,aAAa,EAAE,KAClB,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,oBAAoB,KAAK,YAAY,EACxE,cAAc,KACb,kBAAkB,CAAC;YAEtB,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,YAAY,EAAE,SAAS,CAAC;YACxD,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,GAAG,CAAC;YAE/C,IAAI,kBAAkB,EAAE;gBACtB,eAAe,CAAC,WAAW,CAAC,OAAO,CAAC;gBACpC,cAAc,CAAC,YAAY,CAAC;oBAC1B,KAAK,EAAE,kBAAkB,CAAC,KAAK;oBAC/B,MAAM,EAAE,kBAAkB,CAAC,MAAM;iBAClC,CAAC;gBACF,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,GAAG,aAAa,EAAE,CAAC;gBAC9D,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,UAAU,EAAE,UAAU,CAAC;gBACvD,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC;gBAC7C,IAAI,cAAc,KAAK,MAAM,EAAE;oBAC7B,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC;oBAC7C,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC;iBAC3C;qBAAM,IAAI,iBAAiB,KAAK,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,EAAE;oBAC5D,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC;oBAC/C,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC;iBAC3C;qBAAM,IAAI,cAAc,KAAK,OAAO,EAAE;oBACrC,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC;oBAC5C,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;iBAC5C;qBAAM;oBACL,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,MAAM,EACpC,iBAAiB,KAAK,QAAQ;wBAC5B,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;wBACjC,CAAC,CAAC,iBAAiB,KAAK,OAAO;4BAC7B,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;4BACjC,CAAC,CAAC,KAAK,CACZ;oBACD,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;iBAC5C;gBACD,MAAM,mBAAmB,GACvB,cAAc,KAAK,MAAM;oBACvB,CAAC,CAAC,GAAG;oBACL,CAAC,CAAC,MAAM;gBACZ,MAAM,gBAAgB,GACpB,CAAC,cAAc,KAAK,OAAO,IAAI,iBAAiB,KAAK,QAAQ,CAAC;oBAC5D,CAAC,CAAC,MAAM;oBACR,CAAC,CAAC,CAAC,cAAc,KAAK,MAAM,IAAI,CAAC,iBAAiB,KAAK,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;wBAChF,CAAC,CAAC,OAAO;wBACT,CAAC,CAAC,QAAQ;gBAClB,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,aAAa,mBAAmB,iBAAiB,aAAa,GAAG,CAAC;gBAC/G,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,kBAAkB,EAAE,GAAG,gBAAgB,SAAS,CAAC;gBAEjF,eAAe,CAAC,mCAAmC,CAAC,EAAE,YAAY,EAAE,CAAC;aACtE;iBAAM;gBACL,eAAe,CAAC,WAAW,CAAC,OAAO,CAAC;gBACpC,cAAc,CAAC,YAAY,CAAC;oBAC1B,KAAK,EAAE,YAAY;oBACnB,MAAM,EAAE,aAAa;iBACtB,CAAC;gBACF,IAAI,iBAAiB,KAAK,QAAQ,EAAE;oBAClC,IAAI,OAAO,CAAC,KAAK,EAAE,EAAE;wBACnB,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,cAAc,EAAE,GAAG,SAAS,IAAI,CAAC;qBAClE;yBAAM;wBACL,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,SAAS,IAAI,CAAC;qBACjE;iBACF;qBAAM;oBACL,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,aAAa,CAAC;oBACjD,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;iBACnD;aACF;YAED,eAAe,CAAC,mCAAmC,CAAC,EAAE,YAAY,EAAE,CAAC;YAGrE,eAAe,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;YAEtE,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE;SACtD;aAAM;YACL,eAAe,CAAC,mCAAmC,CAAC,EAAE,YAAY,EAAE,CAAC;YAErE,eAAe,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;SACpE;QAED,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE;IACpD,CAAC;IAED,MAAM,MAAM,GAAG,CAAC,iBAAsI,EAAE,EAAE;QACxJ,OAAO,SAAS,CAAC,iBAAiB,CAAC;IACrC,CAAC;IAED,uCACK,eAAe,KAClB,MAAM,IACP;AACH,CAAC;AAED,MAAM,kBAAkB,GAAG,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,EAKrE,EAAE,kBAAiE,EAAE,EAAE;IACtE,OAAO;;;;;;QAMD,CAAC,kBAAkB;QACrB,CAAC,CAAC;;2BAEmB,cAAc,KAAK,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,cAAc,KAAK,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ;OACjH;QACD,CAAC,CAAC,EAAE;;MAKJ,EAAE;;;;;MAQF,EAAE;;oBAEY,WAAW;;MAO3B,EAAE;;QAEE,WAAW;QACb,CAAC,CAAC;;OAED;QACD,CAAC,CAAC,EAAE;;MAIJ,EAAE;;;;;;;;QAUA,EAAE;;QAOF,EAAE;QACF,CAAC,kBAAkB;QACrB,CAAC,CAAC;;;;;OAKD;QACD,CAAC,CAAC,EAAE;;GAEP;AACH,CAAC","sources":["webpack://@prose-reader/core/./src/spineItem/prePaginatedSpineItem.ts?e13b"],"sourcesContent":["import { BehaviorSubject, Observable } from \"rxjs\"\nimport { Context } from \"../context\"\nimport { Manifest } from \"../types\"\nimport { Hook } from \"../types/Hook\"\nimport { createCommonSpineItem } from \"./commonSpineItem\"\n\nexport const createPrePaginatedSpineItem = ({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ }: {\n  item: Manifest[`spineItems`][number],\n  containerElement: HTMLElement,\n  iframeEventBridgeElement: HTMLElement,\n  context: Context,\n  hooks$: BehaviorSubject<Hook[]>,\n  viewportState$: Observable<`free` | `busy`>\n}) => {\n  const commonSpineItem = createCommonSpineItem({ context, item, parentElement: containerElement, iframeEventBridgeElement, hooks$, viewportState$ })\n  const spineItemFrame = commonSpineItem.spineItemFrame\n\n  const getDimensions = () => {\n    const pageSize = context.getPageSize()\n    const pageWidth = pageSize.width\n    const columnHeight = pageSize.height\n    const columnWidth = pageWidth\n\n    return { columnHeight, columnWidth }\n  }\n\n  const applySize = ({ blankPagePosition, minimumWidth, spreadPosition }: { blankPagePosition: `before` | `after` | `none`, minimumWidth: number, spreadPosition: `none` | `left` | `right` }) => {\n    const { width: pageWidth, height: pageHeight } = context.getPageSize()\n    const { viewportDimensions, computedScale } = commonSpineItem.getViewPortInformation()\n    const visibleArea = context.getVisibleAreaRect()\n    const frameElement = spineItemFrame.getManipulableFrame()?.frame\n\n    if (spineItemFrame?.getIsLoaded() && frameElement?.contentDocument && frameElement?.contentWindow) {\n      const contentWidth = pageWidth\n      const contentHeight = visibleArea.height + context.getCalculatedInnerMargin()\n\n      const cssLink = buildDocumentStyle({\n        ...getDimensions(),\n        enableTouch: context.getSettings().computedPageTurnMode !== `scrollable`,\n        spreadPosition\n      }, viewportDimensions)\n\n      frameElement?.style.setProperty(`visibility`, `visible`)\n      frameElement?.style.setProperty(`opacity`, `1`)\n\n      if (viewportDimensions) {\n        commonSpineItem.injectStyle(cssLink)\n        spineItemFrame.staticLayout({\n          width: viewportDimensions.width,\n          height: viewportDimensions.height\n        })\n        frameElement?.style.setProperty(`--scale`, `${computedScale}`)\n        frameElement?.style.setProperty(`position`, `absolute`)\n        frameElement?.style.setProperty(`top`, `50%`)\n        if (spreadPosition === `left`) {\n          frameElement?.style.setProperty(`right`, `0`)\n          frameElement?.style.removeProperty(`left`)\n        } else if (blankPagePosition === `before` && context.isRTL()) {\n          frameElement?.style.setProperty(`right`, `50%`)\n          frameElement?.style.removeProperty(`left`)\n        } else if (spreadPosition === `right`) {\n          frameElement?.style.setProperty(`left`, `0`)\n          frameElement?.style.removeProperty(`right`)\n        } else {\n          frameElement?.style.setProperty(`left`,\n            blankPagePosition === `before`\n              ? context.isRTL() ? `25%` : `75%`\n              : blankPagePosition === `after`\n                ? context.isRTL() ? `75%` : `25%`\n                : `50%`\n          )\n          frameElement?.style.removeProperty(`right`)\n        }\n        const transformTranslateX =\n          spreadPosition !== `none`\n            ? `0`\n            : `-50%`\n        const transformOriginX =\n          (spreadPosition === `right` && blankPagePosition !== `before`)\n            ? `left`\n            : (spreadPosition === `left` || (blankPagePosition === `before` && context.isRTL()))\n                ? `right`\n                : `center`\n        frameElement?.style.setProperty(`transform`, `translate(${transformTranslateX}, -50%) scale(${computedScale})`)\n        frameElement?.style.setProperty(`transform-origin`, `${transformOriginX} center`)\n\n        commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n      } else {\n        commonSpineItem.injectStyle(cssLink)\n        spineItemFrame.staticLayout({\n          width: contentWidth,\n          height: contentHeight\n        })\n        if (blankPagePosition === `before`) {\n          if (context.isRTL()) {\n            frameElement?.style.setProperty(`margin-right`, `${pageWidth}px`)\n          } else {\n            frameElement?.style.setProperty(`margin-left`, `${pageWidth}px`)\n          }\n        } else {\n          frameElement?.style.removeProperty(`margin-left`)\n          frameElement?.style.removeProperty(`margin-right`)\n        }\n      }\n\n      commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n\n      // commonSpineItem.layout({ width: minimumWidth, height: contentHeight, minimumWidth, blankPagePosition })\n      commonSpineItem.layout({ width: minimumWidth, height: contentHeight })\n\n      return { width: minimumWidth, height: contentHeight }\n    } else {\n      commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n      // commonSpineItem.layout({ width: minimumWidth, height: pageHeight, minimumWidth, blankPagePosition })\n      commonSpineItem.layout({ width: minimumWidth, height: pageHeight })\n    }\n\n    return { width: minimumWidth, height: pageHeight }\n  }\n\n  const layout = (layoutInformation: { blankPagePosition: `before` | `after` | `none`, minimumWidth: number, spreadPosition: `none` | `left` | `right` }) => {\n    return applySize(layoutInformation)\n  }\n\n  return {\n    ...commonSpineItem,\n    layout\n  }\n}\n\nconst buildDocumentStyle = ({ columnWidth, enableTouch, spreadPosition }: {\n  columnWidth: number,\n  columnHeight: number,\n  enableTouch: boolean,\n  spreadPosition: `none` | `left` | `right`\n}, viewportDimensions: { height: number, width: number } | undefined) => {\n  return `\n    body {\n      \n    }\n    body {\n      margin: 0;\n      ${!viewportDimensions\n      ? `\n        display: flex;\n        justify-content: ${spreadPosition === `left` ? `flex-end` : spreadPosition === `right` ? `flex-start` : `center`};\n      `\n      : ``}\n    }\n    ${/*\n      might be html * but it does mess up things like figure if so.\n      check accessible_epub_3\n    */``}\n    html, body {\n      height: 100%;\n      width: 100%;\n    }\n    ${/*\n      This one is important for preventing 100% img to resize above\n      current width. Especially needed for cbz conversion\n    */``}\n    html, body {\n      -max-width: ${columnWidth}px !important;\n    }\n    ${\n    /*\n     * @see https://hammerjs.github.io/touch-action/\n     * It needs to be disabled when using free scroll\n     */\n    ``}\n    html, body {\n      ${enableTouch\n      ? `\n        touch-action: none\n      `\n      : ``}\n    }\n    ${/*\n      prevent drag of image instead of touch on firefox\n    */``}\n    img {\n      user-select: none;\n      -webkit-user-drag: none;\n      -khtml-user-drag: none;\n      -moz-user-drag: none;\n      -o-user-drag: none;\n      user-drag: none;\n      ${/*\n        prevent weird overflow or margin. Try `block` if `flex` has weird behavior\n      */``}\n      display: flex;\n      ${/*\n        If the document does not have viewport, we cannot scale anything inside.\n        This should never happens with a valid epub document however it will happens if\n        we load .jpg, .png, etc directly in the iframe. This is expected, in this case we force\n        the inner content to display correctly.\n      */``}\n      ${!viewportDimensions\n      ? `\n        -width: 100%;\n        max-width: 100%;\n        height:100%;\n        object-fit:contain;\n      `\n      : ``}\n    }\n  `\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/prePaginatedSpineItem.ts\n");
|
|
500
|
+
|
|
501
|
+
/***/ }),
|
|
502
|
+
|
|
503
|
+
/***/ "./src/spineItem/reflowableSpineItem.ts":
|
|
504
|
+
/*!**********************************************!*\
|
|
505
|
+
!*** ./src/spineItem/reflowableSpineItem.ts ***!
|
|
506
|
+
\**********************************************/
|
|
507
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
508
|
+
|
|
509
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createReflowableSpineItem\": () => (/* binding */ createReflowableSpineItem)\n/* harmony export */ });\n/* harmony import */ var _commonSpineItem__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./commonSpineItem */ \"./src/spineItem/commonSpineItem.ts\");\n\nconst createReflowableSpineItem = ({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ }) => {\n const commonSpineItem = (0,_commonSpineItem__WEBPACK_IMPORTED_MODULE_0__.createCommonSpineItem)({ context, item, parentElement: containerElement, iframeEventBridgeElement, hooks$, viewportState$ });\n const spineItemFrame = commonSpineItem.spineItemFrame;\n let latestContentHeightWhenLoaded;\n const getDimensions = (isUsingVerticalWriting, minimumWidth) => {\n const pageSize = context.getPageSize();\n const horizontalMargin = 0;\n const verticalMargin = 0;\n let columnWidth = pageSize.width - (horizontalMargin * 2);\n const columnHeight = pageSize.height - (verticalMargin * 2);\n let width = pageSize.width - (horizontalMargin * 2);\n if (isUsingVerticalWriting) {\n width = minimumWidth - (horizontalMargin * 2);\n columnWidth = columnHeight;\n }\n return {\n columnHeight,\n columnWidth,\n width\n };\n };\n const layout = ({ blankPagePosition, minimumWidth }) => {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n const { width: pageWidth, height: pageHeight } = context.getPageSize();\n (_b = (_a = spineItemFrame.getManipulableFrame()) === null || _a === void 0 ? void 0 : _a.frame) === null || _b === void 0 ? void 0 : _b.style.setProperty(`width`, `${pageWidth}px`);\n (_d = (_c = spineItemFrame.getManipulableFrame()) === null || _c === void 0 ? void 0 : _c.frame) === null || _d === void 0 ? void 0 : _d.style.setProperty(`height`, `${pageHeight}px`);\n const viewportDimensions = spineItemFrame.getViewportDimensions();\n const visibleArea = context.getVisibleAreaRect();\n const frameElement = (_e = spineItemFrame.getManipulableFrame()) === null || _e === void 0 ? void 0 : _e.frame;\n const isGloballyPrePaginated = ((_f = context.getManifest()) === null || _f === void 0 ? void 0 : _f.renditionLayout) === `pre-paginated`;\n if ((spineItemFrame === null || spineItemFrame === void 0 ? void 0 : spineItemFrame.getIsLoaded()) && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentDocument) && (frameElement === null || frameElement === void 0 ? void 0 : frameElement.contentWindow)) {\n let contentWidth = pageWidth;\n let contentHeight = visibleArea.height + context.getCalculatedInnerMargin();\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`visibility`, `visible`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`opacity`, `1`);\n if (viewportDimensions) {\n const computedScale = Math.min(pageWidth / viewportDimensions.width, pageHeight / viewportDimensions.height);\n commonSpineItem.injectStyle(buildStyleForFakePrePaginated());\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n spineItemFrame.staticLayout({\n width: viewportDimensions.width,\n height: viewportDimensions.height\n });\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`--scale`, `${computedScale}`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`position`, `absolute`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`top`, `50%`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`left`, blankPagePosition === `before`\n ? context.isRTL() ? `25%` : `75%`\n : blankPagePosition === `after`\n ? context.isRTL() ? `75%` : `25%`\n : `50%`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`transform`, `translate(-50%, -50%) scale(${computedScale})`);\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`transform-origin`, `center center`);\n }\n else {\n const frameStyle = commonSpineItem.isImageType()\n ? buildStyleForReflowableImageOnly({\n isScrollable: ((_g = context.getManifest()) === null || _g === void 0 ? void 0 : _g.renditionFlow) === `scrolled-continuous`,\n enableTouch: context.getSettings().computedPageTurnMode !== `scrollable`\n })\n : buildStyleWithMultiColumn(getDimensions(spineItemFrame.isUsingVerticalWriting(), minimumWidth));\n commonSpineItem.injectStyle(frameStyle);\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n if (spineItemFrame.isUsingVerticalWriting()) {\n const pages = Math.ceil(frameElement.contentDocument.documentElement.scrollHeight / pageHeight);\n contentHeight = pages * pageHeight;\n spineItemFrame.staticLayout({\n width: minimumWidth,\n height: contentHeight\n });\n }\n else if (((_h = context.getManifest()) === null || _h === void 0 ? void 0 : _h.renditionFlow) === `scrolled-continuous`) {\n contentHeight = frameElement.contentDocument.documentElement.scrollHeight;\n latestContentHeightWhenLoaded = contentHeight;\n spineItemFrame.staticLayout({\n width: minimumWidth,\n height: contentHeight\n });\n }\n else {\n const pages = Math.ceil(frameElement.contentDocument.documentElement.scrollWidth / pageWidth);\n if (isGloballyPrePaginated) {\n contentWidth = pageWidth;\n }\n else {\n contentWidth = pages * pageWidth;\n }\n spineItemFrame.staticLayout({\n width: contentWidth,\n height: contentHeight\n });\n }\n }\n const isFillingAllScreen = contentWidth % minimumWidth === 0;\n if (!isFillingAllScreen) {\n contentWidth = contentWidth + pageWidth;\n if (context.isRTL() && !commonSpineItem.isUsingVerticalWriting()) {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`margin-left`, `${pageWidth}px`);\n }\n }\n else {\n frameElement === null || frameElement === void 0 ? void 0 : frameElement.style.setProperty(`margin-left`, `0px`);\n }\n commonSpineItem.layout({ width: contentWidth, height: contentHeight });\n return { width: contentWidth, height: contentHeight };\n }\n else {\n commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth });\n }\n const height = latestContentHeightWhenLoaded || pageHeight;\n commonSpineItem.layout({ width: minimumWidth, height });\n return { width: minimumWidth, height };\n };\n return Object.assign(Object.assign({}, commonSpineItem), { isReflowable: true, layout });\n};\nconst buildStyleForFakePrePaginated = () => {\n return `\n html {\n width: 100%;\n height: 100%;\n }\n body {\n width: 100%;\n height: 100%;\n margin: 0;\n }\n ${``}\n html, body {\n touch-action: none;\n }\n img {\n display: flex;\n max-width: 100%;\n max-height: 100%;\n margin: 0 auto;\n }\n `;\n};\nconst buildStyleForReflowableImageOnly = ({ isScrollable, enableTouch }) => {\n return `\n html {\n }\n body {\n }\n ${``}\n html, body {\n width: 100%;\n margin: 0;\n padding: 0;\n ${enableTouch\n ? `\n touch-action: none\n `\n : ``}\n }\n ${isScrollable\n ? `\n img {\n height: auto !important;\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n ${``}\n display: block;\n }\n `\n : ``}\n `;\n};\nconst buildStyleWithMultiColumn = ({ width, columnHeight, columnWidth }) => {\n return `\n parsererror {\n display: none !important;\n }\n ${``}\n html, body {\n margin: 0;\n padding: 0 !important;\n -max-width: ${columnWidth}px !important;\n }\n ${``}\n body {\n padding: 0 !important;\n width: ${width}px !important;\n height: ${columnHeight}px !important;\n overflow-y: hidden;\n column-gap: 0px !important;\n column-width: ${columnWidth}px !important;\n column-fill: auto !important;\n word-wrap: break-word;\n box-sizing: border-box;\n }\n body {\n margin: 0;\n }\n body:focus-visible {\n ${``}\n outline: none;\n }\n ${``}\n html, body {\n touch-action: none;\n }\n ${``}\n * {\n -max-width: ${columnWidth}px !important;\n }\n ${``}\n img, video, audio, object, svg {\n max-width: 100%;\n max-width: ${columnWidth}px !important;\n max-height: ${columnHeight}px !important;\n -pointer-events: none;\n -webkit-column-break-inside: avoid;\n page-break-inside: avoid;\n break-inside: avoid;\n }\n figure {\n d-max-width: ${columnWidth}px !important;\n }\n img {\n object-fit: contain;\n break-inside: avoid;\n box-sizing: border-box;\n d-max-width: ${columnWidth}px !important;\n }\n ${``}\n table {\n max-width: ${columnWidth}px !important;\n table-layout: fixed;\n }\n td {\n max-width: ${columnWidth}px;\n }\n `;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItem/reflowableSpineItem.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItem/reflowableSpineItem.ts?080d"],"sourcesContent":["import { BehaviorSubject, Observable } from \"rxjs\"\nimport { Context } from \"../context\"\nimport { Manifest } from \"../types\"\nimport { Hook } from \"../types/Hook\"\nimport { createCommonSpineItem } from \"./commonSpineItem\"\n\nexport const createReflowableSpineItem = ({ item, context, containerElement, iframeEventBridgeElement, hooks$, viewportState$ }: {\n  item: Manifest[`spineItems`][number],\n  containerElement: HTMLElement,\n  iframeEventBridgeElement: HTMLElement,\n  context: Context,\n  hooks$: BehaviorSubject<Hook[]>,\n  viewportState$: Observable<`free` | `busy`>\n}) => {\n  const commonSpineItem = createCommonSpineItem({ context, item, parentElement: containerElement, iframeEventBridgeElement, hooks$, viewportState$ })\n  const spineItemFrame = commonSpineItem.spineItemFrame\n  /**\n   * This value is being used to avoid item to shrink back to smaller size when getting a layout after\n   * the content has been loaded.\n   * This means when previous content get unload, the user does not end up farther than he should be due to previous content\n   * shrinking.\n   *\n   * @important\n   * For now it's only used for continuous-scroll as experimental test. This could potentially solve the sliding\n   * issue with reflow content as wel.\n   */\n  let latestContentHeightWhenLoaded: number | undefined\n\n  const getDimensions = (isUsingVerticalWriting: boolean, minimumWidth: number) => {\n    const pageSize = context.getPageSize()\n    const horizontalMargin = 0\n    const verticalMargin = 0\n    let columnWidth = pageSize.width - (horizontalMargin * 2)\n    const columnHeight = pageSize.height - (verticalMargin * 2)\n    let width = pageSize.width - (horizontalMargin * 2)\n\n    if (isUsingVerticalWriting) {\n      width = minimumWidth - (horizontalMargin * 2)\n      columnWidth = columnHeight\n    }\n\n    return {\n      columnHeight,\n      columnWidth,\n      // horizontalMargin,\n      // verticalMargin,\n      width\n    }\n  }\n\n  const layout = ({ blankPagePosition, minimumWidth }: { blankPagePosition: `before` | `after` | `none`, minimumWidth: number }) => {\n    const { width: pageWidth, height: pageHeight } = context.getPageSize()\n    // reset width of iframe to be able to retrieve real size later\n    spineItemFrame.getManipulableFrame()?.frame?.style.setProperty(`width`, `${pageWidth}px`)\n    spineItemFrame.getManipulableFrame()?.frame?.style.setProperty(`height`, `${pageHeight}px`)\n\n    const viewportDimensions = spineItemFrame.getViewportDimensions()\n    const visibleArea = context.getVisibleAreaRect()\n    const frameElement = spineItemFrame.getManipulableFrame()?.frame\n    const isGloballyPrePaginated = context.getManifest()?.renditionLayout === `pre-paginated`\n\n    if (spineItemFrame?.getIsLoaded() && frameElement?.contentDocument && frameElement?.contentWindow) {\n      let contentWidth = pageWidth\n      let contentHeight = visibleArea.height + context.getCalculatedInnerMargin()\n\n      frameElement?.style.setProperty(`visibility`, `visible`)\n      frameElement?.style.setProperty(`opacity`, `1`)\n\n      if (viewportDimensions) {\n        const computedScale = Math.min(pageWidth / viewportDimensions.width, pageHeight / viewportDimensions.height)\n        commonSpineItem.injectStyle(buildStyleForFakePrePaginated())\n\n        commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n\n        spineItemFrame.staticLayout({\n          width: viewportDimensions.width,\n          height: viewportDimensions.height\n        })\n        frameElement?.style.setProperty(`--scale`, `${computedScale}`)\n        frameElement?.style.setProperty(`position`, `absolute`)\n        frameElement?.style.setProperty(`top`, `50%`)\n        frameElement?.style.setProperty(`left`,\n          blankPagePosition === `before`\n            ? context.isRTL() ? `25%` : `75%`\n            : blankPagePosition === `after`\n              ? context.isRTL() ? `75%` : `25%`\n              : `50%`\n        )\n        frameElement?.style.setProperty(`transform`, `translate(-50%, -50%) scale(${computedScale})`)\n        frameElement?.style.setProperty(`transform-origin`, `center center`)\n      } else {\n        const frameStyle = commonSpineItem.isImageType()\n          ? buildStyleForReflowableImageOnly({\n            isScrollable: context.getManifest()?.renditionFlow === `scrolled-continuous`,\n            enableTouch: context.getSettings().computedPageTurnMode !== `scrollable`\n          })\n          : buildStyleWithMultiColumn(getDimensions(spineItemFrame.isUsingVerticalWriting(), minimumWidth))\n\n        commonSpineItem.injectStyle(frameStyle)\n\n        commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n\n        if (spineItemFrame.isUsingVerticalWriting()) {\n          const pages = Math.ceil(\n            frameElement.contentDocument.documentElement.scrollHeight / pageHeight\n          )\n          contentHeight = pages * pageHeight\n\n          spineItemFrame.staticLayout({\n            width: minimumWidth,\n            height: contentHeight\n          })\n        } else if (context.getManifest()?.renditionFlow === `scrolled-continuous`) {\n          contentHeight = frameElement.contentDocument.documentElement.scrollHeight\n          latestContentHeightWhenLoaded = contentHeight\n\n          spineItemFrame.staticLayout({\n            width: minimumWidth,\n            height: contentHeight\n          })\n        } else {\n          const pages = Math.ceil(\n            frameElement.contentDocument.documentElement.scrollWidth / pageWidth\n          )\n          /**\n           * It is possible that a pre-paginated epub has reflowable item inside it. This is weird because\n           * the spec says that we should use pre-paginated for each spine item. Could be a publisher mistake, in\n           * any case we follow the spec and enforce the iframe to be contained within page width.\n           * If we don't respect the spec we end up with dynamic pagination for a fixed document, which can update\n           * the correct number of pages when item is loaded/unload. Bringing weird user experience.\n           * The publisher should use global reflowable with pre-paginated content instead.\n           */\n          if (isGloballyPrePaginated) {\n            contentWidth = pageWidth\n          } else {\n            contentWidth = pages * pageWidth\n          }\n\n          spineItemFrame.staticLayout({\n            width: contentWidth,\n            height: contentHeight\n          })\n        }\n      }\n\n      const isFillingAllScreen = contentWidth % minimumWidth === 0\n\n      // when a reflow iframe does not fill the entire screen (when spread) we will\n      // enlarge the container to make sure no other reflow item starts on the same screen\n      if (!isFillingAllScreen) {\n        contentWidth = contentWidth + pageWidth\n        if (context.isRTL() && !commonSpineItem.isUsingVerticalWriting()) {\n          frameElement?.style.setProperty(`margin-left`, `${pageWidth}px`)\n        }\n      } else {\n        frameElement?.style.setProperty(`margin-left`, `0px`)\n      }\n\n      commonSpineItem.layout({ width: contentWidth, height: contentHeight })\n\n      return { width: contentWidth, height: contentHeight }\n    } else {\n      commonSpineItem.executeOnLayoutBeforeMeasurmentHook({ minimumWidth })\n    }\n\n    const height = latestContentHeightWhenLoaded || pageHeight\n\n    commonSpineItem.layout({ width: minimumWidth, height })\n\n    return { width: minimumWidth, height }\n  }\n\n  return {\n    ...commonSpineItem,\n    isReflowable: true,\n    layout\n  }\n}\n\n/**\n * Item is:\n * - anything that contains a defined width/height viewport\n *\n * In this case we respect the viewport, scale it and act as pre-paginated\n */\nconst buildStyleForFakePrePaginated = () => {\n  return `\n    html {\n      width: 100%;\n      height: 100%;\n    }\n    body {\n      width: 100%;\n      height: 100%;\n      margin: 0;\n    }\n    ${\n    /*\n     * @see https://hammerjs.github.io/touch-action/\n     */\n    ``}\n    html, body {\n      touch-action: none;\n    }\n    img {\n      display: flex;\n      max-width: 100%;\n      max-height: 100%;\n      margin: 0 auto;\n    }\n  `\n}\n\n/**\n * Item is:\n * - not pre-paginated (we would not be in this item otherwise)\n * - jpg, png, etc\n *\n * It does not means it has to be pre-paginated (scrollable for example)\n */\nconst buildStyleForReflowableImageOnly = ({ isScrollable, enableTouch }: { enableTouch: boolean, isScrollable: boolean }) => {\n  return `\n    html {\n    }\n    body {\n    }\n    ${\n    /*\n     * @see https://hammerjs.github.io/touch-action/\n     */\n    ``}\n    html, body {\n      width: 100%;\n      margin: 0;\n      padding: 0;\n      ${enableTouch\n      ? `\n        touch-action: none\n      `\n      : ``}\n    }\n    ${isScrollable\n      ? `\n      img {\n        height: auto !important;\n        margin: 0;\n        padding: 0;\n        box-sizing: border-box;\n        ${\n      /**\n       * line break issue\n       * @see https://stackoverflow.com/questions/37869020/image-not-taking-up-the-full-height-of-container\n       */\n      ``}\n        display: block;\n      }\n    `\n      : ``}\n  `\n}\n\n/**\n * Item is:\n * - regular html document\n * - does not contain defined width/height viewport\n *\n * We use css multi column to paginate it\n *\n * @important\n * The style here does not takes margin into account, we assume everything is 0.\n * It is being handled by enhancer.\n */\nconst buildStyleWithMultiColumn = ({\n  width,\n  columnHeight,\n  columnWidth\n}: {\n  width: number,\n  columnWidth: number,\n  columnHeight: number,\n}) => {\n  return `\n    parsererror {\n      display: none !important;\n    }\n    ${/*\n      might be html * but it does mess up things like figure if so.\n      check accessible_epub_3\n    */``}\n    html, body {\n      margin: 0;\n      padding: 0 !important;\n      -max-width: ${columnWidth}px !important;\n    }\n    ${/*\n      body {\n        height: ${columnHeight}px !important;\n        width: ${columnWidth}px !important;\n        -margin-left: ${horizontalMargin}px !important;\n        -margin-right: ${horizontalMargin}px !important;\n        -margin: ${verticalMargin}px ${horizontalMargin}px !important;\n        -padding-top: ${horizontalMargin}px !important;\n        -padding-bottom: ${horizontalMargin}px !important;\n      }\n    */``}\n    body {\n      padding: 0 !important;\n      width: ${width}px !important;\n      height: ${columnHeight}px !important;\n      overflow-y: hidden;\n      column-gap: 0px !important;\n      column-width: ${columnWidth}px !important;\n      column-fill: auto !important;\n      word-wrap: break-word;\n      box-sizing: border-box;\n    }\n    body {\n      margin: 0;\n    }\n    body:focus-visible {\n      ${/*\n        we make sure that there are no outline when we focus something inside the iframe\n      */``}\n      outline: none;\n    }\n    ${\n    /*\n     * @see https://hammerjs.github.io/touch-action/\n     */\n    ``}\n    html, body {\n      touch-action: none;\n    }\n    ${/*\n      this messes up hard, be careful with this\n    */``}\n    * {\n      -max-width: ${columnWidth}px !important;\n    }\n    ${/*\n      this is necessary to have a proper calculation when determining size\n      of iframe content. If an img is using something like width:100% it would expand to\n      the size of the original image and potentially gives back a wrong size (much larger)\n      @see https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Columns/Handling_Overflow_in_Multicol\n    */``}\n    img, video, audio, object, svg {\n      max-width: 100%;\n      max-width: ${columnWidth}px !important;\n      max-height: ${columnHeight}px !important;\n      -pointer-events: none;\n      -webkit-column-break-inside: avoid;\n      page-break-inside: avoid;\n      break-inside: avoid;\n    }\n    figure {\n      d-max-width: ${columnWidth}px !important;\n    }\n    img {\n      object-fit: contain;\n      break-inside: avoid;\n      box-sizing: border-box;\n      d-max-width: ${columnWidth}px !important;\n    }\n    ${/*\n      img, video, audio, object, svg {\n        max-height: ${columnHeight}px !important;\n        box-sizing: border-box;\n        object-fit: contain;\n        -webkit-column-break-inside: avoid;\n        page-break-inside: avoid;\n        break-inside: avoid;\n      }\n    */``}\n    table {\n      max-width: ${columnWidth}px !important;\n      table-layout: fixed;\n    }\n    td {\n      max-width: ${columnWidth}px;\n    }\n  `\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItem/reflowableSpineItem.ts\n");
|
|
510
|
+
|
|
511
|
+
/***/ }),
|
|
512
|
+
|
|
513
|
+
/***/ "./src/spineItem/trackers.ts":
|
|
514
|
+
/*!***********************************!*\
|
|
515
|
+
!*** ./src/spineItem/trackers.ts ***!
|
|
516
|
+
\***********************************/
|
|
517
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
518
|
+
|
|
519
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createFingerTracker\": () => (/* binding */ createFingerTracker),\n/* harmony export */ \"createSelectionTracker\": () => (/* binding */ createSelectionTracker)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n\nconst createFingerTracker = () => {\n const fingerPositionInIframe = { x: undefined, y: undefined };\n const subject = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n let isMouseDown = false;\n const track = (frame) => {\n var _a, _b, _c;\n fingerPositionInIframe.x = undefined;\n fingerPositionInIframe.y = undefined;\n (_a = frame.contentDocument) === null || _a === void 0 ? void 0 : _a.addEventListener(`mousedown`, (e) => {\n isMouseDown = true;\n fingerPositionInIframe.x = e.x;\n fingerPositionInIframe.y = e.y;\n subject.next({ event: `fingermove`, data: { x: e.x, y: e.y } });\n });\n (_b = frame.contentDocument) === null || _b === void 0 ? void 0 : _b.addEventListener(`mouseup`, () => {\n isMouseDown = false;\n fingerPositionInIframe.x = undefined;\n fingerPositionInIframe.y = undefined;\n subject.next({ event: `fingerout`, data: undefined });\n });\n (_c = frame.contentDocument) === null || _c === void 0 ? void 0 : _c.addEventListener(`mousemove`, (e) => {\n if (isMouseDown) {\n subject.next({ event: `fingermove`, data: { x: e.x, y: e.y } });\n }\n });\n };\n return {\n track,\n getFingerPositionInIframe() {\n return (fingerPositionInIframe.x === undefined || fingerPositionInIframe.y === undefined) ? undefined : fingerPositionInIframe;\n },\n destroy: () => {\n },\n $: subject.asObservable()\n };\n};\nconst createSelectionTracker = () => {\n let isSelecting = false;\n let frame;\n const subject = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const mouseUpEvents = [\n `mouseup`,\n `pointerup`\n ];\n const track = (frameToTrack) => {\n var _a, _b;\n frame = frameToTrack;\n mouseUpEvents.forEach(eventName => {\n var _a;\n (_a = frameToTrack.contentWindow) === null || _a === void 0 ? void 0 : _a.addEventListener(eventName, () => {\n isSelecting = false;\n });\n });\n (_a = frameToTrack.contentDocument) === null || _a === void 0 ? void 0 : _a.addEventListener(`selectionchange`, () => {\n var _a;\n subject.next({ event: `selectionchange`, data: ((_a = frame === null || frame === void 0 ? void 0 : frame.contentWindow) === null || _a === void 0 ? void 0 : _a.getSelection()) || null });\n });\n (_b = frameToTrack.contentWindow) === null || _b === void 0 ? void 0 : _b.addEventListener(`selectstart`, () => {\n isSelecting = true;\n });\n };\n const destroy = () => {\n };\n return {\n track,\n destroy,\n isSelecting: () => isSelecting,\n getSelection: () => {\n var _a;\n const selection = (_a = frame === null || frame === void 0 ? void 0 : frame.contentWindow) === null || _a === void 0 ? void 0 : _a.getSelection();\n if (!(selection === null || selection === void 0 ? void 0 : selection.anchorNode) || selection.type === `None` || selection.type === `Caret`)\n return undefined;\n return selection;\n },\n $: subject.asObservable()\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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LENBQUM7UUFFRixrQkFBWSxDQUFDLGVBQWUsMENBQUUsZ0JBQWdCLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxFQUFFOztZQUNyRSxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLElBQUksRUFBRSxZQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsYUFBYSwwQ0FBRSxZQUFZLEVBQUUsS0FBSSxJQUFJLEVBQUUsQ0FBQztRQUNoRyxDQUFDLENBQUM7UUFFRixrQkFBWSxDQUFDLGFBQWEsMENBQUUsZ0JBQWdCLENBQUMsYUFBYSxFQUFFLEdBQUcsRUFBRTtZQUMvRCxXQUFXLEdBQUcsSUFBSTtRQUdwQixDQUFDLENBQUM7SUFDSixDQUFDO0lBRUQsTUFBTSxPQUFPLEdBQUcsR0FBRyxFQUFFO0lBRXJCLENBQUM7SUFFRCxPQUFPO1FBQ0wsS0FBSztRQUNMLE9BQU87UUFDUCxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQUMsV0FBVztRQUM5QixZQUFZLEVBQUUsR0FBRyxFQUFFOztZQUNqQixNQUFNLFNBQVMsR0FBRyxXQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsYUFBYSwwQ0FBRSxZQUFZLEVBQUU7WUFDdEQsSUFBSSxDQUFDLFVBQVMsYUFBVCxTQUFTLHVCQUFULFNBQVMsQ0FBRSxVQUFVLEtBQUksU0FBUyxDQUFDLElBQUksS0FBSyxNQUFNLElBQUksU0FBUyxDQUFDLElBQUksS0FBSyxPQUFPO2dCQUFFLE9BQU8sU0FBUztZQUV2RyxPQUFPLFNBQVM7UUFDbEIsQ0FBQztRQUNELENBQUMsRUFBRSxPQUFPLENBQUMsWUFBWSxFQUFFO0tBQzFCO0FBQ0gsQ0FBQyIsInNvdXJjZXMiOlsid2VicGFjazovL0Bwcm9zZS1yZWFkZXIvY29yZS8uL3NyYy9zcGluZUl0ZW0vdHJhY2tlcnMudHM/Yjc2YiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIlxuXG5leHBvcnQgY29uc3QgY3JlYXRlRmluZ2VyVHJhY2tlciA9ICgpID0+IHtcbiAgY29uc3QgZmluZ2VyUG9zaXRpb25JbklmcmFtZTogeyB4OiBudW1iZXIgfCB1bmRlZmluZWQsIHk6IG51bWJlciB8IHVuZGVmaW5lZCB9ID0geyB4OiB1bmRlZmluZWQsIHk6IHVuZGVmaW5lZCB9XG4gIGNvbnN0IHN1YmplY3QgPSBuZXcgU3ViamVjdDx7IGV2ZW50OiBgZmluZ2VybW92ZWAsIGRhdGE6IHsgeDogbnVtYmVyLCB5OiBudW1iZXIgfSB9IHwgeyBldmVudDogYGZpbmdlcm91dGAsIGRhdGE6IHVuZGVmaW5lZCB9PigpXG4gIGxldCBpc01vdXNlRG93biA9IGZhbHNlXG5cbiAgY29uc3QgdHJhY2sgPSAoZnJhbWU6IEhUTUxJRnJhbWVFbGVtZW50KSA9PiB7XG4gICAgZmluZ2VyUG9zaXRpb25JbklmcmFtZS54ID0gdW5kZWZpbmVkXG4gICAgZmluZ2VyUG9zaXRpb25JbklmcmFtZS55ID0gdW5kZWZpbmVkXG5cbiAgICBmcmFtZS5jb250ZW50RG9jdW1lbnQ/LmFkZEV2ZW50TGlzdGVuZXIoYG1vdXNlZG93bmAsIChlKSA9PiB7XG4gICAgICBpc01vdXNlRG93biA9IHRydWVcbiAgICAgIGZpbmdlclBvc2l0aW9uSW5JZnJhbWUueCA9IGUueFxuICAgICAgZmluZ2VyUG9zaXRpb25JbklmcmFtZS55ID0gZS55XG4gICAgICBzdWJqZWN0Lm5leHQoeyBldmVudDogYGZpbmdlcm1vdmVgLCBkYXRhOiB7IHg6IGUueCwgeTogZS55IH0gfSlcbiAgICB9KVxuXG4gICAgZnJhbWUuY29udGVudERvY3VtZW50Py5hZGRFdmVudExpc3RlbmVyKGBtb3VzZXVwYCwgKCkgPT4ge1xuICAgICAgaXNNb3VzZURvd24gPSBmYWxzZVxuICAgICAgZmluZ2VyUG9zaXRpb25JbklmcmFtZS54ID0gdW5kZWZpbmVkXG4gICAgICBmaW5nZXJQb3NpdGlvbkluSWZyYW1lLnkgPSB1bmRlZmluZWRcbiAgICAgIHN1YmplY3QubmV4dCh7IGV2ZW50OiBgZmluZ2Vyb3V0YCwgZGF0YTogdW5kZWZpbmVkIH0pXG4gICAgfSlcblxuICAgIGZyYW1lLmNvbnRlbnREb2N1bWVudD8uYWRkRXZlbnRMaXN0ZW5lcihgbW91c2Vtb3ZlYCwgKGUpID0+IHtcbiAgICAgIGlmIChpc01vdXNlRG93bikge1xuICAgICAgICBzdWJqZWN0Lm5leHQoeyBldmVudDogYGZpbmdlcm1vdmVgLCBkYXRhOiB7IHg6IGUueCwgeTogZS55IH0gfSlcbiAgICAgIH1cbiAgICB9KVxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0cmFjayxcbiAgICBnZXRGaW5nZXJQb3NpdGlvbkluSWZyYW1lICgpIHtcbiAgICAgIHJldHVybiAoZmluZ2VyUG9zaXRpb25JbklmcmFtZS54ID09PSB1bmRlZmluZWQgfHwgZmluZ2VyUG9zaXRpb25JbklmcmFtZS55ID09PSB1bmRlZmluZWQpID8gdW5kZWZpbmVkIDogZmluZ2VyUG9zaXRpb25JbklmcmFtZVxuICAgIH0sXG4gICAgZGVzdHJveTogKCkgPT4ge1xuXG4gICAgfSxcbiAgICAkOiBzdWJqZWN0LmFzT2JzZXJ2YWJsZSgpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVNlbGVjdGlvblRyYWNrZXIgPSAoKSA9PiB7XG4gIGxldCBpc1NlbGVjdGluZyA9IGZhbHNlXG4gIGxldCBmcmFtZTogSFRNTElGcmFtZUVsZW1lbnQgfCB1bmRlZmluZWRcbiAgY29uc3Qgc3ViamVjdCA9IG5ldyBTdWJqZWN0PFxuICAgIHsgZXZlbnQ6IGBzZWxlY3Rpb25jaGFuZ2VgLCBkYXRhOiBTZWxlY3Rpb24gfCBudWxsIH1cbiAgICB8IHsgZXZlbnQ6IGBzZWxlY3RzdGFydGAsIGRhdGE6IFNlbGVjdGlvbiB8IG51bGwgfVxuICAgIHwgeyBldmVudDogYHNlbGVjdGVuZGAsIGRhdGE6IFNlbGVjdGlvbiB8IG51bGwgfVxuICA+KClcbiAgY29uc3QgbW91c2VVcEV2ZW50cyA9IFtcbiAgICBgbW91c2V1cGAgYXMgY29uc3QsXG4gICAgYHBvaW50ZXJ1cGAgYXMgY29uc3RcbiAgXVxuXG4gIGNvbnN0IHRyYWNrID0gKGZyYW1lVG9UcmFjazogSFRNTElGcmFtZUVsZW1lbnQpID0+IHtcbiAgICBmcmFtZSA9IGZyYW1lVG9UcmFja1xuXG4gICAgbW91c2VVcEV2ZW50cy5mb3JFYWNoKGV2ZW50TmFtZSA9PiB7XG4gICAgICBmcmFtZVRvVHJhY2suY29udGVudFdpbmRvdz8uYWRkRXZlbnRMaXN0ZW5lcihldmVudE5hbWUsICgpID0+IHtcbiAgICAgICAgaXNTZWxlY3RpbmcgPSBmYWxzZVxuICAgICAgICAvLyBjb25zb2xlLmxvZyhgJHtldmVudE5hbWV9IHNlbGVjdGVuZGAsIGZyYW1lPy5jb250ZW50V2luZG93Py5nZXRTZWxlY3Rpb24oKSwgZnJhbWU/LmNvbnRlbnRXaW5kb3c/LmdldFNlbGVjdGlvbigpPy50b1N0cmluZygpKVxuICAgICAgICAvLyBzdWJqZWN0Lm5leHQoeyBldmVudDogJ3NlbGVjdGVuZCcsIGRhdGE6IGZyYW1lPy5jb250ZW50V2luZG93Py5nZXRTZWxlY3Rpb24oKSB8fCBudWxsIH0pXG4gICAgICB9KVxuICAgIH0pXG5cbiAgICBmcmFtZVRvVHJhY2suY29udGVudERvY3VtZW50Py5hZGRFdmVudExpc3RlbmVyKGBzZWxlY3Rpb25jaGFuZ2VgLCAoKSA9PiB7XG4gICAgICBzdWJqZWN0Lm5leHQoeyBldmVudDogYHNlbGVjdGlvbmNoYW5nZWAsIGRhdGE6IGZyYW1lPy5jb250ZW50V2luZG93Py5nZXRTZWxlY3Rpb24oKSB8fCBudWxsIH0pXG4gICAgfSlcblxuICAgIGZyYW1lVG9UcmFjay5jb250ZW50V2luZG93Py5hZGRFdmVudExpc3RlbmVyKGBzZWxlY3RzdGFydGAsICgpID0+IHtcbiAgICAgIGlzU2VsZWN0aW5nID0gdHJ1ZVxuICAgICAgLy8gY29uc29sZS5sb2coYHNlbGVjdHN0YXJ0YCwgZSlcbiAgICAgIC8vIHN1YmplY3QubmV4dCh7IGV2ZW50OiAnc2VsZWN0c3RhcnQnLCBkYXRhOiBmcmFtZT8uY29udGVudFdpbmRvdz8uZ2V0U2VsZWN0aW9uKCkgfHwgbnVsbCB9KVxuICAgIH0pXG4gIH1cblxuICBjb25zdCBkZXN0cm95ID0gKCkgPT4ge1xuXG4gIH1cblxuICByZXR1cm4ge1xuICAgIHRyYWNrLFxuICAgIGRlc3Ryb3ksXG4gICAgaXNTZWxlY3Rpbmc6ICgpID0+IGlzU2VsZWN0aW5nLFxuICAgIGdldFNlbGVjdGlvbjogKCkgPT4ge1xuICAgICAgY29uc3Qgc2VsZWN0aW9uID0gZnJhbWU/LmNvbnRlbnRXaW5kb3c/LmdldFNlbGVjdGlvbigpXG4gICAgICBpZiAoIXNlbGVjdGlvbj8uYW5jaG9yTm9kZSB8fCBzZWxlY3Rpb24udHlwZSA9PT0gYE5vbmVgIHx8IHNlbGVjdGlvbi50eXBlID09PSBgQ2FyZXRgKSByZXR1cm4gdW5kZWZpbmVkXG5cbiAgICAgIHJldHVybiBzZWxlY3Rpb25cbiAgICB9LFxuICAgICQ6IHN1YmplY3QuYXNPYnNlcnZhYmxlKClcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/spineItem/trackers.ts\n");
|
|
520
|
+
|
|
521
|
+
/***/ }),
|
|
522
|
+
|
|
523
|
+
/***/ "./src/spineItemManager.ts":
|
|
524
|
+
/*!*********************************!*\
|
|
525
|
+
!*** ./src/spineItemManager.ts ***!
|
|
526
|
+
\*********************************/
|
|
527
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
528
|
+
|
|
529
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"createSpineItemManager\": () => (/* binding */ createSpineItemManager)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"rxjs\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./report */ \"./src/report.ts\");\n/* harmony import */ var _utils_objects__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils/objects */ \"./src/utils/objects.ts\");\n/* harmony import */ var _utils_manifest__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./utils/manifest */ \"./src/utils/manifest.ts\");\n\n\n\n\n\nconst NAMESPACE = `spineItemManager`;\nconst createSpineItemManager = ({ context }) => {\n const focus$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n const layout$ = new rxjs__WEBPACK_IMPORTED_MODULE_0__.Subject();\n let itemLayoutInformation = [];\n const orderedSpineItems = [];\n let focusedSpineItemIndex;\n const layout = () => {\n const manifest = context.getManifest();\n const newItemLayoutInformation = [];\n const isGloballyPrePaginated = (manifest === null || manifest === void 0 ? void 0 : manifest.renditionLayout) === `pre-paginated`;\n const coverItemIndex = manifest ? (0,_utils_manifest__WEBPACK_IMPORTED_MODULE_4__.getCoverItem)(manifest) : undefined;\n orderedSpineItems.reduce((edgeOffset, item, index) => {\n const isPageCover = coverItemIndex === index;\n let minimumWidth = context.getPageSize().width;\n let blankPagePosition = `none`;\n const itemStartOnNewScreen = edgeOffset.edgeX % context.getVisibleAreaRect().width === 0;\n const isLastItem = index === orderedSpineItems.length - 1;\n if (context.shouldDisplaySpread()) {\n if (!isGloballyPrePaginated && item.isReflowable && index !== orderedSpineItems.length - 1) {\n minimumWidth = context.getPageSize().width * 2;\n }\n if (!isGloballyPrePaginated && item.isReflowable && index === orderedSpineItems.length - 1 && itemStartOnNewScreen) {\n minimumWidth = context.getPageSize().width * 2;\n }\n const lastItemStartOnNewScreenInAPrepaginatedBook = itemStartOnNewScreen && isLastItem && isGloballyPrePaginated;\n if (item.item.pageSpreadRight && itemStartOnNewScreen && !context.isRTL()) {\n blankPagePosition = `before`;\n minimumWidth = context.getPageSize().width * 2;\n }\n else if (item.item.pageSpreadLeft && itemStartOnNewScreen && context.isRTL()) {\n blankPagePosition = `before`;\n minimumWidth = context.getPageSize().width * 2;\n }\n else if (lastItemStartOnNewScreenInAPrepaginatedBook) {\n if (context.isRTL()) {\n blankPagePosition = `before`;\n }\n else {\n blankPagePosition = `after`;\n }\n minimumWidth = context.getPageSize().width * 2;\n }\n if (isGloballyPrePaginated && isPageCover) {\n minimumWidth = context.getPageSize().width * 2;\n }\n }\n const { width, height } = item.layout({\n minimumWidth,\n blankPagePosition,\n spreadPosition: context.shouldDisplaySpread()\n ? itemStartOnNewScreen\n ? context.isRTL() ? `right` : `left`\n : context.isRTL() ? `left` : `right`\n : `none`\n });\n if (context.getSettings().computedPageTurnDirection === `vertical`) {\n const currentValidEdgeYForVerticalPositioning = itemStartOnNewScreen ? edgeOffset.edgeY : edgeOffset.edgeY - context.getVisibleAreaRect().height;\n const currentValidEdgeXForVerticalPositioning = itemStartOnNewScreen ? 0 : edgeOffset.edgeX;\n if (context.isRTL()) {\n item.adjustPositionOfElement({\n top: currentValidEdgeYForVerticalPositioning,\n left: currentValidEdgeXForVerticalPositioning\n });\n }\n else {\n item.adjustPositionOfElement({\n top: currentValidEdgeYForVerticalPositioning,\n left: currentValidEdgeXForVerticalPositioning\n });\n }\n const newEdgeX = width + currentValidEdgeXForVerticalPositioning;\n const newEdgeY = height + currentValidEdgeYForVerticalPositioning;\n newItemLayoutInformation.push({\n leftStart: currentValidEdgeXForVerticalPositioning,\n leftEnd: newEdgeX,\n topStart: currentValidEdgeYForVerticalPositioning,\n topEnd: newEdgeY,\n height,\n width\n });\n return {\n edgeX: newEdgeX,\n edgeY: newEdgeY\n };\n }\n if (context.isRTL()) {\n item.adjustPositionOfElement({ right: edgeOffset.edgeX, top: 0 });\n }\n else {\n item.adjustPositionOfElement({ left: edgeOffset.edgeX, top: 0 });\n }\n const newEdgeX = width + edgeOffset.edgeX;\n newItemLayoutInformation.push({\n leftStart: edgeOffset.edgeX,\n leftEnd: newEdgeX,\n topStart: edgeOffset.edgeY,\n topEnd: height,\n height,\n width\n });\n return {\n edgeX: newEdgeX,\n edgeY: 0\n };\n }, { edgeX: 0, edgeY: 0 });\n const hasLayoutChanges = itemLayoutInformation.some((old, index) => !(0,_utils_objects__WEBPACK_IMPORTED_MODULE_3__.isShallowEqual)(old, newItemLayoutInformation[index]));\n itemLayoutInformation = newItemLayoutInformation;\n _report__WEBPACK_IMPORTED_MODULE_2__.Report.log(NAMESPACE, `layout`, { hasLayoutChanges, itemLayoutInformation });\n layout$.next(hasLayoutChanges);\n };\n const focus = (indexOrSpineItem) => {\n const spineItemToFocus = typeof indexOrSpineItem === `number` ? get(indexOrSpineItem) : indexOrSpineItem;\n if (!spineItemToFocus)\n return;\n const newActiveSpineItemIndex = orderedSpineItems.indexOf(spineItemToFocus);\n if (newActiveSpineItemIndex === focusedSpineItemIndex)\n return;\n focusedSpineItemIndex = newActiveSpineItemIndex;\n focus$.next({ data: spineItemToFocus });\n };\n const loadContents = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`loadContents`, 10, (rangeOfIndex) => {\n var _a, _b;\n const [leftIndex, rightIndex] = rangeOfIndex;\n const numberOfAdjacentSpineItemToPreLoad = ((_a = context.getLoadOptions()) === null || _a === void 0 ? void 0 : _a.numberOfAdjacentSpineItemToPreLoad) || 0;\n const isPrePaginated = ((_b = context.getManifest()) === null || _b === void 0 ? void 0 : _b.renditionLayout) === `pre-paginated`;\n const isUsingFreeScroll = context.getSettings().computedPageTurnMode === `scrollable`;\n orderedSpineItems.forEach((orderedSpineItem, index) => {\n const isBeforeFocusedWithPreload = (index < leftIndex && !isPrePaginated && isUsingFreeScroll)\n ? true\n : index < (leftIndex - numberOfAdjacentSpineItemToPreLoad);\n const isAfterTailWithPreload = index > (rightIndex + numberOfAdjacentSpineItemToPreLoad);\n if (!isBeforeFocusedWithPreload && !isAfterTailWithPreload) {\n orderedSpineItem.loadContent();\n }\n else {\n orderedSpineItem.unloadContent();\n }\n });\n });\n const get = (indexOrId) => {\n if (typeof indexOrId === `number`)\n return orderedSpineItems[indexOrId];\n return orderedSpineItems.find(({ item }) => item.id === indexOrId);\n };\n const getAbsolutePositionOf = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`getAbsolutePositionOf`, 10, (spineItemOrIndex) => {\n const pageTurnDirection = context.getSettings().computedPageTurnDirection;\n const indexOfItem = typeof spineItemOrIndex === `number` ? spineItemOrIndex : orderedSpineItems.indexOf(spineItemOrIndex);\n const layoutInformation = itemLayoutInformation[indexOfItem];\n if (!layoutInformation) {\n return { leftStart: 0, leftEnd: 0, topStart: 0, topEnd: 0, width: 0, height: 0 };\n }\n return itemLayoutInformation[indexOfItem] || { leftStart: 0, leftEnd: 0, topStart: 0, topEnd: 0, width: 0, height: 0 };\n }, { disable: true });\n const getFocusedSpineItem = () => focusedSpineItemIndex !== undefined ? orderedSpineItems[focusedSpineItemIndex] : undefined;\n const comparePositionOf = (toCompare, withItem) => {\n const isAfter = orderedSpineItems.indexOf(toCompare) > orderedSpineItems.indexOf(withItem);\n if (isAfter) {\n return `after`;\n }\n return `before`;\n };\n const getSpineItemIndex = (spineItem) => {\n if (!spineItem)\n return undefined;\n const index = orderedSpineItems.indexOf(spineItem);\n return index < 0 ? undefined : index;\n };\n const add = (spineItem) => {\n orderedSpineItems.push(spineItem);\n spineItem.$.contentLayoutChangeSubject$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe(() => {\n layout();\n });\n spineItem.$.loaded$\n .pipe((0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.tap)(() => {\n if (spineItem.isUsingVerticalWriting()) {\n context.setHasVerticalWriting();\n }\n }), (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_1__.takeUntil)(context.$.destroy$))\n .subscribe();\n spineItem.load();\n };\n const getAll = () => orderedSpineItems;\n const getLength = () => {\n return orderedSpineItems.length;\n };\n const getFocusedSpineItemIndex = () => {\n const item = getFocusedSpineItem();\n return item && getSpineItemIndex(item);\n };\n const getSpineItemAtPosition = _report__WEBPACK_IMPORTED_MODULE_2__.Report.measurePerformance(`getSpineItemAtPosition`, 10, (position) => {\n const detectedItem = orderedSpineItems.find(item => {\n const { leftStart, leftEnd, topEnd, topStart } = getAbsolutePositionOf(item);\n const isWithinXAxis = position.x >= leftStart && position.x < leftEnd;\n if (context.getSettings().computedPageTurnDirection === `horizontal`) {\n return isWithinXAxis;\n }\n else {\n return isWithinXAxis && position.y >= topStart && position.y < topEnd;\n }\n });\n if (position.x === 0 && !detectedItem)\n return orderedSpineItems[0];\n return detectedItem;\n }, { disable: true });\n const destroy = () => {\n orderedSpineItems.forEach(item => item.destroy());\n focus$.complete();\n layout$.complete();\n };\n return {\n add,\n get,\n getAll,\n getLength,\n layout,\n focus,\n loadContents,\n comparePositionOf,\n getAbsolutePositionOf,\n getSpineItemAtPosition,\n getFocusedSpineItem,\n getFocusedSpineItemIndex,\n getSpineItemIndex,\n destroy,\n $: {\n focus$: focus$.asObservable(),\n layout$: layout$.asObservable()\n }\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/spineItemManager.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/spineItemManager.ts?8ed5"],"sourcesContent":["import { Subject } from \"rxjs\"\nimport { tap, takeUntil } from \"rxjs/operators\"\nimport { Report } from \"./report\"\nimport { Context } from \"./context\"\nimport { SpineItem } from \"./spineItem/createSpineItem\"\nimport { isShallowEqual } from \"./utils/objects\"\nimport { getCoverItem } from \"./utils/manifest\"\nimport { ViewportPosition } from \"./types\"\n\nconst NAMESPACE = `spineItemManager`\n\nexport const createSpineItemManager = ({ context }: { context: Context }) => {\n  const focus$ = new Subject<{ data: SpineItem }>()\n  const layout$ = new Subject<boolean>()\n  /**\n   * This contains every item dimension / position on the viewport.\n   * This is only used to avoid intensively request bounding of each items later.\n   * This is always in sync with every layout since it is being updated for every layout\n   * done with the manager.\n   */\n  let itemLayoutInformation: { leftStart: number, leftEnd: number, topStart: number, topEnd: number, width: number, height: number }[] = []\n  const orderedSpineItems: SpineItem[] = []\n  /**\n   * focused item represent the current item that the user navigated to.\n   * It can be either the left or right page for a spread, not necessarily the begin item\n   * either. This focused item is very important for everything that is related to navigation\n   * and adjustment of viewport.\n   *\n   * @important\n   * The focused item can sometime not be visible on the screen, in case of a viewport misalignment.\n   * However it means the next adjustment will use the focused item to detect when to move the viewport.\n   */\n  let focusedSpineItemIndex: number | undefined\n\n  /**\n   * @todo\n   * make sure to check how many times it is being called and try to reduce number of layouts\n   * it is called eery time an item is being unload (which can adds up quickly for big books)\n   */\n  const layout = () => {\n    const manifest = context.getManifest()\n    const newItemLayoutInformation: typeof itemLayoutInformation = []\n    const isGloballyPrePaginated = manifest?.renditionLayout === `pre-paginated`\n    const coverItemIndex = manifest ? getCoverItem(manifest) : undefined\n\n    orderedSpineItems.reduce((edgeOffset, item, index) => {\n      const isPageCover = coverItemIndex === index\n      let minimumWidth = context.getPageSize().width\n      let blankPagePosition: `none` | `before` | `after` = `none`\n      const itemStartOnNewScreen = edgeOffset.edgeX % context.getVisibleAreaRect().width === 0\n      const isLastItem = index === orderedSpineItems.length - 1\n\n      if (context.shouldDisplaySpread()) {\n        /**\n         * for now every reflowable content that has reflow siblings takes the entire screen by default\n         * this simplify many things and I am not sure the specs allow one reflow\n         * to end and an other one to start on the same screen anyway\n         *\n         * @important\n         * For now this is impossible to have reflow not taking all screen. This is because\n         * when an element is unloaded, the next element will move back its x, then an adjustment\n         *  will occurs and the previous element will become visible again, meaning it will be loaded,\n         * therefore pushing the focused element, meaning adjustment again, then unload of previous one,\n         * ... infinite loop. Due to the nature of reflow it's pretty much impossible to not load the entire\n         * book with spread on to make it work.\n         *\n         * @important\n         * When the book is globally pre-paginated we will not apply any of this even if each item is\n         * reflowable. This is mostly a publisher mistake but does not comply with spec. Therefore\n         * we ignore it\n         */\n        if (!isGloballyPrePaginated && item.isReflowable && index !== orderedSpineItems.length - 1) {\n          minimumWidth = context.getPageSize().width * 2\n        }\n\n        // mainly to make loading screen looks good\n        if (!isGloballyPrePaginated && item.isReflowable && index === orderedSpineItems.length - 1 && itemStartOnNewScreen) {\n          minimumWidth = context.getPageSize().width * 2\n        }\n\n        const lastItemStartOnNewScreenInAPrepaginatedBook = itemStartOnNewScreen && isLastItem && isGloballyPrePaginated\n\n        if (item.item.pageSpreadRight && itemStartOnNewScreen && !context.isRTL()) {\n          blankPagePosition = `before`\n          minimumWidth = context.getPageSize().width * 2\n        } else if (item.item.pageSpreadLeft && itemStartOnNewScreen && context.isRTL()) {\n          blankPagePosition = `before`\n          minimumWidth = context.getPageSize().width * 2\n        } else if (lastItemStartOnNewScreenInAPrepaginatedBook) {\n          if (context.isRTL()) {\n            blankPagePosition = `before`\n          } else {\n            blankPagePosition = `after`\n          }\n          minimumWidth = context.getPageSize().width * 2\n        }\n\n        if (isGloballyPrePaginated && isPageCover) {\n          minimumWidth = context.getPageSize().width * 2\n        }\n      }\n\n      const { width, height } = item.layout({\n        minimumWidth,\n        blankPagePosition,\n        spreadPosition: context.shouldDisplaySpread()\n          ? itemStartOnNewScreen\n            ? context.isRTL() ? `right` : `left`\n            : context.isRTL() ? `left` : `right`\n          : `none`\n      })\n\n      if (context.getSettings().computedPageTurnDirection === `vertical`) {\n        const currentValidEdgeYForVerticalPositioning = itemStartOnNewScreen ? edgeOffset.edgeY : edgeOffset.edgeY - context.getVisibleAreaRect().height\n        const currentValidEdgeXForVerticalPositioning = itemStartOnNewScreen ? 0 : edgeOffset.edgeX\n\n        if (context.isRTL()) {\n          item.adjustPositionOfElement({\n            top: currentValidEdgeYForVerticalPositioning,\n            left: currentValidEdgeXForVerticalPositioning\n          })\n        } else {\n          item.adjustPositionOfElement({\n            top: currentValidEdgeYForVerticalPositioning,\n            left: currentValidEdgeXForVerticalPositioning\n          })\n        }\n\n        const newEdgeX = width + currentValidEdgeXForVerticalPositioning\n        const newEdgeY = height + currentValidEdgeYForVerticalPositioning\n\n        newItemLayoutInformation.push({\n          leftStart: currentValidEdgeXForVerticalPositioning,\n          leftEnd: newEdgeX,\n          topStart: currentValidEdgeYForVerticalPositioning,\n          topEnd: newEdgeY,\n          height,\n          width\n        })\n\n        return {\n          edgeX: newEdgeX,\n          edgeY: newEdgeY\n        }\n      }\n\n      if (context.isRTL()) {\n        // could also be negative left but I am not in the mood\n        // will push items on the left\n        item.adjustPositionOfElement({ right: edgeOffset.edgeX, top: 0 })\n      } else {\n        // will push items on the right\n        item.adjustPositionOfElement({ left: edgeOffset.edgeX, top: 0 })\n      }\n\n      const newEdgeX = width + edgeOffset.edgeX\n\n      newItemLayoutInformation.push({\n        leftStart: edgeOffset.edgeX,\n        leftEnd: newEdgeX,\n        topStart: edgeOffset.edgeY,\n        topEnd: height,\n        height,\n        width\n      })\n\n      return {\n        edgeX: newEdgeX,\n        edgeY: 0\n      }\n    }, { edgeX: 0, edgeY: 0 })\n\n    const hasLayoutChanges = itemLayoutInformation.some((old, index) => !isShallowEqual(old, newItemLayoutInformation[index]))\n\n    itemLayoutInformation = newItemLayoutInformation\n\n    Report.log(NAMESPACE, `layout`, { hasLayoutChanges, itemLayoutInformation })\n\n    layout$.next(hasLayoutChanges)\n  }\n\n  const focus = (indexOrSpineItem: number | SpineItem) => {\n    const spineItemToFocus = typeof indexOrSpineItem === `number` ? get(indexOrSpineItem) : indexOrSpineItem\n\n    if (!spineItemToFocus) return\n\n    const newActiveSpineItemIndex = orderedSpineItems.indexOf(spineItemToFocus)\n\n    if (newActiveSpineItemIndex === focusedSpineItemIndex) return\n\n    focusedSpineItemIndex = newActiveSpineItemIndex\n\n    focus$.next({ data: spineItemToFocus })\n  }\n\n  /**\n   * @todo\n   * optimize useless calls to it, such as when the layout has not changed and the focus is still the same\n   * @todo\n   * analyze poor performances\n   */\n  const loadContents = Report.measurePerformance(`loadContents`, 10, (rangeOfIndex: [number, number]) => {\n    const [leftIndex, rightIndex] = rangeOfIndex\n    const numberOfAdjacentSpineItemToPreLoad = context.getLoadOptions()?.numberOfAdjacentSpineItemToPreLoad || 0\n    const isPrePaginated = context.getManifest()?.renditionLayout === `pre-paginated`\n    const isUsingFreeScroll = context.getSettings().computedPageTurnMode === `scrollable`\n\n    orderedSpineItems.forEach((orderedSpineItem, index) => {\n      const isBeforeFocusedWithPreload =\n        // we never want to preload anything before on free scroll on flow because it could offset the cursor\n        (index < leftIndex && !isPrePaginated && isUsingFreeScroll)\n          ? true\n          : index < (leftIndex - numberOfAdjacentSpineItemToPreLoad)\n      const isAfterTailWithPreload = index > (rightIndex + numberOfAdjacentSpineItemToPreLoad)\n      if (!isBeforeFocusedWithPreload && !isAfterTailWithPreload) {\n        orderedSpineItem.loadContent()\n      } else {\n        orderedSpineItem.unloadContent()\n      }\n    })\n  })\n\n  const get = (indexOrId: number | string) => {\n    if (typeof indexOrId === `number`) return orderedSpineItems[indexOrId]\n\n    return orderedSpineItems.find(({ item }) => item.id === indexOrId)\n  }\n\n  /**\n   * It's important to not use x,y since we need the absolute position of each element. Otherwise x,y would be relative to\n   * current window (viewport).\n   */\n  const getAbsolutePositionOf = Report.measurePerformance(`getAbsolutePositionOf`, 10, (spineItemOrIndex: SpineItem | number) => {\n    const pageTurnDirection = context.getSettings().computedPageTurnDirection\n    const indexOfItem = typeof spineItemOrIndex === `number` ? spineItemOrIndex : orderedSpineItems.indexOf(spineItemOrIndex)\n\n    const layoutInformation = itemLayoutInformation[indexOfItem]\n\n    if (!layoutInformation) {\n      return { leftStart: 0, leftEnd: 0, topStart: 0, topEnd: 0, width: 0, height: 0 }\n    }\n\n    // const distance = orderedSpineItems\n    //   .slice(0, indexOfItem + 1)\n    //   .reduce((acc, spineItem) => {\n    //     const { width, height } = spineItem.getElementDimensions()\n\n    //     return {\n    //       leftStart: pageTurnDirection === `horizontal` ? acc.leftEnd : 0,\n    //       leftEnd: pageTurnDirection === `horizontal` ? acc.leftEnd + width : width,\n    //       topStart: pageTurnDirection === `horizontal` ? 0 : acc.topEnd,\n    //       topEnd: pageTurnDirection === `horizontal` ? height : acc.topEnd + height,\n    //       width,\n    //       height\n    //     }\n    //   }, { leftStart: 0, leftEnd: 0, topStart: 0, topEnd: 0, width: 0, height: 0 })\n\n    // console.log(distance, itemLayoutInformation[indexOfItem])\n    // return distance\n\n    return itemLayoutInformation[indexOfItem] || { leftStart: 0, leftEnd: 0, topStart: 0, topEnd: 0, width: 0, height: 0 }\n  }, { disable: true })\n\n  const getFocusedSpineItem = () => focusedSpineItemIndex !== undefined ? orderedSpineItems[focusedSpineItemIndex] : undefined\n\n  const comparePositionOf = (toCompare: SpineItem, withItem: SpineItem) => {\n    const isAfter = orderedSpineItems.indexOf(toCompare) > orderedSpineItems.indexOf(withItem)\n\n    if (isAfter) {\n      return `after`\n    }\n\n    return `before`\n  }\n\n  const getSpineItemIndex = (spineItem: SpineItem | undefined) => {\n    if (!spineItem) return undefined\n    const index = orderedSpineItems.indexOf(spineItem)\n\n    return index < 0 ? undefined : index\n  }\n\n  const add = (spineItem: SpineItem) => {\n    orderedSpineItems.push(spineItem)\n\n    spineItem.$.contentLayoutChangeSubject$\n      .pipe(takeUntil(context.$.destroy$))\n      .subscribe(() => {\n        // upstream change, meaning we need to layout again to both resize correctly each item but also to\n        // adjust positions, etc\n        layout()\n      })\n\n    spineItem.$.loaded$\n      .pipe(\n        tap(() => {\n          if (spineItem.isUsingVerticalWriting()) {\n            context.setHasVerticalWriting()\n          }\n        }),\n        takeUntil(context.$.destroy$)\n      )\n      .subscribe()\n\n    spineItem.load()\n  }\n\n  const getAll = () => orderedSpineItems\n\n  const getLength = () => {\n    return orderedSpineItems.length\n  }\n\n  const getFocusedSpineItemIndex = () => {\n    const item = getFocusedSpineItem()\n    return item && getSpineItemIndex(item)\n  }\n\n  const getSpineItemAtPosition = Report.measurePerformance(`getSpineItemAtPosition`, 10, (position: ViewportPosition) => {\n    const detectedItem = orderedSpineItems.find(item => {\n      const { leftStart, leftEnd, topEnd, topStart } = getAbsolutePositionOf(item)\n\n      const isWithinXAxis = position.x >= leftStart && position.x < leftEnd\n\n      if (context.getSettings().computedPageTurnDirection === `horizontal`) {\n        return isWithinXAxis\n      } else {\n        return isWithinXAxis && position.y >= topStart && position.y < topEnd\n      }\n    })\n\n    if (position.x === 0 && !detectedItem) return orderedSpineItems[0]\n\n    return detectedItem\n  }, { disable: true })\n\n  const destroy = () => {\n    orderedSpineItems.forEach(item => item.destroy())\n    focus$.complete()\n    layout$.complete()\n  }\n\n  return {\n    add,\n    get,\n    getAll,\n    getLength,\n    layout,\n    focus,\n    loadContents,\n    comparePositionOf,\n    getAbsolutePositionOf,\n    getSpineItemAtPosition,\n    getFocusedSpineItem,\n    getFocusedSpineItemIndex,\n    getSpineItemIndex,\n    destroy,\n    $: {\n      focus$: focus$.asObservable(),\n      layout$: layout$.asObservable()\n    }\n  }\n}\n\nexport type SpineItemManager = ReturnType<typeof createSpineItemManager>\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/spineItemManager.ts\n");
|
|
530
|
+
|
|
531
|
+
/***/ }),
|
|
532
|
+
|
|
533
|
+
/***/ "./src/utils/compose.ts":
|
|
534
|
+
/*!******************************!*\
|
|
535
|
+
!*** ./src/utils/compose.ts ***!
|
|
536
|
+
\******************************/
|
|
537
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
538
|
+
|
|
539
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"compose\": () => (/* binding */ compose)\n/* harmony export */ });\nfunction compose(...funcs) {\n if (funcs.length === 0) {\n return (arg) => arg;\n }\n if (funcs.length === 1) {\n return funcs[0];\n }\n return funcs.reduce((a, b) => (...args) => b(a(...args)));\n}\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvY29tcG9zZS50cy5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBNkNBLFNBQVMsT0FBTyxDQUFFLEdBQUcsS0FBaUI7SUFDcEMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUV0QixPQUFPLENBQUksR0FBTSxFQUFFLEVBQUUsQ0FBQyxHQUFHO0tBQzFCO0lBRUQsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN0QixPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUM7S0FDaEI7SUFNRCxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQztBQUNoRSxDQUFDO0FBSUEiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvdXRpbHMvY29tcG9zZS50cz81MTlhIl0sInNvdXJjZXNDb250ZW50IjpbInR5cGUgRnVuYzxUIGV4dGVuZHMgYW55W10sIFI+ID0gKC4uLmE6IFQpID0+IFJcblxuLyoqXG4gKiBDb21wb3NlcyBzaW5nbGUtYXJndW1lbnQgZnVuY3Rpb25zIGZyb20gcmlnaHQgdG8gbGVmdC4gVGhlIHJpZ2h0bW9zdFxuICogZnVuY3Rpb24gY2FuIHRha2UgbXVsdGlwbGUgYXJndW1lbnRzIGFzIGl0IHByb3ZpZGVzIHRoZSBzaWduYXR1cmUgZm9yIHRoZVxuICogcmVzdWx0aW5nIGNvbXBvc2l0ZSBmdW5jdGlvbi5cbiAqXG4gKiBAcGFyYW0gZnVuY3MgVGhlIGZ1bmN0aW9ucyB0byBjb21wb3NlLlxuICogQHJldHVybnMgQSBmdW5jdGlvbiBvYnRhaW5lZCBieSBjb21wb3NpbmcgdGhlIGFyZ3VtZW50IGZ1bmN0aW9ucyBmcm9tIHJpZ2h0XG4gKiAgIHRvIGxlZnQuIEZvciBleGFtcGxlLCBgY29tcG9zZShmLCBnLCBoKWAgaXMgaWRlbnRpY2FsIHRvIGRvaW5nXG4gKiAgIGAoLi4uYXJncykgPT4gZihnKGgoLi4uYXJncykpKWAuXG4gKi9cbi8vIGV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNvbXBvc2UoKTogPFI+KGE6IFIpID0+IFJcblxuZnVuY3Rpb24gY29tcG9zZTxGIGV4dGVuZHMgRnVuY3Rpb24+KGY6IEYpOiBGXG5cbi8qIHR3byBmdW5jdGlvbnMgKi9cbmZ1bmN0aW9uIGNvbXBvc2U8QSwgVCBleHRlbmRzIGFueVtdLCBSPihcbiAgZjE6IChhOiBBKSA9PiBSLFxuICBmMjogRnVuYzxULCBBPlxuKTogRnVuYzxULCBSPlxuXG4vKiB0aHJlZSBmdW5jdGlvbnMgKi9cbmZ1bmN0aW9uIGNvbXBvc2U8QSwgQiwgVCBleHRlbmRzIGFueVtdLCBSPihcbiAgZjE6IChiOiBCKSA9PiBSLFxuICBmMjogKGE6IEEpID0+IEIsXG4gIGYzOiBGdW5jPFQsIEE+XG4pOiBGdW5jPFQsIFI+XG5cbi8qIGZvdXIgZnVuY3Rpb25zICovXG5mdW5jdGlvbiBjb21wb3NlPEEsIEIsIEMsIFQgZXh0ZW5kcyBhbnlbXSwgUj4oXG4gIGYxOiAoYzogQykgPT4gUixcbiAgZjI6IChiOiBCKSA9PiBDLFxuICBmMzogKGE6IEEpID0+IEIsXG4gIGY0OiBGdW5jPFQsIEE+XG4pOiBGdW5jPFQsIFI+XG5cbi8qIHJlc3QgKi9cbmZ1bmN0aW9uIGNvbXBvc2U8Uj4oXG4gIGYxOiAoYTogYW55KSA9PiBSLFxuICAuLi5mdW5jczogRnVuY3Rpb25bXVxuKTogKC4uLmFyZ3M6IGFueVtdKSA9PiBSXG5cbmZ1bmN0aW9uIGNvbXBvc2U8Uj4oLi4uZnVuY3M6IEZ1bmN0aW9uW10pOiAoLi4uYXJnczogYW55W10pID0+IFJcblxuZnVuY3Rpb24gY29tcG9zZSAoLi4uZnVuY3M6IEZ1bmN0aW9uW10pIHtcbiAgaWYgKGZ1bmNzLmxlbmd0aCA9PT0gMCkge1xuICAgIC8vIGluZmVyIHRoZSBhcmd1bWVudCB0eXBlIHNvIGl0IGlzIHVzYWJsZSBpbiBpbmZlcmVuY2UgZG93biB0aGUgbGluZVxuICAgIHJldHVybiA8VD4oYXJnOiBUKSA9PiBhcmdcbiAgfVxuXG4gIGlmIChmdW5jcy5sZW5ndGggPT09IDEpIHtcbiAgICByZXR1cm4gZnVuY3NbMF1cbiAgfVxuXG4gIC8vIHJldHVybiBmdW5jcy5yZWR1Y2UoKGEsIGIpID0+ICguLi5hcmdzOiBhbnkpID0+IGEoYiguLi5hcmdzKSkpXG5cbiAgLy8gY29tcG9zZSBmcm9tIGxlZnQtdG8tcmlnaHQgaW5zdGVhZCBvZiByaWdodC10by1sZWZ0LiBUaGF0IHdheSBlbmQgdXNlciBhbHdheXNcbiAgLy8gaGFzIHN1YiBlbmhhbmNlciBhcyBkZXBlbmRlbmN5XG4gIHJldHVybiBmdW5jcy5yZWR1Y2UoKGEsIGIpID0+ICguLi5hcmdzOiBhbnkpID0+IGIoYSguLi5hcmdzKSkpXG59XG5cbmV4cG9ydCB7XG4gIGNvbXBvc2Vcbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/utils/compose.ts\n");
|
|
540
|
+
|
|
541
|
+
/***/ }),
|
|
542
|
+
|
|
543
|
+
/***/ "./src/utils/contentType.ts":
|
|
544
|
+
/*!**********************************!*\
|
|
545
|
+
!*** ./src/utils/contentType.ts ***!
|
|
546
|
+
\**********************************/
|
|
547
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
548
|
+
|
|
549
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"detectContentType\": () => (/* binding */ detectContentType),\n/* harmony export */ \"parseContentType\": () => (/* binding */ parseContentType)\n/* harmony export */ });\n/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./url */ \"./src/utils/url.ts\");\n\nconst detectContentType = (name) => {\n const extension = (0,_url__WEBPACK_IMPORTED_MODULE_0__.getUrlExtension)(name);\n switch (extension) {\n case `png`: return `image/png`;\n case `jpg`: return `image/jpg`;\n case `jpeg`: return `image/jpeg`;\n case `txt`: return `text/plain`;\n case `webp`: return `image/webp`;\n }\n return undefined;\n};\nconst parseContentType = (str) => {\n if (!str.length)\n return undefined;\n const cut = str.indexOf(`;`);\n return cut ? str.substring(0, str.indexOf(`;`)) : str;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvY29udGVudFR5cGUudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQXVDO0FBRWhDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxJQUFZLEVBQUUsRUFBRTtJQUNoRCxNQUFNLFNBQVMsR0FBRyxxREFBZSxDQUFDLElBQUksQ0FBQztJQUV2QyxRQUFRLFNBQVMsRUFBRTtRQUNqQixLQUFLLEtBQUssQ0FBQyxDQUFDLE9BQU8sV0FBVztRQUM5QixLQUFLLEtBQUssQ0FBQyxDQUFDLE9BQU8sV0FBVztRQUM5QixLQUFLLE1BQU0sQ0FBQyxDQUFDLE9BQU8sWUFBWTtRQUNoQyxLQUFLLEtBQUssQ0FBQyxDQUFDLE9BQU8sWUFBWTtRQUMvQixLQUFLLE1BQU0sQ0FBQyxDQUFDLE9BQU8sWUFBWTtLQUNqQztJQUVELE9BQU8sU0FBUztBQUNsQixDQUFDO0FBRU0sTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQVcsRUFBRSxFQUFFO0lBQzlDLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTTtRQUFFLE9BQU8sU0FBUztJQUVqQyxNQUFNLEdBQUcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQztJQUU1QixPQUFPLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHO0FBQ3ZELENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvdXRpbHMvY29udGVudFR5cGUudHM/ZjIxNiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRVcmxFeHRlbnNpb24gfSBmcm9tIFwiLi91cmxcIlxuXG5leHBvcnQgY29uc3QgZGV0ZWN0Q29udGVudFR5cGUgPSAobmFtZTogc3RyaW5nKSA9PiB7XG4gIGNvbnN0IGV4dGVuc2lvbiA9IGdldFVybEV4dGVuc2lvbihuYW1lKVxuXG4gIHN3aXRjaCAoZXh0ZW5zaW9uKSB7XG4gICAgY2FzZSBgcG5nYDogcmV0dXJuIGBpbWFnZS9wbmdgXG4gICAgY2FzZSBganBnYDogcmV0dXJuIGBpbWFnZS9qcGdgXG4gICAgY2FzZSBganBlZ2A6IHJldHVybiBgaW1hZ2UvanBlZ2BcbiAgICBjYXNlIGB0eHRgOiByZXR1cm4gYHRleHQvcGxhaW5gXG4gICAgY2FzZSBgd2VicGA6IHJldHVybiBgaW1hZ2Uvd2VicGBcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWRcbn1cblxuZXhwb3J0IGNvbnN0IHBhcnNlQ29udGVudFR5cGUgPSAoc3RyOiBzdHJpbmcpID0+IHtcbiAgaWYgKCFzdHIubGVuZ3RoKSByZXR1cm4gdW5kZWZpbmVkXG5cbiAgY29uc3QgY3V0ID0gc3RyLmluZGV4T2YoYDtgKVxuXG4gIHJldHVybiBjdXQgPyBzdHIuc3Vic3RyaW5nKDAsIHN0ci5pbmRleE9mKGA7YCkpIDogc3RyXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/utils/contentType.ts\n");
|
|
550
|
+
|
|
551
|
+
/***/ }),
|
|
552
|
+
|
|
553
|
+
/***/ "./src/utils/dom.ts":
|
|
554
|
+
/*!**************************!*\
|
|
555
|
+
!*** ./src/utils/dom.ts ***!
|
|
556
|
+
\**************************/
|
|
557
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
558
|
+
|
|
559
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"isHtmlElement\": () => (/* binding */ isHtmlElement),\n/* harmony export */ \"getFirstVisibleNodeForViewport\": () => (/* binding */ getFirstVisibleNodeForViewport),\n/* harmony export */ \"getRangeFromNode\": () => (/* binding */ getRangeFromNode),\n/* harmony export */ \"isPointerEvent\": () => (/* binding */ isPointerEvent),\n/* harmony export */ \"isMouseEvent\": () => (/* binding */ isMouseEvent),\n/* harmony export */ \"isTouchEvent\": () => (/* binding */ isTouchEvent)\n/* harmony export */ });\n/* harmony import */ var _report__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../report */ \"./src/report.ts\");\n\nconst isHtmlElement = (element) => {\n return (typeof element === `object` && !!element && `nodeType` in element && (element === null || element === void 0 ? void 0 : element.nodeType) === Node.ELEMENT_NODE && `innerText` in element);\n};\nfunction createRangeOrCaretFromPoint(doc, startX, startY) {\n if (`caretPositionFromPoint` in doc) {\n return doc.caretPositionFromPoint(startX, startY);\n }\n else if (typeof doc.caretRangeFromPoint !== `undefined`) {\n return doc.caretRangeFromPoint(startX, startY);\n }\n}\nconst getFirstVisibleNodeForViewport = _report__WEBPACK_IMPORTED_MODULE_0__.Report.measurePerformance(`getFirstVisibleNodeForViewport`, 1, (documentOrElement, viewport) => {\n const element = (`body` in documentOrElement)\n ? getFirstVisibleElementForViewport(documentOrElement.body, viewport)\n : getFirstVisibleElementForViewport(documentOrElement, viewport);\n const ownerDocument = `createRange` in documentOrElement ? documentOrElement : documentOrElement.ownerDocument;\n if (element) {\n let lastValidRange;\n let lastValidOffset = 0;\n const range = ownerDocument.createRange();\n Array.from(element.childNodes).some(childNode => {\n range.selectNodeContents(childNode);\n const rects = range.getClientRects();\n const visibleRect = getFirstVisibleDOMRect(rects, viewport);\n if (visibleRect) {\n lastValidRange = range.cloneRange();\n const rangeOrCaret = createRangeOrCaretFromPoint(ownerDocument, Math.ceil(visibleRect.left), Math.ceil(visibleRect.top));\n if (rangeOrCaret && `startContainer` in rangeOrCaret && rangeOrCaret.startContainer === lastValidRange.startContainer) {\n lastValidOffset = rangeOrCaret.startOffset;\n }\n if (rangeOrCaret && `offsetNode` in rangeOrCaret && rangeOrCaret.offsetNode === lastValidRange.startContainer) {\n lastValidOffset = rangeOrCaret.offset;\n }\n return true;\n }\n return false;\n });\n if (lastValidRange) {\n return { node: lastValidRange.startContainer, offset: lastValidOffset };\n }\n return { node: element, offset: 0 };\n }\n return undefined;\n});\nconst getFirstVisibleElementForViewport = (element, viewport) => {\n let lastValidElement;\n const positionFromViewport = getElementOrNodePositionFromViewPort(element.getBoundingClientRect(), viewport);\n if (positionFromViewport !== `before` && positionFromViewport !== `after`) {\n lastValidElement = element;\n }\n Array.from(element.children).some(child => {\n const childInViewPort = getFirstVisibleElementForViewport(child, viewport);\n if (childInViewPort) {\n lastValidElement = childInViewPort;\n return true;\n }\n return false;\n });\n return lastValidElement;\n};\nfunction getElementOrNodePositionFromViewPort(domRect, { left, right }) {\n if (domRect.left <= left && domRect.right <= left)\n return `before`;\n if (domRect.left <= left && domRect.right > left && domRect.right <= right)\n return `partially-before`;\n if (domRect.left <= right && domRect.right > right)\n return `partially-after`;\n if (domRect.left > right)\n return `after`;\n return `within`;\n}\nfunction getFirstVisibleDOMRect(domRect, viewport) {\n return Array.from(domRect).find(domRect => {\n const position = getElementOrNodePositionFromViewPort(domRect, viewport);\n if (position !== `before` && position !== `after`) {\n return true;\n }\n return false;\n });\n}\nconst getRangeFromNode = (node, offset) => {\n var _a;\n if (node.nodeType !== Node.CDATA_SECTION_NODE && node.nodeType !== Node.DOCUMENT_TYPE_NODE) {\n const range = (_a = node.ownerDocument) === null || _a === void 0 ? void 0 : _a.createRange();\n range === null || range === void 0 ? void 0 : range.selectNodeContents(node);\n try {\n if (offset <= ((range === null || range === void 0 ? void 0 : range.endOffset) || 0)) {\n range === null || range === void 0 ? void 0 : range.setStart(node, offset || 0);\n }\n }\n catch (e) {\n _report__WEBPACK_IMPORTED_MODULE_0__.Report.error(e);\n }\n return range;\n }\n return undefined;\n};\nconst isPointerEvent = (event) => {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\n if (((_a = event) === null || _a === void 0 ? void 0 : _a.target) && ((_c = (_b = event === null || event === void 0 ? void 0 : event.target) === null || _b === void 0 ? void 0 : _b.ownerDocument) === null || _c === void 0 ? void 0 : _c.defaultView)) {\n const eventView = (_e = (_d = event === null || event === void 0 ? void 0 : event.target) === null || _d === void 0 ? void 0 : _d.ownerDocument) === null || _e === void 0 ? void 0 : _e.defaultView;\n if (eventView.PointerEvent) {\n return event instanceof eventView.PointerEvent;\n }\n }\n if (((_f = event) === null || _f === void 0 ? void 0 : _f.view) && ((_h = (_g = event) === null || _g === void 0 ? void 0 : _g.view) === null || _h === void 0 ? void 0 : _h.window)) {\n const eventView = (_j = event) === null || _j === void 0 ? void 0 : _j.view;\n if (eventView.PointerEvent) {\n return event instanceof eventView.PointerEvent;\n }\n }\n return false;\n};\nconst isMouseEvent = (event) => {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\n if (isPointerEvent(event))\n return false;\n if (((_a = event) === null || _a === void 0 ? void 0 : _a.target) && ((_c = (_b = event === null || event === void 0 ? void 0 : event.target) === null || _b === void 0 ? void 0 : _b.ownerDocument) === null || _c === void 0 ? void 0 : _c.defaultView)) {\n const eventView = (_e = (_d = event === null || event === void 0 ? void 0 : event.target) === null || _d === void 0 ? void 0 : _d.ownerDocument) === null || _e === void 0 ? void 0 : _e.defaultView;\n if (eventView.MouseEvent) {\n return event instanceof eventView.MouseEvent;\n }\n }\n if (((_f = event) === null || _f === void 0 ? void 0 : _f.view) && ((_h = (_g = event) === null || _g === void 0 ? void 0 : _g.view) === null || _h === void 0 ? void 0 : _h.window)) {\n const eventView = (_j = event) === null || _j === void 0 ? void 0 : _j.view;\n if (eventView.MouseEvent) {\n return event instanceof eventView.MouseEvent;\n }\n }\n return false;\n};\nconst isTouchEvent = (event) => {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\n if (((_a = event) === null || _a === void 0 ? void 0 : _a.target) && ((_c = (_b = event === null || event === void 0 ? void 0 : event.target) === null || _b === void 0 ? void 0 : _b.ownerDocument) === null || _c === void 0 ? void 0 : _c.defaultView)) {\n const eventView = (_e = (_d = event === null || event === void 0 ? void 0 : event.target) === null || _d === void 0 ? void 0 : _d.ownerDocument) === null || _e === void 0 ? void 0 : _e.defaultView;\n if (eventView.TouchEvent) {\n return event instanceof eventView.TouchEvent;\n }\n }\n if (((_f = event) === null || _f === void 0 ? void 0 : _f.view) && ((_h = (_g = event) === null || _g === void 0 ? void 0 : _g.view) === null || _h === void 0 ? void 0 : _h.window)) {\n const eventView = (_j = event) === null || _j === void 0 ? void 0 : _j.view;\n if (eventView.TouchEvent) {\n return event instanceof eventView.TouchEvent;\n }\n }\n return false;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/utils/dom.ts.js","mappings":"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","sources":["webpack://@prose-reader/core/./src/utils/dom.ts?2340"],"sourcesContent":["// export function createSelectionFromPoint(startX: number, startY: number, endX: number, endY: number) {\n//   var doc = document;\n//   var start, end, range = null;\n//   if (typeof doc.caretPositionFromPoint != \"undefined\") {\n//     start = doc.caretPositionFromPoint(startX, startY);\n//     end = doc.caretPositionFromPoint(endX, endY);\n//     range = doc.createRange();\n//     range.setStart(start.offsetNode, start.offset);\n//     range.setEnd(end.offsetNode, end.offset);\n//   } else if (typeof doc.caretRangeFromPoint != \"undefined\") {\n//     start = doc.caretRangeFromPoint(startX, startY);\n//     end = doc.caretRangeFromPoint(endX, endY);\n//     range = doc.createRange();\n//     range.setStart(start.startContainer, start.startOffset);\n//     range.setEnd(end.startContainer, end.startOffset);\n//   }\n//   if (range !== null && typeof window.getSelection != \"undefined\") {\n//     var sel = window.getSelection();\n//     sel.removeAllRanges();\n//     sel.addRange(range);\n//   } else if (typeof doc.body.createTextRange != \"undefined\") {\n//     range = doc.body.createTextRange();\n//     range.moveToPoint(startX, startY);\n//     var endRange = range.duplicate();\n//     endRange.moveToPoint(endX, endY);\n//     range.setEndPoint(\"EndToEnd\", endRange);\n//     range.select();\n//   }\n// }\n\nimport { Report } from \"../report\"\n\n/**\n * Global env agnostic method to detect if an element is HtmlElement.\n *\n * @example\n * checking instance of element from iframe will not work because\n * `window.HtmlElement` is not the same as iframe.window.HtmlElement\n * element instanceof HtmlElement -> false\n *\n * isHtmlElement(element) -> true\n */\nexport const isHtmlElement = (element?: Element | Node | null | EventTarget): element is HTMLElement => {\n  return (\n    typeof element === `object` && !!element && `nodeType` in element && element?.nodeType === Node.ELEMENT_NODE && `innerText` in (element as HTMLElement)\n  )\n}\n\nfunction createRangeOrCaretFromPoint (doc: Document, startX: number, startY: number) {\n  // @see https://developer.mozilla.org/en-US/docs/Web/API/Document/caretPositionFromPoint\n  if (`caretPositionFromPoint` in doc) {\n    // @see https://developer.mozilla.org/en-US/docs/Web/API/CaretPosition\n    // @ts-expect-error\n    return doc.caretPositionFromPoint(startX, startY) as { offsetNode: Node, offset: number }\n  } else if (typeof doc.caretRangeFromPoint !== `undefined`) {\n    return doc.caretRangeFromPoint(startX, startY)\n  }\n}\n\ntype ViewPort = { left: number, right: number, top: number, bottom: number }\n\n/**\n * @todo optimize\n */\nexport const getFirstVisibleNodeForViewport = Report.measurePerformance(`getFirstVisibleNodeForViewport`, 1, (documentOrElement: Document | Element, viewport: ViewPort) => {\n  const element = (`body` in documentOrElement)\n    ? getFirstVisibleElementForViewport(documentOrElement.body, viewport)\n    : getFirstVisibleElementForViewport(documentOrElement, viewport)\n\n  const ownerDocument = `createRange` in documentOrElement ? documentOrElement : documentOrElement.ownerDocument\n\n  if (element) {\n    let lastValidRange: Range | undefined\n    let lastValidOffset = 0\n    const range = ownerDocument.createRange()\n\n    Array.from(element.childNodes).some(childNode => {\n      range.selectNodeContents(childNode)\n      const rects = range.getClientRects()\n      const visibleRect = getFirstVisibleDOMRect(rects, viewport)\n\n      // At this point we know the range is valid and contains visible rect.\n      // This means we have a valid Node. We still need to know the visible offset to be 100% accurate\n      if (visibleRect) {\n        lastValidRange = range.cloneRange()\n\n        /**\n         * Now we will try to refine the search to get the offset\n         * this is an incredibly expensive operation so we will try to\n         * use native functions to get something\n         * @important\n         * when using float value it looks like sometime when at the begin of the book the returned range will be the last offset of the page\n         * it can be tested with moby-dick.txt by using different font size. Whenever using something different than default font size we might\n         * have floating point for font and we start having issue. Using ceil \"make sure\" to be inside the point. Hopefully.\n         */\n        const rangeOrCaret = createRangeOrCaretFromPoint(ownerDocument, Math.ceil(visibleRect.left), Math.ceil(visibleRect.top))\n\n        // good news we found something with same node so we can assume the offset is already better than nothing\n        if (rangeOrCaret && `startContainer` in rangeOrCaret && rangeOrCaret.startContainer === lastValidRange.startContainer) {\n          lastValidOffset = rangeOrCaret.startOffset\n        }\n        if (rangeOrCaret && `offsetNode` in rangeOrCaret && rangeOrCaret.offsetNode === lastValidRange.startContainer) {\n          lastValidOffset = rangeOrCaret.offset\n        }\n        return true\n      }\n      return false\n    })\n\n    if (lastValidRange) {\n      return { node: lastValidRange.startContainer, offset: lastValidOffset }\n    }\n\n    return { node: element, offset: 0 }\n  }\n\n  return undefined\n})\n\nconst getFirstVisibleElementForViewport = (element: Element, viewport: ViewPort) => {\n  let lastValidElement: Element | undefined\n  const positionFromViewport = getElementOrNodePositionFromViewPort(element.getBoundingClientRect(), viewport)\n\n  if (positionFromViewport !== `before` && positionFromViewport !== `after`) {\n    lastValidElement = element\n  }\n\n  Array.from(element.children).some(child => {\n    const childInViewPort = getFirstVisibleElementForViewport(child, viewport)\n    if (childInViewPort) {\n      lastValidElement = childInViewPort\n\n      return true\n    }\n\n    return false\n  })\n\n  return lastValidElement\n}\n\nfunction getElementOrNodePositionFromViewPort (domRect: DOMRect, { left, right }: ViewPort) {\n  // horizontal + ltr\n  if (domRect.left <= left && domRect.right <= left) return `before`\n  if (domRect.left <= left && domRect.right > left && domRect.right <= right) return `partially-before`\n  if (domRect.left <= right && domRect.right > right) return `partially-after`\n  if (domRect.left > right) return `after`\n  return `within`\n\n  // @todo rtl\n  // @todo vertical-lrt\n  // @todo vertical-rtl\n}\n\nfunction getFirstVisibleDOMRect (domRect: DOMRectList, viewport: ViewPort) {\n  return Array.from(domRect).find(domRect => {\n    const position = getElementOrNodePositionFromViewPort(domRect, viewport)\n\n    if (position !== `before` && position !== `after`) {\n      return true\n    }\n    return false\n  })\n}\n\nexport const getRangeFromNode = (node: Node, offset: number) => {\n  if (node.nodeType !== Node.CDATA_SECTION_NODE && node.nodeType !== Node.DOCUMENT_TYPE_NODE) {\n    const range = node.ownerDocument?.createRange()\n    range?.selectNodeContents(node)\n\n    try {\n      if (offset <= (range?.endOffset || 0)) {\n        range?.setStart(node, offset || 0)\n      }\n    } catch (e) {\n      Report.error(e)\n    }\n\n    return range\n  }\n\n  return undefined\n}\n\nexport const isPointerEvent = (event: Event): event is PointerEvent => {\n  if ((event as PointerEvent)?.target && (event?.target as Element)?.ownerDocument?.defaultView) {\n    const eventView = (event?.target as Element)?.ownerDocument?.defaultView as Window & typeof globalThis\n\n    if (eventView.PointerEvent) {\n      return event instanceof eventView.PointerEvent\n    }\n  }\n\n  if ((event as PointerEvent)?.view && (event as PointerEvent)?.view?.window) {\n    const eventView = (event as PointerEvent)?.view as Window & typeof globalThis\n\n    if (eventView.PointerEvent) {\n      return event instanceof eventView.PointerEvent\n    }\n  }\n\n  return false\n}\n\nexport const isMouseEvent = (event: Event): event is MouseEvent => {\n  if (isPointerEvent(event)) return false\n\n  if ((event as MouseEvent)?.target && (event?.target as Element)?.ownerDocument?.defaultView) {\n    const eventView = (event?.target as Element)?.ownerDocument?.defaultView as Window & typeof globalThis\n\n    if (eventView.MouseEvent) {\n      return event instanceof eventView.MouseEvent\n    }\n  }\n\n  if ((event as MouseEvent)?.view && (event as MouseEvent)?.view?.window) {\n    const eventView = (event as MouseEvent)?.view as Window & typeof globalThis\n\n    if (eventView.MouseEvent) {\n      return event instanceof eventView.MouseEvent\n    }\n  }\n\n  return false\n}\n\nexport const isTouchEvent = (event: Event): event is TouchEvent => {\n  if ((event as TouchEvent)?.target && (event?.target as Element)?.ownerDocument?.defaultView) {\n    const eventView = (event?.target as Element)?.ownerDocument?.defaultView as Window & typeof globalThis\n\n    if (eventView.TouchEvent) {\n      return event instanceof eventView.TouchEvent\n    }\n  }\n\n  if ((event as TouchEvent)?.view && (event as TouchEvent)?.view?.window) {\n    const eventView = (event as TouchEvent)?.view as Window & typeof globalThis\n\n    if (eventView.TouchEvent) {\n      return event instanceof eventView.TouchEvent\n    }\n  }\n\n  return false\n}\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/utils/dom.ts\n");
|
|
560
|
+
|
|
561
|
+
/***/ }),
|
|
562
|
+
|
|
563
|
+
/***/ "./src/utils/manifest.ts":
|
|
564
|
+
/*!*******************************!*\
|
|
565
|
+
!*** ./src/utils/manifest.ts ***!
|
|
566
|
+
\*******************************/
|
|
567
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
568
|
+
|
|
569
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"getCoverItem\": () => (/* binding */ getCoverItem)\n/* harmony export */ });\nconst getCoverItem = (manifest) => {\n var _a;\n const coverItem = (_a = manifest.guide) === null || _a === void 0 ? void 0 : _a.find(item => item.type === `cover`);\n return manifest.spineItems.findIndex(item => coverItem === null || coverItem === void 0 ? void 0 : coverItem.href.endsWith(item.path));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvbWFuaWZlc3QudHMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUtPLE1BQU0sWUFBWSxHQUFHLENBQUMsUUFBa0IsRUFBRSxFQUFFOztJQUNqRCxNQUFNLFNBQVMsR0FBRyxjQUFRLENBQUMsS0FBSywwQ0FBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQztJQUVyRSxPQUFPLFFBQVEsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsU0FBUyxhQUFULFNBQVMsdUJBQVQsU0FBUyxDQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ25GLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvdXRpbHMvbWFuaWZlc3QudHM/NzhhMyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYW5pZmVzdCB9IGZyb20gXCJAcHJvc2UtcmVhZGVyL3NoYXJlZFwiXG5cbi8qKlxuICogQHRvZG8gc3RyaXAgb3V0IHBhcmFtIHVybCBzbyB0aGF0IGVxdWFsaXR5IHdvcmtzIGJldHRlclxuICovXG5leHBvcnQgY29uc3QgZ2V0Q292ZXJJdGVtID0gKG1hbmlmZXN0OiBNYW5pZmVzdCkgPT4ge1xuICBjb25zdCBjb3Zlckl0ZW0gPSBtYW5pZmVzdC5ndWlkZT8uZmluZChpdGVtID0+IGl0ZW0udHlwZSA9PT0gYGNvdmVyYClcblxuICByZXR1cm4gbWFuaWZlc3Quc3BpbmVJdGVtcy5maW5kSW5kZXgoaXRlbSA9PiBjb3Zlckl0ZW0/LmhyZWYuZW5kc1dpdGgoaXRlbS5wYXRoKSlcbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/utils/manifest.ts\n");
|
|
570
|
+
|
|
571
|
+
/***/ }),
|
|
572
|
+
|
|
573
|
+
/***/ "./src/utils/objects.ts":
|
|
574
|
+
/*!******************************!*\
|
|
575
|
+
!*** ./src/utils/objects.ts ***!
|
|
576
|
+
\******************************/
|
|
577
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
578
|
+
|
|
579
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"is\": () => (/* binding */ is),\n/* harmony export */ \"isShallowEqual\": () => (/* binding */ isShallowEqual),\n/* harmony export */ \"groupBy\": () => (/* binding */ groupBy),\n/* harmony export */ \"getBase64FromBlob\": () => (/* binding */ getBase64FromBlob)\n/* harmony export */ });\nconst hasOwn = Object.prototype.hasOwnProperty;\nconst is = (x, y) => {\n if (x === y) {\n return (x !== 0) || (y !== 0) || (1 / x === 1 / y);\n }\n else {\n return false;\n }\n};\nconst isShallowEqual = (objectA, objectB, options) => {\n if (objectA === objectB) {\n return true;\n }\n if (typeof objectA !== `object` || objectA === null) {\n return false;\n }\n if (typeof objectB !== `object` || objectB === null) {\n return false;\n }\n const keysA = Object.keys(objectA);\n const keysB = Object.keys(objectB);\n if (keysA.length !== keysB.length) {\n return false;\n }\n const isEqual = options && typeof options.customEqual === `function` ? options.customEqual : is;\n for (let i = 0; i < keysA.length; i++) {\n const key = keysA[i] || ``;\n if (!hasOwn.call(objectB, key) || !isEqual(objectA[key], objectB[key])) {\n return false;\n }\n }\n return true;\n};\nconst groupBy = (list, getKey) => list.reduce((previous, currentItem) => {\n const group = getKey(currentItem);\n if (!previous[group])\n previous[group] = [];\n previous[group].push(currentItem);\n return previous;\n}, {});\nconst getBase64FromBlob = (data) => {\n const reader = new FileReader();\n return new Promise(resolve => {\n reader.addEventListener(`load`, function () {\n resolve(reader.result);\n }, false);\n reader.readAsDataURL(data);\n });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvb2JqZWN0cy50cy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0EsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxjQUFjO0FBR3ZDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBTSxFQUFFLENBQU0sRUFBVyxFQUFFO0lBQzVDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNYLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7S0FDbkQ7U0FBTTtRQUNMLE9BQU8sS0FBSztLQUNiO0FBQ0gsQ0FBQztBQVlNLE1BQU0sY0FBYyxHQUFHLENBQzVCLE9BQVUsRUFDVixPQUFVLEVBQ1YsT0FFQyxFQUNRLEVBQUU7SUFFWCxJQUFJLE9BQU8sS0FBSyxPQUFPLEVBQUU7UUFDdkIsT0FBTyxJQUFJO0tBQ1o7SUFDRCxJQUFJLE9BQU8sT0FBTyxLQUFLLFFBQVEsSUFBSSxPQUFPLEtBQUssSUFBSSxFQUFFO1FBQ25ELE9BQU8sS0FBSztLQUNiO0lBQ0QsSUFBSSxPQUFPLE9BQU8sS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLElBQUksRUFBRTtRQUNuRCxPQUFPLEtBQUs7S0FDYjtJQUVELE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ2xDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBRWxDLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxLQUFLLENBQUMsTUFBTSxFQUFFO1FBQ2pDLE9BQU8sS0FBSztLQUNiO0lBRUQsTUFBTSxPQUFPLEdBQUcsT0FBTyxJQUFJLE9BQU8sT0FBTyxDQUFDLFdBQVcsS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEVBQUU7SUFFL0YsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDckMsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUU7UUFFMUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRTtZQUN0RSxPQUFPLEtBQUs7U0FDYjtLQUNGO0lBRUQsT0FBTyxJQUFJO0FBQ2IsQ0FBQztBQUVNLE1BQU0sT0FBTyxHQUFHLENBQXlCLElBQVMsRUFBRSxNQUFzQixFQUFFLEVBQUUsQ0FDbkYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFFBQVEsRUFBRSxXQUFXLEVBQUUsRUFBRTtJQUNwQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO0lBQ2pDLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO1FBQUUsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUU7SUFDMUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDakMsT0FBTyxRQUFRO0FBQ2pCLENBQUMsRUFBRSxFQUFvQixDQUFDO0FBRW5CLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxJQUFVLEVBQUUsRUFBRTtJQUM5QyxNQUFNLE1BQU0sR0FBRyxJQUFJLFVBQVUsRUFBRTtJQUUvQixPQUFPLElBQUksT0FBTyxDQUFTLE9BQU8sQ0FBQyxFQUFFO1FBQ25DLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUU7WUFDOUIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxNQUFnQixDQUFDO1FBQ2xDLENBQUMsRUFBRSxLQUFLLENBQUM7UUFFVCxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQztJQUM1QixDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQHByb3NlLXJlYWRlci9jb3JlLy4vc3JjL3V0aWxzL29iamVjdHMudHM/YzkxYSJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBNSVQgwqkgMjAxNyBhenVcbmNvbnN0IGhhc093biA9IE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHlcblxuLy8gT2JqZWN0LmlzIHBvbHlmaWxsXG5leHBvcnQgY29uc3QgaXMgPSAoeDogYW55LCB5OiBhbnkpOiBib29sZWFuID0+IHtcbiAgaWYgKHggPT09IHkpIHtcbiAgICByZXR1cm4gKHggIT09IDApIHx8ICh5ICE9PSAwKSB8fCAoMSAvIHggPT09IDEgLyB5KVxuICB9IGVsc2Uge1xuICAgIHJldHVybiBmYWxzZVxuICB9XG59XG5cbi8qKlxuICogUmV0dXJuIHRydWUsIGlmIGBvYmplY3RBYCBpcyBzaGFsbG93IGVxdWFsIHRvIGBvYmplY3RCYC5cbiAqIFBhc3MgQ3VzdG9tIGVxdWFsaXR5IGZ1bmN0aW9uIHRvIGBjdXN0b21FcXVhbGAuXG4gKiBEZWZhdWx0IGVxdWFsaXR5IGlzIGBPYmplY3QuaXNgXG4gKlxuICogT3B0aW9uczpcbiAqXG4gKiAtIGBjdXN0b21FcXVhbGA6IGZ1bmN0aW9uIHNob3VsZCByZXR1cm4gdHJ1ZSBpZiB0aGUgYGFgIHZhbHVlIGlzIGVxdWFsIHRvIGBiYCB2YWx1ZS5cbiAqIC0gYGRlYnVnYDogZW5hYmxlIGRlYnVnIGluZm8gdG8gY29uc29sZSBsb2cuIFRoaXMgbG9nIHdpbGwgYmUgZGlzYWJsZSBpbiBwcm9kdWN0aW9uIGJ1aWxkXG4gKi9cbmV4cG9ydCBjb25zdCBpc1NoYWxsb3dFcXVhbCA9IDxUID0gYW55LCBSID0gYW55PihcbiAgb2JqZWN0QTogVCxcbiAgb2JqZWN0QjogUixcbiAgb3B0aW9ucz86IHtcbiAgICBjdXN0b21FcXVhbD86IDxUPihhOiBULCBiOiBUKSA9PiBib29sZWFuO1xuICB9XG4pOiBib29sZWFuID0+IHtcbiAgLy8gQHRzLWlnbm9yZVxuICBpZiAob2JqZWN0QSA9PT0gb2JqZWN0Qikge1xuICAgIHJldHVybiB0cnVlXG4gIH1cbiAgaWYgKHR5cGVvZiBvYmplY3RBICE9PSBgb2JqZWN0YCB8fCBvYmplY3RBID09PSBudWxsKSB7XG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cbiAgaWYgKHR5cGVvZiBvYmplY3RCICE9PSBgb2JqZWN0YCB8fCBvYmplY3RCID09PSBudWxsKSB7XG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICBjb25zdCBrZXlzQSA9IE9iamVjdC5rZXlzKG9iamVjdEEpXG4gIGNvbnN0IGtleXNCID0gT2JqZWN0LmtleXMob2JqZWN0QilcblxuICBpZiAoa2V5c0EubGVuZ3RoICE9PSBrZXlzQi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuXG4gIGNvbnN0IGlzRXF1YWwgPSBvcHRpb25zICYmIHR5cGVvZiBvcHRpb25zLmN1c3RvbUVxdWFsID09PSBgZnVuY3Rpb25gID8gb3B0aW9ucy5jdXN0b21FcXVhbCA6IGlzXG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBrZXlzQS5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IGtleSA9IGtleXNBW2ldIHx8IGBgXG4gICAgLy8gQHRzLWlnbm9yZVxuICAgIGlmICghaGFzT3duLmNhbGwob2JqZWN0Qiwga2V5KSB8fCAhaXNFcXVhbChvYmplY3RBW2tleV0sIG9iamVjdEJba2V5XSkpIHtcbiAgICAgIHJldHVybiBmYWxzZVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cnVlXG59XG5cbmV4cG9ydCBjb25zdCBncm91cEJ5ID0gPFQsIEsgZXh0ZW5kcyBrZXlvZiBhbnk+KGxpc3Q6IFRbXSwgZ2V0S2V5OiAoaXRlbTogVCkgPT4gSykgPT5cbiAgbGlzdC5yZWR1Y2UoKHByZXZpb3VzLCBjdXJyZW50SXRlbSkgPT4ge1xuICAgIGNvbnN0IGdyb3VwID0gZ2V0S2V5KGN1cnJlbnRJdGVtKVxuICAgIGlmICghcHJldmlvdXNbZ3JvdXBdKSBwcmV2aW91c1tncm91cF0gPSBbXVxuICAgIHByZXZpb3VzW2dyb3VwXS5wdXNoKGN1cnJlbnRJdGVtKVxuICAgIHJldHVybiBwcmV2aW91c1xuICB9LCB7fSBhcyBSZWNvcmQ8SywgVFtdPilcblxuZXhwb3J0IGNvbnN0IGdldEJhc2U2NEZyb21CbG9iID0gKGRhdGE6IEJsb2IpID0+IHtcbiAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKVxuXG4gIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmc+KHJlc29sdmUgPT4ge1xuICAgIHJlYWRlci5hZGRFdmVudExpc3RlbmVyKGBsb2FkYCwgZnVuY3Rpb24gKCkge1xuICAgICAgcmVzb2x2ZShyZWFkZXIucmVzdWx0IGFzIHN0cmluZylcbiAgICB9LCBmYWxzZSlcblxuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGRhdGEpXG4gIH0pXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/utils/objects.ts\n");
|
|
580
|
+
|
|
581
|
+
/***/ }),
|
|
582
|
+
|
|
583
|
+
/***/ "./src/utils/rxjs.ts":
|
|
584
|
+
/*!***************************!*\
|
|
585
|
+
!*** ./src/utils/rxjs.ts ***!
|
|
586
|
+
\***************************/
|
|
587
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
588
|
+
|
|
589
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"mapKeysTo\": () => (/* binding */ mapKeysTo)\n/* harmony export */ });\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs/operators */ \"rxjs/operators\");\n/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(rxjs_operators__WEBPACK_IMPORTED_MODULE_0__);\n\nconst mapKeysTo = (keys) => {\n return (0,rxjs_operators__WEBPACK_IMPORTED_MODULE_0__.map)((obj) => {\n return Object.entries(obj)\n .reduce((acc, [key, entry]) => {\n if (keys.includes(key)) {\n return Object.assign(Object.assign({}, acc), { [key]: entry });\n }\n return acc;\n }, {});\n });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvcnhqcy50cy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFDb0M7QUFFN0IsTUFBTSxTQUFTLEdBQUcsQ0FBc0QsSUFBUyxFQUFtQyxFQUFFO0lBQzNILE9BQU8sbURBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1FBQ2pCLE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUM7YUFDdkIsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUU7WUFDNUIsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQVUsQ0FBQyxFQUFFO2dCQUM3Qix1Q0FDSyxHQUFHLEtBQ04sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLElBQ2I7YUFDRjtZQUVELE9BQU8sR0FBRztRQUNaLENBQUMsRUFBRSxFQUF5QixDQUFDO0lBQ2pDLENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvdXRpbHMvcnhqcy50cz9jNzgwIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9wZXJhdG9yRnVuY3Rpb24gfSBmcm9tIFwicnhqc1wiXG5pbXBvcnQgeyBtYXAgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIlxuXG5leHBvcnQgY29uc3QgbWFwS2V5c1RvID0gPFIgZXh0ZW5kcyB7IFtrZXk6IHN0cmluZ106IGFueSB9LCBLIGV4dGVuZHMga2V5b2YgUj4oa2V5czogS1tdKTogT3BlcmF0b3JGdW5jdGlvbjxSLCBQaWNrPFIsIEs+PiA9PiB7XG4gIHJldHVybiBtYXAoKG9iaikgPT4ge1xuICAgIHJldHVybiBPYmplY3QuZW50cmllcyhvYmopXG4gICAgICAucmVkdWNlKChhY2MsIFtrZXksIGVudHJ5XSkgPT4ge1xuICAgICAgICBpZiAoa2V5cy5pbmNsdWRlcyhrZXkgYXMgYW55KSkge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5hY2MsXG4gICAgICAgICAgICBba2V5XTogZW50cnlcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYWNjXG4gICAgICB9LCB7fSBhcyBQaWNrPHR5cGVvZiBvYmosIEs+KVxuICB9KVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/utils/rxjs.ts\n");
|
|
590
|
+
|
|
591
|
+
/***/ }),
|
|
592
|
+
|
|
593
|
+
/***/ "./src/utils/url.ts":
|
|
594
|
+
/*!**************************!*\
|
|
595
|
+
!*** ./src/utils/url.ts ***!
|
|
596
|
+
\**************************/
|
|
597
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
598
|
+
|
|
599
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"getUrlExtension\": () => (/* binding */ getUrlExtension)\n/* harmony export */ });\nconst getUrlExtension = (url) => {\n var _a, _b;\n return ((_b = (_a = url.split(/[#?]/)[0]) === null || _a === void 0 ? void 0 : _a.split(`.`).pop()) === null || _b === void 0 ? void 0 : _b.trim()) || ``;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdXRpbHMvdXJsLnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBTyxNQUFNLGVBQWUsR0FBRyxDQUFDLEdBQVcsRUFBRSxFQUFFOztJQUM3QyxPQUFPLGdCQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQywwQ0FBRSxLQUFLLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSwwQ0FBRSxJQUFJLEVBQUUsS0FBSSxFQUFFO0FBQzdELENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9AcHJvc2UtcmVhZGVyL2NvcmUvLi9zcmMvdXRpbHMvdXJsLnRzPzExMGMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGdldFVybEV4dGVuc2lvbiA9ICh1cmw6IHN0cmluZykgPT4ge1xuICByZXR1cm4gdXJsLnNwbGl0KC9bIz9dLylbMF0/LnNwbGl0KGAuYCkucG9wKCk/LnRyaW0oKSB8fCBgYFxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/utils/url.ts\n");
|
|
600
|
+
|
|
601
|
+
/***/ }),
|
|
602
|
+
|
|
603
|
+
/***/ "rxjs":
|
|
604
|
+
/*!***********************!*\
|
|
605
|
+
!*** external "rxjs" ***!
|
|
606
|
+
\***********************/
|
|
607
|
+
/***/ ((module) => {
|
|
608
|
+
|
|
609
|
+
module.exports = require("rxjs");
|
|
610
|
+
|
|
611
|
+
/***/ }),
|
|
612
|
+
|
|
613
|
+
/***/ "rxjs/operators":
|
|
614
|
+
/*!*********************************!*\
|
|
615
|
+
!*** external "rxjs/operators" ***!
|
|
616
|
+
\*********************************/
|
|
617
|
+
/***/ ((module) => {
|
|
618
|
+
|
|
619
|
+
module.exports = require("rxjs/operators");
|
|
620
|
+
|
|
621
|
+
/***/ })
|
|
622
|
+
|
|
623
|
+
/******/ });
|
|
624
|
+
/************************************************************************/
|
|
625
|
+
/******/ // The module cache
|
|
626
|
+
/******/ var __webpack_module_cache__ = {};
|
|
627
|
+
/******/
|
|
628
|
+
/******/ // The require function
|
|
629
|
+
/******/ function __webpack_require__(moduleId) {
|
|
630
|
+
/******/ // Check if module is in cache
|
|
631
|
+
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
632
|
+
/******/ if (cachedModule !== undefined) {
|
|
633
|
+
/******/ return cachedModule.exports;
|
|
634
|
+
/******/ }
|
|
635
|
+
/******/ // Create a new module (and put it into the cache)
|
|
636
|
+
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
637
|
+
/******/ // no module.id needed
|
|
638
|
+
/******/ // no module.loaded needed
|
|
639
|
+
/******/ exports: {}
|
|
640
|
+
/******/ };
|
|
641
|
+
/******/
|
|
642
|
+
/******/ // Execute the module function
|
|
643
|
+
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
644
|
+
/******/
|
|
645
|
+
/******/ // Return the exports of the module
|
|
646
|
+
/******/ return module.exports;
|
|
647
|
+
/******/ }
|
|
648
|
+
/******/
|
|
649
|
+
/************************************************************************/
|
|
650
|
+
/******/ /* webpack/runtime/compat get default export */
|
|
651
|
+
/******/ (() => {
|
|
652
|
+
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
653
|
+
/******/ __webpack_require__.n = (module) => {
|
|
654
|
+
/******/ var getter = module && module.__esModule ?
|
|
655
|
+
/******/ () => (module['default']) :
|
|
656
|
+
/******/ () => (module);
|
|
657
|
+
/******/ __webpack_require__.d(getter, { a: getter });
|
|
658
|
+
/******/ return getter;
|
|
659
|
+
/******/ };
|
|
660
|
+
/******/ })();
|
|
661
|
+
/******/
|
|
662
|
+
/******/ /* webpack/runtime/define property getters */
|
|
663
|
+
/******/ (() => {
|
|
664
|
+
/******/ // define getter functions for harmony exports
|
|
665
|
+
/******/ __webpack_require__.d = (exports, definition) => {
|
|
666
|
+
/******/ for(var key in definition) {
|
|
667
|
+
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
668
|
+
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
669
|
+
/******/ }
|
|
670
|
+
/******/ }
|
|
671
|
+
/******/ };
|
|
672
|
+
/******/ })();
|
|
673
|
+
/******/
|
|
674
|
+
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|
675
|
+
/******/ (() => {
|
|
676
|
+
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
677
|
+
/******/ })();
|
|
678
|
+
/******/
|
|
679
|
+
/******/ /* webpack/runtime/make namespace object */
|
|
680
|
+
/******/ (() => {
|
|
681
|
+
/******/ // define __esModule on exports
|
|
682
|
+
/******/ __webpack_require__.r = (exports) => {
|
|
683
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
684
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
685
|
+
/******/ }
|
|
686
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
687
|
+
/******/ };
|
|
688
|
+
/******/ })();
|
|
689
|
+
/******/
|
|
690
|
+
/************************************************************************/
|
|
691
|
+
/******/
|
|
692
|
+
/******/ // startup
|
|
693
|
+
/******/ // Load entry module and return exports
|
|
694
|
+
/******/ // This entry module is referenced by other modules so it can't be inlined
|
|
695
|
+
/******/ var __webpack_exports__ = __webpack_require__("./src/index.ts");
|
|
696
|
+
/******/ var __webpack_export_target__ = exports;
|
|
697
|
+
/******/ for(var i in __webpack_exports__) __webpack_export_target__[i] = __webpack_exports__[i];
|
|
698
|
+
/******/ if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, "__esModule", { value: true });
|
|
699
|
+
/******/
|
|
700
|
+
/******/ })()
|
|
701
|
+
;
|