MCSI-1 refactor: rename vanila -> vanilla
This commit is contained in:
parent
b1aa09bf57
commit
6e85c7ff06
@ -2,10 +2,10 @@ import 'package:flutter/material.dart';
|
|||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||||
import 'package:gap/gap.dart';
|
import 'package:gap/gap.dart';
|
||||||
import 'package:minecraft_server_installer/main/framework/ui/strings.dart';
|
import 'package:minecraft_server_installer/main/framework/ui/strings.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_bloc.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_bloc.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/game_version_view_model.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/game_version_view_model.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_state.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_state.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/framework/ui/game_version_dropdown.dart';
|
import 'package:minecraft_server_installer/vanilla/framework/ui/game_version_dropdown.dart';
|
||||||
|
|
||||||
class BasicConfigurationTab extends StatefulWidget {
|
class BasicConfigurationTab extends StatefulWidget {
|
||||||
const BasicConfigurationTab({super.key});
|
const BasicConfigurationTab({super.key});
|
||||||
@ -23,7 +23,7 @@ class _BasicConfigurationTabState extends State<BasicConfigurationTab> {
|
|||||||
children: [
|
children: [
|
||||||
const GameVersionDropdown(),
|
const GameVersionDropdown(),
|
||||||
const Spacer(),
|
const Spacer(),
|
||||||
BlocConsumer<VanilaBloc, VanilaState>(
|
BlocConsumer<VanillaBloc, VanillaState>(
|
||||||
listener: (_, __) {},
|
listener: (_, __) {},
|
||||||
builder:
|
builder:
|
||||||
(context, state) => Row(
|
(context, state) => Row(
|
||||||
@ -50,6 +50,6 @@ class _BasicConfigurationTabState extends State<BasicConfigurationTab> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void _downloadServerFile() {
|
void _downloadServerFile() {
|
||||||
context.read<VanilaBloc>().add(VanilaServerFileDownloadedEvent());
|
context.read<VanillaBloc>().add(VanillaServerFileDownloadedEvent());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||||
import 'package:minecraft_server_installer/main/framework/ui/basic_configuration_tab.dart';
|
import 'package:minecraft_server_installer/main/framework/ui/basic_configuration_tab.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/gateway/vanila_repository_impl.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/gateway/vanilla_repository_impl.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_bloc.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_bloc.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_state.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_state.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/get_game_version_list_use_case.dart';
|
import 'package:minecraft_server_installer/vanilla/application/use_case/get_game_version_list_use_case.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/framework/api/vanila_api_service_impl.dart';
|
import 'package:minecraft_server_installer/vanilla/framework/api/vanilla_api_service_impl.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/framework/storage/vanila_file_storage_impl.dart';
|
import 'package:minecraft_server_installer/vanilla/framework/storage/vanilla_file_storage_impl.dart';
|
||||||
|
|
||||||
class MinecraftServerInstaller extends StatelessWidget {
|
class MinecraftServerInstaller extends StatelessWidget {
|
||||||
const MinecraftServerInstaller({super.key});
|
const MinecraftServerInstaller({super.key});
|
||||||
@ -17,9 +17,9 @@ class MinecraftServerInstaller extends StatelessWidget {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final gameVersionApiService = VanilaApiServiceImpl();
|
final gameVersionApiService = VanillaApiServiceImpl();
|
||||||
final gameVersionFileStorage = VanilaFileStorageImpl();
|
final gameVersionFileStorage = VanillaFileStorageImpl();
|
||||||
final gameVersionRepository = VanilaRepositoryImpl(gameVersionApiService, gameVersionFileStorage);
|
final gameVersionRepository = VanillaRepositoryImpl(gameVersionApiService, gameVersionFileStorage);
|
||||||
final getGameVersionListUseCase = GetGameVersionListUseCase(gameVersionRepository);
|
final getGameVersionListUseCase = GetGameVersionListUseCase(gameVersionRepository);
|
||||||
final downloadServerFileUseCase = DownloadServerFileUseCase(gameVersionRepository);
|
final downloadServerFileUseCase = DownloadServerFileUseCase(gameVersionRepository);
|
||||||
|
|
||||||
@ -28,15 +28,15 @@ class MinecraftServerInstaller extends StatelessWidget {
|
|||||||
theme: ThemeData.light().copyWith(colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue.shade900)),
|
theme: ThemeData.light().copyWith(colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue.shade900)),
|
||||||
home: MultiBlocProvider(
|
home: MultiBlocProvider(
|
||||||
providers: [
|
providers: [
|
||||||
BlocProvider<VanilaBloc>(
|
BlocProvider<VanillaBloc>(
|
||||||
create:
|
create:
|
||||||
(context) =>
|
(context) =>
|
||||||
VanilaBloc(getGameVersionListUseCase, downloadServerFileUseCase)
|
VanillaBloc(getGameVersionListUseCase, downloadServerFileUseCase)
|
||||||
..add(VanilaGameVersionListLoadedEvent()),
|
..add(VanillaGameVersionListLoadedEvent()),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
child: Scaffold(
|
child: Scaffold(
|
||||||
body: BlocConsumer<VanilaBloc, VanilaState>(
|
body: BlocConsumer<VanillaBloc, VanillaState>(
|
||||||
listener: (_, __) {},
|
listener: (_, __) {},
|
||||||
builder: (_, state) {
|
builder: (_, state) {
|
||||||
if (state.isLocked) {
|
if (state.isLocked) {
|
||||||
|
@ -1,10 +0,0 @@
|
|||||||
import 'dart:typed_data';
|
|
||||||
|
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
|
||||||
|
|
||||||
abstract interface class VanilaApiService {
|
|
||||||
Future<List<GameVersion>> fetchGameVersionList();
|
|
||||||
|
|
||||||
Future<Uint8List> fetchServerFile(Uri url, {DownloadProgressCallback? onProgressChanged});
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
import 'package:minecraft_server_installer/vanila/adapter/gateway/vanila_api_service.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/gateway/vanila_file_storage.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/application/repository/vanila_repository.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
|
||||||
|
|
||||||
class VanilaRepositoryImpl implements VanilaRepository {
|
|
||||||
final VanilaApiService _gameVersionApiService;
|
|
||||||
final VanilaFileStorage _gameVersionFileStorage;
|
|
||||||
|
|
||||||
VanilaRepositoryImpl(this._gameVersionApiService, this._gameVersionFileStorage);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Future<List<GameVersion>> getGameVersionList() => _gameVersionApiService.fetchGameVersionList();
|
|
||||||
|
|
||||||
@override
|
|
||||||
Future<void> downloadServerFile(
|
|
||||||
GameVersion version,
|
|
||||||
String savePath, {
|
|
||||||
DownloadProgressCallback? onProgressChanged,
|
|
||||||
}) async {
|
|
||||||
final fileBytes = await _gameVersionApiService.fetchServerFile(version.url, onProgressChanged: onProgressChanged);
|
|
||||||
await _gameVersionFileStorage.saveFile(fileBytes, savePath);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,74 +0,0 @@
|
|||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
||||||
import 'package:minecraft_server_installer/main/constants.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/game_version_view_model.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_state.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/get_game_version_list_use_case.dart';
|
|
||||||
import 'package:path/path.dart' as path;
|
|
||||||
|
|
||||||
class VanilaBloc extends Bloc<VanilaEvent, VanilaState> {
|
|
||||||
final GetGameVersionListUseCase _getGameVersionListUseCase;
|
|
||||||
final DownloadServerFileUseCase _downloadServerFileUseCase;
|
|
||||||
|
|
||||||
VanilaBloc(this._getGameVersionListUseCase, this._downloadServerFileUseCase) : super(const VanilaState.empty()) {
|
|
||||||
on<VanilaGameVersionListLoadedEvent>((_, emit) async {
|
|
||||||
try {
|
|
||||||
final gameVersions = await _getGameVersionListUseCase();
|
|
||||||
emit(
|
|
||||||
const VanilaState.empty().copyWith(
|
|
||||||
gameVersions: gameVersions.map((entity) => GameVersionViewModel.from(entity)).toList(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
} on Exception {
|
|
||||||
emit(const VanilaState.empty());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
on<VanilaGameVersionSelectedEvent>((event, emit) {
|
|
||||||
emit(state.copyWith(selectedGameVersion: event.gameVersion));
|
|
||||||
});
|
|
||||||
|
|
||||||
on<VanilaServerFileDownloadedEvent>((_, emit) async {
|
|
||||||
final gameVersion = state.selectedGameVersion;
|
|
||||||
if (gameVersion == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
emit(state.copyWith(isLocked: true));
|
|
||||||
await _downloadServerFileUseCase(
|
|
||||||
gameVersion.toEntity(),
|
|
||||||
path.join('.', Constants.serverFileName),
|
|
||||||
onProgressChanged: (progress) => add(_VanilaDownloadProgressChangedEvent(progress)),
|
|
||||||
);
|
|
||||||
emit(state.copyWith(isLocked: false));
|
|
||||||
});
|
|
||||||
|
|
||||||
on<_VanilaDownloadProgressChangedEvent>((event, emit) {
|
|
||||||
if (event.progress < 0) {
|
|
||||||
emit(state.copyWith(downloadProgress: 0));
|
|
||||||
} else if (event.progress > 1) {
|
|
||||||
emit(state.copyWith(downloadProgress: 1));
|
|
||||||
} else {
|
|
||||||
emit(state.copyWith(downloadProgress: event.progress));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sealed class VanilaEvent {}
|
|
||||||
|
|
||||||
class VanilaGameVersionListLoadedEvent extends VanilaEvent {}
|
|
||||||
|
|
||||||
class VanilaGameVersionSelectedEvent extends VanilaEvent {
|
|
||||||
final GameVersionViewModel gameVersion;
|
|
||||||
|
|
||||||
VanilaGameVersionSelectedEvent(this.gameVersion);
|
|
||||||
}
|
|
||||||
|
|
||||||
class VanilaServerFileDownloadedEvent extends VanilaEvent {}
|
|
||||||
|
|
||||||
class _VanilaDownloadProgressChangedEvent extends VanilaEvent {
|
|
||||||
final double progress;
|
|
||||||
|
|
||||||
_VanilaDownloadProgressChangedEvent(this.progress);
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
|
||||||
|
|
||||||
abstract interface class VanilaRepository {
|
|
||||||
Future<List<GameVersion>> getGameVersionList();
|
|
||||||
|
|
||||||
Future<void> downloadServerFile(GameVersion version, String savePath, {DownloadProgressCallback? onProgressChanged});
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
import 'package:minecraft_server_installer/vanila/application/repository/vanila_repository.dart';
|
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
|
||||||
|
|
||||||
class GetGameVersionListUseCase {
|
|
||||||
final VanilaRepository _gameVersionRepository;
|
|
||||||
|
|
||||||
GetGameVersionListUseCase(this._gameVersionRepository);
|
|
||||||
|
|
||||||
Future<List<GameVersion>> call() => _gameVersionRepository.getGameVersionList();
|
|
||||||
}
|
|
10
lib/vanilla/adapter/gateway/vanilla_api_service.dart
Normal file
10
lib/vanilla/adapter/gateway/vanilla_api_service.dart
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
import 'dart:typed_data';
|
||||||
|
|
||||||
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
|
abstract interface class VanillaApiService {
|
||||||
|
Future<List<GameVersion>> fetchGameVersionList();
|
||||||
|
|
||||||
|
Future<Uint8List> fetchServerFile(Uri url, {DownloadProgressCallback? onProgressChanged});
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
import 'dart:typed_data';
|
import 'dart:typed_data';
|
||||||
|
|
||||||
abstract interface class VanilaFileStorage {
|
abstract interface class VanillaFileStorage {
|
||||||
Future<void> saveFile(Uint8List fileBytes, String savePath);
|
Future<void> saveFile(Uint8List fileBytes, String savePath);
|
||||||
}
|
}
|
25
lib/vanilla/adapter/gateway/vanilla_repository_impl.dart
Normal file
25
lib/vanilla/adapter/gateway/vanilla_repository_impl.dart
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import 'package:minecraft_server_installer/vanilla/adapter/gateway/vanilla_api_service.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/adapter/gateway/vanilla_file_storage.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/application/repository/vanilla_repository.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
|
class VanillaRepositoryImpl implements VanillaRepository {
|
||||||
|
final VanillaApiService _gameVersionApiService;
|
||||||
|
final VanillaFileStorage _gameVersionFileStorage;
|
||||||
|
|
||||||
|
VanillaRepositoryImpl(this._gameVersionApiService, this._gameVersionFileStorage);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<List<GameVersion>> getGameVersionList() => _gameVersionApiService.fetchGameVersionList();
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<void> downloadServerFile(
|
||||||
|
GameVersion version,
|
||||||
|
String savePath, {
|
||||||
|
DownloadProgressCallback? onProgressChanged,
|
||||||
|
}) async {
|
||||||
|
final fileBytes = await _gameVersionApiService.fetchServerFile(version.url, onProgressChanged: onProgressChanged);
|
||||||
|
await _gameVersionFileStorage.saveFile(fileBytes, savePath);
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
import 'package:equatable/equatable.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
class GameVersionViewModel with EquatableMixin {
|
class GameVersionViewModel with EquatableMixin {
|
||||||
final String name;
|
final String name;
|
74
lib/vanilla/adapter/presentation/vanilla_bloc.dart
Normal file
74
lib/vanilla/adapter/presentation/vanilla_bloc.dart
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||||
|
import 'package:minecraft_server_installer/main/constants.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/game_version_view_model.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_state.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/application/use_case/get_game_version_list_use_case.dart';
|
||||||
|
import 'package:path/path.dart' as path;
|
||||||
|
|
||||||
|
class VanillaBloc extends Bloc<VanillaEvent, VanillaState> {
|
||||||
|
final GetGameVersionListUseCase _getGameVersionListUseCase;
|
||||||
|
final DownloadServerFileUseCase _downloadServerFileUseCase;
|
||||||
|
|
||||||
|
VanillaBloc(this._getGameVersionListUseCase, this._downloadServerFileUseCase) : super(const VanillaState.empty()) {
|
||||||
|
on<VanillaGameVersionListLoadedEvent>((_, emit) async {
|
||||||
|
try {
|
||||||
|
final gameVersions = await _getGameVersionListUseCase();
|
||||||
|
emit(
|
||||||
|
const VanillaState.empty().copyWith(
|
||||||
|
gameVersions: gameVersions.map((entity) => GameVersionViewModel.from(entity)).toList(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
} on Exception {
|
||||||
|
emit(const VanillaState.empty());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
on<VanillaGameVersionSelectedEvent>((event, emit) {
|
||||||
|
emit(state.copyWith(selectedGameVersion: event.gameVersion));
|
||||||
|
});
|
||||||
|
|
||||||
|
on<VanillaServerFileDownloadedEvent>((_, emit) async {
|
||||||
|
final gameVersion = state.selectedGameVersion;
|
||||||
|
if (gameVersion == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
emit(state.copyWith(isLocked: true));
|
||||||
|
await _downloadServerFileUseCase(
|
||||||
|
gameVersion.toEntity(),
|
||||||
|
path.join('.', Constants.serverFileName),
|
||||||
|
onProgressChanged: (progress) => add(_VanillaDownloadProgressChangedEvent(progress)),
|
||||||
|
);
|
||||||
|
emit(state.copyWith(isLocked: false));
|
||||||
|
});
|
||||||
|
|
||||||
|
on<_VanillaDownloadProgressChangedEvent>((event, emit) {
|
||||||
|
if (event.progress < 0) {
|
||||||
|
emit(state.copyWith(downloadProgress: 0));
|
||||||
|
} else if (event.progress > 1) {
|
||||||
|
emit(state.copyWith(downloadProgress: 1));
|
||||||
|
} else {
|
||||||
|
emit(state.copyWith(downloadProgress: event.progress));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sealed class VanillaEvent {}
|
||||||
|
|
||||||
|
class VanillaGameVersionListLoadedEvent extends VanillaEvent {}
|
||||||
|
|
||||||
|
class VanillaGameVersionSelectedEvent extends VanillaEvent {
|
||||||
|
final GameVersionViewModel gameVersion;
|
||||||
|
|
||||||
|
VanillaGameVersionSelectedEvent(this.gameVersion);
|
||||||
|
}
|
||||||
|
|
||||||
|
class VanillaServerFileDownloadedEvent extends VanillaEvent {}
|
||||||
|
|
||||||
|
class _VanillaDownloadProgressChangedEvent extends VanillaEvent {
|
||||||
|
final double progress;
|
||||||
|
|
||||||
|
_VanillaDownloadProgressChangedEvent(this.progress);
|
||||||
|
}
|
@ -1,20 +1,20 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
import 'package:equatable/equatable.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/game_version_view_model.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/game_version_view_model.dart';
|
||||||
|
|
||||||
class VanilaState with EquatableMixin {
|
class VanillaState with EquatableMixin {
|
||||||
final bool isLocked;
|
final bool isLocked;
|
||||||
final double downloadProgress;
|
final double downloadProgress;
|
||||||
final List<GameVersionViewModel> gameVersions;
|
final List<GameVersionViewModel> gameVersions;
|
||||||
final GameVersionViewModel? selectedGameVersion;
|
final GameVersionViewModel? selectedGameVersion;
|
||||||
|
|
||||||
const VanilaState({
|
const VanillaState({
|
||||||
required this.isLocked,
|
required this.isLocked,
|
||||||
required this.downloadProgress,
|
required this.downloadProgress,
|
||||||
required this.gameVersions,
|
required this.gameVersions,
|
||||||
required this.selectedGameVersion,
|
required this.selectedGameVersion,
|
||||||
});
|
});
|
||||||
|
|
||||||
const VanilaState.empty()
|
const VanillaState.empty()
|
||||||
: this(isLocked: false, downloadProgress: 0, gameVersions: const [], selectedGameVersion: null);
|
: this(isLocked: false, downloadProgress: 0, gameVersions: const [], selectedGameVersion: null);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
@ -24,12 +24,12 @@ class VanilaState with EquatableMixin {
|
|||||||
|
|
||||||
bool get isDownloading => downloadProgress > 0 && downloadProgress < 1;
|
bool get isDownloading => downloadProgress > 0 && downloadProgress < 1;
|
||||||
|
|
||||||
VanilaState copyWith({
|
VanillaState copyWith({
|
||||||
bool? isLocked,
|
bool? isLocked,
|
||||||
double? downloadProgress,
|
double? downloadProgress,
|
||||||
List<GameVersionViewModel>? gameVersions,
|
List<GameVersionViewModel>? gameVersions,
|
||||||
GameVersionViewModel? selectedGameVersion,
|
GameVersionViewModel? selectedGameVersion,
|
||||||
}) => VanilaState(
|
}) => VanillaState(
|
||||||
isLocked: isLocked ?? this.isLocked,
|
isLocked: isLocked ?? this.isLocked,
|
||||||
downloadProgress: downloadProgress ?? this.downloadProgress,
|
downloadProgress: downloadProgress ?? this.downloadProgress,
|
||||||
gameVersions: gameVersions ?? this.gameVersions,
|
gameVersions: gameVersions ?? this.gameVersions,
|
@ -0,0 +1,8 @@
|
|||||||
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
|
abstract interface class VanillaRepository {
|
||||||
|
Future<List<GameVersion>> getGameVersionList();
|
||||||
|
|
||||||
|
Future<void> downloadServerFile(GameVersion version, String savePath, {DownloadProgressCallback? onProgressChanged});
|
||||||
|
}
|
@ -1,10 +1,10 @@
|
|||||||
import 'package:minecraft_server_installer/vanila/application/repository/vanila_repository.dart';
|
import 'package:minecraft_server_installer/vanilla/application/repository/vanilla_repository.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
typedef DownloadProgressCallback = void Function(double progress);
|
typedef DownloadProgressCallback = void Function(double progress);
|
||||||
|
|
||||||
class DownloadServerFileUseCase {
|
class DownloadServerFileUseCase {
|
||||||
final VanilaRepository _gameVersionRepository;
|
final VanillaRepository _gameVersionRepository;
|
||||||
|
|
||||||
DownloadServerFileUseCase(this._gameVersionRepository);
|
DownloadServerFileUseCase(this._gameVersionRepository);
|
||||||
|
|
@ -0,0 +1,10 @@
|
|||||||
|
import 'package:minecraft_server_installer/vanilla/application/repository/vanilla_repository.dart';
|
||||||
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
|
class GetGameVersionListUseCase {
|
||||||
|
final VanillaRepository _gameVersionRepository;
|
||||||
|
|
||||||
|
GetGameVersionListUseCase(this._gameVersionRepository);
|
||||||
|
|
||||||
|
Future<List<GameVersion>> call() => _gameVersionRepository.getGameVersionList();
|
||||||
|
}
|
@ -3,11 +3,11 @@ import 'dart:typed_data';
|
|||||||
|
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
import 'package:minecraft_server_installer/main/constants.dart';
|
import 'package:minecraft_server_installer/main/constants.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/gateway/vanila_api_service.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/gateway/vanilla_api_service.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/application/use_case/download_server_file_use_case.dart';
|
import 'package:minecraft_server_installer/vanilla/application/use_case/download_server_file_use_case.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/domain/entity/game_version.dart';
|
import 'package:minecraft_server_installer/vanilla/domain/entity/game_version.dart';
|
||||||
|
|
||||||
class VanilaApiServiceImpl implements VanilaApiService {
|
class VanillaApiServiceImpl implements VanillaApiService {
|
||||||
@override
|
@override
|
||||||
Future<List<GameVersion>> fetchGameVersionList() async {
|
Future<List<GameVersion>> fetchGameVersionList() async {
|
||||||
final sourceUrl = Uri.parse(Constants.gameVersionListUrl);
|
final sourceUrl = Uri.parse(Constants.gameVersionListUrl);
|
@ -1,9 +1,9 @@
|
|||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
import 'dart:typed_data';
|
import 'dart:typed_data';
|
||||||
|
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/gateway/vanila_file_storage.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/gateway/vanilla_file_storage.dart';
|
||||||
|
|
||||||
class VanilaFileStorageImpl implements VanilaFileStorage {
|
class VanillaFileStorageImpl implements VanillaFileStorage {
|
||||||
@override
|
@override
|
||||||
Future<void> saveFile(Uint8List fileBytes, String savePath) async {
|
Future<void> saveFile(Uint8List fileBytes, String savePath) async {
|
||||||
final file = File(savePath);
|
final file = File(savePath);
|
@ -1,15 +1,15 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||||
import 'package:minecraft_server_installer/main/framework/ui/strings.dart';
|
import 'package:minecraft_server_installer/main/framework/ui/strings.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_bloc.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_bloc.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/game_version_view_model.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/game_version_view_model.dart';
|
||||||
import 'package:minecraft_server_installer/vanila/adapter/presentation/vanila_state.dart';
|
import 'package:minecraft_server_installer/vanilla/adapter/presentation/vanilla_state.dart';
|
||||||
|
|
||||||
class GameVersionDropdown extends StatelessWidget {
|
class GameVersionDropdown extends StatelessWidget {
|
||||||
const GameVersionDropdown({super.key});
|
const GameVersionDropdown({super.key});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) => BlocConsumer<VanilaBloc, VanilaState>(
|
Widget build(BuildContext context) => BlocConsumer<VanillaBloc, VanillaState>(
|
||||||
listener: (_, __) {},
|
listener: (_, __) {},
|
||||||
builder:
|
builder:
|
||||||
(_, state) => DropdownMenu(
|
(_, state) => DropdownMenu(
|
||||||
@ -20,7 +20,7 @@ class GameVersionDropdown extends StatelessWidget {
|
|||||||
label: const Text('${Strings.fieldGameVersion} *'),
|
label: const Text('${Strings.fieldGameVersion} *'),
|
||||||
onSelected: (value) {
|
onSelected: (value) {
|
||||||
if (value != null) {
|
if (value != null) {
|
||||||
context.read<VanilaBloc>().add(VanilaGameVersionSelectedEvent(value));
|
context.read<VanillaBloc>().add(VanillaGameVersionSelectedEvent(value));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
dropdownMenuEntries:
|
dropdownMenuEntries:
|
Loading…
x
Reference in New Issue
Block a user