-
-
Notifications
You must be signed in to change notification settings - Fork 148
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
Switch to sw mode by default #903
Conversation
f3b0009
to
7194ee9
Compare
Rebased on master to incorporate dependabot updates to testing dependencies. |
I determined that using a Bootstrap alert similar to our Active Content Warning was not ideal because it would only be possible to show the alert once the user has loaded a ZIM archive, which might be some time after initial app launch. Therefore I changed this to a Bootsrap-based System Alert (using the code we have for that in |
In the Firefox extension (if the message channel is supported), it will attempt to switch to SW mode automatically, and show the message below. If the user is switching BACK to SW mode after having successfully (on some previous occaion) launched SW mode and then deliberately returned to jQuery mode, then the standard message (as at present) is shown instead. |
I now need to set the development PWA to this branch, and temporarily set this branch's extension code to access the development PWA, in order to test what happens "on the other side". |
Tested on IceCat. It's a bit clunky: it attempts to load the PWA, then falls back to jQuery mode, but remains redirected to the PWA online until the user exits and relaunches. Then it works as expected in jQuery mode in the extension. Testing for the message channel API is not enough, and it looks like I'll have to put in a specific test (similar to the one we did for WebP support) in order to detect such cases. |
Relying on canvasElementWorkaround detection is not enough because the user can turn this anti-fingerprinting off for the site. |
N.B. Several of the dialog boxes have changed in small ways (usually to make them more concise). How to test PR's logic under various condiitons:
|
All this looks good! |
As a sidenote, this PR improves the situation outlined in #877 and #878, in that instead of leaving users of old Firefox in the PWA once it is discovered that Service Workers are not supported, this PR returns the user to local code. It is possible to prevent the return to local code by cancelling the relevant dialogue box (this is primarily for testing the PWA, but also to ensure the user has ultimate control over what is happening). |
On Firefox OS (simulator), if the user doesn't have an archive on their device (i.e. on their SD card), then the Welcome to Kiwix alert below will show instead of the alert about deprecation of jQuery mode: To address this issue, I have added code in the resolve function of the above alert to remove the key that indicates that the user has seen the deprecation notice. The effect of this is that once the user adds an archive to the device, and on next restart of the app, they will see the deprecation notice like this: |
@mossroy If you would like to test on a physical Firefox OS device, let me know. I still have some tests to do in various scenarios, because I removed a |
I just tested on my Firefox OS device, and it seems to behave as expected: the warning about unsupported SW mode appears (only once), and the app still works. However, when the popup appears, you have 2 ways to close it: the top-right X, or the bottom-right "okay" button. |
That's a good point. It's probably best to be explicit and have a Cancel button alongside the OK button, and then the "X" would be equivalent to Cancel and we can handle it in the code (it's an option in the |
Cancel, 'X' or backdrop (also Esc key) are now handled so that the deprecation warning will show again next session if the user cancelled. Note this does NOT apply to the notice that the user has been upgraded to ServiceWorker mode. In that case, there is no cancel button (but there is an X, as that can't easily be removed). IMHO "Cancel" is meaningless in that context, because we don't want to put the upgraded user back into JQuery mode, and we hope they'll just carry on using SW mode without thinking about it too much. There is one other case when I explicitly show a button that says "Use JQuery mode" (and "Cancel"). This is for users of the Firefox Extension in old browsers (e.g. IceCat). In that case, the user has been sent to the PWA only to discover that their browser doesn't support Service Worker mode. Then the button "Use JQuery mode" explicitly takes them back to the extension. This is a special case. |
Final tests completed:
|
Although we don't officially support it, the last version of Chrome to run on Windows XP/Vista is 49.0.2623.112, so it may be a good proxy for other issues. In this browser, the extension installs fine, but there is no Service Worker support in extensions, because they are not considered a secure origin. When loading the extension, we get the security error below, and this prevents display of the deprecation notice. So I need to handle that so the notice is displayed after this alert. |
In Firefox 107 (Developer Edition), I'm getting a failure to communicate between the PWA (latest code in this branch) and the Extension, which leads to a message on each launch that the last attempt to launch the PWA may have failed. Clearly this needs debugging before we can make SW mode the default. |
Panic over! It was because the PWA version had the wrong setting for |
This reverts commit 6783426.
I won't have the time to test more (I only tested on Firefox OS) or review in detail (I just had a quick look at the code and did not find anything obviously wrong) |
This branch contains work in progress that was commenced by @mossroy. The linked issue is #196.
Initial list of points to cover: