@prose-reader/streamer 1.15.0 → 1.16.0

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.
@@ -91,12 +91,15 @@ const y = {
91
91
  enable: (e) => {
92
92
  b = e;
93
93
  },
94
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
94
95
  log: (...e) => {
95
96
  b && console.log("[prose-reader-streamer]", ...e);
96
97
  },
98
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
97
99
  warn: (...e) => {
98
100
  b && console.warn("[prose-reader-streamer]", ...e);
99
101
  },
102
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
100
103
  error: (...e) => {
101
104
  console.error(...e);
102
105
  },
@@ -113,6 +116,7 @@ const y = {
113
116
  `${e.name} took ${e.duration}ms which is above the ${i}ms target for this function`
114
117
  ));
115
118
  },
119
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
116
120
  measurePerformance: (e, i = 10, n) => (...a) => {
117
121
  const t = performance.now(), r = n(...a);
118
122
  if (r && r.then)
@@ -174,6 +178,7 @@ const y = {
174
178
  progressionWeight: q / V,
175
179
  pageSpreadLeft: D.some((u) => u === "page-spread-left") || void 0,
176
180
  pageSpreadRight: D.some((u) => u === "page-spread-right") || void 0,
181
+ // size: itemSize
177
182
  mediaType: c == null ? void 0 : c.attr["media-type"]
178
183
  };
179
184
  })) || [],
@@ -202,6 +207,7 @@ const y = {
202
207
  ...a.mediaType && {
203
208
  "Content-Type": a.mediaType
204
209
  }
210
+ // 'Cache-Control': `no-cache, no-store, no-transform`
205
211
  }
206
212
  }
207
213
  };
@@ -238,6 +244,9 @@ const y = {
238
244
  renditionSpread: "auto",
239
245
  readingDirection: "ltr",
240
246
  spineItems: n.map((t, r) => ({
247
+ // some books such as cbz can have same basename inside different sub folder
248
+ // we need to make sure to have unique index
249
+ // /chap01/01.png, /chap02/01.png, etc
241
250
  id: `${r}.${t.basename}`,
242
251
  href: encodeURI(`${i}${t.uri}`),
243
252
  renditionLayout: "pre-paginated",
@@ -445,6 +454,9 @@ const y = {
445
454
  ...r.internalStream && {
446
455
  stream: r.internalStream
447
456
  },
457
+ // this is private API
458
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
459
+ // @ts-ignore
448
460
  size: r._data.uncompressedSize
449
461
  }))
450
462
  };
@@ -1 +1 @@
1
- {"version":3,"file":"prose-streamer.js","sources":["../src/parsers/nav.ts","../src/parsers/kobo.ts","../src/report.ts","../src/archives/getArchiveOpfInfo.ts","../src/epub/getSpineItemFilesFromArchive.ts","../src/generators/manifest/hooks/epub.ts","../src/generators/resources.ts","../src/generators/manifest/hooks/default.ts","../src/generators/manifest/hooks/comicInfo.ts","../src/generators/manifest/hooks/epubOptimizer.ts","../src/utils/sortByTitleComparator.ts","../src/generators/manifest/hooks/navigationFallback.ts","../src/generators/manifest/index.ts","../src/utils/uri.ts","../src/archives/createArchiveFromUrls.ts","../src/utils/blobToBAse64.ts","../src/archives/createArchiveFromText.ts","../src/archives/createArchiveFromJszip.ts","../src/archives/createArchiveFromArrayBufferList.ts","../src/configure.ts"],"sourcesContent":["import xmldoc, { XmlElement } from \"xmldoc\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { urlJoin } from \"@prose-reader/shared\"\n\ntype Toc = NonNullable<Manifest[`nav`]>[`toc`]\ntype TocItem = NonNullable<Manifest[`nav`]>[`toc`][number]\n\nconst extractNavChapter = (li: XmlElement, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const chp: TocItem = {\n contents: [],\n path: ``,\n href: ``,\n title: ``,\n }\n let contentNode = li.childNamed(`span`) || li.childNamed(`a`)\n chp.title = contentNode?.attr.title || contentNode?.val.trim() || chp.title\n let node = contentNode?.name\n if (node !== `a`) {\n contentNode = li.descendantWithPath(`${node}.a`)\n if (contentNode) {\n node = contentNode.name.toLowerCase()\n }\n }\n if (node === `a` && contentNode?.attr.href) {\n chp.path = urlJoin(opfBasePath, contentNode.attr.href)\n chp.href = urlJoin(baseUrl, opfBasePath, contentNode.attr.href)\n }\n const sublistNode = li.childNamed(`ol`)\n if (sublistNode) {\n const children = sublistNode.childrenNamed(`li`)\n if (children && children.length > 0) {\n chp.contents = children.map((child) => extractNavChapter(child, { opfBasePath, baseUrl }))\n }\n }\n\n return chp\n}\n\nconst buildTOCFromNav = (doc: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: Toc = []\n\n let navDataChildren\n if (doc.descendantWithPath(`body.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.nav.ol`)?.children\n } else if (doc.descendantWithPath(`body.section.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.section.nav.ol`)?.children\n }\n\n if (navDataChildren && navDataChildren.length > 0) {\n navDataChildren\n .filter((li) => (li as XmlElement).name === `li`)\n .forEach((li) => toc.push(extractNavChapter(li as XmlElement, { opfBasePath, baseUrl })))\n }\n\n return toc\n}\n\nconst parseTocFromNavPath = async (\n opfXmlDoc: xmldoc.XmlDocument,\n archive: Archive,\n { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }\n) => {\n // Try to detect if there is a nav item\n const navItem = opfXmlDoc\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((child) => child.attr.properties === `nav`)\n\n if (navItem) {\n const tocFile = Object.values(archive.files).find((item) => item.uri.endsWith(navItem.attr.href || ``))\n if (tocFile) {\n const doc = new xmldoc.XmlDocument(await tocFile.string())\n return buildTOCFromNav(doc, { opfBasePath, baseUrl })\n }\n }\n}\n\nconst mapNcxChapter = (\n point: xmldoc.XmlElement,\n { opfBasePath, baseUrl, prefix }: { opfBasePath: string; baseUrl: string; prefix: string }\n) => {\n const src = point?.childNamed(`${prefix}content`)?.attr.src || ``\n\n const out: TocItem = {\n title: point?.descendantWithPath(`${prefix}navLabel.${prefix}text`)?.val || ``,\n path: urlJoin(opfBasePath, src),\n href: urlJoin(baseUrl, opfBasePath, src),\n contents: [],\n }\n const children = point.childrenNamed(`${prefix}navPoint`)\n if (children && children.length > 0) {\n out.contents = children.map((pt) => mapNcxChapter(pt, { opfBasePath, baseUrl, prefix }))\n }\n\n return out\n}\n\nconst buildTOCFromNCX = (ncxData: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: NonNullable<Manifest[`nav`]>[`toc`] = []\n\n const rootTagName = ncxData.name\n let prefix = ``\n if (rootTagName.indexOf(`:`) !== -1) {\n prefix = rootTagName.split(`:`)[0] + `:`\n }\n\n ncxData\n .childNamed(`${prefix}navMap`)\n ?.childrenNamed(`${prefix}navPoint`)\n .forEach((point) => toc.push(mapNcxChapter(point, { opfBasePath, baseUrl, prefix })))\n\n return toc\n}\n\nconst parseTocFromNcx = async ({\n opfData,\n opfBasePath,\n baseUrl,\n archive,\n}: {\n opfData: xmldoc.XmlDocument\n opfBasePath: string\n archive: Archive\n baseUrl: string\n}) => {\n const spine = opfData.childNamed(`spine`)\n const ncxId = spine && spine.attr.toc\n\n if (ncxId) {\n const ncxItem = opfData\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((item) => item.attr.id === ncxId)\n\n if (ncxItem) {\n const ncxPath = `${opfBasePath}${opfBasePath === `` ? `` : `/`}${ncxItem.attr.href}`\n\n const file = Object.values(archive.files).find((item) => item.uri.endsWith(ncxPath))\n\n if (file) {\n const ncxData = new xmldoc.XmlDocument(await file.string())\n\n return buildTOCFromNCX(ncxData, { opfBasePath, baseUrl })\n }\n }\n }\n}\n\nexport const parseToc = async (opfXmlDoc: xmldoc.XmlDocument, archive: Archive, { baseUrl }: { baseUrl: string }) => {\n const { basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const tocFromNcx = await parseTocFromNcx({\n opfData: opfXmlDoc,\n opfBasePath,\n archive,\n baseUrl,\n })\n\n if (tocFromNcx) {\n return tocFromNcx\n }\n\n return await parseTocFromNavPath(opfXmlDoc, archive, { opfBasePath, baseUrl })\n}\n","import xmldoc from \"xmldoc\"\nimport { Archive } from \"..\"\n\ntype KoboInformation = {\n renditionLayout?: `reflowable` | `pre-paginated` | undefined\n}\n\nexport const extractKoboInformationFromArchive = async (archive: Archive) => {\n const koboInformation: KoboInformation = {\n renditionLayout: undefined,\n }\n\n await Promise.all(\n archive.files.map(async (file) => {\n if (file.uri.endsWith(`com.kobobooks.display-options.xml`)) {\n const opfXmlDoc = new xmldoc.XmlDocument(await file.string())\n const optionElement = opfXmlDoc.childNamed(`platform`)?.childNamed(`option`)\n if (optionElement?.attr?.name === `fixed-layout` && optionElement.val === `true`) {\n koboInformation.renditionLayout = `pre-paginated`\n }\n }\n })\n )\n\n return koboInformation\n}\n","let enabled = false\n\nexport const Report = {\n enable: (enable: boolean) => {\n enabled = enable\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n log: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n warn: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.warn(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n error: (...data: any[]) => {\n // eslint-disable-next-line no-console\n console.error(...data)\n },\n time: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.time(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n timeEnd: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.timeEnd(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n metric: (performanceEntry: { name: string; duration: number }, targetDuration = Infinity) => {\n const duration = typeof performanceEntry === `number` ? performanceEntry : performanceEntry.duration\n if (enabled) {\n if (performanceEntry.duration <= targetDuration) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer] [metric] `, `${performanceEntry.name} took ${duration}ms`)\n } else {\n // eslint-disable-next-line no-console\n console.warn(\n `[prose-reader-streamer] [metric] `,\n `${performanceEntry.name} took ${performanceEntry.duration}ms which is above the ${targetDuration}ms target for this function`\n )\n }\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n measurePerformance: <F extends (...args: any[]) => any>(name: string, targetDuration = 10, functionToMeasure: F) => {\n return (...args: Parameters<F>): ReturnType<F> => {\n const t0 = performance.now()\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const response = functionToMeasure(...(args as any))\n\n if (response && response.then) {\n return response.then((res: any) => {\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n return res\n })\n }\n\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n\n return response\n }\n },\n}\n","import { Archive } from \"./types\"\n\nexport const getArchiveOpfInfo = (archive: Archive) => {\n const filesAsArray = Object.values(archive.files).filter((file) => !file.dir)\n const file = filesAsArray.find((file) => file.uri.endsWith(`.opf`))\n\n return {\n data: file,\n basePath: file?.uri.substring(0, file.uri.lastIndexOf(`/`)) || ``,\n }\n}\n","import xmldoc from \"xmldoc\"\nimport { getArchiveOpfInfo } from \"../archives/getArchiveOpfInfo\"\nimport { Archive } from \"../archives/types\"\n\nexport const getSpineItemFilesFromArchive = async ({ archive }: { archive: Archive }) => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const data = await opsFile?.string()\n\n if (!data) return []\n\n const _opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const manifestElm = _opfXmlDoc.childNamed(`manifest`)\n const spineElm = _opfXmlDoc.childNamed(`spine`)\n\n const spineItemIds = spineElm?.childrenNamed(`itemref`).map((item) => item.attr.idref) as string[]\n const manifestItemsFromSpine =\n manifestElm?.childrenNamed(`item`).filter((item) => spineItemIds.includes(item.attr.id || ``)) || []\n\n const archiveSpineItems = archive.files.filter((file) => {\n return manifestItemsFromSpine.find((item) => {\n if (!opfBasePath) return `${item.attr.href}` === file.uri\n return `${opfBasePath}/${item.attr.href}` === file.uri\n })\n })\n\n return archiveSpineItems\n}\n","import xmldoc from \"xmldoc\"\nimport { parseToc } from \"../../../parsers/nav\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { extractKoboInformationFromArchive } from \"../../../parsers/kobo\"\nimport { Report } from \"../../../report\"\nimport { Archive } from \"../../../archives/types\"\nimport { getArchiveOpfInfo } from \"../../../archives/getArchiveOpfInfo\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\ntype SpineItemProperties = `rendition:layout-reflowable` | `page-spread-left` | `page-spread-right`\n\nexport const getItemsFromDoc = (doc: xmldoc.XmlDocument) => {\n const manifestElm = doc.childNamed(`manifest`)\n\n return (\n manifestElm?.childrenNamed(`item`)?.map((el) => ({\n href: el.attr.href || ``,\n id: el.attr.id || ``,\n mediaType: el.attr[`media-type`],\n })) || []\n )\n}\n\nexport const epubHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n const koboInformation = await extractKoboInformationFromArchive(archive)\n\n if (!opsFile) {\n return manifest\n }\n\n const data = await opsFile.string()\n\n Report.log(data, koboInformation)\n\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const toc = (await parseToc(opfXmlDoc, archive, { baseUrl })) || []\n\n const metadataElm = opfXmlDoc.childNamed(`metadata`)\n const manifestElm = opfXmlDoc.childNamed(`manifest`)\n const spineElm = opfXmlDoc.childNamed(`spine`)\n const guideElm = opfXmlDoc.childNamed(`guide`)\n const titleElm = metadataElm?.childNamed(`dc:title`)\n const metaElmChildren = metadataElm?.childrenNamed(`meta`) || []\n const metaElmWithRendition = metaElmChildren.find((meta) => meta.attr.property === `rendition:layout`)\n const metaElmWithRenditionFlow = metaElmChildren.find((meta) => meta.attr.property === `rendition:flow`)\n const metaElmWithRenditionSpread = metaElmChildren.find((meta) => meta.attr.property === `rendition:spread`)\n\n const publisherRenditionLayout = metaElmWithRendition?.val as `reflowable` | `pre-paginated` | undefined\n const publisherRenditionFlow = metaElmWithRenditionFlow?.val as\n | `scrolled-continuous`\n | `scrolled-doc`\n | `paginated`\n | `auto`\n | undefined\n const renditionSpread = metaElmWithRenditionSpread?.val as `auto` | undefined\n\n const title = titleElm?.val || archive.files.find(({ dir }) => dir)?.basename || ``\n const pageProgressionDirection = spineElm?.attr[`page-progression-direction`] as `ltr` | `rtl` | undefined\n\n const archiveSpineItems = await getSpineItemFilesFromArchive({ archive })\n\n const totalSize = archiveSpineItems.reduce((size, file) => file.size + size, 0)\n\n return {\n filename: archive.filename,\n nav: {\n toc,\n },\n renditionLayout: publisherRenditionLayout || koboInformation.renditionLayout || `reflowable`,\n renditionFlow: publisherRenditionFlow || `auto`,\n renditionSpread,\n title,\n readingDirection: pageProgressionDirection || `ltr`,\n spineItems:\n spineElm?.childrenNamed(`itemref`).map((itemrefElm) => {\n const manifestItem = manifestElm?.childrenNamed(`item`).find((item) => item.attr.id === itemrefElm?.attr.idref)\n const href = manifestItem?.attr.href || ``\n const properties = (itemrefElm?.attr.properties?.split(` `) || []) as SpineItemProperties[]\n const itemSize = archive.files.find((file) => file.uri.endsWith(href))?.size || 0\n\n // we use base url or nothing (and stay relative)\n const hrefBaseUri = baseUrl ?? \"\"\n\n return {\n id: manifestItem?.attr.id || ``,\n href: manifestItem?.attr.href?.startsWith(`https://`)\n ? manifestItem?.attr.href\n : opfBasePath\n ? `${hrefBaseUri}${opfBasePath}/${manifestItem?.attr.href}`\n : `${hrefBaseUri}${manifestItem?.attr.href}`,\n renditionLayout: publisherRenditionLayout || `reflowable`,\n ...(properties.find((property) => property === `rendition:layout-reflowable`) && {\n renditionLayout: `reflowable`,\n }),\n progressionWeight: itemSize / totalSize,\n pageSpreadLeft: properties.some((property) => property === `page-spread-left`) || undefined,\n pageSpreadRight: properties.some((property) => property === `page-spread-right`) || undefined,\n // size: itemSize\n mediaType: manifestItem?.attr[`media-type`],\n }\n }) || [],\n items: getItemsFromDoc(opfXmlDoc),\n guide: guideElm?.childrenNamed(`reference`).map((elm) => {\n return {\n href: elm.attr.href || ``,\n title: elm.attr.title || ``,\n type: elm.attr.type as NonNullable<Manifest[`guide`]>[number][`type`],\n }\n }),\n }\n }\n","import xmldoc from \"xmldoc\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { getItemsFromDoc } from \"./manifest/hooks/epub\"\n\nexport const generateResourceFromArchive = async (archive: Archive, resourcePath: string) => {\n const file = Object.values(archive.files).find((file) => file.uri === resourcePath)\n\n const metadata = await getMetadata(archive, resourcePath)\n\n if (!file) {\n throw new Error(`no file found`)\n }\n\n const blob = await file.blob()\n\n // if (file.stream) {\n // const stream = file.stream()\n\n // console.log(file, stream)\n // stream.on(`data`, data => {\n // console.log(`data`, data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // console.log(`end`)\n // })\n\n // }\n\n // const stream = file.stream!()\n\n // const readableStream = new ReadableStream({\n // start(controller) {\n // function push() {\n // stream.on(`data`, data => {\n // controller.enqueue(data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // controller.close()\n // })\n\n // stream.resume()\n // }\n\n // push();\n // }\n // })\n\n return {\n body: blob,\n params: {\n headers: {\n ...(blob.type && {\n \"Content-Type\": blob.type,\n }),\n ...(file.encodingFormat && {\n \"Content-Type\": file.encodingFormat,\n }),\n ...(metadata.mediaType && {\n \"Content-Type\": metadata.mediaType,\n }),\n // 'Cache-Control': `no-cache, no-store, no-transform`\n },\n },\n }\n}\n\nconst getMetadata = async (archive: Archive, resourcePath: string) => {\n const opfInfo = getArchiveOpfInfo(archive)\n const data = await opfInfo.data?.string()\n\n if (data) {\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n const items = getItemsFromDoc(opfXmlDoc)\n\n return {\n mediaType: items.find((item) => resourcePath.endsWith(item.href))?.mediaType,\n }\n }\n\n return {\n mediaType: getContentTypeFromExtension(resourcePath),\n }\n}\n\nconst getContentTypeFromExtension = (uri: string) => {\n if (uri.endsWith(`.css`)) {\n return `text/css; charset=UTF-8`\n }\n if (uri.endsWith(`.jpg`)) {\n return `image/jpg`\n }\n if (uri.endsWith(`.xhtml`)) {\n return `application/xhtml+xml`\n }\n if (uri.endsWith(`.mp4`)) {\n return `video/mp4`\n }\n if (uri.endsWith(`.svg`)) {\n return `image/svg+xml`\n }\n}\n","import { Manifest } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\n\nexport const defaultHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (): Promise<Manifest> => {\n const files = Object.values(archive.files).filter((file) => !file.dir)\n\n return {\n filename: archive.filename,\n title: archive.files.find(({ dir }) => dir)?.basename.replace(/\\/$/, ``) || ``,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n readingDirection: `ltr`,\n spineItems: files.map((file, index) => ({\n // some books such as cbz can have same basename inside different sub folder\n // we need to make sure to have unique index\n // /chap01/01.png, /chap02/01.png, etc\n id: `${index}.${file.basename}`,\n href: encodeURI(`${baseUrl}${file.uri}`),\n renditionLayout: `pre-paginated`,\n progressionWeight: 1 / files.length,\n pageSpreadLeft: undefined,\n pageSpreadRight: undefined,\n mediaType: file.encodingFormat,\n })),\n items: files.map((file, index) => ({\n id: `${index}.${file.basename}`,\n href: `${baseUrl}${file.uri}`,\n })),\n }\n }\n","import { Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\n\n/**\n * Handle archive which contains ComicInfo.xml. This is a meta file\n * used to define cbz, etc. I believe it comes from some sites or apps.\n */\nexport const comicInfoHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const comicInfoFile = archive.files.find((file) => file.basename.toLowerCase() === `comicinfo.xml`)\n\n if (!comicInfoFile) {\n return manifest\n }\n\n // @todo handle more meta\n const content = await comicInfoFile.string()\n const xmlDoc = new xmldoc.XmlDocument(content)\n\n const mangaVal = (xmlDoc.childNamed(`Manga`)?.val as `YesAndRightToLeft`) || `unknown`\n\n return {\n ...manifest,\n spineItems: manifest.spineItems.filter((item) => item.id.toLowerCase() !== `comicinfo.xml`),\n readingDirection: mangaVal === `YesAndRightToLeft` ? `rtl` : `ltr`,\n }\n }\n","import { isXmlBasedMimeType, Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\nconst hasDocMetaViewport = (doc: xmldoc.XmlDocument) => {\n const metaElm = doc\n .descendantWithPath(\"head\")\n ?.childrenNamed(\"meta\")\n .find((node) => node.attr.name === \"viewport\")\n\n return !!(metaElm && metaElm.attr.name === \"viewport\")\n}\n\nconst allFilesHaveViewportMeta = (files: Archive[\"files\"]) =>\n files.reduce(async (result, current) => {\n const _result = await result\n\n if (!_result) return false\n\n if (\n !isXmlBasedMimeType({\n mimeType: current.encodingFormat,\n uri: current.uri,\n })\n ) {\n return false\n }\n\n const file = await current.string()\n\n if (!file) return false\n\n return hasDocMetaViewport(new xmldoc.XmlDocument(file))\n }, Promise.resolve(true))\n\nexport const epubOptimizerHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const bookIsFullReflowable =\n manifest.renditionLayout === \"reflowable\" && manifest.spineItems.every((item) => item.renditionLayout === \"reflowable\")\n\n if (bookIsFullReflowable) {\n const files = await getSpineItemFilesFromArchive({ archive })\n\n const hasAllViewport = await allFilesHaveViewportMeta(files)\n\n if (hasAllViewport) {\n return {\n ...manifest,\n spineItems: manifest.spineItems.map((item) => ({\n ...item,\n renditionLayout: \"pre-paginated\",\n })),\n renditionLayout: \"pre-paginated\",\n }\n }\n }\n\n return manifest\n }\n","export const sortByTitleComparator = (a: string, b: string) => {\n const alist = a.split(/(\\d+)/)\n const blist = b.split(/(\\d+)/)\n\n for (let i = 0, len = alist.length; i < len; i++) {\n if (alist[i] !== blist[i]) {\n if (alist[i]?.match(/\\d/)) {\n return +(alist[i] || ``) - +(blist[i] || ``)\n } else {\n return (alist[i] || ``).localeCompare(blist[i] || ``)\n }\n }\n }\n\n return 1\n}\n","import { Manifest, urlJoin } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\nimport { sortByTitleComparator } from \"../../../utils/sortByTitleComparator\"\n\n/**\n * In case no navigation was generated prior to this hook, we will try\n * to generate something based on the structure of the archive.\n *\n * We use folders as chapters.\n */\nexport const navigationFallbackHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n if (manifest.nav) return manifest\n\n const filesSortedByAlpha = [...archive.files].sort((a, b) => sortByTitleComparator(a.uri, b.uri))\n\n const toc: NonNullable<Manifest[\"nav\"]>[\"toc\"] = Object.values(filesSortedByAlpha).reduce((acc, file) => {\n const parts = file.uri.split(\"/\")\n\n // we have a file that is\n const isFileUnderFolder = !file.dir && parts.length > 1\n\n if (isFileUnderFolder) {\n parts.forEach((part, level) => {\n const partIsFileName = level === parts.length - 1\n\n if (partIsFileName) return\n\n const existingTocItem = acc.find(({ title }) => title === part)\n\n if (existingTocItem) {\n // @todo\n } else {\n acc.push({\n contents: [],\n href: urlJoin(baseUrl, encodeURI(file.uri)).replace(/\\/$/, \"\"),\n path: file.uri.replace(/\\/$/, \"\"),\n title: parts[0] ?? \"\",\n })\n }\n })\n }\n\n return acc\n }, [] as NonNullable<Manifest[\"nav\"]>[\"toc\"])\n\n if (toc.length === 0) return manifest\n\n return {\n ...manifest,\n nav: {\n toc,\n },\n }\n }\n","import type { Manifest } from \"@prose-reader/shared\"\nimport { Report } from \"../../report\"\nimport { Archive } from \"../../archives/types\"\nimport { defaultHook } from \"./hooks/default\"\nimport { epubHook } from \"./hooks/epub\"\nimport { comicInfoHook } from \"./hooks/comicInfo\"\nimport { epubOptimizerHook } from \"./hooks/epubOptimizer\"\nimport { navigationFallbackHook } from \"./hooks/navigationFallback\"\n\nconst baseManifest: Manifest = {\n filename: ``,\n items: [],\n nav: {\n toc: [],\n },\n readingDirection: `ltr`,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n spineItems: [],\n title: ``,\n}\n\nexport const generateManifestFromArchive = async (archive: Archive, { baseUrl = `` }: { baseUrl?: string } = {}) => {\n const hooks = [\n defaultHook({ archive, baseUrl }),\n epubHook({ archive, baseUrl }),\n epubOptimizerHook({ archive, baseUrl }),\n comicInfoHook({ archive, baseUrl }),\n navigationFallbackHook({ archive, baseUrl }),\n ]\n\n try {\n const manifest = await hooks.reduce(async (manifest, gen) => {\n return await gen(await manifest)\n }, Promise.resolve(baseManifest))\n\n Report.log(\"Generated manifest\", manifest)\n\n return manifest\n } catch (e) {\n Report.error(e)\n\n throw e\n }\n}\n","export const getUriBasename = (uri: string) => uri.substring(uri.lastIndexOf(`/`) + 1) || uri\n","import { detectMimeTypeFromName } from \"@prose-reader/shared\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * @important\n * Make sure the urls are on the same origin or the cors header is set otherwise\n * the resource cannot be consumed as it is on the web.\n */\nexport const createArchiveFromUrls = async (urls: string[], options?: { useRenditionFlow: boolean }): Promise<Archive> => {\n const opfFileData = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?><package xmlns=\"http://www.idpf.org/2007/opf\" version=\"2.0\" unique-identifier=\"bookid\">\n <metadata>\n <meta property=\"rendition:layout\">${options?.useRenditionFlow ? `reflowable` : `pre-paginated`}</meta>\n ${options?.useRenditionFlow ? `<meta property=\"rendition:flow\">scrolled-continuous</meta>` : ``}\n </metadata>\n <manifest>\n ${urls\n .map((url) => `<item id=\"${getUriBasename(url)}\" href=\"${url}\" media-type=\"${detectMimeTypeFromName(url)}\"/>`)\n .join(`\\n`)}\n </manifest>\n <spine>\n ${urls.map((url) => `<itemref idref=\"${getUriBasename(url)}\" />`).join(`\\n`)}\n </spine>\n </package>\n `\n\n const filesFromUrl: Archive[`files`] = urls.map((url) => ({\n dir: false,\n basename: getUriBasename(url),\n encodingFormat: detectMimeTypeFromName(url),\n uri: url,\n size: 100 / urls.length,\n base64: async () => ``,\n blob: async () => new Blob(),\n string: async () => ``,\n }))\n\n const opfFile: Archive[`files`][number] = {\n dir: false,\n basename: `content.opf`,\n uri: `content.opf`,\n size: 0,\n base64: async () => opfFileData,\n blob: async () => new Blob(),\n string: async () => opfFileData,\n }\n\n return {\n filename: ``,\n files: [opfFile, ...filesFromUrl],\n }\n}\n","export const blobToBase64 = async (blob: Blob) =>\n new Promise<string>((resolve) => {\n const reader = new FileReader()\n reader.readAsDataURL(blob)\n reader.onloadend = function () {\n const base64data = reader.result as string\n resolve(base64data)\n }\n })\n","import { blobToBase64 } from \"../utils/blobToBAse64\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * Useful to create archive from txt content\n */\nexport const createArchiveFromText = async (\n content: string | Blob,\n {\n mimeType,\n direction,\n }: {\n direction?: `ltr` | `rtl`\n mimeType?: string\n } = { mimeType: \"text/plain\" }\n) => {\n const txtOpfContent = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n <package xmlns=\"http://www.idpf.org/2007/opf\" version=\"3.0\" xml:lang=\"ja\" prefix=\"rendition: http://www.idpf.org/vocab/rendition/#\"\n unique-identifier=\"ootuya-id\">\n <metadata xmlns:opf=\"http://www.idpf.org/2007/opf\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:dcterms=\"http://purl.org/dc/terms/\">\n <meta property=\"rendition:layout\">reflowable</meta>\n </metadata>\n <manifest>\n <item id=\"p01\" href=\"p01.txt\" media-type=\"text/plain\"/>\n </manifest>\n <spine page-progression-direction=\"${direction ?? `ltr`}\">\n <itemref idref=\"p01\" />\n </spine>\n </package>\n `\n\n const archive: Archive = {\n filename: `content.txt`,\n files: [\n {\n dir: false,\n basename: getUriBasename(`generated.opf`),\n uri: `generated.opf`,\n blob: async () => new Blob([txtOpfContent]),\n string: async () => txtOpfContent,\n base64: async () => btoa(txtOpfContent),\n size: 0,\n },\n {\n dir: false,\n basename: getUriBasename(`p01.txt`),\n uri: `p01.txt`,\n blob: async () => {\n if (typeof content === `string`) return new Blob([content])\n return content\n },\n string: async () => {\n if (typeof content === `string`) return content\n return content.text()\n },\n base64: async () => {\n if (typeof content === `string`) return btoa(content)\n return blobToBase64(content)\n },\n size: typeof content === `string` ? content.length : content.size,\n encodingFormat: mimeType,\n },\n ],\n }\n\n return archive\n}\n","import { Report } from \"../report\"\nimport { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive, StreamResult } from \"./types\"\n\ninterface OutputByType {\n base64: string\n string: string\n text: string\n binarystring: string\n array: number[]\n uint8array: Uint8Array\n arraybuffer: ArrayBuffer\n blob: Blob\n nodebuffer: Buffer\n}\n\ntype OutputType = keyof OutputByType\ninterface JSZipObject {\n name: string\n dir: boolean\n date: Date\n comment: string\n unixPermissions: number | string | null\n dosPermissions: number | null\n async<T extends OutputType>(type: T): Promise<OutputByType[T]>\n // nodeStream(type?: `nodebuffer`): NodeJS.ReadableStream;\n internalStream?: (type?: `uint8array`) => StreamResult\n}\n\ninterface JSZip {\n files: { [key: string]: JSZipObject }\n}\n\nexport const createArchiveFromJszip = async (\n jszip: JSZip,\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = Object.values(jszip.files)\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n const archive = {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.dir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: () => file.async(`blob`),\n string: () => file.async(`string`),\n base64: () => file.async(`base64`),\n ...(file.internalStream && {\n stream: file.internalStream,\n }),\n // this is private API\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n size: file._data.uncompressedSize,\n })),\n }\n\n Report.log(\"Generated archive\", archive)\n\n return archive\n}\n","import { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\nexport const createArchiveFromArrayBufferList = async (\n list: {\n isDir: boolean\n name: string\n size: number\n data: () => Promise<ArrayBuffer>\n }[],\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = list\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n return {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.isDir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: async () => new Blob([await file.data()]),\n string: async () => {\n const data = await file.data()\n return String.fromCharCode.apply(null, Array.from(new Uint16Array(data)))\n },\n base64: async () => {\n // @todo not used for now, lets implement it later if needed\n return ``\n },\n size: file.size,\n })),\n }\n}\n","import { Report } from \"./report\"\n\nexport const configure = ({ enableReport }: { enableReport?: boolean } = {}) => {\n Report.enable(!!enableReport)\n}\n"],"names":["extractNavChapter","li","opfBasePath","baseUrl","chp","contentNode","node","urlJoin","sublistNode","children","child","buildTOCFromNav","doc","toc","navDataChildren","_a","_b","parseTocFromNavPath","opfXmlDoc","archive","navItem","tocFile","item","xmldoc","mapNcxChapter","point","prefix","src","out","pt","buildTOCFromNCX","ncxData","rootTagName","parseTocFromNcx","opfData","spine","ncxId","ncxItem","ncxPath","file","parseToc","getArchiveOpfInfo","tocFromNcx","extractKoboInformationFromArchive","koboInformation","optionElement","enabled","Report","enable","data","label","performanceEntry","targetDuration","duration","name","functionToMeasure","args","t0","response","res","t1","getSpineItemFilesFromArchive","opsFile","_opfXmlDoc","manifestElm","spineElm","spineItemIds","manifestItemsFromSpine","getItemsFromDoc","el","epubHook","manifest","metadataElm","guideElm","titleElm","metaElmChildren","metaElmWithRendition","meta","metaElmWithRenditionFlow","metaElmWithRenditionSpread","publisherRenditionLayout","publisherRenditionFlow","renditionSpread","title","dir","pageProgressionDirection","totalSize","size","itemrefElm","manifestItem","href","properties","itemSize","hrefBaseUri","_c","property","elm","generateResourceFromArchive","resourcePath","metadata","getMetadata","blob","getContentTypeFromExtension","uri","defaultHook","files","index","comicInfoHook","comicInfoFile","content","mangaVal","hasDocMetaViewport","metaElm","allFilesHaveViewportMeta","result","current","isXmlBasedMimeType","epubOptimizerHook","sortByTitleComparator","a","b","alist","blist","i","len","navigationFallbackHook","filesSortedByAlpha","acc","parts","part","level","baseManifest","generateManifestFromArchive","hooks","gen","e","getUriBasename","createArchiveFromUrls","urls","options","opfFileData","url","detectMimeTypeFromName","filesFromUrl","blobToBase64","resolve","reader","base64data","createArchiveFromText","mimeType","direction","txtOpfContent","createArchiveFromJszip","jszip","orderByAlpha","createArchiveFromArrayBufferList","list","configure","enableReport"],"mappings":"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"}
1
+ {"version":3,"file":"prose-streamer.js","sources":["../src/parsers/nav.ts","../src/parsers/kobo.ts","../src/report.ts","../src/archives/getArchiveOpfInfo.ts","../src/epub/getSpineItemFilesFromArchive.ts","../src/generators/manifest/hooks/epub.ts","../src/generators/resources.ts","../src/generators/manifest/hooks/default.ts","../src/generators/manifest/hooks/comicInfo.ts","../src/generators/manifest/hooks/epubOptimizer.ts","../src/utils/sortByTitleComparator.ts","../src/generators/manifest/hooks/navigationFallback.ts","../src/generators/manifest/index.ts","../src/utils/uri.ts","../src/archives/createArchiveFromUrls.ts","../src/utils/blobToBAse64.ts","../src/archives/createArchiveFromText.ts","../src/archives/createArchiveFromJszip.ts","../src/archives/createArchiveFromArrayBufferList.ts","../src/configure.ts"],"sourcesContent":["import xmldoc, { XmlElement } from \"xmldoc\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { urlJoin } from \"@prose-reader/shared\"\n\ntype Toc = NonNullable<Manifest[`nav`]>[`toc`]\ntype TocItem = NonNullable<Manifest[`nav`]>[`toc`][number]\n\nconst extractNavChapter = (li: XmlElement, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const chp: TocItem = {\n contents: [],\n path: ``,\n href: ``,\n title: ``,\n }\n let contentNode = li.childNamed(`span`) || li.childNamed(`a`)\n chp.title = contentNode?.attr.title || contentNode?.val.trim() || chp.title\n let node = contentNode?.name\n if (node !== `a`) {\n contentNode = li.descendantWithPath(`${node}.a`)\n if (contentNode) {\n node = contentNode.name.toLowerCase()\n }\n }\n if (node === `a` && contentNode?.attr.href) {\n chp.path = urlJoin(opfBasePath, contentNode.attr.href)\n chp.href = urlJoin(baseUrl, opfBasePath, contentNode.attr.href)\n }\n const sublistNode = li.childNamed(`ol`)\n if (sublistNode) {\n const children = sublistNode.childrenNamed(`li`)\n if (children && children.length > 0) {\n chp.contents = children.map((child) => extractNavChapter(child, { opfBasePath, baseUrl }))\n }\n }\n\n return chp\n}\n\nconst buildTOCFromNav = (doc: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: Toc = []\n\n let navDataChildren\n if (doc.descendantWithPath(`body.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.nav.ol`)?.children\n } else if (doc.descendantWithPath(`body.section.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.section.nav.ol`)?.children\n }\n\n if (navDataChildren && navDataChildren.length > 0) {\n navDataChildren\n .filter((li) => (li as XmlElement).name === `li`)\n .forEach((li) => toc.push(extractNavChapter(li as XmlElement, { opfBasePath, baseUrl })))\n }\n\n return toc\n}\n\nconst parseTocFromNavPath = async (\n opfXmlDoc: xmldoc.XmlDocument,\n archive: Archive,\n { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }\n) => {\n // Try to detect if there is a nav item\n const navItem = opfXmlDoc\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((child) => child.attr.properties === `nav`)\n\n if (navItem) {\n const tocFile = Object.values(archive.files).find((item) => item.uri.endsWith(navItem.attr.href || ``))\n if (tocFile) {\n const doc = new xmldoc.XmlDocument(await tocFile.string())\n return buildTOCFromNav(doc, { opfBasePath, baseUrl })\n }\n }\n}\n\nconst mapNcxChapter = (\n point: xmldoc.XmlElement,\n { opfBasePath, baseUrl, prefix }: { opfBasePath: string; baseUrl: string; prefix: string }\n) => {\n const src = point?.childNamed(`${prefix}content`)?.attr.src || ``\n\n const out: TocItem = {\n title: point?.descendantWithPath(`${prefix}navLabel.${prefix}text`)?.val || ``,\n path: urlJoin(opfBasePath, src),\n href: urlJoin(baseUrl, opfBasePath, src),\n contents: [],\n }\n const children = point.childrenNamed(`${prefix}navPoint`)\n if (children && children.length > 0) {\n out.contents = children.map((pt) => mapNcxChapter(pt, { opfBasePath, baseUrl, prefix }))\n }\n\n return out\n}\n\nconst buildTOCFromNCX = (ncxData: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: NonNullable<Manifest[`nav`]>[`toc`] = []\n\n const rootTagName = ncxData.name\n let prefix = ``\n if (rootTagName.indexOf(`:`) !== -1) {\n prefix = rootTagName.split(`:`)[0] + `:`\n }\n\n ncxData\n .childNamed(`${prefix}navMap`)\n ?.childrenNamed(`${prefix}navPoint`)\n .forEach((point) => toc.push(mapNcxChapter(point, { opfBasePath, baseUrl, prefix })))\n\n return toc\n}\n\nconst parseTocFromNcx = async ({\n opfData,\n opfBasePath,\n baseUrl,\n archive,\n}: {\n opfData: xmldoc.XmlDocument\n opfBasePath: string\n archive: Archive\n baseUrl: string\n}) => {\n const spine = opfData.childNamed(`spine`)\n const ncxId = spine && spine.attr.toc\n\n if (ncxId) {\n const ncxItem = opfData\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((item) => item.attr.id === ncxId)\n\n if (ncxItem) {\n const ncxPath = `${opfBasePath}${opfBasePath === `` ? `` : `/`}${ncxItem.attr.href}`\n\n const file = Object.values(archive.files).find((item) => item.uri.endsWith(ncxPath))\n\n if (file) {\n const ncxData = new xmldoc.XmlDocument(await file.string())\n\n return buildTOCFromNCX(ncxData, { opfBasePath, baseUrl })\n }\n }\n }\n}\n\nexport const parseToc = async (opfXmlDoc: xmldoc.XmlDocument, archive: Archive, { baseUrl }: { baseUrl: string }) => {\n const { basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const tocFromNcx = await parseTocFromNcx({\n opfData: opfXmlDoc,\n opfBasePath,\n archive,\n baseUrl,\n })\n\n if (tocFromNcx) {\n return tocFromNcx\n }\n\n return await parseTocFromNavPath(opfXmlDoc, archive, { opfBasePath, baseUrl })\n}\n","import xmldoc from \"xmldoc\"\nimport { Archive } from \"..\"\n\ntype KoboInformation = {\n renditionLayout?: `reflowable` | `pre-paginated` | undefined\n}\n\nexport const extractKoboInformationFromArchive = async (archive: Archive) => {\n const koboInformation: KoboInformation = {\n renditionLayout: undefined,\n }\n\n await Promise.all(\n archive.files.map(async (file) => {\n if (file.uri.endsWith(`com.kobobooks.display-options.xml`)) {\n const opfXmlDoc = new xmldoc.XmlDocument(await file.string())\n const optionElement = opfXmlDoc.childNamed(`platform`)?.childNamed(`option`)\n if (optionElement?.attr?.name === `fixed-layout` && optionElement.val === `true`) {\n koboInformation.renditionLayout = `pre-paginated`\n }\n }\n })\n )\n\n return koboInformation\n}\n","let enabled = false\n\nexport const Report = {\n enable: (enable: boolean) => {\n enabled = enable\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n log: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n warn: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.warn(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n error: (...data: any[]) => {\n // eslint-disable-next-line no-console\n console.error(...data)\n },\n time: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.time(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n timeEnd: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.timeEnd(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n metric: (performanceEntry: { name: string; duration: number }, targetDuration = Infinity) => {\n const duration = typeof performanceEntry === `number` ? performanceEntry : performanceEntry.duration\n if (enabled) {\n if (performanceEntry.duration <= targetDuration) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer] [metric] `, `${performanceEntry.name} took ${duration}ms`)\n } else {\n // eslint-disable-next-line no-console\n console.warn(\n `[prose-reader-streamer] [metric] `,\n `${performanceEntry.name} took ${performanceEntry.duration}ms which is above the ${targetDuration}ms target for this function`\n )\n }\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n measurePerformance: <F extends (...args: any[]) => any>(name: string, targetDuration = 10, functionToMeasure: F) => {\n return (...args: Parameters<F>): ReturnType<F> => {\n const t0 = performance.now()\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const response = functionToMeasure(...(args as any))\n\n if (response && response.then) {\n return response.then((res: any) => {\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n return res\n })\n }\n\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n\n return response\n }\n },\n}\n","import { Archive } from \"./types\"\n\nexport const getArchiveOpfInfo = (archive: Archive) => {\n const filesAsArray = Object.values(archive.files).filter((file) => !file.dir)\n const file = filesAsArray.find((file) => file.uri.endsWith(`.opf`))\n\n return {\n data: file,\n basePath: file?.uri.substring(0, file.uri.lastIndexOf(`/`)) || ``,\n }\n}\n","import xmldoc from \"xmldoc\"\nimport { getArchiveOpfInfo } from \"../archives/getArchiveOpfInfo\"\nimport { Archive } from \"../archives/types\"\n\nexport const getSpineItemFilesFromArchive = async ({ archive }: { archive: Archive }) => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const data = await opsFile?.string()\n\n if (!data) return []\n\n const _opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const manifestElm = _opfXmlDoc.childNamed(`manifest`)\n const spineElm = _opfXmlDoc.childNamed(`spine`)\n\n const spineItemIds = spineElm?.childrenNamed(`itemref`).map((item) => item.attr.idref) as string[]\n const manifestItemsFromSpine =\n manifestElm?.childrenNamed(`item`).filter((item) => spineItemIds.includes(item.attr.id || ``)) || []\n\n const archiveSpineItems = archive.files.filter((file) => {\n return manifestItemsFromSpine.find((item) => {\n if (!opfBasePath) return `${item.attr.href}` === file.uri\n return `${opfBasePath}/${item.attr.href}` === file.uri\n })\n })\n\n return archiveSpineItems\n}\n","import xmldoc from \"xmldoc\"\nimport { parseToc } from \"../../../parsers/nav\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { extractKoboInformationFromArchive } from \"../../../parsers/kobo\"\nimport { Report } from \"../../../report\"\nimport { Archive } from \"../../../archives/types\"\nimport { getArchiveOpfInfo } from \"../../../archives/getArchiveOpfInfo\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\ntype SpineItemProperties = `rendition:layout-reflowable` | `page-spread-left` | `page-spread-right`\n\nexport const getItemsFromDoc = (doc: xmldoc.XmlDocument) => {\n const manifestElm = doc.childNamed(`manifest`)\n\n return (\n manifestElm?.childrenNamed(`item`)?.map((el) => ({\n href: el.attr.href || ``,\n id: el.attr.id || ``,\n mediaType: el.attr[`media-type`],\n })) || []\n )\n}\n\nexport const epubHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n const koboInformation = await extractKoboInformationFromArchive(archive)\n\n if (!opsFile) {\n return manifest\n }\n\n const data = await opsFile.string()\n\n Report.log(data, koboInformation)\n\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const toc = (await parseToc(opfXmlDoc, archive, { baseUrl })) || []\n\n const metadataElm = opfXmlDoc.childNamed(`metadata`)\n const manifestElm = opfXmlDoc.childNamed(`manifest`)\n const spineElm = opfXmlDoc.childNamed(`spine`)\n const guideElm = opfXmlDoc.childNamed(`guide`)\n const titleElm = metadataElm?.childNamed(`dc:title`)\n const metaElmChildren = metadataElm?.childrenNamed(`meta`) || []\n const metaElmWithRendition = metaElmChildren.find((meta) => meta.attr.property === `rendition:layout`)\n const metaElmWithRenditionFlow = metaElmChildren.find((meta) => meta.attr.property === `rendition:flow`)\n const metaElmWithRenditionSpread = metaElmChildren.find((meta) => meta.attr.property === `rendition:spread`)\n\n const publisherRenditionLayout = metaElmWithRendition?.val as `reflowable` | `pre-paginated` | undefined\n const publisherRenditionFlow = metaElmWithRenditionFlow?.val as\n | `scrolled-continuous`\n | `scrolled-doc`\n | `paginated`\n | `auto`\n | undefined\n const renditionSpread = metaElmWithRenditionSpread?.val as `auto` | undefined\n\n const title = titleElm?.val || archive.files.find(({ dir }) => dir)?.basename || ``\n const pageProgressionDirection = spineElm?.attr[`page-progression-direction`] as `ltr` | `rtl` | undefined\n\n const archiveSpineItems = await getSpineItemFilesFromArchive({ archive })\n\n const totalSize = archiveSpineItems.reduce((size, file) => file.size + size, 0)\n\n return {\n filename: archive.filename,\n nav: {\n toc,\n },\n renditionLayout: publisherRenditionLayout || koboInformation.renditionLayout || `reflowable`,\n renditionFlow: publisherRenditionFlow || `auto`,\n renditionSpread,\n title,\n readingDirection: pageProgressionDirection || `ltr`,\n spineItems:\n spineElm?.childrenNamed(`itemref`).map((itemrefElm) => {\n const manifestItem = manifestElm?.childrenNamed(`item`).find((item) => item.attr.id === itemrefElm?.attr.idref)\n const href = manifestItem?.attr.href || ``\n const properties = (itemrefElm?.attr.properties?.split(` `) || []) as SpineItemProperties[]\n const itemSize = archive.files.find((file) => file.uri.endsWith(href))?.size || 0\n\n // we use base url or nothing (and stay relative)\n const hrefBaseUri = baseUrl ?? \"\"\n\n return {\n id: manifestItem?.attr.id || ``,\n href: manifestItem?.attr.href?.startsWith(`https://`)\n ? manifestItem?.attr.href\n : opfBasePath\n ? `${hrefBaseUri}${opfBasePath}/${manifestItem?.attr.href}`\n : `${hrefBaseUri}${manifestItem?.attr.href}`,\n renditionLayout: publisherRenditionLayout || `reflowable`,\n ...(properties.find((property) => property === `rendition:layout-reflowable`) && {\n renditionLayout: `reflowable`,\n }),\n progressionWeight: itemSize / totalSize,\n pageSpreadLeft: properties.some((property) => property === `page-spread-left`) || undefined,\n pageSpreadRight: properties.some((property) => property === `page-spread-right`) || undefined,\n // size: itemSize\n mediaType: manifestItem?.attr[`media-type`],\n }\n }) || [],\n items: getItemsFromDoc(opfXmlDoc),\n guide: guideElm?.childrenNamed(`reference`).map((elm) => {\n return {\n href: elm.attr.href || ``,\n title: elm.attr.title || ``,\n type: elm.attr.type as NonNullable<Manifest[`guide`]>[number][`type`],\n }\n }),\n }\n }\n","import xmldoc from \"xmldoc\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { getItemsFromDoc } from \"./manifest/hooks/epub\"\n\nexport const generateResourceFromArchive = async (archive: Archive, resourcePath: string) => {\n const file = Object.values(archive.files).find((file) => file.uri === resourcePath)\n\n const metadata = await getMetadata(archive, resourcePath)\n\n if (!file) {\n throw new Error(`no file found`)\n }\n\n const blob = await file.blob()\n\n // if (file.stream) {\n // const stream = file.stream()\n\n // console.log(file, stream)\n // stream.on(`data`, data => {\n // console.log(`data`, data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // console.log(`end`)\n // })\n\n // }\n\n // const stream = file.stream!()\n\n // const readableStream = new ReadableStream({\n // start(controller) {\n // function push() {\n // stream.on(`data`, data => {\n // controller.enqueue(data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // controller.close()\n // })\n\n // stream.resume()\n // }\n\n // push();\n // }\n // })\n\n return {\n body: blob,\n params: {\n headers: {\n ...(blob.type && {\n \"Content-Type\": blob.type,\n }),\n ...(file.encodingFormat && {\n \"Content-Type\": file.encodingFormat,\n }),\n ...(metadata.mediaType && {\n \"Content-Type\": metadata.mediaType,\n }),\n // 'Cache-Control': `no-cache, no-store, no-transform`\n },\n },\n }\n}\n\nconst getMetadata = async (archive: Archive, resourcePath: string) => {\n const opfInfo = getArchiveOpfInfo(archive)\n const data = await opfInfo.data?.string()\n\n if (data) {\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n const items = getItemsFromDoc(opfXmlDoc)\n\n return {\n mediaType: items.find((item) => resourcePath.endsWith(item.href))?.mediaType,\n }\n }\n\n return {\n mediaType: getContentTypeFromExtension(resourcePath),\n }\n}\n\nconst getContentTypeFromExtension = (uri: string) => {\n if (uri.endsWith(`.css`)) {\n return `text/css; charset=UTF-8`\n }\n if (uri.endsWith(`.jpg`)) {\n return `image/jpg`\n }\n if (uri.endsWith(`.xhtml`)) {\n return `application/xhtml+xml`\n }\n if (uri.endsWith(`.mp4`)) {\n return `video/mp4`\n }\n if (uri.endsWith(`.svg`)) {\n return `image/svg+xml`\n }\n}\n","import { Manifest } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\n\nexport const defaultHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (): Promise<Manifest> => {\n const files = Object.values(archive.files).filter((file) => !file.dir)\n\n return {\n filename: archive.filename,\n title: archive.files.find(({ dir }) => dir)?.basename.replace(/\\/$/, ``) || ``,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n readingDirection: `ltr`,\n spineItems: files.map((file, index) => ({\n // some books such as cbz can have same basename inside different sub folder\n // we need to make sure to have unique index\n // /chap01/01.png, /chap02/01.png, etc\n id: `${index}.${file.basename}`,\n href: encodeURI(`${baseUrl}${file.uri}`),\n renditionLayout: `pre-paginated`,\n progressionWeight: 1 / files.length,\n pageSpreadLeft: undefined,\n pageSpreadRight: undefined,\n mediaType: file.encodingFormat,\n })),\n items: files.map((file, index) => ({\n id: `${index}.${file.basename}`,\n href: `${baseUrl}${file.uri}`,\n })),\n }\n }\n","import { Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\n\n/**\n * Handle archive which contains ComicInfo.xml. This is a meta file\n * used to define cbz, etc. I believe it comes from some sites or apps.\n */\nexport const comicInfoHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const comicInfoFile = archive.files.find((file) => file.basename.toLowerCase() === `comicinfo.xml`)\n\n if (!comicInfoFile) {\n return manifest\n }\n\n // @todo handle more meta\n const content = await comicInfoFile.string()\n const xmlDoc = new xmldoc.XmlDocument(content)\n\n const mangaVal = (xmlDoc.childNamed(`Manga`)?.val as `YesAndRightToLeft`) || `unknown`\n\n return {\n ...manifest,\n spineItems: manifest.spineItems.filter((item) => item.id.toLowerCase() !== `comicinfo.xml`),\n readingDirection: mangaVal === `YesAndRightToLeft` ? `rtl` : `ltr`,\n }\n }\n","import { isXmlBasedMimeType, Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\nconst hasDocMetaViewport = (doc: xmldoc.XmlDocument) => {\n const metaElm = doc\n .descendantWithPath(\"head\")\n ?.childrenNamed(\"meta\")\n .find((node) => node.attr.name === \"viewport\")\n\n return !!(metaElm && metaElm.attr.name === \"viewport\")\n}\n\nconst allFilesHaveViewportMeta = (files: Archive[\"files\"]) =>\n files.reduce(async (result, current) => {\n const _result = await result\n\n if (!_result) return false\n\n if (\n !isXmlBasedMimeType({\n mimeType: current.encodingFormat,\n uri: current.uri,\n })\n ) {\n return false\n }\n\n const file = await current.string()\n\n if (!file) return false\n\n return hasDocMetaViewport(new xmldoc.XmlDocument(file))\n }, Promise.resolve(true))\n\nexport const epubOptimizerHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const bookIsFullReflowable =\n manifest.renditionLayout === \"reflowable\" && manifest.spineItems.every((item) => item.renditionLayout === \"reflowable\")\n\n if (bookIsFullReflowable) {\n const files = await getSpineItemFilesFromArchive({ archive })\n\n const hasAllViewport = await allFilesHaveViewportMeta(files)\n\n if (hasAllViewport) {\n return {\n ...manifest,\n spineItems: manifest.spineItems.map((item) => ({\n ...item,\n renditionLayout: \"pre-paginated\",\n })),\n renditionLayout: \"pre-paginated\",\n }\n }\n }\n\n return manifest\n }\n","export const sortByTitleComparator = (a: string, b: string) => {\n const alist = a.split(/(\\d+)/)\n const blist = b.split(/(\\d+)/)\n\n for (let i = 0, len = alist.length; i < len; i++) {\n if (alist[i] !== blist[i]) {\n if (alist[i]?.match(/\\d/)) {\n return +(alist[i] || ``) - +(blist[i] || ``)\n } else {\n return (alist[i] || ``).localeCompare(blist[i] || ``)\n }\n }\n }\n\n return 1\n}\n","import { Manifest, urlJoin } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\nimport { sortByTitleComparator } from \"../../../utils/sortByTitleComparator\"\n\n/**\n * In case no navigation was generated prior to this hook, we will try\n * to generate something based on the structure of the archive.\n *\n * We use folders as chapters.\n */\nexport const navigationFallbackHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n if (manifest.nav) return manifest\n\n const filesSortedByAlpha = [...archive.files].sort((a, b) => sortByTitleComparator(a.uri, b.uri))\n\n const toc: NonNullable<Manifest[\"nav\"]>[\"toc\"] = Object.values(filesSortedByAlpha).reduce((acc, file) => {\n const parts = file.uri.split(\"/\")\n\n // we have a file that is\n const isFileUnderFolder = !file.dir && parts.length > 1\n\n if (isFileUnderFolder) {\n parts.forEach((part, level) => {\n const partIsFileName = level === parts.length - 1\n\n if (partIsFileName) return\n\n const existingTocItem = acc.find(({ title }) => title === part)\n\n if (existingTocItem) {\n // @todo\n } else {\n acc.push({\n contents: [],\n href: urlJoin(baseUrl, encodeURI(file.uri)).replace(/\\/$/, \"\"),\n path: file.uri.replace(/\\/$/, \"\"),\n title: parts[0] ?? \"\",\n })\n }\n })\n }\n\n return acc\n }, [] as NonNullable<Manifest[\"nav\"]>[\"toc\"])\n\n if (toc.length === 0) return manifest\n\n return {\n ...manifest,\n nav: {\n toc,\n },\n }\n }\n","import type { Manifest } from \"@prose-reader/shared\"\nimport { Report } from \"../../report\"\nimport { Archive } from \"../../archives/types\"\nimport { defaultHook } from \"./hooks/default\"\nimport { epubHook } from \"./hooks/epub\"\nimport { comicInfoHook } from \"./hooks/comicInfo\"\nimport { epubOptimizerHook } from \"./hooks/epubOptimizer\"\nimport { navigationFallbackHook } from \"./hooks/navigationFallback\"\n\nconst baseManifest: Manifest = {\n filename: ``,\n items: [],\n nav: {\n toc: [],\n },\n readingDirection: `ltr`,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n spineItems: [],\n title: ``,\n}\n\nexport const generateManifestFromArchive = async (archive: Archive, { baseUrl = `` }: { baseUrl?: string } = {}) => {\n const hooks = [\n defaultHook({ archive, baseUrl }),\n epubHook({ archive, baseUrl }),\n epubOptimizerHook({ archive, baseUrl }),\n comicInfoHook({ archive, baseUrl }),\n navigationFallbackHook({ archive, baseUrl }),\n ]\n\n try {\n const manifest = await hooks.reduce(async (manifest, gen) => {\n return await gen(await manifest)\n }, Promise.resolve(baseManifest))\n\n Report.log(\"Generated manifest\", manifest)\n\n return manifest\n } catch (e) {\n Report.error(e)\n\n throw e\n }\n}\n","export const getUriBasename = (uri: string) => uri.substring(uri.lastIndexOf(`/`) + 1) || uri\n","import { detectMimeTypeFromName } from \"@prose-reader/shared\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * @important\n * Make sure the urls are on the same origin or the cors header is set otherwise\n * the resource cannot be consumed as it is on the web.\n */\nexport const createArchiveFromUrls = async (urls: string[], options?: { useRenditionFlow: boolean }): Promise<Archive> => {\n const opfFileData = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?><package xmlns=\"http://www.idpf.org/2007/opf\" version=\"2.0\" unique-identifier=\"bookid\">\n <metadata>\n <meta property=\"rendition:layout\">${options?.useRenditionFlow ? `reflowable` : `pre-paginated`}</meta>\n ${options?.useRenditionFlow ? `<meta property=\"rendition:flow\">scrolled-continuous</meta>` : ``}\n </metadata>\n <manifest>\n ${urls\n .map((url) => `<item id=\"${getUriBasename(url)}\" href=\"${url}\" media-type=\"${detectMimeTypeFromName(url)}\"/>`)\n .join(`\\n`)}\n </manifest>\n <spine>\n ${urls.map((url) => `<itemref idref=\"${getUriBasename(url)}\" />`).join(`\\n`)}\n </spine>\n </package>\n `\n\n const filesFromUrl: Archive[`files`] = urls.map((url) => ({\n dir: false,\n basename: getUriBasename(url),\n encodingFormat: detectMimeTypeFromName(url),\n uri: url,\n size: 100 / urls.length,\n base64: async () => ``,\n blob: async () => new Blob(),\n string: async () => ``,\n }))\n\n const opfFile: Archive[`files`][number] = {\n dir: false,\n basename: `content.opf`,\n uri: `content.opf`,\n size: 0,\n base64: async () => opfFileData,\n blob: async () => new Blob(),\n string: async () => opfFileData,\n }\n\n return {\n filename: ``,\n files: [opfFile, ...filesFromUrl],\n }\n}\n","export const blobToBase64 = async (blob: Blob) =>\n new Promise<string>((resolve) => {\n const reader = new FileReader()\n reader.readAsDataURL(blob)\n reader.onloadend = function () {\n const base64data = reader.result as string\n resolve(base64data)\n }\n })\n","import { blobToBase64 } from \"../utils/blobToBAse64\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * Useful to create archive from txt content\n */\nexport const createArchiveFromText = async (\n content: string | Blob,\n {\n mimeType,\n direction,\n }: {\n direction?: `ltr` | `rtl`\n mimeType?: string\n } = { mimeType: \"text/plain\" }\n) => {\n const txtOpfContent = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n <package xmlns=\"http://www.idpf.org/2007/opf\" version=\"3.0\" xml:lang=\"ja\" prefix=\"rendition: http://www.idpf.org/vocab/rendition/#\"\n unique-identifier=\"ootuya-id\">\n <metadata xmlns:opf=\"http://www.idpf.org/2007/opf\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:dcterms=\"http://purl.org/dc/terms/\">\n <meta property=\"rendition:layout\">reflowable</meta>\n </metadata>\n <manifest>\n <item id=\"p01\" href=\"p01.txt\" media-type=\"text/plain\"/>\n </manifest>\n <spine page-progression-direction=\"${direction ?? `ltr`}\">\n <itemref idref=\"p01\" />\n </spine>\n </package>\n `\n\n const archive: Archive = {\n filename: `content.txt`,\n files: [\n {\n dir: false,\n basename: getUriBasename(`generated.opf`),\n uri: `generated.opf`,\n blob: async () => new Blob([txtOpfContent]),\n string: async () => txtOpfContent,\n base64: async () => btoa(txtOpfContent),\n size: 0,\n },\n {\n dir: false,\n basename: getUriBasename(`p01.txt`),\n uri: `p01.txt`,\n blob: async () => {\n if (typeof content === `string`) return new Blob([content])\n return content\n },\n string: async () => {\n if (typeof content === `string`) return content\n return content.text()\n },\n base64: async () => {\n if (typeof content === `string`) return btoa(content)\n return blobToBase64(content)\n },\n size: typeof content === `string` ? content.length : content.size,\n encodingFormat: mimeType,\n },\n ],\n }\n\n return archive\n}\n","import { Report } from \"../report\"\nimport { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive, StreamResult } from \"./types\"\n\ninterface OutputByType {\n base64: string\n string: string\n text: string\n binarystring: string\n array: number[]\n uint8array: Uint8Array\n arraybuffer: ArrayBuffer\n blob: Blob\n nodebuffer: Buffer\n}\n\ntype OutputType = keyof OutputByType\ninterface JSZipObject {\n name: string\n dir: boolean\n date: Date\n comment: string\n unixPermissions: number | string | null\n dosPermissions: number | null\n async<T extends OutputType>(type: T): Promise<OutputByType[T]>\n // nodeStream(type?: `nodebuffer`): NodeJS.ReadableStream;\n internalStream?: (type?: `uint8array`) => StreamResult\n}\n\ninterface JSZip {\n files: { [key: string]: JSZipObject }\n}\n\nexport const createArchiveFromJszip = async (\n jszip: JSZip,\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = Object.values(jszip.files)\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n const archive = {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.dir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: () => file.async(`blob`),\n string: () => file.async(`string`),\n base64: () => file.async(`base64`),\n ...(file.internalStream && {\n stream: file.internalStream,\n }),\n // this is private API\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n size: file._data.uncompressedSize,\n })),\n }\n\n Report.log(\"Generated archive\", archive)\n\n return archive\n}\n","import { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\nexport const createArchiveFromArrayBufferList = async (\n list: {\n isDir: boolean\n name: string\n size: number\n data: () => Promise<ArrayBuffer>\n }[],\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = list\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n return {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.isDir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: async () => new Blob([await file.data()]),\n string: async () => {\n const data = await file.data()\n return String.fromCharCode.apply(null, Array.from(new Uint16Array(data)))\n },\n base64: async () => {\n // @todo not used for now, lets implement it later if needed\n return ``\n },\n size: file.size,\n })),\n }\n}\n","import { Report } from \"./report\"\n\nexport const configure = ({ enableReport }: { enableReport?: boolean } = {}) => {\n Report.enable(!!enableReport)\n}\n"],"names":["extractNavChapter","li","opfBasePath","baseUrl","chp","contentNode","node","urlJoin","sublistNode","children","child","buildTOCFromNav","doc","toc","navDataChildren","_a","_b","parseTocFromNavPath","opfXmlDoc","archive","navItem","tocFile","item","xmldoc","mapNcxChapter","point","prefix","src","out","pt","buildTOCFromNCX","ncxData","rootTagName","parseTocFromNcx","opfData","spine","ncxId","ncxItem","ncxPath","file","parseToc","getArchiveOpfInfo","tocFromNcx","extractKoboInformationFromArchive","koboInformation","optionElement","enabled","Report","enable","data","label","performanceEntry","targetDuration","duration","name","functionToMeasure","args","t0","response","res","t1","getSpineItemFilesFromArchive","opsFile","_opfXmlDoc","manifestElm","spineElm","spineItemIds","manifestItemsFromSpine","getItemsFromDoc","el","epubHook","manifest","metadataElm","guideElm","titleElm","metaElmChildren","metaElmWithRendition","meta","metaElmWithRenditionFlow","metaElmWithRenditionSpread","publisherRenditionLayout","publisherRenditionFlow","renditionSpread","title","dir","pageProgressionDirection","totalSize","size","itemrefElm","manifestItem","href","properties","itemSize","hrefBaseUri","_c","property","elm","generateResourceFromArchive","resourcePath","metadata","getMetadata","blob","getContentTypeFromExtension","uri","defaultHook","files","index","comicInfoHook","comicInfoFile","content","mangaVal","hasDocMetaViewport","metaElm","allFilesHaveViewportMeta","result","current","isXmlBasedMimeType","epubOptimizerHook","sortByTitleComparator","a","b","alist","blist","i","len","navigationFallbackHook","filesSortedByAlpha","acc","parts","part","level","baseManifest","generateManifestFromArchive","hooks","gen","e","getUriBasename","createArchiveFromUrls","urls","options","opfFileData","url","detectMimeTypeFromName","filesFromUrl","blobToBase64","resolve","reader","base64data","createArchiveFromText","mimeType","direction","txtOpfContent","createArchiveFromJszip","jszip","orderByAlpha","createArchiveFromArrayBufferList","list","configure","enableReport"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"prose-streamer.umd.cjs","sources":["../src/parsers/nav.ts","../src/parsers/kobo.ts","../src/report.ts","../src/archives/getArchiveOpfInfo.ts","../src/epub/getSpineItemFilesFromArchive.ts","../src/generators/manifest/hooks/epub.ts","../src/generators/resources.ts","../src/generators/manifest/hooks/default.ts","../src/generators/manifest/hooks/comicInfo.ts","../src/generators/manifest/hooks/epubOptimizer.ts","../src/utils/sortByTitleComparator.ts","../src/generators/manifest/hooks/navigationFallback.ts","../src/generators/manifest/index.ts","../src/utils/uri.ts","../src/archives/createArchiveFromUrls.ts","../src/utils/blobToBAse64.ts","../src/archives/createArchiveFromText.ts","../src/archives/createArchiveFromJszip.ts","../src/archives/createArchiveFromArrayBufferList.ts","../src/configure.ts"],"sourcesContent":["import xmldoc, { XmlElement } from \"xmldoc\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { urlJoin } from \"@prose-reader/shared\"\n\ntype Toc = NonNullable<Manifest[`nav`]>[`toc`]\ntype TocItem = NonNullable<Manifest[`nav`]>[`toc`][number]\n\nconst extractNavChapter = (li: XmlElement, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const chp: TocItem = {\n contents: [],\n path: ``,\n href: ``,\n title: ``,\n }\n let contentNode = li.childNamed(`span`) || li.childNamed(`a`)\n chp.title = contentNode?.attr.title || contentNode?.val.trim() || chp.title\n let node = contentNode?.name\n if (node !== `a`) {\n contentNode = li.descendantWithPath(`${node}.a`)\n if (contentNode) {\n node = contentNode.name.toLowerCase()\n }\n }\n if (node === `a` && contentNode?.attr.href) {\n chp.path = urlJoin(opfBasePath, contentNode.attr.href)\n chp.href = urlJoin(baseUrl, opfBasePath, contentNode.attr.href)\n }\n const sublistNode = li.childNamed(`ol`)\n if (sublistNode) {\n const children = sublistNode.childrenNamed(`li`)\n if (children && children.length > 0) {\n chp.contents = children.map((child) => extractNavChapter(child, { opfBasePath, baseUrl }))\n }\n }\n\n return chp\n}\n\nconst buildTOCFromNav = (doc: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: Toc = []\n\n let navDataChildren\n if (doc.descendantWithPath(`body.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.nav.ol`)?.children\n } else if (doc.descendantWithPath(`body.section.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.section.nav.ol`)?.children\n }\n\n if (navDataChildren && navDataChildren.length > 0) {\n navDataChildren\n .filter((li) => (li as XmlElement).name === `li`)\n .forEach((li) => toc.push(extractNavChapter(li as XmlElement, { opfBasePath, baseUrl })))\n }\n\n return toc\n}\n\nconst parseTocFromNavPath = async (\n opfXmlDoc: xmldoc.XmlDocument,\n archive: Archive,\n { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }\n) => {\n // Try to detect if there is a nav item\n const navItem = opfXmlDoc\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((child) => child.attr.properties === `nav`)\n\n if (navItem) {\n const tocFile = Object.values(archive.files).find((item) => item.uri.endsWith(navItem.attr.href || ``))\n if (tocFile) {\n const doc = new xmldoc.XmlDocument(await tocFile.string())\n return buildTOCFromNav(doc, { opfBasePath, baseUrl })\n }\n }\n}\n\nconst mapNcxChapter = (\n point: xmldoc.XmlElement,\n { opfBasePath, baseUrl, prefix }: { opfBasePath: string; baseUrl: string; prefix: string }\n) => {\n const src = point?.childNamed(`${prefix}content`)?.attr.src || ``\n\n const out: TocItem = {\n title: point?.descendantWithPath(`${prefix}navLabel.${prefix}text`)?.val || ``,\n path: urlJoin(opfBasePath, src),\n href: urlJoin(baseUrl, opfBasePath, src),\n contents: [],\n }\n const children = point.childrenNamed(`${prefix}navPoint`)\n if (children && children.length > 0) {\n out.contents = children.map((pt) => mapNcxChapter(pt, { opfBasePath, baseUrl, prefix }))\n }\n\n return out\n}\n\nconst buildTOCFromNCX = (ncxData: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: NonNullable<Manifest[`nav`]>[`toc`] = []\n\n const rootTagName = ncxData.name\n let prefix = ``\n if (rootTagName.indexOf(`:`) !== -1) {\n prefix = rootTagName.split(`:`)[0] + `:`\n }\n\n ncxData\n .childNamed(`${prefix}navMap`)\n ?.childrenNamed(`${prefix}navPoint`)\n .forEach((point) => toc.push(mapNcxChapter(point, { opfBasePath, baseUrl, prefix })))\n\n return toc\n}\n\nconst parseTocFromNcx = async ({\n opfData,\n opfBasePath,\n baseUrl,\n archive,\n}: {\n opfData: xmldoc.XmlDocument\n opfBasePath: string\n archive: Archive\n baseUrl: string\n}) => {\n const spine = opfData.childNamed(`spine`)\n const ncxId = spine && spine.attr.toc\n\n if (ncxId) {\n const ncxItem = opfData\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((item) => item.attr.id === ncxId)\n\n if (ncxItem) {\n const ncxPath = `${opfBasePath}${opfBasePath === `` ? `` : `/`}${ncxItem.attr.href}`\n\n const file = Object.values(archive.files).find((item) => item.uri.endsWith(ncxPath))\n\n if (file) {\n const ncxData = new xmldoc.XmlDocument(await file.string())\n\n return buildTOCFromNCX(ncxData, { opfBasePath, baseUrl })\n }\n }\n }\n}\n\nexport const parseToc = async (opfXmlDoc: xmldoc.XmlDocument, archive: Archive, { baseUrl }: { baseUrl: string }) => {\n const { basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const tocFromNcx = await parseTocFromNcx({\n opfData: opfXmlDoc,\n opfBasePath,\n archive,\n baseUrl,\n })\n\n if (tocFromNcx) {\n return tocFromNcx\n }\n\n return await parseTocFromNavPath(opfXmlDoc, archive, { opfBasePath, baseUrl })\n}\n","import xmldoc from \"xmldoc\"\nimport { Archive } from \"..\"\n\ntype KoboInformation = {\n renditionLayout?: `reflowable` | `pre-paginated` | undefined\n}\n\nexport const extractKoboInformationFromArchive = async (archive: Archive) => {\n const koboInformation: KoboInformation = {\n renditionLayout: undefined,\n }\n\n await Promise.all(\n archive.files.map(async (file) => {\n if (file.uri.endsWith(`com.kobobooks.display-options.xml`)) {\n const opfXmlDoc = new xmldoc.XmlDocument(await file.string())\n const optionElement = opfXmlDoc.childNamed(`platform`)?.childNamed(`option`)\n if (optionElement?.attr?.name === `fixed-layout` && optionElement.val === `true`) {\n koboInformation.renditionLayout = `pre-paginated`\n }\n }\n })\n )\n\n return koboInformation\n}\n","let enabled = false\n\nexport const Report = {\n enable: (enable: boolean) => {\n enabled = enable\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n log: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n warn: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.warn(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n error: (...data: any[]) => {\n // eslint-disable-next-line no-console\n console.error(...data)\n },\n time: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.time(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n timeEnd: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.timeEnd(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n metric: (performanceEntry: { name: string; duration: number }, targetDuration = Infinity) => {\n const duration = typeof performanceEntry === `number` ? performanceEntry : performanceEntry.duration\n if (enabled) {\n if (performanceEntry.duration <= targetDuration) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer] [metric] `, `${performanceEntry.name} took ${duration}ms`)\n } else {\n // eslint-disable-next-line no-console\n console.warn(\n `[prose-reader-streamer] [metric] `,\n `${performanceEntry.name} took ${performanceEntry.duration}ms which is above the ${targetDuration}ms target for this function`\n )\n }\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n measurePerformance: <F extends (...args: any[]) => any>(name: string, targetDuration = 10, functionToMeasure: F) => {\n return (...args: Parameters<F>): ReturnType<F> => {\n const t0 = performance.now()\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const response = functionToMeasure(...(args as any))\n\n if (response && response.then) {\n return response.then((res: any) => {\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n return res\n })\n }\n\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n\n return response\n }\n },\n}\n","import { Archive } from \"./types\"\n\nexport const getArchiveOpfInfo = (archive: Archive) => {\n const filesAsArray = Object.values(archive.files).filter((file) => !file.dir)\n const file = filesAsArray.find((file) => file.uri.endsWith(`.opf`))\n\n return {\n data: file,\n basePath: file?.uri.substring(0, file.uri.lastIndexOf(`/`)) || ``,\n }\n}\n","import xmldoc from \"xmldoc\"\nimport { getArchiveOpfInfo } from \"../archives/getArchiveOpfInfo\"\nimport { Archive } from \"../archives/types\"\n\nexport const getSpineItemFilesFromArchive = async ({ archive }: { archive: Archive }) => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const data = await opsFile?.string()\n\n if (!data) return []\n\n const _opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const manifestElm = _opfXmlDoc.childNamed(`manifest`)\n const spineElm = _opfXmlDoc.childNamed(`spine`)\n\n const spineItemIds = spineElm?.childrenNamed(`itemref`).map((item) => item.attr.idref) as string[]\n const manifestItemsFromSpine =\n manifestElm?.childrenNamed(`item`).filter((item) => spineItemIds.includes(item.attr.id || ``)) || []\n\n const archiveSpineItems = archive.files.filter((file) => {\n return manifestItemsFromSpine.find((item) => {\n if (!opfBasePath) return `${item.attr.href}` === file.uri\n return `${opfBasePath}/${item.attr.href}` === file.uri\n })\n })\n\n return archiveSpineItems\n}\n","import xmldoc from \"xmldoc\"\nimport { parseToc } from \"../../../parsers/nav\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { extractKoboInformationFromArchive } from \"../../../parsers/kobo\"\nimport { Report } from \"../../../report\"\nimport { Archive } from \"../../../archives/types\"\nimport { getArchiveOpfInfo } from \"../../../archives/getArchiveOpfInfo\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\ntype SpineItemProperties = `rendition:layout-reflowable` | `page-spread-left` | `page-spread-right`\n\nexport const getItemsFromDoc = (doc: xmldoc.XmlDocument) => {\n const manifestElm = doc.childNamed(`manifest`)\n\n return (\n manifestElm?.childrenNamed(`item`)?.map((el) => ({\n href: el.attr.href || ``,\n id: el.attr.id || ``,\n mediaType: el.attr[`media-type`],\n })) || []\n )\n}\n\nexport const epubHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n const koboInformation = await extractKoboInformationFromArchive(archive)\n\n if (!opsFile) {\n return manifest\n }\n\n const data = await opsFile.string()\n\n Report.log(data, koboInformation)\n\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const toc = (await parseToc(opfXmlDoc, archive, { baseUrl })) || []\n\n const metadataElm = opfXmlDoc.childNamed(`metadata`)\n const manifestElm = opfXmlDoc.childNamed(`manifest`)\n const spineElm = opfXmlDoc.childNamed(`spine`)\n const guideElm = opfXmlDoc.childNamed(`guide`)\n const titleElm = metadataElm?.childNamed(`dc:title`)\n const metaElmChildren = metadataElm?.childrenNamed(`meta`) || []\n const metaElmWithRendition = metaElmChildren.find((meta) => meta.attr.property === `rendition:layout`)\n const metaElmWithRenditionFlow = metaElmChildren.find((meta) => meta.attr.property === `rendition:flow`)\n const metaElmWithRenditionSpread = metaElmChildren.find((meta) => meta.attr.property === `rendition:spread`)\n\n const publisherRenditionLayout = metaElmWithRendition?.val as `reflowable` | `pre-paginated` | undefined\n const publisherRenditionFlow = metaElmWithRenditionFlow?.val as\n | `scrolled-continuous`\n | `scrolled-doc`\n | `paginated`\n | `auto`\n | undefined\n const renditionSpread = metaElmWithRenditionSpread?.val as `auto` | undefined\n\n const title = titleElm?.val || archive.files.find(({ dir }) => dir)?.basename || ``\n const pageProgressionDirection = spineElm?.attr[`page-progression-direction`] as `ltr` | `rtl` | undefined\n\n const archiveSpineItems = await getSpineItemFilesFromArchive({ archive })\n\n const totalSize = archiveSpineItems.reduce((size, file) => file.size + size, 0)\n\n return {\n filename: archive.filename,\n nav: {\n toc,\n },\n renditionLayout: publisherRenditionLayout || koboInformation.renditionLayout || `reflowable`,\n renditionFlow: publisherRenditionFlow || `auto`,\n renditionSpread,\n title,\n readingDirection: pageProgressionDirection || `ltr`,\n spineItems:\n spineElm?.childrenNamed(`itemref`).map((itemrefElm) => {\n const manifestItem = manifestElm?.childrenNamed(`item`).find((item) => item.attr.id === itemrefElm?.attr.idref)\n const href = manifestItem?.attr.href || ``\n const properties = (itemrefElm?.attr.properties?.split(` `) || []) as SpineItemProperties[]\n const itemSize = archive.files.find((file) => file.uri.endsWith(href))?.size || 0\n\n // we use base url or nothing (and stay relative)\n const hrefBaseUri = baseUrl ?? \"\"\n\n return {\n id: manifestItem?.attr.id || ``,\n href: manifestItem?.attr.href?.startsWith(`https://`)\n ? manifestItem?.attr.href\n : opfBasePath\n ? `${hrefBaseUri}${opfBasePath}/${manifestItem?.attr.href}`\n : `${hrefBaseUri}${manifestItem?.attr.href}`,\n renditionLayout: publisherRenditionLayout || `reflowable`,\n ...(properties.find((property) => property === `rendition:layout-reflowable`) && {\n renditionLayout: `reflowable`,\n }),\n progressionWeight: itemSize / totalSize,\n pageSpreadLeft: properties.some((property) => property === `page-spread-left`) || undefined,\n pageSpreadRight: properties.some((property) => property === `page-spread-right`) || undefined,\n // size: itemSize\n mediaType: manifestItem?.attr[`media-type`],\n }\n }) || [],\n items: getItemsFromDoc(opfXmlDoc),\n guide: guideElm?.childrenNamed(`reference`).map((elm) => {\n return {\n href: elm.attr.href || ``,\n title: elm.attr.title || ``,\n type: elm.attr.type as NonNullable<Manifest[`guide`]>[number][`type`],\n }\n }),\n }\n }\n","import xmldoc from \"xmldoc\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { getItemsFromDoc } from \"./manifest/hooks/epub\"\n\nexport const generateResourceFromArchive = async (archive: Archive, resourcePath: string) => {\n const file = Object.values(archive.files).find((file) => file.uri === resourcePath)\n\n const metadata = await getMetadata(archive, resourcePath)\n\n if (!file) {\n throw new Error(`no file found`)\n }\n\n const blob = await file.blob()\n\n // if (file.stream) {\n // const stream = file.stream()\n\n // console.log(file, stream)\n // stream.on(`data`, data => {\n // console.log(`data`, data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // console.log(`end`)\n // })\n\n // }\n\n // const stream = file.stream!()\n\n // const readableStream = new ReadableStream({\n // start(controller) {\n // function push() {\n // stream.on(`data`, data => {\n // controller.enqueue(data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // controller.close()\n // })\n\n // stream.resume()\n // }\n\n // push();\n // }\n // })\n\n return {\n body: blob,\n params: {\n headers: {\n ...(blob.type && {\n \"Content-Type\": blob.type,\n }),\n ...(file.encodingFormat && {\n \"Content-Type\": file.encodingFormat,\n }),\n ...(metadata.mediaType && {\n \"Content-Type\": metadata.mediaType,\n }),\n // 'Cache-Control': `no-cache, no-store, no-transform`\n },\n },\n }\n}\n\nconst getMetadata = async (archive: Archive, resourcePath: string) => {\n const opfInfo = getArchiveOpfInfo(archive)\n const data = await opfInfo.data?.string()\n\n if (data) {\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n const items = getItemsFromDoc(opfXmlDoc)\n\n return {\n mediaType: items.find((item) => resourcePath.endsWith(item.href))?.mediaType,\n }\n }\n\n return {\n mediaType: getContentTypeFromExtension(resourcePath),\n }\n}\n\nconst getContentTypeFromExtension = (uri: string) => {\n if (uri.endsWith(`.css`)) {\n return `text/css; charset=UTF-8`\n }\n if (uri.endsWith(`.jpg`)) {\n return `image/jpg`\n }\n if (uri.endsWith(`.xhtml`)) {\n return `application/xhtml+xml`\n }\n if (uri.endsWith(`.mp4`)) {\n return `video/mp4`\n }\n if (uri.endsWith(`.svg`)) {\n return `image/svg+xml`\n }\n}\n","import { Manifest } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\n\nexport const defaultHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (): Promise<Manifest> => {\n const files = Object.values(archive.files).filter((file) => !file.dir)\n\n return {\n filename: archive.filename,\n title: archive.files.find(({ dir }) => dir)?.basename.replace(/\\/$/, ``) || ``,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n readingDirection: `ltr`,\n spineItems: files.map((file, index) => ({\n // some books such as cbz can have same basename inside different sub folder\n // we need to make sure to have unique index\n // /chap01/01.png, /chap02/01.png, etc\n id: `${index}.${file.basename}`,\n href: encodeURI(`${baseUrl}${file.uri}`),\n renditionLayout: `pre-paginated`,\n progressionWeight: 1 / files.length,\n pageSpreadLeft: undefined,\n pageSpreadRight: undefined,\n mediaType: file.encodingFormat,\n })),\n items: files.map((file, index) => ({\n id: `${index}.${file.basename}`,\n href: `${baseUrl}${file.uri}`,\n })),\n }\n }\n","import { Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\n\n/**\n * Handle archive which contains ComicInfo.xml. This is a meta file\n * used to define cbz, etc. I believe it comes from some sites or apps.\n */\nexport const comicInfoHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const comicInfoFile = archive.files.find((file) => file.basename.toLowerCase() === `comicinfo.xml`)\n\n if (!comicInfoFile) {\n return manifest\n }\n\n // @todo handle more meta\n const content = await comicInfoFile.string()\n const xmlDoc = new xmldoc.XmlDocument(content)\n\n const mangaVal = (xmlDoc.childNamed(`Manga`)?.val as `YesAndRightToLeft`) || `unknown`\n\n return {\n ...manifest,\n spineItems: manifest.spineItems.filter((item) => item.id.toLowerCase() !== `comicinfo.xml`),\n readingDirection: mangaVal === `YesAndRightToLeft` ? `rtl` : `ltr`,\n }\n }\n","import { isXmlBasedMimeType, Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\nconst hasDocMetaViewport = (doc: xmldoc.XmlDocument) => {\n const metaElm = doc\n .descendantWithPath(\"head\")\n ?.childrenNamed(\"meta\")\n .find((node) => node.attr.name === \"viewport\")\n\n return !!(metaElm && metaElm.attr.name === \"viewport\")\n}\n\nconst allFilesHaveViewportMeta = (files: Archive[\"files\"]) =>\n files.reduce(async (result, current) => {\n const _result = await result\n\n if (!_result) return false\n\n if (\n !isXmlBasedMimeType({\n mimeType: current.encodingFormat,\n uri: current.uri,\n })\n ) {\n return false\n }\n\n const file = await current.string()\n\n if (!file) return false\n\n return hasDocMetaViewport(new xmldoc.XmlDocument(file))\n }, Promise.resolve(true))\n\nexport const epubOptimizerHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const bookIsFullReflowable =\n manifest.renditionLayout === \"reflowable\" && manifest.spineItems.every((item) => item.renditionLayout === \"reflowable\")\n\n if (bookIsFullReflowable) {\n const files = await getSpineItemFilesFromArchive({ archive })\n\n const hasAllViewport = await allFilesHaveViewportMeta(files)\n\n if (hasAllViewport) {\n return {\n ...manifest,\n spineItems: manifest.spineItems.map((item) => ({\n ...item,\n renditionLayout: \"pre-paginated\",\n })),\n renditionLayout: \"pre-paginated\",\n }\n }\n }\n\n return manifest\n }\n","export const sortByTitleComparator = (a: string, b: string) => {\n const alist = a.split(/(\\d+)/)\n const blist = b.split(/(\\d+)/)\n\n for (let i = 0, len = alist.length; i < len; i++) {\n if (alist[i] !== blist[i]) {\n if (alist[i]?.match(/\\d/)) {\n return +(alist[i] || ``) - +(blist[i] || ``)\n } else {\n return (alist[i] || ``).localeCompare(blist[i] || ``)\n }\n }\n }\n\n return 1\n}\n","import { Manifest, urlJoin } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\nimport { sortByTitleComparator } from \"../../../utils/sortByTitleComparator\"\n\n/**\n * In case no navigation was generated prior to this hook, we will try\n * to generate something based on the structure of the archive.\n *\n * We use folders as chapters.\n */\nexport const navigationFallbackHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n if (manifest.nav) return manifest\n\n const filesSortedByAlpha = [...archive.files].sort((a, b) => sortByTitleComparator(a.uri, b.uri))\n\n const toc: NonNullable<Manifest[\"nav\"]>[\"toc\"] = Object.values(filesSortedByAlpha).reduce((acc, file) => {\n const parts = file.uri.split(\"/\")\n\n // we have a file that is\n const isFileUnderFolder = !file.dir && parts.length > 1\n\n if (isFileUnderFolder) {\n parts.forEach((part, level) => {\n const partIsFileName = level === parts.length - 1\n\n if (partIsFileName) return\n\n const existingTocItem = acc.find(({ title }) => title === part)\n\n if (existingTocItem) {\n // @todo\n } else {\n acc.push({\n contents: [],\n href: urlJoin(baseUrl, encodeURI(file.uri)).replace(/\\/$/, \"\"),\n path: file.uri.replace(/\\/$/, \"\"),\n title: parts[0] ?? \"\",\n })\n }\n })\n }\n\n return acc\n }, [] as NonNullable<Manifest[\"nav\"]>[\"toc\"])\n\n if (toc.length === 0) return manifest\n\n return {\n ...manifest,\n nav: {\n toc,\n },\n }\n }\n","import type { Manifest } from \"@prose-reader/shared\"\nimport { Report } from \"../../report\"\nimport { Archive } from \"../../archives/types\"\nimport { defaultHook } from \"./hooks/default\"\nimport { epubHook } from \"./hooks/epub\"\nimport { comicInfoHook } from \"./hooks/comicInfo\"\nimport { epubOptimizerHook } from \"./hooks/epubOptimizer\"\nimport { navigationFallbackHook } from \"./hooks/navigationFallback\"\n\nconst baseManifest: Manifest = {\n filename: ``,\n items: [],\n nav: {\n toc: [],\n },\n readingDirection: `ltr`,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n spineItems: [],\n title: ``,\n}\n\nexport const generateManifestFromArchive = async (archive: Archive, { baseUrl = `` }: { baseUrl?: string } = {}) => {\n const hooks = [\n defaultHook({ archive, baseUrl }),\n epubHook({ archive, baseUrl }),\n epubOptimizerHook({ archive, baseUrl }),\n comicInfoHook({ archive, baseUrl }),\n navigationFallbackHook({ archive, baseUrl }),\n ]\n\n try {\n const manifest = await hooks.reduce(async (manifest, gen) => {\n return await gen(await manifest)\n }, Promise.resolve(baseManifest))\n\n Report.log(\"Generated manifest\", manifest)\n\n return manifest\n } catch (e) {\n Report.error(e)\n\n throw e\n }\n}\n","export const getUriBasename = (uri: string) => uri.substring(uri.lastIndexOf(`/`) + 1) || uri\n","import { detectMimeTypeFromName } from \"@prose-reader/shared\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * @important\n * Make sure the urls are on the same origin or the cors header is set otherwise\n * the resource cannot be consumed as it is on the web.\n */\nexport const createArchiveFromUrls = async (urls: string[], options?: { useRenditionFlow: boolean }): Promise<Archive> => {\n const opfFileData = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?><package xmlns=\"http://www.idpf.org/2007/opf\" version=\"2.0\" unique-identifier=\"bookid\">\n <metadata>\n <meta property=\"rendition:layout\">${options?.useRenditionFlow ? `reflowable` : `pre-paginated`}</meta>\n ${options?.useRenditionFlow ? `<meta property=\"rendition:flow\">scrolled-continuous</meta>` : ``}\n </metadata>\n <manifest>\n ${urls\n .map((url) => `<item id=\"${getUriBasename(url)}\" href=\"${url}\" media-type=\"${detectMimeTypeFromName(url)}\"/>`)\n .join(`\\n`)}\n </manifest>\n <spine>\n ${urls.map((url) => `<itemref idref=\"${getUriBasename(url)}\" />`).join(`\\n`)}\n </spine>\n </package>\n `\n\n const filesFromUrl: Archive[`files`] = urls.map((url) => ({\n dir: false,\n basename: getUriBasename(url),\n encodingFormat: detectMimeTypeFromName(url),\n uri: url,\n size: 100 / urls.length,\n base64: async () => ``,\n blob: async () => new Blob(),\n string: async () => ``,\n }))\n\n const opfFile: Archive[`files`][number] = {\n dir: false,\n basename: `content.opf`,\n uri: `content.opf`,\n size: 0,\n base64: async () => opfFileData,\n blob: async () => new Blob(),\n string: async () => opfFileData,\n }\n\n return {\n filename: ``,\n files: [opfFile, ...filesFromUrl],\n }\n}\n","export const blobToBase64 = async (blob: Blob) =>\n new Promise<string>((resolve) => {\n const reader = new FileReader()\n reader.readAsDataURL(blob)\n reader.onloadend = function () {\n const base64data = reader.result as string\n resolve(base64data)\n }\n })\n","import { blobToBase64 } from \"../utils/blobToBAse64\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * Useful to create archive from txt content\n */\nexport const createArchiveFromText = async (\n content: string | Blob,\n {\n mimeType,\n direction,\n }: {\n direction?: `ltr` | `rtl`\n mimeType?: string\n } = { mimeType: \"text/plain\" }\n) => {\n const txtOpfContent = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n <package xmlns=\"http://www.idpf.org/2007/opf\" version=\"3.0\" xml:lang=\"ja\" prefix=\"rendition: http://www.idpf.org/vocab/rendition/#\"\n unique-identifier=\"ootuya-id\">\n <metadata xmlns:opf=\"http://www.idpf.org/2007/opf\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:dcterms=\"http://purl.org/dc/terms/\">\n <meta property=\"rendition:layout\">reflowable</meta>\n </metadata>\n <manifest>\n <item id=\"p01\" href=\"p01.txt\" media-type=\"text/plain\"/>\n </manifest>\n <spine page-progression-direction=\"${direction ?? `ltr`}\">\n <itemref idref=\"p01\" />\n </spine>\n </package>\n `\n\n const archive: Archive = {\n filename: `content.txt`,\n files: [\n {\n dir: false,\n basename: getUriBasename(`generated.opf`),\n uri: `generated.opf`,\n blob: async () => new Blob([txtOpfContent]),\n string: async () => txtOpfContent,\n base64: async () => btoa(txtOpfContent),\n size: 0,\n },\n {\n dir: false,\n basename: getUriBasename(`p01.txt`),\n uri: `p01.txt`,\n blob: async () => {\n if (typeof content === `string`) return new Blob([content])\n return content\n },\n string: async () => {\n if (typeof content === `string`) return content\n return content.text()\n },\n base64: async () => {\n if (typeof content === `string`) return btoa(content)\n return blobToBase64(content)\n },\n size: typeof content === `string` ? content.length : content.size,\n encodingFormat: mimeType,\n },\n ],\n }\n\n return archive\n}\n","import { Report } from \"../report\"\nimport { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive, StreamResult } from \"./types\"\n\ninterface OutputByType {\n base64: string\n string: string\n text: string\n binarystring: string\n array: number[]\n uint8array: Uint8Array\n arraybuffer: ArrayBuffer\n blob: Blob\n nodebuffer: Buffer\n}\n\ntype OutputType = keyof OutputByType\ninterface JSZipObject {\n name: string\n dir: boolean\n date: Date\n comment: string\n unixPermissions: number | string | null\n dosPermissions: number | null\n async<T extends OutputType>(type: T): Promise<OutputByType[T]>\n // nodeStream(type?: `nodebuffer`): NodeJS.ReadableStream;\n internalStream?: (type?: `uint8array`) => StreamResult\n}\n\ninterface JSZip {\n files: { [key: string]: JSZipObject }\n}\n\nexport const createArchiveFromJszip = async (\n jszip: JSZip,\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = Object.values(jszip.files)\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n const archive = {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.dir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: () => file.async(`blob`),\n string: () => file.async(`string`),\n base64: () => file.async(`base64`),\n ...(file.internalStream && {\n stream: file.internalStream,\n }),\n // this is private API\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n size: file._data.uncompressedSize,\n })),\n }\n\n Report.log(\"Generated archive\", archive)\n\n return archive\n}\n","import { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\nexport const createArchiveFromArrayBufferList = async (\n list: {\n isDir: boolean\n name: string\n size: number\n data: () => Promise<ArrayBuffer>\n }[],\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = list\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n return {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.isDir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: async () => new Blob([await file.data()]),\n string: async () => {\n const data = await file.data()\n return String.fromCharCode.apply(null, Array.from(new Uint16Array(data)))\n },\n base64: async () => {\n // @todo not used for now, lets implement it later if needed\n return ``\n },\n size: file.size,\n })),\n }\n}\n","import { Report } from \"./report\"\n\nexport const configure = ({ enableReport }: { enableReport?: boolean } = {}) => {\n Report.enable(!!enableReport)\n}\n"],"names":["extractNavChapter","li","opfBasePath","baseUrl","chp","contentNode","node","urlJoin","sublistNode","children","child","buildTOCFromNav","doc","toc","navDataChildren","_a","_b","parseTocFromNavPath","opfXmlDoc","archive","navItem","tocFile","item","xmldoc","mapNcxChapter","point","prefix","src","out","pt","buildTOCFromNCX","ncxData","rootTagName","parseTocFromNcx","opfData","spine","ncxId","ncxItem","ncxPath","file","parseToc","getArchiveOpfInfo","tocFromNcx","extractKoboInformationFromArchive","koboInformation","optionElement","enabled","Report","enable","data","label","performanceEntry","targetDuration","duration","name","functionToMeasure","args","t0","response","res","t1","getSpineItemFilesFromArchive","opsFile","_opfXmlDoc","manifestElm","spineElm","spineItemIds","manifestItemsFromSpine","getItemsFromDoc","el","epubHook","manifest","metadataElm","guideElm","titleElm","metaElmChildren","metaElmWithRendition","meta","metaElmWithRenditionFlow","metaElmWithRenditionSpread","publisherRenditionLayout","publisherRenditionFlow","renditionSpread","title","dir","pageProgressionDirection","totalSize","size","itemrefElm","manifestItem","href","properties","itemSize","hrefBaseUri","_c","property","elm","generateResourceFromArchive","resourcePath","metadata","getMetadata","blob","getContentTypeFromExtension","uri","defaultHook","files","index","comicInfoHook","comicInfoFile","content","mangaVal","hasDocMetaViewport","metaElm","allFilesHaveViewportMeta","result","current","isXmlBasedMimeType","epubOptimizerHook","sortByTitleComparator","a","b","alist","blist","i","len","navigationFallbackHook","filesSortedByAlpha","acc","parts","part","level","baseManifest","generateManifestFromArchive","hooks","gen","e","getUriBasename","createArchiveFromUrls","urls","options","opfFileData","url","detectMimeTypeFromName","filesFromUrl","blobToBase64","resolve","reader","base64data","createArchiveFromText","mimeType","direction","txtOpfContent","createArchiveFromJszip","jszip","orderByAlpha","createArchiveFromArrayBufferList","list","configure","enableReport"],"mappings":"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"}
1
+ {"version":3,"file":"prose-streamer.umd.cjs","sources":["../src/parsers/nav.ts","../src/parsers/kobo.ts","../src/report.ts","../src/archives/getArchiveOpfInfo.ts","../src/epub/getSpineItemFilesFromArchive.ts","../src/generators/manifest/hooks/epub.ts","../src/generators/resources.ts","../src/generators/manifest/hooks/default.ts","../src/generators/manifest/hooks/comicInfo.ts","../src/generators/manifest/hooks/epubOptimizer.ts","../src/utils/sortByTitleComparator.ts","../src/generators/manifest/hooks/navigationFallback.ts","../src/generators/manifest/index.ts","../src/utils/uri.ts","../src/archives/createArchiveFromUrls.ts","../src/utils/blobToBAse64.ts","../src/archives/createArchiveFromText.ts","../src/archives/createArchiveFromJszip.ts","../src/archives/createArchiveFromArrayBufferList.ts","../src/configure.ts"],"sourcesContent":["import xmldoc, { XmlElement } from \"xmldoc\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { urlJoin } from \"@prose-reader/shared\"\n\ntype Toc = NonNullable<Manifest[`nav`]>[`toc`]\ntype TocItem = NonNullable<Manifest[`nav`]>[`toc`][number]\n\nconst extractNavChapter = (li: XmlElement, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const chp: TocItem = {\n contents: [],\n path: ``,\n href: ``,\n title: ``,\n }\n let contentNode = li.childNamed(`span`) || li.childNamed(`a`)\n chp.title = contentNode?.attr.title || contentNode?.val.trim() || chp.title\n let node = contentNode?.name\n if (node !== `a`) {\n contentNode = li.descendantWithPath(`${node}.a`)\n if (contentNode) {\n node = contentNode.name.toLowerCase()\n }\n }\n if (node === `a` && contentNode?.attr.href) {\n chp.path = urlJoin(opfBasePath, contentNode.attr.href)\n chp.href = urlJoin(baseUrl, opfBasePath, contentNode.attr.href)\n }\n const sublistNode = li.childNamed(`ol`)\n if (sublistNode) {\n const children = sublistNode.childrenNamed(`li`)\n if (children && children.length > 0) {\n chp.contents = children.map((child) => extractNavChapter(child, { opfBasePath, baseUrl }))\n }\n }\n\n return chp\n}\n\nconst buildTOCFromNav = (doc: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: Toc = []\n\n let navDataChildren\n if (doc.descendantWithPath(`body.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.nav.ol`)?.children\n } else if (doc.descendantWithPath(`body.section.nav.ol`)) {\n navDataChildren = doc.descendantWithPath(`body.section.nav.ol`)?.children\n }\n\n if (navDataChildren && navDataChildren.length > 0) {\n navDataChildren\n .filter((li) => (li as XmlElement).name === `li`)\n .forEach((li) => toc.push(extractNavChapter(li as XmlElement, { opfBasePath, baseUrl })))\n }\n\n return toc\n}\n\nconst parseTocFromNavPath = async (\n opfXmlDoc: xmldoc.XmlDocument,\n archive: Archive,\n { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }\n) => {\n // Try to detect if there is a nav item\n const navItem = opfXmlDoc\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((child) => child.attr.properties === `nav`)\n\n if (navItem) {\n const tocFile = Object.values(archive.files).find((item) => item.uri.endsWith(navItem.attr.href || ``))\n if (tocFile) {\n const doc = new xmldoc.XmlDocument(await tocFile.string())\n return buildTOCFromNav(doc, { opfBasePath, baseUrl })\n }\n }\n}\n\nconst mapNcxChapter = (\n point: xmldoc.XmlElement,\n { opfBasePath, baseUrl, prefix }: { opfBasePath: string; baseUrl: string; prefix: string }\n) => {\n const src = point?.childNamed(`${prefix}content`)?.attr.src || ``\n\n const out: TocItem = {\n title: point?.descendantWithPath(`${prefix}navLabel.${prefix}text`)?.val || ``,\n path: urlJoin(opfBasePath, src),\n href: urlJoin(baseUrl, opfBasePath, src),\n contents: [],\n }\n const children = point.childrenNamed(`${prefix}navPoint`)\n if (children && children.length > 0) {\n out.contents = children.map((pt) => mapNcxChapter(pt, { opfBasePath, baseUrl, prefix }))\n }\n\n return out\n}\n\nconst buildTOCFromNCX = (ncxData: xmldoc.XmlDocument, { opfBasePath, baseUrl }: { opfBasePath: string; baseUrl: string }) => {\n const toc: NonNullable<Manifest[`nav`]>[`toc`] = []\n\n const rootTagName = ncxData.name\n let prefix = ``\n if (rootTagName.indexOf(`:`) !== -1) {\n prefix = rootTagName.split(`:`)[0] + `:`\n }\n\n ncxData\n .childNamed(`${prefix}navMap`)\n ?.childrenNamed(`${prefix}navPoint`)\n .forEach((point) => toc.push(mapNcxChapter(point, { opfBasePath, baseUrl, prefix })))\n\n return toc\n}\n\nconst parseTocFromNcx = async ({\n opfData,\n opfBasePath,\n baseUrl,\n archive,\n}: {\n opfData: xmldoc.XmlDocument\n opfBasePath: string\n archive: Archive\n baseUrl: string\n}) => {\n const spine = opfData.childNamed(`spine`)\n const ncxId = spine && spine.attr.toc\n\n if (ncxId) {\n const ncxItem = opfData\n .childNamed(`manifest`)\n ?.childrenNamed(`item`)\n .find((item) => item.attr.id === ncxId)\n\n if (ncxItem) {\n const ncxPath = `${opfBasePath}${opfBasePath === `` ? `` : `/`}${ncxItem.attr.href}`\n\n const file = Object.values(archive.files).find((item) => item.uri.endsWith(ncxPath))\n\n if (file) {\n const ncxData = new xmldoc.XmlDocument(await file.string())\n\n return buildTOCFromNCX(ncxData, { opfBasePath, baseUrl })\n }\n }\n }\n}\n\nexport const parseToc = async (opfXmlDoc: xmldoc.XmlDocument, archive: Archive, { baseUrl }: { baseUrl: string }) => {\n const { basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const tocFromNcx = await parseTocFromNcx({\n opfData: opfXmlDoc,\n opfBasePath,\n archive,\n baseUrl,\n })\n\n if (tocFromNcx) {\n return tocFromNcx\n }\n\n return await parseTocFromNavPath(opfXmlDoc, archive, { opfBasePath, baseUrl })\n}\n","import xmldoc from \"xmldoc\"\nimport { Archive } from \"..\"\n\ntype KoboInformation = {\n renditionLayout?: `reflowable` | `pre-paginated` | undefined\n}\n\nexport const extractKoboInformationFromArchive = async (archive: Archive) => {\n const koboInformation: KoboInformation = {\n renditionLayout: undefined,\n }\n\n await Promise.all(\n archive.files.map(async (file) => {\n if (file.uri.endsWith(`com.kobobooks.display-options.xml`)) {\n const opfXmlDoc = new xmldoc.XmlDocument(await file.string())\n const optionElement = opfXmlDoc.childNamed(`platform`)?.childNamed(`option`)\n if (optionElement?.attr?.name === `fixed-layout` && optionElement.val === `true`) {\n koboInformation.renditionLayout = `pre-paginated`\n }\n }\n })\n )\n\n return koboInformation\n}\n","let enabled = false\n\nexport const Report = {\n enable: (enable: boolean) => {\n enabled = enable\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n log: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n warn: (...data: any[]) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.warn(`[prose-reader-streamer]`, ...data)\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n error: (...data: any[]) => {\n // eslint-disable-next-line no-console\n console.error(...data)\n },\n time: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.time(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n timeEnd: (label?: string | undefined) => {\n if (enabled) {\n // eslint-disable-next-line no-console\n console.timeEnd(`[prose-reader-streamer] [metric] ${label}`)\n }\n },\n metric: (performanceEntry: { name: string; duration: number }, targetDuration = Infinity) => {\n const duration = typeof performanceEntry === `number` ? performanceEntry : performanceEntry.duration\n if (enabled) {\n if (performanceEntry.duration <= targetDuration) {\n // eslint-disable-next-line no-console\n console.log(`[prose-reader-streamer] [metric] `, `${performanceEntry.name} took ${duration}ms`)\n } else {\n // eslint-disable-next-line no-console\n console.warn(\n `[prose-reader-streamer] [metric] `,\n `${performanceEntry.name} took ${performanceEntry.duration}ms which is above the ${targetDuration}ms target for this function`\n )\n }\n }\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n measurePerformance: <F extends (...args: any[]) => any>(name: string, targetDuration = 10, functionToMeasure: F) => {\n return (...args: Parameters<F>): ReturnType<F> => {\n const t0 = performance.now()\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const response = functionToMeasure(...(args as any))\n\n if (response && response.then) {\n return response.then((res: any) => {\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n return res\n })\n }\n\n const t1 = performance.now()\n Report.metric({ name, duration: t1 - t0 }, targetDuration)\n\n return response\n }\n },\n}\n","import { Archive } from \"./types\"\n\nexport const getArchiveOpfInfo = (archive: Archive) => {\n const filesAsArray = Object.values(archive.files).filter((file) => !file.dir)\n const file = filesAsArray.find((file) => file.uri.endsWith(`.opf`))\n\n return {\n data: file,\n basePath: file?.uri.substring(0, file.uri.lastIndexOf(`/`)) || ``,\n }\n}\n","import xmldoc from \"xmldoc\"\nimport { getArchiveOpfInfo } from \"../archives/getArchiveOpfInfo\"\nimport { Archive } from \"../archives/types\"\n\nexport const getSpineItemFilesFromArchive = async ({ archive }: { archive: Archive }) => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n\n const data = await opsFile?.string()\n\n if (!data) return []\n\n const _opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const manifestElm = _opfXmlDoc.childNamed(`manifest`)\n const spineElm = _opfXmlDoc.childNamed(`spine`)\n\n const spineItemIds = spineElm?.childrenNamed(`itemref`).map((item) => item.attr.idref) as string[]\n const manifestItemsFromSpine =\n manifestElm?.childrenNamed(`item`).filter((item) => spineItemIds.includes(item.attr.id || ``)) || []\n\n const archiveSpineItems = archive.files.filter((file) => {\n return manifestItemsFromSpine.find((item) => {\n if (!opfBasePath) return `${item.attr.href}` === file.uri\n return `${opfBasePath}/${item.attr.href}` === file.uri\n })\n })\n\n return archiveSpineItems\n}\n","import xmldoc from \"xmldoc\"\nimport { parseToc } from \"../../../parsers/nav\"\nimport type { Manifest } from \"@prose-reader/shared\"\nimport { extractKoboInformationFromArchive } from \"../../../parsers/kobo\"\nimport { Report } from \"../../../report\"\nimport { Archive } from \"../../../archives/types\"\nimport { getArchiveOpfInfo } from \"../../../archives/getArchiveOpfInfo\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\ntype SpineItemProperties = `rendition:layout-reflowable` | `page-spread-left` | `page-spread-right`\n\nexport const getItemsFromDoc = (doc: xmldoc.XmlDocument) => {\n const manifestElm = doc.childNamed(`manifest`)\n\n return (\n manifestElm?.childrenNamed(`item`)?.map((el) => ({\n href: el.attr.href || ``,\n id: el.attr.id || ``,\n mediaType: el.attr[`media-type`],\n })) || []\n )\n}\n\nexport const epubHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const { data: opsFile, basePath: opfBasePath } = getArchiveOpfInfo(archive) || {}\n const koboInformation = await extractKoboInformationFromArchive(archive)\n\n if (!opsFile) {\n return manifest\n }\n\n const data = await opsFile.string()\n\n Report.log(data, koboInformation)\n\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n\n const toc = (await parseToc(opfXmlDoc, archive, { baseUrl })) || []\n\n const metadataElm = opfXmlDoc.childNamed(`metadata`)\n const manifestElm = opfXmlDoc.childNamed(`manifest`)\n const spineElm = opfXmlDoc.childNamed(`spine`)\n const guideElm = opfXmlDoc.childNamed(`guide`)\n const titleElm = metadataElm?.childNamed(`dc:title`)\n const metaElmChildren = metadataElm?.childrenNamed(`meta`) || []\n const metaElmWithRendition = metaElmChildren.find((meta) => meta.attr.property === `rendition:layout`)\n const metaElmWithRenditionFlow = metaElmChildren.find((meta) => meta.attr.property === `rendition:flow`)\n const metaElmWithRenditionSpread = metaElmChildren.find((meta) => meta.attr.property === `rendition:spread`)\n\n const publisherRenditionLayout = metaElmWithRendition?.val as `reflowable` | `pre-paginated` | undefined\n const publisherRenditionFlow = metaElmWithRenditionFlow?.val as\n | `scrolled-continuous`\n | `scrolled-doc`\n | `paginated`\n | `auto`\n | undefined\n const renditionSpread = metaElmWithRenditionSpread?.val as `auto` | undefined\n\n const title = titleElm?.val || archive.files.find(({ dir }) => dir)?.basename || ``\n const pageProgressionDirection = spineElm?.attr[`page-progression-direction`] as `ltr` | `rtl` | undefined\n\n const archiveSpineItems = await getSpineItemFilesFromArchive({ archive })\n\n const totalSize = archiveSpineItems.reduce((size, file) => file.size + size, 0)\n\n return {\n filename: archive.filename,\n nav: {\n toc,\n },\n renditionLayout: publisherRenditionLayout || koboInformation.renditionLayout || `reflowable`,\n renditionFlow: publisherRenditionFlow || `auto`,\n renditionSpread,\n title,\n readingDirection: pageProgressionDirection || `ltr`,\n spineItems:\n spineElm?.childrenNamed(`itemref`).map((itemrefElm) => {\n const manifestItem = manifestElm?.childrenNamed(`item`).find((item) => item.attr.id === itemrefElm?.attr.idref)\n const href = manifestItem?.attr.href || ``\n const properties = (itemrefElm?.attr.properties?.split(` `) || []) as SpineItemProperties[]\n const itemSize = archive.files.find((file) => file.uri.endsWith(href))?.size || 0\n\n // we use base url or nothing (and stay relative)\n const hrefBaseUri = baseUrl ?? \"\"\n\n return {\n id: manifestItem?.attr.id || ``,\n href: manifestItem?.attr.href?.startsWith(`https://`)\n ? manifestItem?.attr.href\n : opfBasePath\n ? `${hrefBaseUri}${opfBasePath}/${manifestItem?.attr.href}`\n : `${hrefBaseUri}${manifestItem?.attr.href}`,\n renditionLayout: publisherRenditionLayout || `reflowable`,\n ...(properties.find((property) => property === `rendition:layout-reflowable`) && {\n renditionLayout: `reflowable`,\n }),\n progressionWeight: itemSize / totalSize,\n pageSpreadLeft: properties.some((property) => property === `page-spread-left`) || undefined,\n pageSpreadRight: properties.some((property) => property === `page-spread-right`) || undefined,\n // size: itemSize\n mediaType: manifestItem?.attr[`media-type`],\n }\n }) || [],\n items: getItemsFromDoc(opfXmlDoc),\n guide: guideElm?.childrenNamed(`reference`).map((elm) => {\n return {\n href: elm.attr.href || ``,\n title: elm.attr.title || ``,\n type: elm.attr.type as NonNullable<Manifest[`guide`]>[number][`type`],\n }\n }),\n }\n }\n","import xmldoc from \"xmldoc\"\nimport { Archive, getArchiveOpfInfo } from \"..\"\nimport { getItemsFromDoc } from \"./manifest/hooks/epub\"\n\nexport const generateResourceFromArchive = async (archive: Archive, resourcePath: string) => {\n const file = Object.values(archive.files).find((file) => file.uri === resourcePath)\n\n const metadata = await getMetadata(archive, resourcePath)\n\n if (!file) {\n throw new Error(`no file found`)\n }\n\n const blob = await file.blob()\n\n // if (file.stream) {\n // const stream = file.stream()\n\n // console.log(file, stream)\n // stream.on(`data`, data => {\n // console.log(`data`, data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // console.log(`end`)\n // })\n\n // }\n\n // const stream = file.stream!()\n\n // const readableStream = new ReadableStream({\n // start(controller) {\n // function push() {\n // stream.on(`data`, data => {\n // controller.enqueue(data)\n // })\n // stream.on(`error`, data => {\n // console.error(`error`, data)\n // })\n // stream.on(`end`, () => {\n // controller.close()\n // })\n\n // stream.resume()\n // }\n\n // push();\n // }\n // })\n\n return {\n body: blob,\n params: {\n headers: {\n ...(blob.type && {\n \"Content-Type\": blob.type,\n }),\n ...(file.encodingFormat && {\n \"Content-Type\": file.encodingFormat,\n }),\n ...(metadata.mediaType && {\n \"Content-Type\": metadata.mediaType,\n }),\n // 'Cache-Control': `no-cache, no-store, no-transform`\n },\n },\n }\n}\n\nconst getMetadata = async (archive: Archive, resourcePath: string) => {\n const opfInfo = getArchiveOpfInfo(archive)\n const data = await opfInfo.data?.string()\n\n if (data) {\n const opfXmlDoc = new xmldoc.XmlDocument(data)\n const items = getItemsFromDoc(opfXmlDoc)\n\n return {\n mediaType: items.find((item) => resourcePath.endsWith(item.href))?.mediaType,\n }\n }\n\n return {\n mediaType: getContentTypeFromExtension(resourcePath),\n }\n}\n\nconst getContentTypeFromExtension = (uri: string) => {\n if (uri.endsWith(`.css`)) {\n return `text/css; charset=UTF-8`\n }\n if (uri.endsWith(`.jpg`)) {\n return `image/jpg`\n }\n if (uri.endsWith(`.xhtml`)) {\n return `application/xhtml+xml`\n }\n if (uri.endsWith(`.mp4`)) {\n return `video/mp4`\n }\n if (uri.endsWith(`.svg`)) {\n return `image/svg+xml`\n }\n}\n","import { Manifest } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\n\nexport const defaultHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (): Promise<Manifest> => {\n const files = Object.values(archive.files).filter((file) => !file.dir)\n\n return {\n filename: archive.filename,\n title: archive.files.find(({ dir }) => dir)?.basename.replace(/\\/$/, ``) || ``,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n readingDirection: `ltr`,\n spineItems: files.map((file, index) => ({\n // some books such as cbz can have same basename inside different sub folder\n // we need to make sure to have unique index\n // /chap01/01.png, /chap02/01.png, etc\n id: `${index}.${file.basename}`,\n href: encodeURI(`${baseUrl}${file.uri}`),\n renditionLayout: `pre-paginated`,\n progressionWeight: 1 / files.length,\n pageSpreadLeft: undefined,\n pageSpreadRight: undefined,\n mediaType: file.encodingFormat,\n })),\n items: files.map((file, index) => ({\n id: `${index}.${file.basename}`,\n href: `${baseUrl}${file.uri}`,\n })),\n }\n }\n","import { Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\n\n/**\n * Handle archive which contains ComicInfo.xml. This is a meta file\n * used to define cbz, etc. I believe it comes from some sites or apps.\n */\nexport const comicInfoHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const comicInfoFile = archive.files.find((file) => file.basename.toLowerCase() === `comicinfo.xml`)\n\n if (!comicInfoFile) {\n return manifest\n }\n\n // @todo handle more meta\n const content = await comicInfoFile.string()\n const xmlDoc = new xmldoc.XmlDocument(content)\n\n const mangaVal = (xmlDoc.childNamed(`Manga`)?.val as `YesAndRightToLeft`) || `unknown`\n\n return {\n ...manifest,\n spineItems: manifest.spineItems.filter((item) => item.id.toLowerCase() !== `comicinfo.xml`),\n readingDirection: mangaVal === `YesAndRightToLeft` ? `rtl` : `ltr`,\n }\n }\n","import { isXmlBasedMimeType, Manifest } from \"@prose-reader/shared\"\nimport xmldoc from \"xmldoc\"\nimport { Archive } from \"../../../archives/types\"\nimport { getSpineItemFilesFromArchive } from \"../../../epub/getSpineItemFilesFromArchive\"\n\nconst hasDocMetaViewport = (doc: xmldoc.XmlDocument) => {\n const metaElm = doc\n .descendantWithPath(\"head\")\n ?.childrenNamed(\"meta\")\n .find((node) => node.attr.name === \"viewport\")\n\n return !!(metaElm && metaElm.attr.name === \"viewport\")\n}\n\nconst allFilesHaveViewportMeta = (files: Archive[\"files\"]) =>\n files.reduce(async (result, current) => {\n const _result = await result\n\n if (!_result) return false\n\n if (\n !isXmlBasedMimeType({\n mimeType: current.encodingFormat,\n uri: current.uri,\n })\n ) {\n return false\n }\n\n const file = await current.string()\n\n if (!file) return false\n\n return hasDocMetaViewport(new xmldoc.XmlDocument(file))\n }, Promise.resolve(true))\n\nexport const epubOptimizerHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n const bookIsFullReflowable =\n manifest.renditionLayout === \"reflowable\" && manifest.spineItems.every((item) => item.renditionLayout === \"reflowable\")\n\n if (bookIsFullReflowable) {\n const files = await getSpineItemFilesFromArchive({ archive })\n\n const hasAllViewport = await allFilesHaveViewportMeta(files)\n\n if (hasAllViewport) {\n return {\n ...manifest,\n spineItems: manifest.spineItems.map((item) => ({\n ...item,\n renditionLayout: \"pre-paginated\",\n })),\n renditionLayout: \"pre-paginated\",\n }\n }\n }\n\n return manifest\n }\n","export const sortByTitleComparator = (a: string, b: string) => {\n const alist = a.split(/(\\d+)/)\n const blist = b.split(/(\\d+)/)\n\n for (let i = 0, len = alist.length; i < len; i++) {\n if (alist[i] !== blist[i]) {\n if (alist[i]?.match(/\\d/)) {\n return +(alist[i] || ``) - +(blist[i] || ``)\n } else {\n return (alist[i] || ``).localeCompare(blist[i] || ``)\n }\n }\n }\n\n return 1\n}\n","import { Manifest, urlJoin } from \"@prose-reader/shared\"\nimport { Archive } from \"../../../archives/types\"\nimport { sortByTitleComparator } from \"../../../utils/sortByTitleComparator\"\n\n/**\n * In case no navigation was generated prior to this hook, we will try\n * to generate something based on the structure of the archive.\n *\n * We use folders as chapters.\n */\nexport const navigationFallbackHook =\n ({ archive, baseUrl }: { archive: Archive; baseUrl: string }) =>\n async (manifest: Manifest): Promise<Manifest> => {\n if (manifest.nav) return manifest\n\n const filesSortedByAlpha = [...archive.files].sort((a, b) => sortByTitleComparator(a.uri, b.uri))\n\n const toc: NonNullable<Manifest[\"nav\"]>[\"toc\"] = Object.values(filesSortedByAlpha).reduce((acc, file) => {\n const parts = file.uri.split(\"/\")\n\n // we have a file that is\n const isFileUnderFolder = !file.dir && parts.length > 1\n\n if (isFileUnderFolder) {\n parts.forEach((part, level) => {\n const partIsFileName = level === parts.length - 1\n\n if (partIsFileName) return\n\n const existingTocItem = acc.find(({ title }) => title === part)\n\n if (existingTocItem) {\n // @todo\n } else {\n acc.push({\n contents: [],\n href: urlJoin(baseUrl, encodeURI(file.uri)).replace(/\\/$/, \"\"),\n path: file.uri.replace(/\\/$/, \"\"),\n title: parts[0] ?? \"\",\n })\n }\n })\n }\n\n return acc\n }, [] as NonNullable<Manifest[\"nav\"]>[\"toc\"])\n\n if (toc.length === 0) return manifest\n\n return {\n ...manifest,\n nav: {\n toc,\n },\n }\n }\n","import type { Manifest } from \"@prose-reader/shared\"\nimport { Report } from \"../../report\"\nimport { Archive } from \"../../archives/types\"\nimport { defaultHook } from \"./hooks/default\"\nimport { epubHook } from \"./hooks/epub\"\nimport { comicInfoHook } from \"./hooks/comicInfo\"\nimport { epubOptimizerHook } from \"./hooks/epubOptimizer\"\nimport { navigationFallbackHook } from \"./hooks/navigationFallback\"\n\nconst baseManifest: Manifest = {\n filename: ``,\n items: [],\n nav: {\n toc: [],\n },\n readingDirection: `ltr`,\n renditionLayout: `pre-paginated`,\n renditionSpread: `auto`,\n spineItems: [],\n title: ``,\n}\n\nexport const generateManifestFromArchive = async (archive: Archive, { baseUrl = `` }: { baseUrl?: string } = {}) => {\n const hooks = [\n defaultHook({ archive, baseUrl }),\n epubHook({ archive, baseUrl }),\n epubOptimizerHook({ archive, baseUrl }),\n comicInfoHook({ archive, baseUrl }),\n navigationFallbackHook({ archive, baseUrl }),\n ]\n\n try {\n const manifest = await hooks.reduce(async (manifest, gen) => {\n return await gen(await manifest)\n }, Promise.resolve(baseManifest))\n\n Report.log(\"Generated manifest\", manifest)\n\n return manifest\n } catch (e) {\n Report.error(e)\n\n throw e\n }\n}\n","export const getUriBasename = (uri: string) => uri.substring(uri.lastIndexOf(`/`) + 1) || uri\n","import { detectMimeTypeFromName } from \"@prose-reader/shared\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * @important\n * Make sure the urls are on the same origin or the cors header is set otherwise\n * the resource cannot be consumed as it is on the web.\n */\nexport const createArchiveFromUrls = async (urls: string[], options?: { useRenditionFlow: boolean }): Promise<Archive> => {\n const opfFileData = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?><package xmlns=\"http://www.idpf.org/2007/opf\" version=\"2.0\" unique-identifier=\"bookid\">\n <metadata>\n <meta property=\"rendition:layout\">${options?.useRenditionFlow ? `reflowable` : `pre-paginated`}</meta>\n ${options?.useRenditionFlow ? `<meta property=\"rendition:flow\">scrolled-continuous</meta>` : ``}\n </metadata>\n <manifest>\n ${urls\n .map((url) => `<item id=\"${getUriBasename(url)}\" href=\"${url}\" media-type=\"${detectMimeTypeFromName(url)}\"/>`)\n .join(`\\n`)}\n </manifest>\n <spine>\n ${urls.map((url) => `<itemref idref=\"${getUriBasename(url)}\" />`).join(`\\n`)}\n </spine>\n </package>\n `\n\n const filesFromUrl: Archive[`files`] = urls.map((url) => ({\n dir: false,\n basename: getUriBasename(url),\n encodingFormat: detectMimeTypeFromName(url),\n uri: url,\n size: 100 / urls.length,\n base64: async () => ``,\n blob: async () => new Blob(),\n string: async () => ``,\n }))\n\n const opfFile: Archive[`files`][number] = {\n dir: false,\n basename: `content.opf`,\n uri: `content.opf`,\n size: 0,\n base64: async () => opfFileData,\n blob: async () => new Blob(),\n string: async () => opfFileData,\n }\n\n return {\n filename: ``,\n files: [opfFile, ...filesFromUrl],\n }\n}\n","export const blobToBase64 = async (blob: Blob) =>\n new Promise<string>((resolve) => {\n const reader = new FileReader()\n reader.readAsDataURL(blob)\n reader.onloadend = function () {\n const base64data = reader.result as string\n resolve(base64data)\n }\n })\n","import { blobToBase64 } from \"../utils/blobToBAse64\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\n/**\n * Useful to create archive from txt content\n */\nexport const createArchiveFromText = async (\n content: string | Blob,\n {\n mimeType,\n direction,\n }: {\n direction?: `ltr` | `rtl`\n mimeType?: string\n } = { mimeType: \"text/plain\" }\n) => {\n const txtOpfContent = `\n <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n <package xmlns=\"http://www.idpf.org/2007/opf\" version=\"3.0\" xml:lang=\"ja\" prefix=\"rendition: http://www.idpf.org/vocab/rendition/#\"\n unique-identifier=\"ootuya-id\">\n <metadata xmlns:opf=\"http://www.idpf.org/2007/opf\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:dcterms=\"http://purl.org/dc/terms/\">\n <meta property=\"rendition:layout\">reflowable</meta>\n </metadata>\n <manifest>\n <item id=\"p01\" href=\"p01.txt\" media-type=\"text/plain\"/>\n </manifest>\n <spine page-progression-direction=\"${direction ?? `ltr`}\">\n <itemref idref=\"p01\" />\n </spine>\n </package>\n `\n\n const archive: Archive = {\n filename: `content.txt`,\n files: [\n {\n dir: false,\n basename: getUriBasename(`generated.opf`),\n uri: `generated.opf`,\n blob: async () => new Blob([txtOpfContent]),\n string: async () => txtOpfContent,\n base64: async () => btoa(txtOpfContent),\n size: 0,\n },\n {\n dir: false,\n basename: getUriBasename(`p01.txt`),\n uri: `p01.txt`,\n blob: async () => {\n if (typeof content === `string`) return new Blob([content])\n return content\n },\n string: async () => {\n if (typeof content === `string`) return content\n return content.text()\n },\n base64: async () => {\n if (typeof content === `string`) return btoa(content)\n return blobToBase64(content)\n },\n size: typeof content === `string` ? content.length : content.size,\n encodingFormat: mimeType,\n },\n ],\n }\n\n return archive\n}\n","import { Report } from \"../report\"\nimport { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive, StreamResult } from \"./types\"\n\ninterface OutputByType {\n base64: string\n string: string\n text: string\n binarystring: string\n array: number[]\n uint8array: Uint8Array\n arraybuffer: ArrayBuffer\n blob: Blob\n nodebuffer: Buffer\n}\n\ntype OutputType = keyof OutputByType\ninterface JSZipObject {\n name: string\n dir: boolean\n date: Date\n comment: string\n unixPermissions: number | string | null\n dosPermissions: number | null\n async<T extends OutputType>(type: T): Promise<OutputByType[T]>\n // nodeStream(type?: `nodebuffer`): NodeJS.ReadableStream;\n internalStream?: (type?: `uint8array`) => StreamResult\n}\n\ninterface JSZip {\n files: { [key: string]: JSZipObject }\n}\n\nexport const createArchiveFromJszip = async (\n jszip: JSZip,\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = Object.values(jszip.files)\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n const archive = {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.dir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: () => file.async(`blob`),\n string: () => file.async(`string`),\n base64: () => file.async(`base64`),\n ...(file.internalStream && {\n stream: file.internalStream,\n }),\n // this is private API\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n size: file._data.uncompressedSize,\n })),\n }\n\n Report.log(\"Generated archive\", archive)\n\n return archive\n}\n","import { sortByTitleComparator } from \"../utils/sortByTitleComparator\"\nimport { getUriBasename } from \"../utils/uri\"\nimport { Archive } from \"./types\"\n\nexport const createArchiveFromArrayBufferList = async (\n list: {\n isDir: boolean\n name: string\n size: number\n data: () => Promise<ArrayBuffer>\n }[],\n { orderByAlpha, name }: { orderByAlpha?: boolean; name?: string } = {}\n): Promise<Archive> => {\n let files = list\n\n if (orderByAlpha) {\n files = files.sort((a, b) => sortByTitleComparator(a.name, b.name))\n }\n\n return {\n filename: name || ``,\n files: files.map((file) => ({\n dir: file.isDir,\n basename: getUriBasename(file.name),\n uri: file.name,\n blob: async () => new Blob([await file.data()]),\n string: async () => {\n const data = await file.data()\n return String.fromCharCode.apply(null, Array.from(new Uint16Array(data)))\n },\n base64: async () => {\n // @todo not used for now, lets implement it later if needed\n return ``\n },\n size: file.size,\n })),\n }\n}\n","import { Report } from \"./report\"\n\nexport const configure = ({ enableReport }: { enableReport?: boolean } = {}) => {\n Report.enable(!!enableReport)\n}\n"],"names":["extractNavChapter","li","opfBasePath","baseUrl","chp","contentNode","node","urlJoin","sublistNode","children","child","buildTOCFromNav","doc","toc","navDataChildren","_a","_b","parseTocFromNavPath","opfXmlDoc","archive","navItem","tocFile","item","xmldoc","mapNcxChapter","point","prefix","src","out","pt","buildTOCFromNCX","ncxData","rootTagName","parseTocFromNcx","opfData","spine","ncxId","ncxItem","ncxPath","file","parseToc","getArchiveOpfInfo","tocFromNcx","extractKoboInformationFromArchive","koboInformation","optionElement","enabled","Report","enable","data","label","performanceEntry","targetDuration","duration","name","functionToMeasure","args","t0","response","res","t1","getSpineItemFilesFromArchive","opsFile","_opfXmlDoc","manifestElm","spineElm","spineItemIds","manifestItemsFromSpine","getItemsFromDoc","el","epubHook","manifest","metadataElm","guideElm","titleElm","metaElmChildren","metaElmWithRendition","meta","metaElmWithRenditionFlow","metaElmWithRenditionSpread","publisherRenditionLayout","publisherRenditionFlow","renditionSpread","title","dir","pageProgressionDirection","totalSize","size","itemrefElm","manifestItem","href","properties","itemSize","hrefBaseUri","_c","property","elm","generateResourceFromArchive","resourcePath","metadata","getMetadata","blob","getContentTypeFromExtension","uri","defaultHook","files","index","comicInfoHook","comicInfoFile","content","mangaVal","hasDocMetaViewport","metaElm","allFilesHaveViewportMeta","result","current","isXmlBasedMimeType","epubOptimizerHook","sortByTitleComparator","a","b","alist","blist","i","len","navigationFallbackHook","filesSortedByAlpha","acc","parts","part","level","baseManifest","generateManifestFromArchive","hooks","gen","e","getUriBasename","createArchiveFromUrls","urls","options","opfFileData","url","detectMimeTypeFromName","filesFromUrl","blobToBase64","resolve","reader","base64data","createArchiveFromText","mimeType","direction","txtOpfContent","createArchiveFromJszip","jszip","orderByAlpha","createArchiveFromArrayBufferList","list","configure","enableReport"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@prose-reader/streamer",
3
- "version": "1.15.0",
3
+ "version": "1.16.0",
4
4
  "type": "module",
5
5
  "main": "./dist/prose-streamer.umd.cjs",
6
6
  "module": "./dist/prose-streamer.js",
@@ -24,13 +24,13 @@
24
24
  "test:watch": "vitest watch"
25
25
  },
26
26
  "dependencies": {
27
- "@prose-reader/shared": "^1.15.0"
27
+ "@prose-reader/shared": "^1.16.0"
28
28
  },
29
29
  "peerDependencies": {
30
30
  "buffer": "^6.0.3",
31
31
  "xmldoc": "^1.1.2"
32
32
  },
33
- "gitHead": "d31fddf1134ea528cefdc680b02a1aa5adc5205d",
33
+ "gitHead": "c1c77c9d10c37dbcf9239d57cdd4ff0feb839e69",
34
34
  "devDependencies": {
35
35
  "buffer": "^6.0.3",
36
36
  "xmldoc": "^1.2.0"