|
|
|
@ -1,4 +1,3 @@
|
|
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter_svg/flutter_svg.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/classes/colors.dart';
|
|
|
|
@ -7,37 +6,44 @@ import 'package:mohem_flutter_app/config/routes.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/int_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/string_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/widget_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/generated/locale_keys.g.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/models/dashboard/menu_entries.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/ui/my_attendance/dynamic_screens/dynamic_listview_screen.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/app_bar_widget.dart';
|
|
|
|
|
|
|
|
|
|
class MyAttendanceScreen extends StatelessWidget {
|
|
|
|
|
List<GetMenuEntriesList> list;
|
|
|
|
|
class ServicesMenuListScreenParams {
|
|
|
|
|
final String title;
|
|
|
|
|
final List<GetMenuEntriesList> list;
|
|
|
|
|
|
|
|
|
|
MyAttendanceScreen({Key? key, this.list = const <GetMenuEntriesList>[]}) : super(key: key);
|
|
|
|
|
ServicesMenuListScreenParams(this.title, this.list);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class ServicesMenuListScreen extends StatelessWidget {
|
|
|
|
|
late ServicesMenuListScreenParams servicesMenuData;
|
|
|
|
|
|
|
|
|
|
ServicesMenuListScreen({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
list = ModalRoute.of(context)!.settings.arguments as List<GetMenuEntriesList>;
|
|
|
|
|
servicesMenuData = ModalRoute.of(context)!.settings.arguments as ServicesMenuListScreenParams;
|
|
|
|
|
|
|
|
|
|
return Scaffold(
|
|
|
|
|
backgroundColor: Colors.white,
|
|
|
|
|
appBar: AppBarWidget(
|
|
|
|
|
context,
|
|
|
|
|
title: LocaleKeys.myAttendance.tr(),
|
|
|
|
|
title: servicesMenuData.title,
|
|
|
|
|
),
|
|
|
|
|
body: SizedBox(
|
|
|
|
|
width: double.infinity,
|
|
|
|
|
height: double.infinity,
|
|
|
|
|
child: list.isEmpty
|
|
|
|
|
child: servicesMenuData.list.isEmpty
|
|
|
|
|
? Utils.getNoDataWidget(context)
|
|
|
|
|
: ListView.separated(
|
|
|
|
|
padding: const EdgeInsets.all(21),
|
|
|
|
|
itemBuilder: (cxt, index) => itemView("assets/images/pdf.svg", list[index].prompt!).onPress(() {
|
|
|
|
|
Navigator.pushNamed(context, AppRoutes.dynamicScreen, arguments: DynamicListViewParams(list[index].prompt!, list[index].functionName!));
|
|
|
|
|
itemBuilder: (cxt, index) => itemView("assets/images/pdf.svg", servicesMenuData.list[index].prompt!).onPress(() {
|
|
|
|
|
Navigator.pushNamed(context, AppRoutes.dynamicScreen, arguments: DynamicListViewParams(servicesMenuData.list[index].prompt!, servicesMenuData.list[index].functionName!));
|
|
|
|
|
}),
|
|
|
|
|
separatorBuilder: (cxt, index) => 12.height,
|
|
|
|
|
itemCount: list.length),
|
|
|
|
|
itemCount: servicesMenuData.list.length),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|