mirror of
https://github.com/videojs/video.js.git
synced 2025-01-08 07:00:10 +02:00
a8ff970d4a
Broke out bind, guid, and element data functions from Lib Separated out more dom functions in to dom.js Broke out URL functions into url.js Removed setLocalStorage since it wasn't being used Moved browser tests out of lib Moved log functions into their own file Removed trim() since it wasn't being used Moved formatTime into its own file Moved round into its own file and renamed roundFloat() Moved capitalize into its own file and renamed as toTitleCase() Moved createTimeRange into its own file Removed Lib.arr.forEach infavor of the native forEach Removed Lib.obj.create in favor of native Object.create (ES6-sham) Removed obj.each in favor of native Object.getOwnPropertyNames().forEach() Removed obj.merge and copy. Using lodash.assign instead. Replaced Lib.obj.isPlain with lodash.isPlainObject Removed Lib.obj.isArray in favor of the native Array.isArray Also removed the lib.js tests file as all tests have been moved or removed. Removed Lib.isEmpty in favor of !Object.getOwnPropertyNames().length Switched Util.mergeOptions and deepMerge to use new mergeOptions() Moved Lib.TEST_VID to Html5.TEST_VID Removed Lib references everywhere. Woo! Attempting to fix sourcemap test errors by setting grunt-browserify version Switched to object.assign from lodash.assign Removed unused 'inherits' dependency Reorganzied test files and added '.test' to file names Combined js/core.js and js/video.js Moved events.js into the utils directory
218 lines
8.1 KiB
JavaScript
218 lines
8.1 KiB
JavaScript
import TextTrackSettings from '../../../src/js/tracks/text-track-settings.js';
|
|
import TestHelpers from '../test-helpers.js';
|
|
import * as Events from '../../../src/js/utils/events.js';
|
|
import safeParseTuple from 'safe-json-parse/tuple';
|
|
import window from 'global/window';
|
|
|
|
var tracks = [{
|
|
kind: 'captions',
|
|
label: 'test'
|
|
}];
|
|
|
|
q.module('Text Track Settings', {
|
|
beforeEach: function() {
|
|
window.localStorage.clear();
|
|
}
|
|
});
|
|
|
|
test('should update settings', function() {
|
|
var player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: true
|
|
}),
|
|
newSettings = {
|
|
'backgroundOpacity': '1',
|
|
'textOpacity': '1',
|
|
'windowOpacity': '1',
|
|
'edgeStyle': 'raised',
|
|
'fontFamily': 'monospaceSerif',
|
|
'color': '#FFF',
|
|
'backgroundColor': '#FFF',
|
|
'windowColor': '#FFF',
|
|
'fontPercent': 1.25
|
|
};
|
|
|
|
player.textTrackSettings.setValues(newSettings);
|
|
deepEqual(player.textTrackSettings.getValues(), newSettings, 'values are updated');
|
|
|
|
equal(player.el().querySelector('.vjs-fg-color > select').selectedIndex, 1, 'fg-color is set to new value');
|
|
equal(player.el().querySelector('.vjs-bg-color > select').selectedIndex, 1, 'bg-color is set to new value');
|
|
equal(player.el().querySelector('.window-color > select').selectedIndex, 1, 'window-color is set to new value');
|
|
equal(player.el().querySelector('.vjs-text-opacity > select').selectedIndex, 1, 'text-opacity is set to new value');
|
|
equal(player.el().querySelector('.vjs-bg-opacity > select').selectedIndex, 1, 'bg-opacity is set to new value');
|
|
equal(player.el().querySelector('.vjs-window-opacity > select').selectedIndex, 1, 'window-opacity is set to new value');
|
|
equal(player.el().querySelector('.vjs-edge-style select').selectedIndex, 1, 'edge-style is set to new value');
|
|
equal(player.el().querySelector('.vjs-font-family select').selectedIndex, 1, 'font-family is set to new value');
|
|
equal(player.el().querySelector('.vjs-font-percent select').selectedIndex, 3, 'font-percent is set to new value');
|
|
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
deepEqual(safeParseTuple(window.localStorage.getItem('vjs-text-track-settings'))[1], newSettings, 'values are saved');
|
|
});
|
|
|
|
test('should restore default settings', function() {
|
|
var player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: true
|
|
});
|
|
|
|
player.el().querySelector('.vjs-fg-color > select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-bg-color > select').selectedIndex = 1;
|
|
player.el().querySelector('.window-color > select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-text-opacity > select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-bg-opacity > select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-window-opacity > select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-edge-style select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-font-family select').selectedIndex = 1;
|
|
player.el().querySelector('.vjs-font-percent select').selectedIndex = 3;
|
|
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
Events.trigger(player.el().querySelector('.vjs-default-button'), 'click');
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
|
|
deepEqual(player.textTrackSettings.getValues(), {}, 'values are defaulted');
|
|
deepEqual(window.localStorage.getItem('vjs-text-track-settings'), null, 'values are saved');
|
|
|
|
equal(player.el().querySelector('.vjs-fg-color > select').selectedIndex, 0, 'fg-color is set to default value');
|
|
equal(player.el().querySelector('.vjs-bg-color > select').selectedIndex, 0, 'bg-color is set to default value');
|
|
equal(player.el().querySelector('.window-color > select').selectedIndex, 0, 'window-color is set to default value');
|
|
equal(player.el().querySelector('.vjs-text-opacity > select').selectedIndex, 0, 'text-opacity is set to default value');
|
|
equal(player.el().querySelector('.vjs-bg-opacity > select').selectedIndex, 0, 'bg-opacity is set to default value');
|
|
equal(player.el().querySelector('.vjs-window-opacity > select').selectedIndex, 0, 'window-opacity is set to default value');
|
|
equal(player.el().querySelector('.vjs-edge-style select').selectedIndex, 0, 'edge-style is set to default value');
|
|
equal(player.el().querySelector('.vjs-font-family select').selectedIndex, 0, 'font-family is set to default value');
|
|
equal(player.el().querySelector('.vjs-font-percent select').selectedIndex, 2, 'font-percent is set to default value');
|
|
});
|
|
|
|
test('should open on click', function() {
|
|
var player = TestHelpers.makePlayer({
|
|
tracks: tracks
|
|
});
|
|
Events.trigger(player.el().querySelector('.vjs-texttrack-settings'), 'click');
|
|
ok(!player.textTrackSettings.hasClass('vjs-hidden'), 'settings open');
|
|
});
|
|
|
|
test('should close on done click', function() {
|
|
var player = TestHelpers.makePlayer({
|
|
tracks: tracks
|
|
});
|
|
Events.trigger(player.el().querySelector('.vjs-texttrack-settings'), 'click');
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
ok(player.textTrackSettings.hasClass('vjs-hidden'), 'settings closed');
|
|
});
|
|
|
|
test('if persist option is set, restore settings on init', function() {
|
|
var player,
|
|
oldRestoreSettings = TextTrackSettings.prototype.restoreSettings,
|
|
restore = 0;
|
|
|
|
TextTrackSettings.prototype.restoreSettings = function() {
|
|
restore++;
|
|
};
|
|
|
|
player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: true
|
|
});
|
|
|
|
equal(restore, 1, 'restore was called');
|
|
|
|
TextTrackSettings.prototype.restoreSettings = oldRestoreSettings;
|
|
});
|
|
|
|
test('if persist option is set, save settings when "done"', function() {
|
|
var player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: true
|
|
}),
|
|
oldSaveSettings = TextTrackSettings.prototype.saveSettings,
|
|
save = 0;
|
|
|
|
TextTrackSettings.prototype.saveSettings = function() {
|
|
save++;
|
|
};
|
|
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
|
|
equal(save, 1, 'save was called');
|
|
|
|
TextTrackSettings.prototype.saveSettings = oldSaveSettings;
|
|
});
|
|
|
|
test('do not try to restore or save settings if persist option is not set', function() {
|
|
var player,
|
|
oldRestoreSettings = TextTrackSettings.prototype.restoreSettings,
|
|
oldSaveSettings = TextTrackSettings.prototype.saveSettings,
|
|
save = 0,
|
|
restore = 0;
|
|
|
|
TextTrackSettings.prototype.restoreSettings = function() {
|
|
restore++;
|
|
};
|
|
TextTrackSettings.prototype.saveSettings = function() {
|
|
save++;
|
|
};
|
|
|
|
player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: false
|
|
});
|
|
|
|
equal(restore, 0, 'restore was not called');
|
|
|
|
Events.trigger(player.el().querySelector('.vjs-done-button'), 'click');
|
|
|
|
// saveSettings is called but does nothing
|
|
equal(save, 1, 'save was not called');
|
|
|
|
TextTrackSettings.prototype.saveSettings = oldSaveSettings;
|
|
TextTrackSettings.prototype.restoreSettings = oldRestoreSettings;
|
|
});
|
|
|
|
test('should restore saved settings', function() {
|
|
var player,
|
|
newSettings = {
|
|
'backgroundOpacity': '1',
|
|
'textOpacity': '1',
|
|
'windowOpacity': '1',
|
|
'edgeStyle': 'raised',
|
|
'fontFamily': 'monospaceSerif',
|
|
'color': '#FFF',
|
|
'backgroundColor': '#FFF',
|
|
'windowColor': '#FFF',
|
|
'fontPercent': 1.25
|
|
};
|
|
|
|
window.localStorage.setItem('vjs-text-track-settings', JSON.stringify(newSettings));
|
|
|
|
player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: true
|
|
});
|
|
|
|
deepEqual(player.textTrackSettings.getValues(), newSettings);
|
|
});
|
|
|
|
test('should not restore saved settings', function() {
|
|
var player,
|
|
newSettings = {
|
|
'backgroundOpacity': '1',
|
|
'textOpacity': '1',
|
|
'windowOpacity': '1',
|
|
'edgeStyle': 'raised',
|
|
'fontFamily': 'monospaceSerif',
|
|
'color': '#FFF',
|
|
'backgroundColor': '#FFF',
|
|
'windowColor': '#FFF',
|
|
'fontPercent': 1.25
|
|
};
|
|
|
|
window.localStorage.setItem('vjs-text-track-settings', JSON.stringify(newSettings));
|
|
|
|
player = TestHelpers.makePlayer({
|
|
tracks: tracks,
|
|
persistTextTrackSettings: false
|
|
});
|
|
|
|
deepEqual(player.textTrackSettings.getValues(), {});
|
|
});
|