Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added an Error Page #6856

Merged
merged 32 commits into from
Jan 14, 2022
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
8d800fe
feat(error-page): First draft of the page with the content
mananjadhav Dec 21, 2021
a9df026
feat(error-page): Additional styling and alignment
mananjadhav Dec 21, 2021
bacc606
feat(error-page): Added link styling and design adjustment
mananjadhav Dec 21, 2021
83fc0e2
feat(error-page): Fixed button size for small screen devices
mananjadhav Dec 21, 2021
5bf449b
feat(error-page): Added alignment for mobile devices and fixed functi…
mananjadhav Dec 21, 2021
c123dd1
feat(error-page): Code cleanup
mananjadhav Dec 21, 2021
132adef
Merge branch 'main' of https://github.com/mananjadhav/App into feat/e…
mananjadhav Dec 22, 2021
719d3c2
feat(error-page): Link fixes and removed unused code
mananjadhav Dec 23, 2021
68a0a3b
feat(error-page): Added reload for web and desktop
mananjadhav Dec 23, 2021
748719d
feat(error-page): Added app reload functionality
mananjadhav Dec 23, 2021
a025797
feat(error-page): Added comments
mananjadhav Dec 23, 2021
eb5e43c
fix: Removed unwanted package
mananjadhav Dec 30, 2021
ad552c6
Moved the component to pages
mananjadhav Dec 30, 2021
37699b7
fix: Fixed imports and props
mananjadhav Dec 30, 2021
e9064d5
fix: Added signOut and redirect
mananjadhav Dec 30, 2021
07e08e5
fix: Corrected translation keys
mananjadhav Dec 30, 2021
b47b6ee
fix: Styling for button alignment in mobile devices
mananjadhav Dec 30, 2021
ba3e32b
Merge branch 'main' of https://github.com/mananjadhav/App into feat/e…
mananjadhav Dec 30, 2021
88984eb
Merge branch 'main' of https://github.com/mananjadhav/App into feat/e…
mananjadhav Dec 30, 2021
fa1205c
fix: Update refs to Text component
mananjadhav Dec 30, 2021
6559976
fix: Corrected component name and moved Signout to props
mananjadhav Jan 1, 2022
5d0ef59
fix: Made buttons left aligned
mananjadhav Jan 1, 2022
f3ea35d
fix: Removed unwated props
mananjadhav Jan 1, 2022
c839bcd
fix: Added medium button style
mananjadhav Jan 3, 2022
d4fa9ff
fix: Changed button style to medium
mananjadhav Jan 3, 2022
ea9178c
fix: Removed windowDimensions
mananjadhav Jan 3, 2022
0e924d4
fix: Reduced the margin between buttons
mananjadhav Jan 3, 2022
fa78f55
Merge branch 'main' of https://github.com/mananjadhav/App into feat/e…
mananjadhav Jan 12, 2022
5101d2e
fix: Code cleanup
mananjadhav Jan 12, 2022
9209388
Merge branch 'feat/error-page' of https://github.com/mananjadhav/App …
mananjadhav Jan 12, 2022
964ee33
fix: Renamed func ref
mananjadhav Jan 12, 2022
ae0f10d
Merge branch 'main' of https://github.com/mananjadhav/App into feat/e…
mananjadhav Jan 13, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion src/components/ErrorBoundary/BaseErrorBoundary.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React from 'react';
import PropTypes from 'prop-types';
import BootSplash from '../../libs/BootSplash';
import GenericErrorView from '../GenericErrorView';

const propTypes = {
/* A message posted to `logError` (along with error data) when this component intercepts an error */
Expand Down Expand Up @@ -43,7 +44,7 @@ class BaseErrorBoundary extends React.Component {
render() {
if (this.state.hasError) {
// For the moment we've decided not to render any fallback UI
return null;
return <GenericErrorView />;
}

return this.props.children;
Expand Down
5 changes: 5 additions & 0 deletions src/components/GenericErrorView/ErrorBodyText/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import React from 'react';

export default () => (
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<></>
);
22 changes: 22 additions & 0 deletions src/components/GenericErrorView/ErrorBodyText/index.native.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import React from 'react';
import ExpensifyText from '../../ExpensifyText';
import withLocalize, {withLocalizePropTypes} from '../../withLocalize';
import TextLink from '../../TextLink';
import CONST from '../../../CONST';
import styles from '../../../styles/styles';

const propTypes = {
...withLocalizePropTypes,
};

const ErrorBodyText = props => (
<ExpensifyText>
{props.translate('genericErrorView.body.helpTextMobile')}
<TextLink href={CONST.NEW_EXPENSIFY_URL} style={[styles.link]}>
{props.translate('genericErrorView.body.helpTextWeb')}
</TextLink>
</ExpensifyText>
);

ErrorBodyText.propTypes = propTypes;
export default withLocalize(ErrorBodyText);
79 changes: 79 additions & 0 deletions src/components/GenericErrorView/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
import React from 'react';
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
import {View} from 'react-native';
import Icon from '../Icon';
import defaultTheme from '../../styles/themes/default';
import * as Expensicons from '../Icon/Expensicons';
import ExpensifyText from '../ExpensifyText';
import Button from '../Button';
import LogoWordmark from '../../../assets/images/expensify-wordmark.svg';
import withLocalize, {withLocalizePropTypes} from '../withLocalize';
import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';
import compose from '../../libs/compose';
import variables from '../../styles/variables';
import Navigation from '../../libs/Navigation/Navigation';
import styles from '../../styles/styles';
import ErrorBodyText from './ErrorBodyText';
import TextLink from '../TextLink';
import CONST from '../../CONST';

const propTypes = {
...withLocalizePropTypes,
...windowDimensionsPropTypes,
};

const GenericErrorView = (props) => {
const refreshPage = () => {
Navigation.navigate(Navigation.getCurrentRoute());
};
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved

return (
<View style={[styles.flex1, styles.pv10, styles.ph5, styles.errorPageContainer]}>
<View style={[styles.flexColumn, styles.flex1, styles.alignItemsCenter, styles.justifyContentCenter]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<View style={[styles.flexColumn, styles.flexColumn, styles.alignItemsStart]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<View style={[styles.mb5]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<Icon
src={Expensicons.Bug}
height={variables.componentSizeNormal}
width={variables.componentSizeNormal}
fill={defaultTheme.iconSuccessFill}
/>
</View>
<View style={[styles.mb5]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<ExpensifyText style={[styles.headerText, styles.textXXLarge]}>
{props.translate('genericErrorView.title')}
</ExpensifyText>
</View>
<View style={[styles.mb5]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<ErrorBodyText />
<ExpensifyText>
{props.translate('genericErrorView.body.helpTextConcierge')}
<TextLink href={CONST.EMAIL.CONCIERGE} style={[styles.link]}>
{CONST.EMAIL.CONCIERGE}
</TextLink>
</ExpensifyText>
</View>
<View style={styles.flexWrap}>
<Button
success
small={props.isSmallScreenWidth}
onPress={refreshPage}
text={props.translate('genericErrorView.refresh')}
/>
</View>
</View>
</View>
<View styles={[styles.alignSelfEnd]}>
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
<View style={[styles.flex1, styles.flexRow, styles.justifyContentCenter]}>
<LogoWordmark height={30} width={80} />
</View>
</View>
</View>
);
};

GenericErrorView.propTypes = propTypes;

export default compose(
withWindowDimensions,
withLocalize,
)(GenericErrorView);
9 changes: 9 additions & 0 deletions src/languages/en.js
Original file line number Diff line number Diff line change
Expand Up @@ -829,4 +829,13 @@ export default {
screenShare: 'Screen share',
screenShareRequest: 'Expensify is inviting you to a screen share',
},
genericErrorView: {
title: 'Uh-oh, something went wrong!',
body: {
helpTextMobile: 'Please try closing and reopening the app or switching to ',
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
helpTextWeb: 'web.',
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
helpTextConcierge: 'If the problem persists, reach out to ',
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
},
refresh: 'Refresh',
},
};
9 changes: 9 additions & 0 deletions src/languages/es.js
Original file line number Diff line number Diff line change
Expand Up @@ -831,4 +831,13 @@ export default {
screenShare: 'Compartir pantalla',
screenShareRequest: 'Expensify te está invitando a compartir la pantalla',
},
genericErrorView: {
title: '¡Uh-oh, algo salió mal!',
body: {
helpTextMobile: 'Intente cerrar y volver a abrir la aplicación o cambiar a la ',
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
helpTextWeb: 'web.',
roryabraham marked this conversation as resolved.
Show resolved Hide resolved
helpTextConcierge: 'Si el problema persiste, comuníquese con ',
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
},
refresh: 'Refresh',
},
};
11 changes: 11 additions & 0 deletions src/libs/Navigation/Navigation.js
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,16 @@ function isActiveRoute(routePath) {
return path === routePath;
}

/**
* Returns the current route of the navigation stack
* @returns {String}
*/
function getCurrentRoute() {
return navigationRef.current && navigationRef.current.getCurrentRoute().name
? getPathFromState(navigationRef.current.getState(), linkingConfig.config).substring(1)
: '';
}

/**
* Alternative to the `Navigation.dismissModal()` function that we can use inside
* the render function of other components to avoid breaking React rules about side-effects.
Expand Down Expand Up @@ -222,6 +232,7 @@ export default {
closeDrawer,
getDefaultDrawerState,
setDidTapNotification,
getCurrentRoute,
};

export {
Expand Down
8 changes: 8 additions & 0 deletions src/styles/styles.js
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,10 @@ const styles = {
fontSize: variables.fontSizeLarge,
},

textXXLarge: {
fontSize: variables.fontSizeXXLarge,
},

textXXXLarge: {
color: themeColors.heading,
fontFamily: fontFamily.GTA_BOLD,
Expand Down Expand Up @@ -2340,6 +2344,10 @@ const styles = {
backgroundColor: colors.black,
flex: 1,
},

errorPageContainer: {
backgroundColor: themeColors.componentBG,
},
mananjadhav marked this conversation as resolved.
Show resolved Hide resolved
};

export default styles;
4 changes: 4 additions & 0 deletions src/styles/utilities/spacing.js
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,10 @@ export default {
paddingVertical: 20,
},

pv10: {
paddingVertical: 40,
},

ph0: {
paddingHorizontal: 0,
},
Expand Down
1 change: 1 addition & 0 deletions src/styles/variables.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export default {
fontSizeLarge: 17,
fontSizeHero: 36,
fontSizeh1: 19,
fontSizeXXLarge: 28,
fontSizeXXXLarge: 32,
fontSizeNormalHeight: 20,
lineHeightHero: 40,
Expand Down