🎨 Continued to rearrange core folders content
This commit is contained in:
34
lib/shared/tour/techincal_review_intro.dart
Normal file
34
lib/shared/tour/techincal_review_intro.dart
Normal file
@@ -0,0 +1,34 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:gap/gap.dart';
|
||||
import 'package:island/drive/content/sheet_scaffold.dart';
|
||||
import 'package:styled_widget/styled_widget.dart';
|
||||
|
||||
class TechicalReviewIntroWidget extends StatelessWidget {
|
||||
const TechicalReviewIntroWidget({super.key});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return SheetScaffold(
|
||||
titleText: '技术性预览',
|
||||
child: SingleChildScrollView(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
||||
children: [
|
||||
Text('👋').fontSize(32),
|
||||
Text('你好呀~').fontSize(24),
|
||||
Text('欢迎来使用 Solar Network 3.0 的技术性预览版。'),
|
||||
const Gap(24),
|
||||
Text('技术性预览的初衷是让我们更顺滑的将 3.0 发布出来,帮助我们一点一点的迁移数据。'),
|
||||
const Gap(24),
|
||||
Text('同时,既然是测试版,肯定有一系列的 Bug 和问题,请多多包涵,也欢迎积极反馈到 GitHub 上。'),
|
||||
Text('目前帐号数据已经迁移完毕,其他数据将在未来逐渐迁移。还请耐心等待,不要重复创建以免未来数据冲突。'),
|
||||
const Gap(24),
|
||||
Text('最后,感谢你愿意参与技术性预览,祝你使用愉快!'),
|
||||
const Gap(16),
|
||||
Text('关掉这个对话框就开始探索吧!').fontSize(11),
|
||||
],
|
||||
).padding(horizontal: 20, vertical: 24),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
36
lib/shared/tour/tour.dart
Normal file
36
lib/shared/tour/tour.dart
Normal file
@@ -0,0 +1,36 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_hooks/flutter_hooks.dart';
|
||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||
import 'package:island/core/services/tour.dart';
|
||||
|
||||
const List<String> kStartTours = ['technical_review_intro'];
|
||||
|
||||
class TourTriggerWidget extends HookConsumerWidget {
|
||||
final Widget child;
|
||||
const TourTriggerWidget({super.key, required this.child});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final tourStatus = ref.watch(tourStatusProvider.notifier);
|
||||
|
||||
useEffect(() {
|
||||
Future(() async {
|
||||
for (final tour in kStartTours) {
|
||||
final widget = await tourStatus.showTour(tour);
|
||||
if (widget != null) {
|
||||
if (!context.mounted) return;
|
||||
await showModalBottomSheet(
|
||||
isScrollControlled: true,
|
||||
useRootNavigator: true,
|
||||
context: context,
|
||||
builder: (context) => widget,
|
||||
);
|
||||
}
|
||||
}
|
||||
});
|
||||
return null;
|
||||
}, [tourStatus]);
|
||||
|
||||
return child;
|
||||
}
|
||||
}
|
||||
@@ -6,7 +6,7 @@ import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||
import 'package:in_app_review/in_app_review.dart';
|
||||
import 'package:island/auth/web_auth/web_auth_providers.dart';
|
||||
import 'package:island/notifications/notification.dart';
|
||||
import 'package:island/thought/thought/think_sheet.dart';
|
||||
import 'package:island/thoughts/think_sheet.dart';
|
||||
import 'package:protocol_handler/protocol_handler.dart';
|
||||
import 'package:island/activity/activity_rpc.dart';
|
||||
import 'package:island/core/config.dart';
|
||||
@@ -18,8 +18,8 @@ import 'package:island/settings/tray_manager.dart';
|
||||
import 'package:island/core/services/notify.dart';
|
||||
import 'package:island/core/services/sharing_intent.dart';
|
||||
import 'package:island/core/services/update_service.dart';
|
||||
import 'package:island/core/widgets/content/network_status_sheet.dart';
|
||||
import 'package:island/core/tour/tour.dart';
|
||||
import 'package:island/drive/content/network_status_sheet.dart';
|
||||
import 'package:island/shared/tour/tour.dart';
|
||||
import 'package:island/posts/posts_widgets/compose_sheet.dart';
|
||||
import 'package:island/core/services/event_bus.dart';
|
||||
import 'package:snow_fall_animation/snow_fall_animation.dart';
|
||||
|
||||
@@ -6,8 +6,8 @@ import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||
import 'package:island/drive/drive_models/file.dart';
|
||||
import 'package:island/drive/drive_models/file_pool.dart';
|
||||
import 'package:island/drive/drive/file_pool.dart';
|
||||
import 'package:island/core/widgets/content/attachment_preview.dart';
|
||||
import 'package:island/core/widgets/content/sheet.dart';
|
||||
import 'package:island/drive/content/attachment_preview.dart';
|
||||
import 'package:island/drive/content/sheet_scaffold.dart';
|
||||
import 'package:easy_localization/easy_localization.dart';
|
||||
import 'package:gap/gap.dart';
|
||||
import 'package:island/posts/posts_widgets/post/compose_shared.dart';
|
||||
|
||||
30
lib/shared/widgets/navigation/conditional_bottom_nav.dart
Normal file
30
lib/shared/widgets/navigation/conditional_bottom_nav.dart
Normal file
@@ -0,0 +1,30 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_hooks/flutter_hooks.dart';
|
||||
import 'package:go_router/go_router.dart';
|
||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||
import 'package:island/settings/tabs_screen.dart';
|
||||
import 'package:island/core/services/responsive.dart';
|
||||
|
||||
class ConditionalBottomNav extends HookConsumerWidget {
|
||||
final Widget child;
|
||||
const ConditionalBottomNav({super.key, required this.child});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final currentLocation = GoRouterState.of(context).uri.toString();
|
||||
|
||||
// Force rebuild when route changes
|
||||
useEffect(() {
|
||||
// This effect will run whenever currentLocation changes
|
||||
return null;
|
||||
}, [currentLocation]);
|
||||
|
||||
final routes = kTabRoutes.sublist(
|
||||
0,
|
||||
isWideScreen(context) ? null : kWideScreenRouteStart,
|
||||
);
|
||||
final shouldShowBottomNav = routes.contains(currentLocation);
|
||||
|
||||
return shouldShowBottomNav ? child : const SizedBox.shrink();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user