drift/moor_flutter/example/lib/widgets/homescreen.dart

95 lines
2.9 KiB
Dart

import 'package:flutter/material.dart' hide Column;
import 'package:flutter/widgets.dart' as f show Column;
import 'package:moor_example/bloc.dart';
import 'package:moor_example/database/database.dart';
import 'package:moor_example/widgets/categories_drawer.dart';
import 'package:moor_example/widgets/todo_card.dart';
import 'package:provider/provider.dart';
// ignore_for_file: prefer_const_constructors
class HomeScreen extends StatefulWidget {
@override
HomeScreenState createState() {
return HomeScreenState();
}
}
/// Shows a list of todos and displays a text input to add another one
class HomeScreenState extends State<HomeScreen> {
// we only use this to reset the input field at the bottom when a entry has
// been added
final TextEditingController controller = TextEditingController();
TodoAppBloc get bloc => Provider.of<TodoAppBloc>(context);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Todo list'),
),
drawer: CategoriesDrawer(),
body: StreamBuilder<List<EntryWithCategory>>(
stream: bloc.homeScreenEntries,
builder: (context, snapshot) {
if (!snapshot.hasData) {
return const Align(
alignment: Alignment.center,
child: CircularProgressIndicator(),
);
}
final activeTodos = snapshot.data;
return ListView.builder(
itemCount: activeTodos.length,
itemBuilder: (context, index) {
return TodoCard(activeTodos[index].entry);
},
);
},
),
bottomSheet: Material(
elevation: 12,
child: SafeArea(
child: Padding(
padding: const EdgeInsets.all(8),
child: f.Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text('What needs to be done?'),
Row(
children: <Widget>[
Expanded(
child: TextField(
controller: controller,
onSubmitted: (_) => _createTodoEntry(),
),
),
IconButton(
icon: Icon(Icons.send),
color: Theme.of(context).accentColor,
onPressed: _createTodoEntry,
),
],
),
],
),
),
),
),
);
}
void _createTodoEntry() {
if (controller.text.isNotEmpty) {
// We write the entry here. Notice how we don't have to call setState()
// or anything - moor will take care of updating the list automatically.
bloc.createEntry(controller.text);
controller.clear();
}
}
}