import 'dart:collection'; import 'package:flutter/material.dart'; import 'package:selfprivacy/config/brand_colors.dart'; import 'package:selfprivacy/config/get_it_config.dart'; import 'package:selfprivacy/logic/models/message.dart'; import 'package:selfprivacy/ui/components/brand_header/brand_header.dart'; class Console extends StatefulWidget { const Console({final super.key}); @override State createState() => _ConsoleState(); } class _ConsoleState extends State { @override void initState() { getIt.get().addListener(update); super.initState(); } @override void dispose() { getIt().removeListener(update); super.dispose(); } void update() => setState(() => {}); @override Widget build(final BuildContext context) => SafeArea( child: Scaffold( appBar: PreferredSize( preferredSize: const Size.fromHeight(53), child: Column( children: const [ BrandHeader(title: 'Console', hasBackButton: true) ], ), ), body: FutureBuilder( future: getIt.allReady(), builder: ( final BuildContext context, final AsyncSnapshot snapshot, ) { if (snapshot.hasData) { final List messages = getIt.get().messages; return ListView( reverse: true, shrinkWrap: true, children: [ const SizedBox(height: 20), ...UnmodifiableListView( messages .map((final message) { final bool isError = message.type == MessageType.warning; return Padding( padding: const EdgeInsets.symmetric(vertical: 4), child: RichText( text: TextSpan( style: DefaultTextStyle.of(context).style, children: [ TextSpan( text: '${message.timeString}${isError ? '(Error)' : ''}: \n', style: TextStyle( fontWeight: FontWeight.bold, color: isError ? BrandColors.red1 : null, ), ), TextSpan(text: message.text), ], ), ), ); }) .toList() .reversed, ), ], ); } else { return Column( mainAxisAlignment: MainAxisAlignment.center, mainAxisSize: MainAxisSize.min, children: const [ Text('Waiting for initialisation'), SizedBox( height: 16, ), CircularProgressIndicator(), ], ); } }, ), ), ); }