Compare commits

..

No commits in common. "af182b6f5acf8dc5b4fbd908d03a3999ebfa7a11" and "93560b85cb41723da3d961def8f63ddebe1f642a" have entirely different histories.

13 changed files with 161 additions and 427 deletions

View File

@ -39,28 +39,12 @@ class PrintStruckBloc extends Bloc<PrintStruckEvent, PrintStruckState> {
), ),
); );
}, },
cashier: (e) async { saveOrder: (e) async {
Either<PrinterFailure, Unit> failureOrSuccess; Either<PrinterFailure, Unit> failureOrSuccess;
emit(state.copyWith(isPrinting: true, failureOrPrintStruck: none())); emit(state.copyWith(isPrinting: true, failureOrPrintStruck: none()));
failureOrSuccess = await _printerRepository.printStruckCashier( failureOrSuccess = await _printerRepository.printStruckSaveOrder(
order: e.order,
);
emit(
state.copyWith(
isPrinting: false,
failureOrPrintStruck: optionOf(failureOrSuccess),
),
);
},
payment: (e) async {
Either<PrinterFailure, Unit> failureOrSuccess;
emit(state.copyWith(isPrinting: true, failureOrPrintStruck: none()));
failureOrSuccess = await _printerRepository.printStruckPayment(
order: e.order, order: e.order,
); );

View File

@ -21,39 +21,33 @@ mixin _$PrintStruckEvent {
@optionalTypeArgs @optionalTypeArgs
TResult when<TResult extends Object?>({ TResult when<TResult extends Object?>({
required TResult Function(Order order) order, required TResult Function(Order order) order,
required TResult Function(Order order) cashier, required TResult Function(Order order) saveOrder,
required TResult Function(Order order) payment,
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@optionalTypeArgs @optionalTypeArgs
TResult? whenOrNull<TResult extends Object?>({ TResult? whenOrNull<TResult extends Object?>({
TResult? Function(Order order)? order, TResult? Function(Order order)? order,
TResult? Function(Order order)? cashier, TResult? Function(Order order)? saveOrder,
TResult? Function(Order order)? payment,
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@optionalTypeArgs @optionalTypeArgs
TResult maybeWhen<TResult extends Object?>({ TResult maybeWhen<TResult extends Object?>({
TResult Function(Order order)? order, TResult Function(Order order)? order,
TResult Function(Order order)? cashier, TResult Function(Order order)? saveOrder,
TResult Function(Order order)? payment,
required TResult orElse(), required TResult orElse(),
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@optionalTypeArgs @optionalTypeArgs
TResult map<TResult extends Object?>({ TResult map<TResult extends Object?>({
required TResult Function(_Order value) order, required TResult Function(_Order value) order,
required TResult Function(_Cashier value) cashier, required TResult Function(_SaveOrder value) saveOrder,
required TResult Function(_Payment value) payment,
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@optionalTypeArgs @optionalTypeArgs
TResult? mapOrNull<TResult extends Object?>({ TResult? mapOrNull<TResult extends Object?>({
TResult? Function(_Order value)? order, TResult? Function(_Order value)? order,
TResult? Function(_Cashier value)? cashier, TResult? Function(_SaveOrder value)? saveOrder,
TResult? Function(_Payment value)? payment,
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@optionalTypeArgs @optionalTypeArgs
TResult maybeMap<TResult extends Object?>({ TResult maybeMap<TResult extends Object?>({
TResult Function(_Order value)? order, TResult Function(_Order value)? order,
TResult Function(_Cashier value)? cashier, TResult Function(_SaveOrder value)? saveOrder,
TResult Function(_Payment value)? payment,
required TResult orElse(), required TResult orElse(),
}) => throw _privateConstructorUsedError; }) => throw _privateConstructorUsedError;
@ -189,8 +183,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult when<TResult extends Object?>({ TResult when<TResult extends Object?>({
required TResult Function(Order order) order, required TResult Function(Order order) order,
required TResult Function(Order order) cashier, required TResult Function(Order order) saveOrder,
required TResult Function(Order order) payment,
}) { }) {
return order(this.order); return order(this.order);
} }
@ -199,8 +192,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult? whenOrNull<TResult extends Object?>({ TResult? whenOrNull<TResult extends Object?>({
TResult? Function(Order order)? order, TResult? Function(Order order)? order,
TResult? Function(Order order)? cashier, TResult? Function(Order order)? saveOrder,
TResult? Function(Order order)? payment,
}) { }) {
return order?.call(this.order); return order?.call(this.order);
} }
@ -209,8 +201,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult maybeWhen<TResult extends Object?>({ TResult maybeWhen<TResult extends Object?>({
TResult Function(Order order)? order, TResult Function(Order order)? order,
TResult Function(Order order)? cashier, TResult Function(Order order)? saveOrder,
TResult Function(Order order)? payment,
required TResult orElse(), required TResult orElse(),
}) { }) {
if (order != null) { if (order != null) {
@ -223,8 +214,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult map<TResult extends Object?>({ TResult map<TResult extends Object?>({
required TResult Function(_Order value) order, required TResult Function(_Order value) order,
required TResult Function(_Cashier value) cashier, required TResult Function(_SaveOrder value) saveOrder,
required TResult Function(_Payment value) payment,
}) { }) {
return order(this); return order(this);
} }
@ -233,8 +223,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult? mapOrNull<TResult extends Object?>({ TResult? mapOrNull<TResult extends Object?>({
TResult? Function(_Order value)? order, TResult? Function(_Order value)? order,
TResult? Function(_Cashier value)? cashier, TResult? Function(_SaveOrder value)? saveOrder,
TResult? Function(_Payment value)? payment,
}) { }) {
return order?.call(this); return order?.call(this);
} }
@ -243,8 +232,7 @@ class _$OrderImpl implements _Order {
@optionalTypeArgs @optionalTypeArgs
TResult maybeMap<TResult extends Object?>({ TResult maybeMap<TResult extends Object?>({
TResult Function(_Order value)? order, TResult Function(_Order value)? order,
TResult Function(_Cashier value)? cashier, TResult Function(_SaveOrder value)? saveOrder,
TResult Function(_Payment value)? payment,
required TResult orElse(), required TResult orElse(),
}) { }) {
if (order != null) { if (order != null) {
@ -269,12 +257,12 @@ abstract class _Order implements PrintStruckEvent {
} }
/// @nodoc /// @nodoc
abstract class _$$CashierImplCopyWith<$Res> abstract class _$$SaveOrderImplCopyWith<$Res>
implements $PrintStruckEventCopyWith<$Res> { implements $PrintStruckEventCopyWith<$Res> {
factory _$$CashierImplCopyWith( factory _$$SaveOrderImplCopyWith(
_$CashierImpl value, _$SaveOrderImpl value,
$Res Function(_$CashierImpl) then, $Res Function(_$SaveOrderImpl) then,
) = __$$CashierImplCopyWithImpl<$Res>; ) = __$$SaveOrderImplCopyWithImpl<$Res>;
@override @override
@useResult @useResult
$Res call({Order order}); $Res call({Order order});
@ -284,12 +272,12 @@ abstract class _$$CashierImplCopyWith<$Res>
} }
/// @nodoc /// @nodoc
class __$$CashierImplCopyWithImpl<$Res> class __$$SaveOrderImplCopyWithImpl<$Res>
extends _$PrintStruckEventCopyWithImpl<$Res, _$CashierImpl> extends _$PrintStruckEventCopyWithImpl<$Res, _$SaveOrderImpl>
implements _$$CashierImplCopyWith<$Res> { implements _$$SaveOrderImplCopyWith<$Res> {
__$$CashierImplCopyWithImpl( __$$SaveOrderImplCopyWithImpl(
_$CashierImpl _value, _$SaveOrderImpl _value,
$Res Function(_$CashierImpl) _then, $Res Function(_$SaveOrderImpl) _then,
) : super(_value, _then); ) : super(_value, _then);
/// Create a copy of PrintStruckEvent /// Create a copy of PrintStruckEvent
@ -298,7 +286,7 @@ class __$$CashierImplCopyWithImpl<$Res>
@override @override
$Res call({Object? order = null}) { $Res call({Object? order = null}) {
return _then( return _then(
_$CashierImpl( _$SaveOrderImpl(
null == order null == order
? _value.order ? _value.order
: order // ignore: cast_nullable_to_non_nullable : order // ignore: cast_nullable_to_non_nullable
@ -310,22 +298,22 @@ class __$$CashierImplCopyWithImpl<$Res>
/// @nodoc /// @nodoc
class _$CashierImpl implements _Cashier { class _$SaveOrderImpl implements _SaveOrder {
const _$CashierImpl(this.order); const _$SaveOrderImpl(this.order);
@override @override
final Order order; final Order order;
@override @override
String toString() { String toString() {
return 'PrintStruckEvent.cashier(order: $order)'; return 'PrintStruckEvent.saveOrder(order: $order)';
} }
@override @override
bool operator ==(Object other) { bool operator ==(Object other) {
return identical(this, other) || return identical(this, other) ||
(other.runtimeType == runtimeType && (other.runtimeType == runtimeType &&
other is _$CashierImpl && other is _$SaveOrderImpl &&
(identical(other.order, order) || other.order == order)); (identical(other.order, order) || other.order == order));
} }
@ -337,39 +325,36 @@ class _$CashierImpl implements _Cashier {
@JsonKey(includeFromJson: false, includeToJson: false) @JsonKey(includeFromJson: false, includeToJson: false)
@override @override
@pragma('vm:prefer-inline') @pragma('vm:prefer-inline')
_$$CashierImplCopyWith<_$CashierImpl> get copyWith => _$$SaveOrderImplCopyWith<_$SaveOrderImpl> get copyWith =>
__$$CashierImplCopyWithImpl<_$CashierImpl>(this, _$identity); __$$SaveOrderImplCopyWithImpl<_$SaveOrderImpl>(this, _$identity);
@override @override
@optionalTypeArgs @optionalTypeArgs
TResult when<TResult extends Object?>({ TResult when<TResult extends Object?>({
required TResult Function(Order order) order, required TResult Function(Order order) order,
required TResult Function(Order order) cashier, required TResult Function(Order order) saveOrder,
required TResult Function(Order order) payment,
}) { }) {
return cashier(this.order); return saveOrder(this.order);
} }
@override @override
@optionalTypeArgs @optionalTypeArgs
TResult? whenOrNull<TResult extends Object?>({ TResult? whenOrNull<TResult extends Object?>({
TResult? Function(Order order)? order, TResult? Function(Order order)? order,
TResult? Function(Order order)? cashier, TResult? Function(Order order)? saveOrder,
TResult? Function(Order order)? payment,
}) { }) {
return cashier?.call(this.order); return saveOrder?.call(this.order);
} }
@override @override
@optionalTypeArgs @optionalTypeArgs
TResult maybeWhen<TResult extends Object?>({ TResult maybeWhen<TResult extends Object?>({
TResult Function(Order order)? order, TResult Function(Order order)? order,
TResult Function(Order order)? cashier, TResult Function(Order order)? saveOrder,
TResult Function(Order order)? payment,
required TResult orElse(), required TResult orElse(),
}) { }) {
if (cashier != null) { if (saveOrder != null) {
return cashier(this.order); return saveOrder(this.order);
} }
return orElse(); return orElse();
} }
@ -378,39 +363,36 @@ class _$CashierImpl implements _Cashier {
@optionalTypeArgs @optionalTypeArgs
TResult map<TResult extends Object?>({ TResult map<TResult extends Object?>({
required TResult Function(_Order value) order, required TResult Function(_Order value) order,
required TResult Function(_Cashier value) cashier, required TResult Function(_SaveOrder value) saveOrder,
required TResult Function(_Payment value) payment,
}) { }) {
return cashier(this); return saveOrder(this);
} }
@override @override
@optionalTypeArgs @optionalTypeArgs
TResult? mapOrNull<TResult extends Object?>({ TResult? mapOrNull<TResult extends Object?>({
TResult? Function(_Order value)? order, TResult? Function(_Order value)? order,
TResult? Function(_Cashier value)? cashier, TResult? Function(_SaveOrder value)? saveOrder,
TResult? Function(_Payment value)? payment,
}) { }) {
return cashier?.call(this); return saveOrder?.call(this);
} }
@override @override
@optionalTypeArgs @optionalTypeArgs
TResult maybeMap<TResult extends Object?>({ TResult maybeMap<TResult extends Object?>({
TResult Function(_Order value)? order, TResult Function(_Order value)? order,
TResult Function(_Cashier value)? cashier, TResult Function(_SaveOrder value)? saveOrder,
TResult Function(_Payment value)? payment,
required TResult orElse(), required TResult orElse(),
}) { }) {
if (cashier != null) { if (saveOrder != null) {
return cashier(this); return saveOrder(this);
} }
return orElse(); return orElse();
} }
} }
abstract class _Cashier implements PrintStruckEvent { abstract class _SaveOrder implements PrintStruckEvent {
const factory _Cashier(final Order order) = _$CashierImpl; const factory _SaveOrder(final Order order) = _$SaveOrderImpl;
@override @override
Order get order; Order get order;
@ -419,162 +401,7 @@ abstract class _Cashier implements PrintStruckEvent {
/// with the given fields replaced by the non-null parameter values. /// with the given fields replaced by the non-null parameter values.
@override @override
@JsonKey(includeFromJson: false, includeToJson: false) @JsonKey(includeFromJson: false, includeToJson: false)
_$$CashierImplCopyWith<_$CashierImpl> get copyWith => _$$SaveOrderImplCopyWith<_$SaveOrderImpl> get copyWith =>
throw _privateConstructorUsedError;
}
/// @nodoc
abstract class _$$PaymentImplCopyWith<$Res>
implements $PrintStruckEventCopyWith<$Res> {
factory _$$PaymentImplCopyWith(
_$PaymentImpl value,
$Res Function(_$PaymentImpl) then,
) = __$$PaymentImplCopyWithImpl<$Res>;
@override
@useResult
$Res call({Order order});
@override
$OrderCopyWith<$Res> get order;
}
/// @nodoc
class __$$PaymentImplCopyWithImpl<$Res>
extends _$PrintStruckEventCopyWithImpl<$Res, _$PaymentImpl>
implements _$$PaymentImplCopyWith<$Res> {
__$$PaymentImplCopyWithImpl(
_$PaymentImpl _value,
$Res Function(_$PaymentImpl) _then,
) : super(_value, _then);
/// Create a copy of PrintStruckEvent
/// with the given fields replaced by the non-null parameter values.
@pragma('vm:prefer-inline')
@override
$Res call({Object? order = null}) {
return _then(
_$PaymentImpl(
null == order
? _value.order
: order // ignore: cast_nullable_to_non_nullable
as Order,
),
);
}
}
/// @nodoc
class _$PaymentImpl implements _Payment {
const _$PaymentImpl(this.order);
@override
final Order order;
@override
String toString() {
return 'PrintStruckEvent.payment(order: $order)';
}
@override
bool operator ==(Object other) {
return identical(this, other) ||
(other.runtimeType == runtimeType &&
other is _$PaymentImpl &&
(identical(other.order, order) || other.order == order));
}
@override
int get hashCode => Object.hash(runtimeType, order);
/// Create a copy of PrintStruckEvent
/// with the given fields replaced by the non-null parameter values.
@JsonKey(includeFromJson: false, includeToJson: false)
@override
@pragma('vm:prefer-inline')
_$$PaymentImplCopyWith<_$PaymentImpl> get copyWith =>
__$$PaymentImplCopyWithImpl<_$PaymentImpl>(this, _$identity);
@override
@optionalTypeArgs
TResult when<TResult extends Object?>({
required TResult Function(Order order) order,
required TResult Function(Order order) cashier,
required TResult Function(Order order) payment,
}) {
return payment(this.order);
}
@override
@optionalTypeArgs
TResult? whenOrNull<TResult extends Object?>({
TResult? Function(Order order)? order,
TResult? Function(Order order)? cashier,
TResult? Function(Order order)? payment,
}) {
return payment?.call(this.order);
}
@override
@optionalTypeArgs
TResult maybeWhen<TResult extends Object?>({
TResult Function(Order order)? order,
TResult Function(Order order)? cashier,
TResult Function(Order order)? payment,
required TResult orElse(),
}) {
if (payment != null) {
return payment(this.order);
}
return orElse();
}
@override
@optionalTypeArgs
TResult map<TResult extends Object?>({
required TResult Function(_Order value) order,
required TResult Function(_Cashier value) cashier,
required TResult Function(_Payment value) payment,
}) {
return payment(this);
}
@override
@optionalTypeArgs
TResult? mapOrNull<TResult extends Object?>({
TResult? Function(_Order value)? order,
TResult? Function(_Cashier value)? cashier,
TResult? Function(_Payment value)? payment,
}) {
return payment?.call(this);
}
@override
@optionalTypeArgs
TResult maybeMap<TResult extends Object?>({
TResult Function(_Order value)? order,
TResult Function(_Cashier value)? cashier,
TResult Function(_Payment value)? payment,
required TResult orElse(),
}) {
if (payment != null) {
return payment(this);
}
return orElse();
}
}
abstract class _Payment implements PrintStruckEvent {
const factory _Payment(final Order order) = _$PaymentImpl;
@override
Order get order;
/// Create a copy of PrintStruckEvent
/// with the given fields replaced by the non-null parameter values.
@override
@JsonKey(includeFromJson: false, includeToJson: false)
_$$PaymentImplCopyWith<_$PaymentImpl> get copyWith =>
throw _privateConstructorUsedError; throw _privateConstructorUsedError;
} }

View File

@ -3,6 +3,5 @@ part of 'print_struck_bloc.dart';
@freezed @freezed
class PrintStruckEvent with _$PrintStruckEvent { class PrintStruckEvent with _$PrintStruckEvent {
const factory PrintStruckEvent.order(Order order) = _Order; const factory PrintStruckEvent.order(Order order) = _Order;
const factory PrintStruckEvent.cashier(Order order) = _Cashier; const factory PrintStruckEvent.saveOrder(Order order) = _SaveOrder;
const factory PrintStruckEvent.payment(Order order) = _Payment;
} }

View File

@ -161,17 +161,6 @@ class Order with _$Order {
paymentCount: 1, paymentCount: 1,
splitType: 'Single', splitType: 'Single',
); );
// For Add Item Order
factory Order.fromLastOrder(Order order, List<ProductQuantity> products) =>
order.copyWith(
orderItems: products
.map((e) => OrderItem.fromProductQuantity(e))
.toList(),
totalAmount: products
.map((e) => e.product.price.toInt() * e.quantity)
.reduce((value, element) => value + element),
);
} }
@freezed @freezed
@ -213,25 +202,4 @@ class OrderItem with _$OrderItem {
printerType: '', printerType: '',
paidQuantity: 0, paidQuantity: 0,
); );
factory OrderItem.fromProductQuantity(ProductQuantity productQuantity) =>
OrderItem(
id: '',
orderId: '',
productId: productQuantity.product.id,
productName: productQuantity.product.name,
productVariantId: productQuantity.variant?.id ?? '',
productVariantName: productQuantity.variant?.name ?? '',
quantity: productQuantity.quantity,
unitPrice: productQuantity.product.price.toInt(),
totalPrice: (productQuantity.product.price * productQuantity.quantity)
.toInt(),
modifiers: [],
notes: productQuantity.notes,
status: 'pending',
createdAt: DateTime.now(),
updatedAt: DateTime.now(),
printerType: productQuantity.product.printerType,
paidQuantity: 0,
);
} }

View File

@ -3,7 +3,6 @@ import 'package:freezed_annotation/freezed_annotation.dart';
import '../../common/api/api_failure.dart'; import '../../common/api/api_failure.dart';
import '../../common/types/split_type.dart'; import '../../common/types/split_type.dart';
import '../product/product.dart';
part 'order.freezed.dart'; part 'order.freezed.dart';

View File

@ -19,10 +19,4 @@ abstract class IPrinterRepository {
Future<Either<PrinterFailure, Unit>> printStruckSaveOrder({ Future<Either<PrinterFailure, Unit>> printStruckSaveOrder({
required Order order, required Order order,
}); });
Future<Either<PrinterFailure, Unit>> printStruckCashier({
required Order order,
});
Future<Either<PrinterFailure, Unit>> printStruckPayment({
required Order order,
});
} }

View File

@ -480,24 +480,6 @@ class PrinterRepository implements IPrinterRepository {
} }
} }
@override
Future<Either<PrinterFailure, Unit>> printStruckCashier({
required Order order,
}) async {
final outlet = await _outletLocalDatasource.currentOutlet();
final user = await _authLocalDataProvider.currentUser();
return _printCashier(order: order, outlet: outlet, cashieName: user.name);
}
@override
Future<Either<PrinterFailure, Unit>> printStruckPayment({
required Order order,
}) async {
final outlet = await _outletLocalDatasource.currentOutlet();
final user = await _authLocalDataProvider.currentUser();
return _printReceipt(order: order, outlet: outlet, cashieName: user.name);
}
Future<Either<PrinterFailure, Unit>> _printReceipt({ Future<Either<PrinterFailure, Unit>> _printReceipt({
required Order order, required Order order,
required Outlet outlet, required Outlet outlet,

View File

@ -4,10 +4,8 @@ import 'package:flutter/widgets.dart';
import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../application/order/order_loader/order_loader_bloc.dart'; import '../../../application/order/order_loader/order_loader_bloc.dart';
import '../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../common/theme/theme.dart'; import '../../../common/theme/theme.dart';
import '../../../injection.dart'; import '../../../injection.dart';
import '../../components/toast/flushbar.dart';
import 'widgets/order_left_panel.dart'; import 'widgets/order_left_panel.dart';
import 'widgets/order_right_panel.dart'; import 'widgets/order_right_panel.dart';
@ -38,20 +36,6 @@ class OrderPage extends StatelessWidget implements AutoRouteWrapper {
); );
}, },
), ),
BlocListener<PrintStruckBloc, PrintStruckState>(
listenWhen: (previous, current) =>
previous.failureOrPrintStruck != current.failureOrPrintStruck,
listener: (context, state) {
state.failureOrPrintStruck.fold(() {}, (either) {
either.fold(
(f) => AppFlushbar.showPrinterFailureToast(context, f),
(success) {
AppFlushbar.showSuccess(context, "Struck berhasil dicetak");
},
);
});
},
),
], ],
child: SafeArea( child: SafeArea(
child: Scaffold( child: Scaffold(

View File

@ -3,10 +3,8 @@ import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../../application/checkout/checkout_form/checkout_form_bloc.dart'; import '../../../../../application/checkout/checkout_form/checkout_form_bloc.dart';
import '../../../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../../../common/theme/theme.dart'; import '../../../../../common/theme/theme.dart';
import '../../../../components/spaces/space.dart'; import '../../../../components/spaces/space.dart';
import '../../../../components/toast/flushbar.dart';
import 'widgets/success_add_item_order_left_panel.dart'; import 'widgets/success_add_item_order_left_panel.dart';
import 'widgets/success_add_item_order_right_panel.dart'; import 'widgets/success_add_item_order_right_panel.dart';
@ -16,46 +14,32 @@ class SuccessAddItemOrderPage extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return BlocListener<PrintStruckBloc, PrintStruckState>( return Scaffold(
listenWhen: (p, c) => p.failureOrPrintStruck != c.failureOrPrintStruck, backgroundColor: AppColor.background,
listener: (context, state) { body: SafeArea(
state.failureOrPrintStruck.fold( child: BlocBuilder<CheckoutFormBloc, CheckoutFormState>(
() {}, builder: (context, checkoutState) {
(either) => either.fold( return Padding(
(f) => AppFlushbar.showPrinterFailureToast(context, f), padding: const EdgeInsets.all(24.0),
(success) { child: Row(
AppFlushbar.showSuccess(context, "Struck berhasil dicetak"); children: [
}, Expanded(
), flex: 35,
); child: SuccessAddItemOrderLeftPanel(
}, checkoutState: checkoutState,
child: Scaffold(
backgroundColor: AppColor.background,
body: SafeArea(
child: BlocBuilder<CheckoutFormBloc, CheckoutFormState>(
builder: (context, checkoutState) {
return Padding(
padding: const EdgeInsets.all(24.0),
child: Row(
children: [
Expanded(
flex: 35,
child: SuccessAddItemOrderLeftPanel(
checkoutState: checkoutState,
),
), ),
SpaceWidth(16), ),
Expanded( SpaceWidth(16),
flex: 65, Expanded(
child: SuccessAddItemOrderRightPanel( flex: 65,
checkoutState: checkoutState, child: SuccessAddItemOrderRightPanel(
), checkoutState: checkoutState,
), ),
], ),
), ],
); ),
}, );
), },
), ),
), ),
); );

View File

@ -3,10 +3,8 @@ import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../../../application/checkout/checkout_form/checkout_form_bloc.dart'; import '../../../../../../application/checkout/checkout_form/checkout_form_bloc.dart';
import '../../../../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../../../../common/extension/extension.dart'; import '../../../../../../common/extension/extension.dart';
import '../../../../../../common/theme/theme.dart'; import '../../../../../../common/theme/theme.dart';
import '../../../../../../domain/order/order.dart';
import '../../../../../components/button/button.dart'; import '../../../../../components/button/button.dart';
import '../../../../../components/spaces/space.dart'; import '../../../../../components/spaces/space.dart';
import '../../../../../router/app_router.gr.dart'; import '../../../../../router/app_router.gr.dart';
@ -188,14 +186,22 @@ class SuccessAddItemOrderLeftPanel extends StatelessWidget {
Expanded( Expanded(
child: AppElevatedButton.filled( child: AppElevatedButton.filled(
onPressed: () { onPressed: () {
context.read<PrintStruckBloc>().add( // onPrintRecipt(
PrintStruckEvent.order( // context,
Order.fromLastOrder( // order: widget.order,
checkoutState.orderAdded!, // paymentMethod: widget.paymentMethod,
checkoutState.items, // nominalBayar: widget.paymentMethod == "Cash"
), // ? widget.nominalBayar
), // : widget.order.totalAmount ?? 0,
); // kembalian: widget.nominalBayar -
// (widget.order.totalAmount ?? 0),
// productQuantity: widget.productQuantity,
// );
// onPrint(
// context,
// productQuantity: widget.productQuantity,
// order: widget.order,
// );
}, },
label: 'Cetak Struk', label: 'Cetak Struk',
icon: Icon(Icons.print_rounded, color: AppColor.white), icon: Icon(Icons.print_rounded, color: AppColor.white),

View File

@ -1,9 +1,7 @@
import 'package:auto_route/auto_route.dart'; import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../application/order/order_loader/order_loader_bloc.dart'; import '../../../../application/order/order_loader/order_loader_bloc.dart';
import '../../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../../common/theme/theme.dart'; import '../../../../common/theme/theme.dart';
import '../../../components/button/button.dart'; import '../../../components/button/button.dart';
import '../../../components/spaces/space.dart'; import '../../../components/spaces/space.dart';
@ -61,13 +59,26 @@ class OrderRightPanel extends StatelessWidget {
AppElevatedButton.outlined( AppElevatedButton.outlined(
onPressed: () { onPressed: () {
if (state.selectedOrder?.status == 'completed') { if (state.selectedOrder?.status == 'completed') {
context.read<PrintStruckBloc>().add( // onPrintRecipt(
PrintStruckEvent.payment(state.selectedOrder!), // context,
); // order: orderDetail!,
// paymentMethod:
// orderDetail!.payments
// ?.map((p) => p.paymentMethodName)
// .join(', ') ??
// "",
// nominalBayar: orderDetail?.totalPaid ?? 0,
// kembalian: 0,
// productQuantity: orderDetail!.orderItems!
// .toProductQuantities(),
// );
} else { } else {
context.read<PrintStruckBloc>().add( // onPrintBill(
PrintStruckEvent.cashier(state.selectedOrder!), // context,
); // productQuantity: orderDetail!.orderItems!
// .toProductQuantities(),
// order: orderDetail!,
// );
} }
}, },
label: 'Print Bill', label: 'Print Bill',

View File

@ -3,12 +3,10 @@ import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../../application/order/order_loader/order_loader_bloc.dart'; import '../../../../../application/order/order_loader/order_loader_bloc.dart';
import '../../../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../../../common/theme/theme.dart'; import '../../../../../common/theme/theme.dart';
import '../../../../../injection.dart'; import '../../../../../injection.dart';
import '../../../../components/error/order_loader_error_state_widget.dart'; import '../../../../components/error/order_loader_error_state_widget.dart';
import '../../../../components/loader/loader_with_text.dart'; import '../../../../components/loader/loader_with_text.dart';
import '../../../../components/toast/flushbar.dart';
import 'widgets/payment_success_left_panel.dart'; import 'widgets/payment_success_left_panel.dart';
import 'widgets/payment_success_right_panel.dart'; import 'widgets/payment_success_right_panel.dart';
@ -19,58 +17,45 @@ class PaymentSuccessPage extends StatelessWidget implements AutoRouteWrapper {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return BlocListener<PrintStruckBloc, PrintStruckState>( return Scaffold(
listenWhen: (previous, current) => backgroundColor: AppColor.background,
previous.failureOrPrintStruck != current.failureOrPrintStruck, body: SafeArea(
listener: (context, state) { child: BlocBuilder<OrderLoaderBloc, OrderLoaderState>(
state.failureOrPrintStruck.fold(() {}, (either) { builder: (context, state) {
either.fold((f) => AppFlushbar.showPrinterFailureToast(context, f), ( if (state.isFetchingById) {
success, return const Center(child: LoaderWithText());
) { }
AppFlushbar.showSuccess(context, "Struck berhasil dicetak"); return state.failureOptionGetById.fold(
}); () => Container(
}); padding: const EdgeInsets.all(24.0),
}, child: Row(
child: Scaffold( children: [
backgroundColor: AppColor.background, // Left Panel - Success Message & Order Info
body: SafeArea( Expanded(
child: BlocBuilder<OrderLoaderBloc, OrderLoaderState>( flex: 35,
builder: (context, state) { child: PaymentSuccessLeftPanel(order: state.order),
if (state.isFetchingById) { ),
return const Center(child: LoaderWithText());
}
return state.failureOptionGetById.fold(
() => Container(
padding: const EdgeInsets.all(24.0),
child: Row(
children: [
// Left Panel - Success Message & Order Info
Expanded(
flex: 35,
child: PaymentSuccessLeftPanel(order: state.order),
),
const SizedBox(width: 16), const SizedBox(width: 16),
// Right Panel - Order Details // Right Panel - Order Details
Expanded( Expanded(
flex: 65, flex: 65,
child: PaymentSuccessRightPanel(order: state.order), child: PaymentSuccessRightPanel(order: state.order),
), ),
], ],
),
), ),
(f) => OrderLoaderErrorStateWidget( ),
failure: f, (f) => OrderLoaderErrorStateWidget(
onRefresh: () { failure: f,
context.read<OrderLoaderBloc>().add( onRefresh: () {
OrderLoaderEvent.getById(orderId), context.read<OrderLoaderBloc>().add(
); OrderLoaderEvent.getById(orderId),
}, );
), },
); ),
}, );
), },
), ),
), ),
); );

View File

@ -1,8 +1,6 @@
import 'package:auto_route/auto_route.dart'; import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../../../application/printer/print_struck/print_struck_bloc.dart';
import '../../../../../../common/extension/extension.dart'; import '../../../../../../common/extension/extension.dart';
import '../../../../../../common/theme/theme.dart'; import '../../../../../../common/theme/theme.dart';
import '../../../../../../domain/order/order.dart'; import '../../../../../../domain/order/order.dart';
@ -162,9 +160,22 @@ class PaymentSuccessLeftPanel extends StatelessWidget {
Expanded( Expanded(
child: AppElevatedButton.filled( child: AppElevatedButton.filled(
onPressed: () { onPressed: () {
context.read<PrintStruckBloc>().add( // onPrintRecipt(
PrintStruckEvent.payment(order), // context,
); // order: widget.order,
// paymentMethod: widget.paymentMethod,
// nominalBayar: widget.paymentMethod == "Cash"
// ? widget.nominalBayar
// : widget.order.totalAmount ?? 0,
// kembalian: widget.nominalBayar -
// (widget.order.totalAmount ?? 0),
// productQuantity: widget.productQuantity,
// );
// onPrint(
// context,
// productQuantity: widget.productQuantity,
// order: widget.order,
// );
}, },
label: 'Cetak Struk', label: 'Cetak Struk',
icon: Icon(Icons.print_rounded, color: AppColor.white), icon: Icon(Icons.print_rounded, color: AppColor.white),