Skip to content

Commit

Permalink
remove location suggestions from route planning
Browse files Browse the repository at this point in the history
  • Loading branch information
bwees committed Sep 20, 2024
1 parent d6c5040 commit 63d254f
Showing 1 changed file with 31 additions and 48 deletions.
79 changes: 31 additions & 48 deletions app/data/api_query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -227,71 +227,54 @@ export const useSearchSuggestion = (query: string) => {
return useQuery<SearchSuggestion[]>({
queryKey: ["searchSuggestion", query],
queryFn: async () => {
let dataSources: Promise<any>[] = [
findLocations(query, "AIzaSyD-Ap8GzlFWIUOwqMnYpxRjwwAyhpb3ljQ")
]

// we need data from pattern paths to get the stop GPS locations
// This is limitation of the API where we can't get the GPS location of a stop directly
// we can just ignore the bus stops if we don't have the pattern paths
// since Google already has most buildings in their search
if (patternPathsQuery.isSuccess && baseDataQuery.isSuccess) {
dataSources.push(findBusStops(query, authTokenQuery.data!))
}

const responses = await Promise.all(dataSources);

// handle locations
const locations: [SearchSuggestion] = responses[0].map((location: IFoundLocation) => {
return {
type: "map",
title: location.structured_formatting.main_text,
subtitle: location.structured_formatting.secondary_text,
placeId: location.place_id,
}
});

const stops = await findBusStops(query, authTokenQuery.data!)

// handle bus stops
let busStops: SearchSuggestion[] = []
if (responses.length > 1) {
// we need the baseData to get the stop GPS locations
const baseData = baseDataQuery.data as IGetBaseDataResponse;

busStops = responses[1].map((stop: IFoundStop) => {
// find the stop location (lat/long) in baseData patternPaths
// TODO: convert this processing to be on the BaseData loading
let foundLocation: IPatternPoint | undefined = undefined;
for (let route of baseData.routes) {
for (let path of route.patternPaths) {
const stops = path.patternPoints.filter(point => point.stop != null)
for (let point of stops) {
if (point.stop?.stopCode === stop.stopCode) {
foundLocation = point;
break;
}

// we need the baseData to get the stop GPS locations
const baseData = baseDataQuery.data as IGetBaseDataResponse;

busStops = stops.map((stop: IFoundStop) => {
// find the stop location (lat/long) in baseData patternPaths
// TODO: convert this processing to be on the BaseData loading
let foundLocation: IPatternPoint | undefined = undefined;
for (let route of baseData.routes) {
for (let path of route.patternPaths) {
const stops = path.patternPoints.filter(point => point.stop != null)
for (let point of stops) {
if (point.stop?.stopCode === stop.stopCode) {
foundLocation = point;
break;
}
if (foundLocation) break;
}

if (foundLocation) break;
}

return {
type: "stop",
title: stop.stopName,
subtitle: "ID: " + stop.stopCode,
code: stop.stopCode,
lat: foundLocation?.latitude,
long: foundLocation?.longitude
}
});
}
if (foundLocation) break;
}

return {
type: "stop",
title: stop.stopName,
subtitle: "ID: " + stop.stopCode,
code: stop.stopCode,
lat: foundLocation?.latitude,
long: foundLocation?.longitude
}
});

return [...busStops, ...locations];
return busStops;
},
enabled:
authTokenQuery.isSuccess &&
patternPathsQuery.isSuccess &&
baseDataQuery.isSuccess &&
query !== "" ,
throwOnError: true,
staleTime: Infinity
Expand Down

0 comments on commit 63d254f

Please sign in to comment.