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.

157 lines
5.0KB

  1. import 'package:dio/dio.dart';
  2. import 'package:farm_tpf/data/repository/repository.dart';
  3. import 'package:farm_tpf/models/Plot.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/utils/const_color.dart';
  8. import 'package:farm_tpf/utils/const_enum.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(icon: Icon(FontAwesomeIcons.qrcode), onPressed: () {})
  40. ],
  41. ),
  42. body: InfinityView());
  43. }
  44. }
  45. class InfinityView extends StatefulWidget {
  46. @override
  47. _InfinityViewState createState() => _InfinityViewState();
  48. }
  49. class _InfinityViewState extends State<InfinityView> {
  50. final _scrollController = ScrollController();
  51. final _scrollThreshold = 250.0;
  52. PlotBloc _plotBloc;
  53. @override
  54. void initState() {
  55. _scrollController.addListener(() {
  56. final maxScroll = _scrollController.position.maxScrollExtent;
  57. final currentScroll = _scrollController.position.pixels;
  58. if (maxScroll - currentScroll < _scrollThreshold) {
  59. _plotBloc.add(DataFetched());
  60. }
  61. });
  62. _plotBloc = BlocProvider.of<PlotBloc>(context);
  63. super.initState();
  64. }
  65. @override
  66. Widget build(BuildContext context) {
  67. return BlocBuilder<PlotBloc, PlotState>(
  68. builder: (context, state) {
  69. if (state is PlotFailure) {
  70. return Center(child: Text(state.errorString));
  71. }
  72. if (state is PlotSuccess) {
  73. if (state.items.isEmpty) {
  74. return Center(child: Text(label_list_empty));
  75. }
  76. return Column(
  77. children: <Widget>[
  78. WidgetSearch(),
  79. Expanded(
  80. child: RefreshIndicator(
  81. child: ListView.builder(
  82. physics: AlwaysScrollableScrollPhysics(),
  83. itemBuilder: (BuildContext context, int index) {
  84. return index >= state.items.length
  85. ? BottomLoader()
  86. : ItemInfinityWidget(item: state.items[index]);
  87. },
  88. itemCount: state.hasReachedMax
  89. ? state.items.length
  90. : state.items.length + 1,
  91. controller: _scrollController,
  92. ),
  93. onRefresh: () async {
  94. _plotBloc.add(OnRefresh());
  95. }))
  96. ],
  97. );
  98. }
  99. return Center(
  100. child: LoadingListPage(),
  101. );
  102. },
  103. );
  104. }
  105. @override
  106. void dispose() {
  107. _scrollController.dispose();
  108. super.dispose();
  109. }
  110. }
  111. class ItemInfinityWidget extends StatelessWidget {
  112. final Plot item;
  113. const ItemInfinityWidget({Key key, @required this.item}) : super(key: key);
  114. @override
  115. Widget build(BuildContext context) {
  116. return GestureDetector(
  117. child: Card(
  118. color: item.status == "STATUS_ARE_ACTIVE"
  119. ? Colors.white
  120. : COLOR_CONST.DEFAULT,
  121. child: ListTile(
  122. title: Text(
  123. item.code.toString() + " - " + item.suppliesName.toString(),
  124. style: TextStyle(
  125. color: item.status == "STATUS_ARE_ACTIVE"
  126. ? COLOR_CONST.DEFAULT
  127. : Colors.white),
  128. ),
  129. subtitle: Text(item.startDate.format_DDMMYY_HHmm().toString(),
  130. style: TextStyle(
  131. color: item.status == "STATUS_ARE_ACTIVE"
  132. ? COLOR_CONST.DEFAULT
  133. : Colors.white)),
  134. trailing: Text(
  135. item.areaM2.formatNumtoStringDecimal().toString() + " m\u00B2",
  136. style: TextStyle(
  137. color: item.status == "STATUS_ARE_ACTIVE"
  138. ? COLOR_CONST.DEFAULT
  139. : Colors.white)),
  140. ),
  141. ),
  142. onTap: () {});
  143. }
  144. }