use dom_struct::dom_struct;
use crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::TextTrackCueListBinding::TextTrackCueListMethods;
use crate::dom::bindings::reflector::{reflect_dom_object, Reflector};
use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::DOMString;
use crate::dom::texttrackcue::TextTrackCue;
use crate::dom::window::Window;
use crate::script_runtime::CanGc;
#[dom_struct]
pub struct TextTrackCueList {
reflector_: Reflector,
dom_cues: DomRefCell<Vec<Dom<TextTrackCue>>>,
}
impl TextTrackCueList {
pub fn new_inherited(cues: &[&TextTrackCue]) -> TextTrackCueList {
TextTrackCueList {
reflector_: Reflector::new(),
dom_cues: DomRefCell::new(cues.iter().map(|g| Dom::from_ref(&**g)).collect()),
}
}
pub fn new(window: &Window, cues: &[&TextTrackCue]) -> DomRoot<TextTrackCueList> {
reflect_dom_object(
Box::new(TextTrackCueList::new_inherited(cues)),
window,
CanGc::note(),
)
}
pub fn item(&self, idx: usize) -> Option<DomRoot<TextTrackCue>> {
self.dom_cues
.borrow()
.get(idx)
.map(|t| DomRoot::from_ref(&**t))
}
pub fn find(&self, cue: &TextTrackCue) -> Option<usize> {
self.dom_cues
.borrow()
.iter()
.enumerate()
.find(|(_, c)| **c == cue)
.map(|(i, _)| i)
}
pub fn add(&self, cue: &TextTrackCue) {
if self.find(cue).is_none() {
self.dom_cues.borrow_mut().push(Dom::from_ref(cue));
}
}
pub fn remove(&self, idx: usize) {
self.dom_cues.borrow_mut().remove(idx);
}
}
impl TextTrackCueListMethods<crate::DomTypeHolder> for TextTrackCueList {
fn Length(&self) -> u32 {
self.dom_cues.borrow().len() as u32
}
fn IndexedGetter(&self, idx: u32) -> Option<DomRoot<TextTrackCue>> {
self.item(idx as usize)
}
fn GetCueById(&self, id: DOMString) -> Option<DomRoot<TextTrackCue>> {
if id.is_empty() {
None
} else {
self.dom_cues
.borrow()
.iter()
.find(|cue| cue.id() == id)
.map(|t| DomRoot::from_ref(&**t))
}
}
}