You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
80 lines
2.7 KiB
Dart
80 lines
2.7 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:car_customer_app/views/dashboard/fragments/appointments_fragment.dart';
|
|
import 'package:car_customer_app/views/dashboard/fragments/home_fragment.dart';
|
|
import 'package:car_customer_app/views/dashboard/widgets/bottom_nav_bar.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:mc_common_app/classes/app_state.dart';
|
|
import 'package:mc_common_app/config/routes.dart';
|
|
import 'package:mc_common_app/utils/enums.dart';
|
|
import 'package:mc_common_app/utils/navigator.dart';
|
|
import 'package:mc_common_app/utils/utils.dart';
|
|
import 'package:mc_common_app/view_models/dashboard_view_model_customer.dart';
|
|
import 'package:mc_common_app/views/common_fragments/ads_fragment.dart';
|
|
import 'package:mc_common_app/views/common_fragments/requests_fragment.dart';
|
|
import 'package:mc_common_app/widgets/extensions/extensions_widget.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'fragments/branches_fragment.dart';
|
|
|
|
class DashboardView extends StatefulWidget {
|
|
final DashboardRouteEnum dashboardRouteEnum;
|
|
|
|
const DashboardView({Key? key, required this.dashboardRouteEnum}) : super(key: key);
|
|
|
|
@override
|
|
State<DashboardView> createState() => _DashboardViewState();
|
|
}
|
|
|
|
class _DashboardViewState extends State<DashboardView> {
|
|
late DashboardVmCustomer dashboardVM;
|
|
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
dashboardVM = context.read<DashboardVmCustomer>();
|
|
scheduleMicrotask(() => dashboardVM.onRefresh(context, dashboardRouteEnum: widget.dashboardRouteEnum));
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
List<Widget> fragments = [
|
|
const BranchesFragment(),
|
|
const AppointmentsFragment(),
|
|
const HomeFragment(),
|
|
const AdsFragment(),
|
|
const MyRequestsFragment(),
|
|
];
|
|
|
|
// return GestureDetector(
|
|
// behavior: HitTestBehavior.translucent,
|
|
// onTap: () {
|
|
// if (AppState().getIsViewOnly) {
|
|
// Utils.showToast("message");
|
|
// } else {
|
|
// print("========NN========");
|
|
// }
|
|
// },
|
|
// child: child,
|
|
// )
|
|
return PopScope(
|
|
canPop: false,
|
|
child: Scaffold(
|
|
key: _scaffoldKey,
|
|
bottomNavigationBar: CustomBottomNavbar(),
|
|
body: fragments[context.watch<DashboardVmCustomer>().selectedNavbarBarIndex],
|
|
),
|
|
);
|
|
|
|
// return PopScope(
|
|
// canPop: false,
|
|
// child: Scaffold(
|
|
// key: _scaffoldKey,
|
|
// bottomNavigationBar: CustomBottomNavbar(),
|
|
// body: fragments[context.watch<DashboardVmCustomer>().selectedNavbarBarIndex],
|
|
// ),
|
|
// );
|
|
}
|
|
}
|