Skip to content
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

Use articleContent.write() #354

Closed

Conversation

Jaifroid
Copy link
Member

@Jaifroid Jaifroid commented Apr 8, 2018

This PR implements just the code that injects HTML into the iframe using articleContent.write() instead of .innerHTML. For explanation see #341. It is for testing, because it cannot be merged as is for the reason shown in the screenshot (explanation continues after screenshot):

image

I.e., the Headings are closed, and there is no way to open them, since clicking on the headers does nothing on FFOS (because the inline .onclick event is blocked (and errors are swallowed by Q) and the opening routines rely on jQuery which is not attached to the iframe).

This example is the page "Tuberculosis management" from the latest WikiMed ZIM. But any page on new-style mobile-first ZIMs will have this problem.

@mossroy , when you've had a chance to review this (absolutely no rush, I have a lot on this coming week), please request changes, so that I can then add the next step. Possible next steps:

@Jaifroid Jaifroid added the bug label Apr 8, 2018
@Jaifroid Jaifroid added this to the v2.3 milestone Apr 8, 2018
@Jaifroid Jaifroid self-assigned this Apr 8, 2018
@Jaifroid Jaifroid requested a review from mossroy April 8, 2018 19:40
@mossroy
Copy link
Contributor

mossroy commented Apr 8, 2018

On which ZIM file do you reproduce the issue?
I tried with wikipedia_en_medicine_novid_2018-03.zim but it does not seem to be a mobile version

@mossroy
Copy link
Contributor

mossroy commented Apr 8, 2018

NB : I think it should be avoided to use special characters like parenthesis in a branch name, as it's not always properly handled by git tools (for example autocompletion on command-line)

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 9, 2018

On which ZIM file do you reproduce the issue?
I tried with wikipedia_en_medicine_novid_2018-03.zim but it does not seem to be a mobile version

That's strange. The above screenshot is taken in the FFOS simulator on this PR using wikipedia_en_medicine_novid_2018-03.zim. Do you get a different result? I get the same result in wikivoyage_en_all_novid_2018-03.zim:

image

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 9, 2018

I think it should be avoided to use special characters like parenthesis in a branch name

OK, I'll try to rename.

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 9, 2018

Seems only way to rename remote branch is to delete this branch and push the renamed copy, but not sure how that would affect the PR. Seems confusing, so I'll leave as is for now.

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 9, 2018

Just to add a data point: running this PR in Firefox ESR produces this error (screenshot below) on every page load from mobile-style WikiMed in the Console log (the error is not reported in the FFOS simulator -- this is running the full browser). Error also with onclick events. It's possible that FFOS also blocks window.onload along with inline onclick events, which is why no error is seen in that context.

image

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 9, 2018

More info from Internet Explorer for onclick error:

image

mossroy added 2 commits April 11, 2018 11:28
Without this fix, the links were often broken in jQuery mode, because they were not parsed (because the DOM was not ready yet).
This fix waits for the iframe to be ready before parsing it.
@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

I pushed some commits on this branch : the first one fixes a race-condition, the second one fixes UI tests on Travis.
With this, it seems to work fine on Firefox 59, Chromium 65 and Firefox OS devices. Both in jQuery and ServiceWorker modes. But I did not test a lot.

I now reproduce the header toggle issue (due to missing jquery javascript) : it was because my desktop screen was considered too wide by the CSS to collapse the headers. It is indeed a real (and separate) issue.

NB : never mind for the branch name, we'll see if it causes other issues or not.

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

@Jaifroid : can you confirm that this PR fixes #341?
If it's the case, we might test a bit more, then merge this PR

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

I think it also fixes #347 , but it needs to be verified.

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

I opened #355 for the toggleSection issue

loadCSSJQuery();
//JavaScript loading currently disabled
//loadJavaScriptJQuery();
iframeArticleContent.onload = function() {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @mossroy , thanks for your work on this! Can I just ask if you introduced this .onload function with the iframe in order to cure a race condition you observed with articleContent.write()? I've got absolutely no problem with doing it this way, but I'm curious as to whether you were still noticing the race problem with this way of injecting to the iframe -- I thought it was a problem pertaining to the loading of dummyArticle only, and went away once we got rid of dummyArticle. Again, no problem here, it looks like a good way of avoiding potential problems.

I'll try to do some testing of the PR this evening and will get back to you.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In my first test, the links were simply not parsed (on my desktop Firefox 59). So they were leading to an error page, because the href was not found.
On the other hand, I tried to remove the onload trick, and can not reproduce the issue now...

So I can't say I'm 100% sure. I should test more

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I just reproduced it a few times, on several ZIM files

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, thanks for confirming. So it turns out document.write() is asynchronous, at least in the latest Firefox. Good to know.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I reproduced that also on Firefox ESR 52.7.3 and Chrome 68, with the Ray Charles archive.
I suppose the browser enfines interpret the iframe in a separate thread, which makes sense.

I'm wondering if it would be necessary to move the statement "articleContent.close();" after the onload declarations. If the iframe loading is really in another thread, it might finish before we put the onload.
It's probably safer to move this line.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I read somewhere that document.close(); may be necessary to trigger the document.onload event. May be wrong. But if it works as is, and #347 is not reproducible with this PR, then maybe we're OK...

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think you're right about document.close() : the onload event is certainly fired after the document.close(). To illustrate my proposal, I've commited it in the branch : I've moved the document.close() after setting the onload

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

When running this PR on Chromium, it displays the following warning in the console :
[Violation] Avoid using document.write().

It does work, but it's not a good sign of proper support in the long term : not cool...

@Jaifroid
Copy link
Member Author

Discussion in second link seems pretty balanced. It's more a conceptual problem people have with it. For loading content into an iframe from a known and controlled source (the ZIM in our case) where you want active content to run, it seems like the perfect use case...

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

Thanks for the links. You seem to be right : it's not deprecated, but seems to be often misused.

@mossroy
Copy link
Contributor

mossroy commented Apr 11, 2018

Regarding the document.write() method, can you test it a bit more on Edge? Because there is the following comment on https://developer.mozilla.org/en-US/docs/Web/API/Document/write :

Note: In Edge only, calling document.write more than once in an iframe causes the error SCRIPT70: Permission denied.

See https://stackoverflow.com/questions/39954217/several-document-write-in-iframe-in-edge-cause-script70-permission-denied

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 11, 2018

On the Edge bug: I've just thoroughly tested this PR as it currently is in Edge, and there is no sign of this bug SCRIPT70 in Wikimedia ZIMs. The only error I'm getting in the console is the one we get in other browsers about $ not being defined. But pages are all loading fine and fast in Edge with this PR.

In Stackexchange ZIMs I'm getting a lot of console errors relating to JavaScript being executed, I think (see screenshot), but none of them are SCRIPT70 and the page still loads correctly and looks fine, and all links work. In UWP context, I would have to neutralize the JavaScript because otherwise I will cause the app to hang, but this can be done in the Windows version only if it doesn't affect any other apps.

image

@Jaifroid
Copy link
Member Author

Actually, ignore all those script errors, they are caused by a completely unrelated issue switching between non-console use and opening the console. If I run the pages with the console open the whole time, the only error I'm getting on Edge from Stackexchange ZIMs relates to cross-site access for the font file, which I also get in Firefox.

In any case, I can safely answer that the document.write() bug with iframes in Edge is not being triggered by our code. This makes sense because we are only calling it once, then we empty the contentWindow before calling it again for a new document.

To avoid a potential race condition : if the browser is very fast to parse the content, it might be loaded before we set the onload event.
@Jaifroid
Copy link
Member Author

From testing in Edge and IE, far as I can tell, this PR is working fine with the exception of what I'd consider to be a blocker bug of not being able to open content on narrow screens/mobile devices.

How would you like to proceed? I would personally be a bit wary of merging a PR that has such a problem. It seems to me there are now two courses of action:

  1. Leave this PR unmerged until we can get Enable injection of javascript content coming from ZIM files in jQuery mode #152 working.

  2. Remove the "client-js" class (if any) from the html tag as a temporary workaround pending Enable injection of javascript content coming from ZIM files in jQuery mode #152 (and comment it as such in the code). This would, I believe, allow us to merge this PR.

Optionally I would also recommend including JavaScripts in the regex that currently replaces <img src=...> with <img data-kiwixsrc=...> in jQuery mode, as it prevents the browser launching a useless request for a file it won't be able to find. We will give the scripts a new src once we have extracted the JavaScript blob. It's a one-word addition to our current regex.

Copy link
Contributor

@mossroy mossroy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The sections can not be toggled in kiwix-js for now (in this branch as in the master branch).
It is indeed a real problem, but merging this PR does not make things worse.
It fixes a bug, and leaves the toggling issue as it was before.

On the other hand, as far as I understood, it does create a regression on UWP apps, where running the inline javascript can crash the app if the javascript dependencies are not loaded? Maybe this could be temporarily workarounded in kiwix-js-windows, by removing the onload/onclick attributes?

@mossroy
Copy link
Contributor

mossroy commented Apr 16, 2018

Let's talk on #355 about the workarounds or solutions to the toggling issue

@Jaifroid
Copy link
Member Author

Jaifroid commented Apr 16, 2018

OK, no need to worry about the regression in Kiwix JS Windows -- it is already worked around, as I discovered a long time ago that clicking on links in mobile-style ZIMs caused an app crash (not because of the document.write() code which is new here, but because the app attempts to run the inline onclick event). I had thought the issue was unique to UWP (which it is in a way, at least in so far as causing a crash, though some other systems do attempt to run the onclick code), so I hadn't at the time investigated it further or raised it as an issue here.

I'll squash/merge this branch and we can work on the other issues separately.

@Jaifroid
Copy link
Member Author

Merged to master.

@Jaifroid Jaifroid closed this Apr 16, 2018
@Jaifroid Jaifroid deleted the Use-articleContent.write()-instead-of-innerHTML branch April 16, 2018 21:50
@mossroy
Copy link
Contributor

mossroy commented Apr 17, 2018

Cool! Thanks a lot for this PR
I think it gives us a saner base to work on the other issues.

I suppose we can now close #341 , #347, and even #343 ?

@Jaifroid
Copy link
Member Author

Yes, I think all of those can be closed now. I didn't manage to do work on JavaScript at the w/e, but will have a go soon.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants