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(), {}); });