use std::cell::Cell;
use dom_struct::dom_struct;
use crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::TextTrackCueBinding::TextTrackCueMethods;
use crate::dom::bindings::num::Finite;
use crate::dom::bindings::reflector::reflect_dom_object;
use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::DOMString;
use crate::dom::eventtarget::EventTarget;
use crate::dom::texttrack::TextTrack;
use crate::dom::window::Window;
#[dom_struct]
pub struct TextTrackCue {
eventtarget: EventTarget,
id: DomRefCell<DOMString>,
track: Option<Dom<TextTrack>>,
start_time: Cell<f64>,
end_time: Cell<f64>,
pause_on_exit: Cell<bool>,
}
impl TextTrackCue {
pub fn new_inherited(
id: DOMString,
start_time: f64,
end_time: f64,
track: Option<&TextTrack>,
) -> TextTrackCue {
TextTrackCue {
eventtarget: EventTarget::new_inherited(),
id: DomRefCell::new(id),
track: track.map(Dom::from_ref),
start_time: Cell::new(start_time),
end_time: Cell::new(end_time),
pause_on_exit: Cell::new(false),
}
}
#[allow(dead_code)]
pub fn new(
window: &Window,
id: DOMString,
start_time: f64,
end_time: f64,
track: Option<&TextTrack>,
) -> DomRoot<TextTrackCue> {
reflect_dom_object(
Box::new(TextTrackCue::new_inherited(id, start_time, end_time, track)),
window,
)
}
pub fn id(&self) -> DOMString {
self.id.borrow().clone()
}
pub fn get_track(&self) -> Option<DomRoot<TextTrack>> {
self.track.as_ref().map(|t| DomRoot::from_ref(&**t))
}
}
impl TextTrackCueMethods<crate::DomTypeHolder> for TextTrackCue {
fn Id(&self) -> DOMString {
self.id()
}
fn SetId(&self, value: DOMString) {
*self.id.borrow_mut() = value;
}
fn GetTrack(&self) -> Option<DomRoot<TextTrack>> {
self.get_track()
}
fn StartTime(&self) -> Finite<f64> {
Finite::wrap(self.start_time.get())
}
fn SetStartTime(&self, value: Finite<f64>) {
self.start_time.set(*value);
}
fn EndTime(&self) -> Finite<f64> {
Finite::wrap(self.end_time.get())
}
fn SetEndTime(&self, value: Finite<f64>) {
self.end_time.set(*value);
}
fn PauseOnExit(&self) -> bool {
self.pause_on_exit.get()
}
fn SetPauseOnExit(&self, value: bool) {
self.pause_on_exit.set(value);
}
event_handler!(enter, GetOnenter, SetOnenter);
event_handler!(exit, GetOnexit, SetOnexit);
}