minecraft-server-installer/lib/main/framework/ui/basic_configuration_tab.dart

57 lines
2.2 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:gap/gap.dart';
import 'package:minecraft_server_installer/main/adapter/presentation/installation_bloc.dart';
import 'package:minecraft_server_installer/main/adapter/presentation/installation_state.dart';
import 'package:minecraft_server_installer/main/framework/ui/path_browsing_field.dart';
import 'package:minecraft_server_installer/main/framework/ui/strings.dart';
import 'package:minecraft_server_installer/vanilla/adapter/presentation/game_version_view_model.dart';
import 'package:minecraft_server_installer/vanilla/framework/ui/game_version_dropdown.dart';
class BasicConfigurationTab extends StatefulWidget {
const BasicConfigurationTab({super.key});
@override
State<BasicConfigurationTab> createState() => _BasicConfigurationTabState();
}
class _BasicConfigurationTabState extends State<BasicConfigurationTab> {
GameVersionViewModel? selectedGameVersion;
@override
Widget build(BuildContext context) => Column(
children: [
const GameVersionDropdown(),
const Gap(16),
const PathBrowsingField(),
const Spacer(),
_bottomControl,
],
);
Widget get _bottomControl => BlocConsumer<InstallationBloc, InstallationState>(
listener: (_, __) {},
builder: (_, state) => Row(
mainAxisAlignment: MainAxisAlignment.end,
children: [
if (state.downloadProgress.isInProgress)
Expanded(child: LinearProgressIndicator(value: state.downloadProgress.value)),
const Gap(32),
ElevatedButton.icon(
style: ElevatedButton.styleFrom(shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(4))),
onPressed: context.watch<InstallationBloc>().state.canStartToInstall ? _downloadServerFile : null,
icon: const Icon(Icons.download),
label: const Padding(
padding: EdgeInsets.symmetric(vertical: 12),
child: Text(Strings.buttonStartToInstall),
),
),
],
),
);
void _downloadServerFile() {
context.read<InstallationBloc>().add((InstallationStartedEvent()));
}
}