mirror of
https://github.com/an-anime-team/an-anime-game-launcher.git
synced 2025-01-12 11:57:20 +03:00
Several changes
- made selection list component - generalized selection box component; added `LanguageSelection` component - `DXVK.get()` method was renamed to `DXVK.get()` - added `DXVK.get()` method to get a DXVK with a specified version
This commit is contained in:
parent
210157a5a8
commit
317557b335
14 changed files with 332 additions and 173 deletions
|
@ -10,7 +10,7 @@
|
||||||
<body theme="light">
|
<body theme="light">
|
||||||
<div id="app">
|
<div id="app">
|
||||||
<div class="menu">
|
<div class="menu">
|
||||||
<div class="menu-item menu-item-active" anchor="general">General</div>
|
<div class="menu-item menu-item-active" anchor="general">{{ $t('settings.general.title') }}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="settings">
|
<div class="settings">
|
||||||
|
@ -21,9 +21,13 @@
|
||||||
<l-checkbox locale="general.test2" prop="test2"></l-checkbox>
|
<l-checkbox locale="general.test2" prop="test2"></l-checkbox>
|
||||||
<l-checkbox locale="general.test3" prop="test3"></l-checkbox>
|
<l-checkbox locale="general.test3" prop="test3"></l-checkbox>
|
||||||
|
|
||||||
<l-selectbox locale="general.lang.launcher" prop="lang.launcher">
|
<l-language locale="general.lang.launcher" prop="lang.launcher">
|
||||||
<li v-for="(lang, code) in languages" :lang="code">{{ lang }}</li>
|
<li v-for="(lang, code) in languages" :option="code">{{ lang }}</li>
|
||||||
</l-selectbox>
|
</l-language>
|
||||||
|
|
||||||
|
<l-dxvks>
|
||||||
|
<l-dxvk-item v-for="dxvk in dxvks" :title="dxvk.version"></l-dxvk-item>
|
||||||
|
</l-dxvks>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -19,9 +19,9 @@ export default defineComponent({
|
||||||
active: false
|
active: false
|
||||||
}),
|
}),
|
||||||
|
|
||||||
async created()
|
created()
|
||||||
{
|
{
|
||||||
this.active = await Configs.get(this.prop) as boolean;
|
Configs.get(this.prop).then((active) => this.active = active as boolean);
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
|
9
src/components/DXVKItem.vue
Normal file
9
src/components/DXVKItem.vue
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
|
import SelectionListItem from './bases/SelectionListItem.vue';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
mixins: [SelectionListItem]
|
||||||
|
});
|
||||||
|
</script>
|
10
src/components/DXVKs.vue
Normal file
10
src/components/DXVKs.vue
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
import Configs from '../ts/Configs';
|
||||||
|
|
||||||
|
import SelectionList from './bases/SelectionList.vue';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
mixins: [SelectionList]
|
||||||
|
});
|
||||||
|
</script>
|
52
src/components/LanguageSelection.vue
Normal file
52
src/components/LanguageSelection.vue
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
import Configs from '../ts/Configs';
|
||||||
|
|
||||||
|
import Selectbox from './bases/Selectbox.vue';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
mixins: [Selectbox],
|
||||||
|
inject: ['languages'],
|
||||||
|
|
||||||
|
data()
|
||||||
|
{
|
||||||
|
return {
|
||||||
|
trueTitle: '',
|
||||||
|
selectionOpen: false,
|
||||||
|
options: {
|
||||||
|
selected: 'en-us',
|
||||||
|
available: this.languages
|
||||||
|
}
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
created()
|
||||||
|
{
|
||||||
|
const group = this.locale.split('.')[0];
|
||||||
|
const locale = this.locale.substring(this.locale.indexOf('.') + 1);
|
||||||
|
|
||||||
|
this.trueTitle = `settings.${group}.items.${locale}`;
|
||||||
|
|
||||||
|
Configs.get('lang.launcher').then((lang) => {
|
||||||
|
this.options.selected = (lang as string|null) ?? 'en-us';
|
||||||
|
|
||||||
|
const children = document.getElementById(this.prop)!.children;
|
||||||
|
|
||||||
|
/*for (let i = 0; i < children.length; ++i)
|
||||||
|
if (children[i].getAttribute('lang') === )*/
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
selectionChanged(value: string)
|
||||||
|
{
|
||||||
|
this.$i18n.locale = value;
|
||||||
|
},
|
||||||
|
|
||||||
|
defaultOption(): Promise<string>
|
||||||
|
{
|
||||||
|
return Configs.get('lang.launcher') as Promise<string>;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
|
@ -1,77 +0,0 @@
|
||||||
<template>
|
|
||||||
<div class="select" :class="{'select-active': selectionOpen}">
|
|
||||||
<span>{{ $t(this.trueLocale) }}</span>
|
|
||||||
|
|
||||||
<div class="select-options">
|
|
||||||
<ul @click="selectLang">
|
|
||||||
<slot></slot>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="selected-item" @click="this.selectionOpen = !this.selectionOpen">
|
|
||||||
<span>{{ lang.available[lang.selected] }}</span>
|
|
||||||
|
|
||||||
<img src="../assets/svgs/arrow.svg" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts">
|
|
||||||
import { defineComponent } from 'vue';
|
|
||||||
import Configs from '../ts/Configs';
|
|
||||||
|
|
||||||
export default defineComponent({
|
|
||||||
props: ['locale', 'prop'],
|
|
||||||
inject: ['languages'],
|
|
||||||
|
|
||||||
data()
|
|
||||||
{
|
|
||||||
return {
|
|
||||||
trueLocale: '',
|
|
||||||
selectionOpen: false,
|
|
||||||
lang: {
|
|
||||||
selected: 'en-us',
|
|
||||||
available: this.languages
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
|
||||||
|
|
||||||
created()
|
|
||||||
{
|
|
||||||
const group = this.locale.split('.')[0];
|
|
||||||
const locale = this.locale.substring(this.locale.indexOf('.') + 1);
|
|
||||||
|
|
||||||
this.trueLocale = `settings.${group}.items.${locale}`;
|
|
||||||
|
|
||||||
Configs.get('lang.launcher').then((lang) => {
|
|
||||||
this.lang.selected = (lang as string|null) ?? 'en-us';
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
methods: {
|
|
||||||
selectLang(event: MouseEvent)
|
|
||||||
{
|
|
||||||
const li = event.target as HTMLElement;
|
|
||||||
|
|
||||||
if (!li.classList.contains('selected'))
|
|
||||||
{
|
|
||||||
const children = li.parentElement!.children;
|
|
||||||
|
|
||||||
for (let i = 0; i < children.length; ++i)
|
|
||||||
children[i].classList.remove('selected');
|
|
||||||
|
|
||||||
li.classList.add('selected');
|
|
||||||
|
|
||||||
this.lang.selected = li.getAttribute('lang')!;
|
|
||||||
this.selectionOpen = false;
|
|
||||||
|
|
||||||
this.$i18n.locale = this.lang.selected;
|
|
||||||
|
|
||||||
Configs.set(this.prop, this.lang.selected);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style src="../sass/components/selectbox.sass" lang="sass"></style>
|
|
85
src/components/bases/Selectbox.vue
Normal file
85
src/components/bases/Selectbox.vue
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
<template>
|
||||||
|
<div class="select" :class="{'select-active': selectionOpen}">
|
||||||
|
<span>{{ $t(this.trueTitle) }}</span>
|
||||||
|
|
||||||
|
<div class="select-options">
|
||||||
|
<ul @click="selectItem" :id="prop">
|
||||||
|
<slot></slot>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="selected-item" @click="this.selectionOpen = !this.selectionOpen">
|
||||||
|
<span>{{ options.available[options.selected] }}</span>
|
||||||
|
|
||||||
|
<img src="../../assets/svgs/arrow.svg" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
import Configs from '../../ts/Configs';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
props: ['locale', 'prop'],
|
||||||
|
|
||||||
|
data()
|
||||||
|
{
|
||||||
|
return {
|
||||||
|
trueTitle: '',
|
||||||
|
selectionOpen: false,
|
||||||
|
options: {
|
||||||
|
selected: '',
|
||||||
|
available: []
|
||||||
|
}
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
created()
|
||||||
|
{
|
||||||
|
const group = this.locale.split('.')[0];
|
||||||
|
const locale = this.locale.substring(this.locale.indexOf('.') + 1);
|
||||||
|
|
||||||
|
this.trueTitle = `settings.${group}.items.${locale}`;
|
||||||
|
|
||||||
|
this.defaultOption().then((option) => {
|
||||||
|
this.options.selected = option;
|
||||||
|
|
||||||
|
const children = document.getElementById(this.prop)!.children;
|
||||||
|
|
||||||
|
for (let i = 0; i < children.length; ++i)
|
||||||
|
if (children[i].getAttribute('option') === option)
|
||||||
|
children[i].classList.add('selected');
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
selectItem(event: MouseEvent)
|
||||||
|
{
|
||||||
|
const li = event.target as HTMLElement;
|
||||||
|
|
||||||
|
if (!li.classList.contains('selected'))
|
||||||
|
{
|
||||||
|
const children = li.parentElement!.children;
|
||||||
|
|
||||||
|
for (let i = 0; i < children.length; ++i)
|
||||||
|
children[i].classList.remove('selected');
|
||||||
|
|
||||||
|
li.classList.add('selected');
|
||||||
|
|
||||||
|
this.options.selected = li.getAttribute('option')!;
|
||||||
|
this.selectionOpen = false;
|
||||||
|
|
||||||
|
this.selectionChanged(this.options.selected);
|
||||||
|
|
||||||
|
Configs.set(this.prop, this.options.selected);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
selectionChanged(value: string) {},
|
||||||
|
defaultOption(): Promise<string> { return new Promise((resolve) => resolve('')); }
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style src="../../sass/components/selectbox.sass" lang="sass"></style>
|
13
src/components/bases/SelectionList.vue
Normal file
13
src/components/bases/SelectionList.vue
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
<template>
|
||||||
|
<div class="list">
|
||||||
|
<slot></slot>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
|
export default defineComponent({});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style src="../../sass/components/selectionList.sass" lang="sass"></style>
|
19
src/components/bases/SelectionListItem.vue
Normal file
19
src/components/bases/SelectionListItem.vue
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
<template>
|
||||||
|
<div class="list-item">
|
||||||
|
{{ title }}
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<span></span>
|
||||||
|
<img class="item-delete" src="../../assets/images/delete.png">
|
||||||
|
<img class="item-download" src="../../assets/images/download.png">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
props: ['title']
|
||||||
|
});
|
||||||
|
</script>
|
|
@ -4,9 +4,13 @@ import { createI18n } from 'vue-i18n';
|
||||||
import Window from '../ts/neutralino/Window';
|
import Window from '../ts/neutralino/Window';
|
||||||
|
|
||||||
import Locales from '../ts/core/Locales';
|
import Locales from '../ts/core/Locales';
|
||||||
|
import DXVK from '../ts/core/DXVK';
|
||||||
|
import Configs from '../ts/Configs';
|
||||||
|
|
||||||
import Checkbox from '../components/Checkbox.vue';
|
import Checkbox from '../components/Checkbox.vue';
|
||||||
import Selectbox from '../components/Selectbox.vue';
|
import LanguageSelection from '../components/LanguageSelection.vue';
|
||||||
|
import DXVKS from '../components/DXVKs.vue';
|
||||||
|
import DXVKItem from '../components/DXVKItem.vue';
|
||||||
|
|
||||||
const app = createApp({
|
const app = createApp({
|
||||||
data: () => ({
|
data: () => ({
|
||||||
|
@ -15,8 +19,10 @@ const app = createApp({
|
||||||
// Languages selection
|
// Languages selection
|
||||||
languages: {
|
languages: {
|
||||||
'en-us': 'English (US)',
|
'en-us': 'English (US)',
|
||||||
'ru-ru': 'Russian'
|
'ru-ru': 'Русский'
|
||||||
}
|
},
|
||||||
|
|
||||||
|
dxvks: []
|
||||||
}),
|
}),
|
||||||
|
|
||||||
provide()
|
provide()
|
||||||
|
@ -26,17 +32,26 @@ const app = createApp({
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
|
created()
|
||||||
|
{
|
||||||
|
DXVK.list().then((list) => this.dxvks = list);
|
||||||
|
},
|
||||||
|
|
||||||
components: {
|
components: {
|
||||||
'l-checkbox': Checkbox,
|
'l-checkbox': Checkbox,
|
||||||
'l-selectbox': Selectbox
|
'l-language': LanguageSelection,
|
||||||
|
'l-dxvks': DXVKS,
|
||||||
|
'l-dxvk-item': DXVKItem
|
||||||
},
|
},
|
||||||
|
|
||||||
mounted: () => Window.current.show()
|
mounted: () => Window.current.show()
|
||||||
});
|
});
|
||||||
|
|
||||||
Locales.get().then((locales) => {
|
Locales.get().then(async (locales) => {
|
||||||
|
const locale = await Configs.get('lang.launcher');
|
||||||
|
|
||||||
app.use(createI18n({
|
app.use(createI18n({
|
||||||
locale: 'en-us',
|
locale: locale as string,
|
||||||
fallbackLocale: 'en-us',
|
fallbackLocale: 'en-us',
|
||||||
|
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
|
|
|
@ -145,81 +145,6 @@
|
||||||
.button:not(:last-child)
|
.button:not(:last-child)
|
||||||
margin-right: 8px
|
margin-right: 8px
|
||||||
|
|
||||||
/* List of buttons */
|
|
||||||
|
|
||||||
.list-item
|
|
||||||
display: flex
|
|
||||||
align-items: center
|
|
||||||
|
|
||||||
height: 52px
|
|
||||||
margin-bottom: 8px
|
|
||||||
padding: 0 12px
|
|
||||||
|
|
||||||
border-radius: 12px
|
|
||||||
background-color: map.get($theme-map, "background1")
|
|
||||||
|
|
||||||
font-size: 18px
|
|
||||||
cursor: pointer
|
|
||||||
|
|
||||||
@if $theme-name == dark
|
|
||||||
img
|
|
||||||
filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(219deg) brightness(102%) contrast(104%)
|
|
||||||
|
|
||||||
&:hover
|
|
||||||
background-color: map.get($theme-map, "background2")
|
|
||||||
|
|
||||||
> div
|
|
||||||
width: auto
|
|
||||||
height: 52px
|
|
||||||
min-width: 52px
|
|
||||||
|
|
||||||
margin-left: auto
|
|
||||||
|
|
||||||
display: flex
|
|
||||||
align-items: center
|
|
||||||
|
|
||||||
img
|
|
||||||
width: 16px
|
|
||||||
height: 16px
|
|
||||||
|
|
||||||
margin: auto
|
|
||||||
|
|
||||||
img.item-delete
|
|
||||||
// filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(93deg) brightness(103%) contrast(103%)
|
|
||||||
|
|
||||||
width: 20px
|
|
||||||
height: 20px
|
|
||||||
|
|
||||||
display: none
|
|
||||||
|
|
||||||
.list-item-active
|
|
||||||
background-color: map.get($theme-map, "primary") !important
|
|
||||||
color: white !important
|
|
||||||
|
|
||||||
img.item-delete
|
|
||||||
display: none !important
|
|
||||||
|
|
||||||
.list-item-disabled
|
|
||||||
background-color: map.get($theme-map, "background1") !important
|
|
||||||
color: #abadbd !important
|
|
||||||
|
|
||||||
cursor: default !important
|
|
||||||
|
|
||||||
img
|
|
||||||
filter: invert(70%) sepia(13%) saturate(241%) hue-rotate(196deg) brightness(97%) contrast(91%)
|
|
||||||
|
|
||||||
.list-item-downloading
|
|
||||||
img
|
|
||||||
display: none !important
|
|
||||||
|
|
||||||
.list-item-downloaded
|
|
||||||
> div
|
|
||||||
img.item-download
|
|
||||||
display: none
|
|
||||||
|
|
||||||
img.item-delete
|
|
||||||
display: block
|
|
||||||
|
|
||||||
/* Buttons */
|
/* Buttons */
|
||||||
|
|
||||||
.button
|
.button
|
||||||
|
|
82
src/sass/components/selectionList.sass
Normal file
82
src/sass/components/selectionList.sass
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
@use "sass:map"
|
||||||
|
|
||||||
|
@mixin themable($theme-name, $theme-map)
|
||||||
|
body[theme=#{$theme-name}]
|
||||||
|
.list-item
|
||||||
|
display: flex
|
||||||
|
align-items: center
|
||||||
|
|
||||||
|
height: 52px
|
||||||
|
margin-bottom: 8px
|
||||||
|
padding: 0 12px
|
||||||
|
|
||||||
|
border-radius: 12px
|
||||||
|
background-color: map.get($theme-map, "background1")
|
||||||
|
|
||||||
|
font-size: 18px
|
||||||
|
cursor: pointer
|
||||||
|
|
||||||
|
@if $theme-name == dark
|
||||||
|
img
|
||||||
|
filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(219deg) brightness(102%) contrast(104%)
|
||||||
|
|
||||||
|
&:hover
|
||||||
|
background-color: map.get($theme-map, "background2")
|
||||||
|
|
||||||
|
> div
|
||||||
|
width: auto
|
||||||
|
height: 52px
|
||||||
|
min-width: 52px
|
||||||
|
|
||||||
|
margin-left: auto
|
||||||
|
|
||||||
|
display: flex
|
||||||
|
align-items: center
|
||||||
|
|
||||||
|
img
|
||||||
|
width: 16px
|
||||||
|
height: 16px
|
||||||
|
|
||||||
|
margin: auto
|
||||||
|
|
||||||
|
img.item-delete
|
||||||
|
// filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(93deg) brightness(103%) contrast(103%)
|
||||||
|
|
||||||
|
width: 20px
|
||||||
|
height: 20px
|
||||||
|
|
||||||
|
display: none
|
||||||
|
|
||||||
|
.list-item-active
|
||||||
|
background-color: map.get($theme-map, "primary") !important
|
||||||
|
color: white !important
|
||||||
|
|
||||||
|
img.item-delete
|
||||||
|
display: none !important
|
||||||
|
|
||||||
|
.list-item-disabled
|
||||||
|
background-color: map.get($theme-map, "background1") !important
|
||||||
|
color: #abadbd !important
|
||||||
|
|
||||||
|
cursor: default !important
|
||||||
|
|
||||||
|
img
|
||||||
|
filter: invert(70%) sepia(13%) saturate(241%) hue-rotate(196deg) brightness(97%) contrast(91%)
|
||||||
|
|
||||||
|
.list-item-downloading
|
||||||
|
img
|
||||||
|
display: none !important
|
||||||
|
|
||||||
|
.list-item-downloaded
|
||||||
|
> div
|
||||||
|
img.item-download
|
||||||
|
display: none
|
||||||
|
|
||||||
|
img.item-delete
|
||||||
|
display: block
|
||||||
|
|
||||||
|
@import "../themes/light"
|
||||||
|
@import "../themes/dark"
|
||||||
|
|
||||||
|
@include themable(light, $light)
|
||||||
|
@include themable(dark, $dark)
|
|
@ -18,7 +18,7 @@ export default class DXVK
|
||||||
/**
|
/**
|
||||||
* Get DXVKs list
|
* Get DXVKs list
|
||||||
*/
|
*/
|
||||||
public static get(): Promise<TDXVK[]>
|
public static list(): Promise<TDXVK[]>
|
||||||
{
|
{
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
constants.paths.dxvksDir.then(async (dxvksDir: string) => {
|
constants.paths.dxvksDir.then(async (dxvksDir: string) => {
|
||||||
|
@ -46,6 +46,26 @@ export default class DXVK
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get DXVK with specified version
|
||||||
|
*/
|
||||||
|
public static get(version: string): Promise<DXVK|null>
|
||||||
|
{
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
this.list().then((list) => {
|
||||||
|
for (const dxvk of list)
|
||||||
|
if (dxvk.version === version)
|
||||||
|
{
|
||||||
|
resolve(dxvk);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
resolve(null);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Download DXVK to the [constants.paths.dxvks] directory
|
* Download DXVK to the [constants.paths.dxvks] directory
|
||||||
*
|
*
|
||||||
|
@ -59,14 +79,16 @@ export default class DXVK
|
||||||
// then we should find this DXVK version and call this method for it
|
// then we should find this DXVK version and call this method for it
|
||||||
if (typeof dxvk == 'string')
|
if (typeof dxvk == 'string')
|
||||||
{
|
{
|
||||||
|
this.list().then((list) => {
|
||||||
let foundDXVK;
|
let foundDXVK;
|
||||||
|
|
||||||
(await this.get()).forEach((currDxvk) => {
|
list.forEach((currDxvk) => {
|
||||||
if (currDxvk.version == dxvk)
|
if (currDxvk.version == dxvk)
|
||||||
foundDXVK = currDxvk;
|
foundDXVK = currDxvk;
|
||||||
});
|
});
|
||||||
|
|
||||||
resolve(foundDXVK === null ? null : new Stream(foundDXVK));
|
resolve(foundDXVK === null ? null : new Stream(foundDXVK));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise we can use dxvk.uri and so on to download DXVK
|
// Otherwise we can use dxvk.uri and so on to download DXVK
|
||||||
|
|
Loading…
Reference in a new issue