diff --git a/examples/historyState/historyState.js b/examples/historyState/historyState.js index 04b2816..b98cded 100644 --- a/examples/historyState/historyState.js +++ b/examples/historyState/historyState.js @@ -9,11 +9,13 @@ if (Meteor.isClient) { Template.hello.events({ 'submit #push': function(e, t) { e.preventDefault(); - Iron.Location.go('/' + Random.id(), {historyState: t.$('input').val()}); + var state = $(e.target).find('input').val(); + Iron.Location.go('/' + Random.id(), {historyState: state}); }, 'submit #replace': function(e, t) { e.preventDefault(); - console.log("Can't do this yet"); + var state = $(e.target).find('input').val(); + Iron.Location.replaceState(state); } }) } diff --git a/lib/location.js b/lib/location.js index b79d8b0..bf1a398 100644 --- a/lib/location.js +++ b/lib/location.js @@ -125,6 +125,21 @@ var onClickHandler = function (e) { throw err; } }; + +var replaceState = function(historyState) { + // XXX: should we throw / warn / do nothing here? + if (isUsingHashPaths()) + throw new Error("Can't replaceState when using hash paths"); + + var state = current; + if (EJSON.equals(state.options.historyState, historyState)) + return; + + state.options.historyState = historyState; + history.replaceState(historyState, null, state.url); + dep.changed(); +} + /*****************************************************************************/ /* Location API */ /*****************************************************************************/ @@ -232,6 +247,13 @@ Location.go = function (url, options) { return go(url, options); }; +/** + * Update the history.state for the given location + */ +Location.replaceState = function(historyState) { + return replaceState(historyState); +} + /** * Automatically start Iron.Location */