From 7dbe06815b4939a8ca8fd67225b16fdc51c42ad4 Mon Sep 17 00:00:00 2001 From: Pravin D Date: Sun, 3 Dec 2023 16:23:16 +0530 Subject: [PATCH] Fix for bug https://github.com/futurepress/epub.js/issues/1367 --- src/book.js | 2 +- src/navigation.js | 9 +++++++-- src/utils/path.js | 11 +++++++++++ 3 files changed, 19 insertions(+), 3 deletions(-) diff --git a/src/book.js b/src/book.js index fb66e54b1..606ab2e3d 100644 --- a/src/book.js +++ b/src/book.js @@ -547,7 +547,7 @@ class Book { return this.load(navPath, "xml") .then((xml) => { - this.navigation = new Navigation(xml); + this.navigation = new Navigation(xml, navPath); this.pageList = new PageList(xml); return this.navigation; }); diff --git a/src/navigation.js b/src/navigation.js index 801598bdc..8a40348ce 100644 --- a/src/navigation.js +++ b/src/navigation.js @@ -1,11 +1,12 @@ import {qs, qsa, querySelectorByType, filterChildren, getParentByTagName} from "./utils/core"; +import Path from './utils/path' /** * Navigation Parser * @param {document} xml navigation html / xhtml / ncx */ class Navigation { - constructor(xml) { + constructor(xml, navPath='') { this.toc = []; this.tocByHref = {}; this.tocById = {}; @@ -14,6 +15,9 @@ class Navigation { this.landmarksByType = {}; this.length = 0; + if (navPath) { + this.tocPath = new Path(navPath) + } if (xml) { this.parse(xml); } @@ -198,7 +202,8 @@ class Navigation { return; } - let src = content.getAttribute("href") || ""; + const href = content.getAttribute("href") || ""; + let src = this.tocPath.join(href) if (!id) { id = src; diff --git a/src/utils/path.js b/src/utils/path.js index 6a060cb14..1b71ab920 100644 --- a/src/utils/path.js +++ b/src/utils/path.js @@ -58,6 +58,17 @@ class Path { return (what.charAt(what.length-1) === "/"); } + /** + * Join a paths + * + * https://nodejs.org/api/path.html#pathjoinpaths + * @param {string} what + * @returns {string} joined path + */ + join (what) { + return path.join(this.directory, what); + } + /** * Resolve a path against the directory of the Path *