aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom
diff options
context:
space:
mode:
Diffstat (limited to 'components/script/dom')
-rw-r--r--components/script/dom/history.rs5
-rw-r--r--components/script/dom/window.rs25
2 files changed, 28 insertions, 2 deletions
diff --git a/components/script/dom/history.rs b/components/script/dom/history.rs
index 369c59b524c..939cf9a8c20 100644
--- a/components/script/dom/history.rs
+++ b/components/script/dom/history.rs
@@ -85,7 +85,10 @@ impl History {
// Step 6
let hash_changed = old_url.fragment() != url.fragment();
- // TODO: Step 8 - scroll restoration
+ // Step 8
+ if let Some(fragment) = url.fragment() {
+ document.check_and_scroll_fragment(fragment);
+ }
// Step 11
let state_changed = state_id != self.state_id.get();
diff --git a/components/script/dom/window.rs b/components/script/dom/window.rs
index ea3a92e0f37..a26570edb1c 100644
--- a/components/script/dom/window.rs
+++ b/components/script/dom/window.rs
@@ -33,7 +33,10 @@ use dom::cssstyledeclaration::{CSSModificationAccess, CSSStyleDeclaration, CSSSt
use dom::customelementregistry::CustomElementRegistry;
use dom::document::{AnimationFrameCallback, Document};
use dom::element::Element;
+use dom::event::Event;
+use dom::eventtarget::EventTarget;
use dom::globalscope::GlobalScope;
+use dom::hashchangeevent::HashChangeEvent;
use dom::history::History;
use dom::location::Location;
use dom::mediaquerylist::{MediaQueryList, WeakMediaQueryListVec};
@@ -1582,13 +1585,33 @@ impl Window {
referrer_policy: Option<ReferrerPolicy>) {
let doc = self.Document();
let referrer_policy = referrer_policy.or(doc.get_referrer_policy());
-
// https://html.spec.whatwg.org/multipage/#navigating-across-documents
if !force_reload && url.as_url()[..Position::AfterQuery] ==
doc.url().as_url()[..Position::AfterQuery] {
// Step 6
if let Some(fragment) = url.fragment() {
+ self.send_to_constellation(ScriptMsg::NavigatedToFragment(url.clone(), replace));
doc.check_and_scroll_fragment(fragment);
+ let this = Trusted::new(self);
+ let old_url = doc.url().into_string();
+ let new_url = url.clone().into_string();
+ let task = task!(hashchange_event: move || {
+ let this = this.root();
+ let event = HashChangeEvent::new(
+ &this,
+ atom!("hashchange"),
+ false,
+ false,
+ old_url,
+ new_url);
+ event.upcast::<Event>().fire(this.upcast::<EventTarget>());
+ });
+ // FIXME(nox): Why are errors silenced here?
+ let _ = self.script_chan.send(CommonScriptMsg::Task(
+ ScriptThreadEventCategory::DomEvent,
+ Box::new(self.task_canceller(TaskSourceName::DOMManipulation).wrap_task(task)),
+ self.pipeline_id()
+ ));
doc.set_url(url.clone());
return
}