You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

172 lines
5.4KB

  1. import 'package:farm_tpf/data/repository/repository.dart';
  2. import 'package:farm_tpf/models/index.dart';
  3. import 'package:farm_tpf/presentation/custom_widgets/bottom_loader.dart';
  4. import 'package:farm_tpf/presentation/custom_widgets/loading_list_page.dart';
  5. import 'package:farm_tpf/presentation/custom_widgets/widget_loading.dart';
  6. import 'package:farm_tpf/presentation/screens/plot/widget_search.dart';
  7. import 'package:farm_tpf/presentation/screens/plot_detail/sc_plot_detail.dart';
  8. import 'package:farm_tpf/presentation/screens/plot_detail/sc_plot_information.dart';
  9. import 'package:farm_tpf/utils/const_color.dart';
  10. import 'package:flutter/material.dart';
  11. import 'package:flutter_bloc/flutter_bloc.dart';
  12. import 'package:farm_tpf/utils/const_string.dart';
  13. import 'package:font_awesome_flutter/font_awesome_flutter.dart';
  14. import 'package:farm_tpf/utils/formatter.dart';
  15. import 'package:get/get.dart';
  16. import 'bloc/plot_bloc.dart';
  17. class PlotListScreen extends StatefulWidget {
  18. @override
  19. _PlotListScreenState createState() => _PlotListScreenState();
  20. }
  21. class _PlotListScreenState extends State<PlotListScreen> {
  22. @override
  23. Widget build(BuildContext context) {
  24. return BlocProvider(
  25. create: (context) =>
  26. PlotBloc(repository: Repository())..add(DataFetched()),
  27. child: HoldInfinityWidget(),
  28. );
  29. }
  30. }
  31. class HoldInfinityWidget extends StatelessWidget {
  32. final GlobalKey<ScaffoldState> _scaffoldKey = new GlobalKey<ScaffoldState>();
  33. @override
  34. Widget build(BuildContext context) {
  35. return Scaffold(
  36. key: _scaffoldKey,
  37. appBar: AppBar(
  38. centerTitle: true,
  39. title: Text("Danh sách lô"),
  40. actions: <Widget>[
  41. IconButton(
  42. icon: Icon(FontAwesomeIcons.infoCircle),
  43. onPressed: () {
  44. Get.to(PlotInformationScreen());
  45. })
  46. ],
  47. ),
  48. body: InfinityView());
  49. }
  50. }
  51. class InfinityView extends StatefulWidget {
  52. @override
  53. _InfinityViewState createState() => _InfinityViewState();
  54. }
  55. class _InfinityViewState extends State<InfinityView> {
  56. final _scrollController = ScrollController();
  57. final _scrollThreshold = 250.0;
  58. PlotBloc _plotBloc;
  59. @override
  60. void initState() {
  61. _scrollController.addListener(() {
  62. final maxScroll = _scrollController.position.maxScrollExtent;
  63. final currentScroll = _scrollController.position.pixels;
  64. if (maxScroll - currentScroll < _scrollThreshold) {
  65. _plotBloc.add(DataFetched());
  66. }
  67. });
  68. _plotBloc = BlocProvider.of<PlotBloc>(context);
  69. super.initState();
  70. }
  71. @override
  72. Widget build(BuildContext context) {
  73. return Column(
  74. children: <Widget>[
  75. WidgetSearch(),
  76. Expanded(child: BlocBuilder<PlotBloc, PlotState>(
  77. builder: (context, state) {
  78. if (state is PlotFailure) {
  79. return Center(child: Text(state.errorString));
  80. }
  81. if (state is PlotSuccess) {
  82. if (state.items.isEmpty) {
  83. return Center(child: Text(label_list_empty));
  84. }
  85. return RefreshIndicator(
  86. child: ListView.builder(
  87. physics: AlwaysScrollableScrollPhysics(),
  88. itemBuilder: (BuildContext context, int index) {
  89. return index >= state.items.length
  90. ? BottomLoader()
  91. : ItemInfinityWidget(item: state.items[index]);
  92. },
  93. itemCount: state.hasReachedMax
  94. ? state.items.length
  95. : state.items.length + 1,
  96. controller: _scrollController,
  97. ),
  98. onRefresh: () async {
  99. _plotBloc.add(OnRefresh());
  100. });
  101. }
  102. return Center(
  103. child: LoadingListPage(),
  104. );
  105. },
  106. ))
  107. ],
  108. );
  109. }
  110. @override
  111. void dispose() {
  112. _scrollController.dispose();
  113. super.dispose();
  114. }
  115. }
  116. class ItemInfinityWidget extends StatelessWidget {
  117. final PlotCrop item;
  118. const ItemInfinityWidget({Key key, @required this.item}) : super(key: key);
  119. @override
  120. Widget build(BuildContext context) {
  121. var backgroundColor;
  122. var textColor;
  123. switch (item.status) {
  124. case "STATUS_ARE_ACTIVE":
  125. backgroundColor = Colors.white;
  126. textColor = COLOR_CONST.DEFAULT;
  127. break;
  128. case "STATUS_FINISHED":
  129. backgroundColor = COLOR_CONST.DEFAULT;
  130. textColor = Colors.white;
  131. break;
  132. default:
  133. backgroundColor = Colors.white;
  134. textColor = Colors.black;
  135. }
  136. return GestureDetector(
  137. child: Card(
  138. color: backgroundColor,
  139. child: ListTile(
  140. title: Text(
  141. item.code.toString() + " - " + item.suppliesName.toString(),
  142. style: TextStyle(color: textColor)),
  143. subtitle: Text(item.startDate.format_DDMMYY_HHmm().toString(),
  144. style: TextStyle(color: textColor)),
  145. trailing: Text(
  146. item.areaM2.formatNumtoStringDecimal().toString() + " m\u00B2",
  147. style: TextStyle(color: textColor)),
  148. ),
  149. ),
  150. onTap: () {
  151. Navigator.push(
  152. context,
  153. MaterialPageRoute(
  154. builder: (BuildContext context) =>
  155. PlotDetailScreen(cropId: item.id)));
  156. });
  157. }
  158. }