Skip to content

Commit

Permalink
Merge pull request #15223 from courajs/stable-history-location
Browse files Browse the repository at this point in the history
[BUGFIX beta] Preserve current history state on app boot
  • Loading branch information
ef4 authored Dec 20, 2017
2 parents 71b688a + 2b7ab2a commit cacefee
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 1 deletion.
9 changes: 8 additions & 1 deletion packages/ember-routing/lib/location/history_location.js
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,14 @@ export default EmberObject.extend({
this.supportsHistory = true;
}

this.replaceState(this.formatURL(this.getURL()));
let state = this.getState();
let path = this.formatURL(this.getURL());
if (state && state.path === path) { // preserve existing state
// used for webkit workaround, since there will be no initial popstate event
this._previousURL = this.getURL();
} else {
this.replaceState(path);
}
},

/**
Expand Down
22 changes: 22 additions & 0 deletions packages/ember-routing/tests/location/history_location_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -304,3 +304,25 @@ QUnit.test('HistoryLocation.getURL() drops duplicate slashes', function() {

equal(location.getURL(), '/');
});

QUnit.test('Existing state is preserved on init', function() {
expect(1);

let existingState = {
path: '/route/path',
uuid: 'abcd'
};

FakeHistory.state = existingState;

HistoryTestLocation.reopen({
init() {
this._super(...arguments);
set(this, 'location', mockBrowserLocation('/route/path'));
}
});

createLocation();
location.initState();
deepEqual(location.getState(), existingState);
});

0 comments on commit cacefee

Please sign in to comment.