Added Provider and DetailPage

This commit is contained in:
marcoabat
2023-08-05 14:35:19 +02:00
parent 77e1fa8244
commit 64e680ec6f
7 changed files with 104 additions and 4 deletions

View File

@@ -1,7 +1,10 @@
import 'package:briessenchecker/pages/detail_checklist_page.dart';
import 'package:briessenchecker/pages/edit_checklist_page.dart'; import 'package:briessenchecker/pages/edit_checklist_page.dart';
import 'package:briessenchecker/services/checklist_provider.dart';
import 'package:briessenchecker/services/dbhelper.dart'; import 'package:briessenchecker/services/dbhelper.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_dotenv/flutter_dotenv.dart'; import 'package:flutter_dotenv/flutter_dotenv.dart';
import 'package:provider/provider.dart';
import 'pages/dashboard_page.dart'; import 'pages/dashboard_page.dart';
import 'pages/landing_page.dart'; import 'pages/landing_page.dart';
import 'pages/login_page.dart'; import 'pages/login_page.dart';
@@ -9,7 +12,11 @@ import 'pages/login_page.dart';
void main() async { void main() async {
await dotenv.load(fileName: 'secrets.env'); await dotenv.load(fileName: 'secrets.env');
await DbHelper.init(); await DbHelper.init();
runApp(const MyApp()); runApp(MultiProvider(providers: [
ChangeNotifierProvider(
create: (_) => ChecklistProvider(),
),
], child: const MyApp()));
} }
class MyApp extends StatelessWidget { class MyApp extends StatelessWidget {
@@ -30,6 +37,7 @@ class MyApp extends StatelessWidget {
LoginPage.routeName: (context) => const LoginPage(), LoginPage.routeName: (context) => const LoginPage(),
DashboardPage.routeName: (context) => const DashboardPage(), DashboardPage.routeName: (context) => const DashboardPage(),
EditChecklistPage.routeName: (context) => const EditChecklistPage(), EditChecklistPage.routeName: (context) => const EditChecklistPage(),
DetailChecklistPage.routeName: (context) => const DetailChecklistPage(),
}, },
); );
} }

View File

@@ -1,6 +1,9 @@
import 'package:briessenchecker/models/checklist.dart'; import 'package:briessenchecker/models/checklist.dart';
import 'package:briessenchecker/pages/detail_checklist_page.dart';
import 'package:briessenchecker/services/checklist_provider.dart';
import 'package:briessenchecker/services/dbhelper.dart'; import 'package:briessenchecker/services/dbhelper.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class DashboardPage extends StatefulWidget { class DashboardPage extends StatefulWidget {
const DashboardPage({super.key}); const DashboardPage({super.key});
@@ -12,9 +15,16 @@ class DashboardPage extends StatefulWidget {
class _DashboardPageState extends State<DashboardPage> { class _DashboardPageState extends State<DashboardPage> {
final Future<List<Checklist>> checklistFuture = DbHelper.fetchChecklist; final Future<List<Checklist>> checklistFuture = DbHelper.fetchChecklist;
late ChecklistProvider checklistProvider;
@override
void initState() {
super.initState();
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
checklistProvider = Provider.of<ChecklistProvider>(context, listen: true);
return Scaffold( return Scaffold(
body: FutureBuilder( body: FutureBuilder(
future: checklistFuture, future: checklistFuture,
@@ -49,6 +59,9 @@ class _DashboardPageState extends State<DashboardPage> {
} }
void _onAddTapped() { void _onAddTapped() {
DbHelper.addChecklist().then((id) {}); DbHelper.addChecklist().then((id) {
checklistProvider.updateSelectedChecklist(id, silent: true);
});
Navigator.of(context).pushNamed(DetailChecklistPage.routeName);
} }
} }

View File

@@ -1,10 +1,56 @@
import 'package:briessenchecker/models/checklist.dart';
import 'package:briessenchecker/services/checklist_provider.dart';
import 'package:briessenchecker/services/dbhelper.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class DetailChecklistPage extends StatelessWidget { class DetailChecklistPage extends StatefulWidget {
const DetailChecklistPage({super.key}); const DetailChecklistPage({super.key});
static const routeName = '/detail'; static const routeName = '/detail';
@override
State<DetailChecklistPage> createState() => _DetailChecklistPageState();
}
class _DetailChecklistPageState extends State<DetailChecklistPage> {
late final ChecklistProvider checklistProvider;
late Future<Checklist> checklistFuture;
@override
void initState() {
super.initState();
checklistProvider = Provider.of<ChecklistProvider>(context, listen: false);
checklistFuture =
DbHelper.getChecklistById(checklistProvider.selectedChecklistId!);
}
@override
void dispose() {
super.dispose();
checklistProvider.updateSelectedChecklist(null, silent: true);
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return const Placeholder(); return Scaffold(
body: FutureBuilder(
future: checklistFuture,
builder: _futureBuilder,
),
);
}
Widget _futureBuilder(
BuildContext context, AsyncSnapshot<Checklist> snapshot) {
if (snapshot.hasData) {
return Column(
children: [
Text(snapshot.data!.title),
Text(snapshot.data!.description),
],
);
} else {
return const CircularProgressIndicator();
}
} }
} }

View File

@@ -0,0 +1,12 @@
import 'package:flutter/material.dart';
class ChecklistProvider extends ChangeNotifier {
int? _selectedChecklistId;
updateSelectedChecklist(int? checklistId, {bool silent = false}) {
_selectedChecklistId = checklistId;
if (!silent) notifyListeners();
}
int? get selectedChecklistId => _selectedChecklistId;
}

View File

@@ -34,6 +34,10 @@ class DbHelper {
return 0; return 0;
} }
static Future<Checklist> getChecklistById(int id) async {
return ed.checklists.first;
}
static Stream<AuthState> get authChangeEventStream => static Stream<AuthState> get authChangeEventStream =>
_client.auth.onAuthStateChange; _client.auth.onAuthStateChange;
} }

View File

@@ -224,6 +224,14 @@ packages:
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.0.4" version: "1.0.4"
nested:
dependency: transitive
description:
name: nested
sha256: "03bac4c528c64c95c722ec99280375a6f2fc708eec17c7b3f07253b626cd2a20"
url: "https://pub.dev"
source: hosted
version: "1.0.0"
path: path:
dependency: transitive dependency: transitive
description: description:
@@ -304,6 +312,14 @@ packages:
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.4.0" version: "1.4.0"
provider:
dependency: "direct main"
description:
name: provider
sha256: cdbe7530b12ecd9eb455bdaa2fcb8d4dad22e80b8afb4798b41479d5ce26847f
url: "https://pub.dev"
source: hosted
version: "6.0.5"
realtime_client: realtime_client:
dependency: transitive dependency: transitive
description: description:

View File

@@ -37,6 +37,7 @@ dependencies:
cupertino_icons: ^1.0.2 cupertino_icons: ^1.0.2
supabase_flutter: ^1.10.11 supabase_flutter: ^1.10.11
flutter_dotenv: ^5.1.0 flutter_dotenv: ^5.1.0
provider: ^6.0.5
dev_dependencies: dev_dependencies:
flutter_test: flutter_test: