Site and extension options: done
This commit is contained in:
parent
8b1da27af7
commit
42cdcd5c25
@ -355,7 +355,8 @@ export interface SiteSettingsInterface {
|
|||||||
enableAard: ExtensionEnvironmentSettingsInterface;
|
enableAard: ExtensionEnvironmentSettingsInterface;
|
||||||
enableKeyboard: ExtensionEnvironmentSettingsInterface;
|
enableKeyboard: ExtensionEnvironmentSettingsInterface;
|
||||||
|
|
||||||
type?: 'official' | 'community' | 'user-defined' | 'testing' | 'officially-disabled';
|
type?: 'official' | 'community' | 'user-defined' | 'testing' | 'officially-disabled' | 'unknown' | 'modified';
|
||||||
|
defaultType: 'official' | 'community' | 'user-defined' | 'testing' | 'officially-disabled' | 'unknown' | 'modified';
|
||||||
|
|
||||||
// must be defined in @global and @empty
|
// must be defined in @global and @empty
|
||||||
persistCSA?: CropModePersistence, // CSA - crop, stretch, alignment
|
persistCSA?: CropModePersistence, // CSA - crop, stretch, alignment
|
||||||
|
@ -389,3 +389,8 @@ small {
|
|||||||
.monospace {
|
.monospace {
|
||||||
font-family: 'Overpass Mono';
|
font-family: 'Overpass Mono';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.pointer {
|
||||||
|
cursor: pointer;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
@ -267,7 +267,7 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
&.community {
|
&.community {
|
||||||
background-color: rgb(47, 47, 97);
|
background-color: rgb(85, 85, 179);
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
|
||||||
.mdi {
|
.mdi {
|
||||||
|
@ -48,6 +48,13 @@
|
|||||||
></SiteExtensionSettings>
|
></SiteExtensionSettings>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<template v-if="tab === 'otherSites'">
|
||||||
|
<OtherSiteSettings
|
||||||
|
v-if="settings"
|
||||||
|
:settings="settings"
|
||||||
|
>
|
||||||
|
</OtherSiteSettings>
|
||||||
|
</template>
|
||||||
<!-- <SiteSettingsBasicTable
|
<!-- <SiteSettingsBasicTable
|
||||||
:settings="settings"
|
:settings="settings"
|
||||||
></SiteSettingsBasicTable> -->
|
></SiteSettingsBasicTable> -->
|
||||||
@ -56,8 +63,9 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import SiteSettingsBasicTable from './PanelComponents/ExtensionSettings/SiteSettingsBasicTable.vue'
|
import SiteSettingsBasicTable from './PanelComponents/ExtensionSettings/SiteSettingsBasicTable.vue';
|
||||||
import SiteExtensionSettings from './PanelComponents/ExtensionSettings/SiteExtensionSettings.vue'
|
import SiteExtensionSettings from './PanelComponents/ExtensionSettings/SiteExtensionSettings.vue';
|
||||||
|
import OtherSiteSettings from './PanelComponents/ExtensionSettings/OtherSiteSettings.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
@ -74,7 +82,8 @@ export default {
|
|||||||
],
|
],
|
||||||
components: {
|
components: {
|
||||||
SiteExtensionSettings,
|
SiteExtensionSettings,
|
||||||
SiteSettingsBasicTable
|
SiteSettingsBasicTable,
|
||||||
|
OtherSiteSettings
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
globalSettings() {
|
globalSettings() {
|
||||||
|
@ -0,0 +1,122 @@
|
|||||||
|
<template>
|
||||||
|
<div class="">
|
||||||
|
<template v-if="!selectedSite">
|
||||||
|
<div style="margin-top: 1rem; margin-bottom: 1rem;">
|
||||||
|
<b>NOTE:</b> Sites not on this list use default extension settings.
|
||||||
|
</div>
|
||||||
|
<div v-for="site of sites" :key="site.key" @click="selectedSite = site.key" class="flex flex-column container pointer" style="margin-top: 4px; padding: 0.5rem 1rem;">
|
||||||
|
<div class="flex flex-row">
|
||||||
|
<div class="flex-grow pointer">
|
||||||
|
<b>{{ site.key }}</b>
|
||||||
|
<span :style="getSiteTypeColor(site.type)">
|
||||||
|
(config: {{site.type ?? 'unknown'}})
|
||||||
|
</span></div>
|
||||||
|
<div>Edit</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-row">
|
||||||
|
<small>
|
||||||
|
Enabled: <span :style="getSiteEnabledColor(site.key, 'enable')"><small>{{ getSiteEnabledModes(site.key, 'enable') }}</small></span>;
|
||||||
|
Aard <span :style="getSiteEnabledColor(site.key, 'enableAard')"><small>{{ getSiteEnabledModes(site.key, 'enableAard') }}</small></span>;
|
||||||
|
kbd: <span :style="getSiteEnabledColor(site.key, 'enableKeyboard')"><small>{{ getSiteEnabledModes(site.key, 'enableKeyboard') }}</small></span>
|
||||||
|
</small>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<template v-if="selectedSite">
|
||||||
|
<div class="flex flex-row container" style="align-items: center; color: #dedede; margin-top: 1rem;">
|
||||||
|
<div @click="selectedSite = null" class="pointer button-hover" style=" font-size: 2em; padding: 0.5rem; margin-right: 1em;">
|
||||||
|
←
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
Editing {{ selectedSite }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<SiteExtensionSettings
|
||||||
|
v-if="selectedSiteSettings"
|
||||||
|
:settings="settings"
|
||||||
|
:siteSettings="selectedSiteSettings"
|
||||||
|
:isDefaultConfiguration="false"
|
||||||
|
></SiteExtensionSettings>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import ExtensionMode from '../../../../../common/enums/ExtensionMode.enum';
|
||||||
|
import SiteExtensionSettings from './SiteExtensionSettings.vue';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
selectedSite: null,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
props: [
|
||||||
|
'settings',
|
||||||
|
],
|
||||||
|
components: {
|
||||||
|
SiteExtensionSettings,
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
sites() {
|
||||||
|
if (!this.settings?.active?.sites) {
|
||||||
|
return [];
|
||||||
|
} else {
|
||||||
|
const sites = [];
|
||||||
|
for (const siteKey in this.settings.active.sites) {
|
||||||
|
if (!siteKey.startsWith('@')) {
|
||||||
|
sites.push({
|
||||||
|
key: siteKey,
|
||||||
|
...this.settings.active.sites[siteKey]
|
||||||
|
})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
sites.sort((a, b) => {
|
||||||
|
const cmpa = a.key.replace('www.', '');
|
||||||
|
const cmpb = b.key.replace('www.', '');
|
||||||
|
|
||||||
|
return cmpa < cmpb ? -1 : 1;
|
||||||
|
});
|
||||||
|
return sites;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
selectedSiteSettings() {
|
||||||
|
return this.settings?.getSiteSettings(this.selectedSite) ?? null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getSiteTypeColor(siteType) {
|
||||||
|
switch (siteType) {
|
||||||
|
case 'official': return 'color: #fa6';
|
||||||
|
case 'community': return 'color: rgb(114, 114, 218)';
|
||||||
|
case 'officially-disabled': return 'color: #f00';
|
||||||
|
case 'testing': return 'color: #d81';
|
||||||
|
default: return 'color: rgb(138, 65, 126)'
|
||||||
|
};
|
||||||
|
},
|
||||||
|
getSiteEnabledColor(site, component) {
|
||||||
|
const status = this.getSiteEnabledModes(site, component);
|
||||||
|
|
||||||
|
return status === 'disabled' ? 'color: #f00' : 'color: #1f8';
|
||||||
|
},
|
||||||
|
getSiteEnabledModes(site, component) {
|
||||||
|
if (this.settings?.getSiteSettings(site).data[component]?.normal === ExtensionMode.Enabled) {
|
||||||
|
return 'always';
|
||||||
|
}
|
||||||
|
if (this.settings?.getSiteSettings(site).data[component]?.theater === ExtensionMode.Enabled) {
|
||||||
|
return 'T + FS';
|
||||||
|
}
|
||||||
|
if (this.settings?.getSiteSettings(site).data[component]?.fullscreen === ExtensionMode.Enabled) {
|
||||||
|
return 'fullscreen';
|
||||||
|
}
|
||||||
|
return 'disabled';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" src="../../../../../res/css/flex.scss" scoped></style>
|
||||||
|
<style lang="scss" src="../../../res-common/panels.scss" scoped></style>
|
||||||
|
<style lang="scss" src="../../../res-common/common.scss" scoped></style>
|
@ -408,8 +408,6 @@ export default {
|
|||||||
setExtensionMode(component, event) {
|
setExtensionMode(component, event) {
|
||||||
const option = event.target.value;
|
const option = event.target.value;
|
||||||
|
|
||||||
console.log('setting option', component, 'to', event.target.value);
|
|
||||||
|
|
||||||
if (option === 'complex') {
|
if (option === 'complex') {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -458,3 +456,8 @@ export default {
|
|||||||
<style lang="scss" src="../../../../../res/css/flex.scss" scoped></style>
|
<style lang="scss" src="../../../../../res/css/flex.scss" scoped></style>
|
||||||
<style lang="scss" src="../../../res-common/panels.scss" scoped></style>
|
<style lang="scss" src="../../../res-common/panels.scss" scoped></style>
|
||||||
<style lang="scss" src="../../../res-common/common.scss" scoped></style>
|
<style lang="scss" src="../../../res-common/common.scss" scoped></style>
|
||||||
|
<style scoped>
|
||||||
|
.button-hover:hover {
|
||||||
|
color: #fa6;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -150,3 +150,8 @@ h1, h2, h3 {
|
|||||||
padding: 0.25rem 0.5rem;
|
padding: 0.25rem 0.5rem;
|
||||||
padding-top: 0.5rem;
|
padding-top: 0.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.pointer {
|
||||||
|
cursor: pointer;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
@ -20,3 +20,7 @@
|
|||||||
background-color:rgba(0, 0, 0, 0.75)
|
background-color:rgba(0, 0, 0, 0.75)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
background-color: rgba(0, 0, 0, 0.5);
|
||||||
|
}
|
||||||
|
@ -264,6 +264,15 @@ const ExtensionConfPatch = [
|
|||||||
}
|
}
|
||||||
userOptions.sites['@empty'].defaults.alignment = {x: VideoAlignmentType.Default, y: VideoAlignmentType.Default};
|
userOptions.sites['@empty'].defaults.alignment = {x: VideoAlignmentType.Default, y: VideoAlignmentType.Default};
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
forVersion: '5.99.6',
|
||||||
|
updateFn: (userOptions: SettingsInterface, defaultOptions) => {
|
||||||
|
for (const site in userOptions.sites) {
|
||||||
|
userOptions.sites[site].defaultType = userOptions.sites[site].type as any;
|
||||||
|
}
|
||||||
|
userOptions.sites['@global'].defaultType = 'unknown';
|
||||||
|
userOptions.sites['@empty'].defaultType = 'modified';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -1441,7 +1441,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
theater: ExtensionMode.Enabled,
|
theater: ExtensionMode.Enabled,
|
||||||
normal: ExtensionMode.Disabled
|
normal: ExtensionMode.Disabled
|
||||||
},
|
},
|
||||||
|
defaultType: 'unknown',
|
||||||
persistCSA: CropModePersistence.Disabled,
|
persistCSA: CropModePersistence.Disabled,
|
||||||
|
|
||||||
defaults: {
|
defaults: {
|
||||||
@ -1467,6 +1467,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'user-defined',
|
type: 'user-defined',
|
||||||
|
defaultType: 'user-defined',
|
||||||
persistCSA: CropModePersistence.Default,
|
persistCSA: CropModePersistence.Default,
|
||||||
defaults: {
|
defaults: {
|
||||||
crop: null,
|
crop: null,
|
||||||
@ -1492,6 +1493,8 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
},
|
},
|
||||||
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')
|
||||||
|
defaultType: 'official', // if user mucks around with settings, type changes to 'user-defined'.
|
||||||
|
// We still want to know what the original type was, hence defaultType
|
||||||
|
|
||||||
activeDOMConfig: 'official',
|
activeDOMConfig: 'official',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
@ -1524,6 +1527,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
},
|
},
|
||||||
override: false,
|
override: false,
|
||||||
type: 'community',
|
type: 'community',
|
||||||
|
defaultType: 'community',
|
||||||
},
|
},
|
||||||
"www.disneyplus.com" : {
|
"www.disneyplus.com" : {
|
||||||
enable: {
|
enable: {
|
||||||
@ -1542,6 +1546,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'community',
|
type: 'community',
|
||||||
|
defaultType: 'community',
|
||||||
activeDOMConfig: 'community-mstefan99',
|
activeDOMConfig: 'community-mstefan99',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'community-mstefan99': {
|
'community-mstefan99': {
|
||||||
@ -1577,32 +1582,34 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'official',
|
type: 'official',
|
||||||
|
defaultType: 'official',
|
||||||
},
|
},
|
||||||
"streamable.com": {
|
// "streamable.com": {
|
||||||
enable: {
|
// enable: {
|
||||||
fullscreen: ExtensionMode.Default,
|
// fullscreen: ExtensionMode.Default,
|
||||||
theater: ExtensionMode.Default,
|
// theater: ExtensionMode.Default,
|
||||||
normal: ExtensionMode.Default,
|
// normal: ExtensionMode.Default,
|
||||||
},
|
// },
|
||||||
enableAard: {
|
// enableAard: {
|
||||||
fullscreen: ExtensionMode.Default,
|
// fullscreen: ExtensionMode.Default,
|
||||||
theater: ExtensionMode.Default,
|
// theater: ExtensionMode.Default,
|
||||||
normal: ExtensionMode.Default,
|
// normal: ExtensionMode.Default,
|
||||||
},
|
// },
|
||||||
enableKeyboard: {
|
// enableKeyboard: {
|
||||||
fullscreen: ExtensionMode.Default,
|
// fullscreen: ExtensionMode.Default,
|
||||||
theater: ExtensionMode.Default,
|
// theater: ExtensionMode.Default,
|
||||||
normal: ExtensionMode.Default
|
// normal: ExtensionMode.Default
|
||||||
},
|
// },
|
||||||
type: 'official',
|
// type: 'official',
|
||||||
activeDOMConfig: 'official',
|
// type: 'defaultType',
|
||||||
DOMConfig: {
|
// activeDOMConfig: 'official',
|
||||||
'official': {
|
// DOMConfig: {
|
||||||
type: 'official',
|
// 'official': {
|
||||||
customCss: ".player {text-align: left}"
|
// type: 'official',
|
||||||
}
|
// customCss: ".player {text-align: left}"
|
||||||
}
|
// }
|
||||||
},
|
// }
|
||||||
|
// },
|
||||||
"vimeo.com": {
|
"vimeo.com": {
|
||||||
enable: {
|
enable: {
|
||||||
fullscreen: ExtensionMode.Default,
|
fullscreen: ExtensionMode.Default,
|
||||||
@ -1620,6 +1627,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'official',
|
type: 'official',
|
||||||
|
defaultType: 'official',
|
||||||
activeDOMConfig: 'official',
|
activeDOMConfig: 'official',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'official': {
|
'official': {
|
||||||
@ -1651,6 +1659,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Disabled,
|
normal: ExtensionMode.Disabled,
|
||||||
},
|
},
|
||||||
type: 'officially-disabled',
|
type: 'officially-disabled',
|
||||||
|
defaultType: 'officially-disabled',
|
||||||
activeDOMConfig: 'official',
|
activeDOMConfig: 'official',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'official': {
|
'official': {
|
||||||
@ -1682,6 +1691,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Disabled,
|
normal: ExtensionMode.Disabled,
|
||||||
},
|
},
|
||||||
type: 'officially-disabled',
|
type: 'officially-disabled',
|
||||||
|
defaultType: 'officially-disabled',
|
||||||
activeDOMConfig: 'official',
|
activeDOMConfig: 'official',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'official': {
|
'official': {
|
||||||
@ -1713,6 +1723,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Disabled,
|
normal: ExtensionMode.Disabled,
|
||||||
},
|
},
|
||||||
type: 'officially-disabled',
|
type: 'officially-disabled',
|
||||||
|
defaultType: 'officially-disabled',
|
||||||
},
|
},
|
||||||
"gfycat.com": {
|
"gfycat.com": {
|
||||||
enable: {
|
enable: {
|
||||||
@ -1731,6 +1742,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Disabled,
|
normal: ExtensionMode.Disabled,
|
||||||
},
|
},
|
||||||
type: 'officially-disabled',
|
type: 'officially-disabled',
|
||||||
|
defaultType: 'officially-disabled',
|
||||||
},
|
},
|
||||||
"giant.gfycat.com": {
|
"giant.gfycat.com": {
|
||||||
enable: {
|
enable: {
|
||||||
@ -1749,6 +1761,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Disabled,
|
normal: ExtensionMode.Disabled,
|
||||||
},
|
},
|
||||||
type: 'officially-disabled',
|
type: 'officially-disabled',
|
||||||
|
defaultType: 'officially-disabled',
|
||||||
},
|
},
|
||||||
"www.wakanim.tv": {
|
"www.wakanim.tv": {
|
||||||
enable: {
|
enable: {
|
||||||
@ -1767,6 +1780,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'community',
|
type: 'community',
|
||||||
|
defaultType: 'community',
|
||||||
activeDOMConfig: 'community',
|
activeDOMConfig: 'community',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'community': {
|
'community': {
|
||||||
@ -1797,6 +1811,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: 'community',
|
type: 'community',
|
||||||
|
defaultType: 'community',
|
||||||
activeDOMConfig: 'community',
|
activeDOMConfig: 'community',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'community': {
|
'community': {
|
||||||
@ -1822,6 +1837,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: "community",
|
type: "community",
|
||||||
|
defaultType: "community",
|
||||||
activeDOMConfig: 'community',
|
activeDOMConfig: 'community',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'community': {
|
'community': {
|
||||||
@ -1851,6 +1867,7 @@ const ExtensionConf: SettingsInterface = {
|
|||||||
normal: ExtensionMode.Default
|
normal: ExtensionMode.Default
|
||||||
},
|
},
|
||||||
type: "community",
|
type: "community",
|
||||||
|
defaultType: "community",
|
||||||
activeDOMConfig: 'community',
|
activeDOMConfig: 'community',
|
||||||
DOMConfig: {
|
DOMConfig: {
|
||||||
'community': {
|
'community': {
|
||||||
|
@ -80,7 +80,6 @@ export class SiteSettings {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for (const enableSegment of ['enable', 'enableAard', 'enableKeyboard']) {
|
for (const enableSegment of ['enable', 'enableAard', 'enableKeyboard']) {
|
||||||
if (!this.data[enableSegment]) {
|
if (!this.data[enableSegment]) {
|
||||||
this.data[enableSegment] = {};
|
this.data[enableSegment] = {};
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
"manifest_version": 3,
|
"manifest_version": 3,
|
||||||
"name": "Ultrawidify",
|
"name": "Ultrawidify",
|
||||||
"description": "Removes black bars on ultrawide videos and offers advanced options to fix aspect ratio.",
|
"description": "Removes black bars on ultrawide videos and offers advanced options to fix aspect ratio.",
|
||||||
"version": "5.99.5",
|
"version": "5.99.6",
|
||||||
"icons": {
|
"icons": {
|
||||||
"32":"res/icons/uw-32.png",
|
"32":"res/icons/uw-32.png",
|
||||||
"64":"res/icons/uw-64.png"
|
"64":"res/icons/uw-64.png"
|
||||||
|
Loading…
Reference in New Issue
Block a user