stack_wallet/lib/pages/exchange_view/exchange_loading_overlay.dart

129 lines
3.8 KiB
Dart
Raw Permalink Normal View History

2023-05-26 21:21:16 +00:00
/*
* This file is part of Stack Wallet.
*
* Copyright (c) 2023 Cypher Stack
* All Rights Reserved.
* The code is distributed under GPLv3 license, see LICENSE file for details.
* Generated by Cypher Stack on 2023-05-26
*
*/
2022-08-26 08:11:35 +00:00
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
2024-05-27 23:56:22 +00:00
import '../../providers/exchange/changenow_initial_load_status.dart';
import '../../themes/stack_colors.dart';
import '../../utilities/text_styles.dart';
import '../../widgets/custom_loading_overlay.dart';
import '../../widgets/stack_dialog.dart';
2022-08-26 08:11:35 +00:00
class ExchangeLoadingOverlayView extends ConsumerStatefulWidget {
2022-09-09 14:03:36 +00:00
const ExchangeLoadingOverlayView({
2024-05-27 23:56:22 +00:00
super.key,
2022-09-09 14:03:36 +00:00
required this.unawaitedLoad,
2024-05-27 23:56:22 +00:00
});
2022-09-09 14:03:36 +00:00
final VoidCallback unawaitedLoad;
2022-08-26 08:11:35 +00:00
@override
ConsumerState<ExchangeLoadingOverlayView> createState() =>
_ExchangeLoadingOverlayViewState();
}
class _ExchangeLoadingOverlayViewState
extends ConsumerState<ExchangeLoadingOverlayView> {
late ChangeNowLoadStatus _statusEst;
late ChangeNowLoadStatus _statusFixed;
bool userReloaded = false;
@override
void initState() {
_statusEst =
ref.read(changeNowEstimatedInitialLoadStatusStateProvider.state).state;
_statusFixed =
ref.read(changeNowFixedInitialLoadStatusStateProvider.state).state;
super.initState();
}
@override
Widget build(BuildContext context) {
debugPrint("BUILD: $runtimeType");
ref.listen(
changeNowEstimatedInitialLoadStatusStateProvider
.select((value) => value), (previous, next) {
if (next is ChangeNowLoadStatus) {
setState(() {
_statusEst = next;
});
}
});
ref.listen(
changeNowFixedInitialLoadStatusStateProvider.select((value) => value),
(previous, next) {
if (next is ChangeNowLoadStatus) {
setState(() {
_statusFixed = next;
});
}
});
return Stack(
children: [
if (_statusEst == ChangeNowLoadStatus.loading ||
(_statusFixed == ChangeNowLoadStatus.loading && userReloaded))
Container(
color: Theme.of(context)
.extension<StackColors>()!
.overlay
.withOpacity(0.7),
2022-08-26 08:11:35 +00:00
child: const CustomLoadingOverlay(
2024-05-27 23:56:22 +00:00
message: "Loading Exchange data",
eventBus: null,
),
2022-08-26 08:11:35 +00:00
),
2022-09-09 14:03:36 +00:00
if ((_statusEst == ChangeNowLoadStatus.failed ||
_statusFixed == ChangeNowLoadStatus.failed) &&
_statusEst != ChangeNowLoadStatus.loading &&
_statusFixed != ChangeNowLoadStatus.loading)
2022-08-26 08:11:35 +00:00
Container(
color: Theme.of(context)
.extension<StackColors>()!
.overlay
.withOpacity(0.7),
2022-08-26 08:11:35 +00:00
child: Column(
mainAxisAlignment: MainAxisAlignment.end,
children: [
StackDialog(
title: "Failed to fetch Exchange data",
2022-08-26 08:11:35 +00:00
message:
"Exchange requires a working internet connection. Tap OK to try fetching again.",
2022-08-26 08:11:35 +00:00
rightButton: TextButton(
style: Theme.of(context)
.extension<StackColors>()!
2023-01-24 19:29:12 +00:00
.getSecondaryEnabledButtonStyle(context),
2022-08-26 08:11:35 +00:00
child: Text(
"OK",
2022-09-22 22:17:21 +00:00
style: STextStyles.button(context).copyWith(
color: Theme.of(context)
.extension<StackColors>()!
.buttonTextSecondary,
),
2022-08-26 08:11:35 +00:00
),
onPressed: () {
2022-09-09 14:03:36 +00:00
userReloaded = true;
widget.unawaitedLoad();
2022-08-26 08:11:35 +00:00
},
),
),
],
),
),
],
);
}
}