Compare commits

...

2 Commits

Author SHA1 Message Date
711e5f3f52 Merge pull request 'feat: page profile' (#21) from bayu/dev into dev
Reviewed-on: #21
2024-03-08 16:28:56 +07:00
a99365fb0a feat: page profile 2024-03-08 16:27:43 +07:00
10 changed files with 121 additions and 2 deletions

BIN
assets/icons/icon-card.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
assets/icons/icon-chat.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.0 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

View File

@ -64,6 +64,11 @@ class PathAssets {
static const String iconFund = 'assets/icons/icon-fund.png';
static const String iconHome = 'assets/icons/icon-home.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 =
'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 imgGrowing = 'assets/images/img-growing.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 imgLion = 'assets/images/img-lion.png';
static const String imgGuideBank = 'assets/images/img-guide-bank.png';
@ -108,6 +114,7 @@ class PathAssets {
'assets/images/img-expand-purchase.png';
static const String imgEmptyTransaction =
'assets/images/img-empty-transaction.png';
static const String bgProfile = 'assets/images/bg-profile.png';
static const Map<String, String> goalInvestIcon = {
'Education': iconToga,

View 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});
}

View File

@ -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/features/profile/model/list_menu_model.dart';
import 'package:flutter/material.dart';
class ProfileView extends StatelessWidget {
@ -7,8 +11,108 @@ class ProfileView extends StatelessWidget {
@override
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(
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),
],
),
),
),
],
),
);
}
}