mirror of
https://github.com/ALEZ-DEV/Babylonia-terminal.git
synced 2025-12-18 02:18:51 +00:00
add select and fetch proton versions
This commit is contained in:
parent
26d4e35d19
commit
436827b390
18
babylonia_terminal_launcher/lib/models/github.dart
Normal file
18
babylonia_terminal_launcher/lib/models/github.dart
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import 'package:babylonia_terminal_launcher/messages/github.pb.dart';
|
||||||
|
|
||||||
|
class Github {
|
||||||
|
static bool _isFetchingProtonVersions = false;
|
||||||
|
static Future<List<String>> getProtonVersions() async {
|
||||||
|
if (!_isFetchingProtonVersions) {
|
||||||
|
_isFetchingProtonVersions = true;
|
||||||
|
AskProtonVersions().sendSignalToRust();
|
||||||
|
final stream = ProtonVersions.rustSignalStream;
|
||||||
|
|
||||||
|
await for (final rustSignal in stream) {
|
||||||
|
_isFetchingProtonVersions = false;
|
||||||
|
return rustSignal.message.versions;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -6,6 +6,7 @@ import './../../messages/game_state.pb.dart';
|
|||||||
import './../../providers/providers.dart';
|
import './../../providers/providers.dart';
|
||||||
import './../../widgets/selectable_yaru_expansion_panel.dart';
|
import './../../widgets/selectable_yaru_expansion_panel.dart';
|
||||||
import './../../widgets/simple_button.dart';
|
import './../../widgets/simple_button.dart';
|
||||||
|
import './../../widgets/steps/proton_steps_widget.dart';
|
||||||
|
|
||||||
class StepsScreen extends StatelessWidget {
|
class StepsScreen extends StatelessWidget {
|
||||||
StepsScreen({super.key});
|
StepsScreen({super.key});
|
||||||
@ -45,10 +46,7 @@ class StepsScreen extends StatelessWidget {
|
|||||||
Text("Dependecies"),
|
Text("Dependecies"),
|
||||||
],
|
],
|
||||||
children: const [
|
children: const [
|
||||||
Padding(
|
ProtonSteps(),
|
||||||
padding: EdgeInsets.all(40.0),
|
|
||||||
child: Text("Proton"),
|
|
||||||
),
|
|
||||||
Padding(
|
Padding(
|
||||||
padding: EdgeInsets.all(40.0),
|
padding: EdgeInsets.all(40.0),
|
||||||
child: Text("DXVK"),
|
child: Text("DXVK"),
|
||||||
|
|||||||
@ -0,0 +1,69 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:yaru/widgets.dart';
|
||||||
|
|
||||||
|
import './../../models/github.dart';
|
||||||
|
|
||||||
|
class ProtonSteps extends StatefulWidget {
|
||||||
|
const ProtonSteps({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<ProtonSteps> createState() => _ProtonStepsState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _ProtonStepsState extends State<ProtonSteps> {
|
||||||
|
bool hasLoaded = false;
|
||||||
|
bool isLoading = false;
|
||||||
|
late List<String> protonVersions;
|
||||||
|
String? selectedValue;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didChangeDependencies() async {
|
||||||
|
if (!hasLoaded) {
|
||||||
|
isLoading = true;
|
||||||
|
protonVersions = await Github.getProtonVersions();
|
||||||
|
setState(() {
|
||||||
|
isLoading = false;
|
||||||
|
hasLoaded = true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
super.didChangeDependencies();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
if (hasLoaded && selectedValue == null) {
|
||||||
|
selectedValue = protonVersions.first;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Padding(
|
||||||
|
padding: const EdgeInsets.all(8.0),
|
||||||
|
child: isLoading
|
||||||
|
? const Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Padding(
|
||||||
|
padding: EdgeInsets.all(8.0),
|
||||||
|
child: CircularProgressIndicator(),
|
||||||
|
),
|
||||||
|
Text('Fetching versions...'),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
: YaruPopupMenuButton(
|
||||||
|
initialValue: selectedValue,
|
||||||
|
itemBuilder: (_) => protonVersions
|
||||||
|
.map(
|
||||||
|
(e) => PopupMenuItem(
|
||||||
|
value: e,
|
||||||
|
child: Text(e),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.toList(),
|
||||||
|
onSelected: (v) => setState(() {
|
||||||
|
selectedValue = v!;
|
||||||
|
}),
|
||||||
|
child: Text(selectedValue!),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
10
babylonia_terminal_launcher/messages/github.proto
Normal file
10
babylonia_terminal_launcher/messages/github.proto
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
syntax = "proto3";
|
||||||
|
package github;
|
||||||
|
|
||||||
|
// [RINF:DART-SIGNAL]
|
||||||
|
message AskProtonVersions {}
|
||||||
|
|
||||||
|
// [RINF:RUST-SIGNAL]
|
||||||
|
message ProtonVersions {
|
||||||
|
repeated string versions = 1;
|
||||||
|
}
|
||||||
@ -2,7 +2,7 @@ use babylonia_terminal_sdk::game_state::GameState;
|
|||||||
|
|
||||||
use crate::messages::config::{ConfigInput, ConfigOutput};
|
use crate::messages::config::{ConfigInput, ConfigOutput};
|
||||||
|
|
||||||
pub async fn get_config() {
|
pub async fn listen_config() {
|
||||||
let mut receiver = ConfigInput::get_dart_signal_receiver();
|
let mut receiver = ConfigInput::get_dart_signal_receiver();
|
||||||
while let Some(_) = receiver.recv().await {
|
while let Some(_) = receiver.recv().await {
|
||||||
let config = GameState::get_config().await;
|
let config = GameState::get_config().await;
|
||||||
|
|||||||
@ -20,7 +20,7 @@ impl GameStateMessage {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_game_state() {
|
pub async fn listen_game_state() {
|
||||||
let mut receiver = AskGameState::get_dart_signal_receiver();
|
let mut receiver = AskGameState::get_dart_signal_receiver();
|
||||||
while let Some(_) = receiver.recv().await {
|
while let Some(_) = receiver.recv().await {
|
||||||
let result_state = GameState::get_current_state().await;
|
let result_state = GameState::get_current_state().await;
|
||||||
|
|||||||
30
babylonia_terminal_launcher/native/hub/src/github.rs
Normal file
30
babylonia_terminal_launcher/native/hub/src/github.rs
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
use babylonia_terminal_sdk::{
|
||||||
|
components::proton_component::{PROTON_DEV, PROTON_REPO},
|
||||||
|
utils::github_requester::{GithubRelease, GithubRequester},
|
||||||
|
};
|
||||||
|
|
||||||
|
use crate::messages::github::{AskProtonVersions, ProtonVersions};
|
||||||
|
|
||||||
|
#[warn(dead_code)]
|
||||||
|
struct GithubInfo;
|
||||||
|
|
||||||
|
impl GithubRequester for GithubInfo {
|
||||||
|
fn set_github_release_index(&mut self, _: usize) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn listen_proton_version() {
|
||||||
|
let mut receiver = AskProtonVersions::get_dart_signal_receiver();
|
||||||
|
while let Some(_) = receiver.recv().await {
|
||||||
|
let releases: Result<Vec<GithubRelease>, _> =
|
||||||
|
GithubInfo::get_github_releases(PROTON_DEV, PROTON_REPO).await;
|
||||||
|
match releases {
|
||||||
|
Ok(r) => ProtonVersions {
|
||||||
|
versions: r.iter().map(|v| v.tag_name.to_owned()).collect(),
|
||||||
|
}
|
||||||
|
.send_signal_to_dart(),
|
||||||
|
Err(_) => todo!(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -8,6 +8,7 @@ use tokio_with_wasm::tokio;
|
|||||||
|
|
||||||
mod config;
|
mod config;
|
||||||
mod game_state;
|
mod game_state;
|
||||||
|
mod github;
|
||||||
mod messages;
|
mod messages;
|
||||||
|
|
||||||
rinf::write_interface!();
|
rinf::write_interface!();
|
||||||
@ -22,6 +23,8 @@ async fn main() {
|
|||||||
//tokio::spawn(sample_functions::tell_numbers());
|
//tokio::spawn(sample_functions::tell_numbers());
|
||||||
//tokio::spawn(sample_functions::stream_fractal());
|
//tokio::spawn(sample_functions::stream_fractal());
|
||||||
//tokio::spawn(sample_functions::run_debug_tests());
|
//tokio::spawn(sample_functions::run_debug_tests());
|
||||||
tokio::spawn(game_state::get_game_state());
|
tokio::spawn(game_state::listen_game_state());
|
||||||
tokio::spawn(config::get_config());
|
tokio::spawn(config::listen_config());
|
||||||
|
tokio::spawn(config::listen_config());
|
||||||
|
tokio::spawn(github::listen_proton_version());
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user