109 lines
3.6 KiB
Dart
Raw Normal View History

2025-10-30 16:35:47 +07:00
import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../application/payment/payment_form/payment_form_bloc.dart';
import '../../../application/payment_method/payment_method_loader/payment_method_loader_bloc.dart';
import '../../../common/theme/theme.dart';
import '../../../domain/order/order.dart';
import '../../../injection.dart';
import '../../components/spaces/space.dart';
import '../../components/toast/flushbar.dart';
2025-10-30 17:08:11 +07:00
import '../../router/app_router.gr.dart';
2025-10-30 16:35:47 +07:00
import 'widgets/payment_left_panel.dart';
import 'widgets/payment_right_panel.dart';
@RoutePage()
class PaymentPage extends StatelessWidget implements AutoRouteWrapper {
final Order order;
const PaymentPage({super.key, required this.order});
@override
Widget build(BuildContext context) {
return BlocListener<PaymentFormBloc, PaymentFormState>(
listenWhen: (p, c) => p.failureOrPayment != c.failureOrPayment,
listener: (context, state) {
state.failureOrPayment.fold(
() {},
(either) => either.fold(
(f) => AppFlushbar.showOrderFailureToast(context, f),
2025-10-30 17:08:11 +07:00
(data) {
if (context.mounted) {
context.router.replace(PaymentSuccessRoute(orderId: order.id));
}
},
2025-10-30 16:35:47 +07:00
),
);
},
child: Scaffold(
backgroundColor: AppColor.background,
appBar: AppBar(
backgroundColor: AppColor.white,
elevation: 0,
title: const Text(
'Pembayaran',
style: TextStyle(color: AppColor.primary),
),
leading: IconButton(
onPressed: () => context.router.maybePop(),
icon: Icon(Icons.arrow_back, color: AppColor.primary),
),
),
body: LayoutBuilder(
builder: (context, constraints) {
final isWide = constraints.maxWidth > 800;
return BlocBuilder<PaymentFormBloc, PaymentFormState>(
builder: (context, state) {
return Padding(
padding: const EdgeInsets.all(16),
child: isWide
? Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Expanded(
flex: 3,
child: PaymentLeftPanel(state: state),
),
const SizedBox(width: 24),
Expanded(
flex: 2,
child: PaymentRightPanel(state: state),
),
],
)
: SingleChildScrollView(
child: Column(
children: [
PaymentLeftPanel(state: state),
const SpaceHeight(24),
PaymentRightPanel(state: state),
],
),
),
);
},
);
},
),
),
);
}
@override
Widget wrappedRoute(BuildContext context) => MultiBlocProvider(
providers: [
BlocProvider(
create: (context) =>
getIt<PaymentFormBloc>()..add(PaymentFormEvent.setOrder(order)),
),
BlocProvider(
create: (context) =>
getIt<PaymentMethodLoaderBloc>()
..add(PaymentMethodLoaderEvent.fetched(isRefresh: true)),
),
],
child: this,
);
}