-
Notifications
You must be signed in to change notification settings - Fork 141
swipemenu.js issues in Tablet OS 2.1 BETA #31
Comments
I can confirm this issue. Had swipemenu.js working fine and after the 2.1 Update it stopped working. |
Forums thread discussing this issue: |
I tracked this down to createSwipeMenu function, more specifically this line Guess from here it's out of my capacity to debug :) |
I just removed the "use strict" from swipemenu.js and everything works fine. |
I can't give you too much to go on. But I can replicate the issue. Just did a deploy with (sign + debug) and onSwipeDown gives no errors (no function calls either), but menu does not appear. If you hit the 'simulate bezel swipe' button the JS fires but the menu doesn't appear (console.log info): PB OS: 2.1.0.560 (p.s. as a test I installed the bbUI sample app and onSwipeDown works in that app) |
There is no problem with the swipedown event. |
Yup I know, just trying to give Adam all the details I can :) Adam - nunodonato has it the tip of the iceberg on this one. It isn't just that one re-assignment (rightButtons.style = style) I removed a lot of the re-assignments and it keeps finding me more to remove. It appears that any time you assign style = obj.style then work with it and assign it back obj.style = style it is choking because it thinks obj.style is readonly. The reason removing "use strict" 'fixes' it is because it is just failing silently without it. This is also why bbUI doesn't appear to be affected as it doesn't have 'use strict'. I just removed all the re-assignments and the swipe menu works fine again with "use strict" still in place. I know this is not an ideal solution as this was originally done to reduce the screen re-writes. |
Feedback from our browser folks: "style" is clearly defined as "read-only" here: http://trac.webkit.org/browser/trunk/Source/WebCore/dom/Element.idl They think this is an old bug that was finally fixed in WebKit. Bit of a surprise, but there it is. We will just need to identify the right way to do this and make a change. |
Is the purpose of this in and out of variables trick is to reduce redraws on the screen? My (maybe flawed) thought is this: if the elements have just been created and not yet attached to the DOM does it really cause a redraw? (my knowledge of this sort of manipulation is still budding) Could this step just be skipped on items that aren't attached to the DOM yet? |
Yes, the purpose of this technique is to reduce page repaints. However for newly create elements, this is not an issue so we can work around it for this. However, for live DOM content, I would like to explore what is now the most efficient way of making style changes like these. So swipemenu.js will have to be updated to adjust for the latest changes to WebKit. Style is a readonly property now. |
I'm working on fixing this today. Hoping to submit a pull request this afternoon. |
Hearing reports from developers that swipemenu.js is broken when run from within the Tablet OS 2.1 BETA.
I've just updated my device to the 2.1 BETA and re-ran the sample app included in the swipemenu.js project and did not see any problems.
If you are seeing issues, can you please report them here?
The text was updated successfully, but these errors were encountered: