use dom_struct::dom_struct;
use js::rust::HandleObject;
use servo_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::{reflect_dom_object_with_proto, DomObject};
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 struct XRReferenceSpaceEvent {
event: Event,
space: Dom<XRReferenceSpace>,
transform: Option<Dom<XRRigidTransform>>,
}
impl XRReferenceSpaceEvent {
#[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 fn new(
global: &GlobalScope,
type_: Atom,
bubbles: bool,
cancelable: bool,
space: &XRReferenceSpace,
transform: Option<&XRRigidTransform>,
can_gc: CanGc,
) -> DomRoot<XRReferenceSpaceEvent> {
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<HandleObject>,
type_: Atom,
bubbles: bool,
cancelable: bool,
space: &XRReferenceSpace,
transform: Option<&XRRigidTransform>,
can_gc: CanGc,
) -> DomRoot<XRReferenceSpaceEvent> {
let trackevent = reflect_dom_object_with_proto(
Box::new(XRReferenceSpaceEvent::new_inherited(space, transform)),
global,
proto,
can_gc,
);
{
let event = trackevent.upcast::<Event>();
event.init_event(type_, bubbles, cancelable);
}
trackevent
}
}
impl XRReferenceSpaceEventMethods for XRReferenceSpaceEvent {
fn Constructor(
window: &Window,
proto: Option<HandleObject>,
can_gc: CanGc,
type_: DOMString,
init: &XRReferenceSpaceEventInit,
) -> Fallible<DomRoot<XRReferenceSpaceEvent>> {
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<XRReferenceSpace> {
DomRoot::from_ref(&*self.space)
}
fn GetTransform(&self) -> Option<DomRoot<XRRigidTransform>> {
self.transform
.as_ref()
.map(|transform| DomRoot::from_ref(&**transform))
}
fn IsTrusted(&self) -> bool {
self.event.IsTrusted()
}
}