Merge pull request #1730 from deepak1556/webview_navigation_patch
navigation: adding clearHistory method
This commit is contained in:
commit
cde6b41a05
7 changed files with 52 additions and 4 deletions
|
@ -4,6 +4,9 @@ ipc = require 'ipc'
|
||||||
ipc.on 'ATOM_SHELL_NAVIGATION_CONTROLLER', (event, method, args...) ->
|
ipc.on 'ATOM_SHELL_NAVIGATION_CONTROLLER', (event, method, args...) ->
|
||||||
event.sender[method] args...
|
event.sender[method] args...
|
||||||
|
|
||||||
|
ipc.on 'ATOM_SHELL_SYNC_NAVIGATION_CONTROLLER', (event, method, args...) ->
|
||||||
|
event.returnValue = 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.
|
||||||
|
@ -11,10 +14,7 @@ ipc.on 'ATOM_SHELL_NAVIGATION_CONTROLLER', (event, method, args...) ->
|
||||||
# process is restarted everytime.
|
# process is restarted everytime.
|
||||||
class NavigationController
|
class NavigationController
|
||||||
constructor: (@webContents) ->
|
constructor: (@webContents) ->
|
||||||
@history = []
|
@clearHistory()
|
||||||
@currentIndex = -1
|
|
||||||
@pendingIndex = -1
|
|
||||||
@inPageIndex = -1
|
|
||||||
|
|
||||||
@webContents.on 'navigation-entry-commited', (event, url, inPage, replaceEntry) =>
|
@webContents.on 'navigation-entry-commited', (event, url, inPage, replaceEntry) =>
|
||||||
if @inPageIndex > -1 and not inPage
|
if @inPageIndex > -1 and not inPage
|
||||||
|
@ -71,6 +71,12 @@ class NavigationController
|
||||||
canGoToOffset: (offset) ->
|
canGoToOffset: (offset) ->
|
||||||
@canGoToIndex @currentIndex + offset
|
@canGoToIndex @currentIndex + offset
|
||||||
|
|
||||||
|
clearHistory: ->
|
||||||
|
@history = []
|
||||||
|
@currentIndex = -1
|
||||||
|
@pendingIndex = -1
|
||||||
|
@inPageIndex = -1
|
||||||
|
|
||||||
goBack: ->
|
goBack: ->
|
||||||
return unless @canGoBack()
|
return unless @canGoBack()
|
||||||
@pendingIndex = @getActiveIndex() - 1
|
@pendingIndex = @getActiveIndex() - 1
|
||||||
|
@ -104,4 +110,7 @@ class NavigationController
|
||||||
getActiveIndex: ->
|
getActiveIndex: ->
|
||||||
if @pendingIndex is -1 then @currentIndex else @pendingIndex
|
if @pendingIndex is -1 then @currentIndex else @pendingIndex
|
||||||
|
|
||||||
|
length: ->
|
||||||
|
@history.length
|
||||||
|
|
||||||
module.exports = NavigationController
|
module.exports = NavigationController
|
||||||
|
|
|
@ -85,6 +85,13 @@ ipc.on 'ATOM_SHELL_GUEST_WINDOW_POSTMESSAGE', (message, targetOrigin) ->
|
||||||
# Forward history operations to browser.
|
# Forward history operations to browser.
|
||||||
sendHistoryOperation = (args...) ->
|
sendHistoryOperation = (args...) ->
|
||||||
ipc.send 'ATOM_SHELL_NAVIGATION_CONTROLLER', args...
|
ipc.send 'ATOM_SHELL_NAVIGATION_CONTROLLER', args...
|
||||||
|
|
||||||
|
getHistoryOperation = (args...) ->
|
||||||
|
ipc.sendSync 'ATOM_SHELL_SYNC_NAVIGATION_CONTROLLER', args...
|
||||||
|
|
||||||
window.history.back = -> sendHistoryOperation 'goBack'
|
window.history.back = -> sendHistoryOperation 'goBack'
|
||||||
window.history.forward = -> sendHistoryOperation 'goForward'
|
window.history.forward = -> sendHistoryOperation 'goForward'
|
||||||
window.history.go = (offset) -> sendHistoryOperation 'goToOffset', offset
|
window.history.go = (offset) -> sendHistoryOperation 'goToOffset', offset
|
||||||
|
Object.defineProperty window.history, 'length',
|
||||||
|
get: ->
|
||||||
|
getHistoryOperation 'length'
|
||||||
|
|
|
@ -244,6 +244,7 @@ registerWebViewElement = ->
|
||||||
"canGoBack"
|
"canGoBack"
|
||||||
"canGoForward"
|
"canGoForward"
|
||||||
"canGoToOffset"
|
"canGoToOffset"
|
||||||
|
"clearHistory"
|
||||||
"goBack"
|
"goBack"
|
||||||
"goForward"
|
"goForward"
|
||||||
"goToIndex"
|
"goToIndex"
|
||||||
|
|
|
@ -792,6 +792,10 @@ Returns whether the web page can go forward.
|
||||||
|
|
||||||
Returns whether the web page can go to `offset`.
|
Returns whether the web page can go to `offset`.
|
||||||
|
|
||||||
|
### WebContents.clearHistory()
|
||||||
|
|
||||||
|
Clears the navigation history.
|
||||||
|
|
||||||
### WebContents.goBack()
|
### WebContents.goBack()
|
||||||
|
|
||||||
Makes the web page go back.
|
Makes the web page go back.
|
||||||
|
|
|
@ -173,6 +173,10 @@ Returns whether guest page can go forward.
|
||||||
|
|
||||||
Returns whether guest page can go to `offset`.
|
Returns whether guest page can go to `offset`.
|
||||||
|
|
||||||
|
### `<webview>`.clearHistory()
|
||||||
|
|
||||||
|
Clears the navigation history.
|
||||||
|
|
||||||
### `<webview>`.goBack()
|
### `<webview>`.goBack()
|
||||||
|
|
||||||
Makes guest page go back.
|
Makes guest page go back.
|
||||||
|
|
8
spec/fixtures/pages/history.html
vendored
Normal file
8
spec/fixtures/pages/history.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<script type="text/javascript" charset="utf-8">
|
||||||
|
window.history.pushState(window.history.state, "test page", "foo.html")
|
||||||
|
require('ipc').sendToHost('history', window.history.length);
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -205,3 +205,18 @@ describe '<webview> tag', ->
|
||||||
webview.setAttribute 'nodeintegration', 'on'
|
webview.setAttribute 'nodeintegration', 'on'
|
||||||
webview.src = "file://#{fixtures}/pages/beforeunload-false.html"
|
webview.src = "file://#{fixtures}/pages/beforeunload-false.html"
|
||||||
document.body.appendChild webview
|
document.body.appendChild webview
|
||||||
|
|
||||||
|
describe '<webview>.clearHistory()', ->
|
||||||
|
it 'should clear the navigation history', (done) ->
|
||||||
|
listener = (e) ->
|
||||||
|
assert.equal e.channel, 'history'
|
||||||
|
assert.equal e.args[0], 2
|
||||||
|
assert webview.canGoBack()
|
||||||
|
webview.clearHistory()
|
||||||
|
assert not webview.canGoBack()
|
||||||
|
webview.removeEventListener 'ipc-message', listener
|
||||||
|
done()
|
||||||
|
webview.addEventListener 'ipc-message', listener
|
||||||
|
webview.setAttribute 'nodeintegration', 'on'
|
||||||
|
webview.src = "file://#{fixtures}/pages/history.html"
|
||||||
|
document.body.appendChild webview
|
||||||
|
|
Loading…
Reference in a new issue