Compare commits
	
		
			148 Commits
		
	
	
		
			patch/4.5.
			...
			special/ro
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 45a0cfee43 | ||
|  | f3f9ee60c2 | ||
|  | a713ae576d | ||
|  | e967dfac2f | ||
|  | fe8df6af2e | ||
|  | 6b12dcbcf6 | ||
|  | 039dff5d8f | ||
|  | 91c8bec6b0 | ||
|  | f13e2e8b78 | ||
|  | c45c58cc64 | ||
|  | bf2b4d356c | ||
|  | f8bd37c452 | ||
|  | 12cd53640d | ||
|  | 627102601d | ||
|  | 5ce9ba9bea | ||
|  | 319e4b7b68 | ||
|  | 8257440138 | ||
|  | 720b4942ee | ||
|  | 72412e87e8 | ||
|  | 93529f4f7d | ||
|  | 38052abd30 | ||
|  | 17602751d6 | ||
|  | acecd1a88b | ||
|  | 1fb471205c | ||
|  | 62d7936425 | ||
|  | 84c050e928 | ||
|  | cb2562fe9c | ||
|  | 49e9ed14bc | ||
|  | 576d9ae222 | ||
|  | 32e61a824b | ||
|  | b551c75061 | ||
|  | 4784899a07 | ||
|  | f4f4f314a8 | ||
|  | 80f4913f89 | ||
|  | cbcb0dc9c2 | ||
|  | e3a65b9127 | ||
|  | edaa16cf35 | ||
|  | e72cb03e08 | ||
|  | b8176d2f29 | ||
|  | a6d8f9ac33 | ||
|  | fd2fe310ab | ||
|  | d4ddaeb17e | ||
|  | 4f14e7023a | ||
|  | 06aedbf81e | ||
|  | e2349cca15 | ||
|  | 06090e0e7a | ||
|  | 3c6f1f42dd | ||
|  | 68cced053e | ||
|  | 06d7ee0559 | ||
|  | f57096e261 | ||
|  | 7a06a5d86a | ||
|  | 484f45f2e2 | ||
|  | 907747f36d | ||
|  | a3ecc80d28 | ||
|  | dc0c5648ac | ||
|  | 8ff57e58c2 | ||
|  | 7048333b07 | ||
|  | ff044926af | ||
|  | 2b1ff91e0f | ||
|  | 9301780212 | ||
|  | 567c357ad2 | ||
|  | 671392d287 | ||
|  | 2a3e6c95b3 | ||
|  | d8806c3047 | ||
|  | 7e36af1ed4 | ||
|  | 58ef72c9df | ||
|  | 99b840e452 | ||
|  | 8310712e5b | ||
|  | 19a74dbc37 | ||
|  | 5e1c6203de | ||
|  | ad34feb191 | ||
|  | 717569993e | ||
|  | fc7edb9e37 | ||
|  | 9992102d69 | ||
|  | 14c1c3ddd2 | ||
|  | dd170d55b4 | ||
|  | 2290c96ca7 | ||
|  | fa7c32298e | ||
|  | 6714f1d612 | ||
|  | 8a94b81052 | ||
|  | 24e784a236 | ||
|  | 8a85572f51 | ||
|  | 431c4c9c0b | ||
|  | 19e9fd8fd8 | ||
|  | ebdec28693 | ||
|  | ab0805689f | ||
|  | 4219e12164 | ||
|  | 6300259e70 | ||
|  | 4009b5eef2 | ||
|  | 33c2f00b73 | ||
|  | 7492028a21 | ||
|  | d6a2846f6b | ||
|  | 5a7e0bcd99 | ||
|  | 0d50326507 | ||
|  | 485102b591 | ||
|  | 65080e68f2 | ||
|  | 87129c6815 | ||
|  | 26d9037963 | ||
|  | 263cb750ce | ||
|  | b54f2f6f7e | ||
|  | 0e06b66368 | ||
|  | 0753bf7023 | ||
|  | 16f7d1f7ad | ||
|  | 0f0d69b22d | ||
|  | 29c84bcc1c | ||
|  | 9e7931926f | ||
|  | 60d8caaefa | ||
|  | f72ac1d97b | ||
|  | 3ca91f402e | ||
|  | a4e85ff2e6 | ||
|  | 57459d975b | ||
|  | 23402aef79 | ||
|  | e4ce671e67 | ||
|  | 789af1aa37 | ||
|  | b23b59eab3 | ||
|  | e38f550b94 | ||
|  | 9b70843e9c | ||
|  | f1e98344ca | ||
|  | 2debff6051 | ||
|  | b7c56f4b90 | ||
|  | 761543af90 | ||
|  | 36b199ef98 | ||
|  | 049b138ca5 | ||
|  | 6c3b186c9b | ||
|  | 5678ad5b35 | ||
|  | 6233c94a80 | ||
|  | 305d386fcc | ||
|  | f62fadffb7 | ||
|  | 8f23faacd7 | ||
|  | 91fb41dab0 | ||
|  | ac1c4f3902 | ||
|  | 9306a9cb25 | ||
|  | d6f727710f | ||
|  | 171df01a0d | ||
|  | d5fab2f49b | ||
|  | 94558b784a | ||
|  | 644f066c96 | ||
|  | fc091a2ae6 | ||
|  | 47bba10c04 | ||
|  | b98f61a802 | ||
|  | ccf764005c | ||
|  | a6a2a6dfbb | ||
|  | 2199e9cc57 | ||
|  | e11d8f534e | ||
|  | 831b632e7d | ||
|  | d47191761a | ||
|  | 5e3ef414f6 | ||
|  | 0e11f63bc3 | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -5,3 +5,4 @@ npm-debug.* | |||||||
| *.p12 | *.p12 | ||||||
| *.key | *.key | ||||||
| *.mobileprovision | *.mobileprovision | ||||||
|  | dist/ | ||||||
							
								
								
									
										355
									
								
								App.js
									
									
									
									
									
								
							
							
						
						
									
										355
									
								
								App.js
									
									
									
									
									
								
							| @@ -1,61 +1,80 @@ | |||||||
| import React, { useEffect, useRef, useState } from "react"; | import React, { useEffect } from "react"; | ||||||
| import { NavigationContainer } from "@react-navigation/native"; | import { NavigationContainer } from "@react-navigation/native"; | ||||||
| import { | import { createStackNavigator } from "@react-navigation/stack"; | ||||||
|   createStackNavigator, |  | ||||||
|   TransitionPresets, |  | ||||||
| } from "@react-navigation/stack"; |  | ||||||
| import { createBottomTabNavigator } from "@react-navigation/bottom-tabs"; | import { createBottomTabNavigator } from "@react-navigation/bottom-tabs"; | ||||||
| import { AntDesign, Ionicons } from "@expo/vector-icons"; |  | ||||||
| import { Platform, UIManager } from "react-native"; | import { Platform, UIManager } from "react-native"; | ||||||
|  | import { GestureHandlerRootView } from "react-native-gesture-handler"; | ||||||
| import { UpdateAsync } from "./UpdateAsync.js"; | import { UpdateAsync } from "./UpdateAsync.js"; | ||||||
| import { getStationList2 } from "./lib/getStationList2"; |  | ||||||
| import { AS } from "./storageControl"; | import { AS } from "./storageControl"; | ||||||
| import Apps from "./Apps"; |  | ||||||
| import TNDView from "./ndView"; | import TNDView from "./ndView"; | ||||||
| import TrainBase from "./trainbaseview"; |  | ||||||
| import HowTo from "./howto"; |  | ||||||
| import Menu from "./menu"; |  | ||||||
| import News from "./components/news.js"; |  | ||||||
| import Setting from "./components/settings.js"; |  | ||||||
| import TrainMenu from "./components/trainMenu.js"; |  | ||||||
| import FavoriteList from "./components/FavoriteList.js"; |  | ||||||
| import { LogBox } from "react-native"; | import { LogBox } from "react-native"; | ||||||
| import useInterval from "./lib/useInterval"; | import useInterval from "./lib/useInterval"; | ||||||
| import { HeaderConfig } from "./lib/HeaderConfig"; | import { HeaderConfig } from "./lib/HeaderConfig"; | ||||||
|  | import { initIcon } from "./lib/initIcon"; | ||||||
|  | import { | ||||||
|  |   useFavoriteStation, | ||||||
|  |   FavoriteStationProvider, | ||||||
|  | } from "./stateBox/useFavoriteStation"; | ||||||
|  | import { Top } from "./Top.js"; | ||||||
|  | import { MenuPage } from "./MenuPage.js"; | ||||||
|  | import { | ||||||
|  |   useCurrentTrain, | ||||||
|  |   CurrentTrainProvider, | ||||||
|  | } from "./stateBox/useCurrentTrain.js"; | ||||||
|  | import { useAreaInfo, AreaInfoProvider } from "./stateBox/useAreaInfo.js"; | ||||||
|  | import { | ||||||
|  |   useBusAndTrainData, | ||||||
|  |   BusAndTrainDataProvider, | ||||||
|  | } from "./stateBox/useBusAndTrainData.js"; | ||||||
|  | import { AllTrainDiagramProvider } from "./stateBox/useAllTrainDiagram.js"; | ||||||
|  | import { SheetProvider } from "react-native-actions-sheet"; | ||||||
|  | import "./components/ActionSheetComponents/sheets.js"; | ||||||
|  | import { TrainDelayDataProvider } from "./stateBox/useTrainDelayData.js"; | ||||||
|  | import { SafeAreaProvider } from "react-native-safe-area-context"; | ||||||
| LogBox.ignoreLogs([ | LogBox.ignoreLogs([ | ||||||
|   "ViewPropTypes will be removed", |   "ViewPropTypes will be removed", | ||||||
|   "ColorPropType will be removed", |   "ColorPropType will be removed", | ||||||
| ]); | ]); | ||||||
| const Stack = createStackNavigator(); |  | ||||||
| const Tab = createBottomTabNavigator(); | const Tab = createBottomTabNavigator(); | ||||||
| if (Platform.OS === "android") { | if (Platform.OS === "android") { | ||||||
|   if (UIManager.setLayoutAnimationEnabledExperimental) { |   if (UIManager.setLayoutAnimationEnabledExperimental) { | ||||||
|     UIManager.setLayoutAnimationEnabledExperimental(true); |     UIManager.setLayoutAnimationEnabledExperimental(true); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| export default function App() { |  | ||||||
|   useEffect(() => { |  | ||||||
|     UpdateAsync(); |  | ||||||
|   }, []); |  | ||||||
|   const [favoriteStation, setFavoriteStation] = useState([]); |  | ||||||
|  |  | ||||||
|   useEffect(() => { | export default function App() { | ||||||
|     AS.getItem("favoriteStation") |   useEffect(() => UpdateAsync(), []); | ||||||
|       .then((d) => { |   return ( | ||||||
|         const returnData = JSON.parse(d); |     <SafeAreaProvider> | ||||||
|         setFavoriteStation(returnData); |       <GestureHandlerRootView style={{ flex: 1 }}> | ||||||
|       }) |         <FavoriteStationProvider> | ||||||
|       .catch((d) => console.log(d)); |           <TrainDelayDataProvider> | ||||||
|   }, []); |             <CurrentTrainProvider> | ||||||
|   const [busAndTrainData, setBusAndTrainData] = useState([]); |               <AreaInfoProvider> | ||||||
|  |                 <AllTrainDiagramProvider> | ||||||
|  |                   <BusAndTrainDataProvider> | ||||||
|  |                     <SheetProvider> | ||||||
|  |                       <AppContainer /> | ||||||
|  |                     </SheetProvider> | ||||||
|  |                   </BusAndTrainDataProvider> | ||||||
|  |                 </AllTrainDiagramProvider> | ||||||
|  |               </AreaInfoProvider> | ||||||
|  |             </CurrentTrainProvider> | ||||||
|  |           </TrainDelayDataProvider> | ||||||
|  |         </FavoriteStationProvider> | ||||||
|  |       </GestureHandlerRootView> | ||||||
|  |     </SafeAreaProvider> | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | export function AppContainer() { | ||||||
|  |   const { setBusAndTrainData, setTrainPairData } = useBusAndTrainData(); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     AS.getItem("busAndTrain") |     AS.getItem("busAndTrain") | ||||||
|       .then((d) => { |       .then((d) => { | ||||||
|         const returnData = JSON.parse(d); |         const returnData = JSON.parse(d); | ||||||
|         setBusAndTrainData(returnData); |         setBusAndTrainData(returnData); | ||||||
|       }) |       }) | ||||||
|       .catch((d) => { |       .catch(() => { | ||||||
|         fetch( |         fetch( | ||||||
|           "https://script.google.com/macros/s/AKfycbw0UW6ZeCDgUYFRP0zxpc_Oqfy-91dBdbWv-cM8n3narKp14IyCd2wy5HW7taXcW7E/exec" |           "https://script.google.com/macros/s/AKfycbw0UW6ZeCDgUYFRP0zxpc_Oqfy-91dBdbWv-cM8n3narKp14IyCd2wy5HW7taXcW7E/exec" | ||||||
|         ) |         ) | ||||||
| @@ -66,34 +85,39 @@ export default function App() { | |||||||
|           }); |           }); | ||||||
|       }); |       }); | ||||||
|   }, []); |   }, []); | ||||||
|  |   useEffect(() => { | ||||||
|   const [currentTrain, setCurrentTrain] = useState([]); //現在在線中の全列車 { num: 列車番号, delay: 遅延時分(状態), Pos: 位置情報 } |     AS.getItem("trainPairData") | ||||||
|   const [currentTrainLoading, setCurrentTrainLoading] = useState("loading"); // success, error, loading |  | ||||||
|   const getCurrentTrain = () => |  | ||||||
|     fetch( |  | ||||||
|       "https://train.jr-shikoku.co.jp/g?arg1=train&arg2=train", |  | ||||||
|       HeaderConfig |  | ||||||
|     ) |  | ||||||
|       .then((response) => response.json()) |  | ||||||
|       .then((d) => |  | ||||||
|         d.map((x) => ({ num: x.TrainNum, delay: x.delay, Pos: x.Pos })) |  | ||||||
|       ) |  | ||||||
|       .then((d) => { |       .then((d) => { | ||||||
|         setCurrentTrain(d); |         const returnData = JSON.parse(d); | ||||||
|         setCurrentTrainLoading("success"); |         setTrainPairData(returnData); | ||||||
|       }) |       }) | ||||||
|       .catch((e) => { |       .catch(() => { | ||||||
|         console.log("えらー"); |         fetch( | ||||||
|         setCurrentTrainLoading("error"); |           "https://script.google.com/macros/s/AKfycbyoBH7_rBwzPmhU1ghRBNTAVuvGltIrZtWxE07gDdhGGlDL9Ip2qk3pFM5u2xtRBl8/exec" | ||||||
|  |         ) | ||||||
|  |           .then((d) => d.json()) | ||||||
|  |           .then((d) => { | ||||||
|  |             setTrainPairData(d); | ||||||
|  |             AS.setItem("trainPairData", JSON.stringify(d)); | ||||||
|           }); |           }); | ||||||
|  |       }); | ||||||
|  |   }, []); | ||||||
|  |  | ||||||
|   useEffect(getCurrentTrain, []); //初回だけ現在の全在線列車取得 |   const { areaInfo, setAreaInfo } = useAreaInfo(); | ||||||
|  |   const getAreaData = () => | ||||||
|   useInterval(getCurrentTrain, 15000); //15秒毎に全在線列車取得 |     fetch( | ||||||
|  |       "https://script.google.com/macros/s/AKfycbz80LcaEUrhnlEsLkJy0LG2IRO3DBVQhfNmN1d_0f_HvtsujNQpxM90SrV9yKWH_JG1Ww/exec" | ||||||
|  |     ) | ||||||
|  |       .then((d) => d.text()) | ||||||
|  |       .then((d) => setAreaInfo(d)); | ||||||
|  |   useEffect(getAreaData, []); | ||||||
|  |   useInterval(getAreaData, 60000); //60秒毎に全在線列車取得 | ||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|     <NavigationContainer name="Root" style={{ flex: 1 }}> |     <NavigationContainer name="Root" style={{ flex: 1 }}> | ||||||
|       <Tab.Navigator detachInactiveScreens={false}> |       <Tab.Navigator | ||||||
|  |         tabBarOptions={{ keyboardHidesTabBar: Platform.OS === "android" }} | ||||||
|  |       > | ||||||
|         <Tab.Screen |         <Tab.Screen | ||||||
|           name="login" |           name="login" | ||||||
|           options={{ |           options={{ | ||||||
| @@ -103,20 +127,7 @@ export default function App() { | |||||||
|             tabBarIcon: initIcon("barchart", "AntDesign"), |             tabBarIcon: initIcon("barchart", "AntDesign"), | ||||||
|           }} |           }} | ||||||
|         > |         > | ||||||
|           {(props) => ( |           {(props) => <Top {...props} />} | ||||||
|             <Top |  | ||||||
|               {...props} |  | ||||||
|               favoriteStation={favoriteStation} |  | ||||||
|               setFavoriteStation={setFavoriteStation} |  | ||||||
|               busAndTrainData={busAndTrainData} |  | ||||||
|               currentTrainState={{ currentTrain, setCurrentTrain }} |  | ||||||
|               currentTrainLoadingState={{ |  | ||||||
|                 currentTrainLoading, |  | ||||||
|                 setCurrentTrainLoading, |  | ||||||
|               }} |  | ||||||
|               getCurrentTrain={getCurrentTrain} |  | ||||||
|             /> |  | ||||||
|           )} |  | ||||||
|         </Tab.Screen> |         </Tab.Screen> | ||||||
|         <Tab.Screen |         <Tab.Screen | ||||||
|           name="menuPage" |           name="menuPage" | ||||||
| @@ -127,20 +138,7 @@ export default function App() { | |||||||
|             tabBarIcon: initIcon("ios-radio", "Ionicons"), |             tabBarIcon: initIcon("ios-radio", "Ionicons"), | ||||||
|           }} |           }} | ||||||
|         > |         > | ||||||
|           {(props) => ( |           {(props) => <MenuPage {...props} />} | ||||||
|             <MenuPage |  | ||||||
|               {...props} |  | ||||||
|               favoriteStation={favoriteStation} |  | ||||||
|               setFavoriteStation={setFavoriteStation} |  | ||||||
|               busAndTrainData={busAndTrainData} |  | ||||||
|               currentTrainState={{ currentTrain, setCurrentTrain }} |  | ||||||
|               currentTrainLoadingState={{ |  | ||||||
|                 currentTrainLoading, |  | ||||||
|                 setCurrentTrainLoading, |  | ||||||
|               }} |  | ||||||
|               getCurrentTrain={getCurrentTrain} |  | ||||||
|             /> |  | ||||||
|           )} |  | ||||||
|         </Tab.Screen> |         </Tab.Screen> | ||||||
|         <Tab.Screen |         <Tab.Screen | ||||||
|           name="home" |           name="home" | ||||||
| @@ -149,6 +147,7 @@ export default function App() { | |||||||
|             headerTransparent: true, |             headerTransparent: true, | ||||||
|             gestureEnabled: true, |             gestureEnabled: true, | ||||||
|             tabBarIcon: initIcon("md-train", "Ionicons"), |             tabBarIcon: initIcon("md-train", "Ionicons"), | ||||||
|  |             tabBarBadge: areaInfo ? "!" : undefined, | ||||||
|           }} |           }} | ||||||
|         > |         > | ||||||
|           {(props) => <TNDView {...props} />} |           {(props) => <TNDView {...props} />} | ||||||
| @@ -157,197 +156,3 @@ export default function App() { | |||||||
|     </NavigationContainer> |     </NavigationContainer> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
|  |  | ||||||
| const initIcon = (name, type) => { |  | ||||||
|   switch (type) { |  | ||||||
|     case "Ionicons": |  | ||||||
|       return ({ focused, color, size }) => ( |  | ||||||
|         <Ionicons name={name} size={32} color={focused ? "#0099CC" : "black"} /> |  | ||||||
|       ); |  | ||||||
|     case "AntDesign": |  | ||||||
|       return ({ focused, color, size }) => ( |  | ||||||
|         <AntDesign |  | ||||||
|           name={name} |  | ||||||
|           size={32} |  | ||||||
|           color={focused ? "#0099CC" : "black"} |  | ||||||
|         /> |  | ||||||
|       ); |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| const Top = ({ |  | ||||||
|   navigation, |  | ||||||
|   favoriteStation, |  | ||||||
|   setFavoriteStation, |  | ||||||
|   busAndTrainData, |  | ||||||
|   currentTrainState, |  | ||||||
|   currentTrainLoadingState, |  | ||||||
|   getCurrentTrain, |  | ||||||
| }) => { |  | ||||||
|   const webview = useRef(); |  | ||||||
|  |  | ||||||
|   //地図用 |  | ||||||
|   const [mapsStationData, setMapsStationData] = useState(undefined); |  | ||||||
|  |  | ||||||
|   useEffect(() => { |  | ||||||
|     getStationList2().then(setMapsStationData); |  | ||||||
|   }, []); |  | ||||||
|  |  | ||||||
|   useEffect(() => { |  | ||||||
|     const unsubscribe = navigation.addListener("tabLongPress", (e) => { |  | ||||||
|       navigation.navigate("favoriteList"); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     return unsubscribe; |  | ||||||
|   }, [navigation]); |  | ||||||
|  |  | ||||||
|   return ( |  | ||||||
|     <Stack.Navigator> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="Apps" |  | ||||||
|         options={{ |  | ||||||
|           headerShown: false, |  | ||||||
|           gestureEnabled: true, |  | ||||||
|           headerTransparent: true, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => ( |  | ||||||
|           <Apps |  | ||||||
|             {...props} |  | ||||||
|             webview={webview} |  | ||||||
|             favoriteStation={favoriteStation} |  | ||||||
|             setFavoriteStation={setFavoriteStation} |  | ||||||
|             busAndTrainData={busAndTrainData} |  | ||||||
|             stationData={mapsStationData} |  | ||||||
|             currentTrainState={currentTrainState} |  | ||||||
|             currentTrainLoadingState={currentTrainLoadingState} |  | ||||||
|             getCurrentTrain={getCurrentTrain} |  | ||||||
|           /> |  | ||||||
|         )} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="trainbase" |  | ||||||
|         options={{ |  | ||||||
|           title: "トレインビジョン", |  | ||||||
|           gestureEnabled: true, |  | ||||||
|           ...TransitionPresets.SlideFromRightIOS, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => <TrainBase {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="howto" |  | ||||||
|         options={{ |  | ||||||
|           ...optionData, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => <HowTo {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen name="news" options={optionData}> |  | ||||||
|         {(props) => <News {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen name="trainMenu" options={optionData}> |  | ||||||
|         {(props) => ( |  | ||||||
|           <TrainMenu |  | ||||||
|             {...props} |  | ||||||
|             webview={webview} |  | ||||||
|             stationData={mapsStationData} |  | ||||||
|           /> |  | ||||||
|         )} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="favoriteList" |  | ||||||
|         options={{ ...optionData, gestureEnabled: false }} |  | ||||||
|       > |  | ||||||
|         {(props) => ( |  | ||||||
|           <FavoriteList |  | ||||||
|             {...props} |  | ||||||
|             webview={webview} |  | ||||||
|             stationData={mapsStationData} |  | ||||||
|             favoriteStation={favoriteStation} |  | ||||||
|             setFavoriteStation={setFavoriteStation} |  | ||||||
|           /> |  | ||||||
|         )} |  | ||||||
|       </Stack.Screen> |  | ||||||
|     </Stack.Navigator> |  | ||||||
|   ); |  | ||||||
| }; |  | ||||||
| function MenuPage({ |  | ||||||
|   navigation, |  | ||||||
|   favoriteStation, |  | ||||||
|   setFavoriteStation, |  | ||||||
|   busAndTrainData, |  | ||||||
|   currentTrainState, |  | ||||||
|   currentTrainLoadingState, |  | ||||||
|   getCurrentTrain, |  | ||||||
| }) { |  | ||||||
|   useEffect(() => { |  | ||||||
|     const unsubscribe = navigation.addListener("tabPress", (e) => { |  | ||||||
|       AS.getItem("favoriteStation") |  | ||||||
|         .then((d) => { |  | ||||||
|           const returnData = JSON.parse(d); |  | ||||||
|           if (favoriteStation.toString() != d) { |  | ||||||
|             setFavoriteStation(returnData); |  | ||||||
|           } |  | ||||||
|         }) |  | ||||||
|         .catch((d) => console.log(d)); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     return unsubscribe; |  | ||||||
|   }, [navigation]); |  | ||||||
|   return ( |  | ||||||
|     <Stack.Navigator> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="menu" |  | ||||||
|         options={{ |  | ||||||
|           headerShown: false, |  | ||||||
|           gestureEnabled: true, |  | ||||||
|           headerTransparent: true, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => ( |  | ||||||
|           <Menu |  | ||||||
|             {...props} |  | ||||||
|             favoriteStation={favoriteStation} |  | ||||||
|             setFavoriteStation={setFavoriteStation} |  | ||||||
|             busAndTrainData={busAndTrainData} |  | ||||||
|             currentTrainState={currentTrainState} |  | ||||||
|             currentTrainLoadingState={currentTrainLoadingState} |  | ||||||
|             getCurrentTrain={getCurrentTrain} |  | ||||||
|           /> |  | ||||||
|         )} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen name="setting" options={optionData}> |  | ||||||
|         {(props) => <Setting {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="trainbase" |  | ||||||
|         options={{ |  | ||||||
|           ...TransitionPresets.ModalPresentationIOS, |  | ||||||
|           cardOverlayEnabled: true, |  | ||||||
|           headerShown: false, |  | ||||||
|           gestureEnabled: true, |  | ||||||
|           headerTransparent: true, |  | ||||||
|           gestureResponseDistance: { vertical: 300 }, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => <TrainBase {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|       <Stack.Screen |  | ||||||
|         name="howto" |  | ||||||
|         options={{ |  | ||||||
|           ...optionData, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         {(props) => <HowTo {...props} />} |  | ||||||
|       </Stack.Screen> |  | ||||||
|     </Stack.Navigator> |  | ||||||
|   ); |  | ||||||
| } |  | ||||||
| const optionData = { |  | ||||||
|   gestureEnabled: true, |  | ||||||
|   ...TransitionPresets.ModalPresentationIOS, |  | ||||||
|   cardOverlayEnabled: true, |  | ||||||
|   headerTransparent: true, |  | ||||||
|   headerShown: false, |  | ||||||
| }; |  | ||||||
|   | |||||||
							
								
								
									
										251
									
								
								Apps.js
									
									
									
									
									
								
							
							
						
						
									
										251
									
								
								Apps.js
									
									
									
									
									
								
							| @@ -1,50 +1,54 @@ | |||||||
| import React, { useEffect, useRef, useState } from "react"; | import React, { useEffect, useState } from "react"; | ||||||
| import { | import { | ||||||
|   View, |   View, | ||||||
|   Platform, |   Platform, | ||||||
|   ToastAndroid, |  | ||||||
|   Text, |   Text, | ||||||
|   TouchableOpacity, |   TouchableOpacity, | ||||||
|  |   useWindowDimensions, | ||||||
|  |   LayoutAnimation, | ||||||
| } from "react-native"; | } from "react-native"; | ||||||
| import { WebView } from "react-native-webview"; | import { WebView } from "react-native-webview"; | ||||||
| import Constants from "expo-constants"; | import Constants from "expo-constants"; | ||||||
| import { Ionicons, MaterialCommunityIcons } from "@expo/vector-icons"; | import { Ionicons } from "@expo/vector-icons"; | ||||||
|  |  | ||||||
| import { AS } from "./storageControl"; | import { AS } from "./storageControl"; | ||||||
| import { news } from "./config/newsUpdate"; | import { news } from "./config/newsUpdate"; | ||||||
| import { getStationList, lineList } from "./lib/getStationList"; | import { getStationList, lineList } from "./lib/getStationList"; | ||||||
| import { StationDeteilView } from "./components/ActionSheetComponents/StationDeteilView"; |  | ||||||
| import { injectJavascriptData } from "./lib/webViewInjectjavascript"; | import { injectJavascriptData } from "./lib/webViewInjectjavascript"; | ||||||
| import { getStationList2 } from "./lib/getStationList2"; |  | ||||||
| import { EachTrainInfo } from "./components/ActionSheetComponents/EachTrainInfo"; |  | ||||||
| import { checkDuplicateTrainData } from "./lib/checkDuplicateTrainData"; | import { checkDuplicateTrainData } from "./lib/checkDuplicateTrainData"; | ||||||
|  | import { useFavoriteStation } from "./stateBox/useFavoriteStation"; | ||||||
|  | import { useCurrentTrain } from "./stateBox/useCurrentTrain"; | ||||||
|  | import { SheetManager } from "react-native-actions-sheet"; | ||||||
|  | import TrainMenu from "./components/trainMenu"; | ||||||
|  | import { EachTrainInfoCore } from "./components/ActionSheetComponents/EachTrainInfoCore"; | ||||||
| /*  | /*  | ||||||
| import StatusbarDetect from './StatusbarDetect'; | import StatusbarDetect from './StatusbarDetect'; | ||||||
| var Status = StatusbarDetect(); */ | var Status = StatusbarDetect(); */ | ||||||
|  |  | ||||||
| export default function Apps({ | export default function Apps({ navigation, webview, stationData }) { | ||||||
|   navigation, |   const { currentTrain } = useCurrentTrain(); | ||||||
|   webview, |   const { height, width } = useWindowDimensions(); | ||||||
|   favoriteStation, |  | ||||||
|   setFavoriteStation, |  | ||||||
|   busAndTrainData, |  | ||||||
|   stationData, |  | ||||||
|   currentTrainState, |  | ||||||
|   currentTrainLoadingState, |  | ||||||
|   getCurrentTrain, |  | ||||||
| }) { |  | ||||||
|   const { currentTrain, setCurrentTrain } = currentTrainState; |  | ||||||
|   const { currentTrainLoading, setCurrentTrainLoading } = |  | ||||||
|     currentTrainLoadingState; |  | ||||||
|   const { navigate } = navigation; |   const { navigate } = navigation; | ||||||
|   var urlcache = ""; |   var urlcache = ""; | ||||||
|  |   const { favoriteStation } = useFavoriteStation(); | ||||||
|  |   const [isLandscape, setIsLandscape] = useState(false); //画面が横向きかどうか | ||||||
|  |   const handleLayout = () => {}; | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (height / width > 1.5) { | ||||||
|  |       setIsLandscape(false); | ||||||
|  |     } | ||||||
|  |     if (height / width < 1.5) { | ||||||
|  |       setIsLandscape(true); | ||||||
|  |     } | ||||||
|  |   }, [height, width]); | ||||||
|  |  | ||||||
|   //画面表示関連 |   //画面表示関連 | ||||||
|   const [iconSetting, setIconSetting] = useState(undefined); |   const [iconSetting, setIconSetting] = useState(undefined); | ||||||
|   const [mapSwitch, setMapSwitch] = useState(undefined); |   const [mapSwitch, setMapSwitch] = useState(undefined); | ||||||
|   const [stationMenu, setStationMenu] = useState(undefined); |   const [stationMenu, setStationMenu] = useState(undefined); | ||||||
|  |   const [LoadError, setLoadError] = useState(false); | ||||||
|  |  | ||||||
|   //列車情報表示関連 |   //列車情報表示関連 | ||||||
|   const EachTrainInfoAsSR = useRef(null); |  | ||||||
|   const [trainInfo, setTrainInfo] = useState({ |   const [trainInfo, setTrainInfo] = useState({ | ||||||
|     trainNum: undefined, |     trainNum: undefined, | ||||||
|     limited: undefined, |     limited: undefined, | ||||||
| @@ -52,17 +56,13 @@ export default function Apps({ | |||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   //駅情報画面用 |   //駅情報画面用 | ||||||
|   const StationBoardAcSR = useRef(null); |  | ||||||
|   const [stationBoardData, setStationBoardData] = useState(undefined); |  | ||||||
|   const [originalStationList, setOriginalStationList] = useState(); |   const [originalStationList, setOriginalStationList] = useState(); | ||||||
|   const [selectedStation, setSelectedStation] = useState(undefined); |  | ||||||
|   const [trainMenu, setTrainMenu] = useState("true"); |   const [trainMenu, setTrainMenu] = useState("true"); | ||||||
|   let once = false; |   let once = false; | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     getStationList().then(setOriginalStationList); |     getStationList().then(setOriginalStationList); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   useEffect(() => {}, [stationData, favoriteStation]); |  | ||||||
|   //地図表示テキスト |   //地図表示テキスト | ||||||
|   const injectJavascript = injectJavascriptData( |   const injectJavascript = injectJavascriptData( | ||||||
|     mapSwitch, |     mapSwitch, | ||||||
| @@ -77,7 +77,7 @@ export default function Apps({ | |||||||
|       .then((d) => { |       .then((d) => { | ||||||
|         if (d != news) navigate("news"); |         if (d != news) navigate("news"); | ||||||
|       }) |       }) | ||||||
|       .catch((e) => navigate("news")); |       .catch(() => navigate("news")); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
| @@ -90,7 +90,7 @@ export default function Apps({ | |||||||
|           AS.setItem("iconSwitch", "true").then(Updates.reloadAsync); |           AS.setItem("iconSwitch", "true").then(Updates.reloadAsync); | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|       .catch((d) => AS.setItem("iconSwitch", "true").then(Updates.reloadAsync)); |       .catch(() => AS.setItem("iconSwitch", "true").then(Updates.reloadAsync)); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
| @@ -103,7 +103,7 @@ export default function Apps({ | |||||||
|           AS.setItem("mapSwitch", "false").then(Updates.reloadAsync); |           AS.setItem("mapSwitch", "false").then(Updates.reloadAsync); | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|       .catch((d) => AS.setItem("mapSwitch", "false").then(Updates.reloadAsync)); |       .catch(() => AS.setItem("mapSwitch", "false").then(Updates.reloadAsync)); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
| @@ -116,7 +116,7 @@ export default function Apps({ | |||||||
|           AS.setItem("stationSwitch", "true").then(Updates.reloadAsync); |           AS.setItem("stationSwitch", "true").then(Updates.reloadAsync); | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|       .catch((d) => |       .catch(() => | ||||||
|         AS.setItem("stationSwitch", "true").then(Updates.reloadAsync) |         AS.setItem("stationSwitch", "true").then(Updates.reloadAsync) | ||||||
|       ); |       ); | ||||||
|   }, []); |   }, []); | ||||||
| @@ -130,9 +130,7 @@ export default function Apps({ | |||||||
|           AS.setItem("trainSwitch", "true").then(Updates.reloadAsync); |           AS.setItem("trainSwitch", "true").then(Updates.reloadAsync); | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|       .catch((d) => |       .catch(() => AS.setItem("trainSwitch", "true").then(Updates.reloadAsync)); | ||||||
|         AS.setItem("trainSwitch", "true").then(Updates.reloadAsync) |  | ||||||
|       ); |  | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   const onMessage = (event) => { |   const onMessage = (event) => { | ||||||
| @@ -146,7 +144,12 @@ export default function Apps({ | |||||||
|     } |     } | ||||||
|     const dataSet = JSON.parse(event.nativeEvent.data); |     const dataSet = JSON.parse(event.nativeEvent.data); | ||||||
|     switch (dataSet.type) { |     switch (dataSet.type) { | ||||||
|       case "PopUpMenu": { |       case "LoadError": { | ||||||
|  |         setLoadError(true); | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  |       case "PopUpMenu": | ||||||
|  |         { | ||||||
|           const selectedStationPDFAddress = dataSet.pdf; |           const selectedStationPDFAddress = dataSet.pdf; | ||||||
|           const findStationEachLine = (selectLine) => { |           const findStationEachLine = (selectLine) => { | ||||||
|             let NearStation = selectLine.filter( |             let NearStation = selectLine.filter( | ||||||
| @@ -163,17 +166,29 @@ export default function Apps({ | |||||||
|             }, []); |             }, []); | ||||||
|  |  | ||||||
|           if (returnDataBase.length) { |           if (returnDataBase.length) { | ||||||
|           setStationBoardData(returnDataBase); |             const payload = { | ||||||
|           StationBoardAcSR.current?.show(); |               currentStation: returnDataBase, | ||||||
|         } else { |               originalStationList: originalStationList, | ||||||
|           setStationBoardData(undefined); |               navigate: navigate, | ||||||
|           StationBoardAcSR.current?.hide(); |               goTo: "Apps", | ||||||
|  |               useShow: () => | ||||||
|  |                 SheetManager.show("StationDetailView", { | ||||||
|  |                   payload, | ||||||
|  |                 }), | ||||||
|  |               onExit: () => { | ||||||
|  |                 SheetManager.hide("StationDetailView"); | ||||||
|  |               }, | ||||||
|  |             }; | ||||||
|  |             SheetManager.show("StationDetailView", { | ||||||
|  |               payload, | ||||||
|  |             }); | ||||||
|  |           } | ||||||
|         } |         } | ||||||
|         return; |         return; | ||||||
|       } |  | ||||||
|       case "ShowTrainTimeInfo": { |       case "ShowTrainTimeInfo": { | ||||||
|         const { trainNum, limited } = dataSet; |         const { trainNum, limited } = dataSet; | ||||||
|         //alert(trainNum, limited); |         //alert(trainNum, limited); | ||||||
|  |         LayoutAnimation.easeInEaseOut(); | ||||||
|         setTrainInfo({ |         setTrainInfo({ | ||||||
|           trainNum, |           trainNum, | ||||||
|           limited, |           limited, | ||||||
| @@ -181,7 +196,19 @@ export default function Apps({ | |||||||
|             currentTrain.filter((a) => a.num == trainNum) |             currentTrain.filter((a) => a.num == trainNum) | ||||||
|           ), |           ), | ||||||
|         }); //遅延情報は未実装 |         }); //遅延情報は未実装 | ||||||
|         EachTrainInfoAsSR.current?.show(); |         if (isLandscape) return; | ||||||
|  |         const payload = { | ||||||
|  |           data: { | ||||||
|  |             trainNum, | ||||||
|  |             limited, | ||||||
|  |           }, | ||||||
|  |           navigate, | ||||||
|  |           originalStationList, | ||||||
|  |           openStationACFromEachTrainInfo, | ||||||
|  |         }; | ||||||
|  |         SheetManager.show("EachTrainInfo", { | ||||||
|  |           payload, | ||||||
|  |         }); | ||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|       default: { |       default: { | ||||||
| @@ -228,8 +255,8 @@ export default function Apps({ | |||||||
|     }, 1); |     }, 1); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   const openStationACFromEachTrainInfo = (stationName) => { |   const openStationACFromEachTrainInfo = async (stationName) => { | ||||||
|     EachTrainInfoAsSR.current?.hide(); |     await SheetManager.hide("EachTrainInfo"); | ||||||
|     const findStationEachLine = (selectLine) => { |     const findStationEachLine = (selectLine) => { | ||||||
|       let NearStation = selectLine.filter((d) => d.Station_JP == stationName); |       let NearStation = selectLine.filter((d) => d.Station_JP == stationName); | ||||||
|       return NearStation; |       return NearStation; | ||||||
| @@ -242,13 +269,24 @@ export default function Apps({ | |||||||
|         return pre; |         return pre; | ||||||
|       }, []); |       }, []); | ||||||
|     if (returnDataBase.length) { |     if (returnDataBase.length) { | ||||||
|       setStationBoardData(returnDataBase); |       const payload = { | ||||||
|       sleep(25, function () { |         currentStation: returnDataBase, | ||||||
|         StationBoardAcSR.current?.show(); |         originalStationList: originalStationList, | ||||||
|  |         navigate: navigate, | ||||||
|  |         goTo: "Apps", | ||||||
|  |         useShow: () => | ||||||
|  |           SheetManager.show("StationDetailView", { | ||||||
|  |             payload, | ||||||
|  |           }), | ||||||
|  |         onExit: () => { | ||||||
|  |           SheetManager.hide("StationDetailView"); | ||||||
|  |         }, | ||||||
|  |       }; | ||||||
|  |       SheetManager.show("StationDetailView", { | ||||||
|  |         payload, | ||||||
|       }); |       }); | ||||||
|     } else { |     } else { | ||||||
|       setStationBoardData(undefined); |       SheetManager.hide("StationDetailView"); | ||||||
|       StationBoardAcSR.current?.hide(); |  | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|   return ( |   return ( | ||||||
| @@ -256,8 +294,22 @@ export default function Apps({ | |||||||
|       style={{ |       style={{ | ||||||
|         height: "100%", |         height: "100%", | ||||||
|         paddingTop: Platform.OS == "ios" ? Constants.statusBarHeight : 0, |         paddingTop: Platform.OS == "ios" ? Constants.statusBarHeight : 0, | ||||||
|  |         flexDirection: isLandscape ? "row" : "column", | ||||||
|       }} |       }} | ||||||
|  |       onLayout={handleLayout} | ||||||
|     > |     > | ||||||
|  |       {!trainInfo.trainNum && isLandscape ? ( | ||||||
|  |         <TrainMenu | ||||||
|  |           webview={webview} | ||||||
|  |           stationData={stationData} | ||||||
|  |           navigation={{ navigate: null }} | ||||||
|  |           style={{ | ||||||
|  |             width: (width / 100) * 40, | ||||||
|  |             height: "100%", | ||||||
|  |             flexDirection: "column-reverse", | ||||||
|  |           }} | ||||||
|  |         /> | ||||||
|  |       ) : null} | ||||||
|       {/* {Status} */} |       {/* {Status} */} | ||||||
|       <WebView |       <WebView | ||||||
|         useWebKit |         useWebKit | ||||||
| @@ -274,7 +326,6 @@ export default function Apps({ | |||||||
|         onNavigationStateChange={onNavigationStateChange} |         onNavigationStateChange={onNavigationStateChange} | ||||||
|         onMessage={onMessage} |         onMessage={onMessage} | ||||||
|         injectedJavaScript={injectJavascript} |         injectedJavaScript={injectJavascript} | ||||||
|         onTouchMove={() => StationBoardAcSR.current?.hide()} |  | ||||||
|         onLoadEnd={() => { |         onLoadEnd={() => { | ||||||
|           if (once) return () => {}; |           if (once) return () => {}; | ||||||
|           if (!stationData) return () => {}; |           if (!stationData) return () => {}; | ||||||
| @@ -296,35 +347,51 @@ export default function Apps({ | |||||||
|           } |           } | ||||||
|         }} |         }} | ||||||
|       /> |       /> | ||||||
|  |       {isLandscape && trainInfo.trainNum && ( | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             width: (width / 100) * 40, | ||||||
|  |             height: height, | ||||||
|  |             flexDirection: "column", | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           <EachTrainInfoCore | ||||||
|  |             {...{ | ||||||
|  |               data: trainInfo.trainNum ? trainInfo : undefined, | ||||||
|  |               navigate, | ||||||
|  |               originalStationList, | ||||||
|  |               openStationACFromEachTrainInfo, | ||||||
|  |               from: "Train", | ||||||
|  |               setTrainInfo, | ||||||
|  |             }} | ||||||
|  |           /> | ||||||
|  |         </View> | ||||||
|  |       )} | ||||||
|  |       {isLandscape || ( | ||||||
|         <MapsButton |         <MapsButton | ||||||
|           onPress={() => navigate("trainMenu", { webview })} |           onPress={() => navigate("trainMenu", { webview })} | ||||||
|           top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} |           top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} | ||||||
|           mapSwitch={mapSwitch == "true" ? "flex" : "none"} |           mapSwitch={mapSwitch == "true" ? "flex" : "none"} | ||||||
|         /> |         /> | ||||||
|  |       )} | ||||||
|  |       {isLandscape && trainInfo.trainNum && ( | ||||||
|  |         <LandscapeBackButton | ||||||
|  |           onPress={() => { | ||||||
|  |             LayoutAnimation.easeInEaseOut(); | ||||||
|  |             setTrainInfo({ | ||||||
|  |               trainNum: undefined, | ||||||
|  |               limited: undefined, | ||||||
|  |               trainData: undefined, | ||||||
|  |             }); | ||||||
|  |           }} | ||||||
|  |           top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} | ||||||
|  |         /> | ||||||
|  |       )} | ||||||
|       <ReloadButton |       <ReloadButton | ||||||
|         onPress={() => webview.current.reload()} |         onPress={() => webview.current.reload()} | ||||||
|         top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} |         top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} | ||||||
|       /> |         right={isLandscape && trainInfo.trainNum ? (width / 100) * 40 : 0} | ||||||
|  |         LoadError={LoadError} | ||||||
|       <StationDeteilView |  | ||||||
|         StationBoardAcSR={StationBoardAcSR} |  | ||||||
|         currentStation={stationBoardData} |  | ||||||
|         originalStationList={originalStationList} |  | ||||||
|         favoriteStation={favoriteStation} |  | ||||||
|         setFavoriteStation={setFavoriteStation} |  | ||||||
|         busAndTrainData={busAndTrainData} |  | ||||||
|         navigate={navigate} |  | ||||||
|         onExit={() => { |  | ||||||
|           StationBoardAcSR.current?.setModalVisible(); |  | ||||||
|           navigate("Apps"); |  | ||||||
|         }} |  | ||||||
|       /> |  | ||||||
|       <EachTrainInfo |  | ||||||
|         setRef={EachTrainInfoAsSR} |  | ||||||
|         data={trainInfo} |  | ||||||
|         navigate={navigate} |  | ||||||
|         originalStationList={originalStationList} |  | ||||||
|         openStationACFromEachTrainInfo={openStationACFromEachTrainInfo} |  | ||||||
|       /> |       /> | ||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
| @@ -366,12 +433,12 @@ const MapsButton = ({ onPress, top, mapSwitch }) => { | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const ReloadButton = ({ onPress, top, mapSwitch }) => { | const LandscapeBackButton = ({ onPress, top }) => { | ||||||
|   const styles = { |   const styles = { | ||||||
|     touch: { |     touch: { | ||||||
|       position: "absolute", |       position: "absolute", | ||||||
|       top, |       top, | ||||||
|       right: 10, |       left: 10, | ||||||
|       width: 50, |       width: 50, | ||||||
|       height: 50, |       height: 50, | ||||||
|       backgroundColor: "#0099CC", |       backgroundColor: "#0099CC", | ||||||
| @@ -382,6 +449,48 @@ const ReloadButton = ({ onPress, top, mapSwitch }) => { | |||||||
|       alignContent: "center", |       alignContent: "center", | ||||||
|       alignSelf: "center", |       alignSelf: "center", | ||||||
|       alignItems: "center", |       alignItems: "center", | ||||||
|  |       display: "flex", | ||||||
|  |     }, | ||||||
|  |     text: { | ||||||
|  |       textAlign: "center", | ||||||
|  |       width: "auto", | ||||||
|  |       height: "auto", | ||||||
|  |       textAlignVertical: "center", | ||||||
|  |       fontWeight: "bold", | ||||||
|  |       color: "white", | ||||||
|  |     }, | ||||||
|  |   }; | ||||||
|  |   return ( | ||||||
|  |     <TouchableOpacity onPress={onPress} style={styles.touch}> | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |       <Ionicons name="arrow-back" color="white" size={30} /> | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |     </TouchableOpacity> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const ReloadButton = ({ | ||||||
|  |   onPress, | ||||||
|  |   top, | ||||||
|  |   mapSwitch, | ||||||
|  |   LoadError = false, | ||||||
|  |   right, | ||||||
|  | }) => { | ||||||
|  |   const styles = { | ||||||
|  |     touch: { | ||||||
|  |       position: "absolute", | ||||||
|  |       top, | ||||||
|  |       right: 10 + right, | ||||||
|  |       width: 50, | ||||||
|  |       height: 50, | ||||||
|  |       backgroundColor: LoadError ? "red" : "#0099CC", | ||||||
|  |       borderColor: "white", | ||||||
|  |       borderStyle: "solid", | ||||||
|  |       borderWidth: 1, | ||||||
|  |       borderRadius: 50, | ||||||
|  |       alignContent: "center", | ||||||
|  |       alignSelf: "center", | ||||||
|  |       alignItems: "center", | ||||||
|       display: mapSwitch, |       display: mapSwitch, | ||||||
|     }, |     }, | ||||||
|     text: { |     text: { | ||||||
|   | |||||||
							
								
								
									
										97
									
								
								MenuPage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								MenuPage.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | import React, { useEffect } from "react"; | ||||||
|  | import { | ||||||
|  |   createStackNavigator, | ||||||
|  |   TransitionPresets, | ||||||
|  | } from "@react-navigation/stack"; | ||||||
|  | import { AS } from "./storageControl"; | ||||||
|  | import TrainBase from "./trainbaseview"; | ||||||
|  | import HowTo from "./howto"; | ||||||
|  | import Menu from "./menu"; | ||||||
|  | import Setting from "./components/settings.js"; | ||||||
|  | import { useFavoriteStation } from "./stateBox/useFavoriteStation"; | ||||||
|  | import { optionData } from "./lib/stackOption.js"; | ||||||
|  | import CurrentTrainListView from "./components/CurrentTrainListView.js"; | ||||||
|  | import AllTrainDiagramView from "./components/AllTrainDiagramView.js"; | ||||||
|  | import { useCurrentTrain } from "./stateBox/useCurrentTrain.js"; | ||||||
|  | const Stack = createStackNavigator(); | ||||||
|  |  | ||||||
|  | export function MenuPage({ navigation }) { | ||||||
|  |   const { favoriteStation, setFavoriteStation } = useFavoriteStation(); | ||||||
|  |   const { getCurrentTrain } = useCurrentTrain(); | ||||||
|  |   useEffect(() => { | ||||||
|  |     const unsubscribe = navigation.addListener("tabPress", (e) => { | ||||||
|  |       AS.getItem("favoriteStation") | ||||||
|  |         .then((d) => { | ||||||
|  |           const returnData = JSON.parse(d); | ||||||
|  |           if (favoriteStation.toString() != d) { | ||||||
|  |             setFavoriteStation(returnData); | ||||||
|  |           } | ||||||
|  |         }) | ||||||
|  |         .catch((d) => console.log(d)); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     return unsubscribe; | ||||||
|  |   }, [navigation]); | ||||||
|  |   return ( | ||||||
|  |     <Stack.Navigator> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="menu" | ||||||
|  |         options={{ | ||||||
|  |           headerShown: false, | ||||||
|  |           gestureEnabled: true, | ||||||
|  |           headerTransparent: true, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <Menu {...props} getCurrentTrain={getCurrentTrain} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen name="setting" options={optionData}> | ||||||
|  |         {(props) => <Setting {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="trainbase" | ||||||
|  |         options={{ | ||||||
|  |           ...TransitionPresets.ModalPresentationIOS, | ||||||
|  |           cardOverlayEnabled: true, | ||||||
|  |           headerShown: false, | ||||||
|  |           gestureEnabled: true, | ||||||
|  |           headerTransparent: true, | ||||||
|  |           gestureResponseDistance: { vertical: 300 }, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <TrainBase {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="currentTrainIDList" | ||||||
|  |         options={{ | ||||||
|  |           ...TransitionPresets.ModalPresentationIOS, | ||||||
|  |           cardOverlayEnabled: true, | ||||||
|  |           headerShown: false, | ||||||
|  |           gestureEnabled: true, | ||||||
|  |           headerTransparent: true, | ||||||
|  |           gestureResponseDistance: { vertical: 300 }, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <CurrentTrainListView {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="AllTrainIDList" | ||||||
|  |         options={{ | ||||||
|  |           ...TransitionPresets.ModalPresentationIOS, | ||||||
|  |           cardOverlayEnabled: true, | ||||||
|  |           headerShown: false, | ||||||
|  |           headerTransparent: true, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <AllTrainDiagramView {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="howto" | ||||||
|  |         options={{ | ||||||
|  |           ...optionData, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <HowTo {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |     </Stack.Navigator> | ||||||
|  |   ); | ||||||
|  | } | ||||||
							
								
								
									
										100
									
								
								Top.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								Top.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | |||||||
|  | import React, { useEffect, useRef, useState } from "react"; | ||||||
|  | import { | ||||||
|  |   createStackNavigator, | ||||||
|  |   TransitionPresets, | ||||||
|  | } from "@react-navigation/stack"; | ||||||
|  | import { getStationList2 } from "./lib/getStationList2"; | ||||||
|  | import Apps from "./Apps"; | ||||||
|  | import TrainBase from "./trainbaseview"; | ||||||
|  | import HowTo from "./howto"; | ||||||
|  | import News from "./components/news.js"; | ||||||
|  | import TrainMenu from "./components/trainMenu.js"; | ||||||
|  | import FavoriteList from "./components/FavoriteList.js"; | ||||||
|  | import { useFavoriteStation } from "./stateBox/useFavoriteStation"; | ||||||
|  | import { optionData } from "./lib/stackOption.js"; | ||||||
|  | import { useCurrentTrain } from "./stateBox/useCurrentTrain.js"; | ||||||
|  | const Stack = createStackNavigator(); | ||||||
|  | export const Top = ({ navigation }) => { | ||||||
|  |   const webview = useRef(); | ||||||
|  |   const { favoriteStation, setFavoriteStation } = useFavoriteStation(); | ||||||
|  |   const { getCurrentTrain } = useCurrentTrain(); | ||||||
|  |  | ||||||
|  |   //地図用 | ||||||
|  |   const [mapsStationData, setMapsStationData] = useState(undefined); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     getStationList2().then(setMapsStationData); | ||||||
|  |   }, []); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     const unsubscribe = navigation.addListener("tabLongPress", (e) => { | ||||||
|  |       navigation.navigate("favoriteList"); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     return unsubscribe; | ||||||
|  |   }, [navigation]); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <Stack.Navigator> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="Apps" | ||||||
|  |         options={{ | ||||||
|  |           headerShown: false, | ||||||
|  |           gestureEnabled: true, | ||||||
|  |           headerTransparent: true, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => ( | ||||||
|  |           <Apps | ||||||
|  |             {...props} | ||||||
|  |             webview={webview} | ||||||
|  |             stationData={mapsStationData} | ||||||
|  |             getCurrentTrain={getCurrentTrain} | ||||||
|  |           /> | ||||||
|  |         )} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="trainbase" | ||||||
|  |         options={{ | ||||||
|  |           title: "トレインビジョン", | ||||||
|  |           gestureEnabled: true, | ||||||
|  |           ...TransitionPresets.SlideFromRightIOS, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <TrainBase {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="howto" | ||||||
|  |         options={{ | ||||||
|  |           ...optionData, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {(props) => <HowTo {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen name="news" options={optionData}> | ||||||
|  |         {(props) => <News {...props} />} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen name="trainMenu" options={optionData}> | ||||||
|  |         {(props) => ( | ||||||
|  |           <TrainMenu | ||||||
|  |             {...props} | ||||||
|  |             webview={webview} | ||||||
|  |             stationData={mapsStationData} | ||||||
|  |           /> | ||||||
|  |         )} | ||||||
|  |       </Stack.Screen> | ||||||
|  |       <Stack.Screen | ||||||
|  |         name="favoriteList" | ||||||
|  |         options={{ ...optionData, gestureEnabled: false }} | ||||||
|  |       > | ||||||
|  |         {(props) => ( | ||||||
|  |           <FavoriteList | ||||||
|  |             {...props} | ||||||
|  |             webview={webview} | ||||||
|  |             stationData={mapsStationData} | ||||||
|  |           /> | ||||||
|  |         )} | ||||||
|  |       </Stack.Screen> | ||||||
|  |     </Stack.Navigator> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										14
									
								
								app.json
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								app.json
									
									
									
									
									
								
							| @@ -7,8 +7,8 @@ | |||||||
|       "ios", |       "ios", | ||||||
|       "android" |       "android" | ||||||
|     ], |     ], | ||||||
|     "version": "4.5", |     "version": "4.6", | ||||||
|     "orientation": "portrait", |     "orientation": "default", | ||||||
|     "icon": "./assets/icon.png", |     "icon": "./assets/icon.png", | ||||||
|     "splash": { |     "splash": { | ||||||
|       "image": "./assets/splash.png", |       "image": "./assets/splash.png", | ||||||
| @@ -16,13 +16,14 @@ | |||||||
|       "backgroundColor": "#00b8ff" |       "backgroundColor": "#00b8ff" | ||||||
|     }, |     }, | ||||||
|     "updates": { |     "updates": { | ||||||
|       "fallbackToCacheTimeout": 0 |       "fallbackToCacheTimeout": 0, | ||||||
|  |       "url": "https://u.expo.dev/398abf60-57a7-11e9-970c-8f04356d08bf" | ||||||
|     }, |     }, | ||||||
|     "assetBundlePatterns": [ |     "assetBundlePatterns": [ | ||||||
|       "**/*" |       "**/*" | ||||||
|     ], |     ], | ||||||
|     "ios": { |     "ios": { | ||||||
|       "buildNumber": "28", |       "buildNumber": "31", | ||||||
|       "supportsTablet": true, |       "supportsTablet": true, | ||||||
|       "bundleIdentifier": "jrshikokuinfo.xprocess.hrkn", |       "bundleIdentifier": "jrshikokuinfo.xprocess.hrkn", | ||||||
|       "config": { |       "config": { | ||||||
| @@ -31,7 +32,7 @@ | |||||||
|     }, |     }, | ||||||
|     "android": { |     "android": { | ||||||
|       "package": "jrshikokuinfo.xprocess.hrkn", |       "package": "jrshikokuinfo.xprocess.hrkn", | ||||||
|       "versionCode": 18, |       "versionCode": 20, | ||||||
|       "permissions": [ |       "permissions": [ | ||||||
|         "ACCESS_FINE_LOCATION" |         "ACCESS_FINE_LOCATION" | ||||||
|       ], |       ], | ||||||
| @@ -46,6 +47,9 @@ | |||||||
|       "eas": { |       "eas": { | ||||||
|         "projectId": "398abf60-57a7-11e9-970c-8f04356d08bf" |         "projectId": "398abf60-57a7-11e9-970c-8f04356d08bf" | ||||||
|       } |       } | ||||||
|  |     }, | ||||||
|  |     "runtimeVersion": { | ||||||
|  |       "policy": "sdkVersion" | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1006,7 +1006,7 @@ | |||||||
| "9026M":"宇多津,発,18:36#坂出,発,18:40#高松,着,18:54#", | "9026M":"宇多津,発,18:36#坂出,発,18:40#高松,着,18:54#", | ||||||
| "9028M":"宇多津,発,19:38#坂出,発,19:43#高松,着,19:56#", | "9028M":"宇多津,発,19:38#坂出,発,19:43#高松,着,19:56#", | ||||||
| "9054D":"宇多津,発,9:00#坂出,発,9:07#高松,着,9:21#", | "9054D":"宇多津,発,9:00#坂出,発,9:07#高松,着,9:21#", | ||||||
| "9095D":"松山,発,10:35#伊予市,発,10:54#下灘,発,11:51#喜多灘,発,12:07#伊予白滝,発,12:42#伊予大洲,着,13:07#", | "9095D":"松山,発,10:34#伊予市,発,10:54#下灘,発,11:51#喜多灘,発,12:07#伊予白滝,発,12:42#伊予大洲,着,13:07#", | ||||||
| "9096D":"伊予大洲,発,13:30#伊予白滝,発,13:47#伊予長浜,発,14:24#喜多灘,発,14:36#下灘,発,15:09#伊予上灘,発,15:31#北伊予,発,15:54#松山,着,16:00#", | "9096D":"伊予大洲,発,13:30#伊予白滝,発,13:47#伊予長浜,発,14:24#喜多灘,発,14:36#下灘,発,15:09#伊予上灘,発,15:31#北伊予,発,15:54#松山,着,16:00#", | ||||||
| "9323D":"高松,発,9:32#栗林,発,9:53#屋島,発,10:24#八栗口,発,10:40#志度,発,11:32#造田,発,12:14#讃岐津田,発,12:36#三本松,発,13:02#讃岐相生,発,13:31#阿波大宮,発,13:46#板野,発,14:06#板東,発,14:24#池谷,発,14:33#勝瑞,発,14:43#徳島,着,14:56#", | "9323D":"高松,発,9:32#栗林,発,9:53#屋島,発,10:24#八栗口,発,10:40#志度,発,11:32#造田,発,12:14#讃岐津田,発,12:36#三本松,発,13:02#讃岐相生,発,13:31#阿波大宮,発,13:46#板野,発,14:06#板東,発,14:24#池谷,発,14:33#勝瑞,発,14:43#徳島,着,14:56#", | ||||||
| "9105D":"児島,発,13:44#坂出,発,14:10#鴨川,発,14:37#端岡,発,14:52#高松,着,15:01#", | "9105D":"児島,発,13:44#坂出,発,14:10#鴨川,発,14:37#端岡,発,14:52#高松,着,15:01#", | ||||||
| @@ -1035,8 +1035,32 @@ | |||||||
| "9666D":"北伊予,発,22:46#市坪,発,22:50#松山,着,22:55#", | "9666D":"北伊予,発,22:46#市坪,発,22:50#松山,着,22:55#", | ||||||
| "9668M":"市坪,発,23:00#松山,着,23:04#", | "9668M":"市坪,発,23:00#松山,着,23:04#", | ||||||
| "9052D":"窪川,発,15:13#土佐久礼,発,15:46#安和,発,15:57#須崎,発,16:25#佐川,発,16:54#日下,発,17:11#伊野,発,17:32#朝倉,発,17:42#高知,着,17:53#", | "9052D":"窪川,発,15:13#土佐久礼,発,15:46#安和,発,15:57#須崎,発,16:25#佐川,発,16:54#日下,発,17:11#伊野,発,17:32#朝倉,発,17:42#高知,着,17:53#", | ||||||
| "9062D":"大歩危,発,14:21#小歩危,発,14:38#阿波川口,発,15:01#阿波池田,発,15:26#坪尻,発,15:53#讃岐財田,発,16:15#琴平,着,16:31#", | "9062D":"大歩危,発,14:21#小歩危,発,14:38#阿波川口,発,15:01#阿波池田,発,15:26#坪尻,発,15:53#讃岐財田,発,16:15#琴平,発,16:50#善通寺,発,17:01#金蔵寺,発,17:09#多度津,着,17:14#", | ||||||
| "9920D":"伊予大洲,発,14:33#五郎,発,14:39#伊予白滝,発,14:59#伊予長浜,発,15:09#下灘,発,15:23#伊予上灘,発,15:30#伊予市,発,15:44#南伊予,発,15:49#北伊予,発,15:55#松山,着,16:01#", | "9920D":"伊予大洲,発,14:33#五郎,発,14:39#伊予白滝,発,14:59#伊予長浜,発,15:09#下灘,発,15:23#伊予上灘,発,15:30#伊予市,発,15:44#南伊予,発,15:49#北伊予,発,15:55#松山,着,16:01#", | ||||||
| "9051D":"高知,発,12:04#朝倉,発,12:29#伊野,発,12:49#日下,発,13:06#西佐川,発,13:21#須崎,発,13:45#安和,発,14:05#土佐久礼,発,14:17#影野,発,14:31#窪川,着,14:40#", | "9051D":"高知,発,12:04#朝倉,発,12:29#伊野,発,12:49#日下,発,13:06#西佐川,発,13:21#須崎,発,13:45#安和,発,14:05#土佐久礼,発,14:17#影野,発,14:31#窪川,着,14:40#", | ||||||
| "9061D":"琴平,発,10:48#讃岐財田,発,11:12#坪尻,発,11:41#阿波池田,発,12:10#三縄,発,12:19#大歩危,着,12:47#" | "9061D":"多度津,発,10:19#善通寺,発,10:26#琴平,発,10:48#讃岐財田,発,11:12#坪尻,発,11:41#阿波池田,発,12:10#三縄,発,12:19#大歩危,着,12:47#", | ||||||
|  | "9523D":"川之江,発,9:00#伊予三島,発,9:15#伊予寒川,発,9:31#伊予土居,発,10:03#関川,発,10:16#多喜浜,発,10:31#中萩,発,10:49#伊予西条,着,10:57#", | ||||||
|  | "9524D":"伊予西条,発,11:11#新居浜,発,11:35#伊予土居,発,11:59#伊予寒川,発,12:08#伊予三島,発,12:17#川之江,着,12:24#", | ||||||
|  | "9987D":"鳴門,発,22:15#撫養,発,22:18#金比羅前,発,22:21#教会前,発,22:24#立道,発,22:27#阿波大谷,発,22:31#池谷,発,22:36#勝瑞,発,22:41#吉成,発,22:44#佐古,発,22:57#徳島,着,23:00#", | ||||||
|  | "9093D":"松山,発,13:31#北伊予,発,13:42#下灘,発,14:22#喜多灘,発,14:38#伊予大洲,発,15:13#伊予平野,発,15:37#八幡浜,着,15:50#", | ||||||
|  | "9094D":"八幡浜,発,16:14#伊予大洲,発,16:33#伊予長浜,発,16:57#下灘,発,17:24#伊予上灘,発,17:36#伊予市,発,17:53#北伊予,発,18:03#市坪,発,18:12#松山,着,18:17#", | ||||||
|  | "9205D":"児島,発,15:10#宇多津,発,15:28#丸亀,発,15:31#多度津,発,15:36#琴平,発,15:47#讃岐財田,発,16:14#坪尻,発,16:35#佃,発,16:51#阿波池田,発,16:57#阿波川口,発,17:16#大歩危,発,17:35#大田口,発,17:58#大杉,発,18:30#土佐北川,発,18:47#繁藤,発,19:02#土佐山田,発,19:17#後免,発,19:22#土佐一宮,発,19:43#高知,着,19:47#", | ||||||
|  | "9204D":"高知,発,8:43#土佐一宮,発,8:49#繁藤,発,9:16#大杉,発,9:28#土佐岩原,発,9:48#大歩危,発,10:08#阿波川口,発,10:29#阿波池田,発,10:42#讃岐財田,発,11:09#琴平,発,11:33#金蔵寺,発,11:59#多度津,発,12:06#丸亀,発,12:10#児島,着,12:25#", | ||||||
|  | "9003M":"高松,発,8:45#坂出,発,9:02#宇多津,着,9:06#", | ||||||
|  | "9005D":"高松,発,9:42#坂出,発,9:56#宇多津,発,10:01#丸亀,発,10:05#多度津,着,10:10#", | ||||||
|  | "9004M":"宇多津,発,7:14#坂出,発,7:21#高松,着,7:36#", | ||||||
|  | "9006D":"宇多津,発,8:26#坂出,発,8:31#高松,着,8:45#", | ||||||
|  | "9253M":"児島,発,11:02#多度津,発,11:30#善通寺,発,11:54#琴平,着,12:00#", | ||||||
|  | "9256M":"琴平,発,15:20#善通寺,発,15:26#多度津,発,15:35#宇多津,発,15:44#児島,着,16:04#", | ||||||
|  | "9057M":"高松,発,18:27#坂出,発,18:41#宇多津,発,18:46#丸亀,発,18:49#多度津,着,18:55#", | ||||||
|  | "9054M":"宇多津,発,9:00#坂出,発,9:07#高松,着,9:21#", | ||||||
|  | //9001: "岡山,発,10:11#児島,発,11:05#坂出,発,11:41#高松,着,12:00#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  | 9001: "ウェルカムセレモニー,頃,9:40#岡山,頃,10:10#琴平,頃,14:00#琴平観光,以降,14:00#湯山荘 阿讃琴南,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第1章\n-瀬戸の海に想いを馳せながら-\n岡山・高松・琴平,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  | //9029: "高松,発,12:42#琴平,着,13:57#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  | 9029: "ウェルカムセレモニー,頃,9:40#岡山,頃,10:10#琴平,頃,14:00#琴平観光,以降,14:00#湯山荘 阿讃琴南,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第1章\n-瀬戸の海に想いを馳せながら-\n岡山・高松・琴平,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  | //9003: "多度津,発,10:09#今治,発,13:20#伊予亀岡,発,13:55#菊間,発,14:04#松山,着,14:50#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  | 9003: "湯山荘 阿讃琴南,頃,9:00#多度津,頃,10:10#松山,頃,14:50#宿泊施設,以降,14:50#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第2章\n -四国の伝統文化を感じて-\n多度津・坂出・松山,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  | 9055: "宿泊施設→バス,着,10:30#松山,頃,10:30#今治,頃,14:15#しまなみエリア観光,以降,14:15#Azumi Setoda,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第3章\n-凪の誘い・瀬戸内の絶景-\n今治・しまなみ海道,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  | 9056: "宿泊施設→バス,着,10:30#松山,頃,10:30#今治,頃,14:15#しまなみエリア観光,以降,14:15#Azumi Setoda,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第3章\n-凪の誘い・瀬戸内の絶景-\n今治・しまなみ海道,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  | 9004: "Azumi Setoda,頃,9:30#今治,頃,10:30#高松,頃,14:30#高松港\n↓\n瀬戸内クルーズ(貸切)\n「おりんぴあどりーむ せと」\n↓ \n 新岡山港,以降,14:15#岡山駅,頃,18:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS フィナーレ\n-四国・瀬戸内の彩りに囲まれて-\n今治・高松・岡山,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
| } | } | ||||||
| @@ -1,714 +1,23 @@ | |||||||
| import React, { useEffect, useState } from "react"; | import React, { useRef } from "react"; | ||||||
| import { | import { Platform } from "react-native"; | ||||||
|   View, |  | ||||||
|   LayoutAnimation, |  | ||||||
|   ScrollView, |  | ||||||
|   Linking, |  | ||||||
|   Text, |  | ||||||
|   TouchableOpacity, |  | ||||||
|   TouchableWithoutFeedback, |  | ||||||
|   TouchableHighlight, |  | ||||||
|   Platform, |  | ||||||
| } from "react-native"; |  | ||||||
| import { Ionicons, MaterialCommunityIcons } from "@expo/vector-icons"; |  | ||||||
| import ActionSheet from "react-native-actions-sheet"; | import ActionSheet from "react-native-actions-sheet"; | ||||||
| import { AS } from "../../storageControl"; | import { EachTrainInfoCore } from "./EachTrainInfoCore"; | ||||||
| import LottieView from "lottie-react-native"; | export const EachTrainInfo = (props) => { | ||||||
| import trainList from "../../assets/originData/trainList"; |   if (!props.payload) return <></>; | ||||||
| import { lineList } from "../../lib/getStationList"; |  | ||||||
| import { |  | ||||||
|   heightPercentageToDP, |  | ||||||
|   widthPercentageToDP, |  | ||||||
| } from "react-native-responsive-screen"; |  | ||||||
| import lineColorList from "../../assets/originData/lineColorList"; |  | ||||||
|  |  | ||||||
| export const EachTrainInfo = ({ |  | ||||||
|   setRef, |  | ||||||
|   data, |  | ||||||
|   navigate, |  | ||||||
|   originalStationList, |  | ||||||
|   openStationACFromEachTrainInfo, |  | ||||||
|   from, |  | ||||||
| }) => { |  | ||||||
|   const [trainData, setTrainData] = useState([]); |  | ||||||
|   const [isTop, setIsTop] = useState(true); |  | ||||||
|   const [currentPosition, setCurrentPosition] = useState([]); |  | ||||||
|  |  | ||||||
|   const [trainPositionSwitch, setTrainPositionSwitch] = useState("false"); |  | ||||||
|  |  | ||||||
|   useEffect(() => { |  | ||||||
|     //列車現在地アイコン表示スイッチ |  | ||||||
|     AS.getItem("trainPositionSwitch") |  | ||||||
|       .then((d) => { |  | ||||||
|         if (d) { |  | ||||||
|           setTrainPositionSwitch(d); |  | ||||||
|         } else { |  | ||||||
|         } |  | ||||||
|       }) |  | ||||||
|       .catch((d) => AS.setItem("trainPositionSwitch", "false")); |  | ||||||
|   }, []); |  | ||||||
|  |  | ||||||
|   const getStationData = (stationName) => { |  | ||||||
|     const Stations = stationList.map((a) => |  | ||||||
|       a.filter((d) => d.StationName == stationName) |  | ||||||
|     ); |  | ||||||
|     const Station = |  | ||||||
|       Stations && |  | ||||||
|       Stations.reduce((newArray, e) => { |  | ||||||
|         return newArray.concat(e); |  | ||||||
|       }, []); |  | ||||||
|     if (!Station[0]) return []; |  | ||||||
|     return Station.map((d) => d.StationNumber)[0]; |  | ||||||
|   }; |  | ||||||
|   useEffect(() => { |  | ||||||
|     //data.trainData.Pos = "鴨川~端岡"; //test |  | ||||||
|     if (!data.trainData?.Pos) return; |  | ||||||
|     if (data.trainData?.Pos.match("~")) { |  | ||||||
|       const pos = data.trainData?.Pos.replace("(下り)", "") |  | ||||||
|         .replace("(上り)", "") |  | ||||||
|         .split("~"); |  | ||||||
|       setCurrentPosition([getStationData(pos[0]), getStationData(pos[1])]); |  | ||||||
|     } else { |  | ||||||
|       setCurrentPosition([getStationData(data.trainData?.Pos)]); |  | ||||||
|     } |  | ||||||
|   }, [data.trainData]); |  | ||||||
|  |  | ||||||
|   const stationList = |  | ||||||
|     originalStationList && |  | ||||||
|     lineList.map((d) => |  | ||||||
|       originalStationList[d].map((a) => ({ |  | ||||||
|         StationNumber: a.StationNumber, |  | ||||||
|         StationName: a.Station_JP, |  | ||||||
|       })) |  | ||||||
|     ); |  | ||||||
|   const stopStationIDList = trainData.map((i, index) => { |  | ||||||
|     const [station, se, time] = i.split(","); |  | ||||||
|     const Stations = stationList.map((a) => |  | ||||||
|       a.filter((d) => d.StationName == station) |  | ||||||
|     ); |  | ||||||
|     const StationNumbers = |  | ||||||
|       Stations && |  | ||||||
|       Stations.reduce((newArray, e) => { |  | ||||||
|         return newArray.concat(e); |  | ||||||
|       }, []) |  | ||||||
|         .filter((d) => d.StationNumber) |  | ||||||
|         .map((d) => d.StationNumber); |  | ||||||
|     return StationNumbers[0]; |  | ||||||
|   }); |  | ||||||
|   function findReversalPoints(array) { |  | ||||||
|     // arrayは現在位置の駅ID(駅在宅の場合は1つの配列、駅間の場合は2つの配列) |  | ||||||
|     // stopStationIDListは停車駅の駅IDの配列 |  | ||||||
|     if (!stopStationIDList.length) return []; |  | ||||||
|     const arrayNumber = array.map((d) => ({ |  | ||||||
|       line: d |  | ||||||
|         .split("") |  | ||||||
|         .filter((s) => "A" < s && s < "Z") |  | ||||||
|         .join(""), |  | ||||||
|       ID: d |  | ||||||
|         .split("") |  | ||||||
|         .filter((s) => "0" <= s && s <= "9") |  | ||||||
|         .join(""), |  | ||||||
|     })); |  | ||||||
|     const stopStationIDListNumber = stopStationIDList.map((d) => { |  | ||||||
|       if (!d) return { line: [], ID: [] }; |  | ||||||
|       return { |  | ||||||
|         line: d |  | ||||||
|           .split("") |  | ||||||
|           .filter((s) => "A" < s && s < "Z") |  | ||||||
|           .join(""), |  | ||||||
|         ID: d |  | ||||||
|           .split("") |  | ||||||
|           .filter((s) => "0" <= s && s <= "9") |  | ||||||
|           .join(""), |  | ||||||
|       }; |  | ||||||
|     }); |  | ||||||
|     // 完全一致 |  | ||||||
|     if (array.length == 1) { |  | ||||||
|       const index = stopStationIDList.indexOf(array[0]); |  | ||||||
|       if (index != -1) return [index]; |  | ||||||
|       // 通過駅の場合 |  | ||||||
|       for (let i = 0; i < stopStationIDListNumber.length - 1; i++) { |  | ||||||
|         if (stopStationIDListNumber[i].ID < arrayNumber[0].ID) { |  | ||||||
|           if (stopStationIDListNumber[i + 1].ID > arrayNumber[0].ID) { |  | ||||||
|             return [i + 1]; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|         if (stopStationIDListNumber[i].ID > arrayNumber[0].ID) { |  | ||||||
|           if (stopStationIDListNumber[i + 1].ID < arrayNumber[0].ID) { |  | ||||||
|             return [i + 1]; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     // 駅間の場合 |  | ||||||
|     if (array.length == 2) { |  | ||||||
|       const index1 = stopStationIDList.indexOf(array[0]); |  | ||||||
|       const index2 = stopStationIDList.indexOf(array[1]); |  | ||||||
|       if (index1 != -1 && index2 != -1) { |  | ||||||
|         // 駅間で通過駅も無い場合 |  | ||||||
|         if (index1 < index2) { |  | ||||||
|           if (index1 + 1 == index2) { |  | ||||||
|             return [index2]; |  | ||||||
|           } else { |  | ||||||
|             const returnArray = []; |  | ||||||
|             for (let i = index1 + 1; i <= index2; i++) { |  | ||||||
|               returnArray.push(i); |  | ||||||
|             } |  | ||||||
|             return returnArray; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|         if (index1 > index2) { |  | ||||||
|           if (index2 + 1 == index1) return [index1]; |  | ||||||
|           else { |  | ||||||
|             const returnArray = []; |  | ||||||
|             for (let i = index2 + 1; i <= index1; i++) { |  | ||||||
|               returnArray.push(i); |  | ||||||
|             } |  | ||||||
|             return returnArray; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|       } else { |  | ||||||
|         const getNearStationID = (stationID) => { |  | ||||||
|           for (let i = 0; i <= stopStationIDListNumber.length; i++) { |  | ||||||
|             if (stopStationIDListNumber[i].ID < stationID) { |  | ||||||
|               if (stopStationIDListNumber[i + 1].ID > stationID) { |  | ||||||
|                 return i + 1; |  | ||||||
|               } |  | ||||||
|             } |  | ||||||
|             if (stopStationIDListNumber[i].ID > stationID) { |  | ||||||
|               if (stopStationIDListNumber[i + 1].ID < stationID) { |  | ||||||
|                 return i + 1; |  | ||||||
|               } |  | ||||||
|             } |  | ||||||
|           } |  | ||||||
|         }; |  | ||||||
|         let newIndex1 = index1; |  | ||||||
|         let newIndex2 = index2; |  | ||||||
|         if (index1 == -1) { |  | ||||||
|           newIndex1 = getNearStationID(arrayNumber[0].ID); |  | ||||||
|         } |  | ||||||
|         if (index2 == -1) { |  | ||||||
|           newIndex2 = getNearStationID(arrayNumber[1].ID); |  | ||||||
|         } |  | ||||||
|         if (newIndex1 && newIndex2) { |  | ||||||
|           return [newIndex1, newIndex2]; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 通過駅の場合 |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       return []; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|   // 使用例 |  | ||||||
|   const points = |  | ||||||
|     trainPositionSwitch == "true" ? findReversalPoints(currentPosition) : []; |  | ||||||
|  |  | ||||||
|   useEffect(() => { |  | ||||||
|     setIsTop(true); |  | ||||||
|     if (!data.trainNum) return; |  | ||||||
|     const TD = trainList[data.trainNum]; |  | ||||||
|     if (!TD) { |  | ||||||
|       setTrainData([]); |  | ||||||
|       return; |  | ||||||
|     } |  | ||||||
|     setTrainData(TD.split("#").filter((d) => d != "")); |  | ||||||
|   }, [data]); |  | ||||||
|   const getType = (string) => { |  | ||||||
|     switch (string) { |  | ||||||
|       case "express": |  | ||||||
|         return "特急"; |  | ||||||
|       case "rapid": |  | ||||||
|         return "快速"; |  | ||||||
|       default: |  | ||||||
|         return ""; |  | ||||||
|     } |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   const migrateTrainName = (string) => { |  | ||||||
|     return string |  | ||||||
|       .replace("マリン", "マリンライナー") |  | ||||||
|       .replace("ライナーライナー", "ライナー"); |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|  |   const actionSheetRef = useRef(null); | ||||||
|   return ( |   return ( | ||||||
|     <ActionSheet |     <ActionSheet | ||||||
|       ref={setRef} |       gestureEnabled={true} | ||||||
|       gestureEnabled={isTop} |       //gestureEnabled={!actionSheetHorizonalScroll} | ||||||
|       CustomHeaderComponent={<></>} |       CustomHeaderComponent={<></>} | ||||||
|     > |       ref={actionSheetRef} | ||||||
|       <View |       drawUnderStatusBar={false} | ||||||
|         style={{ |       isModal={Platform.OS == "ios"} | ||||||
|           backgroundColor: "#0099CC", |  | ||||||
|           borderRadius: 5, |  | ||||||
|           borderColor: "dark", |  | ||||||
|           borderWidth: 1, |  | ||||||
|         }} |  | ||||||
|       > |  | ||||||
|         <View style={{ height: 26, width: "100%" }}> |  | ||||||
|           <View |  | ||||||
|             style={{ |  | ||||||
|               height: 6, |  | ||||||
|               width: 45, |  | ||||||
|               borderRadius: 100, |  | ||||||
|               backgroundColor: "#f0f0f0", |  | ||||||
|               marginVertical: 10, |  | ||||||
|               alignSelf: "center", |  | ||||||
|             }} |  | ||||||
|           /> |  | ||||||
|         </View> |  | ||||||
|         <View |  | ||||||
|           style={{ padding: 10, flexDirection: "row", alignItems: "center" }} |  | ||||||
|         > |  | ||||||
|           <Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}> |  | ||||||
|             {data.limited |  | ||||||
|               ? getType(data.limited.split(":")[0]) + |  | ||||||
|                 migrateTrainName( |  | ||||||
|                   data.limited.split(":")[1] || |  | ||||||
|                     (trainData.length > 0 |  | ||||||
|                       ? trainData[trainData.length - 1].split(",")[0] + "行き" |  | ||||||
|                       : " ") |  | ||||||
|                 ) |  | ||||||
|               : ""} |  | ||||||
|           </Text> |  | ||||||
|           <View style={{ flex: 1 }} /> |  | ||||||
|           <Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}> |  | ||||||
|             {data.trainNum} |  | ||||||
|           </Text> |  | ||||||
|           {data.limited != undefined && |  | ||||||
|             getType(data.limited.split(":")[0]) && |  | ||||||
|             !data.limited.split(":")[1].match("サンポート") && ( |  | ||||||
|               <Ionicons |  | ||||||
|                 name="subway" |  | ||||||
|                 color="white" |  | ||||||
|                 size={30} |  | ||||||
|                 style={{ margin: 5 }} |  | ||||||
|                 onPress={() => { |  | ||||||
|                   LayoutAnimation.easeInEaseOut(); //setLoadingDelayData(true); |  | ||||||
|                   navigate("trainbase", { |  | ||||||
|                     info: "train.html?tn=" + data.trainNum, |  | ||||||
|                     from, |  | ||||||
|                   }); |  | ||||||
|                   setRef.current?.hide(); |  | ||||||
|                 }} |  | ||||||
|               /> |  | ||||||
|             )} |  | ||||||
|         </View> |  | ||||||
|         <ScrollView |  | ||||||
|           style={{ |  | ||||||
|             flexDirection: "row", |  | ||||||
|             //width: widthPercentageToDP("200%"), |  | ||||||
|             minHeight: 200, |  | ||||||
|             height: heightPercentageToDP("20%"), |  | ||||||
|           }} |  | ||||||
|           horizontal |  | ||||||
|           pagingEnabled |  | ||||||
|         > |  | ||||||
|           <View |  | ||||||
|             style={{ |  | ||||||
|               flexDirection: "row", |  | ||||||
|               minHeight: 200, |  | ||||||
|               height: heightPercentageToDP("20%"), |  | ||||||
|               width: widthPercentageToDP("100%"), |  | ||||||
|             }} |  | ||||||
|           > |  | ||||||
|             <View |  | ||||||
|               style={{ |  | ||||||
|                 flex: 1, |  | ||||||
|                 backgroundColor: "white", |  | ||||||
|                 borderRadius: 10, |  | ||||||
|                 padding: 10, |  | ||||||
|                 margin: 10, |  | ||||||
|               }} |  | ||||||
|             > |  | ||||||
|               <Text style={{ fontSize: 15, color: "#0099CC" }}> |  | ||||||
|                 現在地 {currentPosition.toString()} |  | ||||||
|               </Text> |  | ||||||
|               <View style={{ flex: 1 }} /> |  | ||||||
|               {data.trainData?.Pos && data.trainData?.Pos.match("~") ? ( |  | ||||||
|                 <> |  | ||||||
|                   <Text |  | ||||||
|                     style={{ |  | ||||||
|                       fontSize: 28, |  | ||||||
|                       color: "#0099CC", |  | ||||||
|                       textAlign: "right", |  | ||||||
|                     }} |  | ||||||
|                   > |  | ||||||
|                     { |  | ||||||
|                       data.trainData?.Pos.replace("(下り)", "") |  | ||||||
|                         .replace("(上り)", "") |  | ||||||
|                         .split("~")[0] |  | ||||||
|                     } |  | ||||||
|                   </Text> |  | ||||||
|                   <Text style={{ color: "#0099CC", textAlign: "right" }}> |  | ||||||
|                     ~ |  | ||||||
|                   </Text> |  | ||||||
|                   <Text |  | ||||||
|                     style={{ |  | ||||||
|                       fontSize: 28, |  | ||||||
|                       color: "#0099CC", |  | ||||||
|                       textAlign: "right", |  | ||||||
|                     }} |  | ||||||
|                   > |  | ||||||
|                     { |  | ||||||
|                       data.trainData?.Pos.replace("(下り)", "") |  | ||||||
|                         .replace("(上り)", "") |  | ||||||
|                         .split("~")[1] |  | ||||||
|                     } |  | ||||||
|                   </Text> |  | ||||||
|                 </> |  | ||||||
|               ) : ( |  | ||||||
|                 <Text |  | ||||||
|                   style={{ fontSize: 28, color: "#0099CC", textAlign: "right" }} |  | ||||||
|                 > |  | ||||||
|                   {data.trainData?.Pos} |  | ||||||
|                 </Text> |  | ||||||
|               )} |  | ||||||
|             </View> |  | ||||||
|             <View style={{ flex: 1, flexDirection: "column" }}> |  | ||||||
|               <View |  | ||||||
|                 style={{ |  | ||||||
|                   flex: 1, |  | ||||||
|                   backgroundColor: "white", |  | ||||||
|                   borderRadius: 10, |  | ||||||
|                   padding: 10, |  | ||||||
|                   margin: 10, |  | ||||||
|                 }} |  | ||||||
|               > |  | ||||||
|                 <Text style={{ fontSize: 15, color: "#0099CC" }}> |  | ||||||
|                   {isNaN(data.trainData?.delay) ? "状態" : "遅延時分"} |  | ||||||
|                 </Text> |  | ||||||
|                 <View style={{ flex: 1 }} /> |  | ||||||
|                 <Text |  | ||||||
|                   style={{ |  | ||||||
|                     fontSize: 32, |  | ||||||
|                     color: "#0099CC", |  | ||||||
|                     textAlign: "right", |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   {data.trainData?.delay} |  | ||||||
|                   {isNaN(data.trainData?.delay) ? "" : "分"} |  | ||||||
|                 </Text> |  | ||||||
|               </View> |  | ||||||
|               <View |  | ||||||
|                 style={{ |  | ||||||
|                   flex: 1, |  | ||||||
|                   backgroundColor: "white", |  | ||||||
|                   borderRadius: 10, |  | ||||||
|                   padding: 10, |  | ||||||
|                   margin: 10, |  | ||||||
|                 }} |  | ||||||
|               > |  | ||||||
|                 <Text style={{ fontSize: 15, color: "#0099CC" }}>列番</Text> |  | ||||||
|                 <Text |  | ||||||
|                   style={{ |  | ||||||
|                     fontSize: 32, |  | ||||||
|                     color: "#0099CC", |  | ||||||
|                     textAlign: "right", |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   {data.trainData?.num} |  | ||||||
|                 </Text> |  | ||||||
|               </View> |  | ||||||
|             </View> |  | ||||||
|           </View> |  | ||||||
|           {/* <View |  | ||||||
|             style={{ |  | ||||||
|               flexDirection: "column", |  | ||||||
|               height: heightPercentageToDP("20%"), |  | ||||||
|               flex: 1, |  | ||||||
|               width: widthPercentageToDP("100%"), |  | ||||||
|             }} |  | ||||||
|           > |  | ||||||
|             <View style={{ flex: 1, flexDirection: "row" }}> |  | ||||||
|               <View |  | ||||||
|                 style={{ |  | ||||||
|                   flex: 1, |  | ||||||
|                   backgroundColor: "white", |  | ||||||
|                   borderRadius: 10, |  | ||||||
|                   padding: 10, |  | ||||||
|                   margin: 10, |  | ||||||
|                 }} |  | ||||||
|               > |  | ||||||
|                 <Text style={{ fontSize: 15, color: "#0099CC" }}>行先</Text> |  | ||||||
|                 <View style={{ flex: 1 }} /> |  | ||||||
|                 <Text |  | ||||||
|                   style={{ |  | ||||||
|                     fontSize: 20, |  | ||||||
|                     color: "#0099CC", |  | ||||||
|                     textAlign: "right", |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   岡山 |  | ||||||
|                 </Text> |  | ||||||
|               </View> |  | ||||||
|  |  | ||||||
|               <View |       //useBottomSafeAreaPadding={Platform.OS == "android"} | ||||||
|                 style={{ |  | ||||||
|                   flex: 3, |  | ||||||
|                   backgroundColor: "white", |  | ||||||
|                   borderRadius: 10, |  | ||||||
|                   padding: 10, |  | ||||||
|                   margin: 10, |  | ||||||
|                 }} |  | ||||||
|     > |     > | ||||||
|                 <Text style={{ fontSize: 15, color: "#0099CC" }}>車両案内</Text> |       <EachTrainInfoCore {...{ actionSheetRef, ...props.payload }} /> | ||||||
|                 <View style={{ flex: 1 }} /> |  | ||||||
|                 <Text |  | ||||||
|                   style={{ |  | ||||||
|                     fontSize: 20, |  | ||||||
|                     color: "#0099CC", |  | ||||||
|                     textAlign: "right", |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   宇多津でうずしお号と連結 |  | ||||||
|                 </Text> |  | ||||||
|               </View> |  | ||||||
|             </View> |  | ||||||
|             <View style={{ flex: 1, flexDirection: "row" }}> |  | ||||||
|               <View |  | ||||||
|                 style={{ |  | ||||||
|                   flex: 1, |  | ||||||
|                   backgroundColor: "white", |  | ||||||
|                   borderRadius: 10, |  | ||||||
|                   padding: 10, |  | ||||||
|                   margin: 10, |  | ||||||
|                 }} |  | ||||||
|               > |  | ||||||
|                 <Text style={{ fontSize: 15, color: "#0099CC" }}> |  | ||||||
|                   編成(使用車両:2700系) |  | ||||||
|                 </Text> |  | ||||||
|                 <View style={{ flex: 1 }} /> |  | ||||||
|                 <Text |  | ||||||
|                   style={{ |  | ||||||
|                     fontSize: 20, |  | ||||||
|                     color: "#0099CC", |  | ||||||
|                     textAlign: "left", |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   {"[<自][自>][アン自|指>][アン指|G>]"} |  | ||||||
|                 </Text> |  | ||||||
|               </View> |  | ||||||
|             </View> |  | ||||||
|           </View> */} |  | ||||||
|         </ScrollView> |  | ||||||
|         <ScrollView |  | ||||||
|           style={{ maxHeight: heightPercentageToDP("55%") }} |  | ||||||
|           nestedScrollEnabled |  | ||||||
|           onScroll={(e) => { |  | ||||||
|             if (!Platform.OS !== "android") return; |  | ||||||
|             setIsTop(e.nativeEvent.contentOffset.y < 0); |  | ||||||
|           }} |  | ||||||
|         > |  | ||||||
|           <View |  | ||||||
|             style={{ |  | ||||||
|               padding: 10, |  | ||||||
|               backgroundColor: "white", |  | ||||||
|               borderBottomLeftRadius: 5, |  | ||||||
|               borderBottomRightRadius: 5, |  | ||||||
|             }} |  | ||||||
|           > |  | ||||||
|             <View style={{ alignItems: "center" }}> |  | ||||||
|               {/* <LottieView |  | ||||||
|                 autoPlay |  | ||||||
|                 loop |  | ||||||
|                 style={{ width: 150, height: 150, backgroundColor: "#fff" }} |  | ||||||
|                 source={require("../../assets/51690-loading-diamonds.json")} |  | ||||||
|               /> |  | ||||||
|               <Text>ほげほげふがふが</Text> */} |  | ||||||
|               <View style={{ flexDirection: "row" }}> |  | ||||||
|                 <View |  | ||||||
|                   style={{ |  | ||||||
|                     padding: 8, |  | ||||||
|                     flexDirection: "row", |  | ||||||
|                     borderBottomWidth: 1, |  | ||||||
|                     borderBottomColor: "#f0f0f0", |  | ||||||
|                     flex: 1, |  | ||||||
|                   }} |  | ||||||
|                 > |  | ||||||
|                   <Text style={{ fontSize: 20 }}>停車駅</Text> |  | ||||||
|                   <View style={{ flex: 1 }} /> |  | ||||||
|                   <View style={{ flexDirection: "row" }}> |  | ||||||
|                     {!isNaN(data.trainData?.delay) && |  | ||||||
|                       data.trainData?.delay != 0 && ( |  | ||||||
|                         <Text |  | ||||||
|                           style={{ |  | ||||||
|                             fontSize: 15, |  | ||||||
|                             color: "black", |  | ||||||
|                             position: "absolute", |  | ||||||
|                             right: 110, |  | ||||||
|                             textAlign: "right", |  | ||||||
|                             textDecorationLine: "line-through", |  | ||||||
|                           }} |  | ||||||
|                         > |  | ||||||
|                           (定刻) |  | ||||||
|                         </Text> |  | ||||||
|                       )} |  | ||||||
|                     <Text |  | ||||||
|                       style={{ |  | ||||||
|                         fontSize: 20, |  | ||||||
|                         color: isNaN(data.trainData?.delay) |  | ||||||
|                           ? "black" |  | ||||||
|                           : data.trainData?.delay == 0 |  | ||||||
|                           ? "black" |  | ||||||
|                           : "red", |  | ||||||
|                         width: 60, |  | ||||||
|                       }} |  | ||||||
|                     > |  | ||||||
|                       見込 |  | ||||||
|                     </Text> |  | ||||||
|                     <Text style={{ fontSize: 20, width: 50 }}></Text> |  | ||||||
|                   </View> |  | ||||||
|                 </View> |  | ||||||
|               </View> |  | ||||||
|               {trainData.map((i, index) => { |  | ||||||
|                 const [station, se, time] = i.split(","); |  | ||||||
|                 const Stations = stationList.map((a) => |  | ||||||
|                   a.filter((d) => d.StationName == station) |  | ||||||
|                 ); |  | ||||||
|                 const StationNumbers = |  | ||||||
|                   Stations && |  | ||||||
|                   Stations.reduce((newArray, e) => { |  | ||||||
|                     return newArray.concat(e); |  | ||||||
|                   }, []) |  | ||||||
|                     .filter((d) => d.StationNumber) |  | ||||||
|                     .map((d) => d.StationNumber); |  | ||||||
|  |  | ||||||
|                 const colorIDs = |  | ||||||
|                   StationNumbers != null |  | ||||||
|                     ? StationNumbers.map((d) => { |  | ||||||
|                         return d.split("").filter((s) => "A" < s && s < "Z"); |  | ||||||
|                       }).reduce((newArray, e) => { |  | ||||||
|                         return newArray.concat(e); |  | ||||||
|                       }, []) |  | ||||||
|                     : []; |  | ||||||
|                 const EachIDs = |  | ||||||
|                   StationNumbers != null |  | ||||||
|                     ? StationNumbers.map((d) => { |  | ||||||
|                         return d |  | ||||||
|                           .split("") |  | ||||||
|                           .filter((s) => "0" <= s && s <= "9") |  | ||||||
|                           .join(""); |  | ||||||
|                       }) |  | ||||||
|                     : []; |  | ||||||
|                 const date = new Date(); |  | ||||||
|                 if (time) { |  | ||||||
|                   date.setHours(time.split(":")[0], time.split(":")[1]); |  | ||||||
|                 } |  | ||||||
|                 if (!isNaN(data.trainData?.delay)) { |  | ||||||
|                   date.setMinutes(date.getMinutes() + data.trainData?.delay); |  | ||||||
|                 } |  | ||||||
|                 const timeString = date.toTimeString().split(" ")[0].split(":"); |  | ||||||
|                 return ( |  | ||||||
|                   <TouchableWithoutFeedback |  | ||||||
|                     onPress={() => openStationACFromEachTrainInfo(station)} |  | ||||||
|                     key={station} |  | ||||||
|                   > |  | ||||||
|                     <View style={{ flexDirection: "row" }}> |  | ||||||
|                       <View |  | ||||||
|                         style={{ |  | ||||||
|                           width: 35, |  | ||||||
|                           position: "relative", |  | ||||||
|                           marginHorizontal: 15, |  | ||||||
|                           flexDirection: "row", |  | ||||||
|                           height: "101%", |  | ||||||
|                         }} |  | ||||||
|                       > |  | ||||||
|                         {colorIDs.map((color, index) => ( |  | ||||||
|                           <View |  | ||||||
|                             style={{ |  | ||||||
|                               backgroundColor: lineColorList[color], |  | ||||||
|                               flex: 1, |  | ||||||
|                             }} |  | ||||||
|                             key={color} |  | ||||||
|                           > |  | ||||||
|                             <View style={{ flex: 1 }} /> |  | ||||||
|                             <Text |  | ||||||
|                               style={{ |  | ||||||
|                                 color: "white", |  | ||||||
|                                 textAlign: "center", |  | ||||||
|                                 fontSize: 10, |  | ||||||
|                                 fontWeight: "bold", |  | ||||||
|                               }} |  | ||||||
|                             > |  | ||||||
|                               {colorIDs[index]} |  | ||||||
|                             </Text> |  | ||||||
|                             <Text |  | ||||||
|                               style={{ |  | ||||||
|                                 color: "white", |  | ||||||
|                                 textAlign: "center", |  | ||||||
|                                 fontSize: 10, |  | ||||||
|                                 fontWeight: "bold", |  | ||||||
|                               }} |  | ||||||
|                             > |  | ||||||
|                               {EachIDs[index]} |  | ||||||
|                             </Text> |  | ||||||
|                             <View style={{ flex: 1 }} /> |  | ||||||
|                           </View> |  | ||||||
|                         ))} |  | ||||||
|                       </View> |  | ||||||
|                       <View |  | ||||||
|                         style={{ |  | ||||||
|                           padding: 8, |  | ||||||
|                           flexDirection: "row", |  | ||||||
|                           borderBottomWidth: 1, |  | ||||||
|                           borderBottomColor: "#f0f0f0", |  | ||||||
|                           flex: 1, |  | ||||||
|                         }} |  | ||||||
|                       > |  | ||||||
|                         <Text style={{ fontSize: 20 }}>{station}</Text> |  | ||||||
|                         <View style={{ flex: 1 }} /> |  | ||||||
|                         {points.findIndex((d) => d == index) >= 0 ? ( |  | ||||||
|                           <Text |  | ||||||
|                             style={{ |  | ||||||
|                               fontSize: 20, |  | ||||||
|                               marginRight: 70, |  | ||||||
|                             }} |  | ||||||
|                           > |  | ||||||
|                             🚊 |  | ||||||
|                           </Text> |  | ||||||
|                         ) : null} |  | ||||||
|                         {!isNaN(data.trainData?.delay) && |  | ||||||
|                           data.trainData?.delay != 0 && ( |  | ||||||
|                             <Text |  | ||||||
|                               style={{ |  | ||||||
|                                 fontSize: 15, |  | ||||||
|                                 color: "black", |  | ||||||
|                                 width: 60, |  | ||||||
|                                 position: "absolute", |  | ||||||
|                                 right: 120, |  | ||||||
|                                 textAlign: "right", |  | ||||||
|                                 textDecorationLine: "line-through", |  | ||||||
|                               }} |  | ||||||
|                             > |  | ||||||
|                               {time} |  | ||||||
|                             </Text> |  | ||||||
|                           )} |  | ||||||
|                         <Text |  | ||||||
|                           style={{ |  | ||||||
|                             fontSize: 20, |  | ||||||
|                             color: isNaN(data.trainData?.delay) |  | ||||||
|                               ? "black" |  | ||||||
|                               : data.trainData?.delay == 0 |  | ||||||
|                               ? "black" |  | ||||||
|                               : "red", |  | ||||||
|                             width: 60, |  | ||||||
|                           }} |  | ||||||
|                         > |  | ||||||
|                           {timeString[0]}:{timeString[1]} |  | ||||||
|                         </Text> |  | ||||||
|                         <Text style={{ fontSize: 18, width: 50 }}> |  | ||||||
|                           {se?.replace("発", "出発").replace("着", "到着")} |  | ||||||
|                         </Text> |  | ||||||
|                       </View> |  | ||||||
|                     </View> |  | ||||||
|                   </TouchableWithoutFeedback> |  | ||||||
|                 ); |  | ||||||
|               })} |  | ||||||
|             </View> |  | ||||||
|           </View> |  | ||||||
|         </ScrollView> |  | ||||||
|       </View> |  | ||||||
|     </ActionSheet> |     </ActionSheet> | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -0,0 +1,36 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { View, Text, TouchableWithoutFeedback } from "react-native"; | ||||||
|  | import { MaterialCommunityIcons } from "@expo/vector-icons"; | ||||||
|  | import { Linking } from "react-native"; | ||||||
|  | export const DataFromButton = ({ i }) => { | ||||||
|  |   const [station, se, time] = i.split(","); | ||||||
|  |   return ( | ||||||
|  |     <TouchableWithoutFeedback | ||||||
|  |       onPress={() => Linking.openURL(time)} | ||||||
|  |       key={station} | ||||||
|  |     > | ||||||
|  |       <View style={{ flexDirection: "row" }}> | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             padding: 8, | ||||||
|  |             flexDirection: "row", | ||||||
|  |             borderBottomWidth: 1, | ||||||
|  |             borderBottomColor: "#f0f0f0", | ||||||
|  |             flex: 1, | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           <Text style={{ fontSize: 20 }}>{station}</Text> | ||||||
|  |           <View style={{ flex: 1 }} /> | ||||||
|  |           <Text style={{ fontSize: 18 }}> | ||||||
|  |             提供元 | ||||||
|  |             <MaterialCommunityIcons | ||||||
|  |               name={"open-in-new"} | ||||||
|  |               color="black" | ||||||
|  |               size={20} | ||||||
|  |             /> | ||||||
|  |           </Text> | ||||||
|  |         </View> | ||||||
|  |       </View> | ||||||
|  |     </TouchableWithoutFeedback> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										137
									
								
								components/ActionSheetComponents/EachTrainInfo/EachStopList.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								components/ActionSheetComponents/EachTrainInfo/EachStopList.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,137 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { View, Text, TouchableWithoutFeedback } from "react-native"; | ||||||
|  | import dayjs from "dayjs"; | ||||||
|  | import lineColorList from "../../../assets/originData/lineColorList"; | ||||||
|  |  | ||||||
|  | export const EachStopList = ({ | ||||||
|  |   i, | ||||||
|  |   index, | ||||||
|  |   stationList, | ||||||
|  |   points, | ||||||
|  |   currentTrainData, | ||||||
|  |   openStationACFromEachTrainInfo, | ||||||
|  | }) => { | ||||||
|  |   const [station, se, time] = i.split(","); // 阿波池田,発,6:21 | ||||||
|  |   const Stations = stationList | ||||||
|  |     .map((a) => a.filter((d) => d.StationName == station)) | ||||||
|  |     .reduce((newArray, e) => newArray.concat(e), []); | ||||||
|  |   /*Array [ | ||||||
|  |         Object { | ||||||
|  |           "StationName": "佐古", | ||||||
|  |           "StationNumber": "T01", | ||||||
|  |         }, | ||||||
|  |         Object { | ||||||
|  |           "StationName": "佐古", | ||||||
|  |           "StationNumber": "B01", | ||||||
|  |         }, | ||||||
|  |       ] */ | ||||||
|  |   const StationNumbers = | ||||||
|  |     Stations && | ||||||
|  |     Stations.filter((d) => d.StationNumber).map((d) => d.StationNumber); | ||||||
|  |   // Array [  "T01",  "B01",] | ||||||
|  |   const lineIDs = []; | ||||||
|  |   const EachIDs = []; | ||||||
|  |   StationNumbers.forEach((d) => { | ||||||
|  |     const textArray = d.split(""); | ||||||
|  |     lineIDs.push(textArray.filter((s) => "A" < s && s < "Z").join("")); | ||||||
|  |     EachIDs.push(textArray.filter((s) => "0" <= s && s <= "9").join("")); | ||||||
|  |   }); | ||||||
|  |   // Array [  "T",  "B",] | ||||||
|  |   // Array [  "01",  "01",] | ||||||
|  |  | ||||||
|  |   const dates = dayjs() | ||||||
|  |     .set("hour", parseInt(time.split(":")[0])) | ||||||
|  |     .set("minute", parseInt(time.split(":")[1])) | ||||||
|  |     .add(isNaN(currentTrainData?.delay) ? 0 : currentTrainData.delay, "minute"); | ||||||
|  |   const timeString = dates.format("HH:mm").split(":"); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <TouchableWithoutFeedback | ||||||
|  |       onPress={() => openStationACFromEachTrainInfo(station)} | ||||||
|  |       key={station} | ||||||
|  |     > | ||||||
|  |       <View style={{ flexDirection: "row", backgroundColor: "white" }}> | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             width: 35, | ||||||
|  |             position: "relative", | ||||||
|  |             marginHorizontal: 15, | ||||||
|  |             flexDirection: "row", | ||||||
|  |             height: "101%", | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           {lineIDs.map((lineID, index) => ( | ||||||
|  |             <View | ||||||
|  |               style={{ | ||||||
|  |                 backgroundColor: lineColorList[lineID], | ||||||
|  |                 flex: 1, | ||||||
|  |               }} | ||||||
|  |               key={lineID} | ||||||
|  |             > | ||||||
|  |               <View style={{ flex: 1 }} /> | ||||||
|  |               <Text | ||||||
|  |                 style={{ | ||||||
|  |                   color: "white", | ||||||
|  |                   textAlign: "center", | ||||||
|  |                   fontSize: 10, | ||||||
|  |                   fontWeight: "bold", | ||||||
|  |                 }} | ||||||
|  |               > | ||||||
|  |                 {lineIDs[index]} | ||||||
|  |                 {"\n"} | ||||||
|  |                 {EachIDs[index]} | ||||||
|  |               </Text> | ||||||
|  |               <View style={{ flex: 1 }} /> | ||||||
|  |             </View> | ||||||
|  |           ))} | ||||||
|  |         </View> | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             padding: 8, | ||||||
|  |             flexDirection: "row", | ||||||
|  |             borderBottomWidth: 1, | ||||||
|  |             borderBottomColor: "#f0f0f0", | ||||||
|  |             flex: 1, | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           <Text style={{ fontSize: 20 }}>{station}</Text> | ||||||
|  |           <View style={{ flex: 1 }} /> | ||||||
|  |           {points && points.findIndex((d) => d == index) >= 0 ? ( | ||||||
|  |             <Text style={{ fontSize: 20, marginRight: 70 }}>🚊</Text> | ||||||
|  |           ) : null} | ||||||
|  |           {!isNaN(currentTrainData?.delay) && currentTrainData?.delay != 0 && ( | ||||||
|  |             <Text | ||||||
|  |               style={{ | ||||||
|  |                 fontSize: 15, | ||||||
|  |                 color: "black", | ||||||
|  |                 width: 60, | ||||||
|  |                 position: "absolute", | ||||||
|  |                 right: 120, | ||||||
|  |                 textAlign: "right", | ||||||
|  |                 textDecorationLine: "line-through", | ||||||
|  |               }} | ||||||
|  |             > | ||||||
|  |               {time} | ||||||
|  |             </Text> | ||||||
|  |           )} | ||||||
|  |           <Text | ||||||
|  |             style={{ | ||||||
|  |               fontSize: 20, | ||||||
|  |               color: isNaN(currentTrainData?.delay) | ||||||
|  |                 ? "black" | ||||||
|  |                 : currentTrainData?.delay == 0 | ||||||
|  |                 ? "black" | ||||||
|  |                 : "red", | ||||||
|  |               width: 60, | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             {timeString[0]}:{timeString[1]} | ||||||
|  |           </Text> | ||||||
|  |           <Text style={{ fontSize: 18, width: 50 }}> | ||||||
|  |             {se?.replace("発", "出発").replace("着", "到着")} | ||||||
|  |           </Text> | ||||||
|  |         </View> | ||||||
|  |       </View> | ||||||
|  |     </TouchableWithoutFeedback> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { View, Text, ScrollView, useWindowDimensions } from "react-native"; | ||||||
|  |  | ||||||
|  | export const LandscapeTrainInfo = (props) => { | ||||||
|  |   const { leftContent, topStickyContent, children, scrollHandlers } = props; | ||||||
|  |   const { height, width } = useWindowDimensions(); | ||||||
|  |   return ( | ||||||
|  |     <View | ||||||
|  |       style={{ | ||||||
|  |         flexDirection: "row", | ||||||
|  |         backgroundColor: "blue", | ||||||
|  |         width: width, | ||||||
|  |         height: (height / 100) * 70, | ||||||
|  |         marginBottom: 50, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       <View | ||||||
|  |         style={{ | ||||||
|  |           flexDirection: "column", | ||||||
|  |           height: (height / 100) * 70, | ||||||
|  |           width: width / 2, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         <Text>{width / 2}</Text> | ||||||
|  |         {leftContent} | ||||||
|  |       </View> | ||||||
|  |       <ScrollView | ||||||
|  |         {...scrollHandlers} | ||||||
|  |         style={{ | ||||||
|  |           width: width / 2, | ||||||
|  |           height: "auto", | ||||||
|  |         }} | ||||||
|  |         stickyHeaderIndices={[1]} | ||||||
|  |         scrollEventThrottle={16} | ||||||
|  |         onScroll={(d) => { | ||||||
|  |           console.log(d.nativeEvent.contentOffset.y); | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         <View style={{ height: 0 }} /> | ||||||
|  |         <View style={{ flexDirection: "column" }} index={1}> | ||||||
|  |           {topStickyContent} | ||||||
|  |         </View> | ||||||
|  |         {children} | ||||||
|  |       </ScrollView> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										33
									
								
								components/ActionSheetComponents/EachTrainInfo/LongHeader.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								components/ActionSheetComponents/EachTrainInfo/LongHeader.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { ScrollView } from "react-native"; | ||||||
|  | import { TrainDataView } from "./TrainDataView"; | ||||||
|  |  | ||||||
|  | export const LongHeader = ({ | ||||||
|  |   currentTrainData, | ||||||
|  |   currentPosition, | ||||||
|  |   nearTrainIDList, | ||||||
|  |   openTrainInfo, | ||||||
|  | }) => { | ||||||
|  |   return ( | ||||||
|  |     <ScrollView | ||||||
|  |       //onTouchStart={() => setActionSheetHorizonalScroll(true)} | ||||||
|  |       //onScrollEndDrag={() => setActionSheetHorizonalScroll(false)} | ||||||
|  |       //onScrollBeginDrag={() => console.log("onScrollBeginDrag")} | ||||||
|  |       style={{ | ||||||
|  |         flexDirection: "row", | ||||||
|  |         //width: widthPercentageToDP("200%"), | ||||||
|  |         // minHeight: 200, | ||||||
|  |         //height: heightPercentageToDP("20%"), | ||||||
|  |       }} | ||||||
|  |       horizontal | ||||||
|  |       pagingEnabled | ||||||
|  |     > | ||||||
|  |       <TrainDataView | ||||||
|  |         currentTrainData={currentTrainData} | ||||||
|  |         currentPosition={currentPosition} | ||||||
|  |         nearTrainIDList={nearTrainIDList} | ||||||
|  |         openTrainInfo={openTrainInfo} | ||||||
|  |       /> | ||||||
|  |     </ScrollView> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
| @@ -0,0 +1,57 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { View, Text } from "react-native"; | ||||||
|  |  | ||||||
|  | export const ScrollStickyContent = ({ currentTrainData }) => { | ||||||
|  |   return ( | ||||||
|  |     <View | ||||||
|  |       style={{ | ||||||
|  |         alignItems: "center", | ||||||
|  |         backgroundColor: "white", | ||||||
|  |         flexDirection: "row", | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       <View | ||||||
|  |         style={{ | ||||||
|  |           padding: 8, | ||||||
|  |           flexDirection: "row", | ||||||
|  |           borderBottomWidth: 1, | ||||||
|  |           borderBottomColor: "#f0f0f0", | ||||||
|  |           flex: 1, | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         <Text style={{ fontSize: 20 }}>停車駅</Text> | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |         <View style={{ flexDirection: "row" }}> | ||||||
|  |           {!isNaN(currentTrainData?.delay) && currentTrainData?.delay != 0 && ( | ||||||
|  |             <Text | ||||||
|  |               style={{ | ||||||
|  |                 fontSize: 15, | ||||||
|  |                 color: "black", | ||||||
|  |                 position: "absolute", | ||||||
|  |                 right: 110, | ||||||
|  |                 textAlign: "right", | ||||||
|  |                 textDecorationLine: "line-through", | ||||||
|  |               }} | ||||||
|  |             > | ||||||
|  |               (定刻) | ||||||
|  |             </Text> | ||||||
|  |           )} | ||||||
|  |           <Text | ||||||
|  |             style={{ | ||||||
|  |               fontSize: 20, | ||||||
|  |               color: isNaN(currentTrainData?.delay) | ||||||
|  |                 ? "black" | ||||||
|  |                 : currentTrainData?.delay == 0 | ||||||
|  |                 ? "black" | ||||||
|  |                 : "red", | ||||||
|  |               width: 60, | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             見込 | ||||||
|  |           </Text> | ||||||
|  |           <Text style={{ fontSize: 20, width: 50 }}></Text> | ||||||
|  |         </View> | ||||||
|  |       </View> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
| @@ -0,0 +1,35 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { ScrollView } from "react-native"; | ||||||
|  | import { TrainDataView } from "./TrainDataView"; | ||||||
|  |  | ||||||
|  | export const ShortHeader = ({ | ||||||
|  |   currentTrainData, | ||||||
|  |   currentPosition, | ||||||
|  |   nearTrainIDList, | ||||||
|  |   openTrainInfo, | ||||||
|  | }) => { | ||||||
|  |   return ( | ||||||
|  |     <ScrollView | ||||||
|  |       //onTouchStart={() => setActionSheetHorizonalScroll(true)} | ||||||
|  |       //onScrollEndDrag={() => setActionSheetHorizonalScroll(false)} | ||||||
|  |       //onScrollBeginDrag={() => console.log("onScrollBeginDrag")} | ||||||
|  |       style={{ | ||||||
|  |         flexDirection: "row", | ||||||
|  |         flex: 1, | ||||||
|  |         //width: widthPercentageToDP("200%"), | ||||||
|  |         // minHeight: 200, | ||||||
|  |         //height: heightPercentageToDP("20%"), | ||||||
|  |       }} | ||||||
|  |       horizontal | ||||||
|  |       pagingEnabled | ||||||
|  |     > | ||||||
|  |       <TrainDataView | ||||||
|  |         mode={2} | ||||||
|  |         currentTrainData={currentTrainData} | ||||||
|  |         currentPosition={currentPosition} | ||||||
|  |         nearTrainIDList={nearTrainIDList} | ||||||
|  |         openTrainInfo={openTrainInfo} | ||||||
|  |       /> | ||||||
|  |     </ScrollView> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										55
									
								
								components/ActionSheetComponents/EachTrainInfo/StateBox.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								components/ActionSheetComponents/EachTrainInfo/StateBox.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { View, Text } from "react-native"; | ||||||
|  |  | ||||||
|  | export const StateBox = ({ text, title, style, mode }) => ( | ||||||
|  |   <View style={{ ...(mode == 2 ? boxStyle2 : boxStyle), ...style }}> | ||||||
|  |     <Text style={{ fontSize: 12, color: "#0099CC" }}>{title}</Text> | ||||||
|  |     <View style={{ flex: 1 }} /> | ||||||
|  |     <View | ||||||
|  |       style={{ | ||||||
|  |         color: "#0099CC", | ||||||
|  |         textAlign: "right", | ||||||
|  |         flexDirection: mode == 2 ? "row" : "column", | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       {text?.match("~") ? ( | ||||||
|  |         <> | ||||||
|  |           <Text style={mode == 2 ? boxTextStyle2 : boxTextStyle}> | ||||||
|  |             {text.split("~")[0]} | ||||||
|  |           </Text> | ||||||
|  |           <Text style={{ color: "#0099CC", textAlign: "right" }}>~</Text> | ||||||
|  |           <Text style={mode == 2 ? boxTextStyle2 : boxTextStyle}> | ||||||
|  |             {text.split("~")[1]} | ||||||
|  |           </Text> | ||||||
|  |         </> | ||||||
|  |       ) : ( | ||||||
|  |         <Text style={mode == 2 ? boxTextStyle2 : boxTextStyle}>{text}</Text> | ||||||
|  |       )} | ||||||
|  |     </View> | ||||||
|  |   </View> | ||||||
|  | ); | ||||||
|  | const boxStyle = { | ||||||
|  |   flex: 1, | ||||||
|  |   backgroundColor: "white", | ||||||
|  |   borderRadius: 10, | ||||||
|  |   padding: 10, | ||||||
|  |   margin: 10, | ||||||
|  | }; | ||||||
|  | const boxStyle2 = { | ||||||
|  |   flex: 1, | ||||||
|  |   backgroundColor: "white", | ||||||
|  |   borderRadius: 10, | ||||||
|  |   padding: 5, | ||||||
|  |   margin: 5, | ||||||
|  | }; | ||||||
|  | const boxTextStyle2 = { | ||||||
|  |   fontSize: 18, | ||||||
|  |   color: "#0099CC", | ||||||
|  |   textAlign: "right", | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const boxTextStyle = { | ||||||
|  |   fontSize: 25, | ||||||
|  |   color: "#0099CC", | ||||||
|  |   textAlign: "right", | ||||||
|  | }; | ||||||
| @@ -0,0 +1,95 @@ | |||||||
|  | import React, { useEffect, useState } from "react"; | ||||||
|  | import { | ||||||
|  |   View, | ||||||
|  |   Text, | ||||||
|  |   TouchableOpacity, | ||||||
|  |   useWindowDimensions, | ||||||
|  | } from "react-native"; | ||||||
|  | import { StateBox } from "./StateBox"; | ||||||
|  | import { | ||||||
|  |   heightPercentageToDP, | ||||||
|  |   widthPercentageToDP, | ||||||
|  | } from "react-native-responsive-screen"; | ||||||
|  |  | ||||||
|  | export const TrainDataView = ({ | ||||||
|  |   currentTrainData, | ||||||
|  |   currentPosition, | ||||||
|  |   nearTrainIDList, | ||||||
|  |   openTrainInfo, | ||||||
|  |   mode = 0, | ||||||
|  | }) => { | ||||||
|  |   const [isLandscape, setIsLandscape] = useState(false); | ||||||
|  |   const { width, height } = useWindowDimensions(); | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (height / width > 1.5) { | ||||||
|  |       setIsLandscape(false); | ||||||
|  |     } | ||||||
|  |     if (height / width < 1.5) { | ||||||
|  |       setIsLandscape(true); | ||||||
|  |     } | ||||||
|  |   }, [width, height]); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <View | ||||||
|  |       style={{ | ||||||
|  |         flexDirection: "row", | ||||||
|  |         //minHeight: 200, | ||||||
|  |         //height: heightPercentageToDP("20%"), | ||||||
|  |         width: isLandscape ? (width / 100) * 40 : width, | ||||||
|  |         flex: 1, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       <StateBox | ||||||
|  |         mode={mode} | ||||||
|  |         title={`現在地 ${currentPosition.toString()}`} | ||||||
|  |         text={ | ||||||
|  |           currentTrainData?.Pos.match("~") | ||||||
|  |             ? `${ | ||||||
|  |                 currentTrainData?.Pos.replace("(下り)", "") | ||||||
|  |                   .replace("(上り)", "") | ||||||
|  |                   .split("~")[0] | ||||||
|  |               }~${ | ||||||
|  |                 currentTrainData?.Pos.replace("(下り)", "") | ||||||
|  |                   .replace("(上り)", "") | ||||||
|  |                   .split("~")[1] | ||||||
|  |               }` | ||||||
|  |             : currentTrainData?.Pos | ||||||
|  |         } | ||||||
|  |       /> | ||||||
|  |       <View style={{ flex: 1, flexDirection: mode == 2 ? "row" : "column" }}> | ||||||
|  |         <View style={{ flex: 1, flexDirection: "row" }}> | ||||||
|  |           <StateBox | ||||||
|  |             mode={mode} | ||||||
|  |             title={isNaN(currentTrainData?.delay) ? "状態" : "遅延時分"} | ||||||
|  |             text={`${currentTrainData?.delay}${ | ||||||
|  |               isNaN(currentTrainData?.delay) ? "" : "分" | ||||||
|  |             }`} | ||||||
|  |           /> | ||||||
|  |         </View> | ||||||
|  |         <TouchableOpacity | ||||||
|  |           style={{ flex: 1, flexDirection: "row" }} | ||||||
|  |           disabled={nearTrainIDList.length == 0} | ||||||
|  |           onPress={() => { | ||||||
|  |             if (nearTrainIDList.length == 0) return; | ||||||
|  |             openTrainInfo(nearTrainIDList[0]); | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           {nearTrainIDList.length == 0 ? ( | ||||||
|  |             <StateBox mode={mode} title="列番" text={currentTrainData?.num} /> | ||||||
|  |           ) : ( | ||||||
|  |             <StateBox | ||||||
|  |               mode={mode} | ||||||
|  |               title="増解結相手を表示▶️" | ||||||
|  |               text={`${nearTrainIDList}`} | ||||||
|  |               style={{ | ||||||
|  |                 borderWidth: 1, | ||||||
|  |                 borderColor: "red", | ||||||
|  |                 borderStyle: "solid", | ||||||
|  |               }} | ||||||
|  |             /> | ||||||
|  |           )} | ||||||
|  |         </TouchableOpacity> | ||||||
|  |       </View> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										453
									
								
								components/ActionSheetComponents/EachTrainInfoCore.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										453
									
								
								components/ActionSheetComponents/EachTrainInfoCore.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,453 @@ | |||||||
|  | import React, { useEffect, useState, useRef } from "react"; | ||||||
|  | import { | ||||||
|  |   View, | ||||||
|  |   LayoutAnimation, | ||||||
|  |   Text, | ||||||
|  |   TouchableOpacity, | ||||||
|  |   Platform, | ||||||
|  |   StyleSheet, | ||||||
|  |   useWindowDimensions, | ||||||
|  | } from "react-native"; | ||||||
|  | import { Ionicons } from "@expo/vector-icons"; | ||||||
|  | import ActionSheet, { | ||||||
|  |   SheetManager, | ||||||
|  |   useScrollHandlers, | ||||||
|  | } from "react-native-actions-sheet"; | ||||||
|  | import { AS } from "../../storageControl"; | ||||||
|  | import trainList from "../../assets/originData/trainList"; | ||||||
|  | import { lineList } from "../../lib/getStationList"; | ||||||
|  | import { heightPercentageToDP } from "react-native-responsive-screen"; | ||||||
|  | import { useCurrentTrain } from "../../stateBox/useCurrentTrain"; | ||||||
|  | import { checkDuplicateTrainData } from "../../lib/checkDuplicateTrainData"; | ||||||
|  | import { getTrainType } from "../../lib/getTrainType"; | ||||||
|  | import { customTrainDataDetector } from "../custom-train-data"; | ||||||
|  | import { useBusAndTrainData } from "../../stateBox/useBusAndTrainData"; | ||||||
|  | import { EachStopList } from "./EachTrainInfo/EachStopList"; | ||||||
|  | import { DataFromButton } from "./EachTrainInfo/DataFromButton"; | ||||||
|  | import { DynamicHeaderScrollView } from "../DynamicHeaderScrollView"; | ||||||
|  | import { LongHeader } from "./EachTrainInfo/LongHeader"; | ||||||
|  | import { ShortHeader } from "./EachTrainInfo/ShortHeader"; | ||||||
|  | import { ScrollStickyContent } from "./EachTrainInfo/ScrollStickyContent"; | ||||||
|  | import { LandscapeTrainInfo } from "./EachTrainInfo/LandscapeTrainInfo"; | ||||||
|  | import { getStationData } from "../../lib/eachTrainInfoCoreLib/getStationData"; | ||||||
|  | import { findReversalPoints } from "../../lib/eachTrainInfoCoreLib/findReversalPoints"; | ||||||
|  | import { migrateTrainName } from "../../lib/eachTrainInfoCoreLib/migrateTrainName"; | ||||||
|  | import { getType } from "../../lib/eachTrainInfoCoreLib/getType"; | ||||||
|  | import { searchSpecialTrain } from "../../lib/eachTrainInfoCoreLib/searchSpecialTrain"; | ||||||
|  | import { openBackTrainInfo } from "../../lib/eachTrainInfoCoreLib/openBackTrainInfo"; | ||||||
|  |  | ||||||
|  | export const EachTrainInfoCore = ({ | ||||||
|  |   actionSheetRef, | ||||||
|  |   data, | ||||||
|  |   navigate, | ||||||
|  |   originalStationList, | ||||||
|  |   openStationACFromEachTrainInfo, | ||||||
|  |   from, | ||||||
|  |   setTrainInfo, | ||||||
|  | }) => { | ||||||
|  |   // const [actionSheetHorizonalScroll, setActionSheetHorizonalScroll] = useState(false); | ||||||
|  |  | ||||||
|  |   const { currentTrain } = useCurrentTrain(); | ||||||
|  |   const [currentTrainData, setCurrentTrainData] = useState(); | ||||||
|  |  | ||||||
|  |   // const [actionSheetHorizonalScroll, setActionSheetHorizonalScroll] = useState(false); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     console.log(currentTrain.length); | ||||||
|  |     if (!currentTrain.length) return; | ||||||
|  |     setCurrentTrainData( | ||||||
|  |       checkDuplicateTrainData( | ||||||
|  |         currentTrain.filter((d) => d.num == data.trainNum) | ||||||
|  |       ) | ||||||
|  |     ); | ||||||
|  |   }, [currentTrain, data.trainNum]); | ||||||
|  |  | ||||||
|  |   //bconst insets = useSafeAreaInsets(); | ||||||
|  |  | ||||||
|  |   const [headStation, setHeadStation] = useState(); | ||||||
|  |   const [tailStation, setTailStation] = useState(); | ||||||
|  |   const [isConcatNear, setIsConcatNear] = useState(false); | ||||||
|  |   const [showNearTrain, setShowNearTrain] = useState([]); | ||||||
|  |   const [nearTrainIDList, setNearTrainIDList] = useState([]); | ||||||
|  |   const { getInfluencedTrainData } = useBusAndTrainData(); | ||||||
|  |   const [trainPositionSwitch, setTrainPositionSwitch] = useState("false"); | ||||||
|  |   const [currentPosition, setCurrentPosition] = useState([]); | ||||||
|  |   const [trainData, setTrainData] = useState([]); | ||||||
|  |   const scrollHandlers = actionSheetRef | ||||||
|  |     ? useScrollHandlers("scrollview-1", actionSheetRef) | ||||||
|  |     : null; | ||||||
|  |  | ||||||
|  |   const stationList = | ||||||
|  |     originalStationList && | ||||||
|  |     lineList.map((d) => | ||||||
|  |       originalStationList[d].map((a) => ({ | ||||||
|  |         StationNumber: a.StationNumber, | ||||||
|  |         StationName: a.Station_JP, | ||||||
|  |       })) | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |   // 使用例 | ||||||
|  |   const points = | ||||||
|  |     trainPositionSwitch == "true" | ||||||
|  |       ? findReversalPoints(currentPosition, stopStationIDList) | ||||||
|  |       : []; | ||||||
|  |   const stopStationIDList = trainData.map((i, index) => { | ||||||
|  |     const [station, se, time] = i.split(","); | ||||||
|  |     const Stations = stationList.map((a) => | ||||||
|  |       a.filter((d) => d.StationName == station) | ||||||
|  |     ); | ||||||
|  |     const StationNumbers = | ||||||
|  |       Stations && | ||||||
|  |       Stations.reduce((newArray, e) => { | ||||||
|  |         return newArray.concat(e); | ||||||
|  |       }, []) | ||||||
|  |         .filter((d) => d.StationNumber) | ||||||
|  |         .map((d) => d.StationNumber); | ||||||
|  |     return StationNumbers[0]; | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   const { height, width } = useWindowDimensions(); | ||||||
|  |   const [isLandscape, setIsLandscape] = useState(false); | ||||||
|  |  | ||||||
|  |   const [trueTrainID, setTrueTrainID] = useState(); | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (!data.trainNum) return; | ||||||
|  |     const TD = trainList[data.trainNum]; | ||||||
|  |     setIsConcatNear(false); | ||||||
|  |     setHeadStation(); | ||||||
|  |     setTailStation(); | ||||||
|  |     if (!TD) { | ||||||
|  |       const specialTrainActualID = searchSpecialTrain(data.trainNum, trainList); | ||||||
|  |       setTrueTrainID(specialTrainActualID || undefined); | ||||||
|  |       setTrainData([]); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     setTrainData(TD.split("#").filter((d) => d != "")); | ||||||
|  |   }, [data]); | ||||||
|  |   //裏列車探索 | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (!data.trainNum) return; | ||||||
|  |     const [returnArray, TDArray] = getInfluencedTrainData(data.trainNum); | ||||||
|  |     setNearTrainIDList(returnArray); | ||||||
|  |     setShowNearTrain(TDArray); | ||||||
|  |     if (trainData.length == 0) return; | ||||||
|  |     if (TDArray.length == 0) return; | ||||||
|  |     let head; | ||||||
|  |     let tail; | ||||||
|  |     TDArray.forEach((d) => { | ||||||
|  |       const [station, se, time] = d.split(","); | ||||||
|  |  | ||||||
|  |       if (station == trainData[0].split(",")[0]) { | ||||||
|  |         head = trainData[0].split(",")[0]; | ||||||
|  |       } | ||||||
|  |       if (station == trainData[trainData.length - 1].split(",")[0]) { | ||||||
|  |         tail = trainData[trainData.length - 1].split(",")[0]; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (head) setHeadStation(head); | ||||||
|  |     else setHeadStation(); | ||||||
|  |     if (tail) setTailStation(tail); | ||||||
|  |     else setTailStation(); | ||||||
|  |   }, [trainData, data]); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     //currentTrainData.Pos = "鴨川~端岡"; //test | ||||||
|  |     if (!currentTrainData) return; | ||||||
|  |     if (!currentTrainData?.Pos) return; | ||||||
|  |     if (currentTrainData?.Pos.match("~")) { | ||||||
|  |       const pos = currentTrainData?.Pos.replace("(下り)", "") | ||||||
|  |         .replace("(上り)", "") | ||||||
|  |         .split("~"); | ||||||
|  |       setCurrentPosition([ | ||||||
|  |         getStationData(pos[0], stationList), | ||||||
|  |         getStationData(pos[1], stationList), | ||||||
|  |       ]); | ||||||
|  |     } else { | ||||||
|  |       setCurrentPosition([getStationData(currentTrainData?.Pos, stationList)]); | ||||||
|  |     } | ||||||
|  |   }, [currentTrainData]); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (height / width > 1.5) { | ||||||
|  |       setIsLandscape(false); | ||||||
|  |     } | ||||||
|  |     if (height / width < 1.5) { | ||||||
|  |       setIsLandscape(true); | ||||||
|  |     } | ||||||
|  |   }, [width, height]); | ||||||
|  |  | ||||||
|  |   const replaceSpecialTrainDetail = (trainNum) => { | ||||||
|  |     let TD = trainList[trainNum]; | ||||||
|  |     if (!TD) return; | ||||||
|  |     setTrainData(TD.split("#").filter((d) => d != "")); | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     //列車現在地アイコン表示スイッチ | ||||||
|  |     AS.getItem("trainPositionSwitch") | ||||||
|  |       .then((d) => { | ||||||
|  |         if (d) setTrainPositionSwitch(d); | ||||||
|  |       }) | ||||||
|  |       .catch((d) => AS.setItem("trainPositionSwitch", "false")); | ||||||
|  |   }, []); | ||||||
|  |  | ||||||
|  |   const openTrainInfo = (d) => { | ||||||
|  |     const train = customTrainDataDetector(d); | ||||||
|  |     let TrainNumber = ""; | ||||||
|  |     if (train.trainNumDistance != undefined) { | ||||||
|  |       const timeInfo = | ||||||
|  |         parseInt(d.replace("M", "").replace("D", "")) - train.trainNumDistance; | ||||||
|  |       TrainNumber = timeInfo + "号"; | ||||||
|  |     } | ||||||
|  |     const payload = { | ||||||
|  |       data: { | ||||||
|  |         trainNum: d, | ||||||
|  |         limited: `${getTrainType(train.type).data}:${ | ||||||
|  |           train.trainName | ||||||
|  |         }${TrainNumber}`, | ||||||
|  |       }, | ||||||
|  |       navigate, | ||||||
|  |       originalStationList, | ||||||
|  |       from: "AllTrainDiagramView", | ||||||
|  |     }; | ||||||
|  |     if (setTrainInfo) { | ||||||
|  |       setTrainInfo(payload.data); | ||||||
|  |     } else { | ||||||
|  |       SheetManager.hide("EachTrainInfo").then(() => { | ||||||
|  |         //0.1秒待機してから開く | ||||||
|  |         setTimeout(() => { | ||||||
|  |           SheetManager.show("EachTrainInfo", { payload }); | ||||||
|  |         }, 1); | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  |   return ( | ||||||
|  |     <View | ||||||
|  |       style={{ | ||||||
|  |         backgroundColor: "#0099CC", | ||||||
|  |         borderTopRadius: 5, | ||||||
|  |         borderColor: "dark", | ||||||
|  |         borderWidth: 1, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       {isLandscape || ( | ||||||
|  |         <View style={{ height: 26, width: "100%" }}> | ||||||
|  |           <View | ||||||
|  |             style={{ | ||||||
|  |               height: 6, | ||||||
|  |               width: 45, | ||||||
|  |               borderRadius: 100, | ||||||
|  |               backgroundColor: "#f0f0f0", | ||||||
|  |               marginVertical: 10, | ||||||
|  |               alignSelf: "center", | ||||||
|  |             }} | ||||||
|  |           /> | ||||||
|  |         </View> | ||||||
|  |       )} | ||||||
|  |       <View style={{ padding: 10, flexDirection: "row", alignItems: "center" }}> | ||||||
|  |         <Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}> | ||||||
|  |           {data.limited | ||||||
|  |             ? getType(data.limited.split(":")[0]) + | ||||||
|  |               migrateTrainName( | ||||||
|  |                 data.limited.split(":")[1] || | ||||||
|  |                   (trainData.length > 0 | ||||||
|  |                     ? trainData[trainData.length - 1].split(",")[0] + "行き" | ||||||
|  |                     : " ") | ||||||
|  |               ) | ||||||
|  |             : ""} | ||||||
|  |         </Text> | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |         <Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}> | ||||||
|  |           {data.trainNum} | ||||||
|  |           {isConcatNear ? ` + ${nearTrainIDList}` : ""} | ||||||
|  |         </Text> | ||||||
|  |  | ||||||
|  |         {data.limited != undefined && | ||||||
|  |           getType(data.limited.split(":")[0]) && | ||||||
|  |           !data.limited.split(":")[1].match("サンポート") && ( | ||||||
|  |             <Ionicons | ||||||
|  |               name="subway" | ||||||
|  |               color="white" | ||||||
|  |               size={30} | ||||||
|  |               style={{ margin: 5 }} | ||||||
|  |               onPress={() => { | ||||||
|  |                 LayoutAnimation.easeInEaseOut(); //setLoadingDelayData(true); | ||||||
|  |                 navigate("trainbase", { | ||||||
|  |                   info: "train.html?tn=" + data.trainNum, | ||||||
|  |                   from, | ||||||
|  |                 }); | ||||||
|  |                 SheetManager.hide("EachTrainInfo"); | ||||||
|  |               }} | ||||||
|  |             /> | ||||||
|  |           )} | ||||||
|  |       </View> | ||||||
|  |       <DynamicHeaderScrollView | ||||||
|  |         styles={styles} | ||||||
|  |         scrollViewProps={scrollHandlers} | ||||||
|  |         containerProps={{ | ||||||
|  |           style: { | ||||||
|  |             maxHeight: isLandscape ? height - 94 : (height / 100) * 70, | ||||||
|  |           }, | ||||||
|  |         }} | ||||||
|  |         Max_Header_Height={from == "AllTrainDiagramView" ? 0 : 200} | ||||||
|  |         Min_Header_Height={from == "AllTrainDiagramView" ? 0 : 80} | ||||||
|  |         shortHeader={ | ||||||
|  |           from == "AllTrainDiagramView" ? ( | ||||||
|  |             <></> | ||||||
|  |           ) : ( | ||||||
|  |             <ShortHeader | ||||||
|  |               currentTrainData={currentTrainData} | ||||||
|  |               currentPosition={currentPosition} | ||||||
|  |               nearTrainIDList={nearTrainIDList} | ||||||
|  |               openTrainInfo={openTrainInfo} | ||||||
|  |             /> | ||||||
|  |           ) | ||||||
|  |         } | ||||||
|  |         longHeader={ | ||||||
|  |           from == "AllTrainDiagramView" ? ( | ||||||
|  |             <></> | ||||||
|  |           ) : ( | ||||||
|  |             <LongHeader | ||||||
|  |               currentTrainData={currentTrainData} | ||||||
|  |               currentPosition={currentPosition} | ||||||
|  |               nearTrainIDList={nearTrainIDList} | ||||||
|  |               openTrainInfo={openTrainInfo} | ||||||
|  |             /> | ||||||
|  |           ) | ||||||
|  |         } | ||||||
|  |         topStickyContent={ | ||||||
|  |           <ScrollStickyContent currentTrainData={currentTrainData} /> | ||||||
|  |         } | ||||||
|  |       > | ||||||
|  |         {headStation && !isConcatNear && ( | ||||||
|  |           <TouchableOpacity | ||||||
|  |             onPress={() => { | ||||||
|  |               const array = openBackTrainInfo( | ||||||
|  |                 headStation, | ||||||
|  |                 trainData, | ||||||
|  |                 showNearTrain | ||||||
|  |               ); | ||||||
|  |               if (!array) return; | ||||||
|  |               setTrainData(array); | ||||||
|  |               setIsConcatNear(true); | ||||||
|  |             }} | ||||||
|  |             style={{ | ||||||
|  |               padding: 10, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               borderColor: "blue", | ||||||
|  |               borderWidth: 1, | ||||||
|  |               margin: 10, | ||||||
|  |               borderRadius: 5, | ||||||
|  |               alignItems: "center", | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             <Text style={{ fontSize: 18, fontWeight: "bold", color: "black" }}> | ||||||
|  |               「本当の始発駅」を表示 | ||||||
|  |             </Text> | ||||||
|  |           </TouchableOpacity> | ||||||
|  |         )} | ||||||
|  |         {/* <LottieView | ||||||
|  |                 autoPlay | ||||||
|  |                 loop | ||||||
|  |                 style={{ width: 150, height: 150, backgroundColor: "#fff" }} | ||||||
|  |                 source={require("../../assets/51690-loading-diamonds.json")} | ||||||
|  |               /> | ||||||
|  |               <Text>ほげほげふがふが</Text> */} | ||||||
|  |         {trainData.length == 0 && trueTrainID && ( | ||||||
|  |           <TouchableOpacity | ||||||
|  |             onPress={() => replaceSpecialTrainDetail(trueTrainID)} | ||||||
|  |             style={{ | ||||||
|  |               padding: 10, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               borderColor: "blue", | ||||||
|  |               borderWidth: 1, | ||||||
|  |               margin: 10, | ||||||
|  |               borderRadius: 5, | ||||||
|  |               alignItems: "center", | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             <Text style={{ fontSize: 18, fontWeight: "bold", color: "black" }}> | ||||||
|  |               本来の列車情報を表示 | ||||||
|  |             </Text> | ||||||
|  |           </TouchableOpacity> | ||||||
|  |         )} | ||||||
|  |         {trainData.map((i, index) => | ||||||
|  |           i.split(",")[1] == "提" ? ( | ||||||
|  |             <DataFromButton i={i} /> | ||||||
|  |           ) : ( | ||||||
|  |             <EachStopList | ||||||
|  |               i={i} | ||||||
|  |               index={index} | ||||||
|  |               stationList={stationList} | ||||||
|  |               points={points} | ||||||
|  |               currentTrainData={currentTrainData} | ||||||
|  |               openStationACFromEachTrainInfo={openStationACFromEachTrainInfo} | ||||||
|  |             /> | ||||||
|  |           ) | ||||||
|  |         )} | ||||||
|  |         {tailStation && !isConcatNear && ( | ||||||
|  |           <TouchableOpacity | ||||||
|  |             onPress={() => { | ||||||
|  |               const array = openBackTrainInfo( | ||||||
|  |                 tailStation, | ||||||
|  |                 trainData, | ||||||
|  |                 showNearTrain | ||||||
|  |               ); | ||||||
|  |  | ||||||
|  |               if (!array) return; | ||||||
|  |               setTrainData(array); | ||||||
|  |               setIsConcatNear(true); | ||||||
|  |             }} | ||||||
|  |             style={{ | ||||||
|  |               padding: 10, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               borderColor: "blue", | ||||||
|  |               borderWidth: 1, | ||||||
|  |               margin: 10, | ||||||
|  |               borderRadius: 5, | ||||||
|  |               alignItems: "center", | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             <Text style={{ fontSize: 18, fontWeight: "bold", color: "black" }}> | ||||||
|  |               「本当の終着駅」を表示 | ||||||
|  |             </Text> | ||||||
|  |           </TouchableOpacity> | ||||||
|  |         )} | ||||||
|  |  | ||||||
|  |         <View style={{ flexDirection: "row" }}> | ||||||
|  |           <View | ||||||
|  |             style={{ | ||||||
|  |               padding: 8, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               borderBottomWidth: 1, | ||||||
|  |               borderBottomColor: "#f0f0f0", | ||||||
|  |               flex: 1, | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             <Text style={{ fontSize: 20 }}> </Text> | ||||||
|  |             <View style={{ flex: 1 }} /> | ||||||
|  |           </View> | ||||||
|  |         </View> | ||||||
|  |       </DynamicHeaderScrollView> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const styles = StyleSheet.create({ | ||||||
|  |   header: { | ||||||
|  |     justifyContent: "center", | ||||||
|  |     alignItems: "center", | ||||||
|  |     left: 0, | ||||||
|  |     right: 0, | ||||||
|  |     //paddingTop: 10, | ||||||
|  |     position: "absolute", | ||||||
|  |     zIndex: 1, | ||||||
|  |     backgroundColor: "f0f0f0", | ||||||
|  |   }, | ||||||
|  |   headerText: { | ||||||
|  |     color: "#fff", | ||||||
|  |     fontSize: 25, | ||||||
|  |     fontWeight: "bold", | ||||||
|  |     textAlign: "center", | ||||||
|  |   }, | ||||||
|  | }); | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| import React from "react"; | import React, { useRef } from "react"; | ||||||
| import { | import { | ||||||
|   View, |   View, | ||||||
|   LayoutAnimation, |   LayoutAnimation, | ||||||
| @@ -6,33 +6,62 @@ import { | |||||||
|   Linking, |   Linking, | ||||||
|   Text, |   Text, | ||||||
|   TouchableOpacity, |   TouchableOpacity, | ||||||
|  |   Platform, | ||||||
| } from "react-native"; | } from "react-native"; | ||||||
| import { Ionicons, MaterialCommunityIcons } from "@expo/vector-icons"; | import { Ionicons, MaterialCommunityIcons } from "@expo/vector-icons"; | ||||||
| import ActionSheet from "react-native-actions-sheet"; | import ActionSheet, { useScrollHandlers } from "react-native-actions-sheet"; | ||||||
| import LottieView from "lottie-react-native"; | import LottieView from "lottie-react-native"; | ||||||
| export const JRSTraInfo = (props) => { | import { useSafeAreaInsets } from "react-native-safe-area-context"; | ||||||
|   const { | import ViewShot from "react-native-view-shot"; | ||||||
|     JRSTraInfoEXAcSR, | import * as Sharing from "expo-sharing"; | ||||||
|     getTime, | import { useTrainDelayData } from "../../stateBox/useTrainDelayData"; | ||||||
|     loadingDelayData, | export const JRSTraInfo = () => { | ||||||
|     setLoadingDelayData, |   const { getTime, delayData, loadingDelayData, setLoadingDelayData } = | ||||||
|     delayData, |     useTrainDelayData(); | ||||||
|   } = props; |   const actionSheetRef = useRef(null); | ||||||
|  |   const scrollHandlers = useScrollHandlers("scrollview-1", actionSheetRef); | ||||||
|  |   const insets = useSafeAreaInsets(); | ||||||
|  |   const viewShot = useRef(null); | ||||||
|  |  | ||||||
|  |   const onCapture = async () => { | ||||||
|  |     const url = await viewShot.current.capture(); | ||||||
|  |  | ||||||
|  |     const ok = await Sharing.isAvailableAsync(); | ||||||
|  |     if (ok) { | ||||||
|  |       await Sharing.shareAsync( | ||||||
|  |         "file://" + url, | ||||||
|  |         (options = { mimeType: "image/jpeg", dialogTitle: "Share this image" }) | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|     <ActionSheet |     <ActionSheet | ||||||
|       ref={JRSTraInfoEXAcSR} |  | ||||||
|       gestureEnabled |       gestureEnabled | ||||||
|       CustomHeaderComponent={<></>} |       CustomHeaderComponent={<></>} | ||||||
|  |       ref={actionSheetRef} | ||||||
|  |       isModal={Platform.OS == "ios"} | ||||||
|  |       containerStyle={ | ||||||
|  |         Platform.OS == "android" | ||||||
|  |           ? { | ||||||
|  |               paddingBottom: insets.bottom, | ||||||
|  |             } | ||||||
|  |           : {} | ||||||
|  |       } | ||||||
|  |       useBottomSafeAreaPadding={Platform.OS == "android"} | ||||||
|     > |     > | ||||||
|       <View |       <View | ||||||
|         style={{ |         style={{ | ||||||
|           backgroundColor: "#0099CC", |           backgroundColor: "#0099CC", | ||||||
|           borderRadius: 5, |           borderTopRadius: 5, | ||||||
|           borderColor: "dark", |           borderColor: "dark", | ||||||
|           borderWidth: 1, |           borderWidth: 1, | ||||||
|         }} |         }} | ||||||
|       > |       > | ||||||
|         <View style={{ height: 26, width: "100%" }}> |         <ViewShot ref={viewShot} options={{ format: "jpg" }}> | ||||||
|  |           <View | ||||||
|  |             style={{ height: 26, width: "100%", backgroundColor: "#0099CC" }} | ||||||
|  |           > | ||||||
|             <View |             <View | ||||||
|               style={{ |               style={{ | ||||||
|                 height: 6, |                 height: 6, | ||||||
| @@ -45,7 +74,12 @@ export const JRSTraInfo = (props) => { | |||||||
|             /> |             /> | ||||||
|           </View> |           </View> | ||||||
|           <View |           <View | ||||||
|           style={{ padding: 10, flexDirection: "row", alignItems: "center" }} |             style={{ | ||||||
|  |               padding: 10, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               alignItems: "center", | ||||||
|  |               backgroundColor: "#0099CC", | ||||||
|  |             }} | ||||||
|           > |           > | ||||||
|             <Text style={{ fontSize: 30, fontWeight: "bold", color: "white" }}> |             <Text style={{ fontSize: 30, fontWeight: "bold", color: "white" }}> | ||||||
|               列車遅延速報EX |               列車遅延速報EX | ||||||
| @@ -71,13 +105,11 @@ export const JRSTraInfo = (props) => { | |||||||
|               }} |               }} | ||||||
|             /> |             /> | ||||||
|           </View> |           </View> | ||||||
|         <ScrollView> |           <ScrollView {...scrollHandlers}> | ||||||
|             <View |             <View | ||||||
|               style={{ |               style={{ | ||||||
|                 padding: 10, |                 padding: 10, | ||||||
|                 backgroundColor: "white", |                 backgroundColor: "white", | ||||||
|               borderBottomLeftRadius: 5, |  | ||||||
|               borderBottomRightRadius: 5, |  | ||||||
|               }} |               }} | ||||||
|             > |             > | ||||||
|               {loadingDelayData ? ( |               {loadingDelayData ? ( | ||||||
| @@ -107,14 +139,26 @@ export const JRSTraInfo = (props) => { | |||||||
|               )} |               )} | ||||||
|             </View> |             </View> | ||||||
|  |  | ||||||
|           <View style={{ padding: 10 }}> |             <View style={{ padding: 10, backgroundColor: "#0099CC" }}> | ||||||
|             <Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}> |               <Text | ||||||
|  |                 style={{ fontSize: 20, fontWeight: "bold", color: "white" }} | ||||||
|  |               > | ||||||
|                 列車遅延情報EXについて |                 列車遅延情報EXについて | ||||||
|               </Text> |               </Text> | ||||||
|               <Text style={{ color: "white" }}> |               <Text style={{ color: "white" }}> | ||||||
|                 列車遅延情報をJR四国公式列車運行情報より5分毎に取得します。Twitterにて投稿している内容と同一のものとなります。 |                 列車遅延情報をJR四国公式列車運行情報より5分毎に取得します。Twitterにて投稿している内容と同一のものとなります。 | ||||||
|               </Text> |               </Text> | ||||||
|             </View> |             </View> | ||||||
|  |           </ScrollView> | ||||||
|  |         </ViewShot> | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             padding: 10, | ||||||
|  |             backgroundColor: "#0099CC", | ||||||
|  |             flexDirection: "row", | ||||||
|  |             justifyContent: "space-between", | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|           <TouchableOpacity |           <TouchableOpacity | ||||||
|             style={{ |             style={{ | ||||||
|               padding: 10, |               padding: 10, | ||||||
| @@ -124,20 +168,40 @@ export const JRSTraInfo = (props) => { | |||||||
|               margin: 10, |               margin: 10, | ||||||
|               borderRadius: 5, |               borderRadius: 5, | ||||||
|               alignItems: "center", |               alignItems: "center", | ||||||
|  |               backgroundColor: "#0099CC", | ||||||
|  |               flex: 1, | ||||||
|             }} |             }} | ||||||
|             onPress={() => Linking.openURL("https://twitter.com/JRSTrainfoEX")} |             onPress={() => | ||||||
|  |               Linking.openURL("https://mstdn.y-zu.org/@JRSTraInfoEX") | ||||||
|  |             } | ||||||
|           > |           > | ||||||
|             <MaterialCommunityIcons name="twitter" color="white" size={30} /> |             <MaterialCommunityIcons name="mastodon" color="white" size={30} /> | ||||||
|             <View style={{ flex: 1 }} /> |             <View style={{ flex: 1 }} /> | ||||||
|             <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> |             <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> | ||||||
|               TwitterBOTはこちら! |               MastodonBOT | ||||||
|             </Text> |             </Text> | ||||||
|             <View style={{ flex: 1 }} /> |             <View style={{ flex: 1 }} /> | ||||||
|             <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> |  | ||||||
|               → |  | ||||||
|             </Text> |  | ||||||
|           </TouchableOpacity> |           </TouchableOpacity> | ||||||
|         </ScrollView> |           <TouchableOpacity | ||||||
|  |             style={{ | ||||||
|  |               padding: 10, | ||||||
|  |               flexDirection: "row", | ||||||
|  |               borderColor: "white", | ||||||
|  |               borderWidth: 1, | ||||||
|  |               margin: 10, | ||||||
|  |               borderRadius: 5, | ||||||
|  |               alignItems: "center", | ||||||
|  |               backgroundColor: "#0099CC", | ||||||
|  |             }} | ||||||
|  |             onPress={onCapture} | ||||||
|  |           > | ||||||
|  |             <MaterialCommunityIcons | ||||||
|  |               name="share-variant" | ||||||
|  |               color="white" | ||||||
|  |               size={30} | ||||||
|  |             /> | ||||||
|  |           </TouchableOpacity> | ||||||
|  |         </View> | ||||||
|       </View> |       </View> | ||||||
|     </ActionSheet> |     </ActionSheet> | ||||||
|   ); |   ); | ||||||
|   | |||||||
| @@ -1,38 +1,29 @@ | |||||||
| import React, { useState, useEffect } from "react"; | import React, { useState, useEffect } from "react"; | ||||||
| import { | import { View, Linking, Text, TouchableOpacity, Platform } from "react-native"; | ||||||
|   StatusBar, |  | ||||||
|   View, |  | ||||||
|   LayoutAnimation, |  | ||||||
|   ScrollView, |  | ||||||
|   Linking, |  | ||||||
|   Text, |  | ||||||
|   TouchableOpacity, |  | ||||||
| } from "react-native"; |  | ||||||
| import AutoHeightImage from "react-native-auto-height-image"; | import AutoHeightImage from "react-native-auto-height-image"; | ||||||
| import { FontAwesome, Foundation, Ionicons } from "@expo/vector-icons"; | import { FontAwesome, Foundation, Ionicons } from "@expo/vector-icons"; | ||||||
|  | import { useSafeAreaInsets } from "react-native-safe-area-context"; | ||||||
| import ActionSheet from "react-native-actions-sheet"; | import ActionSheet from "react-native-actions-sheet"; | ||||||
| import Sign from "../../components/駅名表/Sign"; | import Sign from "../../components/駅名表/Sign"; | ||||||
| import { useInterval } from "../../lib/useInterval"; |  | ||||||
|  |  | ||||||
| import { TicketBox } from "../atom/TicketBox"; | import { TicketBox } from "../atom/TicketBox"; | ||||||
| import { | import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | ||||||
|   widthPercentageToDP as wp, |  | ||||||
|   heightPercentageToDP as hp, |  | ||||||
| } from "react-native-responsive-screen"; |  | ||||||
| import lineColorList from "../../assets/originData/lineColorList"; | import lineColorList from "../../assets/originData/lineColorList"; | ||||||
| import { getPDFViewURL } from "../../lib/getPdfViewURL"; | import { getPDFViewURL } from "../../lib/getPdfViewURL"; | ||||||
|  | import { useBusAndTrainData } from "../../stateBox/useBusAndTrainData"; | ||||||
|  | import { AS } from "../../storageControl"; | ||||||
|  |  | ||||||
| export const StationDeteilView = (props) => { | export const StationDeteilView = (props) => { | ||||||
|  |   if (!props.payload) return <></>; | ||||||
|   const { |   const { | ||||||
|     StationBoardAcSR, |  | ||||||
|     currentStation, |     currentStation, | ||||||
|     originalStationList, |     originalStationList, | ||||||
|     favoriteStation, |  | ||||||
|     setFavoriteStation, |  | ||||||
|     busAndTrainData, |  | ||||||
|     navigate, |     navigate, | ||||||
|     onExit, |     onExit, | ||||||
|   } = props; |     goTo, | ||||||
|  |     useShow, | ||||||
|  |   } = props.payload; | ||||||
|  |   const { busAndTrainData } = useBusAndTrainData(); | ||||||
|   const [trainBus, setTrainBus] = useState(); |   const [trainBus, setTrainBus] = useState(); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     if (!currentStation) return () => {}; |     if (!currentStation) return () => {}; | ||||||
| @@ -44,22 +35,36 @@ export const StationDeteilView = (props) => { | |||||||
|     } |     } | ||||||
|     setTrainBus(data[0]); |     setTrainBus(data[0]); | ||||||
|   }, [currentStation]); |   }, [currentStation]); | ||||||
|  |  | ||||||
|  |   const [usePDFView, setUsePDFView] = useState(undefined); | ||||||
|  |   useEffect(() => { | ||||||
|  |     AS.getItem("usePDFView").then(setUsePDFView); | ||||||
|  |   }, []); | ||||||
|   const info = |   const info = | ||||||
|     currentStation && |     currentStation && | ||||||
|     (currentStation[0].StationTimeTable.match(".pdf") |     (currentStation[0].StationTimeTable.match(".pdf") | ||||||
|       ? getPDFViewURL(currentStation[0].StationTimeTable) |       ? getPDFViewURL(currentStation[0].StationTimeTable) | ||||||
|       : currentStation[0].StationTimeTable); |       : currentStation[0].StationTimeTable); | ||||||
|  |   const insets = useSafeAreaInsets(); | ||||||
|   return ( |   return ( | ||||||
|     <ActionSheet |     <ActionSheet | ||||||
|       ref={StationBoardAcSR} |  | ||||||
|       gestureEnabled |       gestureEnabled | ||||||
|       CustomHeaderComponent={<></>} |       CustomHeaderComponent={<></>} | ||||||
|  |       isModal={Platform.OS == "ios"} | ||||||
|  |       containerStyle={ | ||||||
|  |         Platform.OS == "android" | ||||||
|  |           ? { | ||||||
|  |               paddingBottom: insets.bottom, | ||||||
|  |             } | ||||||
|  |           : {} | ||||||
|  |       } | ||||||
|  |       useBottomSafeAreaPadding={Platform.OS == "android"} | ||||||
|     > |     > | ||||||
|       <View |       <View | ||||||
|         key={currentStation} |         key={currentStation} | ||||||
|         style={{ |         style={{ | ||||||
|           backgroundColor: "white", |           backgroundColor: "white", | ||||||
|           borderRadius: 5, |           borderTopRadius: 5, | ||||||
|           borderColor: "dark", |           borderColor: "dark", | ||||||
|           borderWidth: 1, |           borderWidth: 1, | ||||||
|         }} |         }} | ||||||
| @@ -87,14 +92,15 @@ export const StationDeteilView = (props) => { | |||||||
|               <Sign |               <Sign | ||||||
|                 currentStation={currentStation} |                 currentStation={currentStation} | ||||||
|                 originalStationList={originalStationList} |                 originalStationList={originalStationList} | ||||||
|                 favoriteStation={favoriteStation} |  | ||||||
|                 setFavoriteStation={setFavoriteStation} |  | ||||||
|                 oP={() => { |                 oP={() => { | ||||||
|                   navigate("howto", { |                   usePDFView == "true" | ||||||
|  |                     ? Linking.openURL(currentStation[0].StationTimeTable) | ||||||
|  |                     : navigate("howto", { | ||||||
|                         info, |                         info, | ||||||
|                     onExit, |                         goTo, | ||||||
|  |                         useShow, | ||||||
|                       }); |                       }); | ||||||
|                   StationBoardAcSR.current?.hide(); |                   onExit(); | ||||||
|                 }} |                 }} | ||||||
|                 oLP={() => Linking.openURL(currentStation[0].StationTimeTable)} |                 oLP={() => Linking.openURL(currentStation[0].StationTimeTable)} | ||||||
|               /> |               /> | ||||||
| @@ -105,8 +111,6 @@ export const StationDeteilView = (props) => { | |||||||
|               <NexPreStationLine |               <NexPreStationLine | ||||||
|                 currentStation={d} |                 currentStation={d} | ||||||
|                 originalStationList={originalStationList} |                 originalStationList={originalStationList} | ||||||
|                 favoriteStation={favoriteStation} |  | ||||||
|                 setFavoriteStation={setFavoriteStation} |  | ||||||
|               /> |               /> | ||||||
|             ))} |             ))} | ||||||
|           {currentStation && |           {currentStation && | ||||||
| @@ -118,9 +122,11 @@ export const StationDeteilView = (props) => { | |||||||
|                     info: |                     info: | ||||||
|                       currentStation[0].JrHpUrl.replace("/index.html", "/") + |                       currentStation[0].JrHpUrl.replace("/index.html", "/") + | ||||||
|                       "/kounai_map.html", |                       "/kounai_map.html", | ||||||
|                     onExit, |  | ||||||
|  |                     goTo, | ||||||
|  |                     useShow, | ||||||
|                   }); |                   }); | ||||||
|                   StationBoardAcSR.current?.hide(); |                   onExit(); | ||||||
|                 }} |                 }} | ||||||
|                 oLP={() => { |                 oLP={() => { | ||||||
|                   Linking.openURL( |                   Linking.openURL( | ||||||
| @@ -141,9 +147,11 @@ export const StationDeteilView = (props) => { | |||||||
|                   onPressButton={() => { |                   onPressButton={() => { | ||||||
|                     navigate("howto", { |                     navigate("howto", { | ||||||
|                       info: currentStation[0].JrHpUrl, |                       info: currentStation[0].JrHpUrl, | ||||||
|                       onExit, |  | ||||||
|  |                       goTo, | ||||||
|  |                       useShow, | ||||||
|                     }); |                     }); | ||||||
|                     StationBoardAcSR.current?.hide(); |                     onExit(); | ||||||
|                   }} |                   }} | ||||||
|                   onLongPressButton={() => |                   onLongPressButton={() => | ||||||
|                     Linking.openURL(currentStation[0].JrHpUrl) |                     Linking.openURL(currentStation[0].JrHpUrl) | ||||||
| @@ -158,11 +166,15 @@ export const StationDeteilView = (props) => { | |||||||
|                   icon={<FontAwesome name="table" color="white" size={50} />} |                   icon={<FontAwesome name="table" color="white" size={50} />} | ||||||
|                   flex={1} |                   flex={1} | ||||||
|                   onPressButton={() => { |                   onPressButton={() => { | ||||||
|                     navigate("howto", { |                     usePDFView == "true" | ||||||
|  |                       ? Linking.openURL(currentStation[0].StationTimeTable) | ||||||
|  |                       : navigate("howto", { | ||||||
|                           info, |                           info, | ||||||
|                       onExit, |  | ||||||
|  |                           goTo, | ||||||
|  |                           useShow, | ||||||
|                         }); |                         }); | ||||||
|                     StationBoardAcSR.current?.hide(); |                     onExit(); | ||||||
|                   }} |                   }} | ||||||
|                   onLongPressButton={() => |                   onLongPressButton={() => | ||||||
|                     Linking.openURL(currentStation[0].StationTimeTable) |                     Linking.openURL(currentStation[0].StationTimeTable) | ||||||
| @@ -191,9 +203,11 @@ export const StationDeteilView = (props) => { | |||||||
|                   onPressButton={() => { |                   onPressButton={() => { | ||||||
|                     navigate("howto", { |                     navigate("howto", { | ||||||
|                       info: trainBus.address, |                       info: trainBus.address, | ||||||
|                       onExit, |  | ||||||
|  |                       goTo, | ||||||
|  |                       useShow, | ||||||
|                     }); |                     }); | ||||||
|                     StationBoardAcSR.current?.hide(); |                     onExit(); | ||||||
|                   }} |                   }} | ||||||
|                   onLongPressButton={() => Linking.openURL(trainBus.address)} |                   onLongPressButton={() => Linking.openURL(trainBus.address)} | ||||||
|                 > |                 > | ||||||
| @@ -218,13 +232,7 @@ const StationName = (props) => { | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const NexPreStationLine = ({ | const NexPreStationLine = ({ currentStation, originalStationList }) => { | ||||||
|   currentStation, |  | ||||||
|   originalStationList, |  | ||||||
|   oP, |  | ||||||
|   favoriteStation, |  | ||||||
|   setFavoriteStation, |  | ||||||
| }) => { |  | ||||||
|   const [preStation, setPreStation] = useState(); |   const [preStation, setPreStation] = useState(); | ||||||
|   const [nexStation, setNexStation] = useState(); |   const [nexStation, setNexStation] = useState(); | ||||||
|   const [lineName, setLineName] = useState(); |   const [lineName, setLineName] = useState(); | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								components/ActionSheetComponents/sheets.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								components/ActionSheetComponents/sheets.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | import { registerSheet } from "react-native-actions-sheet"; | ||||||
|  | import { EachTrainInfo } from "./EachTrainInfo"; | ||||||
|  | import { JRSTraInfo } from "./JRSTraInfo"; | ||||||
|  | import { StationDeteilView } from "./StationDeteilView"; | ||||||
|  |  | ||||||
|  | registerSheet("EachTrainInfo", EachTrainInfo); | ||||||
|  | registerSheet("JRSTraInfo", JRSTraInfo); | ||||||
|  | registerSheet("StationDetailView", StationDeteilView); | ||||||
|  |  | ||||||
|  | export {}; | ||||||
							
								
								
									
										164
									
								
								components/AllTrainDiagramView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								components/AllTrainDiagramView.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,164 @@ | |||||||
|  | import React, { useRef, useState, useEffect } from "react"; | ||||||
|  | import { | ||||||
|  |   View, | ||||||
|  |   Text, | ||||||
|  |   TouchableOpacity, | ||||||
|  |   Linking, | ||||||
|  |   ScrollView, | ||||||
|  |   FlatList, | ||||||
|  |   KeyboardAvoidingView, | ||||||
|  |   TextInput, | ||||||
|  |   Platform, | ||||||
|  |   Keyboard, | ||||||
|  | } from "react-native"; | ||||||
|  | import MapView, { Marker } from "react-native-maps"; | ||||||
|  | import { MaterialCommunityIcons } from "@expo/vector-icons"; | ||||||
|  | import { useCurrentTrain } from "../stateBox/useCurrentTrain"; | ||||||
|  | import { useAreaInfo } from "../stateBox/useAreaInfo"; | ||||||
|  | import { useAllTrainDiagram } from "../stateBox/useAllTrainDiagram"; | ||||||
|  |  | ||||||
|  | import { customTrainDataDetector } from "./custom-train-data"; | ||||||
|  | import { getStationList, lineList } from "../lib/getStationList"; | ||||||
|  | import { getTrainType } from "../lib/getTrainType"; | ||||||
|  | import { checkDuplicateTrainData } from "../lib/checkDuplicateTrainData"; | ||||||
|  | import { SheetManager } from "react-native-actions-sheet"; | ||||||
|  | export default function AllTrainDiagramView({ navigation: { navigate } }) { | ||||||
|  |   const { currentTrain } = useCurrentTrain(); | ||||||
|  |   const { areaInfo } = useAreaInfo(); | ||||||
|  |   const { allTrainDiagram } = useAllTrainDiagram(); | ||||||
|  |   const [originalStationList, setOriginalStationList] = useState(); // 第一要素 | ||||||
|  |   const [keyList, setKeyList] = useState(); // 第二要素 | ||||||
|  |   useEffect(() => getStationList().then(setOriginalStationList), []); | ||||||
|  |   useEffect( | ||||||
|  |     () => allTrainDiagram && setKeyList(Object.keys(allTrainDiagram)), | ||||||
|  |     [] | ||||||
|  |   ); | ||||||
|  |   const [input, setInput] = useState(""); // 文字入力 | ||||||
|  |   const [keyBoardVisible, setKeyBoardVisible] = useState(false); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     const showSubscription = Keyboard.addListener("keyboardDidShow", () => { | ||||||
|  |       setKeyBoardVisible(true); | ||||||
|  |     }); | ||||||
|  |     const hideSubscription = Keyboard.addListener("keyboardDidHide", () => { | ||||||
|  |       setKeyBoardVisible(false); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     return () => { | ||||||
|  |       showSubscription.remove(); | ||||||
|  |       hideSubscription.remove(); | ||||||
|  |     }; | ||||||
|  |   }, []); | ||||||
|  |  | ||||||
|  |   const openTrainInfo = (d) => { | ||||||
|  |     const train = customTrainDataDetector(d); | ||||||
|  |     let TrainNumber = ""; | ||||||
|  |     if (train.trainNumDistance != undefined) { | ||||||
|  |       const timeInfo = | ||||||
|  |         parseInt(d.replace("M", "").replace("D", "")) - train.trainNumDistance; | ||||||
|  |       TrainNumber = timeInfo + "号"; | ||||||
|  |     } | ||||||
|  |     const payload = { | ||||||
|  |       data: { | ||||||
|  |         trainNum: d, | ||||||
|  |         limited: `${getTrainType(train.type).data}:${ | ||||||
|  |           train.trainName | ||||||
|  |         }${TrainNumber}`, | ||||||
|  |       }, | ||||||
|  |       navigate, | ||||||
|  |       originalStationList, | ||||||
|  |       from: "AllTrainDiagramView", | ||||||
|  |     }; | ||||||
|  |     SheetManager.show("EachTrainInfo", { | ||||||
|  |       payload, | ||||||
|  |     }); | ||||||
|  |   }; | ||||||
|  |   return ( | ||||||
|  |     <View style={{ backgroundColor: "#0099CC", height: "100%" }}> | ||||||
|  |       <FlatList | ||||||
|  |         style={{ flex: 1 }} | ||||||
|  |         data={keyList?.filter((d) => d.includes(input))} | ||||||
|  |         renderItem={({ item }) => ( | ||||||
|  |           <Item openTrainInfo={openTrainInfo} id={item} /> | ||||||
|  |         )} | ||||||
|  |         keyExtractor={(item) => item} | ||||||
|  |         initialNumToRender={100} | ||||||
|  |       /> | ||||||
|  |       <KeyboardAvoidingView | ||||||
|  |         behavior="padding" | ||||||
|  |         keyboardVerticalOffset={80} | ||||||
|  |         enabled={Platform.OS === "ios"} | ||||||
|  |       > | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             height: 35, | ||||||
|  |             margin: 5, | ||||||
|  |             alignItems: "center", | ||||||
|  |             backgroundColor: "#F4F4F4", | ||||||
|  |             flexDirection: "row", | ||||||
|  |             paddingLeft: 10, | ||||||
|  |             paddingRight: 10, | ||||||
|  |             borderRadius: 25, | ||||||
|  |             borderColor: "#F4F4F4", | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           <TextInput | ||||||
|  |             placeholder="列番を入力してフィルタリングします。" | ||||||
|  |             onFocus={() => { | ||||||
|  |               setKeyBoardVisible(true); | ||||||
|  |             }} | ||||||
|  |             onEndEditing={() => {}} | ||||||
|  |             onChange={(ret) => { | ||||||
|  |               setInput(ret.nativeEvent.text); | ||||||
|  |             }} | ||||||
|  |             value={input} | ||||||
|  |             style={{ flex: 1 }} | ||||||
|  |           /> | ||||||
|  |         </View> | ||||||
|  |       </KeyboardAvoidingView> | ||||||
|  |  | ||||||
|  |       <TouchableOpacity | ||||||
|  |         style={{ | ||||||
|  |           padding: 10, | ||||||
|  |           flexDirection: "row", | ||||||
|  |           borderColor: "white", | ||||||
|  |           borderWidth: 1, | ||||||
|  |           margin: 10, | ||||||
|  |           borderRadius: 5, | ||||||
|  |           alignItems: "center", | ||||||
|  |           display: | ||||||
|  |             Platform.OS === "ios" ? "flex" : keyBoardVisible ? "none" : "flex", | ||||||
|  |         }} | ||||||
|  |         onPress={() => navigate("menu")} | ||||||
|  |       > | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |         <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> | ||||||
|  |           閉じる | ||||||
|  |         </Text> | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |       </TouchableOpacity> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | const Item = ({ id, openTrainInfo }) => { | ||||||
|  |   return ( | ||||||
|  |     <TouchableOpacity | ||||||
|  |       style={{ | ||||||
|  |         padding: 5, | ||||||
|  |         flexDirection: "row", | ||||||
|  |         borderColor: "white", | ||||||
|  |         borderWidth: 1, | ||||||
|  |         margin: 5, | ||||||
|  |         borderRadius: 5, | ||||||
|  |         alignItems: "center", | ||||||
|  |       }} | ||||||
|  |       onPress={() => openTrainInfo(id)} | ||||||
|  |     > | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |       <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> | ||||||
|  |         {id} | ||||||
|  |       </Text> | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |     </TouchableOpacity> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										51
									
								
								components/CurrentTrainListView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								components/CurrentTrainListView.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | import React, { useRef } from "react"; | ||||||
|  | import { View, Text, TouchableOpacity, Linking } from "react-native"; | ||||||
|  | import MapView, { Marker } from "react-native-maps"; | ||||||
|  | import { MaterialCommunityIcons } from "@expo/vector-icons"; | ||||||
|  | import { useCurrentTrain } from "../stateBox/useCurrentTrain"; | ||||||
|  | export default function CurrentTrainListView({ navigation: { navigate } }) { | ||||||
|  |   const { currentTrain } = useCurrentTrain(); | ||||||
|  |   return ( | ||||||
|  |     <View style={{ height: "100%", backgroundColor: "#0099CC" }}> | ||||||
|  |       {currentTrain && currentTrain.map((d) => <Text>{d.num}</Text>)} | ||||||
|  |       <TouchableOpacity | ||||||
|  |         style={{ | ||||||
|  |           padding: 10, | ||||||
|  |           flexDirection: "row", | ||||||
|  |           borderColor: "white", | ||||||
|  |           borderWidth: 1, | ||||||
|  |           margin: 10, | ||||||
|  |           borderRadius: 5, | ||||||
|  |           alignItems: "center", | ||||||
|  |         }} | ||||||
|  |         onPress={() => navigate("menu")} | ||||||
|  |       > | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |         <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> | ||||||
|  |           閉じる | ||||||
|  |         </Text> | ||||||
|  |         <View style={{ flex: 1 }} /> | ||||||
|  |       </TouchableOpacity> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | const UsefulBox = (props) => { | ||||||
|  |   const { icon, backgroundColor, flex, onPressButton, children } = props; | ||||||
|  |   return ( | ||||||
|  |     <TouchableOpacity | ||||||
|  |       style={{ | ||||||
|  |         flex: flex, | ||||||
|  |         backgroundColor: backgroundColor, | ||||||
|  |         padding: 10, | ||||||
|  |         alignItems: "center", | ||||||
|  |         margin: 2, | ||||||
|  |       }} | ||||||
|  |       onPress={onPressButton} | ||||||
|  |     > | ||||||
|  |       <MaterialCommunityIcons name={icon} color="white" size={50} /> | ||||||
|  |       <Text style={{ color: "white", fontWeight: "bold", fontSize: 18 }}> | ||||||
|  |         {children} | ||||||
|  |       </Text> | ||||||
|  |     </TouchableOpacity> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										106
									
								
								components/DynamicHeaderScrollView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								components/DynamicHeaderScrollView.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,106 @@ | |||||||
|  | import { ScrollView, View, Animated, Platform } from "react-native"; | ||||||
|  | import React, { useRef } from "react"; | ||||||
|  |  | ||||||
|  | export const DynamicHeaderScrollView = (props) => { | ||||||
|  |   const { | ||||||
|  |     Max_Header_Height = 200, | ||||||
|  |     Min_Header_Height = 80, | ||||||
|  |     children, | ||||||
|  |     scrollViewProps = {}, | ||||||
|  |     containerProps = {}, | ||||||
|  |     shortHeader = <></>, | ||||||
|  |     longHeader = <></>, | ||||||
|  |     topStickyContent, | ||||||
|  |     styles, | ||||||
|  |   } = props; | ||||||
|  |   const scrollOffsetY = useRef(new Animated.Value(0)).current; | ||||||
|  |  | ||||||
|  |   const Scroll_Distance = Max_Header_Height - Min_Header_Height; | ||||||
|  |  | ||||||
|  |   const animatedHeaderHeight = scrollOffsetY.interpolate({ | ||||||
|  |     inputRange: [Scroll_Distance, Scroll_Distance + 30], | ||||||
|  |     outputRange: [Max_Header_Height, 0], | ||||||
|  |     extrapolate: "clamp", | ||||||
|  |   }); | ||||||
|  |   const animatedHeaderHeight2 = scrollOffsetY.interpolate({ | ||||||
|  |     inputRange: [Scroll_Distance, Scroll_Distance + 30], | ||||||
|  |     outputRange: [Max_Header_Height, Min_Header_Height], | ||||||
|  |     extrapolate: "clamp", | ||||||
|  |   }); | ||||||
|  |   const animatedHeaderVisible = scrollOffsetY.interpolate({ | ||||||
|  |     inputRange: [Scroll_Distance - 30, Scroll_Distance], | ||||||
|  |     outputRange: [1, 0], | ||||||
|  |     extrapolate: "clamp", | ||||||
|  |   }); | ||||||
|  |   const animatedHeaderVisible2 = scrollOffsetY.interpolate({ | ||||||
|  |     inputRange: [Scroll_Distance - 30, Scroll_Distance + 30], | ||||||
|  |     outputRange: [0, 1], | ||||||
|  |     extrapolate: "clamp", | ||||||
|  |   }); | ||||||
|  |   return ( | ||||||
|  |     <View {...containerProps}> | ||||||
|  |       <View style={{ zIndex: 1 }}> | ||||||
|  |         <Animated.View | ||||||
|  |           style={[ | ||||||
|  |             styles.header, | ||||||
|  |             { | ||||||
|  |               height: animatedHeaderHeight2, | ||||||
|  |               backgroundColor: "#0099CC", | ||||||
|  |               margin: 0, | ||||||
|  |               top: 0, | ||||||
|  |               opacity: animatedHeaderVisible2, | ||||||
|  |             }, | ||||||
|  |           ]} | ||||||
|  |         > | ||||||
|  |           {shortHeader} | ||||||
|  |         </Animated.View> | ||||||
|  |         <Animated.View | ||||||
|  |           style={[ | ||||||
|  |             styles.header, | ||||||
|  |             { | ||||||
|  |               height: animatedHeaderHeight, | ||||||
|  |               backgroundColor: "#0099CC", | ||||||
|  |               opacity: animatedHeaderVisible, | ||||||
|  |  | ||||||
|  |               top: 0, | ||||||
|  |             }, | ||||||
|  |           ]} | ||||||
|  |         > | ||||||
|  |           {longHeader} | ||||||
|  |         </Animated.View> | ||||||
|  |       </View> | ||||||
|  |       <ScrollView | ||||||
|  |         {...scrollViewProps} | ||||||
|  |         style={{ | ||||||
|  |           backgroundColor: "white", | ||||||
|  |           zIndex: 0, | ||||||
|  |         }} | ||||||
|  |         stickyHeaderIndices={[1]} | ||||||
|  |         scrollEventThrottle={16} | ||||||
|  |         onScroll={Animated.event( | ||||||
|  |           [{ nativeEvent: { contentOffset: { y: scrollOffsetY } } }], | ||||||
|  |           { useNativeDriver: false } | ||||||
|  |         )} | ||||||
|  |       > | ||||||
|  |         <View | ||||||
|  |           style={{ | ||||||
|  |             height: Scroll_Distance, | ||||||
|  |             flexDirection: "column", | ||||||
|  |           }} | ||||||
|  |         /> | ||||||
|  |         {topStickyContent && ( | ||||||
|  |           <View | ||||||
|  |             style={{ | ||||||
|  |               paddingTop: Min_Header_Height, | ||||||
|  |               flexDirection: "column", | ||||||
|  |             }} | ||||||
|  |             index={1} | ||||||
|  |           > | ||||||
|  |             {topStickyContent} | ||||||
|  |           </View> | ||||||
|  |         )} | ||||||
|  |         {children} | ||||||
|  |       </ScrollView> | ||||||
|  |     </View> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
| @@ -1,21 +1,11 @@ | |||||||
| import React, { Component, useRef, useState, useEffect } from "react"; | import React from "react"; | ||||||
| import { View, Text, TouchableOpacity, ScrollView } from "react-native"; | import { View, Text, TouchableOpacity, ScrollView } from "react-native"; | ||||||
| import { WebView } from "react-native-webview"; |  | ||||||
| import { ListItem } from "native-base"; | import { ListItem } from "native-base"; | ||||||
| import Icon from "react-native-vector-icons/Entypo"; | import Icon from "react-native-vector-icons/Entypo"; | ||||||
| import StatusbarDetect from "../StatusbarDetect"; | import { useFavoriteStation } from "../stateBox/useFavoriteStation"; | ||||||
| import { AS } from "../storageControl"; | export default function FavoriteList({ navigation, webview, stationData }) { | ||||||
| import { news } from "../config/newsUpdate"; |  | ||||||
| import { getStationList, lineList } from "../lib/getStationList"; |  | ||||||
| var Status = StatusbarDetect(); |  | ||||||
| export default function FavoriteList({ |  | ||||||
|   navigation, |  | ||||||
|   webview, |  | ||||||
|   stationData, |  | ||||||
|   favoriteStation, |  | ||||||
|   setFavoriteStation, |  | ||||||
| }) { |  | ||||||
|   const { navigate } = navigation; |   const { navigate } = navigation; | ||||||
|  |   const { favoriteStation } = useFavoriteStation(); | ||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|     <View style={{ height: "100%", backgroundColor: "#0099CC" }}> |     <View style={{ height: "100%", backgroundColor: "#0099CC" }}> | ||||||
|   | |||||||
| @@ -7,8 +7,8 @@ export const TextBox = (props) => { | |||||||
|       style={{ |       style={{ | ||||||
|         flex: flex, |         flex: flex, | ||||||
|         backgroundColor: backgroundColor, |         backgroundColor: backgroundColor, | ||||||
|         padding: 10, |         padding: 5, | ||||||
|         height: 70, |         minHeight: 70, | ||||||
|         alignItems: "center", |         alignItems: "center", | ||||||
|         alignContent: "center", |         alignContent: "center", | ||||||
|         margin: 2, |         margin: 2, | ||||||
|   | |||||||
| @@ -608,6 +608,43 @@ export const customTrainDataDetector = (TrainNumber) => { | |||||||
|         info: "", |         info: "", | ||||||
|       }; |       }; | ||||||
|  |  | ||||||
|  |     /////ロイヤルエクスプレス | ||||||
|  |     case "9001": | ||||||
|  |     case "9029": | ||||||
|  |       return { | ||||||
|  |         type: "SPCL", | ||||||
|  |         trainName: "THE ROYAL EXPRESS", | ||||||
|  |         trainIcon: "http://trainfrontview.net/p/izq2100rex1.png", | ||||||
|  |         trainNumDistance: null, | ||||||
|  |         info: "[団体専用] 第1章 -瀬戸の海に想いを馳せながら- 岡山・高松・琴平", | ||||||
|  |       }; | ||||||
|  |     /////ロイヤルエクスプレス | ||||||
|  |     case "9003": | ||||||
|  |       return { | ||||||
|  |         type: "SPCL", | ||||||
|  |         trainName: "THE ROYAL EXPRESS", | ||||||
|  |         trainIcon: "http://trainfrontview.net/p/izq2100rex1.png", | ||||||
|  |         trainNumDistance: null, | ||||||
|  |         info: "[団体専用] 第2章 -四国の伝統文化を感じて- 多度津・坂出・松山", | ||||||
|  |       }; | ||||||
|  |       /////ロイヤルエクスプレス | ||||||
|  |       case "9055": | ||||||
|  |       case "9056": | ||||||
|  |         return { | ||||||
|  |           type: "SPCL", | ||||||
|  |           trainName: "THE ROYAL EXPRESS", | ||||||
|  |           trainIcon: "http://trainfrontview.net/p/izq2100rex1.png", | ||||||
|  |           trainNumDistance: null, | ||||||
|  |           info: "[団体専用] 第3章 -凪の誘い・瀬戸内の絶景- 今治・しまなみ海道", | ||||||
|  |         }; | ||||||
|  |       case "9004": | ||||||
|  |         return { | ||||||
|  |           type: "SPCL", | ||||||
|  |           trainName: "THE ROYAL EXPRESS", | ||||||
|  |           trainIcon: "http://trainfrontview.net/p/izq2100rex1.png", | ||||||
|  |           trainNumDistance: null, | ||||||
|  |           info: "[団体専用] フィナーレ -四国・瀬戸内の彩りに囲まれて- 今治・高松・岡山", | ||||||
|  |         }; | ||||||
|     default: |     default: | ||||||
|       return { |       return { | ||||||
|         type: "Normal", |         type: "Normal", | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| import React, { useState, useEffect } from "react"; | import React, { useState, useEffect } from "react"; | ||||||
| import { View, Text, TouchableOpacity } from "react-native"; | import { View, Text, TouchableOpacity, Linking } from "react-native"; | ||||||
| import * as Updates from "expo-updates"; | import * as Updates from "expo-updates"; | ||||||
| import StatusbarDetect from "../StatusbarDetect"; | import StatusbarDetect from "../StatusbarDetect"; | ||||||
| import { AS } from "../storageControl"; | import { AS } from "../storageControl"; | ||||||
| @@ -10,15 +10,17 @@ export default function Setting(props) { | |||||||
|   const { |   const { | ||||||
|     navigation: { navigate }, |     navigation: { navigate }, | ||||||
|   } = props; |   } = props; | ||||||
|   const [iconSetting, setIconSetting] = useState(undefined); |   const [iconSetting, setIconSetting] = useState(false); | ||||||
|   const [mapSwitch, setMapSwitch] = useState(undefined); |   const [mapSwitch, setMapSwitch] = useState(false); | ||||||
|   const [stationMenu, setStationMenu] = useState(undefined); |   const [stationMenu, setStationMenu] = useState(false); | ||||||
|   const [trainMenu, setTrainMenu] = useState(undefined); |   const [usePDFView, setUsePDFView] = useState(false); | ||||||
|   const [trainPosition, setTrainPosition] = useState(undefined); |   const [trainMenu, setTrainMenu] = useState(false); | ||||||
|  |   const [trainPosition, setTrainPosition] = useState(false); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     AS.getItem("iconSwitch").then(setIconSetting); |     AS.getItem("iconSwitch").then(setIconSetting); | ||||||
|     AS.getItem("mapSwitch").then(setMapSwitch); |     AS.getItem("mapSwitch").then(setMapSwitch); | ||||||
|     AS.getItem("stationSwitch").then(setStationMenu); |     AS.getItem("stationSwitch").then(setStationMenu); | ||||||
|  |     AS.getItem("usePDFView").then(setUsePDFView); | ||||||
|     AS.getItem("trainSwitch").then(setTrainMenu); |     AS.getItem("trainSwitch").then(setTrainMenu); | ||||||
|     AS.getItem("trainPositionSwitch").then(setTrainPosition); |     AS.getItem("trainPositionSwitch").then(setTrainPosition); | ||||||
|   }, []); |   }, []); | ||||||
| @@ -96,6 +98,25 @@ export default function Setting(props) { | |||||||
|               onValueChange={(value) => setStationMenu(value.toString())} |               onValueChange={(value) => setStationMenu(value.toString())} | ||||||
|             /> |             /> | ||||||
|           </View> |           </View> | ||||||
|  |           <View style={{ flexDirection: "row", padding: 10 }}> | ||||||
|  |             <Text | ||||||
|  |               style={{ | ||||||
|  |                 fontSize: 25, | ||||||
|  |                 alignItems: "center", | ||||||
|  |                 alignContent: "center", | ||||||
|  |                 textAlign: "center", | ||||||
|  |                 textAlignVertical: "center", | ||||||
|  |               }} | ||||||
|  |             > | ||||||
|  |               時刻表PDFをアプリ外で表示 | ||||||
|  |             </Text> | ||||||
|  |             <View style={{ flex: 1 }} /> | ||||||
|  |             <Switch | ||||||
|  |               value={usePDFView == "true" ? true : false} | ||||||
|  |               color={usePDFView == "true" ? "red" : null} | ||||||
|  |               onValueChange={(value) => setUsePDFView(value.toString())} | ||||||
|  |             /> | ||||||
|  |           </View> | ||||||
|           <View style={{ flexDirection: "row", padding: 10 }}> |           <View style={{ flexDirection: "row", padding: 10 }}> | ||||||
|             <Text |             <Text | ||||||
|               style={{ |               style={{ | ||||||
| @@ -144,7 +165,7 @@ export default function Setting(props) { | |||||||
|                 textAlignVertical: "center", |                 textAlignVertical: "center", | ||||||
|               }} |               }} | ||||||
|             > |             > | ||||||
|               内部バージョン: 4.5 beta-2 |               内部バージョン: 4.6.4 | ||||||
|             </Text> |             </Text> | ||||||
|             <View style={{ flex: 1 }} /> |             <View style={{ flex: 1 }} /> | ||||||
|           </View> |           </View> | ||||||
| @@ -158,10 +179,31 @@ export default function Setting(props) { | |||||||
|                 textAlignVertical: "center", |                 textAlignVertical: "center", | ||||||
|               }} |               }} | ||||||
|             > |             > | ||||||
|               releaseChannel: {Updates.releaseChannel} |               releaseChannel: {Updates.channel} | ||||||
|             </Text> |             </Text> | ||||||
|             <View style={{ flex: 1 }} /> |             <View style={{ flex: 1 }} /> | ||||||
|           </View> |           </View> | ||||||
|  |           <TouchableOpacity | ||||||
|  |             style={{ flexDirection: "row", padding: 10 }} | ||||||
|  |             onPress={() => | ||||||
|  |               Linking.openURL( | ||||||
|  |                 "https://nexcloud.haruk.in/sites/press-harukin/JRShikokuApps/policy" | ||||||
|  |               ) | ||||||
|  |             } | ||||||
|  |           > | ||||||
|  |             <Text | ||||||
|  |               style={{ | ||||||
|  |                 fontSize: 25, | ||||||
|  |                 alignItems: "center", | ||||||
|  |                 alignContent: "center", | ||||||
|  |                 textAlign: "center", | ||||||
|  |                 textAlignVertical: "center", | ||||||
|  |               }} | ||||||
|  |             > | ||||||
|  |               プライバシーポリシー | ||||||
|  |             </Text> | ||||||
|  |             <View style={{ flex: 1 }} /> | ||||||
|  |           </TouchableOpacity> | ||||||
|         </View> |         </View> | ||||||
|       </View> |       </View> | ||||||
|       <TouchableOpacity |       <TouchableOpacity | ||||||
| @@ -179,6 +221,7 @@ export default function Setting(props) { | |||||||
|             AS.setItem("iconSwitch", iconSetting.toString()), |             AS.setItem("iconSwitch", iconSetting.toString()), | ||||||
|             AS.setItem("mapSwitch", mapSwitch.toString()), |             AS.setItem("mapSwitch", mapSwitch.toString()), | ||||||
|             AS.setItem("stationSwitch", stationMenu.toString()), |             AS.setItem("stationSwitch", stationMenu.toString()), | ||||||
|  |             AS.setItem("usePDFView", usePDFView.toString()), | ||||||
|             AS.setItem("trainSwitch", trainMenu.toString()), |             AS.setItem("trainSwitch", trainMenu.toString()), | ||||||
|             AS.setItem("trainPositionSwitch", trainPosition.toString()), |             AS.setItem("trainPositionSwitch", trainPosition.toString()), | ||||||
|           ]).then(() => { |           ]).then(() => { | ||||||
|   | |||||||
| @@ -6,10 +6,11 @@ export default function TrainMenu({ | |||||||
|   navigation: { navigate }, |   navigation: { navigate }, | ||||||
|   webview, |   webview, | ||||||
|   stationData, |   stationData, | ||||||
|  |   style, | ||||||
| }) { | }) { | ||||||
|   const mapRef = useRef(); |   const mapRef = useRef(); | ||||||
|   return ( |   return ( | ||||||
|     <View style={{ height: "100%", backgroundColor: "#0099CC" }}> |     <View style={{ height: "100%", backgroundColor: "#0099CC", ...style }}> | ||||||
|       <MapView |       <MapView | ||||||
|         style={{ flex: 1, width: "100%", height: "100%" }} |         style={{ flex: 1, width: "100%", height: "100%" }} | ||||||
|         showsUserLocation={true} |         showsUserLocation={true} | ||||||
| @@ -46,13 +47,14 @@ export default function TrainMenu({ | |||||||
|                     webview.current?.injectJavaScript( |                     webview.current?.injectJavaScript( | ||||||
|                       `MoveDisplayStation('${d}_${D.MyStation}_${D.Station_JP}')` |                       `MoveDisplayStation('${d}_${D.MyStation}_${D.Station_JP}')` | ||||||
|                     ); |                     ); | ||||||
|                     navigate("Apps"); |                     if (navigate) navigate("Apps"); | ||||||
|                   }} |                   }} | ||||||
|                 ></Marker> |                 ></Marker> | ||||||
|               ); |               ); | ||||||
|             }) |             }) | ||||||
|           )} |           )} | ||||||
|       </MapView> |       </MapView> | ||||||
|  |       {navigate && ( | ||||||
|         <View style={{ flexDirection: "row" }}> |         <View style={{ flexDirection: "row" }}> | ||||||
|           <UsefulBox |           <UsefulBox | ||||||
|             backgroundColor={"#F89038"} |             backgroundColor={"#F89038"} | ||||||
| @@ -84,9 +86,11 @@ export default function TrainMenu({ | |||||||
|               ) |               ) | ||||||
|             } |             } | ||||||
|           > |           > | ||||||
|           この機能のフィードバック |             フィードバック | ||||||
|           </UsefulBox> |           </UsefulBox> | ||||||
|         </View> |         </View> | ||||||
|  |       )} | ||||||
|  |       {navigate && ( | ||||||
|         <TouchableOpacity |         <TouchableOpacity | ||||||
|           style={{ |           style={{ | ||||||
|             padding: 10, |             padding: 10, | ||||||
| @@ -105,6 +109,7 @@ export default function TrainMenu({ | |||||||
|           </Text> |           </Text> | ||||||
|           <View style={{ flex: 1 }} /> |           <View style={{ flex: 1 }} /> | ||||||
|         </TouchableOpacity> |         </TouchableOpacity> | ||||||
|  |       )} | ||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
| @@ -115,14 +120,14 @@ const UsefulBox = (props) => { | |||||||
|       style={{ |       style={{ | ||||||
|         flex: flex, |         flex: flex, | ||||||
|         backgroundColor: backgroundColor, |         backgroundColor: backgroundColor, | ||||||
|         padding: 10, |         padding: 5, | ||||||
|         alignItems: "center", |         alignItems: "center", | ||||||
|         margin: 2, |         margin: 2, | ||||||
|       }} |       }} | ||||||
|       onPress={onPressButton} |       onPress={onPressButton} | ||||||
|     > |     > | ||||||
|       <MaterialCommunityIcons name={icon} color="white" size={50} /> |       <MaterialCommunityIcons name={icon} color="white" size={50} /> | ||||||
|       <Text style={{ color: "white", fontWeight: "bold", fontSize: 18 }}> |       <Text style={{ color: "white", fontWeight: "bold", fontSize: 16 }}> | ||||||
|         {children} |         {children} | ||||||
|       </Text> |       </Text> | ||||||
|     </TouchableOpacity> |     </TouchableOpacity> | ||||||
|   | |||||||
| @@ -3,16 +3,16 @@ import { View, Text, TouchableOpacity } from "react-native"; | |||||||
| import { Switch } from "react-native-elements"; | import { Switch } from "react-native-elements"; | ||||||
| import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | ||||||
| import LottieView from "lottie-react-native"; | import LottieView from "lottie-react-native"; | ||||||
| import { Ionicons, MaterialCommunityIcons } from "@expo/vector-icons"; | import { Ionicons } from "@expo/vector-icons"; | ||||||
| import { customTrainDataDetector } from "../custom-train-data"; | import { customTrainDataDetector } from "../custom-train-data"; | ||||||
| import { useInterval } from "../../lib/useInterval"; | import { useInterval } from "../../lib/useInterval"; | ||||||
| import { objectIsEmpty } from "../../lib/objectIsEmpty"; | import { objectIsEmpty } from "../../lib/objectIsEmpty"; | ||||||
| import { getTrainType } from "../../lib/getTrainType"; | import { getTrainType } from "../../lib/getTrainType"; | ||||||
| import { HeaderConfig } from "../../lib/HeaderConfig"; |  | ||||||
| import { getTrainDelayStatus } from "../../lib/getTrainDelayStatus"; | import { getTrainDelayStatus } from "../../lib/getTrainDelayStatus"; | ||||||
| import { checkDuplicateTrainData } from "../../lib/checkDuplicateTrainData"; | import { checkDuplicateTrainData } from "../../lib/checkDuplicateTrainData"; | ||||||
|  | import { useCurrentTrain } from "../../stateBox/useCurrentTrain"; | ||||||
| let diagramData = undefined; | import { useAreaInfo } from "../../stateBox/useAreaInfo"; | ||||||
|  | import { SheetManager } from "react-native-actions-sheet"; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
| @@ -46,20 +46,18 @@ let diagramData = undefined; | |||||||
| export default function LED_vision(props) { | export default function LED_vision(props) { | ||||||
|   const { |   const { | ||||||
|     station, |     station, | ||||||
|     setTrainInfo, |  | ||||||
|     EachTrainInfoAsSR, |  | ||||||
|     trainDiagram, |     trainDiagram, | ||||||
|     currentTrainState, |  | ||||||
|     currentTrainLoadingState, |  | ||||||
|     getCurrentTrain, |     getCurrentTrain, | ||||||
|  |     navigate, | ||||||
|  |     originalStationList, | ||||||
|  |     openStationACFromEachTrainInfo, | ||||||
|   } = props; |   } = props; | ||||||
|   const { currentTrain, setCurrentTrain } = currentTrainState; |   const { currentTrain } = useCurrentTrain(); | ||||||
|   const { currentTrainLoading, setCurrentTrainLoading } = |  | ||||||
|     currentTrainLoadingState; |  | ||||||
|   const [stationDiagram, setStationDiagram] = useState({}); //当該駅の全時刻表 |   const [stationDiagram, setStationDiagram] = useState({}); //当該駅の全時刻表 | ||||||
|   const [finalSwitch, setFinalSwitch] = useState(false); |   const [finalSwitch, setFinalSwitch] = useState(false); | ||||||
|   const [trainIDSwitch, setTrainIDSwitch] = useState(false); |   const [trainIDSwitch, setTrainIDSwitch] = useState(false); | ||||||
|   const [trainDescriptionSwitch, setTrainDescriptionSwitch] = useState(false); |   const [trainDescriptionSwitch, setTrainDescriptionSwitch] = useState(false); | ||||||
|  |   const { areaInfo } = useAreaInfo(); | ||||||
|  |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     // 現在の駅に停車するダイヤを作成する副作用[列車ダイヤと現在駅情報] |     // 現在の駅に停車するダイヤを作成する副作用[列車ダイヤと現在駅情報] | ||||||
| @@ -149,6 +147,34 @@ export default function LED_vision(props) { | |||||||
|     return false; |     return false; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|  |   const [areaString, setAreaString] = useState(""); | ||||||
|  |   const [areaStringLength, setAreaStringLength] = useState(0); | ||||||
|  |   const [move, setMove] = useState(0); | ||||||
|  |   useInterval( | ||||||
|  |     () => { | ||||||
|  |       if (areaInfo != "") { | ||||||
|  |         if (areaStringLength < move) { | ||||||
|  |           setMove(0); | ||||||
|  |         } else { | ||||||
|  |           setMove(move + 1); | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     350, | ||||||
|  |     true | ||||||
|  |   ); | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (!areaInfo) return () => {}; | ||||||
|  |     setAreaString( | ||||||
|  |       areaInfo.substring(move, areaInfo.length) + areaInfo.substring(0, move) | ||||||
|  |     ); | ||||||
|  |   }, [move]); | ||||||
|  |  | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (!areaInfo) return () => {}; | ||||||
|  |     setAreaStringLength(areaInfo.length); | ||||||
|  |   }, [areaInfo]); | ||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|     <View |     <View | ||||||
|       style={{ |       style={{ | ||||||
| @@ -159,23 +185,27 @@ export default function LED_vision(props) { | |||||||
|         marginHorizontal: wp("1%"), |         marginHorizontal: wp("1%"), | ||||||
|       }} |       }} | ||||||
|     > |     > | ||||||
|       <Header |       <Header getCurrentTrain={getCurrentTrain} /> | ||||||
|         currentTrainLoading={currentTrainLoading} |       {selectedTrain.map((d) => ( | ||||||
|         setCurrentTrainLoading={setCurrentTrainLoading} |  | ||||||
|         getCurrentTrain={getCurrentTrain} |  | ||||||
|       /> |  | ||||||
|       {selectedTrain.map((d, index) => ( |  | ||||||
|         <EachData |         <EachData | ||||||
|           d={d} |           d={d} | ||||||
|           trainIDSwitch={trainIDSwitch} |           trainIDSwitch={trainIDSwitch} | ||||||
|           trainDescriptionSwitch={trainDescriptionSwitch} |           trainDescriptionSwitch={trainDescriptionSwitch} | ||||||
|           station={station} |           station={station} | ||||||
|           currentTrain={currentTrain} |  | ||||||
|           customTrainDataDetector={customTrainDataDetector} |           customTrainDataDetector={customTrainDataDetector} | ||||||
|           setTrainInfo={setTrainInfo} |           navigate={navigate} | ||||||
|           EachTrainInfoAsSR={EachTrainInfoAsSR} |           originalStationList={originalStationList} | ||||||
|  |           openStationACFromEachTrainInfo={openStationACFromEachTrainInfo} | ||||||
|         /> |         /> | ||||||
|       ))} |       ))} | ||||||
|  |       {areaString != "" && ( | ||||||
|  |         <Description | ||||||
|  |           numberOfLines={1} | ||||||
|  |           info={areaString.replace("\n", "").replace("\r", "")} | ||||||
|  |           onClick={() => alert(areaInfo)} | ||||||
|  |         /> | ||||||
|  |       )} | ||||||
|  |  | ||||||
|       <Footer |       <Footer | ||||||
|         trainIDSwitch={trainIDSwitch} |         trainIDSwitch={trainIDSwitch} | ||||||
|         setTrainIDSwitch={setTrainIDSwitch} |         setTrainIDSwitch={setTrainIDSwitch} | ||||||
| @@ -187,11 +217,9 @@ export default function LED_vision(props) { | |||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
| const Header = ({ | const Header = ({ getCurrentTrain }) => { | ||||||
|   currentTrainLoading, |   const { currentTrainLoading, setCurrentTrainLoading } = useCurrentTrain(); | ||||||
|   setCurrentTrainLoading, |   return ( | ||||||
|   getCurrentTrain, |  | ||||||
| }) => ( |  | ||||||
|     <View |     <View | ||||||
|       style={{ |       style={{ | ||||||
|         alignContent: "center", |         alignContent: "center", | ||||||
| @@ -231,6 +259,7 @@ const Header = ({ | |||||||
|       </View> |       </View> | ||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const Footer = (props) => { | const Footer = (props) => { | ||||||
|   const { |   const { | ||||||
| @@ -272,11 +301,12 @@ const EachData = ({ | |||||||
|   trainIDSwitch, |   trainIDSwitch, | ||||||
|   trainDescriptionSwitch, |   trainDescriptionSwitch, | ||||||
|   station, |   station, | ||||||
|   currentTrain, |  | ||||||
|   customTrainDataDetector, |   customTrainDataDetector, | ||||||
|   setTrainInfo, |   navigate, | ||||||
|   EachTrainInfoAsSR, |   originalStationList, | ||||||
|  |   openStationACFromEachTrainInfo, | ||||||
| }) => { | }) => { | ||||||
|  |   const { currentTrain } = useCurrentTrain(); | ||||||
|   const openTrainInfo = (d) => { |   const openTrainInfo = (d) => { | ||||||
|     let TrainNumber = ""; |     let TrainNumber = ""; | ||||||
|     if (train.trainNumDistance != undefined) { |     if (train.trainNumDistance != undefined) { | ||||||
| @@ -285,16 +315,21 @@ const EachData = ({ | |||||||
|         train.trainNumDistance; |         train.trainNumDistance; | ||||||
|       TrainNumber = timeInfo + "号"; |       TrainNumber = timeInfo + "号"; | ||||||
|     } |     } | ||||||
|     setTrainInfo({ |     const payload = { | ||||||
|  |       data: { | ||||||
|         trainNum: d.train, |         trainNum: d.train, | ||||||
|         limited: `${getTrainType(train.type).data}:${ |         limited: `${getTrainType(train.type).data}:${ | ||||||
|           train.trainName |           train.trainName | ||||||
|         }${TrainNumber}`, |         }${TrainNumber}`, | ||||||
|       trainData: checkDuplicateTrainData( |       }, | ||||||
|         currentTrain.filter((a) => a.num == d.train) |       navigate, | ||||||
|       ), |       originalStationList, | ||||||
|  |       openStationACFromEachTrainInfo, | ||||||
|  |       from: "LED", | ||||||
|  |     }; | ||||||
|  |     SheetManager.show("EachTrainInfo", { | ||||||
|  |       payload, | ||||||
|     }); |     }); | ||||||
|     EachTrainInfoAsSR.current?.show(); |  | ||||||
|   }; |   }; | ||||||
|   const [train, setTrain] = useState(customTrainDataDetector(d.train)); |   const [train, setTrain] = useState(customTrainDataDetector(d.train)); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
| @@ -413,8 +448,8 @@ const StatusAndDelay = ({ trainDelayStatus }) => { | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const Description = ({ info }) => ( | const Description = ({ info, numberOfLines = 0, onClick }) => ( | ||||||
|   <View |   <TouchableOpacity | ||||||
|     style={{ |     style={{ | ||||||
|       alignContent: "center", |       alignContent: "center", | ||||||
|       alignItems: "center", |       alignItems: "center", | ||||||
| @@ -424,6 +459,7 @@ const Description = ({ info }) => ( | |||||||
|       backgroundColor: "#000", |       backgroundColor: "#000", | ||||||
|       flexDirection: "row", |       flexDirection: "row", | ||||||
|     }} |     }} | ||||||
|  |     onPress={onClick} | ||||||
|   > |   > | ||||||
|     <View style={{ flex: 4 }}> |     <View style={{ flex: 4 }}> | ||||||
|       <Text |       <Text | ||||||
| @@ -432,10 +468,11 @@ const Description = ({ info }) => ( | |||||||
|           color: "green", |           color: "green", | ||||||
|           fontWeight: "bold", |           fontWeight: "bold", | ||||||
|         }} |         }} | ||||||
|  |         numberOfLines={numberOfLines} | ||||||
|       > |       > | ||||||
|         {" "} |         {" "} | ||||||
|         > {info} |         > {info} | ||||||
|       </Text> |       </Text> | ||||||
|     </View> |     </View> | ||||||
|   </View> |   </TouchableOpacity> | ||||||
| ); | ); | ||||||
|   | |||||||
| @@ -1,36 +1,21 @@ | |||||||
| import React, { Component, useRef, useState, useEffect } from "react"; | import React, { useRef, useState, useEffect } from "react"; | ||||||
| import { | import { View, Text, TouchableOpacity } from "react-native"; | ||||||
|   StatusBar, | import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | ||||||
|   View, |  | ||||||
|   LayoutAnimation, |  | ||||||
|   ScrollView, |  | ||||||
|   Linking, |  | ||||||
|   Text, |  | ||||||
|   TouchableOpacity, |  | ||||||
| } from "react-native"; |  | ||||||
| import { |  | ||||||
|   widthPercentageToDP as wp, |  | ||||||
|   heightPercentageToDP as hp, |  | ||||||
| } from "react-native-responsive-screen"; |  | ||||||
| import LottieView from "lottie-react-native"; | import LottieView from "lottie-react-native"; | ||||||
| import { useInterval } from "../../lib/useInterval"; | import { useInterval } from "../../lib/useInterval"; | ||||||
| import { AS } from "../../storageControl"; | import { AS } from "../../storageControl"; | ||||||
|  | import { useFavoriteStation } from "../../stateBox/useFavoriteStation"; | ||||||
|  |  | ||||||
|  | import lineColorList from "../../assets/originData/lineColorList"; | ||||||
|  |  | ||||||
| export default function Sign(props) { | export default function Sign(props) { | ||||||
|   const { |   const { currentStation, originalStationList, oP, oLP } = props; | ||||||
|     currentStation, |   const { favoriteStation, setFavoriteStation } = useFavoriteStation(); | ||||||
|     originalStationList, |  | ||||||
|     oP, |  | ||||||
|     oLP, |  | ||||||
|     favoriteStation, |  | ||||||
|     setFavoriteStation, |  | ||||||
|   } = props; |  | ||||||
|   const [nexPrePosition, setNexPrePosition] = useState(0); |   const [nexPrePosition, setNexPrePosition] = useState(0); | ||||||
|  |  | ||||||
|   const [preStation, setPreStation] = useState(); |   const [preStation, setPreStation] = useState(); | ||||||
|   const [nexStation, setNexStation] = useState(); |   const [nexStation, setNexStation] = useState(); | ||||||
|   const [testButtonStatus, setTestButtonStatus] = useState(false); |   const [testButtonStatus, setTestButtonStatus] = useState(false); | ||||||
|  |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     const isFavorite = favoriteStation.filter((d) => { |     const isFavorite = favoriteStation.filter((d) => { | ||||||
|       const compare = JSON.stringify(d); |       const compare = JSON.stringify(d); | ||||||
| @@ -41,7 +26,7 @@ export default function Sign(props) { | |||||||
|         return false; |         return false; | ||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
|     setTestButtonStatus(isFavorite.length != 0); |     setTestButtonStatus(isFavorite.length == 0 ? false : true); | ||||||
|   }, [favoriteStation, currentStation]); |   }, [favoriteStation, currentStation]); | ||||||
|  |  | ||||||
|   useInterval(() => { |   useInterval(() => { | ||||||
| @@ -237,7 +222,10 @@ const StationNumberMaker = (props) => { | |||||||
|   }; |   }; | ||||||
|   return props.currentStation |   return props.currentStation | ||||||
|     .filter((d) => (d.StationNumber ? true : false)) |     .filter((d) => (d.StationNumber ? true : false)) | ||||||
|     .map((d, index, array) => ( |     .map((d, index, array) => { | ||||||
|  |       const lineID = d.StationNumber.slice(0, 1); | ||||||
|  |       const lineName = d.StationNumber.slice(1); | ||||||
|  |       return ( | ||||||
|         <View |         <View | ||||||
|           style={{ |           style={{ | ||||||
|             position: "absolute", |             position: "absolute", | ||||||
| @@ -247,16 +235,27 @@ const StationNumberMaker = (props) => { | |||||||
|             right: "10%", |             right: "10%", | ||||||
|             width: wp("10%"), |             width: wp("10%"), | ||||||
|             height: wp("10%"), |             height: wp("10%"), | ||||||
|           borderColor: "#2E94BB", |             borderColor: lineColorList[lineID], | ||||||
|           borderWidth: parseInt("2%"), |             borderWidth: parseInt("3%"), | ||||||
|             borderRadius: parseInt("100%"), |             borderRadius: parseInt("100%"), | ||||||
|           }} |           }} | ||||||
|  |           key={array[index].StationNumber} | ||||||
|         > |         > | ||||||
|           <View style={{ flex: 1 }} /> |           <View style={{ flex: 1 }} /> | ||||||
|         <Text style={{ fontSize: parseInt("20%") }}>{d.StationNumber}</Text> |           <Text | ||||||
|  |             style={{ | ||||||
|  |               fontSize: parseInt("13%"), | ||||||
|  |               margin: 0, | ||||||
|  |               padding: 0, | ||||||
|  |               textAlign: "center", | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             {lineID + "\n" + lineName} | ||||||
|  |           </Text> | ||||||
|           <View style={{ flex: 1 }} /> |           <View style={{ flex: 1 }} /> | ||||||
|         </View> |         </View> | ||||||
|     )); |       ); | ||||||
|  |     }); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const StationNameArea = (props) => { | const StationNameArea = (props) => { | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| export const news = "2023-7-16"; | export const news = "2023-12-25"; | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								eas.json
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								eas.json
									
									
									
									
									
								
							| @@ -5,10 +5,12 @@ | |||||||
|   "build": { |   "build": { | ||||||
|     "development": { |     "development": { | ||||||
|       "developmentClient": true, |       "developmentClient": true, | ||||||
|       "distribution": "internal" |       "distribution": "internal", | ||||||
|  |       "channel": "development" | ||||||
|     }, |     }, | ||||||
|     "preview": { |     "preview": { | ||||||
|       "distribution": "internal" |       "distribution": "internal", | ||||||
|  |       "channel": "preview" | ||||||
|     }, |     }, | ||||||
|     "mapsbuild": { |     "mapsbuild": { | ||||||
|       "releaseChannel": "mapsbuild" |       "releaseChannel": "mapsbuild" | ||||||
| @@ -21,6 +23,18 @@ | |||||||
|     }, |     }, | ||||||
|     "production4.5": { |     "production4.5": { | ||||||
|       "releaseChannel": "buyma" |       "releaseChannel": "buyma" | ||||||
|  |     }, | ||||||
|  |     "beta4.6": { | ||||||
|  |       "channel": "catch" | ||||||
|  |     }, | ||||||
|  |     "production4.6": { | ||||||
|  |       "channel": "costoco" | ||||||
|  |     }, | ||||||
|  |     "beta5.0": { | ||||||
|  |       "channel": "dshopping" | ||||||
|  |     }, | ||||||
|  |     "production5.0": { | ||||||
|  |       "channel": "dmm" | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "submit": { |   "submit": { | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								howto.js
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								howto.js
									
									
									
									
									
								
							| @@ -3,11 +3,17 @@ import React, { Component } from "react"; | |||||||
| import { StatusBar, View, TouchableOpacity, Text } from "react-native"; | import { StatusBar, View, TouchableOpacity, Text } from "react-native"; | ||||||
| import { WebView } from "react-native-webview"; | import { WebView } from "react-native-webview"; | ||||||
| export default ({ navigation: { navigate }, route }) => { | export default ({ navigation: { navigate }, route }) => { | ||||||
|   const { info, onExit = () => navigate("Apps") } = route.params; |   const { info, goTo, useShow } = route.params; | ||||||
|  |   const onExit = () => { | ||||||
|  |     navigate(goTo); | ||||||
|  |     useShow(); | ||||||
|  |   }; | ||||||
|   return ( |   return ( | ||||||
|     <View style={styles.View}> |     <View style={styles.View}> | ||||||
|       <WebView useWebKit source={{ uri: info }} /> |       <WebView | ||||||
|  |         useWebKit | ||||||
|  |         source={{ uri: info.replace("http://", "https://") }} | ||||||
|  |       /> | ||||||
|       <TouchableOpacity style={styles.touch} onPress={onExit}> |       <TouchableOpacity style={styles.touch} onPress={onExit}> | ||||||
|         <View style={{ flex: 1 }} /> |         <View style={{ flex: 1 }} /> | ||||||
|         <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> |         <Text style={{ fontSize: 25, fontWeight: "bold", color: "white" }}> | ||||||
|   | |||||||
							
								
								
									
										113
									
								
								lib/eachTrainInfoCoreLib/findReversalPoints.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								lib/eachTrainInfoCoreLib/findReversalPoints.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | |||||||
|  | // arrayは現在位置の駅ID(駅在宅の場合は1つの配列、駅間の場合は2つの配列) | ||||||
|  | // stopStationIDListは停車駅の駅IDの配列 [Y01,Y02,Y05,...] | ||||||
|  | export const findReversalPoints = (array, stopStationIDList) => { | ||||||
|  |   try { | ||||||
|  |     if (!stopStationIDList) return []; | ||||||
|  |     // arrayが二次元配列だったら早期リターン | ||||||
|  |     if (!array instanceof Array) return []; | ||||||
|  |     if (!array) return []; | ||||||
|  |     if (array[0] instanceof Array) return []; | ||||||
|  |     const arrayNumber = array.map((d) => ({ | ||||||
|  |       line: d | ||||||
|  |         .split("") | ||||||
|  |         .filter((s) => "A" < s && s < "Z") | ||||||
|  |         .join(""), | ||||||
|  |       ID: d | ||||||
|  |         .split("") | ||||||
|  |         .filter((s) => "0" <= s && s <= "9") | ||||||
|  |         .join(""), | ||||||
|  |     })); | ||||||
|  |     const stopStationIDListNumber = stopStationIDList.map((d) => { | ||||||
|  |       if (!d) return { line: [], ID: [] }; | ||||||
|  |       return { | ||||||
|  |         line: d | ||||||
|  |           .split("") | ||||||
|  |           .filter((s) => "A" < s && s < "Z") | ||||||
|  |           .join(""), | ||||||
|  |         ID: d | ||||||
|  |           .split("") | ||||||
|  |           .filter((s) => "0" <= s && s <= "9") | ||||||
|  |           .join(""), | ||||||
|  |       }; | ||||||
|  |     }); | ||||||
|  |     // 完全一致 | ||||||
|  |     if (array.length == 1) { | ||||||
|  |       const index = stopStationIDList.indexOf(array[0]); | ||||||
|  |       if (index != -1) return [index]; | ||||||
|  |       // 通過駅の場合 | ||||||
|  |       for (let i = 0; i < stopStationIDListNumber.length - 1; i++) { | ||||||
|  |         if (stopStationIDListNumber[i].ID < arrayNumber[0].ID) { | ||||||
|  |           if (stopStationIDListNumber[i + 1].ID > arrayNumber[0].ID) { | ||||||
|  |             return [i + 1]; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |         if (stopStationIDListNumber[i].ID > arrayNumber[0].ID) { | ||||||
|  |           if (stopStationIDListNumber[i + 1].ID < arrayNumber[0].ID) { | ||||||
|  |             return [i + 1]; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     // 駅間の場合 | ||||||
|  |     if (array.length == 2) { | ||||||
|  |       const index1 = stopStationIDList.indexOf(array[0]); | ||||||
|  |       const index2 = stopStationIDList.indexOf(array[1]); | ||||||
|  |       if (index1 != -1 && index2 != -1) { | ||||||
|  |         // 駅間で通過駅も無い場合 | ||||||
|  |         if (index1 < index2) { | ||||||
|  |           if (index1 + 1 == index2) { | ||||||
|  |             return [index2]; | ||||||
|  |           } else { | ||||||
|  |             const returnArray = []; | ||||||
|  |             for (let i = index1 + 1; i <= index2; i++) { | ||||||
|  |               returnArray.push(i); | ||||||
|  |             } | ||||||
|  |             return returnArray; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |         if (index1 > index2) { | ||||||
|  |           if (index2 + 1 == index1) return [index1]; | ||||||
|  |           else { | ||||||
|  |             const returnArray = []; | ||||||
|  |             for (let i = index2 + 1; i <= index1; i++) { | ||||||
|  |               returnArray.push(i); | ||||||
|  |             } | ||||||
|  |             return returnArray; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } else { | ||||||
|  |         const getNearStationID = (stationID) => { | ||||||
|  |           for (let i = 0; i <= stopStationIDListNumber.length; i++) { | ||||||
|  |             if (stopStationIDListNumber[i].ID < stationID) { | ||||||
|  |               if (stopStationIDListNumber[i + 1].ID > stationID) { | ||||||
|  |                 return i + 1; | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |             if (stopStationIDListNumber[i].ID > stationID) { | ||||||
|  |               if (stopStationIDListNumber[i + 1].ID < stationID) { | ||||||
|  |                 return i + 1; | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         }; | ||||||
|  |         let newIndex1 = index1; | ||||||
|  |         let newIndex2 = index2; | ||||||
|  |         if (index1 == -1) { | ||||||
|  |           newIndex1 = getNearStationID(arrayNumber[0].ID); | ||||||
|  |         } | ||||||
|  |         if (index2 == -1) { | ||||||
|  |           newIndex2 = getNearStationID(arrayNumber[1].ID); | ||||||
|  |         } | ||||||
|  |         if (newIndex1 && newIndex2) { | ||||||
|  |           return [newIndex1, newIndex2]; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // 通過駅の場合 | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       return []; | ||||||
|  |     } | ||||||
|  |   } catch (e) { | ||||||
|  |     console.log(e); | ||||||
|  |   } | ||||||
|  | }; | ||||||
							
								
								
									
										15
									
								
								lib/eachTrainInfoCoreLib/getStationData.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								lib/eachTrainInfoCoreLib/getStationData.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | // 駅名から駅情報を取得する | ||||||
|  | //stationName: 駅名 | ||||||
|  | //stationList: 駅情報リスト | ||||||
|  | export const getStationData = (stationName, stationList) => { | ||||||
|  |   const Stations = stationList.map((a) => | ||||||
|  |     a.filter((d) => d.StationName == stationName) | ||||||
|  |   ); | ||||||
|  |   const Station = | ||||||
|  |     Stations && | ||||||
|  |     Stations.reduce((newArray, e) => { | ||||||
|  |       return newArray.concat(e); | ||||||
|  |     }, []); | ||||||
|  |   if (!Station[0]) return []; | ||||||
|  |   return Station.map((d) => d.StationNumber)[0]; | ||||||
|  | }; | ||||||
							
								
								
									
										11
									
								
								lib/eachTrainInfoCoreLib/getType.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								lib/eachTrainInfoCoreLib/getType.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | // 種別判定 | ||||||
|  | export const getType = (string) => { | ||||||
|  |   switch (string) { | ||||||
|  |     case "express": | ||||||
|  |       return "特急"; | ||||||
|  |     case "rapid": | ||||||
|  |       return "快速"; | ||||||
|  |     default: | ||||||
|  |       return ""; | ||||||
|  |   } | ||||||
|  | }; | ||||||
							
								
								
									
										7
									
								
								lib/eachTrainInfoCoreLib/migrateTrainName.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/eachTrainInfoCoreLib/migrateTrainName.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | // Description: 電車名の変換を行う。 | ||||||
|  | // マリンライナーやマリン表記をマリンライナーに変換する。 | ||||||
|  | export const migrateTrainName = (string) => { | ||||||
|  |   return string | ||||||
|  |     .replace("マリン", "マリンライナー") | ||||||
|  |     .replace("ライナーライナー", "ライナー"); | ||||||
|  | }; | ||||||
							
								
								
									
										68
									
								
								lib/eachTrainInfoCoreLib/openBackTrainInfo.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								lib/eachTrainInfoCoreLib/openBackTrainInfo.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | export const openBackTrainInfo = (stationInfo, trainData, showNearTrain) => { | ||||||
|  |   const migrationArray = (stationInfo) => { | ||||||
|  |     const mainTrainStationPosition = trainData.findIndex( | ||||||
|  |       (d) => d.split(",")[0] == stationInfo | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     const relationMain = (() => { | ||||||
|  |       if (mainTrainStationPosition == 0) return "head"; | ||||||
|  |       if (mainTrainStationPosition == trainData.length - 1) return "tail"; | ||||||
|  |       return "middle"; | ||||||
|  |     })(); | ||||||
|  |  | ||||||
|  |     const subTrainStationPosition = showNearTrain.findIndex( | ||||||
|  |       (d) => d.split(",")[0] == stationInfo | ||||||
|  |     ); | ||||||
|  |     const relationSub = (() => { | ||||||
|  |       if (subTrainStationPosition == 0) return "head"; | ||||||
|  |       if (subTrainStationPosition == showNearTrain.length - 1) return "tail"; | ||||||
|  |       return "middle"; | ||||||
|  |     })(); | ||||||
|  |  | ||||||
|  |     switch (relationMain) { | ||||||
|  |       case "head": | ||||||
|  |         if (relationSub == "head") { | ||||||
|  |           return; | ||||||
|  |         } else if (relationSub == "tail") { | ||||||
|  |           return [ | ||||||
|  |             ...showNearTrain.slice(0, subTrainStationPosition), | ||||||
|  |             ...trainData, | ||||||
|  |           ]; | ||||||
|  |         } else if (relationSub == "middle") { | ||||||
|  |           return [ | ||||||
|  |             ...showNearTrain.slice(0, subTrainStationPosition), | ||||||
|  |             ...trainData, | ||||||
|  |           ]; | ||||||
|  |         } else return; | ||||||
|  |       case "tail": | ||||||
|  |         if (relationSub == "head") { | ||||||
|  |           return [ | ||||||
|  |             ...trainData.slice(0, mainTrainStationPosition), | ||||||
|  |             ...showNearTrain, | ||||||
|  |           ]; | ||||||
|  |         } else if (relationSub == "tail") { | ||||||
|  |           return; | ||||||
|  |         } else if (relationSub == "middle") { | ||||||
|  |           return [ | ||||||
|  |             ...trainData.slice(0, mainTrainStationPosition), | ||||||
|  |             ...showNearTrain.slice(subTrainStationPosition), | ||||||
|  |           ]; | ||||||
|  |         } else return; | ||||||
|  |       case "middle": | ||||||
|  |         if (relationSub == "head") { | ||||||
|  |           return [ | ||||||
|  |             ...trainData.slice(0, mainTrainStationPosition), | ||||||
|  |             ...showNearTrain, | ||||||
|  |           ]; | ||||||
|  |         } else if (relationSub == "tail") { | ||||||
|  |           return [ | ||||||
|  |             ...showNearTrain.slice(0, subTrainStationPosition), | ||||||
|  |             ...trainData.slice(mainTrainStationPosition), | ||||||
|  |           ]; | ||||||
|  |         } else return; | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  |   const array = migrationArray(stationInfo); | ||||||
|  |   if (!array) return null; | ||||||
|  |   return array; | ||||||
|  | }; | ||||||
							
								
								
									
										13
									
								
								lib/eachTrainInfoCoreLib/searchSpecialTrain.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								lib/eachTrainInfoCoreLib/searchSpecialTrain.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | // S列番の列車からDやMの列車を検索する | ||||||
|  | export const searchSpecialTrain = (trainNum, trainList) => { | ||||||
|  |   const searchBase = trainNum.replace("S", "").replace("X", ""); | ||||||
|  |   const search = (text) => { | ||||||
|  |     const TD = trainList[searchBase + text]; | ||||||
|  |     if (TD) { | ||||||
|  |       return true; | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  |   }; | ||||||
|  |   if (search("D")) return searchBase + "D"; | ||||||
|  |   if (search("M")) return searchBase + "M"; | ||||||
|  | }; | ||||||
| @@ -3,5 +3,5 @@ import { Platform } from "react-native"; | |||||||
| export const getPDFViewURL = (url) => { | export const getPDFViewURL = (url) => { | ||||||
|   if (Platform.OS == "ios") return url; |   if (Platform.OS == "ios") return url; | ||||||
|   else |   else | ||||||
|     return `https://docs.google.com/viewer?url=${encodeURI(url)}&embedded=true`; |     return `https://mozilla.github.io/pdf.js/web/viewer.html?file=${encodeURI(url)}`; | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -6,6 +6,8 @@ export const getTrainType = (nameString) => { | |||||||
|       return { color: "red", name: "特急", data: "express" }; |       return { color: "red", name: "特急", data: "express" }; | ||||||
|     case "NightLTDEXP": |     case "NightLTDEXP": | ||||||
|       return { color: "red", name: "寝台特急", data: "express" }; |       return { color: "red", name: "寝台特急", data: "express" }; | ||||||
|  |     case "SPCL": | ||||||
|  |       return { color: "blue", name: "臨時", data: "normal" }; | ||||||
|     case "Normal": |     case "Normal": | ||||||
|       return { color: "white", name: "普通列車", data: "normal" }; |       return { color: "white", name: "普通列車", data: "normal" }; | ||||||
|     default: |     default: | ||||||
|   | |||||||
							
								
								
									
										19
									
								
								lib/initIcon.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								lib/initIcon.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | import React from "react"; | ||||||
|  | import { Ionicons, AntDesign } from "@expo/vector-icons"; | ||||||
|  |  | ||||||
|  | export const initIcon = (name, type) => { | ||||||
|  |   switch (type) { | ||||||
|  |     case "Ionicons": | ||||||
|  |       return ({ focused, color, size }) => ( | ||||||
|  |         <Ionicons name={name} size={32} color={focused ? "#0099CC" : "black"} /> | ||||||
|  |       ); | ||||||
|  |     case "AntDesign": | ||||||
|  |       return ({ focused, color, size }) => ( | ||||||
|  |         <AntDesign | ||||||
|  |           name={name} | ||||||
|  |           size={32} | ||||||
|  |           color={focused ? "#0099CC" : "black"} | ||||||
|  |         /> | ||||||
|  |       ); | ||||||
|  |   } | ||||||
|  | }; | ||||||
							
								
								
									
										8
									
								
								lib/stackOption.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								lib/stackOption.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | import { TransitionPresets } from "@react-navigation/stack"; | ||||||
|  | export const optionData = { | ||||||
|  |   gestureEnabled: true, | ||||||
|  |   ...TransitionPresets.ModalPresentationIOS, | ||||||
|  |   cardOverlayEnabled: true, | ||||||
|  |   headerTransparent: true, | ||||||
|  |   headerShown: false, | ||||||
|  | }; | ||||||
| @@ -6,6 +6,34 @@ export const injectJavascriptData = ( | |||||||
|   stationMenu, |   stationMenu, | ||||||
|   trainMenu |   trainMenu | ||||||
| ) => { | ) => { | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   const specialTrainIcon = ` | ||||||
|  |     ////ロイヤルエクスプレス | ||||||
|  |     case "9001": | ||||||
|  |     case "9029": | ||||||
|  |     case "9003": | ||||||
|  |     case "9055":   | ||||||
|  |     case "9056": | ||||||
|  |     case "9004": | ||||||
|  |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/izq2100rex.png'); | ||||||
|  |     break; | ||||||
|  |   ` | ||||||
|  |   const specialTrainName = ` | ||||||
|  |     ////ロイヤルエクスプレス | ||||||
|  |     case "9001": | ||||||
|  |     case "9029": | ||||||
|  |       return "ロイヤルエクスプレス\\n-瀬戸の海に想いを馳せながら-"; | ||||||
|  |     case "9003": | ||||||
|  |       return "ロイヤルエクスプレス\\n-四国の伝統文化を感じて-"; | ||||||
|  |     case "9055":   | ||||||
|  |     case "9056": | ||||||
|  |       return "ロイヤルエクスプレス\\n-凪の誘い・瀬戸内の絶景-"; | ||||||
|  |     case "9004": | ||||||
|  |       return "ロイヤルエクスプレス\\n-四国・瀬戸内の彩りに囲まれて-"; | ||||||
|  |     break; | ||||||
|  |     ` | ||||||
|  |  | ||||||
|   // 一番上のメニュー非表示 地図スイッチによって切り替え |   // 一番上のメニュー非表示 地図スイッチによって切り替え | ||||||
|   const topMenu = |   const topMenu = | ||||||
|     mapSwitch != "true" |     mapSwitch != "true" | ||||||
| @@ -72,14 +100,14 @@ export const injectJavascriptData = ( | |||||||
|     case "25M": |     case "25M": | ||||||
|     case "27M": |     case "27M": | ||||||
|     case "29M": |     case "29M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s8000nr.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000nr.png'); | ||||||
|       break; |       break; | ||||||
|     //8000 アンパン |     //8000 アンパン | ||||||
|     case "10M": |     case "10M": | ||||||
|     case "22M": |     case "22M": | ||||||
|     case "9M": |     case "9M": | ||||||
|     case "21M": |     case "21M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s8000ap.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000ap.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -92,7 +120,7 @@ export const injectJavascriptData = ( | |||||||
|     case "11M": |     case "11M": | ||||||
|     case "19M": |     case "19M": | ||||||
|     case "23M": |     case "23M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s8600.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8600.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //いしづちメイン |     //いしづちメイン | ||||||
| @@ -115,7 +143,7 @@ export const injectJavascriptData = ( | |||||||
|     case "1025M": |     case "1025M": | ||||||
|     case "1027M": |     case "1027M": | ||||||
|     case "1029M": |     case "1029M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s8000nr.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000nr.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //8000 アンパン |     //8000 アンパン | ||||||
| @@ -123,7 +151,7 @@ export const injectJavascriptData = ( | |||||||
|     case "1022M": |     case "1022M": | ||||||
|     case "1009M": |     case "1009M": | ||||||
|     case "1021M": |     case "1021M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s8000ap.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000ap.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //8600 |     //8600 | ||||||
| @@ -135,29 +163,29 @@ export const injectJavascriptData = ( | |||||||
|     case "1011M": |     case "1011M": | ||||||
|     case "1019M": |     case "1019M": | ||||||
|     case "1023M": |     case "1023M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s8600_isz.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8600_isz.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //MEXP |     //MEXP | ||||||
|     //8000 |     //8000 | ||||||
|     case "1092M": |     case "1092M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s8000nr.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000nr.png'); | ||||||
|       break; |       break; | ||||||
|     //8600 |     //8600 | ||||||
|     case "1091M": |     case "1091M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s8600_isz.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8600_isz.png'); | ||||||
|       break; |       break; | ||||||
|     //三桁いしづち |     //三桁いしづち | ||||||
|     //8000 アンパン |     //8000 アンパン | ||||||
|     case "1041M": |     case "1041M": | ||||||
|     case "1044M": |     case "1044M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s8000ap.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8000ap.png'); | ||||||
|       break; |       break; | ||||||
|     //8600 |     //8600 | ||||||
|     case "1043M": |     case "1043M": | ||||||
|     case "1042M": |     case "1042M": | ||||||
|     case "1046M": |     case "1046M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s8600_isz.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s8600_isz.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -180,7 +208,7 @@ export const injectJavascriptData = ( | |||||||
|     case "51D": |     case "51D": | ||||||
|     case "53D": |     case "53D": | ||||||
|     case "55D": |     case "55D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2700.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2700.png'); | ||||||
|       break; |       break; | ||||||
|     //2700アンパン |     //2700アンパン | ||||||
|     case "32D": |     case "32D": | ||||||
| @@ -193,7 +221,7 @@ export const injectJavascriptData = ( | |||||||
|     case "45D": |     case "45D": | ||||||
|     case "49D": |     case "49D": | ||||||
|     case "57D": |     case "57D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s2700apr.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2700apr.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -223,7 +251,7 @@ export const injectJavascriptData = ( | |||||||
|     case "3027D": |     case "3027D": | ||||||
|     case "3031D": |     case "3031D": | ||||||
|     case "3033D": |     case "3033D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2700_uzu.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2700_uzu.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //2600 |     //2600 | ||||||
| @@ -235,13 +263,13 @@ export const injectJavascriptData = ( | |||||||
|     case "3011D": |     case "3011D": | ||||||
|     case "3017D": |     case "3017D": | ||||||
|     case "3023D": |     case "3023D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2600.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2600.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //キハ185 |     //キハ185 | ||||||
|     case "3009D": |     case "3009D": | ||||||
|     case "3032D": |     case "3032D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185tu_uzu.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185tu_uzu.png'); | ||||||
|       break; |       break; | ||||||
|        |        | ||||||
|     //マリンライナー |     //マリンライナー | ||||||
| @@ -313,14 +341,14 @@ export const injectJavascriptData = ( | |||||||
|     case "3167M": |     case "3167M": | ||||||
|     case "3169M": |     case "3169M": | ||||||
|     case "3175M": |     case "3175M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s5001.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s5001.png'); | ||||||
|       break; |       break; | ||||||
|     case "3102M": |     case "3102M": | ||||||
|     case "3101M": |     case "3101M": | ||||||
|     case "3103M": |     case "3103M": | ||||||
|     case "3171M": |     case "3171M": | ||||||
|     case "3173M": |     case "3173M": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s5001k.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s5001k.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //サンライズ瀬戸 |     //サンライズ瀬戸 | ||||||
| @@ -328,7 +356,7 @@ export const injectJavascriptData = ( | |||||||
|     case "5031M": |     case "5031M": | ||||||
|     case "8041M": //琴平延長高松迄 |     case "8041M": //琴平延長高松迄 | ||||||
|     case "8031M": //琴平延長高松以降 |     case "8031M": //琴平延長高松以降 | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/w285.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/w285.png'); | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
|     //宇和海 |     //宇和海 | ||||||
| @@ -357,7 +385,7 @@ export const injectJavascriptData = ( | |||||||
|     case "1075D": |     case "1075D": | ||||||
|     case "1077D": |     case "1077D": | ||||||
|     case "1079D": |     case "1079D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2000_uwa.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2000_uwa.png'); | ||||||
|     break; |     break; | ||||||
|     //2000 アンパン込み |     //2000 アンパン込み | ||||||
|     case "1054D": |     case "1054D": | ||||||
| @@ -368,7 +396,7 @@ export const injectJavascriptData = ( | |||||||
|     case "1061D": |     case "1061D": | ||||||
|     case "1067D": |     case "1067D": | ||||||
|     case "1081D": |     case "1081D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s2002a.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2002a.png'); | ||||||
|     break; |     break; | ||||||
|     //しまんと |     //しまんと | ||||||
|     case "2002D": |     case "2002D": | ||||||
| @@ -379,7 +407,7 @@ export const injectJavascriptData = ( | |||||||
|     case "2003D": |     case "2003D": | ||||||
|     case "2005D": |     case "2005D": | ||||||
|     case "2007D": |     case "2007D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2700_smn.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2700_smn.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     //あしずり 2000 |     //あしずり 2000 | ||||||
| @@ -393,7 +421,7 @@ export const injectJavascriptData = ( | |||||||
|     case "2077D": |     case "2077D": | ||||||
|     case "2081D": |     case "2081D": | ||||||
|     case "2083D": |     case "2083D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2000_asi.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2000_asi.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     //あしずり 2700 |     //あしずり 2700 | ||||||
| @@ -404,7 +432,7 @@ export const injectJavascriptData = ( | |||||||
|     case "2079D": |     case "2079D": | ||||||
|     case "2085D": |     case "2085D": | ||||||
|     case "2072D": |     case "2072D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s2700_asi.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s2700_asi.png'); | ||||||
|     break; |     break; | ||||||
|     //剣山 |     //剣山 | ||||||
|     case "4002D": |     case "4002D": | ||||||
| @@ -418,19 +446,19 @@ export const injectJavascriptData = ( | |||||||
|     case "4007D": |     case "4007D": | ||||||
|     case "4009D": |     case "4009D": | ||||||
|     case "4011D": |     case "4011D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185tu.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185tu.png'); | ||||||
|     break; |     break; | ||||||
|     //むろと |     //むろと | ||||||
|     case "5051D": |     case "5051D": | ||||||
|     case "5052D": |     case "5052D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185_mrt.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185_mrt.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|  |  | ||||||
|     //よしのがわトロッコ |     //よしのがわトロッコ | ||||||
|     case "8452D": |     case "8452D": | ||||||
|     case "8451D": |     case "8451D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s185to_ai.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185to_ai.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     //岡山高松アントロ |     //岡山高松アントロ | ||||||
| @@ -439,7 +467,7 @@ export const injectJavascriptData = ( | |||||||
|     //岡山琴平アントロ |     //岡山琴平アントロ | ||||||
|     case "8277D": |     case "8277D": | ||||||
|     case "8278D": |     case "8278D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/s32to4.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s32to4.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     //伊予灘ものがたり |     //伊予灘ものがたり | ||||||
| @@ -447,14 +475,14 @@ export const injectJavascriptData = ( | |||||||
|     case "8093D": |     case "8093D": | ||||||
|     case "8092D": |     case "8092D": | ||||||
|     case "8094D": |     case "8094D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185iyoy.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185iyoy.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|  |  | ||||||
|     //千年ものがたり |     //千年ものがたり | ||||||
|     case "8011D": |     case "8011D": | ||||||
|     case "8012D": |     case "8012D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185mm1.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185mm1.png'); | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     //夜明けものがたり |     //夜明けものがたり | ||||||
| @@ -462,8 +490,9 @@ export const injectJavascriptData = ( | |||||||
|     case "8054D": |     case "8054D": | ||||||
|     case "8062D": |     case "8062D": | ||||||
|     case "8063D": |     case "8063D": | ||||||
|       setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/b/s185ym1.png'); |       setStationIcon(element.querySelector("img"),'https://storage.haruk.in/s185ym1.png'); | ||||||
|     break; |     break; | ||||||
|  | `+specialTrainIcon+` | ||||||
|     default: |     default: | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
| @@ -472,7 +501,7 @@ export const injectJavascriptData = ( | |||||||
|  |  | ||||||
|   const JRF_icon = |   const JRF_icon = | ||||||
|     iconSetting == "true" |     iconSetting == "true" | ||||||
|       ? `JRF || setStationIcon(element.querySelector("img"),'http://www.trainfrontview.net/f/ef210a.png');` |       ? `JRF || setStationIcon(element.querySelector("img"),'https://storage.haruk.in/ef210a.png');` | ||||||
|       : ``; |       : ``; | ||||||
|   const normal_train_name = ` |   const normal_train_name = ` | ||||||
|     if(new RegExp(/^4[1-9]\\d\\d[DM]$/).test(列番データ) || new RegExp(/^5[1-7]\\d\\d[DM]$/).test(列番データ)){ |     if(new RegExp(/^4[1-9]\\d\\d[DM]$/).test(列番データ) || new RegExp(/^5[1-7]\\d\\d[DM]$/).test(列番データ)){ | ||||||
| @@ -541,6 +570,7 @@ const data = getJRF(列番データ); | |||||||
|   //安芸行と併結列車を個別に表示、それ以外をdefaultで下りなら既定の行き先を、上りなら奈半利行を設定 |   //安芸行と併結列車を個別に表示、それ以外をdefaultで下りなら既定の行き先を、上りなら奈半利行を設定 | ||||||
|   const getTKT = num =>{ |   const getTKT = num =>{ | ||||||
|     switch(num){ |     switch(num){ | ||||||
|  |       `+specialTrainName+` | ||||||
|     case "5814D": |     case "5814D": | ||||||
|     case "5816D": |     case "5816D": | ||||||
|       return "ごめん・なはり線直通\\n快速 奈半利行"; |       return "ごめん・なはり線直通\\n快速 奈半利行"; | ||||||
| @@ -667,7 +697,8 @@ const setStrings = () =>{ | |||||||
|       document.getElementById('disp').style.overflowX = 'hidden'; |       document.getElementById('disp').style.overflowX = 'hidden'; | ||||||
|  |  | ||||||
|     }catch(e){ |     }catch(e){ | ||||||
|       alert("にゃーん"); |       alert("本家サーバーからのデータ取得に失敗しました。"); | ||||||
|  |       window.ReactNativeWebView.postMessage(JSON.stringify({type:"LoadError"})); | ||||||
|     } |     } | ||||||
|   } catch (e) {} |   } catch (e) {} | ||||||
| } | } | ||||||
| @@ -745,6 +776,23 @@ const setStationMenuDialog = new MutationObserver( (mutations) => { | |||||||
|       window.ReactNativeWebView.postMessage(JSON.stringify({type:"PopUpMenu",event:s[0],id:s[1],name:s[2],pdf:s[3],map:s[4],url:s[5],chk:s[6]})); |       window.ReactNativeWebView.postMessage(JSON.stringify({type:"PopUpMenu",event:s[0],id:s[1],name:s[2],pdf:s[3],map:s[4],url:s[5],chk:s[6]})); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   const data2 =[]; | ||||||
|  |   document.querySelectorAll('#disp > div > div > div > div > font > div').forEach(d=>data2.push(d)) | ||||||
|  |  | ||||||
|  |   for(let d of data2 ){ | ||||||
|  |     if(!d.offclick){ | ||||||
|  |       d.offclick = d.onclick.toString(); | ||||||
|  |     } | ||||||
|  |     const stationID = d.childNodes[0].innerText; | ||||||
|  |     const PDFAddress = d.offclick.split("'")[1]; | ||||||
|  |     const Name = d.childNodes[2].innerText; | ||||||
|  |     //alert(PDFAddress); | ||||||
|  |     d.onclick = () =>{  | ||||||
|  |       //const s = d.offclick.replace('(event)','').replaceAll("'", "").split('(')[1].split(')')[0].split(','); | ||||||
|  |       // これの中身抽出 PopUpMenu(event,'2','端岡','http://www.jr-shikoku.co.jp/01_trainbus/jikoku/pdf/hashioka.pdf','https://www.google.co.jp/maps/place/34.305027,133.967643','','1') | ||||||
|  |       window.ReactNativeWebView.postMessage(JSON.stringify({type:"PopUpMenu",id:stationID,name:Name,pdf:PDFAddress})); | ||||||
|  |     } | ||||||
|  |   } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| // 監視を開始 | // 監視を開始 | ||||||
|   | |||||||
							
								
								
									
										156
									
								
								menu.js
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								menu.js
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| import React, { useRef, useState, useEffect } from "react"; | import React, { useRef, useState, useEffect, useLayoutEffect } from "react"; | ||||||
| import Carousel from "react-native-snap-carousel"; | import Carousel from "react-native-snap-carousel"; | ||||||
| import { | import { | ||||||
|   Platform, |   Platform, | ||||||
| @@ -7,14 +7,12 @@ import { | |||||||
|   Linking, |   Linking, | ||||||
|   Text, |   Text, | ||||||
|   TouchableOpacity, |   TouchableOpacity, | ||||||
|   ToastAndroid, |  | ||||||
| } from "react-native"; | } from "react-native"; | ||||||
| import Constants from "expo-constants"; | import Constants from "expo-constants"; | ||||||
| import { ListItem } from "native-base"; | import { ListItem } from "native-base"; | ||||||
| import Icon from "react-native-vector-icons/Entypo"; | import Icon from "react-native-vector-icons/Entypo"; | ||||||
| import * as Location from "expo-location"; | import * as Location from "expo-location"; | ||||||
| import StatusbarDetect from "./StatusbarDetect"; | import StatusbarDetect from "./StatusbarDetect"; | ||||||
| import { useNavigation } from "@react-navigation/native"; |  | ||||||
| import AutoHeightImage from "react-native-auto-height-image"; | import AutoHeightImage from "react-native-auto-height-image"; | ||||||
| import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | import { widthPercentageToDP as wp } from "react-native-responsive-screen"; | ||||||
| import { | import { | ||||||
| @@ -24,7 +22,6 @@ import { | |||||||
|   MaterialCommunityIcons, |   MaterialCommunityIcons, | ||||||
| } from "@expo/vector-icons"; | } from "@expo/vector-icons"; | ||||||
| import LottieView from "lottie-react-native"; | import LottieView from "lottie-react-native"; | ||||||
| import { StationDeteilView } from "./components/ActionSheetComponents/StationDeteilView"; |  | ||||||
| import { parseAllTrainDiagram } from "./lib/parseAllTrainDiagram"; | import { parseAllTrainDiagram } from "./lib/parseAllTrainDiagram"; | ||||||
| import trainList from "./assets/originData/trainList"; | import trainList from "./assets/originData/trainList"; | ||||||
|  |  | ||||||
| @@ -35,24 +32,18 @@ import { UsefulBox } from "./components/atom/UsefulBox"; | |||||||
| import { TicketBox } from "./components/atom/TicketBox"; | import { TicketBox } from "./components/atom/TicketBox"; | ||||||
| import { TextBox } from "./components/atom/TextBox"; | import { TextBox } from "./components/atom/TextBox"; | ||||||
| import { getStationList, lineList } from "./lib/getStationList"; | import { getStationList, lineList } from "./lib/getStationList"; | ||||||
| import { JRSTraInfo } from "./components/ActionSheetComponents/JRSTraInfo"; |  | ||||||
| import { EachTrainInfo } from "./components/ActionSheetComponents/EachTrainInfo"; |  | ||||||
| import useInterval from "./lib/useInterval"; | import useInterval from "./lib/useInterval"; | ||||||
| import { HeaderConfig } from "./lib/HeaderConfig"; | import { HeaderConfig } from "./lib/HeaderConfig"; | ||||||
|  | import { useFavoriteStation } from "./stateBox/useFavoriteStation"; | ||||||
|  | import { SheetManager } from "react-native-actions-sheet"; | ||||||
|  | import { useTrainDelayData } from "./stateBox/useTrainDelayData"; | ||||||
|  |  | ||||||
| export default function Menu(props) { | export default function Menu(props) { | ||||||
|   const { |   const { | ||||||
|     navigation: { navigate }, |     navigation: { navigate }, | ||||||
|     favoriteStation, |  | ||||||
|     setFavoriteStation, |  | ||||||
|     busAndTrainData, |  | ||||||
|     currentTrainState, |  | ||||||
|     currentTrainLoadingState, |  | ||||||
|     getCurrentTrain, |     getCurrentTrain, | ||||||
|   } = props; |   } = props; | ||||||
|   const JRSTraInfoEXAcSR = useRef(null); |   const { favoriteStation } = useFavoriteStation(); | ||||||
|   const StationBoardAcSR = useRef(null); |  | ||||||
|   const navigation = useNavigation(); |  | ||||||
|  |  | ||||||
|   //位置情報 |   //位置情報 | ||||||
|   const [locationStatus, setLocationStatus] = useState(null); |   const [locationStatus, setLocationStatus] = useState(null); | ||||||
| @@ -62,14 +53,6 @@ export default function Menu(props) { | |||||||
|     }); |     }); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   //列車情報表示関連 |  | ||||||
|   const EachTrainInfoAsSR = useRef(null); |  | ||||||
|   const [trainInfo, setTrainInfo] = useState({ |  | ||||||
|     trainNum: undefined, |  | ||||||
|     limited: undefined, |  | ||||||
|     trainData: undefined, |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   const getCurrentPosition = () => { |   const getCurrentPosition = () => { | ||||||
|     if (locationStatus !== "granted") return () => {}; |     if (locationStatus !== "granted") return () => {}; | ||||||
|     Location.getCurrentPositionAsync({}).then((location) => |     Location.getCurrentPositionAsync({}).then((location) => | ||||||
| @@ -118,27 +101,17 @@ export default function Menu(props) { | |||||||
|   const [currentStation, setCurrentStation] = useState(undefined); //第三要素 |   const [currentStation, setCurrentStation] = useState(undefined); //第三要素 | ||||||
|  |  | ||||||
|   const [originalStationList, setOriginalStationList] = useState(); // 第一要素 |   const [originalStationList, setOriginalStationList] = useState(); // 第一要素 | ||||||
|   useEffect(() => getStationList().then(setOriginalStationList), []); |   useLayoutEffect(() => getStationList().then(setOriginalStationList), []); | ||||||
|  |  | ||||||
|   const [count, setCount] = useState(0); |  | ||||||
|   const [delayData, setDelayData] = useState(undefined); |  | ||||||
|   const [getTime, setGetTime] = useState(new Date()); |  | ||||||
|   const [loadingDelayData, setLoadingDelayData] = useState(true); |  | ||||||
|   const carouselRef = useRef(); |   const carouselRef = useRef(); | ||||||
|   const [selectedCurrentStation, setSelectedCurrentStation] = useState(0); |   const [selectedCurrentStation, setSelectedCurrentStation] = useState(0); | ||||||
|  |  | ||||||
|  |   const [allStationData, setAllStationData] = useState([]); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     fetch( |     setAllStationData( | ||||||
|       "https://script.google.com/macros/s/AKfycbyKxch7z7l8e07LXulRHqxjVoIiB13kcgvoToLE-rqlxLmLSKdlmqz0FI1F2EuA7Zfg/exec" |       [currentStation, ...favoriteStation].filter((d) => d != undefined) | ||||||
|     ) |  | ||||||
|       .then((response) => response.text()) |  | ||||||
|       .then((data) => setDelayData(data !== "" ? data.split("^") : null)) |  | ||||||
|       .then(() => setGetTime(new Date())) |  | ||||||
|       .finally(() => setLoadingDelayData(false)); |  | ||||||
|   }, [loadingDelayData]); |  | ||||||
|   const allStationData = [currentStation, ...favoriteStation].filter( |  | ||||||
|     (d) => d != undefined |  | ||||||
|     ); |     ); | ||||||
|  |   }, [currentStation, favoriteStation]); | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     if (allStationData.length == 0) { |     if (allStationData.length == 0) { | ||||||
|       setSelectedCurrentStation(0); |       setSelectedCurrentStation(0); | ||||||
| @@ -170,13 +143,13 @@ export default function Menu(props) { | |||||||
|         if (d.indexOf("<title>404 Not Found</title>") != -1) throw Error; |         if (d.indexOf("<title>404 Not Found</title>") != -1) throw Error; | ||||||
|         setTrainDiagram(parseAllTrainDiagram(d)); |         setTrainDiagram(parseAllTrainDiagram(d)); | ||||||
|       }) |       }) | ||||||
|       .catch((d) => { |       .catch(() => { | ||||||
|         console.log("fallback"); |         console.log("fallback"); | ||||||
|         setTrainDiagram(trainList); |         setTrainDiagram(trainList); | ||||||
|       }); |       }); | ||||||
|   }, []); |   }, []); | ||||||
|  |  | ||||||
|   const openStationACFromEachTrainInfo = (stationName) => { |   const openStationACFromEachTrainInfo = () => { | ||||||
|     // EachTrainInfoAsSR.current?.hide(); |     // EachTrainInfoAsSR.current?.hide(); | ||||||
|     // const findStationEachLine = (selectLine) => { |     // const findStationEachLine = (selectLine) => { | ||||||
|     //   let NearStation = selectLine.filter((d) => d.Station_JP == stationName); |     //   let NearStation = selectLine.filter((d) => d.Station_JP == stationName); | ||||||
| @@ -224,7 +197,7 @@ export default function Menu(props) { | |||||||
|             onSnapToItem={(d) => { |             onSnapToItem={(d) => { | ||||||
|               setSelectedCurrentStation(d); |               setSelectedCurrentStation(d); | ||||||
|             }} |             }} | ||||||
|             renderItem={({ item, index }) => { |             renderItem={({ item }) => { | ||||||
|               return ( |               return ( | ||||||
|                 <View |                 <View | ||||||
|                   style={{ marginVertical: 10 }} |                   style={{ marginVertical: 10 }} | ||||||
| @@ -233,9 +206,27 @@ export default function Menu(props) { | |||||||
|                   <Sign |                   <Sign | ||||||
|                     currentStation={item} |                     currentStation={item} | ||||||
|                     originalStationList={originalStationList} |                     originalStationList={originalStationList} | ||||||
|                     favoriteStation={favoriteStation} |                     oP={() => { | ||||||
|                     setFavoriteStation={setFavoriteStation} |                       const payload = { | ||||||
|                     oP={StationBoardAcSR.current?.setModalVisible} |                         currentStation: | ||||||
|  |                           originalStationList && | ||||||
|  |                           allStationData.length != 0 && | ||||||
|  |                           allStationData[selectedCurrentStation], | ||||||
|  |                         originalStationList: originalStationList, | ||||||
|  |                         navigate: navigate, | ||||||
|  |                         goTo: "menu", | ||||||
|  |                         useShow: () => | ||||||
|  |                           SheetManager.show("StationDetailView", { | ||||||
|  |                             payload, | ||||||
|  |                           }), | ||||||
|  |                         onExit: () => { | ||||||
|  |                           SheetManager.hide("StationDetailView"); | ||||||
|  |                         }, | ||||||
|  |                       }; | ||||||
|  |                       SheetManager.show("StationDetailView", { | ||||||
|  |                         payload, | ||||||
|  |                       }); | ||||||
|  |                     }} | ||||||
|                   /> |                   /> | ||||||
|                 </View> |                 </View> | ||||||
|               ); |               ); | ||||||
| @@ -249,56 +240,16 @@ export default function Menu(props) { | |||||||
|               station={ |               station={ | ||||||
|                 originalStationList && allStationData[selectedCurrentStation][0] |                 originalStationList && allStationData[selectedCurrentStation][0] | ||||||
|               } |               } | ||||||
|               setTrainInfo={setTrainInfo} |  | ||||||
|               EachTrainInfoAsSR={EachTrainInfoAsSR} |  | ||||||
|               trainDiagram={trainDiagram} |               trainDiagram={trainDiagram} | ||||||
|               currentTrainState={currentTrainState} |  | ||||||
|               currentTrainLoadingState={currentTrainLoadingState} |  | ||||||
|               getCurrentTrain={getCurrentTrain} |               getCurrentTrain={getCurrentTrain} | ||||||
|             /> |  | ||||||
|           )} |  | ||||||
|         <JRSTraInfoBox |  | ||||||
|           JRSTraInfoEXAcSR={JRSTraInfoEXAcSR} |  | ||||||
|           getTime={getTime} |  | ||||||
|           setLoadingDelayData={setLoadingDelayData} |  | ||||||
|           loadingDelayData={loadingDelayData} |  | ||||||
|           delayData={delayData} |  | ||||||
|         /> |  | ||||||
|         <FixedContentBottom navigate={navigate} /> |  | ||||||
|       </ScrollView> |  | ||||||
|  |  | ||||||
|       <StationDeteilView |  | ||||||
|         StationBoardAcSR={StationBoardAcSR} |  | ||||||
|         currentStation={ |  | ||||||
|           originalStationList && |  | ||||||
|           allStationData.length != 0 && |  | ||||||
|           allStationData[selectedCurrentStation] |  | ||||||
|         } |  | ||||||
|         originalStationList={originalStationList} |  | ||||||
|         favoriteStation={favoriteStation} |  | ||||||
|         setFavoriteStation={setFavoriteStation} |  | ||||||
|         busAndTrainData={busAndTrainData} |  | ||||||
|         navigate={navigate} |  | ||||||
|         onExit={() => { |  | ||||||
|           StationBoardAcSR.current?.setModalVisible(); |  | ||||||
|           navigate("menu"); |  | ||||||
|         }} |  | ||||||
|       /> |  | ||||||
|       <JRSTraInfo |  | ||||||
|         JRSTraInfoEXAcSR={JRSTraInfoEXAcSR} |  | ||||||
|         getTime={getTime} |  | ||||||
|         loadingDelayData={loadingDelayData} |  | ||||||
|         setLoadingDelayData={setLoadingDelayData} |  | ||||||
|         delayData={delayData} |  | ||||||
|       /> |  | ||||||
|       <EachTrainInfo |  | ||||||
|         setRef={EachTrainInfoAsSR} |  | ||||||
|         data={trainInfo} |  | ||||||
|               navigate={navigate} |               navigate={navigate} | ||||||
|               originalStationList={originalStationList} |               originalStationList={originalStationList} | ||||||
|               openStationACFromEachTrainInfo={openStationACFromEachTrainInfo} |               openStationACFromEachTrainInfo={openStationACFromEachTrainInfo} | ||||||
|         from="LED" |  | ||||||
|             /> |             /> | ||||||
|  |           )} | ||||||
|  |         <JRSTraInfoBox /> | ||||||
|  |         <FixedContentBottom navigate={navigate} /> | ||||||
|  |       </ScrollView> | ||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
| @@ -361,14 +312,15 @@ const TopMenuButton = () => { | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const JRSTraInfoBox = (props) => { | const JRSTraInfoBox = () => { | ||||||
|   const { |   const { | ||||||
|     JRSTraInfoEXAcSR, |  | ||||||
|     getTime, |     getTime, | ||||||
|     setLoadingDelayData, |     setGetTime, | ||||||
|     loadingDelayData, |  | ||||||
|     delayData, |     delayData, | ||||||
|   } = props; |     setDelayData, | ||||||
|  |     loadingDelayData, | ||||||
|  |     setLoadingDelayData, | ||||||
|  |   } = useTrainDelayData(); | ||||||
|   const styles = { |   const styles = { | ||||||
|     touch: { |     touch: { | ||||||
|       backgroundColor: "#0099CC", |       backgroundColor: "#0099CC", | ||||||
| @@ -400,7 +352,7 @@ const JRSTraInfoBox = (props) => { | |||||||
|   }; |   }; | ||||||
|   return ( |   return ( | ||||||
|     <TouchableOpacity |     <TouchableOpacity | ||||||
|       onPress={JRSTraInfoEXAcSR.current?.setModalVisible} |       onPress={() => SheetManager.show("JRSTraInfo")} | ||||||
|       style={styles.touch} |       style={styles.touch} | ||||||
|     > |     > | ||||||
|       <ScrollView scrollEnabled={false} style={styles.scroll}> |       <ScrollView scrollEnabled={false} style={styles.scroll}> | ||||||
| @@ -439,7 +391,7 @@ const JRSTraInfoBox = (props) => { | |||||||
|               /> |               /> | ||||||
|             </View> |             </View> | ||||||
|           ) : delayData ? ( |           ) : delayData ? ( | ||||||
|             delayData.map((d, index) => { |             delayData.map((d) => { | ||||||
|               let data = d.split(" "); |               let data = d.split(" "); | ||||||
|               return ( |               return ( | ||||||
|                 <View style={{ flexDirection: "row" }} key={data[1] + "key"}> |                 <View style={{ flexDirection: "row" }} key={data[1] + "key"}> | ||||||
| @@ -467,7 +419,7 @@ const JRSTraInfoBox = (props) => { | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const FixedContentTop = (props) => { | const FixedContentTop = () => { | ||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
|       <TopMenuButton /> |       <TopMenuButton /> | ||||||
| @@ -716,12 +668,26 @@ const FixedContentBottom = (props) => { | |||||||
|           ))} |           ))} | ||||||
|         </View> |         </View> | ||||||
|       </View> |       </View> | ||||||
|  |       <Text style={{ fontWeight: "bold", fontSize: 20 }}>上級者向け機能</Text> | ||||||
|  |       <TextBox | ||||||
|  |         backgroundColor="#8c00d6" | ||||||
|  |         flex={1} | ||||||
|  |         onPressButton={() => props.navigate("AllTrainIDList")} | ||||||
|  |       > | ||||||
|  |         <Text style={{ color: "white", fontWeight: "bold", fontSize: 20 }}> | ||||||
|  |           列番探索 | ||||||
|  |         </Text> | ||||||
|  |         <Text style={{ color: "white", fontSize: 18 }}> | ||||||
|  |           データベースに存在する全列車のダイヤを探索 | ||||||
|  |         </Text> | ||||||
|  |       </TextBox> | ||||||
|       <Text style={{ fontWeight: "bold", fontSize: 20 }}> |       <Text style={{ fontWeight: "bold", fontSize: 20 }}> | ||||||
|         このアプリについて |         このアプリについて | ||||||
|       </Text> |       </Text> | ||||||
|       <Text> |       <Text> | ||||||
|         このアプリはXprocess(HARUKIN)が製作しているJR四国の完全非公式アシストアプリケーションです。このアプリに関することでのJR四国公式へ問合せすることはお控えください。以下のTwitterよりお願いします。 |         このアプリはXprocess(HARUKIN)が製作しているJR四国の完全非公式アシストアプリケーションです。このアプリに関することでのJR四国公式へ問合せすることはお控えください。以下のTwitterよりお願いします。 | ||||||
|       </Text> |       </Text> | ||||||
|  |  | ||||||
|       <TextBox |       <TextBox | ||||||
|         backgroundColor="#CC0000" |         backgroundColor="#CC0000" | ||||||
|         flex={1} |         flex={1} | ||||||
|   | |||||||
							
								
								
									
										54
									
								
								ndView.js
									
									
									
									
									
								
							
							
						
						
									
										54
									
								
								ndView.js
									
									
									
									
									
								
							| @@ -1,8 +1,11 @@ | |||||||
| import React from "react"; | import React, { useRef, useState } from "react"; | ||||||
| import { View, Platform } from "react-native"; | import { View, Platform, TouchableOpacity } from "react-native"; | ||||||
| import { WebView } from "react-native-webview"; | import { WebView } from "react-native-webview"; | ||||||
| import Constants from "expo-constants"; | import Constants from "expo-constants"; | ||||||
|  | import { Ionicons } from "@expo/vector-icons"; | ||||||
| export default function tndView() { | export default function tndView() { | ||||||
|  |   const webview = useRef(); | ||||||
|  |   const [LoadError, setLoadError] = useState(false); | ||||||
|   return ( |   return ( | ||||||
|     <View |     <View | ||||||
|       style={{ |       style={{ | ||||||
| @@ -13,11 +16,22 @@ export default function tndView() { | |||||||
|     > |     > | ||||||
|       <WebView |       <WebView | ||||||
|         useWebKit={true} |         useWebKit={true} | ||||||
|  |         ref={webview} | ||||||
|         source={{ uri: "https://www.jr-shikoku.co.jp/info/" }} |         source={{ uri: "https://www.jr-shikoku.co.jp/info/" }} | ||||||
|         originWhitelist={["https://www.jr-shikoku.co.jp"]} |         originWhitelist={["https://www.jr-shikoku.co.jp"]} | ||||||
|         mixedContentMode={"compatibility"} |         mixedContentMode={"compatibility"} | ||||||
|         javaScriptEnabled={true} |         javaScriptEnabled={true} | ||||||
|         injectedJavaScript={jsa} |         injectedJavaScript={jsa} | ||||||
|  |         pullToRefreshEnabled | ||||||
|  |         onError={(syntheticEvent) => { | ||||||
|  |           //webViewの再読み込みを行う | ||||||
|  |           this.webView.reload(); | ||||||
|  |         }} | ||||||
|  |       /> | ||||||
|  |       <ReloadButton | ||||||
|  |         onPress={() => webview.current.reload()} | ||||||
|  |         top={Platform.OS == "ios" ? Constants.statusBarHeight : 0} | ||||||
|  |         LoadError={LoadError} | ||||||
|       /> |       /> | ||||||
|     </View> |     </View> | ||||||
|   ); |   ); | ||||||
| @@ -26,3 +40,39 @@ const jsa = ` | |||||||
| document.querySelector('.sitettl').style.display = 'none';	 | document.querySelector('.sitettl').style.display = 'none';	 | ||||||
| document.querySelector('.attention').style.display = 'none'; | document.querySelector('.attention').style.display = 'none'; | ||||||
| `; | `; | ||||||
|  |  | ||||||
|  | const ReloadButton = ({ onPress, top, mapSwitch, LoadError = false }) => { | ||||||
|  |   const styles = { | ||||||
|  |     touch: { | ||||||
|  |       position: "absolute", | ||||||
|  |       top, | ||||||
|  |       right: 10, | ||||||
|  |       width: 50, | ||||||
|  |       height: 50, | ||||||
|  |       backgroundColor: LoadError ? "red" : "#0099CC", | ||||||
|  |       borderColor: "white", | ||||||
|  |       borderStyle: "solid", | ||||||
|  |       borderWidth: 1, | ||||||
|  |       borderRadius: 50, | ||||||
|  |       alignContent: "center", | ||||||
|  |       alignSelf: "center", | ||||||
|  |       alignItems: "center", | ||||||
|  |       display: mapSwitch, | ||||||
|  |     }, | ||||||
|  |     text: { | ||||||
|  |       textAlign: "center", | ||||||
|  |       width: "auto", | ||||||
|  |       height: "auto", | ||||||
|  |       textAlignVertical: "center", | ||||||
|  |       fontWeight: "bold", | ||||||
|  |       color: "white", | ||||||
|  |     }, | ||||||
|  |   }; | ||||||
|  |   return ( | ||||||
|  |     <TouchableOpacity onPress={onPress} style={styles.touch}> | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |       <Ionicons name="reload" color="white" size={30} /> | ||||||
|  |       <View style={{ flex: 1 }} /> | ||||||
|  |     </TouchableOpacity> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								package.json
									
									
									
									
									
								
							| @@ -8,43 +8,49 @@ | |||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@expo/vector-icons": "^13.0.0", |     "@expo/vector-icons": "^13.0.0", | ||||||
|     "@react-native-async-storage/async-storage": "1.17.11", |     "@react-native-async-storage/async-storage": "1.18.2", | ||||||
|     "@react-native-community/masked-view": "0.1.10", |     "@react-native-community/masked-view": "0.1.10", | ||||||
|     "@react-navigation/bottom-tabs": "^5.11.11", |     "@react-navigation/bottom-tabs": "^5.11.11", | ||||||
|     "@react-navigation/native": "^5.9.4", |     "@react-navigation/native": "^5.9.4", | ||||||
|     "@react-navigation/stack": "^5.14.5", |     "@react-navigation/stack": "^5.14.5", | ||||||
|     "expo": "^48.0.0", |     "dayjs": "^1.11.9", | ||||||
|     "expo-font": "~11.1.1", |     "eas-cli": "^5.9.1", | ||||||
|     "expo-location": "~15.1.1", |     "expo": "^49.0.21", | ||||||
|     "expo-updates": "~0.16.3", |     "expo-device": "~5.4.0", | ||||||
|     "expo-web-browser": "~12.1.1", |     "expo-font": "~11.4.0", | ||||||
|  |     "expo-location": "~16.1.0", | ||||||
|  |     "expo-notifications": "~0.20.1", | ||||||
|  |     "expo-sharing": "~11.5.0", | ||||||
|  |     "expo-updates": "~0.18.17", | ||||||
|  |     "expo-web-browser": "~12.3.2", | ||||||
|     "firebase": "8.2.3", |     "firebase": "8.2.3", | ||||||
|     "lottie-react-native": "5.1.4", |     "lottie-react-native": "5.1.6", | ||||||
|     "native-base": "^2.15.2", |     "native-base": "^2.15.2", | ||||||
|     "npm": "^7.18.1", |     "npm": "^7.18.1", | ||||||
|     "pushy-react-native": "^1.0.18", |     "pushy-react-native": "^1.0.18", | ||||||
|     "react": "18.2.0", |     "react": "18.2.0", | ||||||
|     "react-native": "0.71.3", |     "react-native": "0.72.6", | ||||||
|     "react-native-actions-sheet": "^0.4.9", |     "react-native-actions-sheet": "0.8.21", | ||||||
|     "react-native-auto-height-image": "^3.2.4", |     "react-native-auto-height-image": "^3.2.4", | ||||||
|     "react-native-elements": "^3.4.2", |     "react-native-elements": "^3.4.2", | ||||||
|     "react-native-gesture-handler": "~2.9.0", |     "react-native-gesture-handler": "~2.12.0", | ||||||
|     "react-native-maps": "1.3.2", |     "react-native-maps": "1.7.1", | ||||||
|     "react-native-reanimated": "~2.14.4", |     "react-native-reanimated": "^3.6.1", | ||||||
|     "react-native-remote-svg": "^2.0.6", |     "react-native-remote-svg": "^2.0.6", | ||||||
|     "react-native-responsive-screen": "^1.4.2", |     "react-native-responsive-screen": "^1.4.2", | ||||||
|     "react-native-router-flux": "^4.3.1", |     "react-native-router-flux": "^4.3.1", | ||||||
|     "react-native-safe-area-context": "4.5.0", |     "react-native-safe-area-context": "4.6.3", | ||||||
|     "react-native-screens": "~3.20.0", |     "react-native-screens": "~3.22.0", | ||||||
|     "react-native-snap-carousel": "^3.9.1", |     "react-native-snap-carousel": "^3.9.1", | ||||||
|     "react-native-storage": "^1.0.1", |     "react-native-storage": "^1.0.1", | ||||||
|     "react-native-svg": "13.4.0", |     "react-native-svg": "13.9.0", | ||||||
|     "react-native-svg-uri": "^1.2.3", |     "react-native-svg-uri": "^1.2.3", | ||||||
|     "react-native-vector-icons": "^8.1.0", |     "react-native-vector-icons": "^8.1.0", | ||||||
|     "react-native-webview": "11.26.0" |     "react-native-view-shot": "3.7.0", | ||||||
|  |     "react-native-webview": "^13.6.3" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "babel-preset-expo": "^9.3.0" |     "babel-preset-expo": "^9.5.0" | ||||||
|   }, |   }, | ||||||
|   "private": true |   "private": true | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								stateBox/useAllTrainDiagram.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								stateBox/useAllTrainDiagram.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | import React, { createContext, useContext, useEffect, useState } from "react"; | ||||||
|  | const initialState = { | ||||||
|  |   allTrainDiagram: undefined, | ||||||
|  |   setAllTrainDiagram: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const AllTrainDiagramContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useAllTrainDiagram = () => { | ||||||
|  |   return useContext(AllTrainDiagramContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const AllTrainDiagramProvider = ({ children }) => { | ||||||
|  |   const [allTrainDiagram, setAllTrainDiagram] = useState(); | ||||||
|  |   const customData = { | ||||||
|  |     //9001: "岡山,発,10:11#児島,発,11:05#坂出,発,11:41#高松,着,12:00#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  |     9001: "ウェルカムセレモニー,頃,9:40#岡山,頃,10:10#琴平,頃,14:00#琴平観光,以降,14:00#湯山荘 阿讃琴南,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第1章\n-瀬戸の海に想いを馳せながら-\n岡山・高松・琴平,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |     //9029: "高松,発,12:42#琴平,着,13:57#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  |     9029: "ウェルカムセレモニー,頃,9:40#岡山,頃,10:10#琴平,頃,14:00#琴平観光,以降,14:00#湯山荘 阿讃琴南,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第1章\n-瀬戸の海に想いを馳せながら-\n岡山・高松・琴平,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |     //9003: "多度津,発,10:09#今治,発,13:20#伊予亀岡,発,13:55#菊間,発,14:04#松山,着,14:50#独自補完データ,提,https://x.com/makkun3/status/1750490886293848372#", | ||||||
|  |     9003: "湯山荘 阿讃琴南,頃,9:00#多度津,頃,10:10#松山,頃,14:50#宿泊施設,以降,14:50#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第2章\n -四国の伝統文化を感じて-\n多度津・坂出・松山,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |     9055: "宿泊施設→バス,着,10:30#松山,頃,10:30#今治,頃,14:15#しまなみエリア観光,以降,14:15#Azumi Setoda,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第3章\n-凪の誘い・瀬戸内の絶景-\n今治・しまなみ海道,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |     9056: "宿泊施設→バス,着,10:30#松山,頃,10:30#今治,頃,14:15#しまなみエリア観光,以降,14:15#Azumi Setoda,頃,16:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS 第3章\n-凪の誘い・瀬戸内の絶景-\n今治・しまなみ海道,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |     9004: "Azumi Setoda,頃,9:30#今治,頃,10:30#高松,頃,14:30#高松港\n↓\n瀬戸内クルーズ(貸切)\n「おりんぴあどりーむ せと」\n↓ \n 新岡山港,以降,14:15#岡山駅,頃,18:00#独自補完データ,提,https://www.the-royalexpress.jp/plan/2614/#ROYAL EXPRESS フィナーレ\n-四国・瀬戸内の彩りに囲まれて-\n今治・高松・岡山,提,https://www.the-royalexpress.jp/plan/2614/#", | ||||||
|  |   }; | ||||||
|  |   useEffect(() => { | ||||||
|  |     fetch( | ||||||
|  |       "https://script.google.com/macros/s/AKfycbx_s7RB-xTy-iAslFJg7LfplLV09-hjDXEjdi9kCP_JT45wq17Af_IPOKIOqIfaNDg/exec" | ||||||
|  |     ) | ||||||
|  |       .then((res) => res.json()) | ||||||
|  |       .then((res) => { | ||||||
|  |         const data = {}; | ||||||
|  |         res.forEach((d) => { | ||||||
|  |           const keys = Object.keys(d); | ||||||
|  |           data[keys] = d[keys]; | ||||||
|  |         }); | ||||||
|  |         return data; | ||||||
|  |       }) | ||||||
|  |       .then((res) => { | ||||||
|  |         Object.assign(res, customData); | ||||||
|  |         setAllTrainDiagram(res); | ||||||
|  |       }); | ||||||
|  |   }, []); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <AllTrainDiagramContext.Provider | ||||||
|  |       value={{ allTrainDiagram, setAllTrainDiagram }} | ||||||
|  |     > | ||||||
|  |       {children} | ||||||
|  |     </AllTrainDiagramContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										21
									
								
								stateBox/useAreaInfo.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								stateBox/useAreaInfo.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | import React, { createContext, useContext, useState } from "react"; | ||||||
|  | const initialState = { | ||||||
|  |   areaInfo: "", | ||||||
|  |   setAreainfo: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const AreaInfoContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useAreaInfo = () => { | ||||||
|  |   return useContext(AreaInfoContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const AreaInfoProvider = ({ children }) => { | ||||||
|  |   const [areaInfo, setAreaInfo] = useState(""); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <AreaInfoContext.Provider value={{ areaInfo, setAreaInfo }}> | ||||||
|  |       {children} | ||||||
|  |     </AreaInfoContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										70
									
								
								stateBox/useBusAndTrainData.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								stateBox/useBusAndTrainData.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | |||||||
|  | import React, { createContext, useContext, useState } from "react"; | ||||||
|  | import trainList from "../assets/originData/trainList"; | ||||||
|  | const initialState = { | ||||||
|  |   busAndTrainData: [], | ||||||
|  |   setBusAndTrainData: () => {}, | ||||||
|  |   trainPairData: [], | ||||||
|  |   setTrainPairData: () => {}, | ||||||
|  |   initializeTrainPairList: () => {}, | ||||||
|  |   getInfluencedTrainData: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const BusAndTrainDataContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useBusAndTrainData = () => { | ||||||
|  |   return useContext(BusAndTrainDataContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const BusAndTrainDataProvider = ({ children }) => { | ||||||
|  |   const [busAndTrainData, setBusAndTrainData] = useState([]); | ||||||
|  |   const [trainPairData, setTrainPairData] = useState([]); | ||||||
|  |   const initializeTrainPairList = () => { | ||||||
|  |     const trainPairList = {}; | ||||||
|  |     trainPairData.forEach((d) => { | ||||||
|  |       trainPairList[Object.keys(d)[0]] = d[Object.keys(d)[0]]; | ||||||
|  |     }); | ||||||
|  |     return trainPairList; | ||||||
|  |   }; | ||||||
|  |   const getInfluencedTrainData = (trainNum) => { | ||||||
|  |     const trainPairList = initializeTrainPairList(); | ||||||
|  |  | ||||||
|  |     const returnArray = []; | ||||||
|  |     if (!trainNum) return; | ||||||
|  |     if (trainPairList[trainNum]) { | ||||||
|  |       returnArray.push(Object.keys(trainPairList[trainNum])[0]); | ||||||
|  |     } | ||||||
|  |     if ( | ||||||
|  |       // 列番が4xxDまたは5xxDの場合はxxDの列番を検索 | ||||||
|  |       new RegExp(/^4[1-9]\d\d[DM]$/).test(trainNum) || | ||||||
|  |       new RegExp(/^5[1-7]\d\d[DM]$/).test(trainNum) | ||||||
|  |     ) { | ||||||
|  |       if (trainList[trainNum.substring(1)]) { | ||||||
|  |         returnArray.push(trainNum.substring(1)); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     if (new RegExp(/^[1-9]\d\d[DM]$/).test(trainNum)) { | ||||||
|  |       // 列番がxxDの場合は4xxDと5xxDの列番を検索 | ||||||
|  |       if (trainList["4" + trainNum]) returnArray.push("4" + trainNum); | ||||||
|  |       if (trainList["5" + trainNum]) returnArray.push("5" + trainNum); | ||||||
|  |     } | ||||||
|  |     if (!returnArray[0]) return [[], []]; | ||||||
|  |     const TD = trainList[returnArray[0]]; | ||||||
|  |     if (!TD) return [[], []]; | ||||||
|  |     const TDArray = TD.split("#").filter((d) => d != ""); | ||||||
|  |     return [returnArray, TDArray]; | ||||||
|  |   }; | ||||||
|  |   return ( | ||||||
|  |     <BusAndTrainDataContext.Provider | ||||||
|  |       value={{ | ||||||
|  |         busAndTrainData, | ||||||
|  |         setBusAndTrainData, | ||||||
|  |         trainPairData, | ||||||
|  |         setTrainPairData, | ||||||
|  |         initializeTrainPairList, | ||||||
|  |         getInfluencedTrainData, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       {children} | ||||||
|  |     </BusAndTrainDataContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										56
									
								
								stateBox/useCurrentTrain.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								stateBox/useCurrentTrain.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | import React, { createContext, useContext, useState, useEffect } from "react"; | ||||||
|  | import { HeaderConfig } from "../lib/HeaderConfig"; | ||||||
|  |  | ||||||
|  | import useInterval from "../lib/useInterval"; | ||||||
|  | const initialState = { | ||||||
|  |   currentTrain: [], | ||||||
|  |   setCurrentTrain: () => {}, | ||||||
|  |   currentTrainLoading: "loading", | ||||||
|  |   setCurrentTrainLoading: () => {}, | ||||||
|  |   getCurrentTrain: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const CurrentTrainContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useCurrentTrain = () => { | ||||||
|  |   return useContext(CurrentTrainContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const CurrentTrainProvider = ({ children }) => { | ||||||
|  |   const [currentTrain, setCurrentTrain] = useState([]); //現在在線中の全列車 { num: 列車番号, delay: 遅延時分(状態), Pos: 位置情報 } | ||||||
|  |   const [currentTrainLoading, setCurrentTrainLoading] = useState("loading"); // success, error, loading | ||||||
|  |   const getCurrentTrain = () => | ||||||
|  |     fetch( | ||||||
|  |       "https://script.google.com/macros/s/AKfycby9Y2-Bm75J_WkbZimi7iS8v5r9wMa9wtzpdwES9sOGF4i6HIYEJOM60W6gM1gXzt1o/exec", | ||||||
|  |       HeaderConfig | ||||||
|  |     ) | ||||||
|  |       .then((response) => response.json()) | ||||||
|  |       .then((d) => | ||||||
|  |         d.map((x) => ({ num: x.TrainNum, delay: x.delay, Pos: x.Pos })) | ||||||
|  |       ) | ||||||
|  |       .then((d) => { | ||||||
|  |         setCurrentTrain(d); | ||||||
|  |         setCurrentTrainLoading("success"); | ||||||
|  |       }) | ||||||
|  |       .catch(() => { | ||||||
|  |         console.log("えらー"); | ||||||
|  |         setCurrentTrainLoading("error"); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |   useEffect(getCurrentTrain, []); //初回だけ現在の全在線列車取得 | ||||||
|  |  | ||||||
|  |   useInterval(getCurrentTrain, 15000); //15秒毎に全在線列車取得 | ||||||
|  |   return ( | ||||||
|  |     <CurrentTrainContext.Provider | ||||||
|  |       value={{ | ||||||
|  |         currentTrain, | ||||||
|  |         setCurrentTrain, | ||||||
|  |         currentTrainLoading, | ||||||
|  |         setCurrentTrainLoading, | ||||||
|  |         getCurrentTrain, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       {children} | ||||||
|  |     </CurrentTrainContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										36
									
								
								stateBox/useFavoriteStation.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								stateBox/useFavoriteStation.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | import React, { | ||||||
|  |   createContext, | ||||||
|  |   useContext, | ||||||
|  |   useState, | ||||||
|  |   useLayoutEffect, | ||||||
|  | } from "react"; | ||||||
|  | import { AS } from "../storageControl"; | ||||||
|  | const initialState = { | ||||||
|  |   favoriteStation: [], | ||||||
|  |   setFavoriteStation: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const FavoriteStationContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useFavoriteStation = () => { | ||||||
|  |   return useContext(FavoriteStationContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const FavoriteStationProvider = ({ children }) => { | ||||||
|  |   const [favoriteStation, setFavoriteStation] = useState([]); | ||||||
|  |   useLayoutEffect(() => { | ||||||
|  |     AS.getItem("favoriteStation") | ||||||
|  |       .then((d) => { | ||||||
|  |         const returnData = JSON.parse(d); | ||||||
|  |         setFavoriteStation(returnData); | ||||||
|  |       }) | ||||||
|  |       .catch((d) => console.log(d)); | ||||||
|  |   }, []); | ||||||
|  |   return ( | ||||||
|  |     <FavoriteStationContext.Provider | ||||||
|  |       value={{ favoriteStation, setFavoriteStation }} | ||||||
|  |     > | ||||||
|  |       {children} | ||||||
|  |     </FavoriteStationContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
							
								
								
									
										45
									
								
								stateBox/useTrainDelayData.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								stateBox/useTrainDelayData.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | import React, { createContext, useContext, useEffect, useState } from "react"; | ||||||
|  | const initialState = { | ||||||
|  |   getTime: new Date(), | ||||||
|  |   setGetTime: () => {}, | ||||||
|  |   loadingDelayData: true, | ||||||
|  |   setLoadingDelayData: () => {}, | ||||||
|  |   delayData: undefined, | ||||||
|  |   setDelayData: () => {}, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const TrainDelayDataContext = createContext(initialState); | ||||||
|  |  | ||||||
|  | export const useTrainDelayData = () => { | ||||||
|  |   return useContext(TrainDelayDataContext); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const TrainDelayDataProvider = ({ children }) => { | ||||||
|  |   const [delayData, setDelayData] = useState(undefined); | ||||||
|  |   const [getTime, setGetTime] = useState(new Date()); | ||||||
|  |   const [loadingDelayData, setLoadingDelayData] = useState(true); | ||||||
|  |   useEffect(() => { | ||||||
|  |     fetch( | ||||||
|  |       "https://script.google.com/macros/s/AKfycbyKxch7z7l8e07LXulRHqxjVoIiB13kcgvoToLE-rqlxLmLSKdlmqz0FI1F2EuA7Zfg/exec" | ||||||
|  |     ) | ||||||
|  |       .then((response) => response.text()) | ||||||
|  |       .then((data) => setDelayData(data !== "" ? data.split("^") : null)) | ||||||
|  |       .then(() => setGetTime(new Date())) | ||||||
|  |       .finally(() => setLoadingDelayData(false)); | ||||||
|  |   }, [loadingDelayData]); | ||||||
|  |  | ||||||
|  |   return ( | ||||||
|  |     <TrainDelayDataContext.Provider | ||||||
|  |       value={{ | ||||||
|  |         getTime, | ||||||
|  |         setGetTime, | ||||||
|  |         loadingDelayData, | ||||||
|  |         setLoadingDelayData, | ||||||
|  |         delayData, | ||||||
|  |         setDelayData, | ||||||
|  |       }} | ||||||
|  |     > | ||||||
|  |       {children} | ||||||
|  |     </TrainDelayDataContext.Provider> | ||||||
|  |   ); | ||||||
|  | }; | ||||||
| @@ -36,7 +36,7 @@ export default function TrainBase({ route, navigation }) { | |||||||
|         setSupportMultipleWindows={false} |         setSupportMultipleWindows={false} | ||||||
|         onMessage={(event) => {}} |         onMessage={(event) => {}} | ||||||
|       /> |       /> | ||||||
|       {from == "LED" && ( |       {(from == "LED" || from == "AllTrainDiagramView") && ( | ||||||
|         <TouchableOpacity |         <TouchableOpacity | ||||||
|           style={{ |           style={{ | ||||||
|             padding: 10, |             padding: 10, | ||||||
| @@ -47,7 +47,9 @@ export default function TrainBase({ route, navigation }) { | |||||||
|             borderRadius: 5, |             borderRadius: 5, | ||||||
|             alignItems: "center", |             alignItems: "center", | ||||||
|           }} |           }} | ||||||
|           onPress={() => navigate("menu")} |           onPress={() => | ||||||
|  |             navigate(from == "AllTrainDiagramView" ? "AllTrainIDList" : "menu") | ||||||
|  |           } | ||||||
|         > |         > | ||||||
|           <View style={{ flex: 1 }} /> |           <View style={{ flex: 1 }} /> | ||||||
|           <MaterialCommunityIcons name="close" color="black" size={30} /> |           <MaterialCommunityIcons name="close" color="black" size={30} /> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user