-
-
Notifications
You must be signed in to change notification settings - Fork 71
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
[WIP] Merge enhancements and fixes from Readest project into foliate-js upstream #43
base: main
Are you sure you want to change the base?
Conversation
1, 2, & 3: As hinted in the readme, I do not wish to support older browsers. In particular, it seems these features are supported if you're using the oldest currently supported version of macOS/iOS. 4 & 5: The reason these are the way they are now is that foliate-js is designed to be imported directly as is, as native ES modules. I'm not sure how it would work if you make these changes. 6: It's not entirely clear to me what the issue is, but I presume one can use the 7: I have not tried the feature so I don't know how it works exactly. If you just need to scroll to a certain fraction of a section, you can use a number as the |
1, 2, & 3: To support these features the app needs to target macOS 13.3 (which is release early last year) and above. I think it's fine to drop supports of lower versions. 4 & 5: The reason I need this is also supporting older browsers so that only legacy build of pdfjs is used. So if supports of older browsers are dropped this is fine. 6: To auto-hide the scrollbar the container needs to be notified the 7: That will be great. I will try this API now. |
Great. 6 & 7 are fixed in Readest side. Only 1 - 5 are needed to support older browsers. I'll maintain these patches for now and squash all future compatibility patches into this single commit. |
According to caniuse.com, those features are supported since Safari 16.4, and according to https://developer.apple.com/documentation/safari-release-notes the latest version of Safari available for macOS 11 Big Sur is 16.6. The oldest version of macOS still getting security updates, from what I gather, appears to be 12 Monterey. Am I missing something? Another thing that occurred to me is CSS nesting. Are you polyfilling for that? |
I have no idea of this and I didn't polyfill it. And on older browsers like UPDATE: This issue is already fixed by readest/readest@0076bab. |
One of my MacBook(MacBook Pro 13-inch, 2015) is stuck at macOS 12.7.6 as Apple has discontinued to support this model. Even though the last update of macOS 12.7.6 brings the Safari to version 17.6 but according to Tauri's documentation:
It is verified with this: ~ awk '/CFBundleVersion/{getline;gsub(/<[^>]*>/,"");print}' /System/Library/Frameworks/WebKit.framework/Resources/Info.plist
17613.3.9.1.16 Even it has a Safari with Version 17.6 (17618.3.11.11.7, 17618), the preinstalled WebKit with the operating system is stuck at 17613.3.9.1.16. So if we target to macOS version 13.3 and above which has WebKit version 17615.1.26, almost all MacBook before 2017 are ruled out. |
I see it. The |
d66b81a
to
22125a6
Compare
1. Avoid the use of Lookbehind regex which is not supported on WebKit version below 614.3.7.1.5; 2. Polyfill CSSStyleSheet constructor which is not supported on WebKit version below 615.1.26.11.22; 3. Avoid the use of module top-level await which is not supported on WebKit version below 613.3.9.1.16; 4. Use legacy build of pdfjs instead of the bundled pdfjs in the vendor directory: * Web Workers loading scripts in pdfjsPath now from the base / that's the public directory of a Next.js project; * Use @pdfjs instead of hard coding dist files path of pdfjs so that we can alias @pdfjs to the public directory;
…also scale background size
6774111
to
c7b4475
Compare
in order to support more TTS backends
This PR merges the changes made in the foliate-js submodule on the Readest project as discussed in the Windows build issue of the foliate project. These changes aim to enhance functionality and fix issues encountered during integration. By merging these updates into the upstream foliate-js, future versions of Readest can directly include the foliate-js as a dependency, ensuring alignment with the upstream repository and simplifying maintenance.
Summary of Changes:
1: Avoid the use of Lookbehind regex which is not supported on WebKit version below 614.3.7.1.5;
2: Polyfill CSSStyleSheet constructor which is not supported on WebKit version below 615.1.26.11.22;
3: Avoid the use of module top-level await which is not supported on WebKit version below 613.3.9.1.16;
4: Web Workers loading scripts in
pdfjsPath
now from the base/
that's thepublic
directory of a Next.js project;5: Use
@pdfjs
instead of hard codingdist
files path ofpdfjs
so that we can alias@pdfjs
to thepublic
directory;6: A hack to auto-hide the scrollbar by padding incontainer
other than theiframe
, so thatcontainer
could grab themouseleave
event and hide the scrollbar on macOS, otherwise once the scrollbar is shown it will be visible forever which is quite annoying on macOS;7: To implement Parallel View in Readest, the scrollTo function of the paginator should be public.Additional Notes:
Let me know if there are any adjustments or further refinements required for compatibility or style. Thank you for reviewing this patch! Looking forward to discussing and refining these updates for inclusion in foliate-js.