message_list_page.dart 4.6 KB

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