Added Provider and DetailPage
This commit is contained in:
@@ -1,7 +1,10 @@
|
||||
import 'package:briessenchecker/pages/detail_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:flutter/material.dart';
|
||||
import 'package:flutter_dotenv/flutter_dotenv.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'pages/dashboard_page.dart';
|
||||
import 'pages/landing_page.dart';
|
||||
import 'pages/login_page.dart';
|
||||
@@ -9,7 +12,11 @@ import 'pages/login_page.dart';
|
||||
void main() async {
|
||||
await dotenv.load(fileName: 'secrets.env');
|
||||
await DbHelper.init();
|
||||
runApp(const MyApp());
|
||||
runApp(MultiProvider(providers: [
|
||||
ChangeNotifierProvider(
|
||||
create: (_) => ChecklistProvider(),
|
||||
),
|
||||
], child: const MyApp()));
|
||||
}
|
||||
|
||||
class MyApp extends StatelessWidget {
|
||||
@@ -30,6 +37,7 @@ class MyApp extends StatelessWidget {
|
||||
LoginPage.routeName: (context) => const LoginPage(),
|
||||
DashboardPage.routeName: (context) => const DashboardPage(),
|
||||
EditChecklistPage.routeName: (context) => const EditChecklistPage(),
|
||||
DetailChecklistPage.routeName: (context) => const DetailChecklistPage(),
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
@@ -1,6 +1,9 @@
|
||||
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:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class DashboardPage extends StatefulWidget {
|
||||
const DashboardPage({super.key});
|
||||
@@ -12,9 +15,16 @@ class DashboardPage extends StatefulWidget {
|
||||
|
||||
class _DashboardPageState extends State<DashboardPage> {
|
||||
final Future<List<Checklist>> checklistFuture = DbHelper.fetchChecklist;
|
||||
late ChecklistProvider checklistProvider;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
checklistProvider = Provider.of<ChecklistProvider>(context, listen: true);
|
||||
return Scaffold(
|
||||
body: FutureBuilder(
|
||||
future: checklistFuture,
|
||||
@@ -49,6 +59,9 @@ class _DashboardPageState extends State<DashboardPage> {
|
||||
}
|
||||
|
||||
void _onAddTapped() {
|
||||
DbHelper.addChecklist().then((id) {});
|
||||
DbHelper.addChecklist().then((id) {
|
||||
checklistProvider.updateSelectedChecklist(id, silent: true);
|
||||
});
|
||||
Navigator.of(context).pushNamed(DetailChecklistPage.routeName);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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:provider/provider.dart';
|
||||
|
||||
class DetailChecklistPage extends StatelessWidget {
|
||||
class DetailChecklistPage extends StatefulWidget {
|
||||
const DetailChecklistPage({super.key});
|
||||
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
|
||||
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();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
12
lib/services/checklist_provider.dart
Normal file
12
lib/services/checklist_provider.dart
Normal 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;
|
||||
}
|
||||
@@ -34,6 +34,10 @@ class DbHelper {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static Future<Checklist> getChecklistById(int id) async {
|
||||
return ed.checklists.first;
|
||||
}
|
||||
|
||||
static Stream<AuthState> get authChangeEventStream =>
|
||||
_client.auth.onAuthStateChange;
|
||||
}
|
||||
|
||||
16
pubspec.lock
16
pubspec.lock
@@ -224,6 +224,14 @@ packages:
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.0.4"
|
||||
nested:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: nested
|
||||
sha256: "03bac4c528c64c95c722ec99280375a6f2fc708eec17c7b3f07253b626cd2a20"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.0.0"
|
||||
path:
|
||||
dependency: transitive
|
||||
description:
|
||||
@@ -304,6 +312,14 @@ packages:
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
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:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
||||
@@ -37,6 +37,7 @@ dependencies:
|
||||
cupertino_icons: ^1.0.2
|
||||
supabase_flutter: ^1.10.11
|
||||
flutter_dotenv: ^5.1.0
|
||||
provider: ^6.0.5
|
||||
|
||||
dev_dependencies:
|
||||
flutter_test:
|
||||
|
||||
Reference in New Issue
Block a user