Skip to content

Commit

Permalink
allow multiple transport modes to be specified in a single transportmode
Browse files Browse the repository at this point in the history
  • Loading branch information
daniel-heppner-ibigroup committed Oct 8, 2024
1 parent 17598ad commit cd81a2f
Show file tree
Hide file tree
Showing 5 changed files with 17 additions and 4 deletions.
6 changes: 5 additions & 1 deletion example-config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -268,7 +268,11 @@ modes:
iconName: wheelchair
type: CHECKBOX # Possible options: CHECKBOX, SUBMODE, SLIDER, DROPDOWN
transitModes:
- mode: BUS
# Mode can be a string or an array of strings.
- mode: ["TROLLEYBUS", "BUS"]
# When mode is an array an overrideMode must be provided.
# This specifies the displayed mode used for icon and URL param.
overrideMode: BUS
label: Bus
# A mode color can be added, used throughout the application,
# most notably in the enhanced stop viewer bubble
Expand Down
2 changes: 1 addition & 1 deletion lib/actions/form.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ export function resetForm(full = false) {
const options = getTripOptionsFromQuery(defaultQuery)
// Default mode is currently WALK,TRANSIT. We need to update this value
// here to match the list of modes, otherwise the form will break.
options.mode = ['WALK', ...transitModes.map((m) => m.mode)].join(',')
options.mode = ['WALK', ...transitModes.flatMap((m) => m.mode)].join(',')
dispatch(settingQueryParam(options))
}
if (full) {
Expand Down
1 change: 1 addition & 0 deletions lib/components/form/util.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ export const addCustomSettingLabels =
if (modeSetting.type === 'SUBMODE') {
const modeLabel =
modeSetting.overrideMode || modeSetting.addTransportMode.mode
console.log(modeSetting, modeLabel)
return {
...modeSetting,
label: getFormattedMode(modeLabel, intl)
Expand Down
10 changes: 9 additions & 1 deletion lib/reducers/create-otp-reducer.js
Original file line number Diff line number Diff line change
Expand Up @@ -135,10 +135,18 @@ export function getInitialState(userDefinedConfig) {

const transitModeSettings = config?.modes?.transitModes.map((transitMode) => {
const { mode, overrideMode } = transitMode
if (Array.isArray(mode) && !overrideMode) {
console.warn(
`Mode ${mode} is an array, but no overrideMode is specified.`
)
}
const displayedMode = overrideMode || mode
const addTransportModes = Array.isArray(mode)
? mode.map((m) => ({ mode: m }))
: { mode }
return {
// This is the mode that gets added to the actual query to OTP
addTransportMode: { mode },
addTransportMode: addTransportModes,
applicableMode: 'TRANSIT',
default: true,
iconName: displayedMode.toLowerCase(),
Expand Down
2 changes: 1 addition & 1 deletion lib/util/config-types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -312,7 +312,7 @@ export interface GeocoderConfig extends GeocoderConfigOtpUI {
export interface TransitModeConfig {
color?: string
label?: string
mode: string
mode: string | string[]
showWheelchairSetting?: boolean
}

Expand Down

0 comments on commit cd81a2f

Please sign in to comment.