関係ありそうな列車をピックアップする機能を仮作成
This commit is contained in:
parent
d6a2846f6b
commit
7492028a21
@ -28,6 +28,8 @@ import lineColorList from "../../assets/originData/lineColorList";
|
|||||||
import { useCurrentTrain } from "../../stateBox/useCurrentTrain";
|
import { useCurrentTrain } from "../../stateBox/useCurrentTrain";
|
||||||
import { checkDuplicateTrainData } from "../../lib/checkDuplicateTrainData";
|
import { checkDuplicateTrainData } from "../../lib/checkDuplicateTrainData";
|
||||||
import dayjs from "dayjs";
|
import dayjs from "dayjs";
|
||||||
|
import { getTrainType } from "../../lib/getTrainType";
|
||||||
|
import { customTrainDataDetector } from "../custom-train-data";
|
||||||
|
|
||||||
export const EachTrainInfo = (props) => {
|
export const EachTrainInfo = (props) => {
|
||||||
if (!props.payload) return <></>;
|
if (!props.payload) return <></>;
|
||||||
@ -46,7 +48,52 @@ export const EachTrainInfo = (props) => {
|
|||||||
const { currentTrain } = useCurrentTrain();
|
const { currentTrain } = useCurrentTrain();
|
||||||
|
|
||||||
const [currentTrainData, setCurrentTrainData] = useState([]);
|
const [currentTrainData, setCurrentTrainData] = useState([]);
|
||||||
|
const [nearTrainIDList, setNearTrainIDList] = useState([]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const returnArray = [];
|
||||||
|
if (!data.trainNum) return;
|
||||||
|
if (
|
||||||
|
new RegExp(/^4[1-9]\d\d[DM]$/).test(data.trainNum) ||
|
||||||
|
new RegExp(/^5[1-7]\d\d[DM]$/).test(data.trainNum)
|
||||||
|
) {
|
||||||
|
if (trainList[data.trainNum.substring(1)]) {
|
||||||
|
returnArray.push(data.trainNum.substring(1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (new RegExp(/^[1-9]\d\d[DM]$/).test(data.trainNum)) {
|
||||||
|
if (trainList["4" + data.trainNum]) {
|
||||||
|
returnArray.push("4" + data.trainNum);
|
||||||
|
}
|
||||||
|
if (trainList["5" + data.trainNum]) {
|
||||||
|
returnArray.push("5" + data.trainNum);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setNearTrainIDList(returnArray);
|
||||||
|
}, [data]);
|
||||||
|
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,
|
||||||
|
});
|
||||||
|
};
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setCurrentTrainData(
|
setCurrentTrainData(
|
||||||
checkDuplicateTrainData(
|
checkDuplicateTrainData(
|
||||||
@ -302,9 +349,17 @@ export const EachTrainInfo = (props) => {
|
|||||||
: ""}
|
: ""}
|
||||||
</Text>
|
</Text>
|
||||||
<View style={{ flex: 1 }} />
|
<View style={{ flex: 1 }} />
|
||||||
<Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}>
|
<TouchableOpacity
|
||||||
{data.trainNum}
|
onPress={() => {
|
||||||
</Text>
|
nearTrainIDList.length && openTrainInfo(nearTrainIDList[0]);
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<Text style={{ fontSize: 20, fontWeight: "bold", color: "white" }}>
|
||||||
|
{data.trainNum}
|
||||||
|
{nearTrainIDList.length ? "..." : ""}
|
||||||
|
</Text>
|
||||||
|
</TouchableOpacity>
|
||||||
|
|
||||||
{data.limited != undefined &&
|
{data.limited != undefined &&
|
||||||
getType(data.limited.split(":")[0]) &&
|
getType(data.limited.split(":")[0]) &&
|
||||||
!data.limited.split(":")[1].match("サンポート") && (
|
!data.limited.split(":")[1].match("サンポート") && (
|
||||||
|
Loading…
Reference in New Issue
Block a user