claude refactorings, flutter best practices, platform dependent changes, general cleanup
This commit is contained in:
@@ -7,7 +7,7 @@ import 'package:jiffy/jiffy.dart';
|
||||
import 'package:localstore/localstore.dart';
|
||||
|
||||
import '../../../widget/placeholder_view.dart';
|
||||
import '../../api/requestCache.dart';
|
||||
import '../../api/request_cache.dart';
|
||||
import 'json_viewer.dart';
|
||||
|
||||
class CacheView extends StatefulWidget {
|
||||
@@ -21,9 +21,9 @@ class CacheView extends StatefulWidget {
|
||||
}
|
||||
|
||||
Future<int> totalSize() async {
|
||||
var data = await Localstore.instance.collection(RequestCache.collection).get();
|
||||
if(data!.length <= 1) return jsonEncode(data.values.first).length * 8;
|
||||
return data.values.reduce((a, b) => jsonEncode(a).length + jsonEncode(b).length) * 8;
|
||||
final data = await Localstore.instance.collection(RequestCache.collection).get();
|
||||
if (data == null || data.isEmpty) return 0;
|
||||
return data.values.fold<int>(0, (sum, value) => sum + jsonEncode(value).length) * 8;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -49,15 +49,16 @@ class _CacheViewState extends State<CacheView> {
|
||||
return ListView.builder(
|
||||
itemCount: snapshot.data!.length,
|
||||
itemBuilder: (context, index) {
|
||||
Map<String, dynamic> element = snapshot.data![snapshot.data!.keys.elementAt(index)];
|
||||
var filename = snapshot.data!.keys.elementAt(index).split('/').last;
|
||||
final key = snapshot.data!.keys.elementAt(index);
|
||||
final element = snapshot.data![key] as Map<String, dynamic>;
|
||||
final filename = key.split('/').last;
|
||||
|
||||
return ListTile(
|
||||
leading: const Icon(Icons.text_snippet_outlined),
|
||||
title: Text(filename),
|
||||
subtitle: Text("${filesize(jsonEncode(element).length * 8)}, ${Jiffy.parseFromMillisecondsSinceEpoch(element['lastupdate']).fromNow()}"),
|
||||
subtitle: Text('${filesize(jsonEncode(element).length * 8)}, ${Jiffy.parseFromMillisecondsSinceEpoch(element['lastupdate'] as int).fromNow()}'),
|
||||
trailing: const Icon(Icons.arrow_right),
|
||||
onTap: () => JsonViewer.asDialog(context, jsonDecode(element['json'])),
|
||||
onTap: () => JsonViewer.asDialog(context, jsonDecode(element['json'] as String) as Map<String, dynamic>),
|
||||
);
|
||||
},
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user