🐛 Fixes of serval bugs
This commit is contained in:
@@ -13,6 +13,7 @@ import 'package:island/widgets/content/sheet.dart';
|
|||||||
import 'package:island/widgets/file_list_view.dart';
|
import 'package:island/widgets/file_list_view.dart';
|
||||||
import 'package:island/widgets/usage_overview.dart';
|
import 'package:island/widgets/usage_overview.dart';
|
||||||
import 'package:material_symbols_icons/symbols.dart';
|
import 'package:material_symbols_icons/symbols.dart';
|
||||||
|
import 'package:styled_widget/styled_widget.dart';
|
||||||
|
|
||||||
class FileListScreen extends HookConsumerWidget {
|
class FileListScreen extends HookConsumerWidget {
|
||||||
const FileListScreen({super.key});
|
const FileListScreen({super.key});
|
||||||
@@ -196,7 +197,10 @@ class FileListScreen extends HookConsumerWidget {
|
|||||||
builder:
|
builder:
|
||||||
(context) => SheetScaffold(
|
(context) => SheetScaffold(
|
||||||
titleText: 'Usage Overview',
|
titleText: 'Usage Overview',
|
||||||
child: UsageOverviewWidget(usage: usage, quota: quota),
|
child: UsageOverviewWidget(
|
||||||
|
usage: usage,
|
||||||
|
quota: quota,
|
||||||
|
).padding(horizontal: 8, vertical: 16),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,5 +5,11 @@ String formatFileSize(int bytes) {
|
|||||||
if (bytes < 1024 * 1024 * 1024) {
|
if (bytes < 1024 * 1024 * 1024) {
|
||||||
return '${(bytes / (1024 * 1024)).toStringAsFixed(2)} MB';
|
return '${(bytes / (1024 * 1024)).toStringAsFixed(2)} MB';
|
||||||
}
|
}
|
||||||
return '${(bytes / (1024 * 1024 * 1024)).toStringAsFixed(2)} GB';
|
if (bytes < 1024 * 1024 * 1024 * 1024) {
|
||||||
|
return '${(bytes / (1024 * 1024 * 1024)).toStringAsFixed(2)} GB';
|
||||||
|
}
|
||||||
|
if (bytes < 1024 * 1024 * 1024 * 1024 * 1024) {
|
||||||
|
return '${(bytes / (1024 * 1024 * 1024 * 1024)).toStringAsFixed(2)} TB';
|
||||||
|
}
|
||||||
|
return '${(bytes / (1024 * 1024 * 1024 * 1024 * 1024)).toStringAsFixed(2)} PB';
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,12 @@
|
|||||||
|
import 'dart:async';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
||||||
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||||
import 'package:cached_network_image/cached_network_image.dart';
|
import 'package:cached_network_image/cached_network_image.dart';
|
||||||
import 'package:island/models/account.dart';
|
import 'package:island/models/account.dart';
|
||||||
import 'package:island/pods/network.dart';
|
import 'package:island/pods/network.dart';
|
||||||
import 'package:island/pods/config.dart';
|
import 'package:island/pods/config.dart';
|
||||||
|
import 'package:island/widgets/account/account_pfc.dart';
|
||||||
import 'package:material_symbols_icons/material_symbols_icons.dart';
|
import 'package:material_symbols_icons/material_symbols_icons.dart';
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||||
import 'package:styled_widget/styled_widget.dart';
|
import 'package:styled_widget/styled_widget.dart';
|
||||||
@@ -20,11 +23,20 @@ Future<List<SnFriendOverviewItem>> friendsOverview(Ref ref) async {
|
|||||||
.toList();
|
.toList();
|
||||||
}
|
}
|
||||||
|
|
||||||
class FriendsOverviewWidget extends ConsumerWidget {
|
class FriendsOverviewWidget extends HookConsumerWidget {
|
||||||
const FriendsOverviewWidget({super.key});
|
const FriendsOverviewWidget({super.key});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
Widget build(BuildContext context, WidgetRef ref) {
|
||||||
|
// Set up periodic refresh every minute
|
||||||
|
useEffect(() {
|
||||||
|
final timer = Timer.periodic(const Duration(minutes: 1), (_) {
|
||||||
|
ref.invalidate(friendsOverviewProvider);
|
||||||
|
});
|
||||||
|
|
||||||
|
return () => timer.cancel(); // Cleanup when widget is disposed
|
||||||
|
}, const []);
|
||||||
|
|
||||||
final friendsOverviewAsync = ref.watch(friendsOverviewProvider);
|
final friendsOverviewAsync = ref.watch(friendsOverviewProvider);
|
||||||
|
|
||||||
return friendsOverviewAsync.when(
|
return friendsOverviewAsync.when(
|
||||||
@@ -53,7 +65,10 @@ class FriendsOverviewWidget extends ConsumerWidget {
|
|||||||
itemCount: onlineFriends.length,
|
itemCount: onlineFriends.length,
|
||||||
itemBuilder: (context, index) {
|
itemBuilder: (context, index) {
|
||||||
final friend = onlineFriends[index];
|
final friend = onlineFriends[index];
|
||||||
return _FriendTile(friend: friend);
|
return AccountPfcGestureDetector(
|
||||||
|
uname: friend.account.name,
|
||||||
|
child: _FriendTile(friend: friend),
|
||||||
|
);
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -444,7 +444,7 @@ class ThoughtChatInterface extends HookConsumerWidget {
|
|||||||
top: 16,
|
top: 16,
|
||||||
bottom:
|
bottom:
|
||||||
MediaQuery.of(context).padding.bottom +
|
MediaQuery.of(context).padding.bottom +
|
||||||
56 +
|
8 +
|
||||||
inputHeight.value, // Leave space for thought input
|
inputHeight.value, // Leave space for thought input
|
||||||
),
|
),
|
||||||
reverse: true,
|
reverse: true,
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import 'package:fl_chart/fl_chart.dart';
|
import 'package:fl_chart/fl_chart.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:gap/gap.dart';
|
import 'package:gap/gap.dart';
|
||||||
|
import 'package:island/utils/format.dart';
|
||||||
import 'package:styled_widget/styled_widget.dart';
|
import 'package:styled_widget/styled_widget.dart';
|
||||||
|
|
||||||
class UsageOverviewWidget extends StatelessWidget {
|
class UsageOverviewWidget extends StatelessWidget {
|
||||||
@@ -26,7 +27,7 @@ class UsageOverviewWidget extends StatelessWidget {
|
|||||||
Expanded(
|
Expanded(
|
||||||
child: _buildStatCard(
|
child: _buildStatCard(
|
||||||
'All Uploads',
|
'All Uploads',
|
||||||
'${((nonNullUsage['total_usage_bytes'] as num) / (1024 * 1024 * 1024)).toStringAsFixed(3)} GiB',
|
formatFileSize(nonNullUsage['total_usage_bytes'] as int),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Expanded(
|
Expanded(
|
||||||
@@ -42,7 +43,9 @@ class UsageOverviewWidget extends StatelessWidget {
|
|||||||
Expanded(
|
Expanded(
|
||||||
child: _buildStatCard(
|
child: _buildStatCard(
|
||||||
'Quota',
|
'Quota',
|
||||||
'${nonNullUsage['total_quota']} MiB',
|
formatFileSize(
|
||||||
|
(nonNullUsage['total_quota'] as int) * 1024 * 1024,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Expanded(
|
Expanded(
|
||||||
|
|||||||
Reference in New Issue
Block a user