oneticket-sdk-vi 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.tsx +44 -0
- package/dist/App.d.ts +9 -0
- package/dist/App.js +32 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.js +29 -0
- package/dist/src/assets/icons/BackIcon.d.ts +7 -0
- package/dist/src/assets/icons/BackIcon.js +36 -0
- package/dist/src/assets/icons/BellIcon.d.ts +7 -0
- package/dist/src/assets/icons/BellIcon.js +36 -0
- package/dist/src/assets/icons/BusIcon.d.ts +7 -0
- package/dist/src/assets/icons/BusIcon.js +14 -0
- package/dist/src/assets/icons/CalendarIcon.d.ts +7 -0
- package/dist/src/assets/icons/CalendarIcon.js +14 -0
- package/dist/src/assets/icons/ChangeIcon.d.ts +8 -0
- package/dist/src/assets/icons/ChangeIcon.js +39 -0
- package/dist/src/assets/icons/ChatIcon.d.ts +7 -0
- package/dist/src/assets/icons/ChatIcon.js +35 -0
- package/dist/src/assets/icons/ChevronDownIcon.d.ts +7 -0
- package/dist/src/assets/icons/ChevronDownIcon.js +35 -0
- package/dist/src/assets/icons/ChevronLeftIcon.d.ts +7 -0
- package/dist/src/assets/icons/ChevronLeftIcon.js +35 -0
- package/dist/src/assets/icons/ChevronRightIcon.d.ts +7 -0
- package/dist/src/assets/icons/ChevronRightIcon.js +35 -0
- package/dist/src/assets/icons/ChevronUpIcon.d.ts +7 -0
- package/dist/src/assets/icons/ChevronUpIcon.js +35 -0
- package/dist/src/assets/icons/CloseIcon.d.ts +7 -0
- package/dist/src/assets/icons/CloseIcon.js +14 -0
- package/dist/src/assets/icons/DeleteIcon.d.ts +7 -0
- package/dist/src/assets/icons/DeleteIcon.js +14 -0
- package/dist/src/assets/icons/ErrorIcon.d.ts +7 -0
- package/dist/src/assets/icons/ErrorIcon.js +14 -0
- package/dist/src/assets/icons/FAQIcon.d.ts +7 -0
- package/dist/src/assets/icons/FAQIcon.js +14 -0
- package/dist/src/assets/icons/FilterIcon.d.ts +7 -0
- package/dist/src/assets/icons/FilterIcon.js +35 -0
- package/dist/src/assets/icons/HamburgerIcon.d.ts +7 -0
- package/dist/src/assets/icons/HamburgerIcon.js +38 -0
- package/dist/src/assets/icons/HelpIcon.d.ts +7 -0
- package/dist/src/assets/icons/HelpIcon.js +37 -0
- package/dist/src/assets/icons/HistoryIcon.d.ts +7 -0
- package/dist/src/assets/icons/HistoryIcon.js +14 -0
- package/dist/src/assets/icons/Home.d.ts +8 -0
- package/dist/src/assets/icons/Home.js +36 -0
- package/dist/src/assets/icons/HomeIcon.d.ts +8 -0
- package/dist/src/assets/icons/HomeIcon.js +16 -0
- package/dist/src/assets/icons/InfoIcon.d.ts +7 -0
- package/dist/src/assets/icons/InfoIcon.js +37 -0
- package/dist/src/assets/icons/IssueIcon.d.ts +7 -0
- package/dist/src/assets/icons/IssueIcon.js +26 -0
- package/dist/src/assets/icons/LocationIcon.d.ts +8 -0
- package/dist/src/assets/icons/LocationIcon.js +36 -0
- package/dist/src/assets/icons/LogoutIcon.d.ts +7 -0
- package/dist/src/assets/icons/LogoutIcon.js +14 -0
- package/dist/src/assets/icons/MailIcon.d.ts +7 -0
- package/dist/src/assets/icons/MailIcon.js +14 -0
- package/dist/src/assets/icons/MetroIcon.d.ts +7 -0
- package/dist/src/assets/icons/MetroIcon.js +14 -0
- package/dist/src/assets/icons/MinusIcon.d.ts +7 -0
- package/dist/src/assets/icons/MinusIcon.js +35 -0
- package/dist/src/assets/icons/PhoneIcon.d.ts +7 -0
- package/dist/src/assets/icons/PhoneIcon.js +35 -0
- package/dist/src/assets/icons/PlusIcon.d.ts +7 -0
- package/dist/src/assets/icons/PlusIcon.js +36 -0
- package/dist/src/assets/icons/RefreshIcon.d.ts +8 -0
- package/dist/src/assets/icons/RefreshIcon.js +35 -0
- package/dist/src/assets/icons/RightArrowIcon.d.ts +7 -0
- package/dist/src/assets/icons/RightArrowIcon.js +36 -0
- package/dist/src/assets/icons/SearchIcon.d.ts +7 -0
- package/dist/src/assets/icons/SearchIcon.js +14 -0
- package/dist/src/assets/icons/SendIcon.d.ts +7 -0
- package/dist/src/assets/icons/SendIcon.js +35 -0
- package/dist/src/assets/icons/ShareIcon.d.ts +7 -0
- package/dist/src/assets/icons/ShareIcon.js +16 -0
- package/dist/src/assets/icons/SuccessIcon.d.ts +7 -0
- package/dist/src/assets/icons/SuccessIcon.js +14 -0
- package/dist/src/assets/icons/SwapIcon.d.ts +7 -0
- package/dist/src/assets/icons/SwapIcon.js +14 -0
- package/dist/src/assets/icons/TickIcon.d.ts +7 -0
- package/dist/src/assets/icons/TickIcon.js +14 -0
- package/dist/src/assets/icons/UserIcon.d.ts +8 -0
- package/dist/src/assets/icons/UserIcon.js +18 -0
- package/dist/src/assets/icons/WalkIcon.d.ts +7 -0
- package/dist/src/assets/icons/WalkIcon.js +14 -0
- package/dist/src/assets/images/AgraMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/AgraMetroLogo.js +16 -0
- package/dist/src/assets/images/AhmedabadMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/AhmedabadMetroLogo.js +17 -0
- package/dist/src/assets/images/BengaluruMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/BengaluruMetroLogo.js +26 -0
- package/dist/src/assets/images/ChennaiMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/ChennaiMetroLogo.js +28 -0
- package/dist/src/assets/images/DelhiMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/DelhiMetroLogo.js +17 -0
- package/dist/src/assets/images/HyderabadMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/HyderabadMetroLogo.js +116 -0
- package/dist/src/assets/images/JaipurMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/JaipurMetroLogo.js +15 -0
- package/dist/src/assets/images/KanpurMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/KanpurMetroLogo.js +16 -0
- package/dist/src/assets/images/KochiMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/KochiMetroLogo.js +17 -0
- package/dist/src/assets/images/KolkataMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/KolkataMetroLogo.js +17 -0
- package/dist/src/assets/images/LucknowMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/LucknowMetroLogo.js +16 -0
- package/dist/src/assets/images/MMO-Flow-logo.png +0 -0
- package/dist/src/assets/images/MMOLogo.d.ts +0 -0
- package/dist/src/assets/images/MMOLogo.js +1 -0
- package/dist/src/assets/images/MumbaiMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/MumbaiMetroLogo.js +25 -0
- package/dist/src/assets/images/NagpurMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/NagpurMetroLogo.js +29 -0
- package/dist/src/assets/images/NaviMumbaiMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/NaviMumbaiMetroLogo.js +17 -0
- package/dist/src/assets/images/NoData.png +0 -0
- package/dist/src/assets/images/NoDataNewTheme.png +0 -0
- package/dist/src/assets/images/OneTicketLogo.png +0 -0
- package/dist/src/assets/images/OneTicketLogoBlue.png +0 -0
- package/dist/src/assets/images/OneTicketNameLogo.png +0 -0
- package/dist/src/assets/images/OneTicketNameLogoBlue.png +0 -0
- package/dist/src/assets/images/OneTicketNewBlueLogo.png +0 -0
- package/dist/src/assets/images/OneTicketShortBoxLogo.png +0 -0
- package/dist/src/assets/images/OneTicketShortLogo.png +0 -0
- package/dist/src/assets/images/PuneMetroLogo.d.ts +7 -0
- package/dist/src/assets/images/PuneMetroLogo.js +47 -0
- package/dist/src/assets/images/SplashScreen.png +0 -0
- package/dist/src/assets/images/adaptive-icon.png +0 -0
- package/dist/src/assets/images/bengaluru_metro_logo.png +0 -0
- package/dist/src/assets/images/bengaluru_metro_logo.svg +15 -0
- package/dist/src/assets/images/bus.png +0 -0
- package/dist/src/assets/images/bus.svg +20 -0
- package/dist/src/assets/images/car.png +0 -0
- package/dist/src/assets/images/car.svg +10 -0
- package/dist/src/assets/images/chennai_metro_logo.png +0 -0
- package/dist/src/assets/images/chennai_metro_logo.svg +5 -0
- package/dist/src/assets/images/company-short-logo.png +0 -0
- package/dist/src/assets/images/company-short-logo.svg +18 -0
- package/dist/src/assets/images/completed.gif +0 -0
- package/dist/src/assets/images/completed.json +1 -0
- package/dist/src/assets/images/delhi_metro_logo.png +0 -0
- package/dist/src/assets/images/delhi_metro_logo.svg +13 -0
- package/dist/src/assets/images/failed.json +1 -0
- package/dist/src/assets/images/favicon.png +0 -0
- package/dist/src/assets/images/google-pay.png +0 -0
- package/dist/src/assets/images/hyderabad_metro_logo.png +0 -0
- package/dist/src/assets/images/hyderabad_metro_logo.svg +35 -0
- package/dist/src/assets/images/icon.png +0 -0
- package/dist/src/assets/images/kochi_metro_logo.png +0 -0
- package/dist/src/assets/images/kochi_metro_logo.svg +7 -0
- package/dist/src/assets/images/mastercard.png +0 -0
- package/dist/src/assets/images/metro.png +0 -0
- package/dist/src/assets/images/metro.svg +11 -0
- package/dist/src/assets/images/mitra_logo.png +0 -0
- package/dist/src/assets/images/mumbai_metro_line_1_logo.png +0 -0
- package/dist/src/assets/images/mumbai_metro_line_1_logo.svg +15 -0
- package/dist/src/assets/images/ondc_logo.png +0 -0
- package/dist/src/assets/images/ondc_network_vertical.png +0 -0
- package/dist/src/assets/images/partial-react-logo.png +0 -0
- package/dist/src/assets/images/paypal.png +0 -0
- package/dist/src/assets/images/phonepay.png +0 -0
- package/dist/src/assets/images/poweredByLogo.png +0 -0
- package/dist/src/assets/images/random_qr.png +0 -0
- package/dist/src/assets/images/react-logo.png +0 -0
- package/dist/src/assets/images/react-logo@2x.png +0 -0
- package/dist/src/assets/images/react-logo@3x.png +0 -0
- package/dist/src/assets/images/return_journey.png +0 -0
- package/dist/src/assets/images/return_journey.svg +8 -0
- package/dist/src/assets/images/sequelstring_logo.png +0 -0
- package/dist/src/assets/images/shareAppQR.png +0 -0
- package/dist/src/assets/images/short-logo.png +0 -0
- package/dist/src/assets/images/short-logo.svg +66 -0
- package/dist/src/assets/images/single_journey.png +0 -0
- package/dist/src/assets/images/single_journey.svg +12 -0
- package/dist/src/assets/images/spinner.svg +71 -0
- package/dist/src/assets/images/splash.png +0 -0
- package/dist/src/assets/images/trip_pass.png +0 -0
- package/dist/src/assets/images/trip_pass.svg +10 -0
- package/dist/src/assets/images/update.json +1 -0
- package/dist/src/assets/images/visa.png +0 -0
- package/dist/src/components/authGuard/AuthGuard.d.ts +6 -0
- package/dist/src/components/authGuard/AuthGuard.js +59 -0
- package/dist/src/components/common/AdBanner/AdBanner.d.ts +7 -0
- package/dist/src/components/common/AdBanner/AdBanner.js +31 -0
- package/dist/src/components/common/Avatar/Avatar.d.ts +14 -0
- package/dist/src/components/common/Avatar/Avatar.js +59 -0
- package/dist/src/components/common/Badge/Badge.d.ts +10 -0
- package/dist/src/components/common/Badge/Badge.js +48 -0
- package/dist/src/components/common/Button/Button.d.ts +20 -0
- package/dist/src/components/common/Button/Button.js +62 -0
- package/dist/src/components/common/Cards/IssueCard.d.ts +11 -0
- package/dist/src/components/common/Cards/IssueCard.js +79 -0
- package/dist/src/components/common/Cards/RecentCard.d.ts +11 -0
- package/dist/src/components/common/Cards/RecentCard.js +71 -0
- package/dist/src/components/common/Cards/TransactionCard.d.ts +12 -0
- package/dist/src/components/common/Cards/TransactionCard.js +89 -0
- package/dist/src/components/common/Cards/TransportationCard.d.ts +13 -0
- package/dist/src/components/common/Cards/TransportationCard.js +65 -0
- package/dist/src/components/common/Cards/TypeCard.d.ts +11 -0
- package/dist/src/components/common/Cards/TypeCard.js +58 -0
- package/dist/src/components/common/Checkbox/Checkbox.d.ts +12 -0
- package/dist/src/components/common/Checkbox/Checkbox.js +27 -0
- package/dist/src/components/common/CustomInput/CustomInput.d.ts +22 -0
- package/dist/src/components/common/CustomInput/CustomInput.js +332 -0
- package/dist/src/components/common/DropdownComponent/DropdownComponent.d.ts +23 -0
- package/dist/src/components/common/DropdownComponent/DropdownComponent.js +133 -0
- package/dist/src/components/common/DropdownComponent/MultiSelectDropdown.d.ts +15 -0
- package/dist/src/components/common/DropdownComponent/MultiSelectDropdown.js +133 -0
- package/dist/src/components/common/EmptyState/EmptyState.d.ts +8 -0
- package/dist/src/components/common/EmptyState/EmptyState.js +40 -0
- package/dist/src/components/common/Header/Header.d.ts +15 -0
- package/dist/src/components/common/Header/Header.js +134 -0
- package/dist/src/components/common/Input/Input.d.ts +15 -0
- package/dist/src/components/common/Input/Input.js +91 -0
- package/dist/src/components/common/Loaders/FooterComponentFlatList.d.ts +6 -0
- package/dist/src/components/common/Loaders/FooterComponentFlatList.js +13 -0
- package/dist/src/components/common/Loaders/FullScreenLoader.d.ts +6 -0
- package/dist/src/components/common/Loaders/FullScreenLoader.js +120 -0
- package/dist/src/components/common/Loaders/Loader.d.ts +6 -0
- package/dist/src/components/common/Loaders/Loader.js +79 -0
- package/dist/src/components/common/Modals/CancellationModal.d.ts +10 -0
- package/dist/src/components/common/Modals/CancellationModal.js +188 -0
- package/dist/src/components/common/Modals/IssueCategoryData.d.ts +5 -0
- package/dist/src/components/common/Modals/IssueCategoryData.js +27 -0
- package/dist/src/components/common/Popup/ForceUpdatePopup.d.ts +8 -0
- package/dist/src/components/common/Popup/ForceUpdatePopup.js +69 -0
- package/dist/src/components/common/PoweredBy/PoweredBy.d.ts +3 -0
- package/dist/src/components/common/PoweredBy/PoweredBy.js +29 -0
- package/dist/src/components/common/QRCodeGenerator/QRCodeGenerator.d.ts +18 -0
- package/dist/src/components/common/QRCodeGenerator/QRCodeGenerator.js +271 -0
- package/dist/src/components/common/SplashScreen/SplashScreen.d.ts +3 -0
- package/dist/src/components/common/SplashScreen/SplashScreen.js +33 -0
- package/dist/src/components/common/Tabs/Tabs2.d.ts +12 -0
- package/dist/src/components/common/Tabs/Tabs2.js +133 -0
- package/dist/src/components/common/Text/CustomText.d.ts +10 -0
- package/dist/src/components/common/Text/CustomText.js +62 -0
- package/dist/src/components/common/Toast/CustomToast.d.ts +3 -0
- package/dist/src/components/common/Toast/CustomToast.js +99 -0
- package/dist/src/components/ticketDetail/BillingDetailsSection.d.ts +15 -0
- package/dist/src/components/ticketDetail/BillingDetailsSection.js +79 -0
- package/dist/src/components/ticketDetail/QRCodeSection.d.ts +22 -0
- package/dist/src/components/ticketDetail/QRCodeSection.js +62 -0
- package/dist/src/components/ticketDetail/RouteSection.d.ts +7 -0
- package/dist/src/components/ticketDetail/RouteSection.js +198 -0
- package/dist/src/components/ticketDetail/TicketDetailSection.d.ts +9 -0
- package/dist/src/components/ticketDetail/TicketDetailSection.js +66 -0
- package/dist/src/helper/getProviders.d.ts +4 -0
- package/dist/src/helper/getProviders.js +59 -0
- package/dist/src/helper/itemsLowestFare.d.ts +1 -0
- package/dist/src/helper/itemsLowestFare.js +20 -0
- package/dist/src/hooks/useSessionTracker.d.ts +1 -0
- package/dist/src/hooks/useSessionTracker.js +47 -0
- package/dist/src/navigation/AuthStack.d.ts +29 -0
- package/dist/src/navigation/AuthStack.js +41 -0
- package/dist/src/navigation/BaseStack.d.ts +16 -0
- package/dist/src/navigation/BaseStack.js +71 -0
- package/dist/src/navigation/UnAuthStack.d.ts +21 -0
- package/dist/src/navigation/UnAuthStack.js +27 -0
- package/dist/src/navigation/metro/HistoryStack.d.ts +18 -0
- package/dist/src/navigation/metro/HistoryStack.js +22 -0
- package/dist/src/navigation/metro/IssueStack.d.ts +14 -0
- package/dist/src/navigation/metro/IssueStack.js +19 -0
- package/dist/src/navigation/metro/MetroStack.d.ts +60 -0
- package/dist/src/navigation/metro/MetroStack.js +82 -0
- package/dist/src/navigation/metro/MetroTabs.d.ts +21 -0
- package/dist/src/navigation/metro/MetroTabs.js +70 -0
- package/dist/src/navigation/metro/MetroWithTabsStack.d.ts +21 -0
- package/dist/src/navigation/metro/MetroWithTabsStack.js +25 -0
- package/dist/src/navigation/metro/ProfileStack.d.ts +18 -0
- package/dist/src/navigation/metro/ProfileStack.js +25 -0
- package/dist/src/screens/auth/DetailsScreen.d.ts +2 -0
- package/dist/src/screens/auth/DetailsScreen.js +106 -0
- package/dist/src/screens/auth/LogInScreen.d.ts +2 -0
- package/dist/src/screens/auth/LogInScreen.js +114 -0
- package/dist/src/screens/auth/OTPScreen.d.ts +2 -0
- package/dist/src/screens/auth/OTPScreen.js +190 -0
- package/dist/src/screens/auth/SignUpScreen.d.ts +2 -0
- package/dist/src/screens/auth/SignUpScreen.js +125 -0
- package/dist/src/screens/auth/SuccessScreen.d.ts +3 -0
- package/dist/src/screens/auth/SuccessScreen.js +81 -0
- package/dist/src/screens/common/Faq/Components/CategoryButton.d.ts +12 -0
- package/dist/src/screens/common/Faq/Components/CategoryButton.js +46 -0
- package/dist/src/screens/common/Faq/FaqScreen.d.ts +3 -0
- package/dist/src/screens/common/Faq/FaqScreen.js +158 -0
- package/dist/src/screens/common/MyAccountScreen.d.ts +3 -0
- package/dist/src/screens/common/MyAccountScreen.js +148 -0
- package/dist/src/screens/common/Profile/Components/MenuItem.d.ts +11 -0
- package/dist/src/screens/common/Profile/Components/MenuItem.js +65 -0
- package/dist/src/screens/common/Profile/ProfileScreen.d.ts +3 -0
- package/dist/src/screens/common/Profile/ProfileScreen.js +197 -0
- package/dist/src/screens/metro/BuyTicket/BuyTicketScreen.d.ts +3 -0
- package/dist/src/screens/metro/BuyTicket/BuyTicketScreen.js +327 -0
- package/dist/src/screens/metro/ChooseStation/ChooseStation.d.ts +3 -0
- package/dist/src/screens/metro/ChooseStation/ChooseStation.js +24 -0
- package/dist/src/screens/metro/ChooseStation/ChooseStationContext.d.ts +11 -0
- package/dist/src/screens/metro/ChooseStation/ChooseStationContext.js +43 -0
- package/dist/src/screens/metro/ChooseStation/Components/Search.d.ts +3 -0
- package/dist/src/screens/metro/ChooseStation/Components/Search.js +74 -0
- package/dist/src/screens/metro/ChooseStation/Components/StationList.d.ts +3 -0
- package/dist/src/screens/metro/ChooseStation/Components/StationList.js +114 -0
- package/dist/src/screens/metro/ChooseStation/types.d.ts +0 -0
- package/dist/src/screens/metro/ChooseStation/types.js +1 -0
- package/dist/src/screens/metro/ChooseTicketTypeScreen.d.ts +3 -0
- package/dist/src/screens/metro/ChooseTicketTypeScreen.js +119 -0
- package/dist/src/screens/metro/HistoryScreen.d.ts +3 -0
- package/dist/src/screens/metro/HistoryScreen.js +239 -0
- package/dist/src/screens/metro/IssueChatScreen.d.ts +2 -0
- package/dist/src/screens/metro/IssueChatScreen.js +137 -0
- package/dist/src/screens/metro/IssueDetailsScreen.d.ts +3 -0
- package/dist/src/screens/metro/IssueDetailsScreen.js +213 -0
- package/dist/src/screens/metro/IssuesScreen.d.ts +3 -0
- package/dist/src/screens/metro/IssuesScreen.js +98 -0
- package/dist/src/screens/metro/MetroSelectionScreen.d.ts +3 -0
- package/dist/src/screens/metro/MetroSelectionScreen.js +58 -0
- package/dist/src/screens/metro/RaiseIssueScreen.d.ts +3 -0
- package/dist/src/screens/metro/RaiseIssueScreen.js +251 -0
- package/dist/src/screens/metro/RecentTransactionScreen.d.ts +3 -0
- package/dist/src/screens/metro/RecentTransactionScreen.js +69 -0
- package/dist/src/screens/metro/SelectStations/Components/FooterButton.d.ts +3 -0
- package/dist/src/screens/metro/SelectStations/Components/FooterButton.js +35 -0
- package/dist/src/screens/metro/SelectStations/Components/RecentTransactions.d.ts +10 -0
- package/dist/src/screens/metro/SelectStations/Components/RecentTransactions.js +52 -0
- package/dist/src/screens/metro/SelectStations/Components/ToAndFromStations.d.ts +3 -0
- package/dist/src/screens/metro/SelectStations/Components/ToAndFromStations.js +111 -0
- package/dist/src/screens/metro/SelectStations/SelectStationContext.d.ts +18 -0
- package/dist/src/screens/metro/SelectStations/SelectStationContext.js +78 -0
- package/dist/src/screens/metro/SelectStations/SelectStations.d.ts +3 -0
- package/dist/src/screens/metro/SelectStations/SelectStations.js +68 -0
- package/dist/src/screens/metro/SelectStations/types.d.ts +0 -0
- package/dist/src/screens/metro/SelectStations/types.js +1 -0
- package/dist/src/screens/metro/TicketDetailsScreen.d.ts +3 -0
- package/dist/src/screens/metro/TicketDetailsScreen.js +252 -0
- package/dist/src/screens/metro/TransportationSelectionScreen.d.ts +0 -0
- package/dist/src/screens/metro/TransportationSelectionScreen.js +96 -0
- package/dist/src/services/apiCall.d.ts +1 -0
- package/dist/src/services/apiCall.js +67 -0
- package/dist/src/services/apiRoutes.d.ts +39 -0
- package/dist/src/services/apiRoutes.js +60 -0
- package/dist/src/services/apis/appVersion/apis.d.ts +2 -0
- package/dist/src/services/apis/appVersion/apis.js +20 -0
- package/dist/src/services/apis/appVersion/hooks.d.ts +2 -0
- package/dist/src/services/apis/appVersion/hooks.js +20 -0
- package/dist/src/services/apis/appVersion/types.d.ts +14 -0
- package/dist/src/services/apis/appVersion/types.js +2 -0
- package/dist/src/services/apis/auth/apis.d.ts +9 -0
- package/dist/src/services/apis/auth/apis.js +62 -0
- package/dist/src/services/apis/auth/hooks.d.ts +9 -0
- package/dist/src/services/apis/auth/hooks.js +185 -0
- package/dist/src/services/apis/auth/types.d.ts +80 -0
- package/dist/src/services/apis/auth/types.js +2 -0
- package/dist/src/services/apis/city/apis.d.ts +5 -0
- package/dist/src/services/apis/city/apis.js +39 -0
- package/dist/src/services/apis/city/hooks.d.ts +6 -0
- package/dist/src/services/apis/city/hooks.js +68 -0
- package/dist/src/services/apis/city/types.d.ts +51 -0
- package/dist/src/services/apis/city/types.js +2 -0
- package/dist/src/services/apis/metro/cancelTicket/apis.d.ts +3 -0
- package/dist/src/services/apis/metro/cancelTicket/apis.js +26 -0
- package/dist/src/services/apis/metro/cancelTicket/hooks.d.ts +3 -0
- package/dist/src/services/apis/metro/cancelTicket/hooks.js +49 -0
- package/dist/src/services/apis/metro/cancelTicket/types.d.ts +18 -0
- package/dist/src/services/apis/metro/cancelTicket/types.js +2 -0
- package/dist/src/services/apis/metro/confirmTicket/apis.d.ts +2 -0
- package/dist/src/services/apis/metro/confirmTicket/apis.js +19 -0
- package/dist/src/services/apis/metro/confirmTicket/hooks.d.ts +2 -0
- package/dist/src/services/apis/metro/confirmTicket/hooks.js +28 -0
- package/dist/src/services/apis/metro/confirmTicket/types.d.ts +8 -0
- package/dist/src/services/apis/metro/confirmTicket/types.js +2 -0
- package/dist/src/services/apis/metro/fare/apis.d.ts +2 -0
- package/dist/src/services/apis/metro/fare/apis.js +20 -0
- package/dist/src/services/apis/metro/fare/hooks.d.ts +3 -0
- package/dist/src/services/apis/metro/fare/hooks.js +20 -0
- package/dist/src/services/apis/metro/fare/types.d.ts +26 -0
- package/dist/src/services/apis/metro/fare/types.js +2 -0
- package/dist/src/services/apis/metro/issue/apis.d.ts +7 -0
- package/dist/src/services/apis/metro/issue/apis.js +65 -0
- package/dist/src/services/apis/metro/issue/hooks.d.ts +7 -0
- package/dist/src/services/apis/metro/issue/hooks.js +106 -0
- package/dist/src/services/apis/metro/issue/types.d.ts +95 -0
- package/dist/src/services/apis/metro/issue/types.js +2 -0
- package/dist/src/services/apis/metro/payment/apis.d.ts +4 -0
- package/dist/src/services/apis/metro/payment/apis.js +32 -0
- package/dist/src/services/apis/metro/payment/hooks.d.ts +4 -0
- package/dist/src/services/apis/metro/payment/hooks.js +73 -0
- package/dist/src/services/apis/metro/payment/types.d.ts +36 -0
- package/dist/src/services/apis/metro/payment/types.js +2 -0
- package/dist/src/services/apis/metro/providers/apis.d.ts +3 -0
- package/dist/src/services/apis/metro/providers/apis.js +26 -0
- package/dist/src/services/apis/metro/providers/hooks.d.ts +3 -0
- package/dist/src/services/apis/metro/providers/hooks.js +37 -0
- package/dist/src/services/apis/metro/providers/types.d.ts +25 -0
- package/dist/src/services/apis/metro/providers/types.js +2 -0
- package/dist/src/services/apis/metro/stations/apis.d.ts +3 -0
- package/dist/src/services/apis/metro/stations/apis.js +27 -0
- package/dist/src/services/apis/metro/stations/hooks.d.ts +3 -0
- package/dist/src/services/apis/metro/stations/hooks.js +28 -0
- package/dist/src/services/apis/metro/stations/types.d.ts +31 -0
- package/dist/src/services/apis/metro/stations/types.js +2 -0
- package/dist/src/services/apis/metro/status/apis.d.ts +3 -0
- package/dist/src/services/apis/metro/status/apis.js +26 -0
- package/dist/src/services/apis/metro/status/hooks.d.ts +3 -0
- package/dist/src/services/apis/metro/status/hooks.js +21 -0
- package/dist/src/services/apis/metro/status/types.d.ts +51 -0
- package/dist/src/services/apis/metro/status/types.js +2 -0
- package/dist/src/services/apis/metro/ticketInit/apis.d.ts +2 -0
- package/dist/src/services/apis/metro/ticketInit/apis.js +20 -0
- package/dist/src/services/apis/metro/ticketInit/hooks.d.ts +2 -0
- package/dist/src/services/apis/metro/ticketInit/hooks.js +28 -0
- package/dist/src/services/apis/metro/ticketInit/types.d.ts +24 -0
- package/dist/src/services/apis/metro/ticketInit/types.js +2 -0
- package/dist/src/services/apis/session/apis.d.ts +3 -0
- package/dist/src/services/apis/session/apis.js +26 -0
- package/dist/src/services/apis/session/hooks.d.ts +3 -0
- package/dist/src/services/apis/session/hooks.js +49 -0
- package/dist/src/services/apis/session/types.d.ts +14 -0
- package/dist/src/services/apis/session/types.js +2 -0
- package/dist/src/services/apis/transaction/apis.d.ts +3 -0
- package/dist/src/services/apis/transaction/apis.js +27 -0
- package/dist/src/services/apis/transaction/hooks.d.ts +3 -0
- package/dist/src/services/apis/transaction/hooks.js +31 -0
- package/dist/src/services/apis/transaction/types.d.ts +39 -0
- package/dist/src/services/apis/transaction/types.js +2 -0
- package/dist/src/services/apis/user/apis.d.ts +2 -0
- package/dist/src/services/apis/user/apis.js +20 -0
- package/dist/src/services/apis/user/hooks.d.ts +2 -0
- package/dist/src/services/apis/user/hooks.js +19 -0
- package/dist/src/services/apis/user/types.d.ts +9 -0
- package/dist/src/services/apis/user/types.js +2 -0
- package/dist/src/theme/ThemeProvider.d.ts +16 -0
- package/dist/src/theme/ThemeProvider.js +67 -0
- package/dist/src/theme/ThemeToggle.d.ts +3 -0
- package/dist/src/theme/ThemeToggle.js +25 -0
- package/dist/src/theme/WithSplashScreen.d.ts +10 -0
- package/dist/src/theme/WithSplashScreen.js +132 -0
- package/dist/src/theme/animations.d.ts +2 -0
- package/dist/src/theme/animations.js +10 -0
- package/dist/src/theme/colors.d.ts +12 -0
- package/dist/src/theme/colors.js +167 -0
- package/dist/src/theme/components/Badge.d.ts +2 -0
- package/dist/src/theme/components/Badge.js +29 -0
- package/dist/src/theme/components/Button.d.ts +2 -0
- package/dist/src/theme/components/Button.js +98 -0
- package/dist/src/theme/components/Card.d.ts +2 -0
- package/dist/src/theme/components/Card.js +23 -0
- package/dist/src/theme/components/Chip.d.ts +2 -0
- package/dist/src/theme/components/Chip.js +28 -0
- package/dist/src/theme/components/Input.d.ts +2 -0
- package/dist/src/theme/components/Input.js +29 -0
- package/dist/src/theme/elevation.d.ts +2 -0
- package/dist/src/theme/elevation.js +47 -0
- package/dist/src/theme/icons.d.ts +2 -0
- package/dist/src/theme/icons.js +16 -0
- package/dist/src/theme/index.d.ts +4 -0
- package/dist/src/theme/index.js +58 -0
- package/dist/src/theme/spacing.d.ts +2 -0
- package/dist/src/theme/spacing.js +14 -0
- package/dist/src/theme/types.d.ts +236 -0
- package/dist/src/theme/types.js +2 -0
- package/dist/src/theme/typography.d.ts +2 -0
- package/dist/src/theme/typography.js +95 -0
- package/dist/src/theme/utils.d.ts +3 -0
- package/dist/src/theme/utils.js +28 -0
- package/dist/src/utils/consoleFunc.d.ts +1 -0
- package/dist/src/utils/consoleFunc.js +7 -0
- package/dist/src/utils/delayApis.d.ts +1 -0
- package/dist/src/utils/delayApis.js +5 -0
- package/dist/src/utils/faqData.d.ts +8 -0
- package/dist/src/utils/faqData.js +65 -0
- package/dist/src/utils/formatDate.d.ts +2 -0
- package/dist/src/utils/formatDate.js +24 -0
- package/dist/src/utils/getBorderStyle.d.ts +4 -0
- package/dist/src/utils/getBorderStyle.js +11 -0
- package/dist/src/utils/offlineHelper.d.ts +19 -0
- package/dist/src/utils/offlineHelper.js +109 -0
- package/dist/src/utils/queryString.d.ts +1 -0
- package/dist/src/utils/queryString.js +16 -0
- package/dist/src/utils/toastHelpers.d.ts +5 -0
- package/dist/src/utils/toastHelpers.js +39 -0
- package/index.ts +29 -0
- package/oneticket-sdk-vi-1.0.0.tgz +0 -0
- package/package.json +43 -0
- package/src/assets/fonts/SpaceMono-Regular.ttf +0 -0
- package/src/assets/icons/BackIcon.tsx +27 -0
- package/src/assets/icons/BellIcon.tsx +29 -0
- package/src/assets/icons/BusIcon.tsx +20 -0
- package/src/assets/icons/CalendarIcon.tsx +20 -0
- package/src/assets/icons/ChangeIcon.tsx +61 -0
- package/src/assets/icons/ChatIcon.tsx +25 -0
- package/src/assets/icons/ChevronDownIcon.tsx +26 -0
- package/src/assets/icons/ChevronLeftIcon.tsx +26 -0
- package/src/assets/icons/ChevronRightIcon.tsx +26 -0
- package/src/assets/icons/ChevronUpIcon.tsx +26 -0
- package/src/assets/icons/CloseIcon.tsx +20 -0
- package/src/assets/icons/DeleteIcon.tsx +20 -0
- package/src/assets/icons/ErrorIcon.tsx +20 -0
- package/src/assets/icons/FAQIcon.tsx +20 -0
- package/src/assets/icons/FilterIcon.tsx +27 -0
- package/src/assets/icons/HamburgerIcon.tsx +33 -0
- package/src/assets/icons/HelpIcon.tsx +29 -0
- package/src/assets/icons/HistoryIcon.tsx +20 -0
- package/src/assets/icons/Home.tsx +30 -0
- package/src/assets/icons/HomeIcon.tsx +24 -0
- package/src/assets/icons/InfoIcon.tsx +29 -0
- package/src/assets/icons/IssueIcon.tsx +32 -0
- package/src/assets/icons/LocationIcon.tsx +38 -0
- package/src/assets/icons/LogoutIcon.tsx +20 -0
- package/src/assets/icons/MailIcon.tsx +20 -0
- package/src/assets/icons/MetroIcon.tsx +20 -0
- package/src/assets/icons/MinusIcon.tsx +27 -0
- package/src/assets/icons/PhoneIcon.tsx +22 -0
- package/src/assets/icons/PlusIcon.tsx +29 -0
- package/src/assets/icons/RefreshIcon.tsx +29 -0
- package/src/assets/icons/RightArrowIcon.tsx +29 -0
- package/src/assets/icons/SearchIcon.tsx +20 -0
- package/src/assets/icons/SendIcon.tsx +25 -0
- package/src/assets/icons/ShareIcon.tsx +22 -0
- package/src/assets/icons/SuccessIcon.tsx +20 -0
- package/src/assets/icons/SwapIcon.tsx +20 -0
- package/src/assets/icons/TickIcon.tsx +20 -0
- package/src/assets/icons/UserIcon.tsx +25 -0
- package/src/assets/icons/WalkIcon.tsx +20 -0
- package/src/assets/images/AgraMetroLogo.tsx +23 -0
- package/src/assets/images/AhmedabadMetroLogo.tsx +23 -0
- package/src/assets/images/BengaluruMetroLogo.tsx +32 -0
- package/src/assets/images/ChennaiMetroLogo.tsx +34 -0
- package/src/assets/images/DelhiMetroLogo.tsx +23 -0
- package/src/assets/images/HyderabadMetroLogo.tsx +122 -0
- package/src/assets/images/JaipurMetroLogo.tsx +21 -0
- package/src/assets/images/KanpurMetroLogo.tsx +22 -0
- package/src/assets/images/KochiMetroLogo.tsx +23 -0
- package/src/assets/images/KolkataMetroLogo.tsx +23 -0
- package/src/assets/images/LucknowMetroLogo.tsx +22 -0
- package/src/assets/images/MMO-Flow-logo.png +0 -0
- package/src/assets/images/MMOLogo.tsx +0 -0
- package/src/assets/images/MumbaiMetroLogo.tsx +31 -0
- package/src/assets/images/NagpurMetroLogo.tsx +35 -0
- package/src/assets/images/NaviMumbaiMetroLogo.tsx +23 -0
- package/src/assets/images/NoData.png +0 -0
- package/src/assets/images/NoDataNewTheme.png +0 -0
- package/src/assets/images/OneTicketLogo.png +0 -0
- package/src/assets/images/OneTicketLogoBlue.png +0 -0
- package/src/assets/images/OneTicketNameLogo.png +0 -0
- package/src/assets/images/OneTicketNameLogoBlue.png +0 -0
- package/src/assets/images/OneTicketNewBlueLogo.png +0 -0
- package/src/assets/images/OneTicketShortBoxLogo.png +0 -0
- package/src/assets/images/OneTicketShortLogo.png +0 -0
- package/src/assets/images/PuneMetroLogo.tsx +53 -0
- package/src/assets/images/SplashScreen.png +0 -0
- package/src/assets/images/adaptive-icon.png +0 -0
- package/src/assets/images/bengaluru_metro_logo.png +0 -0
- package/src/assets/images/bengaluru_metro_logo.svg +15 -0
- package/src/assets/images/bus.png +0 -0
- package/src/assets/images/bus.svg +20 -0
- package/src/assets/images/car.png +0 -0
- package/src/assets/images/car.svg +10 -0
- package/src/assets/images/chennai_metro_logo.png +0 -0
- package/src/assets/images/chennai_metro_logo.svg +5 -0
- package/src/assets/images/company-short-logo.png +0 -0
- package/src/assets/images/company-short-logo.svg +18 -0
- package/src/assets/images/completed.gif +0 -0
- package/src/assets/images/completed.json +1 -0
- package/src/assets/images/delhi_metro_logo.png +0 -0
- package/src/assets/images/delhi_metro_logo.svg +13 -0
- package/src/assets/images/failed.json +1 -0
- package/src/assets/images/favicon.png +0 -0
- package/src/assets/images/google-pay.png +0 -0
- package/src/assets/images/hyderabad_metro_logo.png +0 -0
- package/src/assets/images/hyderabad_metro_logo.svg +35 -0
- package/src/assets/images/icon.png +0 -0
- package/src/assets/images/kochi_metro_logo.png +0 -0
- package/src/assets/images/kochi_metro_logo.svg +7 -0
- package/src/assets/images/mastercard.png +0 -0
- package/src/assets/images/metro.png +0 -0
- package/src/assets/images/metro.svg +11 -0
- package/src/assets/images/mitra_logo.png +0 -0
- package/src/assets/images/mumbai_metro_line_1_logo.png +0 -0
- package/src/assets/images/mumbai_metro_line_1_logo.svg +15 -0
- package/src/assets/images/ondc_logo.png +0 -0
- package/src/assets/images/ondc_network_vertical.png +0 -0
- package/src/assets/images/partial-react-logo.png +0 -0
- package/src/assets/images/paypal.png +0 -0
- package/src/assets/images/phonepay.png +0 -0
- package/src/assets/images/poweredByLogo.png +0 -0
- package/src/assets/images/random_qr.png +0 -0
- package/src/assets/images/react-logo.png +0 -0
- package/src/assets/images/react-logo@2x.png +0 -0
- package/src/assets/images/react-logo@3x.png +0 -0
- package/src/assets/images/return_journey.png +0 -0
- package/src/assets/images/return_journey.svg +8 -0
- package/src/assets/images/sequelstring_logo.png +0 -0
- package/src/assets/images/shareAppQR.png +0 -0
- package/src/assets/images/short-logo.png +0 -0
- package/src/assets/images/short-logo.svg +66 -0
- package/src/assets/images/single_journey.png +0 -0
- package/src/assets/images/single_journey.svg +12 -0
- package/src/assets/images/spinner.svg +71 -0
- package/src/assets/images/splash.png +0 -0
- package/src/assets/images/trip_pass.png +0 -0
- package/src/assets/images/trip_pass.svg +10 -0
- package/src/assets/images/update.json +1 -0
- package/src/assets/images/visa.png +0 -0
- package/src/components/authGuard/AuthGuard.tsx +41 -0
- package/src/components/common/AdBanner/AdBanner.tsx +44 -0
- package/src/components/common/Avatar/Avatar.tsx +99 -0
- package/src/components/common/Badge/Badge.tsx +68 -0
- package/src/components/common/Button/Button.tsx +149 -0
- package/src/components/common/Cards/IssueCard.tsx +108 -0
- package/src/components/common/Cards/RecentCard.tsx +102 -0
- package/src/components/common/Cards/TransactionCard.tsx +122 -0
- package/src/components/common/Cards/TransportationCard.tsx +119 -0
- package/src/components/common/Cards/TypeCard.tsx +95 -0
- package/src/components/common/Checkbox/Checkbox.tsx +50 -0
- package/src/components/common/CustomInput/CustomInput.tsx +523 -0
- package/src/components/common/DropdownComponent/DropdownComponent.tsx +189 -0
- package/src/components/common/DropdownComponent/MultiSelectDropdown.tsx +180 -0
- package/src/components/common/EmptyState/EmptyState.tsx +48 -0
- package/src/components/common/Header/Header.tsx +238 -0
- package/src/components/common/Input/Input.tsx +134 -0
- package/src/components/common/Loaders/FooterComponentFlatList.tsx +13 -0
- package/src/components/common/Loaders/FullScreenLoader.tsx +135 -0
- package/src/components/common/Loaders/Loader.tsx +86 -0
- package/src/components/common/Modals/CancellationModal.tsx +268 -0
- package/src/components/common/Modals/IssueCategoryData.tsx +26 -0
- package/src/components/common/Popup/ForceUpdatePopup.tsx +103 -0
- package/src/components/common/PoweredBy/PoweredBy.tsx +59 -0
- package/src/components/common/QRCodeGenerator/QRCodeGenerator.tsx +372 -0
- package/src/components/common/SplashScreen/SplashScreen.tsx +38 -0
- package/src/components/common/Tabs/Tabs2.tsx +165 -0
- package/src/components/common/Text/CustomText.tsx +82 -0
- package/src/components/common/Toast/CustomToast.tsx +115 -0
- package/src/components/ticketDetail/BillingDetailsSection.tsx +129 -0
- package/src/components/ticketDetail/QRCodeSection.tsx +152 -0
- package/src/components/ticketDetail/RouteSection.tsx +252 -0
- package/src/components/ticketDetail/TicketDetailSection.tsx +98 -0
- package/src/helper/getProviders.ts +58 -0
- package/src/helper/itemsLowestFare.ts +16 -0
- package/src/hooks/useSessionTracker.ts +42 -0
- package/src/navigation/AuthStack.tsx +72 -0
- package/src/navigation/BaseStack.tsx +74 -0
- package/src/navigation/UnAuthStack.tsx +40 -0
- package/src/navigation/metro/HistoryStack.tsx +34 -0
- package/src/navigation/metro/IssueStack.tsx +29 -0
- package/src/navigation/metro/MetroStack.tsx +110 -0
- package/src/navigation/metro/MetroTabs.tsx +99 -0
- package/src/navigation/metro/MetroWithTabsStack.tsx +42 -0
- package/src/navigation/metro/ProfileStack.tsx +37 -0
- package/src/screens/auth/DetailsScreen.tsx +129 -0
- package/src/screens/auth/LogInScreen.tsx +165 -0
- package/src/screens/auth/OTPScreen.tsx +231 -0
- package/src/screens/auth/SignUpScreen.tsx +184 -0
- package/src/screens/auth/SuccessScreen.tsx +91 -0
- package/src/screens/common/Faq/Components/CategoryButton.tsx +70 -0
- package/src/screens/common/Faq/FaqScreen.tsx +215 -0
- package/src/screens/common/MyAccountScreen.tsx +224 -0
- package/src/screens/common/Profile/Components/MenuItem.tsx +96 -0
- package/src/screens/common/Profile/ProfileScreen.tsx +269 -0
- package/src/screens/metro/BuyTicket/BuyTicketScreen.tsx +417 -0
- package/src/screens/metro/ChooseStation/ChooseStation.tsx +26 -0
- package/src/screens/metro/ChooseStation/ChooseStationContext.tsx +31 -0
- package/src/screens/metro/ChooseStation/Components/Search.tsx +75 -0
- package/src/screens/metro/ChooseStation/Components/StationList.tsx +131 -0
- package/src/screens/metro/ChooseStation/types.ts +0 -0
- package/src/screens/metro/ChooseTicketTypeScreen.tsx +129 -0
- package/src/screens/metro/HistoryScreen.tsx +348 -0
- package/src/screens/metro/IssueChatScreen.tsx +156 -0
- package/src/screens/metro/IssueDetailsScreen.tsx +272 -0
- package/src/screens/metro/IssuesScreen.tsx +130 -0
- package/src/screens/metro/MetroSelectionScreen.tsx +86 -0
- package/src/screens/metro/RaiseIssueScreen.tsx +394 -0
- package/src/screens/metro/RecentTransactionScreen.tsx +111 -0
- package/src/screens/metro/SelectStations/Components/FooterButton.tsx +48 -0
- package/src/screens/metro/SelectStations/Components/RecentTransactions.tsx +81 -0
- package/src/screens/metro/SelectStations/Components/ToAndFromStations.tsx +147 -0
- package/src/screens/metro/SelectStations/SelectStationContext.tsx +82 -0
- package/src/screens/metro/SelectStations/SelectStations.tsx +85 -0
- package/src/screens/metro/SelectStations/types.ts +0 -0
- package/src/screens/metro/TicketDetailsScreen.tsx +326 -0
- package/src/screens/metro/TransportationSelectionScreen.tsx +102 -0
- package/src/services/apiCall.ts +29 -0
- package/src/services/apiRoutes.ts +74 -0
- package/src/services/apis/appVersion/apis.ts +9 -0
- package/src/services/apis/appVersion/hooks.ts +17 -0
- package/src/services/apis/appVersion/types.ts +19 -0
- package/src/services/apis/auth/apis.ts +50 -0
- package/src/services/apis/auth/hooks.ts +173 -0
- package/src/services/apis/auth/types.ts +100 -0
- package/src/services/apis/city/apis.ts +28 -0
- package/src/services/apis/city/hooks.ts +61 -0
- package/src/services/apis/city/types.ts +62 -0
- package/src/services/apis/metro/cancelTicket/apis.ts +16 -0
- package/src/services/apis/metro/cancelTicket/hooks.ts +42 -0
- package/src/services/apis/metro/cancelTicket/types.ts +21 -0
- package/src/services/apis/metro/confirmTicket/apis.ts +8 -0
- package/src/services/apis/metro/confirmTicket/hooks.ts +22 -0
- package/src/services/apis/metro/confirmTicket/types.ts +8 -0
- package/src/services/apis/metro/fare/apis.ts +9 -0
- package/src/services/apis/metro/fare/hooks.ts +18 -0
- package/src/services/apis/metro/fare/types.ts +27 -0
- package/src/services/apis/metro/issue/apis.ts +47 -0
- package/src/services/apis/metro/issue/hooks.ts +99 -0
- package/src/services/apis/metro/issue/types.ts +108 -0
- package/src/services/apis/metro/payment/apis.ts +21 -0
- package/src/services/apis/metro/payment/hooks.ts +65 -0
- package/src/services/apis/metro/payment/types.ts +42 -0
- package/src/services/apis/metro/providers/apis.ts +15 -0
- package/src/services/apis/metro/providers/hooks.ts +31 -0
- package/src/services/apis/metro/providers/types.ts +28 -0
- package/src/services/apis/metro/stations/apis.ts +18 -0
- package/src/services/apis/metro/stations/hooks.ts +27 -0
- package/src/services/apis/metro/stations/types.ts +34 -0
- package/src/services/apis/metro/status/apis.ts +15 -0
- package/src/services/apis/metro/status/hooks.ts +19 -0
- package/src/services/apis/metro/status/types.ts +55 -0
- package/src/services/apis/metro/ticketInit/apis.ts +9 -0
- package/src/services/apis/metro/ticketInit/hooks.ts +23 -0
- package/src/services/apis/metro/ticketInit/types.ts +25 -0
- package/src/services/apis/session/apis.ts +15 -0
- package/src/services/apis/session/hooks.ts +42 -0
- package/src/services/apis/session/types.ts +17 -0
- package/src/services/apis/transaction/apis.ts +17 -0
- package/src/services/apis/transaction/hooks.ts +29 -0
- package/src/services/apis/transaction/types.ts +42 -0
- package/src/services/apis/user/apis.ts +9 -0
- package/src/services/apis/user/hooks.ts +18 -0
- package/src/services/apis/user/types.ts +10 -0
- package/src/theme/ThemeProvider.tsx +62 -0
- package/src/theme/ThemeToggle.tsx +42 -0
- package/src/theme/WithSplashScreen.tsx +167 -0
- package/src/theme/animations.ts +9 -0
- package/src/theme/colors.ts +237 -0
- package/src/theme/components/Badge.ts +28 -0
- package/src/theme/components/Button.ts +99 -0
- package/src/theme/components/Card.ts +22 -0
- package/src/theme/components/Chip.ts +27 -0
- package/src/theme/components/Input.ts +28 -0
- package/src/theme/elevation.ts +47 -0
- package/src/theme/icons.ts +15 -0
- package/src/theme/index.ts +60 -0
- package/src/theme/spacing.ts +13 -0
- package/src/theme/types.ts +256 -0
- package/src/theme/typography.ts +95 -0
- package/src/theme/utils.ts +32 -0
- package/src/utils/consoleFunc.ts +3 -0
- package/src/utils/delayApis.ts +1 -0
- package/src/utils/faqData.ts +69 -0
- package/src/utils/formatDate.ts +20 -0
- package/src/utils/getBorderStyle.ts +11 -0
- package/src/utils/mmmoclQr.js +5 -0
- package/src/utils/offlineHelper.ts +72 -0
- package/src/utils/queryString.ts +12 -0
- package/src/utils/toastHelpers.ts +34 -0
- package/tsconfig.json +14 -0
@@ -0,0 +1,213 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
const react_1 = __importStar(require("react"));
|
30
|
+
const react_native_1 = require("react-native");
|
31
|
+
const native_1 = require("@react-navigation/native");
|
32
|
+
const Header_1 = __importDefault(require("../../components/common/Header/Header"));
|
33
|
+
const hooks_1 = require("../../services/apis/metro/issue/hooks");
|
34
|
+
const MetroStack_1 = require("../../navigation/metro/MetroStack");
|
35
|
+
const MetroTabs_1 = require("../../navigation/metro/MetroTabs");
|
36
|
+
const ChatIcon_1 = __importDefault(require("../../assets/icons/ChatIcon"));
|
37
|
+
const Badge_1 = __importDefault(require("../../components/common/Badge/Badge"));
|
38
|
+
const ThemeProvider_1 = require("../../theme/ThemeProvider");
|
39
|
+
const react_native_size_matters_1 = require("react-native-size-matters");
|
40
|
+
const Button_1 = require("../../components/common/Button/Button");
|
41
|
+
const CustomText_1 = require("../../components/common/Text/CustomText");
|
42
|
+
const IssueDetailsScreen = () => {
|
43
|
+
var _a, _b;
|
44
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
45
|
+
const { navigate, goBack } = (0, native_1.useNavigation)();
|
46
|
+
const [showIssueCloseModal, setShowIssueCloseModal] = (0, react_1.useState)(false);
|
47
|
+
const { params: { transaction_id } } = (0, native_1.useRoute)();
|
48
|
+
const { data: issueDetails, isLoading: issueDetailsLoading } = (0, hooks_1.useFetchGetMetroIssueDetails)({ transaction_id });
|
49
|
+
const { mutateAsync: closeIssue, isPending: closeIssueLoading } = (0, hooks_1.useMutateCloseIssue)(() => { });
|
50
|
+
const handleCloseIssue = (rating) => {
|
51
|
+
closeIssue({ transaction_id, rating });
|
52
|
+
setShowIssueCloseModal(false);
|
53
|
+
};
|
54
|
+
(0, native_1.useFocusEffect)((0, react_1.useCallback)(() => {
|
55
|
+
const onBackPress = () => {
|
56
|
+
navigate(MetroStack_1.MetroScreens.MetroTabs, {
|
57
|
+
screen: MetroTabs_1.MetroTabScreens.IssuesStack,
|
58
|
+
});
|
59
|
+
return true;
|
60
|
+
};
|
61
|
+
const subscription = react_native_1.BackHandler.addEventListener('hardwareBackPress', onBackPress);
|
62
|
+
return () => {
|
63
|
+
var _a;
|
64
|
+
if (typeof (subscription === null || subscription === void 0 ? void 0 : subscription.remove) === 'function') {
|
65
|
+
subscription.remove(); // ✅ RN 0.72+
|
66
|
+
}
|
67
|
+
else {
|
68
|
+
(_a = react_native_1.BackHandler.removeEventListener) === null || _a === void 0 ? void 0 : _a.call(react_native_1.BackHandler, 'hardwareBackPress', onBackPress); // ✅ fallback for RN < 0.72
|
69
|
+
}
|
70
|
+
};
|
71
|
+
}, [navigate]));
|
72
|
+
const getStatusVariant = (status) => {
|
73
|
+
switch (status) {
|
74
|
+
case 'CLOSED': return 'success';
|
75
|
+
case 'OPEN': return 'warning';
|
76
|
+
case 'RESOLVED': return 'info';
|
77
|
+
default: return 'primary';
|
78
|
+
}
|
79
|
+
};
|
80
|
+
const styles = react_native_1.StyleSheet.create({
|
81
|
+
container: {
|
82
|
+
flex: 1,
|
83
|
+
backgroundColor: theme.colors.backdrop,
|
84
|
+
},
|
85
|
+
contentContainer: {
|
86
|
+
padding: (0, react_native_size_matters_1.ms)(theme.spacing.m),
|
87
|
+
},
|
88
|
+
issueCard: {
|
89
|
+
marginVertical: (0, react_native_size_matters_1.mvs)(12),
|
90
|
+
padding: (0, react_native_size_matters_1.ms)(12),
|
91
|
+
backgroundColor: theme.colors.background,
|
92
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
93
|
+
shadowColor: theme.colors.shadow,
|
94
|
+
shadowOffset: { width: 0, height: 2 },
|
95
|
+
shadowOpacity: 0.1,
|
96
|
+
shadowRadius: 4,
|
97
|
+
elevation: 2,
|
98
|
+
},
|
99
|
+
title: {
|
100
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(theme.spacing.s),
|
101
|
+
},
|
102
|
+
description: {
|
103
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(12),
|
104
|
+
},
|
105
|
+
divider: {
|
106
|
+
height: 1,
|
107
|
+
backgroundColor: theme.colors.gray[300],
|
108
|
+
marginVertical: (0, react_native_size_matters_1.mvs)(theme.spacing.s),
|
109
|
+
},
|
110
|
+
sectionTitle: {
|
111
|
+
fontWeight: '800',
|
112
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(theme.spacing.xs),
|
113
|
+
},
|
114
|
+
row: {
|
115
|
+
flexDirection: 'row',
|
116
|
+
justifyContent: 'space-between',
|
117
|
+
alignItems: 'center',
|
118
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(theme.spacing.s),
|
119
|
+
},
|
120
|
+
stationRow: {
|
121
|
+
flexDirection: 'row',
|
122
|
+
justifyContent: 'space-between',
|
123
|
+
alignItems: 'center',
|
124
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(12),
|
125
|
+
},
|
126
|
+
stationText: {
|
127
|
+
flex: 1,
|
128
|
+
fontWeight: '800'
|
129
|
+
},
|
130
|
+
closeButtonText: {
|
131
|
+
fontSize: (0, react_native_size_matters_1.ms)(16),
|
132
|
+
fontWeight: '500',
|
133
|
+
color: theme.colors.white,
|
134
|
+
},
|
135
|
+
modalContainer: {
|
136
|
+
flex: 1,
|
137
|
+
justifyContent: 'center',
|
138
|
+
alignItems: 'center',
|
139
|
+
backgroundColor: 'rgba(0,0,0,0.7)',
|
140
|
+
},
|
141
|
+
modalContent: {
|
142
|
+
width: '90%',
|
143
|
+
borderRadius: (0, react_native_size_matters_1.ms)(16),
|
144
|
+
padding: (0, react_native_size_matters_1.ms)(16),
|
145
|
+
elevation: 10,
|
146
|
+
},
|
147
|
+
modalTitle: {
|
148
|
+
fontWeight: 'bold',
|
149
|
+
fontSize: (0, react_native_size_matters_1.ms)(18),
|
150
|
+
textAlign: 'center',
|
151
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(24),
|
152
|
+
},
|
153
|
+
buttonRow: {
|
154
|
+
flexDirection: 'row',
|
155
|
+
justifyContent: 'space-between',
|
156
|
+
gap: (0, react_native_size_matters_1.ms)(10),
|
157
|
+
},
|
158
|
+
buttonText: {
|
159
|
+
color: theme.colors.white,
|
160
|
+
fontWeight: '500',
|
161
|
+
},
|
162
|
+
});
|
163
|
+
const renderIssueItem = ({ item }) => {
|
164
|
+
var _a;
|
165
|
+
return (react_1.default.createElement(react_native_1.View, { style: styles.issueCard },
|
166
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'heading2', style: styles.title }, item.short_desc || 'N/A'),
|
167
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: styles.description }, item.long_desc || 'No description available'),
|
168
|
+
react_1.default.createElement(react_native_1.View, { style: styles.divider }),
|
169
|
+
react_1.default.createElement(react_native_1.View, null,
|
170
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: styles.sectionTitle }, "Response"),
|
171
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body2', style: styles.description }, item.status === "RESOLVED"
|
172
|
+
? "Your issue is resolved, you can close the issue"
|
173
|
+
: item.status === "CLOSED"
|
174
|
+
? "Your issue is closed"
|
175
|
+
: "Your issue is in progress.")),
|
176
|
+
react_1.default.createElement(react_native_1.View, { style: styles.divider }),
|
177
|
+
react_1.default.createElement(react_native_1.View, { style: styles.stationRow },
|
178
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: styles.stationText },
|
179
|
+
item.startStationName,
|
180
|
+
" - ",
|
181
|
+
item.destinationStationName),
|
182
|
+
react_1.default.createElement(Button_1.Button, { size: 'sm', variant: 'text', onPress: () => navigate(MetroStack_1.MetroScreens.IssueChat, { issueId: item.issueId }) },
|
183
|
+
react_1.default.createElement(ChatIcon_1.default, { color: theme.colors.primary[500], size: 22 }))),
|
184
|
+
react_1.default.createElement(react_native_1.View, { style: styles.row },
|
185
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: { fontWeight: '500' } }, "Issue ID:"),
|
186
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1' }, item.issue_id)),
|
187
|
+
react_1.default.createElement(react_native_1.View, { style: styles.row },
|
188
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: { fontWeight: '500' } }, "Issue Category:"),
|
189
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1' }, ((_a = item.category) === null || _a === void 0 ? void 0 : _a.label) || 'N/A')),
|
190
|
+
react_1.default.createElement(react_native_1.View, { style: Object.assign(Object.assign({}, styles.row), { alignItems: 'flex-start' }) },
|
191
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: { fontWeight: '500', flex: 1.5 } }, "Issue Sub-category:"),
|
192
|
+
react_1.default.createElement(CustomText_1.CustomText, { style: { flex: 2, textAlign: 'right' } }, item.sub_category.value || 'N/A')),
|
193
|
+
react_1.default.createElement(react_native_1.View, { style: styles.row },
|
194
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: 'body1', style: { fontWeight: '500' } }, "Status:"),
|
195
|
+
react_1.default.createElement(Badge_1.default, { text: item.status, variant: getStatusVariant(item.status), size: "md" }))));
|
196
|
+
};
|
197
|
+
return (react_1.default.createElement(react_native_1.View, { style: styles.container },
|
198
|
+
react_1.default.createElement(Header_1.default, { showBackButton: true, onBackPress: () => navigate(MetroStack_1.MetroScreens.MetroTabs, {
|
199
|
+
screen: MetroTabs_1.MetroTabScreens.IssuesStack
|
200
|
+
}), title: "Issue Detail" }),
|
201
|
+
react_1.default.createElement(react_native_1.FlatList, { data: (issueDetails === null || issueDetails === void 0 ? void 0 : issueDetails.issue) || [], keyExtractor: (item, index) => `issue-${index}`, contentContainerStyle: styles.contentContainer, renderItem: renderIssueItem }),
|
202
|
+
((_b = (_a = issueDetails === null || issueDetails === void 0 ? void 0 : issueDetails.issue) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.status) !== "CLOSED" && (react_1.default.createElement(Button_1.Button, { size: 'md', onPress: () => setShowIssueCloseModal(true), disabled: closeIssueLoading || !(issueDetails === null || issueDetails === void 0 ? void 0 : issueDetails.issue), style: { margin: (0, react_native_size_matters_1.ms)(16) }, textStyle: { fontSize: (0, react_native_size_matters_1.ms)(16) }, children: 'Close Issue' })),
|
203
|
+
react_1.default.createElement(react_native_1.Modal, { visible: showIssueCloseModal, transparent: true, animationType: "fade", onRequestClose: () => setShowIssueCloseModal(false) },
|
204
|
+
react_1.default.createElement(react_native_1.View, { style: styles.modalContainer },
|
205
|
+
react_1.default.createElement(react_native_1.View, { style: [styles.modalContent, { backgroundColor: theme.colors.backdrop, shadowColor: theme.colors.shadow }] },
|
206
|
+
react_1.default.createElement(CustomText_1.CustomText, { style: styles.modalTitle }, "Give the rating on your issue resolve process"),
|
207
|
+
react_1.default.createElement(react_native_1.View, { style: styles.buttonRow },
|
208
|
+
react_1.default.createElement(Button_1.Button, { size: 'sm', style: { flex: 1 }, onPress: () => handleCloseIssue("THUMBS-UP") },
|
209
|
+
react_1.default.createElement(react_native_1.Text, { style: styles.buttonText }, "Great")),
|
210
|
+
react_1.default.createElement(Button_1.Button, { size: 'sm', style: { flex: 1, backgroundColor: theme.colors.error[500] }, onPress: () => handleCloseIssue("THUMBS-DOWN") },
|
211
|
+
react_1.default.createElement(react_native_1.Text, { style: styles.buttonText }, "Average"))))))));
|
212
|
+
};
|
213
|
+
exports.default = IssueDetailsScreen;
|
@@ -0,0 +1,98 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
const react_1 = __importStar(require("react"));
|
30
|
+
const react_native_1 = require("react-native");
|
31
|
+
const native_1 = require("@react-navigation/native");
|
32
|
+
const Header_1 = __importDefault(require("../../components/common/Header/Header"));
|
33
|
+
const IssueCard_1 = __importDefault(require("../../components/common/Cards/IssueCard"));
|
34
|
+
const MetroStack_1 = require("../../navigation/metro/MetroStack");
|
35
|
+
const hooks_1 = require("../../services/apis/metro/issue/hooks");
|
36
|
+
const Loader_1 = __importDefault(require("../../components/common/Loaders/Loader"));
|
37
|
+
const FooterComponentFlatList_1 = __importDefault(require("../../components/common/Loaders/FooterComponentFlatList"));
|
38
|
+
const formatDate_1 = require("../../utils/formatDate");
|
39
|
+
const ThemeProvider_1 = require("../../theme/ThemeProvider");
|
40
|
+
const react_native_size_matters_1 = require("react-native-size-matters");
|
41
|
+
const EmptyState_1 = __importDefault(require("../../components/common/EmptyState/EmptyState"));
|
42
|
+
const Tabs2_1 = __importDefault(require("../../components/common/Tabs/Tabs2"));
|
43
|
+
const IssuesScreen = () => {
|
44
|
+
var _a, _b;
|
45
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
46
|
+
const { navigate } = (0, native_1.useNavigation)();
|
47
|
+
const [selectedTab, setSelectedTab] = (0, react_1.useState)('');
|
48
|
+
const { data: allIssues, isLoading: allIssuesLoading, fetchNextPage, isFetchingNextPage, refetch, isRefetching } = (0, hooks_1.useFetchGetAllMetroIssues)({ status: selectedTab });
|
49
|
+
const allIssuesData = ((_b = (_a = allIssues === null || allIssues === void 0 ? void 0 : allIssues.pages) === null || _a === void 0 ? void 0 : _a.map(page => (page === null || page === void 0 ? void 0 : page.allIssues) || [])) === null || _b === void 0 ? void 0 : _b.flat()) || [];
|
50
|
+
const sortedIssuesData = allIssuesData.sort((a, b) => {
|
51
|
+
const dateA = new Date(a.createdAt).getTime();
|
52
|
+
const dateB = new Date(b.createdAt).getTime();
|
53
|
+
return dateB - dateA; // Newest on top
|
54
|
+
});
|
55
|
+
const styles = react_native_1.StyleSheet.create({
|
56
|
+
container: {
|
57
|
+
flex: 1,
|
58
|
+
backgroundColor: theme.colors.background,
|
59
|
+
},
|
60
|
+
contentContainer: {
|
61
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(theme.spacing.m),
|
62
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(theme.spacing.m),
|
63
|
+
},
|
64
|
+
emptyContainer: {
|
65
|
+
alignItems: 'center',
|
66
|
+
justifyContent: 'center',
|
67
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(theme.spacing.xl),
|
68
|
+
},
|
69
|
+
emptyImage: {
|
70
|
+
width: (0, react_native_size_matters_1.ms)(300),
|
71
|
+
height: (0, react_native_size_matters_1.mvs)(250),
|
72
|
+
alignSelf: 'center',
|
73
|
+
},
|
74
|
+
emptyText: {
|
75
|
+
fontSize: (0, react_native_size_matters_1.ms)(16),
|
76
|
+
color: theme.colors.primary[500],
|
77
|
+
fontWeight: '600',
|
78
|
+
marginTop: (0, react_native_size_matters_1.mvs)(theme.spacing.m),
|
79
|
+
},
|
80
|
+
listContainer: {
|
81
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(theme.spacing.m),
|
82
|
+
},
|
83
|
+
});
|
84
|
+
return (react_1.default.createElement(react_native_1.View, { style: styles.container },
|
85
|
+
react_1.default.createElement(Header_1.default, { showBackButton: true, showHomeButton: false, title: "Issues" }),
|
86
|
+
react_1.default.createElement(react_native_1.View, { style: styles.contentContainer },
|
87
|
+
react_1.default.createElement(Tabs2_1.default, { tabs: [
|
88
|
+
{ id: '', title: 'All' },
|
89
|
+
{ id: 'OPEN', title: 'Open' },
|
90
|
+
{ id: 'CLOSED', title: 'Closed' },
|
91
|
+
], activeTab: selectedTab, onChange: setSelectedTab })),
|
92
|
+
allIssuesLoading ? (react_1.default.createElement(Loader_1.default, null)) : (react_1.default.createElement(react_native_1.FlatList, { data: sortedIssuesData, ListEmptyComponent: react_1.default.createElement(EmptyState_1.default
|
93
|
+
// image={require('../../assets/images/NoData.png')}
|
94
|
+
, {
|
95
|
+
// image={require('../../assets/images/NoData.png')}
|
96
|
+
image: require('../../assets/images/NoDataNewTheme.png'), title: "No Issues" }), style: styles.listContainer, renderItem: ({ item }) => (react_1.default.createElement(IssueCard_1.default, { date: (0, formatDate_1.formatDateWithTime)(item.createdAt), onPress: () => navigate(MetroStack_1.MetroScreens.IssueDetails, { transaction_id: item._id }), status: item.status, startStation: item.startStation, destinationStation: item.destinationStation, issueCount: item.issueCount })), onEndReachedThreshold: 0.1, onEndReached: () => fetchNextPage(), ListFooterComponent: react_1.default.createElement(FooterComponentFlatList_1.default, { isFetchingNextPage: isFetchingNextPage }), refreshControl: react_1.default.createElement(react_native_1.RefreshControl, { refreshing: isRefetching, onRefresh: refetch, colors: [theme.colors.primary[500]], tintColor: theme.colors.primary[500] }) }))));
|
97
|
+
};
|
98
|
+
exports.default = IssuesScreen;
|
@@ -0,0 +1,58 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
const react_1 = __importDefault(require("react"));
|
7
|
+
const react_native_1 = require("react-native");
|
8
|
+
const native_1 = require("@react-navigation/native");
|
9
|
+
const ThemeProvider_1 = require("../../theme/ThemeProvider");
|
10
|
+
const react_native_size_matters_1 = require("react-native-size-matters");
|
11
|
+
const Header_1 = __importDefault(require("../../components/common/Header/Header"));
|
12
|
+
const FullScreenLoader_1 = __importDefault(require("../../components/common/Loaders/FullScreenLoader"));
|
13
|
+
const hooks_1 = require("../../services/apis/city/hooks");
|
14
|
+
const MetroTabs_1 = require("../../navigation/metro/MetroTabs");
|
15
|
+
const MetroStack_1 = require("../../navigation/metro/MetroStack");
|
16
|
+
const MetroWithTabsStack_1 = require("../../navigation/metro/MetroWithTabsStack");
|
17
|
+
const TransportationCard_1 = __importDefault(require("../../components/common/Cards/TransportationCard"));
|
18
|
+
const PoweredBy_1 = __importDefault(require("../../components/common/PoweredBy/PoweredBy"));
|
19
|
+
const MetroSelectionScreen = () => {
|
20
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
21
|
+
const { navigate } = (0, native_1.useNavigation)();
|
22
|
+
const { mutateAsync: selectCity, isPending: selectCityLoading } = (0, hooks_1.useMutateSelectCity)(data => {
|
23
|
+
if (data.status === 'success') {
|
24
|
+
navigate(MetroStack_1.MetroScreens.MetroTabs, {
|
25
|
+
screen: MetroTabs_1.MetroTabScreens.MetroWithTabsStack,
|
26
|
+
params: {
|
27
|
+
screen: MetroWithTabsStack_1.MetroWithTabsScreens.SelectStations,
|
28
|
+
params: {}
|
29
|
+
}
|
30
|
+
});
|
31
|
+
}
|
32
|
+
});
|
33
|
+
const { data: allCities, isLoading: allCitiesLoading } = (0, hooks_1.useFetchAllCities)({});
|
34
|
+
if (allCitiesLoading) {
|
35
|
+
return react_1.default.createElement(FullScreenLoader_1.default, null);
|
36
|
+
}
|
37
|
+
return (react_1.default.createElement(react_native_1.View, { style: [styles.container, { backgroundColor: theme.colors.background }] },
|
38
|
+
react_1.default.createElement(Header_1.default, { showBackButton: false, showHomeButton: false, title: 'Select Metro' }),
|
39
|
+
react_1.default.createElement(react_native_1.FlatList, { style: styles.list, contentContainerStyle: { paddingBottom: (0, react_native_size_matters_1.mvs)(16) }, data: (allCities === null || allCities === void 0 ? void 0 : allCities.cities) || [], keyExtractor: item => item._id, renderItem: ({ item }) => (react_1.default.createElement(TransportationCard_1.default, { style: styles.card, label: item.name, desc: `${item.is_active ? `Book QR tickets for ${item.description}` : item.description}`, image: item.image, imageSize: 50, onPress: () => selectCity({ cityCode: item.cityCode }), disabled: selectCityLoading || !item.is_active })) }),
|
40
|
+
react_1.default.createElement(react_native_1.View, { style: styles.footer },
|
41
|
+
react_1.default.createElement(PoweredBy_1.default, null))));
|
42
|
+
};
|
43
|
+
const styles = react_native_1.StyleSheet.create({
|
44
|
+
container: {
|
45
|
+
flex: 1,
|
46
|
+
},
|
47
|
+
list: {
|
48
|
+
marginTop: (0, react_native_size_matters_1.mvs)(32),
|
49
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(24),
|
50
|
+
},
|
51
|
+
card: {
|
52
|
+
marginVertical: (0, react_native_size_matters_1.mvs)(8),
|
53
|
+
},
|
54
|
+
footer: {
|
55
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(12),
|
56
|
+
}
|
57
|
+
});
|
58
|
+
exports.default = MetroSelectionScreen;
|
@@ -0,0 +1,251 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
const react_1 = __importStar(require("react"));
|
30
|
+
const react_native_1 = require("react-native");
|
31
|
+
const Header_1 = __importDefault(require("../../components/common/Header/Header"));
|
32
|
+
const DropdownComponent_1 = __importDefault(require("../../components/common/DropdownComponent/DropdownComponent"));
|
33
|
+
const CustomInput_1 = __importDefault(require("../../components/common/CustomInput/CustomInput"));
|
34
|
+
const IssueCategoryData_1 = require("../../components/common/Modals/IssueCategoryData");
|
35
|
+
const MultiSelectDropdown_1 = __importDefault(require("../../components/common/DropdownComponent/MultiSelectDropdown"));
|
36
|
+
const native_1 = require("@react-navigation/native");
|
37
|
+
const MetroStack_1 = require("../../navigation/metro/MetroStack");
|
38
|
+
const react_native_toast_message_1 = __importDefault(require("react-native-toast-message"));
|
39
|
+
const hooks_1 = require("../../services/apis/metro/issue/hooks");
|
40
|
+
const CustomText_1 = require("../../components/common/Text/CustomText");
|
41
|
+
const Button_1 = require("../../components/common/Button/Button");
|
42
|
+
const Checkbox_1 = require("../../components/common/Checkbox/Checkbox");
|
43
|
+
const ThemeProvider_1 = require("../../theme/ThemeProvider");
|
44
|
+
const react_native_size_matters_1 = require("react-native-size-matters");
|
45
|
+
const RaiseIssueScreen = () => {
|
46
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
|
47
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
48
|
+
const { navigate } = (0, native_1.useNavigation)();
|
49
|
+
const { params: { transaction_id, orders } } = (0, native_1.useRoute)();
|
50
|
+
const [selectedOrders, setSelectedOrders] = (0, react_1.useState)([]);
|
51
|
+
const [differentIssues, setDifferentIssues] = (0, react_1.useState)(false);
|
52
|
+
const [ticketIssues, setTicketIssues] = (0, react_1.useState)({});
|
53
|
+
const { mutateAsync: raiseIssue, isPending: raiseIsuueLoading } = (0, hooks_1.useMutateRaiseMetroTicketIssue)(data => {
|
54
|
+
if (data.status === "success") {
|
55
|
+
navigate(MetroStack_1.MetroScreens.IssueDetails, { transaction_id: transaction_id });
|
56
|
+
}
|
57
|
+
});
|
58
|
+
const onChangeOrder = (val) => {
|
59
|
+
const index = selectedOrders.findIndex(order => order.transaction_id === val);
|
60
|
+
if (index === -1) {
|
61
|
+
const find = orders.find(o => o.transaction_id === val);
|
62
|
+
if (!find) {
|
63
|
+
react_native_toast_message_1.default.show({
|
64
|
+
type: "error",
|
65
|
+
text1: "Order not found",
|
66
|
+
});
|
67
|
+
}
|
68
|
+
else {
|
69
|
+
setSelectedOrders(selectedOrders => {
|
70
|
+
const updatedOrders = [
|
71
|
+
...selectedOrders,
|
72
|
+
{
|
73
|
+
transaction_id: find.transaction_id,
|
74
|
+
startStation: find.startStation,
|
75
|
+
destinationStation: find.destinationStation,
|
76
|
+
},
|
77
|
+
];
|
78
|
+
setTicketIssues(prev => (Object.assign(Object.assign({}, prev), { [find.transaction_id]: {
|
79
|
+
category: null,
|
80
|
+
subCategory: null,
|
81
|
+
subject: '',
|
82
|
+
detailedDescription: '',
|
83
|
+
} })));
|
84
|
+
return updatedOrders;
|
85
|
+
});
|
86
|
+
}
|
87
|
+
}
|
88
|
+
else {
|
89
|
+
setSelectedOrders(selectedOrders => {
|
90
|
+
const updatedOrders = selectedOrders.filter((_, idx) => idx !== index);
|
91
|
+
const updatedIssues = Object.assign({}, ticketIssues);
|
92
|
+
delete updatedIssues[val];
|
93
|
+
setTicketIssues(updatedIssues);
|
94
|
+
return updatedOrders;
|
95
|
+
});
|
96
|
+
}
|
97
|
+
};
|
98
|
+
const handleFieldChange = (ticketId, field, value) => {
|
99
|
+
setTicketIssues(prev => (Object.assign(Object.assign({}, prev), { [ticketId]: Object.assign(Object.assign({}, prev[ticketId]), { [field]: value }) })));
|
100
|
+
};
|
101
|
+
const handleSubmit = () => {
|
102
|
+
let ordersData;
|
103
|
+
if (!differentIssues) {
|
104
|
+
// Apply the same values to all tickets
|
105
|
+
const baseIssue = ticketIssues[selectedOrders[0].transaction_id] || {};
|
106
|
+
ordersData = selectedOrders.map(order => ({
|
107
|
+
transaction_id: order.transaction_id,
|
108
|
+
category: baseIssue.category || '',
|
109
|
+
sub_category: baseIssue.subCategory || '',
|
110
|
+
short_desc: baseIssue.subject || '',
|
111
|
+
long_desc: baseIssue.detailedDescription || '',
|
112
|
+
}));
|
113
|
+
}
|
114
|
+
else {
|
115
|
+
// Use individual values for each ticket
|
116
|
+
ordersData = selectedOrders.map(order => {
|
117
|
+
var _a, _b, _c, _d;
|
118
|
+
return ({
|
119
|
+
transaction_id: order.transaction_id,
|
120
|
+
category: ((_a = ticketIssues[order.transaction_id]) === null || _a === void 0 ? void 0 : _a.category) || '',
|
121
|
+
sub_category: ((_b = ticketIssues[order.transaction_id]) === null || _b === void 0 ? void 0 : _b.subCategory) || '',
|
122
|
+
short_desc: ((_c = ticketIssues[order.transaction_id]) === null || _c === void 0 ? void 0 : _c.subject) || '',
|
123
|
+
long_desc: ((_d = ticketIssues[order.transaction_id]) === null || _d === void 0 ? void 0 : _d.detailedDescription) || '',
|
124
|
+
});
|
125
|
+
});
|
126
|
+
}
|
127
|
+
console.log("Submitting issues data:", {
|
128
|
+
transaction_id: transaction_id,
|
129
|
+
orders: ordersData,
|
130
|
+
});
|
131
|
+
// Call the API
|
132
|
+
raiseIssue({
|
133
|
+
transaction_id: transaction_id,
|
134
|
+
orders: ordersData,
|
135
|
+
});
|
136
|
+
};
|
137
|
+
return (react_1.default.createElement(react_native_1.View, { style: [styles.container, { backgroundColor: theme.colors.background }] },
|
138
|
+
react_1.default.createElement(Header_1.default, { showBackButton: true, showHomeButton: false, title: "Raise an Issue" }),
|
139
|
+
react_1.default.createElement(react_native_1.ScrollView, { contentContainerStyle: styles.scrollContent, showsVerticalScrollIndicator: false, showsHorizontalScrollIndicator: false },
|
140
|
+
react_1.default.createElement(react_native_1.View, { style: styles.contentContainer },
|
141
|
+
react_1.default.createElement(react_native_1.View, null,
|
142
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
143
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Select Tickets"),
|
144
|
+
react_1.default.createElement(MultiSelectDropdown_1.default, { data: orders.map(item => ({
|
145
|
+
label: `${item.startStation} - ${item.destinationStation}`,
|
146
|
+
value: item.transaction_id
|
147
|
+
})), placeholder: "Select ticket", selectedLabels: selectedOrders.map(item => `${item.startStation} - ${item.destinationStation}`), selectedValues: selectedOrders.map(item => item.transaction_id), onValueChange: onChangeOrder })),
|
148
|
+
selectedOrders.length > 1 && (react_1.default.createElement(react_native_1.View, { style: [styles.checkboxRow, !differentIssues && { marginBottom: (0, react_native_size_matters_1.mvs)(16) }] },
|
149
|
+
react_1.default.createElement(Checkbox_1.Checkbox, { value: differentIssues, onValueChange: setDifferentIssues }),
|
150
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.checkboxLabel }, "Different issues with each ticket"))),
|
151
|
+
(!selectedOrders || !differentIssues) && selectedOrders.length === 0 && (react_1.default.createElement(react_native_1.View, { key: (_a = selectedOrders[0]) === null || _a === void 0 ? void 0 : _a.transaction_id },
|
152
|
+
react_1.default.createElement(react_native_1.View, null,
|
153
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
154
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Category"),
|
155
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: IssueCategoryData_1.categories, enableSearch: false, value: (_c = ticketIssues[(_b = selectedOrders[0]) === null || _b === void 0 ? void 0 : _b.transaction_id]) === null || _c === void 0 ? void 0 : _c.category, placeholder: "Category", onChange: item => { var _a; return handleFieldChange((_a = selectedOrders[0]) === null || _a === void 0 ? void 0 : _a.transaction_id, 'category', item.value); } })),
|
156
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
157
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subcategory"),
|
158
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: (IssueCategoryData_1.subCategories[(_e = ticketIssues[(_d = selectedOrders[0]) === null || _d === void 0 ? void 0 : _d.transaction_id]) === null || _e === void 0 ? void 0 : _e.category] || []).map((sub) => ({
|
159
|
+
label: sub.value,
|
160
|
+
value: sub.key,
|
161
|
+
})), value: (_g = ticketIssues[(_f = selectedOrders[0]) === null || _f === void 0 ? void 0 : _f.transaction_id]) === null || _g === void 0 ? void 0 : _g.subCategory, placeholder: "SubCategory", enableSearch: false, isDisabled: true, onChange: item => { var _a; return handleFieldChange((_a = selectedOrders[0]) === null || _a === void 0 ? void 0 : _a.transaction_id, 'subCategory', item.value); } })),
|
162
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
163
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subject"),
|
164
|
+
react_1.default.createElement(CustomInput_1.default, { name: `subject-${(_h = selectedOrders[0]) === null || _h === void 0 ? void 0 : _h.transaction_id}`, type: "text", placeholder: "Subject", floatingLabel: false, value: (_k = ticketIssues[(_j = selectedOrders[0]) === null || _j === void 0 ? void 0 : _j.transaction_id]) === null || _k === void 0 ? void 0 : _k.subject, onChange: value => { var _a; return handleFieldChange((_a = selectedOrders[0]) === null || _a === void 0 ? void 0 : _a.transaction_id, 'subject', value); } })),
|
165
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
166
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Description"),
|
167
|
+
react_1.default.createElement(CustomInput_1.default, { name: `description-${(_l = selectedOrders[0]) === null || _l === void 0 ? void 0 : _l.transaction_id}`, type: "textarea", placeholder: "Detailed Description", floatingLabel: false, value: (_o = ticketIssues[(_m = selectedOrders[0]) === null || _m === void 0 ? void 0 : _m.transaction_id]) === null || _o === void 0 ? void 0 : _o.detailedDescription, onChange: value => { var _a; return handleFieldChange((_a = selectedOrders[0]) === null || _a === void 0 ? void 0 : _a.transaction_id, 'detailedDescription', value); } }))))),
|
168
|
+
(selectedOrders.length === 1 || !differentIssues) && selectedOrders.length > 0 && (react_1.default.createElement(react_native_1.View, { key: selectedOrders[0].transaction_id },
|
169
|
+
react_1.default.createElement(react_native_1.View, null,
|
170
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
171
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Category"),
|
172
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: IssueCategoryData_1.categories, enableSearch: false, value: (_p = ticketIssues[selectedOrders[0].transaction_id]) === null || _p === void 0 ? void 0 : _p.category, placeholder: "Category", onChange: item => handleFieldChange(selectedOrders[0].transaction_id, 'category', item.value) })),
|
173
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
174
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subcategory"),
|
175
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: (IssueCategoryData_1.subCategories[(_q = ticketIssues[selectedOrders[0].transaction_id]) === null || _q === void 0 ? void 0 : _q.category] || []).map((sub) => ({
|
176
|
+
label: sub.value,
|
177
|
+
value: sub.key,
|
178
|
+
})), value: (_r = ticketIssues[selectedOrders[0].transaction_id]) === null || _r === void 0 ? void 0 : _r.subCategory, placeholder: "SubCategory", enableSearch: false, isDisabled: !((_s = ticketIssues[selectedOrders[0].transaction_id]) === null || _s === void 0 ? void 0 : _s.category), onChange: item => handleFieldChange(selectedOrders[0].transaction_id, 'subCategory', item.value) })),
|
179
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
180
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subject"),
|
181
|
+
react_1.default.createElement(CustomInput_1.default, { name: `subject-${selectedOrders[0].transaction_id}`, type: "text", placeholder: "Subject", floatingLabel: false, value: (_t = ticketIssues[selectedOrders[0].transaction_id]) === null || _t === void 0 ? void 0 : _t.subject, onChange: value => handleFieldChange(selectedOrders[0].transaction_id, 'subject', value) })),
|
182
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
183
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Description"),
|
184
|
+
react_1.default.createElement(CustomInput_1.default, { name: `description-${selectedOrders[0].transaction_id}`, type: "textarea", placeholder: "Detailed Description", floatingLabel: false, value: (_u = ticketIssues[selectedOrders[0].transaction_id]) === null || _u === void 0 ? void 0 : _u.detailedDescription, onChange: value => handleFieldChange(selectedOrders[0].transaction_id, 'detailedDescription', value) }))))),
|
185
|
+
differentIssues && selectedOrders.length > 1 && selectedOrders.map(order => {
|
186
|
+
var _a, _b, _c, _d, _e, _f;
|
187
|
+
return (react_1.default.createElement(react_native_1.View, { key: order.transaction_id },
|
188
|
+
react_1.default.createElement(react_native_1.View, { style: [styles.divider, { backgroundColor: theme.colors.borderLight }] }),
|
189
|
+
react_1.default.createElement(react_native_1.View, null,
|
190
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.orderTitle }, `${order.startStation} - ${order.destinationStation}`),
|
191
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
192
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Category"),
|
193
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: IssueCategoryData_1.categories, value: (_a = ticketIssues[order.transaction_id]) === null || _a === void 0 ? void 0 : _a.category, placeholder: "Category", enableSearch: false, onChange: item => handleFieldChange(order.transaction_id, 'category', item.value) })),
|
194
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
195
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subcategory"),
|
196
|
+
react_1.default.createElement(DropdownComponent_1.default, { data: (IssueCategoryData_1.subCategories[(_b = ticketIssues[order.transaction_id]) === null || _b === void 0 ? void 0 : _b.category] || []).map((sub) => ({
|
197
|
+
label: sub.value,
|
198
|
+
value: sub.key,
|
199
|
+
})), value: (_c = ticketIssues[order.transaction_id]) === null || _c === void 0 ? void 0 : _c.subCategory, placeholder: "SubCategory", enableSearch: false, isDisabled: !((_d = ticketIssues[order.transaction_id]) === null || _d === void 0 ? void 0 : _d.category), onChange: item => handleFieldChange(order.transaction_id, 'subCategory', item.value) })),
|
200
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
201
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Subject"),
|
202
|
+
react_1.default.createElement(CustomInput_1.default, { name: `subject-${order.transaction_id}`, type: "text", placeholder: "Subject", floatingLabel: false, value: (_e = ticketIssues[order.transaction_id]) === null || _e === void 0 ? void 0 : _e.subject, onChange: value => handleFieldChange(order.transaction_id, 'subject', value) })),
|
203
|
+
react_1.default.createElement(react_native_1.View, { style: styles.formControl },
|
204
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelMedium", style: styles.label }, "Description"),
|
205
|
+
react_1.default.createElement(CustomInput_1.default, { name: `description-${order.transaction_id}`, type: "textarea", placeholder: "Detailed Description", floatingLabel: false, value: (_f = ticketIssues[order.transaction_id]) === null || _f === void 0 ? void 0 : _f.detailedDescription, onChange: value => handleFieldChange(order.transaction_id, 'detailedDescription', value) })))));
|
206
|
+
})),
|
207
|
+
react_1.default.createElement(Button_1.Button, { variant: "primary", style: styles.submitButton, onPress: handleSubmit, loading: raiseIsuueLoading, loadingText: "Raising..." }, "Submit")))));
|
208
|
+
};
|
209
|
+
const styles = react_native_1.StyleSheet.create({
|
210
|
+
container: {
|
211
|
+
flex: 1,
|
212
|
+
},
|
213
|
+
scrollContent: {
|
214
|
+
flexGrow: 1,
|
215
|
+
},
|
216
|
+
contentContainer: {
|
217
|
+
flex: 1,
|
218
|
+
padding: (0, react_native_size_matters_1.ms)(20),
|
219
|
+
justifyContent: 'space-between'
|
220
|
+
},
|
221
|
+
formControl: {
|
222
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(16),
|
223
|
+
gap: (0, react_native_size_matters_1.mvs)(4),
|
224
|
+
},
|
225
|
+
label: {
|
226
|
+
fontWeight: 'bold',
|
227
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(4)
|
228
|
+
},
|
229
|
+
checkboxRow: {
|
230
|
+
flexDirection: 'row',
|
231
|
+
alignItems: 'center',
|
232
|
+
gap: (0, react_native_size_matters_1.ms)(8),
|
233
|
+
},
|
234
|
+
checkboxLabel: {
|
235
|
+
flex: 1,
|
236
|
+
},
|
237
|
+
divider: {
|
238
|
+
height: 1,
|
239
|
+
marginVertical: (0, react_native_size_matters_1.mvs)(16),
|
240
|
+
},
|
241
|
+
orderTitle: {
|
242
|
+
fontWeight: 'bold',
|
243
|
+
textDecorationLine: 'underline',
|
244
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(16)
|
245
|
+
},
|
246
|
+
submitButton: {
|
247
|
+
marginTop: (0, react_native_size_matters_1.mvs)(16),
|
248
|
+
height: (0, react_native_size_matters_1.mvs)(50),
|
249
|
+
},
|
250
|
+
});
|
251
|
+
exports.default = RaiseIssueScreen;
|