@opentripplanner/core-utils 11.4.0 → 11.4.2-mobility-profile
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/__mocks__/bike-rental-itinerary.json +863 -0
- package/lib/__tests__/__mocks__/config.json +54 -0
- package/lib/__tests__/__mocks__/fare-products-itinerary.json +1299 -0
- package/lib/__tests__/__mocks__/routes.json +107 -0
- package/lib/__tests__/__mocks__/tnc-itinerary.json +1726 -0
- package/lib/bike-rental-itinerary.json +863 -0
- package/lib/config.json +54 -0
- package/lib/core-utils.story.d.ts +0 -1
- package/lib/core-utils.story.d.ts.map +1 -1
- package/lib/fare-products-itinerary.json +1299 -0
- package/lib/otpSchema.json +13373 -0
- package/lib/planQuery.graphql +281 -0
- package/lib/query-gen.d.ts +3 -1
- package/lib/query-gen.d.ts.map +1 -1
- package/lib/query-gen.js +6 -2
- package/lib/query-gen.js.map +1 -1
- package/lib/routes.json +107 -0
- package/lib/suspense.js +26 -0
- package/lib/suspense.js.map +1 -0
- package/lib/tnc-itinerary.json +1726 -0
- package/package.json +2 -2
- package/src/otpSchema.json +10 -0
- package/src/planQuery.graphql +2 -0
- package/src/query-gen.ts +7 -1
- package/esm/graphql.d.js +0 -2
- package/esm/graphql.d.js.map +0 -1
- package/esm/index.js +0 -24
- package/esm/index.js.map +0 -1
- package/esm/itinerary.js +0 -688
- package/esm/itinerary.js.map +0 -1
- package/esm/map.js +0 -53
- package/esm/map.js.map +0 -1
- package/esm/profile.js +0 -172
- package/esm/profile.js.map +0 -1
- package/esm/query-gen.js +0 -231
- package/esm/query-gen.js.map +0 -1
- package/esm/query-params.js +0 -786
- package/esm/query-params.js.map +0 -1
- package/esm/query.js +0 -538
- package/esm/query.js.map +0 -1
- package/esm/route.js +0 -460
- package/esm/route.js.map +0 -1
- package/esm/storage.js +0 -46
- package/esm/storage.js.map +0 -1
- package/esm/time.js +0 -94
- package/esm/time.js.map +0 -1
- package/esm/ui.js +0 -48
- package/esm/ui.js.map +0 -1
- package/tsconfig.tsbuildinfo +0 -1
package/esm/query-params.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/query-params.js"],"names":["cloneDeep","React","Wheelchair","isTransit","isAccessMode","isCar","hasTransit","hasBike","hasMicromobility","getItem","getCurrentDate","getCurrentTime","formatPlace","location","alternateName","name","lat","lon","storedSettings","queryParams","routingTypes","itineraryRewrite","value","fromPlace","profileRewrite","from","toPlace","to","arriveBy","accessModes","directModes","transitModes","length","split","forEach","m","push","applicable","query","otp2","mode","indexOf","selector","label","options","text","maxWalkDistance","maxBikeDistance","opts","optimize","low","high","step","labelLow","labelHigh","maxEScooterDistance","watts","maximumMicromobilitySpeed","weight","TYPICAL_RIDER_WEIGHT","icon","config","modes","configModes","concat","some","configMode","find","showWheelchairSetting","company","companies","includes","places","Array","isArray","intermediatePlaces","map","place","undefined","param","userDefaultOverride","getCustomQueryParams","customizations","clonedParams","Object","keys","k","paramIndex","findIndex"],"mappings":"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","sourcesContent":["// TODO: Remove this entire file, as it is deprecated in favor of i18n-queryParams within\n// the SettingsSelector package\n\n// This is only used within stories\nimport cloneDeep from \"lodash.clonedeep\";\nimport React from \"react\";\nimport { Wheelchair } from \"@styled-icons/foundation/Wheelchair\";\n\nimport {\n isTransit,\n isAccessMode,\n isCar,\n hasTransit,\n hasBike,\n hasMicromobility\n} from \"./itinerary\";\nimport { getItem } from \"./storage\";\nimport { getCurrentDate, getCurrentTime } from \"./time\";\n\n/**\n * name: the default name of the parameter used for internal reference and API calls\n *\n * routingTypes: array of routing type(s) (ITINERARY, PROFILE, or both) this param applies to\n *\n * applicable: an optional function (accepting the current full query as a\n * parameter) indicating whether this query parameter is applicable to the query.\n * (Applicability is assumed if this function is not provided.)\n *\n * default: the default value for this parameter. The default can be also be a\n * function that gets executed when accessing the default value.\n *\n * itineraryRewrite: an optional function for translating the key and/or value\n * for ITINERARY mode only (e.g. 'to' is rewritten as 'toPlace'). Accepts the\n * initial internal value as a function parameter.\n *\n * profileRewrite: an optional function for translating the value for PROFILE mode\n *\n * label: a text label for for onscreen display. May either be a text string or a\n * function (accepting the current full query as a parameter) returning a string\n *\n * selector: the default type of UI selector to use in the form. Can be one of:\n * - DROPDOWN: a standard drop-down menu selector\n *\n * options: an array of text/value pairs used with a dropdown selector\n *\n * TODO: validation system for rewrite functions and/or better user documentation\n * TODO: alphabetize below list\n */\n\n// FIXME: Use for parsing URL values?\n// const stringToLocation = string => {\n// const split = string.split(',')\n// return split.length === 2\n// ? {lat: split[0], lon: split[1]}\n// : {lat: null, lon: null}\n// }\n\n/**\n * Format location object as string for use in fromPlace or toPlace query param.\n */\nexport function formatPlace(location, alternateName) {\n if (!location) return null;\n const name =\n location.name ||\n `${alternateName ? `${alternateName} ` : \"\"}(${location.lat},${\n location.lon\n })`;\n // This string is not language-specific\n return `${name}::${location.lat},${location.lon}`;\n}\n\n// Load stored default query settings from local storage\nconst storedSettings = getItem(\"defaultQuery\", {});\n\nconst queryParams = [\n {\n /* from - the trip origin. stored internally as a location (lat/lon/name) object */\n name: \"from\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: null,\n itineraryRewrite: value => ({ fromPlace: formatPlace(value) }),\n profileRewrite: value => ({ from: { lat: value.lat, lon: value.lon } })\n // FIXME: Use for parsing URL values?\n // fromURL: stringToLocation\n },\n\n {\n /* to - the trip destination. stored internally as a location (lat/lon/name) object */\n name: \"to\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: null,\n itineraryRewrite: value => ({ toPlace: formatPlace(value) }),\n profileRewrite: value => ({ to: { lat: value.lat, lon: value.lon } })\n // FIXME: Use for parsing URL values?\n // fromURL: stringToLocation\n },\n\n {\n /* date - the date of travel, in MM-DD-YYYY format */\n name: \"date\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: getCurrentDate\n },\n\n {\n /* time - the arrival/departure time for an itinerary trip, in HH:mm format */\n name: \"time\",\n routingTypes: [\"ITINERARY\"],\n default: getCurrentTime\n },\n\n {\n /* departArrive - whether this is a depart-at, arrive-by, or leave-now trip */\n name: \"departArrive\",\n routingTypes: [\"ITINERARY\"],\n default: \"NOW\",\n itineraryRewrite: value => ({ arriveBy: value === \"ARRIVE\" })\n },\n\n {\n /* startTime - the start time for a profile trip, in HH:mm format */\n name: \"startTime\",\n routingTypes: [\"PROFILE\"],\n default: \"07:00\"\n },\n\n {\n /* endTime - the end time for a profile trip, in HH:mm format */\n name: \"endTime\",\n routingTypes: [\"PROFILE\"],\n default: \"09:00\"\n },\n\n {\n /* mode - the allowed modes for a trip, as a comma-separated list */\n name: \"mode\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: \"WALK,TRANSIT\", // TODO: make this dependent on routingType?\n profileRewrite: value => {\n const accessModes = [];\n const directModes = [];\n const transitModes = [];\n\n if (value && value.length > 0) {\n value.split(\",\").forEach(m => {\n if (isTransit(m)) transitModes.push(m);\n if (isAccessMode(m)) {\n accessModes.push(m);\n // TODO: make configurable whether direct-driving is considered\n if (!isCar(m)) directModes.push(m);\n }\n });\n }\n\n return { accessModes, directModes, transitModes };\n }\n },\n\n {\n /* showIntermediateStops - whether response should include intermediate stops for transit legs */\n name: \"showIntermediateStops\",\n routingTypes: [\"ITINERARY\"],\n default: true\n },\n\n {\n /* maxWalkDistance - the maximum distance in meters the user will walk to transit. */\n name: \"maxWalkDistance\",\n routingTypes: [\"ITINERARY\"],\n applicable: query =>\n /* Since this query variable isn't in this list, it's not included in the generated query\n * It does however allow us to determine if we should show the OTP1 max walk distance\n * dropdown or the OTP2 walk reluctance slider\n */\n !query.otp2 &&\n query.mode &&\n hasTransit(query.mode) &&\n query.mode.indexOf(\"WALK\") !== -1,\n default: 1609, // 1 mi.\n selector: \"DROPDOWN\",\n label: \"Maximum Walk\",\n options: [\n {\n text: \"1/10 mile\",\n value: 160.9\n },\n {\n text: \"1/4 mile\",\n value: 402.3\n },\n {\n text: \"1/2 mile\",\n value: 804.7\n },\n {\n text: \"3/4 mile\",\n value: 1207\n },\n {\n text: \"1 mile\",\n value: 1609\n },\n {\n text: \"2 miles\",\n value: 3219\n },\n {\n text: \"5 miles\",\n value: 8047\n }\n ]\n },\n\n {\n /* maxBikeDistance - the maximum distance in meters the user will bike. Not\n * actually an OTP parameter (maxWalkDistance doubles for biking) but we\n * store it separately internally in order to allow different default values,\n * options, etc. Translated to 'maxWalkDistance' via the rewrite function.\n */\n name: \"maxBikeDistance\",\n routingTypes: [\"ITINERARY\"],\n applicable: query =>\n query.mode &&\n hasTransit(query.mode) &&\n query.mode.indexOf(\"BICYCLE\") !== -1,\n default: 4828, // 3 mi.\n selector: \"DROPDOWN\",\n label: \"Maximum Bike\",\n options: [\n {\n text: \"1/4 mile\",\n value: 402.3\n },\n {\n text: \"1/2 mile\",\n value: 804.7\n },\n {\n text: \"3/4 mile\",\n value: 1207\n },\n {\n text: \"1 mile\",\n value: 1609\n },\n {\n text: \"2 miles\",\n value: 3219\n },\n {\n text: \"3 miles\",\n value: 4828\n },\n {\n text: \"5 miles\",\n value: 8047\n },\n {\n text: \"10 miles\",\n value: 16093\n },\n {\n text: \"20 miles\",\n value: 32187\n },\n {\n text: \"30 miles\",\n value: 48280\n }\n ],\n itineraryRewrite: value => ({\n maxWalkDistance: value,\n // ensures that the value is repopulated when loaded from URL params\n maxBikeDistance: value\n })\n },\n\n {\n /* optimize -- how to optimize a trip (non-bike, non-micromobility trips) */\n name: \"optimize\",\n // This parameter doesn't seem to do anything\n applicable: () => false,\n routingTypes: [\"ITINERARY\"],\n default: \"QUICK\",\n selector: \"DROPDOWN\",\n label: \"Optimize for\",\n options: [\n {\n text: \"Speed\",\n value: \"QUICK\"\n },\n {\n text: \"Fewest Transfers\",\n value: \"TRANSFERS\"\n }\n ]\n },\n\n {\n /* optimizeBike -- how to optimize an bike-based trip */\n name: \"optimizeBike\",\n applicable: query => !query.otp2 && hasBike(query.mode),\n routingTypes: [\"ITINERARY\"],\n default: \"SAFE\",\n selector: \"DROPDOWN\",\n label: \"Optimize for\",\n options: () => {\n const opts = [\n {\n text: \"Speed\",\n value: \"QUICK\"\n },\n {\n text: \"Bike-Friendly Trip\",\n value: \"SAFE\"\n },\n {\n text: \"Flat Trip\",\n value: \"FLAT\"\n }\n ];\n\n return opts;\n },\n itineraryRewrite: value => ({ optimize: value })\n },\n\n {\n /* maxWalkTime -- the maximum time the user will spend walking in minutes */\n name: \"maxWalkTime\",\n routingTypes: [\"PROFILE\"],\n default: 15,\n selector: \"DROPDOWN\",\n label: \"Max Walk Time\",\n applicable: query =>\n query.mode && hasTransit(query.mode) && query.mode.indexOf(\"WALK\") !== -1,\n options: [\n {\n text: \"5 minutes\",\n value: 5\n },\n {\n text: \"10 minutes\",\n value: 10\n },\n {\n text: \"15 minutes\",\n value: 15\n },\n {\n text: \"20 minutes\",\n value: 20\n },\n {\n text: \"30 minutes\",\n value: 30\n },\n {\n text: \"45 minutes\",\n value: 45\n },\n {\n text: \"1 hour\",\n value: 60\n }\n ]\n },\n {\n name: \"walkReluctance\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n selector: \"SLIDER\",\n low: 1,\n high: 10,\n step: 0.5,\n label: \"walk reluctance\",\n labelLow: \"More Walking\",\n labelHigh: \"More Transit\",\n applicable: query =>\n /* Since this query variable isn't in this list, it's not included in the generated query\n * It does however allow us to determine if we should show the OTP1 max walk distance\n * dropdown or the OTP2 walk reluctance slider\n */\n !!query.otp2 && query.mode && query.mode.indexOf(\"WALK\") !== -1\n },\n {\n /* maxBikeTime -- the maximum time the user will spend biking in minutes */\n name: \"maxBikeTime\",\n routingTypes: [\"PROFILE\"],\n default: 20,\n selector: \"DROPDOWN\",\n label: \"Max Bike Time\",\n applicable: query =>\n query.mode &&\n hasTransit(query.mode) &&\n query.mode.indexOf(\"BICYCLE\") !== -1,\n options: [\n {\n text: \"5 minutes\",\n value: 5\n },\n {\n text: \"10 minutes\",\n value: 10\n },\n {\n text: \"15 minutes\",\n value: 15\n },\n {\n text: \"20 minutes\",\n value: 20\n },\n {\n text: \"30 minutes\",\n value: 30\n },\n {\n text: \"45 minutes\",\n value: 45\n },\n {\n text: \"1 hour\",\n value: 60\n }\n ]\n },\n\n {\n /* bikeSpeed -- the user's bikeSpeed speed in m/s */\n name: \"bikeSpeed\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: 3.58,\n selector: \"DROPDOWN\",\n label: \"Bicycle Speed\",\n applicable: query => query.mode && query.mode.indexOf(\"BICYCLE\") !== -1,\n options: [\n {\n text: \"6 MPH\",\n value: 2.68\n },\n {\n text: \"8 MPH\",\n value: 3.58\n },\n {\n text: \"10 MPH\",\n value: 4.47\n },\n {\n text: \"12 MPH\",\n value: 5.36\n }\n ]\n },\n\n {\n /* maxEScooterDistance - the maximum distance in meters the user will ride\n * an E-scooter. Not actually an OTP parameter (maxWalkDistance doubles for\n * any non-transit mode except for car) but we store it separately\n * internally in order to allow different default values, options, etc.\n * Translated to 'maxWalkDistance' via the rewrite function.\n */\n name: \"maxEScooterDistance\",\n routingTypes: [\"ITINERARY\"],\n applicable: query =>\n query.mode && hasTransit(query.mode) && hasMicromobility(query.mode),\n default: 4828, // 3 mi.\n selector: \"DROPDOWN\",\n label: \"Maximum E-scooter Distance\",\n options: [\n {\n text: \"1/4 mile\",\n value: 402.3\n },\n {\n text: \"1/2 mile\",\n value: 804.7\n },\n {\n text: \"3/4 mile\",\n value: 1207\n },\n {\n text: \"1 mile\",\n value: 1609\n },\n {\n text: \"2 miles\",\n value: 3219\n },\n {\n text: \"3 miles\",\n value: 4828\n },\n {\n text: \"5 miles\",\n value: 8047\n },\n {\n text: \"10 miles\",\n value: 16093\n },\n {\n text: \"20 miles\",\n value: 32187\n },\n {\n text: \"30 miles\",\n value: 48280\n }\n ],\n itineraryRewrite: value => ({\n maxWalkDistance: value,\n // ensures that the value is repopulated when loaded from URL params\n maxEScooterDistance: value\n })\n },\n\n {\n /* bikeSpeed -- the user's bikeSpeed speed in m/s */\n name: \"watts\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: 250,\n selector: \"DROPDOWN\",\n label: \"E-scooter Power\",\n // this configuration should only be allowed for personal E-scooters as these\n // settings will be defined by the vehicle type of an E-scooter being rented\n applicable: query =>\n query.mode &&\n query.mode.indexOf(\"MICROMOBILITY\") !== -1 &&\n query.mode.indexOf(\"MICROMOBILITY_RENT\") === -1 &&\n query.mode.indexOf(\"SCOOTER\") === -1,\n options: [\n {\n text: \"Kid's hoverboard (6mph)\",\n value: 125\n },\n {\n text: \"Entry-level scooter (11mph)\",\n value: 250\n },\n {\n text: \"Robust E-scooter (18mph)\",\n value: 500\n },\n {\n text: \"Powerful E-scooter (24mph)\",\n value: 1500\n }\n ],\n // rewrite a few other values to add some baseline assumptions about the\n // vehicle\n itineraryRewrite: value => {\n const watts = value;\n // the maximum cruising and downhill speed. Units in m/s\n let maximumMicromobilitySpeed;\n let weight;\n // see https://en.wikipedia.org/wiki/Human_body_weight#Average_weight_around_the_world\n // estimate is for an average North American human with clothes and stuff\n // units are in kg\n const TYPICAL_RIDER_WEIGHT = 90;\n switch (watts) {\n case 125:\n // exemplar: Swagtron Turbo 5 hoverboard (https://swagtron.com/product/recertified-swagtron-turbo-five-hoverboard-classic/)\n maximumMicromobilitySpeed = 2.8; // ~= 6mph\n weight = TYPICAL_RIDER_WEIGHT + 9;\n break;\n case 250:\n // exemplar: Xiaomi M365 (https://www.gearbest.com/skateboard/pp_596618.html)\n maximumMicromobilitySpeed = 5; // ~= 11.5mph\n weight = TYPICAL_RIDER_WEIGHT + 12.5;\n break;\n case 500:\n // exemplar: Razor EcoSmart Metro (https://www.amazon.com/Razor-EcoSmart-Metro-Electric-Scooter/dp/B002ZDAEIS?SubscriptionId=AKIAJMXJ2YFJTEDLQMUQ&tag=digitren08-20&linkCode=xm2&camp=2025&creative=165953&creativeASIN=B002ZDAEIS&ascsubtag=15599460143449ocb)\n maximumMicromobilitySpeed = 8; // ~= 18mph\n weight = TYPICAL_RIDER_WEIGHT + 30;\n break;\n case 1000:\n // exemplar: Boosted Rev (https://boostedboards.com/vehicles/scooters/boosted-rev)\n maximumMicromobilitySpeed = 11; // ~= 24mph\n weight = TYPICAL_RIDER_WEIGHT + 21;\n break;\n default:\n break;\n }\n return { maximumMicromobilitySpeed, watts, weight };\n }\n },\n\n {\n /* ignoreRealtimeUpdates -- if true, do not use realtime updates in routing */\n name: \"ignoreRealtimeUpdates\",\n routingTypes: [\"ITINERARY\"],\n default: false\n },\n\n {\n /* companies -- tnc companies to query */\n name: \"companies\",\n routingTypes: [\"ITINERARY\"]\n },\n\n {\n /* wheelchair -- whether the user requires a wheelchair-accessible trip */\n name: \"wheelchair\",\n routingTypes: [\"ITINERARY\", \"PROFILE\"],\n default: false,\n selector: \"CHECKBOX\",\n label: \"Prefer Wheelchair Accessible Routes\",\n icon: <Wheelchair />,\n applicable: (query, config) => {\n if (!query.mode || !config.modes) return false;\n const configModes = (config.modes.accessModes || []).concat(\n config.modes.transitModes || []\n );\n return query.mode.split(\",\").some(mode => {\n const configMode = configModes.find(m => m.mode === mode);\n if (!configMode || !configMode.showWheelchairSetting) return false;\n if (\n configMode.company &&\n (!query.companies ||\n !query.companies.split(\",\").includes(configMode.company))\n )\n return false;\n return true;\n });\n }\n },\n\n {\n name: \"bannedRoutes\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"numItineraries\",\n routingTypes: [\"ITINERARY\"],\n default: 3\n },\n {\n name: \"intermediatePlaces\",\n default: [],\n routingTypes: [\"ITINERARY\"],\n itineraryRewrite: places =>\n Array.isArray(places) && places.length > 0\n ? {\n intermediatePlaces: places.map(place => formatPlace(place))\n }\n : undefined\n },\n {\n // Time penalty in seconds the requester is willing to accept in order to\n // complete journey on preferred route. I.e., number of seconds that we are\n // willing to wait for the preferred route.\n name: \"otherThanPreferredRoutesPenalty\",\n default: 15 * 60, // 15 minutes\n routingTypes: [\"ITINERARY\"]\n },\n // Below are less commonly used query params included so that in case they are\n // passed in a query parameter they do not get filtered out from the ultimate\n // API request.\n {\n name: \"preferredRoutes\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"maxPreTransitTime\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"waitReluctance\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"driveDistanceReluctance\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"driveTimeReluctance\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"waitAtBeginningFactor\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bikeSwitchTime\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bikeSwitchCost\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"minTransferTime\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"preferredAgencies\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"unpreferredRoutes\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"unpreferredAgencies\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"walkBoardCost\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bikeBoardCost\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"whiteListedRoutes\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bannedAgencies\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"whiteListedAgencies\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bannedTrips\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bannedStops\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"bannedStopsHard\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"transferPenalty\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"nonpreferredTransferPenalty\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"maxTransfers\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"batch\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"startTransitStopId\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"startTransitTripId\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"clampInitialWait\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"reverseOptimizeOnTheFly\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"boardSlack\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"alightSlack\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"locale\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"disableRemainingWeightHeuristic\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"flexFlagStopBufferSize\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"flexUseReservationServices\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"flexUseEligibilityServices\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"flexIgnoreDrtAdvanceBookMin\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"maxHours\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"useRequestedDateTimeInMaxHours\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"disableAlertFiltering\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"geoidElevation\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"invalidDateStrategy\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"minTransitDistance\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"searchTimeout\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"pathComparator\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"onlyTransitTrips\",\n routingTypes: [\"ITINERARY\"]\n },\n {\n name: \"minimumMicromobilitySpeed\",\n routingTypes: [\"ITINERARY\"]\n }\n];\n// Iterate over stored settings and update query param defaults.\n// FIXME: this does not get updated if the user defaults are cleared\nqueryParams.forEach(param => {\n if (param.name in storedSettings) {\n param.default = storedSettings[param.name];\n param.userDefaultOverride = true;\n }\n});\n\nexport default queryParams;\n\n/**\n * You can customize the queryParams labels and options, and labels and values for each option.\n * @param customizations The optional customizations to apply: an object whose fields\n * correspond to the items in queryParams with the corresponding name,\n * the value for those fields being an object which fields (label, options...)\n * will override the originals.\n * Example:\n * {\n * // Matches the name param\n * maxWalkDistance: {\n * // Any fields that should be overridden go here\n * options: [\n * // ...new options\n * ],\n * default: 500,\n * label: \"max walk dist\"\n * }\n * }\n * @returns A copy of the default queryParams that has the given customizations applied.\n * If no customizations parameter is provided, returns the queryParams object itself.\n */\nexport function getCustomQueryParams(customizations) {\n if (!customizations) return queryParams;\n\n const clonedParams = cloneDeep(queryParams);\n Object.keys(customizations).forEach(k => {\n // Merge fields into the cloned object\n const paramIndex = clonedParams.findIndex(param => param.name === k);\n if (paramIndex !== -1) {\n clonedParams[paramIndex] = {\n ...clonedParams[paramIndex],\n ...customizations[k]\n };\n }\n });\n return clonedParams;\n}\n"],"file":"query-params.js"}
|
package/esm/query.js
DELETED
|
@@ -1,538 +0,0 @@
|
|
|
1
|
-
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
2
|
-
import _typeof from "@babel/runtime/helpers/typeof";
|
|
3
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
-
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
5
|
-
|
|
6
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
7
|
-
|
|
8
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
9
|
-
|
|
10
|
-
import { format, isMatch, parse } from "date-fns";
|
|
11
|
-
import getGeocoder from "@opentripplanner/geocoder/lib";
|
|
12
|
-
import qs from "qs";
|
|
13
|
-
import { getTransitModes, hasCar, isAccessMode } from "./itinerary";
|
|
14
|
-
import { coordsToString, stringToCoords } from "./map";
|
|
15
|
-
import queryParams from "./query-params";
|
|
16
|
-
import { getCurrentTime, getCurrentDate, OTP_API_DATE_FORMAT, OTP_API_TIME_FORMAT } from "./time";
|
|
17
|
-
/* The list of default parameters considered in the settings panel */
|
|
18
|
-
|
|
19
|
-
export var defaultParams = ["wheelchair", "maxWalkDistance", "walkReluctance", "maxWalkTime", "maxBikeDistance", "maxBikeTime", "bikeSpeed", "optimize", "optimizeBike", "maxEScooterDistance", "watts"];
|
|
20
|
-
/**
|
|
21
|
-
* List of time formats to parse when reading query params.
|
|
22
|
-
*/
|
|
23
|
-
|
|
24
|
-
var TIME_FORMATS = ["HH:mm:ss", "HH:mm", "H:mm", "h:mm:ss a", "h:mm:ssa", "h:mm a", "h:mma", "h:mm", "HHmm", "hmm", "ha"];
|
|
25
|
-
/* A function to retrieve a property value from an entry in the query-params
|
|
26
|
-
* table, checking for either a static value or a function */
|
|
27
|
-
|
|
28
|
-
export function getQueryParamProperty(paramInfo, property, query) {
|
|
29
|
-
return typeof paramInfo[property] === "function" ? paramInfo[property](query) : paramInfo[property];
|
|
30
|
-
}
|
|
31
|
-
export function ensureSingleAccessMode(queryModes) {
|
|
32
|
-
// Count the number of access modes
|
|
33
|
-
var accessCount = queryModes.filter(function (m) {
|
|
34
|
-
return isAccessMode(m);
|
|
35
|
-
}).length; // If multiple access modes are specified, keep only the first one
|
|
36
|
-
|
|
37
|
-
if (accessCount > 1) {
|
|
38
|
-
var firstAccess = queryModes.find(function (m) {
|
|
39
|
-
return isAccessMode(m);
|
|
40
|
-
});
|
|
41
|
-
queryModes = queryModes.filter(function (m) {
|
|
42
|
-
return !isAccessMode(m) || m === firstAccess;
|
|
43
|
-
}); // If no access modes are specified, add 'WALK' as the default
|
|
44
|
-
} else if (accessCount === 0) {
|
|
45
|
-
queryModes.push("WALK");
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return queryModes;
|
|
49
|
-
}
|
|
50
|
-
export function getUrlParams() {
|
|
51
|
-
return qs.parse(window.location.href.split("?")[1]);
|
|
52
|
-
}
|
|
53
|
-
export function getOtpUrlParams() {
|
|
54
|
-
return Object.keys(getUrlParams()).filter(function (key) {
|
|
55
|
-
return !key.startsWith("ui_");
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
export function getTripOptionsFromQuery(query) {
|
|
59
|
-
var keepPlace = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
60
|
-
|
|
61
|
-
var options = _objectSpread({}, query); // Delete time/date options and from/to
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
delete options.time;
|
|
65
|
-
delete options.departArrive;
|
|
66
|
-
delete options.date;
|
|
67
|
-
|
|
68
|
-
if (!keepPlace) {
|
|
69
|
-
delete options.from;
|
|
70
|
-
delete options.to;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
return options;
|
|
74
|
-
}
|
|
75
|
-
/**
|
|
76
|
-
* Gets the query param's default value that is either a constant or by
|
|
77
|
-
* executing the default value function.
|
|
78
|
-
*/
|
|
79
|
-
|
|
80
|
-
function getDefaultQueryParamValue(param) {
|
|
81
|
-
return typeof param["default"] === "function" ? param["default"]() : param["default"];
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Get the default query to OTP based on the given config.
|
|
85
|
-
*/
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
export function getDefaultQuery() {
|
|
89
|
-
var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
|
|
90
|
-
var defaultQuery = {
|
|
91
|
-
routingType: "ITINERARY"
|
|
92
|
-
};
|
|
93
|
-
queryParams.filter(function (qp) {
|
|
94
|
-
return "default" in qp;
|
|
95
|
-
}).forEach(function (qp) {
|
|
96
|
-
defaultQuery[qp.name] = getDefaultQueryParamValue(qp);
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
if (config) {
|
|
100
|
-
if (config.routingTypes && config.routingTypes.length > 0) {
|
|
101
|
-
defaultQuery.routingType = config.routingTypes[0].key;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (config.defaultQueryParams) {
|
|
105
|
-
Object.keys(config.defaultQueryParams).forEach(function (key) {
|
|
106
|
-
defaultQuery[key] = config.defaultQueryParams[key];
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
return defaultQuery;
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Determine if the specified query param applies to the given query (based on
|
|
115
|
-
* routing type and the param's own applicable function).
|
|
116
|
-
* @param paramInfo an entry from query-params.js
|
|
117
|
-
* @param query the query against which to check if the param applies
|
|
118
|
-
* @param config OTP config
|
|
119
|
-
* @return {Boolean}
|
|
120
|
-
*/
|
|
121
|
-
|
|
122
|
-
function isParamApplicable(paramInfo, query, config) {
|
|
123
|
-
var applicable = paramInfo.applicable,
|
|
124
|
-
routingTypes = paramInfo.routingTypes;
|
|
125
|
-
if (!routingTypes.includes(query.routingType)) return false;
|
|
126
|
-
|
|
127
|
-
if (typeof applicable === "function" && !applicable(query, config)) {
|
|
128
|
-
return false;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
return true;
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Helper method which replaces OTP flex modes with single FLEX mode that's
|
|
135
|
-
* more useful and easier to work with.
|
|
136
|
-
*/
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
export function reduceOtpFlexModes(modes) {
|
|
140
|
-
var enabled = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
141
|
-
if (!enabled) return modes;
|
|
142
|
-
return modes.reduce(function (prev, cur) {
|
|
143
|
-
var newModes = prev; // Add the current mode if it is not a flex mode
|
|
144
|
-
|
|
145
|
-
if (!cur.includes("FLEX")) {
|
|
146
|
-
newModes.push(cur); // If it is a flex mode, do not add it but rather add the custom flex mode
|
|
147
|
-
// if not already present
|
|
148
|
-
} else if (!newModes.includes("FLEX")) {
|
|
149
|
-
newModes.push("FLEX");
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
return newModes;
|
|
153
|
-
}, []);
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Helper method to process a mode string, replacing all instances of FLEX
|
|
157
|
-
* with the full set of FLEX modes used by otp-2
|
|
158
|
-
* @param {*} mode a mode String, not an array
|
|
159
|
-
* @returns a mode String, not an array (with flex modes expanded)
|
|
160
|
-
*/
|
|
161
|
-
|
|
162
|
-
export function expandOtpFlexMode(mode) {
|
|
163
|
-
var modes = reduceOtpFlexModes(mode.split(","));
|
|
164
|
-
return modes.map(function (m) {
|
|
165
|
-
// If both the expanded and shrunk modes are included, remove the expanded one
|
|
166
|
-
if (m === "FLEX_EGRESS" || m === "FLEX_ACCESS" || m === "FLEX_DIRECT") {
|
|
167
|
-
if (mode.includes("FLEX")) return "";
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
if (m === "FLEX") {
|
|
171
|
-
return "FLEX_EGRESS,FLEX_ACCESS,FLEX_DIRECT";
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
return m;
|
|
175
|
-
}).join(",");
|
|
176
|
-
}
|
|
177
|
-
/**
|
|
178
|
-
* Determines whether the specified query differs from the default query, i.e.,
|
|
179
|
-
* whether the user has modified any trip options (including mode) from their
|
|
180
|
-
* default values.
|
|
181
|
-
*/
|
|
182
|
-
|
|
183
|
-
export function isNotDefaultQuery(query, config) {
|
|
184
|
-
var _config$modes;
|
|
185
|
-
|
|
186
|
-
var activeModes = reduceOtpFlexModes(query.mode.split(",").sort(), (_config$modes = config.modes) === null || _config$modes === void 0 ? void 0 : _config$modes.mergeFlex);
|
|
187
|
-
|
|
188
|
-
if (activeModes.length !== 2 || activeModes[0] !== "TRANSIT" || activeModes[1] !== "WALK") {
|
|
189
|
-
// Default mode is TRANSIT,WALK. If general TRANSIT is not used, check
|
|
190
|
-
// against available transit modes in config.
|
|
191
|
-
var defaultModes = getTransitModes(config).concat(["WALK"]).sort();
|
|
192
|
-
var modesEqual = activeModes.length === defaultModes.length && activeModes.every(function (value, index) {
|
|
193
|
-
return value === defaultModes[index];
|
|
194
|
-
});
|
|
195
|
-
if (!modesEqual) return true;
|
|
196
|
-
} // If modes are equal, check the remaining params.
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
var defaultQuery = getDefaultQuery(config);
|
|
200
|
-
|
|
201
|
-
var _loop = function _loop(i) {
|
|
202
|
-
var param = defaultParams[i];
|
|
203
|
-
var paramInfo = queryParams.find(function (qp) {
|
|
204
|
-
return qp.name === param;
|
|
205
|
-
}); // If the parameter applies to the query and does not match the default
|
|
206
|
-
// value, the query is not default.
|
|
207
|
-
|
|
208
|
-
if (isParamApplicable(paramInfo, query, config) && query[param] !== defaultQuery[param]) {
|
|
209
|
-
return {
|
|
210
|
-
v: true
|
|
211
|
-
};
|
|
212
|
-
}
|
|
213
|
-
};
|
|
214
|
-
|
|
215
|
-
for (var i = 0; i < defaultParams.length; i++) {
|
|
216
|
-
var _ret = _loop(i);
|
|
217
|
-
|
|
218
|
-
if (_typeof(_ret) === "object") return _ret.v;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
return false;
|
|
222
|
-
}
|
|
223
|
-
/**
|
|
224
|
-
* Geocode utility for returning the first result for the provided place name text.
|
|
225
|
-
* @param {string} text - text to search
|
|
226
|
-
* @param {Object} geocoderConfig
|
|
227
|
-
* @return {Location}
|
|
228
|
-
*/
|
|
229
|
-
|
|
230
|
-
function getFirstGeocodeResult(_x, _x2) {
|
|
231
|
-
return _getFirstGeocodeResult.apply(this, arguments);
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* OTP allows passing a location in the form '123 Main St::lat,lon', so we check
|
|
235
|
-
* for the double colon and parse the coordinates accordingly.
|
|
236
|
-
* @param {string} value - query param for place described above
|
|
237
|
-
* @return {Location} - location or null if the value is falsey or the parsed
|
|
238
|
-
* coordinates do not result in both a lat and lon
|
|
239
|
-
*/
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
function _getFirstGeocodeResult() {
|
|
243
|
-
_getFirstGeocodeResult = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(text, geocoderConfig) {
|
|
244
|
-
var geocoder;
|
|
245
|
-
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
246
|
-
while (1) {
|
|
247
|
-
switch (_context.prev = _context.next) {
|
|
248
|
-
case 0:
|
|
249
|
-
geocoder = getGeocoder(geocoderConfig); // Attempt to geocode search text and return first result if found.
|
|
250
|
-
// TODO: Import geocoder from @opentripplanner
|
|
251
|
-
|
|
252
|
-
return _context.abrupt("return", geocoder.search({
|
|
253
|
-
text: text
|
|
254
|
-
}).then(function (result) {
|
|
255
|
-
var firstResult = result.features && result.features[0];
|
|
256
|
-
|
|
257
|
-
if (firstResult) {
|
|
258
|
-
return geocoder.getLocationFromGeocodedFeature(firstResult);
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
return null;
|
|
262
|
-
}));
|
|
263
|
-
|
|
264
|
-
case 2:
|
|
265
|
-
case "end":
|
|
266
|
-
return _context.stop();
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
}, _callee);
|
|
270
|
-
}));
|
|
271
|
-
return _getFirstGeocodeResult.apply(this, arguments);
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
export function parseLocationString(value) {
|
|
275
|
-
if (!value) return null;
|
|
276
|
-
var parts = value.split("::");
|
|
277
|
-
var coordinates = parts[1] ? stringToCoords(parts[1]) : stringToCoords(parts[0]);
|
|
278
|
-
var name = parts[1] ? parts[0] : coordsToString(coordinates);
|
|
279
|
-
return coordinates.length === 2 ? {
|
|
280
|
-
name: name || null,
|
|
281
|
-
lat: coordinates[0] || null,
|
|
282
|
-
lon: coordinates[1] || null
|
|
283
|
-
} : null;
|
|
284
|
-
}
|
|
285
|
-
/**
|
|
286
|
-
* Convert a string query param for a from or to place into a location. If
|
|
287
|
-
* coordinates not provided and geocoder config is present, use the first
|
|
288
|
-
* geocoded result.
|
|
289
|
-
* @param {string} value
|
|
290
|
-
* @param {Object} [geocoderConfig=null]
|
|
291
|
-
* @return {Location}
|
|
292
|
-
*/
|
|
293
|
-
|
|
294
|
-
function queryParamToLocation(_x3, _x4) {
|
|
295
|
-
return _queryParamToLocation.apply(this, arguments);
|
|
296
|
-
}
|
|
297
|
-
/**
|
|
298
|
-
* Create a otp query based on a the url params.
|
|
299
|
-
*
|
|
300
|
-
* @param {Object} params An object representing the parsed querystring of url
|
|
301
|
-
* params.
|
|
302
|
-
*/
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
function _queryParamToLocation() {
|
|
306
|
-
_queryParamToLocation = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(value, geocoderConfig) {
|
|
307
|
-
var location;
|
|
308
|
-
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
309
|
-
while (1) {
|
|
310
|
-
switch (_context2.prev = _context2.next) {
|
|
311
|
-
case 0:
|
|
312
|
-
location = parseLocationString(value);
|
|
313
|
-
|
|
314
|
-
if (!(!location && value && geocoderConfig)) {
|
|
315
|
-
_context2.next = 5;
|
|
316
|
-
break;
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
_context2.next = 4;
|
|
320
|
-
return getFirstGeocodeResult(value, geocoderConfig);
|
|
321
|
-
|
|
322
|
-
case 4:
|
|
323
|
-
location = _context2.sent;
|
|
324
|
-
|
|
325
|
-
case 5:
|
|
326
|
-
return _context2.abrupt("return", location);
|
|
327
|
-
|
|
328
|
-
case 6:
|
|
329
|
-
case "end":
|
|
330
|
-
return _context2.stop();
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
}, _callee2);
|
|
334
|
-
}));
|
|
335
|
-
return _queryParamToLocation.apply(this, arguments);
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
export function planParamsToQuery(params) {
|
|
339
|
-
var query = {};
|
|
340
|
-
Object.keys(params).forEach(function (key) {
|
|
341
|
-
switch (key) {
|
|
342
|
-
case "fromPlace":
|
|
343
|
-
query.from = parseLocationString(params.fromPlace);
|
|
344
|
-
break;
|
|
345
|
-
|
|
346
|
-
case "toPlace":
|
|
347
|
-
query.to = parseLocationString(params.toPlace);
|
|
348
|
-
break;
|
|
349
|
-
|
|
350
|
-
case "arriveBy":
|
|
351
|
-
query.departArrive = params.arriveBy === "true" ? "ARRIVE" : params.arriveBy === "false" ? "DEPART" : "NOW";
|
|
352
|
-
break;
|
|
353
|
-
|
|
354
|
-
case "date":
|
|
355
|
-
query.date = params.date || getCurrentDate();
|
|
356
|
-
break;
|
|
357
|
-
|
|
358
|
-
case "time":
|
|
359
|
-
{
|
|
360
|
-
// Match one of the supported time formats
|
|
361
|
-
var matchedTimeFormat = TIME_FORMATS.find(function (timeFormat) {
|
|
362
|
-
return isMatch(params.time, timeFormat);
|
|
363
|
-
});
|
|
364
|
-
query.time = matchedTimeFormat ? format(parse(params.time, matchedTimeFormat, new Date()), OTP_API_TIME_FORMAT) : getCurrentTime();
|
|
365
|
-
}
|
|
366
|
-
break;
|
|
367
|
-
|
|
368
|
-
case "intermediatePlaces":
|
|
369
|
-
// If query has intermediate places, ensure that they are parsed
|
|
370
|
-
// as locations.
|
|
371
|
-
query.intermediatePlaces = params.intermediatePlaces ? params.intermediatePlaces.map(parseLocationString) : [];
|
|
372
|
-
break;
|
|
373
|
-
|
|
374
|
-
default:
|
|
375
|
-
{
|
|
376
|
-
var maybeNumber = Number(params[key]); // If the param value is an empty string literal and is not a number,
|
|
377
|
-
// use string value. Else, use parsed number value.
|
|
378
|
-
// See https://github.com/opentripplanner/otp-ui/issues/50
|
|
379
|
-
|
|
380
|
-
query[key] = params[key] === "" || Number.isNaN(maybeNumber) ? params[key] : maybeNumber;
|
|
381
|
-
break;
|
|
382
|
-
}
|
|
383
|
-
}
|
|
384
|
-
});
|
|
385
|
-
return query;
|
|
386
|
-
}
|
|
387
|
-
/**
|
|
388
|
-
* Async method to create a otp query based on a the url params. This provides
|
|
389
|
-
* the same functionality as planParamsToQuery, except that it will also attempt
|
|
390
|
-
* to geocode the input from and to strings if no lat/lng values were provided.
|
|
391
|
-
*
|
|
392
|
-
* @param {Object} params An object representing the parsed querystring of url
|
|
393
|
-
* params.
|
|
394
|
-
* @param config the config in the otp-rr store.
|
|
395
|
-
*/
|
|
396
|
-
|
|
397
|
-
export function planParamsToQueryAsync(_x5) {
|
|
398
|
-
return _planParamsToQueryAsync.apply(this, arguments);
|
|
399
|
-
}
|
|
400
|
-
/**
|
|
401
|
-
* Create an object that can be used as a querystring in making an OTP
|
|
402
|
-
* PlannerResource request.
|
|
403
|
-
*
|
|
404
|
-
* See http://otp-docs.ibi-transit.com/api/resource_PlannerResource.html
|
|
405
|
-
*
|
|
406
|
-
* @param {Object} config The OTP application config. See types#configType
|
|
407
|
-
* @param {Object} currentQuery The current query parameters as saved in the
|
|
408
|
-
* application state. This method does some extra logic on top of this data
|
|
409
|
-
* in order to create a request suitable for OTP. See __tests__/query.js#L14 for more.
|
|
410
|
-
* @param {boolean} ignoreRealtimeUpdates If true, will create a request that
|
|
411
|
-
* does not use realtime data.
|
|
412
|
-
*/
|
|
413
|
-
|
|
414
|
-
function _planParamsToQueryAsync() {
|
|
415
|
-
_planParamsToQueryAsync = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(params) {
|
|
416
|
-
var config,
|
|
417
|
-
query,
|
|
418
|
-
_args3 = arguments;
|
|
419
|
-
return _regeneratorRuntime.wrap(function _callee3$(_context3) {
|
|
420
|
-
while (1) {
|
|
421
|
-
switch (_context3.prev = _context3.next) {
|
|
422
|
-
case 0:
|
|
423
|
-
config = _args3.length > 1 && _args3[1] !== undefined ? _args3[1] : {};
|
|
424
|
-
// Construct query from plan params.
|
|
425
|
-
query = planParamsToQuery(params); // Attempt to geocode from and to params if the string parsing does not return
|
|
426
|
-
// valid locations.
|
|
427
|
-
|
|
428
|
-
if (query.from) {
|
|
429
|
-
_context3.next = 6;
|
|
430
|
-
break;
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
_context3.next = 5;
|
|
434
|
-
return queryParamToLocation(params.fromPlace, config.geocoder);
|
|
435
|
-
|
|
436
|
-
case 5:
|
|
437
|
-
query.from = _context3.sent;
|
|
438
|
-
|
|
439
|
-
case 6:
|
|
440
|
-
if (query.to) {
|
|
441
|
-
_context3.next = 10;
|
|
442
|
-
break;
|
|
443
|
-
}
|
|
444
|
-
|
|
445
|
-
_context3.next = 9;
|
|
446
|
-
return queryParamToLocation(params.toPlace, config.geocoder);
|
|
447
|
-
|
|
448
|
-
case 9:
|
|
449
|
-
query.to = _context3.sent;
|
|
450
|
-
|
|
451
|
-
case 10:
|
|
452
|
-
return _context3.abrupt("return", query);
|
|
453
|
-
|
|
454
|
-
case 11:
|
|
455
|
-
case "end":
|
|
456
|
-
return _context3.stop();
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
}, _callee3);
|
|
460
|
-
}));
|
|
461
|
-
return _planParamsToQueryAsync.apply(this, arguments);
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
export function getRoutingParams(config, currentQuery, ignoreRealtimeUpdates) {
|
|
465
|
-
var _config$modes2;
|
|
466
|
-
|
|
467
|
-
var routingType = currentQuery.routingType;
|
|
468
|
-
var isItinerary = routingType === "ITINERARY";
|
|
469
|
-
var params = {}; // Start with the universe of OTP parameters defined in query-params.js:
|
|
470
|
-
|
|
471
|
-
queryParams.filter(function (qp) {
|
|
472
|
-
// A given parameter is included in the request if all of the following:
|
|
473
|
-
// 1. Must apply to the active routing type (ITINERARY or PROFILE)
|
|
474
|
-
// 2. Must be included in the current user-defined query
|
|
475
|
-
// 3. Must pass the parameter's applicability test, if one is specified
|
|
476
|
-
return qp.routingTypes.indexOf(routingType) !== -1 && qp.name in currentQuery && (typeof qp.applicable !== "function" || qp.applicable(currentQuery, config));
|
|
477
|
-
}).forEach(function (qp) {
|
|
478
|
-
// Translate the applicable parameters according to their rewrite
|
|
479
|
-
// functions (if provided)
|
|
480
|
-
var rewriteFunction = isItinerary ? qp.itineraryRewrite : qp.profileRewrite;
|
|
481
|
-
params = Object.assign(params, rewriteFunction ? rewriteFunction(currentQuery[qp.name]) : _defineProperty({}, qp.name, currentQuery[qp.name]));
|
|
482
|
-
}); // Additional processing specific to ITINERARY mode
|
|
483
|
-
|
|
484
|
-
if (isItinerary) {
|
|
485
|
-
// override ignoreRealtimeUpdates if provided
|
|
486
|
-
if (typeof ignoreRealtimeUpdates === "boolean") {
|
|
487
|
-
params.ignoreRealtimeUpdates = ignoreRealtimeUpdates;
|
|
488
|
-
} // check date/time validity; ignore both if either is invalid
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
var dateValid = isMatch(params.date, OTP_API_DATE_FORMAT);
|
|
492
|
-
var timeValid = isMatch(params.time, OTP_API_TIME_FORMAT);
|
|
493
|
-
|
|
494
|
-
if (!dateValid || !timeValid) {
|
|
495
|
-
delete params.time;
|
|
496
|
-
delete params.date;
|
|
497
|
-
} // temp: set additional parameters for CAR_HAIL or CAR_RENT trips
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
if (params.mode && (params.mode.includes("CAR_HAIL") || params.mode.includes("CAR_RENT"))) {
|
|
501
|
-
params.minTransitDistance = "50%"; // increase search timeout because these queries can take a while
|
|
502
|
-
|
|
503
|
-
params.searchTimeout = 10000;
|
|
504
|
-
} // set onlyTransitTrips for car rental searches
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
if (params.mode && params.mode.includes("CAR_RENT")) {
|
|
508
|
-
params.onlyTransitTrips = true;
|
|
509
|
-
} // Additional processing specific to PROFILE mode
|
|
510
|
-
|
|
511
|
-
} else {
|
|
512
|
-
// check start and end time validity; ignore both if either is invalid
|
|
513
|
-
var startTimeValid = isMatch(params.startTime, OTP_API_TIME_FORMAT);
|
|
514
|
-
var endTimeValid = isMatch(params.endTime, OTP_API_TIME_FORMAT);
|
|
515
|
-
|
|
516
|
-
if (!startTimeValid || !endTimeValid) {
|
|
517
|
-
delete params.startTimeValid;
|
|
518
|
-
delete params.endTimeValid;
|
|
519
|
-
}
|
|
520
|
-
} // TODO: check that valid from/to locations are provided
|
|
521
|
-
// hack to add walking to driving/TNC trips
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
if (hasCar(params.mode)) {
|
|
525
|
-
params.mode += ",WALK";
|
|
526
|
-
} // Replace FLEX placeholder with OTP flex modes
|
|
527
|
-
// Explicit false check allows avoiding a breaking change -- undefined is true
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
if (params.mode && ((_config$modes2 = config.modes) === null || _config$modes2 === void 0 ? void 0 : _config$modes2.mergeFlex) !== false) {
|
|
531
|
-
// Ensure query is in reduced format to avoid replacing twice
|
|
532
|
-
var reducedMode = reduceOtpFlexModes(params.mode.split(",")).join(",");
|
|
533
|
-
params.mode = expandOtpFlexMode(reducedMode);
|
|
534
|
-
}
|
|
535
|
-
|
|
536
|
-
return params;
|
|
537
|
-
}
|
|
538
|
-
//# sourceMappingURL=query.js.map
|