Compare commits
No commits in common. "af182b6f5acf8dc5b4fbd908d03a3999ebfa7a11" and "93560b85cb41723da3d961def8f63ddebe1f642a" have entirely different histories.
af182b6f5a
...
93560b85cb
@ -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,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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';
|
||||||
|
|
||||||
|
|||||||
@ -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,
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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,
|
||||||
|
|||||||
@ -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(
|
||||||
|
|||||||
@ -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,
|
||||||
),
|
),
|
||||||
],
|
),
|
||||||
),
|
],
|
||||||
);
|
),
|
||||||
},
|
);
|
||||||
),
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|||||||
@ -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),
|
||||||
|
|||||||
@ -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',
|
||||||
|
|||||||
@ -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),
|
||||||
},
|
);
|
||||||
),
|
},
|
||||||
);
|
),
|
||||||
},
|
);
|
||||||
),
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|||||||
@ -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),
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user