Commit 08a0f5a8d40e5fc98111857b64f62efb4d149995
1 parent
3c1d5c64
feat:路由方式更新
Showing
11 changed files
with
178 additions
and
112 deletions
ios/Runner.xcodeproj/project.pbxproj
| ... | ... | @@ -54,6 +54,7 @@ |
| 54 | 54 | 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; }; |
| 55 | 55 | 48BCA0827DCB98991774F5AC /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = "<group>"; }; |
| 56 | 56 | 52450AF02A4C415B007B3E4B /* XSMessageMehtodChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = XSMessageMehtodChannel.swift; sourceTree = "<group>"; }; |
| 57 | + 52450AF22A4ED0EC007B3E4B /* Runner.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = Runner.entitlements; sourceTree = "<group>"; }; | |
| 57 | 58 | 525E17192A4BD03900104CDF /* VoiceXSMessageChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = VoiceXSMessageChannel.swift; sourceTree = "<group>"; }; |
| 58 | 59 | 6DEBBC1D861BE053F3ECE0B9 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; }; |
| 59 | 60 | 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; }; |
| ... | ... | @@ -147,6 +148,7 @@ |
| 147 | 148 | 97C146F01CF9000F007C117D /* Runner */ = { |
| 148 | 149 | isa = PBXGroup; |
| 149 | 150 | children = ( |
| 151 | + 52450AF22A4ED0EC007B3E4B /* Runner.entitlements */, | |
| 150 | 152 | 97C146FA1CF9000F007C117D /* Main.storyboard */, |
| 151 | 153 | 97C146FD1CF9000F007C117D /* Assets.xcassets */, |
| 152 | 154 | 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */, |
| ... | ... | @@ -492,6 +494,7 @@ |
| 492 | 494 | buildSettings = { |
| 493 | 495 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
| 494 | 496 | CLANG_ENABLE_MODULES = YES; |
| 497 | + CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; | |
| 495 | 498 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
| 496 | 499 | DEVELOPMENT_TEAM = T8P9KW8GWH; |
| 497 | 500 | ENABLE_BITCODE = NO; |
| ... | ... | @@ -671,6 +674,7 @@ |
| 671 | 674 | buildSettings = { |
| 672 | 675 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
| 673 | 676 | CLANG_ENABLE_MODULES = YES; |
| 677 | + CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; | |
| 674 | 678 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
| 675 | 679 | DEVELOPMENT_TEAM = T8P9KW8GWH; |
| 676 | 680 | ENABLE_BITCODE = NO; |
| ... | ... | @@ -694,6 +698,7 @@ |
| 694 | 698 | buildSettings = { |
| 695 | 699 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
| 696 | 700 | CLANG_ENABLE_MODULES = YES; |
| 701 | + CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; | |
| 697 | 702 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
| 698 | 703 | DEVELOPMENT_TEAM = T8P9KW8GWH; |
| 699 | 704 | ENABLE_BITCODE = NO; | ... | ... |
ios/Runner/Runner.entitlements
0 → 100644
lib/app/splash_page.dart
| ... | ... | @@ -36,9 +36,9 @@ class _TransitionViewState extends State<TransitionView> { |
| 36 | 36 | Timer(const Duration(seconds: 2), () { |
| 37 | 37 | if (userEntity != null) { |
| 38 | 38 | // todo 调一下接口判断一下有效性再往下 |
| 39 | - Navigator.of(context).pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 39 | + pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 40 | 40 | } else { |
| 41 | - Navigator.of(context).pushNamedAndRemoveUntil(AppRouteName.login, (route) => false); | |
| 41 | + pushNamedAndRemoveUntil(AppRouteName.login, (route) => false); | |
| 42 | 42 | } |
| 43 | 43 | }); |
| 44 | 44 | } | ... | ... |
lib/pages/home/home_page.dart
| ... | ... | @@ -29,15 +29,15 @@ class HomePage extends StatelessWidget { |
| 29 | 29 | class _HomePageView extends StatelessWidget { |
| 30 | 30 | void _headerActionEvent(HeaderActionType type) { |
| 31 | 31 | if (type == HeaderActionType.video) { |
| 32 | - Navigator.of(AppRouter.context).pushNamed(AppRouteName.reAfter); | |
| 32 | + pushNamed(AppRouteName.reAfter); | |
| 33 | 33 | } else if (type == HeaderActionType.phase) { |
| 34 | - Navigator.of(AppRouter.context).pushNamed(AppRouteName.lesson); | |
| 34 | + pushNamed(AppRouteName.lesson); | |
| 35 | 35 | } else if (type == HeaderActionType.listen) { |
| 36 | - Navigator.of(AppRouter.context).pushNamed(AppRouteName.listen); | |
| 36 | + pushNamed(AppRouteName.listen); | |
| 37 | 37 | } else if (type == HeaderActionType.shop) { |
| 38 | - Navigator.of(AppRouter.context).pushNamed(AppRouteName.shop); | |
| 38 | + pushNamed(AppRouteName.shop); | |
| 39 | 39 | } else if (type == HeaderActionType.user) { |
| 40 | - Navigator.of(AppRouter.context).pushNamed(AppRouteName.user); | |
| 40 | + pushNamed(AppRouteName.user); | |
| 41 | 41 | } else { |
| 42 | 42 | |
| 43 | 43 | } |
| ... | ... | @@ -66,7 +66,7 @@ class _HomePageView extends StatelessWidget { |
| 66 | 66 | if (videoUrl.isEmpty) { |
| 67 | 67 | return; |
| 68 | 68 | } |
| 69 | - Navigator.of(context).pushNamed(AppRouteName.lookVideo,arguments: {'videoUrl':videoUrl,'title':title}); | |
| 69 | + pushNamed(AppRouteName.lookVideo,arguments: {'videoUrl':videoUrl,'title':title}); | |
| 70 | 70 | } |
| 71 | 71 | }, |
| 72 | 72 | child: _homeView(), |
| ... | ... | @@ -74,100 +74,100 @@ class _HomePageView extends StatelessWidget { |
| 74 | 74 | } |
| 75 | 75 | |
| 76 | 76 | Widget _homeView() => BlocBuilder<HomeBloc, HomeState>(builder: (context, state) { |
| 77 | - final bloc = BlocProvider.of<HomeBloc>(context); | |
| 78 | - return Scaffold( | |
| 79 | - body: Container( | |
| 80 | - color: Colors.white, | |
| 81 | - child: Center( | |
| 82 | - child: Column( | |
| 83 | - mainAxisAlignment: MainAxisAlignment.spaceBetween, | |
| 84 | - children: [ | |
| 85 | - HomeTabHeaderWidget( | |
| 86 | - actionTap: (HeaderActionType type) { | |
| 87 | - _headerActionEvent(type); | |
| 88 | - }, | |
| 89 | - ), | |
| 90 | - Expanded( | |
| 91 | - child: ListView.builder( | |
| 92 | - itemCount: bloc.modelData?.totalCourseLesson, | |
| 93 | - scrollDirection: Axis.horizontal, | |
| 94 | - itemBuilder: (BuildContext context, int index) { | |
| 95 | - CourseCourseLessons? data = bloc.modelData?.courseLessons?[index]; | |
| 96 | - if (data?.courseType == 5) { | |
| 97 | - //彩蛋 | |
| 98 | - return GestureDetector( | |
| 99 | - onTap: () { | |
| 100 | - if (data!.lock!) { | |
| 101 | - showToast('当前课程暂未解锁'); | |
| 102 | - return; | |
| 103 | - } | |
| 104 | - bloc.add(RequestVideoLessonEvent(data.id!,data.courseType!)); | |
| 105 | - }, | |
| 106 | - child: HomeBoundsItem( | |
| 107 | - imageUrl: data?.coverUrl, | |
| 108 | - ), | |
| 109 | - ); | |
| 110 | - } else { | |
| 111 | - return GestureDetector( | |
| 112 | - onTap: () { | |
| 113 | - debugPrint('>>>>>>>类型${data?.courseType}'); | |
| 114 | - if (data!.lock!) { | |
| 115 | - showToast('当前课程暂未解锁'); | |
| 116 | - return; | |
| 117 | - } | |
| 118 | - if (data.courseType == 4) {//绘本 | |
| 119 | - return; | |
| 120 | - } | |
| 77 | + final bloc = BlocProvider.of<HomeBloc>(context); | |
| 78 | + return Scaffold( | |
| 79 | + body: Container( | |
| 80 | + color: Colors.white, | |
| 81 | + child: Center( | |
| 82 | + child: Column( | |
| 83 | + mainAxisAlignment: MainAxisAlignment.spaceBetween, | |
| 84 | + children: [ | |
| 85 | + HomeTabHeaderWidget( | |
| 86 | + actionTap: (HeaderActionType type) { | |
| 87 | + _headerActionEvent(type); | |
| 88 | + }, | |
| 89 | + ), | |
| 90 | + Expanded( | |
| 91 | + child: ListView.builder( | |
| 92 | + itemCount: bloc.modelData?.totalCourseLesson, | |
| 93 | + scrollDirection: Axis.horizontal, | |
| 94 | + itemBuilder: (BuildContext context, int index) { | |
| 95 | + CourseCourseLessons? data = bloc.modelData?.courseLessons?[index]; | |
| 96 | + if (data?.courseType == 5) { | |
| 97 | + //彩蛋 | |
| 98 | + return GestureDetector( | |
| 99 | + onTap: () { | |
| 100 | + if (data!.lock!) { | |
| 101 | + showToast('当前课程暂未解锁'); | |
| 102 | + return; | |
| 103 | + } | |
| 104 | + bloc.add(RequestVideoLessonEvent(data.id!,data.courseType!)); | |
| 105 | + }, | |
| 106 | + child: HomeBoundsItem( | |
| 107 | + imageUrl: data?.coverUrl, | |
| 108 | + ), | |
| 109 | + ); | |
| 110 | + } else { | |
| 111 | + return GestureDetector( | |
| 112 | + onTap: () { | |
| 113 | + debugPrint('>>>>>>>类型${data?.courseType}'); | |
| 114 | + if (data!.lock!) { | |
| 115 | + showToast('当前课程暂未解锁'); | |
| 116 | + return; | |
| 117 | + } | |
| 118 | + if (data.courseType == 4) {//绘本 | |
| 119 | + return; | |
| 120 | + } | |
| 121 | 121 | |
| 122 | - if (data.courseType == 3) {//练习 | |
| 123 | - Navigator.of(context).pushNamed(AppRouteName.topicPic,arguments: {'courseLessonId':data.id!}); | |
| 124 | - return; | |
| 125 | - } | |
| 122 | + if (data.courseType == 3) {//练习 | |
| 123 | + Navigator.of(context).pushNamed(AppRouteName.topicPic,arguments: {'courseLessonId':data.id!}); | |
| 124 | + return; | |
| 125 | + } | |
| 126 | 126 | |
| 127 | - //儿歌/看视频 | |
| 128 | - bloc.add(RequestVideoLessonEvent(data.id!,data.courseType!)); | |
| 129 | - }, | |
| 130 | - child: HomeVideoItem( | |
| 131 | - lessons: data, | |
| 132 | - ), | |
| 133 | - ); | |
| 134 | - } | |
| 135 | - })), | |
| 136 | - SafeArea( | |
| 137 | - child: Padding( | |
| 138 | - padding: EdgeInsets.symmetric(horizontal: 13.w), | |
| 139 | - child: Row( | |
| 140 | - mainAxisAlignment: MainAxisAlignment.spaceBetween, | |
| 141 | - children: [ | |
| 142 | - SizedBox( | |
| 143 | - height: 47.h, | |
| 144 | - width: 80.w, | |
| 145 | - ), | |
| 146 | - Container( | |
| 147 | - decoration: BoxDecoration( | |
| 148 | - color: Colors.blue, | |
| 149 | - borderRadius: BorderRadius.circular(14.5.r), | |
| 150 | - ), | |
| 151 | - padding: EdgeInsets.symmetric(vertical: 8.h, horizontal: 24.w), | |
| 152 | - child: Text( | |
| 153 | - '${(bloc.modelData?.nowCourseLesson)}/${bloc.modelData?.totalCourseLesson}', | |
| 154 | - style: TextStyle(color: Colors.white, fontSize: 12.sp), | |
| 127 | + //儿歌/看视频 | |
| 128 | + bloc.add(RequestVideoLessonEvent(data.id!,data.courseType!)); | |
| 129 | + }, | |
| 130 | + child: HomeVideoItem( | |
| 131 | + lessons: data, | |
| 155 | 132 | ), |
| 156 | - ), | |
| 157 | - Image.asset( | |
| 158 | - 'blue-positive'.assetPng, | |
| 159 | - height: 47.h, | |
| 160 | - width: 80.w, | |
| 161 | - // color: Colors.red, | |
| 162 | - ), | |
| 163 | - ], | |
| 133 | + ); | |
| 134 | + } | |
| 135 | + })), | |
| 136 | + SafeArea( | |
| 137 | + child: Padding( | |
| 138 | + padding: EdgeInsets.symmetric(horizontal: 13.w), | |
| 139 | + child: Row( | |
| 140 | + mainAxisAlignment: MainAxisAlignment.spaceBetween, | |
| 141 | + children: [ | |
| 142 | + SizedBox( | |
| 143 | + height: 47.h, | |
| 144 | + width: 80.w, | |
| 164 | 145 | ), |
| 165 | - ), | |
| 166 | - ) | |
| 167 | - ], | |
| 168 | - ), | |
| 169 | - ), | |
| 146 | + Container( | |
| 147 | + decoration: BoxDecoration( | |
| 148 | + color: Colors.blue, | |
| 149 | + borderRadius: BorderRadius.circular(14.5.r), | |
| 150 | + ), | |
| 151 | + padding: EdgeInsets.symmetric(vertical: 8.h, horizontal: 24.w), | |
| 152 | + child: Text( | |
| 153 | + '${(bloc.modelData?.nowCourseLesson)}/${bloc.modelData?.totalCourseLesson}', | |
| 154 | + style: TextStyle(color: Colors.white, fontSize: 12.sp), | |
| 155 | + ), | |
| 156 | + ), | |
| 157 | + Image.asset( | |
| 158 | + 'blue-positive'.assetPng, | |
| 159 | + height: 47.h, | |
| 160 | + width: 80.w, | |
| 161 | + // color: Colors.red, | |
| 162 | + ), | |
| 163 | + ], | |
| 164 | + ), | |
| 165 | + ), | |
| 166 | + ) | |
| 167 | + ], | |
| 170 | 168 | ), |
| 171 | - ); | |
| 172 | - }); | |
| 169 | + ), | |
| 170 | + ), | |
| 171 | + ); | |
| 172 | + }); | |
| 173 | 173 | } | ... | ... |
lib/pages/lessons/lesson_page.dart
| ... | ... | @@ -171,7 +171,7 @@ class _LessonPageView extends StatelessWidget { |
| 171 | 171 | model: model, |
| 172 | 172 | isSelected: bloc.currentPageIndex == index, |
| 173 | 173 | onClickEvent: () { |
| 174 | - Navigator.of(context).pushNamedAndRemoveUntil(AppRouteName.home, (route) => false,arguments: {'moduleId':model?.id}); | |
| 174 | + pushNamedAndRemoveUntil(AppRouteName.home, (route) => false,arguments: {'moduleId':model?.id}); | |
| 175 | 175 | }, |
| 176 | 176 | ), |
| 177 | 177 | ), | ... | ... |
lib/pages/login/loginpage/login_page.dart
| ... | ... | @@ -30,7 +30,7 @@ class _LoginPageView extends StatelessWidget { |
| 30 | 30 | if (state is LoginResultChangeState) { |
| 31 | 31 | // 调试用 |
| 32 | 32 | // Navigator.of(context).pushNamed(AppRouteName.home); |
| 33 | - Navigator.of(context).pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 33 | + pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 34 | 34 | } |
| 35 | 35 | }, |
| 36 | 36 | child: _buildLoginViewWidget(), | ... | ... |
lib/pages/login/setpwd/set_pwd_page.dart
| ... | ... | @@ -57,7 +57,7 @@ class _SetPassWordPageView extends StatelessWidget { |
| 57 | 57 | } else { |
| 58 | 58 | showToast('密码修改成功'); |
| 59 | 59 | } |
| 60 | - Navigator.of(context).pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 60 | + pushNamedAndRemoveUntil(AppRouteName.home, (route) => false); | |
| 61 | 61 | } else if (state is PasswordSetFailedState) { |
| 62 | 62 | state.message.toast(); |
| 63 | 63 | } | ... | ... |
lib/pages/repeatafter/repeat_after_page.dart
| ... | ... | @@ -3,7 +3,7 @@ import 'package:flutter_bloc/flutter_bloc.dart'; |
| 3 | 3 | import 'package:wow_english/common/widgets/we_app_bar.dart'; |
| 4 | 4 | import 'package:wow_english/models/follow_read_entity.dart'; |
| 5 | 5 | import 'package:wow_english/pages/repeatafter/widgets/repeat_after_item.dart'; |
| 6 | -import 'package:wow_english/utils/toast_util.dart'; | |
| 6 | +import 'package:wow_english/route/route.dart'; | |
| 7 | 7 | |
| 8 | 8 | import 'bloc/repeat_after_bloc.dart'; |
| 9 | 9 | |
| ... | ... | @@ -24,9 +24,7 @@ class _RepeatAfterPageView extends StatelessWidget { |
| 24 | 24 | Widget build(BuildContext context) { |
| 25 | 25 | return BlocListener<RepeatAfterBloc, RepeatAfterState>( |
| 26 | 26 | listener: (context, state) { |
| 27 | - if (state is RequestDataState) { | |
| 28 | - showToast('网络请求结束'); | |
| 29 | - } | |
| 27 | + | |
| 30 | 28 | }, |
| 31 | 29 | child: _repeatAfterView(), |
| 32 | 30 | ); |
| ... | ... | @@ -49,7 +47,9 @@ class _RepeatAfterPageView extends StatelessWidget { |
| 49 | 47 | itemBuilder: (BuildContext context, int index) { |
| 50 | 48 | FollowReadEntity? entity = bloc.listData[index]; |
| 51 | 49 | return RepeatAfterItem( |
| 52 | - tapEvent: () {}, | |
| 50 | + tapEvent: () { | |
| 51 | + pushNamed(AppRouteName.readAfterContent); | |
| 52 | + }, | |
| 53 | 53 | entity: entity, |
| 54 | 54 | ); |
| 55 | 55 | }), | ... | ... |
lib/pages/repeatafter/widgets/repeat_after_item.dart
| ... | ... | @@ -5,11 +5,11 @@ import 'package:wow_english/common/widgets/ow_image_widget.dart'; |
| 5 | 5 | import 'package:wow_english/models/follow_read_entity.dart'; |
| 6 | 6 | |
| 7 | 7 | class RepeatAfterItem extends StatelessWidget { |
| 8 | - const RepeatAfterItem({super.key, required this.tapEvent, this.entity}); | |
| 8 | + const RepeatAfterItem({super.key, this.tapEvent, this.entity}); | |
| 9 | 9 | |
| 10 | 10 | final FollowReadEntity? entity; |
| 11 | 11 | |
| 12 | - final Function() tapEvent; | |
| 12 | + final Function()? tapEvent; | |
| 13 | 13 | |
| 14 | 14 | @override |
| 15 | 15 | Widget build(BuildContext context) { |
| ... | ... | @@ -20,8 +20,8 @@ class RepeatAfterItem extends StatelessWidget { |
| 20 | 20 | child: GestureDetector( |
| 21 | 21 | onTap: (){ |
| 22 | 22 | if (entity != null) { |
| 23 | - if (entity?.lock??false) { | |
| 24 | - tapEvent(); | |
| 23 | + if (!entity!.lock!) { | |
| 24 | + tapEvent?.call(); | |
| 25 | 25 | } |
| 26 | 26 | } |
| 27 | 27 | }, | ... | ... |
lib/pages/repeataftercontent/repeat_after_content_page.dart
0 → 100644
| 1 | +import 'package:flutter/material.dart'; | |
| 2 | +import 'package:flutter_screenutil/flutter_screenutil.dart'; | |
| 3 | +import 'package:wow_english/common/extension/string_extension.dart'; | |
| 4 | +import 'package:wow_english/route/route.dart'; | |
| 5 | + | |
| 6 | +class RepeatAfterContentPage extends StatelessWidget { | |
| 7 | + const RepeatAfterContentPage({super.key}); | |
| 8 | + | |
| 9 | + @override | |
| 10 | + Widget build(BuildContext context) { | |
| 11 | + return Container( | |
| 12 | + color: Colors.white, | |
| 13 | + child: SafeArea( | |
| 14 | + child: Stack( | |
| 15 | + children: [ | |
| 16 | + Positioned( | |
| 17 | + top: 13.h, | |
| 18 | + child: GestureDetector( | |
| 19 | + onTap: () => popPage(), | |
| 20 | + child: Image.asset( | |
| 21 | + 'back_around'.assetPng, | |
| 22 | + height: 40.h, | |
| 23 | + width: 40.w, | |
| 24 | + ), | |
| 25 | + ), | |
| 26 | + ) | |
| 27 | + ], | |
| 28 | + ), | |
| 29 | + ), | |
| 30 | + ); | |
| 31 | + } | |
| 32 | +} | |
| 0 | 33 | \ No newline at end of file | ... | ... |
lib/route/route.dart
| ... | ... | @@ -10,6 +10,7 @@ import 'package:wow_english/pages/login/loginpage/login_page.dart'; |
| 10 | 10 | import 'package:wow_english/pages/login/setpwd/set_pwd_page.dart'; |
| 11 | 11 | import 'package:wow_english/pages/practice/topic_picture_page.dart'; |
| 12 | 12 | import 'package:wow_english/pages/repeatafter/repeat_after_page.dart'; |
| 13 | +import 'package:wow_english/pages/repeataftercontent/repeat_after_content_page.dart'; | |
| 13 | 14 | import 'package:wow_english/pages/shop/exchane/exchange_lesson_page.dart'; |
| 14 | 15 | import 'package:wow_english/pages/shop/exchangelist/exchange_lesson_list_page.dart'; |
| 15 | 16 | import 'package:wow_english/pages/shop/home/shop_home_page.dart'; |
| ... | ... | @@ -40,10 +41,14 @@ class AppRouteName { |
| 40 | 41 | |
| 41 | 42 | /// 用户详细信息页 |
| 42 | 43 | static const String userInformation = 'userInformation'; |
| 44 | + ///看视频 | |
| 43 | 45 | static const String lookVideo = 'lookVideo'; |
| 46 | + ///绘本 | |
| 44 | 47 | static const String reading = 'reading'; |
| 48 | + ///视频跟读详情 | |
| 49 | + static const String readAfterContent = 'readAfterContent'; | |
| 50 | + | |
| 45 | 51 | |
| 46 | - ///绘本 | |
| 47 | 52 | static const String tab = '/'; |
| 48 | 53 | } |
| 49 | 54 | |
| ... | ... | @@ -123,6 +128,9 @@ class AppRouter { |
| 123 | 128 | urlStr: urlStr, |
| 124 | 129 | webViewTitle: webViewTitle, |
| 125 | 130 | )); |
| 131 | + case AppRouteName.readAfterContent: | |
| 132 | + return CupertinoPageRoute( | |
| 133 | + builder: (_) => const RepeatAfterContentPage()); | |
| 126 | 134 | case AppRouteName.tab: |
| 127 | 135 | return PageRouteBuilder( |
| 128 | 136 | opaque: false, |
| ... | ... | @@ -138,3 +146,16 @@ class AppRouter { |
| 138 | 146 | } |
| 139 | 147 | } |
| 140 | 148 | } |
| 149 | + | |
| 150 | +void pushNamed(String routeName, {Object? arguments}) { | |
| 151 | + Navigator.of(AppRouter.context).pushNamed(routeName,arguments: arguments); | |
| 152 | +} | |
| 153 | + | |
| 154 | +void pushNamedAndRemoveUntil(String routeName,RoutePredicate predicate, {Object? arguments}) { | |
| 155 | + Navigator.of(AppRouter.context).pushNamedAndRemoveUntil(routeName, predicate,arguments: arguments); | |
| 156 | +} | |
| 157 | + | |
| 158 | +void popPage() { | |
| 159 | + Navigator.pop(AppRouter.context); | |
| 160 | +} | |
| 161 | + | ... | ... |