message_list_page.dart 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. import 'package:flutter/material.dart';
  2. import 'package:liftmanager/internal/heavy/provider/heavy_page.dart';
  3. import 'package:liftmanager/internal/heavy/widgets/HeavyList.dart';
  4. import 'package:liftmanager/internal/message/widgets/messageList.dart';
  5. import 'package:liftmanager/res/resources.dart';
  6. import 'package:liftmanager/routers/fluro_navigator.dart';
  7. import 'package:liftmanager/utils/theme_utils.dart';
  8. import 'package:liftmanager/widgets/app_bar.dart';
  9. import 'package:provider/provider.dart' as p;
  10. class MessageListPage extends StatefulWidget {
  11. @override
  12. MessageListPageState createState() => MessageListPageState();
  13. }
  14. class MessageListPageState extends State<MessageListPage>
  15. with SingleTickerProviderStateMixin, AutomaticKeepAliveClientMixin {
  16. HeavyPageProvider provider = HeavyPageProvider();
  17. List<Map> tabs = [
  18. {"id": 1, "name": "团队消息"},
  19. {"id": 2, "name": "保养消息"},
  20. {"id": 3, "name": "急修消息"},
  21. {"id": 4, "name": "工作消息"}
  22. ];
  23. TabController _tabController;
  24. PageController _pageController = PageController(initialPage: 0);
  25. @override
  26. void initState() {
  27. super.initState();
  28. _tabController = new TabController(vsync: this, length: tabs.length);
  29. }
  30. @override
  31. void dispose() {
  32. _tabController.dispose();
  33. super.dispose();
  34. }
  35. _onPageChange(int index) {
  36. _tabController.animateTo(index);
  37. provider.setIndex(index);
  38. }
  39. @override
  40. Widget build(BuildContext context) {
  41. return p.ChangeNotifierProvider<HeavyPageProvider>(
  42. create: (_) => provider,
  43. child: WillPopScope(
  44. onWillPop: () {
  45. NavigatorUtils.goBackWithParams(context, true);
  46. return Future.value(false);
  47. },
  48. child: Scaffold(
  49. appBar: MyAppBar(
  50. centerTitle: "消息中心",
  51. ),
  52. body: Column(
  53. crossAxisAlignment: CrossAxisAlignment.start,
  54. children: <Widget>[
  55. Container(
  56. // 隐藏点击效果
  57. color: ThemeUtils.getTabsBg(context),
  58. child: TabBar(
  59. onTap: (index) {
  60. if (!mounted) {
  61. return;
  62. }
  63. _pageController.jumpToPage(index);
  64. },
  65. isScrollable: false,
  66. controller: _tabController,
  67. labelStyle: TextStyles.textBold18,
  68. indicatorSize: TabBarIndicatorSize.label,
  69. labelPadding: const EdgeInsets.all(0),
  70. unselectedLabelColor: Colours.text_gray,
  71. labelColor: Theme.of(context).primaryColor,
  72. indicatorPadding:
  73. const EdgeInsets.only(left: 5.0, right: 5.0),
  74. tabs: tabs.map((map) {
  75. return _TabView("${map["name"]}", "", map["id"]);
  76. }).toList()),
  77. ),
  78. Gaps.line,
  79. Expanded(
  80. child: PageView.builder(
  81. key: const Key('pageView'),
  82. itemCount: tabs.length,
  83. onPageChanged: _onPageChange,
  84. controller: _pageController,
  85. itemBuilder: (BuildContext context, int index) {
  86. return Container(
  87. color: ThemeUtils.getBackgroundColor(context),
  88. child: MessageList(index: index + 1));
  89. },
  90. ),
  91. )
  92. ],
  93. ),
  94. ),
  95. ));
  96. }
  97. @override
  98. bool get wantKeepAlive => true;
  99. }
  100. class _TabView extends StatelessWidget {
  101. const _TabView(this.tabName, this.tabSub, this.index);
  102. final String tabName;
  103. final String tabSub;
  104. final int index;
  105. @override
  106. Widget build(BuildContext context) {
  107. return p.Consumer<HeavyPageProvider>(
  108. builder: (_, provider, child) {
  109. return Tab(
  110. child: SizedBox(
  111. child: Row(
  112. crossAxisAlignment: CrossAxisAlignment.center,
  113. mainAxisAlignment: MainAxisAlignment.center,
  114. children: <Widget>[
  115. Text(
  116. tabName,
  117. style: TextStyle(fontSize: 15),
  118. ),
  119. Offstage(
  120. offstage: provider.index != index,
  121. child: Padding(
  122. padding: const EdgeInsets.only(top: 1.0),
  123. child: Text(tabSub,
  124. style: TextStyle(fontSize: Dimens.font_sp12)),
  125. )),
  126. ],
  127. ),
  128. ));
  129. },
  130. );
  131. }
  132. }