Skip to content

Commit

Permalink
feat: Add an Audio Description icon to an audio track name in the tra…
Browse files Browse the repository at this point in the history
…ck menu if it is "main-desc" kind. (#4599)
  • Loading branch information
OwenEdwards authored and gkatsev committed Jul 9, 2018
1 parent 89f6397 commit efcfc84
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 0 deletions.
14 changes: 14 additions & 0 deletions src/css/components/_audio.scss
Original file line number Diff line number Diff line change
@@ -1,3 +1,17 @@
.video-js .vjs-audio-button .vjs-icon-placeholder {
@extend .vjs-icon-audio;
}

.video-js .vjs-audio-button + .vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder {
vertical-align: middle;
display: inline-block;
margin-bottom: -0.1em;
}

// Mark a main-desc-menu-item (main + description) item with a trailing Audio Description icon
.video-js .vjs-audio-button + .vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before {
font-family: VideoJS;
content: " \f11d";
font-size: 1.5em;
line-height: inherit;
}
22 changes: 22 additions & 0 deletions src/js/control-bar/audio-track-controls/audio-track-menu-item.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
*/
import MenuItem from '../../menu/menu-item.js';
import Component from '../../component.js';
import {assign} from '../../utils/obj';

/**
* An {@link AudioTrack} {@link MenuItem}
Expand Down Expand Up @@ -32,6 +33,8 @@ class AudioTrackMenuItem extends MenuItem {

this.track = track;

this.addClass(`vjs-${track.kind}-menu-item`);

const changeHandler = (...args) => {
this.handleTracksChange.apply(this, args);
};
Expand All @@ -42,6 +45,25 @@ class AudioTrackMenuItem extends MenuItem {
});
}

createEl(type, props, attrs) {
let innerHTML = `<span class="vjs-menu-item-text">${this.localize(this.options_.label)}`;

if (this.options_.track.kind === 'main-desc') {
innerHTML += `
<span aria-hidden="true" class="vjs-icon-placeholder"></span>
<span class="vjs-control-text"> ${this.localize('Descriptions')}</span>
`;
}

innerHTML += '</span>';

const el = super.createEl(type, assign({
innerHTML
}, props), attrs);

return el;
}

/**
* This gets called when an `AudioTrackMenuItem is "clicked". See {@link ClickableComponent}
* for more detailed information on what a click can be.
Expand Down

0 comments on commit efcfc84

Please sign in to comment.