/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ use dom_struct::dom_struct; use js::rust::HandleObject; use stylo_atoms::Atom; use crate::dom::bindings::codegen::Bindings::EventBinding::Event_Binding::EventMethods; use crate::dom::bindings::codegen::Bindings::XRReferenceSpaceEventBinding::{ XRReferenceSpaceEventInit, XRReferenceSpaceEventMethods, }; use crate::dom::bindings::error::Fallible; use crate::dom::bindings::inheritance::Castable; use crate::dom::bindings::reflector::{DomGlobal, reflect_dom_object_with_proto}; use crate::dom::bindings::root::{Dom, DomRoot}; use crate::dom::bindings::str::DOMString; use crate::dom::event::Event; use crate::dom::globalscope::GlobalScope; use crate::dom::window::Window; use crate::dom::xrreferencespace::XRReferenceSpace; use crate::dom::xrrigidtransform::XRRigidTransform; use crate::script_runtime::CanGc; #[dom_struct] pub(crate) struct XRReferenceSpaceEvent { event: Event, space: Dom, transform: Option>, } impl XRReferenceSpaceEvent { #[cfg_attr(crown, allow(crown::unrooted_must_root))] fn new_inherited( space: &XRReferenceSpace, transform: Option<&XRRigidTransform>, ) -> XRReferenceSpaceEvent { XRReferenceSpaceEvent { event: Event::new_inherited(), space: Dom::from_ref(space), transform: transform.map(Dom::from_ref), } } pub(crate) fn new( global: &GlobalScope, type_: Atom, bubbles: bool, cancelable: bool, space: &XRReferenceSpace, transform: Option<&XRRigidTransform>, can_gc: CanGc, ) -> DomRoot { Self::new_with_proto( global, None, type_, bubbles, cancelable, space, transform, can_gc, ) } #[allow(clippy::too_many_arguments)] fn new_with_proto( global: &GlobalScope, proto: Option, type_: Atom, bubbles: bool, cancelable: bool, space: &XRReferenceSpace, transform: Option<&XRRigidTransform>, can_gc: CanGc, ) -> DomRoot { let trackevent = reflect_dom_object_with_proto( Box::new(XRReferenceSpaceEvent::new_inherited(space, transform)), global, proto, can_gc, ); { let event = trackevent.upcast::(); event.init_event(type_, bubbles, cancelable); } trackevent } } impl XRReferenceSpaceEventMethods for XRReferenceSpaceEvent { /// fn Constructor( window: &Window, proto: Option, can_gc: CanGc, type_: DOMString, init: &XRReferenceSpaceEventInit, ) -> Fallible> { Ok(XRReferenceSpaceEvent::new_with_proto( &window.global(), proto, Atom::from(type_), init.parent.bubbles, init.parent.cancelable, &init.referenceSpace, init.transform.as_deref(), can_gc, )) } /// fn ReferenceSpace(&self) -> DomRoot { DomRoot::from_ref(&*self.space) } /// fn GetTransform(&self) -> Option> { self.transform .as_ref() .map(|transform| DomRoot::from_ref(&**transform)) } /// fn IsTrusted(&self) -> bool { self.event.IsTrusted() } }