基础组件库
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.
 
 
 
 
 

145 lines
4.3 KiB

  1. import 'package:flutter/cupertino.dart';
  2. import 'package:flutter/material.dart';
  3. import 'package:provider/provider.dart';
  4. import 'package:pull_to_refresh/pull_to_refresh.dart';
  5. import 'package:zhiying_base_widget/pages/main_page/main_page_bloc.dart';
  6. import 'package:zhiying_base_widget/pages/main_page/notifier/main_page_bg_notifier.dart';
  7. import 'package:zhiying_base_widget/pages/main_page/notifier/main_page_notifier.dart';
  8. import 'package:zhiying_base_widget/widgets/others/mine_header_bg_widget.dart';
  9. import 'package:zhiying_comm/util/base_bloc.dart';
  10. import 'package:zhiying_comm/zhiying_comm.dart';
  11. class MainPage extends StatefulWidget {
  12. final Map<String, dynamic> data;
  13. MainPage(
  14. this.data, {
  15. Key key,
  16. }) : super(key: key);
  17. @override
  18. _MainPageState createState() => _MainPageState();
  19. }
  20. class _MainPageState extends State<MainPage> {
  21. @override
  22. Widget build(BuildContext context) {
  23. return Scaffold(
  24. backgroundColor: Color(0xfff9f9f9),
  25. body: MultiProvider(
  26. providers: [
  27. ChangeNotifierProvider.value(value: MainPageNotifier()),
  28. ChangeNotifierProvider.value(value: MainPageBgNotifier()),
  29. ],
  30. child: BlocProvider<MainPageBloc>(
  31. bloc: MainPageBloc(),
  32. child: _MainPageContainer(widget.data),
  33. ),
  34. ),
  35. );
  36. }
  37. }
  38. class _MainPageContainer extends StatefulWidget {
  39. final Map<String, dynamic> data;
  40. _MainPageContainer(this.data, {Key key}) : super(key: key);
  41. @override
  42. _MainPageContainerState createState() => _MainPageContainerState();
  43. }
  44. class _MainPageContainerState extends State<_MainPageContainer> {
  45. bool _isEnded = false;
  46. ScrollController _controller = ScrollController();
  47. MainPageBloc _bloc;
  48. RefreshController _refreshController =
  49. RefreshController(initialRefresh: false);
  50. void _onLoading() async {
  51. // await Future.delayed(Duration(milliseconds: 1000));
  52. // if (mounted) setState(() {});
  53. // _refreshController.loadComplete();
  54. }
  55. @override
  56. void dispose() {
  57. _controller.dispose();
  58. super.dispose();
  59. }
  60. @override
  61. void initState() {
  62. _bloc = BlocProvider.of<MainPageBloc>(context);
  63. _controller.addListener(() {
  64. // print('${_controller.offset} ${_controller.position.maxScrollExtent}');
  65. if (_controller.offset >= _controller.position.maxScrollExtent &&
  66. !_isEnded) {
  67. // 滑动到底部
  68. _isEnded = true;
  69. Provider.of<MainPageNotifier>(context, listen: false).loadMore();
  70. } else if (_controller.offset < _controller.position.maxScrollExtent &&
  71. _isEnded) {
  72. _isEnded = false;
  73. Provider.of<MainPageNotifier>(context, listen: false).reset();
  74. }
  75. });
  76. super.initState();
  77. }
  78. @override
  79. Widget build(BuildContext context) {
  80. return StreamBuilder<Map<String, dynamic>>(
  81. stream: _bloc.outData,
  82. builder: (BuildContext context, AsyncSnapshot snapshot) {
  83. return MediaQuery.removePadding(
  84. removeTop: true,
  85. context: context,
  86. child: SmartRefresher(
  87. enablePullDown: false,
  88. enablePullUp: false,
  89. header: WaterDropHeader(),
  90. controller: _refreshController,
  91. onLoading: _onLoading,
  92. child: Container(
  93. width: double.infinity,
  94. child: Stack(
  95. fit: StackFit.passthrough,
  96. children: <Widget>[
  97. MineHeaderBgWidget(
  98. controller: _controller,
  99. ),
  100. CustomScrollView(
  101. controller: _controller,
  102. slivers: _createContent(context),
  103. )
  104. ],
  105. ),
  106. ),
  107. ));
  108. },
  109. );
  110. }
  111. List<Widget> _createContent(BuildContext context) {
  112. WidgetModel model = WidgetModel.fromJson(widget.data);
  113. List<Widget> list = List();
  114. for (int i = 0; i < model.components.length; i++) {
  115. WidgetModel item = model.components[i];
  116. Map<String, dynamic> data = Map();
  117. if (widget.data.containsKey('components')) {
  118. data = widget.data['components'][i];
  119. }
  120. list.addAll(WidgetFactory.create(
  121. item.modName,
  122. isSliver: true,
  123. model: data,
  124. ));
  125. }
  126. model.components.forEach((item) {});
  127. return list;
  128. }
  129. }