feat: add item to order

This commit is contained in:
efrilm 2025-08-04 01:12:56 +07:00
parent 571ba9802e
commit 6fb1a7d0c4
6 changed files with 426 additions and 40 deletions

View File

@ -355,4 +355,44 @@ class OrderRemoteDatasource {
return const Left('Terjadi kesalahan tak terduga');
}
}
Future<Either<String, OrderDetailResponseModel>> addToOrder({
required String orderId,
required List<OrderItemRequest> orderItems,
}) async {
final authData = await AuthLocalDataSource().getAuthData();
final url = '${Variables.baseUrl}/api/v1/orders/$orderId/add-items';
try {
final response = await dio.post(
url,
data: {
"order_items": orderItems.map((item) => item.toMap()).toList(),
'notes': '',
},
options: Options(
headers: {
'Authorization': 'Bearer ${authData.token}',
'Accept': 'application/json',
'Content-Type': 'application/json',
},
),
);
if (response.statusCode == 200) {
final data = OrderDetailResponseModel.fromMap(response.data);
return Right(data);
} else {
return const Left('Gagal menambahkan pesanan pesanan');
}
} on DioException catch (e) {
final errorMessage = e.response?.data['message'] ?? 'Kesalahan jaringan';
log("💥 Dio error: ${e.message}");
log("💥 Dio response: ${e.response?.data}");
return Left(errorMessage);
} catch (e) {
log("💥 Unexpected error: $e");
return const Left('Terjadi kesalahan tak terduga');
}
}
}

View File

@ -106,6 +106,32 @@ class OrderFormBloc extends Bloc<OrderFormEvent, OrderFormState> {
}
},
);
on<_AddToOrder>(
(event, emit) async {
emit(const _Loading());
try {
final result = await _orderRemoteDatasource.addToOrder(
orderId: event.orderId,
orderItems: event.items
.map((item) => OrderItemRequest(
productId: item.product.id,
quantity: item.quantity,
unitPrice: item.product.price,
notes: item.notes))
.toList(),
);
result.fold(
(error) => emit(_Error(error)),
(success) => emit(_Success(success.data!)),
);
} catch (e) {
log("Error in AddOrderItemsBloc: $e");
emit(_Error("Failed to add order items: $e"));
}
},
);
on<_ToggleItem>((event, emit) {
state.maybeWhen(
loaded: (order, selectedItems, _) {

View File

@ -25,6 +25,8 @@ mixin _$OrderFormEvent {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -39,6 +41,7 @@ mixin _$OrderFormEvent {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -53,6 +56,7 @@ mixin _$OrderFormEvent {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -64,6 +68,7 @@ mixin _$OrderFormEvent {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -74,6 +79,7 @@ mixin _$OrderFormEvent {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -84,6 +90,7 @@ mixin _$OrderFormEvent {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -188,6 +195,8 @@ class _$StartedImpl implements _Started {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -205,6 +214,7 @@ class _$StartedImpl implements _Started {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -222,6 +232,7 @@ class _$StartedImpl implements _Started {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -239,6 +250,7 @@ class _$StartedImpl implements _Started {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -252,6 +264,7 @@ class _$StartedImpl implements _Started {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -265,6 +278,7 @@ class _$StartedImpl implements _Started {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -318,7 +332,7 @@ class __$$CreateImplCopyWithImpl<$Res>
Object? items = null,
Object? customerName = null,
Object? orderType = null,
Object? table = freezed,
Object? table = null,
}) {
return _then(_$CreateImpl(
items: null == items
@ -333,7 +347,7 @@ class __$$CreateImplCopyWithImpl<$Res>
? _value.orderType
: orderType // ignore: cast_nullable_to_non_nullable
as OrderType,
table: freezed == table
table: null == table
? _value.table
: table // ignore: cast_nullable_to_non_nullable
as TableModel,
@ -381,7 +395,7 @@ class _$CreateImpl implements _Create {
other.customerName == customerName) &&
(identical(other.orderType, orderType) ||
other.orderType == orderType) &&
const DeepCollectionEquality().equals(other.table, table));
(identical(other.table, table) || other.table == table));
}
@override
@ -390,7 +404,7 @@ class _$CreateImpl implements _Create {
const DeepCollectionEquality().hash(_items),
customerName,
orderType,
const DeepCollectionEquality().hash(table));
table);
/// Create a copy of OrderFormEvent
/// with the given fields replaced by the non-null parameter values.
@ -410,6 +424,8 @@ class _$CreateImpl implements _Create {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -427,6 +443,7 @@ class _$CreateImpl implements _Create {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -444,6 +461,7 @@ class _$CreateImpl implements _Create {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -461,6 +479,7 @@ class _$CreateImpl implements _Create {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -474,6 +493,7 @@ class _$CreateImpl implements _Create {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -487,6 +507,7 @@ class _$CreateImpl implements _Create {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -550,7 +571,7 @@ class __$$CreateWithPaymentMethodImplCopyWithImpl<$Res>
Object? items = null,
Object? customerName = null,
Object? orderType = null,
Object? table = freezed,
Object? table = null,
Object? paymentMethod = null,
}) {
return _then(_$CreateWithPaymentMethodImpl(
@ -566,7 +587,7 @@ class __$$CreateWithPaymentMethodImplCopyWithImpl<$Res>
? _value.orderType
: orderType // ignore: cast_nullable_to_non_nullable
as OrderType,
table: freezed == table
table: null == table
? _value.table
: table // ignore: cast_nullable_to_non_nullable
as TableModel,
@ -621,7 +642,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
other.customerName == customerName) &&
(identical(other.orderType, orderType) ||
other.orderType == orderType) &&
const DeepCollectionEquality().equals(other.table, table) &&
(identical(other.table, table) || other.table == table) &&
(identical(other.paymentMethod, paymentMethod) ||
other.paymentMethod == paymentMethod));
}
@ -632,7 +653,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
const DeepCollectionEquality().hash(_items),
customerName,
orderType,
const DeepCollectionEquality().hash(table),
table,
paymentMethod);
/// Create a copy of OrderFormEvent
@ -654,6 +675,8 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -672,6 +695,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -690,6 +714,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -708,6 +733,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -721,6 +747,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -734,6 +761,7 @@ class _$CreateWithPaymentMethodImpl implements _CreateWithPaymentMethod {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -768,6 +796,209 @@ abstract class _CreateWithPaymentMethod implements OrderFormEvent {
get copyWith => throw _privateConstructorUsedError;
}
/// @nodoc
abstract class _$$AddToOrderImplCopyWith<$Res> {
factory _$$AddToOrderImplCopyWith(
_$AddToOrderImpl value, $Res Function(_$AddToOrderImpl) then) =
__$$AddToOrderImplCopyWithImpl<$Res>;
@useResult
$Res call({List<ProductQuantity> items, String orderId});
}
/// @nodoc
class __$$AddToOrderImplCopyWithImpl<$Res>
extends _$OrderFormEventCopyWithImpl<$Res, _$AddToOrderImpl>
implements _$$AddToOrderImplCopyWith<$Res> {
__$$AddToOrderImplCopyWithImpl(
_$AddToOrderImpl _value, $Res Function(_$AddToOrderImpl) _then)
: super(_value, _then);
/// Create a copy of OrderFormEvent
/// with the given fields replaced by the non-null parameter values.
@pragma('vm:prefer-inline')
@override
$Res call({
Object? items = null,
Object? orderId = null,
}) {
return _then(_$AddToOrderImpl(
items: null == items
? _value._items
: items // ignore: cast_nullable_to_non_nullable
as List<ProductQuantity>,
orderId: null == orderId
? _value.orderId
: orderId // ignore: cast_nullable_to_non_nullable
as String,
));
}
}
/// @nodoc
class _$AddToOrderImpl implements _AddToOrder {
const _$AddToOrderImpl(
{required final List<ProductQuantity> items, required this.orderId})
: _items = items;
final List<ProductQuantity> _items;
@override
List<ProductQuantity> get items {
if (_items is EqualUnmodifiableListView) return _items;
// ignore: implicit_dynamic_type
return EqualUnmodifiableListView(_items);
}
@override
final String orderId;
@override
String toString() {
return 'OrderFormEvent.addToOrder(items: $items, orderId: $orderId)';
}
@override
bool operator ==(Object other) {
return identical(this, other) ||
(other.runtimeType == runtimeType &&
other is _$AddToOrderImpl &&
const DeepCollectionEquality().equals(other._items, _items) &&
(identical(other.orderId, orderId) || other.orderId == orderId));
}
@override
int get hashCode => Object.hash(
runtimeType, const DeepCollectionEquality().hash(_items), orderId);
/// Create a copy of OrderFormEvent
/// with the given fields replaced by the non-null parameter values.
@JsonKey(includeFromJson: false, includeToJson: false)
@override
@pragma('vm:prefer-inline')
_$$AddToOrderImplCopyWith<_$AddToOrderImpl> get copyWith =>
__$$AddToOrderImplCopyWithImpl<_$AddToOrderImpl>(this, _$identity);
@override
@optionalTypeArgs
TResult when<TResult extends Object?>({
required TResult Function(Order order) started,
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table)
create,
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
}) {
return addToOrder(items, orderId);
}
@override
@optionalTypeArgs
TResult? whenOrNull<TResult extends Object?>({
TResult? Function(Order order)? started,
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table)?
create,
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
}) {
return addToOrder?.call(items, orderId);
}
@override
@optionalTypeArgs
TResult maybeWhen<TResult extends Object?>({
TResult Function(Order order)? started,
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table)?
create,
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
required TResult orElse(),
}) {
if (addToOrder != null) {
return addToOrder(items, orderId);
}
return orElse();
}
@override
@optionalTypeArgs
TResult map<TResult extends Object?>({
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
}) {
return addToOrder(this);
}
@override
@optionalTypeArgs
TResult? mapOrNull<TResult extends Object?>({
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
}) {
return addToOrder?.call(this);
}
@override
@optionalTypeArgs
TResult maybeMap<TResult extends Object?>({
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
required TResult orElse(),
}) {
if (addToOrder != null) {
return addToOrder(this);
}
return orElse();
}
}
abstract class _AddToOrder implements OrderFormEvent {
const factory _AddToOrder(
{required final List<ProductQuantity> items,
required final String orderId}) = _$AddToOrderImpl;
List<ProductQuantity> get items;
String get orderId;
/// Create a copy of OrderFormEvent
/// with the given fields replaced by the non-null parameter values.
@JsonKey(includeFromJson: false, includeToJson: false)
_$$AddToOrderImplCopyWith<_$AddToOrderImpl> get copyWith =>
throw _privateConstructorUsedError;
}
/// @nodoc
abstract class _$$ToggleItemImplCopyWith<$Res> {
factory _$$ToggleItemImplCopyWith(
@ -843,6 +1074,8 @@ class _$ToggleItemImpl implements _ToggleItem {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -860,6 +1093,7 @@ class _$ToggleItemImpl implements _ToggleItem {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -877,6 +1111,7 @@ class _$ToggleItemImpl implements _ToggleItem {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -894,6 +1129,7 @@ class _$ToggleItemImpl implements _ToggleItem {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -907,6 +1143,7 @@ class _$ToggleItemImpl implements _ToggleItem {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -920,6 +1157,7 @@ class _$ToggleItemImpl implements _ToggleItem {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -1021,6 +1259,8 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -1038,6 +1278,7 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -1055,6 +1296,7 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -1072,6 +1314,7 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -1085,6 +1328,7 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -1098,6 +1342,7 @@ class _$ToggleSelectAllImpl implements _ToggleSelectAll {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,
@ -1170,6 +1415,8 @@ class _$RefundImpl implements _Refund {
required TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)
createWithPayment,
required TResult Function(List<ProductQuantity> items, String orderId)
addToOrder,
required TResult Function(OrderItem item) toggleItem,
required TResult Function(bool selectAll) toggleSelectAll,
required TResult Function() refund,
@ -1187,6 +1434,7 @@ class _$RefundImpl implements _Refund {
TResult? Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult? Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult? Function(OrderItem item)? toggleItem,
TResult? Function(bool selectAll)? toggleSelectAll,
TResult? Function()? refund,
@ -1204,6 +1452,7 @@ class _$RefundImpl implements _Refund {
TResult Function(List<ProductQuantity> items, String customerName,
OrderType orderType, TableModel table, PaymentMethod paymentMethod)?
createWithPayment,
TResult Function(List<ProductQuantity> items, String orderId)? addToOrder,
TResult Function(OrderItem item)? toggleItem,
TResult Function(bool selectAll)? toggleSelectAll,
TResult Function()? refund,
@ -1221,6 +1470,7 @@ class _$RefundImpl implements _Refund {
required TResult Function(_Started value) started,
required TResult Function(_Create value) create,
required TResult Function(_CreateWithPaymentMethod value) createWithPayment,
required TResult Function(_AddToOrder value) addToOrder,
required TResult Function(_ToggleItem value) toggleItem,
required TResult Function(_ToggleSelectAll value) toggleSelectAll,
required TResult Function(_Refund value) refund,
@ -1234,6 +1484,7 @@ class _$RefundImpl implements _Refund {
TResult? Function(_Started value)? started,
TResult? Function(_Create value)? create,
TResult? Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult? Function(_AddToOrder value)? addToOrder,
TResult? Function(_ToggleItem value)? toggleItem,
TResult? Function(_ToggleSelectAll value)? toggleSelectAll,
TResult? Function(_Refund value)? refund,
@ -1247,6 +1498,7 @@ class _$RefundImpl implements _Refund {
TResult Function(_Started value)? started,
TResult Function(_Create value)? create,
TResult Function(_CreateWithPaymentMethod value)? createWithPayment,
TResult Function(_AddToOrder value)? addToOrder,
TResult Function(_ToggleItem value)? toggleItem,
TResult Function(_ToggleSelectAll value)? toggleSelectAll,
TResult Function(_Refund value)? refund,

View File

@ -16,6 +16,10 @@ class OrderFormEvent with _$OrderFormEvent {
required TableModel table,
required PaymentMethod paymentMethod,
}) = _CreateWithPaymentMethod;
const factory OrderFormEvent.addToOrder({
required List<ProductQuantity> items,
required String orderId,
}) = _AddToOrder;
const factory OrderFormEvent.toggleItem(OrderItem item) = _ToggleItem;
const factory OrderFormEvent.toggleSelectAll(bool selectAll) =
_ToggleSelectAll;

View File

@ -1,28 +1,41 @@
import 'package:enaklo_pos/core/components/buttons.dart';
import 'package:enaklo_pos/core/components/custom_modal_dialog.dart';
import 'package:enaklo_pos/core/components/flushbar.dart';
import 'package:enaklo_pos/core/components/spaces.dart';
import 'package:enaklo_pos/core/constants/colors.dart';
import 'package:enaklo_pos/core/extensions/build_context_ext.dart';
import 'package:enaklo_pos/data/models/response/table_model.dart';
import 'package:enaklo_pos/presentation/home/bloc/get_table_status/get_table_status_bloc.dart';
import 'package:enaklo_pos/data/models/response/order_response_model.dart';
import 'package:enaklo_pos/presentation/home/bloc/order_form/order_form_bloc.dart';
import 'package:enaklo_pos/presentation/home/models/product_quantity.dart';
import 'package:enaklo_pos/presentation/sales/blocs/order_loader/order_loader_bloc.dart';
import 'package:enaklo_pos/presentation/success/pages/success_save_order_page.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
class PaymentAddOrderDialog extends StatefulWidget {
const PaymentAddOrderDialog({super.key});
final List<ProductQuantity> items;
const PaymentAddOrderDialog({super.key, required this.items});
@override
State<PaymentAddOrderDialog> createState() => _PaymentAddOrderDialogState();
}
class _PaymentAddOrderDialogState extends State<PaymentAddOrderDialog> {
TableModel? selectTable;
Order? selectOrder;
@override
void initState() {
super.initState();
context
.read<OrderLoaderBloc>()
.add(OrderLoaderEvent.getByStatus('pending'));
}
@override
Widget build(BuildContext context) {
return CustomModalDialog(
title: 'Tambah Pesanan',
subtitle: 'Silahkan tambahkan pesanan',
title: 'Bayar Nanti',
subtitle: 'Simpan pesanan dan bayar nanti',
contentPadding:
const EdgeInsets.symmetric(horizontal: 16.0, vertical: 24.0),
minWidth: context.deviceWidth * 0.4,
@ -34,28 +47,44 @@ class _PaymentAddOrderDialogState extends State<PaymentAddOrderDialog> {
crossAxisAlignment: CrossAxisAlignment.start,
children: [
const Text(
'Pilih Meja yang Sudah Ada Pesanan',
'Pilih Meja yang sudah dipesan',
style: TextStyle(
color: AppColors.black,
fontSize: 16,
fontWeight: FontWeight.w600,
),
),
const SpaceHeight(12.0),
BlocBuilder<GetTableStatusBloc, GetTableStatusState>(
const SpaceHeight(6.0),
BlocBuilder<OrderLoaderBloc, OrderLoaderState>(
builder: (context, state) {
return state.maybeWhen(
orElse: () => const CircularProgressIndicator(),
success: (tables) {
print(
"🔘 Add to Order - Tables fetched: ${tables.length} tables");
print(
"🔘 Add to Order - Table statuses: ${tables.map((t) => '${t.tableName}: ${t.status}').join(', ')}");
// No need to filter since we're fetching occupied tables directly
final occupiedTables = tables;
orElse: () =>
Center(child: const CircularProgressIndicator()),
loading: () =>
Center(child: const CircularProgressIndicator()),
loaded: (orders, totalOrder) {
final availableOrders = orders;
if (selectTable == null && occupiedTables.isNotEmpty) {
selectTable = occupiedTables.first;
if (selectOrder == null && availableOrders.isNotEmpty) {
selectOrder = availableOrders.first;
}
if (availableOrders.isEmpty) {
return Container(
padding: const EdgeInsets.all(16),
decoration: BoxDecoration(
color: Colors.orange[50],
borderRadius: BorderRadius.circular(16),
border: Border.all(
color: Colors.orange,
width: 1,
),
),
child: const Text(
'Tidak ada meja yang tersedia. Silakan pilih opsi lain.',
style: TextStyle(color: Colors.orange),
),
);
}
return Container(
@ -69,20 +98,24 @@ class _PaymentAddOrderDialogState extends State<PaymentAddOrderDialog> {
),
),
child: DropdownButtonHideUnderline(
child: DropdownButton<TableModel>(
child: DropdownButton<Order>(
isExpanded: true,
value: selectTable,
onChanged: (TableModel? newValue) {
value: availableOrders.firstWhere(
(t) => t.id == selectOrder?.id,
orElse: () => availableOrders.first,
),
onChanged: (Order? newValue) {
setState(() {
selectTable = newValue;
selectOrder = newValue;
});
},
items: occupiedTables
.map<DropdownMenuItem<TableModel>>(
(TableModel value) =>
DropdownMenuItem<TableModel>(
items: availableOrders
.map<DropdownMenuItem<Order>>(
(Order value) => DropdownMenuItem<Order>(
value: value,
child: Text('${value.tableName} (Occupied)'),
child: Text(
"${value.tableNumber ?? ""} - ${value.metadata?['customer_name'] ?? ""}",
),
),
)
.toList(),
@ -95,9 +128,38 @@ class _PaymentAddOrderDialogState extends State<PaymentAddOrderDialog> {
],
),
SpaceHeight(24),
Button.filled(
onPressed: () {},
label: "Simpan",
BlocListener<OrderFormBloc, OrderFormState>(
listener: (context, state) {
state.maybeWhen(
orElse: () {},
success: (data) {
context.pushReplacement(SuccessSaveOrderPage(
order: data,
));
},
error: (message) => AppFlushbar.showError(context, message),
);
},
child: BlocBuilder<OrderFormBloc, OrderFormState>(
builder: (context, state) {
return state.maybeWhen(
orElse: () => Button.filled(
onPressed: () {
context
.read<OrderFormBloc>()
.add(OrderFormEvent.addToOrder(
items: widget.items,
orderId: selectOrder?.id ?? "",
));
},
label: "Simpan",
),
loading: () => Center(
child: const CircularProgressIndicator(),
),
);
},
),
),
],
),

View File

@ -58,7 +58,9 @@ class _SaveDialogState extends State<SaveDialog> {
subtitle: 'Tambah item ke daftar pesanan',
onTap: () => showDialog(
context: context,
builder: (context) => const PaymentAddOrderDialog(),
builder: (context) => PaymentAddOrderDialog(
items: widget.items,
),
),
),
],