aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/audiotracklist.rs
diff options
context:
space:
mode:
authoryvt <i@yvt.jp>2021-07-10 17:24:27 +0900
committeryvt <i@yvt.jp>2021-07-10 17:55:42 +0900
commit01a7de50ab1843d85295f9dccad7f4c099e7208c (patch)
treeee53fb6e8889deb7b880ee969e6c662e6128d210 /components/script/dom/audiotracklist.rs
parentff8d2cdbbfc7a9dc7f38b7dd47cb350fde39388f (diff)
parent94b613fbdaa2b98f2179fc0bbda13c64e6fa0d38 (diff)
downloadservo-01a7de50ab1843d85295f9dccad7f4c099e7208c.tar.gz
servo-01a7de50ab1843d85295f9dccad7f4c099e7208c.zip
Merge remote-tracking branch 'upstream/master' into feat-cow-infra
`tests/wpt/web-platform-tests/html/browsers/origin/cross-origin-objects/cross-origin-objects.html` was reverted to the upstream version.
Diffstat (limited to 'components/script/dom/audiotracklist.rs')
-rw-r--r--components/script/dom/audiotracklist.rs146
1 files changed, 146 insertions, 0 deletions
diff --git a/components/script/dom/audiotracklist.rs b/components/script/dom/audiotracklist.rs
new file mode 100644
index 00000000000..6a7fd3b4ebb
--- /dev/null
+++ b/components/script/dom/audiotracklist.rs
@@ -0,0 +1,146 @@
+/* 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::audiotrack::AudioTrack;
+use crate::dom::bindings::cell::DomRefCell;
+use crate::dom::bindings::codegen::Bindings::AudioTrackListBinding::AudioTrackListMethods;
+use crate::dom::bindings::inheritance::Castable;
+use crate::dom::bindings::refcounted::Trusted;
+use crate::dom::bindings::reflector::{reflect_dom_object, DomObject};
+use crate::dom::bindings::root::{Dom, DomRoot};
+use crate::dom::bindings::str::DOMString;
+use crate::dom::eventtarget::EventTarget;
+use crate::dom::htmlmediaelement::HTMLMediaElement;
+use crate::dom::window::Window;
+use crate::task_source::TaskSource;
+use dom_struct::dom_struct;
+
+#[dom_struct]
+pub struct AudioTrackList {
+ eventtarget: EventTarget,
+ tracks: DomRefCell<Vec<Dom<AudioTrack>>>,
+ media_element: Option<Dom<HTMLMediaElement>>,
+}
+
+impl AudioTrackList {
+ pub fn new_inherited(
+ tracks: &[&AudioTrack],
+ media_element: Option<&HTMLMediaElement>,
+ ) -> AudioTrackList {
+ AudioTrackList {
+ eventtarget: EventTarget::new_inherited(),
+ tracks: DomRefCell::new(tracks.iter().map(|track| Dom::from_ref(&**track)).collect()),
+ media_element: media_element.map(|m| Dom::from_ref(m)),
+ }
+ }
+
+ pub fn new(
+ window: &Window,
+ tracks: &[&AudioTrack],
+ media_element: Option<&HTMLMediaElement>,
+ ) -> DomRoot<AudioTrackList> {
+ reflect_dom_object(
+ Box::new(AudioTrackList::new_inherited(tracks, media_element)),
+ window,
+ )
+ }
+
+ pub fn len(&self) -> usize {
+ self.tracks.borrow().len()
+ }
+
+ pub fn find(&self, track: &AudioTrack) -> Option<usize> {
+ self.tracks.borrow().iter().position(|t| &**t == track)
+ }
+
+ pub fn item(&self, idx: usize) -> Option<DomRoot<AudioTrack>> {
+ self.tracks
+ .borrow()
+ .get(idx)
+ .map(|track| DomRoot::from_ref(&**track))
+ }
+
+ pub fn enabled_index(&self) -> Option<usize> {
+ self.tracks
+ .borrow()
+ .iter()
+ .position(|track| track.enabled())
+ }
+
+ pub fn set_enabled(&self, idx: usize, value: bool) {
+ let track = match self.item(idx) {
+ Some(t) => t,
+ None => return,
+ };
+
+ // If the chosen tracks enabled status is the same as the new status, return early.
+ if track.enabled() == value {
+ return;
+ }
+ // Set the tracks enabled status.
+ track.set_enabled(value);
+ if let Some(media_element) = self.media_element.as_ref() {
+ media_element.set_audio_track(idx, value);
+ }
+
+ // Queue a task to fire an event named change.
+ let global = &self.global();
+ let this = Trusted::new(self);
+ let (source, canceller) = global
+ .as_window()
+ .task_manager()
+ .media_element_task_source_with_canceller();
+
+ let _ = source.queue_with_canceller(
+ task!(media_track_change: move || {
+ let this = this.root();
+ this.upcast::<EventTarget>().fire_event(atom!("change"));
+ }),
+ &canceller,
+ );
+ }
+
+ pub fn add(&self, track: &AudioTrack) {
+ self.tracks.borrow_mut().push(Dom::from_ref(track));
+ track.add_track_list(self);
+ }
+
+ pub fn clear(&self) {
+ self.tracks
+ .borrow()
+ .iter()
+ .for_each(|t| t.remove_track_list());
+ self.tracks.borrow_mut().clear();
+ }
+}
+
+impl AudioTrackListMethods for AudioTrackList {
+ // https://html.spec.whatwg.org/multipage/#dom-audiotracklist-length
+ fn Length(&self) -> u32 {
+ self.len() as u32
+ }
+
+ // https://html.spec.whatwg.org/multipage/#dom-tracklist-item
+ fn IndexedGetter(&self, idx: u32) -> Option<DomRoot<AudioTrack>> {
+ self.item(idx as usize)
+ }
+
+ // https://html.spec.whatwg.org/multipage/#dom-audiotracklist-gettrackbyid
+ fn GetTrackById(&self, id: DOMString) -> Option<DomRoot<AudioTrack>> {
+ self.tracks
+ .borrow()
+ .iter()
+ .find(|track| track.id() == id)
+ .map(|track| DomRoot::from_ref(&**track))
+ }
+
+ // https://html.spec.whatwg.org/multipage/#handler-tracklist-onchange
+ event_handler!(change, GetOnchange, SetOnchange);
+
+ // https://html.spec.whatwg.org/multipage/#handler-tracklist-onaddtrack
+ event_handler!(addtrack, GetOnaddtrack, SetOnaddtrack);
+
+ // https://html.spec.whatwg.org/multipage/#handler-tracklist-onremovetrack
+ event_handler!(removetrack, GetOnremovetrack, SetOnremovetrack);
+}