Send history operations as asynchronous messages
Sending as sync message will cause weird results for NavigationController
This commit is contained in:
parent
d1545a64ae
commit
82ffa4d2b1
3 changed files with 13 additions and 7 deletions
|
@ -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.
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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'
|
||||||
|
|
Loading…
Reference in a new issue