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,332 @@
|
|
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 react_native_size_matters_1 = require("react-native-size-matters");
|
32
|
+
const CustomText_1 = require("../Text/CustomText");
|
33
|
+
const ThemeProvider_1 = require("../../../theme/ThemeProvider");
|
34
|
+
const Checkbox_1 = require("../Checkbox/Checkbox");
|
35
|
+
const ChevronDownIcon_1 = __importDefault(require("../../../assets/icons/ChevronDownIcon"));
|
36
|
+
const TickIcon_1 = __importDefault(require("../../../assets/icons/TickIcon"));
|
37
|
+
const CustomInput = ({ type, label, placeholder, error, name, value, onChange, required, options, disabled, showError, maxDate, minDate, maxLength, size = "md", isReadOnly, floatingLabel = true, }) => {
|
38
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
39
|
+
const [phoneValue, setPhoneValue] = (0, react_1.useState)(value || "");
|
40
|
+
const [formattedPhoneValue, setFormattedPhoneValue] = (0, react_1.useState)("");
|
41
|
+
const [showPassword, setShowPassword] = (0, react_1.useState)(false);
|
42
|
+
const [date, setDate] = (0, react_1.useState)(undefined);
|
43
|
+
const [isFocused, setIsFocused] = (0, react_1.useState)(false);
|
44
|
+
const [isSelectOpen, setIsSelectOpen] = (0, react_1.useState)(false);
|
45
|
+
const [selectedOption, setSelectedOption] = (0, react_1.useState)(null);
|
46
|
+
const inputRef = (0, react_1.useRef)(null);
|
47
|
+
const animatedLabel = (0, react_1.useRef)(new react_native_1.Animated.Value(value ? 1 : 0)).current;
|
48
|
+
(0, react_1.useEffect)(() => {
|
49
|
+
react_native_1.Animated.timing(animatedLabel, {
|
50
|
+
toValue: isFocused || value ? 1 : 0,
|
51
|
+
duration: 200,
|
52
|
+
useNativeDriver: false,
|
53
|
+
}).start();
|
54
|
+
}, [isFocused, value]);
|
55
|
+
const labelStyle = {
|
56
|
+
position: "absolute",
|
57
|
+
left: (0, react_native_size_matters_1.ms)(14),
|
58
|
+
top: animatedLabel.interpolate({
|
59
|
+
inputRange: [0, 1],
|
60
|
+
outputRange: [(0, react_native_size_matters_1.mvs)(13), (0, react_native_size_matters_1.mvs)(-11)],
|
61
|
+
}),
|
62
|
+
backgroundColor: theme.colors.background,
|
63
|
+
zIndex: 1,
|
64
|
+
paddingLeft: (0, react_native_size_matters_1.ms)(5),
|
65
|
+
paddingRight: (0, react_native_size_matters_1.ms)(5),
|
66
|
+
fontSize: animatedLabel.interpolate({
|
67
|
+
inputRange: [0, 1],
|
68
|
+
outputRange: [(0, react_native_size_matters_1.ms)(14), (0, react_native_size_matters_1.ms)(14)],
|
69
|
+
}),
|
70
|
+
color: animatedLabel.interpolate({
|
71
|
+
inputRange: [0, 1],
|
72
|
+
outputRange: [theme.colors.textTertiary, theme.colors.text],
|
73
|
+
}),
|
74
|
+
};
|
75
|
+
const handleTogglePassword = () => {
|
76
|
+
setShowPassword(!showPassword);
|
77
|
+
};
|
78
|
+
const handleLabelPress = () => {
|
79
|
+
var _a;
|
80
|
+
(_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
81
|
+
};
|
82
|
+
const handleSelectOption = (option) => {
|
83
|
+
setSelectedOption(option);
|
84
|
+
if (onChange)
|
85
|
+
onChange(option.value);
|
86
|
+
setIsSelectOpen(false);
|
87
|
+
};
|
88
|
+
const getInputSize = () => {
|
89
|
+
switch (size) {
|
90
|
+
case "sm": return (0, react_native_size_matters_1.mvs)(40);
|
91
|
+
case "lg": return (0, react_native_size_matters_1.mvs)(50);
|
92
|
+
default: return (0, react_native_size_matters_1.mvs)(48);
|
93
|
+
}
|
94
|
+
};
|
95
|
+
const renderInputComponent = () => {
|
96
|
+
switch (type) {
|
97
|
+
// case "phone":
|
98
|
+
// return (
|
99
|
+
// <PhoneInput
|
100
|
+
// value={value}
|
101
|
+
// defaultCode="IN"
|
102
|
+
// layout="first"
|
103
|
+
// textInputProps={{
|
104
|
+
// maxLength: 10,
|
105
|
+
// placeholderTextColor: theme.colors.textTertiary,
|
106
|
+
// placeholder: floatingLabel ? undefined : placeholder
|
107
|
+
// }}
|
108
|
+
// disabled={disabled}
|
109
|
+
// onChangeText={(text) => {
|
110
|
+
// setPhoneValue(text);
|
111
|
+
// if (onChange) onChange(text);
|
112
|
+
// }}
|
113
|
+
// containerStyle={[
|
114
|
+
// styles.phoneContainer,
|
115
|
+
// {
|
116
|
+
// borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
117
|
+
// height: getInputSize()
|
118
|
+
// }
|
119
|
+
// ]}
|
120
|
+
// textContainerStyle={[
|
121
|
+
// styles.phoneInput,
|
122
|
+
// { backgroundColor: theme.colors.surfaceVariant }
|
123
|
+
// ]}
|
124
|
+
// textInputStyle={[
|
125
|
+
// styles.numberInput,
|
126
|
+
// { color: theme.colors.text }
|
127
|
+
// ]}
|
128
|
+
// codeTextStyle={{
|
129
|
+
// fontSize: ms(16),
|
130
|
+
// fontWeight: '700',
|
131
|
+
// color: theme.colors.text
|
132
|
+
// }}
|
133
|
+
// />
|
134
|
+
// );
|
135
|
+
case "password":
|
136
|
+
return (react_1.default.createElement(react_native_1.View, { style: [
|
137
|
+
styles.inputGroup,
|
138
|
+
styles.focusedInput,
|
139
|
+
{
|
140
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
141
|
+
height: getInputSize()
|
142
|
+
}
|
143
|
+
] },
|
144
|
+
react_1.default.createElement(react_native_1.TextInput, { ref: inputRef, secureTextEntry: !showPassword, style: [
|
145
|
+
styles.input,
|
146
|
+
{
|
147
|
+
color: theme.colors.text,
|
148
|
+
flex: 1,
|
149
|
+
height: '100%'
|
150
|
+
}
|
151
|
+
], placeholder: floatingLabel ? undefined : placeholder, placeholderTextColor: theme.colors.textTertiary, value: value, onChangeText: onChange, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), editable: !disabled, maxLength: maxLength }),
|
152
|
+
react_1.default.createElement(react_native_1.TouchableOpacity, { onPress: handleTogglePassword, style: styles.iconButton })));
|
153
|
+
case "number":
|
154
|
+
return (react_1.default.createElement(react_native_1.TextInput, { ref: inputRef, style: [
|
155
|
+
styles.input,
|
156
|
+
styles.focusedInput,
|
157
|
+
{
|
158
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
159
|
+
height: getInputSize(),
|
160
|
+
textAlign: 'center',
|
161
|
+
color: theme.colors.text
|
162
|
+
}
|
163
|
+
], keyboardType: "numeric", placeholder: floatingLabel ? undefined : placeholder, placeholderTextColor: theme.colors.textTertiary, value: value, onChangeText: onChange, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), editable: !disabled, maxLength: maxLength, autoComplete: "cc-number", autoCorrect: false, autoCapitalize: "none" }));
|
164
|
+
case "text":
|
165
|
+
return (react_1.default.createElement(react_native_1.TextInput, { ref: inputRef, style: [
|
166
|
+
styles.input,
|
167
|
+
styles.focusedInput,
|
168
|
+
{
|
169
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
170
|
+
height: getInputSize(),
|
171
|
+
color: theme.colors.text
|
172
|
+
}
|
173
|
+
], placeholder: floatingLabel ? undefined : placeholder, placeholderTextColor: theme.colors.textTertiary, value: value, onChangeText: onChange, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), editable: !disabled && !isReadOnly, maxLength: maxLength, scrollEnabled: true }));
|
174
|
+
case "textarea":
|
175
|
+
return (react_1.default.createElement(react_native_1.TextInput, { ref: inputRef, multiline: true, numberOfLines: 4, placeholder: floatingLabel ? undefined : placeholder, placeholderTextColor: theme.colors.textTertiary, value: value, onChangeText: onChange, style: [
|
176
|
+
styles.textarea,
|
177
|
+
{
|
178
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
179
|
+
color: theme.colors.text
|
180
|
+
}
|
181
|
+
], onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), maxLength: maxLength, editable: !disabled }));
|
182
|
+
case "radio":
|
183
|
+
return (react_1.default.createElement(react_native_1.View, { style: styles.radioGroup }, options === null || options === void 0 ? void 0 : options.map((opt) => (react_1.default.createElement(react_native_1.View, { key: `${name}-${opt.value}`, style: styles.radioOption },
|
184
|
+
react_1.default.createElement(Checkbox_1.Checkbox, { value: value === opt.value, onValueChange: () => !disabled && onChange && onChange(opt.value), disabled: disabled, size: (0, react_native_size_matters_1.ms)(18) }),
|
185
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "body1", style: [
|
186
|
+
styles.radioLabel,
|
187
|
+
disabled && { borderColor: theme.colors.gray[200], backgroundColor: theme.colors.disabled }
|
188
|
+
] }, opt.label))))));
|
189
|
+
case "switch":
|
190
|
+
return (react_1.default.createElement(react_native_1.Switch, { value: value, onValueChange: (val) => onChange && onChange(val), disabled: disabled, trackColor: {
|
191
|
+
false: theme.colors.surfaceVariant,
|
192
|
+
true: theme.colors.primary[500]
|
193
|
+
}, thumbColor: theme.colors.background }));
|
194
|
+
case "select":
|
195
|
+
return (react_1.default.createElement(react_native_1.View, null,
|
196
|
+
react_1.default.createElement(react_native_1.Pressable, { onPress: () => !disabled && setIsSelectOpen(true), style: [
|
197
|
+
styles.selectInput,
|
198
|
+
{
|
199
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
200
|
+
height: getInputSize()
|
201
|
+
}
|
202
|
+
] },
|
203
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "body1", style: [
|
204
|
+
styles.selectText,
|
205
|
+
{
|
206
|
+
color: selectedOption ? theme.colors.text : theme.colors.textTertiary
|
207
|
+
}
|
208
|
+
] }, (selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) || placeholder),
|
209
|
+
react_1.default.createElement(ChevronDownIcon_1.default, { size: (0, react_native_size_matters_1.ms)(16), color: theme.colors.textTertiary })),
|
210
|
+
react_1.default.createElement(react_native_1.Modal, { visible: isSelectOpen, transparent: true, animationType: "fade", onRequestClose: () => setIsSelectOpen(false) },
|
211
|
+
react_1.default.createElement(react_native_1.View, { style: styles.modalOverlay },
|
212
|
+
react_1.default.createElement(react_native_1.View, { style: [
|
213
|
+
styles.modalContent,
|
214
|
+
{ backgroundColor: theme.colors.background }
|
215
|
+
] },
|
216
|
+
react_1.default.createElement(react_native_1.FlatList, { data: options || [], keyExtractor: (item) => item.value, renderItem: ({ item }) => (react_1.default.createElement(react_native_1.Pressable, { style: styles.selectItem, onPress: () => handleSelectOption(item) },
|
217
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "body1" }, item.label),
|
218
|
+
(selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value) === item.value && (react_1.default.createElement(TickIcon_1.default, { color: theme.colors.text })))) }))))));
|
219
|
+
default:
|
220
|
+
return (react_1.default.createElement(react_native_1.TextInput, { ref: inputRef, style: [
|
221
|
+
styles.input,
|
222
|
+
styles.focusedInput,
|
223
|
+
{
|
224
|
+
borderColor: isFocused ? theme.colors.primary[500] : theme.colors.borderDark,
|
225
|
+
height: getInputSize(),
|
226
|
+
color: theme.colors.text
|
227
|
+
}
|
228
|
+
], placeholder: floatingLabel ? undefined : placeholder, placeholderTextColor: theme.colors.textTertiary, value: value, onChangeText: onChange, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), editable: !disabled, maxLength: maxLength }));
|
229
|
+
}
|
230
|
+
};
|
231
|
+
return (react_1.default.createElement(react_native_1.View, { style: styles.container },
|
232
|
+
floatingLabel && (react_1.default.createElement(react_native_1.TouchableWithoutFeedback, { onPress: handleLabelPress },
|
233
|
+
react_1.default.createElement(react_native_1.Animated.Text, { style: [labelStyle] },
|
234
|
+
label,
|
235
|
+
" ",
|
236
|
+
required && "*"))),
|
237
|
+
renderInputComponent(),
|
238
|
+
showError && error && (react_1.default.createElement(CustomText_1.CustomText, { variant: "caption", style: [styles.errorText, { color: theme.colors.error[500] }] }, error))));
|
239
|
+
};
|
240
|
+
const styles = react_native_1.StyleSheet.create({
|
241
|
+
container: {
|
242
|
+
position: 'relative',
|
243
|
+
},
|
244
|
+
inputGroup: {
|
245
|
+
flexDirection: "row",
|
246
|
+
alignItems: "center",
|
247
|
+
borderWidth: 1,
|
248
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
249
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(14),
|
250
|
+
},
|
251
|
+
input: {
|
252
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(14),
|
253
|
+
fontSize: (0, react_native_size_matters_1.ms)(14),
|
254
|
+
width: '100%',
|
255
|
+
},
|
256
|
+
phoneContainer: {
|
257
|
+
borderWidth: 1,
|
258
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
259
|
+
width: "100%",
|
260
|
+
},
|
261
|
+
phoneInput: {
|
262
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
263
|
+
padding: 0,
|
264
|
+
},
|
265
|
+
numberInput: {
|
266
|
+
padding: 0,
|
267
|
+
fontSize: (0, react_native_size_matters_1.ms)(16),
|
268
|
+
fontWeight: '700',
|
269
|
+
marginLeft: (0, react_native_size_matters_1.ms)(6),
|
270
|
+
},
|
271
|
+
textarea: {
|
272
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(12),
|
273
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(14),
|
274
|
+
borderWidth: 1,
|
275
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
276
|
+
fontSize: (0, react_native_size_matters_1.ms)(14),
|
277
|
+
height: (0, react_native_size_matters_1.mvs)(100),
|
278
|
+
textAlignVertical: "top",
|
279
|
+
lineHeight: (0, react_native_size_matters_1.mvs)(24),
|
280
|
+
},
|
281
|
+
radioGroup: {
|
282
|
+
gap: (0, react_native_size_matters_1.mvs)(8),
|
283
|
+
},
|
284
|
+
radioOption: {
|
285
|
+
flexDirection: 'row',
|
286
|
+
alignItems: 'center',
|
287
|
+
gap: (0, react_native_size_matters_1.ms)(8),
|
288
|
+
},
|
289
|
+
radioLabel: {
|
290
|
+
flex: 1,
|
291
|
+
},
|
292
|
+
focusedInput: {
|
293
|
+
borderWidth: 1,
|
294
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
295
|
+
},
|
296
|
+
errorText: {
|
297
|
+
marginTop: (0, react_native_size_matters_1.mvs)(4),
|
298
|
+
},
|
299
|
+
iconButton: {
|
300
|
+
padding: (0, react_native_size_matters_1.ms)(8),
|
301
|
+
},
|
302
|
+
selectInput: {
|
303
|
+
borderWidth: 1,
|
304
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
305
|
+
paddingHorizontal: (0, react_native_size_matters_1.ms)(14),
|
306
|
+
flexDirection: 'row',
|
307
|
+
alignItems: 'center',
|
308
|
+
justifyContent: 'space-between',
|
309
|
+
},
|
310
|
+
selectText: {
|
311
|
+
flex: 1,
|
312
|
+
},
|
313
|
+
modalOverlay: {
|
314
|
+
flex: 1,
|
315
|
+
justifyContent: 'center',
|
316
|
+
alignItems: 'center',
|
317
|
+
backgroundColor: 'rgba(0, 0, 0, 0.7)',
|
318
|
+
},
|
319
|
+
modalContent: {
|
320
|
+
width: '80%',
|
321
|
+
maxHeight: '60%',
|
322
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
323
|
+
padding: (0, react_native_size_matters_1.ms)(16),
|
324
|
+
},
|
325
|
+
selectItem: {
|
326
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(12),
|
327
|
+
flexDirection: 'row',
|
328
|
+
justifyContent: 'space-between',
|
329
|
+
alignItems: 'center',
|
330
|
+
},
|
331
|
+
});
|
332
|
+
exports.default = CustomInput;
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { TextStyle, ViewStyle } from 'react-native';
|
3
|
+
interface DropdownComponentProps {
|
4
|
+
isOpen?: boolean;
|
5
|
+
data: any[];
|
6
|
+
value: any | null;
|
7
|
+
enableLabelAnimation?: boolean;
|
8
|
+
enableSearch?: boolean;
|
9
|
+
placeholder?: string;
|
10
|
+
searchPlaceholder?: string;
|
11
|
+
maxHeight?: number;
|
12
|
+
dropdownStyle?: ViewStyle;
|
13
|
+
placeholderStyle?: TextStyle;
|
14
|
+
selectedTextStyle?: TextStyle;
|
15
|
+
iconStyle?: any;
|
16
|
+
inputSearchStyle?: TextStyle;
|
17
|
+
containerStyle?: TextStyle;
|
18
|
+
itemTextStyle?: TextStyle;
|
19
|
+
onChange: (item: any) => void;
|
20
|
+
isDisabled?: boolean;
|
21
|
+
}
|
22
|
+
declare const DropdownComponent: React.FC<DropdownComponentProps>;
|
23
|
+
export default DropdownComponent;
|
@@ -0,0 +1,133 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
26
|
+
const react_1 = __importStar(require("react"));
|
27
|
+
const react_native_1 = require("react-native");
|
28
|
+
const react_native_element_dropdown_1 = require("react-native-element-dropdown");
|
29
|
+
const ThemeProvider_1 = require("../../../theme/ThemeProvider");
|
30
|
+
const DropdownComponent = ({ isOpen = false, data, value, enableLabelAnimation = true, enableSearch = true, placeholder = '', searchPlaceholder = 'Search...', maxHeight = 300, dropdownStyle, placeholderStyle, selectedTextStyle, iconStyle, inputSearchStyle, containerStyle, itemTextStyle, onChange, isDisabled, }) => {
|
31
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
32
|
+
const [isFocus, setIsFocus] = (0, react_1.useState)(isOpen);
|
33
|
+
const dropdownRef = (0, react_1.useRef)(null);
|
34
|
+
const [search, setSearch] = (0, react_1.useState)('');
|
35
|
+
const getLabelField = () => { var _a; return ((_a = data[0]) === null || _a === void 0 ? void 0 : _a.label) ? 'label' : 'name'; };
|
36
|
+
const getValueField = () => { var _a; return ((_a = data[0]) === null || _a === void 0 ? void 0 : _a.value) ? 'value' : 'name'; };
|
37
|
+
// const searchInputRef = useRef<TextInput>(null);
|
38
|
+
// const filteredStations = data.filter(st => {
|
39
|
+
// if (st.name.toLowerCase().trim().includes(search.toLowerCase().trim())) {
|
40
|
+
// return true;
|
41
|
+
// } else {
|
42
|
+
// return false;
|
43
|
+
// }
|
44
|
+
// });
|
45
|
+
(0, react_1.useEffect)(() => {
|
46
|
+
if (enableSearch && isFocus) {
|
47
|
+
setTimeout(() => {
|
48
|
+
// searchInputRef.current?.focus();
|
49
|
+
}, 500);
|
50
|
+
}
|
51
|
+
}, [isFocus, enableSearch]);
|
52
|
+
(0, react_1.useEffect)(() => {
|
53
|
+
var _a, _b;
|
54
|
+
if (isOpen) {
|
55
|
+
(_a = dropdownRef.current) === null || _a === void 0 ? void 0 : _a.open();
|
56
|
+
setIsFocus(true);
|
57
|
+
}
|
58
|
+
else {
|
59
|
+
(_b = dropdownRef.current) === null || _b === void 0 ? void 0 : _b.close();
|
60
|
+
setIsFocus(false);
|
61
|
+
}
|
62
|
+
}, [isOpen]);
|
63
|
+
const styles = react_native_1.StyleSheet.create({
|
64
|
+
container: {
|
65
|
+
position: 'relative',
|
66
|
+
},
|
67
|
+
dropdown: {
|
68
|
+
height: 50,
|
69
|
+
// borderColor: '#a1a1aa', // NativeBase input border color when not focused
|
70
|
+
borderColor: theme.colors.borderDark,
|
71
|
+
borderWidth: 1,
|
72
|
+
borderRadius: 8,
|
73
|
+
paddingHorizontal: 8,
|
74
|
+
color: theme.colors.text,
|
75
|
+
},
|
76
|
+
label: {
|
77
|
+
position: 'absolute',
|
78
|
+
// backgroundColor: '#FFF',
|
79
|
+
backgroundColor: theme.colors.background,
|
80
|
+
left: 18,
|
81
|
+
bottom: 40,
|
82
|
+
zIndex: 999,
|
83
|
+
paddingHorizontal: 4,
|
84
|
+
fontSize: 14,
|
85
|
+
color: theme.colors.gray[500], // NativeBase default label color
|
86
|
+
},
|
87
|
+
placeholderStyle: {
|
88
|
+
fontSize: 14,
|
89
|
+
paddingLeft: 4,
|
90
|
+
color: theme.colors.textTertiary, // NativeBase default placeholder color
|
91
|
+
},
|
92
|
+
selectedTextStyle: {
|
93
|
+
fontSize: 14,
|
94
|
+
paddingLeft: 6,
|
95
|
+
color: theme.colors.text, // NativeBase input text color
|
96
|
+
},
|
97
|
+
iconStyle: {
|
98
|
+
width: 20,
|
99
|
+
height: 20,
|
100
|
+
},
|
101
|
+
inputSearchStyle: {
|
102
|
+
height: 45,
|
103
|
+
borderRadius: 8,
|
104
|
+
fontSize: 14,
|
105
|
+
color: theme.colors.text, // Text color for search input
|
106
|
+
},
|
107
|
+
containerStyle: {
|
108
|
+
backgroundColor: theme.colors.backdrop,
|
109
|
+
borderRadius: 8,
|
110
|
+
shadowOpacity: 1,
|
111
|
+
elevation: 8,
|
112
|
+
},
|
113
|
+
itemTextStyle: {
|
114
|
+
color: theme.colors.text,
|
115
|
+
fontSize: 14
|
116
|
+
},
|
117
|
+
});
|
118
|
+
return (react_1.default.createElement(react_native_1.View, { style: [styles.container, containerStyle] },
|
119
|
+
react_1.default.createElement(react_native_element_dropdown_1.Dropdown, { style: [
|
120
|
+
styles.dropdown,
|
121
|
+
dropdownStyle,
|
122
|
+
isFocus && { borderColor: theme.colors.primary[500] },
|
123
|
+
isDisabled && { borderColor: theme.colors.gray[200], backgroundColor: theme.colors.disabled }
|
124
|
+
], ref: dropdownRef, labelField: getLabelField(), valueField: getValueField(), placeholderStyle: [styles.placeholderStyle, placeholderStyle], selectedTextStyle: [styles.selectedTextStyle, selectedTextStyle], inputSearchStyle: [styles.inputSearchStyle, inputSearchStyle], iconStyle: [styles.iconStyle, iconStyle], containerStyle: [styles.containerStyle, containerStyle], itemTextStyle: [styles.itemTextStyle, itemTextStyle], showsVerticalScrollIndicator: true, data: data, search: enableSearch, maxHeight: maxHeight,
|
125
|
+
// labelField="name"
|
126
|
+
// valueField="name"
|
127
|
+
placeholder: enableLabelAnimation ? (!isFocus ? placeholder : '...') : placeholder, value: value, disable: isDisabled, onFocus: () => setIsFocus(true), onBlur: () => setIsFocus(false), onChange: (item) => {
|
128
|
+
setIsFocus(false);
|
129
|
+
onChange(item);
|
130
|
+
setSearch('');
|
131
|
+
}, renderInputSearch: (searchProps) => (react_1.default.createElement(react_native_1.TextInput, Object.assign({ value: search, onChangeText: val => setSearch(val), placeholder: searchPlaceholder }, searchProps, { style: [styles.inputSearchStyle, inputSearchStyle] }))) })));
|
132
|
+
};
|
133
|
+
exports.default = DropdownComponent;
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
interface Option {
|
3
|
+
label: string;
|
4
|
+
value: string;
|
5
|
+
}
|
6
|
+
interface MultiSelectDropdownProps {
|
7
|
+
data: Option[];
|
8
|
+
placeholder: string;
|
9
|
+
selectedLabels: string[];
|
10
|
+
selectedValues: string[];
|
11
|
+
onValueChange: (value: string) => void;
|
12
|
+
disabled?: boolean;
|
13
|
+
}
|
14
|
+
declare const MultiSelectDropdown: React.FC<MultiSelectDropdownProps>;
|
15
|
+
export default MultiSelectDropdown;
|
@@ -0,0 +1,133 @@
|
|
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 CustomText_1 = require("../../../components/common/Text/CustomText");
|
32
|
+
const Checkbox_1 = require("../../../components/common/Checkbox/Checkbox");
|
33
|
+
const Button_1 = require("../../../components/common/Button/Button");
|
34
|
+
const ChevronDownIcon_1 = __importDefault(require("../../../assets/icons/ChevronDownIcon"));
|
35
|
+
const ThemeProvider_1 = require("../../../theme/ThemeProvider");
|
36
|
+
const react_native_size_matters_1 = require("react-native-size-matters");
|
37
|
+
const MultiSelectDropdown = ({ data, placeholder, selectedLabels, selectedValues, onValueChange, disabled = false }) => {
|
38
|
+
const { theme } = (0, ThemeProvider_1.useTheme)();
|
39
|
+
const [isOpen, setIsOpen] = (0, react_1.useState)(false);
|
40
|
+
(0, react_1.useEffect)(() => {
|
41
|
+
if (data.length === 1) {
|
42
|
+
const onlyOption = data[0];
|
43
|
+
if (!selectedValues.includes(onlyOption.value)) {
|
44
|
+
onValueChange(onlyOption.value);
|
45
|
+
}
|
46
|
+
}
|
47
|
+
}, [data, selectedValues, onValueChange]);
|
48
|
+
return (react_1.default.createElement(react_native_1.View, null,
|
49
|
+
react_1.default.createElement(react_native_1.Pressable, { onPress: () => !disabled && setIsOpen(true), disabled: disabled || data.length === 1 },
|
50
|
+
react_1.default.createElement(react_native_1.View, { style: [
|
51
|
+
styles.dropdownContainer,
|
52
|
+
{
|
53
|
+
borderColor: disabled ? theme.colors.gray[200] : theme.colors.borderDark,
|
54
|
+
backgroundColor: disabled ? theme.colors.disabled : theme.colors.background
|
55
|
+
}
|
56
|
+
] },
|
57
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "body1", style: [
|
58
|
+
styles.dropdownText,
|
59
|
+
{
|
60
|
+
color: disabled ? theme.colors.textTertiary :
|
61
|
+
selectedLabels.length ? theme.colors.text : theme.colors.textTertiary
|
62
|
+
}
|
63
|
+
] }, selectedLabels.length
|
64
|
+
? selectedLabels.join(', ')
|
65
|
+
: data.length === 1
|
66
|
+
? data[0].label
|
67
|
+
: placeholder),
|
68
|
+
data.length > 1 && !disabled && (react_1.default.createElement(ChevronDownIcon_1.default, { size: (0, react_native_size_matters_1.ms)(16), color: theme.colors.textTertiary })))),
|
69
|
+
data.length > 1 && (react_1.default.createElement(react_native_1.Modal, { visible: isOpen, transparent: true, animationType: "fade", onRequestClose: () => setIsOpen(false) },
|
70
|
+
react_1.default.createElement(react_native_1.View, { style: styles.modalOverlay },
|
71
|
+
react_1.default.createElement(react_native_1.View, { style: [
|
72
|
+
styles.modalContent,
|
73
|
+
{ backgroundColor: theme.colors.backdrop, shadowColor: theme.colors.shadow }
|
74
|
+
] },
|
75
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "labelLarge", style: styles.modalTitle }, "Select Options"),
|
76
|
+
react_1.default.createElement(react_native_1.FlatList, { data: data, keyExtractor: (item) => item.value, renderItem: ({ item }) => (react_1.default.createElement(react_native_1.Pressable, { style: styles.checkboxItem, onPress: () => onValueChange(item.value) },
|
77
|
+
react_1.default.createElement(Checkbox_1.Checkbox, { value: selectedValues.includes(item.value), onValueChange: () => onValueChange(item.value), size: (0, react_native_size_matters_1.ms)(18), disabled: disabled }),
|
78
|
+
react_1.default.createElement(CustomText_1.CustomText, { variant: "body1", style: styles.checkboxLabel }, item.label))), contentContainerStyle: styles.listContent }),
|
79
|
+
react_1.default.createElement(Button_1.Button, { variant: "primary", style: styles.confirmButton, onPress: () => setIsOpen(false) }, "Confirm")))))));
|
80
|
+
};
|
81
|
+
const styles = react_native_1.StyleSheet.create({
|
82
|
+
dropdownContainer: {
|
83
|
+
borderWidth: 1,
|
84
|
+
borderRadius: (0, react_native_size_matters_1.ms)(8),
|
85
|
+
paddingVertical: (0, react_native_size_matters_1.mvs)(12),
|
86
|
+
paddingLeft: (0, react_native_size_matters_1.ms)(12),
|
87
|
+
paddingRight: (0, react_native_size_matters_1.ms)(8),
|
88
|
+
flexDirection: 'row',
|
89
|
+
alignItems: 'center',
|
90
|
+
justifyContent: 'space-between',
|
91
|
+
height: (0, react_native_size_matters_1.mvs)(48),
|
92
|
+
},
|
93
|
+
dropdownText: {
|
94
|
+
flex: 1,
|
95
|
+
},
|
96
|
+
modalOverlay: {
|
97
|
+
flex: 1,
|
98
|
+
justifyContent: 'center',
|
99
|
+
alignItems: 'center',
|
100
|
+
backgroundColor: 'rgba(0, 0, 0, 0.7)',
|
101
|
+
},
|
102
|
+
modalContent: {
|
103
|
+
width: '90%',
|
104
|
+
maxHeight: '70%',
|
105
|
+
borderRadius: (0, react_native_size_matters_1.ms)(12),
|
106
|
+
padding: (0, react_native_size_matters_1.ms)(16),
|
107
|
+
shadowOffset: { width: 0, height: 2 },
|
108
|
+
shadowOpacity: 0.25,
|
109
|
+
shadowRadius: (0, react_native_size_matters_1.ms)(4),
|
110
|
+
elevation: 5,
|
111
|
+
},
|
112
|
+
modalTitle: {
|
113
|
+
fontWeight: 'bold',
|
114
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(16),
|
115
|
+
},
|
116
|
+
listContent: {
|
117
|
+
paddingBottom: (0, react_native_size_matters_1.mvs)(8),
|
118
|
+
},
|
119
|
+
checkboxItem: {
|
120
|
+
flexDirection: 'row',
|
121
|
+
alignItems: 'center',
|
122
|
+
marginBottom: (0, react_native_size_matters_1.mvs)(8),
|
123
|
+
},
|
124
|
+
checkboxLabel: {
|
125
|
+
flex: 1,
|
126
|
+
marginLeft: (0, react_native_size_matters_1.ms)(8),
|
127
|
+
},
|
128
|
+
confirmButton: {
|
129
|
+
height: (0, react_native_size_matters_1.mvs)(50),
|
130
|
+
marginTop: (0, react_native_size_matters_1.mvs)(16),
|
131
|
+
},
|
132
|
+
});
|
133
|
+
exports.default = MultiSelectDropdown;
|