Redefine settings interface, write function to migrate some settings on update

This commit is contained in:
Tamius Han 2023-01-07 03:05:17 +01:00
parent 64bad6758b
commit d0ba619b45
3 changed files with 594 additions and 254 deletions

View File

@ -32,6 +32,12 @@ interface RestrictionsSettings {
onlyAllowAutodetectionInFullScreen?: boolean; // if enabled, autodetection will only start once in full screen onlyAllowAutodetectionInFullScreen?: boolean; // if enabled, autodetection will only start once in full screen
} }
interface ExtensionEnvironmentSettingsInterface {
normal: ExtensionMode,
theater: ExtensionMode,
fullscreen: ExtensionMode,
}
export interface CommandInterface { export interface CommandInterface {
action: string, action: string,
label: string, label: string,
@ -294,49 +300,112 @@ interface SettingsInterface {
// * disabled — never allow // * disabled — never allow
// //
sites: { sites: {
[x: string]: { [x: string]: SiteSettingsInterface,
defaultCrop?: any, // v6 new }
defaultStretch?: any, // v6 new // sites: {
// [x: string]: {
// defaultCrop?: any, // v6 new
// defaultStretch?: any, // v6 new
// enabled: ExtensionEnvironmentSettingsInterface, // v6 new
// enabledAard: ExtensionEnvironmentSettingsInterface,// v6 new
// everything 'superseded by' needs to be implemented // // everything 'superseded by' needs to be implemented
// as well as ported from the old settings // // as well as ported from the old settings
mode?: ExtensionMode, // v6 — superseded by defaultCrop // mode?: ExtensionMode, // v6 — superseded by looking at enableIn
autoar?: ExtensionMode, // v6 — superseded by defaultCrop // autoar?: ExtensionMode, // v6 — superseded by looking at enableIn
autoarFallback?: ExtensionMode, // v6 — deprecated, no replacement // autoarFallback?: ExtensionMode, // v6 — deprecated, no replacement
stretch?: StretchType, // v6 — superseded by defaultStretch // stretch?: StretchType, // v6 — superseded by defaultStretch
videoAlignment?: VideoAlignmentType, // videoAlignment?: VideoAlignmentType,
keyboardShortcutsEnabled?: ExtensionMode, // keyboardShortcutsEnabled?: ExtensionMode,
type?: string, // type?: string,
override?: boolean, // override?: boolean,
arPersistence?: boolean, // arPersistence?: boolean,
actions?: any; // actions?: any;
// cropModePersistence?: CropModePersistence;
// DOM?: {
// player?: {
// manual?: boolean,
// querySelectors?: string,
// additionalCss?: string,
// useRelativeAncestor?: boolean,
// videoAncestor?: any,
// playerNodeCss?: string,
// periodicallyRefreshPlayerElement?: boolean
// },
// video?: {
// manual?: boolean,
// querySelectors?: string,
// additionalCss?: string,
// useRelativeAncestor?: boolean,
// playerNodeCss?: string
// }
// },
// css?: string;
// usePlayerArInFullscreen?: boolean;
// restrictions?: RestrictionsSettings;
// }
// }
}
export interface SiteSettingsInterface {
enable: ExtensionEnvironmentSettingsInterface;
enableAard: ExtensionEnvironmentSettingsInterface;
enableKeyboard: ExtensionEnvironmentSettingsInterface;
type?: 'official' | 'community' | 'user-defined' | 'testing' | 'officially-disabled';
persistOption?: { // must be defined in @global and @empty
crop?: CropModePersistence,
stretch?: CropModePersistence,
alignment?: CropModePersistence
},
defaults?: { // must be defined in @global and @empty
crop?: {type: AspectRatioType, [x: string]: any},
stretch?: StretchType,
alignment?: any,
}
cropModePersistence?: CropModePersistence; cropModePersistence?: CropModePersistence;
stretchModePersistence?: CropModePersistence;
alignmentPersistence?: CropModePersistence;
DOM?: {
player?: {
manual?: boolean,
querySelectors?: string,
additionalCss?: string,
useRelativeAncestor?: boolean,
videoAncestor?: any,
playerNodeCss?: string,
periodicallyRefreshPlayerElement?: boolean
},
video?: {
manual?: boolean,
querySelectors?: string,
additionalCss?: string,
useRelativeAncestor?: boolean,
playerNodeCss?: string
}
},
css?: string;
usePlayerArInFullscreen?: boolean;
restrictions?: RestrictionsSettings; activeDOMConfig?: string;
} DOMConfig?: { [x: string]: SiteDOMSettingsInterface };
}
// the following script are for extension caching and shouldn't be saved.
// if they _are_ saved, they will be overwritten
currentDOMConfig?: SiteDOMSettingsInterface;
// the following fields are for use with extension update script
override?: boolean; // whether settings for this site will be overwritten by extension upgrade script
}
export interface SiteDOMSettingsInterface {
type: 'official' | 'community' | 'user-defined' | undefined;
elements?: {
player?: SiteDOMElementSettingsInterface,
video?: SiteDOMElementSettingsInterface,
other?: { [x: number]: SiteDOMElementSettingsInterface }
};
customCss?: string;
periodicallyRefreshPlayerElement?: boolean;
// the following script are for extension caching and shouldn't be saved.
// if they _are_ saved, they will be overwritten
anchorElementIndex?: number;
anchorElement?: HTMLElement;
}
export interface SiteDOMElementSettingsInterface {
manual?: boolean;
querySelectors?: string;
index?: number; // previously: useRelativeAncestor + videoAncestor
nodeCss?: {[x: string]: string};
} }
export default SettingsInterface; export default SettingsInterface;

View File

@ -5,6 +5,7 @@ import ExtensionMode from '../../common/enums/ExtensionMode.enum';
import VideoAlignmentType from '../../common/enums/VideoAlignmentType.enum'; import VideoAlignmentType from '../../common/enums/VideoAlignmentType.enum';
import BrowserDetect from './BrowserDetect'; import BrowserDetect from './BrowserDetect';
import SettingsInterface from '../../common/interfaces/SettingsInterface'; import SettingsInterface from '../../common/interfaces/SettingsInterface';
import { _cp } from '../../common/js/utils';
const ExtensionConfPatch = [ const ExtensionConfPatch = [
{ {
@ -128,6 +129,78 @@ const ExtensionConfPatch = [
// add new commands // add new commands
userOptions.commands = defaultOptions.commands; userOptions.commands = defaultOptions.commands;
} }
}, {
// NOTE - when releasing shit, ensure ALL alpha migrations are combined together in one function
forVersion: '6.0.0-alpha2',
updateFn: (userOptions, defaultOptions) => {
userOptions.commands = defaultOptions.commands;
// migrates old settings regarding whether extension is enabled or not
const copyEnabled = (site) => {
userOptions.sites[site].enable = {
fullscreen: userOptions.sites[site].mode,
theater: userOptions.sites[site].mode,
normal: ExtensionMode.Disabled
};
userOptions.sites[site].enableKeyboard = {
fullscreen: userOptions.sites[site].keyboardShortcutsEnabled,
theater: userOptions.sites[site].keyboardShortcutsEnabled,
normal: ExtensionMode.Disabled
};
userOptions.sites[site].enableAard = {
fullscreen: userOptions.sites[site].autoar,
theater: userOptions.sites[site].autoar,
normal: ExtensionMode.Disabled
};
userOptions.sites[site].stretchModePersistence = userOptions.sites[site].cropModePersistence;
// remove old options
delete userOptions.sites[site].mode;
delete userOptions.sites[site].keyboardShortcutsEnabled;
delete userOptions.sites[site].autoar;
}
// globals get carried over before other sites:
copyEnabled('@global');
// we make another guess about a new option we just added
for (const key in userOptions.sites) {
// we already had this
if (key === '@global') {
continue;
}
copyEnabled(key);
userOptions.sites[key].DOMConfig = _cp(defaultOptions.sites[key].DOMConfig)
// convert old site.DOM to site.DOMConfig[]
if (userOptions.sites[key].type === 'user-defined') {
const DOM = userOptions.sites[key].DOM;
if (DOM) {
userOptions.sites[key].DOMConfig['user-defined'] = {
type: 'user-1',
customCss: DOM?.css,
periodicallyRefreshPlayerElement: DOM?.player?.periodicallyRefreshPlayerElement,
elements: !(DOM?.player) ? undefined : {
player: {
manual: DOM?.player?.manual,
querySelectors: DOM?.player?.useRelativeAncestor ? undefined : DOM?.player?.querySelectors,
index: DOM?.player?.useRelativeAncestor ? DOM?.player?.videoAncestor : undefined,
}
}
}
userOptions.sites[key].activeDOMConfig = 'user-1';
// remove old configuration
delete userOptions.sites[key].DOM;
}
}
}
}
} }
]; ];

View File

@ -8,6 +8,7 @@ import AspectRatioType from '../../common/enums/AspectRatioType.enum';
import CropModePersistence from '../../common/enums/CropModePersistence.enum'; import CropModePersistence from '../../common/enums/CropModePersistence.enum';
import SettingsInterface from '../../common/interfaces/SettingsInterface'; import SettingsInterface from '../../common/interfaces/SettingsInterface';
import BrowserDetect from './BrowserDetect'; import BrowserDetect from './BrowserDetect';
import { Extension } from 'typescript';
if(Debug.debug) if(Debug.debug)
console.log("Loading: ExtensionConf.js"); console.log("Loading: ExtensionConf.js");
@ -1393,248 +1394,445 @@ const ExtensionConf: SettingsInterface = {
// to avoid writing this multiple times. Tags: // to avoid writing this multiple times. Tags:
// #g — only available in @global // #g — only available in @global
// #s — only available for specific site // #s — only available for specific site
mode: ExtensionMode.Enabled, // How should extension work: enable: { // How should extension work:
// 'enabled' - work everywhere except blacklist fullscreen: ExtensionMode.Enabled, // 'enabled' - work everywhere except blacklist
// 'whitelist' - only work on whitelisted sites (#g) theater: ExtensionMode.Enabled, // 'whitelist' - only work on whitelisted sites (#g)
// 'disabled' - work nowhere normal: ExtensionMode.Disabled, // 'disabled' - work nowhere
// 'basic' - (Possible future use) }, // 'default' - follow global rules (#s)
// 'default' - follow global rules (#s) enableAard: { // Should we try to automatically detect aspect ratio?
autoar: ExtensionMode.Enabled, // Should we try to automatically detect aspect ratio? fullscreen: ExtensionMode.Enabled, // Options: 'enabled', 'whitelist' (#g), 'default' (#s), 'disabled'
// Options: 'enabled', 'whitelist' (#g), 'default' (#s), 'disabled' theater: ExtensionMode.Enabled,
autoarFallback: currentBrowser.firefox ? // if autoAr fails, try fallback mode? normal: ExtensionMode.Disabled,
ExtensionMode.Enabled : // Options same as in autoar. },
ExtensionMode.Disabled, // if autoar is disabled, this setting is irrelevant enableKeyboard: {
stretch: StretchType.NoStretch, // Default stretch mode. fullscreen: ExtensionMode.Enabled,
videoAlignment: VideoAlignmentType.Center, // Video alignment theater: ExtensionMode.Enabled,
keyboardShortcutsEnabled: ExtensionMode.Enabled, normal: ExtensionMode.Disabled
},
persistOption: {
crop: CropModePersistence.Disabled,
stretch: CropModePersistence.Disabled,
alignment: CropModePersistence.Disabled,
},
defaults: {
crop: {type: AspectRatioType.Reset}, // does NOT override Aard
stretch: StretchType.NoStretch,
}
},
"@empty": { // placeholder settings object with fallbacks to @global
enable: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'user-defined',
persistOption: {
crop: CropModePersistence.Default,
stretch: CropModePersistence.Default,
alignment: CropModePersistence.Default,
},
defaults: {
crop: null,
stretch: StretchType.Default,
}
}, },
"www.youtube.com" : { "www.youtube.com" : {
mode: ExtensionMode.Enabled, enable: {
autoar: ExtensionMode.Enabled, fullscreen: ExtensionMode.Default,
autoarFallback: ExtensionMode.Enabled, theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
override: false, // ignore value localStorage in favour of this override: false, // ignore value localStorage in favour of this
type: 'official', // is officially supported? (Alternatives are 'community' and 'user-defined') type: 'official', // is officially supported? (Alternatives are 'community' and 'user-defined')
actions: null, // overrides global keyboard shortcuts and button configs. Is array, is optional.
stretch: StretchType.Default, activeDOMConfig: 'official',
videoAlignment: VideoAlignmentType.Default, DOMConfig: {
keyboardShortcutsEnabled: ExtensionMode.Default, 'official': {
DOM: { type: 'official',
elements: {
player: { player: {
manual: true, manual: true,
querySelectors: "#movie_player, #player, #c4-player", querySelectors: "#movie_player, #player, #c4-player",
additionalCss: "", }
useRelativeAncestor: false, }
playerNodeCss: "",
} }
} }
}, },
"www.netflix.com" : { "www.netflix.com" : {
mode: ExtensionMode.Enabled, enable: {
autoar: ExtensionMode.Enabled, fullscreen: ExtensionMode.Default,
override: false, theater: ExtensionMode.Default,
type: 'official', normal: ExtensionMode.Default,
stretch: StretchType.Default, },
videoAlignment: VideoAlignmentType.Default, enableAard: {
keyboardShortcutsEnabled: ExtensionMode.Default, fullscreen: ExtensionMode.Default,
arPersistence: true, // persist aspect ratio between different videos theater: ExtensionMode.Default,
DOM: { normal: ExtensionMode.Default,
player: { },
manual: false, // as of 2021-09, netflix no longer requires manual player class. This may change in the future tho. enableKeyboard: {
} fullscreen: ExtensionMode.Default,
} theater: ExtensionMode.Default,
normal: ExtensionMode.Disabled
}, },
"www.disneyplus.com" : {
mode: ExtensionMode.Enabled,
autoar: ExtensionMode.Enabled,
override: false, override: false,
type: 'community', type: 'community',
stretch: StretchType.Default, },
videoAlignment: VideoAlignmentType.Default, "www.disneyplus.com" : {
keyboardShortcutsEnabled: ExtensionMode.Default, enable: {
arPersistence: true, // persist aspect ratio between different videos fullscreen: ExtensionMode.Default,
DOM: { theater: ExtensionMode.Default,
"player": { normal: ExtensionMode.Default,
"manual": true, },
"querySelectors": ".btm-media-client-element", enableAard: {
"additionalCss": "", fullscreen: ExtensionMode.Default,
"useRelativeAncestor": false, theater: ExtensionMode.Default,
"videoAncestor": 1, normal: ExtensionMode.Default,
"playerNodeCss": "" },
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'community',
activeDOMConfig: 'community-mstefan99',
DOMConfig: {
'community-mstefan99': {
type: 'official',
elements: {
player: {
manual: true,
querySelectors: ".btm-media-player",
},
video: {
manual: true,
querySelectors: ".btm-media-client-element"
} }
}, },
css: ".hudson-container { height: 100%; }", customCss: ".hudson-container { height: 100%; }"
}
}
}, },
"www.twitch.tv": { "www.twitch.tv": {
mode: ExtensionMode.Enabled, enable: {
autoar: ExtensionMode.Enabled, fullscreen: ExtensionMode.Default,
override: true, theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'official', type: 'official',
stretch: StretchType.Default,
videoAlignment: VideoAlignmentType.Default,
keyboardShortcutsEnabled: ExtensionMode.Default,
DOM: {
player: {
manual: false,
querySelectors: "",
additionalCss: "",
useRelativeAncestor: false,
playerNodeCss: ""
}
}
}, },
"streamable.com": { "streamable.com": {
mode: 3, enable: {
autoar: 3, fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'official', type: 'official',
stretch: -1, activeDOMConfig: 'official',
videoAlignment: -1, DOMConfig: {
keyboardShortcutsEnabled: 0, 'official': {
css: ".player {text-align: left}" type: 'official',
customCss: ".player {text-align: left}"
}
}
}, },
"vimeo.com": { "vimeo.com": {
mode: 3, enable: {
autoar: 3, fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'official', type: 'official',
stretch: -1, activeDOMConfig: 'official',
videoAlignment: -1, DOMConfig: {
keyboardShortcutsEnabled: 0, 'official': {
DOM: { type: 'official',
customCss: ".player_outro_area {\n width: 100% !important;\n display: flex !important;\n justify-content: center !important;\n}\n\n.player_container, .player {\n width: 100% !important; \n}",
elements: {
player: { player: {
manual: true, manual: true,
querySelectors: ".player_outro_area", querySelectors: ".player_outro_area",
useRelativeAncestor: false, }
}
}
}, },
}, },
css: ".player_outro_area {\n width: 100% !important;\n display: flex !important;\n justify-content: center !important;\n}\n\n.player_container, .player {\n width: 100% !important; \n}"
},
"old.reddit.com" : { "old.reddit.com" : {
mode: ExtensionMode.Enabled, enable: {
autoar:ExtensionMode.Enabled, fullscreen: ExtensionMode.Disabled,
override: false, theater: ExtensionMode.Disabled,
type: 'testing', normal: ExtensionMode.Disabled,
stretch: StretchType.Default, },
videoAlignment: VideoAlignmentType.Default, enableAard: {
keyboardShortcutsEnabled: ExtensionMode.Default, fullscreen: ExtensionMode.Disabled,
DOM: { theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
enableKeyboard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
type: 'officially-disabled',
activeDOMConfig: 'official',
DOMConfig: {
'official': {
type: 'official',
customCss: 'video {\n width: 100% !important;\n height: 100% !important;\n}',
elements: {
player: { player: {
manual: false, manual: false,
useRelativeAncestor: false,
querySelectors: '.reddit-video-player-root, .media-preview-content' querySelectors: '.reddit-video-player-root, .media-preview-content'
} }
}
}
}, },
css: 'video {\n width: 100% !important;\n height: 100% !important;\n}',
}, },
"www.reddit.com" : { "www.reddit.com" : {
mode: ExtensionMode.Enabled, enable: {
autoar: ExtensionMode.Enabled, fullscreen: ExtensionMode.Disabled,
override: false, theater: ExtensionMode.Disabled,
type: 'testing', normal: ExtensionMode.Disabled,
stretch: StretchType.Default, },
videoAlignment: VideoAlignmentType.Default, enableAard: {
keyboardShortcutsEnabled: ExtensionMode.Default, fullscreen: ExtensionMode.Disabled,
DOM: { theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
enableKeyboard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
type: 'officially-disabled',
activeDOMConfig: 'official',
DOMConfig: {
'official': {
type: 'official',
customCss: 'video {\n width: 100% !important;\n height: 100% !important;\n}',
elements: {
player: { player: {
manual: false, manual: false,
useRelativeAncestor: false,
querySelectors: '.reddit-video-player-root, .media-preview-content' querySelectors: '.reddit-video-player-root, .media-preview-content'
} }
}
}
}, },
css: 'video {\n width: 100% !important;\n height: 100% !important;\n}',
}, },
"imgur.com": { "imgur.com": {
mode: -1, enable: {
autoar: -1, fullscreen: ExtensionMode.Disabled,
autoarFallback: 0, theater: ExtensionMode.Disabled,
stretch: -1, normal: ExtensionMode.Disabled,
videoAlignment: 1, },
type: 'official', enableAard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
enableKeyboard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
type: 'officially-disabled',
}, },
"gfycat.com": { "gfycat.com": {
mode: -1, enable: {
autoar: -1, fullscreen: ExtensionMode.Disabled,
autoarFallback: 0, theater: ExtensionMode.Disabled,
stretch: -1, normal: ExtensionMode.Disabled,
videoAlignment: 1, },
type: 'official,' enableAard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
enableKeyboard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
type: 'officially-disabled',
}, },
"giant.gfycat.com": { "giant.gfycat.com": {
mode: -1, enable: {
autoar: -1, fullscreen: ExtensionMode.Disabled,
autoarFallback: 0, theater: ExtensionMode.Disabled,
stretch: -1, normal: ExtensionMode.Disabled,
videoAlignment: 1, },
type: 'official', enableAard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
enableKeyboard: {
fullscreen: ExtensionMode.Disabled,
theater: ExtensionMode.Disabled,
normal: ExtensionMode.Disabled,
},
type: 'officially-disabled',
}, },
"www.wakanim.tv": { "www.wakanim.tv": {
enable: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'community', type: 'community',
DOM: { activeDOMConfig: 'community',
DOMConfig: {
'community': {
type: 'community',
elements: {
player: { player: {
manual: true, manual: true,
querySelectors: "#jwplayer-container", querySelectors: "#jwplayer-container"
additionalCss: "",
useRelativeAncestor: false,
playerNodeCss: "",
} }
} }
}
},
}, },
"app.plex.tv": { "app.plex.tv": {
mode: 3, enable: {
autoar: 3, fullscreen: ExtensionMode.Default,
type: "community", theater: ExtensionMode.Default,
stretch: -1, normal: ExtensionMode.Default,
videoAlignment: -1,
keyboardShortcutsEnabled: 0,
DOM: {
player: {
manual: false,
querySelectors: "",
additionalCss: "",
useRelativeAncestor: false,
playerNodeCss: ""
}
}, },
css: "body {\n background-color: #000;\n}\n\n.application {\n background-color: #000;\n}" enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: 'community',
activeDOMConfig: 'community',
DOMConfig: {
'community': {
type: 'community',
customCss: "body {\n background-color: #000;\n}\n\n.application {\n background-color: #000;\n}"
}
}
}, },
"metaivi.com": { "metaivi.com": {
mode: 0, enable: {
autoar: 0, fullscreen: ExtensionMode.Default,
type: "community", theater: ExtensionMode.Default,
stretch: -1, normal: ExtensionMode.Default,
videoAlignment: -1,
DOM: {
video: {
manual: false,
querySelectors: "",
additionalCss: "position: absolute !important;"
}, },
player: { enableAard: {
manual: false, fullscreen: ExtensionMode.Default,
querySelectors: "", theater: ExtensionMode.Default,
additionalCss: "", normal: ExtensionMode.Default,
useRelativeAncestor: false, },
playerNodeCss: "" enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: "community",
activeDOMConfig: 'community',
DOMConfig: {
'community': {
type: 'community',
elements: {
video: {
nodeCss: {'position': 'absolute !important'}
}
}
} }
}, },
"css": ""
}, },
"piped.kavin.rocks": { "piped.kavin.rocks": {
mode: 0, enable: {
autoar: 0, fullscreen: ExtensionMode.Default,
type: 'community', theater: ExtensionMode.Default,
autoarFallback: 0, normal: ExtensionMode.Default,
stretch: 0,
videoAlignment: -1,
keyboardShortcutsEnabled: 0,
DOM: {
player: {
manual: false,
querySelectors: "",
additionalCss: "",
useRelativeAncestor: false,
playerNodeCss: ""
}
}, },
css: ".shaka-video-container {\n flex-direction: column !important;\n}" enableAard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default,
},
enableKeyboard: {
fullscreen: ExtensionMode.Default,
theater: ExtensionMode.Default,
normal: ExtensionMode.Default
},
type: "community",
activeDOMConfig: 'community',
DOMConfig: {
'community': {
type: 'community',
customCss: ".shaka-video-container {\n flex-direction: column !important;\n}"
}
}
}, },
} }
} }