1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
/* 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 crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::TextTrackListBinding::{self, TextTrackListMethods};
use crate::dom::bindings::inheritance::Castable;
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;
use dom_struct::dom_struct;
#[dom_struct]
pub struct TextTrackList {
eventtarget: EventTarget,
dom_tracks: DomRefCell<Vec<Dom<TextTrack>>>,
}
impl TextTrackList {
pub fn new_inherited(tracks: &[&TextTrack]) -> TextTrackList {
TextTrackList {
eventtarget: EventTarget::new_inherited(),
dom_tracks: DomRefCell::new(tracks.iter().map(|g| Dom::from_ref(&**g)).collect()),
}
}
pub fn new(window: &Window, tracks: &[&TextTrack]) -> DomRoot<TextTrackList> {
reflect_dom_object(
Box::new(TextTrackList::new_inherited(tracks)),
window,
TextTrackListBinding::Wrap,
)
}
pub fn item(&self, idx: usize) -> Option<DomRoot<TextTrack>> {
self.dom_tracks
.borrow()
.get(idx as usize)
.map(|t| DomRoot::from_ref(&**t))
}
pub fn find(&self, track: &TextTrack) -> Option<usize> {
self.dom_tracks
.borrow()
.iter()
.enumerate()
.filter(|(_, t)| **t == track)
.next()
.map(|(i, _)| i)
}
pub fn add(&self, track: &TextTrack) {
// Only add a track if it does not exist in the list
if self.find(track).is_none() {
self.dom_tracks.borrow_mut().push(Dom::from_ref(track));
};
self.upcast::<EventTarget>().fire_event(atom!("addtrack"));
}
// FIXME(#22314, dlrobertson) allow TextTracks to be
// removed from the TextTrackList.
#[allow(dead_code)]
pub fn remove(&self, idx: usize) {
self.dom_tracks.borrow_mut().remove(idx);
self.upcast::<EventTarget>()
.fire_event(atom!("removetrack"));
}
}
impl TextTrackListMethods for TextTrackList {
// https://html.spec.whatwg.org/multipage/#dom-texttracklist-length
fn Length(&self) -> u32 {
self.dom_tracks.borrow().len() as u32
}
// https://html.spec.whatwg.org/multipage/#dom-texttracklist-item
fn IndexedGetter(&self, idx: u32) -> Option<DomRoot<TextTrack>> {
self.item(idx as usize)
}
// https://html.spec.whatwg.org/multipage/#dom-texttracklist-gettrackbyid
fn GetTrackById(&self, id: DOMString) -> Option<DomRoot<TextTrack>> {
let id_str = String::from(id.clone());
self.dom_tracks
.borrow()
.iter()
.filter(|track| track.id() == &id_str)
.next()
.map(|t| DomRoot::from_ref(&**t))
}
// https://html.spec.whatwg.org/multipage/#handler-texttracklist-onchange
event_handler!(onchange, GetOnchange, SetOnchange);
// https://html.spec.whatwg.org/multipage/#handler-texttracklist-onaddtrack
event_handler!(onaddtrack, GetOnaddtrack, SetOnaddtrack);
// https://html.spec.whatwg.org/multipage/#handler-texttracklist-onremovetrack
event_handler!(onremovetrack, GetOnremovetrack, SetOnremovetrack);
}
|