CommunityAPP/lib/login_page.dart

134 lines
4.3 KiB
Dart

import 'package:flutter/material.dart';
import 'home_page.dart'; // 要跳轉的頁面
class LoginPage extends StatefulWidget {
const LoginPage({super.key});
@override
State<LoginPage> createState() => _LoginPageState();
}
class _LoginPageState extends State<LoginPage> {
final TextEditingController _emailController = TextEditingController();
final TextEditingController _passwordController = TextEditingController();
void _login() {
String account = _emailController.text.trim();
String password = _passwordController.text;
if (account == 'admin' && password == '1234') {
// 登入成功,跳轉到主畫面
Navigator.pushReplacement(
context,
MaterialPageRoute(builder: (context) => const HomePage()),
);
} else {
// 登入失敗,跳出錯誤訊息
showDialog(
context: context,
builder:
(_) => AlertDialog(
title: const Text('登入失敗'),
content: const Text('帳號或密碼錯誤,請重新輸入。'),
actions: [
TextButton(
onPressed: () => Navigator.pop(context),
child: const Text('確定'),
),
],
),
);
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.grey[100],
body: Center(
child: SingleChildScrollView(
padding: const EdgeInsets.all(16),
child: Container(
padding: const EdgeInsets.all(24),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(20),
boxShadow: [
BoxShadow(
color: Colors.black.withOpacity(0.1),
blurRadius: 10,
offset: const Offset(0, 5),
),
],
),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
CircleAvatar(
radius: 64,
backgroundImage: AssetImage('assets/images/login.png'),
),
const SizedBox(height: 24),
const Text(
'歡迎回來',
style: TextStyle(fontSize: 24, fontWeight: FontWeight.bold),
),
const SizedBox(height: 24),
TextField(
controller: _emailController,
decoration: InputDecoration(
labelText: '帳號',
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(10),
),
),
),
const SizedBox(height: 16),
TextField(
controller: _passwordController,
decoration: InputDecoration(
labelText: '密碼',
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(10),
),
),
obscureText: true,
),
const SizedBox(height: 24),
SizedBox(
width: double.infinity,
child: ElevatedButton(
onPressed: _login,
style: ElevatedButton.styleFrom(
backgroundColor: Colors.indigo,
padding: const EdgeInsets.symmetric(vertical: 14),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(10),
),
),
child: const Text(
'登入',
style: TextStyle(color: Colors.white),
),
),
),
const SizedBox(height: 16),
TextButton(
onPressed: () {},
child: const Text(
'忘記密碼?',
style: TextStyle(
color: Colors.indigo,
decoration: TextDecoration.underline,
),
),
),
],
),
),
),
),
);
}
}