1
0
mirror of https://github.com/trezor/trezor-wallet synced 2025-01-03 21:00:55 +00:00

send form clear button for ripple and eth

This commit is contained in:
slowbackspace 2019-01-15 13:54:34 +01:00
parent e24574d70b
commit c77cd10f03
6 changed files with 140 additions and 32 deletions

View File

@ -29,6 +29,8 @@ export type SendFormAction = {
type: typeof SEND.TOGGLE_ADVANCED | typeof SEND.TX_SENDING | typeof SEND.TX_ERROR, type: typeof SEND.TOGGLE_ADVANCED | typeof SEND.TX_SENDING | typeof SEND.TX_ERROR,
} | { } | {
type: typeof SEND.TX_COMPLETE, type: typeof SEND.TX_COMPLETE,
} | {
type: typeof SEND.CLEAR,
}; };

View File

@ -7,3 +7,4 @@ export const TX_SENDING: 'send__tx_sending' = 'send__tx_sending';
export const TX_COMPLETE: 'send__tx_complete' = 'send__tx_complete'; export const TX_COMPLETE: 'send__tx_complete' = 'send__tx_complete';
export const TX_ERROR: 'send__tx_error' = 'send__tx_error'; export const TX_ERROR: 'send__tx_error' = 'send__tx_error';
export const TOGGLE_ADVANCED: 'send__toggle_advanced' = 'send__toggle_advanced'; export const TOGGLE_ADVANCED: 'send__toggle_advanced' = 'send__toggle_advanced';
export const CLEAR: 'send__clear' = 'send__clear';

View File

@ -53,6 +53,13 @@ export const observe = (prevState: ReducersState, action: Action): ThunkAction =
return; return;
} }
// clear transaction draft from session storage and reinitialize send form
if (action.type === SEND.CLEAR) {
dispatch(SessionStorageActions.clear());
dispatch(init());
return;
}
// if send form was not initialized // if send form was not initialized
if (currentState.sendFormEthereum.currency === '') { if (currentState.sendFormEthereum.currency === '') {
dispatch(init()); dispatch(init());
@ -109,6 +116,8 @@ export const init = (): AsyncAction => async (dispatch: Dispatch, getState: GetS
network, network,
} = getState().selectedAccount; } = getState().selectedAccount;
const { advanced } = getState().sendFormEthereum;
if (!account || !network) return; if (!account || !network) return;
const stateFromStorage = dispatch(SessionStorageActions.loadEthereumDraftTransaction()); const stateFromStorage = dispatch(SessionStorageActions.loadEthereumDraftTransaction());
@ -140,6 +149,7 @@ export const init = (): AsyncAction => async (dispatch: Dispatch, getState: GetS
recommendedGasPrice: gasPrice.toString(), recommendedGasPrice: gasPrice.toString(),
gasLimit, gasLimit,
gasPrice: gasPrice.toString(), gasPrice: gasPrice.toString(),
advanced,
}, },
}); });
}; };
@ -152,6 +162,14 @@ export const toggleAdvanced = (): Action => ({
networkType: 'ethereum', networkType: 'ethereum',
}); });
/*
* Called from UI from "clear" button
*/
export const onClear = (): Action => ({
type: SEND.CLEAR,
networkType: 'ethereum',
});
/* /*
* Called from UI on "address" field change * Called from UI on "address" field change
*/ */
@ -613,4 +631,5 @@ export default {
onNonceChange, onNonceChange,
onDataChange, onDataChange,
onSend, onSend,
onClear,
}; };

View File

@ -35,6 +35,13 @@ export const observe = (prevState: ReducersState, action: Action): ThunkAction =
return; return;
} }
// clear transaction draft from session storage and reinitialize send form
if (action.type === SEND.CLEAR) {
dispatch(SessionStorageActions.clear());
dispatch(init());
return;
}
// if send form was not initialized // if send form was not initialized
if (currentState.sendFormRipple.networkSymbol === '') { if (currentState.sendFormRipple.networkSymbol === '') {
dispatch(init()); dispatch(init());
@ -80,6 +87,8 @@ export const init = (): AsyncAction => async (dispatch: Dispatch, getState: GetS
network, network,
} = getState().selectedAccount; } = getState().selectedAccount;
const { advanced } = getState().sendFormEthereum;
if (!account || account.networkType !== 'ripple' || !network) return; if (!account || account.networkType !== 'ripple' || !network) return;
const stateFromStorage = dispatch(SessionStorageActions.loadRippleDraftTransaction()); const stateFromStorage = dispatch(SessionStorageActions.loadRippleDraftTransaction());
@ -107,6 +116,7 @@ export const init = (): AsyncAction => async (dispatch: Dispatch, getState: GetS
selectedFeeLevel, selectedFeeLevel,
fee: network.fee.defaultFee, fee: network.fee.defaultFee,
sequence: '1', sequence: '1',
advanced,
}, },
}); });
}; };
@ -119,6 +129,15 @@ export const toggleAdvanced = (): Action => ({
networkType: 'ripple', networkType: 'ripple',
}); });
/*
* Called from UI from "clear" button
*/
export const onClear = (): Action => ({
type: SEND.CLEAR,
networkType: 'ripple',
});
/* /*
* Called from UI on "address" field change * Called from UI on "address" field change
*/ */
@ -368,4 +387,5 @@ export default {
onFeeChange, onFeeChange,
onDestinationTagChange, onDestinationTagChange,
onSend, onSend,
onClear,
}; };

View File

@ -142,17 +142,33 @@ const ToggleAdvancedSettingsButton = styled(Button)`
min-height: 40px; min-height: 40px;
padding: 0; padding: 0;
display: flex; display: flex;
flex: 1 1 0;
align-items: center; align-items: center;
font-weight: ${FONT_WEIGHT.SEMIBOLD}; font-weight: ${FONT_WEIGHT.SEMIBOLD};
`; `;
const SendButton = styled(Button)` const FormButtons = styled.div`
min-width: ${props => (props.isAdvancedSettingsHidden ? '50%' : '100%')}; display: flex;
word-break: break-all; flex: 1 1;
@media screen and (max-width: ${SmallScreenWidth}) { @media screen and (max-width: ${SmallScreenWidth}) {
margin-top: ${props => (props.isAdvancedSettingsHidden ? '10px' : 0)}; margin-top: ${props => (props.isAdvancedSettingsHidden ? '10px' : 0)};
} }
Button + Button {
margin-left: 5px;
}
`;
const SendButton = styled(Button)`
word-break: break-all;
flex: 1;
`;
const ClearButton = styled(Button)`
`; `;
const AdvancedSettingsIcon = styled(Icon)` const AdvancedSettingsIcon = styled(Icon)`
@ -228,6 +244,7 @@ const AccountSend = (props: Props) => {
onFeeLevelChange, onFeeLevelChange,
updateFeeLevels, updateFeeLevels,
onSend, onSend,
onClear,
} = props.sendFormActions; } = props.sendFormActions;
if (!device || !account || !discovery || !network || !shouldRender) { if (!device || !account || !discovery || !network || !shouldRender) {
@ -387,24 +404,40 @@ const AccountSend = (props: Props) => {
</ToggleAdvancedSettingsButton> </ToggleAdvancedSettingsButton>
{isAdvancedSettingsHidden && ( {isAdvancedSettingsHidden && (
<SendButton <FormButtons>
isDisabled={isSendButtonDisabled} <ClearButton
isAdvancedSettingsHidden={isAdvancedSettingsHidden} isWhite
onClick={() => onSend()} onClick={() => onClear()}
> >
{sendButtonText} Clear
</SendButton> </ClearButton>
<SendButton
isDisabled={isSendButtonDisabled}
isAdvancedSettingsHidden={isAdvancedSettingsHidden}
onClick={() => onSend()}
>
{sendButtonText}
</SendButton>
</FormButtons>
)} )}
</ToggleAdvancedSettingsWrapper> </ToggleAdvancedSettingsWrapper>
{advanced && ( {advanced && (
<AdvancedForm {...props}> <AdvancedForm {...props}>
<SendButton <FormButtons>
isDisabled={isSendButtonDisabled} <ClearButton
onClick={() => onSend()} isWhite
> onClick={() => onClear()}
{sendButtonText} >
</SendButton> Clear
</ClearButton>
<SendButton
isDisabled={isSendButtonDisabled}
onClick={() => onSend()}
>
{sendButtonText}
</SendButton>
</FormButtons>
</AdvancedForm> </AdvancedForm>
)} )}

View File

@ -129,17 +129,33 @@ const ToggleAdvancedSettingsButton = styled(Button)`
min-height: 40px; min-height: 40px;
padding: 0; padding: 0;
display: flex; display: flex;
flex: 1 1 0;
align-items: center; align-items: center;
font-weight: ${FONT_WEIGHT.SEMIBOLD}; font-weight: ${FONT_WEIGHT.SEMIBOLD};
`; `;
const SendButton = styled(Button)` const FormButtons = styled.div`
min-width: ${props => (props.isAdvancedSettingsHidden ? '50%' : '100%')}; display: flex;
word-break: break-all; flex: 1 1;
@media screen and (max-width: ${SmallScreenWidth}) { @media screen and (max-width: ${SmallScreenWidth}) {
margin-top: ${props => (props.isAdvancedSettingsHidden ? '10px' : 0)}; margin-top: ${props => (props.isAdvancedSettingsHidden ? '10px' : 0)};
} }
Button + Button {
margin-left: 5px;
}
`;
const SendButton = styled(Button)`
word-break: break-all;
flex: 1;
`;
const ClearButton = styled(Button)`
`; `;
const AdvancedSettingsIcon = styled(Icon)` const AdvancedSettingsIcon = styled(Icon)`
@ -204,6 +220,7 @@ const AccountSend = (props: Props) => {
onFeeLevelChange, onFeeLevelChange,
updateFeeLevels, updateFeeLevels,
onSend, onSend,
onClear,
} = props.sendFormActions; } = props.sendFormActions;
if (!device || !account || !discovery || !network || !shouldRender) { if (!device || !account || !discovery || !network || !shouldRender) {
@ -341,24 +358,40 @@ const AccountSend = (props: Props) => {
</ToggleAdvancedSettingsButton> </ToggleAdvancedSettingsButton>
{isAdvancedSettingsHidden && ( {isAdvancedSettingsHidden && (
<SendButton <FormButtons>
isDisabled={isSendButtonDisabled} <ClearButton
isAdvancedSettingsHidden={isAdvancedSettingsHidden} isWhite
onClick={() => onSend()} onClick={() => onClear()}
> >
{sendButtonText} Clear
</SendButton> </ClearButton>
<SendButton
isDisabled={isSendButtonDisabled}
isAdvancedSettingsHidden={isAdvancedSettingsHidden}
onClick={() => onSend()}
>
{sendButtonText}
</SendButton>
</FormButtons>
)} )}
</ToggleAdvancedSettingsWrapper> </ToggleAdvancedSettingsWrapper>
{advanced && ( {advanced && (
<AdvancedForm {...props}> <AdvancedForm {...props}>
<SendButton <FormButtons>
isDisabled={isSendButtonDisabled} <ClearButton
onClick={() => onSend()} isWhite
> onClick={() => onClear()}
{sendButtonText} >
</SendButton> Clear
</ClearButton>
<SendButton
isDisabled={isSendButtonDisabled}
onClick={() => onSend()}
>
{sendButtonText}
</SendButton>
</FormButtons>
</AdvancedForm> </AdvancedForm>
)} )}