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/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(),
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
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;
|
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;
|
||||||
}
|
}
|
||||||
|
|||||||
16
pubspec.lock
16
pubspec.lock
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
Reference in New Issue
Block a user