234 lines
6.8 KiB
Dart
234 lines
6.8 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:penyaluran_app/app/modules/profile/controllers/profile_controller.dart';
|
|
import 'package:penyaluran_app/app/theme/app_theme.dart';
|
|
|
|
class ProfileView extends GetView<ProfileController> {
|
|
const ProfileView({Key? key}) : super(key: key);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: const Text('Profil'),
|
|
actions: [
|
|
Obx(() {
|
|
if (controller.isEditing.value) {
|
|
return IconButton(
|
|
icon: const Icon(Icons.save),
|
|
onPressed: controller.updateProfile,
|
|
);
|
|
} else {
|
|
return IconButton(
|
|
icon: const Icon(Icons.edit),
|
|
onPressed: controller.toggleEditMode,
|
|
);
|
|
}
|
|
}),
|
|
],
|
|
),
|
|
body: Obx(() {
|
|
if (controller.isLoading.value) {
|
|
return const Center(child: CircularProgressIndicator());
|
|
}
|
|
|
|
return SingleChildScrollView(
|
|
padding: const EdgeInsets.all(16.0),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
_buildProfileHeader(),
|
|
const SizedBox(height: 24),
|
|
_buildProfileForm(),
|
|
const SizedBox(height: 24),
|
|
_buildPasswordSection(context),
|
|
],
|
|
),
|
|
);
|
|
}),
|
|
);
|
|
}
|
|
|
|
Widget _buildProfileHeader() {
|
|
return Center(
|
|
child: Column(
|
|
children: [
|
|
const CircleAvatar(
|
|
radius: 50,
|
|
backgroundColor: AppTheme.primaryColor,
|
|
child: Icon(
|
|
Icons.person,
|
|
size: 60,
|
|
color: Colors.white,
|
|
),
|
|
),
|
|
const SizedBox(height: 16),
|
|
Obx(() => Text(
|
|
controller.user.value?.name ?? 'Pengguna',
|
|
style: const TextStyle(
|
|
fontSize: 24,
|
|
fontWeight: FontWeight.bold,
|
|
),
|
|
)),
|
|
const SizedBox(height: 4),
|
|
Obx(() => Text(
|
|
controller.user.value?.role?.toUpperCase() ?? 'PENGGUNA',
|
|
style: TextStyle(
|
|
fontSize: 14,
|
|
color: Colors.grey[600],
|
|
fontWeight: FontWeight.w500,
|
|
),
|
|
)),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
|
|
Widget _buildProfileForm() {
|
|
return Obx(() {
|
|
final isEditing = controller.isEditing.value;
|
|
|
|
return Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
const Text(
|
|
'Informasi Pribadi',
|
|
style: TextStyle(
|
|
fontSize: 18,
|
|
fontWeight: FontWeight.bold,
|
|
),
|
|
),
|
|
const SizedBox(height: 16),
|
|
|
|
// Nama
|
|
TextField(
|
|
controller: controller.nameController,
|
|
decoration: InputDecoration(
|
|
labelText: 'Nama Lengkap',
|
|
border: OutlineInputBorder(),
|
|
prefixIcon: Icon(Icons.person),
|
|
enabled: isEditing,
|
|
),
|
|
),
|
|
const SizedBox(height: 16),
|
|
|
|
// Email
|
|
TextField(
|
|
controller: controller.emailController,
|
|
decoration: InputDecoration(
|
|
labelText: 'Email',
|
|
border: OutlineInputBorder(),
|
|
prefixIcon: Icon(Icons.email),
|
|
enabled: isEditing,
|
|
),
|
|
keyboardType: TextInputType.emailAddress,
|
|
),
|
|
const SizedBox(height: 16),
|
|
|
|
// Nomor Telepon
|
|
TextField(
|
|
controller: controller.phoneController,
|
|
decoration: InputDecoration(
|
|
labelText: 'Nomor Telepon',
|
|
border: OutlineInputBorder(),
|
|
prefixIcon: Icon(Icons.phone),
|
|
enabled: isEditing,
|
|
),
|
|
keyboardType: TextInputType.phone,
|
|
),
|
|
],
|
|
);
|
|
});
|
|
}
|
|
|
|
Widget _buildPasswordSection(BuildContext context) {
|
|
return Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
const Text(
|
|
'Keamanan',
|
|
style: TextStyle(
|
|
fontSize: 18,
|
|
fontWeight: FontWeight.bold,
|
|
),
|
|
),
|
|
const SizedBox(height: 16),
|
|
ElevatedButton.icon(
|
|
onPressed: () => _showChangePasswordDialog(context),
|
|
icon: const Icon(Icons.lock),
|
|
label: const Text('Ubah Password'),
|
|
style: ElevatedButton.styleFrom(
|
|
backgroundColor: AppTheme.primaryColor,
|
|
foregroundColor: Colors.white,
|
|
minimumSize: const Size(double.infinity, 50),
|
|
),
|
|
),
|
|
],
|
|
);
|
|
}
|
|
|
|
void _showChangePasswordDialog(BuildContext context) {
|
|
final currentPasswordController = TextEditingController();
|
|
final newPasswordController = TextEditingController();
|
|
final confirmPasswordController = TextEditingController();
|
|
|
|
Get.dialog(
|
|
AlertDialog(
|
|
title: const Text('Ubah Password'),
|
|
content: SingleChildScrollView(
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
TextField(
|
|
controller: currentPasswordController,
|
|
decoration: const InputDecoration(
|
|
labelText: 'Password Saat Ini',
|
|
border: OutlineInputBorder(),
|
|
),
|
|
obscureText: true,
|
|
),
|
|
const SizedBox(height: 16),
|
|
TextField(
|
|
controller: newPasswordController,
|
|
decoration: const InputDecoration(
|
|
labelText: 'Password Baru',
|
|
border: OutlineInputBorder(),
|
|
),
|
|
obscureText: true,
|
|
),
|
|
const SizedBox(height: 16),
|
|
TextField(
|
|
controller: confirmPasswordController,
|
|
decoration: const InputDecoration(
|
|
labelText: 'Konfirmasi Password Baru',
|
|
border: OutlineInputBorder(),
|
|
),
|
|
obscureText: true,
|
|
),
|
|
],
|
|
),
|
|
),
|
|
actions: [
|
|
TextButton(
|
|
onPressed: () => Get.back(),
|
|
child: const Text('Batal'),
|
|
),
|
|
ElevatedButton(
|
|
onPressed: () {
|
|
controller.changePassword(
|
|
currentPasswordController.text,
|
|
newPasswordController.text,
|
|
confirmPasswordController.text,
|
|
);
|
|
},
|
|
style: ElevatedButton.styleFrom(
|
|
backgroundColor: AppTheme.primaryColor,
|
|
),
|
|
child: const Text('Simpan'),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|