Feat: add argument for page ticket booking step 4
This commit is contained in:
parent
210209b376
commit
491ba3b55f
|
@ -500,7 +500,7 @@
|
||||||
"languageVersion": "3.4"
|
"languageVersion": "3.4"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"generated": "2025-03-21T19:39:10.352546Z",
|
"generated": "2025-03-26T12:09:54.704663Z",
|
||||||
"generator": "pub",
|
"generator": "pub",
|
||||||
"generatorVersion": "3.5.0",
|
"generatorVersion": "3.5.0",
|
||||||
"flutterRoot": "file:///D:/Flutter/flutter_sdk/flutter_3.24.0",
|
"flutterRoot": "file:///D:/Flutter/flutter_sdk/flutter_3.24.0",
|
||||||
|
|
|
@ -150,7 +150,6 @@ class _TicketBookingStep3ScreenState extends State<TicketBookingStep3Screen> {
|
||||||
selectedDepartureService = null;
|
selectedDepartureService = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (serviceType == 'arrival') {
|
} else if (serviceType == 'arrival') {
|
||||||
if (isSelected) {
|
if (isSelected) {
|
||||||
if (selectedArrivalService != null) {
|
if (selectedArrivalService != null) {
|
||||||
|
@ -164,7 +163,6 @@ class _TicketBookingStep3ScreenState extends State<TicketBookingStep3Screen> {
|
||||||
selectedArrivalService = null;
|
selectedArrivalService = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (serviceType == 'transit') {
|
} else if (serviceType == 'transit') {
|
||||||
if (isSelected) {
|
if (isSelected) {
|
||||||
if (selectedTransitService != null) {
|
if (selectedTransitService != null) {
|
||||||
|
@ -279,9 +277,38 @@ class _TicketBookingStep3ScreenState extends State<TicketBookingStep3Screen> {
|
||||||
labelText: "Pesanan",
|
labelText: "Pesanan",
|
||||||
labelButton: "Lanjut",
|
labelButton: "Lanjut",
|
||||||
onTap: () {
|
onTap: () {
|
||||||
Get.toNamed(Routes.TICKETBOOKINGSTEP4);
|
List<String> selectedServiceLabels = [];
|
||||||
|
Map<String, PorterServiceModel?> selectedPorterServices = {};
|
||||||
|
|
||||||
|
if (_isChecked1) {
|
||||||
|
selectedServiceLabels.add("Keberangkatan");
|
||||||
|
selectedPorterServices['departure'] = selectedDepartureService;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_isChecked2) {
|
||||||
|
selectedServiceLabels.add("Kedatangan");
|
||||||
|
selectedPorterServices['arrival'] = selectedArrivalService;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_isChecked3) {
|
||||||
|
selectedServiceLabels.add("Transit");
|
||||||
|
selectedPorterServices['transit'] = selectedTransitService;
|
||||||
|
}
|
||||||
|
final argument = {
|
||||||
|
'tickedId': ticketId,
|
||||||
|
'flightId': flightId,
|
||||||
|
'ticketDate': ticketDate,
|
||||||
|
'passenger': passenger,
|
||||||
|
'selectedPassenger': selectedPassengers,
|
||||||
|
'numberSeat': numberSeat,
|
||||||
|
'grandTotal': grandTotal,
|
||||||
|
'selectedServiceLabels': selectedServiceLabels,
|
||||||
|
'selectedPorter': selectedPorterServices,
|
||||||
|
};
|
||||||
|
Get.toNamed(Routes.TICKETBOOKINGSTEP4, arguments: argument);
|
||||||
},
|
},
|
||||||
));
|
),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _buildCheckBox(
|
Widget _buildCheckBox(
|
||||||
|
|
|
@ -7,8 +7,11 @@ import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
import 'package:flutter_svg/svg.dart';
|
import 'package:flutter_svg/svg.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
import 'package:intl/intl.dart';
|
||||||
import '../../../../_core/component/appbar/appbar_component.dart';
|
import '../../../../_core/component/appbar/appbar_component.dart';
|
||||||
import '../../../../_core/component/icons/icons_library.dart';
|
import '../../../../_core/component/icons/icons_library.dart';
|
||||||
|
import '../../../../domain/models/porter_service_model.dart';
|
||||||
|
import '../../../../domain/models/user_entity.dart';
|
||||||
import '../component/card_flight_information.dart';
|
import '../component/card_flight_information.dart';
|
||||||
|
|
||||||
class TicketBookingStep4Screen extends StatefulWidget {
|
class TicketBookingStep4Screen extends StatefulWidget {
|
||||||
|
@ -19,6 +22,31 @@ class TicketBookingStep4Screen extends StatefulWidget {
|
||||||
}
|
}
|
||||||
|
|
||||||
class _TicketBookingStep4ScreenState extends State<TicketBookingStep4Screen> {
|
class _TicketBookingStep4ScreenState extends State<TicketBookingStep4Screen> {
|
||||||
|
late final String ticketId;
|
||||||
|
late final String flightId;
|
||||||
|
late String? ticketDate;
|
||||||
|
late final int passenger;
|
||||||
|
late final List<PassengerModel?> selectedPassengers;
|
||||||
|
late List<String> numberSeat;
|
||||||
|
late double? grandTotal;
|
||||||
|
late List<String> selectedServiceLabels;
|
||||||
|
late Map<String, PorterServiceModel?> selectedPorterServices;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
final args = Get.arguments as Map<String, dynamic>;
|
||||||
|
ticketId = args['ticketId'] ?? '';
|
||||||
|
flightId = args['flightId'] ?? '';
|
||||||
|
ticketDate = args['date'] ?? '';
|
||||||
|
passenger = args['passenger'] ?? 0;
|
||||||
|
selectedPassengers = args['selectedPassenger'] ?? [];
|
||||||
|
numberSeat = args['numberSeat'] ?? '';
|
||||||
|
grandTotal = args['grandTotal'] ?? 0;
|
||||||
|
selectedServiceLabels = args['selectedServiceLabels'] ?? [];
|
||||||
|
selectedPorterServices = args['selectedPorterServices'] ?? {};
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
|
@ -130,7 +158,7 @@ class _TicketBookingStep4ScreenState extends State<TicketBookingStep4Screen> {
|
||||||
)),
|
)),
|
||||||
bottomNavigationBar: FooterPrice(
|
bottomNavigationBar: FooterPrice(
|
||||||
labelText: "Pembayaran",
|
labelText: "Pembayaran",
|
||||||
price: "1.450.000",
|
price: "Rp ${NumberFormat.decimalPattern('id_ID').format(grandTotal)}",
|
||||||
labelButton: "Buat Pesanan",
|
labelButton: "Buat Pesanan",
|
||||||
iconButton: CustomeIcons.ProtectOutline(color: Colors.white),
|
iconButton: CustomeIcons.ProtectOutline(color: Colors.white),
|
||||||
onTap: () {
|
onTap: () {
|
||||||
|
|
Loading…
Reference in New Issue