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.

147 lines
4.4KB

  1. import 'package:farm_tpf/custom_model/Supply.dart';
  2. import 'package:farm_tpf/data/repository/repository.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/screens/resources/bloc/supply_bloc.dart';
  6. import 'package:farm_tpf/presentation/screens/resources/widget_search.dart';
  7. import 'package:farm_tpf/utils/const_string.dart';
  8. import 'package:flutter/material.dart';
  9. import 'package:flutter_bloc/flutter_bloc.dart';
  10. class ResourceHelperScreen extends StatefulWidget {
  11. final String type;
  12. final int selectedId;
  13. final String titleName;
  14. ResourceHelperScreen(
  15. {@required this.type,
  16. @required this.selectedId,
  17. @required this.titleName});
  18. @override
  19. _ResourceHelperScreenState createState() => _ResourceHelperScreenState();
  20. }
  21. class _ResourceHelperScreenState extends State<ResourceHelperScreen> {
  22. @override
  23. Widget build(BuildContext context) {
  24. return BlocProvider(
  25. create: (context) => SupplyBloc(repository: Repository())
  26. ..add(DataFetched(type: widget.type, selectedId: widget.selectedId)),
  27. child: HoldInfinityWidget(
  28. selectedId: widget.selectedId,
  29. type: widget.type,
  30. titleName: widget.titleName,
  31. ),
  32. );
  33. }
  34. }
  35. class HoldInfinityWidget extends StatelessWidget {
  36. final int selectedId;
  37. final String type;
  38. final String titleName;
  39. HoldInfinityWidget(
  40. {@required this.selectedId,
  41. @required this.type,
  42. @required this.titleName});
  43. final GlobalKey<ScaffoldState> _scaffoldKey = new GlobalKey<ScaffoldState>();
  44. @override
  45. Widget build(BuildContext context) {
  46. return Scaffold(
  47. key: _scaffoldKey,
  48. appBar: AppBar(title: Text("Chọn $titleName")),
  49. body: Column(
  50. children: <Widget>[
  51. WidgetSearch(
  52. type: type,
  53. selectedId: selectedId,
  54. ),
  55. Expanded(
  56. child: InfinityView(
  57. selectedId: selectedId,
  58. type: type,
  59. ))
  60. ],
  61. ));
  62. }
  63. }
  64. class InfinityView extends StatefulWidget {
  65. final int selectedId;
  66. final String type;
  67. InfinityView({@required this.selectedId, @required this.type});
  68. @override
  69. _InfinityViewState createState() => _InfinityViewState();
  70. }
  71. class _InfinityViewState extends State<InfinityView> {
  72. SupplyBloc _supplyBloc;
  73. @override
  74. void initState() {
  75. _supplyBloc = BlocProvider.of<SupplyBloc>(context);
  76. _supplyBloc
  77. .add(DataFetched(type: widget.type, selectedId: widget.selectedId));
  78. super.initState();
  79. }
  80. @override
  81. Widget build(BuildContext context) {
  82. return BlocBuilder<SupplyBloc, SupplyState>(
  83. builder: (context, state) {
  84. if (state is SupplyFailure) {
  85. return Center(child: Text(label_error_get_data));
  86. }
  87. if (state is SupplySuccess) {
  88. if (state.items.isEmpty) {
  89. return Center(child: Text(label_list_empty));
  90. }
  91. return RefreshIndicator(
  92. child: ListView.builder(
  93. itemBuilder: (BuildContext context, int index) {
  94. return index >= state.items.length
  95. ? BottomLoader()
  96. : ItemInfinityWidget(item: state.items[index]);
  97. },
  98. itemCount: state.items.length),
  99. onRefresh: () async {
  100. _supplyBloc.add(OnRefresh(
  101. type: widget.type, selectedId: widget.selectedId));
  102. });
  103. }
  104. return Center(
  105. child: LoadingListPage(),
  106. );
  107. },
  108. );
  109. }
  110. @override
  111. void dispose() {
  112. super.dispose();
  113. }
  114. }
  115. class ItemInfinityWidget extends StatelessWidget {
  116. final Supply item;
  117. const ItemInfinityWidget({Key key, @required this.item}) : super(key: key);
  118. @override
  119. Widget build(BuildContext context) {
  120. return GestureDetector(
  121. child: Card(
  122. child: Material(
  123. child: RadioListTile(
  124. title: Text(item.tbSuppliesName.toString()),
  125. subtitle: Text(item.tbWarehouseName.toString()),
  126. value: item,
  127. groupValue: item.isSelected == false ? null : item,
  128. onChanged: (Supply value) {
  129. print("selected value: ${value.id}");
  130. Navigator.of(context).pop(value);
  131. }),
  132. )),
  133. onTap: () {});
  134. }
  135. }