Merge remote-tracking branch 'origin/develop' into develop

This commit is contained in:
Hosted Weblate 2025-03-25 22:58:55 +01:00
commit 83603de8ed
No known key found for this signature in database
GPG key ID: A3FAAA06E6569B4C

View file

@ -1,3 +1,7 @@
import 'dart:io';
import 'package:aves/ref/locales.dart';
import 'package:aves/utils/file_utils.dart';
import 'package:aves/widgets/common/identity/aves_expansion_tile.dart'; import 'package:aves/widgets/common/identity/aves_expansion_tile.dart';
import 'package:collection/collection.dart'; import 'package:collection/collection.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
@ -95,21 +99,60 @@ class _CollectorOverlayState extends State<_CollectorOverlay> {
child: SafeArea( child: SafeArea(
child: Container( child: Container(
color: Colors.indigo.shade900.withAlpha(0xCC), color: Colors.indigo.shade900.withAlpha(0xCC),
child: Row(mainAxisSize: MainAxisSize.min, children: [ child: Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Wrap(
crossAxisAlignment: WrapCrossAlignment.center,
children: [
IconButton( IconButton(
onPressed: () => setState(() => _alignment = _alignment == AlignmentDirectional.bottomStart ? AlignmentDirectional.topStart : AlignmentDirectional.bottomStart), onPressed: () => setState(() => _alignment = _alignment == AlignmentDirectional.bottomStart ? AlignmentDirectional.topStart : AlignmentDirectional.bottomStart),
icon: Icon(_alignment == AlignmentDirectional.bottomStart ? Icons.vertical_align_top_outlined : Icons.vertical_align_bottom_outlined), icon: Icon(_alignment == AlignmentDirectional.bottomStart ? Icons.vertical_align_top_outlined : Icons.vertical_align_bottom_outlined),
), ),
...LeakType.values.map((type) { ...LeakType.values.map((type) {
return TextButton( return OutlinedButton(
style: ButtonStyle(
padding: WidgetStateProperty.all(const EdgeInsets.all(6)),
minimumSize: WidgetStateProperty.all(Size.zero),
),
onPressed: () => LeakTracking.collectLeaks().then((leaks) { onPressed: () => LeakTracking.collectLeaks().then((leaks) {
final reports = leaks.byType[type] ?? []; final reports = leaks.byType[type] ?? [];
_printLeaks(type, reports); _printLeaks(type, reports);
}), }),
child: Text(type.name), child: Text(type.name),
); );
}) }),
]), ],
),
Wrap(
crossAxisAlignment: WrapCrossAlignment.center,
children: [
StreamBuilder(
stream: Stream.periodic(const Duration(seconds: 1)),
builder: (context, snapshot) {
final currentRss = formatFileSize(asciiLocale, ProcessInfo.currentRss);
final maxRss = formatFileSize(asciiLocale, ProcessInfo.maxRss);
return Text('RSS: $currentRss / $maxRss');
},
),
],
),
Wrap(
crossAxisAlignment: WrapCrossAlignment.center,
children: [
StreamBuilder(
stream: Stream.periodic(const Duration(seconds: 1)),
builder: (context, snapshot) {
final currentImageCache = formatFileSize(asciiLocale, imageCache.currentSizeBytes);
final maxImageCache = formatFileSize(asciiLocale, imageCache.maximumSizeBytes);
return Text('imageCache: $currentImageCache / $maxImageCache');
},
),
],
),
],
),
), ),
), ),
), ),