use dom_struct::dom_struct;
use js::rust::HandleObject;
use servo_atoms::Atom;
use crate::dom::bindings::codegen::Bindings::EventBinding::EventMethods;
use crate::dom::bindings::codegen::Bindings::RTCErrorEventBinding::{
RTCErrorEventInit, RTCErrorEventMethods,
};
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::rtcerror::RTCError;
use crate::dom::window::Window;
use crate::script_runtime::CanGc;
#[dom_struct]
pub struct RTCErrorEvent {
event: Event,
error: Dom<RTCError>,
}
impl RTCErrorEvent {
fn new_inherited(error: &RTCError) -> RTCErrorEvent {
RTCErrorEvent {
event: Event::new_inherited(),
error: Dom::from_ref(error),
}
}
pub fn new(
global: &GlobalScope,
type_: Atom,
bubbles: bool,
cancelable: bool,
error: &RTCError,
) -> DomRoot<RTCErrorEvent> {
Self::new_with_proto(
global,
None,
type_,
bubbles,
cancelable,
error,
CanGc::note(),
)
}
fn new_with_proto(
global: &GlobalScope,
proto: Option<HandleObject>,
type_: Atom,
bubbles: bool,
cancelable: bool,
error: &RTCError,
can_gc: CanGc,
) -> DomRoot<RTCErrorEvent> {
let event = reflect_dom_object_with_proto(
Box::new(RTCErrorEvent::new_inherited(error)),
global,
proto,
can_gc,
);
{
let event = event.upcast::<Event>();
event.init_event(type_, bubbles, cancelable);
}
event
}
}
impl RTCErrorEventMethods for RTCErrorEvent {
fn Constructor(
window: &Window,
proto: Option<HandleObject>,
can_gc: CanGc,
type_: DOMString,
init: &RTCErrorEventInit,
) -> DomRoot<RTCErrorEvent> {
RTCErrorEvent::new_with_proto(
&window.global(),
proto,
Atom::from(type_),
init.parent.bubbles,
init.parent.cancelable,
&init.error,
can_gc,
)
}
fn Error(&self) -> DomRoot<RTCError> {
DomRoot::from_ref(&*self.error)
}
fn IsTrusted(&self) -> bool {
self.event.IsTrusted()
}
}