-
Notifications
You must be signed in to change notification settings - Fork 44
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
PDF Viewer in Nextcloud 25 not working with QtWebEngine 5.15 LTS (Chromium 87 based) - please use PDF.js legacy build #684
Comments
I suspect that using the |
Hum, we do not support chrom(ium) 87. |
According to: In addition, according to the same link, Nextcloud explicitly supports Safari and Edge which are also supported by PDF.js only in the legacy build. And surely some missing or not working feature is a better experience than the viewer coming up completely blank as it does now for a non-negligible amount of users. |
(In fact, IMHO, PDF.js legacy is already very demanding for the minimum browser version, but acceptable. PDF.js modern supporting only the very latest&greatest, I personally consider absolutely unacceptable.) When I try the demo links from Mozilla, which I assume use the very latest PDF.js (i.e., even newer than what Nextcloud 25 now uses):
the first link displays the same blank page on my browser that Nextcloud 25 does, whereas the second link works without any issues. |
Yep, I updated the documentation. nextcloud/documentation#9408 |
Not if this is broken. It's a dev versus user point of vue. |
Even with your change, you still document Safari and Edge as supported, and those also require the legacy version of PDF.js. The default/modern version supports only Firefox and Chrome! (And only the very latest version.) And additionally there is a huge difference in practice between "For the best experience with the Nextcloud web interface, we recommend" (but in practice, older/LTS browsers mostly or even completely work) and PDF.js just displaying nothing with a JavaScript syntax error. |
(See also #674 for Safari.) |
In practice, your browser list for Nextcloud includes Safari 13, which uses a WebKit version approximately one year older than Chromium 87, so it is not a big surprise that Nextcloud does not fail with JavaScript syntax errors on QtWebEngine 5.15. Except for the PDF viewer which (according to #674) is also broken at least on Safari 14 (and possibly even on later versions too considering that PDF.js default/modern does not support Safari at all, no matter the version). It would be great if QtWebEngine LTS were part of your testing, but it does not seem to be needed to work in practice. PDF.js is the one painpoint. |
Note that QtWebEngine 5.15 LTS is publicly available under the LGPL and can be built against any Qt 5.15, so the latest LTS version with the latest security backports can be used just fine with Qt Open Source. (That is what I am using.) |
Your browser list (the one at browserlists.dev to which you linked) also includes UC Browser 13.4 which is based on Chromium 78 (i.e., 9 versions older than QtWebEngine 5.15 LTS). |
Switching to legacy PDF.js is actually as easy as:
I can confirm that this works just fine, so I no longer have to downgrade PDF.js to an older release, the legacy build of 2.15.349 works fine. Please consider making this trivial change (see step 3) in the released Nextcloud application. It will greatly improve browser compatibility at practically no cost to you. |
Or alternatively, how much work would it be for you to simply ship both and let the local server admin choose through a UI checkbox which version to show to users (or even the individual user)? I would say it is not worth it because it is much easier to just ship legacy only, which will work everywhere, but if you are uncomfortable with that, shipping both could be a solution. |
Please stop spamming. Seeing 7 pings from the same user in one afternoon will make me ignore the ticket 😢
This will never happen. This is counter intuitive. you're looking to fix an issue that have minimal impact and applies to a handful of users (compared to millions)
This, I think, is the only point where it make sense to use the legacy build imho |
The other new submitted bugs are on the same topic |
This script can be used by the local admin as a workaround. (It can be run remotely, and it needs #!/bin/bash
SERVER=root@foo.example.com
if [ -z "$1" ] ; then
echo "usage: ./fix-nextcloud-pdfviewer.sh VERSION"
exit 1
fi
if [ ! -f files_pdfviewer-$1.tar.gz ] ; then
wget https://github.com/nextcloud/files_pdfviewer/archive/refs/tags/v$1.tar.gz -O files_pdfviewer-$1.tar.gz || exit $?
fi
rm -rf files_pdfviewer-$1 files_pdfviewer-$1-pdfjs-legacy
tar xzf files_pdfviewer-$1.tar.gz || exit $?
cp -a files_pdfviewer-$1 files_pdfviewer-$1-pdfjs-legacy || exit $?
cd files_pdfviewer-$1-pdfjs-legacy
sed -i -e 's/-dist\.zip/-legacy-dist.zip/g' pdfjs-get.js || exit $?
npm update || exit $?
npm run build || exit $?
node pdfjs-get.js || exit $?
tar cJf js.tar.xz js pdfjs-get.js || exit $?
scp js.tar.xz $SERVER:/var/www/nextcloud/apps/files_pdfviewer/ || exit $?
ssh $SERVER "cd /var/www/nextcloud/apps/files_pdfviewer/ && tar xJf js.tar.xz && chown -R www-data:www-data js pdfjs-get.js && rm -f js.tar.xz" || exit $?
cd ..
exit 0 |
FYI, the last PDF.js that supports QtWebEngine 5.15 LTS even in legacy mode is 3.5.141, so for Nextcloud 27.0.1, PDF.js also has to be downgraded: sed -i -e 's/"pdfjs-dist": "\^3\.6\.[0-9]\+"/"pdfjs-dist": "^3.5.141"/g' package.json || exit $? (I added this after my other QtWebEngine 5.15 LTS is based on Chromium 87. PDF.js 3.6.172, which is used in Nextcloud 27.0.1 / files_pdfviewer 2.8.0, bumps the minimum Chromium version to 88 (!). The result is that there are several display issues in QtWebEngine 5.15 LTS due to the use of unsupported CSS features. (The latest upstream, 3.8.162, bumps it further to 92. The result in QtWebEngine 5.15 LTS is a completely blank rendering with 0 pages due to JavaScript errors, same as in the non-legacy version, just slower to load.) |
Steps to reproduce
Expected behaviour
The PDF is displayed.
Actual behaviour
Blank space is displayed instead of the PDF viewer, and I get errors in the JavaScript console.
Additional information
The issue is that the PDF.js version was upgraded from 2.13.216 to 2.15.349, which introduces new JavaScript constructs not supported in Chromium 87, and that you use the default build of PDF.js, which supports only the very latest browsers, instead of the
legacy
build, which is much more compatible (see https://github.com/mozilla/pdf.js/wiki/Frequently-Asked-Questions#faq-support). QtWebEngine 5.15 LTS is a stable branch with backported security fixes (comparable to the Firefox ESR branches).I was able to quickly work around the issue by downgrading PDF.js to 2.13.216 on the server I administer, but I think using the
legacy
build would be a better long-term fix. I have not tried that yet, because I am not sure what exactly I need to change. (pdfjs-dist
ships both the default and thelegacy
build, the latter in a subdirectory.)The text was updated successfully, but these errors were encountered: