mirror of
https://github.com/an-anime-team/an-anime-game-launcher.git
synced 2024-12-24 02:28:15 +03:00
Settings menu improvements
- added voice selection - added theme selection - added discrod rpc toggle - added hud selection - added gamemode, fps unlocker and dxvk logs auto-deletion options - default settings were moved to a separate file - dxvk list now shows installed and active dxvk - added `DXVK.current` field
This commit is contained in:
parent
8937a8eba9
commit
342eeadbfd
9 changed files with 324 additions and 53 deletions
|
@ -22,7 +22,7 @@
|
||||||
"fullScreen": false,
|
"fullScreen": false,
|
||||||
"alwaysOnTop": false,
|
"alwaysOnTop": false,
|
||||||
"icon": "/public/icons/64x64.png",
|
"icon": "/public/icons/64x64.png",
|
||||||
"enableInspector": true,
|
"enableInspector": false,
|
||||||
"borderless": false,
|
"borderless": false,
|
||||||
"maximize": false,
|
"maximize": false,
|
||||||
"hidden": true,
|
"hidden": true,
|
||||||
|
|
|
@ -5,10 +5,49 @@ settings:
|
||||||
items:
|
items:
|
||||||
# Language selection
|
# Language selection
|
||||||
lang:
|
lang:
|
||||||
|
# Launcher language
|
||||||
launcher:
|
launcher:
|
||||||
title: Launcher
|
title: Launcher
|
||||||
items:
|
items:
|
||||||
en-us: English (US)
|
en-us: English (US)
|
||||||
ru-ru: Русский
|
ru-ru: Русский
|
||||||
|
|
||||||
dxvks: DXVK
|
# Game voice pack language
|
||||||
|
voice:
|
||||||
|
title: Voice pack
|
||||||
|
items:
|
||||||
|
en-us: English (US)
|
||||||
|
ja-jp: Japanese
|
||||||
|
ko-kr: Korean
|
||||||
|
zn-cn: Chinese
|
||||||
|
|
||||||
|
# Launcher theme
|
||||||
|
theme:
|
||||||
|
title: Theme
|
||||||
|
items:
|
||||||
|
system: System
|
||||||
|
light: Light
|
||||||
|
dark: Dark
|
||||||
|
|
||||||
|
discord: Discord RPC
|
||||||
|
dxvks: DXVK
|
||||||
|
|
||||||
|
# Enhancements
|
||||||
|
enhancements:
|
||||||
|
title: Enhancements
|
||||||
|
items:
|
||||||
|
# HUD
|
||||||
|
hud:
|
||||||
|
title: HUD
|
||||||
|
items:
|
||||||
|
none: None
|
||||||
|
dxvk: DXVK
|
||||||
|
mangohud: MangoHUD
|
||||||
|
|
||||||
|
gamemode: GameMode
|
||||||
|
fps_unlocker: Unlock FPS
|
||||||
|
purge_dxvk_logs: Auto-delete DXVK logs
|
||||||
|
|
||||||
|
# DXVKs
|
||||||
|
dxvks:
|
||||||
|
title: DXVK
|
|
@ -5,10 +5,50 @@ settings:
|
||||||
items:
|
items:
|
||||||
# Выбор языка
|
# Выбор языка
|
||||||
lang:
|
lang:
|
||||||
|
# Лаунчер
|
||||||
launcher:
|
launcher:
|
||||||
title: Лаунчер
|
title: Лаунчер
|
||||||
items:
|
items:
|
||||||
en-us: English (US)
|
en-us: English (US)
|
||||||
ru-ru: Русский
|
ru-ru: Русский
|
||||||
|
|
||||||
dxvks: DXVK
|
# Язык озвучки в игре
|
||||||
|
voice:
|
||||||
|
title: Язык озвучки
|
||||||
|
items:
|
||||||
|
en-us: Английский (США)
|
||||||
|
ja-jp: Японский
|
||||||
|
ko-kr: Корейский
|
||||||
|
zn-cn: Китайский
|
||||||
|
|
||||||
|
# Тема лаунчера
|
||||||
|
theme:
|
||||||
|
title: Тема
|
||||||
|
items:
|
||||||
|
system: Системная
|
||||||
|
light: Светлая
|
||||||
|
dark: Тёмная
|
||||||
|
|
||||||
|
discord: Discord RPC
|
||||||
|
dxvks: DXVK
|
||||||
|
|
||||||
|
# Улучшения
|
||||||
|
enhancements:
|
||||||
|
title: Улучшения
|
||||||
|
items:
|
||||||
|
# HUD
|
||||||
|
hud:
|
||||||
|
title: HUD
|
||||||
|
items:
|
||||||
|
none: Отключён
|
||||||
|
dxvk: DXVK
|
||||||
|
mangohud: MangoHUD
|
||||||
|
|
||||||
|
# TODO: add hints to the components so I could describe what these options means
|
||||||
|
gamemode: GameMode
|
||||||
|
fps_unlocker: Разблокировать FPS
|
||||||
|
purge_dxvk_logs: Автоматически удалять логи DXVK
|
||||||
|
|
||||||
|
# DXVKs
|
||||||
|
dxvks:
|
||||||
|
title: DXVK
|
|
@ -7,19 +7,27 @@
|
||||||
DXVK as TDXVK
|
DXVK as TDXVK
|
||||||
} from '../ts/types/DXVK';
|
} from '../ts/types/DXVK';
|
||||||
|
|
||||||
let dxvks: TDXVK[] = [];
|
let dxvks: TDXVK[] = [], selectedVersion;
|
||||||
|
|
||||||
DXVK.list().then((list) => dxvks = list);
|
DXVK.list().then((list) => dxvks = list);
|
||||||
|
DXVK.current.then((current) => selectedVersion = current?.version);
|
||||||
|
|
||||||
import Delete from '../assets/images/delete.png';
|
import Delete from '../assets/images/delete.png';
|
||||||
import Download from '../assets/images/download.png';
|
import Download from '../assets/images/download.png';
|
||||||
</script>
|
|
||||||
|
|
||||||
<h2>{ $_('settings.general.items.dxvks') }</h2>
|
const dxvkInstalled = (dxvk: TDXVK): boolean => {
|
||||||
|
const filtered = dxvks.filter((item) => item.version === dxvk.version);
|
||||||
|
|
||||||
|
if (filtered.length === 1)
|
||||||
|
return filtered[0].installed;
|
||||||
|
|
||||||
|
else return false;
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
<div class="list">
|
<div class="list">
|
||||||
{#each dxvks as dxvk}
|
{#each dxvks as dxvk}
|
||||||
<div class="list-item">
|
<div class="list-item" class:list-item-downloaded={dxvkInstalled(dxvk)} class:list-item-active={dxvk.version === selectedVersion}>
|
||||||
{ dxvk.version }
|
{ dxvk.version }
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
export let prop: string = '';
|
export let prop: string = '';
|
||||||
export let lang: string = '';
|
export let lang: string = '';
|
||||||
export let items: ArrayLike<string> = [];
|
export let items = {};
|
||||||
export let valueChanged: (value: string) => void = () => {};
|
export let valueChanged: (value: string) => void = () => {};
|
||||||
|
|
||||||
import Arrow from '../assets/svgs/arrow.svg';
|
import Arrow from '../assets/svgs/arrow.svg';
|
||||||
|
@ -44,7 +44,7 @@
|
||||||
data-value={itemLang}
|
data-value={itemLang}
|
||||||
|
|
||||||
on:click={selectionChanged}
|
on:click={selectionChanged}
|
||||||
|
|
||||||
on:click={() => {
|
on:click={() => {
|
||||||
selectedValue = itemLang;
|
selectedValue = itemLang;
|
||||||
|
|
||||||
|
|
98
src/defaultSettings.ts
Normal file
98
src/defaultSettings.ts
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
import Configs from './ts/Configs';
|
||||||
|
import constants from './ts/Constants';
|
||||||
|
import promisify from './ts/core/promisify';
|
||||||
|
|
||||||
|
promisify(async () => {
|
||||||
|
Configs.defaults({
|
||||||
|
lang: {
|
||||||
|
launcher: 'en-us',
|
||||||
|
voice: 'en-us'
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Path to wine prefix
|
||||||
|
*
|
||||||
|
* @default constants.paths.prefix.default
|
||||||
|
*/
|
||||||
|
prefix: await constants.paths.prefix.default,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runner name to use, or null if runner is not specified
|
||||||
|
*
|
||||||
|
* @default null
|
||||||
|
*/
|
||||||
|
runner: null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DXVK name to use, or null if DXVK is not specified
|
||||||
|
*
|
||||||
|
* @default null
|
||||||
|
*/
|
||||||
|
dxvk: null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launcher theme
|
||||||
|
*
|
||||||
|
* Can be "system", "light" and "dark"
|
||||||
|
*
|
||||||
|
* @defaul "system"
|
||||||
|
*/
|
||||||
|
theme: 'system',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HUD
|
||||||
|
*
|
||||||
|
* "none" if don't use. Otherwise should be "dxvk" or "mangohud"
|
||||||
|
*
|
||||||
|
* @default "none"
|
||||||
|
*/
|
||||||
|
hud: 'none',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* vkBasalt preset to use
|
||||||
|
*
|
||||||
|
* null if don't use. Otherwise should be some folder name from the "shaders" folder
|
||||||
|
*
|
||||||
|
* @default null
|
||||||
|
*/
|
||||||
|
shaders: null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Discord RPC integration
|
||||||
|
*/
|
||||||
|
discord: {
|
||||||
|
/**
|
||||||
|
* If it is enabled
|
||||||
|
*
|
||||||
|
* @default false
|
||||||
|
*/
|
||||||
|
enabled: false,
|
||||||
|
|
||||||
|
// todo
|
||||||
|
texts: {
|
||||||
|
idk: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Do the launcher should use GameMode
|
||||||
|
*
|
||||||
|
* @default false
|
||||||
|
*/
|
||||||
|
gamemode: false,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Do the launcher should use FPS unlocker
|
||||||
|
*
|
||||||
|
* @default false
|
||||||
|
*/
|
||||||
|
fps_unlocker: false,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Do the launcher should automatically delete DXVK log files
|
||||||
|
*
|
||||||
|
* @default true
|
||||||
|
*/
|
||||||
|
purge_dxvk_logs: true
|
||||||
|
});
|
||||||
|
});
|
|
@ -1,43 +1,10 @@
|
||||||
import Configs from '../ts/Configs';
|
|
||||||
import constants from '../ts/Constants';
|
|
||||||
|
|
||||||
import '../i18n';
|
import '../i18n';
|
||||||
import App from '../index.svelte';
|
import App from '../index.svelte';
|
||||||
|
|
||||||
declare const Neutralino;
|
declare const Neutralino;
|
||||||
|
|
||||||
Neutralino.init();
|
Neutralino.init();
|
||||||
|
Neutralino.events.on('ready', () => import('../defaultSettings'));
|
||||||
Neutralino.events.on('ready', async () => {
|
|
||||||
Configs.defaults({
|
|
||||||
lang: {
|
|
||||||
launcher: 'en-us',
|
|
||||||
voice: 'en-us'
|
|
||||||
},
|
|
||||||
|
|
||||||
// Path to wine prefix
|
|
||||||
prefix: await constants.paths.prefix.default,
|
|
||||||
|
|
||||||
// runner name to use, or null if runner is not specified
|
|
||||||
runner: null,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* HUD
|
|
||||||
*
|
|
||||||
* null if don't use
|
|
||||||
* otherwise should be "dxvk" or "mangohud"
|
|
||||||
*/
|
|
||||||
hud: null,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* vkBasalt preset to use
|
|
||||||
*
|
|
||||||
* null if don't use
|
|
||||||
* otherwise should be some folder name from the "shaders" folder
|
|
||||||
*/
|
|
||||||
shaders: null
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
const app = new App({
|
const app = new App({
|
||||||
target: document.getElementById('app')!
|
target: document.getElementById('app')!
|
||||||
|
|
|
@ -6,15 +6,84 @@
|
||||||
import SelectionBox from './components/SelectionBox.svelte';
|
import SelectionBox from './components/SelectionBox.svelte';
|
||||||
import DXVKSelectionList from './components/DXVKSelectionList.svelte';
|
import DXVKSelectionList from './components/DXVKSelectionList.svelte';
|
||||||
|
|
||||||
let availableLocales: ArrayLike<string> = [];
|
import Window from './ts/neutralino/Window';
|
||||||
|
|
||||||
|
// TODO: somehow simplify all this variables definitions
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launcher language
|
||||||
|
*/
|
||||||
|
let launcherLocales = {};
|
||||||
|
|
||||||
$locales.forEach((locale) => {
|
$locales.forEach((locale) => {
|
||||||
availableLocales[locale] = `settings.general.items.lang.launcher.items.${locale}`;
|
launcherLocales[locale] = `settings.general.items.lang.launcher.items.${locale}`;
|
||||||
});
|
});
|
||||||
|
|
||||||
availableLocales = availableLocales;
|
launcherLocales = launcherLocales;
|
||||||
|
|
||||||
import Window from './ts/neutralino/Window';
|
/**
|
||||||
|
* Game voice packs languages
|
||||||
|
*/
|
||||||
|
|
||||||
|
const voiceLocales = {
|
||||||
|
'en-us': 'settings.general.items.lang.voice.items.en-us',
|
||||||
|
'ja-jp': 'settings.general.items.lang.voice.items.ja-jp',
|
||||||
|
'ko-kr': 'settings.general.items.lang.voice.items.ko-kr',
|
||||||
|
'zn-cn': 'settings.general.items.lang.voice.items.zn-cn'
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Themes
|
||||||
|
*/
|
||||||
|
|
||||||
|
const themes = {
|
||||||
|
'system': 'settings.general.items.theme.items.system',
|
||||||
|
'light': 'settings.general.items.theme.items.light',
|
||||||
|
'dark': 'settings.general.items.theme.items.dark'
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HUD options
|
||||||
|
*/
|
||||||
|
|
||||||
|
const huds = {
|
||||||
|
'none': 'settings.enhancements.items.hud.items.none',
|
||||||
|
'dxvk': 'settings.enhancements.items.hud.items.dxvk',
|
||||||
|
'mangohud': 'settings.enhancements.items.hud.items.mangohud'
|
||||||
|
};
|
||||||
|
|
||||||
|
const menuItems = [
|
||||||
|
'general',
|
||||||
|
'enhancements',
|
||||||
|
'dxvks'
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Menu items changing
|
||||||
|
*/
|
||||||
|
let selectedItem: string = 'general';
|
||||||
|
|
||||||
|
const changeItem = (event: MouseEvent) => {
|
||||||
|
const item = event.target! as HTMLElement;
|
||||||
|
const settings = document.getElementsByClassName('settings')[0]!;
|
||||||
|
|
||||||
|
settings.scrollTop = document.getElementById(item.getAttribute('data-anchor') as string)!.offsetTop - 16;
|
||||||
|
|
||||||
|
selectedItem = item.getAttribute('data-anchor')!;
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateItems = () => {
|
||||||
|
const settings = document.getElementsByClassName('settings')[0]! as HTMLElement;
|
||||||
|
const settingsItems = <HTMLCollectionOf<HTMLElement>>settings.children;
|
||||||
|
|
||||||
|
let visibleElement;
|
||||||
|
|
||||||
|
for (let i = 0; i < settingsItems.length; ++i)
|
||||||
|
if (settingsItems[i].offsetTop - settings.scrollTop < 180)
|
||||||
|
visibleElement = settingsItems[i];
|
||||||
|
|
||||||
|
selectedItem = visibleElement.getAttribute('id');
|
||||||
|
};
|
||||||
|
|
||||||
// Do some stuff when all the content will be loaded
|
// Do some stuff when all the content will be loaded
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
|
@ -24,20 +93,54 @@
|
||||||
|
|
||||||
{#if typeof $locale === 'string'}
|
{#if typeof $locale === 'string'}
|
||||||
<div class="menu">
|
<div class="menu">
|
||||||
<div class="menu-item menu-item-active" data-anchor="general">{$_('settings.general.title')}</div>
|
{#each menuItems as item}
|
||||||
|
<div class="menu-item" on:click={changeItem} class:menu-item-active={selectedItem === item} data-anchor={item}>{ $_(`settings.${item}.title`) }</div>
|
||||||
|
{/each}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="settings">
|
<div class="settings" on:scroll={updateItems}>
|
||||||
<div class="settings-item" id="general">
|
<div class="settings-item" id="general">
|
||||||
<h1>{$_('settings.general.title')}</h1>
|
<h1>{$_('settings.general.title')}</h1>
|
||||||
|
|
||||||
<SelectionBox
|
<SelectionBox
|
||||||
lang="settings.general.items.lang.launcher.title"
|
lang="settings.general.items.lang.launcher.title"
|
||||||
prop="lang.launcher"
|
prop="lang.launcher"
|
||||||
items={availableLocales}
|
items={launcherLocales}
|
||||||
valueChanged={(value) => $locale = value}
|
valueChanged={(value) => $locale = value}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
<SelectionBox
|
||||||
|
lang="settings.general.items.lang.voice.title"
|
||||||
|
prop="lang.voice"
|
||||||
|
items={voiceLocales}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<SelectionBox
|
||||||
|
lang="settings.general.items.theme.title"
|
||||||
|
prop="theme"
|
||||||
|
items={themes}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<Checkbox lang="settings.general.items.discord" prop="discord.enabled" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="settings-item" id="enhancements">
|
||||||
|
<h1>{$_('settings.enhancements.title')}</h1>
|
||||||
|
|
||||||
|
<SelectionBox
|
||||||
|
lang="settings.enhancements.items.hud.title"
|
||||||
|
prop="hud"
|
||||||
|
items={huds}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<Checkbox lang="settings.enhancements.items.gamemode" prop="gamemode" />
|
||||||
|
<Checkbox lang="settings.enhancements.items.fps_unlocker" prop="fps_unlocker" />
|
||||||
|
<Checkbox lang="settings.enhancements.items.purge_dxvk_logs" prop="purge_dxvk_logs" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="settings-item" id="dxvks">
|
||||||
|
<h1>{$_('settings.dxvks.title')}</h1>
|
||||||
|
|
||||||
<DXVKSelectionList />
|
<DXVKSelectionList />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import type { DXVK as TDXVK } from '../types/DXVK';
|
import type { DXVK as TDXVK } from '../types/DXVK';
|
||||||
|
|
||||||
import constants from '../Constants';
|
import constants from '../Constants';
|
||||||
|
import Configs from '../Configs';
|
||||||
import AbstractInstaller from './AbstractInstaller';
|
import AbstractInstaller from './AbstractInstaller';
|
||||||
|
|
||||||
declare const Neutralino;
|
declare const Neutralino;
|
||||||
|
@ -15,6 +16,21 @@ class Stream extends AbstractInstaller
|
||||||
|
|
||||||
export default class DXVK
|
export default class DXVK
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Get the current using DXVK according to the config file
|
||||||
|
*/
|
||||||
|
public static get current(): Promise<TDXVK|null>
|
||||||
|
{
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
Configs.get('dxvk').then((dxvk) => {
|
||||||
|
if (typeof dxvk === 'string')
|
||||||
|
DXVK.get(dxvk).then((dxvk) => resolve(dxvk));
|
||||||
|
|
||||||
|
else resolve(null);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get DXVKs list
|
* Get DXVKs list
|
||||||
*/
|
*/
|
||||||
|
@ -49,7 +65,7 @@ export default class DXVK
|
||||||
/**
|
/**
|
||||||
* Get DXVK with specified version
|
* Get DXVK with specified version
|
||||||
*/
|
*/
|
||||||
public static get(version: string): Promise<DXVK|null>
|
public static get(version: string): Promise<TDXVK|null>
|
||||||
{
|
{
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
this.list().then((list) => {
|
this.list().then((list) => {
|
||||||
|
|
Loading…
Reference in a new issue