diff options
author | Rémy Raes <contact@remyraes.com> | 2022-10-20 10:12:36 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-20 10:12:36 +0200 |
commit | 2e5c9b034d6bd7aa6fddc7f7f75be071b30b9c5a (patch) | |
tree | 6ec4bfbca57658543e0cf6d610af1c21f2de106c /src-vue/src/plugins | |
parent | 8edfb16aba17f082a3a0da891d8e49658bf36530 (diff) | |
parent | 9b4e032b73e3f40c8c4126a25356f467a833d239 (diff) | |
download | FlightCore-2e5c9b034d6bd7aa6fddc7f7f75be071b30b9c5a.tar.gz FlightCore-2e5c9b034d6bd7aa6fddc7f7f75be071b30b9c5a.zip |
Merge branch 'GeckoEidechse:main' into refactor/router-view
Diffstat (limited to 'src-vue/src/plugins')
-rw-r--r-- | src-vue/src/plugins/store.ts | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/src-vue/src/plugins/store.ts b/src-vue/src/plugins/store.ts index 4fa7328b..4fdf50a3 100644 --- a/src-vue/src/plugins/store.ts +++ b/src-vue/src/plugins/store.ts @@ -5,8 +5,10 @@ import { InstallType } from "../utils/InstallType"; import { invoke } from "@tauri-apps/api"; import { GameInstall } from "../utils/GameInstall"; import { ReleaseCanal } from "../utils/ReleaseCanal"; -import { ElNotification } from 'element-plus'; +import { ElNotification, NotificationHandle } from 'element-plus'; import { NorthstarState } from '../utils/NorthstarState'; +import { appDir } from '@tauri-apps/api/path'; +import { open } from '@tauri-apps/api/dialog'; import { Store } from 'tauri-plugin-store-api'; import {router} from "../main"; @@ -28,6 +30,8 @@ export interface FlightCoreStore { origin_is_running: boolean } +let notification_handle: NotificationHandle; + export const store = createStore<FlightCoreStore>({ state (): FlightCoreStore { return { @@ -65,6 +69,48 @@ export const store = createStore<FlightCoreStore>({ updateCurrentTab(state: any, newTab: Tabs) { router.push({path: newTab}); }, + async updateGamePath(state: FlightCoreStore) { + // Open a selection dialog for directories + const selected = await open({ + directory: true, + multiple: false, + defaultPath: await appDir(), + }); + if (Array.isArray(selected)) { + // user selected multiple directories + alert("Please only select a single directory"); + } else if (selected === null) { + // user cancelled the selection + } else { + // user selected a single directory + + // Verify if valid Titanfall2 install location + let is_valid_titanfall2_install = await invoke("verify_install_location", { gamePath: selected }) as boolean; + if (is_valid_titanfall2_install) { + state.game_path = selected; + ElNotification({ + title: 'New game folder', + message: "Game folder was successfully updated.", + type: 'success', + position: 'bottom-right' + }); + notification_handle.close(); + state.install_type = InstallType.UNKNOWN; + + // Check for Northstar install + store.commit('checkNorthstarUpdates'); + } + else { + // Not valid Titanfall2 install + ElNotification({ + title: 'Wrong folder', + message: "Selected folder is not a valid Titanfall2 install.", + type: 'error', + position: 'bottom-right' + }); + } + } + }, async launchGame(state: any) { // TODO update installation if release track was switched switch (state.northstar_state) { @@ -130,6 +176,10 @@ export const store = createStore<FlightCoreStore>({ alert(error); }); break; + + case NorthstarState.GAME_NOT_FOUND: + store.commit('updateGamePath'); + break; } } } @@ -162,7 +212,7 @@ async function _initializeApp(state: any) { .catch((err) => { // Gamepath not found or other error console.error(err); - ElNotification({ + notification_handle = ElNotification({ title: 'Titanfall2 not found!', message: "Please manually select install location", type: 'error', |