提交 bf93392c authored 作者: songchuancai's avatar songchuancai

调整菜单(隐藏对话菜单,登录后只显示应用列表)

上级 74a1a0b1
import 'package:allen/home_page.dart'; import 'package:allen/pages/apps_page.dart';
import 'package:allen/pallete.dart'; import 'package:allen/pallete.dart';
import 'package:allen/providers.dart'; import 'package:allen/providers.dart';
...@@ -55,12 +55,12 @@ class MyApp extends StatelessWidget { ...@@ -55,12 +55,12 @@ class MyApp extends StatelessWidget {
return const CircularProgressIndicator(); return const CircularProgressIndicator();
} }
return snapshot.hasData ? const HomePage() : const LoginPage(); return snapshot.hasData ? const AppsPage() : const LoginPage();
}, },
), ),
onGenerateRoute: (settings) { onGenerateRoute: (settings) {
if (settings.name == '/home') { if (settings.name == '/apps') {
return MaterialPageRoute(builder: (context) => const HomePage()); return MaterialPageRoute(builder: (context) => const AppsPage());
} }
if (settings.name == '/login') { if (settings.name == '/login') {
...@@ -76,10 +76,10 @@ class MyApp extends StatelessWidget { ...@@ -76,10 +76,10 @@ class MyApp extends StatelessWidget {
); );
} }
return MaterialPageRoute(builder: (context) => const HomePage()); return MaterialPageRoute(builder: (context) => const AppsPage());
} }
return MaterialPageRoute(builder: (context) => const HomePage()); return MaterialPageRoute(builder: (context) => const AppsPage());
}, },
); );
} }
......
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import '../services/api_service.dart';
import '../services/apps_service.dart'; import '../services/apps_service.dart';
import '../models/app_item.dart'; import '../models/app_item.dart';
...@@ -11,8 +10,6 @@ import '../services/storage_service.dart'; ...@@ -11,8 +10,6 @@ import '../services/storage_service.dart';
import '../models/user.dart'; import '../models/user.dart';
import 'package:shared_preferences/shared_preferences.dart';
class AppsPage extends StatefulWidget { class AppsPage extends StatefulWidget {
const AppsPage({super.key}); const AppsPage({super.key});
...@@ -39,12 +36,13 @@ class _AppsPageState extends State<AppsPage> { ...@@ -39,12 +36,13 @@ class _AppsPageState extends State<AppsPage> {
static const int _pageSize = 4; static const int _pageSize = 4;
User? _currentUser;
@override @override
void initState() { void initState() {
super.initState(); super.initState();
_loadUserInfo();
_initializeService(); _initializeService();
_scrollController.addListener(_onScroll); _scrollController.addListener(_onScroll);
} }
...@@ -126,6 +124,20 @@ class _AppsPageState extends State<AppsPage> { ...@@ -126,6 +124,20 @@ class _AppsPageState extends State<AppsPage> {
} }
} }
Future<void> _loadUserInfo() async {
final user = await StorageService.getUser();
setState(() {
_currentUser = user;
});
}
void _handleLogout() async {
await StorageService.clearUser();
if (mounted) {
Navigator.pushReplacementNamed(context, '/login');
}
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
if (isLoading) { if (isLoading) {
...@@ -136,7 +148,38 @@ class _AppsPageState extends State<AppsPage> { ...@@ -136,7 +148,38 @@ class _AppsPageState extends State<AppsPage> {
return Center(child: Text(error!)); return Center(child: Text(error!));
} }
return ListView.builder( return Scaffold(
appBar: AppBar(
automaticallyImplyLeading: false,
title: const Text(
'我的应用',
style: TextStyle(
fontSize: 24,
fontWeight: FontWeight.bold,
),
),
actions: [
if (_currentUser != null) ...[
Center(
child: Text(
_currentUser!.username,
style: const TextStyle(
fontSize: 16,
fontWeight: FontWeight.w500,
),
),
),
const SizedBox(width: 12),
IconButton(
icon: const Icon(Icons.logout),
onPressed: _handleLogout,
tooltip: '退出登录',
),
const SizedBox(width: 8),
],
],
),
body: ListView.builder(
controller: _scrollController, controller: _scrollController,
padding: const EdgeInsets.all(16), padding: const EdgeInsets.all(16),
itemCount: apps.length + (_hasMoreData ? 1 : 0), itemCount: apps.length + (_hasMoreData ? 1 : 0),
...@@ -197,6 +240,7 @@ class _AppsPageState extends State<AppsPage> { ...@@ -197,6 +240,7 @@ class _AppsPageState extends State<AppsPage> {
), ),
); );
}, },
),
); );
} }
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论