mirror of
https://github.com/trezor/trezor-wallet
synced 2025-01-18 20:10:59 +00:00
add WALLET.SET_FIRST_LOCATION_CHANGE action
This commit is contained in:
parent
5a6ea6610e
commit
e7ae73c570
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
import { push, LOCATION_CHANGE } from 'connected-react-router';
|
import { push, LOCATION_CHANGE } from 'connected-react-router';
|
||||||
import { CONTEXT_NONE } from 'actions/constants/modal';
|
import { CONTEXT_NONE } from 'actions/constants/modal';
|
||||||
import { SET_INITIAL_URL } from 'actions/constants/wallet';
|
import { SET_INITIAL_URL, SET_FIRST_LOCATION_CHANGE } from 'actions/constants/wallet';
|
||||||
import { routes } from 'support/routes';
|
import { routes } from 'support/routes';
|
||||||
import * as deviceUtils from 'utils/device';
|
import * as deviceUtils from 'utils/device';
|
||||||
|
|
||||||
@ -133,7 +133,12 @@ export const getValidUrl = (action: RouterAction): PayloadAction<string> => (dis
|
|||||||
const { firstLocationChange } = getState().wallet;
|
const { firstLocationChange } = getState().wallet;
|
||||||
// redirect to landing page (loading screen)
|
// redirect to landing page (loading screen)
|
||||||
// and wait until application is ready
|
// and wait until application is ready
|
||||||
if (firstLocationChange) return '/';
|
if (firstLocationChange) {
|
||||||
|
dispatch({
|
||||||
|
type: SET_FIRST_LOCATION_CHANGE,
|
||||||
|
});
|
||||||
|
return '/';
|
||||||
|
}
|
||||||
|
|
||||||
console.log('action', action);
|
console.log('action', action);
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ export type WalletAction = {
|
|||||||
type: typeof WALLET.CLEAR_UNAVAILABLE_DEVICE_DATA,
|
type: typeof WALLET.CLEAR_UNAVAILABLE_DEVICE_DATA,
|
||||||
devices: Array<TrezorDevice>
|
devices: Array<TrezorDevice>
|
||||||
} | {
|
} | {
|
||||||
type: typeof WALLET.SHOW_BETA_DISCLAIMER | typeof WALLET.HIDE_BETA_DISCLAIMER,
|
type: typeof WALLET.SHOW_BETA_DISCLAIMER | typeof WALLET.HIDE_BETA_DISCLAIMER | typeof WALLET.SET_FIRST_LOCATION_CHANGE,
|
||||||
}
|
}
|
||||||
|
|
||||||
export const init = (): ThunkAction => (dispatch: Dispatch): void => {
|
export const init = (): ThunkAction => (dispatch: Dispatch): void => {
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
export const TOGGLE_DEVICE_DROPDOWN: 'wallet__toggle_dropdown' = 'wallet__toggle_dropdown';
|
export const TOGGLE_DEVICE_DROPDOWN: 'wallet__toggle_dropdown' = 'wallet__toggle_dropdown';
|
||||||
export const SET_INITIAL_URL: 'wallet__set_initial_url' = 'wallet__set_initial_url';
|
export const SET_INITIAL_URL: 'wallet__set_initial_url' = 'wallet__set_initial_url';
|
||||||
|
export const SET_FIRST_LOCATION_CHANGE: 'wallet__set_first_location_change' = 'wallet__set_first_location_change';
|
||||||
export const ONLINE_STATUS: 'wallet__online_status' = 'wallet__online_status';
|
export const ONLINE_STATUS: 'wallet__online_status' = 'wallet__online_status';
|
||||||
|
|
||||||
export const SET_SELECTED_DEVICE: 'wallet__set_selected_device' = 'wallet__set_selected_device';
|
export const SET_SELECTED_DEVICE: 'wallet__set_selected_device' = 'wallet__set_selected_device';
|
||||||
|
6
src/flowtype/npm/react-router-redux.js
vendored
6
src/flowtype/npm/react-router-redux.js
vendored
@ -19,7 +19,10 @@ declare module 'connected-react-router' {
|
|||||||
|
|
||||||
declare export type RouterAction = {
|
declare export type RouterAction = {
|
||||||
type: typeof LOCATION_CHANGE,
|
type: typeof LOCATION_CHANGE,
|
||||||
payload: Location;
|
payload: {
|
||||||
|
action: string,
|
||||||
|
location: Location,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
declare export type State = {
|
declare export type State = {
|
||||||
@ -35,6 +38,7 @@ declare module 'connected-react-router' {
|
|||||||
//declare export function routerReducer<S, A>(state?: S, action: A): S;
|
//declare export function routerReducer<S, A>(state?: S, action: A): S;
|
||||||
declare export function routerReducer(state?: State, action: any): State;
|
declare export function routerReducer(state?: State, action: any): State;
|
||||||
declare export function routerMiddleware(history: any): any;
|
declare export function routerMiddleware(history: any): any;
|
||||||
|
declare export function connectRouter(history: any): any;
|
||||||
|
|
||||||
declare export class ConnectedRouter extends React$Component<{
|
declare export class ConnectedRouter extends React$Component<{
|
||||||
history: any
|
history: any
|
||||||
|
@ -36,11 +36,14 @@ const initialState: State = {
|
|||||||
export default function wallet(state: State = initialState, action: Action): State {
|
export default function wallet(state: State = initialState, action: Action): State {
|
||||||
switch (action.type) {
|
switch (action.type) {
|
||||||
case WALLET.SET_INITIAL_URL:
|
case WALLET.SET_INITIAL_URL:
|
||||||
console.log('action2', action);
|
|
||||||
return {
|
return {
|
||||||
...state,
|
...state,
|
||||||
initialParams: action.state,
|
initialParams: action.state,
|
||||||
initialPathname: action.pathname,
|
initialPathname: action.pathname,
|
||||||
|
};
|
||||||
|
case WALLET.SET_FIRST_LOCATION_CHANGE:
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
firstLocationChange: false,
|
firstLocationChange: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ const RouterService: Middleware = (api: MiddlewareAPI) => (next: MiddlewareDispa
|
|||||||
console.log('api.dispatch(RouterActions.pathToParams(validUrl))', api.dispatch(RouterActions.pathToParams(validUrl)));
|
console.log('api.dispatch(RouterActions.pathToParams(validUrl))', api.dispatch(RouterActions.pathToParams(validUrl)));
|
||||||
override.payload.location.state = api.dispatch(RouterActions.pathToParams(validUrl));
|
override.payload.location.state = api.dispatch(RouterActions.pathToParams(validUrl));
|
||||||
const redirect = action.payload.location.pathname !== validUrl;
|
const redirect = action.payload.location.pathname !== validUrl;
|
||||||
|
console.warn('OVERRIDE', action.payload.location.pathname, validUrl);
|
||||||
if (redirect) {
|
if (redirect) {
|
||||||
// override action pathname
|
// override action pathname
|
||||||
override.payload.location.pathname = validUrl;
|
override.payload.location.pathname = validUrl;
|
||||||
|
Loading…
Reference in New Issue
Block a user