Skip to content

Commit

Permalink
fix: pushback without command (#5684)
Browse files Browse the repository at this point in the history
* Fixed import from simVars

* Enable sourcemaps for development builds.

* fix: unintended tug pushback after EFB tab switch

When the tug was called and  the pilot selected some tab other than the ground one in the EFB the tug would start with an unintentional push back.

* Applied suggestions from PR

Co-authored-by: Roelf de Kock <[email protected]>
  • Loading branch information
kiemdoder and Roelf de Kock authored Aug 25, 2021
1 parent 2b0aad4 commit eb7ab6f
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 18 deletions.
34 changes: 19 additions & 15 deletions src/instruments/src/EFB/Ground/Ground.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { BUTTON_STATE_REDUCER } from '../Store';
import {
addActiveButton, removeActiveButton, setTugRequestOnly,
setActiveButtons, addDisabledButton, removeDisabledButton,
setPushBackWaitTimerHandle,
} from '../Store/action-creator/ground-state';

type StatefulButton = {
Expand All @@ -18,11 +19,11 @@ type StatefulButton = {
}

export const Ground = ({
activeButtons, disabledButtons, tugRequestOnly,
setTugRequestOnly, addActiveButton, removeActiveButton, setActiveButtons, addDisabledButton, removeDisabledButton,
activeButtons, disabledButtons, pushBackWaitTimerHandle, setPushBackWaitTimerHandle,
tugRequestOnly, setTugRequestOnly, addActiveButton, removeActiveButton, setActiveButtons, addDisabledButton, removeDisabledButton,
}) => {
const [jetWayActive, setJetWayActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:0', 'Percent over 100', 'K:TOGGLE_JETWAY', 'bool', 1000);
const [_rampActive, setRampActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:0', 'Percent over 100', 'K:TOGGLE_RAMPTRUCK', 'bool', 1000);
const [, setRampActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:0', 'Percent over 100', 'K:TOGGLE_RAMPTRUCK', 'bool', 1000);
const [cargoActive, setCargoActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:5', 'Percent over 100', 'K:REQUEST_LUGGAGE', 'bool', 1000);
const [cateringActive, setCateringActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:3', 'Percent over 100', 'K:REQUEST_CATERING', 'bool', 1000);

Expand All @@ -31,7 +32,7 @@ export const Ground = ({
const [pushBack, setPushBack] = useSplitSimVar('PUSHBACK STATE', 'enum', 'K:TOGGLE_PUSHBACK', 'bool', 1000);
const [powerActive, setPowerActive] = useSplitSimVar('A:INTERACTIVE POINT OPEN:8', 'Percent over 100', 'K:REQUEST_POWER_SUPPLY', 'bool', 1000);

const [pushBackWait, setPushBackWait] = useSimVar('Pushback Wait', 'bool', 100);
const [, setPushBackWait] = useSimVar('Pushback Wait', 'bool', 100);
const [pushBackAttached] = useSimVar('Pushback Attached', 'bool', 1000);

const [tugDirection, setTugDirection] = useState(0);
Expand All @@ -51,16 +52,19 @@ export const Ground = ({
computeAndSetTugHeading(tugDirection);
setTugDirection(0);
}
/**
* Timer needed, as we cannot check when the variable "Pushback Wait" is being set to false after calling the tug
*/
const timer = setInterval(() => {
if (tugRequestOnly) {
setPushBackWait(1);
if (activeButtons.find((button) => button.id === 'tug-request') && tugRequestOnly) {
/* Timer needed, as we cannot check when the variable "Pushback Wait" is being set to false after calling the tug */
if (pushBackWaitTimerHandle === -1) {
const timer = setInterval(() => {
setPushBackWait(1);
}, 100);
setPushBackWaitTimerHandle(timer);
}
}, 100);
return () => clearInterval(timer);
}, [pushBackWait, tugRequestOnly, pushBack, tugDirection]);
} else if (pushBackWaitTimerHandle !== -1) {
clearInterval(pushBackWaitTimerHandle);
setPushBackWaitTimerHandle(-1);
}
}, [pushBack, tugDirection, activeButtons, pushBackWaitTimerHandle, tugRequestOnly, pushBack, tugDirection]);

const getTugHeading = (value: number): number => (tugHeading + value) % 360;

Expand Down Expand Up @@ -316,6 +320,6 @@ export const Ground = ({
};

export default connect(
({ [BUTTON_STATE_REDUCER]: { activeButtons, disabledButtons, tugRequestOnly } }) => ({ activeButtons, disabledButtons, tugRequestOnly }),
{ addActiveButton, removeActiveButton, setActiveButtons, addDisabledButton, removeDisabledButton, setTugRequestOnly },
({ [BUTTON_STATE_REDUCER]: { activeButtons, disabledButtons, tugRequestOnly, pushBackWaitTimerHandle } }) => ({ activeButtons, disabledButtons, tugRequestOnly, pushBackWaitTimerHandle }),
{ addActiveButton, removeActiveButton, setActiveButtons, addDisabledButton, removeDisabledButton, setTugRequestOnly, setPushBackWaitTimerHandle },
)(Ground);
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { ADD_ACTIVE_BUTTON, ADD_DISABLED_BUTTON, REMOVE_ACTIVE_BUTTON, REMOVE_DISABLED_BUTTON, SET_ACTIVE_BUTTONS, SET_TUG_REQUEST_ONLY } from '../actions';
import { ADD_ACTIVE_BUTTON, ADD_DISABLED_BUTTON, REMOVE_ACTIVE_BUTTON, REMOVE_DISABLED_BUTTON, SET_ACTIVE_BUTTONS, SET_TUG_REQUEST_ONLY, SET_PUSH_BACK_WAIT_TIMER_HANDLE } from '../actions';

export const addActiveButton = (button) => ({
type: ADD_ACTIVE_BUTTON,
Expand Down Expand Up @@ -29,3 +29,8 @@ export const setTugRequestOnly = (tugRequest) => ({
type: SET_TUG_REQUEST_ONLY,
tugRequest,
});

export const setPushBackWaitTimerHandle = (pushBackWaitTimerHandle) => ({
type: SET_PUSH_BACK_WAIT_TIMER_HANDLE,
pushBackWaitTimerHandle,
});
1 change: 1 addition & 0 deletions src/instruments/src/EFB/Store/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,4 @@ export const ADD_DISABLED_BUTTON = 'ADD_DISABLED_BUTTON';
export const REMOVE_DISABLED_BUTTON = 'REMOVE_DISABLED_BUTTON';

export const SET_TUG_REQUEST_ONLY = 'SET_TUG_REQUEST_ONLY';
export const SET_PUSH_BACK_WAIT_TIMER_HANDLE = 'SET_PUSH_BACK_WAIT_TIMER_HANDLE';
10 changes: 8 additions & 2 deletions src/instruments/src/EFB/Store/reducer/ground-reducer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,19 +6,21 @@ import {
SET_ACTIVE_BUTTONS,
REMOVE_DISABLED_BUTTON,
SET_TUG_REQUEST_ONLY,
SET_PUSH_BACK_WAIT_TIMER_HANDLE,
} from '../actions';

type ButtonSelectionState = {
activeButtons: any[];
disabledButtons: string[];
tugRequestOnly: boolean,

tugRequestOnly: boolean;
pushBackWaitTimerHandle: number;
};

const initialState: ButtonSelectionState = {
activeButtons: [],
disabledButtons: [],
tugRequestOnly: false,
pushBackWaitTimerHandle: -1,
};

export const buttonsReducer = typeToReducer(
Expand Down Expand Up @@ -60,6 +62,10 @@ export const buttonsReducer = typeToReducer(
...state,
tugRequestOnly: tugRequest,
}),
[SET_PUSH_BACK_WAIT_TIMER_HANDLE]: (state, { pushBackWaitTimerHandle }) => ({
...state,
pushBackWaitTimerHandle,
}),
},
initialState,
);
1 change: 1 addition & 0 deletions src/instruments/src/EFB/rollup.development.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,5 +59,6 @@ module.exports = {
output: {
file: `${__dirname}/web/bundle.js`,
format: 'iife',
sourcemap: true,
},
};

0 comments on commit eb7ab6f

Please sign in to comment.