-
Notifications
You must be signed in to change notification settings - Fork 445
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Migrate to CSS modules / Support NextJS #284
Conversation
10049cf
to
4c0bdbd
Compare
c700bca
to
800d775
Compare
Tried it, think it works for the most part! A couple notes though: Trying to import types like this fails, probably due to ESM module resolution? (this was broken in my fork too) I'm not sure if export type { LTWH, LTWHP, Scaled, Position, ScaledPosition, Content, HighlightContent, Comment, HighlightComment, NewHighlight, IHighlight, ViewportHighlight, Viewport, Page } from "./types"; I made these changes to try and get the library to play well with Turbopack but the underlying diff --git a/node_modules/pdfjs-dist/build/pdf.mjs b/node_modules/pdfjs-dist/build/pdf.mjs
index 7906d1a..4875738 100644
--- a/node_modules/pdfjs-dist/build/pdf.mjs
+++ b/node_modules/pdfjs-dist/build/pdf.mjs
@@ -11878,8 +11878,17 @@ class PDFWorker {
if (this.#mainThreadWorkerMessageHandler) {
return this.#mainThreadWorkerMessageHandler;
}
- const worker = await import( /*webpackIgnore: true*/this.workerSrc);
- return worker.WorkerMessageHandler;
+ // Dynamically create a script element to load the worker script
+ return new Promise((resolve, reject) => {
+ const script = document.createElement('script');
+ script.src = this.workerSrc ?? "https://unpkg.com/[email protected]/build/pdf.worker.min.mjs";
+ script.type = 'module';
+ script.onload = () => {
+ resolve(globalThis.pdfjsWorker.WorkerMessageHandler);
+ };
+ script.onerror = reject;
+ document.head.appendChild(script);
+ });
};
return shadow(this, "_setupFakeWorkerGlobal", loader());
}
diff --git a/node_modules/pdfjs-dist/legacy/web/pdf_viewer.mjs b/node_modules/pdfjs-dist/legacy/web/pdf_viewer.mjs
index fad5698..ce02cd1 100644
--- a/node_modules/pdfjs-dist/legacy/web/pdf_viewer.mjs
+++ b/node_modules/pdfjs-dist/legacy/web/pdf_viewer.mjs
@@ -9749,10 +9749,16 @@ async function docProperties(pdfDocument) {
class GenericScripting {
constructor(sandboxBundleSrc) {
this._ready = new Promise((resolve, reject) => {
- const sandbox = import( /*webpackIgnore: true*/sandboxBundleSrc);
- sandbox.then(pdfjsSandbox => {
- resolve(pdfjsSandbox.QuickJSSandbox());
- }).catch(reject);
+ const script = document.createElement('script');
+ script.src = sandboxBundleSrc ?? "https://unpkg.com/[email protected]/build/pdf.sandbox.min.mjs";
+ script.type = 'module';
+ script.onload = () => {
+ import(sandboxBundleSrc).then(pdfjsSandbox => {
+ resolve(pdfjsSandbox.QuickJSSandbox());
+ }).catch(reject);
+ };
+ script.onerror = reject;
+ document.head.appendChild(script);
});
}
async createSandbox(data) {
diff --git a/node_modules/pdfjs-dist/web/pdf_viewer.css b/node_modules/pdfjs-dist/web/pdf_viewer.css
index 94828c8..e4065fc 100644
--- a/node_modules/pdfjs-dist/web/pdf_viewer.css
+++ b/node_modules/pdfjs-dist/web/pdf_viewer.css
@@ -315,14 +315,14 @@
backdrop-filter:var(--highlight-selected-backdrop-filter);
}
-.textLayer ::-moz-selection{
- background:rgba(0 0 255 / 0.25);
- background:color-mix(in srgb, AccentColor, transparent 75%);
+.textLayer ::-moz-selection {
+ background: blue;
+ background: AccentColor;
}
-.textLayer ::selection{
- background:rgba(0 0 255 / 0.25);
- background:color-mix(in srgb, AccentColor, transparent 75%);
+.textLayer ::selection {
+ background: blue;
+ background: AccentColor;
}
.textLayer br::-moz-selection{
diff --git a/node_modules/pdfjs-dist/web/pdf_viewer.mjs b/node_modules/pdfjs-dist/web/pdf_viewer.mjs
index 9c4f97d..35f1ce4 100644
--- a/node_modules/pdfjs-dist/web/pdf_viewer.mjs
+++ b/node_modules/pdfjs-dist/web/pdf_viewer.mjs
@@ -5994,10 +5994,16 @@ async function docProperties(pdfDocument) {
class GenericScripting {
constructor(sandboxBundleSrc) {
this._ready = new Promise((resolve, reject) => {
- const sandbox = import( /*webpackIgnore: true*/sandboxBundleSrc);
- sandbox.then(pdfjsSandbox => {
- resolve(pdfjsSandbox.QuickJSSandbox());
- }).catch(reject);
+ const script = document.createElement('script');
+ script.src = sandboxBundleSrc ?? "https://unpkg.com/[email protected]/build/pdf.sandbox.min.mjs";
+ script.type = 'module';
+ script.onload = () => {
+ import(sandboxBundleSrc).then(pdfjsSandbox => {
+ resolve(pdfjsSandbox.QuickJSSandbox());
+ }).catch(reject);
+ };
+ script.onerror = reject;
+ document.head.appendChild(script);
});
}
async createSandbox(data) { Basically, it didn't respect the parcel-bundler/lightningcss#685 (comment) Not sure if you want to include these patches in your library as well, but just wanted to flag! |
Closes #156
Based on the work in
#62 (comment)
https://github.com/teesis/react-pdf-highlighter/tree/next-compatibility
Tests
Notes