🐛 Fixes of serval bugs

This commit is contained in:
2025-11-16 17:40:37 +08:00
parent 82397dd087
commit 98f4698d5b
5 changed files with 36 additions and 8 deletions

View File

@@ -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),
), ),
); );
} }

View File

@@ -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';
} }
if (bytes < 1024 * 1024 * 1024 * 1024) {
return '${(bytes / (1024 * 1024 * 1024)).toStringAsFixed(2)} GB'; 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';
}

View File

@@ -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),
);
}, },
), ),
), ),

View File

@@ -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,

View File

@@ -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(