Send history operations as asynchronous messages

Sending as sync message will cause weird results for
NavigationController
This commit is contained in:
Cheng Zhao 2015-05-11 16:03:25 +08:00
parent d1545a64ae
commit 82ffa4d2b1
3 changed files with 13 additions and 7 deletions

View file

@ -1,3 +1,9 @@
ipc = require 'ipc'
# The history operation in renderer is redirected to browser.
ipc.on 'ATOM_SHELL_NAVIGATION_CONTROLLER', (event, method, args...) ->
event.sender[method] args...
# JavaScript implementation of Chromium's NavigationController. # JavaScript implementation of Chromium's NavigationController.
# Instead of relying on Chromium for history control, we compeletely do history # Instead of relying on Chromium for history control, we compeletely do history
# control on user land, and only rely on WebContents.loadUrl for navigation. # control on user land, and only rely on WebContents.loadUrl for navigation.

View file

@ -29,7 +29,6 @@ module.exports.wrap = (webContents) ->
# The navigation controller. # The navigation controller.
controller = new NavigationController(webContents) controller = new NavigationController(webContents)
webContents.controller = controller
for name, method of NavigationController.prototype when method instanceof Function for name, method of NavigationController.prototype when method instanceof Function
do (name, method) -> do (name, method) ->
webContents[name] = -> method.apply controller, arguments webContents[name] = -> method.apply controller, arguments

View file

@ -74,15 +74,16 @@ window.confirm = (message, title='') ->
window.prompt = -> window.prompt = ->
throw new Error('prompt() is and will not be supported.') throw new Error('prompt() is and will not be supported.')
# Forward history operations to browser. # Simple implementation of postMessage.
window.history.back = ->
remote.getCurrentWebContents().goBack()
window.history.forward = ->
remote.getCurrentWebContents().goForward()
window.opener = window.opener =
postMessage: (message, targetOrigin='*') -> postMessage: (message, targetOrigin='*') ->
ipc.send 'ATOM_SHELL_GUEST_WINDOW_MANAGER_WINDOW_OPENER_POSTMESSAGE', message, targetOrigin ipc.send 'ATOM_SHELL_GUEST_WINDOW_MANAGER_WINDOW_OPENER_POSTMESSAGE', message, targetOrigin
ipc.on 'ATOM_SHELL_GUEST_WINDOW_POSTMESSAGE', (message, targetOrigin) -> ipc.on 'ATOM_SHELL_GUEST_WINDOW_POSTMESSAGE', (message, targetOrigin) ->
window.postMessage message, targetOrigin window.postMessage message, targetOrigin
# Forward history operations to browser.
sendHistoryOperation = (args...) ->
ipc.send 'ATOM_SHELL_NAVIGATION_CONTROLLER', args...
window.history.back = -> sendHistoryOperation 'goBack'
window.history.forward = -> sendHistoryOperation 'goForward'