Compare commits
2 Commits
41f0bb7a68
...
711e5f3f52
Author | SHA1 | Date | |
---|---|---|---|
711e5f3f52 | |||
a99365fb0a |
BIN
assets/icons/icon-card.png
Normal file
After Width: | Height: | Size: 2.3 KiB |
BIN
assets/icons/icon-chat.png
Normal file
After Width: | Height: | Size: 3.0 KiB |
BIN
assets/icons/icon-logout.png
Normal file
After Width: | Height: | Size: 2.7 KiB |
BIN
assets/icons/icon-profile.png
Normal file
After Width: | Height: | Size: 3.1 KiB |
BIN
assets/icons/icon-setting.png
Normal file
After Width: | Height: | Size: 3.4 KiB |
BIN
assets/images/bg-profile.png
Normal file
After Width: | Height: | Size: 4.0 MiB |
BIN
assets/images/img-cat-outlined.png
Normal file
After Width: | Height: | Size: 14 KiB |
|
@ -64,6 +64,11 @@ class PathAssets {
|
||||||
static const String iconFund = 'assets/icons/icon-fund.png';
|
static const String iconFund = 'assets/icons/icon-fund.png';
|
||||||
static const String iconHome = 'assets/icons/icon-home.png';
|
static const String iconHome = 'assets/icons/icon-home.png';
|
||||||
static const String iconShop = 'assets/icons/icon-shop.png';
|
static const String iconShop = 'assets/icons/icon-shop.png';
|
||||||
|
static const String iconCard = 'assets/icons/icon-card.png';
|
||||||
|
static const String iconChat = 'assets/icons/icon-chat.png';
|
||||||
|
static const String iconLogout = 'assets/icons/icon-logout.png';
|
||||||
|
static const String iconProfile = 'assets/icons/icon-profile.png';
|
||||||
|
static const String iconSetting = 'assets/icons/icon-setting.png';
|
||||||
static const String iconGadgetOutline =
|
static const String iconGadgetOutline =
|
||||||
'assets/icons/icon-gadget-outline.png';
|
'assets/icons/icon-gadget-outline.png';
|
||||||
|
|
||||||
|
@ -94,6 +99,7 @@ class PathAssets {
|
||||||
static const String imgMoneyIncome = 'assets/images/img-money-income.png';
|
static const String imgMoneyIncome = 'assets/images/img-money-income.png';
|
||||||
static const String imgGrowing = 'assets/images/img-growing.png';
|
static const String imgGrowing = 'assets/images/img-growing.png';
|
||||||
static const String imgCat = 'assets/images/img-cat.png';
|
static const String imgCat = 'assets/images/img-cat.png';
|
||||||
|
static const String imgCatOutlined = 'assets/images/img-cat-outlined.png';
|
||||||
static const String imgDeer = 'assets/images/img-deer.png';
|
static const String imgDeer = 'assets/images/img-deer.png';
|
||||||
static const String imgLion = 'assets/images/img-lion.png';
|
static const String imgLion = 'assets/images/img-lion.png';
|
||||||
static const String imgGuideBank = 'assets/images/img-guide-bank.png';
|
static const String imgGuideBank = 'assets/images/img-guide-bank.png';
|
||||||
|
@ -108,6 +114,7 @@ class PathAssets {
|
||||||
'assets/images/img-expand-purchase.png';
|
'assets/images/img-expand-purchase.png';
|
||||||
static const String imgEmptyTransaction =
|
static const String imgEmptyTransaction =
|
||||||
'assets/images/img-empty-transaction.png';
|
'assets/images/img-empty-transaction.png';
|
||||||
|
static const String bgProfile = 'assets/images/bg-profile.png';
|
||||||
|
|
||||||
static const Map<String, String> goalInvestIcon = {
|
static const Map<String, String> goalInvestIcon = {
|
||||||
'Education': iconToga,
|
'Education': iconToga,
|
||||||
|
|
8
lib/features/profile/model/list_menu_model.dart
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class ListMenuModel {
|
||||||
|
final String title, pathAsset;
|
||||||
|
final Widget page;
|
||||||
|
ListMenuModel(
|
||||||
|
{required this.title, required this.pathAsset, required this.page});
|
||||||
|
}
|
|
@ -1,5 +1,9 @@
|
||||||
import 'package:cims_apps/application/component/custom_app_bar/custom_app_bar.dart';
|
import 'package:cims_apps/application/assets/path_assets.dart';
|
||||||
|
import 'package:cims_apps/application/component/image/image_view.dart';
|
||||||
|
import 'package:cims_apps/application/theme/color_palette.dart';
|
||||||
|
import 'package:cims_apps/core/route/route.dart';
|
||||||
import 'package:cims_apps/core/utils/size_config.dart';
|
import 'package:cims_apps/core/utils/size_config.dart';
|
||||||
|
import 'package:cims_apps/features/profile/model/list_menu_model.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
class ProfileView extends StatelessWidget {
|
class ProfileView extends StatelessWidget {
|
||||||
|
@ -7,8 +11,108 @@ class ProfileView extends StatelessWidget {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
List<ListMenuModel> listMenuGeneral = [
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'Personal Data',
|
||||||
|
pathAsset: PathAssets.iconProfile,
|
||||||
|
page: Container()),
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'Change Password',
|
||||||
|
pathAsset: PathAssets.iconLock,
|
||||||
|
page: Container()),
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'Add Card', pathAsset: PathAssets.iconCard, page: Container()),
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'Settings',
|
||||||
|
pathAsset: PathAssets.iconSetting,
|
||||||
|
page: Container()),
|
||||||
|
];
|
||||||
|
|
||||||
|
List<ListMenuModel> listMenuPreferences = [
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'FAQs', pathAsset: PathAssets.iconChat, page: Container()),
|
||||||
|
ListMenuModel(
|
||||||
|
title: 'Log Out',
|
||||||
|
pathAsset: PathAssets.iconLogout,
|
||||||
|
page: Container()),
|
||||||
|
];
|
||||||
|
TextStyle textStyle = const TextStyle(
|
||||||
|
fontSize: 20,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
color: Colors.white,
|
||||||
|
);
|
||||||
|
|
||||||
|
Widget cardContent(
|
||||||
|
{required String title, required List<ListMenuModel> listMenu}) {
|
||||||
|
return Container(
|
||||||
|
width: SizeConfig.width,
|
||||||
|
padding: const EdgeInsets.all(16.0),
|
||||||
|
decoration: const BoxDecoration(
|
||||||
|
color: Colors.white,
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(12))),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Text(title),
|
||||||
|
...listMenu.map((e) {
|
||||||
|
return Padding(
|
||||||
|
padding: const EdgeInsets.only(top: 8.0),
|
||||||
|
child: ListTile(
|
||||||
|
title: Text(e.title),
|
||||||
|
contentPadding: EdgeInsets.zero,
|
||||||
|
leading: ImageView(
|
||||||
|
image: e.pathAsset, width: SizeConfig.width * .08),
|
||||||
|
trailing: const Icon(Icons.arrow_forward_ios,
|
||||||
|
color: ColorPalette.slate400),
|
||||||
|
onTap: () => routePush(context, page: e.page),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
appBar: CustomAppBar(height: SizeConfig.height * .08, title: 'Profile'),
|
appBar: null,
|
||||||
|
body: Stack(
|
||||||
|
children: [
|
||||||
|
ImageView(image: PathAssets.bgProfile, width: SizeConfig.width),
|
||||||
|
Container(
|
||||||
|
width: SizeConfig.width,
|
||||||
|
padding: const EdgeInsets.only(top: 40.0, left: 16.0, right: 16.0),
|
||||||
|
child: SingleChildScrollView(
|
||||||
|
padding: const EdgeInsets.only(bottom: 60.0),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Text('Profile', style: textStyle),
|
||||||
|
Padding(
|
||||||
|
padding: const EdgeInsets.only(top: 40.0, bottom: 8.0),
|
||||||
|
child: ImageView(
|
||||||
|
image: PathAssets.imgCatOutlined,
|
||||||
|
width: SizeConfig.width * .28,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Text('Muhamad Rosyidin',
|
||||||
|
style: textStyle.copyWith(fontSize: 24)),
|
||||||
|
Text('Investor Conservative',
|
||||||
|
style: textStyle.copyWith(
|
||||||
|
fontSize: 16,
|
||||||
|
fontWeight: FontWeight.normal,
|
||||||
|
color: ColorPalette.green400,
|
||||||
|
)),
|
||||||
|
SizedBox(height: SizeConfig.height * .02),
|
||||||
|
cardContent(title: 'General', listMenu: listMenuGeneral),
|
||||||
|
SizedBox(height: SizeConfig.height * .03),
|
||||||
|
cardContent(
|
||||||
|
title: 'Preference', listMenu: listMenuPreferences),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|