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.

171 lines
5.2KB

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