From 5ae65ead66ad2f87b2dcd4b1ab55c87a4b3a17ce Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 26 Jul 2023 16:19:52 -0700 Subject: [PATCH 001/105] Component for indicator messages with close button --- .../DotIndicatorMessageWithClose.js | 74 +++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 src/components/DotIndicatorMessageWithClose.js diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/DotIndicatorMessageWithClose.js new file mode 100644 index 000000000000..1a0770508eb3 --- /dev/null +++ b/src/components/DotIndicatorMessageWithClose.js @@ -0,0 +1,74 @@ +import React from 'react'; +import _ from 'underscore'; +import PropTypes from 'prop-types'; +import {View} from 'react-native'; +import styles from '../styles/styles'; +import Icon from './Icon'; +import * as Expensicons from './Icon/Expensicons'; +import DotIndicatorMessage from './DotIndicatorMessage'; +import Tooltip from './Tooltip'; +import CONST from '../CONST'; +import * as StyleUtils from '../styles/StyleUtils'; +import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; +import stylePropTypes from '../styles/stylePropTypes'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; + +const propTypes = { + /** + * In most cases this should just be errors from onxyData + * if you are not passing that data then this needs to be in a similar shape like + * { + * timestamp: 'message', + * } + */ + messages: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))])), + + // The type of message, 'error' shows a red dot, 'success' shows a green dot + type: PropTypes.oneOf(['error', 'success']).isRequired, + + /** A function to run when the X button next to the message is clicked */ + onClose: PropTypes.func, + + /** Additional style object for the container*/ + containerStyles: stylePropTypes, + + ...withLocalizePropTypes, +}; + +const defaultProps = { + messages: {}, + onClose: () => {}, + containerStyles: [], +}; + +function DotIndicatorMessageWithClose(props) { + if (_.isEmpty(props.messages)) { + return null; + } + + return ( + + + + + + + + + ); +} + +DotIndicatorMessageWithClose.propTypes = propTypes; +DotIndicatorMessageWithClose.defaultProps = defaultProps; +DotIndicatorMessageWithClose.displayName = 'DotIndicatorMessageWithClose'; + +export default withLocalize(DotIndicatorMessageWithClose); From 1039385b4d1c94b7f7586ea3aff57e716e171391 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 26 Jul 2023 16:21:29 -0700 Subject: [PATCH 002/105] Show message when members added with primary login --- src/languages/en.js | 1 + src/pages/workspace/WorkspaceMembersPage.js | 7 +++++++ 2 files changed, 8 insertions(+) diff --git a/src/languages/en.js b/src/languages/en.js index b7a130addf18..a0f73bc41788 100755 --- a/src/languages/en.js +++ b/src/languages/en.js @@ -1150,6 +1150,7 @@ export default { cannotRemove: 'You cannot remove yourself or the workspace owner.', genericRemove: 'There was a problem removing that workspace member.', }, + addedWithPrimary: 'Some users were added with their primary logins.', }, card: { header: 'Unlock free Expensify Cards', diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index e758d738d964..028420d60093 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -38,6 +38,7 @@ import PressableWithFeedback from '../../components/Pressable/PressableWithFeedb import usePrevious from '../../hooks/usePrevious'; import Log from '../../libs/Log'; import * as PersonalDetailsUtils from '../../libs/PersonalDetailsUtils'; +import DotIndicatorMessageWithClose from '../../components/DotIndicatorMessageWithClose'; const propTypes = { /** All personal details asssociated with user */ @@ -397,6 +398,7 @@ function WorkspaceMembersPage(props) { }); const policyID = lodashGet(props.route, 'params.policyID'); const policyName = lodashGet(props.policy, 'name'); + const primaryLoginsInvited = props.policy.primaryLoginsInvited || {}; return ( + {data.length > 0 ? ( From fa3adb21e53d8cdb0460c7fe739ba253bbbb6847 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 26 Jul 2023 16:21:57 -0700 Subject: [PATCH 003/105] Style fix --- src/components/DotIndicatorMessageWithClose.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/DotIndicatorMessageWithClose.js index 1a0770508eb3..fd535475583f 100644 --- a/src/components/DotIndicatorMessageWithClose.js +++ b/src/components/DotIndicatorMessageWithClose.js @@ -29,7 +29,7 @@ const propTypes = { /** A function to run when the X button next to the message is clicked */ onClose: PropTypes.func, - /** Additional style object for the container*/ + /** Additional style object for the container */ containerStyles: stylePropTypes, ...withLocalizePropTypes, @@ -47,7 +47,7 @@ function DotIndicatorMessageWithClose(props) { } return ( - + Date: Wed, 26 Jul 2023 16:29:40 -0700 Subject: [PATCH 004/105] Allow dismissing added with primary message --- src/libs/actions/Policy.js | 5 +++++ src/pages/workspace/WorkspaceMembersPage.js | 1 + 2 files changed, 6 insertions(+) diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index ebf9f100bc90..b1364dd9c373 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -1144,6 +1144,10 @@ function clearErrors(policyID) { hideWorkspaceAlertMessage(policyID); } +function dismissAddedWithPrimaryMessages(policyID) { + Onyx.merge(`${ONYXKEYS.COLLECTION.POLICY}${policyID}`, {primaryLoginsInvited: null}); +} + export { removeMembers, addMembersToWorkspace, @@ -1173,4 +1177,5 @@ export { setWorkspaceInviteMembersDraft, isPolicyOwner, clearErrors, + dismissAddedWithPrimaryMessages, }; diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index 028420d60093..7c396aa0f65d 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -460,6 +460,7 @@ function WorkspaceMembersPage(props) { type="success" messages={_.isEmpty(primaryLoginsInvited) ? null : {0: props.translate('workspace.people.addedWithPrimary')}} containerStyles={[styles.pt3]} + onClose={() => Policy.dismissAddedWithPrimaryMessages(props.route.params.policyID)} /> {data.length > 0 ? ( From 8a449b1a8b70fdc1fb4a82038a5d94f0b65b1a2a Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 26 Jul 2023 18:02:22 -0700 Subject: [PATCH 005/105] Show added by secondary login messages --- src/languages/en.js | 1 + src/pages/workspace/WorkspaceMembersPage.js | 6 ++++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/src/languages/en.js b/src/languages/en.js index a0f73bc41788..b35bf44f6159 100755 --- a/src/languages/en.js +++ b/src/languages/en.js @@ -1151,6 +1151,7 @@ export default { genericRemove: 'There was a problem removing that workspace member.', }, addedWithPrimary: 'Some users were added with their primary logins.', + invitedBySecondaryLogin: ({secondaryLogin}) => `Added by secondary login ${secondaryLogin}.`, }, card: { header: 'Unlock free Expensify Cards', diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index 7c396aa0f65d..3dadf76b2431 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -342,6 +342,7 @@ function WorkspaceMembersPage(props) { }} onSelectRow={() => toggleUser(item.accountID, item.pendingAction)} /> + {Boolean(item.invitedSecondaryLogin) && {props.translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})}} {(props.session.accountID === item.accountID || item.role === 'admin') && ( @@ -362,6 +363,7 @@ function WorkspaceMembersPage(props) { [selectedEmployees, errors, props.session.accountID, dismissError, toggleUser], ); + const invitedSecondaryToPrimaryLogins = _.invert(props.policy.primaryLoginsInvited); const policyOwner = lodashGet(props.policy, 'owner'); const currentUserLogin = lodashGet(props.currentUserPersonalDetails, 'login'); const removableMembers = {}; @@ -378,6 +380,7 @@ function WorkspaceMembersPage(props) { data.push({ ...policyMember, ...details, + invitedSecondaryLogin: invitedSecondaryToPrimaryLogins[details.login] || '', }); }); data = _.sortBy(data, (value) => value.displayName.toLowerCase()); @@ -398,7 +401,6 @@ function WorkspaceMembersPage(props) { }); const policyID = lodashGet(props.route, 'params.policyID'); const policyName = lodashGet(props.policy, 'name'); - const primaryLoginsInvited = props.policy.primaryLoginsInvited || {}; return ( Policy.dismissAddedWithPrimaryMessages(props.route.params.policyID)} /> From 3afc37b3a183f25584a56acc7759128f0d0d1896 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 3 Aug 2023 18:23:29 -0700 Subject: [PATCH 006/105] Reuse component where it was extracted from --- src/components/OfflineWithFeedback.js | 29 +++++++-------------------- 1 file changed, 7 insertions(+), 22 deletions(-) diff --git a/src/components/OfflineWithFeedback.js b/src/components/OfflineWithFeedback.js index 820cce252205..87963ed26fd9 100644 --- a/src/components/OfflineWithFeedback.js +++ b/src/components/OfflineWithFeedback.js @@ -9,13 +9,9 @@ import CONST from '../CONST'; import networkPropTypes from './networkPropTypes'; import stylePropTypes from '../styles/stylePropTypes'; import styles from '../styles/styles'; -import Tooltip from './Tooltip'; -import Icon from './Icon'; -import * as Expensicons from './Icon/Expensicons'; import * as StyleUtils from '../styles/StyleUtils'; -import DotIndicatorMessage from './DotIndicatorMessage'; import shouldRenderOffscreen from '../libs/shouldRenderOffscreen'; -import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; +import DotIndicatorMessageWithClose from './DotIndicatorMessageWithClose'; /** * This component should be used when we are using the offline pattern B (offline with feedback). @@ -116,23 +112,12 @@ function OfflineWithFeedback(props) { )} {props.shouldShowErrorMessages && hasErrorMessages && ( - - - - - - - - + )} ); From d4c2c737245b230484be65a2f31faf40ddf8c5f6 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 3 Aug 2023 18:23:37 -0700 Subject: [PATCH 007/105] style --- src/pages/workspace/WorkspaceMembersPage.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index 3dadf76b2431..647c35b4f6b3 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -342,7 +342,11 @@ function WorkspaceMembersPage(props) { }} onSelectRow={() => toggleUser(item.accountID, item.pendingAction)} /> - {Boolean(item.invitedSecondaryLogin) && {props.translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})}} + {Boolean(item.invitedSecondaryLogin) && ( + + {props.translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})} + + )} {(props.session.accountID === item.accountID || item.role === 'admin') && ( From 9157c287179821b57de11d482fc64134ce615a2b Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 3 Aug 2023 18:36:09 -0700 Subject: [PATCH 008/105] Add informative comments, better variable name --- src/components/DotIndicatorMessage.js | 8 +------- src/libs/actions/Policy.js | 5 +++++ src/pages/workspace/WorkspaceMembersPage.js | 8 +++++--- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/src/components/DotIndicatorMessage.js b/src/components/DotIndicatorMessage.js index ac550f34de3f..1073f8c9aedc 100644 --- a/src/components/DotIndicatorMessage.js +++ b/src/components/DotIndicatorMessage.js @@ -10,13 +10,7 @@ import Text from './Text'; import * as Localize from '../libs/Localize'; const propTypes = { - /** - * In most cases this should just be errors from onxyData - * if you are not passing that data then this needs to be in a similar shape like - * { - * timestamp: 'message', - * } - */ + // The error messages to display messages: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))])), // The type of message, 'error' shows a red dot, 'success' shows a green dot diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index b1364dd9c373..28ebb3d29e09 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -1144,6 +1144,11 @@ function clearErrors(policyID) { hideWorkspaceAlertMessage(policyID); } +/** + * Dismiss the informative messages about which policy members were added with primary logins when invited with their secondary login. + * + * @param {String} policyID + */ function dismissAddedWithPrimaryMessages(policyID) { Onyx.merge(`${ONYXKEYS.COLLECTION.POLICY}${policyID}`, {primaryLoginsInvited: null}); } diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index 647c35b4f6b3..018ffb717908 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -367,7 +367,7 @@ function WorkspaceMembersPage(props) { [selectedEmployees, errors, props.session.accountID, dismissError, toggleUser], ); - const invitedSecondaryToPrimaryLogins = _.invert(props.policy.primaryLoginsInvited); + const invitedPrimaryToSecondaryLogins = _.invert(props.policy.primaryLoginsInvited); const policyOwner = lodashGet(props.policy, 'owner'); const currentUserLogin = lodashGet(props.currentUserPersonalDetails, 'login'); const removableMembers = {}; @@ -384,7 +384,9 @@ function WorkspaceMembersPage(props) { data.push({ ...policyMember, ...details, - invitedSecondaryLogin: invitedSecondaryToPrimaryLogins[details.login] || '', + + // Note which secondary login was used to invite this primary login + invitedSecondaryLogin: invitedPrimaryToSecondaryLogins[details.login] || '', }); }); data = _.sortBy(data, (value) => value.displayName.toLowerCase()); @@ -464,7 +466,7 @@ function WorkspaceMembersPage(props) { /> Policy.dismissAddedWithPrimaryMessages(props.route.params.policyID)} /> From 0a28b29e21703cdee9083c317c54c182b7fd82a3 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 3 Aug 2023 19:22:53 -0700 Subject: [PATCH 009/105] Add spanish translations --- src/languages/es.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/languages/es.js b/src/languages/es.js index 4006f559eb1f..f2837c60b5e7 100644 --- a/src/languages/es.js +++ b/src/languages/es.js @@ -1159,6 +1159,8 @@ export default { cannotRemove: 'No puedes eliminarte ni a ti mismo ni al dueño del espacio de trabajo.', genericRemove: 'Ha ocurrido un problema al eliminar al miembro del espacio de trabajo.', }, + addedWithPrimary: 'Se agregaron algunos usuarios con sus inicios de sesión principales.', + invitedBySecondaryLogin: ({secondaryLogin}) => `Agregado por inicio de sesión secundario ${secondaryLogin}.`, }, card: { header: 'Desbloquea Tarjetas Expensify gratis', From f88a4560795434cfe55384c37f30e9d43b9b4fb6 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 3 Aug 2023 19:26:25 -0700 Subject: [PATCH 010/105] Change comment in proper file --- src/components/DotIndicatorMessage.js | 8 +++++++- src/components/DotIndicatorMessageWithClose.js | 8 +------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/components/DotIndicatorMessage.js b/src/components/DotIndicatorMessage.js index 1073f8c9aedc..ac550f34de3f 100644 --- a/src/components/DotIndicatorMessage.js +++ b/src/components/DotIndicatorMessage.js @@ -10,7 +10,13 @@ import Text from './Text'; import * as Localize from '../libs/Localize'; const propTypes = { - // The error messages to display + /** + * In most cases this should just be errors from onxyData + * if you are not passing that data then this needs to be in a similar shape like + * { + * timestamp: 'message', + * } + */ messages: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))])), // The type of message, 'error' shows a red dot, 'success' shows a green dot diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/DotIndicatorMessageWithClose.js index fd535475583f..7626a956489f 100644 --- a/src/components/DotIndicatorMessageWithClose.js +++ b/src/components/DotIndicatorMessageWithClose.js @@ -14,13 +14,7 @@ import stylePropTypes from '../styles/stylePropTypes'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { - /** - * In most cases this should just be errors from onxyData - * if you are not passing that data then this needs to be in a similar shape like - * { - * timestamp: 'message', - * } - */ + // The error messages to display messages: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))])), // The type of message, 'error' shows a red dot, 'success' shows a green dot From 1a9d3284a1eaf165b1119d5bbc50231747a494e3 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Mon, 7 Aug 2023 17:10:30 -0700 Subject: [PATCH 011/105] Update with native speaker translations --- src/languages/es.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/languages/es.js b/src/languages/es.js index 3e2d5b820f9e..8592f55d998c 100644 --- a/src/languages/es.js +++ b/src/languages/es.js @@ -1184,8 +1184,8 @@ export default { cannotRemove: 'No puedes eliminarte ni a ti mismo ni al dueño del espacio de trabajo.', genericRemove: 'Ha ocurrido un problema al eliminar al miembro del espacio de trabajo.', }, - addedWithPrimary: 'Se agregaron algunos usuarios con sus inicios de sesión principales.', - invitedBySecondaryLogin: ({secondaryLogin}) => `Agregado por inicio de sesión secundario ${secondaryLogin}.`, + addedWithPrimary: 'Se agregaron algunos usuarios con sus nombres de usuario principales.', + invitedBySecondaryLogin: ({secondaryLogin}) => `Agregado por nombre de usuario secundario ${secondaryLogin}.`, }, card: { header: 'Desbloquea Tarjetas Expensify gratis', From 45b90544c39d8bdaa5c0fdaea999d3a3d95f31e1 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 21 Sep 2023 13:07:56 +0800 Subject: [PATCH 012/105] boilerplate for changes --- src/languages/en.ts | 1 + src/languages/es.ts | 1 + src/libs/actions/Report.js | 36 +++++++++++++++++++ .../report/ContextMenu/ContextMenuActions.js | 28 +++++++++++++++ 4 files changed, 66 insertions(+) diff --git a/src/languages/en.ts b/src/languages/en.ts index 1882b7e97afb..30f6b0c68f8e 100755 --- a/src/languages/en.ts +++ b/src/languages/en.ts @@ -396,6 +396,7 @@ export default { deleteConfirmation: ({action}: DeleteConfirmationParams) => `Are you sure you want to delete this ${ReportActionsUtils.isMoneyRequestAction(action) ? 'request' : 'comment'}?`, onlyVisible: 'Only visible to', replyInThread: 'Reply in thread', + subscribeToThread: 'Subscribe to thread', flagAsOffensive: 'Flag as offensive', }, emojiReactions: { diff --git a/src/languages/es.ts b/src/languages/es.ts index 87c7a19fed8a..f2786057e107 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -387,6 +387,7 @@ export default { deleteConfirmation: ({action}: DeleteConfirmationParams) => `¿Estás seguro de que quieres eliminar este ${ReportActionsUtils.isMoneyRequestAction(action) ? 'pedido' : 'comentario'}`, onlyVisible: 'Visible sólo para', replyInThread: 'Responder en el hilo', + subscribeToThread: 'NEED TO TRANSLATE', flagAsOffensive: 'Marcar como ofensivo', }, emojiReactions: { diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 55b03110e925..61d6df634dca 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -630,6 +630,42 @@ function navigateToAndOpenChildReport(childReportID = '0', parentReportAction = } } +/** + * This will subscribe to an existing thread, or create a new one and then subsribe to it if necessary + * + * @param {String} childReportID The reportID we are trying to open + * @param {Object} parentReportAction the parent comment of a thread + * @param {String} parentReportID The reportID of the parent + * + */ +function subscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0') { + if (childReportID !== '0') { + openReport(childReportID); + Navigation.navigate(ROUTES.getReportRoute(childReportID)); + } else { + const participantAccountIDs = _.uniq([currentUserAccountID, Number(parentReportAction.actorAccountID)]); + const parentReport = allReports[parentReportID]; + const newChat = ReportUtils.buildOptimisticChatReport( + participantAccountIDs, + lodashGet(parentReportAction, ['message', 0, 'text']), + lodashGet(parentReport, 'chatType', ''), + lodashGet(parentReport, 'policyID', CONST.POLICY.OWNER_EMAIL_FAKE), + CONST.POLICY.OWNER_ACCOUNT_ID_FAKE, + false, + '', + undefined, + undefined, + CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, + parentReportAction.reportActionID, + parentReportID, + ); + + const participantLogins = PersonalDetailsUtils.getLoginsByAccountIDs(newChat.participantAccountIDs); + openReport(newChat.reportID, participantLogins, newChat, parentReportAction.reportActionID); + Navigation.navigate(ROUTES.getReportRoute(newChat.reportID)); + } +} + /** * Get the latest report history without marking the report as read. * diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 173bda0e5221..6e7256162be6 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -146,6 +146,34 @@ export default [ }, getDescription: () => {}, }, + { + isAnonymousAction: false, + textTranslateKey: 'reportActionContextMenu.subscribeToThread', + icon: Expensicons.ChatBubble, + successTextTranslateKey: '', + successIcon: null, + shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { + if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { + return false; + } + const isCommentAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.ADDCOMMENT && !ReportUtils.isThreadFirstChat(reportAction, reportID); + const isReportPreviewAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.REPORTPREVIEW; + const isIOUAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.IOU && !ReportActionsUtils.isSplitBillAction(reportAction); + return isCommentAction || isReportPreviewAction || isIOUAction; + }, + onPress: (closePopover, {reportAction, reportID}) => { + if (closePopover) { + hideContextMenu(false, () => { + ReportActionComposeFocusManager.focus(); + Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + }); + return; + } + + Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + }, + getDescription: () => {}, + }, { isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.copyURLToClipboard', From 58f417f8039a4d6faab3d0ee6254582beada2fd3 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Fri, 22 Sep 2023 16:19:47 +0800 Subject: [PATCH 013/105] intermediate changes --- src/libs/actions/Report.js | 33 +++++++++++++++++-- .../report/ContextMenu/ContextMenuActions.js | 22 +++++++------ 2 files changed, 43 insertions(+), 12 deletions(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 61d6df634dca..c2dd3daf49b1 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -638,10 +638,11 @@ function navigateToAndOpenChildReport(childReportID = '0', parentReportAction = * @param {String} parentReportID The reportID of the parent * */ -function subscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0') { +function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0', prevNotificationPreference) { if (childReportID !== '0') { openReport(childReportID); - Navigation.navigate(ROUTES.getReportRoute(childReportID)); + if (prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE) + updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, ) } else { const participantAccountIDs = _.uniq([currentUserAccountID, Number(parentReportAction.actorAccountID)]); const parentReport = allReports[parentReportID]; @@ -1241,6 +1242,32 @@ function saveReportActionDraftNumberOfLines(reportID, reportActionID, numberOfLi Onyx.merge(`${ONYXKEYS.COLLECTION.REPORT_DRAFT_COMMENT_NUMBER_OF_LINES}${reportID}_${reportActionID}`, numberOfLines); } +/** + * @param {String} reportID + * @param {String} previousValue + * @param {String} newValue + */ +function updateNotificationPreference(reportID, previousValue, newValue) { + if (previousValue === newValue) { + return; + } + const optimisticData = [ + { + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT}${reportID}`, + value: {notificationPreference: newValue}, + }, + ]; + const failureData = [ + { + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT}${reportID}`, + value: {notificationPreference: previousValue}, + }, + ]; + API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue}, {optimisticData, failureData}); +} + /** * @param {String} reportID * @param {String} previousValue @@ -2105,6 +2132,7 @@ export { reconnect, updateWelcomeMessage, updateWriteCapabilityAndNavigate, + updateNotificationPreference, updateNotificationPreferenceAndNavigate, subscribeToReportTypingEvents, unsubscribeFromReportChannel, @@ -2132,6 +2160,7 @@ export { navigateToAndOpenReport, navigateToAndOpenReportWithAccountIDs, navigateToAndOpenChildReport, + toggleSubscribeToChildReport, updatePolicyRoomNameAndNavigate, clearPolicyRoomNameErrors, clearIOUError, diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 6e7256162be6..61bf5abe4674 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -25,6 +25,7 @@ import * as Task from '../../../../libs/actions/Task'; import * as Localize from '../../../../libs/Localize'; import * as TransactionUtils from '../../../../libs/TransactionUtils'; import * as CurrencyUtils from '../../../../libs/CurrencyUtils'; +import Log from '../../../../libs/Log'; /** * Gets the HTML version of the message in an action. @@ -149,7 +150,7 @@ export default [ { isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.subscribeToThread', - icon: Expensicons.ChatBubble, + icon: Expensicons.Chair, successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { @@ -162,15 +163,16 @@ export default [ return isCommentAction || isReportPreviewAction || isIOUAction; }, onPress: (closePopover, {reportAction, reportID}) => { - if (closePopover) { - hideContextMenu(false, () => { - ReportActionComposeFocusManager.focus(); - Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); - }); - return; - } - - Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + Log.info("sparsisparsi start"); + Log.info(JSON.stringify(reportAction)); + Log.info("sparsisparsi done"); + // if (closePopover) { + // hideContextMenu(false, () => { + // ReportActionComposeFocusManager.focus(); + // Report.subscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + // }); + // return; + // } }, getDescription: () => {}, }, From 0b7a83e8edd8e44971226f86f55c81140b20fc76 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 28 Sep 2023 18:22:10 +0800 Subject: [PATCH 014/105] icons and frontend wip --- assets/images/bell.svg | 3 ++ assets/images/bellSlash.svg | 3 ++ ios/NewExpensify.xcodeproj/project.pbxproj | 18 +++++++- ios/tmp.xcconfig | 10 ++++- src/components/Icon/Expensicons.js | 4 ++ src/languages/en.ts | 1 + src/languages/es.ts | 1 + src/libs/actions/Report.js | 1 + .../report/ContextMenu/ContextMenuActions.js | 43 +++++++++++++++++-- 9 files changed, 77 insertions(+), 7 deletions(-) create mode 100644 assets/images/bell.svg create mode 100644 assets/images/bellSlash.svg diff --git a/assets/images/bell.svg b/assets/images/bell.svg new file mode 100644 index 000000000000..a53c9508cbd6 --- /dev/null +++ b/assets/images/bell.svg @@ -0,0 +1,3 @@ + + + diff --git a/assets/images/bellSlash.svg b/assets/images/bellSlash.svg new file mode 100644 index 000000000000..2cacb07f4268 --- /dev/null +++ b/assets/images/bellSlash.svg @@ -0,0 +1,3 @@ + + + diff --git a/ios/NewExpensify.xcodeproj/project.pbxproj b/ios/NewExpensify.xcodeproj/project.pbxproj index 64ed3fda8b02..d1cd2d066833 100644 --- a/ios/NewExpensify.xcodeproj/project.pbxproj +++ b/ios/NewExpensify.xcodeproj/project.pbxproj @@ -29,7 +29,7 @@ 70CF6E82262E297300711ADC /* BootSplash.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 70CF6E81262E297300711ADC /* BootSplash.storyboard */; }; BDB853621F354EBB84E619C2 /* ExpensifyNewKansas-MediumItalic.otf in Resources */ = {isa = PBXBuildFile; fileRef = D2AFB39EC1D44BF9B91D3227 /* ExpensifyNewKansas-MediumItalic.otf */; }; DD79042B2792E76D004484B4 /* RCTBootSplash.m in Sources */ = {isa = PBXBuildFile; fileRef = DD79042A2792E76D004484B4 /* RCTBootSplash.m */; }; - E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */ = {isa = PBXBuildFile; }; + E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */ = {isa = PBXBuildFile; }; E9DF872D2525201700607FDC /* AirshipConfig.plist in Resources */ = {isa = PBXBuildFile; fileRef = E9DF872C2525201700607FDC /* AirshipConfig.plist */; }; ED222ED90E074A5481A854FA /* ExpensifyNeue-BoldItalic.otf in Resources */ = {isa = PBXBuildFile; fileRef = 8B28D84EF339436DBD42A203 /* ExpensifyNeue-BoldItalic.otf */; }; F0C450EA2705020500FD2970 /* colors.json in Resources */ = {isa = PBXBuildFile; fileRef = F0C450E92705020500FD2970 /* colors.json */; }; @@ -124,7 +124,7 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( - E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */, + E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */, 5A464BC8112CDB1DE1E38F1C /* libPods-NewExpensify.a in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; @@ -722,9 +722,11 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -738,6 +740,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.dev; PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = expensify_chat_dev; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_dev; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -754,9 +757,11 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -769,6 +774,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.dev; PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = expensify_chat_dev; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_dev; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; @@ -976,6 +982,7 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -989,6 +996,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; PRODUCT_NAME = "New Expensify"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = chat_expensify_appstore; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -1098,6 +1106,7 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -1111,6 +1120,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.adhoc; PRODUCT_NAME = "New Expensify AdHoc"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_adhoc; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -1214,6 +1224,7 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -1226,6 +1237,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; PRODUCT_NAME = "New Expensify"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = chat_expensify_appstore; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; @@ -1326,6 +1338,7 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; + "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -1338,6 +1351,7 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.adhoc; PRODUCT_NAME = "New Expensify AdHoc"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_adhoc; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; diff --git a/ios/tmp.xcconfig b/ios/tmp.xcconfig index 8b137891791f..2f2502669450 100644 --- a/ios/tmp.xcconfig +++ b/ios/tmp.xcconfig @@ -1 +1,9 @@ - +NEW_EXPENSIFY_URL=https:/$()/new.expensify.com/ +SECURE_EXPENSIFY_URL=https:/$()/secure.expensify.com/ +EXPENSIFY_URL=https:/$()/www.expensify.com/ +EXPENSIFY_PARTNER_NAME=chat-expensify-com +EXPENSIFY_PARTNER_PASSWORD=e21965746fd75f82bb66 +PUSHER_APP_KEY=268df511a204fbb60884 +USE_WEB_PROXY=false +ENVIRONMENT=production +SEND_CRASH_REPORTS=true diff --git a/src/components/Icon/Expensicons.js b/src/components/Icon/Expensicons.js index a0c8b72d755a..0eea0ca7398c 100644 --- a/src/components/Icon/Expensicons.js +++ b/src/components/Icon/Expensicons.js @@ -9,6 +9,8 @@ import ArrowRightLong from '../../../assets/images/arrow-right-long.svg'; import ArrowsUpDown from '../../../assets/images/arrows-updown.svg'; import BackArrow from '../../../assets/images/back-left.svg'; import Bank from '../../../assets/images/bank.svg'; +import Bell from '../../../assets/images/bell.svg'; +import BellSlash from '../../../assets/images/bellSlash.svg'; import Bill from '../../../assets/images/bill.svg'; import Bolt from '../../../assets/images/bolt.svg'; import Briefcase from '../../../assets/images/briefcase.svg'; @@ -138,6 +140,8 @@ export { BackArrow, Bank, Bill, + Bell, + BellSlash, Bolt, Briefcase, Bug, diff --git a/src/languages/en.ts b/src/languages/en.ts index 53b9bab98ced..e038acf7a862 100755 --- a/src/languages/en.ts +++ b/src/languages/en.ts @@ -400,6 +400,7 @@ export default { onlyVisible: 'Only visible to', replyInThread: 'Reply in thread', subscribeToThread: 'Subscribe to thread', + unsubscribeFromThread: 'Unsubscribe from thread', flagAsOffensive: 'Flag as offensive', }, emojiReactions: { diff --git a/src/languages/es.ts b/src/languages/es.ts index 4eead6ddc0f3..c577e8f4b7ce 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -391,6 +391,7 @@ export default { onlyVisible: 'Visible sólo para', replyInThread: 'Responder en el hilo', subscribeToThread: 'NEED TO TRANSLATE', + unsubscribeFromThread: 'NEED TO TRANSLATE', flagAsOffensive: 'Marcar como ofensivo', }, emojiReactions: { diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index ecb98548d5e1..4d9b74a5a69f 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -706,6 +706,7 @@ function navigateToAndOpenChildReport(childReportID = '0', parentReportAction = * @param {String} childReportID The reportID we are trying to open * @param {Object} parentReportAction the parent comment of a thread * @param {String} parentReportID The reportID of the parent + * @param {String} prevNotificationPreference The previous notification preference for the child report * */ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0', prevNotificationPreference) { diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 1e603e40a99e..3fd39ddf25c0 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -138,7 +138,7 @@ export default [ if (closePopover) { hideContextMenu(false, () => { ReportActionComposeFocusManager.focus(); - Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', ''), reportAction, reportID); }); return; } @@ -150,22 +150,57 @@ export default [ { isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.subscribeToThread', - icon: Expensicons.Chair, + // textTranslateKey: lodashGet(reportAction, 'childReportNotificationPreference', '0'), + icon: Expensicons.Bell, + successTextTranslateKey: '', + successIcon: null,g + shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { + const subscribed = lodashGet(reportAction, 'childReportNotificationPreference', '') !== "hidden"; + if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { + return false; + } + const isCommentAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.ADDCOMMENT && !ReportUtils.isThreadFirstChat(reportAction, reportID); + const isReportPreviewAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.REPORTPREVIEW; + const isIOUAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.IOU && !ReportActionsUtils.isSplitBillAction(reportAction); + return !subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); + }, + onPress: (closePopover, {reportAction, reportID}) => { + Log.info("sparsisparsi start"); + Log.info(lodashGet(reportAction, 'childReportNotificationPreference', '0')); + Log.info("sparsisparsi done"); + debugger; + // if (closePopover) { + // hideContextMenu(false, () => { + // ReportActionComposeFocusManager.focus(); + // Report.subscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); + // }); + // return; + // } + }, + getDescription: () => {}, + }, + { + isAnonymousAction: false, + textTranslateKey: 'reportActionContextMenu.unsubscribeFromThread', + // textTranslateKey: lodashGet(reportAction, 'childReportNotificationPreference', '0'), + icon: Expensicons.BellSlash, successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { + const subscribed = lodashGet(reportAction, 'childReportNotificationPreference', '0') !== "hidden"; if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } const isCommentAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.ADDCOMMENT && !ReportUtils.isThreadFirstChat(reportAction, reportID); const isReportPreviewAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.REPORTPREVIEW; const isIOUAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.IOU && !ReportActionsUtils.isSplitBillAction(reportAction); - return isCommentAction || isReportPreviewAction || isIOUAction; + return subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); }, onPress: (closePopover, {reportAction, reportID}) => { Log.info("sparsisparsi start"); - Log.info(JSON.stringify(reportAction)); + Log.info(lodashGet(reportAction, 'childReportNotificationPreference', '0')); Log.info("sparsisparsi done"); + debugger; // if (closePopover) { // hideContextMenu(false, () => { // ReportActionComposeFocusManager.focus(); From 800ce65fcb7a954ce6738a111dfa4a62761a4991 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Wed, 11 Oct 2023 18:15:03 +0200 Subject: [PATCH 015/105] [TS migration] Migrate 'KeyboardShortcut' lib to TypeScript --- .../KeyDownPressListener/index.js | 9 - .../KeyDownPressListener/index.native.js | 4 - .../KeyDownPressListener/index.native.ts | 6 + .../KeyDownPressListener/index.ts | 11 + .../KeyDownPressListener/types.ts | 6 + .../bindHandlerToKeydownEvent/index.native.js | 33 --- .../bindHandlerToKeydownEvent/index.native.ts | 28 +++ .../{index.js => index.ts} | 32 +-- .../bindHandlerToKeydownEvent/types.ts | 11 + .../KeyboardShortcut/getKeyEventModifiers.js | 27 --- .../KeyboardShortcut/getKeyEventModifiers.ts | 29 +++ src/libs/KeyboardShortcut/index.js | 170 ---------------- src/libs/KeyboardShortcut/index.ts | 188 ++++++++++++++++++ ...position.js => isEnterWhileComposition.ts} | 8 +- .../ComposerWithSuggestions.js | 8 +- .../modules/react-native-key-command.d.ts | 4 +- src/types/modules/react-native.d.ts | 2 +- 17 files changed, 306 insertions(+), 270 deletions(-) delete mode 100644 src/libs/KeyboardShortcut/KeyDownPressListener/index.js delete mode 100644 src/libs/KeyboardShortcut/KeyDownPressListener/index.native.js create mode 100644 src/libs/KeyboardShortcut/KeyDownPressListener/index.native.ts create mode 100644 src/libs/KeyboardShortcut/KeyDownPressListener/index.ts create mode 100644 src/libs/KeyboardShortcut/KeyDownPressListener/types.ts delete mode 100644 src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.js create mode 100644 src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts rename src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/{index.js => index.ts} (52%) create mode 100644 src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts delete mode 100644 src/libs/KeyboardShortcut/getKeyEventModifiers.js create mode 100644 src/libs/KeyboardShortcut/getKeyEventModifiers.ts delete mode 100644 src/libs/KeyboardShortcut/index.js create mode 100644 src/libs/KeyboardShortcut/index.ts rename src/libs/KeyboardShortcut/{isEnterWhileComposition.js => isEnterWhileComposition.ts} (80%) diff --git a/src/libs/KeyboardShortcut/KeyDownPressListener/index.js b/src/libs/KeyboardShortcut/KeyDownPressListener/index.js deleted file mode 100644 index 4401beef1c59..000000000000 --- a/src/libs/KeyboardShortcut/KeyDownPressListener/index.js +++ /dev/null @@ -1,9 +0,0 @@ -function addKeyDownPressListner(callbackFunction) { - document.addEventListener('keydown', callbackFunction); -} - -function removeKeyDownPressListner(callbackFunction) { - document.removeEventListener('keydown', callbackFunction); -} - -export {addKeyDownPressListner, removeKeyDownPressListner}; diff --git a/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.js b/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.js deleted file mode 100644 index aa1ded824d22..000000000000 --- a/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.js +++ /dev/null @@ -1,4 +0,0 @@ -function addKeyDownPressListner() {} -function removeKeyDownPressListner() {} - -export {addKeyDownPressListner, removeKeyDownPressListner}; diff --git a/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.ts b/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.ts new file mode 100644 index 000000000000..8b460a069f05 --- /dev/null +++ b/src/libs/KeyboardShortcut/KeyDownPressListener/index.native.ts @@ -0,0 +1,6 @@ +import {AddKeyDownPressListener, RemoveKeyDownPressListener} from './types'; + +const addKeyDownPressListener: AddKeyDownPressListener = () => {}; +const removeKeyDownPressListener: RemoveKeyDownPressListener = () => {}; + +export {addKeyDownPressListener, removeKeyDownPressListener}; diff --git a/src/libs/KeyboardShortcut/KeyDownPressListener/index.ts b/src/libs/KeyboardShortcut/KeyDownPressListener/index.ts new file mode 100644 index 000000000000..7e2b2a2ce319 --- /dev/null +++ b/src/libs/KeyboardShortcut/KeyDownPressListener/index.ts @@ -0,0 +1,11 @@ +import type {AddKeyDownPressListener, RemoveKeyDownPressListener} from './types'; + +const addKeyDownPressListener: AddKeyDownPressListener = (callbackFunction) => { + document.addEventListener('keydown', callbackFunction); +}; + +const removeKeyDownPressListener: RemoveKeyDownPressListener = (callbackFunction) => { + document.removeEventListener('keydown', callbackFunction); +}; + +export {addKeyDownPressListener, removeKeyDownPressListener}; diff --git a/src/libs/KeyboardShortcut/KeyDownPressListener/types.ts b/src/libs/KeyboardShortcut/KeyDownPressListener/types.ts new file mode 100644 index 000000000000..1e36051a794d --- /dev/null +++ b/src/libs/KeyboardShortcut/KeyDownPressListener/types.ts @@ -0,0 +1,6 @@ +type KeyDownPressCallback = (event: KeyboardEvent) => void; + +type AddKeyDownPressListener = (callbackFunction: KeyDownPressCallback) => void; +type RemoveKeyDownPressListener = (callbackFunction: KeyDownPressCallback) => void; + +export type {AddKeyDownPressListener, RemoveKeyDownPressListener}; diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.js b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.js deleted file mode 100644 index de59c819c504..000000000000 --- a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.js +++ /dev/null @@ -1,33 +0,0 @@ -import _ from 'underscore'; -import getKeyEventModifiers from '../getKeyEventModifiers'; - -/** - * Checks if an event for that key is configured and if so, runs it. - * @param {Function} getDisplayName - * @param {Object} eventHandlers - * @param {Object} keycommandEvent - * @param {Event} event - * @private - */ -function bindHandlerToKeydownEvent(getDisplayName, eventHandlers, keycommandEvent, event) { - const eventModifiers = getKeyEventModifiers(keycommandEvent); - const displayName = getDisplayName(keycommandEvent.input, eventModifiers); - - // Loop over all the callbacks - _.every(eventHandlers[displayName], (callback) => { - // Determine if the event should bubble before executing the callback (which may have side-effects) - let shouldBubble = callback.shouldBubble || false; - if (_.isFunction(callback.shouldBubble)) { - shouldBubble = callback.shouldBubble(); - } - - if (_.isFunction(callback.callback)) { - callback.callback(event); - } - - // If the event should not bubble, short-circuit the loop - return shouldBubble; - }); -} - -export default bindHandlerToKeydownEvent; diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts new file mode 100644 index 000000000000..d23d558fa1f8 --- /dev/null +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts @@ -0,0 +1,28 @@ +import getKeyEventModifiers from '../getKeyEventModifiers'; +import BindHandlerToKeydownEvent from './types'; + +/** + * Checks if an event for that key is configured and if so, runs it. + */ +const bindHandlerToKeydownEvent: BindHandlerToKeydownEvent = (getDisplayName, eventHandlers, keyCommandEvent, event) => { + const eventModifiers = getKeyEventModifiers(keyCommandEvent); + const displayName = getDisplayName(keyCommandEvent.input, eventModifiers); + + // Loop over all the callbacks + Object.values(eventHandlers[displayName]).every((callback) => { + // Determine if the event should bubble before executing the callback (which may have side-effects) + let shouldBubble: boolean | (() => void) | void = callback.shouldBubble || false; + if (typeof callback.shouldBubble === 'function') { + shouldBubble = callback.shouldBubble(); + } + + if (typeof callback.callback === 'function') { + callback.callback(event); + } + + // If the event should not bubble, short-circuit the loop + return shouldBubble; + }); +}; + +export default bindHandlerToKeydownEvent; diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.js b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts similarity index 52% rename from src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.js rename to src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts index 7b1cb00a408b..8f06c2fe9c2f 100644 --- a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.js +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts @@ -1,44 +1,44 @@ -import _ from 'underscore'; import getKeyEventModifiers from '../getKeyEventModifiers'; import isEnterWhileComposition from '../isEnterWhileComposition'; +import BindHandlerToKeydownEvent from './types'; /** * Checks if an event for that key is configured and if so, runs it. - * @param {Function} getDisplayName - * @param {Object} eventHandlers - * @param {Object} keycommandEvent - * @param {Event} event - * @private */ -function bindHandlerToKeydownEvent(getDisplayName, eventHandlers, keycommandEvent, event) { +const bindHandlerToKeydownEvent: BindHandlerToKeydownEvent = (getDisplayName, eventHandlers, keyCommandEvent, event) => { if (!(event instanceof KeyboardEvent) || isEnterWhileComposition(event)) { return; } - const eventModifiers = getKeyEventModifiers(keycommandEvent); - const displayName = getDisplayName(keycommandEvent.input, eventModifiers); + const eventModifiers = getKeyEventModifiers(keyCommandEvent); + const displayName = getDisplayName(keyCommandEvent.input, eventModifiers); // Loop over all the callbacks - _.every(eventHandlers[displayName], (callback) => { + Object.values(eventHandlers[displayName]).every((callback) => { + const textArea = event.target as HTMLTextAreaElement; + const contentEditable = textArea?.contentEditable; + const nodeName = textArea?.nodeName; + // Early return for excludedNodes - if (_.contains(callback.excludedNodes, event.target.nodeName)) { + if (callback.excludedNodes.includes(nodeName)) { return true; } // If configured to do so, prevent input text control to trigger this event - if (!callback.captureOnInputs && (event.target.nodeName === 'INPUT' || event.target.nodeName === 'TEXTAREA' || event.target.contentEditable === 'true')) { + if (!callback.captureOnInputs && (nodeName === 'INPUT' || nodeName === 'TEXTAREA' || contentEditable === 'true')) { return true; } // Determine if the event should bubble before executing the callback (which may have side-effects) - let shouldBubble = callback.shouldBubble || false; - if (_.isFunction(callback.shouldBubble)) { + let shouldBubble: boolean | (() => void) | void = callback.shouldBubble || false; + if (typeof callback.shouldBubble === 'function') { shouldBubble = callback.shouldBubble(); } - if (_.isFunction(callback.callback)) { + if (typeof callback.callback === 'function') { callback.callback(event); } + if (callback.shouldPreventDefault) { event.preventDefault(); } @@ -46,6 +46,6 @@ function bindHandlerToKeydownEvent(getDisplayName, eventHandlers, keycommandEven // If the event should not bubble, short-circuit the loop return shouldBubble; }); -} +}; export default bindHandlerToKeydownEvent; diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts new file mode 100644 index 000000000000..6a9aefb30676 --- /dev/null +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts @@ -0,0 +1,11 @@ +import type {EventHandler} from '../index'; + +type KeyCommandEvent = {input: string; modifierFlags?: string}; + +type GetDisplayName = (key: string, modifiers: string | string[]) => string; + +type BindHandlerToKeydownEvent = (getDisplayName: GetDisplayName, eventHandlers: Record, keyCommandEvent: KeyCommandEvent, event: KeyboardEvent) => void; + +export default BindHandlerToKeydownEvent; + +export type {KeyCommandEvent}; diff --git a/src/libs/KeyboardShortcut/getKeyEventModifiers.js b/src/libs/KeyboardShortcut/getKeyEventModifiers.js deleted file mode 100644 index 7865d51a0507..000000000000 --- a/src/libs/KeyboardShortcut/getKeyEventModifiers.js +++ /dev/null @@ -1,27 +0,0 @@ -import * as KeyCommand from 'react-native-key-command'; -import lodashGet from 'lodash/get'; - -/** - * Gets modifiers from a keyboard event. - * - * @param {Event} event - * @returns {Array} - */ -function getKeyEventModifiers(event) { - if (event.modifierFlags === lodashGet(KeyCommand, 'constants.keyModifierControl', 'keyModifierControl')) { - return ['CONTROL']; - } - if (event.modifierFlags === lodashGet(KeyCommand, 'constants.keyModifierCommand', 'keyModifierCommand')) { - return ['META']; - } - if (event.modifierFlags === lodashGet(KeyCommand, 'constants.keyModifierShiftControl', 'keyModifierShiftControl')) { - return ['CONTROL', 'Shift']; - } - if (event.modifierFlags === lodashGet(KeyCommand, 'constants.keyModifierShiftCommand', 'keyModifierShiftCommand')) { - return ['META', 'Shift']; - } - - return []; -} - -export default getKeyEventModifiers; diff --git a/src/libs/KeyboardShortcut/getKeyEventModifiers.ts b/src/libs/KeyboardShortcut/getKeyEventModifiers.ts new file mode 100644 index 000000000000..f82de725bb50 --- /dev/null +++ b/src/libs/KeyboardShortcut/getKeyEventModifiers.ts @@ -0,0 +1,29 @@ +import * as KeyCommand from 'react-native-key-command'; +import {KeyCommandEvent} from './bindHandlerToKeydownEvent/types'; + +const keyModifierControl = KeyCommand?.constants.keyModifierControl ?? 'keyModifierControl'; +const keyModifierCommand = KeyCommand?.constants.keyModifierCommand ?? 'keyModifierCommand'; +const keyModifierShiftControl = KeyCommand?.constants.keyModifierShiftControl ?? 'keyModifierShiftControl'; +const keyModifierShiftCommand = KeyCommand?.constants.keyModifierShiftCommand ?? 'keyModifierShiftCommand'; + +/** + * Gets modifiers from a keyboard event. + */ +function getKeyEventModifiers(event: KeyCommandEvent): string[] { + if (event.modifierFlags === keyModifierControl) { + return ['CONTROL']; + } + if (event.modifierFlags === keyModifierCommand) { + return ['META']; + } + if (event.modifierFlags === keyModifierShiftControl) { + return ['CONTROL', 'Shift']; + } + if (event.modifierFlags === keyModifierShiftCommand) { + return ['META', 'Shift']; + } + + return []; +} + +export default getKeyEventModifiers; diff --git a/src/libs/KeyboardShortcut/index.js b/src/libs/KeyboardShortcut/index.js deleted file mode 100644 index f91c81a1b856..000000000000 --- a/src/libs/KeyboardShortcut/index.js +++ /dev/null @@ -1,170 +0,0 @@ -import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; -import * as KeyCommand from 'react-native-key-command'; -import bindHandlerToKeydownEvent from './bindHandlerToKeydownEvent'; -import getOperatingSystem from '../getOperatingSystem'; -import CONST from '../../CONST'; - -const operatingSystem = getOperatingSystem(); - -// Handlers for the various keyboard listeners we set up -const eventHandlers = {}; - -// Documentation information for keyboard shortcuts that are displayed in the keyboard shortcuts informational modal -const documentedShortcuts = {}; - -/** - * @returns {Array} - */ -function getDocumentedShortcuts() { - return _.sortBy(_.values(documentedShortcuts), 'displayName'); -} - -/** - * Generates the normalized display name for keyboard shortcuts. - * - * @param {String} key - * @param {String|Array} modifiers - * @returns {String} - */ -function getDisplayName(key, modifiers) { - let displayName = (() => { - // Type of key is string and the type of KeyCommand.constants.* is number | string. Use _.isEqual to match different types. - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputEnter', 'keyInputEnter').toString().toLowerCase())) { - return ['ENTER']; - } - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputEscape', 'keyInputEscape').toString().toLowerCase())) { - return ['ESCAPE']; - } - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputUpArrow', 'keyInputUpArrow').toString().toLowerCase())) { - return ['ARROWUP']; - } - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputDownArrow', 'keyInputDownArrow').toString().toLowerCase())) { - return ['ARROWDOWN']; - } - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputLeftArrow', 'keyInputLeftArrow').toString().toLowerCase())) { - return ['ARROWLEFT']; - } - if (_.isEqual(key.toLowerCase(), lodashGet(KeyCommand, 'constants.keyInputRightArrow', 'keyInputRightArrow').toString().toLowerCase())) { - return ['ARROWRIGHT']; - } - return [key.toUpperCase()]; - })(); - - if (_.isString(modifiers)) { - displayName.unshift(modifiers); - } else if (_.isArray(modifiers)) { - displayName = [..._.sortBy(modifiers), ...displayName]; - } - - displayName = _.map(displayName, (modifier) => lodashGet(CONST.KEYBOARD_SHORTCUT_KEY_DISPLAY_NAME, modifier.toUpperCase(), modifier)); - - return displayName.join(' + '); -} - -_.each(CONST.KEYBOARD_SHORTCUTS, (shortcut) => { - const shortcutTrigger = lodashGet(shortcut, ['trigger', operatingSystem], lodashGet(shortcut, 'trigger.DEFAULT')); - - // If there is no trigger for the current OS nor a default trigger, then we don't need to do anything - if (!shortcutTrigger) { - return; - } - - KeyCommand.addListener(shortcutTrigger, (keycommandEvent, event) => bindHandlerToKeydownEvent(getDisplayName, eventHandlers, keycommandEvent, event)); -}); - -/** - * Unsubscribes a keyboard event handler. - * - * @param {String} displayName The display name for the key combo to stop watching - * @param {String} callbackID The specific ID given to the callback at the time it was added - * @private - */ -function unsubscribe(displayName, callbackID) { - eventHandlers[displayName] = _.reject(eventHandlers[displayName], (callback) => callback.id === callbackID); - if (_.has(documentedShortcuts, displayName) && _.size(eventHandlers[displayName]) === 0) { - delete documentedShortcuts[displayName]; - } -} - -/** - * Return platform specific modifiers for keys like Control (CMD on macOS) - * - * @param {Array} keys - * @returns {Array} - */ -function getPlatformEquivalentForKeys(keys) { - return _.map(keys, (key) => { - if (!_.has(CONST.PLATFORM_SPECIFIC_KEYS, key)) { - return key; - } - - const platformModifiers = CONST.PLATFORM_SPECIFIC_KEYS[key]; - return lodashGet(platformModifiers, operatingSystem, platformModifiers.DEFAULT || key); - }); -} - -/** - * Subscribes to a keyboard event. - * @param {String} key The key to watch, i.e. 'K' or 'Escape' - * @param {Function} callback The callback to call - * @param {String} descriptionKey Translation key for shortcut description - * @param {Array} [modifiers] Can either be shift or control - * @param {Boolean} [captureOnInputs] Should we capture the event on inputs too? - * @param {Boolean|Function} [shouldBubble] Should the event bubble? - * @param {Number} [priority] The position the callback should take in the stack. 0 means top priority, and 1 means less priority than the most recently added. - * @param {Boolean} [shouldPreventDefault] Should call event.preventDefault after callback? - * @param {Array} [excludedNodes] Do not capture key events targeting excluded nodes (i.e. do not prevent default and let the event bubble) - * @returns {Function} clean up method - */ -function subscribe(key, callback, descriptionKey, modifiers = 'shift', captureOnInputs = false, shouldBubble = false, priority = 0, shouldPreventDefault = true, excludedNodes = []) { - const platformAdjustedModifiers = getPlatformEquivalentForKeys(modifiers); - const displayName = getDisplayName(key, platformAdjustedModifiers); - if (!_.has(eventHandlers, displayName)) { - eventHandlers[displayName] = []; - } - - const callbackID = Str.guid(); - eventHandlers[displayName].splice(priority, 0, { - id: callbackID, - callback, - captureOnInputs, - shouldPreventDefault, - shouldBubble, - excludedNodes, - }); - - if (descriptionKey) { - documentedShortcuts[displayName] = { - shortcutKey: key, - descriptionKey, - displayName, - modifiers, - }; - } - - return () => unsubscribe(displayName, callbackID); -} - -/** - * This module configures a global keyboard event handler. - * - * It uses a stack to store event handlers for each key combination. Some additional details: - * - * - By default, new handlers are pushed to the top of the stack. If you pass a >0 priority when subscribing to the key event, - * then the handler will get pushed further down the stack. This means that priority of 0 is higher than priority 1. - * - * - When a key event occurs, we trigger callbacks for that key starting from the top of the stack. - * By default, events do not bubble, and only the handler at the top of the stack will be executed. - * Individual callbacks can be configured with the shouldBubble parameter, to allow the next event handler on the stack execute. - * - * - Each handler has a unique callbackID, so calling the `unsubscribe` function (returned from `subscribe`) will unsubscribe the expected handler, - * regardless of its position in the stack. - */ -const KeyboardShortcut = { - subscribe, - getDocumentedShortcuts, -}; - -export default KeyboardShortcut; diff --git a/src/libs/KeyboardShortcut/index.ts b/src/libs/KeyboardShortcut/index.ts new file mode 100644 index 000000000000..e0da1a2edf15 --- /dev/null +++ b/src/libs/KeyboardShortcut/index.ts @@ -0,0 +1,188 @@ +import Str from 'expensify-common/lib/str'; +import * as KeyCommand from 'react-native-key-command'; +import bindHandlerToKeydownEvent from './bindHandlerToKeydownEvent'; +import getOperatingSystem from '../getOperatingSystem'; +import CONST from '../../CONST'; + +const operatingSystem = getOperatingSystem(); + +type EventHandler = { + id: string; + callback: (event?: KeyboardEvent) => void; + captureOnInputs: boolean; + shouldPreventDefault: boolean; + shouldBubble: boolean | (() => void); + excludedNodes: string[]; +}; + +// Handlers for the various keyboard listeners we set up +const eventHandlers: Record = {}; + +type Shortcut = { + displayName: string; + shortcutKey: string; + descriptionKey: string; + modifiers: string[]; +}; + +// Documentation information for keyboard shortcuts that are displayed in the keyboard shortcuts informational modal +const documentedShortcuts: Record = {}; + +function getDocumentedShortcuts(): Shortcut[] { + return Object.values(documentedShortcuts).sort((a, b) => a.displayName.localeCompare(b.displayName)); +} + +const keyInputEnter = KeyCommand?.constants?.keyInputEnter ?? 'keyInputEnter'; +const keyInputEscape = KeyCommand?.constants?.keyInputEscape ?? 'keyInputEscape'; +const keyInputUpArrow = KeyCommand?.constants?.keyInputUpArrow ?? 'keyInputUpArrow'; +const keyInputDownArrow = KeyCommand?.constants?.keyInputDownArrow ?? 'keyInputDownArrow'; +const keyInputLeftArrow = KeyCommand?.constants?.keyInputLeftArrow ?? 'keyInputLeftArrow'; +const keyInputRightArrow = KeyCommand?.constants?.keyInputRightArrow ?? 'keyInputRightArrow'; + +/** + * Generates the normalized display name for keyboard shortcuts. + */ +function getDisplayName(key: string, modifiers: string | string[]): string { + let displayName = (() => { + // Type of key is string and the type of KeyCommand.constants.* is number | string. + if (key.toLowerCase() === keyInputEnter.toLowerCase()) { + return ['ENTER']; + } + if (key.toLowerCase() === keyInputEscape.toLowerCase()) { + return ['ESCAPE']; + } + if (key.toLowerCase() === keyInputUpArrow.toLowerCase()) { + return ['ARROWUP']; + } + if (key.toLowerCase() === keyInputDownArrow.toLowerCase()) { + return ['ARROWDOWN']; + } + if (key.toLowerCase() === keyInputLeftArrow.toLowerCase()) { + return ['ARROWLEFT']; + } + if (key.toLowerCase() === keyInputRightArrow.toLowerCase()) { + return ['ARROWRIGHT']; + } + return [key.toUpperCase()]; + })(); + + if (typeof modifiers === 'string') { + displayName.unshift(modifiers); + } else if (Array.isArray(modifiers)) { + displayName = [...modifiers.sort(), ...displayName]; + } + + displayName = displayName.map((modifier) => CONST.KEYBOARD_SHORTCUT_KEY_DISPLAY_NAME[modifier.toUpperCase() as keyof typeof CONST.KEYBOARD_SHORTCUT_KEY_DISPLAY_NAME] ?? modifier); + + return displayName.join(' + '); +} + +Object.values(CONST.KEYBOARD_SHORTCUTS).forEach((shortcut) => { + // If there is no trigger for the current OS nor a default trigger, then we don't need to do anything + if (!('trigger' in shortcut)) { + return; + } + + const shortcutTrigger = (operatingSystem && shortcut.trigger[operatingSystem as keyof typeof shortcut.trigger]) ?? shortcut.trigger.DEFAULT; + + KeyCommand.addListener(shortcutTrigger, (keyCommandEvent, event) => bindHandlerToKeydownEvent(getDisplayName, eventHandlers, keyCommandEvent, event)); +}); + +/** + * Unsubscribes a keyboard event handler. + */ +function unsubscribe(displayName: string, callbackID: string) { + eventHandlers[displayName] = eventHandlers[displayName].filter((callback) => callback.id !== callbackID); + if (eventHandlers[displayName]?.length === 0) { + delete documentedShortcuts[displayName]; + } +} + +/** + * Return platform specific modifiers for keys like Control (CMD on macOS) + */ +function getPlatformEquivalentForKeys(keys: string[]): string[] { + return keys.map((key) => { + if (!(key in CONST.PLATFORM_SPECIFIC_KEYS)) { + return key; + } + + const platformModifiers = CONST.PLATFORM_SPECIFIC_KEYS[key as keyof typeof CONST.PLATFORM_SPECIFIC_KEYS]; + return platformModifiers?.[operatingSystem as keyof typeof platformModifiers] ?? platformModifiers.DEFAULT ?? key; + }); +} + +/** + * Subscribes to a keyboard event. + * @param key The key to watch, i.e. 'K' or 'Escape' + * @param callback The callback to call + * @param descriptionKey Translation key for shortcut description + * @param [modifiers] Can either be shift or control + * @param [captureOnInputs] Should we capture the event on inputs too? + * @param [shouldBubble] Should the event bubble? + * @param [priority] The position the callback should take in the stack. 0 means top priority, and 1 means less priority than the most recently added. + * @param [shouldPreventDefault] Should call event.preventDefault after callback? + * @param [excludedNodes] Do not capture key events targeting excluded nodes (i.e. do not prevent default and let the event bubble) + * @returns clean up method + */ +function subscribe( + key: string, + callback: () => void, + descriptionKey: string, + modifiers: string[] = ['shift'], + captureOnInputs = false, + shouldBubble = false, + priority = 0, + shouldPreventDefault = true, + excludedNodes = [], +) { + const platformAdjustedModifiers = getPlatformEquivalentForKeys(modifiers); + const displayName = getDisplayName(key, platformAdjustedModifiers); + if (!eventHandlers[displayName]) { + eventHandlers[displayName] = []; + } + + const callbackID = Str.guid(); + eventHandlers[displayName].splice(priority, 0, { + id: callbackID, + callback, + captureOnInputs, + shouldPreventDefault, + shouldBubble, + excludedNodes, + }); + + if (descriptionKey) { + documentedShortcuts[displayName] = { + shortcutKey: key, + descriptionKey, + displayName, + modifiers, + }; + } + + return () => unsubscribe(displayName, callbackID); +} + +/** + * This module configures a global keyboard event handler. + * + * It uses a stack to store event handlers for each key combination. Some additional details: + * + * - By default, new handlers are pushed to the top of the stack. If you pass a >0 priority when subscribing to the key event, + * then the handler will get pushed further down the stack. This means that priority of 0 is higher than priority 1. + * + * - When a key event occurs, we trigger callbacks for that key starting from the top of the stack. + * By default, events do not bubble, and only the handler at the top of the stack will be executed. + * Individual callbacks can be configured with the shouldBubble parameter, to allow the next event handler on the stack execute. + * + * - Each handler has a unique callbackID, so calling the `unsubscribe` function (returned from `subscribe`) will unsubscribe the expected handler, + * regardless of its position in the stack. + */ +const KeyboardShortcut = { + subscribe, + getDocumentedShortcuts, +}; + +export default KeyboardShortcut; +export type {EventHandler}; diff --git a/src/libs/KeyboardShortcut/isEnterWhileComposition.js b/src/libs/KeyboardShortcut/isEnterWhileComposition.ts similarity index 80% rename from src/libs/KeyboardShortcut/isEnterWhileComposition.js rename to src/libs/KeyboardShortcut/isEnterWhileComposition.ts index 6269440716b5..2a0a2fec110f 100644 --- a/src/libs/KeyboardShortcut/isEnterWhileComposition.js +++ b/src/libs/KeyboardShortcut/isEnterWhileComposition.ts @@ -1,13 +1,12 @@ +import {NativeSyntheticEvent} from 'react-native'; import * as Browser from '../Browser'; import CONST from '../../CONST'; /** * Check if the Enter key was pressed during IME confirmation (i.e. while the text is being composed). * See {@link https://en.wikipedia.org/wiki/Input_method} - * @param {Event} event - * @returns {boolean} */ -const isEnterWhileComposition = (event) => { +const isEnterWhileComposition = (event: KeyboardEvent): boolean => { // if on mobile chrome, the enter key event is never fired when the enter key is pressed while composition. if (Browser.isMobileChrome()) { return false; @@ -18,7 +17,8 @@ const isEnterWhileComposition = (event) => { if (CONST.BROWSER.SAFARI === Browser.getBrowser()) { return event.keyCode === 229; } - return event.key === CONST.KEYBOARD_SHORTCUTS.ENTER.shortcutKey && event.nativeEvent && event.nativeEvent.isComposing; + + return event.key === CONST.KEYBOARD_SHORTCUTS.ENTER.shortcutKey && (event as unknown as NativeSyntheticEvent)?.nativeEvent?.isComposing; }; export default isEnterWhileComposition; diff --git a/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js b/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js index faa710d2cd6b..7284b965de50 100644 --- a/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js +++ b/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js @@ -447,19 +447,19 @@ function ComposerWithSuggestions({ }, []); useEffect(() => { - const unsubscribeNavigationBlur = navigation.addListener('blur', () => KeyDownListener.removeKeyDownPressListner(focusComposerOnKeyPress)); + const unsubscribeNavigationBlur = navigation.addListener('blur', () => KeyDownListener.removeKeyDownPressListener(focusComposerOnKeyPress)); const unsubscribeNavigationFocus = navigation.addListener('focus', () => { - KeyDownListener.addKeyDownPressListner(focusComposerOnKeyPress); + KeyDownListener.addKeyDownPressListener(focusComposerOnKeyPress); setUpComposeFocusManager(); }); - KeyDownListener.addKeyDownPressListner(focusComposerOnKeyPress); + KeyDownListener.addKeyDownPressListener(focusComposerOnKeyPress); setUpComposeFocusManager(); return () => { ReportActionComposeFocusManager.clear(true); - KeyDownListener.removeKeyDownPressListner(focusComposerOnKeyPress); + KeyDownListener.removeKeyDownPressListener(focusComposerOnKeyPress); unsubscribeNavigationBlur(); unsubscribeNavigationFocus(); }; diff --git a/src/types/modules/react-native-key-command.d.ts b/src/types/modules/react-native-key-command.d.ts index f93204891e84..6af989e33814 100644 --- a/src/types/modules/react-native-key-command.d.ts +++ b/src/types/modules/react-native-key-command.d.ts @@ -21,9 +21,9 @@ declare module 'react-native-key-command' { keyModifierAlternate: 'keyModifierAlternate', } as const; - type KeyCommand = {input: string; modifierFlags: string}; + type KeyCommandEvent = {input: string; modifierFlags?: string}; - declare function addListener(keyCommand: KeyCommand, callback: (keycommandEvent: KeyCommand, event: Event) => void): () => void; + declare function addListener(keyCommand: KeyCommandEvent, callback: (keyCommandEvent: KeyCommand, event: KeyboardEvent) => void): () => void; // eslint-disable-next-line import/prefer-default-export export {constants, addListener}; diff --git a/src/types/modules/react-native.d.ts b/src/types/modules/react-native.d.ts index ebe0974db690..b9102dfbb0ff 100644 --- a/src/types/modules/react-native.d.ts +++ b/src/types/modules/react-native.d.ts @@ -3,7 +3,7 @@ import 'react-native'; import {BootSplashModule} from '../../libs/BootSplash/types'; declare module 'react-native' { - interface TextInput { + interface TextI2put { // Typescript type declaration is missing in React Native for setting text selection. setSelection: (start: number, end: number) => void; } From 36ef1c56ec17b86fceddeebf6e50619cb983d2b6 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Wed, 11 Oct 2023 18:18:12 +0200 Subject: [PATCH 016/105] Revert a typo --- src/types/modules/react-native.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/types/modules/react-native.d.ts b/src/types/modules/react-native.d.ts index b9102dfbb0ff..6e75a5a0077b 100644 --- a/src/types/modules/react-native.d.ts +++ b/src/types/modules/react-native.d.ts @@ -3,7 +3,7 @@ import 'react-native'; import {BootSplashModule} from '../../libs/BootSplash/types'; declare module 'react-native' { - interface TextI2put { + interface TextIput { // Typescript type declaration is missing in React Native for setting text selection. setSelection: (start: number, end: number) => void; } From c3df845adfe24f1377d7d9ca03fdb21b476ea566 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Wed, 11 Oct 2023 23:07:57 -0400 Subject: [PATCH 017/105] resolve merge conflicts --- src/pages/home/report/ContextMenu/ContextMenuActions.js | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 01b4e5a64b04..0c2ace646cdb 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -148,13 +148,12 @@ export default [ getDescription: () => {}, }, { -<<<<<<< HEAD isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.subscribeToThread', // textTranslateKey: lodashGet(reportAction, 'childReportNotificationPreference', '0'), icon: Expensicons.Bell, successTextTranslateKey: '', - successIcon: null,g + successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { const subscribed = lodashGet(reportAction, 'childReportNotificationPreference', '') !== "hidden"; if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { @@ -213,10 +212,7 @@ export default [ getDescription: () => {}, }, { - isAnonymousAction: false, -======= isAnonymousAction: true, ->>>>>>> main textTranslateKey: 'reportActionContextMenu.copyURLToClipboard', icon: Expensicons.Copy, successTextTranslateKey: 'reportActionContextMenu.copied', From c2a4275d851ff9b560e389019518ec0025073260 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Thu, 12 Oct 2023 15:57:02 +0200 Subject: [PATCH 018/105] Fix a type x2 --- src/types/modules/react-native.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/types/modules/react-native.d.ts b/src/types/modules/react-native.d.ts index 6e75a5a0077b..ebe0974db690 100644 --- a/src/types/modules/react-native.d.ts +++ b/src/types/modules/react-native.d.ts @@ -3,7 +3,7 @@ import 'react-native'; import {BootSplashModule} from '../../libs/BootSplash/types'; declare module 'react-native' { - interface TextIput { + interface TextInput { // Typescript type declaration is missing in React Native for setting text selection. setSelection: (start: number, end: number) => void; } From 89d24014bd09a8d2930a6e611ba6578706f16b46 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Thu, 12 Oct 2023 18:40:11 +0200 Subject: [PATCH 019/105] Fix android --- src/libs/KeyboardShortcut/index.ts | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/libs/KeyboardShortcut/index.ts b/src/libs/KeyboardShortcut/index.ts index aa8a8b20e563..3109ccda8aaf 100644 --- a/src/libs/KeyboardShortcut/index.ts +++ b/src/libs/KeyboardShortcut/index.ts @@ -32,12 +32,12 @@ function getDocumentedShortcuts(): Shortcut[] { return Object.values(documentedShortcuts).sort((a, b) => a.displayName.localeCompare(b.displayName)); } -const keyInputEnter = KeyCommand?.constants?.keyInputEnter ?? 'keyInputEnter'; -const keyInputEscape = KeyCommand?.constants?.keyInputEscape ?? 'keyInputEscape'; -const keyInputUpArrow = KeyCommand?.constants?.keyInputUpArrow ?? 'keyInputUpArrow'; -const keyInputDownArrow = KeyCommand?.constants?.keyInputDownArrow ?? 'keyInputDownArrow'; -const keyInputLeftArrow = KeyCommand?.constants?.keyInputLeftArrow ?? 'keyInputLeftArrow'; -const keyInputRightArrow = KeyCommand?.constants?.keyInputRightArrow ?? 'keyInputRightArrow'; +const keyInputEnter = KeyCommand?.constants?.keyInputEnter?.toString() ?? 'keyInputEnter'; +const keyInputEscape = KeyCommand?.constants?.keyInputEscape?.toString() ?? 'keyInputEscape'; +const keyInputUpArrow = KeyCommand?.constants?.keyInputUpArrow?.toString() ?? 'keyInputUpArrow'; +const keyInputDownArrow = KeyCommand?.constants?.keyInputDownArrow?.toString() ?? 'keyInputDownArrow'; +const keyInputLeftArrow = KeyCommand?.constants?.keyInputLeftArrow?.toString() ?? 'keyInputLeftArrow'; +const keyInputRightArrow = KeyCommand?.constants?.keyInputRightArrow?.toString() ?? 'keyInputRightArrow'; /** * Generates the normalized display name for keyboard shortcuts. From 9a562e897f3b17f2f75cc2b1d05f5b25b99bc81f Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Fri, 13 Oct 2023 15:28:54 -0700 Subject: [PATCH 020/105] Implement review feedback --- .../DotIndicatorMessageWithClose.js | 23 +++++++++---------- 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/DotIndicatorMessageWithClose.js index 7626a956489f..0f23c3783336 100644 --- a/src/components/DotIndicatorMessageWithClose.js +++ b/src/components/DotIndicatorMessageWithClose.js @@ -11,7 +11,7 @@ import CONST from '../CONST'; import * as StyleUtils from '../styles/StyleUtils'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; import stylePropTypes from '../styles/stylePropTypes'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import useLocalize from '../hooks/useLocalize'; const propTypes = { // The error messages to display @@ -25,8 +25,6 @@ const propTypes = { /** Additional style object for the container */ containerStyles: stylePropTypes, - - ...withLocalizePropTypes, }; const defaultProps = { @@ -35,24 +33,25 @@ const defaultProps = { containerStyles: [], }; -function DotIndicatorMessageWithClose(props) { - if (_.isEmpty(props.messages)) { +function DotIndicatorMessageWithClose({messages, type, onClose, containerStyles}) { + const {translate} = useLocalize(); + if (_.isEmpty(messages)) { return null; } return ( - + - + @@ -65,4 +64,4 @@ DotIndicatorMessageWithClose.propTypes = propTypes; DotIndicatorMessageWithClose.defaultProps = defaultProps; DotIndicatorMessageWithClose.displayName = 'DotIndicatorMessageWithClose'; -export default withLocalize(DotIndicatorMessageWithClose); +export default DotIndicatorMessageWithClose; From e22bd99ba4bead6b9c0df158e174fb2a543657b0 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Mon, 16 Oct 2023 09:46:58 -0700 Subject: [PATCH 021/105] Show message about users added by primary login --- .../SelectionList/BaseSelectionList.js | 2 ++ .../SelectionList/selectionListPropTypes.js | 3 +++ src/pages/workspace/WorkspaceMembersPage.js | 16 ++++++++++++++++ 3 files changed, 21 insertions(+) diff --git a/src/components/SelectionList/BaseSelectionList.js b/src/components/SelectionList/BaseSelectionList.js index fdb1f92ca73b..0878e404aafe 100644 --- a/src/components/SelectionList/BaseSelectionList.js +++ b/src/components/SelectionList/BaseSelectionList.js @@ -48,6 +48,7 @@ function BaseSelectionList({ headerMessage = '', confirmButtonText = '', onConfirm, + headerContent, footerContent, showScrollIndicator = false, showLoadingPlaceholder = false, @@ -389,6 +390,7 @@ function BaseSelectionList({ {headerMessage} )} + {Boolean(headerContent) && headerContent} {flattenedSections.allOptions.length === 0 && showLoadingPlaceholder ? ( ) : ( diff --git a/src/components/SelectionList/selectionListPropTypes.js b/src/components/SelectionList/selectionListPropTypes.js index e75335e39b23..58aecb0da1a1 100644 --- a/src/components/SelectionList/selectionListPropTypes.js +++ b/src/components/SelectionList/selectionListPropTypes.js @@ -174,6 +174,9 @@ const propTypes = { /** A ref to forward to the TextInput */ inputRef: PropTypes.oneOfType([PropTypes.object]), + /** Custom content to display in the header */ + headerContent: PropTypes.oneOfType([PropTypes.func, PropTypes.node]), + /** Custom content to display in the footer */ footerContent: PropTypes.oneOfType([PropTypes.func, PropTypes.node]), }; diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index e0e818ba90d6..120d818fcd20 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -262,6 +262,7 @@ function WorkspaceMembersPage(props) { const currentUserLogin = lodashGet(props.currentUserPersonalDetails, 'login'); const policyID = lodashGet(props.route, 'params.policyID'); const policyName = lodashGet(props.policy, 'name'); + const invitedPrimaryToSecondaryLogins = _.invert(props.policy.primaryLoginsInvited); const getMemberOptions = () => { let result = []; @@ -354,6 +355,20 @@ function WorkspaceMembersPage(props) { return searchValue.trim() && !data.length ? props.translate('workspace.common.memberNotFound') : ''; }; + const getHeaderContent = () => { + if (_.isEmpty(invitedPrimaryToSecondaryLogins)) { + return null; + } + return ( + Policy.dismissAddedWithPrimaryMessages(policyID)} + /> + ); + }; + return ( toggleUser(item.keyForList)} onSelectAll={() => toggleAllUsers(data)} onDismissError={dismissError} From 6e747221a7e920e7e5ec8fe4670574c5dc488402 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 03:06:31 -0400 Subject: [PATCH 022/105] re-add functionality --- src/libs/actions/Report.js | 2 +- .../report/ContextMenu/ContextMenuActions.js | 50 ++++++++++--------- 2 files changed, 27 insertions(+), 25 deletions(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index af052c717425..c9ab02f127f4 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1351,7 +1351,7 @@ function updateNotificationPreference(reportID, previousValue, newValue, navigat function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0', prevNotificationPreference) { if (childReportID !== '0') { openReport(childReportID); - if (prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN) { + if (!prevNotificationPreference || prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN) { updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false) } else { updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false) diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 0c2ace646cdb..468c06326064 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -155,7 +155,8 @@ export default [ successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { - const subscribed = lodashGet(reportAction, 'childReportNotificationPreference', '') !== "hidden"; + const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + const subscribed = childReportNotificationPreference && (childReportNotificationPreference !== "hidden"); if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } @@ -165,17 +166,17 @@ export default [ return !subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); }, onPress: (closePopover, {reportAction, reportID}) => { - Log.info("sparsisparsi start"); - Log.info(lodashGet(reportAction, 'childReportNotificationPreference', '0')); - Log.info("sparsisparsi done"); - debugger; - // if (closePopover) { - // hideContextMenu(false, () => { - // ReportActionComposeFocusManager.focus(); - // Report.subscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); - // }); - // return; - // } + const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (closePopover) { + hideContextMenu(false, () => { + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); + }); + return; + } else { + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); + } }, getDescription: () => {}, }, @@ -187,7 +188,8 @@ export default [ successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { - const subscribed = lodashGet(reportAction, 'childReportNotificationPreference', '0') !== "hidden"; + const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + const subscribed = childReportNotificationPreference && (childReportNotificationPreference !== "hidden"); if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } @@ -197,17 +199,17 @@ export default [ return subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); }, onPress: (closePopover, {reportAction, reportID}) => { - Log.info("sparsisparsi start"); - Log.info(lodashGet(reportAction, 'childReportNotificationPreference', '0')); - Log.info("sparsisparsi done"); - debugger; - // if (closePopover) { - // hideContextMenu(false, () => { - // ReportActionComposeFocusManager.focus(); - // Report.subscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); - // }); - // return; - // } + const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (closePopover) { + hideContextMenu(false, () => { + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); + }); + return; + } else { + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); + } }, getDescription: () => {}, }, From bad56feb0f2c0e2a618a90eab0c29dca631835c2 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 03:17:37 -0400 Subject: [PATCH 023/105] lint --- assets/images/bell.svg | 7 +++++-- assets/images/bellSlash.svg | 7 +++++-- src/libs/actions/Report.js | 4 ++-- .../report/ContextMenu/ContextMenuActions.js | 20 ++++++++----------- 4 files changed, 20 insertions(+), 18 deletions(-) diff --git a/assets/images/bell.svg b/assets/images/bell.svg index a53c9508cbd6..6ba600dc695b 100644 --- a/assets/images/bell.svg +++ b/assets/images/bell.svg @@ -1,3 +1,6 @@ - - + + + + diff --git a/assets/images/bellSlash.svg b/assets/images/bellSlash.svg index 2cacb07f4268..488acc4de05e 100644 --- a/assets/images/bellSlash.svg +++ b/assets/images/bellSlash.svg @@ -1,3 +1,6 @@ - - + + + + diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index c9ab02f127f4..d7c8be68977c 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1352,9 +1352,9 @@ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = if (childReportID !== '0') { openReport(childReportID); if (!prevNotificationPreference || prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN) { - updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false) + updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false); } else { - updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false) + updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false); } } else { const participantAccountIDs = _.uniq([currentUserAccountID, Number(parentReportAction.actorAccountID)]); diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 468c06326064..ba5c274ed59a 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -22,10 +22,6 @@ import MiniQuickEmojiReactions from '../../../../components/Reactions/MiniQuickE import Navigation from '../../../../libs/Navigation/Navigation'; import ROUTES from '../../../../ROUTES'; import * as Task from '../../../../libs/actions/Task'; -import * as Localize from '../../../../libs/Localize'; -import * as TransactionUtils from '../../../../libs/TransactionUtils'; -import * as CurrencyUtils from '../../../../libs/CurrencyUtils'; -import Log from '../../../../libs/Log'; /** * Gets the HTML version of the message in an action. @@ -156,7 +152,7 @@ export default [ successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); - const subscribed = childReportNotificationPreference && (childReportNotificationPreference !== "hidden"); + const subscribed = childReportNotificationPreference && childReportNotificationPreference !== 'hidden'; if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } @@ -173,10 +169,10 @@ export default [ Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }); return; - } else { - ReportActionComposeFocusManager.focus(); - Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); } + + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }, getDescription: () => {}, }, @@ -189,7 +185,7 @@ export default [ successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); - const subscribed = childReportNotificationPreference && (childReportNotificationPreference !== "hidden"); + const subscribed = childReportNotificationPreference && childReportNotificationPreference !== 'hidden'; if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } @@ -206,10 +202,10 @@ export default [ Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }); return; - } else { - ReportActionComposeFocusManager.focus(); - Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); } + + ReportActionComposeFocusManager.focus(); + Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }, getDescription: () => {}, }, From f016bb803da86d178715ce4d8179e5b999606641 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 03:23:22 -0400 Subject: [PATCH 024/105] prettier --- src/pages/home/report/ContextMenu/ContextMenuActions.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index ba5c274ed59a..8006cd3e3f29 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -170,7 +170,7 @@ export default [ }); return; } - + ReportActionComposeFocusManager.focus(); Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }, @@ -203,7 +203,7 @@ export default [ }); return; } - + ReportActionComposeFocusManager.focus(); Report.toggleSubscribeToChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID, childReportNotificationPreference); }, From b022e3238b7cf3cc50eeb56ff85987fc592d1e24 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Tue, 17 Oct 2023 14:56:35 +0200 Subject: [PATCH 025/105] [TS migration] Migrate 'SignInPageForm' component to TypeScript --- src/components/SignInPageForm/index.native.js | 10 ---------- src/components/SignInPageForm/index.native.tsx | 12 ++++++++++++ .../SignInPageForm/{index.js => index.tsx} | 11 ++++++----- src/components/SignInPageForm/types.ts | 5 +++++ 4 files changed, 23 insertions(+), 15 deletions(-) delete mode 100644 src/components/SignInPageForm/index.native.js create mode 100644 src/components/SignInPageForm/index.native.tsx rename src/components/SignInPageForm/{index.js => index.tsx} (80%) create mode 100644 src/components/SignInPageForm/types.ts diff --git a/src/components/SignInPageForm/index.native.js b/src/components/SignInPageForm/index.native.js deleted file mode 100644 index acd1dfe0d197..000000000000 --- a/src/components/SignInPageForm/index.native.js +++ /dev/null @@ -1,10 +0,0 @@ -import React from 'react'; -import FormElement from '../FormElement'; - -function Form(props) { - // eslint-disable-next-line react/jsx-props-no-spreading - return ; -} - -Form.displayName = 'Form'; -export default Form; diff --git a/src/components/SignInPageForm/index.native.tsx b/src/components/SignInPageForm/index.native.tsx new file mode 100644 index 000000000000..487822c62de9 --- /dev/null +++ b/src/components/SignInPageForm/index.native.tsx @@ -0,0 +1,12 @@ +import React from 'react'; +import FormElement from '../FormElement'; +import SignInPageFormProps from './types'; + +function SignInPageForm(props: SignInPageFormProps) { + // eslint-disable-next-line react/jsx-props-no-spreading + return ; +} + +SignInPageForm.displayName = 'SignInPageForm'; + +export default SignInPageForm; diff --git a/src/components/SignInPageForm/index.js b/src/components/SignInPageForm/index.tsx similarity index 80% rename from src/components/SignInPageForm/index.js rename to src/components/SignInPageForm/index.tsx index 5a1e5a62ff23..fd415dbbd930 100644 --- a/src/components/SignInPageForm/index.js +++ b/src/components/SignInPageForm/index.tsx @@ -1,14 +1,15 @@ import React, {useEffect, useRef} from 'react'; import FormElement from '../FormElement'; +import SignInPageFormProps from './types'; -const preventFormDefault = (event) => { +const preventFormDefault = (event: SubmitEvent) => { // When enter is pressed form is submitted to action url (POST /). // As we are using controlled component, we need to disable it here. event.preventDefault(); }; -function Form(props) { - const form = useRef(null); +function SignInPageForm(props: SignInPageFormProps) { + const form = useRef(null); useEffect(() => { const formCurrent = form.current; @@ -42,6 +43,6 @@ function Form(props) { ); } -Form.displayName = 'Form'; +SignInPageForm.displayName = 'SignInPageForm'; -export default Form; +export default SignInPageForm; diff --git a/src/components/SignInPageForm/types.ts b/src/components/SignInPageForm/types.ts new file mode 100644 index 000000000000..02d948f917b9 --- /dev/null +++ b/src/components/SignInPageForm/types.ts @@ -0,0 +1,5 @@ +import {ViewProps} from 'react-native'; + +type SignInPageFormProps = ViewProps; + +export default SignInPageFormProps; From cac1f47ec4628b6c5d209b74308e94b9b1345e20 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Tue, 17 Oct 2023 08:44:20 -0700 Subject: [PATCH 026/105] Use a more simple component name --- src/components/DotIndicatorMessageWithClose.js | 10 +++++----- src/components/OfflineWithFeedback.js | 4 ++-- src/pages/workspace/WorkspaceMembersPage.js | 4 ++-- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/DotIndicatorMessageWithClose.js index 0f23c3783336..37366ce5a442 100644 --- a/src/components/DotIndicatorMessageWithClose.js +++ b/src/components/DotIndicatorMessageWithClose.js @@ -33,7 +33,7 @@ const defaultProps = { containerStyles: [], }; -function DotIndicatorMessageWithClose({messages, type, onClose, containerStyles}) { +function MessagesRow({messages, type, onClose, containerStyles}) { const {translate} = useLocalize(); if (_.isEmpty(messages)) { return null; @@ -60,8 +60,8 @@ function DotIndicatorMessageWithClose({messages, type, onClose, containerStyles} ); } -DotIndicatorMessageWithClose.propTypes = propTypes; -DotIndicatorMessageWithClose.defaultProps = defaultProps; -DotIndicatorMessageWithClose.displayName = 'DotIndicatorMessageWithClose'; +MessagesRow.propTypes = propTypes; +MessagesRow.defaultProps = defaultProps; +MessagesRow.displayName = 'MessagesRow'; -export default DotIndicatorMessageWithClose; +export default MessagesRow; diff --git a/src/components/OfflineWithFeedback.js b/src/components/OfflineWithFeedback.js index e0f0de5df6d7..23b0facf8366 100644 --- a/src/components/OfflineWithFeedback.js +++ b/src/components/OfflineWithFeedback.js @@ -7,7 +7,7 @@ import stylePropTypes from '../styles/stylePropTypes'; import styles from '../styles/styles'; import * as StyleUtils from '../styles/StyleUtils'; import shouldRenderOffscreen from '../libs/shouldRenderOffscreen'; -import DotIndicatorMessageWithClose from './DotIndicatorMessageWithClose'; +import MessagesRow from './MessagesRow'; import useNetwork from '../hooks/useNetwork'; /** @@ -118,7 +118,7 @@ function OfflineWithFeedback(props) { )} {props.shouldShowErrorMessages && hasErrorMessages && ( - Date: Tue, 17 Oct 2023 08:58:27 -0700 Subject: [PATCH 027/105] Woops, rename file too --- .../{DotIndicatorMessageWithClose.js => MessagesRow.js} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename src/components/{DotIndicatorMessageWithClose.js => MessagesRow.js} (100%) diff --git a/src/components/DotIndicatorMessageWithClose.js b/src/components/MessagesRow.js similarity index 100% rename from src/components/DotIndicatorMessageWithClose.js rename to src/components/MessagesRow.js From 3b928cb9e56d823614710239336e5082d6717086 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Tue, 17 Oct 2023 09:27:53 -0700 Subject: [PATCH 028/105] WIP display invited secondary login below member --- src/components/SelectionList/UserListItem.js | 5 +++++ src/pages/workspace/WorkspaceMembersPage.js | 3 +++ 2 files changed, 8 insertions(+) diff --git a/src/components/SelectionList/UserListItem.js b/src/components/SelectionList/UserListItem.js index 436ae8cb056b..faef86b68aed 100644 --- a/src/components/SelectionList/UserListItem.js +++ b/src/components/SelectionList/UserListItem.js @@ -6,8 +6,10 @@ import Text from '../Text'; import {userListItemPropTypes} from './selectionListPropTypes'; import Tooltip from '../Tooltip'; import SubscriptAvatar from '../SubscriptAvatar'; +import useLocalize from '../../hooks/useLocalize'; function UserListItem({item, isFocused = false, showTooltip}) { + const {translate} = useLocalize(); return ( <> {Boolean(item.icons) && ( @@ -42,6 +44,9 @@ function UserListItem({item, isFocused = false, showTooltip}) { )} + {Boolean(item.invitedSecondaryLogin) && ( + {translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})} + )} {Boolean(item.rightElement) && item.rightElement} diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index 2bd045a12e5d..769e5b07ea0e 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -339,6 +339,9 @@ function WorkspaceMembersPage(props) { ], errors: policyMember.errors, pendingAction: policyMember.pendingAction, + + // Note which secondary login was used to invite this primary login + invitedSecondaryLogin: invitedPrimaryToSecondaryLogins[details.login] || '', }); }); From 9beba29d8cd3fbc95723ae061aa9e99dba9ed519 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 18:36:18 -0400 Subject: [PATCH 029/105] pass in prev notification preference --- src/libs/actions/Report.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index d7c8be68977c..96975d9b2383 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1352,9 +1352,9 @@ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = if (childReportID !== '0') { openReport(childReportID); if (!prevNotificationPreference || prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN) { - updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false); + updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false); } else { - updateNotificationPreference(childReportID, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false); + updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false); } } else { const participantAccountIDs = _.uniq([currentUserAccountID, Number(parentReportAction.actorAccountID)]); From 341d267aff9c5c1ec9fa86832cb2c226c6434c38 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 21:33:38 -0400 Subject: [PATCH 030/105] update notification preferences optimistically --- src/libs/actions/Report.js | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 96975d9b2383..223ee41a5991 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1311,8 +1311,10 @@ function saveReportActionDraftNumberOfLines(reportID, reportActionID, numberOfLi * @param {String} previousValue * @param {String} newValue * @param {boolean} navigate + * @param {String} parentReportID + * @param {String} parentReportActionID */ -function updateNotificationPreference(reportID, previousValue, newValue, navigate) { +function updateNotificationPreference(reportID, previousValue, newValue, navigate, parentReportID = 0, parentReportActionID = 0) { if (previousValue === newValue) { if (navigate) { Navigation.goBack(ROUTES.REPORT_SETTINGS.getRoute(reportID)); @@ -1333,7 +1335,23 @@ function updateNotificationPreference(reportID, previousValue, newValue, navigat value: {notificationPreference: previousValue}, }, ]; - API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue}, {optimisticData, failureData}); + if (parentReportID && parentReportActionID) { + optimisticData.push( + { + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, + value: {[parentReportActionID] : {childReportNotificationPreference: newValue}}, + } + ); + failureData.push( + { + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, + value: {[parentReportActionID] : {childReportNotificationPreference: previousValue}}, + } + ) + } + API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue, parentReportID, parentReportActionID}, {optimisticData, failureData}); if (navigate) { Navigation.goBack(ROUTES.REPORT_SETTINGS.getRoute(reportID)); } @@ -1351,10 +1369,11 @@ function updateNotificationPreference(reportID, previousValue, newValue, navigat function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = {}, parentReportID = '0', prevNotificationPreference) { if (childReportID !== '0') { openReport(childReportID); + const parentReportActionID = lodashGet(parentReportAction, 'reportActionID', '0'); if (!prevNotificationPreference || prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN) { - updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false); + updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false, parentReportID, parentReportActionID); } else { - updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false); + updateNotificationPreference(childReportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN, false, parentReportID, parentReportActionID); } } else { const participantAccountIDs = _.uniq([currentUserAccountID, Number(parentReportAction.actorAccountID)]); From e6851b38c971df65cf722272100efcad5cfc3a7d Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 22:30:28 -0400 Subject: [PATCH 031/105] prettier --- src/libs/actions/Report.js | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 223ee41a5991..8506807a0fff 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1336,20 +1336,16 @@ function updateNotificationPreference(reportID, previousValue, newValue, navigat }, ]; if (parentReportID && parentReportActionID) { - optimisticData.push( - { - onyxMethod: Onyx.METHOD.MERGE, - key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, - value: {[parentReportActionID] : {childReportNotificationPreference: newValue}}, - } - ); - failureData.push( - { - onyxMethod: Onyx.METHOD.MERGE, - key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, - value: {[parentReportActionID] : {childReportNotificationPreference: previousValue}}, - } - ) + optimisticData.push({ + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, + value: {[parentReportActionID]: {childReportNotificationPreference: newValue}}, + }); + failureData.push({ + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${parentReportID}`, + value: {[parentReportActionID]: {childReportNotificationPreference: previousValue}}, + }); } API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue, parentReportID, parentReportActionID}, {optimisticData, failureData}); if (navigate) { From d30f297412c3450f1175c5e2cdf4d58f50fcac60 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Tue, 17 Oct 2023 22:42:38 -0400 Subject: [PATCH 032/105] update notification preference on new reports --- src/libs/actions/Report.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 8506807a0fff..6dd66d570450 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1391,7 +1391,7 @@ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = const participantLogins = PersonalDetailsUtils.getLoginsByAccountIDs(newChat.participantAccountIDs); openReport(newChat.reportID, participantLogins, newChat, parentReportAction.reportActionID); - Navigation.navigate(ROUTES.getReportRoute(newChat.reportID)); + updateNotificationPreference(newChat.reportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false, parentReportID, parentReportAction.reportActionID); } } From f9c66e185ccf95ef0ac17c5f9fb1e36f0ed7c77f Mon Sep 17 00:00:00 2001 From: Jayesh Mangwani Date: Wed, 18 Oct 2023 14:46:33 +0530 Subject: [PATCH 033/105] added allOptions to useCallback dependencies --- src/components/SelectionList/BaseSelectionList.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/SelectionList/BaseSelectionList.js b/src/components/SelectionList/BaseSelectionList.js index fdb1f92ca73b..685c6cb7c0d4 100644 --- a/src/components/SelectionList/BaseSelectionList.js +++ b/src/components/SelectionList/BaseSelectionList.js @@ -176,7 +176,7 @@ function BaseSelectionList({ // If we don't disable dependencies here, we would need to make sure that the `sections` prop is stable in every usage of this component. // eslint-disable-next-line react-hooks/exhaustive-deps - }, []); + }, [flattenedSections.allOptions]); /** * Logic to run when a row is selected, either with click/press or keyboard hotkeys. From a5980135dbb4175fcae978585e272fb26a9bfe93 Mon Sep 17 00:00:00 2001 From: Jayesh Mangwani Date: Wed, 18 Oct 2023 15:13:48 +0530 Subject: [PATCH 034/105] fix: prettier diff detected --- .../SelectionList/BaseSelectionList.js | 41 ++++++++++--------- 1 file changed, 22 insertions(+), 19 deletions(-) diff --git a/src/components/SelectionList/BaseSelectionList.js b/src/components/SelectionList/BaseSelectionList.js index 685c6cb7c0d4..47a947bc2db5 100644 --- a/src/components/SelectionList/BaseSelectionList.js +++ b/src/components/SelectionList/BaseSelectionList.js @@ -152,31 +152,34 @@ function BaseSelectionList({ * @param {Number} index - the index of the item to scroll to * @param {Boolean} animated - whether to animate the scroll */ - const scrollToIndex = useCallback((index, animated = true) => { - const item = flattenedSections.allOptions[index]; + const scrollToIndex = useCallback( + (index, animated = true) => { + const item = flattenedSections.allOptions[index]; - if (!listRef.current || !item) { - return; - } + if (!listRef.current || !item) { + return; + } - const itemIndex = item.index; - const sectionIndex = item.sectionIndex; + const itemIndex = item.index; + const sectionIndex = item.sectionIndex; - // Note: react-native's SectionList automatically strips out any empty sections. - // So we need to reduce the sectionIndex to remove any empty sections in front of the one we're trying to scroll to. - // Otherwise, it will cause an index-out-of-bounds error and crash the app. - let adjustedSectionIndex = sectionIndex; - for (let i = 0; i < sectionIndex; i++) { - if (_.isEmpty(lodashGet(sections, `[${i}].data`))) { - adjustedSectionIndex--; + // Note: react-native's SectionList automatically strips out any empty sections. + // So we need to reduce the sectionIndex to remove any empty sections in front of the one we're trying to scroll to. + // Otherwise, it will cause an index-out-of-bounds error and crash the app. + let adjustedSectionIndex = sectionIndex; + for (let i = 0; i < sectionIndex; i++) { + if (_.isEmpty(lodashGet(sections, `[${i}].data`))) { + adjustedSectionIndex--; + } } - } - listRef.current.scrollToLocation({sectionIndex: adjustedSectionIndex, itemIndex, animated, viewOffset: variables.contentHeaderHeight}); + listRef.current.scrollToLocation({sectionIndex: adjustedSectionIndex, itemIndex, animated, viewOffset: variables.contentHeaderHeight}); - // If we don't disable dependencies here, we would need to make sure that the `sections` prop is stable in every usage of this component. - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [flattenedSections.allOptions]); + // If we don't disable dependencies here, we would need to make sure that the `sections` prop is stable in every usage of this component. + // eslint-disable-next-line react-hooks/exhaustive-deps + }, + [flattenedSections.allOptions], + ); /** * Logic to run when a row is selected, either with click/press or keyboard hotkeys. From db319a7b9114bdbb3b9489def5bcf04051ae57ac Mon Sep 17 00:00:00 2001 From: Jayesh Mangwani Date: Wed, 18 Oct 2023 16:42:26 +0530 Subject: [PATCH 035/105] added sections to scrollToIndex dependencies --- src/components/SelectionList/BaseSelectionList.js | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/components/SelectionList/BaseSelectionList.js b/src/components/SelectionList/BaseSelectionList.js index 47a947bc2db5..a2f3661f0c59 100644 --- a/src/components/SelectionList/BaseSelectionList.js +++ b/src/components/SelectionList/BaseSelectionList.js @@ -174,11 +174,8 @@ function BaseSelectionList({ } listRef.current.scrollToLocation({sectionIndex: adjustedSectionIndex, itemIndex, animated, viewOffset: variables.contentHeaderHeight}); - - // If we don't disable dependencies here, we would need to make sure that the `sections` prop is stable in every usage of this component. - // eslint-disable-next-line react-hooks/exhaustive-deps }, - [flattenedSections.allOptions], + [flattenedSections.allOptions, sections], ); /** From 2ca79c84e1a50d16f53a01e49087e602101d3b86 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 18 Oct 2023 10:17:33 -0700 Subject: [PATCH 036/105] Invited secondary login message row below item --- src/components/SelectionList/BaseListItem.js | 10 ++++++++-- src/components/SelectionList/UserListItem.js | 5 ----- src/styles/utilities/spacing.ts | 4 ++++ 3 files changed, 12 insertions(+), 7 deletions(-) diff --git a/src/components/SelectionList/BaseListItem.js b/src/components/SelectionList/BaseListItem.js index 171a58ee9fa9..497bba20ceb4 100644 --- a/src/components/SelectionList/BaseListItem.js +++ b/src/components/SelectionList/BaseListItem.js @@ -12,6 +12,8 @@ import UserListItem from './UserListItem'; import RadioListItem from './RadioListItem'; import OfflineWithFeedback from '../OfflineWithFeedback'; import CONST from '../../CONST'; +import useLocalize from '../../hooks/useLocalize'; +import Text from '../Text'; function BaseListItem({ item, @@ -23,6 +25,7 @@ function BaseListItem({ onSelectRow, onDismissError = () => {}, }) { + const {translate} = useLocalize(); const isUserItem = lodashGet(item, 'icons.length', 0) > 0; const ListItem = isUserItem ? UserListItem : RadioListItem; @@ -76,7 +79,6 @@ function BaseListItem({ )} - - {!canSelectMultiple && item.isSelected && ( )} + {Boolean(item.invitedSecondaryLogin) && ( + + {translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})} + + )} ); diff --git a/src/components/SelectionList/UserListItem.js b/src/components/SelectionList/UserListItem.js index faef86b68aed..436ae8cb056b 100644 --- a/src/components/SelectionList/UserListItem.js +++ b/src/components/SelectionList/UserListItem.js @@ -6,10 +6,8 @@ import Text from '../Text'; import {userListItemPropTypes} from './selectionListPropTypes'; import Tooltip from '../Tooltip'; import SubscriptAvatar from '../SubscriptAvatar'; -import useLocalize from '../../hooks/useLocalize'; function UserListItem({item, isFocused = false, showTooltip}) { - const {translate} = useLocalize(); return ( <> {Boolean(item.icons) && ( @@ -44,9 +42,6 @@ function UserListItem({item, isFocused = false, showTooltip}) { )} - {Boolean(item.invitedSecondaryLogin) && ( - {translate('workspace.people.invitedBySecondaryLogin', {secondaryLogin: item.invitedSecondaryLogin})} - )} {Boolean(item.rightElement) && item.rightElement} diff --git a/src/styles/utilities/spacing.ts b/src/styles/utilities/spacing.ts index e2b161ca0d62..4d30d9136785 100644 --- a/src/styles/utilities/spacing.ts +++ b/src/styles/utilities/spacing.ts @@ -155,6 +155,10 @@ export default { marginLeft: 32, }, + ml9: { + marginLeft: 36, + }, + ml10: { marginLeft: 40, }, From 81c8c58687a01b43e711c989710fc0e6a1335e5f Mon Sep 17 00:00:00 2001 From: pradeepkumar Date: Thu, 19 Oct 2023 05:01:14 +0530 Subject: [PATCH 037/105] plaid modal opne --- src/ONYXKEYS.ts | 3 +++ src/components/AddPlaidBankAccount.js | 1 + src/components/PlaidLink/index.native.js | 7 ++++++- src/libs/actions/BankAccounts.ts | 7 ++++++- .../ReimbursementAccount/ReimbursementAccountPage.js | 9 +++++++-- 5 files changed, 23 insertions(+), 4 deletions(-) diff --git a/src/ONYXKEYS.ts b/src/ONYXKEYS.ts index c3003699378c..8bf8ba0fc5c5 100755 --- a/src/ONYXKEYS.ts +++ b/src/ONYXKEYS.ts @@ -119,6 +119,9 @@ const ONYXKEYS = { /** Token needed to initialize Plaid link */ PLAID_LINK_TOKEN: 'plaidLinkToken', + /** Capture Plaid event */ + PLAID_CURRENT_EVENT: 'plaidCurrentEvent', + /** Token needed to initialize Onfido */ ONFIDO_TOKEN: 'onfidoToken', diff --git a/src/components/AddPlaidBankAccount.js b/src/components/AddPlaidBankAccount.js index dbe7e46ff6aa..246514f3420a 100644 --- a/src/components/AddPlaidBankAccount.js +++ b/src/components/AddPlaidBankAccount.js @@ -203,6 +203,7 @@ function AddPlaidBankAccount({ Log.hmmm('[PlaidLink] Error: ', error.message); }} onEvent={(event, metadata) => { + BankAccounts.setPlaidEvent(event); // Handle Plaid login errors (will potentially reset plaid token and item depending on the error) if (event === 'ERROR') { Log.hmmm('[PlaidLink] Error: ', metadata); diff --git a/src/components/PlaidLink/index.native.js b/src/components/PlaidLink/index.native.js index 48cd41e283c3..71ed551af235 100644 --- a/src/components/PlaidLink/index.native.js +++ b/src/components/PlaidLink/index.native.js @@ -1,5 +1,5 @@ import {useEffect} from 'react'; -import {openLink, useDeepLinkRedirector, usePlaidEmitter} from 'react-native-plaid-link-sdk'; +import {openLink, useDeepLinkRedirector, usePlaidEmitter, dismissLink} from 'react-native-plaid-link-sdk'; import Log from '../../libs/Log'; import {plaidLinkPropTypes, plaidLinkDefaultProps} from './plaidLinkPropTypes'; @@ -10,6 +10,7 @@ function PlaidLink(props) { props.onEvent(event.eventName, event.metadata); }); useEffect(() => { + props.onEvent('OPEN', {}); openLink({ tokenConfig: { token: props.token, @@ -23,6 +24,10 @@ function PlaidLink(props) { }, }); + return () => { + dismissLink(); + }; + // We generally do not need to include the token as a dependency here as it is only provided once via props and should not change // eslint-disable-next-line react-hooks/exhaustive-deps }, []); diff --git a/src/libs/actions/BankAccounts.ts b/src/libs/actions/BankAccounts.ts index 249d7de9293a..5b56e8321a3f 100644 --- a/src/libs/actions/BankAccounts.ts +++ b/src/libs/actions/BankAccounts.ts @@ -35,7 +35,7 @@ type ReimbursementAccountSubStep = BankAccountSubStep | ''; function clearPlaid(): Promise { Onyx.set(ONYXKEYS.PLAID_LINK_TOKEN, ''); - + Onyx.set(ONYXKEYS.PLAID_CURRENT_EVENT, null); return Onyx.set(ONYXKEYS.PLAID_DATA, PlaidDataProps.plaidDataDefaultProps); } @@ -43,6 +43,10 @@ function openPlaidView() { clearPlaid().then(() => ReimbursementAccount.setBankAccountSubStep(CONST.BANK_ACCOUNT.SETUP_TYPE.PLAID)); } +function setPlaidEvent(eventName: string) { + Onyx.set(ONYXKEYS.PLAID_CURRENT_EVENT, eventName); +} + /** * Open the personal bank account setup flow, with an optional exitReportID to redirect to once the flow is finished. */ @@ -426,6 +430,7 @@ export { clearOnfidoToken, clearPersonalBankAccount, clearPlaid, + setPlaidEvent, openPlaidView, connectBankAccountManually, connectBankAccountWithPlaid, diff --git a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js index a99e3d7332a0..e37058c2a21d 100644 --- a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js +++ b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js @@ -340,6 +340,7 @@ class ReimbursementAccountPage extends React.Component { } if (subStep) { BankAccounts.setBankAccountSubStep(null); + BankAccounts.setPlaidEvent(null); } else { Navigation.goBack(backTo); } @@ -396,8 +397,9 @@ class ReimbursementAccountPage extends React.Component { ); } - - const isLoading = this.props.isLoadingReportData || this.props.account.isLoading || this.props.reimbursementAccount.isLoading; + const isLoading = + (this.props.isLoadingReportData || this.props.account.isLoading || this.props.reimbursementAccount.isLoading) && + (!this.props.plaidCurrentEvent || this.props.plaidCurrentEvent === 'EXIT'); // Prevent the full-page blocking offline view from being displayed for these steps if the device goes offline. const shouldShowOfflineLoader = !( @@ -551,6 +553,9 @@ export default compose( plaidLinkToken: { key: ONYXKEYS.PLAID_LINK_TOKEN, }, + plaidCurrentEvent: { + key: ONYXKEYS.PLAID_CURRENT_EVENT, + }, onfidoToken: { key: ONYXKEYS.ONFIDO_TOKEN, }, From ae942cf4ef3eeebee9363e1a7fb1cccc9cd9aa3a Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 19 Oct 2023 10:58:11 +0700 Subject: [PATCH 038/105] Update request money header title --- src/pages/iou/steps/MoneyRequestConfirmPage.js | 4 ++++ .../MoneyRequestParticipantsPage.js | 16 +++++++++++++--- .../MoneyRequestParticipantsSelector.js | 8 +++++++- 3 files changed, 24 insertions(+), 4 deletions(-) diff --git a/src/pages/iou/steps/MoneyRequestConfirmPage.js b/src/pages/iou/steps/MoneyRequestConfirmPage.js index 46367e275af4..616955e1cd80 100644 --- a/src/pages/iou/steps/MoneyRequestConfirmPage.js +++ b/src/pages/iou/steps/MoneyRequestConfirmPage.js @@ -308,6 +308,10 @@ function MoneyRequestConfirmPage(props) { return props.translate('common.send'); } + if (isScanRequest) { + return props.translate('tabSelector.scan'); + } + return props.translate('tabSelector.manual'); }; diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index 25e41ba78556..fb3799336cc8 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -54,6 +54,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { const isScanRequest = MoneyRequestUtils.isScanRequest(selectedTab); const isSplitRequest = iou.id === CONST.IOU.MONEY_REQUEST_TYPE.SPLIT; const [headerTitle, setHeaderTitle] = useState(); + const [selectedParticipants, setSelectedParticipants] = useState([]); useEffect(() => { if (isDistanceRequest) { @@ -66,10 +67,18 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { return; } - setHeaderTitle(_.isEmpty(iou.participants) ? translate('tabSelector.manual') : translate('iou.split')); - }, [iou.participants, isDistanceRequest, isSendRequest, translate]); + if (isScanRequest) { + setHeaderTitle(translate('tabSelector.scan')); + return; + } + + setHeaderTitle(_.isEmpty(selectedParticipants) ? translate('tabSelector.manual') : translate('iou.split')); + }, [selectedParticipants, isDistanceRequest, translate, isScanRequest]); const navigateToConfirmationStep = (moneyRequestType) => { + if (moneyRequestType === iouType.current) { + setSelectedParticipants([]); + } IOU.setMoneyRequestId(moneyRequestType); Navigation.navigate(ROUTES.MONEY_REQUEST_CONFIRMATION.getRoute(moneyRequestType, reportID.current)); }; @@ -118,7 +127,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { /> (optionsSelectorRef.current = el)} - participants={iou.participants} + participants={selectedParticipants} onAddParticipants={IOU.setMoneyRequestParticipants} navigateToRequest={() => navigateToConfirmationStep(iouType.current)} navigateToSplit={() => navigateToConfirmationStep(CONST.IOU.MONEY_REQUEST_TYPE.SPLIT)} @@ -126,6 +135,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { iouType={iouType.current} isDistanceRequest={isDistanceRequest} isScanRequest={isScanRequest} + setSelectedParticipants={setSelectedParticipants} /> )} diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js index 547d2b7c363a..5a3a5a797946 100755 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js @@ -47,6 +47,9 @@ const propTypes = { /** All of the personal details for everyone */ personalDetails: PropTypes.objectOf(personalDetailsPropType), + /** Callback to request parent modal to go to next step, which should be split */ + setSelectedParticipants: PropTypes.func.isRequired, + /** All reports shared with the user */ reports: PropTypes.objectOf(reportPropTypes), @@ -85,6 +88,7 @@ function MoneyRequestParticipantsSelector({ safeAreaPaddingBottomStyle, iouType, isDistanceRequest, + setSelectedParticipants, }) { const [searchTerm, setSearchTerm] = useState(''); const [newChatOptions, setNewChatOptions] = useState({ @@ -198,9 +202,11 @@ function MoneyRequestParticipantsSelector({ ]; } + setSelectedParticipants(newSelectedOptions); + onAddParticipants(newSelectedOptions); }, - [participants, onAddParticipants], + [participants, onAddParticipants, setSelectedParticipants], ); const headerMessage = OptionsListUtils.getHeaderMessage( From c34e28403dc574b6b5f5a6fffae3c6b5755ae1ba Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 19 Oct 2023 11:24:55 +0700 Subject: [PATCH 039/105] fix lint --- .../MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index fb3799336cc8..9e2f1a3a1f45 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -73,7 +73,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { } setHeaderTitle(_.isEmpty(selectedParticipants) ? translate('tabSelector.manual') : translate('iou.split')); - }, [selectedParticipants, isDistanceRequest, translate, isScanRequest]); + }, [selectedParticipants, isDistanceRequest, translate, isScanRequest, isSendRequest]); const navigateToConfirmationStep = (moneyRequestType) => { if (moneyRequestType === iouType.current) { From 28105ea2ca5838ee6cb9230b836f7fa58636600e Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 19 Oct 2023 03:55:34 -0400 Subject: [PATCH 040/105] restore ios folder from main --- ios/NewExpensify.xcodeproj/project.pbxproj | 18 ++---------------- ios/NewExpensify/Info.plist | 4 ++-- ios/NewExpensifyTests/Info.plist | 4 ++-- ios/Podfile.lock | 14 +++++++------- ios/tmp.xcconfig | 10 +--------- 5 files changed, 14 insertions(+), 36 deletions(-) diff --git a/ios/NewExpensify.xcodeproj/project.pbxproj b/ios/NewExpensify.xcodeproj/project.pbxproj index d1cd2d066833..64ed3fda8b02 100644 --- a/ios/NewExpensify.xcodeproj/project.pbxproj +++ b/ios/NewExpensify.xcodeproj/project.pbxproj @@ -29,7 +29,7 @@ 70CF6E82262E297300711ADC /* BootSplash.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 70CF6E81262E297300711ADC /* BootSplash.storyboard */; }; BDB853621F354EBB84E619C2 /* ExpensifyNewKansas-MediumItalic.otf in Resources */ = {isa = PBXBuildFile; fileRef = D2AFB39EC1D44BF9B91D3227 /* ExpensifyNewKansas-MediumItalic.otf */; }; DD79042B2792E76D004484B4 /* RCTBootSplash.m in Sources */ = {isa = PBXBuildFile; fileRef = DD79042A2792E76D004484B4 /* RCTBootSplash.m */; }; - E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */ = {isa = PBXBuildFile; }; + E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */ = {isa = PBXBuildFile; }; E9DF872D2525201700607FDC /* AirshipConfig.plist in Resources */ = {isa = PBXBuildFile; fileRef = E9DF872C2525201700607FDC /* AirshipConfig.plist */; }; ED222ED90E074A5481A854FA /* ExpensifyNeue-BoldItalic.otf in Resources */ = {isa = PBXBuildFile; fileRef = 8B28D84EF339436DBD42A203 /* ExpensifyNeue-BoldItalic.otf */; }; F0C450EA2705020500FD2970 /* colors.json in Resources */ = {isa = PBXBuildFile; fileRef = F0C450E92705020500FD2970 /* colors.json */; }; @@ -124,7 +124,7 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( - E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */, + E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */, 5A464BC8112CDB1DE1E38F1C /* libPods-NewExpensify.a in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; @@ -722,11 +722,9 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -740,7 +738,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.dev; PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = expensify_chat_dev; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_dev; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -757,11 +754,9 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -774,7 +769,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.dev; PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = expensify_chat_dev; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_dev; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; @@ -982,7 +976,6 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -996,7 +989,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; PRODUCT_NAME = "New Expensify"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = chat_expensify_appstore; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -1106,7 +1098,6 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; ENABLE_BITCODE = NO; INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; IPHONEOS_DEPLOYMENT_TARGET = 13.0; @@ -1120,7 +1111,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.adhoc; PRODUCT_NAME = "New Expensify AdHoc"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_adhoc; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -1224,7 +1214,6 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -1237,7 +1226,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; PRODUCT_NAME = "New Expensify"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = chat_expensify_appstore; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; @@ -1338,7 +1326,6 @@ CODE_SIGN_STYLE = Manual; CURRENT_PROJECT_VERSION = 3; DEVELOPMENT_TEAM = 368M544MTT; - "DEVELOPMENT_TEAM[sdk=iphoneos*]" = 368M544MTT; INFOPLIST_FILE = NewExpensify/Info.plist; IPHONEOS_DEPLOYMENT_TARGET = 13.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; @@ -1351,7 +1338,6 @@ PRODUCT_BUNDLE_IDENTIFIER = com.expensify.chat.adhoc; PRODUCT_NAME = "New Expensify AdHoc"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; - "PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = expensify_chat_adhoc; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; diff --git a/ios/NewExpensify/Info.plist b/ios/NewExpensify/Info.plist index cb04e9c1ef90..8eed7d03e73f 100644 --- a/ios/NewExpensify/Info.plist +++ b/ios/NewExpensify/Info.plist @@ -19,7 +19,7 @@ CFBundlePackageType APPL CFBundleShortVersionString - 1.3.81 + 1.3.87 CFBundleSignature ???? CFBundleURLTypes @@ -40,7 +40,7 @@ CFBundleVersion - 1.3.81.10 + 1.3.87.1 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/ios/NewExpensifyTests/Info.plist b/ios/NewExpensifyTests/Info.plist index e597c10142d8..57b623864549 100644 --- a/ios/NewExpensifyTests/Info.plist +++ b/ios/NewExpensifyTests/Info.plist @@ -15,10 +15,10 @@ CFBundlePackageType BNDL CFBundleShortVersionString - 1.3.81 + 1.3.87 CFBundleSignature ???? CFBundleVersion - 1.3.81.10 + 1.3.87.1 diff --git a/ios/Podfile.lock b/ios/Podfile.lock index 54d0525fd3c9..cb120bca2b88 100644 --- a/ios/Podfile.lock +++ b/ios/Podfile.lock @@ -251,9 +251,9 @@ PODS: - nanopb/encode (= 2.30908.0) - nanopb/decode (2.30908.0) - nanopb/encode (2.30908.0) - - Onfido (27.4.0) - - onfido-react-native-sdk (7.4.0): - - Onfido (= 27.4.0) + - Onfido (28.3.0) + - onfido-react-native-sdk (8.3.0): + - Onfido (~> 28.3.0) - React - OpenSSL-Universal (1.1.1100) - Plaid (4.1.0) @@ -819,7 +819,7 @@ PODS: - SDWebImage/Core (~> 5.10) - SocketRocket (0.6.1) - Turf (2.6.1) - - VisionCamera (2.15.4): + - VisionCamera (2.16.2): - React - React-callinvoker - React-Core @@ -1204,8 +1204,8 @@ SPEC CHECKSUMS: MapboxMaps: af50ec61a7eb3b032c3f7962c6bd671d93d2a209 MapboxMobileEvents: de50b3a4de180dd129c326e09cd12c8adaaa46d6 nanopb: a0ba3315591a9ae0a16a309ee504766e90db0c96 - Onfido: e36f284b865adcf99d9c905590a64ac09d4a576b - onfido-react-native-sdk: 4ecde1a97435dcff9f00a878e3f8d1eb14fabbdc + Onfido: c7d010d9793790d44a07799d9be25aa8e3814ee7 + onfido-react-native-sdk: b346a620af5669f9fecb6dc3052314a35a94ad9f OpenSSL-Universal: ebc357f1e6bc71fa463ccb2fe676756aff50e88c Plaid: 7d340abeadb46c7aa1a91f896c5b22395a31fcf2 PromisesObjC: 09985d6d70fbe7878040aa746d78236e6946d2ef @@ -1287,7 +1287,7 @@ SPEC CHECKSUMS: SDWebImageWebPCoder: 908b83b6adda48effe7667cd2b7f78c897e5111d SocketRocket: f32cd54efbe0f095c4d7594881e52619cfe80b17 Turf: 469ce2c3d22e5e8e4818d5a3b254699a5c89efa4 - VisionCamera: d3ec8883417a6a4a0e3a6ba37d81d22db7611601 + VisionCamera: 95f969b8950b411285579d633a1014782fe0e634 Yoga: 3efc43e0d48686ce2e8c60f99d4e6bd349aff981 YogaKit: f782866e155069a2cca2517aafea43200b01fd5a diff --git a/ios/tmp.xcconfig b/ios/tmp.xcconfig index 2f2502669450..8b137891791f 100644 --- a/ios/tmp.xcconfig +++ b/ios/tmp.xcconfig @@ -1,9 +1 @@ -NEW_EXPENSIFY_URL=https:/$()/new.expensify.com/ -SECURE_EXPENSIFY_URL=https:/$()/secure.expensify.com/ -EXPENSIFY_URL=https:/$()/www.expensify.com/ -EXPENSIFY_PARTNER_NAME=chat-expensify-com -EXPENSIFY_PARTNER_PASSWORD=e21965746fd75f82bb66 -PUSHER_APP_KEY=268df511a204fbb60884 -USE_WEB_PROXY=false -ENVIRONMENT=production -SEND_CRASH_REPORTS=true + From c7a0c606782349385f45fee20cf463b28141787a Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 19 Oct 2023 04:06:21 -0400 Subject: [PATCH 041/105] cleanup changes --- src/languages/es.ts | 120 +++++++++--------- .../report/ContextMenu/ContextMenuActions.js | 4 +- 2 files changed, 61 insertions(+), 63 deletions(-) diff --git a/src/languages/es.ts b/src/languages/es.ts index 5b03ff63438d..1e3ea723288c 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -2,81 +2,81 @@ import CONST from '../CONST'; import * as ReportActionsUtils from '../libs/ReportActionsUtils'; import type { AddressLineParams, - CharacterLimitParams, - MaxParticipantsReachedParams, - ZipCodeExampleFormatParams, - LoggedInAsParams, - NewFaceEnterMagicCodeParams, - WelcomeEnterMagicCodeParams, AlreadySignedInParams, - GoBackMessageParams, - LocalTimeParams, - EditActionParams, - DeleteActionParams, - DeleteConfirmationParams, - BeginningOfChatHistoryDomainRoomPartOneParams, + AmountEachParams, BeginningOfChatHistoryAdminRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartTwo, - WelcomeToRoomParams, - ReportArchiveReasonsClosedParams, - ReportArchiveReasonsMergedParams, - ReportArchiveReasonsRemovedFromPolicyParams, - ReportArchiveReasonsPolicyDeletedParams, - RequestCountParams, - SettleExpensifyCardParams, - RequestAmountParams, - SplitAmountParams, + BeginningOfChatHistoryDomainRoomPartOneParams, + CharacterLimitParams, + ConfirmThatParams, + DateShouldBeAfterParams, + DateShouldBeBeforeParams, + DeleteActionParams, + DeleteConfirmationParams, DidSplitAmountMessageParams, - AmountEachParams, + EditActionParams, + EnglishTranslation, + EnterMagicCodeParams, + FormattedMaxLengthParams, + GoBackMessageParams, + GoToRoomParams, + IncorrectZipFormatParams, + InstantSummaryParams, + LocalTimeParams, + LoggedInAsParams, + ManagerApprovedParams, + MaxParticipantsReachedParams, + NewFaceEnterMagicCodeParams, + NoLongerHaveAccessParams, + NotAllowedExtensionParams, + NotYouParams, + OOOEventSummaryFullDayParams, + OOOEventSummaryPartialDayParams, + OurEmailProviderParams, + PaidElsewhereWithAmountParams, + PaidWithExpensifyWithAmountParams, + ParentNavigationSummaryParams, PayerOwesAmountParams, PayerOwesParams, PayerPaidAmountParams, PayerPaidParams, PayerSettledParams, - WaitingOnBankAccountParams, + RemovedTheRequestParams, + RenamedRoomActionParams, + ReportArchiveReasonsClosedParams, + ReportArchiveReasonsMergedParams, + ReportArchiveReasonsPolicyDeletedParams, + ReportArchiveReasonsRemovedFromPolicyParams, + RequestAmountParams, + RequestCountParams, + RequestedAmountMessageParams, + ResolutionConstraintsParams, + RoomNameReservedErrorParams, + RoomRenamedToParams, + SetTheDistanceParams, + SetTheRequestParams, + SettleExpensifyCardParams, SettledAfterAddedBankAccountParams, - PaidElsewhereWithAmountParams, - PaidWithExpensifyWithAmountParams, + SizeExceededParams, + SplitAmountParams, + StepCounterParams, + TagSelectionParams, ThreadRequestReportNameParams, ThreadSentMoneyReportNameParams, - SizeExceededParams, - ResolutionConstraintsParams, - NotAllowedExtensionParams, - EnterMagicCodeParams, - TransferParams, - InstantSummaryParams, - NotYouParams, - DateShouldBeBeforeParams, - DateShouldBeAfterParams, - IncorrectZipFormatParams, - WeSentYouMagicSignInLinkParams, ToValidateLoginParams, - NoLongerHaveAccessParams, - OurEmailProviderParams, - ConfirmThatParams, + TransferParams, UntilTimeParams, - StepCounterParams, - UserIsAlreadyMemberParams, - GoToRoomParams, - WelcomeNoteParams, - RoomNameReservedErrorParams, - RenamedRoomActionParams, - RoomRenamedToParams, - OOOEventSummaryFullDayParams, - OOOEventSummaryPartialDayParams, - ParentNavigationSummaryParams, - ManagerApprovedParams, - SetTheRequestParams, - SetTheDistanceParams, - UpdatedTheRequestParams, UpdatedTheDistanceParams, - RemovedTheRequestParams, - FormattedMaxLengthParams, - RequestedAmountMessageParams, - TagSelectionParams, - EnglishTranslation, + UpdatedTheRequestParams, + UserIsAlreadyMemberParams, + WaitingOnBankAccountParams, WalletProgramParams, + WeSentYouMagicSignInLinkParams, + WelcomeEnterMagicCodeParams, + WelcomeNoteParams, + WelcomeToRoomParams, + ZipCodeExampleFormatParams, } from './types'; /* eslint-disable max-len */ @@ -417,8 +417,8 @@ export default { deleteConfirmation: ({action}: DeleteConfirmationParams) => `¿Estás seguro de que quieres eliminar este ${ReportActionsUtils.isMoneyRequestAction(action) ? 'pedido' : 'comentario'}`, onlyVisible: 'Visible sólo para', replyInThread: 'Responder en el hilo', - subscribeToThread: 'NEED TO TRANSLATE', - unsubscribeFromThread: 'NEED TO TRANSLATE', + subscribeToThread: 'Suscríbete al hilo', + unsubscribeFromThread: 'Darse de baja del hilo', flagAsOffensive: 'Marcar como ofensivo', }, emojiReactions: { diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 8006cd3e3f29..999f8e9fa26b 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -134,7 +134,7 @@ export default [ if (closePopover) { hideContextMenu(false, () => { ReportActionComposeFocusManager.focus(); - Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', ''), reportAction, reportID); + Report.navigateToAndOpenChildReport(lodashGet(reportAction, 'childReportID', '0'), reportAction, reportID); }); return; } @@ -146,7 +146,6 @@ export default [ { isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.subscribeToThread', - // textTranslateKey: lodashGet(reportAction, 'childReportNotificationPreference', '0'), icon: Expensicons.Bell, successTextTranslateKey: '', successIcon: null, @@ -179,7 +178,6 @@ export default [ { isAnonymousAction: false, textTranslateKey: 'reportActionContextMenu.unsubscribeFromThread', - // textTranslateKey: lodashGet(reportAction, 'childReportNotificationPreference', '0'), icon: Expensicons.BellSlash, successTextTranslateKey: '', successIcon: null, From 8a609fd5b22dd83baf79b48f65e481d02ac25598 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 19 Oct 2023 04:07:45 -0400 Subject: [PATCH 042/105] revert accidental change --- src/languages/es.ts | 116 ++++++++++++++++++++++---------------------- 1 file changed, 58 insertions(+), 58 deletions(-) diff --git a/src/languages/es.ts b/src/languages/es.ts index 1e3ea723288c..0ecff93d2758 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -2,81 +2,81 @@ import CONST from '../CONST'; import * as ReportActionsUtils from '../libs/ReportActionsUtils'; import type { AddressLineParams, + CharacterLimitParams, + MaxParticipantsReachedParams, + ZipCodeExampleFormatParams, + LoggedInAsParams, + NewFaceEnterMagicCodeParams, + WelcomeEnterMagicCodeParams, AlreadySignedInParams, - AmountEachParams, + GoBackMessageParams, + LocalTimeParams, + EditActionParams, + DeleteActionParams, + DeleteConfirmationParams, + BeginningOfChatHistoryDomainRoomPartOneParams, BeginningOfChatHistoryAdminRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartTwo, - BeginningOfChatHistoryDomainRoomPartOneParams, - CharacterLimitParams, - ConfirmThatParams, - DateShouldBeAfterParams, - DateShouldBeBeforeParams, - DeleteActionParams, - DeleteConfirmationParams, + WelcomeToRoomParams, + ReportArchiveReasonsClosedParams, + ReportArchiveReasonsMergedParams, + ReportArchiveReasonsRemovedFromPolicyParams, + ReportArchiveReasonsPolicyDeletedParams, + RequestCountParams, + SettleExpensifyCardParams, + RequestAmountParams, + SplitAmountParams, DidSplitAmountMessageParams, - EditActionParams, - EnglishTranslation, - EnterMagicCodeParams, - FormattedMaxLengthParams, - GoBackMessageParams, - GoToRoomParams, - IncorrectZipFormatParams, - InstantSummaryParams, - LocalTimeParams, - LoggedInAsParams, - ManagerApprovedParams, - MaxParticipantsReachedParams, - NewFaceEnterMagicCodeParams, - NoLongerHaveAccessParams, - NotAllowedExtensionParams, - NotYouParams, - OOOEventSummaryFullDayParams, - OOOEventSummaryPartialDayParams, - OurEmailProviderParams, - PaidElsewhereWithAmountParams, - PaidWithExpensifyWithAmountParams, - ParentNavigationSummaryParams, + AmountEachParams, PayerOwesAmountParams, PayerOwesParams, PayerPaidAmountParams, PayerPaidParams, PayerSettledParams, - RemovedTheRequestParams, - RenamedRoomActionParams, - ReportArchiveReasonsClosedParams, - ReportArchiveReasonsMergedParams, - ReportArchiveReasonsPolicyDeletedParams, - ReportArchiveReasonsRemovedFromPolicyParams, - RequestAmountParams, - RequestCountParams, - RequestedAmountMessageParams, - ResolutionConstraintsParams, - RoomNameReservedErrorParams, - RoomRenamedToParams, - SetTheDistanceParams, - SetTheRequestParams, - SettleExpensifyCardParams, + WaitingOnBankAccountParams, SettledAfterAddedBankAccountParams, - SizeExceededParams, - SplitAmountParams, - StepCounterParams, - TagSelectionParams, + PaidElsewhereWithAmountParams, + PaidWithExpensifyWithAmountParams, ThreadRequestReportNameParams, ThreadSentMoneyReportNameParams, - ToValidateLoginParams, + SizeExceededParams, + ResolutionConstraintsParams, + NotAllowedExtensionParams, + EnterMagicCodeParams, TransferParams, + InstantSummaryParams, + NotYouParams, + DateShouldBeBeforeParams, + DateShouldBeAfterParams, + IncorrectZipFormatParams, + WeSentYouMagicSignInLinkParams, + ToValidateLoginParams, + NoLongerHaveAccessParams, + OurEmailProviderParams, + ConfirmThatParams, UntilTimeParams, - UpdatedTheDistanceParams, - UpdatedTheRequestParams, + StepCounterParams, UserIsAlreadyMemberParams, - WaitingOnBankAccountParams, - WalletProgramParams, - WeSentYouMagicSignInLinkParams, - WelcomeEnterMagicCodeParams, + GoToRoomParams, WelcomeNoteParams, - WelcomeToRoomParams, - ZipCodeExampleFormatParams, + RoomNameReservedErrorParams, + RenamedRoomActionParams, + RoomRenamedToParams, + OOOEventSummaryFullDayParams, + OOOEventSummaryPartialDayParams, + ParentNavigationSummaryParams, + ManagerApprovedParams, + SetTheRequestParams, + SetTheDistanceParams, + UpdatedTheRequestParams, + UpdatedTheDistanceParams, + RemovedTheRequestParams, + FormattedMaxLengthParams, + RequestedAmountMessageParams, + TagSelectionParams, + EnglishTranslation, + WalletProgramParams, } from './types'; /* eslint-disable max-len */ From a691d7eb3b7f121964201387bccce67f3ce594d4 Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Thu, 28 Sep 2023 11:51:21 +0200 Subject: [PATCH 043/105] Migrated Welcome.js to TypeScript. Signed-off-by: Kacper Falat --- src/libs/ReportUtils.js | 2 +- src/libs/actions/Policy.js | 2 +- src/libs/actions/{Welcome.js => Welcome.ts} | 64 ++++++++++++--------- 3 files changed, 39 insertions(+), 29 deletions(-) rename src/libs/actions/{Welcome.js => Welcome.ts} (73%) diff --git a/src/libs/ReportUtils.js b/src/libs/ReportUtils.js index eb512b7927a9..b279c8cfc6f7 100644 --- a/src/libs/ReportUtils.js +++ b/src/libs/ReportUtils.js @@ -363,7 +363,7 @@ function isUserCreatedPolicyRoom(report) { /** * Whether the provided report is a Policy Expense chat. * @param {Object} report - * @param {String} report.chatType + * @param {String} [report.chatType] * @returns {Boolean} */ function isPolicyExpenseChat(report) { diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index 89324dd35485..4696ab2f0649 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -162,7 +162,7 @@ function deleteWorkspace(policyID, reports, policyName) { /** * Is the user an admin of a free policy (aka workspace)? * - * @param {Array} policies + * @param {Record} policies * @returns {Boolean} */ function isAdminOfFreePolicy(policies) { diff --git a/src/libs/actions/Welcome.js b/src/libs/actions/Welcome.ts similarity index 73% rename from src/libs/actions/Welcome.js rename to src/libs/actions/Welcome.ts index 8e1832edb9a7..0c6f69451d1e 100644 --- a/src/libs/actions/Welcome.js +++ b/src/libs/actions/Welcome.ts @@ -1,6 +1,4 @@ import Onyx from 'react-native-onyx'; -import _ from 'underscore'; -import lodashGet from 'lodash/get'; import Navigation from '../Navigation/Navigation'; import * as ReportUtils from '../ReportUtils'; import ROUTES from '../../ROUTES'; @@ -8,15 +6,28 @@ import * as Policy from './Policy'; import ONYXKEYS from '../../ONYXKEYS'; import SCREENS from '../../SCREENS'; import CONST from '../../CONST'; +import Report from '../../types/onyx/Report'; +import OnyxPolicy from "../../types/onyx/Policy"; -let resolveIsReadyPromise; +let resolveIsReadyPromise: (value?: (PromiseLike)) => void; let isReadyPromise = new Promise((resolve) => { resolveIsReadyPromise = resolve; }); -let isFirstTimeNewExpensifyUser; +let isFirstTimeNewExpensifyUser: boolean | undefined; let isLoadingReportData = true; -let currentUserAccountID; +let currentUserAccountID: number | undefined; + +type Route = { + name: string; + params?: {path: string, exitTo?: string, openOnAdminRoom?: boolean}; +}; + +type ShowParams = { + routes: Route[]; + showCreateMenu?: () => void; + showPopoverMenu?: () => boolean; +}; /** * Check that a few requests have completed so that the welcome action can proceed: @@ -26,11 +37,13 @@ let currentUserAccountID; * - Whether we have loaded all reports the server knows about */ function checkOnReady() { - if (!_.isBoolean(isFirstTimeNewExpensifyUser) || isLoadingReportData) { + if (typeof isFirstTimeNewExpensifyUser !== "boolean" || isLoadingReportData) { return; } - resolveIsReadyPromise(); + if(resolveIsReadyPromise) { + resolveIsReadyPromise(); + } } Onyx.connect({ @@ -39,7 +52,7 @@ Onyx.connect({ callback: (val) => { // If isFirstTimeNewExpensifyUser was true do not update it to false. We update it to false inside the Welcome.show logic // More context here https://github.com/Expensify/App/pull/16962#discussion_r1167351359 - if (!isFirstTimeNewExpensifyUser) { + if (val !== null) { isFirstTimeNewExpensifyUser = val; } checkOnReady(); @@ -50,12 +63,15 @@ Onyx.connect({ key: ONYXKEYS.IS_LOADING_REPORT_DATA, initWithStoredValues: false, callback: (val) => { - isLoadingReportData = val; + if(val) + { + isLoadingReportData = val; + } checkOnReady(); }, }); -const allReports = {}; +const allReports: Record = {}; Onyx.connect({ key: ONYXKEYS.COLLECTION.REPORT, initWithStoredValues: false, @@ -68,7 +84,7 @@ Onyx.connect({ }, }); -const allPolicies = {}; +const allPolicies: Record = {}; Onyx.connect({ key: ONYXKEYS.COLLECTION.POLICY, callback: (val, key) => { @@ -98,13 +114,8 @@ Onyx.connect({ /** * Shows a welcome action on first login - * - * @param {Object} params - * @param {Object} params.routes - * @param {Function} [params.showCreateMenu] - * @param {Function} [params.showPopoverMenu] */ -function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => {}}) { +function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false}: ShowParams) { isReadyPromise.then(() => { if (!isFirstTimeNewExpensifyUser) { return; @@ -112,20 +123,19 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => {}}) { // If we are rendering the SidebarScreen at the same time as a workspace route that means we've already created a workspace via workspace/new and should not open the global // create menu right now. We should also stay on the workspace page if that is our destination. - const topRoute = _.last(routes); - const isWorkspaceRoute = topRoute.name === 'Settings' && topRoute.params.path.includes('workspace'); - const transitionRoute = _.find(routes, (route) => route.name === SCREENS.TRANSITION_BETWEEN_APPS); - const exitingToWorkspaceRoute = lodashGet(transitionRoute, 'params.exitTo', '') === 'workspace/new'; - const openOnAdminRoom = lodashGet(topRoute, 'params.openOnAdminRoom', false); - const isDisplayingWorkspaceRoute = isWorkspaceRoute || exitingToWorkspaceRoute; + const topRoute = routes[routes.length - 1] + const isWorkspaceRoute = topRoute.name === 'Settings' && topRoute.params?.path.includes('workspace'); + const transitionRoute = routes.find((route) => route.name === SCREENS.TRANSITION_BETWEEN_APPS); + const exitingToWorkspaceRoute = transitionRoute?.params?.exitTo === 'workspace/new'; + const openOnAdminRoom = topRoute.params?.openOnAdminRoom ?? false; + const isDisplayingWorkspaceRoute = isWorkspaceRoute ?? exitingToWorkspaceRoute; // If we already opened the workspace settings or want the admin room to stay open, do not // navigate away to the workspace chat report const shouldNavigateToWorkspaceChat = !isDisplayingWorkspaceRoute && !openOnAdminRoom; - const workspaceChatReport = _.find( - allReports, - (report) => ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED, + const workspaceChatReport = Object(allReports).values().find((report: Report) => + ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED ); if (workspaceChatReport || openOnAdminRoom) { @@ -138,7 +148,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => {}}) { // If showPopoverMenu exists and returns true then it opened the Popover Menu successfully, and we can update isFirstTimeNewExpensifyUser // so the Welcome logic doesn't run again - if (showPopoverMenu()) { + if (showPopoverMenu && showPopoverMenu()) { isFirstTimeNewExpensifyUser = false; } From 51272573c6b7619615dc61b6d0598e2d4c4fdf5d Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Fri, 29 Sep 2023 09:27:02 +0200 Subject: [PATCH 044/105] Requested changes implemented. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 39 ++++++++++++++++++++----------------- 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 0c6f69451d1e..7a8d64b0e37e 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -1,4 +1,4 @@ -import Onyx from 'react-native-onyx'; +import Onyx, {OnyxCollection, OnyxEntry} from 'react-native-onyx'; import Navigation from '../Navigation/Navigation'; import * as ReportUtils from '../ReportUtils'; import ROUTES from '../../ROUTES'; @@ -9,7 +9,7 @@ import CONST from '../../CONST'; import Report from '../../types/onyx/Report'; import OnyxPolicy from "../../types/onyx/Policy"; -let resolveIsReadyPromise: (value?: (PromiseLike)) => void; +let resolveIsReadyPromise: (value?: (PromiseLike)) => void | undefined; let isReadyPromise = new Promise((resolve) => { resolveIsReadyPromise = resolve; }); @@ -37,23 +37,21 @@ type ShowParams = { * - Whether we have loaded all reports the server knows about */ function checkOnReady() { - if (typeof isFirstTimeNewExpensifyUser !== "boolean" || isLoadingReportData) { + if (isFirstTimeNewExpensifyUser === undefined || isLoadingReportData) { return; } - if(resolveIsReadyPromise) { - resolveIsReadyPromise(); - } + resolveIsReadyPromise?.(); } Onyx.connect({ key: ONYXKEYS.NVP_IS_FIRST_TIME_NEW_EXPENSIFY_USER, initWithStoredValues: false, - callback: (val) => { + callback: (val: OnyxEntry) => { // If isFirstTimeNewExpensifyUser was true do not update it to false. We update it to false inside the Welcome.show logic // More context here https://github.com/Expensify/App/pull/16962#discussion_r1167351359 - if (val !== null) { - isFirstTimeNewExpensifyUser = val; + if (!isFirstTimeNewExpensifyUser) { + isFirstTimeNewExpensifyUser = val ?? undefined; } checkOnReady(); }, @@ -71,7 +69,7 @@ Onyx.connect({ }, }); -const allReports: Record = {}; +const allReports: OnyxCollection = {}; Onyx.connect({ key: ONYXKEYS.COLLECTION.REPORT, initWithStoredValues: false, @@ -84,7 +82,7 @@ Onyx.connect({ }, }); -const allPolicies: Record = {}; +const allPolicies: OnyxCollection = {}; Onyx.connect({ key: ONYXKEYS.COLLECTION.POLICY, callback: (val, key) => { @@ -134,21 +132,26 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} // navigate away to the workspace chat report const shouldNavigateToWorkspaceChat = !isDisplayingWorkspaceRoute && !openOnAdminRoom; - const workspaceChatReport = Object(allReports).values().find((report: Report) => - ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED - ); + const workspaceChatReport = Object.values(allReports ?? {}).find((report) => { + if (report) { + return ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED + } + return false; + }); - if (workspaceChatReport || openOnAdminRoom) { + if (workspaceChatReport ?? openOnAdminRoom) { // This key is only updated when we call ReconnectApp, setting it to false now allows the user to navigate normally instead of always redirecting to the workspace chat Onyx.set(ONYXKEYS.NVP_IS_FIRST_TIME_NEW_EXPENSIFY_USER, false); } if (shouldNavigateToWorkspaceChat && workspaceChatReport) { - Navigation.navigate(ROUTES.REPORT_WITH_ID.getRoute(workspaceChatReport.reportID)); + if (workspaceChatReport.reportID != null) { + Navigation.navigate(ROUTES.REPORT_WITH_ID.getRoute(workspaceChatReport.reportID)); + } // If showPopoverMenu exists and returns true then it opened the Popover Menu successfully, and we can update isFirstTimeNewExpensifyUser // so the Welcome logic doesn't run again - if (showPopoverMenu && showPopoverMenu()) { + if (showPopoverMenu?.()) { isFirstTimeNewExpensifyUser = false; } @@ -157,7 +160,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} // If user is not already an admin of a free policy and we are not navigating them to their workspace or creating a new workspace via workspace/new then // we will show the create menu. - if (!Policy.isAdminOfFreePolicy(allPolicies) && !isDisplayingWorkspaceRoute) { + if (allPolicies && !Policy.isAdminOfFreePolicy(allPolicies) && !isDisplayingWorkspaceRoute) { showCreateMenu(); } From 220991b5d2f67cb96dcc96cff435b0cbe35a065a Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Fri, 29 Sep 2023 09:27:53 +0200 Subject: [PATCH 045/105] Requested changes implemented + prettier. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 7a8d64b0e37e..2c211ef6c117 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -7,9 +7,9 @@ import ONYXKEYS from '../../ONYXKEYS'; import SCREENS from '../../SCREENS'; import CONST from '../../CONST'; import Report from '../../types/onyx/Report'; -import OnyxPolicy from "../../types/onyx/Policy"; +import OnyxPolicy from '../../types/onyx/Policy'; -let resolveIsReadyPromise: (value?: (PromiseLike)) => void | undefined; +let resolveIsReadyPromise: (value?: PromiseLike) => void | undefined; let isReadyPromise = new Promise((resolve) => { resolveIsReadyPromise = resolve; }); @@ -20,7 +20,7 @@ let currentUserAccountID: number | undefined; type Route = { name: string; - params?: {path: string, exitTo?: string, openOnAdminRoom?: boolean}; + params?: {path: string; exitTo?: string; openOnAdminRoom?: boolean}; }; type ShowParams = { @@ -61,8 +61,7 @@ Onyx.connect({ key: ONYXKEYS.IS_LOADING_REPORT_DATA, initWithStoredValues: false, callback: (val) => { - if(val) - { + if (val) { isLoadingReportData = val; } checkOnReady(); @@ -121,7 +120,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} // If we are rendering the SidebarScreen at the same time as a workspace route that means we've already created a workspace via workspace/new and should not open the global // create menu right now. We should also stay on the workspace page if that is our destination. - const topRoute = routes[routes.length - 1] + const topRoute = routes[routes.length - 1]; const isWorkspaceRoute = topRoute.name === 'Settings' && topRoute.params?.path.includes('workspace'); const transitionRoute = routes.find((route) => route.name === SCREENS.TRANSITION_BETWEEN_APPS); const exitingToWorkspaceRoute = transitionRoute?.params?.exitTo === 'workspace/new'; @@ -134,7 +133,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} const workspaceChatReport = Object.values(allReports ?? {}).find((report) => { if (report) { - return ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED + return ReportUtils.isPolicyExpenseChat(report) && report.ownerAccountID === currentUserAccountID && report.statusNum !== CONST.REPORT.STATUS.CLOSED; } return false; }); From c5a2f2b6e56e8c8a89e4874e1b67b480135f7483 Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Fri, 29 Sep 2023 10:50:20 +0200 Subject: [PATCH 046/105] Solved comments. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 2c211ef6c117..2fc5a0553c5e 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -1,4 +1,4 @@ -import Onyx, {OnyxCollection, OnyxEntry} from 'react-native-onyx'; +import Onyx, {OnyxCollection} from 'react-native-onyx'; import Navigation from '../Navigation/Navigation'; import * as ReportUtils from '../ReportUtils'; import ROUTES from '../../ROUTES'; @@ -9,8 +9,8 @@ import CONST from '../../CONST'; import Report from '../../types/onyx/Report'; import OnyxPolicy from '../../types/onyx/Policy'; -let resolveIsReadyPromise: (value?: PromiseLike) => void | undefined; -let isReadyPromise = new Promise((resolve) => { +let resolveIsReadyPromise: (value?: Promise) => void | undefined; +let isReadyPromise = new Promise((resolve) => { resolveIsReadyPromise = resolve; }); @@ -47,7 +47,7 @@ function checkOnReady() { Onyx.connect({ key: ONYXKEYS.NVP_IS_FIRST_TIME_NEW_EXPENSIFY_USER, initWithStoredValues: false, - callback: (val: OnyxEntry) => { + callback: (val) => { // If isFirstTimeNewExpensifyUser was true do not update it to false. We update it to false inside the Welcome.show logic // More context here https://github.com/Expensify/App/pull/16962#discussion_r1167351359 if (!isFirstTimeNewExpensifyUser) { @@ -176,7 +176,7 @@ function resetReadyCheck() { isLoadingReportData = true; } -function serverDataIsReadyPromise() { +function serverDataIsReadyPromise(): Promise { return isReadyPromise; } From 2258f1f5af167705841070e72b11401ebf3ff2bf Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Fri, 29 Sep 2023 11:40:13 +0200 Subject: [PATCH 047/105] Renamed val -> value. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 2fc5a0553c5e..e4ab9caa39bc 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -47,11 +47,11 @@ function checkOnReady() { Onyx.connect({ key: ONYXKEYS.NVP_IS_FIRST_TIME_NEW_EXPENSIFY_USER, initWithStoredValues: false, - callback: (val) => { + callback: (value) => { // If isFirstTimeNewExpensifyUser was true do not update it to false. We update it to false inside the Welcome.show logic // More context here https://github.com/Expensify/App/pull/16962#discussion_r1167351359 if (!isFirstTimeNewExpensifyUser) { - isFirstTimeNewExpensifyUser = val ?? undefined; + isFirstTimeNewExpensifyUser = value ?? undefined; } checkOnReady(); }, @@ -60,9 +60,9 @@ Onyx.connect({ Onyx.connect({ key: ONYXKEYS.IS_LOADING_REPORT_DATA, initWithStoredValues: false, - callback: (val) => { - if (val) { - isLoadingReportData = val; + callback: (value) => { + if (value) { + isLoadingReportData = value; } checkOnReady(); }, From bdd184110b6ae91f1937c8e24c7d8111f56d8d40 Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Tue, 3 Oct 2023 09:56:34 +0200 Subject: [PATCH 048/105] Resolved comment. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index e4ab9caa39bc..b0dc1738c193 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -144,7 +144,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} } if (shouldNavigateToWorkspaceChat && workspaceChatReport) { - if (workspaceChatReport.reportID != null) { + if (workspaceChatReport.reportID !== null) { Navigation.navigate(ROUTES.REPORT_WITH_ID.getRoute(workspaceChatReport.reportID)); } From f97333182f7c011d21ef7044ad1aa8d81c173e1a Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Thu, 5 Oct 2023 10:05:11 +0200 Subject: [PATCH 049/105] Graceful handling of last array element. Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index b0dc1738c193..cbfac7c917da 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -120,11 +120,11 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} // If we are rendering the SidebarScreen at the same time as a workspace route that means we've already created a workspace via workspace/new and should not open the global // create menu right now. We should also stay on the workspace page if that is our destination. - const topRoute = routes[routes.length - 1]; - const isWorkspaceRoute = topRoute.name === 'Settings' && topRoute.params?.path.includes('workspace'); + const topRoute = routes.length > 0 ? routes[routes.length - 1] : undefined; + const isWorkspaceRoute = topRoute !== undefined && topRoute.name === 'Settings' && topRoute.params?.path.includes('workspace'); const transitionRoute = routes.find((route) => route.name === SCREENS.TRANSITION_BETWEEN_APPS); const exitingToWorkspaceRoute = transitionRoute?.params?.exitTo === 'workspace/new'; - const openOnAdminRoom = topRoute.params?.openOnAdminRoom ?? false; + const openOnAdminRoom = topRoute === undefined ? undefined : topRoute.params?.openOnAdminRoom ?? false; const isDisplayingWorkspaceRoute = isWorkspaceRoute ?? exitingToWorkspaceRoute; // If we already opened the workspace settings or want the admin room to stay open, do not From 69b495a9daf2f3bcc4aba586de2c96db1f6954ce Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kacper=20Fa=C5=82at?= Date: Mon, 9 Oct 2023 09:11:37 +0200 Subject: [PATCH 050/105] Requested change on Welcome.ts Co-authored-by: Hayata Suenaga Signed-off-by: Kacper Falat --- src/libs/actions/Welcome.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index cbfac7c917da..5494f5437a76 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -124,7 +124,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} const isWorkspaceRoute = topRoute !== undefined && topRoute.name === 'Settings' && topRoute.params?.path.includes('workspace'); const transitionRoute = routes.find((route) => route.name === SCREENS.TRANSITION_BETWEEN_APPS); const exitingToWorkspaceRoute = transitionRoute?.params?.exitTo === 'workspace/new'; - const openOnAdminRoom = topRoute === undefined ? undefined : topRoute.params?.openOnAdminRoom ?? false; + const openOnAdminRoom = topRoute?.params?.openOnAdminRoom ?? false; const isDisplayingWorkspaceRoute = isWorkspaceRoute ?? exitingToWorkspaceRoute; // If we already opened the workspace settings or want the admin room to stay open, do not From e651ba360ce9c32793cbf11bb83a6276aad08abf Mon Sep 17 00:00:00 2001 From: Kacper Falat Date: Thu, 19 Oct 2023 10:47:38 +0200 Subject: [PATCH 051/105] Rebased and resigned old commit tree. --- src/libs/actions/Policy.js | 2 +- src/libs/actions/Welcome.ts | 12 +++++------- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index 4696ab2f0649..02dd45ce7969 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -162,7 +162,7 @@ function deleteWorkspace(policyID, reports, policyName) { /** * Is the user an admin of a free policy (aka workspace)? * - * @param {Record} policies + * @param {Record} [policies] * @returns {Boolean} */ function isAdminOfFreePolicy(policies) { diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 5494f5437a76..29e0088ed689 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -50,9 +50,9 @@ Onyx.connect({ callback: (value) => { // If isFirstTimeNewExpensifyUser was true do not update it to false. We update it to false inside the Welcome.show logic // More context here https://github.com/Expensify/App/pull/16962#discussion_r1167351359 - if (!isFirstTimeNewExpensifyUser) { - isFirstTimeNewExpensifyUser = value ?? undefined; - } + + isFirstTimeNewExpensifyUser = value ?? undefined; + checkOnReady(); }, }); @@ -61,9 +61,7 @@ Onyx.connect({ key: ONYXKEYS.IS_LOADING_REPORT_DATA, initWithStoredValues: false, callback: (value) => { - if (value) { - isLoadingReportData = value; - } + isLoadingReportData = value ?? false; checkOnReady(); }, }); @@ -159,7 +157,7 @@ function show({routes, showCreateMenu = () => {}, showPopoverMenu = () => false} // If user is not already an admin of a free policy and we are not navigating them to their workspace or creating a new workspace via workspace/new then // we will show the create menu. - if (allPolicies && !Policy.isAdminOfFreePolicy(allPolicies) && !isDisplayingWorkspaceRoute) { + if (!Policy.isAdminOfFreePolicy(allPolicies ?? undefined) && !isDisplayingWorkspaceRoute) { showCreateMenu(); } From 304931aed8e83b2b4ce69176c96eaab5f6364b9a Mon Sep 17 00:00:00 2001 From: Viktoryia Kliushun Date: Thu, 19 Oct 2023 14:51:46 +0200 Subject: [PATCH 052/105] [TS migration] Migrate 'RadioButtons.js' component --- .../{RadioButtons.js => RadioButtons.tsx} | 27 +++++++++---------- 1 file changed, 12 insertions(+), 15 deletions(-) rename src/components/{RadioButtons.js => RadioButtons.tsx} (61%) diff --git a/src/components/RadioButtons.js b/src/components/RadioButtons.tsx similarity index 61% rename from src/components/RadioButtons.js rename to src/components/RadioButtons.tsx index 455f4dad1674..f570bf6fad3e 100644 --- a/src/components/RadioButtons.js +++ b/src/components/RadioButtons.tsx @@ -1,33 +1,31 @@ import React, {useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import RadioButtonWithLabel from './RadioButtonWithLabel'; import styles from '../styles/styles'; -const propTypes = { +type Choice = { + label: string; + value: string; +}; + +type RadioButtonsProps = { /** List of choices to display via radio buttons */ - items: PropTypes.arrayOf( - PropTypes.shape({ - label: PropTypes.string.isRequired, - value: PropTypes.string.isRequired, - }), - ).isRequired, + items: Choice[]; /** Callback to fire when selecting a radio button */ - onPress: PropTypes.func.isRequired, + onPress: (value: string) => void; }; -function RadioButtons(props) { +function RadioButtons(props: RadioButtonsProps) { const [checkedValue, setCheckedValue] = useState(''); return ( - {_.map(props.items, (item, index) => ( + {props.items.map((item) => ( { setCheckedValue(item.value); return props.onPress(item.value); @@ -39,7 +37,6 @@ function RadioButtons(props) { ); } -RadioButtons.propTypes = propTypes; RadioButtons.displayName = 'RadioButtons'; export default RadioButtons; From 84e6c26ba8f86a2b5952e13629d5a4c6114ee07d Mon Sep 17 00:00:00 2001 From: Viktoryia Kliushun Date: Thu, 19 Oct 2023 16:11:53 +0200 Subject: [PATCH 053/105] Destructure props object --- src/components/RadioButtons.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/components/RadioButtons.tsx b/src/components/RadioButtons.tsx index f570bf6fad3e..cf9830d4b967 100644 --- a/src/components/RadioButtons.tsx +++ b/src/components/RadioButtons.tsx @@ -16,19 +16,19 @@ type RadioButtonsProps = { onPress: (value: string) => void; }; -function RadioButtons(props: RadioButtonsProps) { +function RadioButtons({items, onPress}: RadioButtonsProps) { const [checkedValue, setCheckedValue] = useState(''); return ( - {props.items.map((item) => ( + {items.map((item) => ( { setCheckedValue(item.value); - return props.onPress(item.value); + return onPress(item.value); }} label={item.label} /> From 71cb32ba907148e412bd9841d2f111cf69908091 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Thu, 19 Oct 2023 12:21:41 -0700 Subject: [PATCH 054/105] Extra merge changes that got left out --- src/components/MessagesRow.js | 28 +++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/src/components/MessagesRow.js b/src/components/MessagesRow.js index 37366ce5a442..6f4aa13a36f8 100644 --- a/src/components/MessagesRow.js +++ b/src/components/MessagesRow.js @@ -25,15 +25,19 @@ const propTypes = { /** Additional style object for the container */ containerStyles: stylePropTypes, + + /** Whether we can dismiss the error message */ + canDismissError: PropTypes.bool, }; const defaultProps = { messages: {}, onClose: () => {}, containerStyles: [], + canDismissError: true, }; -function MessagesRow({messages, type, onClose, containerStyles}) { +function MessagesRow({messages, type, onClose, containerStyles, canDismissError}) { const {translate} = useLocalize(); if (_.isEmpty(messages)) { return null; @@ -46,16 +50,18 @@ function MessagesRow({messages, type, onClose, containerStyles}) { messages={messages} type={type} /> - - - - - + {canDismissError && ( + + + + + + )} ); } From db19896eff8e7589909a1b7b3cd9955c3cc77eb5 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 19 Oct 2023 18:57:10 -0400 Subject: [PATCH 055/105] remove extra parameters --- src/libs/actions/Report.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 7d8bce044f94..cdc07df2ea13 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1354,7 +1354,7 @@ function updateNotificationPreference(reportID, previousValue, newValue, navigat value: {[parentReportActionID]: {childReportNotificationPreference: previousValue}}, }); } - API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue, parentReportID, parentReportActionID}, {optimisticData, failureData}); + API.write('UpdateReportNotificationPreference', {reportID, notificationPreference: newValue}, {optimisticData, failureData}); if (navigate) { Navigation.goBack(ROUTES.REPORT_SETTINGS.getRoute(reportID)); } From 986529036ba06832f10ae7f3dc387872e6519ea5 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Thu, 19 Oct 2023 18:58:34 -0400 Subject: [PATCH 056/105] modify spanish translation --- src/languages/es.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/languages/es.ts b/src/languages/es.ts index 0ecff93d2758..287790fe24c7 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -417,7 +417,7 @@ export default { deleteConfirmation: ({action}: DeleteConfirmationParams) => `¿Estás seguro de que quieres eliminar este ${ReportActionsUtils.isMoneyRequestAction(action) ? 'pedido' : 'comentario'}`, onlyVisible: 'Visible sólo para', replyInThread: 'Responder en el hilo', - subscribeToThread: 'Suscríbete al hilo', + subscribeToThread: 'Suscribirse al hilo', unsubscribeFromThread: 'Darse de baja del hilo', flagAsOffensive: 'Marcar como ofensivo', }, From c51b66730ac14dec9fe6a86cba3b89c7d699acd3 Mon Sep 17 00:00:00 2001 From: Jayesh Mangwani Date: Fri, 20 Oct 2023 11:54:02 +0530 Subject: [PATCH 057/105] dsable exhaustive-deps for scrollToIndex --- src/components/SelectionList/BaseSelectionList.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/components/SelectionList/BaseSelectionList.js b/src/components/SelectionList/BaseSelectionList.js index a2f3661f0c59..585871b4cc83 100644 --- a/src/components/SelectionList/BaseSelectionList.js +++ b/src/components/SelectionList/BaseSelectionList.js @@ -175,7 +175,9 @@ function BaseSelectionList({ listRef.current.scrollToLocation({sectionIndex: adjustedSectionIndex, itemIndex, animated, viewOffset: variables.contentHeaderHeight}); }, - [flattenedSections.allOptions, sections], + + // eslint-disable-next-line react-hooks/exhaustive-deps + [flattenedSections.allOptions], ); /** From 60799d9b5c91a0ccefde0c747b1fde8649e64850 Mon Sep 17 00:00:00 2001 From: pradeepkumar Date: Fri, 20 Oct 2023 21:28:08 +0530 Subject: [PATCH 058/105] add const values --- src/CONST.ts | 4 ++++ src/components/PlaidLink/index.native.js | 3 ++- src/pages/ReimbursementAccount/ReimbursementAccountPage.js | 2 +- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/CONST.ts b/src/CONST.ts index e2f3fea08215..f50c435a9221 100755 --- a/src/CONST.ts +++ b/src/CONST.ts @@ -157,6 +157,10 @@ const CONST = { ERROR: { TOO_MANY_ATTEMPTS: 'Too many attempts', }, + EVENTS_NAME: { + OPEN: 'OPEN', + EXIT: 'EXIT', + }, }, ERROR: { MISSING_ROUTING_NUMBER: '402 Missing routingNumber', diff --git a/src/components/PlaidLink/index.native.js b/src/components/PlaidLink/index.native.js index 71ed551af235..53c513258ecf 100644 --- a/src/components/PlaidLink/index.native.js +++ b/src/components/PlaidLink/index.native.js @@ -2,6 +2,7 @@ import {useEffect} from 'react'; import {openLink, useDeepLinkRedirector, usePlaidEmitter, dismissLink} from 'react-native-plaid-link-sdk'; import Log from '../../libs/Log'; import {plaidLinkPropTypes, plaidLinkDefaultProps} from './plaidLinkPropTypes'; +import CONST from '../../CONST'; function PlaidLink(props) { useDeepLinkRedirector(); @@ -10,7 +11,7 @@ function PlaidLink(props) { props.onEvent(event.eventName, event.metadata); }); useEffect(() => { - props.onEvent('OPEN', {}); + props.onEvent(CONST.BANK_ACCOUNT.PLAID.EVENTS_NAME.OPEN, {}); openLink({ tokenConfig: { token: props.token, diff --git a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js index e37058c2a21d..db2e062573ce 100644 --- a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js +++ b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js @@ -399,7 +399,7 @@ class ReimbursementAccountPage extends React.Component { } const isLoading = (this.props.isLoadingReportData || this.props.account.isLoading || this.props.reimbursementAccount.isLoading) && - (!this.props.plaidCurrentEvent || this.props.plaidCurrentEvent === 'EXIT'); + (!this.props.plaidCurrentEvent || this.props.plaidCurrentEvent === CONST.BANK_ACCOUNT.PLAID.EVENTS_NAME.EXIT); // Prevent the full-page blocking offline view from being displayed for these steps if the device goes offline. const shouldShowOfflineLoader = !( From e93d6dde643a722b4765589fbe3a8181ea76216e Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Fri, 20 Oct 2023 19:22:58 -0400 Subject: [PATCH 059/105] unsubscribe on new comment --- src/libs/ReportUtils.js | 11 +++++++++++ src/libs/actions/Report.js | 3 ++- .../report/ContextMenu/ContextMenuActions.js | 17 +++++++++++------ 3 files changed, 24 insertions(+), 7 deletions(-) diff --git a/src/libs/ReportUtils.js b/src/libs/ReportUtils.js index efd4557aea8b..8ea5c20b324f 100644 --- a/src/libs/ReportUtils.js +++ b/src/libs/ReportUtils.js @@ -777,6 +777,16 @@ function getReport(reportID) { return lodashGet(allReports, `${ONYXKEYS.COLLECTION.REPORT}${reportID}`, {}) || {}; } +/** + * Returns whether or not the author of the action is this user + * + * @param {Object} reportAction + * @returns {Boolean} + */ +function isActionCreator(reportAction) { + return reportAction.actorAccountID === currentUserAccountID +} + /** * Can only delete if the author is this user and the action is an ADDCOMMENT action or an IOU action in an unsettled report, or if the user is a * policy admin @@ -3969,6 +3979,7 @@ export { canEditReportAction, canFlagReportAction, shouldShowFlagComment, + isActionCreator, canDeleteReportAction, canLeaveRoom, sortReportsByLastRead, diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 93b2d72f9d96..2e714154c8aa 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1398,7 +1398,8 @@ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = const participantLogins = PersonalDetailsUtils.getLoginsByAccountIDs(newChat.participantAccountIDs); openReport(newChat.reportID, participantLogins, newChat, parentReportAction.reportActionID); - updateNotificationPreference(newChat.reportID, prevNotificationPreference, CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, false, parentReportID, parentReportAction.reportActionID); + const notificationPreference = prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; + updateNotificationPreference(newChat.reportID, prevNotificationPreference, notificationPreference, false, parentReportID, parentReportAction.reportActionID); } } diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 999f8e9fa26b..cb26af15181d 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -150,11 +150,12 @@ export default [ successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { - const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); - const subscribed = childReportNotificationPreference && childReportNotificationPreference !== 'hidden'; - if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { - return false; + let childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (!childReportNotificationPreference) { + const isActionCreator = ReportUtils.isActionCreator(reportAction); + childReportNotificationPreference = isActionCreator ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; } + const subscribed = childReportNotificationPreference !== 'hidden'; const isCommentAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.ADDCOMMENT && !ReportUtils.isThreadFirstChat(reportAction, reportID); const isReportPreviewAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.REPORTPREVIEW; const isIOUAction = reportAction.actionName === CONST.REPORT.ACTIONS.TYPE.IOU && !ReportActionsUtils.isSplitBillAction(reportAction); @@ -182,8 +183,12 @@ export default [ successTextTranslateKey: '', successIcon: null, shouldShow: (type, reportAction, isArchivedRoom, betas, anchor, isChronosReport, reportID) => { - const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); - const subscribed = childReportNotificationPreference && childReportNotificationPreference !== 'hidden'; + let childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (!childReportNotificationPreference) { + const isActionCreator = ReportUtils.isActionCreator(reportAction); + childReportNotificationPreference = isActionCreator ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; + } + const subscribed = childReportNotificationPreference !== 'hidden'; if (type !== CONTEXT_MENU_TYPES.REPORT_ACTION) { return false; } From 6caf051a8d0e1fb734c6fd1887f36afba9fe7fd6 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Fri, 20 Oct 2023 19:54:04 -0400 Subject: [PATCH 060/105] prettier --- src/libs/ReportUtils.js | 2 +- src/libs/actions/Report.js | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/libs/ReportUtils.js b/src/libs/ReportUtils.js index 8ea5c20b324f..7f231381c85d 100644 --- a/src/libs/ReportUtils.js +++ b/src/libs/ReportUtils.js @@ -784,7 +784,7 @@ function getReport(reportID) { * @returns {Boolean} */ function isActionCreator(reportAction) { - return reportAction.actorAccountID === currentUserAccountID + return reportAction.actorAccountID === currentUserAccountID; } /** diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 2e714154c8aa..38889a474231 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1398,7 +1398,8 @@ function toggleSubscribeToChildReport(childReportID = '0', parentReportAction = const participantLogins = PersonalDetailsUtils.getLoginsByAccountIDs(newChat.participantAccountIDs); openReport(newChat.reportID, participantLogins, newChat, parentReportAction.reportActionID); - const notificationPreference = prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; + const notificationPreference = + prevNotificationPreference === CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; updateNotificationPreference(newChat.reportID, prevNotificationPreference, notificationPreference, false, parentReportID, parentReportAction.reportActionID); } } From c4182b36cb17a87789777f2296ae48f45040ec25 Mon Sep 17 00:00:00 2001 From: Srikar Parsi Date: Fri, 20 Oct 2023 20:52:20 -0400 Subject: [PATCH 061/105] change subscribe based on user created --- .../home/report/ContextMenu/ContextMenuActions.js | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index cb26af15181d..c4fac6d21283 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -162,7 +162,11 @@ export default [ return !subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); }, onPress: (closePopover, {reportAction, reportID}) => { - const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + let childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (!childReportNotificationPreference) { + const isActionCreator = ReportUtils.isActionCreator(reportAction); + childReportNotificationPreference = isActionCreator ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; + } if (closePopover) { hideContextMenu(false, () => { ReportActionComposeFocusManager.focus(); @@ -198,7 +202,11 @@ export default [ return subscribed && (isCommentAction || isReportPreviewAction || isIOUAction); }, onPress: (closePopover, {reportAction, reportID}) => { - const childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + let childReportNotificationPreference = lodashGet(reportAction, 'childReportNotificationPreference', ''); + if (!childReportNotificationPreference) { + const isActionCreator = ReportUtils.isActionCreator(reportAction); + childReportNotificationPreference = isActionCreator ? CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS : CONST.REPORT.NOTIFICATION_PREFERENCE.HIDDEN; + } if (closePopover) { hideContextMenu(false, () => { ReportActionComposeFocusManager.focus(); From 52919facbe7c256270c250be89f0933f00d55d3d Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Mon, 23 Oct 2023 21:25:31 +0700 Subject: [PATCH 062/105] Add default value to selected participants --- .../MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index 9e2f1a3a1f45..768f66cc2c7f 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -54,7 +54,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { const isScanRequest = MoneyRequestUtils.isScanRequest(selectedTab); const isSplitRequest = iou.id === CONST.IOU.MONEY_REQUEST_TYPE.SPLIT; const [headerTitle, setHeaderTitle] = useState(); - const [selectedParticipants, setSelectedParticipants] = useState([]); + const [selectedParticipants, setSelectedParticipants] = useState(iou.participants); useEffect(() => { if (isDistanceRequest) { From a6e963deb122f17c83cab9917bd103cc722b9542 Mon Sep 17 00:00:00 2001 From: Aman Sheikh Date: Tue, 24 Oct 2023 21:25:04 +0530 Subject: [PATCH 063/105] use absolute positioning for error message and ensure 12px of gap --- src/pages/iou/steps/MoneyRequestAmountForm.js | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/pages/iou/steps/MoneyRequestAmountForm.js b/src/pages/iou/steps/MoneyRequestAmountForm.js index d84c4d9e3cd0..5a74c907ad94 100644 --- a/src/pages/iou/steps/MoneyRequestAmountForm.js +++ b/src/pages/iou/steps/MoneyRequestAmountForm.js @@ -261,14 +261,14 @@ function MoneyRequestAmountForm({amount, currency, isEditing, forwardedRef, onCu }} onKeyPress={textInputKeyPress} /> + {!_.isEmpty(formError) && ( + + )} - {!_.isEmpty(formError) && ( - - )} onMouseDown(event, [NUM_PAD_CONTAINER_VIEW_ID, NUM_PAD_VIEW_ID])} style={[styles.w100, styles.justifyContentEnd, styles.pageWrapper, styles.pt0]} @@ -286,7 +286,7 @@ function MoneyRequestAmountForm({amount, currency, isEditing, forwardedRef, onCu allowBubble pressOnEnter medium={isExtraSmallScreenHeight} - style={[styles.w100, canUseTouchScreen ? styles.mt5 : styles.mt2]} + style={[styles.w100, canUseTouchScreen ? styles.mt5 : styles.mt3]} onPress={submitAndNavigateToNextPage} text={buttonText} /> From f2d3c241fa3b53d4de28e35c98335fda5fb6fbae Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Tue, 24 Oct 2023 18:03:18 -0700 Subject: [PATCH 064/105] Review feedback and rename prop --- src/components/MessagesRow.js | 14 +++++++------- src/components/OfflineWithFeedback.js | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/components/MessagesRow.js b/src/components/MessagesRow.js index 6f4aa13a36f8..8a699265bb56 100644 --- a/src/components/MessagesRow.js +++ b/src/components/MessagesRow.js @@ -14,10 +14,10 @@ import stylePropTypes from '../styles/stylePropTypes'; import useLocalize from '../hooks/useLocalize'; const propTypes = { - // The error messages to display + /* The messages to display */ messages: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))])), - // The type of message, 'error' shows a red dot, 'success' shows a green dot + /* The type of message, 'error' shows a red dot, 'success' shows a green dot */ type: PropTypes.oneOf(['error', 'success']).isRequired, /** A function to run when the X button next to the message is clicked */ @@ -26,18 +26,18 @@ const propTypes = { /** Additional style object for the container */ containerStyles: stylePropTypes, - /** Whether we can dismiss the error message */ - canDismissError: PropTypes.bool, + /** Whether we can dismiss the messages */ + canDismiss: PropTypes.bool, }; const defaultProps = { messages: {}, onClose: () => {}, containerStyles: [], - canDismissError: true, + canDismiss: true, }; -function MessagesRow({messages, type, onClose, containerStyles, canDismissError}) { +function MessagesRow({messages, type, onClose, containerStyles, canDismiss}) { const {translate} = useLocalize(); if (_.isEmpty(messages)) { return null; @@ -50,7 +50,7 @@ function MessagesRow({messages, type, onClose, containerStyles, canDismissError} messages={messages} type={type} /> - {canDismissError && ( + {canDismiss && ( )} From 7e81daeb9e92adea827ec62b73af638c0c4f6c34 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Tue, 24 Oct 2023 19:11:57 -0700 Subject: [PATCH 065/105] WIP remove secondary login messages with members --- src/libs/actions/Policy.js | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index f275ab420e79..e141bf382acb 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -14,6 +14,7 @@ import * as ErrorUtils from '../ErrorUtils'; import * as ReportUtils from '../ReportUtils'; import * as PersonalDetailsUtils from '../PersonalDetailsUtils'; import Log from '../Log'; +import CollectionUtils from '../CollectionUtils'; const allPolicies = {}; Onyx.connect({ @@ -44,6 +45,18 @@ Onyx.connect({ }, }); +const allPolicyMembers = {}; +Onyx.connect({ + key: ONYXKEYS.COLLECTION.POLICY_MEMBERS, + callback: (val, key) => { + if (!val || !key) { + return; + } + const policyID = CollectionUtils.extractCollectionItemID(key); + allPolicyMembers[policyID] = val; + }, +}); + let lastAccessedWorkspacePolicyID = null; Onyx.connect({ key: ONYXKEYS.LAST_ACCESSED_WORKSPACE_POLICY_ID, @@ -242,6 +255,27 @@ function removeMembers(accountIDs, policyID) { })), ]; + // If the policy has primaryLoginsInvited, then it displays informative messages on the members page about which primary logins were added by secondary logins. + // If we delete all these logins then we should clear the informative messages since they are no longer relevant. + if (!_.isEmpty(policy.primaryLoginsInvited)) { + // Take the current policy members and remove them optimistically + const policyMemberAccountIDs = _.keys(allPolicyMembers[policyID]); + const remainingMemberAccountIDs = _.difference(policyMemberAccountIDs, accountIDs); + const remainingLogins = PersonalDetailsUtils.getLoginsByAccountIDs(remainingMemberAccountIDs); + const invitedPrimaryToSecondaryLogins = _.invert(policy.primaryLoginsInvited); + + // Then, if no remaining members exist in primaryLoginsInvited, delete it + if (!_.some(remainingLogins, (remainingLogin) => Boolean(invitedPrimaryToSecondaryLogins[remainingLogin]))) { + optimisticData.push({ + onyxMethod: Onyx.METHOD.MERGE, + key: `${ONYXKEYS.COLLECTION.POLICY}${policyID}`, + value: { + primaryLoginsInvited: null, + }, + }); + } + } + const successData = [ { onyxMethod: Onyx.METHOD.MERGE, From b1ff83927424a9520c9f073d5c53f33e211031b3 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 25 Oct 2023 08:38:47 -0700 Subject: [PATCH 066/105] Fix remove secondary login messages with members --- src/libs/actions/Policy.js | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index e141bf382acb..854a7850c585 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -45,16 +45,11 @@ Onyx.connect({ }, }); -const allPolicyMembers = {}; +let allPolicyMembers; Onyx.connect({ key: ONYXKEYS.COLLECTION.POLICY_MEMBERS, - callback: (val, key) => { - if (!val || !key) { - return; - } - const policyID = CollectionUtils.extractCollectionItemID(key); - allPolicyMembers[policyID] = val; - }, + waitForCollectionCallback: true, + callback: (val) => (allPolicyMembers = val), }); let lastAccessedWorkspacePolicyID = null; @@ -259,12 +254,12 @@ function removeMembers(accountIDs, policyID) { // If we delete all these logins then we should clear the informative messages since they are no longer relevant. if (!_.isEmpty(policy.primaryLoginsInvited)) { // Take the current policy members and remove them optimistically - const policyMemberAccountIDs = _.keys(allPolicyMembers[policyID]); + const policyMemberAccountIDs = _.map(allPolicyMembers[`${ONYXKEYS.COLLECTION.POLICY_MEMBERS}${policyID}`], (value, key) => Number(key)); const remainingMemberAccountIDs = _.difference(policyMemberAccountIDs, accountIDs); const remainingLogins = PersonalDetailsUtils.getLoginsByAccountIDs(remainingMemberAccountIDs); const invitedPrimaryToSecondaryLogins = _.invert(policy.primaryLoginsInvited); - // Then, if no remaining members exist in primaryLoginsInvited, delete it + // Then, if no remaining members exist that were invited by a secondary login, clear the informative messages if (!_.some(remainingLogins, (remainingLogin) => Boolean(invitedPrimaryToSecondaryLogins[remainingLogin]))) { optimisticData.push({ onyxMethod: Onyx.METHOD.MERGE, From 6514698aacab9ed95f6ba7998308f272decd8a8b Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Wed, 25 Oct 2023 23:31:26 +0700 Subject: [PATCH 067/105] Add isSplitRequest to IOU onyx --- src/libs/actions/IOU.js | 8 ++++++++ .../MoneyRequestParticipantsPage.js | 12 +++--------- .../MoneyRequestParticipantsSelector.js | 15 ++++++++------- 3 files changed, 19 insertions(+), 16 deletions(-) diff --git a/src/libs/actions/IOU.js b/src/libs/actions/IOU.js index 422dd8fbb03a..80a2fed6fe67 100644 --- a/src/libs/actions/IOU.js +++ b/src/libs/actions/IOU.js @@ -2834,6 +2834,13 @@ function setMoneyRequestParticipants(participants) { Onyx.merge(ONYXKEYS.IOU, {participants}); } +/** + * @param {Boolean} isSplitRequest + */ +function setMoneyRequestIsSplitRequest(isSplitRequest) { + Onyx.merge(ONYXKEYS.IOU, {isSplitRequest}); +} + /** * @param {String} receiptPath * @param {String} receiptFilename @@ -2941,6 +2948,7 @@ export { resetMoneyRequestTag, setMoneyRequestBillable, setMoneyRequestParticipants, + setMoneyRequestIsSplitRequest, setMoneyRequestReceipt, setUpDistanceTransaction, navigateToNextPage, diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index 768f66cc2c7f..d83b562b0ba0 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -3,7 +3,6 @@ import {View} from 'react-native'; import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import CONST from '../../../../CONST'; import ONYXKEYS from '../../../../ONYXKEYS'; import ROUTES from '../../../../ROUTES'; @@ -54,7 +53,6 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { const isScanRequest = MoneyRequestUtils.isScanRequest(selectedTab); const isSplitRequest = iou.id === CONST.IOU.MONEY_REQUEST_TYPE.SPLIT; const [headerTitle, setHeaderTitle] = useState(); - const [selectedParticipants, setSelectedParticipants] = useState(iou.participants); useEffect(() => { if (isDistanceRequest) { @@ -72,13 +70,10 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { return; } - setHeaderTitle(_.isEmpty(selectedParticipants) ? translate('tabSelector.manual') : translate('iou.split')); - }, [selectedParticipants, isDistanceRequest, translate, isScanRequest, isSendRequest]); + setHeaderTitle(iou.isSplitRequest ? translate('iou.split') : translate('tabSelector.manual')); + }, [iou.isSplitRequest, isDistanceRequest, translate, isScanRequest, isSendRequest]); const navigateToConfirmationStep = (moneyRequestType) => { - if (moneyRequestType === iouType.current) { - setSelectedParticipants([]); - } IOU.setMoneyRequestId(moneyRequestType); Navigation.navigate(ROUTES.MONEY_REQUEST_CONFIRMATION.getRoute(moneyRequestType, reportID.current)); }; @@ -127,7 +122,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { /> (optionsSelectorRef.current = el)} - participants={selectedParticipants} + participants={iou.participants} onAddParticipants={IOU.setMoneyRequestParticipants} navigateToRequest={() => navigateToConfirmationStep(iouType.current)} navigateToSplit={() => navigateToConfirmationStep(CONST.IOU.MONEY_REQUEST_TYPE.SPLIT)} @@ -135,7 +130,6 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { iouType={iouType.current} isDistanceRequest={isDistanceRequest} isScanRequest={isScanRequest} - setSelectedParticipants={setSelectedParticipants} /> )} diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js index 5a3a5a797946..a98de08f7e4d 100755 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js @@ -16,6 +16,7 @@ import CONST from '../../../../CONST'; import personalDetailsPropType from '../../../personalDetailsPropType'; import reportPropTypes from '../../../reportPropTypes'; import refPropTypes from '../../../../components/refPropTypes'; +import * as IOU from '../../../../libs/actions/IOU'; const propTypes = { /** Beta features list */ @@ -47,9 +48,6 @@ const propTypes = { /** All of the personal details for everyone */ personalDetails: PropTypes.objectOf(personalDetailsPropType), - /** Callback to request parent modal to go to next step, which should be split */ - setSelectedParticipants: PropTypes.func.isRequired, - /** All reports shared with the user */ reports: PropTypes.objectOf(reportPropTypes), @@ -88,7 +86,6 @@ function MoneyRequestParticipantsSelector({ safeAreaPaddingBottomStyle, iouType, isDistanceRequest, - setSelectedParticipants, }) { const [searchTerm, setSearchTerm] = useState(''); const [newChatOptions, setNewChatOptions] = useState({ @@ -163,6 +160,7 @@ function MoneyRequestParticipantsSelector({ onAddParticipants([ {accountID: option.accountID, login: option.login, isPolicyExpenseChat: option.isPolicyExpenseChat, reportID: option.reportID, selected: true, searchText: option.searchText}, ]); + IOU.setMoneyRequestIsSplitRequest(false); navigateToRequest(); }; @@ -202,11 +200,14 @@ function MoneyRequestParticipantsSelector({ ]; } - setSelectedParticipants(newSelectedOptions); - + if (newSelectedOptions.length === 0) { + IOU.setMoneyRequestIsSplitRequest(false); + } else { + IOU.setMoneyRequestIsSplitRequest(true); + } onAddParticipants(newSelectedOptions); }, - [participants, onAddParticipants, setSelectedParticipants], + [participants, onAddParticipants], ); const headerMessage = OptionsListUtils.getHeaderMessage( From 8ee843ad1f5cbf7a245f403350518b9f1d8080af Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Wed, 25 Oct 2023 23:47:37 +0700 Subject: [PATCH 068/105] fix lint --- .../MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index d83b562b0ba0..cefbd1d0c6d3 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -3,6 +3,7 @@ import {View} from 'react-native'; import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import _ from 'underscore'; import CONST from '../../../../CONST'; import ONYXKEYS from '../../../../ONYXKEYS'; import ROUTES from '../../../../ROUTES'; From 2e2b5c89e0a22046789a9c4324eb2d2285c4a5fb Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 26 Oct 2023 00:28:15 +0700 Subject: [PATCH 069/105] fix logic update isSplitRequest --- src/libs/actions/IOU.js | 10 ++-------- .../MoneyRequestParticipantsSelector.js | 17 +++++------------ 2 files changed, 7 insertions(+), 20 deletions(-) diff --git a/src/libs/actions/IOU.js b/src/libs/actions/IOU.js index 80a2fed6fe67..46b878941af4 100644 --- a/src/libs/actions/IOU.js +++ b/src/libs/actions/IOU.js @@ -2829,15 +2829,10 @@ function setMoneyRequestBillable(billable) { /** * @param {Object[]} participants - */ -function setMoneyRequestParticipants(participants) { - Onyx.merge(ONYXKEYS.IOU, {participants}); -} - -/** * @param {Boolean} isSplitRequest */ -function setMoneyRequestIsSplitRequest(isSplitRequest) { +function setMoneyRequestParticipants(participants, isSplitRequest) { + Onyx.merge(ONYXKEYS.IOU, {participants}); Onyx.merge(ONYXKEYS.IOU, {isSplitRequest}); } @@ -2948,7 +2943,6 @@ export { resetMoneyRequestTag, setMoneyRequestBillable, setMoneyRequestParticipants, - setMoneyRequestIsSplitRequest, setMoneyRequestReceipt, setUpDistanceTransaction, navigateToNextPage, diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js index a98de08f7e4d..8cdabdaf6458 100755 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js @@ -16,7 +16,6 @@ import CONST from '../../../../CONST'; import personalDetailsPropType from '../../../personalDetailsPropType'; import reportPropTypes from '../../../reportPropTypes'; import refPropTypes from '../../../../components/refPropTypes'; -import * as IOU from '../../../../libs/actions/IOU'; const propTypes = { /** Beta features list */ @@ -157,10 +156,10 @@ function MoneyRequestParticipantsSelector({ * @param {Object} option */ const addSingleParticipant = (option) => { - onAddParticipants([ - {accountID: option.accountID, login: option.login, isPolicyExpenseChat: option.isPolicyExpenseChat, reportID: option.reportID, selected: true, searchText: option.searchText}, - ]); - IOU.setMoneyRequestIsSplitRequest(false); + onAddParticipants( + [{accountID: option.accountID, login: option.login, isPolicyExpenseChat: option.isPolicyExpenseChat, reportID: option.reportID, selected: true, searchText: option.searchText}], + false, + ); navigateToRequest(); }; @@ -199,13 +198,7 @@ function MoneyRequestParticipantsSelector({ }, ]; } - - if (newSelectedOptions.length === 0) { - IOU.setMoneyRequestIsSplitRequest(false); - } else { - IOU.setMoneyRequestIsSplitRequest(true); - } - onAddParticipants(newSelectedOptions); + onAddParticipants(newSelectedOptions, newSelectedOptions.length !== 0); }, [participants, onAddParticipants], ); From 36818f84f443e4b9780a3b420cb25e75d56d6f8e Mon Sep 17 00:00:00 2001 From: Sara Jo Jacobson Date: Wed, 25 Oct 2023 12:35:38 -0500 Subject: [PATCH 070/105] Update Tags.md You can use tags to assign expenses to a specific department, project, location, cost center, and more. --- .../workspace-and-domain-settings/Tags.md | 94 ++++++++++++++++++- 1 file changed, 91 insertions(+), 3 deletions(-) diff --git a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md index 3ee1c8656b4b..301a1c9d8c06 100644 --- a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md +++ b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md @@ -1,5 +1,93 @@ --- -title: Coming Soon -description: Coming Soon +title: Workspace-Tags.md --- -## Resource Coming Soon! +# Overview +You can use tags to assign expenses to a specific department, project, location, cost center, and more. + +Note that tags function differently depending on whether or not you connect Expensify to a direct account integration (i.e., QuickBooks Online, NetSuite, etc.). With that said, this article covers tags that work for all account setups. +# How to use Tags +Tags are a workspace-level feature. They’re generally used to code expenses to things like customers, projects, locations, or departments. at the expense level. You can have different sets of tags for different workspaces, allowing you to customize coding for cohorts of employees. + +With that said, tags come in two forms: single tags and multi-level tags. + +## Single Tags +Single tags refer to the simplest version of tags, allowing users to code expenses on a single level. With a single tag setup, users will pick from the list of tags you created and make a single selection on each expense. +## Multi-Level Tags +On the other hand, Multi-Level Tags refer to a more advanced tagging system that allows you to code expenses in a hierarchical or nested manner. Unlike single tags, which are standalone labels, multi-level tags enable you to create a structured hierarchy of tags, with sub-tags nested within parent tags. This feature is particularly useful for organizations that require a more detailed and organized approach to expense tracking. +# How to import single tags (no accounting integration connected) +## Add single tags via spreadsheet +To set up Tags, follow these steps: +- Go to **Settings > Workspace > Group / Individual > [Workspace name] > Tags**. +- You can choose to add tags one by one, or upload them in bulk via a spreadsheet. + +After downloading the CSV and creating the tags you want to import, go to the Tags section in the policy editor: Settings > Workspaces > Group > [Workspace name] > Tags + Enable multi-level tags by toggling the button. +Click "Import from Spreadsheet" to bring in your CSV. + Indicate whether the first line contains the tag header. +Choose if the tag list is independent or dependent (matching your CSV). +Decide if your tags list includes GL codes. +Upload your CSV or TSV file. +Confirm your file and update your tags list. +## Manually add single tags + +If you need to add Tags to your workspace manually, you can follow the steps below. + +On web: + +1. Navigate to Settings > Workspace > Group / Individual > [Workspace name] > Tags. +2. Add new tags under Add a Category. + +On mobile: + +1. Tap the three-bar menu icon at the top left corner of the app +2. Tap on Settings in the menu on the left side +3. Scroll to the Workspace subhead and click on tags listed underneath the default policy +4. Add new categories by tapping the + button in the upper right corner. To delete a category, on iOS swipe left, on Android press and hold. Tap a category name to edit it. + +# How to import multi-level tags (no accounting integration connected) +To use multi-level tags, go to the Tags section in your workspace settings. +Toggle on "Do you want to use multiple levels of tags?" + +This feature is available for companies with group workspaces and helps accountants track more details in expenses. + +If you need to make changes to your multi-level tags, follow these steps: +1. Start by editing them in a CSV file. +2. Import the revised tags into Expensify. +3. Remember to back up your tags! Uploading a CSV will replace your existing settings. +4. Safest Option: Download the old CSV from the Tags page using 'Export to CSV,' make edits, then import it. +## Manage multi-level tags +Once multi-level tagging has been set up, employees will be able to choose more than one tag per expense. Based on the choice made for the first tag, the second subset of tag options will appear. After the second tag is chosen, more tag lists can appear, customizable up to 5 tag levels. + +### Best Practices +- Multi-level tagging is available for companies on group workspaces and is intended to help accountants track additional information at the expense line-item level. +- If you need to make any changes to the Tags, you need to first make them on the CSV and import the revised Tags into Expensify. +- Make sure to have a backup of your tags! Every time you upload a CSV it will override your previous settings. +- The easiest way to keep the old CSV is to download it from the Tags page by clicking Export to CSV, editing the list, and then importing it to apply the changes. + + +# How to import tags with an accounting integration connected +If you have connected Expensify to a direct integration such as QuickBooks Online, QuickBooks Desktop, Sage Intacct, Xero, or NetSuite, then Expensify automatically imports XYZ from your accounting system as tags. + +When you first connect your accounting integration you’ll configure classes, customers, projects, departments locations, etc. to import as tags in Expensify. + +If you need to update your tags in Expensify, you will first need to update them in your accounting system, then sync the connection in Expensify by navigating to Settings > Workspace > Group > [Workspace Name] > Connection > Sync Now. + +Alternatively, if you update the tag details in your accounting integration, be sure to sync the policy connection so that the updated information is available on the workspace. + +# Deep Dive +## Make tags required +You can require tags for any workspace expenses by enabling People must tag expenses on the Tags page by navigating to Settings > Workspace > Group > [Workspace Name] > Tags. +# FAQ + +## What are the different tag options? +If you want your second tag to depend on the first one, use dependent tags. Include GL codes if needed, especially when using accounting integrations. +For other scenarios, like not using accounting integrations, use independent tags, which can still include GL codes if necessary. + + +## Are the multi-level tags only available with a certain subscription (pricing plan)? +Multi-level tagging is only available with the Control type policy. + +## I can’t see "Do you want to use multiple level tags" feature on my company's expense workspace. Why is that? +If you are connected to an accounting integration, you will not see this feature. You will need to add those tags in your integration first, then sync the connection. + + From 3fd048d3bf71bbac35303f33d346cabd824d523f Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 26 Oct 2023 00:38:26 +0700 Subject: [PATCH 071/105] fix chore --- src/libs/actions/IOU.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/libs/actions/IOU.js b/src/libs/actions/IOU.js index 46b878941af4..74a852b29361 100644 --- a/src/libs/actions/IOU.js +++ b/src/libs/actions/IOU.js @@ -2832,8 +2832,7 @@ function setMoneyRequestBillable(billable) { * @param {Boolean} isSplitRequest */ function setMoneyRequestParticipants(participants, isSplitRequest) { - Onyx.merge(ONYXKEYS.IOU, {participants}); - Onyx.merge(ONYXKEYS.IOU, {isSplitRequest}); + Onyx.merge(ONYXKEYS.IOU, {participants, isSplitRequest}); } /** From aeaa508ad4d9ea67e0da66f9cba527c28122f8dd Mon Sep 17 00:00:00 2001 From: Sara Jo Jacobson Date: Wed, 25 Oct 2023 12:59:28 -0500 Subject: [PATCH 072/105] Update docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md Co-authored-by: Rushat Gabhane --- .../expensify-classic/workspace-and-domain-settings/Tags.md | 1 + 1 file changed, 1 insertion(+) diff --git a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md index 301a1c9d8c06..16e8bc2d4c90 100644 --- a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md +++ b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md @@ -55,6 +55,7 @@ If you need to make changes to your multi-level tags, follow these steps: 2. Import the revised tags into Expensify. 3. Remember to back up your tags! Uploading a CSV will replace your existing settings. 4. Safest Option: Download the old CSV from the Tags page using 'Export to CSV,' make edits, then import it. + ## Manage multi-level tags Once multi-level tagging has been set up, employees will be able to choose more than one tag per expense. Based on the choice made for the first tag, the second subset of tag options will appear. After the second tag is chosen, more tag lists can appear, customizable up to 5 tag levels. From 40735457d5ca555e2a6763681b6c65577e982601 Mon Sep 17 00:00:00 2001 From: Sara Jo Jacobson Date: Wed, 25 Oct 2023 12:59:52 -0500 Subject: [PATCH 073/105] Update docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md Co-authored-by: Rushat Gabhane --- .../expensify-classic/workspace-and-domain-settings/Tags.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md index 16e8bc2d4c90..2e6bd335ce4c 100644 --- a/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md +++ b/docs/articles/expensify-classic/workspace-and-domain-settings/Tags.md @@ -1,5 +1,5 @@ --- -title: Workspace-Tags.md +title: Workspace Tags --- # Overview You can use tags to assign expenses to a specific department, project, location, cost center, and more. From 7eb0ba5710f17decd7b9b028fd78b780eb3e64a3 Mon Sep 17 00:00:00 2001 From: neil-marcellini Date: Wed, 25 Oct 2023 12:24:40 -0700 Subject: [PATCH 074/105] Fix lint, remove unused import --- src/libs/actions/Policy.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index 854a7850c585..f06757362f6a 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -14,7 +14,6 @@ import * as ErrorUtils from '../ErrorUtils'; import * as ReportUtils from '../ReportUtils'; import * as PersonalDetailsUtils from '../PersonalDetailsUtils'; import Log from '../Log'; -import CollectionUtils from '../CollectionUtils'; const allPolicies = {}; Onyx.connect({ From 64780a1c2c270eab310ea8b5616dd8a9b189f72b Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 26 Oct 2023 09:48:14 +0700 Subject: [PATCH 075/105] Reset isSplitRequest when reset IOU --- src/libs/actions/IOU.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/libs/actions/IOU.js b/src/libs/actions/IOU.js index 74a852b29361..bfd7b7d2dfee 100644 --- a/src/libs/actions/IOU.js +++ b/src/libs/actions/IOU.js @@ -137,6 +137,7 @@ function resetMoneyRequestInfo(id = '') { receiptFilename: '', transactionID: '', billable: null, + isSplitRequest: false, }); } From 9df120e972aaf9d0ae040f08e575be7d225a127d Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Thu, 26 Oct 2023 09:59:48 +0700 Subject: [PATCH 076/105] fix lint --- .../MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index cefbd1d0c6d3..d83b562b0ba0 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -3,7 +3,6 @@ import {View} from 'react-native'; import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import CONST from '../../../../CONST'; import ONYXKEYS from '../../../../ONYXKEYS'; import ROUTES from '../../../../ROUTES'; From d7d19c14dc898762fb1b552eaf0eb4664e3b6f6a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kacper=20Miko=C5=82ajczak?= Date: Thu, 26 Oct 2023 21:19:17 +0200 Subject: [PATCH 077/105] hijack ref without hover support --- src/components/Hoverable/index.js | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/components/Hoverable/index.js b/src/components/Hoverable/index.js index 2ded0e52e94d..62f42a9b4b93 100644 --- a/src/components/Hoverable/index.js +++ b/src/components/Hoverable/index.js @@ -194,15 +194,21 @@ const Hoverable = React.forwardRef(({disabled, onHoverIn, onHoverOut, onMouseEnt [child.props], ); + // We need to access the ref of a children from both parent and current component + // So we pass it to current ref and assign it once again to the child ref prop + const hijackRef = (el) => { + ref.current = el; + assignRef(child.ref, el); + }; + if (!DeviceCapabilities.hasHoverSupport()) { - return child; + return React.cloneElement(child, { + ref: hijackRef, + }); } return React.cloneElement(child, { - ref: (el) => { - ref.current = el; - assignRef(child.ref, el); - }, + ref: hijackRef, onMouseEnter: enableHoveredOnMouseEnter, onMouseLeave: disableHoveredOnMouseLeave, onBlur: disableHoveredOnBlur, From d4bce7806be0ded476bfd9e686c2160fbe3207cd Mon Sep 17 00:00:00 2001 From: DylanDylann Date: Fri, 27 Oct 2023 09:39:20 +0700 Subject: [PATCH 078/105] fix money request participants selector in manual --- .../MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index d83b562b0ba0..6dac11e70bfe 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -122,7 +122,7 @@ function MoneyRequestParticipantsPage({iou, selectedTab, route}) { /> (optionsSelectorRef.current = el)} - participants={iou.participants} + participants={iou.isSplitRequest ? iou.participants : []} onAddParticipants={IOU.setMoneyRequestParticipants} navigateToRequest={() => navigateToConfirmationStep(iouType.current)} navigateToSplit={() => navigateToConfirmationStep(CONST.IOU.MONEY_REQUEST_TYPE.SPLIT)} From e0e51ede0f77984eebec7943674ca27cdcb4cda6 Mon Sep 17 00:00:00 2001 From: Youssef Lourayad Date: Fri, 27 Oct 2023 11:50:28 +0400 Subject: [PATCH 079/105] Fix viewing attachments --- src/components/OptionsList/BaseOptionsList.js | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/components/OptionsList/BaseOptionsList.js b/src/components/OptionsList/BaseOptionsList.js index 91fd77dbea30..31dfe307cbb4 100644 --- a/src/components/OptionsList/BaseOptionsList.js +++ b/src/components/OptionsList/BaseOptionsList.js @@ -1,5 +1,5 @@ import _ from 'underscore'; -import React, {useRef, useEffect, forwardRef, memo} from 'react'; +import React, {useRef, useCallback, useEffect, forwardRef, memo} from 'react'; import {View} from 'react-native'; import PropTypes from 'prop-types'; import styles from '../../styles/styles'; @@ -120,14 +120,16 @@ function BaseOptionsList({ flattenedData.current = buildFlatSectionArray(); }); - const onViewableItemsChanged = () => { + const onViewableItemsChanged = useCallback(() => { if (didLayout.current || !onLayout) { return; } didLayout.current = true; onLayout(); - }; + }, []); + + const viewConfigRef = useRef({viewAreaCoveragePercentThreshold: 95}); /** * This function is used to compute the layout of any given item in our list. @@ -277,7 +279,7 @@ function BaseOptionsList({ initialNumToRender={12} maxToRenderPerBatch={5} windowSize={5} - viewabilityConfig={{viewAreaCoveragePercentThreshold: 95}} + viewabilityConfig={viewConfigRef.current} onViewableItemsChanged={onViewableItemsChanged} bounces={bounces} /> From d2844c954da477fc730f83326db75a539d708f2b Mon Sep 17 00:00:00 2001 From: Youssef Lourayad Date: Fri, 27 Oct 2023 11:58:05 +0400 Subject: [PATCH 080/105] Add dependencies to useCallback --- src/components/OptionsList/BaseOptionsList.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/OptionsList/BaseOptionsList.js b/src/components/OptionsList/BaseOptionsList.js index 31dfe307cbb4..cfab94ca632d 100644 --- a/src/components/OptionsList/BaseOptionsList.js +++ b/src/components/OptionsList/BaseOptionsList.js @@ -127,7 +127,7 @@ function BaseOptionsList({ didLayout.current = true; onLayout(); - }, []); + }, [didLayout, onLayout]); const viewConfigRef = useRef({viewAreaCoveragePercentThreshold: 95}); From 1c8903fd454769aaac3272a1bec4b5259cab5469 Mon Sep 17 00:00:00 2001 From: Youssef Lourayad Date: Fri, 27 Oct 2023 12:23:32 +0400 Subject: [PATCH 081/105] Remove unneeded ref --- src/components/OptionsList/BaseOptionsList.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/components/OptionsList/BaseOptionsList.js b/src/components/OptionsList/BaseOptionsList.js index cfab94ca632d..5a700ae61da2 100644 --- a/src/components/OptionsList/BaseOptionsList.js +++ b/src/components/OptionsList/BaseOptionsList.js @@ -129,8 +129,6 @@ function BaseOptionsList({ onLayout(); }, [didLayout, onLayout]); - const viewConfigRef = useRef({viewAreaCoveragePercentThreshold: 95}); - /** * This function is used to compute the layout of any given item in our list. * We need to implement it so that we can programmatically scroll to items outside the virtual render window of the SectionList. @@ -279,7 +277,7 @@ function BaseOptionsList({ initialNumToRender={12} maxToRenderPerBatch={5} windowSize={5} - viewabilityConfig={viewConfigRef.current} + viewabilityConfig={{viewAreaCoveragePercentThreshold: 95}} onViewableItemsChanged={onViewableItemsChanged} bounces={bounces} /> From 8c9751c0dd7617f2fe10db14ac2f7774f2024d6c Mon Sep 17 00:00:00 2001 From: Adam Horodyski Date: Fri, 27 Oct 2023 11:50:45 +0200 Subject: [PATCH 082/105] chore: use predefined optionRowHeight instead of paymentMethodHeight style variable --- src/pages/settings/Wallet/PaymentMethodList.js | 4 ++-- src/styles/styles.ts | 2 +- src/styles/variables.ts | 1 - 3 files changed, 3 insertions(+), 4 deletions(-) diff --git a/src/pages/settings/Wallet/PaymentMethodList.js b/src/pages/settings/Wallet/PaymentMethodList.js index efbe8993c84f..5125832f6eb3 100644 --- a/src/pages/settings/Wallet/PaymentMethodList.js +++ b/src/pages/settings/Wallet/PaymentMethodList.js @@ -333,9 +333,9 @@ function PaymentMethodList({ return ( <> - + paymentMethod: { paddingHorizontal: 20, - height: variables.paymentMethodHeight, + height: variables.optionRowHeight, }, archivedReportFooter: { diff --git a/src/styles/variables.ts b/src/styles/variables.ts index d88fb2822b36..382ed3e032d1 100644 --- a/src/styles/variables.ts +++ b/src/styles/variables.ts @@ -152,7 +152,6 @@ export default { anonymousReportFooterBreakpoint: 650, dropDownButtonDividerHeight: 28, addPaymentMethodLeftSpacing: 2, - paymentMethodHeight: 64, addBankAccountLeftSpacing: 3, eReceiptThumbnailSmallBreakpoint: 110, eReceiptThumbnailMediumBreakpoint: 335, From 81a05f8196ee50b73ba3b826977a976aa8945e94 Mon Sep 17 00:00:00 2001 From: Bartosz Grajdek Date: Fri, 27 Oct 2023 13:26:35 +0200 Subject: [PATCH 083/105] Style fixes in Text.tsx --- src/components/Text.tsx | 24 ++++-------------------- 1 file changed, 4 insertions(+), 20 deletions(-) diff --git a/src/components/Text.tsx b/src/components/Text.tsx index 60a59aae1520..5cb252626d1f 100644 --- a/src/components/Text.tsx +++ b/src/components/Text.tsx @@ -1,62 +1,46 @@ import React, {ForwardedRef} from 'react'; // eslint-disable-next-line no-restricted-imports -import {Text as RNText} from 'react-native'; +import {Text as RNText, TextProps as RNTextProps, StyleSheet} from 'react-native'; import type {TextStyle} from 'react-native'; import fontFamily from '../styles/fontFamily'; import themeColors from '../styles/themes/default'; import variables from '../styles/variables'; -type TextProps = { +type TextProps = RNTextProps & { /** The color of the text */ color?: string; /** The size of the text */ fontSize?: number; - /** The alignment of the text */ textAlign?: 'left' | 'right' | 'auto' | 'center' | 'justify'; - /** Any children to display */ children: React.ReactNode; /** The family of the font to use */ family?: keyof typeof fontFamily; - - /** Any additional styles to apply */ - style?: TextStyle | TextStyle[]; }; function Text( {color = themeColors.text, fontSize = variables.fontSizeNormal, textAlign = 'left', children = null, family = 'EXP_NEUE', style = {}, ...props}: TextProps, ref: ForwardedRef, ) { - // If the style prop is an array of styles, we need to mix them all together - const mergedStyles = !Array.isArray(style) - ? style - : style.reduce( - (finalStyles, s) => ({ - ...finalStyles, - ...s, - }), - {}, - ); const componentStyle: TextStyle = { color, fontSize, textAlign, fontFamily: fontFamily[family], - ...mergedStyles, + ...StyleSheet.flatten(style), }; if (!componentStyle.lineHeight && componentStyle.fontSize === variables.fontSizeNormal) { componentStyle.lineHeight = variables.fontSizeNormalHeight; } - return ( From 9c0efa5a8c469204de83fcfa43f691daf41487ed Mon Sep 17 00:00:00 2001 From: Bartosz Grajdek Date: Fri, 27 Oct 2023 13:36:53 +0200 Subject: [PATCH 084/105] Fix tests --- tests/ui/UnreadIndicatorsTest.js | 25 +++++++------------------ 1 file changed, 7 insertions(+), 18 deletions(-) diff --git a/tests/ui/UnreadIndicatorsTest.js b/tests/ui/UnreadIndicatorsTest.js index a9ffe258ac7f..5615e0b67729 100644 --- a/tests/ui/UnreadIndicatorsTest.js +++ b/tests/ui/UnreadIndicatorsTest.js @@ -221,7 +221,7 @@ describe('Unread Indicators', () => { // And that the text is bold const displayNameHintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNameText = screen.queryByLabelText(displayNameHintText); - expect(lodashGet(displayNameText, ['props', 'style', 0, 'fontWeight'])).toBe(fontWeightBold); + expect(lodashGet(displayNameText, ['props', 'style', 'fontWeight'])).toBe(fontWeightBold); return navigateToSidebarOption(0); }) @@ -233,7 +233,6 @@ describe('Unread Indicators', () => { const reportCommentsHintText = Localize.translateLocal('accessibilityHints.chatMessage'); const reportComments = screen.queryAllByLabelText(reportCommentsHintText); expect(reportComments).toHaveLength(9); - // Since the last read timestamp is the timestamp of action 3 we should have an unread indicator above the next "unread" action which will // have actionID of 4 const newMessageLineIndicatorHintText = Localize.translateLocal('accessibilityHints.newMessageLineIndicator'); @@ -241,12 +240,10 @@ describe('Unread Indicators', () => { expect(unreadIndicator).toHaveLength(1); const reportActionID = lodashGet(unreadIndicator, [0, 'props', 'data-action-id']); expect(reportActionID).toBe('4'); - // Scroll up and verify that the "New messages" badge appears scrollUpToRevealNewMessagesBadge(); return waitFor(() => expect(isNewMessagesBadgeVisible()).toBe(true)); })); - it('Clear the new line indicator and bold when we navigate away from a chat that is now read', () => signInAndGetAppWithUnreadChat() // Navigate to the unread chat from the sidebar @@ -255,14 +252,12 @@ describe('Unread Indicators', () => { .then(() => navigateToSidebarOption(0)) .then(() => { expect(areYouOnChatListScreen()).toBe(false); - // Then navigate back to the sidebar return navigateToSidebar(); }) .then(() => { // Verify the LHN is now open expect(areYouOnChatListScreen()).toBe(true); - // Tap on the chat again return navigateToSidebarOption(0); }) @@ -271,7 +266,6 @@ describe('Unread Indicators', () => { const newMessageLineIndicatorHintText = Localize.translateLocal('accessibilityHints.newMessageLineIndicator'); const unreadIndicator = screen.queryAllByLabelText(newMessageLineIndicatorHintText); expect(unreadIndicator).toHaveLength(0); - // Tap on the chat again return navigateToSidebarOption(0); }) @@ -282,7 +276,6 @@ describe('Unread Indicators', () => { expect(unreadIndicator).toHaveLength(0); expect(areYouOnChatListScreen()).toBe(false); })); - it('Shows a browser notification and bold text when a new message arrives for a chat that is read', () => signInAndGetAppWithUnreadChat() .then(() => { @@ -291,7 +284,6 @@ describe('Unread Indicators', () => { const NEW_REPORT_ID = '2'; const NEW_REPORT_CREATED_DATE = subSeconds(new Date(), 5); const NEW_REPORT_FIST_MESSAGE_CREATED_DATE = addSeconds(NEW_REPORT_CREATED_DATE, 1); - const createdReportActionID = NumberUtils.rand64(); const commentReportActionID = NumberUtils.rand64(); const channel = Pusher.getChannel(`${CONST.PUSHER.PRIVATE_USER_CHANNEL_PREFIX}${USER_A_ACCOUNT_ID}${CONFIG.PUSHER.SUFFIX}`); @@ -354,17 +346,16 @@ describe('Unread Indicators', () => { const optionRowsHintText = Localize.translateLocal('accessibilityHints.navigatesToChat'); const optionRows = screen.queryAllByAccessibilityHint(optionRowsHintText); expect(optionRows).toHaveLength(2); - // Verify the text for both chats are bold indicating that nothing has not yet been read const displayNameHintTexts = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNameTexts = screen.queryAllByLabelText(displayNameHintTexts); expect(displayNameTexts).toHaveLength(2); const firstReportOption = displayNameTexts[0]; - expect(lodashGet(firstReportOption, ['props', 'style', 0, 'fontWeight'])).toBe(fontWeightBold); + expect(lodashGet(firstReportOption, ['props', 'style', 'fontWeight'])).toBe(fontWeightBold); expect(lodashGet(firstReportOption, ['props', 'children'])).toBe('C User'); const secondReportOption = displayNameTexts[1]; - expect(lodashGet(secondReportOption, ['props', 'style', 0, 'fontWeight'])).toBe(fontWeightBold); + expect(lodashGet(secondReportOption, ['props', 'style', 'fontWeight'])).toBe(fontWeightBold); expect(lodashGet(secondReportOption, ['props', 'children'])).toBe('B User'); // Tap the new report option and navigate back to the sidebar again via the back button @@ -376,9 +367,9 @@ describe('Unread Indicators', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(2); - expect(lodashGet(displayNameTexts[0], ['props', 'style', 0, 'fontWeight'])).toBe(undefined); + expect(lodashGet(displayNameTexts[0], ['props', 'style', 'fontWeight'])).toBe(undefined); expect(lodashGet(displayNameTexts[0], ['props', 'children'])).toBe('C User'); - expect(lodashGet(displayNameTexts[1], ['props', 'style', 0, 'fontWeight'])).toBe(fontWeightBold); + expect(lodashGet(displayNameTexts[1], ['props', 'style', 'fontWeight'])).toBe(fontWeightBold); expect(lodashGet(displayNameTexts[1], ['props', 'children'])).toBe('B User'); })); @@ -399,12 +390,10 @@ describe('Unread Indicators', () => { expect(unreadIndicator).toHaveLength(1); const reportActionID = lodashGet(unreadIndicator, [0, 'props', 'data-action-id']); expect(reportActionID).toBe('3'); - // Scroll up and verify the new messages badge appears scrollUpToRevealNewMessagesBadge(); return waitFor(() => expect(isNewMessagesBadgeVisible()).toBe(true)); }) - // Navigate to the sidebar .then(navigateToSidebar) .then(() => { @@ -412,7 +401,7 @@ describe('Unread Indicators', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(1); - expect(lodashGet(displayNameTexts[0], ['props', 'style', 0, 'fontWeight'])).toBe(fontWeightBold); + expect(lodashGet(displayNameTexts[0], ['props', 'style', 'fontWeight'])).toBe(fontWeightBold); expect(lodashGet(displayNameTexts[0], ['props', 'children'])).toBe('B User'); // Navigate to the report again and back to the sidebar @@ -424,7 +413,7 @@ describe('Unread Indicators', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(1); - expect(lodashGet(displayNameTexts[0], ['props', 'style', 0, 'fontWeight'])).toBe(undefined); + expect(lodashGet(displayNameTexts[0], ['props', 'style', 'fontWeight'])).toBe(undefined); expect(lodashGet(displayNameTexts[0], ['props', 'children'])).toBe('B User'); // Navigate to the report again and verify the new line indicator is missing From ffa49c0a40e18b397ccbe8bde6fb2e0966aea750 Mon Sep 17 00:00:00 2001 From: Justin Persaud Date: Fri, 27 Oct 2023 09:37:29 -0400 Subject: [PATCH 085/105] Add imgbot config --- .imgbotconfig | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 .imgbotconfig diff --git a/.imgbotconfig b/.imgbotconfig new file mode 100644 index 000000000000..9996ba809af1 --- /dev/null +++ b/.imgbotconfig @@ -0,0 +1,6 @@ +{ + "ignoredFiles": [ + "assets/images/empty-state_background-fade.png", // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 + ], + "aggressiveCompression": "false" +} From 4191b3998c42c020cd85fd6acd9f5f4ffecf0959 Mon Sep 17 00:00:00 2001 From: Justin Persaud Date: Fri, 27 Oct 2023 09:39:15 -0400 Subject: [PATCH 086/105] revert optimization on empty state background --- assets/images/empty-state_background-fade.png | Bin 129303 -> 174425 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/assets/images/empty-state_background-fade.png b/assets/images/empty-state_background-fade.png index e449ca1efa23935994adec4be33b7cb4083777f9..816ff7343310f1a5a88f70e51dfd67b9860c2311 100644 GIT binary patch literal 174425 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 z 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

MM>puOTFE*(-3GIyUQ(({CK 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

yGFT$oSQNd3xwyOp7-^(l*?Pp<~il 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 b2Kd?eL4D&QM*MVuMikdfZd8PgbGdyld From ee5e6de5e8c34f8f60d6d78f4b83aa159c1e9dec Mon Sep 17 00:00:00 2001 From: OSBotify Date: Fri, 27 Oct 2023 14:09:00 +0000 Subject: [PATCH 087/105] Update version to 1.3.92-1 --- android/app/build.gradle | 4 ++-- ios/NewExpensify/Info.plist | 2 +- ios/NewExpensifyTests/Info.plist | 2 +- package-lock.json | 4 ++-- package.json | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/android/app/build.gradle b/android/app/build.gradle index cf8097adc18f..3b5d9814cf67 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -90,8 +90,8 @@ android { minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion multiDexEnabled rootProject.ext.multiDexEnabled - versionCode 1001039200 - versionName "1.3.92-0" + versionCode 1001039201 + versionName "1.3.92-1" } flavorDimensions "default" diff --git a/ios/NewExpensify/Info.plist b/ios/NewExpensify/Info.plist index 759364765b4c..1292487b6288 100644 --- a/ios/NewExpensify/Info.plist +++ b/ios/NewExpensify/Info.plist @@ -40,7 +40,7 @@ CFBundleVersion - 1.3.92.0 + 1.3.92.1 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/ios/NewExpensifyTests/Info.plist b/ios/NewExpensifyTests/Info.plist index 6dd2088565cb..ba40bc30cb66 100644 --- a/ios/NewExpensifyTests/Info.plist +++ b/ios/NewExpensifyTests/Info.plist @@ -19,6 +19,6 @@ CFBundleSignature ???? CFBundleVersion - 1.3.92.0 + 1.3.92.1 diff --git a/package-lock.json b/package-lock.json index f852bc4ddee4..750da0129a81 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "new.expensify", - "version": "1.3.92-0", + "version": "1.3.92-1", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "new.expensify", - "version": "1.3.92-0", + "version": "1.3.92-1", "hasInstallScript": true, "license": "MIT", "dependencies": { diff --git a/package.json b/package.json index a5d189bf943c..1bf9f59d88a0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "new.expensify", - "version": "1.3.92-0", + "version": "1.3.92-1", "author": "Expensify, Inc.", "homepage": "https://new.expensify.com", "description": "New Expensify is the next generation of Expensify: a reimagination of payments based atop a foundation of chat.", From e00029654f0922f486632450284baa10826d2c23 Mon Sep 17 00:00:00 2001 From: Amy Evans Date: Fri, 27 Oct 2023 10:42:55 -0400 Subject: [PATCH 088/105] Update formatting per prettier --- .imgbotconfig | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.imgbotconfig b/.imgbotconfig index 9996ba809af1..ff5c3345cc4d 100644 --- a/.imgbotconfig +++ b/.imgbotconfig @@ -1,6 +1,6 @@ { "ignoredFiles": [ - "assets/images/empty-state_background-fade.png", // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 + "assets/images/empty-state_background-fade.png" // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 ], "aggressiveCompression": "false" } From 6777fb5e78b22342a8c25b86c26eb8e6ca985227 Mon Sep 17 00:00:00 2001 From: Hardik Choudhary Date: Fri, 27 Oct 2023 20:40:02 +0530 Subject: [PATCH 089/105] emoji/mention suggestion are displayed --- src/libs/convertToLTRForComposer/index.ts | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/src/libs/convertToLTRForComposer/index.ts b/src/libs/convertToLTRForComposer/index.ts index eb14bfa8c11a..c29c27362458 100644 --- a/src/libs/convertToLTRForComposer/index.ts +++ b/src/libs/convertToLTRForComposer/index.ts @@ -1,19 +1,27 @@ import CONST from '../../CONST'; import ConvertToLTRForComposer from './types'; -function hasLTRorRTLCharacters(text: string): boolean { - // Regular expressions to match LTR and RTL character ranges. +function hasRTLCharacters(text: string): boolean { + // Regular expressions to match RTL character ranges. + const rtlPattern = /[\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC]/; + return rtlPattern.test(text); +} +function hasLTRCharacters(text: string): boolean { + // Regular expressions to match LTR character ranges. // eslint-disable-next-line no-control-regex const ltrPattern = /[\u0001-\u05FF\u0600-\u06FF\u0750-\u077F\uFB50-\uFDFF\uFE70-\uFEFF]/; - const rtlPattern = /[\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC]/; - return ltrPattern.test(text) || rtlPattern.test(text); + return ltrPattern.test(text); } // Converts a given text to ensure it starts with the LTR (Left-to-Right) marker. const convertToLTRForComposer: ConvertToLTRForComposer = (text) => { - // Ensure the text contains LTR or RTL characters to avoid an unwanted special character at the beginning, even after a backspace deletion. - if (!hasLTRorRTLCharacters(text)) { + // Ensure that the text starts with RTL characters if not we return the same text to avoid concatination with special character at the start which leads to unexpected behaviour for Emoji/Mention suggestions. + if (!hasRTLCharacters(text)) { + // If text contains LTR character return the same text otherwise return an empty string to avoid an empty draft due to special character. + if (hasLTRCharacters(text)) { + return text; + } return ''; } From 4bc16b4d26795f724df4a77e5a16055b2ab5d5ce Mon Sep 17 00:00:00 2001 From: rory Date: Fri, 27 Oct 2023 08:28:35 -0700 Subject: [PATCH 090/105] Include more paths in lint workflow --- .github/workflows/lint.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 9d7efc7d4c29..ee9d66b59e90 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -5,7 +5,7 @@ on: pull_request: types: [opened, synchronize] branches-ignore: [staging, production] - paths: ['**.js', '**.ts', '**.tsx'] + paths: ['**.js', '**.ts', '**.tsx', '**.json', '**.mjs', '**.cjs', '.editorconfig', '.watchmanconfig'] jobs: lint: From 3704cb5d6007ee68fad184814aeae156ac19a2a0 Mon Sep 17 00:00:00 2001 From: rory Date: Fri, 27 Oct 2023 08:33:27 -0700 Subject: [PATCH 091/105] Move comment to test change in .imgbotconfig --- .imgbotconfig | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.imgbotconfig b/.imgbotconfig index ff5c3345cc4d..feccb69b68ad 100644 --- a/.imgbotconfig +++ b/.imgbotconfig @@ -1,6 +1,7 @@ { "ignoredFiles": [ - "assets/images/empty-state_background-fade.png" // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 + // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 + "assets/images/empty-state_background-fade.png" ], "aggressiveCompression": "false" } From 55284576dd3fbc8da3f7c46425ac081bef4714ee Mon Sep 17 00:00:00 2001 From: rory Date: Fri, 27 Oct 2023 08:35:32 -0700 Subject: [PATCH 092/105] include imgbotconfig --- .github/workflows/lint.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index ee9d66b59e90..3072b3354a84 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -5,7 +5,7 @@ on: pull_request: types: [opened, synchronize] branches-ignore: [staging, production] - paths: ['**.js', '**.ts', '**.tsx', '**.json', '**.mjs', '**.cjs', '.editorconfig', '.watchmanconfig'] + paths: ['**.js', '**.ts', '**.tsx', '**.json', '**.mjs', '**.cjs', 'config/.editorconfig', '.watchmanconfig', '.imgbotconfig'] jobs: lint: From e4e6fd8819fced935e3ec7794d66d9209a004417 Mon Sep 17 00:00:00 2001 From: rory Date: Fri, 27 Oct 2023 08:36:26 -0700 Subject: [PATCH 093/105] Move comment back --- .imgbotconfig | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.imgbotconfig b/.imgbotconfig index feccb69b68ad..ff5c3345cc4d 100644 --- a/.imgbotconfig +++ b/.imgbotconfig @@ -1,7 +1,6 @@ { "ignoredFiles": [ - // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 - "assets/images/empty-state_background-fade.png" + "assets/images/empty-state_background-fade.png" // Caused an issue with colour gradients, https://github.com/Expensify/App/issues/30499 ], "aggressiveCompression": "false" } From 8531566b46380a9c66c541ed0af5735addd65209 Mon Sep 17 00:00:00 2001 From: Youssef Lourayad Date: Fri, 27 Oct 2023 20:02:35 +0400 Subject: [PATCH 094/105] Apply fix in AttachmentModal instead of BaseOptionsList --- src/components/OptionsList/BaseOptionsList.js | 6 +++--- src/pages/home/report/ReportAttachments.js | 15 ++++++++++----- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/src/components/OptionsList/BaseOptionsList.js b/src/components/OptionsList/BaseOptionsList.js index 5a700ae61da2..91fd77dbea30 100644 --- a/src/components/OptionsList/BaseOptionsList.js +++ b/src/components/OptionsList/BaseOptionsList.js @@ -1,5 +1,5 @@ import _ from 'underscore'; -import React, {useRef, useCallback, useEffect, forwardRef, memo} from 'react'; +import React, {useRef, useEffect, forwardRef, memo} from 'react'; import {View} from 'react-native'; import PropTypes from 'prop-types'; import styles from '../../styles/styles'; @@ -120,14 +120,14 @@ function BaseOptionsList({ flattenedData.current = buildFlatSectionArray(); }); - const onViewableItemsChanged = useCallback(() => { + const onViewableItemsChanged = () => { if (didLayout.current || !onLayout) { return; } didLayout.current = true; onLayout(); - }, [didLayout, onLayout]); + }; /** * This function is used to compute the layout of any given item in our list. diff --git a/src/pages/home/report/ReportAttachments.js b/src/pages/home/report/ReportAttachments.js index 5f194d10bce3..23da908fed17 100644 --- a/src/pages/home/report/ReportAttachments.js +++ b/src/pages/home/report/ReportAttachments.js @@ -1,4 +1,4 @@ -import React from 'react'; +import React, {useCallback} from 'react'; import _ from 'underscore'; import PropTypes from 'prop-types'; import AttachmentModal from '../../../components/AttachmentModal'; @@ -24,6 +24,14 @@ function ReportAttachments(props) { const report = ReportUtils.getReport(reportID); const source = decodeURI(_.get(props, ['route', 'params', 'source'])); + const onCarouselAttachmentChange = useCallback( + (attachment) => { + const route = ROUTES.REPORT_ATTACHMENTS.getRoute(reportID, attachment.source); + Navigation.navigate(route); + }, + [reportID], + ); + return ( Navigation.dismissModal()} - onCarouselAttachmentChange={(attachment) => { - const route = ROUTES.REPORT_ATTACHMENTS.getRoute(reportID, attachment.source); - Navigation.navigate(route); - }} + onCarouselAttachmentChange={onCarouselAttachmentChange} /> ); } From e3df74f4c2e353c25a23e9d7e2bb0c25fed7b952 Mon Sep 17 00:00:00 2001 From: OSBotify Date: Fri, 27 Oct 2023 16:44:25 +0000 Subject: [PATCH 095/105] Update version to 1.3.92-2 --- android/app/build.gradle | 4 ++-- ios/NewExpensify/Info.plist | 2 +- ios/NewExpensifyTests/Info.plist | 2 +- package-lock.json | 4 ++-- package.json | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/android/app/build.gradle b/android/app/build.gradle index 3b5d9814cf67..242164594fd8 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -90,8 +90,8 @@ android { minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion multiDexEnabled rootProject.ext.multiDexEnabled - versionCode 1001039201 - versionName "1.3.92-1" + versionCode 1001039202 + versionName "1.3.92-2" } flavorDimensions "default" diff --git a/ios/NewExpensify/Info.plist b/ios/NewExpensify/Info.plist index 1292487b6288..4e2edb559ee4 100644 --- a/ios/NewExpensify/Info.plist +++ b/ios/NewExpensify/Info.plist @@ -40,7 +40,7 @@ CFBundleVersion - 1.3.92.1 + 1.3.92.2 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/ios/NewExpensifyTests/Info.plist b/ios/NewExpensifyTests/Info.plist index ba40bc30cb66..781853ba92d2 100644 --- a/ios/NewExpensifyTests/Info.plist +++ b/ios/NewExpensifyTests/Info.plist @@ -19,6 +19,6 @@ CFBundleSignature ???? CFBundleVersion - 1.3.92.1 + 1.3.92.2 diff --git a/package-lock.json b/package-lock.json index 750da0129a81..14cee71de530 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "new.expensify", - "version": "1.3.92-1", + "version": "1.3.92-2", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "new.expensify", - "version": "1.3.92-1", + "version": "1.3.92-2", "hasInstallScript": true, "license": "MIT", "dependencies": { diff --git a/package.json b/package.json index 1bf9f59d88a0..e514f5afead0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "new.expensify", - "version": "1.3.92-1", + "version": "1.3.92-2", "author": "Expensify, Inc.", "homepage": "https://new.expensify.com", "description": "New Expensify is the next generation of Expensify: a reimagination of payments based atop a foundation of chat.", From 11053d98a92c1045ed45fa43022bc0f3ce5ddcf6 Mon Sep 17 00:00:00 2001 From: Hardik Choudhary Date: Fri, 27 Oct 2023 22:31:42 +0530 Subject: [PATCH 096/105] native emoji support added --- src/libs/convertToLTRForComposer/index.ts | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/src/libs/convertToLTRForComposer/index.ts b/src/libs/convertToLTRForComposer/index.ts index c29c27362458..79c1eaed59a5 100644 --- a/src/libs/convertToLTRForComposer/index.ts +++ b/src/libs/convertToLTRForComposer/index.ts @@ -6,23 +6,16 @@ function hasRTLCharacters(text: string): boolean { const rtlPattern = /[\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC]/; return rtlPattern.test(text); } -function hasLTRCharacters(text: string): boolean { - // Regular expressions to match LTR character ranges. - // eslint-disable-next-line no-control-regex - const ltrPattern = /[\u0001-\u05FF\u0600-\u06FF\u0750-\u077F\uFB50-\uFDFF\uFE70-\uFEFF]/; - - return ltrPattern.test(text); -} // Converts a given text to ensure it starts with the LTR (Left-to-Right) marker. const convertToLTRForComposer: ConvertToLTRForComposer = (text) => { // Ensure that the text starts with RTL characters if not we return the same text to avoid concatination with special character at the start which leads to unexpected behaviour for Emoji/Mention suggestions. if (!hasRTLCharacters(text)) { - // If text contains LTR character return the same text otherwise return an empty string to avoid an empty draft due to special character. - if (hasLTRCharacters(text)) { - return text; + // If text is empty string return empty string to avoid an empty draft due to special character. + if (text === '' || CONST.UNICODE.LTR.match(text)) { + return ''; } - return ''; + return text; } // Check if the text contains only spaces. If it does, we do not concatenate it with CONST.UNICODE.LTR, From c01af10eec5d3ff75f709c8afb951869d4f32a82 Mon Sep 17 00:00:00 2001 From: Carlos Martins Date: Fri, 27 Oct 2023 12:11:48 -0600 Subject: [PATCH 097/105] Revert "[Form Provider Refactor] RoomNameInput" --- src/components/Form/FormProvider.js | 24 +++---- src/components/Form/InputWrapper.js | 2 - src/components/RoomNameInput/index.js | 50 ++++++++++---- src/components/RoomNameInput/index.native.js | 66 +++++++++++++++++++ .../RoomNameInput/roomNameInputPropTypes.js | 6 +- src/pages/settings/Report/RoomNamePage.js | 8 +-- src/pages/workspace/WorkspaceNewRoomPage.js | 21 +++--- 7 files changed, 128 insertions(+), 49 deletions(-) create mode 100644 src/components/RoomNameInput/index.native.js diff --git a/src/components/Form/FormProvider.js b/src/components/Form/FormProvider.js index ce402976d097..add58dbef18c 100644 --- a/src/components/Form/FormProvider.js +++ b/src/components/Form/FormProvider.js @@ -229,15 +229,13 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC .first() .value() || ''; - const value = !_.isUndefined(inputValues[`${inputID}ToDisplay`]) ? inputValues[`${inputID}ToDisplay`] : inputValues[inputID]; - return { ...propsToParse, ref: newRef, inputID, key: propsToParse.key || inputID, errorText: errors[inputID] || fieldErrorMessage, - value, + value: inputValues[inputID], // As the text input is controlled, we never set the defaultValue prop // as this is already happening by the value prop. defaultValue: undefined, @@ -277,19 +275,13 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC propsToParse.onBlur(event); } }, - onInputChange: (inputValue, key) => { + onInputChange: (value, key) => { const inputKey = key || inputID; setInputValues((prevState) => { - const newState = _.isFunction(propsToParse.valueParser) - ? { - ...prevState, - [inputKey]: propsToParse.valueParser(inputValue), - [`${inputKey}ToDisplay`]: inputValue, - } - : { - ...prevState, - [inputKey]: inputValue, - }; + const newState = { + ...prevState, + [inputKey]: value, + }; if (shouldValidateOnChange) { onValidate(newState); @@ -298,11 +290,11 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC }); if (propsToParse.shouldSaveDraft) { - FormActions.setDraftValues(propsToParse.formID, {[inputKey]: inputValue}); + FormActions.setDraftValues(propsToParse.formID, {[inputKey]: value}); } if (_.isFunction(propsToParse.onValueChange)) { - propsToParse.onValueChange(inputValue, inputKey); + propsToParse.onValueChange(value, inputKey); } }, }; diff --git a/src/components/Form/InputWrapper.js b/src/components/Form/InputWrapper.js index 74a741239a3f..8a87bc2f5a5a 100644 --- a/src/components/Form/InputWrapper.js +++ b/src/components/Form/InputWrapper.js @@ -7,13 +7,11 @@ const propTypes = { inputID: PropTypes.string.isRequired, valueType: PropTypes.string, forwardedRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({current: PropTypes.instanceOf(React.Component)})]), - valueParser: PropTypes.func, }; const defaultProps = { forwardedRef: undefined, valueType: 'string', - valueParser: undefined, }; function InputWrapper(props) { diff --git a/src/components/RoomNameInput/index.js b/src/components/RoomNameInput/index.js index 197b6b77acae..ec9bf7a090ab 100644 --- a/src/components/RoomNameInput/index.js +++ b/src/components/RoomNameInput/index.js @@ -1,23 +1,49 @@ -import React from 'react'; +import React, {useState} from 'react'; +import _ from 'underscore'; import CONST from '../../CONST'; import TextInput from '../TextInput'; import useLocalize from '../../hooks/useLocalize'; import * as roomNameInputPropTypes from './roomNameInputPropTypes'; -import InputWrapper from '../Form/InputWrapper'; -import getOperatingSystem from '../../libs/getOperatingSystem'; import * as RoomNameInputUtils from '../../libs/RoomNameInputUtils'; -function RoomNameInput({isFocused, autoFocus, disabled, errorText, forwardedRef, onBlur, shouldDelayFocus, inputID}) { +function RoomNameInput({isFocused, autoFocus, disabled, errorText, forwardedRef, value, onBlur, onChangeText, onInputChange, shouldDelayFocus}) { const {translate} = useLocalize(); - const keyboardType = getOperatingSystem() === CONST.OS.IOS ? CONST.KEYBOARD_TYPE.ASCII_CAPABLE : CONST.KEYBOARD_TYPE.VISIBLE_PASSWORD; + const [selection, setSelection] = useState(); - const valueParser = (roomName) => RoomNameInputUtils.modifyRoomName(roomName); + /** + * Calls the onChangeText callback with a modified room name + * @param {Event} event + */ + const setModifiedRoomName = (event) => { + const roomName = event.nativeEvent.text; + const modifiedRoomName = RoomNameInputUtils.modifyRoomName(roomName); + onChangeText(modifiedRoomName); + + // if custom component has onInputChange, use it to trigger changes (Form input) + if (_.isFunction(onInputChange)) { + onInputChange(modifiedRoomName); + } + + // Prevent cursor jump behaviour: + // Check if newRoomNameWithHash is the same as modifiedRoomName + // If it is then the room name is valid (does not contain unallowed characters); no action required + // If not then the room name contains unvalid characters and we must adjust the cursor position manually + // Read more: https://github.com/Expensify/App/issues/12741 + const oldRoomNameWithHash = value || ''; + const newRoomNameWithHash = `${CONST.POLICY.ROOM_PREFIX}${roomName}`; + if (modifiedRoomName !== newRoomNameWithHash) { + const offset = modifiedRoomName.length - oldRoomNameWithHash.length; + const newSelection = { + start: selection.start + offset, + end: selection.end + offset, + }; + setSelection(newSelection); + } + }; return ( - setSelection(event.nativeEvent.selection)} errorText={errorText} - valueParser={valueParser} autoCapitalize="none" onBlur={() => isFocused && onBlur()} shouldDelayFocus={shouldDelayFocus} @@ -34,7 +63,6 @@ function RoomNameInput({isFocused, autoFocus, disabled, errorText, forwardedRef, maxLength={CONST.REPORT.MAX_ROOM_NAME_LENGTH} spellCheck={false} shouldInterceptSwipe - keyboardType={keyboardType} // this is a bit hacky solution to a RN issue https://github.com/facebook/react-native/issues/27449 /> ); } diff --git a/src/components/RoomNameInput/index.native.js b/src/components/RoomNameInput/index.native.js new file mode 100644 index 000000000000..9e83a673982c --- /dev/null +++ b/src/components/RoomNameInput/index.native.js @@ -0,0 +1,66 @@ +import React from 'react'; +import _ from 'underscore'; +import CONST from '../../CONST'; +import useLocalize from '../../hooks/useLocalize'; +import TextInput from '../TextInput'; +import * as roomNameInputPropTypes from './roomNameInputPropTypes'; +import * as RoomNameInputUtils from '../../libs/RoomNameInputUtils'; +import getOperatingSystem from '../../libs/getOperatingSystem'; + +function RoomNameInput({isFocused, autoFocus, disabled, errorText, forwardedRef, value, onBlur, onChangeText, onInputChange, shouldDelayFocus}) { + const {translate} = useLocalize(); + + /** + * Calls the onChangeText callback with a modified room name + * @param {Event} event + */ + const setModifiedRoomName = (event) => { + const roomName = event.nativeEvent.text; + const modifiedRoomName = RoomNameInputUtils.modifyRoomName(roomName); + onChangeText(modifiedRoomName); + + // if custom component has onInputChange, use it to trigger changes (Form input) + if (_.isFunction(onInputChange)) { + onInputChange(modifiedRoomName); + } + }; + + const keyboardType = getOperatingSystem() === CONST.OS.IOS ? CONST.KEYBOARD_TYPE.ASCII_CAPABLE : CONST.KEYBOARD_TYPE.VISIBLE_PASSWORD; + + return ( + isFocused && onBlur()} + autoFocus={isFocused && autoFocus} + autoCapitalize="none" + shouldDelayFocus={shouldDelayFocus} + /> + ); +} + +RoomNameInput.propTypes = roomNameInputPropTypes.propTypes; +RoomNameInput.defaultProps = roomNameInputPropTypes.defaultProps; +RoomNameInput.displayName = 'RoomNameInput'; + +const RoomNameInputWithRef = React.forwardRef((props, ref) => ( + +)); + +RoomNameInputWithRef.displayName = 'RoomNameInputWithRef'; + +export default RoomNameInputWithRef; diff --git a/src/components/RoomNameInput/roomNameInputPropTypes.js b/src/components/RoomNameInput/roomNameInputPropTypes.js index 3d1ad18d27b3..7f8292f0123e 100644 --- a/src/components/RoomNameInput/roomNameInputPropTypes.js +++ b/src/components/RoomNameInput/roomNameInputPropTypes.js @@ -1,5 +1,4 @@ import PropTypes from 'prop-types'; -import refPropTypes from '../refPropTypes'; const propTypes = { /** Callback to execute when the text input is modified correctly */ @@ -15,10 +14,10 @@ const propTypes = { errorText: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object]))]), /** A ref forwarded to the TextInput */ - forwardedRef: refPropTypes, + forwardedRef: PropTypes.func, /** The ID used to uniquely identify the input in a Form */ - inputID: PropTypes.string.isRequired, + inputID: PropTypes.string, /** Callback that is called when the text input is blurred */ onBlur: PropTypes.func, @@ -40,6 +39,7 @@ const defaultProps = { errorText: '', forwardedRef: () => {}, + inputID: undefined, onBlur: () => {}, autoFocus: false, shouldDelayFocus: false, diff --git a/src/pages/settings/Report/RoomNamePage.js b/src/pages/settings/Report/RoomNamePage.js index 8163b09ca943..4ce997533378 100644 --- a/src/pages/settings/Report/RoomNamePage.js +++ b/src/pages/settings/Report/RoomNamePage.js @@ -7,6 +7,7 @@ import CONST from '../../../CONST'; import ScreenWrapper from '../../../components/ScreenWrapper'; import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; +import Form from '../../../components/Form'; import ONYXKEYS from '../../../ONYXKEYS'; import styles from '../../../styles/styles'; import Navigation from '../../../libs/Navigation/Navigation'; @@ -20,7 +21,6 @@ import * as Report from '../../../libs/actions/Report'; import RoomNameInput from '../../../components/RoomNameInput'; import * as ReportUtils from '../../../libs/ReportUtils'; import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; -import FormProvider from '../../../components/Form/FormProvider'; const propTypes = { ...withLocalizePropTypes, @@ -90,7 +90,7 @@ function RoomNamePage(props) { title={translate('newRoomPage.roomName')} onBackButtonPress={() => Navigation.goBack(ROUTES.REPORT_SETTINGS.getRoute(report.reportID))} /> - Report.updatePolicyRoomNameAndNavigate(report, values.roomName)} @@ -100,13 +100,13 @@ function RoomNamePage(props) { > (roomNameInputRef.current = ref)} inputID="roomName" defaultValue={report.reportName} isFocused={isFocused} /> - + ); diff --git a/src/pages/workspace/WorkspaceNewRoomPage.js b/src/pages/workspace/WorkspaceNewRoomPage.js index 548b00254721..c059a54b7c21 100644 --- a/src/pages/workspace/WorkspaceNewRoomPage.js +++ b/src/pages/workspace/WorkspaceNewRoomPage.js @@ -20,14 +20,13 @@ import * as ErrorUtils from '../../libs/ErrorUtils'; import * as ValidationUtils from '../../libs/ValidationUtils'; import * as ReportUtils from '../../libs/ReportUtils'; import * as PolicyUtils from '../../libs/PolicyUtils'; +import Form from '../../components/Form'; import policyMemberPropType from '../policyMemberPropType'; import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; import compose from '../../libs/compose'; import variables from '../../styles/variables'; import useDelayedInputFocus from '../../hooks/useDelayedInputFocus'; import ValuePicker from '../../components/ValuePicker'; -import FormProvider from '../../components/Form/FormProvider'; -import InputWrapper from '../../components/Form/InputWrapper'; const propTypes = { /** All reports shared with the user */ @@ -184,7 +183,7 @@ function WorkspaceNewRoomPage(props) { // This is because when wrapping whole screen the screen was freezing when changing Tabs. keyboardVerticalOffset={variables.contentHeaderHeight + variables.tabSelectorButtonHeight + variables.tabSelectorButtonPadding + insets.top} > - (roomNameInputRef.current = el)} inputID="roomName" isFocused={props.isFocused} shouldDelayFocus @@ -202,8 +201,7 @@ function WorkspaceNewRoomPage(props) { /> - - {isPolicyAdmin && ( - )} - {visibilityDescription} - + )} From dfbaffeb345c3e1fa0ad42d99851a5a085eceff6 Mon Sep 17 00:00:00 2001 From: isabelastisser <31258516+isabelastisser@users.noreply.github.com> Date: Fri, 27 Oct 2023 14:51:11 -0400 Subject: [PATCH 098/105] Update QuickBooks-Online.md Adding the QuickBooks Online resource to the help site. --- .../QuickBooks-Online.md | 321 +++++++++++++++++- 1 file changed, 318 insertions(+), 3 deletions(-) diff --git a/docs/articles/new-expensify/integrations/accounting-integrations/QuickBooks-Online.md b/docs/articles/new-expensify/integrations/accounting-integrations/QuickBooks-Online.md index aa5f40ee4e5d..7a0717eeb5d1 100644 --- a/docs/articles/new-expensify/integrations/accounting-integrations/QuickBooks-Online.md +++ b/docs/articles/new-expensify/integrations/accounting-integrations/QuickBooks-Online.md @@ -1,5 +1,320 @@ --- -title: QuickBooks Online -description: QuickBooks Online +title: The QuickBooks Online Integration +description: Expensify's integration with QuickBooks Online streamlines your expense management. + --- -## Resource Coming Soon! +# Overview + +The Expensify integration with QuickBooks Online brings in your expense accounts and other data and even exports reports directly to QuickBooks for easy reconciliation. Plus, with advanced features in QuickBooks Online, you can fine-tune coding settings in Expensify for automated data export to optimize your accounting workflow. + +## Before connecting + +It's crucial to understand the requirements based on your specific QuickBooks subscription: + +- While all the features are available in Expensify, their accessibility may vary depending on your QuickBooks Online subscription. +- An error will occur if you try to export to QuickBooks with a feature enabled that isn't part of your subscription. +- Please be aware that Expensify does not support the Self-Employed subscription in QuickBooks Online. + +# How to connect to QuickBooks Online + +## Step 1: Setup employees in QuickBooks Online + +Employees must be set up as either Vendors or Employees in QuickBooks Online. Make sure to include the submitter's email in their record. + +If you use vendor records, you can export as Vendor Bills, Checks, or Journal Entries. If you use employee records, you can export as Checks or Journal Entries (if exporting against a liability account). + +Additional Options for Streamlined Setup: + +- Automatic Vendor Creation: Enable “Automatically Create Entities” in your connection settings to automatically generate Vendor or Employee records upon export for submitters that don't already exist in QBO. +- Employee Setup Considerations: If setting up submitters as Employees, ensure you activate QuickBooks Online Payroll. This will grant access to the Employee Profile tab to input employee email addresses. + +## Step 2: Connect Expensify and QuickBooks Online + +- Navigate to Settings > Workspaces > Group > [Workspace Name] > Connections > QuickBooks Online. Click Connect to QuickBooks. +- Enter your QuickBooks Online Administrator’s login information and choose the QuickBooks Online Company File you want to connect to Expensify (you can connect one Company File per Workspace). Then Click Authorize. +- Enter your QuickBooks Online Administrator’s login information and choose the QuickBooks Online Company File you want to connect to Expensify (you can connect one Company File per Workspace): + +Exporting Historical Reports to QuickBooks Online: + +After connecting QuickBooks Online to Expensify, you may receive a prompt to export all historical reports from Expensify. To export multiple reports at once, follow these steps: + +a. Go to the Reports page on the web. + +b. Tick the checkbox next to the reports you want to export. + +c. Click 'Export To' and select 'QuickBooks Online' from the drop-down list. + +If you don't want to export specific reports, click “Mark as manually entered” on the report. + +# How to configure export settings for QuickBooks Online + +Our QuickBooks Online integration offers a range of features. This section will focus on Export Settings and how to set them up. + +## Preferred Exporter + +Any Workspace admin can export to your accounting integration, but the Preferred Exporter can be chosen to automate specific steps. You can set this role from Settings > Workspaces > Group > [Workspace Name] > Connections > Configure > Export > Preferred Exporter. + +The Preferred Exporter: + +- Is the user whose Concierge performs all automated exports on behalf of. +- Is the only user who will see reports awaiting export in their **Home.** +- Must be a **Domain Admin** if you have set individual GL accounts for Company Card export. +- Must be a **Domain Admin** if this is the Preferred Workspace for any Expensify Card domain using Automatic Reconciliation. + +## Date + +When exporting reports to QuickBooks Online, you can choose the report's **submitted date**, the report's **exported date**, or the **date of the last expense on the report.** + +Most export options (Check, Journal Entry, and Vendor Bill) will create a single itemized entry with one date. +Please note that if you choose a Credit Card or Debit Card for non-reimbursable expenses, we'll use the transaction date on each expense during export. + +# Reimbursable expenses + +Reimbursable expenses export to QuickBooks Online as: + +- Vendor Bills +- Checks +- Journal Entries + +## Vendor bill (recommended) + +This is a single itemized vendor bill for each Expensify report. If the accounting period is closed, we will post the vendor bill on the first day of the next open period. If you export as Vendor Bills, you can also choose to Sync reimbursed reports (set on the Advanced tab). **An A/P account is required to export to a vendor bill. Here is a screenshot of how your expenses map in QuickBooks.** + +The submitter will be listed as the vendor in the vendor bill. + +## Check + +This is a single itemized check for each Expensify report. You can mark a check to be printed later in QuickBooks Online. + +## Journal entry + +This is a single itemized journal entry for each Expensify report. + +# Non-reimbursable expenses + +Non-reimbursable expenses export to QuickBooks Online as: + +- Credit Card expenses +- Debit Card Expenses +- Vendor Bills + +## Credit/debit card + +Using Credit/Debit Card Transactions: + +- Each expense will be exported as a bank transaction with its transaction date. +- If you split an expense in Expensify, we'll consolidate it into a single credit card transaction in QuickBooks with multiple line items posted to the corresponding General Ledger accounts. + +Pro-Tip: To ensure the payee field in QuickBooks Online reflects the merchant name for Credit Card expenses, ensure there's a matching Vendor in QuickBooks Online. Expensify checks for an exact match during export. If none are found, the payee will be mapped to a vendor we create and labeled as Credit Card Misc. or Debit Card Misc. + +If you centrally manage your company cards through Domains, you can export expenses from each card to a specific account in QuickBooks. + +## Vendor Bill + +- A single detailed vendor bill is generated for each Expensify report. If the accounting period is closed, the vendor bill will be posted on the first day of the next open period. If you choose to export non-reimbursable expenses as Vendor Bills, you can assign a default vendor to the bill. +- The export will use your default vendor if you have Default Vendor enabled. If the Default Vendor is disabled, the report's submitter will be set as the Vendor in QuickBooks. + +Billable Expenses: + +- In Expensify, you can designate expenses as billable. These will be exported to QuickBooks Online with the billable flag. - This feature applies only to expenses exported as Vendor Bills or Checks. To maximize this functionality, ensure that any billable expense is associated with a Customer/Job. + +## Export Invoices + +If you are creating Invoices in Expensify and exporting these to QuickBooks Online, this is the account the invoice will appear against. + +# Configure coding for QuickBooks Online + +The coding tab is where your information is configured for Expensify; this will allow employees to code expenses and reports accurately. + +- Categories +- Classes and/or Customers/Projects +- Locations +- Items +- Tax + +## Categories + +QuickBooks Online expense accounts will be automatically imported into Expensify as Categories. + +## Account Import + +Equity type accounts will also be imported as categories. + +Important notes: + +- Other Current Liabilities can only be exported as Journal Entries if the submitter is set up as an Employee in QuickBooks. +- Exchange Gain or Loss detail type does not import. + +Recommended steps to take after importing the expense accounts from QuickBooks to Expensify: + +- Go to Settings > Workspaces > Groups > [Workspace Name] > Categories to see the accounts imported from QuickBooks Online. +- Use the enable/disable button to choose which Categories to make available to your employees, and set Category specific rules via the blue settings cog. +- If necessary, edit the names of imported Categories to make expense coding easier for your employees. (Please Note: If you make any changes to these accounts in QuickBooks Online, the category names on Expensify's side will revert to match the name of the account in QuickBooks Online the next time you sync). +- If you use Items in QuickBooks Online, you can import them into Expensify as Categories. + +Please note that each expense has to have a category selected to export to QuickBooks Online. The chosen category has to be imported from QuickBooks Online and cannot be manually created within the Workspace settings. + +## Classes and Customers/Projects + +If you use Classes or Customers/Projects in QuickBooks Online, you can import those into Expensify as Tags or Report Fields: + +- Tags let you apply a Class and/or Customer/Project to each expense +- Report Fields enables you to apply a Class and/or Customer/Project to all expenses on a report. + +Note: Although Projects can be imported into Expensify and coded to expenses, due to the limitations of the QuickBooks API, expenses cannot be created within the Projects module in QuickBooks. + +## Locations + +Locations can be imported into Expensify as a Report Field or, if you export reimbursable expenses as Journal Entries and non-reimbursable expenses as Credit/Debit Card, you can import Locations as Tags. + +## Items + +If you use Items in QuickBooks Online, you can import Items defined with Purchasing Information (with or without Sales Information) into Expensify as Categories. +## Tax + +- Using our tax tracking feature, you can assign a tax rate and amount to each expense. +-To activate tax tracking, go to connection configuration and enable it. This will automatically import purchasing taxes from QuickBooks Online into Expensify. +- After the connection is set, navigate to Settings > Worspaces > Groups > Workspace Name] > Tax. Here, you can view the taxes imported from QuickBooks Online. +- Use the enable/disable button to choose which taxes are accessible to your employees. +- Set a default tax for the Company Workspace, which will automatically apply to all new expenses. +- Please note that, at present, tax cannot be exported to Journal Entries in QuickBooks Online. +- Expensify performs a daily sync to ensure your information is up-to-date. This minimizes errors from outdated QuickBooks Online data and saves you time on syncing. + +# How to configure advanced settings for QuickBooks Online + +The advanced settings are where functionality for automating and customizing the QuickBooks Online integration can be enabled. +Navigate to this section of your Workspace by following Settings > Workspaces > Group > [Workspace Name] > Connections > Configure button > Advanced tab. +## Auto Sync +With QuickBooks Online auto-sync, once a non-reimbursable report is final approved in Expensify, it's automatically queued for export to QuickBooks Online. For expenses eligible for reimbursement with a linked business bank account, they'll sync when marked as reimbursed. + +## Newly Imported Categories + +This setting determines the default status of newly imported categories from QuickBooks Online to Expensify, either enabled or disabled. + +## Invite Employees + +Enabling this automatically invites all Employees from QuickBooks Online to the connected Expensify Company Workspace. If not, you can manually invite or import them using a CSV file. + +## Automatically Create Entities + +When exporting reimbursable expenses as Vendor Bills or Journal Entries, Expensify will automatically create a vendor in QuickBooks if one doesn't exist. It will also generate a customer when exporting Invoices. + +## Sync Reimbursed Reports + +Enabling this marks the Vendor Bill as paid in QuickBooks Online when you reimburse a report via ACH direct deposit in Expensify. If reimbursing outside Expensify, marking the Vendor Bill as paid will automatically in QuickBooks Online update the report as reimbursed in Expensify. Note: After enabling this feature, select your QuickBooks Account in the drop-down, indicating the bank account for reimbursements. + +## Collection Account + +If you are exporting Invoices from Expensify to Quickbooks Online, this is the account the Invoice will appear against once marked as Paid. + +# Deep Dive + +## Preventing Duplicate Transactions in QuickBooks + +When importing a banking feed directly into QuickBooks Online while also importing transactions from Expensify, it's possible to encounter duplicate entries in QuickBooks. To prevent this, follow these steps: + +Step 1: Complete the Approval Process in Expensify + +- Before exporting any expenses to QuickBooks Online, ensure they are added to a report and the report receives approval. Depending on your Workspace setup, reports may require approval from one or more individuals. The approval process concludes when the last user who views the report selects "Final Approve." + +Step 2: Exporting Reports to QuickBooks Online + +- To ensure expenses exported from Expensify match seamlessly in the QuickBooks Banking platform, make sure these expenses are marked as non-reimbursable within Expensify and that “Credit Card” is selected as the non-reimbursable export option for your expenses. + +Step 3: Importing Your Credit Card Transactions into QuickBooks Online + +- After completing Steps 1 and 2, you can import your credit card transactions into QuickBooks Online. These imported banking transactions will align with the ones brought in from Expensify. QuickBooks Online will guide you through the process of matching these transactions, similar to the example below: + +## Tax in QuickBooks Online + +If your country applies taxes on sales (like GST, HST, or VAT), you can utilize Expensify's Tax Tracking along with your QuickBooks Online tax rates. Please note: Tax Tracking is not available for Workspaces linked to the US version of QuickBooks Online. If you need assistance applying taxes after reports are exported, contact QuickBooks. + +To get started: + +- Go to Settings > Workpaces > Group > [Workspace Name] > Connections, and click Configure. +- Navigate to the Coding tab. +- Turn on 'T.''. +- Click Save. This imports the Tax Name and rate from QuickBooks Online. +- Visit Settings > Workspaces > Group > [Workspace Name] > Tax to view the imported taxes. +- Use the enable/disable button in the Tax tab to choose which taxes your employees can use. + +Remember, you can also set a default tax rate for the entire Workspace. This will be automatically applied to all new expenses. The user can still choose a different tax rate for each expense. + +Tax information can't be sent to Journal Entries in QuickBooks Online. Also, when dealing with multiple tax rates, where one receipt has different tax rates (like in the EU, UK, and Canada), users should split the expense into the respective parts and set the appropriate tax rate for each part. + +## Multi-currency + +When working with QuickBooks Online Multi-Currency, there are some things to remember when exporting Vendor Bills and Check! Make sure the vendor's currency and the Accounts Payable (A/P) bank account match. + +In QuickBooks Online, the currency conversion rates are not applied when exporting. All transactions will be exported with a 1:1 conversion rate, so for example, if a vendor's currency is CAD (Canadian Dollar) and the home currency is USD (US Dollar), the export will show these currencies without applying conversion rates. + +To correct this, you must manually update the conversion rate after the report has been exported to QuickBooks Online. + +Specifically for Vendor Bills: + +If multi-currency is enabled and the Vendor's currency is different from the Workspace currency, OR if QuickBooks Online home currency is foreign from the Workspace currency, then: + +- We create the Vendor Bill in the Vendor's currency (this is a QuickBooks Online requirement - we don't have a choice) +- We set the exchange rate between the home currency and the Vendor's currency +- We convert line item amounts to the vendor's currency + +Let's consider this example: + +- QuickBooks Online home currency is USD +- Vendor's currency is VND +- Workspace (report) currency is JPY + +Upon export, we: + +1. Specified the bill is in VND +2. Set the exchange rate between VND and USD (home currency), computed at the time of export. +3. Converted line items from JPY (currency in Expensify) to VND +4. QuickBooks Online automatically computed the USD amount (home currency) based on the exchange rate we specified +5. Journal Entries, Credit Card, and Debit Card: + +Multi-currency exports will fail as the account currency must match both the vendor and home currencies. + +## Report Fields + +Report fields are a handy way to collect specific information for a report tailored to your organization's needs. They can specify a project, business trip, client, location, and more! + +When integrating Expensify with Your Accounting Software, you can create your report fields in your accounting software so the next time you sync your Workspace, these fields will be imported into Expensify. + +To select how a specific field imports to Expensify, head to Settings > Workspaces > Group > +[Workspace Name] > Connections > Accounting Integrations > QuickBooks Online > Configure > Coding. + +Here are the QuickBooks Online fields that can be mapped as a report field within Expensify: + +- Classes +- Customers/Projects +- Locations + +# FAQ + +## What happens if the report can't be exported to QuickBooks Online automatically? + +If a report encounters an issue during automatic export to QuickBooks Online, you'll receive an email with details about the problem, including any specific error messages. These messages will also be recorded in the report's history section. + +The report will be placed in your Home for your attention. You can address the issues there. If you need further assistance, refer to our QuickBooks Online Export Errors page or export the report manually. + +## How can I ensure that I final approve reports before they're exported to QuickBooks Online? + +To ensure reports are reviewed before export, set up your Workspaces with the appropriate workflow in Expensify. Additionally, consider changing your Workspace settings to enforce expense Workspace workflows strictly. This guarantees that your Workspace's workflow is consistently followed. + +## What happens to existing approved and reimbursed reports if I enable Auto Sync? + +- If Auto Sync was disabled when your Workspace was linked to QuickBooks Online, enabling it won't impact existing reports that haven't been exported. +- If a report has been exported and reimbursed via ACH, it will be automatically marked as paid in QuickBooks Online during the next sync. +- If a report has been exported and marked as paid in QuickBooks Online, it will be automatically marked as reimbursed in Expensify during the next sync. +- Reports that have yet to be exported to QuickBooks Online won't be automatically exported. + + + + + + + + + + + From 9ffb7a35074bee64688fdd2b9f1a71540f9421f6 Mon Sep 17 00:00:00 2001 From: OSBotify Date: Fri, 27 Oct 2023 18:57:56 +0000 Subject: [PATCH 099/105] Update version to 1.3.92-3 --- android/app/build.gradle | 4 ++-- ios/NewExpensify/Info.plist | 2 +- ios/NewExpensifyTests/Info.plist | 2 +- package-lock.json | 4 ++-- package.json | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/android/app/build.gradle b/android/app/build.gradle index 242164594fd8..4ac63865ad43 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -90,8 +90,8 @@ android { minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion multiDexEnabled rootProject.ext.multiDexEnabled - versionCode 1001039202 - versionName "1.3.92-2" + versionCode 1001039203 + versionName "1.3.92-3" } flavorDimensions "default" diff --git a/ios/NewExpensify/Info.plist b/ios/NewExpensify/Info.plist index 4e2edb559ee4..4e44dfb6cfbb 100644 --- a/ios/NewExpensify/Info.plist +++ b/ios/NewExpensify/Info.plist @@ -40,7 +40,7 @@ CFBundleVersion - 1.3.92.2 + 1.3.92.3 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/ios/NewExpensifyTests/Info.plist b/ios/NewExpensifyTests/Info.plist index 781853ba92d2..27d98f1dff94 100644 --- a/ios/NewExpensifyTests/Info.plist +++ b/ios/NewExpensifyTests/Info.plist @@ -19,6 +19,6 @@ CFBundleSignature ???? CFBundleVersion - 1.3.92.2 + 1.3.92.3 diff --git a/package-lock.json b/package-lock.json index 14cee71de530..03d3b0f1f46f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "new.expensify", - "version": "1.3.92-2", + "version": "1.3.92-3", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "new.expensify", - "version": "1.3.92-2", + "version": "1.3.92-3", "hasInstallScript": true, "license": "MIT", "dependencies": { diff --git a/package.json b/package.json index e514f5afead0..90b3169d91e2 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "new.expensify", - "version": "1.3.92-2", + "version": "1.3.92-3", "author": "Expensify, Inc.", "homepage": "https://new.expensify.com", "description": "New Expensify is the next generation of Expensify: a reimagination of payments based atop a foundation of chat.", From 08557e9a99b80d438ab8391fd2d89cd469d261c9 Mon Sep 17 00:00:00 2001 From: Ishpaul Singh Date: Sat, 28 Oct 2023 00:53:13 +0530 Subject: [PATCH 100/105] fix/focus error input on click of CTA message --- src/components/Form/FormProvider.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/components/Form/FormProvider.js b/src/components/Form/FormProvider.js index ce402976d097..7e6ace1fa4c6 100644 --- a/src/components/Form/FormProvider.js +++ b/src/components/Form/FormProvider.js @@ -204,6 +204,7 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC const registerInput = useCallback( (inputID, propsToParse = {}) => { + const newRef = inputRefs.current[inputID] || propsToParse.ref || createRef(); if (inputRefs.current[inputID] !== newRef) { inputRefs.current[inputID] = newRef; @@ -233,7 +234,10 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC return { ...propsToParse, - ref: newRef, + ref: typeof propsToParse.ref === 'function' ? (node) => { + propsToParse.ref(node); + newRef.current = node; + } : newRef, inputID, key: propsToParse.key || inputID, errorText: errors[inputID] || fieldErrorMessage, From 8ec732744d2a65425b0fd26300a6625240feb607 Mon Sep 17 00:00:00 2001 From: Ishpaul Singh Date: Sat, 28 Oct 2023 01:05:56 +0530 Subject: [PATCH 101/105] fix linters --- src/components/Form/FormProvider.js | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/src/components/Form/FormProvider.js b/src/components/Form/FormProvider.js index 7e6ace1fa4c6..6d63435e1f9d 100644 --- a/src/components/Form/FormProvider.js +++ b/src/components/Form/FormProvider.js @@ -204,7 +204,6 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC const registerInput = useCallback( (inputID, propsToParse = {}) => { - const newRef = inputRefs.current[inputID] || propsToParse.ref || createRef(); if (inputRefs.current[inputID] !== newRef) { inputRefs.current[inputID] = newRef; @@ -234,10 +233,13 @@ function FormProvider({validate, formID, shouldValidateOnBlur, shouldValidateOnC return { ...propsToParse, - ref: typeof propsToParse.ref === 'function' ? (node) => { - propsToParse.ref(node); - newRef.current = node; - } : newRef, + ref: + typeof propsToParse.ref === 'function' + ? (node) => { + propsToParse.ref(node); + newRef.current = node; + } + : newRef, inputID, key: propsToParse.key || inputID, errorText: errors[inputID] || fieldErrorMessage, From 7da77b2d659b47f8fa92e92bc6e83814df2811c7 Mon Sep 17 00:00:00 2001 From: OSBotify Date: Fri, 27 Oct 2023 20:58:31 +0000 Subject: [PATCH 102/105] Update version to 1.3.92-4 --- android/app/build.gradle | 4 ++-- ios/NewExpensify/Info.plist | 2 +- ios/NewExpensifyTests/Info.plist | 2 +- package-lock.json | 4 ++-- package.json | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/android/app/build.gradle b/android/app/build.gradle index 4ac63865ad43..8396dc1e4ec1 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -90,8 +90,8 @@ android { minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion multiDexEnabled rootProject.ext.multiDexEnabled - versionCode 1001039203 - versionName "1.3.92-3" + versionCode 1001039204 + versionName "1.3.92-4" } flavorDimensions "default" diff --git a/ios/NewExpensify/Info.plist b/ios/NewExpensify/Info.plist index 4e44dfb6cfbb..848823f3578e 100644 --- a/ios/NewExpensify/Info.plist +++ b/ios/NewExpensify/Info.plist @@ -40,7 +40,7 @@ CFBundleVersion - 1.3.92.3 + 1.3.92.4 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/ios/NewExpensifyTests/Info.plist b/ios/NewExpensifyTests/Info.plist index 27d98f1dff94..d211b5b97278 100644 --- a/ios/NewExpensifyTests/Info.plist +++ b/ios/NewExpensifyTests/Info.plist @@ -19,6 +19,6 @@ CFBundleSignature ???? CFBundleVersion - 1.3.92.3 + 1.3.92.4 diff --git a/package-lock.json b/package-lock.json index 03d3b0f1f46f..49a94029b2d5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "new.expensify", - "version": "1.3.92-3", + "version": "1.3.92-4", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "new.expensify", - "version": "1.3.92-3", + "version": "1.3.92-4", "hasInstallScript": true, "license": "MIT", "dependencies": { diff --git a/package.json b/package.json index 90b3169d91e2..6d01ba6570a3 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "new.expensify", - "version": "1.3.92-3", + "version": "1.3.92-4", "author": "Expensify, Inc.", "homepage": "https://new.expensify.com", "description": "New Expensify is the next generation of Expensify: a reimagination of payments based atop a foundation of chat.", From 419e0774795d88ff66e667400debf05049378bf8 Mon Sep 17 00:00:00 2001 From: Mahesh Vagicherla Date: Sat, 28 Oct 2023 18:37:04 +0530 Subject: [PATCH 103/105] import alias config --- .eslintrc.js | 25 +- .prettierrc.js | 3 + .storybook/webpack.config.js | 3 + babel.config.js | 36 +++ config/webpack/webpack.common.js | 13 + package-lock.json | 443 ++++++++++++++++++++++++------- package.json | 4 +- tsconfig.json | 15 +- 8 files changed, 449 insertions(+), 93 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 35a4a333f8af..ac549aa13c4b 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -24,7 +24,7 @@ const restrictedImportPatterns = [ ]; module.exports = { - extends: ['expensify', 'plugin:storybook/recommended', 'plugin:react-hooks/recommended', 'plugin:react-native-a11y/basic', 'prettier'], + extends: ['expensify', 'plugin:storybook/recommended', 'plugin:react-hooks/recommended', 'plugin:react-native-a11y/basic', 'plugin:@dword-design/import-alias/recommended', 'prettier'], plugins: ['react-hooks', 'react-native-a11y'], parser: 'babel-eslint', ignorePatterns: ['!.*', 'src/vendor', '.github/actions/**/index.js', 'desktop/dist/*.js', 'dist/*.js', 'node_modules/.bin/**', 'node_modules/.cache/**', '.git/**'], @@ -49,8 +49,31 @@ module.exports = { touchables: ['PressableWithoutFeedback', 'PressableWithFeedback'], }, ], + '@dword-design/import-alias/prefer-alias': [ + 'warn', + { + alias: { + '@assets': './assets', + '@components': './src/components', + '@hooks': './src/hooks', + // This is needed up here, if not @libs/actions would take the priority + '@userActions': './src/libs/actions', + '@libs': './src/libs', + '@navigation': './src/libs/Navigation', + '@pages': './src/pages', + '@styles': './src/styles', + // This path is provide alias for files like `ONYXKEYS` and `CONST`. + '@src': './src', + }, + }, + ], }, }, + // This helps disable the `prefer-alias` rule to be enabled for specific directories + { + files: ['tests/**/*.js', 'tests/**/*.ts', 'tests/**/*.jsx', 'assets/**/*.js', '.storybook/**/*.js'], + rules: {'@dword-design/import-alias/prefer-alias': ['off']}, + }, { files: ['*.js', '*.jsx'], settings: { diff --git a/.prettierrc.js b/.prettierrc.js index ad1fafbb51be..bcc67708cc95 100644 --- a/.prettierrc.js +++ b/.prettierrc.js @@ -6,4 +6,7 @@ module.exports = { arrowParens: 'always', printWidth: 190, singleAttributePerLine: true, + importOrder: ['@assets/(.*)$', '@components/(.*)$', '@hooks/(.*)$', '@libs/(.*)$', '@navigation/(.*)$', '@pages/(.*)$', '@styles/(.*)$', '@userActions/(.*)$', '@src/(.*)$', '^[./]'], + importOrderSortSpecifiers: true, + importOrderCaseInsensitive: true, }; diff --git a/.storybook/webpack.config.js b/.storybook/webpack.config.js index 3c5dbb41ea2c..fe58f3c0a6d8 100644 --- a/.storybook/webpack.config.js +++ b/.storybook/webpack.config.js @@ -28,6 +28,9 @@ module.exports = ({config}) => { 'react-native-web': '@expensify/react-native-web', '@react-native-community/netinfo': path.resolve(__dirname, '../__mocks__/@react-native-community/netinfo.js'), '@react-navigation/native': path.resolve(__dirname, '../__mocks__/@react-navigation/native'), + + // Module alias support for storybook files, coping from `webpack.common.js` + ...custom.resolve.alias, }; // Necessary to overwrite the values in the existing DefinePlugin hardcoded to the Config staging values diff --git a/babel.config.js b/babel.config.js index 3a49f3bccbe5..189c3379aa6d 100644 --- a/babel.config.js +++ b/babel.config.js @@ -41,6 +41,42 @@ const metro = { ['@babel/plugin-proposal-private-property-in-object', {loose: true}], // The reanimated babel plugin needs to be last, as stated here: https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/installation 'react-native-reanimated/plugin', + // Import alias for native devices + [ + 'module-resolver', + { + extensions: [ + '.native.js', + '.native.jsx', + '.native.ts', + '.native.tsx', + '.js', + '.jsx', + '.ts', + '.tsx', + '.ios.js', + '.ios.jsx', + '.ios.ts', + '.ios.tsx', + '.android.js', + '.android.jsx', + '.android.ts', + '.android.tx', + ], + alias: { + '@assets': './assets', + '@components': './src/components', + '@hooks': './src/hooks', + '@libs': './src/libs', + '@navigation': './src/libs/Navigation', + '@pages': './src/pages', + '@styles': './src/styles', + // This path is provide alias for files like `ONYXKEYS` and `CONST`. + '@src': './src', + '@userActions': './src/libs/actions', + }, + }, + ], ], }; diff --git a/config/webpack/webpack.common.js b/config/webpack/webpack.common.js index 7dc851c95c9e..20e174a004d7 100644 --- a/config/webpack/webpack.common.js +++ b/config/webpack/webpack.common.js @@ -187,6 +187,19 @@ const webpackConfig = ({envFile = '.env', platform = 'web'}) => ({ 'react-native-web': '@expensify/react-native-web', 'react-content-loader/native': 'react-content-loader', 'lottie-react-native': 'react-native-web-lottie', + + // Module alias for web & desktop + // https://webpack.js.org/configuration/resolve/#resolvealias + '@assets': path.resolve(__dirname, '../../assets'), + '@components': path.resolve(__dirname, '../../src/components/'), + '@hooks': path.resolve(__dirname, '../../src/hooks/'), + '@libs': path.resolve(__dirname, '../../src/libs/'), + '@navigation': path.resolve(__dirname, '../../src/libs/Navigation/'), + '@pages': path.resolve(__dirname, '../../src/pages/'), + '@styles': path.resolve(__dirname, '../../src/styles/'), + // This path is provide alias for files like `ONYXKEYS` and `CONST`. + '@src': path.resolve(__dirname, '../../src/'), + '@userActions': path.resolve(__dirname, '../../src/libs/actions/'), }, // React Native libraries may have web-specific module implementations that appear with the extension `.web.js` diff --git a/package-lock.json b/package-lock.json index 579b1b278bcf..e95637f2488d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -135,6 +135,7 @@ "@babel/preset-react": "^7.10.4", "@babel/preset-typescript": "^7.21.5", "@babel/runtime": "^7.20.0", + "@dword-design/eslint-plugin-import-alias": "^4.0.8", "@electron/notarize": "^1.2.3", "@jest/globals": "^29.5.0", "@octokit/core": "4.0.4", @@ -154,6 +155,7 @@ "@svgr/webpack": "^6.0.0", "@testing-library/jest-native": "5.4.1", "@testing-library/react-native": "11.5.1", + "@trivago/prettier-plugin-sort-imports": "^4.2.0", "@types/concurrently": "^7.0.0", "@types/jest": "^29.5.2", "@types/jest-when": "^3.5.2", @@ -383,11 +385,11 @@ } }, "node_modules/@babel/code-frame": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.10.tgz", - "integrity": "sha512-/KKIMG4UEL35WmI9OlvMhurwtytjvXoFcGNrOvyG9zIzA8YmPjVtIZUf7b05+TPO7G7/GEmLHDaoCgACHl9hhA==", + "version": "7.22.13", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", + "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", "dependencies": { - "@babel/highlight": "^7.22.10", + "@babel/highlight": "^7.22.13", "chalk": "^2.4.2" }, "engines": { @@ -440,11 +442,11 @@ } }, "node_modules/@babel/generator": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.10.tgz", - "integrity": "sha512-79KIf7YiWjjdZ81JnLujDRApWtl7BxTqWD88+FFdQEIOG8LJ0etDOM7CXuIgGJa55sGOwZVwuEsaLEm0PJ5/+A==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", + "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", "dependencies": { - "@babel/types": "^7.22.10", + "@babel/types": "^7.23.0", "@jridgewell/gen-mapping": "^0.3.2", "@jridgewell/trace-mapping": "^0.3.17", "jsesc": "^2.5.1" @@ -604,20 +606,20 @@ } }, "node_modules/@babel/helper-environment-visitor": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", - "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", + "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-function-name": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz", - "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", + "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", "dependencies": { - "@babel/template": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/template": "^7.22.15", + "@babel/types": "^7.23.0" }, "engines": { "node": ">=6.9.0" @@ -768,9 +770,9 @@ } }, "node_modules/@babel/helper-validator-identifier": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", - "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==", + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", "engines": { "node": ">=6.9.0" } @@ -811,11 +813,11 @@ } }, "node_modules/@babel/highlight": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.10.tgz", - "integrity": "sha512-78aUtVcT7MUscr0K5mIEnkwxPE0MaxkR5RxRwuHaQ+JuU5AmTPhY+do2mdzVTnIJJpyBglql2pehuBIWHug+WQ==", + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", + "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", "dependencies": { - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20", "chalk": "^2.4.2", "js-tokens": "^4.0.0" }, @@ -824,9 +826,9 @@ } }, "node_modules/@babel/parser": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.11.tgz", - "integrity": "sha512-R5zb8eJIBPJriQtbH/htEQy4k7E2dHWlD2Y2VT07JCzwYZHBxV5ZYtM0UhXSNMT74LyxuM+b1jdL7pSesXbC/g==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", + "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==", "bin": { "parser": "bin/babel-parser.js" }, @@ -2552,31 +2554,31 @@ "integrity": "sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA==" }, "node_modules/@babel/template": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", - "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", + "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", "dependencies": { - "@babel/code-frame": "^7.22.5", - "@babel/parser": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/code-frame": "^7.22.13", + "@babel/parser": "^7.22.15", + "@babel/types": "^7.22.15" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/traverse": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.11.tgz", - "integrity": "sha512-mzAenteTfomcB7mfPtyi+4oe5BZ6MXxWcn4CX+h4IRJ+OOGXBrWU6jDQavkQI9Vuc5P+donFabBfFCcmWka9lQ==", + "version": "7.23.2", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", + "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", "dependencies": { - "@babel/code-frame": "^7.22.10", - "@babel/generator": "^7.22.10", - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-function-name": "^7.22.5", + "@babel/code-frame": "^7.22.13", + "@babel/generator": "^7.23.0", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-function-name": "^7.23.0", "@babel/helper-hoist-variables": "^7.22.5", "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.22.11", - "@babel/types": "^7.22.11", + "@babel/parser": "^7.23.0", + "@babel/types": "^7.23.0", "debug": "^4.1.0", "globals": "^11.1.0" }, @@ -2585,12 +2587,12 @@ } }, "node_modules/@babel/types": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.11.tgz", - "integrity": "sha512-siazHiGuZRz9aB9NpHy9GOs9xiQPKnMzgdr493iI1M67vRXpnEq8ZOOKzezC5q7zwuQ6sDhdSp4SD9ixKSqKZg==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", + "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", "dependencies": { "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20", "to-fast-properties": "^2.0.0" }, "engines": { @@ -2939,6 +2941,63 @@ "node": ">=10.0.0" } }, + "node_modules/@dword-design/dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/@dword-design/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha512-OFmAmzKiDUh9m7WRMYcoEOPI7b5tS5hdqQmtKDwF+ZssVJv8a+GHo9VOtFsmlw3h8Roh/9QzFWIsjSFZyQUMdg==", + "dev": true, + "dependencies": { + "babel-plugin-add-module-exports": "^1.0.2" + } + }, + "node_modules/@dword-design/endent": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/@dword-design/endent/-/endent-1.4.1.tgz", + "integrity": "sha512-e2sCTzth5kyRdM0o+yEb5wBVzUdJL8Y6HblRGRV0Bif0knf1ZjRLhUjdCrqM+Muirb68X/xJzgdRDJVmLqgXGA==", + "dev": true, + "dependencies": { + "@dword-design/dedent": "^0.7.0", + "fast-json-parse": "^1.0.3", + "objectorarray": "^1.0.3" + } + }, + "node_modules/@dword-design/eslint-plugin-import-alias": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/@dword-design/eslint-plugin-import-alias/-/eslint-plugin-import-alias-4.0.8.tgz", + "integrity": "sha512-u20BC0eJ6MHhGen+lG38nf/dvlQI7g1GdXLZbgJfOeGT+GKYey7SVTdotY0X4iKWFGGqElkW0bbOuF07T90VOA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.10.2", + "@dword-design/functions": "^5.0.22", + "babel-plugin-module-resolver": "^5.0.0", + "deepmerge": "^4.3.1", + "jiti": "^1.18.2" + }, + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://github.com/sponsors/dword-design" + } + }, + "node_modules/@dword-design/functions": { + "version": "5.0.26", + "resolved": "https://registry.npmjs.org/@dword-design/functions/-/functions-5.0.26.tgz", + "integrity": "sha512-7MxBcG1zP42LR+45kdRvb+P56u48INNKSolGsdmYMFd367btOP/BLHHHTVU1M+uI3KmH7o2J/oasEPtYquravw==", + "dev": true, + "dependencies": { + "@dword-design/endent": "^1.0.0", + "delay": "^5.0.0", + "lodash": "^4.17.15", + "tinycolor2": "^1.4.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/dword-design" + } + }, "node_modules/@egjs/hammerjs": { "version": "2.0.17", "resolved": "https://registry.npmjs.org/@egjs/hammerjs/-/hammerjs-2.0.17.tgz", @@ -19057,6 +19116,65 @@ "node": ">= 10" } }, + "node_modules/@trivago/prettier-plugin-sort-imports": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/@trivago/prettier-plugin-sort-imports/-/prettier-plugin-sort-imports-4.2.1.tgz", + "integrity": "sha512-iuy2MPVURGdxILTchHr15VAioItuYBejKfcTmQFlxIuqA7jeaT6ngr5aUIG6S6U096d6a6lJCgaOwlRrPLlOPg==", + "dev": true, + "dependencies": { + "@babel/generator": "7.17.7", + "@babel/parser": "^7.20.5", + "@babel/traverse": "7.23.2", + "@babel/types": "7.17.0", + "javascript-natural-sort": "0.7.1", + "lodash": "^4.17.21" + }, + "peerDependencies": { + "@vue/compiler-sfc": "3.x", + "prettier": "2.x - 3.x" + }, + "peerDependenciesMeta": { + "@vue/compiler-sfc": { + "optional": true + } + } + }, + "node_modules/@trivago/prettier-plugin-sort-imports/node_modules/@babel/generator": { + "version": "7.17.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.17.7.tgz", + "integrity": "sha512-oLcVCTeIFadUoArDTwpluncplrYBmTCCZZgXCbgNGvOBBiSDDK3eWO4b/+eOTli5tKv1lg+a5/NAXg+nTcei1w==", + "dev": true, + "dependencies": { + "@babel/types": "^7.17.0", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@trivago/prettier-plugin-sort-imports/node_modules/@babel/types": { + "version": "7.17.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.17.0.tgz", + "integrity": "sha512-TmKSNO4D5rzhL5bjWFcVHHLETzfQ/AmbKpKPOSjlP0WoHZ6L911fgoOKY4Alp/emzG4cHJdyN49zpgkbXFEHHw==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.16.7", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@trivago/prettier-plugin-sort-imports/node_modules/source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/@trysound/sax": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz", @@ -22652,6 +22770,12 @@ "babel-runtime": "^6.22.0" } }, + "node_modules/babel-plugin-add-module-exports": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/babel-plugin-add-module-exports/-/babel-plugin-add-module-exports-1.0.4.tgz", + "integrity": "sha512-g+8yxHUZ60RcyaUpfNzy56OtWW+x9cyEe9j+CranqLiqbju2yf/Cy6ZtYK40EZxtrdHllzlVZgLmcOUCTlJ7Jg==", + "dev": true + }, "node_modules/babel-plugin-add-react-displayname": { "version": "0.0.5", "resolved": "https://registry.npmjs.org/babel-plugin-add-react-displayname/-/babel-plugin-add-react-displayname-0.0.5.tgz", @@ -26894,6 +27018,18 @@ "rimraf": "bin.js" } }, + "node_modules/delay": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/delay/-/delay-5.0.0.tgz", + "integrity": "sha512-ReEBKkIfe4ya47wlPYf/gu5ib6yUG0/Aez0JQZQz94kiWtRQvZIQbTiehsnwHvLSWJnQdhVeqYue7Id1dKr0qw==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", @@ -36915,6 +37051,15 @@ "node": ">=8" } }, + "node_modules/jiti": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.20.0.tgz", + "integrity": "sha512-3TV69ZbrvV6U5DfQimop50jE9Dl6J8O1ja1dvBbMba/sZ3YBEQqJ2VZRoQPVnhlzjNtU1vaXRZVrVjU4qtm8yA==", + "dev": true, + "bin": { + "jiti": "bin/jiti.js" + } + }, "node_modules/joi": { "version": "17.10.2", "resolved": "https://registry.npmjs.org/joi/-/joi-17.10.2.tgz", @@ -49844,6 +49989,12 @@ "integrity": "sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==", "license": "MIT" }, + "node_modules/tinycolor2": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.6.0.tgz", + "integrity": "sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw==", + "dev": true + }, "node_modules/tinyqueue": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/tinyqueue/-/tinyqueue-2.0.3.tgz", @@ -53341,11 +53492,11 @@ } }, "@babel/code-frame": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.10.tgz", - "integrity": "sha512-/KKIMG4UEL35WmI9OlvMhurwtytjvXoFcGNrOvyG9zIzA8YmPjVtIZUf7b05+TPO7G7/GEmLHDaoCgACHl9hhA==", + "version": "7.22.13", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", + "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", "requires": { - "@babel/highlight": "^7.22.10", + "@babel/highlight": "^7.22.13", "chalk": "^2.4.2" } }, @@ -53384,11 +53535,11 @@ } }, "@babel/generator": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.10.tgz", - "integrity": "sha512-79KIf7YiWjjdZ81JnLujDRApWtl7BxTqWD88+FFdQEIOG8LJ0etDOM7CXuIgGJa55sGOwZVwuEsaLEm0PJ5/+A==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", + "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", "requires": { - "@babel/types": "^7.22.10", + "@babel/types": "^7.23.0", "@jridgewell/gen-mapping": "^0.3.2", "@jridgewell/trace-mapping": "^0.3.17", "jsesc": "^2.5.1" @@ -53513,17 +53664,17 @@ } }, "@babel/helper-environment-visitor": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", - "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==" + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", + "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==" }, "@babel/helper-function-name": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz", - "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", + "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", "requires": { - "@babel/template": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/template": "^7.22.15", + "@babel/types": "^7.23.0" } }, "@babel/helper-hoist-variables": { @@ -53626,9 +53777,9 @@ "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==" }, "@babel/helper-validator-identifier": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", - "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==" + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==" }, "@babel/helper-validator-option": { "version": "7.22.5", @@ -53657,19 +53808,19 @@ } }, "@babel/highlight": { - "version": "7.22.10", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.10.tgz", - "integrity": "sha512-78aUtVcT7MUscr0K5mIEnkwxPE0MaxkR5RxRwuHaQ+JuU5AmTPhY+do2mdzVTnIJJpyBglql2pehuBIWHug+WQ==", + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", + "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", "requires": { - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20", "chalk": "^2.4.2", "js-tokens": "^4.0.0" } }, "@babel/parser": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.11.tgz", - "integrity": "sha512-R5zb8eJIBPJriQtbH/htEQy4k7E2dHWlD2Y2VT07JCzwYZHBxV5ZYtM0UhXSNMT74LyxuM+b1jdL7pSesXbC/g==" + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", + "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==" }, "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { "version": "7.22.5", @@ -54747,39 +54898,39 @@ } }, "@babel/template": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", - "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", + "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", "requires": { - "@babel/code-frame": "^7.22.5", - "@babel/parser": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/code-frame": "^7.22.13", + "@babel/parser": "^7.22.15", + "@babel/types": "^7.22.15" } }, "@babel/traverse": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.11.tgz", - "integrity": "sha512-mzAenteTfomcB7mfPtyi+4oe5BZ6MXxWcn4CX+h4IRJ+OOGXBrWU6jDQavkQI9Vuc5P+donFabBfFCcmWka9lQ==", + "version": "7.23.2", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", + "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", "requires": { - "@babel/code-frame": "^7.22.10", - "@babel/generator": "^7.22.10", - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-function-name": "^7.22.5", + "@babel/code-frame": "^7.22.13", + "@babel/generator": "^7.23.0", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-function-name": "^7.23.0", "@babel/helper-hoist-variables": "^7.22.5", "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.22.11", - "@babel/types": "^7.22.11", + "@babel/parser": "^7.23.0", + "@babel/types": "^7.23.0", "debug": "^4.1.0", "globals": "^11.1.0" } }, "@babel/types": { - "version": "7.22.11", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.11.tgz", - "integrity": "sha512-siazHiGuZRz9aB9NpHy9GOs9xiQPKnMzgdr493iI1M67vRXpnEq8ZOOKzezC5q7zwuQ6sDhdSp4SD9ixKSqKZg==", + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", + "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", "requires": { "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20", "to-fast-properties": "^2.0.0" } }, @@ -55046,6 +55197,51 @@ "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", "dev": true }, + "@dword-design/dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/@dword-design/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha512-OFmAmzKiDUh9m7WRMYcoEOPI7b5tS5hdqQmtKDwF+ZssVJv8a+GHo9VOtFsmlw3h8Roh/9QzFWIsjSFZyQUMdg==", + "dev": true, + "requires": { + "babel-plugin-add-module-exports": "^1.0.2" + } + }, + "@dword-design/endent": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/@dword-design/endent/-/endent-1.4.1.tgz", + "integrity": "sha512-e2sCTzth5kyRdM0o+yEb5wBVzUdJL8Y6HblRGRV0Bif0knf1ZjRLhUjdCrqM+Muirb68X/xJzgdRDJVmLqgXGA==", + "dev": true, + "requires": { + "@dword-design/dedent": "^0.7.0", + "fast-json-parse": "^1.0.3", + "objectorarray": "^1.0.3" + } + }, + "@dword-design/eslint-plugin-import-alias": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/@dword-design/eslint-plugin-import-alias/-/eslint-plugin-import-alias-4.0.8.tgz", + "integrity": "sha512-u20BC0eJ6MHhGen+lG38nf/dvlQI7g1GdXLZbgJfOeGT+GKYey7SVTdotY0X4iKWFGGqElkW0bbOuF07T90VOA==", + "dev": true, + "requires": { + "@babel/core": "^7.10.2", + "@dword-design/functions": "^5.0.22", + "babel-plugin-module-resolver": "^5.0.0", + "deepmerge": "^4.3.1", + "jiti": "^1.18.2" + } + }, + "@dword-design/functions": { + "version": "5.0.26", + "resolved": "https://registry.npmjs.org/@dword-design/functions/-/functions-5.0.26.tgz", + "integrity": "sha512-7MxBcG1zP42LR+45kdRvb+P56u48INNKSolGsdmYMFd367btOP/BLHHHTVU1M+uI3KmH7o2J/oasEPtYquravw==", + "dev": true, + "requires": { + "@dword-design/endent": "^1.0.0", + "delay": "^5.0.0", + "lodash": "^4.17.15", + "tinycolor2": "^1.4.1" + } + }, "@egjs/hammerjs": { "version": "2.0.17", "resolved": "https://registry.npmjs.org/@egjs/hammerjs/-/hammerjs-2.0.17.tgz", @@ -66535,6 +66731,49 @@ "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==", "dev": true }, + "@trivago/prettier-plugin-sort-imports": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/@trivago/prettier-plugin-sort-imports/-/prettier-plugin-sort-imports-4.2.1.tgz", + "integrity": "sha512-iuy2MPVURGdxILTchHr15VAioItuYBejKfcTmQFlxIuqA7jeaT6ngr5aUIG6S6U096d6a6lJCgaOwlRrPLlOPg==", + "dev": true, + "requires": { + "@babel/generator": "7.17.7", + "@babel/parser": "^7.20.5", + "@babel/traverse": "7.23.2", + "@babel/types": "7.17.0", + "javascript-natural-sort": "0.7.1", + "lodash": "^4.17.21" + }, + "dependencies": { + "@babel/generator": { + "version": "7.17.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.17.7.tgz", + "integrity": "sha512-oLcVCTeIFadUoArDTwpluncplrYBmTCCZZgXCbgNGvOBBiSDDK3eWO4b/+eOTli5tKv1lg+a5/NAXg+nTcei1w==", + "dev": true, + "requires": { + "@babel/types": "^7.17.0", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/types": { + "version": "7.17.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.17.0.tgz", + "integrity": "sha512-TmKSNO4D5rzhL5bjWFcVHHLETzfQ/AmbKpKPOSjlP0WoHZ6L911fgoOKY4Alp/emzG4cHJdyN49zpgkbXFEHHw==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.16.7", + "to-fast-properties": "^2.0.0" + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "dev": true + } + } + }, "@trysound/sax": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz", @@ -69272,6 +69511,12 @@ "babel-runtime": "^6.22.0" } }, + "babel-plugin-add-module-exports": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/babel-plugin-add-module-exports/-/babel-plugin-add-module-exports-1.0.4.tgz", + "integrity": "sha512-g+8yxHUZ60RcyaUpfNzy56OtWW+x9cyEe9j+CranqLiqbju2yf/Cy6ZtYK40EZxtrdHllzlVZgLmcOUCTlJ7Jg==", + "dev": true + }, "babel-plugin-add-react-displayname": { "version": "0.0.5", "resolved": "https://registry.npmjs.org/babel-plugin-add-react-displayname/-/babel-plugin-add-react-displayname-0.0.5.tgz", @@ -72364,6 +72609,12 @@ } } }, + "delay": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/delay/-/delay-5.0.0.tgz", + "integrity": "sha512-ReEBKkIfe4ya47wlPYf/gu5ib6yUG0/Aez0JQZQz94kiWtRQvZIQbTiehsnwHvLSWJnQdhVeqYue7Id1dKr0qw==", + "dev": true + }, "delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", @@ -79476,6 +79727,12 @@ } } }, + "jiti": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.20.0.tgz", + "integrity": "sha512-3TV69ZbrvV6U5DfQimop50jE9Dl6J8O1ja1dvBbMba/sZ3YBEQqJ2VZRoQPVnhlzjNtU1vaXRZVrVjU4qtm8yA==", + "dev": true + }, "joi": { "version": "17.10.2", "resolved": "https://registry.npmjs.org/joi/-/joi-17.10.2.tgz", @@ -88799,6 +89056,12 @@ "resolved": "https://registry.npmjs.org/tiny-warning/-/tiny-warning-1.0.3.tgz", "integrity": "sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==" }, + "tinycolor2": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.6.0.tgz", + "integrity": "sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw==", + "dev": true + }, "tinyqueue": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/tinyqueue/-/tinyqueue-2.0.3.tgz", diff --git a/package.json b/package.json index c866cc84f62b..e968f3314eb8 100644 --- a/package.json +++ b/package.json @@ -170,6 +170,8 @@ "underscore": "^1.13.1" }, "devDependencies": { + "@dword-design/eslint-plugin-import-alias": "^4.0.8", + "@trivago/prettier-plugin-sort-imports": "^4.2.0", "@actions/core": "1.10.0", "@actions/github": "5.1.1", "@babel/core": "^7.20.0", @@ -298,4 +300,4 @@ "node": "16.15.1", "npm": "8.11.0" } -} +} \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index 0c88512b9749..151087fb1321 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -30,7 +30,20 @@ "resolveJsonModule": true, "allowSyntheticDefaultImports": true, "skipLibCheck": true, - "incremental": true + "incremental": true, + "baseUrl": ".", + "paths": { + "@assets/*": ["./assets/*"], + "@components/*": ["./src/components/*"], + "@hooks/*": ["./src/hooks/*"], + "@libs/*": ["./src/libs/*"], + "@navigation/*": ["./src/libs/Navigation/*"], + "@pages/*": ["./src/pages/*"], + "@styles/*": ["./src/styles/*"], + // This path is provide alias for files like `ONYXKEYS` and `CONST`. + "@src/*": ["./src/*"], + "@userActions/*": ["./src/libs/actions/*"] + } }, "exclude": ["**/node_modules/*", "**/dist/*", ".github/actions/**/index.js", "**/docs/*"], "include": ["src", "desktop", "web", "docs", "assets", "config", "tests", "jest", "__mocks__", ".github/**/*", ".storybook/**/*"] From 5d45f0f6c86e97d4ae58ac167b6c162a610b817c Mon Sep 17 00:00:00 2001 From: Mahesh Vagicherla Date: Sat, 28 Oct 2023 19:58:04 +0530 Subject: [PATCH 104/105] run alias & lint config --- .storybook/preview.js | 8 +- assets/emojis/common.js | 8 +- index.js | 3 +- jest/setup.js | 6 +- src/App.js | 26 +- src/CONFIG.ts | 2 +- src/Expensify.js | 53 ++-- src/ONYXKEYS.ts | 6 +- src/components/AddPaymentMethodMenu.js | 16 +- src/components/AddPlaidBankAccount.js | 38 +-- .../AddressSearch/CurrentLocationButton.js | 16 +- src/components/AddressSearch/index.js | 40 +-- src/components/AmountTextInput.js | 8 +- .../BaseAnchorForAttachmentsOnly.js | 22 +- .../anchorForAttachmentsOnlyPropTypes.js | 2 +- .../AnchorForAttachmentsOnly/index.js | 4 +- .../AnchorForAttachmentsOnly/index.native.js | 2 +- .../BaseAnchorForCommentsOnly.js | 28 +- .../anchorForCommentsOnlyPropTypes.js | 2 +- src/components/AnchorForCommentsOnly/index.js | 4 +- .../AnchorForCommentsOnly/index.native.js | 1 - .../AnimatedStep/AnimatedStepProvider.js | 4 +- src/components/AnimatedStep/index.js | 8 +- src/components/AnonymousReportFooter.js | 14 +- src/components/ArchivedReportFooter.js | 22 +- src/components/ArrowKeyFocusManager.js | 6 +- src/components/AttachmentModal.js | 64 ++--- .../attachmentPickerPropTypes.js | 2 +- src/components/AttachmentPicker/index.js | 6 +- .../AttachmentPicker/index.native.js | 32 +-- .../AttachmentPicker/launchCamera.ios.js | 2 +- .../AttachmentCarouselCellRenderer.js | 8 +- .../AttachmentCarousel/CarouselActions.js | 6 +- .../AttachmentCarousel/CarouselButtons.js | 18 +- .../AttachmentCarousel/CarouselItem.js | 22 +- .../Pager/AttachmentCarouselPage.js | 6 +- .../Pager/ImageTransformer.js | 6 +- .../AttachmentCarousel/Pager/ImageWrapper.js | 4 +- .../AttachmentCarousel/Pager/index.js | 12 +- .../attachmentCarouselPropTypes.js | 4 +- .../extractAttachmentsFromReport.js | 12 +- .../Attachments/AttachmentCarousel/index.js | 30 +- .../AttachmentCarousel/index.native.js | 26 +- .../AttachmentCarousel/useCarouselArrows.js | 4 +- .../AttachmentViewImage/index.js | 14 +- .../AttachmentViewImage/index.native.js | 16 +- .../AttachmentViewImage/propTypes.js | 2 +- .../AttachmentView/AttachmentViewPdf/index.js | 4 +- .../AttachmentViewPdf/index.native.js | 6 +- .../AttachmentViewPdf/propTypes.js | 4 +- .../Attachments/AttachmentView/index.js | 44 +-- .../Attachments/AttachmentView/propTypes.js | 2 +- .../BaseAutoCompleteSuggestions.js | 10 +- .../AutoCompleteSuggestions/index.js | 10 +- .../AutoCompleteSuggestions/index.native.js | 4 +- src/components/AutoEmailLink.js | 6 +- src/components/AutoUpdateTime.js | 10 +- src/components/Avatar.js | 16 +- .../AvatarCropModal/AvatarCropModal.js | 38 +-- .../AvatarCropModal/ImageCropView.js | 10 +- src/components/AvatarCropModal/Slider.js | 8 +- src/components/AvatarWithDisplayName.js | 38 +-- src/components/AvatarWithImagePicker.js | 40 +-- src/components/AvatarWithIndicator.js | 10 +- src/components/Badge.js | 10 +- src/components/Banner.js | 14 +- src/components/BaseMiniContextMenuItem.js | 18 +- src/components/BigNumberPad.js | 8 +- src/components/BlockingViews/BlockingView.js | 20 +- .../BlockingViews/FullPageNotFoundView.js | 16 +- .../FullPageOfflineBlockingView.js | 12 +- src/components/Button/index.js | 30 +- src/components/ButtonWithDropdownMenu.js | 14 +- src/components/CardPreview.js | 12 +- .../CategoryPicker/categoryPickerPropTypes.js | 2 +- src/components/CategoryPicker/index.js | 16 +- src/components/Checkbox.js | 12 +- src/components/CheckboxWithLabel.js | 8 +- ...heckboxWithTooltipForMobileWebAndNative.js | 8 +- .../checkboxWithTooltipPropTypes.js | 6 +- src/components/CheckboxWithTooltip/index.js | 8 +- .../CheckboxWithTooltip/index.native.js | 4 +- .../Collapsible/index.native.js | 2 +- src/components/CollapsibleSection/index.js | 14 +- src/components/CommunicationsLink.js | 8 +- src/components/ComposeProviders.tsx | 2 +- src/components/Composer/index.android.js | 10 +- src/components/Composer/index.ios.js | 10 +- src/components/Composer/index.js | 40 +-- src/components/ConfirmContent.js | 14 +- src/components/ConfirmModal.js | 6 +- src/components/ConfirmPopover.js | 4 +- src/components/ConfirmationPage.js | 8 +- src/components/ConfirmedRoute.js | 25 +- src/components/ConnectBankAccountButton.js | 16 +- src/components/ContextMenuItem.js | 18 +- src/components/CopyTextToClipboard.js | 4 +- src/components/CountrySelector.js | 12 +- src/components/CurrencySymbolButton.js | 10 +- .../index.js | 16 +- src/components/CurrentWalletBalance.js | 12 +- src/components/CustomDevMenu/index.native.js | 2 +- src/components/CustomStatusBar/index.js | 6 +- .../DatePicker/datepickerPropTypes.js | 4 +- src/components/DatePicker/index.android.js | 12 +- src/components/DatePicker/index.ios.js | 22 +- src/components/DatePicker/index.js | 10 +- .../DeeplinkRedirectLoadingIndicator.js | 26 +- .../DeeplinkWrapper/index.website.js | 20 +- .../DisplayNames/DisplayNamesTooltipItem.js | 6 +- .../DisplayNames/DisplayNamesWithTooltip.js | 10 +- .../DisplayNamesWithoutTooltip.js | 4 +- src/components/DisplayNames/index.js | 4 +- src/components/DisplayNames/index.native.js | 4 +- src/components/DistanceEReceipt.js | 30 +- .../DistanceMapView/index.android.js | 14 +- src/components/DistanceMapView/index.js | 2 +- .../DistanceRequest/DistanceRequestFooter.js | 30 +- .../DistanceRequestRenderItem.js | 12 +- src/components/DistanceRequest/index.js | 48 ++-- src/components/DotIndicatorMessage.js | 12 +- src/components/DragAndDrop/Consumer/index.js | 4 +- .../DragAndDrop/NoDropZone/index.js | 6 +- src/components/DragAndDrop/Provider/index.js | 10 +- src/components/DraggableList/index.native.tsx | 2 +- src/components/DraggableList/index.tsx | 6 +- .../DraggableList/useDraggableInPortal.ts | 2 +- src/components/EReceipt.js | 26 +- src/components/EReceiptThumbnail.js | 20 +- .../EmojiPicker/CategoryShortcutBar.js | 4 +- .../EmojiPicker/CategoryShortcutButton.js | 22 +- src/components/EmojiPicker/EmojiPicker.js | 18 +- .../EmojiPicker/EmojiPickerButton.js | 20 +- .../EmojiPicker/EmojiPickerButtonDropdown.js | 24 +- .../EmojiPicker/EmojiPickerMenu/index.js | 44 +-- .../EmojiPickerMenu/index.native.js | 38 +-- .../EmojiPicker/EmojiPickerMenuItem/index.js | 16 +- .../EmojiPickerMenuItem/index.native.js | 14 +- .../EmojiPicker/EmojiSkinToneList.js | 18 +- .../EmojiPicker/getSkinToneEmojiFromIndex.js | 2 +- src/components/EmojiSuggestions.js | 12 +- src/components/EnvironmentBadge.js | 10 +- .../ErrorBoundary/BaseErrorBoundary.js | 6 +- src/components/ErrorBoundary/index.js | 2 +- src/components/ErrorBoundary/index.native.js | 3 +- src/components/ExceededCommentLength.js | 14 +- src/components/ExpensifyWordmark.js | 22 +- src/components/FeatureList.js | 10 +- src/components/FixedFooter.tsx | 2 +- src/components/FlatList/index.android.js | 4 +- src/components/FloatingActionButton.js | 12 +- src/components/Form.js | 26 +- src/components/Form/FormProvider.js | 20 +- src/components/Form/FormWrapper.js | 19 +- src/components/Form/InputWrapper.js | 2 +- src/components/FormAlertWithSubmitButton.js | 4 +- src/components/FormAlertWrapper.js | 12 +- src/components/FormElement.js | 2 +- src/components/FormHelpMessage.js | 12 +- src/components/FormScrollView.tsx | 2 +- .../FormSubmit/formSubmitPropTypes.js | 2 +- src/components/FormSubmit/index.js | 8 +- src/components/FullscreenLoadingIndicator.js | 8 +- .../growlNotificationContainerPropTypes.js | 2 +- .../GrowlNotificationContainer/index.js | 4 +- .../index.native.js | 4 +- src/components/GrowlNotification/index.js | 20 +- .../BaseHTMLEngineProvider.js | 14 +- .../HTMLRenderers/AnchorRenderer.js | 28 +- .../HTMLRenderers/CodeRenderer.js | 6 +- .../HTMLRenderers/EditedRenderer.js | 16 +- .../HTMLRenderers/ImageRenderer.js | 24 +- .../HTMLRenderers/MentionHereRenderer.js | 6 +- .../HTMLRenderers/MentionUserRenderer.js | 38 +-- .../PreRenderer/BasePreRenderer.js | 18 +- .../HTMLRenderers/PreRenderer/index.js | 7 +- .../HTMLRenderers/PreRenderer/index.native.js | 4 +- .../HTMLEngineProvider/HTMLRenderers/index.js | 2 +- src/components/HTMLEngineProvider/index.js | 4 +- .../HTMLEngineProvider/index.native.js | 2 +- src/components/Header.js | 6 +- src/components/HeaderGap/index.desktop.js | 4 +- src/components/HeaderPageLayout.js | 20 +- .../headerWithBackButtonPropTypes.js | 6 +- src/components/HeaderWithBackButton/index.js | 38 +-- src/components/Hoverable/index.js | 10 +- src/components/Hoverable/index.native.js | 4 +- src/components/IFrame.js | 4 +- src/components/Icon/BankIcons.ts | 84 +++--- src/components/Icon/DefaultAvatars.js | 48 ++-- src/components/Icon/EReceiptBGs.js | 12 +- src/components/Icon/Expensicons.js | 256 +++++++++--------- src/components/Icon/Illustrations.js | 98 +++---- src/components/Icon/MCCIcons.js | 26 +- .../Icon/WorkspaceDefaultAvatars.js | 74 ++--- src/components/Icon/index.js | 10 +- src/components/Icon/svgs/LoungeAccessIcon.js | 4 +- src/components/IllustratedHeaderPageLayout.js | 10 +- src/components/Image/imagePropTypes.js | 4 +- src/components/Image/index.js | 4 +- src/components/Image/index.native.js | 6 +- src/components/ImageView/index.js | 16 +- src/components/ImageView/index.native.js | 14 +- src/components/ImageWithSizeCalculation.js | 10 +- src/components/Indicator.js | 26 +- src/components/InlineCodeBlock/WrappedText.js | 10 +- src/components/InlineCodeBlock/index.js | 4 +- .../InlineCodeBlock/index.native.js | 4 +- src/components/InlineErrorText.js | 6 +- src/components/InlineSystemMessage.tsx | 8 +- .../InvertedFlatList/BaseInvertedFlatList.js | 10 +- .../InvertedFlatList/CellRendererComponent.js | 2 +- src/components/InvertedFlatList/index.js | 6 +- src/components/KYCWall/BaseKYCWall.js | 28 +- src/components/KYCWall/index.js | 2 +- src/components/KYCWall/kycWallPropTypes.js | 16 +- .../KeyboardSpacer/BaseKeyboardSpacer.js | 6 +- .../KeyboardSpacer/index.android.js | 4 +- src/components/KeyboardSpacer/index.ios.js | 6 +- .../LHNOptionsList/LHNOptionsList.js | 6 +- src/components/LHNOptionsList/OptionRowLHN.js | 60 ++-- .../LHNOptionsList/OptionRowLHNData.js | 31 +-- .../OptionRowLHNDataWithFocus.js | 4 +- src/components/LocaleContextProvider.js | 21 +- src/components/LocalePicker.js | 18 +- .../BaseLocationErrorMessage.js | 20 +- src/components/LocationErrorMessage/index.js | 2 +- src/components/Lottie/Lottie.tsx | 4 +- src/components/MagicCodeInput.js | 20 +- src/components/MapView/Direction.tsx | 2 +- src/components/MapView/Direction.web.tsx | 6 +- src/components/MapView/MapView.tsx | 12 +- src/components/MapView/MapView.web.tsx | 20 +- src/components/MapView/PendingMapView.tsx | 12 +- src/components/MapView/responder/index.ts | 2 +- src/components/MentionSuggestions.js | 16 +- src/components/MenuItem.js | 40 +-- src/components/MenuItemList.js | 8 +- src/components/MenuItemWithTopDescription.js | 2 +- src/components/MessagesRow.js | 18 +- src/components/Modal/BaseModal.js | 26 +- src/components/Modal/index.android.js | 6 +- src/components/Modal/index.ios.js | 4 +- src/components/Modal/index.web.js | 12 +- src/components/Modal/modalPropTypes.js | 6 +- src/components/MoneyReportHeader.js | 40 +-- src/components/MoneyReportHeaderStatusBar.js | 8 +- .../MoneyRequestConfirmationList.js | 74 ++--- src/components/MoneyRequestHeader.js | 42 +-- src/components/MoneyRequestHeaderStatusBar.js | 4 +- src/components/MoneyRequestSkeletonView.js | 8 +- src/components/MultipleAvatars.js | 16 +- .../NewDatePicker/CalendarPicker/ArrowIcon.js | 12 +- .../CalendarPicker/YearPickerModal.js | 18 +- .../CalendarPicker/generateMonthMatrix.js | 2 +- .../NewDatePicker/CalendarPicker/index.js | 26 +- src/components/NewDatePicker/index.js | 20 +- src/components/OfflineIndicator.js | 14 +- src/components/OfflineWithFeedback.js | 16 +- src/components/Onfido/BaseOnfidoWeb.js | 20 +- src/components/Onfido/index.native.js | 12 +- src/components/Onfido/index.website.js | 2 +- src/components/OnyxProvider.tsx | 4 +- src/components/OpacityView.js | 8 +- src/components/OptionRow.js | 34 +-- src/components/OptionsList/BaseOptionsList.js | 22 +- src/components/OptionsList/index.js | 8 +- src/components/OptionsList/index.native.js | 2 +- .../OptionsList/optionsListPropTypes.js | 6 +- src/components/OptionsListSkeletonView.js | 12 +- .../OptionsSelector/BaseOptionsSelector.js | 34 +-- .../optionsSelectorPropTypes.js | 6 +- src/components/PDFView/PDFInfoMessage.js | 16 +- src/components/PDFView/PDFPasswordForm.js | 24 +- src/components/PDFView/index.js | 32 +-- src/components/PDFView/index.native.js | 24 +- src/components/PDFView/pdfViewPropTypes.js | 4 +- src/components/ParentNavigationSubtitle.js | 14 +- src/components/Picker/BasePicker.js | 20 +- src/components/PinButton.js | 16 +- src/components/PlaidLink/index.js | 4 +- src/components/PlaidLink/index.native.js | 8 +- src/components/Popover/index.js | 12 +- src/components/Popover/index.native.js | 10 +- src/components/Popover/popoverPropTypes.js | 8 +- src/components/PopoverMenu/index.js | 26 +- .../PopoverMenu/popoverMenuPropTypes.js | 2 +- src/components/PopoverProvider/index.js | 2 +- .../PopoverProvider/index.native.js | 2 +- src/components/PopoverWithMeasuredContent.js | 14 +- src/components/PopoverWithoutOverlay/index.js | 14 +- .../GenericPressable/BaseGenericPressable.js | 16 +- .../Pressable/GenericPressable/PropTypes.js | 4 +- .../Pressable/PressableWithDelayToggle.js | 22 +- .../Pressable/PressableWithFeedback.js | 6 +- .../Pressable/PressableWithoutFocus.js | 4 +- .../index.js | 10 +- .../index.native.js | 6 +- ...ssableWithSecondaryInteractionPropTypes.js | 4 +- src/components/QRCode/index.tsx | 6 +- .../QRShare/QRShareWithDownload/index.js | 8 +- .../QRShareWithDownload/index.native.js | 8 +- src/components/QRShare/index.js | 20 +- src/components/RNTextInput.js | 4 +- src/components/RadioButton.js | 6 +- src/components/RadioButtonWithLabel.js | 8 +- src/components/RadioButtons.tsx | 2 +- src/components/Reactions/AddReactionBubble.js | 30 +- .../Reactions/EmojiReactionBubble.js | 16 +- .../Reactions/MiniQuickEmojiReactions.js | 34 +-- .../BaseQuickEmojiReactions.js | 22 +- .../Reactions/QuickEmojiReactions/index.js | 6 +- .../QuickEmojiReactions/index.native.js | 4 +- .../Reactions/ReactionTooltipContent.js | 12 +- .../ReportActionItemEmojiReactions.js | 26 +- .../ReimbursementAccountLoadingIndicator.js | 14 +- src/components/RenderHTML.js | 4 +- .../ReportActionItem/ChronosOOOListActions.js | 20 +- .../ReportActionItem/MoneyReportView.js | 30 +- .../ReportActionItem/MoneyRequestAction.js | 44 +-- .../ReportActionItem/MoneyRequestPreview.js | 68 ++--- .../ReportActionItem/MoneyRequestView.js | 72 ++--- .../ReportActionItem/RenameAction.js | 16 +- .../ReportActionItem/ReportActionItemImage.js | 28 +- .../ReportActionItemImages.js | 12 +- .../ReportActionItem/ReportPreview.js | 60 ++-- src/components/ReportActionItem/TaskAction.js | 10 +- .../ReportActionItem/TaskPreview.js | 46 ++-- src/components/ReportActionItem/TaskView.js | 56 ++-- .../SkeletonViewLines.js | 10 +- .../ReportActionsSkeletonView/index.js | 6 +- src/components/ReportHeaderSkeletonView.js | 18 +- src/components/ReportWelcomeText.js | 26 +- src/components/RoomHeaderAvatars.js | 16 +- src/components/RoomNameInput/index.js | 8 +- src/components/RoomNameInput/index.native.js | 10 +- src/components/SVGImage/index.js | 2 +- src/components/SafeArea/index.ios.js | 4 +- src/components/SafeAreaConsumer.js | 4 +- src/components/ScreenWrapper/index.js | 38 +-- src/components/ScreenWrapper/propTypes.js | 2 +- src/components/ScrollViewWithContext.js | 2 +- src/components/Section.js | 8 +- src/components/SelectCircle.js | 6 +- src/components/SelectionList/BaseListItem.js | 24 +- .../SelectionList/BaseSelectionList.js | 44 +-- src/components/SelectionList/RadioListItem.js | 4 +- src/components/SelectionList/UserListItem.js | 10 +- src/components/SelectionList/index.js | 2 +- .../SelectionList/selectionListPropTypes.js | 2 +- src/components/SettlementButton.js | 30 +- src/components/ShowContextMenuContext.js | 8 +- .../AppleAuthWrapper/index.ios.js | 4 +- .../AppleSignIn/index.android.js | 12 +- .../AppleSignIn/index.desktop.js | 10 +- .../SignInButtons/AppleSignIn/index.ios.js | 10 +- .../AppleSignIn/index.website.js | 16 +- .../GoogleSignIn/index.desktop.js | 12 +- .../GoogleSignIn/index.native.js | 12 +- .../GoogleSignIn/index.website.js | 10 +- src/components/SignInButtons/IconButton.js | 14 +- .../SignInPageForm/index.native.tsx | 2 +- src/components/SignInPageForm/index.tsx | 2 +- src/components/SingleOptionSelector.js | 10 +- src/components/SpacerView.js | 8 +- src/components/SplashScreenHider/index.js | 4 +- .../SplashScreenHider/index.native.js | 10 +- .../StatePicker/StateSelectorModal.js | 24 +- src/components/StatePicker/index.js | 14 +- src/components/SubscriptAvatar.js | 12 +- src/components/SwipeableView/index.native.tsx | 2 +- src/components/Switch.js | 6 +- src/components/TabSelector/TabIcon.js | 8 +- src/components/TabSelector/TabLabel.js | 6 +- src/components/TabSelector/TabSelector.js | 14 +- src/components/TabSelector/TabSelectorItem.js | 8 +- src/components/TagPicker/index.js | 20 +- .../TagPicker/tagPickerPropTypes.js | 2 +- src/components/TaskHeaderActionButton.js | 16 +- src/components/TestToolMenu.js | 26 +- src/components/TestToolRow.tsx | 2 +- src/components/TestToolsModal.js | 12 +- src/components/Text.tsx | 6 +- src/components/TextInput/BaseTextInput.js | 44 +-- .../TextInput/TextInputLabel/index.js | 8 +- .../TextInput/TextInputLabel/index.native.js | 4 +- src/components/TextInput/index.js | 10 +- src/components/TextInput/index.native.js | 2 +- src/components/TextInput/styleConst.js | 2 +- .../BaseTextInputWithCurrencySymbol.js | 10 +- .../index.android.js | 2 +- .../textInputWithCurrencySymbolPropTypes.js | 2 +- src/components/TextLink.js | 14 +- src/components/TextPill.js | 8 +- src/components/TextWithEllipsis/index.js | 10 +- src/components/ThreeDotsMenu/index.js | 22 +- src/components/ThumbnailImage.js | 12 +- src/components/Tooltip/BaseTooltip.js | 18 +- .../Tooltip/PopoverAnchorTooltip.js | 6 +- .../Tooltip/TooltipRenderedOnPageBody.js | 10 +- src/components/Tooltip/TooltipSense.js | 2 +- src/components/Tooltip/index.js | 4 +- src/components/Tooltip/tooltipPropTypes.js | 6 +- src/components/UnorderedList.js | 6 +- src/components/UnreadActionIndicator.js | 4 +- .../UpdateAppModal/BaseUpdateAppModal.js | 8 +- .../UpdateAppModal/index.desktop.js | 2 +- .../BaseUserDetailsTooltip.web.js | 24 +- src/components/UserDetailsTooltip/index.js | 4 +- .../userDetailsTooltipPropTypes.js | 4 +- .../ValidateCode/ExpiredValidateCodeModal.js | 16 +- .../ValidateCode/JustSignedInModal.js | 18 +- .../ValidateCode/ValidateCodeModal.js | 30 +- .../ValuePicker/ValueSelectorModal.js | 16 +- src/components/ValuePicker/index.js | 16 +- .../BaseVideoChatButtonAndMenu.js | 40 +-- .../VideoChatButtonAndMenu/index.android.js | 4 +- .../VideoChatButtonAndMenu/index.js | 4 +- src/components/WalletSection.js | 2 +- src/components/WalletStatementModal/index.js | 24 +- .../WalletStatementModal/index.native.js | 18 +- src/components/ZeroWidthView/index.js | 8 +- src/components/avatarPropTypes.js | 2 +- src/components/createOnyxContext.tsx | 10 +- src/components/menuItemPropTypes.js | 4 +- src/components/optionPropTypes.js | 4 +- src/components/transactionPropTypes.js | 2 +- src/components/withCurrentReportID.js | 7 +- .../withCurrentUserPersonalDetails.tsx | 10 +- src/components/withEnvironment.tsx | 8 +- src/components/withKeyboardState.js | 6 +- src/components/withLocalize.js | 4 +- src/components/withNavigation.tsx | 4 +- src/components/withNavigationFallback.js | 4 +- src/components/withNavigationFocus.tsx | 4 +- src/components/withTheme.js | 6 +- src/components/withThemeStyles.js | 6 +- src/components/withToggleVisibilityView.js | 6 +- src/components/withViewportOffsetTop.tsx | 6 +- src/components/withWindowDimensions/index.js | 10 +- .../withWindowDimensions/index.native.js | 8 +- src/hooks/useArrowKeyFocusManager.js | 4 +- src/hooks/useAutoFocusInput.js | 4 +- src/hooks/useCopySelectionHelper.ts | 10 +- src/hooks/useCurrentReportID.js | 2 +- src/hooks/useDebounce.js | 2 +- src/hooks/useDelayedInputFocus.js | 4 +- src/hooks/useDragAndDrop.ts | 2 +- src/hooks/useEnvironment.ts | 6 +- src/hooks/useKeyboardShortcut.js | 4 +- src/hooks/useKeyboardState.js | 2 +- src/hooks/useLocalize.js | 2 +- src/hooks/useNetwork.ts | 4 +- src/hooks/usePermissions.ts | 4 +- src/hooks/usePrivatePersonalDetails.js | 6 +- .../useReportScrollManager/index.native.ts | 4 +- src/hooks/useReportScrollManager/index.ts | 4 +- src/hooks/useReportScrollManager/types.ts | 2 +- src/hooks/useSingleExecution.js | 2 +- src/hooks/useWaitForNavigation.js | 2 +- src/hooks/useWindowDimensions/index.native.ts | 2 +- src/hooks/useWindowDimensions/index.ts | 2 +- src/languages/en.ts | 120 ++++---- src/languages/es.ts | 120 ++++---- src/languages/types.ts | 2 +- src/libs/API.ts | 10 +- src/libs/Accessibility/index.ts | 2 +- src/libs/ActiveClientManager/index.native.ts | 3 +- src/libs/ActiveClientManager/index.ts | 9 +- src/libs/ApiUtils.ts | 10 +- src/libs/AppStateMonitor/index.ts | 2 +- src/libs/Authentication.ts | 14 +- src/libs/BootSplash/index.native.ts | 2 +- src/libs/BootSplash/index.ts | 2 +- src/libs/Browser/index.web.ts | 6 +- src/libs/CardUtils.ts | 8 +- src/libs/Clipboard/index.js | 4 +- src/libs/CollectionUtils.ts | 2 +- src/libs/ComposerUtils/getDraftComment.ts | 2 +- src/libs/ComposerUtils/index.ts | 2 +- .../updateIsFullComposerAvailable.ts | 2 +- .../updateNumberOfLines/index.native.ts | 6 +- .../updateNumberOfLines/types.ts | 2 +- src/libs/ControlSelection/index.ts | 2 +- src/libs/ControlSelection/types.ts | 2 +- src/libs/CurrencyUtils.ts | 6 +- src/libs/DateUtils.ts | 33 ++- src/libs/DistanceRequestUtils.js | 2 +- src/libs/E2E/API.mock.js | 9 +- src/libs/E2E/actions/e2eLogin.js | 4 +- src/libs/E2E/client.js | 2 +- src/libs/E2E/isE2ETestSession.native.js | 2 +- src/libs/E2E/reactNativeLaunchingTest.js | 10 +- src/libs/E2E/tests/appStartTimeTest.e2e.js | 6 +- src/libs/E2E/tests/openSearchPageTest.e2e.js | 12 +- src/libs/EmojiTrie.ts | 6 +- src/libs/EmojiUtils.js | 10 +- src/libs/Environment/Environment.js | 6 +- .../Environment/betaChecker/index.android.js | 8 +- src/libs/Environment/getEnvironment/index.js | 2 +- .../getEnvironment/index.native.js | 4 +- src/libs/ErrorUtils.ts | 8 +- src/libs/Firebase/index.native.ts | 2 +- src/libs/Growl.ts | 2 +- src/libs/HeaderUtils.js | 6 +- src/libs/HttpUtils.js | 8 +- src/libs/IOUUtils.ts | 6 +- src/libs/IntlPolyfill/index.native.ts | 2 +- src/libs/IntlPolyfill/polyfillNumberFormat.ts | 2 +- .../bindHandlerToKeydownEvent/index.native.ts | 2 +- .../bindHandlerToKeydownEvent/index.ts | 4 +- .../bindHandlerToKeydownEvent/types.ts | 2 +- src/libs/KeyboardShortcut/index.ts | 4 +- .../isEnterWhileComposition.ts | 4 +- src/libs/LocaleDigitUtils.ts | 1 - src/libs/LocalePhoneNumber.ts | 6 +- .../LocaleListener/BaseLocaleListener.js | 4 +- src/libs/Localize/index.js | 14 +- src/libs/Log.ts | 7 +- src/libs/LoginUtils.ts | 8 +- src/libs/Metrics/index.native.ts | 2 +- src/libs/Metrics/index.ts | 2 +- .../Middleware/HandleUnusedOptimisticID.ts | 10 +- src/libs/Middleware/Logging.ts | 8 +- src/libs/Middleware/Reauthentication.ts | 14 +- src/libs/Middleware/RecheckConnection.ts | 4 +- src/libs/Middleware/SaveResponseInOnyx.ts | 8 +- src/libs/Middleware/types.ts | 4 +- src/libs/MoneyRequestUtils.ts | 2 +- .../Navigation/AppNavigator/AuthScreens.js | 62 ++--- .../AppNavigator/ModalStackNavigators.js | 8 +- .../Navigators/CentralPaneNavigator.js | 12 +- .../AppNavigator/Navigators/Overlay.js | 14 +- .../Navigators/RightModalNavigator.js | 15 +- .../Navigation/AppNavigator/PublicScreens.js | 18 +- .../AppNavigator/RHPScreenOptions.js | 2 +- .../AppNavigator/ReportScreenIDSetter.js | 16 +- .../AppNavigator/ReportScreenWrapper.js | 2 +- .../CustomRouter.js | 6 +- .../createCustomStackNavigator/index.js | 8 +- .../getRootNavigatorScreenOptions.js | 8 +- src/libs/Navigation/AppNavigator/index.js | 2 +- .../modalCardStyleInterpolator.js | 4 +- src/libs/Navigation/FreezeWrapper.js | 4 +- src/libs/Navigation/Navigation.js | 24 +- src/libs/Navigation/NavigationRoot.js | 24 +- src/libs/Navigation/OnyxTabNavigator.js | 8 +- src/libs/Navigation/linkTo.js | 8 +- src/libs/Navigation/linkingConfig.js | 8 +- .../shouldPreventDeeplinkPrompt/index.js | 2 +- src/libs/Network/MainQueue.ts | 4 +- src/libs/Network/NetworkStore.ts | 4 +- src/libs/Network/SequentialQueue.ts | 16 +- src/libs/Network/enhanceParameters.ts | 4 +- src/libs/Network/index.ts | 10 +- src/libs/NetworkConnection.ts | 10 +- src/libs/NextStepUtils.js | 2 +- .../LocalNotification/BrowserNotifications.js | 6 +- .../ForegroundNotifications/index.android.js | 2 +- .../ForegroundNotifications/index.ios.js | 2 +- .../backgroundRefresh/index.android.js | 6 +- .../PushNotification/index.native.js | 12 +- .../shouldShowPushNotification.js | 6 +- .../subscribePushNotification/index.js | 4 +- ...bscribeToReportCommentPushNotifications.js | 10 +- src/libs/NumberUtils.ts | 2 +- .../reportWithoutHasDraftSelector.ts | 2 +- src/libs/OptionsListUtils.js | 30 +- src/libs/PaymentUtils.ts | 12 +- src/libs/Performance.tsx | 17 +- src/libs/Permissions.ts | 4 +- src/libs/PersonalDetailsUtils.js | 4 +- src/libs/PolicyUtils.ts | 8 +- src/libs/Pusher/pusher.ts | 16 +- src/libs/PusherConnectionManager.ts | 4 +- src/libs/PusherUtils.ts | 4 +- src/libs/ReceiptUtils.ts | 14 +- src/libs/ReportActionComposeFocusManager.ts | 2 +- src/libs/ReportActionsUtils.ts | 14 +- src/libs/ReportUtils.js | 24 +- src/libs/Request.ts | 6 +- src/libs/RequestThrottle.ts | 2 +- src/libs/RoomNameInputUtils.ts | 2 +- src/libs/SelectionScraper/index.js | 4 +- src/libs/SessionUtils.ts | 2 +- src/libs/SidebarUtils.ts | 28 +- src/libs/StartupTimer/index.ts | 1 - src/libs/StringUtils.ts | 2 +- src/libs/SuggestionUtils.js | 2 +- src/libs/TransactionUtils.ts | 12 +- src/libs/UnreadIndicatorUpdater/index.js | 8 +- .../updateUnread/index.website.js | 2 +- src/libs/UserUtils.ts | 8 +- src/libs/ValidationUtils.ts | 10 +- src/libs/Visibility/index.native.ts | 1 - src/libs/__mocks__/Permissions.ts | 4 +- src/libs/actions/ActiveClients.ts | 2 +- src/libs/actions/App.js | 26 +- src/libs/actions/AppUpdate.ts | 2 +- src/libs/actions/BankAccounts.ts | 22 +- src/libs/actions/CanvasSize.js | 6 +- src/libs/actions/Card.js | 7 +- src/libs/actions/Chronos.ts | 8 +- src/libs/actions/CloseAccount.ts | 4 +- src/libs/actions/Composer.ts | 2 +- src/libs/actions/CurrentDate.ts | 2 +- src/libs/actions/DemoActions.js | 12 +- .../Device/generateDeviceID/index.android.js | 2 +- src/libs/actions/Device/index.js | 4 +- src/libs/actions/Download.ts | 2 +- src/libs/actions/EmojiPickerAction.ts | 4 +- src/libs/actions/IOU.js | 46 ++-- src/libs/actions/InputFocus/index.desktop.ts | 4 +- src/libs/actions/InputFocus/index.website.ts | 6 +- src/libs/actions/Link.js | 12 +- src/libs/actions/MapboxToken.ts | 12 +- .../actions/MemoryOnlyKeys/MemoryOnlyKeys.js | 4 +- .../index.js | 2 +- src/libs/actions/Modal.ts | 2 +- src/libs/actions/Network.ts | 2 +- src/libs/actions/OnyxUpdateManager.js | 8 +- src/libs/actions/OnyxUpdates.ts | 10 +- src/libs/actions/PaymentMethods.ts | 16 +- src/libs/actions/PersistedRequests.ts | 6 +- src/libs/actions/PersonalDetails.js | 16 +- src/libs/actions/Plaid.ts | 8 +- src/libs/actions/Policy.js | 26 +- src/libs/actions/PushNotification.js | 4 +- .../deleteFromBankAccountList.js | 2 +- .../actions/ReimbursementAccount/errors.js | 4 +- .../actions/ReimbursementAccount/index.js | 4 +- .../ReimbursementAccount/navigation.js | 6 +- .../resetFreePlanBankAccount.js | 10 +- .../actions/ReimbursementAccount/store.js | 6 +- src/libs/actions/Report.js | 54 ++-- src/libs/actions/ReportActions.ts | 10 +- src/libs/actions/Session/index.ts | 48 ++-- .../Session/updateSessionAuthTokens.ts | 2 +- src/libs/actions/SignInRedirect.ts | 18 +- src/libs/actions/Tab.ts | 2 +- src/libs/actions/Task.js | 30 +- src/libs/actions/TeachersUnite.js | 16 +- src/libs/actions/TestTool.ts | 4 +- src/libs/actions/Timing.ts | 10 +- src/libs/actions/Transaction.ts | 20 +- src/libs/actions/TransactionEdit.js | 2 +- src/libs/actions/TwoFactorAuthActions.ts | 8 +- src/libs/actions/User.js | 28 +- src/libs/actions/Wallet.js | 4 +- src/libs/actions/Welcome.ts | 16 +- src/libs/addEncryptedAuthTokenToURL.ts | 2 +- src/libs/calculateAnchorPosition.ts | 4 +- src/libs/canFocusInputOnScreenFocus/index.ts | 2 +- src/libs/convertToLTR/index.android.ts | 2 +- src/libs/convertToLTRForComposer/index.ts | 2 +- src/libs/fileDownload/FileUtils.js | 6 +- src/libs/fileDownload/getAttachmentDetails.js | 4 +- src/libs/fileDownload/index.ios.js | 4 +- src/libs/fileDownload/index.js | 2 +- src/libs/focusAndUpdateMultilineInputRange.ts | 1 + src/libs/getButtonState.ts | 2 +- src/libs/getModalState.js | 2 +- src/libs/getOperatingSystem/index.native.ts | 2 +- src/libs/getOperatingSystem/index.ts | 2 +- src/libs/getOperatingSystem/types.ts | 2 +- .../getPermittedDecimalSeparator/index.js | 4 +- .../index.android.ts | 2 +- .../getPlaidLinkTokenParameters/index.ios.ts | 2 +- src/libs/getPlaidLinkTokenParameters/index.ts | 4 +- src/libs/getPlatform/index.android.ts | 2 +- src/libs/getPlatform/index.desktop.ts | 2 +- src/libs/getPlatform/index.ios.ts | 2 +- src/libs/getPlatform/index.ts | 2 +- src/libs/getPlatform/types.ts | 2 +- .../index.android.ts | 2 +- src/libs/isReportMessageAttachment.ts | 4 +- src/libs/localFileDownload/index.android.ts | 2 +- src/libs/localFileDownload/index.ios.ts | 2 +- src/libs/localFileDownload/index.ts | 2 +- src/libs/migrateOnyx.js | 2 +- .../CheckForPreviousReportActionID.js | 6 +- .../KeyReportActionsDraftByReportActionID.js | 6 +- .../migrations/PersonalDetailsByAccountID.js | 6 +- src/libs/migrations/RenameReceiptFilename.js | 6 +- src/libs/models/BankAccount.js | 4 +- src/libs/onyxSubscribe.ts | 2 +- .../index.native.ts | 2 +- .../index.ts | 2 +- src/libs/tryResolveUrlFromApiRoot.ts | 4 +- src/pages/AddPersonalBankAccountPage.js | 32 +-- src/pages/ConciergePage.js | 16 +- src/pages/DemoSetupPage.js | 14 +- src/pages/DetailsPage.js | 54 ++-- src/pages/EditRequestAmountPage.js | 10 +- src/pages/EditRequestCategoryPage.js | 16 +- src/pages/EditRequestCreatedPage.js | 16 +- src/pages/EditRequestDescriptionPage.js | 26 +- src/pages/EditRequestDistancePage.js | 28 +- src/pages/EditRequestMerchantPage.js | 18 +- src/pages/EditRequestPage.js | 48 ++-- src/pages/EditRequestReceiptPage.js | 14 +- src/pages/EditRequestTagPage.js | 16 +- src/pages/EditSplitBillPage.js | 28 +- src/pages/EnablePayments/ActivateStep.js | 18 +- .../EnablePayments/AdditionalDetailsStep.js | 44 +-- .../EnablePayments/EnablePaymentsPage.js | 31 +-- src/pages/EnablePayments/FailedKYC.js | 10 +- src/pages/EnablePayments/IdologyQuestions.js | 28 +- src/pages/EnablePayments/OnfidoPrivacy.js | 28 +- src/pages/EnablePayments/OnfidoStep.js | 22 +- .../EnablePayments/TermsPage/LongTermsForm.js | 18 +- .../TermsPage/ShortTermsForm.js | 12 +- src/pages/EnablePayments/TermsStep.js | 26 +- .../EnablePayments/walletTermsPropTypes.js | 2 +- src/pages/ErrorPage/ErrorBodyText/index.js | 10 +- src/pages/ErrorPage/GenericErrorPage.js | 30 +- src/pages/ErrorPage/NotFoundPage.js | 4 +- src/pages/FlagCommentPage.js | 40 +-- src/pages/GetAssistancePage.js | 36 +-- src/pages/KeyboardShortcutsPage.js | 18 +- src/pages/LogInWithShortLivedAuthTokenPage.js | 28 +- src/pages/LogOutPreviousUserPage.js | 12 +- src/pages/NewChatPage.js | 40 +-- src/pages/NewChatSelectorPage.js | 20 +- .../PrivateNotes/PrivateNotesEditPage.js | 52 ++-- .../PrivateNotes/PrivateNotesListPage.js | 50 ++-- .../PrivateNotes/PrivateNotesViewPage.js | 36 +-- src/pages/ProfilePage.js | 74 ++--- .../ReimbursementAccount/ACHContractStep.js | 32 +-- src/pages/ReimbursementAccount/AddressForm.js | 12 +- .../BankAccountManualStep.js | 34 +-- .../BankAccountPlaidStep.js | 34 +-- .../ReimbursementAccount/BankAccountStep.js | 50 ++-- src/pages/ReimbursementAccount/CompanyStep.js | 42 +-- .../ContinueBankAccountSetup.js | 30 +- .../ReimbursementAccount/Enable2FAPrompt.js | 16 +- src/pages/ReimbursementAccount/EnableStep.js | 44 +-- .../ReimbursementAccount/IdentityForm.js | 12 +- .../ReimbursementAccountPage.js | 56 ++-- .../RequestorOnfidoStep.js | 24 +- .../ReimbursementAccount/RequestorStep.js | 30 +- .../ReimbursementAccount/StepPropTypes.js | 4 +- .../ReimbursementAccount/ValidationStep.js | 48 ++-- .../ReimbursementAccount/exampleCheckImage.js | 6 +- .../reimbursementAccountPropTypes.js | 2 +- src/pages/ReportDetailsPage.js | 54 ++-- src/pages/ReportParticipantsPage.js | 36 +-- src/pages/ReportWelcomeMessagePage.js | 44 +-- src/pages/RoomInvitePage.js | 44 +-- src/pages/RoomMembersPage.js | 50 ++-- src/pages/SearchPage.js | 38 +-- src/pages/ShareCodePage.js | 44 +-- src/pages/TeachersUnite/ImTeacherPage.js | 6 +- .../TeachersUnite/ImTeacherUpdateEmailPage.js | 22 +- .../TeachersUnite/IntroSchoolPrincipalPage.js | 34 +-- src/pages/TeachersUnite/KnowATeacherPage.js | 36 +-- src/pages/TeachersUnite/SaveTheWorldPage.js | 28 +- src/pages/UnlinkLoginPage.js | 18 +- src/pages/ValidateLoginPage/index.js | 14 +- src/pages/ValidateLoginPage/index.website.js | 22 +- src/pages/home/HeaderView.js | 62 ++--- src/pages/home/ReportScreen.js | 68 ++--- src/pages/home/ReportScreenContext.ts | 2 +- .../report/AnimatedEmptyStateBackground.js | 12 +- .../BaseReportActionContextMenu.js | 32 +-- .../report/ContextMenu/ContextMenuActions.js | 44 +-- .../MiniReportActionContextMenu/index.js | 15 +- .../PopoverReportActionContextMenu.js | 14 +- .../index.android.js | 4 +- .../FloatingMessageCounterContainer/index.js | 2 +- .../report/FloatingMessageCounter/index.js | 22 +- src/pages/home/report/LinkPreviewer.js | 18 +- .../ListBoundaryLoader/ListBoundaryLoader.js | 12 +- src/pages/home/report/ParticipantLocalTime.js | 18 +- .../report/ReactionList/BaseReactionList.js | 22 +- .../report/ReactionList/HeaderReactionList.js | 14 +- .../BasePopoverReactionList.js | 26 +- .../ReactionList/PopoverReactionList/index.js | 2 +- .../AttachmentPickerWithMenuItems.js | 36 +-- .../ComposerWithSuggestions.js | 70 ++--- .../ReportActionCompose.js | 68 ++--- .../report/ReportActionCompose/SendButton.js | 18 +- .../SilentCommentUpdater.js | 8 +- .../ReportActionCompose/SuggestionEmoji.js | 18 +- .../ReportActionCompose/SuggestionMention.js | 24 +- .../report/ReportActionCompose/Suggestions.js | 4 +- .../composerWithSuggestionsProps.js | 4 +- src/pages/home/report/ReportActionItem.js | 134 ++++----- .../report/ReportActionItemBasicMessage.js | 6 +- .../home/report/ReportActionItemCreated.js | 36 +-- src/pages/home/report/ReportActionItemDate.js | 12 +- .../home/report/ReportActionItemDraft.js | 4 +- .../home/report/ReportActionItemFragment.js | 38 +-- .../home/report/ReportActionItemGrouped.js | 4 +- .../home/report/ReportActionItemMessage.js | 14 +- .../report/ReportActionItemMessageEdit.js | 72 ++--- .../report/ReportActionItemParentAction.js | 26 +- .../home/report/ReportActionItemSingle.js | 56 ++-- .../home/report/ReportActionItemThread.js | 22 +- src/pages/home/report/ReportActionsList.js | 40 +-- .../report/ReportActionsListItemRenderer.js | 8 +- src/pages/home/report/ReportActionsView.js | 38 +-- src/pages/home/report/ReportAttachments.js | 10 +- .../home/report/ReportAttachmentsContext.js | 4 +- .../home/report/ReportDetailsShareCodePage.js | 6 +- src/pages/home/report/ReportDropUI.js | 14 +- src/pages/home/report/ReportFooter.js | 34 +-- .../home/report/ReportTypingIndicator.js | 22 +- .../withReportAndReportActionOrNotFound.js | 24 +- .../home/report/withReportOrNotFound.tsx | 14 +- .../home/sidebar/AvatarWithOptionalStatus.js | 16 +- .../GlobalNavigationMenuItem.js | 16 +- .../home/sidebar/GlobalNavigation/index.js | 18 +- .../sidebar/PressableAvatarWithIndicator.js | 22 +- src/pages/home/sidebar/SidebarLinks.js | 52 ++-- src/pages/home/sidebar/SidebarLinksData.js | 28 +- .../home/sidebar/SidebarNavigationContext.js | 8 +- .../SidebarScreen/BaseSidebarScreen.js | 18 +- .../FloatingActionButtonAndPopover.js | 52 ++-- src/pages/home/sidebar/SidebarScreen/index.js | 4 +- .../sidebar/SidebarScreen/index.native.js | 4 +- src/pages/home/sidebar/SignInButton.js | 12 +- .../SignInOrAvatarWithOptionalStatus.js | 18 +- .../sidebar/SubNavigation/SubNavigation.js | 14 +- src/pages/iou/IOUCurrencySelection.js | 36 +-- src/pages/iou/MoneyRequestCategoryPage.js | 30 +- src/pages/iou/MoneyRequestDatePage.js | 30 +- src/pages/iou/MoneyRequestDescriptionPage.js | 38 +-- src/pages/iou/MoneyRequestEditWaypointPage.js | 2 +- src/pages/iou/MoneyRequestMerchantPage.js | 28 +- src/pages/iou/MoneyRequestSelectorPage.js | 44 +-- src/pages/iou/MoneyRequestTagPage.js | 36 +-- src/pages/iou/NewDistanceRequestPage.js | 14 +- .../NewDistanceRequestWaypointEditorPage.js | 4 +- src/pages/iou/ReceiptDropUI.js | 12 +- .../ReceiptSelector/NavigationAwareCamera.js | 4 +- .../NavigationAwareCamera.native.js | 6 +- src/pages/iou/ReceiptSelector/index.js | 54 ++-- src/pages/iou/ReceiptSelector/index.native.js | 42 +-- src/pages/iou/SplitBillDetailsPage.js | 44 +-- src/pages/iou/WaypointEditor.js | 46 ++-- src/pages/iou/propTypes/index.js | 4 +- src/pages/iou/steps/MoneyRequestAmountForm.js | 34 +-- .../iou/steps/MoneyRequestConfirmPage.js | 52 ++-- .../MoneyRequestParticipantsPage.js | 32 +-- .../MoneyRequestParticipantsSelector.js | 28 +- src/pages/iou/steps/NewRequestAmountPage.js | 36 +-- src/pages/reportPropTypes.js | 6 +- src/pages/settings/AboutPage/AboutPage.js | 44 +-- src/pages/settings/AppDownloadLinks.js | 30 +- src/pages/settings/InitialSettingsPage.js | 86 +++--- .../settings/Preferences/LanguagePage.js | 20 +- .../settings/Preferences/PreferencesPage.js | 34 +-- .../settings/Preferences/PriorityModePage.js | 26 +- src/pages/settings/Preferences/ThemePage.js | 28 +- .../Contacts/ContactMethodDetailsPage.js | 46 ++-- .../Profile/Contacts/ContactMethodsPage.js | 32 +-- .../Profile/Contacts/NewContactMethodPage.js | 38 +-- .../ValidateCodeForm/BaseValidateCodeForm.js | 46 ++-- .../Profile/CustomStatus/StatusPage.js | 40 +-- .../Profile/CustomStatus/StatusSetPage.js | 34 +-- src/pages/settings/Profile/DisplayNamePage.js | 38 +-- .../settings/Profile/LoungeAccessPage.js | 42 +-- .../Profile/PersonalDetails/AddressPage.js | 40 +-- .../PersonalDetails/CountrySelectionPage.js | 20 +- .../PersonalDetails/DateOfBirthPage.js | 34 +-- .../Profile/PersonalDetails/LegalNamePage.js | 40 +-- .../PersonalDetailsInitialPage.js | 32 +-- src/pages/settings/Profile/ProfilePage.js | 44 +-- src/pages/settings/Profile/PronounsPage.js | 34 +-- .../settings/Profile/TimezoneInitialPage.js | 26 +- .../settings/Profile/TimezoneSelectPage.js | 22 +- .../Report/NotificationPreferencePage.js | 26 +- .../settings/Report/ReportSettingsPage.js | 46 ++-- src/pages/settings/Report/RoomNamePage.js | 42 +-- .../settings/Report/WriteCapabilityPage.js | 34 +-- .../settings/Security/CloseAccountPage.js | 42 +-- .../settings/Security/SecuritySettingsPage.js | 26 +- .../TwoFactorAuth/StepWrapper/StepWrapper.js | 14 +- .../Security/TwoFactorAuth/Steps/CodesStep.js | 44 +-- .../TwoFactorAuth/Steps/DisabledStep.js | 18 +- .../TwoFactorAuth/Steps/EnabledStep.js | 24 +- .../TwoFactorAuth/Steps/SuccessStep.js | 14 +- .../TwoFactorAuth/Steps/VerifyStep.js | 40 +-- .../BaseTwoFactorAuthForm.js | 16 +- .../TwoFactorAuthForm/index.android.js | 2 +- .../TwoFactorAuth/TwoFactorAuthForm/index.js | 2 +- .../TwoFactorAuth/TwoFactorAuthPage.js | 2 +- .../TwoFactorAuth/TwoFactorAuthSteps.js | 10 +- .../Wallet/ActivatePhysicalCardPage.js | 48 ++-- src/pages/settings/Wallet/AddDebitCardPage.js | 42 +-- .../Wallet/ChooseTransferAccountPage.js | 28 +- .../settings/Wallet/DangerCardSection.js | 6 +- .../settings/Wallet/ExpensifyCardPage.js | 44 +-- .../settings/Wallet/PaymentMethodList.js | 54 ++-- .../settings/Wallet/ReportCardLostPage.js | 42 +-- .../Wallet/ReportVirtualCardFraudPage.js | 32 +-- .../settings/Wallet/TransferBalancePage.js | 52 ++-- src/pages/settings/Wallet/WalletEmptyState.js | 22 +- .../settings/Wallet/WalletPage/CardDetails.js | 26 +- .../settings/Wallet/WalletPage/WalletPage.js | 74 ++--- .../Wallet/WalletPage/walletPagePropTypes.js | 12 +- .../settings/Wallet/assignedCardPropTypes.js | 2 +- .../Wallet/walletTransferPropTypes.js | 2 +- .../AppleSignInDesktopPage/index.website.js | 4 +- src/pages/signin/ChangeExpensifyLoginLink.js | 16 +- src/pages/signin/ChooseSSOOrMagicCode.js | 28 +- src/pages/signin/DesktopRedirectPage.js | 4 +- .../index.website.js | 2 +- src/pages/signin/EmailDeliveryFailurePage.js | 22 +- .../GoogleSignInDesktopPage/index.website.js | 4 +- src/pages/signin/Licenses.js | 12 +- src/pages/signin/LoginForm/BaseLoginForm.js | 62 ++--- src/pages/signin/LoginForm/index.js | 2 +- src/pages/signin/LoginForm/index.native.js | 4 +- src/pages/signin/SAMLSignInPage/index.js | 22 +- src/pages/signin/SignInHeroCopy.js | 16 +- src/pages/signin/SignInHeroImage.js | 10 +- src/pages/signin/SignInModal.js | 10 +- src/pages/signin/SignInPage.js | 46 ++-- src/pages/signin/SignInPageHero.js | 12 +- .../BackgroundImage/index.android.js | 4 +- .../SignInPageLayout/BackgroundImage/index.js | 8 +- src/pages/signin/SignInPageLayout/Footer.js | 32 +-- .../SignInPageLayout/SignInPageContent.js | 24 +- src/pages/signin/SignInPageLayout/index.js | 30 +- .../signInPageStyles/index.js | 2 +- .../signInPageStyles/index.native.js | 2 +- src/pages/signin/Socials.js | 16 +- src/pages/signin/Terms.js | 10 +- src/pages/signin/ThirdPartySignInPage.js | 28 +- src/pages/signin/UnlinkLoginForm.js | 32 +-- .../ValidateCodeForm/BaseValidateCodeForm.js | 52 ++-- .../signin/ValidateCodeForm/index.android.js | 2 +- src/pages/signin/ValidateCodeForm/index.js | 2 +- src/pages/tasks/NewTaskDescriptionPage.js | 34 +-- src/pages/tasks/NewTaskDetailsPage.js | 36 +-- src/pages/tasks/NewTaskPage.js | 40 +-- src/pages/tasks/NewTaskTitlePage.js | 32 +-- src/pages/tasks/TaskAssigneeSelectorModal.js | 40 +-- src/pages/tasks/TaskDescriptionPage.js | 40 +-- .../TaskShareDestinationSelectorModal.js | 36 +-- src/pages/tasks/TaskTitlePage.js | 36 +-- src/pages/wallet/WalletStatementPage.js | 40 +-- src/pages/workspace/WorkspaceInitialPage.js | 64 ++--- .../workspace/WorkspaceInviteMessagePage.js | 50 ++-- src/pages/workspace/WorkspaceInvitePage.js | 38 +-- src/pages/workspace/WorkspaceMembersPage.js | 62 ++--- src/pages/workspace/WorkspaceNewRoomPage.js | 54 ++-- .../workspace/WorkspacePageWithSections.js | 34 +-- .../WorkspaceResetBankAccountModal.js | 18 +- .../WorkspaceSettingsCurrencyPage.js | 28 +- src/pages/workspace/WorkspaceSettingsPage.js | 46 ++-- src/pages/workspace/WorkspacesListPage.js | 54 ++-- .../bills/WorkspaceBillsFirstSection.js | 28 +- .../bills/WorkspaceBillsNoVBAView.js | 14 +- .../workspace/bills/WorkspaceBillsPage.js | 8 +- .../workspace/bills/WorkspaceBillsVBAView.js | 16 +- .../workspace/card/WorkspaceCardNoVBAView.js | 16 +- src/pages/workspace/card/WorkspaceCardPage.js | 8 +- .../card/WorkspaceCardVBANoECardView.js | 26 +- .../card/WorkspaceCardVBAWithECardView.js | 16 +- .../invoices/WorkspaceInvoicesFirstSection.js | 16 +- .../invoices/WorkspaceInvoicesNoVBAView.js | 14 +- .../invoices/WorkspaceInvoicesPage.js | 8 +- .../invoices/WorkspaceInvoicesVBAView.js | 16 +- .../reimburse/WorkspaceRateAndUnitPage.js | 44 +-- .../reimburse/WorkspaceReimbursePage.js | 12 +- .../reimburse/WorkspaceReimburseSection.js | 28 +- .../reimburse/WorkspaceReimburseView.js | 48 ++-- .../travel/WorkspaceTravelNoVBAView.js | 14 +- .../workspace/travel/WorkspaceTravelPage.js | 8 +- .../travel/WorkspaceTravelVBAView.js | 18 +- src/pages/workspace/withPolicy.js | 16 +- .../withPolicyAndFullscreenLoading.js | 14 +- src/setup/index.js | 12 +- src/setup/platformSetup/index.desktop.js | 10 +- src/setup/platformSetup/index.native.js | 8 +- src/setup/platformSetup/index.website.js | 10 +- src/stories/AddressSearch.stories.js | 2 +- src/stories/Banner.stories.js | 2 +- src/stories/Button.stories.js | 4 +- src/stories/ButtonWithDropdownMenu.stories.js | 2 +- src/stories/Checkbox.stories.js | 2 +- src/stories/CheckboxWithLabel.stories.js | 6 +- src/stories/Composer.stories.js | 18 +- src/stories/Datepicker.stories.js | 2 +- src/stories/DragAndDrop.stories.js | 12 +- src/stories/EReceipt.stories.js | 4 +- src/stories/EReceiptThumbail.stories.js | 2 +- src/stories/Form.stories.js | 26 +- .../FormAlertWithSubmitButton.stories.js | 2 +- src/stories/Header.stories.js | 2 +- src/stories/HeaderWithBackButton.stories.js | 2 +- src/stories/InlineSystemMessage.stories.js | 2 +- src/stories/MagicCodeInput.stories.js | 2 +- src/stories/MenuItem.stories.js | 6 +- src/stories/OptionRow.stories.js | 7 +- src/stories/Picker.stories.js | 2 +- src/stories/PopoverMenu.stories.js | 8 +- src/stories/ReportActionItemImages.stories.js | 4 +- src/stories/SelectionList.stories.js | 10 +- src/stories/SubscriptAvatar.stories.js | 8 +- src/stories/TextInput.stories.js | 2 +- src/stories/Tooltip.stories.js | 2 +- src/styles/StyleUtils.ts | 8 +- src/styles/ThemeStylesProvider.tsx | 4 +- src/styles/addOutlineWidth/index.native.ts | 1 - src/styles/addOutlineWidth/index.ts | 3 +- .../animation/SpinningIndicatorAnimation.js | 2 +- src/styles/cardStyles/index.ts | 2 +- .../containerComposeStyles/index.native.ts | 2 +- src/styles/containerComposeStyles/index.ts | 2 +- src/styles/editedLabelStyles/index.ts | 4 +- src/styles/getContextMenuItemStyles/index.js | 4 +- .../getContextMenuItemStyles/index.native.js | 2 +- src/styles/getModalStyles.ts | 2 +- .../index.desktop.ts | 2 +- .../index.website.ts | 2 +- .../getPopOverVerticalOffset/index.desktop.ts | 2 +- src/styles/optionRowStyles/index.native.ts | 2 +- src/styles/optionRowStyles/index.ts | 2 +- src/styles/styles.ts | 12 +- src/styles/themes/ThemeProvider.js | 9 +- src/styles/themes/default.ts | 4 +- src/styles/themes/light.ts | 4 +- src/styles/themes/types.ts | 2 +- src/styles/themes/useThemePreference.js | 6 +- src/styles/utilities/writingDirection.ts | 1 + .../modules/react-native-key-command.d.ts | 48 ++-- src/types/modules/react-native-onyx.d.ts | 2 +- src/types/modules/react-native.d.ts | 4 +- src/types/onyx/Account.ts | 2 +- src/types/onyx/BankAccount.ts | 2 +- src/types/onyx/Beta.ts | 2 +- src/types/onyx/Card.ts | 2 +- src/types/onyx/Fund.ts | 2 +- src/types/onyx/OnyxCommon.ts | 4 +- src/types/onyx/OriginalMessage.ts | 4 +- src/types/onyx/PaymentMethod.ts | 2 +- src/types/onyx/PlaidData.ts | 2 +- src/types/onyx/Policy.ts | 2 +- src/types/onyx/ReimbursementAccount.ts | 2 +- src/types/onyx/Report.ts | 2 +- src/types/onyx/Session.ts | 2 +- src/types/onyx/Transaction.ts | 2 +- src/types/onyx/UserWallet.ts | 2 +- src/types/onyx/WalletTransfer.ts | 2 +- src/types/onyx/index.ts | 72 ++--- tests/actions/IOUTest.js | 26 +- tests/actions/ReportTest.js | 26 +- tests/actions/SessionTest.js | 13 +- .../perf-test/ReportActionsList.perf-test.js | 20 +- tests/perf-test/SelectionList.perf-test.js | 2 +- tests/perf-test/SidebarLinks.perf-test.js | 8 +- tests/ui/UnreadIndicatorsTest.js | 32 +-- tests/unit/APITest.js | 13 +- tests/unit/CalendarPickerTest.js | 6 +- tests/unit/CurrencyUtilsTest.js | 7 +- tests/unit/DateUtilsTest.js | 4 +- tests/unit/EmojiTest.js | 10 +- tests/unit/IOUUtilsTest.js | 2 +- tests/unit/LocalePhoneNumberTest.js | 2 +- tests/unit/LocalizeTests.js | 4 +- tests/unit/LoginUtilsTest.js | 2 +- tests/unit/MiddlewareTest.js | 8 +- tests/unit/MigrationTest.js | 4 +- tests/unit/NetworkTest.js | 21 +- tests/unit/OptionsListUtilsTest.js | 6 +- tests/unit/ReportActionItemSingleTest.js | 2 +- tests/unit/ReportActionsUtilsTest.js | 4 +- tests/unit/ReportUtilsTest.js | 4 +- tests/unit/RequestTest.js | 2 +- tests/unit/SidebarFilterTest.js | 8 +- tests/unit/SidebarOrderTest.js | 10 +- tests/unit/SidebarTest.js | 8 +- tests/unit/ValidationUtilsTest.js | 2 +- tests/unit/enhanceParametersTest.js | 4 +- tests/unit/loginTest.js | 4 +- tests/utils/LHNTestUtils.js | 14 +- tests/utils/PusherHelper.js | 4 +- tests/utils/TestHelper.js | 6 +- tests/utils/bumpVersion.mjs | 1 - tests/utils/getPreviousVersion.mjs | 1 - tests/utils/getPullRequestsMergedBetween.mjs | 1 - tests/utils/waitForBatchedUpdates.js | 1 + wdyr.js | 3 +- 1087 files changed, 8303 insertions(+), 8335 deletions(-) diff --git a/.storybook/preview.js b/.storybook/preview.js index a989960794f2..a89c720976c9 100644 --- a/.storybook/preview.js +++ b/.storybook/preview.js @@ -1,16 +1,16 @@ +import {PortalProvider} from '@gorhom/portal'; import React from 'react'; import Onyx from 'react-native-onyx'; import {SafeAreaProvider} from 'react-native-safe-area-context'; -import {PortalProvider} from '@gorhom/portal'; -import './fonts.css'; import ComposeProviders from '../src/components/ComposeProviders'; import HTMLEngineProvider from '../src/components/HTMLEngineProvider'; -import OnyxProvider from '../src/components/OnyxProvider'; import {LocaleContextProvider} from '../src/components/LocaleContextProvider'; -import {KeyboardStateProvider} from '../src/components/withKeyboardState'; +import OnyxProvider from '../src/components/OnyxProvider'; import {EnvironmentProvider} from '../src/components/withEnvironment'; +import {KeyboardStateProvider} from '../src/components/withKeyboardState'; import {WindowDimensionsProvider} from '../src/components/withWindowDimensions'; import ONYXKEYS from '../src/ONYXKEYS'; +import './fonts.css'; Onyx.init({ keys: ONYXKEYS, diff --git a/assets/emojis/common.js b/assets/emojis/common.js index e8a8b15c2dd5..b7593b6e2960 100644 --- a/assets/emojis/common.js +++ b/assets/emojis/common.js @@ -1,11 +1,11 @@ import Smiley from '../images/emoji.svg'; -import AnimalsAndNature from '../images/emojiCategoryIcons/plant.svg'; +import Flags from '../images/emojiCategoryIcons/flag.svg'; import FoodAndDrink from '../images/emojiCategoryIcons/hamburger.svg'; -import TravelAndPlaces from '../images/emojiCategoryIcons/plane.svg'; -import Activities from '../images/emojiCategoryIcons/soccer-ball.svg'; import Objects from '../images/emojiCategoryIcons/light-bulb.svg'; import Symbols from '../images/emojiCategoryIcons/peace-sign.svg'; -import Flags from '../images/emojiCategoryIcons/flag.svg'; +import TravelAndPlaces from '../images/emojiCategoryIcons/plane.svg'; +import AnimalsAndNature from '../images/emojiCategoryIcons/plant.svg'; +import Activities from '../images/emojiCategoryIcons/soccer-ball.svg'; import FrequentlyUsed from '../images/history.svg'; const skinTones = [ diff --git a/index.js b/index.js index ac6b1e452a4b..2a3de088f934 100644 --- a/index.js +++ b/index.js @@ -1,9 +1,8 @@ /** * @format */ - -import {enableLegacyWebImplementation} from 'react-native-gesture-handler'; import {AppRegistry} from 'react-native'; +import {enableLegacyWebImplementation} from 'react-native-gesture-handler'; import App from './src/App'; import Config from './src/CONFIG'; import additionalAppSetup from './src/setup'; diff --git a/jest/setup.js b/jest/setup.js index a54a90678491..38b4b55a68b3 100644 --- a/jest/setup.js +++ b/jest/setup.js @@ -1,8 +1,8 @@ -import 'setimmediate'; -import 'react-native-gesture-handler/jestSetup'; +import mockClipboard from '@react-native-clipboard/clipboard/jest/clipboard-mock'; import '@shopify/flash-list/jestSetup'; +import 'react-native-gesture-handler/jestSetup'; import * as reanimatedJestUtils from 'react-native-reanimated/src/reanimated2/jestUtils'; -import mockClipboard from '@react-native-clipboard/clipboard/jest/clipboard-mock'; +import 'setimmediate'; import setupMockImages from './setupMockImages'; setupMockImages(); diff --git a/src/App.js b/src/App.js index 27e8105c2189..bff766c1235f 100644 --- a/src/App.js +++ b/src/App.js @@ -1,32 +1,32 @@ -import '../wdyr'; +import {PortalProvider} from '@gorhom/portal'; import React from 'react'; import {LogBox} from 'react-native'; import {GestureHandlerRootView} from 'react-native-gesture-handler'; -import {SafeAreaProvider} from 'react-native-safe-area-context'; import Onyx from 'react-native-onyx'; -import {PortalProvider} from '@gorhom/portal'; import {PickerStateProvider} from 'react-native-picker-select'; +import {SafeAreaProvider} from 'react-native-safe-area-context'; +import '../wdyr'; +import ComposeProviders from './components/ComposeProviders'; import CustomStatusBar from './components/CustomStatusBar'; import ErrorBoundary from './components/ErrorBoundary'; -import Expensify from './Expensify'; +import HTMLEngineProvider from './components/HTMLEngineProvider'; import {LocaleContextProvider} from './components/LocaleContextProvider'; import OnyxProvider from './components/OnyxProvider'; -import HTMLEngineProvider from './components/HTMLEngineProvider'; import PopoverContextProvider from './components/PopoverProvider'; -import ComposeProviders from './components/ComposeProviders'; import SafeArea from './components/SafeArea'; -import * as Environment from './libs/Environment/Environment'; -import {WindowDimensionsProvider} from './components/withWindowDimensions'; -import {KeyboardStateProvider} from './components/withKeyboardState'; -import ThemeProvider from './styles/themes/ThemeProvider'; -import ThemeStylesProvider from './styles/ThemeStylesProvider'; import {CurrentReportIDContextProvider} from './components/withCurrentReportID'; import {EnvironmentProvider} from './components/withEnvironment'; -import {ReportAttachmentsProvider} from './pages/home/report/ReportAttachmentsContext'; -import * as Session from './libs/actions/Session'; +import {KeyboardStateProvider} from './components/withKeyboardState'; +import {WindowDimensionsProvider} from './components/withWindowDimensions'; +import Expensify from './Expensify'; import useDefaultDragAndDrop from './hooks/useDefaultDragAndDrop'; import OnyxUpdateManager from './libs/actions/OnyxUpdateManager'; +import * as Session from './libs/actions/Session'; +import * as Environment from './libs/Environment/Environment'; +import {ReportAttachmentsProvider} from './pages/home/report/ReportAttachmentsContext'; import {SidebarNavigationContextProvider} from './pages/home/sidebar/SidebarNavigationContext'; +import ThemeProvider from './styles/themes/ThemeProvider'; +import ThemeStylesProvider from './styles/ThemeStylesProvider'; // For easier debugging and development, when we are in web we expose Onyx to the window, so you can more easily set data into Onyx if (window && Environment.isDevelopment()) { diff --git a/src/CONFIG.ts b/src/CONFIG.ts index 8b1dab5b3d71..61e347671269 100644 --- a/src/CONFIG.ts +++ b/src/CONFIG.ts @@ -1,8 +1,8 @@ import {Platform} from 'react-native'; import Config, {NativeConfig} from 'react-native-config'; +import CONST from './CONST'; import getPlatform from './libs/getPlatform'; import * as Url from './libs/Url'; -import CONST from './CONST'; // react-native-config doesn't trim whitespace on iOS for some reason so we // add a trim() call to prevent headaches diff --git a/src/Expensify.js b/src/Expensify.js index 6010824cf275..b7e3f0f60567 100644 --- a/src/Expensify.js +++ b/src/Expensify.js @@ -1,42 +1,41 @@ -import _ from 'underscore'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import React, {useCallback, useState, useEffect, useRef, useLayoutEffect, useMemo} from 'react'; +import React, {useCallback, useEffect, useLayoutEffect, useMemo, useRef, useState} from 'react'; import {AppState, Linking} from 'react-native'; import Onyx, {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import ConfirmModal from './components/ConfirmModal'; +import DeeplinkWrapper from './components/DeeplinkWrapper'; +import EmojiPicker from './components/EmojiPicker/EmojiPicker'; +import GrowlNotification from './components/GrowlNotification'; +import AppleAuthWrapper from './components/SignInButtons/AppleAuthWrapper'; +import SplashScreenHider from './components/SplashScreenHider'; +import UpdateAppModal from './components/UpdateAppModal'; +import withLocalize, {withLocalizePropTypes} from './components/withLocalize'; +import * as DemoActions from './libs/actions/DemoActions'; +import * as EmojiPickerAction from './libs/actions/EmojiPickerAction'; import * as Report from './libs/actions/Report'; -import BootSplash from './libs/BootSplash'; +import * as User from './libs/actions/User'; import * as ActiveClientManager from './libs/ActiveClientManager'; -import ONYXKEYS from './ONYXKEYS'; -import NavigationRoot from './libs/Navigation/NavigationRoot'; -import migrateOnyx from './libs/migrateOnyx'; -import PushNotification from './libs/Notification/PushNotification'; -import UpdateAppModal from './components/UpdateAppModal'; -import Visibility from './libs/Visibility'; -import GrowlNotification from './components/GrowlNotification'; +import BootSplash from './libs/BootSplash'; +import compose from './libs/compose'; import * as Growl from './libs/Growl'; -import StartupTimer from './libs/StartupTimer'; import Log from './libs/Log'; -import ConfirmModal from './components/ConfirmModal'; -import compose from './libs/compose'; -import withLocalize, {withLocalizePropTypes} from './components/withLocalize'; -import * as User from './libs/actions/User'; -import NetworkConnection from './libs/NetworkConnection'; +import migrateOnyx from './libs/migrateOnyx'; import Navigation from './libs/Navigation/Navigation'; -import PopoverReportActionContextMenu from './pages/home/report/ContextMenu/PopoverReportActionContextMenu'; -import * as ReportActionContextMenu from './pages/home/report/ContextMenu/ReportActionContextMenu'; -import SplashScreenHider from './components/SplashScreenHider'; -import AppleAuthWrapper from './components/SignInButtons/AppleAuthWrapper'; -import EmojiPicker from './components/EmojiPicker/EmojiPicker'; -import * as EmojiPickerAction from './libs/actions/EmojiPickerAction'; -import * as DemoActions from './libs/actions/DemoActions'; -import DeeplinkWrapper from './components/DeeplinkWrapper'; - +import NavigationRoot from './libs/Navigation/NavigationRoot'; +import NetworkConnection from './libs/NetworkConnection'; +import PushNotification from './libs/Notification/PushNotification'; +// eslint-disable-next-line no-unused-vars +import subscribePushNotification from './libs/Notification/PushNotification/subscribePushNotification'; +import StartupTimer from './libs/StartupTimer'; // This lib needs to be imported, but it has nothing to export since all it contains is an Onyx connection // eslint-disable-next-line no-unused-vars import UnreadIndicatorUpdater from './libs/UnreadIndicatorUpdater'; -// eslint-disable-next-line no-unused-vars -import subscribePushNotification from './libs/Notification/PushNotification/subscribePushNotification'; +import Visibility from './libs/Visibility'; +import ONYXKEYS from './ONYXKEYS'; +import PopoverReportActionContextMenu from './pages/home/report/ContextMenu/PopoverReportActionContextMenu'; +import * as ReportActionContextMenu from './pages/home/report/ContextMenu/ReportActionContextMenu'; Onyx.registerLogger(({level, message}) => { if (level === 'alert') { diff --git a/src/ONYXKEYS.ts b/src/ONYXKEYS.ts index 0f80359ddf30..9cd43badac6b 100755 --- a/src/ONYXKEYS.ts +++ b/src/ONYXKEYS.ts @@ -1,8 +1,8 @@ -import {ValueOf} from 'type-fest'; import {OnyxEntry} from 'react-native-onyx/lib/types'; -import DeepValueOf from './types/utils/DeepValueOf'; -import * as OnyxTypes from './types/onyx'; +import {ValueOf} from 'type-fest'; import CONST from './CONST'; +import * as OnyxTypes from './types/onyx'; +import DeepValueOf from './types/utils/DeepValueOf'; /** * This is a file containing constants for all the top level keys in our store diff --git a/src/components/AddPaymentMethodMenu.js b/src/components/AddPaymentMethodMenu.js index 2c3af95a3fad..252c8380b062 100644 --- a/src/components/AddPaymentMethodMenu.js +++ b/src/components/AddPaymentMethodMenu.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import compose from '@libs/compose'; +import Permissions from '@libs/Permissions'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as Expensicons from './Icon/Expensicons'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import compose from '../libs/compose'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import withWindowDimensions from './withWindowDimensions'; -import Permissions from '../libs/Permissions'; import PopoverMenu from './PopoverMenu'; import refPropTypes from './refPropTypes'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import withWindowDimensions from './withWindowDimensions'; const propTypes = { /** Should the component be visible? */ diff --git a/src/components/AddPlaidBankAccount.js b/src/components/AddPlaidBankAccount.js index 246514f3420a..f9667807106b 100644 --- a/src/components/AddPlaidBankAccount.js +++ b/src/components/AddPlaidBankAccount.js @@ -1,26 +1,26 @@ -import _ from 'underscore'; -import React, {useEffect, useRef, useCallback} from 'react'; -import {ActivityIndicator, View} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef} from 'react'; +import {ActivityIndicator, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import Log from '../libs/Log'; -import PlaidLink from './PlaidLink'; -import * as App from '../libs/actions/App'; -import * as BankAccounts from '../libs/actions/BankAccounts'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import Log from '@libs/Log'; +import {plaidDataPropTypes} from '@pages/ReimbursementAccount/plaidDataPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as App from '@userActions/App'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import FullPageOfflineBlockingView from './BlockingViews/FullPageOfflineBlockingView'; +import Icon from './Icon'; +import getBankIcon from './Icon/BankIcons'; import Picker from './Picker'; -import {plaidDataPropTypes} from '../pages/ReimbursementAccount/plaidDataPropTypes'; +import PlaidLink from './PlaidLink'; import Text from './Text'; -import getBankIcon from './Icon/BankIcons'; -import Icon from './Icon'; -import FullPageOfflineBlockingView from './BlockingViews/FullPageOfflineBlockingView'; -import CONST from '../CONST'; -import KeyboardShortcut from '../libs/KeyboardShortcut'; -import useLocalize from '../hooks/useLocalize'; -import useNetwork from '../hooks/useNetwork'; const propTypes = { /** If the user has been throttled from Plaid */ diff --git a/src/components/AddressSearch/CurrentLocationButton.js b/src/components/AddressSearch/CurrentLocationButton.js index 893ec031ab7f..326b82d31e8f 100644 --- a/src/components/AddressSearch/CurrentLocationButton.js +++ b/src/components/AddressSearch/CurrentLocationButton.js @@ -1,14 +1,14 @@ import PropTypes from 'prop-types'; import React from 'react'; import {Text} from 'react-native'; -import colors from '../../styles/colors'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import PressableWithFeedback from '../Pressable/PressableWithFeedback'; -import getButtonState from '../../libs/getButtonState'; -import * as StyleUtils from '../../styles/StyleUtils'; -import useLocalize from '../../hooks/useLocalize'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import useLocalize from '@hooks/useLocalize'; +import getButtonState from '@libs/getButtonState'; +import colors from '@styles/colors'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; const propTypes = { /** Callback that runs when location button is clicked */ diff --git a/src/components/AddressSearch/index.js b/src/components/AddressSearch/index.js index 28c61076332a..3e122e029969 100644 --- a/src/components/AddressSearch/index.js +++ b/src/components/AddressSearch/index.js @@ -1,26 +1,26 @@ -import _ from 'underscore'; -import React, {useEffect, useMemo, useRef, useState} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import {Keyboard, LogBox, ScrollView, View, Text, ActivityIndicator} from 'react-native'; +import React, {useEffect, useMemo, useRef, useState} from 'react'; +import {ActivityIndicator, Keyboard, LogBox, ScrollView, Text, View} from 'react-native'; import {GooglePlacesAutocomplete} from 'react-native-google-places-autocomplete'; -import lodashGet from 'lodash/get'; -import compose from '../../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import TextInput from '../TextInput'; -import * as ApiUtils from '../../libs/ApiUtils'; -import * as GooglePlacesUtils from '../../libs/GooglePlacesUtils'; -import getCurrentPosition from '../../libs/getCurrentPosition'; -import CONST from '../../CONST'; -import * as StyleUtils from '../../styles/StyleUtils'; -import isCurrentTargetInsideContainer from './isCurrentTargetInsideContainer'; -import variables from '../../styles/variables'; -import FullScreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import LocationErrorMessage from '../LocationErrorMessage'; -import {withNetwork} from '../OnyxProvider'; -import networkPropTypes from '../networkPropTypes'; +import _ from 'underscore'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import LocationErrorMessage from '@components/LocationErrorMessage'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import * as ApiUtils from '@libs/ApiUtils'; +import compose from '@libs/compose'; +import getCurrentPosition from '@libs/getCurrentPosition'; +import * as GooglePlacesUtils from '@libs/GooglePlacesUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import CurrentLocationButton from './CurrentLocationButton'; +import isCurrentTargetInsideContainer from './isCurrentTargetInsideContainer'; // The error that's being thrown below will be ignored until we fork the // react-native-google-places-autocomplete repo and replace the diff --git a/src/components/AmountTextInput.js b/src/components/AmountTextInput.js index d110fe39cd6c..5899e68bedb3 100644 --- a/src/components/AmountTextInput.js +++ b/src/components/AmountTextInput.js @@ -1,9 +1,9 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import TextInput from './TextInput'; -import styles from '../styles/styles'; -import CONST from '../CONST'; +import React from 'react'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import refPropTypes from './refPropTypes'; +import TextInput from './TextInput'; const propTypes = { /** Formatted amount in local currency */ diff --git a/src/components/AnchorForAttachmentsOnly/BaseAnchorForAttachmentsOnly.js b/src/components/AnchorForAttachmentsOnly/BaseAnchorForAttachmentsOnly.js index 46576bc62e7a..fd6c3d358a33 100644 --- a/src/components/AnchorForAttachmentsOnly/BaseAnchorForAttachmentsOnly.js +++ b/src/components/AnchorForAttachmentsOnly/BaseAnchorForAttachmentsOnly.js @@ -1,16 +1,16 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import {propTypes as anchorForAttachmentsOnlyPropTypes, defaultProps as anchorForAttachmentsOnlyDefaultProps} from './anchorForAttachmentsOnlyPropTypes'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import AttachmentView from '../Attachments/AttachmentView'; -import * as Download from '../../libs/actions/Download'; -import fileDownload from '../../libs/fileDownload'; -import addEncryptedAuthTokenToURL from '../../libs/addEncryptedAuthTokenToURL'; -import {ShowContextMenuContext, showContextMenuForReport} from '../ShowContextMenuContext'; -import * as ReportUtils from '../../libs/ReportUtils'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; +import AttachmentView from '@components/Attachments/AttachmentView'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import {ShowContextMenuContext, showContextMenuForReport} from '@components/ShowContextMenuContext'; +import addEncryptedAuthTokenToURL from '@libs/addEncryptedAuthTokenToURL'; +import fileDownload from '@libs/fileDownload'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as Download from '@userActions/Download'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps as anchorForAttachmentsOnlyDefaultProps, propTypes as anchorForAttachmentsOnlyPropTypes} from './anchorForAttachmentsOnlyPropTypes'; const propTypes = { /** Press in handler for the link */ diff --git a/src/components/AnchorForAttachmentsOnly/anchorForAttachmentsOnlyPropTypes.js b/src/components/AnchorForAttachmentsOnly/anchorForAttachmentsOnlyPropTypes.js index a17f0a27ce4d..9452e615d31c 100644 --- a/src/components/AnchorForAttachmentsOnly/anchorForAttachmentsOnlyPropTypes.js +++ b/src/components/AnchorForAttachmentsOnly/anchorForAttachmentsOnlyPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import stylePropTypes from '../../styles/stylePropTypes'; +import stylePropTypes from '@styles/stylePropTypes'; const propTypes = { /** The URL of the attachment */ diff --git a/src/components/AnchorForAttachmentsOnly/index.js b/src/components/AnchorForAttachmentsOnly/index.js index 1a58aa4b3ae1..1dae62e771ef 100644 --- a/src/components/AnchorForAttachmentsOnly/index.js +++ b/src/components/AnchorForAttachmentsOnly/index.js @@ -1,8 +1,8 @@ import React from 'react'; +import ControlSelection from '@libs/ControlSelection'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import * as anchorForAttachmentsOnlyPropTypes from './anchorForAttachmentsOnlyPropTypes'; import BaseAnchorForAttachmentsOnly from './BaseAnchorForAttachmentsOnly'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; -import ControlSelection from '../../libs/ControlSelection'; function AnchorForAttachmentsOnly(props) { return ( diff --git a/src/components/AnchorForAttachmentsOnly/index.native.js b/src/components/AnchorForAttachmentsOnly/index.native.js index f27aad641186..91e1b864544d 100644 --- a/src/components/AnchorForAttachmentsOnly/index.native.js +++ b/src/components/AnchorForAttachmentsOnly/index.native.js @@ -1,7 +1,7 @@ import React from 'react'; +import styles from '@styles/styles'; import * as anchorForAttachmentsOnlyPropTypes from './anchorForAttachmentsOnlyPropTypes'; import BaseAnchorForAttachmentsOnly from './BaseAnchorForAttachmentsOnly'; -import styles from '../../styles/styles'; function AnchorForAttachmentsOnly(props) { return ( diff --git a/src/components/AnchorForCommentsOnly/BaseAnchorForCommentsOnly.js b/src/components/AnchorForCommentsOnly/BaseAnchorForCommentsOnly.js index 9cfe9d893d8e..d79faf4dee9c 100644 --- a/src/components/AnchorForCommentsOnly/BaseAnchorForCommentsOnly.js +++ b/src/components/AnchorForCommentsOnly/BaseAnchorForCommentsOnly.js @@ -1,20 +1,20 @@ -import _ from 'underscore'; +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; import {StyleSheet} from 'react-native'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; -import Text from '../Text'; -import PressableWithSecondaryInteraction from '../PressableWithSecondaryInteraction'; -import * as ReportActionContextMenu from '../../pages/home/report/ContextMenu/ReportActionContextMenu'; -import * as ContextMenuActions from '../../pages/home/report/ContextMenu/ContextMenuActions'; -import Tooltip from '../Tooltip'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; +import _ from 'underscore'; +import PressableWithSecondaryInteraction from '@components/PressableWithSecondaryInteraction'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as ContextMenuActions from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import {propTypes as anchorForCommentsOnlyPropTypes} from './anchorForCommentsOnlyPropTypes'; -import CONST from '../../CONST'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; const propTypes = { /** Press in handler for the link */ diff --git a/src/components/AnchorForCommentsOnly/anchorForCommentsOnlyPropTypes.js b/src/components/AnchorForCommentsOnly/anchorForCommentsOnlyPropTypes.js index 10b5a40c853d..6bf1d094497d 100644 --- a/src/components/AnchorForCommentsOnly/anchorForCommentsOnlyPropTypes.js +++ b/src/components/AnchorForCommentsOnly/anchorForCommentsOnlyPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import stylePropTypes from '../../styles/stylePropTypes'; +import stylePropTypes from '@styles/stylePropTypes'; const propTypes = { /** The URL to open */ diff --git a/src/components/AnchorForCommentsOnly/index.js b/src/components/AnchorForCommentsOnly/index.js index 6c72621deeea..24a903dca5fa 100644 --- a/src/components/AnchorForCommentsOnly/index.js +++ b/src/components/AnchorForCommentsOnly/index.js @@ -1,8 +1,8 @@ import React from 'react'; +import ControlSelection from '@libs/ControlSelection'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import * as anchorForCommentsOnlyPropTypes from './anchorForCommentsOnlyPropTypes'; import BaseAnchorForCommentsOnly from './BaseAnchorForCommentsOnly'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; -import ControlSelection from '../../libs/ControlSelection'; function AnchorForCommentsOnly(props) { return ( diff --git a/src/components/AnchorForCommentsOnly/index.native.js b/src/components/AnchorForCommentsOnly/index.native.js index 69211b75e855..b9dc74b7ba05 100644 --- a/src/components/AnchorForCommentsOnly/index.native.js +++ b/src/components/AnchorForCommentsOnly/index.native.js @@ -1,7 +1,6 @@ import React from 'react'; import {Linking} from 'react-native'; import _ from 'underscore'; - import * as anchorForCommentsOnlyPropTypes from './anchorForCommentsOnlyPropTypes'; import BaseAnchorForCommentsOnly from './BaseAnchorForCommentsOnly'; diff --git a/src/components/AnimatedStep/AnimatedStepProvider.js b/src/components/AnimatedStep/AnimatedStepProvider.js index 86d40b5bddeb..eb4797655344 100644 --- a/src/components/AnimatedStep/AnimatedStepProvider.js +++ b/src/components/AnimatedStep/AnimatedStepProvider.js @@ -1,7 +1,7 @@ -import React, {useMemo, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useMemo, useState} from 'react'; +import CONST from '@src/CONST'; import AnimatedStepContext from './AnimatedStepContext'; -import CONST from '../../CONST'; const propTypes = { children: PropTypes.node.isRequired, diff --git a/src/components/AnimatedStep/index.js b/src/components/AnimatedStep/index.js index 5b0dc8bc78fa..e916cbe1b84c 100644 --- a/src/components/AnimatedStep/index.js +++ b/src/components/AnimatedStep/index.js @@ -1,9 +1,9 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import * as Animatable from 'react-native-animatable'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import useNativeDriver from '../../libs/useNativeDriver'; +import useNativeDriver from '@libs/useNativeDriver'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Children to wrap in AnimatedStep. */ diff --git a/src/components/AnonymousReportFooter.js b/src/components/AnonymousReportFooter.js index 43933210dc0b..2dc4159d1627 100644 --- a/src/components/AnonymousReportFooter.js +++ b/src/components/AnonymousReportFooter.js @@ -1,14 +1,14 @@ -import React from 'react'; -import {View, Text} from 'react-native'; import PropTypes from 'prop-types'; -import Button from './Button'; +import React from 'react'; +import {Text, View} from 'react-native'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; import AvatarWithDisplayName from './AvatarWithDisplayName'; +import Button from './Button'; import ExpensifyWordmark from './ExpensifyWordmark'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import reportPropTypes from '../pages/reportPropTypes'; -import styles from '../styles/styles'; -import * as Session from '../libs/actions/Session'; import participantPropTypes from './participantPropTypes'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** The report currently being looked at */ diff --git a/src/components/ArchivedReportFooter.js b/src/components/ArchivedReportFooter.js index 71d331b68db0..52484355a242 100644 --- a/src/components/ArchivedReportFooter.js +++ b/src/components/ArchivedReportFooter.js @@ -1,19 +1,19 @@ +import _ from 'lodash'; import lodashGet from 'lodash/get'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import _ from 'lodash'; -import CONST from '../CONST'; +import compose from '@libs/compose'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Banner from './Banner'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import compose from '../libs/compose'; -import personalDetailsPropType from '../pages/personalDetailsPropType'; -import ONYXKEYS from '../ONYXKEYS'; -import * as ReportUtils from '../libs/ReportUtils'; -import reportPropTypes from '../pages/reportPropTypes'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; -import styles from '../styles/styles'; -import * as PersonalDetailsUtils from '../libs/PersonalDetailsUtils'; const propTypes = { /** The reason this report was archived */ diff --git a/src/components/ArrowKeyFocusManager.js b/src/components/ArrowKeyFocusManager.js index b8c726e75af6..19dc3a7ac614 100644 --- a/src/components/ArrowKeyFocusManager.js +++ b/src/components/ArrowKeyFocusManager.js @@ -1,7 +1,7 @@ -import {Component} from 'react'; import PropTypes from 'prop-types'; -import CONST from '../CONST'; -import KeyboardShortcut from '../libs/KeyboardShortcut'; +import {Component} from 'react'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import CONST from '@src/CONST'; const propTypes = { /** Children to render. */ diff --git a/src/components/AttachmentModal.js b/src/components/AttachmentModal.js index f8c4122dddb0..8231dd7c4fe2 100755 --- a/src/components/AttachmentModal.js +++ b/src/components/AttachmentModal.js @@ -1,44 +1,44 @@ -import React, {useState, useCallback, useRef, useMemo, useEffect} from 'react'; -import PropTypes from 'prop-types'; -import {View, Animated, Keyboard} from 'react-native'; import Str from 'expensify-common/lib/str'; -import lodashGet from 'lodash/get'; import lodashExtend from 'lodash/extend'; -import _ from 'underscore'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {Animated, Keyboard, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../CONST'; -import Modal from './Modal'; -import AttachmentView from './Attachments/AttachmentView'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import addEncryptedAuthTokenToURL from '@libs/addEncryptedAuthTokenToURL'; +import compose from '@libs/compose'; +import fileDownload from '@libs/fileDownload'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import useNativeDriver from '@libs/useNativeDriver'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import * as IOU from '@userActions/IOU'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import AttachmentCarousel from './Attachments/AttachmentCarousel'; -import useLocalize from '../hooks/useLocalize'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import * as FileUtils from '../libs/fileDownload/FileUtils'; -import themeColors from '../styles/themes/default'; -import compose from '../libs/compose'; -import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; +import AttachmentView from './Attachments/AttachmentView'; import Button from './Button'; -import HeaderWithBackButton from './HeaderWithBackButton'; -import fileDownload from '../libs/fileDownload'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; import ConfirmModal from './ConfirmModal'; import HeaderGap from './HeaderGap'; -import SafeAreaConsumer from './SafeAreaConsumer'; -import addEncryptedAuthTokenToURL from '../libs/addEncryptedAuthTokenToURL'; -import reportPropTypes from '../pages/reportPropTypes'; +import HeaderWithBackButton from './HeaderWithBackButton'; import * as Expensicons from './Icon/Expensicons'; -import useWindowDimensions from '../hooks/useWindowDimensions'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import useNativeDriver from '../libs/useNativeDriver'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; -import * as ReportUtils from '../libs/ReportUtils'; -import ONYXKEYS from '../ONYXKEYS'; -import * as Policy from '../libs/actions/Policy'; -import useNetwork from '../hooks/useNetwork'; -import * as IOU from '../libs/actions/IOU'; +import Modal from './Modal'; +import SafeAreaConsumer from './SafeAreaConsumer'; import transactionPropTypes from './transactionPropTypes'; -import * as TransactionUtils from '../libs/TransactionUtils'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; /** * Modal render prop component that exposes modal launching triggers that can be used diff --git a/src/components/AttachmentPicker/attachmentPickerPropTypes.js b/src/components/AttachmentPicker/attachmentPickerPropTypes.js index 3b6fb7d041c5..a3a346f5ea27 100644 --- a/src/components/AttachmentPicker/attachmentPickerPropTypes.js +++ b/src/components/AttachmentPicker/attachmentPickerPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; const propTypes = { /** diff --git a/src/components/AttachmentPicker/index.js b/src/components/AttachmentPicker/index.js index 9930fa49a909..24024eae6515 100644 --- a/src/components/AttachmentPicker/index.js +++ b/src/components/AttachmentPicker/index.js @@ -1,7 +1,7 @@ import React, {useRef} from 'react'; -import CONST from '../../CONST'; -import {propTypes, defaultProps} from './attachmentPickerPropTypes'; -import Visibility from '../../libs/Visibility'; +import Visibility from '@libs/Visibility'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes} from './attachmentPickerPropTypes'; /** * Returns acceptable FileTypes based on ATTACHMENT_PICKER_TYPE diff --git a/src/components/AttachmentPicker/index.native.js b/src/components/AttachmentPicker/index.native.js index 063314a4268c..0e723d4cf048 100644 --- a/src/components/AttachmentPicker/index.native.js +++ b/src/components/AttachmentPicker/index.native.js @@ -1,23 +1,23 @@ -import _ from 'underscore'; -import React, {useState, useRef, useCallback, useMemo} from 'react'; +import lodashCompact from 'lodash/compact'; import PropTypes from 'prop-types'; -import {View, Alert} from 'react-native'; -import RNDocumentPicker from 'react-native-document-picker'; +import React, {useCallback, useMemo, useRef, useState} from 'react'; +import {Alert, View} from 'react-native'; import RNFetchBlob from 'react-native-blob-util'; -import lodashCompact from 'lodash/compact'; +import RNDocumentPicker from 'react-native-document-picker'; import {launchImageLibrary} from 'react-native-image-picker'; -import {propTypes as basePropTypes, defaultProps as baseDefaultProps} from './attachmentPickerPropTypes'; -import CONST from '../../CONST'; -import * as FileUtils from '../../libs/fileDownload/FileUtils'; -import * as Expensicons from '../Icon/Expensicons'; +import _ from 'underscore'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import Popover from '@components/Popover'; +import useArrowKeyFocusManager from '@hooks/useArrowKeyFocusManager'; +import useKeyboardShortcut from '@hooks/useKeyboardShortcut'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import {defaultProps as baseDefaultProps, propTypes as basePropTypes} from './attachmentPickerPropTypes'; import launchCamera from './launchCamera'; -import Popover from '../Popover'; -import MenuItem from '../MenuItem'; -import styles from '../../styles/styles'; -import useLocalize from '../../hooks/useLocalize'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import useKeyboardShortcut from '../../hooks/useKeyboardShortcut'; -import useArrowKeyFocusManager from '../../hooks/useArrowKeyFocusManager'; const propTypes = { ...basePropTypes, diff --git a/src/components/AttachmentPicker/launchCamera.ios.js b/src/components/AttachmentPicker/launchCamera.ios.js index 7ac3708c5dd3..d6e3518d7188 100644 --- a/src/components/AttachmentPicker/launchCamera.ios.js +++ b/src/components/AttachmentPicker/launchCamera.ios.js @@ -1,5 +1,5 @@ -import {PERMISSIONS, request, RESULTS} from 'react-native-permissions'; import {launchCamera} from 'react-native-image-picker'; +import {PERMISSIONS, request, RESULTS} from 'react-native-permissions'; /** * Launching the camera for iOS involves checking for permissions diff --git a/src/components/Attachments/AttachmentCarousel/AttachmentCarouselCellRenderer.js b/src/components/Attachments/AttachmentCarousel/AttachmentCarouselCellRenderer.js index 2c698d5c8a61..673bb7c224e2 100644 --- a/src/components/Attachments/AttachmentCarousel/AttachmentCarouselCellRenderer.js +++ b/src/components/Attachments/AttachmentCarousel/AttachmentCarouselCellRenderer.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import {View, PixelRatio} from 'react-native'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import styles from '../../../styles/styles'; +import React from 'react'; +import {PixelRatio, View} from 'react-native'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import styles from '@styles/styles'; const propTypes = { /** Cell Container styles */ diff --git a/src/components/Attachments/AttachmentCarousel/CarouselActions.js b/src/components/Attachments/AttachmentCarousel/CarouselActions.js index 8861039b8501..cf5309222c4e 100644 --- a/src/components/Attachments/AttachmentCarousel/CarouselActions.js +++ b/src/components/Attachments/AttachmentCarousel/CarouselActions.js @@ -1,8 +1,8 @@ -import {useEffect} from 'react'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import KeyboardShortcut from '../../../libs/KeyboardShortcut'; -import CONST from '../../../CONST'; +import {useEffect} from 'react'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import CONST from '@src/CONST'; const propTypes = { /** Callback to cycle through attachments */ diff --git a/src/components/Attachments/AttachmentCarousel/CarouselButtons.js b/src/components/Attachments/AttachmentCarousel/CarouselButtons.js index d33659fd04ae..9bef889e61a1 100644 --- a/src/components/Attachments/AttachmentCarousel/CarouselButtons.js +++ b/src/components/Attachments/AttachmentCarousel/CarouselButtons.js @@ -1,15 +1,15 @@ import PropTypes from 'prop-types'; import React from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import * as Expensicons from '../../Icon/Expensicons'; -import Tooltip from '../../Tooltip'; -import Button from '../../Button'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; -import * as AttachmentCarouselViewPropTypes from '../propTypes'; -import useLocalize from '../../../hooks/useLocalize'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; +import _ from 'underscore'; +import * as AttachmentCarouselViewPropTypes from '@components/Attachments/propTypes'; +import Button from '@components/Button'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; const propTypes = { /** Where the arrows should be visible */ diff --git a/src/components/Attachments/AttachmentCarousel/CarouselItem.js b/src/components/Attachments/AttachmentCarousel/CarouselItem.js index 2fe62a00b90f..2d271aa6d4c4 100644 --- a/src/components/Attachments/AttachmentCarousel/CarouselItem.js +++ b/src/components/Attachments/AttachmentCarousel/CarouselItem.js @@ -1,16 +1,16 @@ +import PropTypes from 'prop-types'; import React, {useContext, useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import CONST from '../../../CONST'; -import styles from '../../../styles/styles'; -import useLocalize from '../../../hooks/useLocalize'; -import PressableWithoutFeedback from '../../Pressable/PressableWithoutFeedback'; -import Text from '../../Text'; -import Button from '../../Button'; -import AttachmentView from '../AttachmentView'; -import SafeAreaConsumer from '../../SafeAreaConsumer'; -import ReportAttachmentsContext from '../../../pages/home/report/ReportAttachmentsContext'; -import * as AttachmentsPropTypes from '../propTypes'; +import AttachmentView from '@components/Attachments/AttachmentView'; +import * as AttachmentsPropTypes from '@components/Attachments/propTypes'; +import Button from '@components/Button'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import SafeAreaConsumer from '@components/SafeAreaConsumer'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import ReportAttachmentsContext from '@pages/home/report/ReportAttachmentsContext'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Attachment required information such as the source and file name */ diff --git a/src/components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPage.js b/src/components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPage.js index 580c7eaac732..2ded34829a08 100644 --- a/src/components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPage.js +++ b/src/components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPage.js @@ -1,12 +1,12 @@ /* eslint-disable es/no-optional-chaining */ +import PropTypes from 'prop-types'; import React, {useContext, useEffect, useRef, useState} from 'react'; import {ActivityIndicator, PixelRatio, StyleSheet, View} from 'react-native'; -import PropTypes from 'prop-types'; -import Image from '../../../Image'; +import * as AttachmentsPropTypes from '@components/Attachments/propTypes'; +import Image from '@components/Image'; import AttachmentCarouselPagerContext from './AttachmentCarouselPagerContext'; import ImageTransformer from './ImageTransformer'; import ImageWrapper from './ImageWrapper'; -import * as AttachmentsPropTypes from '../../propTypes'; function getCanvasFitScale({canvasWidth, canvasHeight, imageWidth, imageHeight}) { const imageScaleX = canvasWidth / imageWidth; diff --git a/src/components/Attachments/AttachmentCarousel/Pager/ImageTransformer.js b/src/components/Attachments/AttachmentCarousel/Pager/ImageTransformer.js index b1c2864a05f6..5bf8b79dae77 100644 --- a/src/components/Attachments/AttachmentCarousel/Pager/ImageTransformer.js +++ b/src/components/Attachments/AttachmentCarousel/Pager/ImageTransformer.js @@ -1,7 +1,7 @@ /* eslint-disable es/no-optional-chaining */ -import React, {useContext, useEffect, useRef, useState, useMemo} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useContext, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; import {Gesture, GestureDetector} from 'react-native-gesture-handler'; import Animated, { cancelAnimation, @@ -15,7 +15,7 @@ import Animated, { withDecay, withSpring, } from 'react-native-reanimated'; -import styles from '../../../../styles/styles'; +import styles from '@styles/styles'; import AttachmentCarouselPagerContext from './AttachmentCarouselPagerContext'; import ImageWrapper from './ImageWrapper'; diff --git a/src/components/Attachments/AttachmentCarousel/Pager/ImageWrapper.js b/src/components/Attachments/AttachmentCarousel/Pager/ImageWrapper.js index a6a935bbba01..10f2ae94340a 100644 --- a/src/components/Attachments/AttachmentCarousel/Pager/ImageWrapper.js +++ b/src/components/Attachments/AttachmentCarousel/Pager/ImageWrapper.js @@ -1,9 +1,9 @@ /* eslint-disable es/no-optional-chaining */ +import PropTypes from 'prop-types'; import React from 'react'; import {StyleSheet} from 'react-native'; -import PropTypes from 'prop-types'; import Animated from 'react-native-reanimated'; -import styles from '../../../../styles/styles'; +import styles from '@styles/styles'; const imageWrapperPropTypes = { children: PropTypes.node.isRequired, diff --git a/src/components/Attachments/AttachmentCarousel/Pager/index.js b/src/components/Attachments/AttachmentCarousel/Pager/index.js index e5feaedf63b7..e4659caf24f0 100644 --- a/src/components/Attachments/AttachmentCarousel/Pager/index.js +++ b/src/components/Attachments/AttachmentCarousel/Pager/index.js @@ -1,14 +1,14 @@ /* eslint-disable es/no-optional-chaining */ -import React, {useRef, useState, useImperativeHandle, useMemo} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; -import {GestureHandlerRootView, createNativeWrapper} from 'react-native-gesture-handler'; -import Animated, {runOnJS, useAnimatedProps, useAnimatedReaction, useEvent, useHandler, useSharedValue} from 'react-native-reanimated'; +import React, {useImperativeHandle, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; +import {createNativeWrapper, GestureHandlerRootView} from 'react-native-gesture-handler'; import PagerView from 'react-native-pager-view'; +import Animated, {runOnJS, useAnimatedProps, useAnimatedReaction, useEvent, useHandler, useSharedValue} from 'react-native-reanimated'; import _ from 'underscore'; -import styles from '../../../../styles/styles'; +import refPropTypes from '@components/refPropTypes'; +import styles from '@styles/styles'; import AttachmentCarouselPagerContext from './AttachmentCarouselPagerContext'; -import refPropTypes from '../../../refPropTypes'; const AnimatedPagerView = Animated.createAnimatedComponent(createNativeWrapper(PagerView)); diff --git a/src/components/Attachments/AttachmentCarousel/attachmentCarouselPropTypes.js b/src/components/Attachments/AttachmentCarousel/attachmentCarouselPropTypes.js index 81f22f684243..8048773de42c 100644 --- a/src/components/Attachments/AttachmentCarousel/attachmentCarouselPropTypes.js +++ b/src/components/Attachments/AttachmentCarousel/attachmentCarouselPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import reportPropTypes from '../../../pages/reportPropTypes'; -import reportActionPropTypes from '../../../pages/home/report/reportActionPropTypes'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import reportPropTypes from '@pages/reportPropTypes'; const propTypes = { /** source is used to determine the starting index in the array of attachments */ diff --git a/src/components/Attachments/AttachmentCarousel/extractAttachmentsFromReport.js b/src/components/Attachments/AttachmentCarousel/extractAttachmentsFromReport.js index 8420a9e7831b..6f0dd335c2bb 100644 --- a/src/components/Attachments/AttachmentCarousel/extractAttachmentsFromReport.js +++ b/src/components/Attachments/AttachmentCarousel/extractAttachmentsFromReport.js @@ -1,11 +1,11 @@ import {Parser as HtmlParser} from 'htmlparser2'; -import _ from 'underscore'; import lodashGet from 'lodash/get'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import * as TransactionUtils from '../../../libs/TransactionUtils'; -import * as ReceiptUtils from '../../../libs/ReceiptUtils'; -import CONST from '../../../CONST'; -import tryResolveUrlFromApiRoot from '../../../libs/tryResolveUrlFromApiRoot'; +import _ from 'underscore'; +import * as ReceiptUtils from '@libs/ReceiptUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import tryResolveUrlFromApiRoot from '@libs/tryResolveUrlFromApiRoot'; +import CONST from '@src/CONST'; /** * Constructs the initial component state from report actions diff --git a/src/components/Attachments/AttachmentCarousel/index.js b/src/components/Attachments/AttachmentCarousel/index.js index 131c57d4c345..99a23835fd97 100644 --- a/src/components/Attachments/AttachmentCarousel/index.js +++ b/src/components/Attachments/AttachmentCarousel/index.js @@ -1,25 +1,25 @@ -import React, {useRef, useCallback, useState, useEffect} from 'react'; -import {View, FlatList, PixelRatio, Keyboard} from 'react-native'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {FlatList, Keyboard, PixelRatio, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import styles from '../../../styles/styles'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import * as Illustrations from '@components/Icon/Illustrations'; +import withLocalize from '@components/withLocalize'; +import withWindowDimensions from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import ONYXKEYS from '@src/ONYXKEYS'; import AttachmentCarouselCellRenderer from './AttachmentCarouselCellRenderer'; +import {defaultProps, propTypes} from './attachmentCarouselPropTypes'; import CarouselActions from './CarouselActions'; -import withWindowDimensions from '../../withWindowDimensions'; import CarouselButtons from './CarouselButtons'; +import CarouselItem from './CarouselItem'; import extractAttachmentsFromReport from './extractAttachmentsFromReport'; -import {propTypes, defaultProps} from './attachmentCarouselPropTypes'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withLocalize from '../../withLocalize'; -import compose from '../../../libs/compose'; import useCarouselArrows from './useCarouselArrows'; -import CarouselItem from './CarouselItem'; -import Navigation from '../../../libs/Navigation/Navigation'; -import BlockingView from '../../BlockingViews/BlockingView'; -import * as Illustrations from '../../Icon/Illustrations'; -import variables from '../../../styles/variables'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; const viewabilityConfig = { // To facilitate paging through the attachments, we want to consider an item "viewable" when it is diff --git a/src/components/Attachments/AttachmentCarousel/index.native.js b/src/components/Attachments/AttachmentCarousel/index.native.js index bcea50698b3b..8c6957c9371a 100644 --- a/src/components/Attachments/AttachmentCarousel/index.native.js +++ b/src/components/Attachments/AttachmentCarousel/index.native.js @@ -1,22 +1,22 @@ import React, {useCallback, useEffect, useRef, useState} from 'react'; -import {View, Keyboard, PixelRatio} from 'react-native'; +import {Keyboard, PixelRatio, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import AttachmentCarouselPager from './Pager'; -import styles from '../../../styles/styles'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import * as Illustrations from '@components/Icon/Illustrations'; +import withLocalize from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './attachmentCarouselPropTypes'; import CarouselButtons from './CarouselButtons'; -import ONYXKEYS from '../../../ONYXKEYS'; -import {propTypes, defaultProps} from './attachmentCarouselPropTypes'; +import CarouselItem from './CarouselItem'; import extractAttachmentsFromReport from './extractAttachmentsFromReport'; +import AttachmentCarouselPager from './Pager'; import useCarouselArrows from './useCarouselArrows'; -import CarouselItem from './CarouselItem'; -import Navigation from '../../../libs/Navigation/Navigation'; -import BlockingView from '../../BlockingViews/BlockingView'; -import * as Illustrations from '../../Icon/Illustrations'; -import variables from '../../../styles/variables'; -import compose from '../../../libs/compose'; -import withLocalize from '../../withLocalize'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; function AttachmentCarousel({report, reportActions, source, onNavigate, onClose, setDownloadButtonVisibility, translate}) { const pagerRef = useRef(null); diff --git a/src/components/Attachments/AttachmentCarousel/useCarouselArrows.js b/src/components/Attachments/AttachmentCarousel/useCarouselArrows.js index 64c97fa99819..0c55c3ae519d 100644 --- a/src/components/Attachments/AttachmentCarousel/useCarouselArrows.js +++ b/src/components/Attachments/AttachmentCarousel/useCarouselArrows.js @@ -1,6 +1,6 @@ import {useCallback, useEffect, useRef, useState} from 'react'; -import CONST from '../../../CONST'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import CONST from '@src/CONST'; function useCarouselArrows() { const canUseTouchScreen = DeviceCapabilities.canUseTouchScreen(); diff --git a/src/components/Attachments/AttachmentView/AttachmentViewImage/index.js b/src/components/Attachments/AttachmentView/AttachmentViewImage/index.js index 48ac954ced7f..23049915a8d9 100755 --- a/src/components/Attachments/AttachmentView/AttachmentViewImage/index.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewImage/index.js @@ -1,11 +1,11 @@ import React, {memo} from 'react'; -import styles from '../../../../styles/styles'; -import ImageView from '../../../ImageView'; -import withLocalize, {withLocalizePropTypes} from '../../../withLocalize'; -import compose from '../../../../libs/compose'; -import PressableWithoutFeedback from '../../../Pressable/PressableWithoutFeedback'; -import CONST from '../../../../CONST'; -import {attachmentViewImagePropTypes, attachmentViewImageDefaultProps} from './propTypes'; +import ImageView from '@components/ImageView'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import {attachmentViewImageDefaultProps, attachmentViewImagePropTypes} from './propTypes'; const propTypes = { ...attachmentViewImagePropTypes, diff --git a/src/components/Attachments/AttachmentView/AttachmentViewImage/index.native.js b/src/components/Attachments/AttachmentView/AttachmentViewImage/index.native.js index 7334e5391bc1..faf2f21c133d 100755 --- a/src/components/Attachments/AttachmentView/AttachmentViewImage/index.native.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewImage/index.native.js @@ -1,12 +1,12 @@ import React, {memo} from 'react'; -import styles from '../../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../withLocalize'; -import ImageView from '../../../ImageView'; -import compose from '../../../../libs/compose'; -import PressableWithoutFeedback from '../../../Pressable/PressableWithoutFeedback'; -import CONST from '../../../../CONST'; -import AttachmentCarouselPage from '../../AttachmentCarousel/Pager/AttachmentCarouselPage'; -import {attachmentViewImagePropTypes, attachmentViewImageDefaultProps} from './propTypes'; +import AttachmentCarouselPage from '@components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPage'; +import ImageView from '@components/ImageView'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import {attachmentViewImageDefaultProps, attachmentViewImagePropTypes} from './propTypes'; const propTypes = { ...attachmentViewImagePropTypes, diff --git a/src/components/Attachments/AttachmentView/AttachmentViewImage/propTypes.js b/src/components/Attachments/AttachmentView/AttachmentViewImage/propTypes.js index 661b940da207..184d3ae1a367 100644 --- a/src/components/Attachments/AttachmentView/AttachmentViewImage/propTypes.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewImage/propTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import {attachmentViewPropTypes, attachmentViewDefaultProps} from '../propTypes'; +import {attachmentViewDefaultProps, attachmentViewPropTypes} from '@components/Attachments/AttachmentView/propTypes'; const attachmentViewImagePropTypes = { ...attachmentViewPropTypes, diff --git a/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.js b/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.js index 1d1de83951ee..c3d1423b17c9 100644 --- a/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.js @@ -1,6 +1,6 @@ import React, {memo} from 'react'; -import {attachmentViewPdfPropTypes, attachmentViewPdfDefaultProps} from './propTypes'; -import PDFView from '../../../PDFView'; +import PDFView from '@components/PDFView'; +import {attachmentViewPdfDefaultProps, attachmentViewPdfPropTypes} from './propTypes'; function AttachmentViewPdf({file, encryptedSourceUrl, isFocused, onPress, onScaleChanged, onToggleKeyboard, onLoadComplete, errorLabelStyles, style}) { return ( diff --git a/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.native.js b/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.native.js index fea72a3fe37a..9ab0b45f8c8f 100644 --- a/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.native.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewPdf/index.native.js @@ -1,7 +1,7 @@ import React, {memo, useCallback, useContext, useEffect} from 'react'; -import {attachmentViewPdfPropTypes, attachmentViewPdfDefaultProps} from './propTypes'; -import PDFView from '../../../PDFView'; -import AttachmentCarouselPagerContext from '../../AttachmentCarousel/Pager/AttachmentCarouselPagerContext'; +import AttachmentCarouselPagerContext from '@components/Attachments/AttachmentCarousel/Pager/AttachmentCarouselPagerContext'; +import PDFView from '@components/PDFView'; +import {attachmentViewPdfDefaultProps, attachmentViewPdfPropTypes} from './propTypes'; function AttachmentViewPdf({file, encryptedSourceUrl, isFocused, isUsedInCarousel, onPress, onScaleChanged: onScaleChangedProp, onToggleKeyboard, onLoadComplete, errorLabelStyles, style}) { const attachmentCarouselPagerContext = useContext(AttachmentCarouselPagerContext); diff --git a/src/components/Attachments/AttachmentView/AttachmentViewPdf/propTypes.js b/src/components/Attachments/AttachmentView/AttachmentViewPdf/propTypes.js index 07203cc2fe74..a34010f0ba8b 100644 --- a/src/components/Attachments/AttachmentView/AttachmentViewPdf/propTypes.js +++ b/src/components/Attachments/AttachmentView/AttachmentViewPdf/propTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import * as AttachmentsPropTypes from '../../propTypes'; -import stylePropTypes from '../../../../styles/stylePropTypes'; +import * as AttachmentsPropTypes from '@components/Attachments/propTypes'; +import stylePropTypes from '@styles/stylePropTypes'; const attachmentViewPdfPropTypes = { /** File object maybe be instance of File or Object */ diff --git a/src/components/Attachments/AttachmentView/index.js b/src/components/Attachments/AttachmentView/index.js index 66d7b2fa89d6..98086dcc4a0c 100755 --- a/src/components/Attachments/AttachmentView/index.js +++ b/src/components/Attachments/AttachmentView/index.js @@ -1,29 +1,29 @@ -import React, {memo, useState} from 'react'; -import {View, ScrollView, ActivityIndicator} from 'react-native'; -import _ from 'underscore'; -import PropTypes from 'prop-types'; import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; +import React, {memo, useState} from 'react'; +import {ActivityIndicator, ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../../styles/styles'; -import Icon from '../../Icon'; -import * as Expensicons from '../../Icon/Expensicons'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import compose from '../../../libs/compose'; -import Text from '../../Text'; -import Tooltip from '../../Tooltip'; -import themeColors from '../../../styles/themes/default'; -import variables from '../../../styles/variables'; +import _ from 'underscore'; +import DistanceEReceipt from '@components/DistanceEReceipt'; +import EReceipt from '@components/EReceipt'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useNetwork from '@hooks/useNetwork'; +import addEncryptedAuthTokenToURL from '@libs/addEncryptedAuthTokenToURL'; +import compose from '@libs/compose'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import cursor from '@styles/utilities/cursor'; +import variables from '@styles/variables'; +import ONYXKEYS from '@src/ONYXKEYS'; import AttachmentViewImage from './AttachmentViewImage'; import AttachmentViewPdf from './AttachmentViewPdf'; -import addEncryptedAuthTokenToURL from '../../../libs/addEncryptedAuthTokenToURL'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import {attachmentViewPropTypes, attachmentViewDefaultProps} from './propTypes'; -import * as TransactionUtils from '../../../libs/TransactionUtils'; -import DistanceEReceipt from '../../DistanceEReceipt'; -import useNetwork from '../../../hooks/useNetwork'; -import ONYXKEYS from '../../../ONYXKEYS'; -import EReceipt from '../../EReceipt'; -import cursor from '../../../styles/utilities/cursor'; +import {attachmentViewDefaultProps, attachmentViewPropTypes} from './propTypes'; const propTypes = { ...attachmentViewPropTypes, diff --git a/src/components/Attachments/AttachmentView/propTypes.js b/src/components/Attachments/AttachmentView/propTypes.js index 71ae3639b61c..0c7c8814267f 100644 --- a/src/components/Attachments/AttachmentView/propTypes.js +++ b/src/components/Attachments/AttachmentView/propTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import * as AttachmentsPropTypes from '../propTypes'; +import * as AttachmentsPropTypes from '@components/Attachments/propTypes'; const attachmentViewPropTypes = { /** Whether source url requires authentication */ diff --git a/src/components/AutoCompleteSuggestions/BaseAutoCompleteSuggestions.js b/src/components/AutoCompleteSuggestions/BaseAutoCompleteSuggestions.js index 7ba1e51bcdd3..c024b025c80e 100644 --- a/src/components/AutoCompleteSuggestions/BaseAutoCompleteSuggestions.js +++ b/src/components/AutoCompleteSuggestions/BaseAutoCompleteSuggestions.js @@ -1,12 +1,12 @@ import React, {useEffect, useRef} from 'react'; -import Animated, {Easing, FadeOutDown, useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; // We take FlatList from this package to properly handle the scrolling of AutoCompleteSuggestions in chats since one scroll is nested inside another import {FlatList} from 'react-native-gesture-handler'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; -import CONST from '../../CONST'; +import Animated, {Easing, FadeOutDown, useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import {propTypes} from './autoCompleteSuggestionsPropTypes'; -import PressableWithFeedback from '../Pressable/PressableWithFeedback'; /** * @param {Number} numRows diff --git a/src/components/AutoCompleteSuggestions/index.js b/src/components/AutoCompleteSuggestions/index.js index 9234d04f4507..30654caf5708 100644 --- a/src/components/AutoCompleteSuggestions/index.js +++ b/src/components/AutoCompleteSuggestions/index.js @@ -1,11 +1,11 @@ import React from 'react'; -import {View} from 'react-native'; import ReactDOM from 'react-dom'; -import BaseAutoCompleteSuggestions from './BaseAutoCompleteSuggestions'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; +import {View} from 'react-native'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as StyleUtils from '@styles/StyleUtils'; import {propTypes} from './autoCompleteSuggestionsPropTypes'; -import * as StyleUtils from '../../styles/StyleUtils'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; +import BaseAutoCompleteSuggestions from './BaseAutoCompleteSuggestions'; /** * On the mobile-web platform, when long-pressing on auto-complete suggestions, diff --git a/src/components/AutoCompleteSuggestions/index.native.js b/src/components/AutoCompleteSuggestions/index.native.js index f5ff4636f395..439fa45eae78 100644 --- a/src/components/AutoCompleteSuggestions/index.native.js +++ b/src/components/AutoCompleteSuggestions/index.native.js @@ -1,7 +1,7 @@ -import React from 'react'; import {Portal} from '@gorhom/portal'; -import BaseAutoCompleteSuggestions from './BaseAutoCompleteSuggestions'; +import React from 'react'; import {propTypes} from './autoCompleteSuggestionsPropTypes'; +import BaseAutoCompleteSuggestions from './BaseAutoCompleteSuggestions'; function AutoCompleteSuggestions({measureParentContainer, ...props}) { return ( diff --git a/src/components/AutoEmailLink.js b/src/components/AutoEmailLink.js index 9f39997bce13..eece1a16ca5a 100644 --- a/src/components/AutoEmailLink.js +++ b/src/components/AutoEmailLink.js @@ -1,10 +1,10 @@ -import React from 'react'; +import {CONST} from 'expensify-common/lib/CONST'; import PropTypes from 'prop-types'; +import React from 'react'; import _ from 'underscore'; -import {CONST} from 'expensify-common/lib/CONST'; +import styles from '@styles/styles'; import Text from './Text'; import TextLink from './TextLink'; -import styles from '../styles/styles'; const propTypes = { text: PropTypes.string.isRequired, diff --git a/src/components/AutoUpdateTime.js b/src/components/AutoUpdateTime.js index e7d8b133e903..c85f14ed2c29 100644 --- a/src/components/AutoUpdateTime.js +++ b/src/components/AutoUpdateTime.js @@ -2,13 +2,13 @@ * Displays the user's local time and updates it every minute. * The time auto-update logic is extracted to this component to avoid re-rendering a more complex component, e.g. DetailsPage. */ -import {View} from 'react-native'; -import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import PropTypes from 'prop-types'; -import styles from '../styles/styles'; -import DateUtils from '../libs/DateUtils'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; +import DateUtils from '@libs/DateUtils'; +import styles from '@styles/styles'; import Text from './Text'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** Timezone of the user from their personal details */ diff --git a/src/components/Avatar.js b/src/components/Avatar.js index 4f0eb60eb2e0..546387031643 100644 --- a/src/components/Avatar.js +++ b/src/components/Avatar.js @@ -1,17 +1,17 @@ +import PropTypes from 'prop-types'; import React, {useEffect, useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import stylePropTypes from '../styles/stylePropTypes'; +import useNetwork from '@hooks/useNetwork'; +import * as ReportUtils from '@libs/ReportUtils'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import Icon from './Icon'; -import themeColors from '../styles/themes/default'; -import CONST from '../CONST'; -import * as StyleUtils from '../styles/StyleUtils'; import * as Expensicons from './Icon/Expensicons'; import Image from './Image'; -import styles from '../styles/styles'; -import * as ReportUtils from '../libs/ReportUtils'; -import useNetwork from '../hooks/useNetwork'; const propTypes = { /** Source for the avatar. Can be a URL or an icon. */ diff --git a/src/components/AvatarCropModal/AvatarCropModal.js b/src/components/AvatarCropModal/AvatarCropModal.js index 10e8a76f756d..c8bd7f6f7bc8 100644 --- a/src/components/AvatarCropModal/AvatarCropModal.js +++ b/src/components/AvatarCropModal/AvatarCropModal.js @@ -2,27 +2,27 @@ import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useState} from 'react'; import {ActivityIndicator, Image, View} from 'react-native'; import {GestureHandlerRootView} from 'react-native-gesture-handler'; -import {runOnUI, interpolate, useAnimatedGestureHandler, useSharedValue, useWorkletCallback} from 'react-native-reanimated'; -import CONST from '../../CONST'; -import compose from '../../libs/compose'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import Button from '../Button'; -import HeaderWithBackButton from '../HeaderWithBackButton'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import Modal from '../Modal'; -import Text from '../Text'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions'; +import {interpolate, runOnUI, useAnimatedGestureHandler, useSharedValue, useWorkletCallback} from 'react-native-reanimated'; +import Button from '@components/Button'; +import HeaderGap from '@components/HeaderGap'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Modal from '@components/Modal'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import cropOrRotateImage from '@libs/cropOrRotateImage'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import ImageCropView from './ImageCropView'; import Slider from './Slider'; -import cropOrRotateImage from '../../libs/cropOrRotateImage'; -import HeaderGap from '../HeaderGap'; -import * as StyleUtils from '../../styles/StyleUtils'; -import Tooltip from '../Tooltip'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import ScreenWrapper from '../ScreenWrapper'; const propTypes = { /** Link to image for cropping */ diff --git a/src/components/AvatarCropModal/ImageCropView.js b/src/components/AvatarCropModal/ImageCropView.js index be19109d7379..cb135cc76c69 100644 --- a/src/components/AvatarCropModal/ImageCropView.js +++ b/src/components/AvatarCropModal/ImageCropView.js @@ -3,12 +3,12 @@ import React from 'react'; import {View} from 'react-native'; import {PanGestureHandler} from 'react-native-gesture-handler'; import Animated, {interpolate, useAnimatedStyle} from 'react-native-reanimated'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import * as StyleUtils from '../../styles/StyleUtils'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import ControlSelection from '@libs/ControlSelection'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import gestureHandlerPropTypes from './gestureHandlerPropTypes'; -import ControlSelection from '../../libs/ControlSelection'; const propTypes = { /** Link to image for cropping */ diff --git a/src/components/AvatarCropModal/Slider.js b/src/components/AvatarCropModal/Slider.js index 573ee781e5f8..4281da1e7b99 100644 --- a/src/components/AvatarCropModal/Slider.js +++ b/src/components/AvatarCropModal/Slider.js @@ -3,11 +3,11 @@ import React, {useState} from 'react'; import {View} from 'react-native'; import {PanGestureHandler} from 'react-native-gesture-handler'; import Animated, {useAnimatedStyle} from 'react-native-reanimated'; -import styles from '../../styles/styles'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import ControlSelection from '@libs/ControlSelection'; +import styles from '@styles/styles'; import gestureHandlerPropTypes from './gestureHandlerPropTypes'; -import ControlSelection from '../../libs/ControlSelection'; -import Tooltip from '../Tooltip'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; const propTypes = { /** React-native-reanimated lib handler which executes when the user is panning slider */ diff --git a/src/components/AvatarWithDisplayName.js b/src/components/AvatarWithDisplayName.js index 03ae8f51bfb6..a7647aef5e99 100644 --- a/src/components/AvatarWithDisplayName.js +++ b/src/components/AvatarWithDisplayName.js @@ -1,28 +1,28 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import CONST from '../CONST'; -import reportPropTypes from '../pages/reportPropTypes'; -import participantPropTypes from './participantPropTypes'; -import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import SubscriptAvatar from './SubscriptAvatar'; -import * as ReportUtils from '../libs/ReportUtils'; -import MultipleAvatars from './MultipleAvatars'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import DisplayNames from './DisplayNames'; -import compose from '../libs/compose'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import Text from './Text'; -import * as StyleUtils from '../styles/StyleUtils'; +import MultipleAvatars from './MultipleAvatars'; import ParentNavigationSubtitle from './ParentNavigationSubtitle'; +import participantPropTypes from './participantPropTypes'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; +import SubscriptAvatar from './SubscriptAvatar'; +import Text from './Text'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; const propTypes = { /** The report currently being looked at */ diff --git a/src/components/AvatarWithImagePicker.js b/src/components/AvatarWithImagePicker.js index 3dd23d9051eb..871d967e23dc 100644 --- a/src/components/AvatarWithImagePicker.js +++ b/src/components/AvatarWithImagePicker.js @@ -1,31 +1,31 @@ -import _ from 'underscore'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; +import _ from 'underscore'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import getImageResolution from '@libs/fileDownload/getImageResolution'; +import SpinningIndicatorAnimation from '@styles/animation/SpinningIndicatorAnimation'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; +import AttachmentModal from './AttachmentModal'; +import AttachmentPicker from './AttachmentPicker'; import Avatar from './Avatar'; +import AvatarCropModal from './AvatarCropModal/AvatarCropModal'; +import DotIndicatorMessage from './DotIndicatorMessage'; import Icon from './Icon'; -import PopoverMenu from './PopoverMenu'; import * as Expensicons from './Icon/Expensicons'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import AttachmentPicker from './AttachmentPicker'; -import AvatarCropModal from './AvatarCropModal/AvatarCropModal'; import OfflineWithFeedback from './OfflineWithFeedback'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import variables from '../styles/variables'; -import CONST from '../CONST'; -import SpinningIndicatorAnimation from '../styles/animation/SpinningIndicatorAnimation'; -import Tooltip from './Tooltip/PopoverAnchorTooltip'; -import stylePropTypes from '../styles/stylePropTypes'; -import * as FileUtils from '../libs/fileDownload/FileUtils'; -import getImageResolution from '../libs/fileDownload/getImageResolution'; +import PopoverMenu from './PopoverMenu'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; -import AttachmentModal from './AttachmentModal'; -import DotIndicatorMessage from './DotIndicatorMessage'; -import * as Browser from '../libs/Browser'; +import Tooltip from './Tooltip/PopoverAnchorTooltip'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; import withNavigationFocus from './withNavigationFocus'; -import compose from '../libs/compose'; const propTypes = { /** Avatar source to display */ diff --git a/src/components/AvatarWithIndicator.js b/src/components/AvatarWithIndicator.js index 5e7b8d1ee632..c2a8d5346e13 100644 --- a/src/components/AvatarWithIndicator.js +++ b/src/components/AvatarWithIndicator.js @@ -1,12 +1,12 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; import Avatar from './Avatar'; -import styles from '../styles/styles'; -import Tooltip from './Tooltip'; -import * as UserUtils from '../libs/UserUtils'; -import Indicator from './Indicator'; import * as Expensicons from './Icon/Expensicons'; +import Indicator from './Indicator'; +import Tooltip from './Tooltip'; const propTypes = { /** URL for the avatar */ diff --git a/src/components/Badge.js b/src/components/Badge.js index 942733baff37..0a6b72201655 100644 --- a/src/components/Badge.js +++ b/src/components/Badge.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import Text from './Text'; -import CONST from '../CONST'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; +import Text from './Text'; const propTypes = { /** Is Success type */ diff --git a/src/components/Banner.js b/src/components/Banner.js index 7ff1ab8210dc..df1be45a96c5 100644 --- a/src/components/Banner.js +++ b/src/components/Banner.js @@ -1,19 +1,19 @@ -import React, {memo} from 'react'; import PropTypes from 'prop-types'; +import React, {memo} from 'react'; import {View} from 'react-native'; -import compose from '../libs/compose'; +import compose from '@libs/compose'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import Hoverable from './Hoverable'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; +import PressableWithFeedback from './Pressable/PressableWithFeedback'; import RenderHTML from './RenderHTML'; import Text from './Text'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import getButtonState from '../libs/getButtonState'; import Tooltip from './Tooltip'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import PressableWithFeedback from './Pressable/PressableWithFeedback'; -import CONST from '../CONST'; const propTypes = { /** Text to display in the banner. */ diff --git a/src/components/BaseMiniContextMenuItem.js b/src/components/BaseMiniContextMenuItem.js index cf7ff4d95b07..b8d7a4a7484b 100644 --- a/src/components/BaseMiniContextMenuItem.js +++ b/src/components/BaseMiniContextMenuItem.js @@ -1,15 +1,15 @@ -import {View} from 'react-native'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import getButtonState from '../libs/getButtonState'; -import variables from '../styles/variables'; -import Tooltip from './Tooltip/PopoverAnchorTooltip'; +import DomUtils from '@libs/DomUtils'; +import getButtonState from '@libs/getButtonState'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; -import ReportActionComposeFocusManager from '../libs/ReportActionComposeFocusManager'; -import DomUtils from '../libs/DomUtils'; +import Tooltip from './Tooltip/PopoverAnchorTooltip'; const propTypes = { /** diff --git a/src/components/BigNumberPad.js b/src/components/BigNumberPad.js index 5587808a09fd..ecbde3a5afe6 100644 --- a/src/components/BigNumberPad.js +++ b/src/components/BigNumberPad.js @@ -1,12 +1,12 @@ +import PropTypes from 'prop-types'; import React, {useState} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import ControlSelection from '@libs/ControlSelection'; +import styles from '@styles/styles'; import Button from './Button'; -import ControlSelection from '../libs/ControlSelection'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import useWindowDimensions from '../hooks/useWindowDimensions'; const propTypes = { /** Callback to inform parent modal with key pressed */ diff --git a/src/components/BlockingViews/BlockingView.js b/src/components/BlockingViews/BlockingView.js index 5cb342b0fada..14daddea5f9c 100644 --- a/src/components/BlockingViews/BlockingView.js +++ b/src/components/BlockingViews/BlockingView.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; -import Icon from '../Icon'; -import Text from '../Text'; -import themeColors from '../../styles/themes/default'; -import TextLink from '../TextLink'; -import Navigation from '../../libs/Navigation/Navigation'; -import AutoEmailLink from '../AutoEmailLink'; -import useLocalize from '../../hooks/useLocalize'; +import AutoEmailLink from '@components/AutoEmailLink'; +import Icon from '@components/Icon'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; const propTypes = { /** Expensicon for the page */ diff --git a/src/components/BlockingViews/FullPageNotFoundView.js b/src/components/BlockingViews/FullPageNotFoundView.js index a9c4bf63b65e..5232b5eca8dd 100644 --- a/src/components/BlockingViews/FullPageNotFoundView.js +++ b/src/components/BlockingViews/FullPageNotFoundView.js @@ -1,14 +1,14 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import ROUTES from '@src/ROUTES'; import BlockingView from './BlockingView'; -import * as Illustrations from '../Icon/Illustrations'; -import HeaderWithBackButton from '../HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; -import useLocalize from '../../hooks/useLocalize'; -import ROUTES from '../../ROUTES'; const propTypes = { /** Child elements */ diff --git a/src/components/BlockingViews/FullPageOfflineBlockingView.js b/src/components/BlockingViews/FullPageOfflineBlockingView.js index 148c7c751bee..5a876ecb8b1c 100644 --- a/src/components/BlockingViews/FullPageOfflineBlockingView.js +++ b/src/components/BlockingViews/FullPageOfflineBlockingView.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import networkPropTypes from '../networkPropTypes'; -import {withNetwork} from '../OnyxProvider'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import * as Expensicons from '../Icon/Expensicons'; -import compose from '../../libs/compose'; +import React from 'react'; +import * as Expensicons from '@components/Icon/Expensicons'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; import BlockingView from './BlockingView'; const propTypes = { diff --git a/src/components/Button/index.js b/src/components/Button/index.js index 26d33b1431b8..2039157d3f08 100644 --- a/src/components/Button/index.js +++ b/src/components/Button/index.js @@ -1,21 +1,21 @@ +import PropTypes from 'prop-types'; import React, {Component} from 'react'; import {ActivityIndicator, View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import Text from '../Text'; -import KeyboardShortcut from '../../libs/KeyboardShortcut'; -import Icon from '../Icon'; -import CONST from '../../CONST'; -import * as StyleUtils from '../../styles/StyleUtils'; -import HapticFeedback from '../../libs/HapticFeedback'; -import withNavigationFallback from '../withNavigationFallback'; -import compose from '../../libs/compose'; -import * as Expensicons from '../Icon/Expensicons'; -import withNavigationFocus from '../withNavigationFocus'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import refPropTypes from '@components/refPropTypes'; +import Text from '@components/Text'; +import withNavigationFallback from '@components/withNavigationFallback'; +import withNavigationFocus from '@components/withNavigationFocus'; +import compose from '@libs/compose'; +import HapticFeedback from '@libs/HapticFeedback'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import validateSubmitShortcut from './validateSubmitShortcut'; -import PressableWithFeedback from '../Pressable/PressableWithFeedback'; -import refPropTypes from '../refPropTypes'; const propTypes = { /** Should the press event bubble across multiple instances when Enter key triggers it. */ diff --git a/src/components/ButtonWithDropdownMenu.js b/src/components/ButtonWithDropdownMenu.js index 04bc3f6fb54a..7c88d9202b78 100644 --- a/src/components/ButtonWithDropdownMenu.js +++ b/src/components/ButtonWithDropdownMenu.js @@ -1,16 +1,16 @@ -import React, {useState, useRef, useEffect} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect, useRef, useState} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import useWindowDimensions from '../hooks/useWindowDimensions'; -import styles from '../styles/styles'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import Button from './Button'; -import PopoverMenu from './PopoverMenu'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import themeColors from '../styles/themes/default'; -import CONST from '../CONST'; -import * as StyleUtils from '../styles/StyleUtils'; +import PopoverMenu from './PopoverMenu'; const propTypes = { /** Text to display for the menu header */ diff --git a/src/components/CardPreview.js b/src/components/CardPreview.js index 4f774d67360c..9f59ca140ce5 100644 --- a/src/components/CardPreview.js +++ b/src/components/CardPreview.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; +import ExpensifyCardImage from '@assets/images/expensify-card.svg'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import ONYXKEYS from '@src/ONYXKEYS'; import Text from './Text'; -import usePrivatePersonalDetails from '../hooks/usePrivatePersonalDetails'; -import ONYXKEYS from '../ONYXKEYS'; -import ExpensifyCardImage from '../../assets/images/expensify-card.svg'; -import variables from '../styles/variables'; const propTypes = { /** User's private personal details */ diff --git a/src/components/CategoryPicker/categoryPickerPropTypes.js b/src/components/CategoryPicker/categoryPickerPropTypes.js index 6f2800a5d98f..0bc116bf45cc 100644 --- a/src/components/CategoryPicker/categoryPickerPropTypes.js +++ b/src/components/CategoryPicker/categoryPickerPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import categoryPropTypes from '../categoryPropTypes'; +import categoryPropTypes from '@components/categoryPropTypes'; const propTypes = { /** The policyID we are getting categories for */ diff --git a/src/components/CategoryPicker/index.js b/src/components/CategoryPicker/index.js index e7f68e7011fc..f3127131b9b2 100644 --- a/src/components/CategoryPicker/index.js +++ b/src/components/CategoryPicker/index.js @@ -1,14 +1,14 @@ +import lodashGet from 'lodash/get'; import React, {useMemo, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ONYXKEYS from '../../ONYXKEYS'; -import {propTypes, defaultProps} from './categoryPickerPropTypes'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import OptionsSelector from '../OptionsSelector'; -import useLocalize from '../../hooks/useLocalize'; +import OptionsSelector from '@components/OptionsSelector'; +import useLocalize from '@hooks/useLocalize'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './categoryPickerPropTypes'; function CategoryPicker({selectedCategory, policyCategories, policyRecentlyUsedCategories, onSubmit}) { const {translate} = useLocalize(); diff --git a/src/components/Checkbox.js b/src/components/Checkbox.js index b4ffd7a6b062..51b9212133a4 100644 --- a/src/components/Checkbox.js +++ b/src/components/Checkbox.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import stylePropTypes from '../styles/stylePropTypes'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import * as StyleUtils from '../styles/StyleUtils'; -import CONST from '../CONST'; import PressableWithFeedback from './Pressable/PressableWithFeedback'; import refPropTypes from './refPropTypes'; diff --git a/src/components/CheckboxWithLabel.js b/src/components/CheckboxWithLabel.js index c10966934b9d..4bffadecb733 100644 --- a/src/components/CheckboxWithLabel.js +++ b/src/components/CheckboxWithLabel.js @@ -1,13 +1,13 @@ -import React, {useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useState} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; import Checkbox from './Checkbox'; -import Text from './Text'; import FormHelpMessage from './FormHelpMessage'; -import variables from '../styles/variables'; import PressableWithFeedback from './Pressable/PressableWithFeedback'; +import Text from './Text'; /** * Returns an error if the required props are not provided diff --git a/src/components/CheckboxWithTooltip/CheckboxWithTooltipForMobileWebAndNative.js b/src/components/CheckboxWithTooltip/CheckboxWithTooltipForMobileWebAndNative.js index f5bc097d95f7..61a2d6feaa4b 100644 --- a/src/components/CheckboxWithTooltip/CheckboxWithTooltipForMobileWebAndNative.js +++ b/src/components/CheckboxWithTooltip/CheckboxWithTooltipForMobileWebAndNative.js @@ -1,9 +1,9 @@ import React from 'react'; import {View} from 'react-native'; -import Checkbox from '../Checkbox'; -import {propTypes, defaultProps} from './checkboxWithTooltipPropTypes'; -import Growl from '../../libs/Growl'; -import withWindowDimensions from '../withWindowDimensions'; +import Checkbox from '@components/Checkbox'; +import withWindowDimensions from '@components/withWindowDimensions'; +import Growl from '@libs/Growl'; +import {defaultProps, propTypes} from './checkboxWithTooltipPropTypes'; class CheckboxWithTooltipForMobileWebAndNative extends React.Component { constructor(props) { diff --git a/src/components/CheckboxWithTooltip/checkboxWithTooltipPropTypes.js b/src/components/CheckboxWithTooltip/checkboxWithTooltipPropTypes.js index 1656fa7a82cc..67588d00ef65 100644 --- a/src/components/CheckboxWithTooltip/checkboxWithTooltipPropTypes.js +++ b/src/components/CheckboxWithTooltip/checkboxWithTooltipPropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; -import {windowDimensionsPropTypes} from '../withWindowDimensions'; -import CONST from '../../CONST'; -import stylePropTypes from '../../styles/stylePropTypes'; +import {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import stylePropTypes from '@styles/stylePropTypes'; +import CONST from '@src/CONST'; const propTypes = { /** Whether the checkbox is checked */ diff --git a/src/components/CheckboxWithTooltip/index.js b/src/components/CheckboxWithTooltip/index.js index 70b1f345fb61..06e4e0412eba 100644 --- a/src/components/CheckboxWithTooltip/index.js +++ b/src/components/CheckboxWithTooltip/index.js @@ -1,10 +1,10 @@ import React from 'react'; import {View} from 'react-native'; +import Checkbox from '@components/Checkbox'; +import Tooltip from '@components/Tooltip'; +import withWindowDimensions from '@components/withWindowDimensions'; import CheckboxWithTooltipForMobileWebAndNative from './CheckboxWithTooltipForMobileWebAndNative'; -import Checkbox from '../Checkbox'; -import {propTypes, defaultProps} from './checkboxWithTooltipPropTypes'; -import Tooltip from '../Tooltip'; -import withWindowDimensions from '../withWindowDimensions'; +import {defaultProps, propTypes} from './checkboxWithTooltipPropTypes'; function CheckboxWithTooltip(props) { if (props.isSmallScreenWidth || props.isMediumScreenWidth) { diff --git a/src/components/CheckboxWithTooltip/index.native.js b/src/components/CheckboxWithTooltip/index.native.js index 61d171d1717a..46ce0bbd131e 100644 --- a/src/components/CheckboxWithTooltip/index.native.js +++ b/src/components/CheckboxWithTooltip/index.native.js @@ -1,7 +1,7 @@ import React from 'react'; -import {propTypes, defaultProps} from './checkboxWithTooltipPropTypes'; -import withWindowDimensions from '../withWindowDimensions'; +import withWindowDimensions from '@components/withWindowDimensions'; import CheckboxWithTooltipForMobileWebAndNative from './CheckboxWithTooltipForMobileWebAndNative'; +import {defaultProps, propTypes} from './checkboxWithTooltipPropTypes'; function CheckboxWithTooltip(props) { return ( diff --git a/src/components/CollapsibleSection/Collapsible/index.native.js b/src/components/CollapsibleSection/Collapsible/index.native.js index 022d2a2a2ff9..9b800304beeb 100644 --- a/src/components/CollapsibleSection/Collapsible/index.native.js +++ b/src/components/CollapsibleSection/Collapsible/index.native.js @@ -1,6 +1,6 @@ -import CollapsibleRN from 'react-native-collapsible'; import PropTypes from 'prop-types'; import React from 'react'; +import CollapsibleRN from 'react-native-collapsible'; const propTypes = { /** Whether the section should start expanded. False by default */ diff --git a/src/components/CollapsibleSection/index.js b/src/components/CollapsibleSection/index.js index 7009d1905e1d..32d422297ca4 100644 --- a/src/components/CollapsibleSection/index.js +++ b/src/components/CollapsibleSection/index.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import Collapsible from './Collapsible'; -import Text from '../Text'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import PressableWithFeedback from '../Pressable/PressableWithFeedback'; -import CONST from '../../CONST'; const propTypes = { /** Title of the Collapsible section */ diff --git a/src/components/CommunicationsLink.js b/src/components/CommunicationsLink.js index c8ca37f51c0f..f09fecea5239 100644 --- a/src/components/CommunicationsLink.js +++ b/src/components/CommunicationsLink.js @@ -1,10 +1,10 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; -import * as Expensicons from './Icon/Expensicons'; -import Clipboard from '../libs/Clipboard'; +import Clipboard from '@libs/Clipboard'; +import styles from '@styles/styles'; import ContextMenuItem from './ContextMenuItem'; +import * as Expensicons from './Icon/Expensicons'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { diff --git a/src/components/ComposeProviders.tsx b/src/components/ComposeProviders.tsx index bff36db25533..2c73719358d8 100644 --- a/src/components/ComposeProviders.tsx +++ b/src/components/ComposeProviders.tsx @@ -1,5 +1,5 @@ import React, {ComponentType, ReactNode} from 'react'; -import ChildrenProps from '../types/utils/ChildrenProps'; +import ChildrenProps from '@src/types/utils/ChildrenProps'; type ComposeProvidersProps = ChildrenProps & { /** Provider components go here */ diff --git a/src/components/Composer/index.android.js b/src/components/Composer/index.android.js index d5013e9340e3..aca2a9d06f7a 100644 --- a/src/components/Composer/index.android.js +++ b/src/components/Composer/index.android.js @@ -1,10 +1,10 @@ -import React, {useEffect, useCallback, useRef, useMemo} from 'react'; -import {StyleSheet} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef} from 'react'; +import {StyleSheet} from 'react-native'; import _ from 'underscore'; -import RNTextInput from '../RNTextInput'; -import themeColors from '../../styles/themes/default'; -import * as ComposerUtils from '../../libs/ComposerUtils'; +import RNTextInput from '@components/RNTextInput'; +import * as ComposerUtils from '@libs/ComposerUtils'; +import themeColors from '@styles/themes/default'; const propTypes = { /** Maximum number of lines in the text input */ diff --git a/src/components/Composer/index.ios.js b/src/components/Composer/index.ios.js index d073ad8287f6..e5dab3756594 100644 --- a/src/components/Composer/index.ios.js +++ b/src/components/Composer/index.ios.js @@ -1,10 +1,10 @@ -import React, {useEffect, useRef, useMemo, useCallback} from 'react'; -import {StyleSheet} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef} from 'react'; +import {StyleSheet} from 'react-native'; import _ from 'underscore'; -import RNTextInput from '../RNTextInput'; -import themeColors from '../../styles/themes/default'; -import * as ComposerUtils from '../../libs/ComposerUtils'; +import RNTextInput from '@components/RNTextInput'; +import * as ComposerUtils from '@libs/ComposerUtils'; +import themeColors from '@styles/themes/default'; const propTypes = { /** If the input should clear, it actually gets intercepted instead of .clear() */ diff --git a/src/components/Composer/index.js b/src/components/Composer/index.js index 2872060afba5..02042d86a6e0 100755 --- a/src/components/Composer/index.js +++ b/src/components/Composer/index.js @@ -1,25 +1,25 @@ -import React, {useState, useRef, useEffect, useCallback, useMemo} from 'react'; -import {StyleSheet, View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import ExpensiMark from 'expensify-common/lib/ExpensiMark'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import {flushSync} from 'react-dom'; -import RNTextInput from '../RNTextInput'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import themeColors from '../../styles/themes/default'; -import updateIsFullComposerAvailable from '../../libs/ComposerUtils/updateIsFullComposerAvailable'; -import * as ComposerUtils from '../../libs/ComposerUtils'; -import * as Browser from '../../libs/Browser'; -import * as StyleUtils from '../../styles/StyleUtils'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions'; -import compose from '../../libs/compose'; -import styles from '../../styles/styles'; -import Text from '../Text'; -import isEnterWhileComposition from '../../libs/KeyboardShortcut/isEnterWhileComposition'; -import CONST from '../../CONST'; -import withNavigation from '../withNavigation'; -import ReportActionComposeFocusManager from '../../libs/ReportActionComposeFocusManager'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; +import {StyleSheet, View} from 'react-native'; +import _ from 'underscore'; +import RNTextInput from '@components/RNTextInput'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withNavigation from '@components/withNavigation'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import * as ComposerUtils from '@libs/ComposerUtils'; +import updateIsFullComposerAvailable from '@libs/ComposerUtils/updateIsFullComposerAvailable'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import isEnterWhileComposition from '@libs/KeyboardShortcut/isEnterWhileComposition'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; const propTypes = { /** Maximum number of lines in the text input */ diff --git a/src/components/ConfirmContent.js b/src/components/ConfirmContent.js index 469efb4f25d9..6142322848d0 100644 --- a/src/components/ConfirmContent.js +++ b/src/components/ConfirmContent.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import Header from './Header'; -import styles from '../styles/styles'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; import Button from './Button'; -import useLocalize from '../hooks/useLocalize'; -import useNetwork from '../hooks/useNetwork'; -import Text from './Text'; -import variables from '../styles/variables'; +import Header from './Header'; import Icon from './Icon'; +import Text from './Text'; const propTypes = { /** Title of the modal */ diff --git a/src/components/ConfirmModal.js b/src/components/ConfirmModal.js index 705a05ec2058..3fe3838c8c81 100755 --- a/src/components/ConfirmModal.js +++ b/src/components/ConfirmModal.js @@ -1,9 +1,9 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import CONST from '@src/CONST'; +import ConfirmContent from './ConfirmContent'; import Modal from './Modal'; -import CONST from '../CONST'; import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; -import ConfirmContent from './ConfirmContent'; const propTypes = { /** Title of the modal */ diff --git a/src/components/ConfirmPopover.js b/src/components/ConfirmPopover.js index 88df6347f850..83001736b471 100644 --- a/src/components/ConfirmPopover.js +++ b/src/components/ConfirmPopover.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import ConfirmContent from './ConfirmContent'; import Popover from './Popover'; import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; -import ConfirmContent from './ConfirmContent'; const propTypes = { /** Title of the modal */ diff --git a/src/components/ConfirmationPage.js b/src/components/ConfirmationPage.js index 4549d6ca6072..bc154923e926 100644 --- a/src/components/ConfirmationPage.js +++ b/src/components/ConfirmationPage.js @@ -1,12 +1,12 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; +import styles from '@styles/styles'; +import Button from './Button'; +import FixedFooter from './FixedFooter'; import Lottie from './Lottie'; import * as LottieAnimations from './LottieAnimations'; import Text from './Text'; -import styles from '../styles/styles'; -import Button from './Button'; -import FixedFooter from './FixedFooter'; const propTypes = { /** The asset to render */ diff --git a/src/components/ConfirmedRoute.js b/src/components/ConfirmedRoute.js index 8544de62eeb9..656e419449b3 100644 --- a/src/components/ConfirmedRoute.js +++ b/src/components/ConfirmedRoute.js @@ -1,21 +1,20 @@ -import React, {useEffect} from 'react'; -import PropTypes from 'prop-types'; - -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; import lodashIsNil from 'lodash/isNil'; +import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import * as MapboxToken from '../libs/actions/MapboxToken'; -import * as TransactionUtils from '../libs/TransactionUtils'; +import useNetwork from '@hooks/useNetwork'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import styles from '@styles/styles'; +import theme from '@styles/themes/default'; +import * as MapboxToken from '@userActions/MapboxToken'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import DistanceMapView from './DistanceMapView'; import * as Expensicons from './Icon/Expensicons'; -import theme from '../styles/themes/default'; -import styles from '../styles/styles'; -import transactionPropTypes from './transactionPropTypes'; import PendingMapView from './MapView/PendingMapView'; -import useNetwork from '../hooks/useNetwork'; -import DistanceMapView from './DistanceMapView'; +import transactionPropTypes from './transactionPropTypes'; const propTypes = { /** Transaction that stores the distance request data */ diff --git a/src/components/ConnectBankAccountButton.js b/src/components/ConnectBankAccountButton.js index f5e0afe1d52e..64d2421c7d37 100644 --- a/src/components/ConnectBankAccountButton.js +++ b/src/components/ConnectBankAccountButton.js @@ -1,16 +1,16 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import * as ReimbursementAccount from '../libs/actions/ReimbursementAccount'; -import * as Expensicons from './Icon/Expensicons'; -import styles from '../styles/styles'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as ReimbursementAccount from '@userActions/ReimbursementAccount'; import Button from './Button'; -import {withNetwork} from './OnyxProvider'; -import compose from '../libs/compose'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; +import * as Expensicons from './Icon/Expensicons'; import networkPropTypes from './networkPropTypes'; +import {withNetwork} from './OnyxProvider'; import Text from './Text'; -import Navigation from '../libs/Navigation/Navigation'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/components/ContextMenuItem.js b/src/components/ContextMenuItem.js index 010e971784cb..80d4855392a4 100644 --- a/src/components/ContextMenuItem.js +++ b/src/components/ContextMenuItem.js @@ -1,14 +1,14 @@ -import React, {forwardRef, useImperativeHandle} from 'react'; import PropTypes from 'prop-types'; -import MenuItem from './MenuItem'; -import Icon from './Icon'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import getButtonState from '../libs/getButtonState'; -import useThrottledButtonState from '../hooks/useThrottledButtonState'; +import React, {forwardRef, useImperativeHandle} from 'react'; +import useThrottledButtonState from '@hooks/useThrottledButtonState'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import getButtonState from '@libs/getButtonState'; +import getContextMenuItemStyles from '@styles/getContextMenuItemStyles'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import BaseMiniContextMenuItem from './BaseMiniContextMenuItem'; -import useWindowDimensions from '../hooks/useWindowDimensions'; -import getContextMenuItemStyles from '../styles/getContextMenuItemStyles'; +import Icon from './Icon'; +import MenuItem from './MenuItem'; const propTypes = { /** Icon Component */ diff --git a/src/components/CopyTextToClipboard.js b/src/components/CopyTextToClipboard.js index 6adc45cbdf52..ac396c6cedf4 100644 --- a/src/components/CopyTextToClipboard.js +++ b/src/components/CopyTextToClipboard.js @@ -1,8 +1,8 @@ -import React, {useCallback} from 'react'; import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; +import Clipboard from '@libs/Clipboard'; import * as Expensicons from './Icon/Expensicons'; import PressableWithDelayToggle from './Pressable/PressableWithDelayToggle'; -import Clipboard from '../libs/Clipboard'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { diff --git a/src/components/CountrySelector.js b/src/components/CountrySelector.js index 3dac127b1963..93a90dcf6be9 100644 --- a/src/components/CountrySelector.js +++ b/src/components/CountrySelector.js @@ -1,12 +1,12 @@ -import React, {useEffect} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import useLocalize from '../hooks/useLocalize'; -import MenuItemWithTopDescription from './MenuItemWithTopDescription'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import ROUTES from '@src/ROUTES'; import FormHelpMessage from './FormHelpMessage'; +import MenuItemWithTopDescription from './MenuItemWithTopDescription'; const propTypes = { /** Form error text. e.g when no country is selected */ diff --git a/src/components/CurrencySymbolButton.js b/src/components/CurrencySymbolButton.js index 446641ab158c..695cb2bc10c8 100644 --- a/src/components/CurrencySymbolButton.js +++ b/src/components/CurrencySymbolButton.js @@ -1,11 +1,11 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; import Text from './Text'; -import styles from '../styles/styles'; import Tooltip from './Tooltip'; -import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; -import CONST from '../CONST'; -import useLocalize from '../hooks/useLocalize'; const propTypes = { /** Currency symbol of selected currency */ diff --git a/src/components/CurrentUserPersonalDetailsSkeletonView/index.js b/src/components/CurrentUserPersonalDetailsSkeletonView/index.js index cc305a628820..f2d7a8b71897 100644 --- a/src/components/CurrentUserPersonalDetailsSkeletonView/index.js +++ b/src/components/CurrentUserPersonalDetailsSkeletonView/index.js @@ -1,14 +1,14 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React from 'react'; import SkeletonViewContentLoader from 'react-content-loader/native'; -import {Circle, Rect} from 'react-native-svg'; import {View} from 'react-native'; -import * as StyleUtils from '../../styles/StyleUtils'; -import CONST from '../../CONST'; -import themeColors from '../../styles/themes/default'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; +import {Circle, Rect} from 'react-native-svg'; +import _ from 'underscore'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; const propTypes = { /** Whether to animate the skeleton view */ diff --git a/src/components/CurrentWalletBalance.js b/src/components/CurrentWalletBalance.js index 642e6937f1bf..c73c0815a003 100644 --- a/src/components/CurrentWalletBalance.js +++ b/src/components/CurrentWalletBalance.js @@ -1,12 +1,12 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import styles from '../styles/styles'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import compose from '../libs/compose'; -import ONYXKEYS from '../ONYXKEYS'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import styles from '@styles/styles'; +import ONYXKEYS from '@src/ONYXKEYS'; import Text from './Text'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** The user's wallet account */ diff --git a/src/components/CustomDevMenu/index.native.js b/src/components/CustomDevMenu/index.native.js index 52ca0e43782c..c8d0e1e099d4 100644 --- a/src/components/CustomDevMenu/index.native.js +++ b/src/components/CustomDevMenu/index.native.js @@ -1,6 +1,6 @@ import {useEffect} from 'react'; import DevMenu from 'react-native-dev-menu'; -import toggleTestToolsModal from '../../libs/actions/TestTool'; +import toggleTestToolsModal from '@userActions/TestTool'; function CustomDevMenu() { useEffect(() => { diff --git a/src/components/CustomStatusBar/index.js b/src/components/CustomStatusBar/index.js index 4848e6e35f59..2ffd763bf088 100644 --- a/src/components/CustomStatusBar/index.js +++ b/src/components/CustomStatusBar/index.js @@ -1,7 +1,7 @@ import React, {useEffect} from 'react'; -import StatusBar from '../../libs/StatusBar'; -import Navigation, {navigationRef} from '../../libs/Navigation/Navigation'; -import themeColors from '../../styles/themes/default'; +import Navigation, {navigationRef} from '@libs/Navigation/Navigation'; +import StatusBar from '@libs/StatusBar'; +import themeColors from '@styles/themes/default'; function CustomStatusBar() { useEffect(() => { diff --git a/src/components/DatePicker/datepickerPropTypes.js b/src/components/DatePicker/datepickerPropTypes.js index 8bd5d890c42c..c895d919cd33 100644 --- a/src/components/DatePicker/datepickerPropTypes.js +++ b/src/components/DatePicker/datepickerPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import {propTypes as fieldPropTypes, defaultProps as defaultFieldPropTypes} from '../TextInput/baseTextInputPropTypes'; -import CONST from '../../CONST'; +import {defaultProps as defaultFieldPropTypes, propTypes as fieldPropTypes} from '@components/TextInput/baseTextInputPropTypes'; +import CONST from '@src/CONST'; const propTypes = { ...fieldPropTypes, diff --git a/src/components/DatePicker/index.android.js b/src/components/DatePicker/index.android.js index 4c034038305d..002cf5587e44 100644 --- a/src/components/DatePicker/index.android.js +++ b/src/components/DatePicker/index.android.js @@ -1,11 +1,11 @@ -import React, {forwardRef, useCallback, useImperativeHandle, useRef, useState} from 'react'; -import {Keyboard} from 'react-native'; import RNDatePicker from '@react-native-community/datetimepicker'; import moment from 'moment'; -import TextInput from '../TextInput'; -import CONST from '../../CONST'; -import {propTypes, defaultProps} from './datepickerPropTypes'; -import styles from '../../styles/styles'; +import React, {forwardRef, useCallback, useImperativeHandle, useRef, useState} from 'react'; +import {Keyboard} from 'react-native'; +import TextInput from '@components/TextInput'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes} from './datepickerPropTypes'; function DatePicker({value, defaultValue, label, placeholder, errorText, containerStyles, disabled, onBlur, onInputChange, maxDate, minDate}, outerRef) { const ref = useRef(); diff --git a/src/components/DatePicker/index.ios.js b/src/components/DatePicker/index.ios.js index ea53492b34a6..705792b0fad8 100644 --- a/src/components/DatePicker/index.ios.js +++ b/src/components/DatePicker/index.ios.js @@ -1,16 +1,16 @@ -import React, {useState, useRef, useCallback, useEffect} from 'react'; -import {Button, View, Keyboard} from 'react-native'; import RNDatePicker from '@react-native-community/datetimepicker'; -import moment from 'moment'; import isFunction from 'lodash/isFunction'; -import TextInput from '../TextInput'; -import Popover from '../Popover'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import {propTypes, defaultProps} from './datepickerPropTypes'; -import useKeyboardState from '../../hooks/useKeyboardState'; -import useLocalize from '../../hooks/useLocalize'; +import moment from 'moment'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {Button, Keyboard, View} from 'react-native'; +import Popover from '@components/Popover'; +import TextInput from '@components/TextInput'; +import useKeyboardState from '@hooks/useKeyboardState'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes} from './datepickerPropTypes'; function DatePicker({value, defaultValue, innerRef, onInputChange, preferredLocale, minDate, maxDate, label, disabled, onBlur, placeholder, containerStyles, errorText}) { const [isPickerVisible, setIsPickerVisible] = useState(false); diff --git a/src/components/DatePicker/index.js b/src/components/DatePicker/index.js index 163f120b8b98..a5b282b22c73 100644 --- a/src/components/DatePicker/index.js +++ b/src/components/DatePicker/index.js @@ -1,10 +1,10 @@ -import React, {useEffect, useRef} from 'react'; import moment from 'moment'; +import React, {useEffect, useRef} from 'react'; import _ from 'underscore'; -import TextInput from '../TextInput'; -import CONST from '../../CONST'; -import * as Browser from '../../libs/Browser'; -import {propTypes, defaultProps} from './datepickerPropTypes'; +import TextInput from '@components/TextInput'; +import * as Browser from '@libs/Browser'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes} from './datepickerPropTypes'; import './styles.css'; function DatePicker({maxDate, minDate, onInputChange, innerRef, label, value, placeholder, errorText, containerStyles, disabled, onBlur}) { diff --git a/src/components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator.js b/src/components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator.js index 61614c7e49e6..671744a3d59c 100644 --- a/src/components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator.js +++ b/src/components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator.js @@ -1,19 +1,19 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import TextLink from '../TextLink'; -import Text from '../Text'; -import Icon from '../Icon'; -import * as Illustrations from '../Icon/Illustrations'; -import * as Expensicons from '../Icon/Expensicons'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { openLinkInBrowser: PropTypes.func.isRequired, diff --git a/src/components/DeeplinkWrapper/index.website.js b/src/components/DeeplinkWrapper/index.website.js index 0cd7bfd93241..166818e4ae27 100644 --- a/src/components/DeeplinkWrapper/index.website.js +++ b/src/components/DeeplinkWrapper/index.website.js @@ -1,15 +1,15 @@ -import PropTypes from 'prop-types'; -import {useRef, useState, useEffect} from 'react'; import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; +import {useEffect, useRef, useState} from 'react'; import _ from 'underscore'; -import * as Browser from '../../libs/Browser'; -import ROUTES from '../../ROUTES'; -import * as App from '../../libs/actions/App'; -import CONST from '../../CONST'; -import CONFIG from '../../CONFIG'; -import shouldPreventDeeplinkPrompt from '../../libs/Navigation/shouldPreventDeeplinkPrompt'; -import navigationRef from '../../libs/Navigation/navigationRef'; -import Navigation from '../../libs/Navigation/Navigation'; +import * as Browser from '@libs/Browser'; +import Navigation from '@libs/Navigation/Navigation'; +import navigationRef from '@libs/Navigation/navigationRef'; +import shouldPreventDeeplinkPrompt from '@libs/Navigation/shouldPreventDeeplinkPrompt'; +import * as App from '@userActions/App'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Children to render. */ diff --git a/src/components/DisplayNames/DisplayNamesTooltipItem.js b/src/components/DisplayNames/DisplayNamesTooltipItem.js index 16f0f3a6420d..bc4d35777185 100644 --- a/src/components/DisplayNames/DisplayNamesTooltipItem.js +++ b/src/components/DisplayNames/DisplayNamesTooltipItem.js @@ -1,8 +1,8 @@ import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; -import styles from '../../styles/styles'; -import Text from '../Text'; -import UserDetailsTooltip from '../UserDetailsTooltip'; +import Text from '@components/Text'; +import UserDetailsTooltip from '@components/UserDetailsTooltip'; +import styles from '@styles/styles'; const propTypes = { index: PropTypes.number, diff --git a/src/components/DisplayNames/DisplayNamesWithTooltip.js b/src/components/DisplayNames/DisplayNamesWithTooltip.js index 0e8c435f4457..254ad3ff824f 100644 --- a/src/components/DisplayNames/DisplayNamesWithTooltip.js +++ b/src/components/DisplayNames/DisplayNamesWithTooltip.js @@ -1,12 +1,12 @@ +import lodashGet from 'lodash/get'; import React, {Fragment, useCallback, useRef} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import styles from '../../styles/styles'; -import Text from '../Text'; -import Tooltip from '../Tooltip'; -import DisplayNamesTooltipItem from './DisplayNamesTooltipItem'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import styles from '@styles/styles'; import {defaultProps, propTypes} from './displayNamesPropTypes'; +import DisplayNamesTooltipItem from './DisplayNamesTooltipItem'; function DisplayNamesWithToolTip(props) { const containerRef = useRef(null); diff --git a/src/components/DisplayNames/DisplayNamesWithoutTooltip.js b/src/components/DisplayNames/DisplayNamesWithoutTooltip.js index 66604d09673c..bdc26d4c3f8d 100644 --- a/src/components/DisplayNames/DisplayNamesWithoutTooltip.js +++ b/src/components/DisplayNames/DisplayNamesWithoutTooltip.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; import React from 'react'; -import styles from '../../styles/styles'; -import Text from '../Text'; +import Text from '@components/Text'; +import styles from '@styles/styles'; const propTypes = { /** The full title of the DisplayNames component (not split up) */ diff --git a/src/components/DisplayNames/index.js b/src/components/DisplayNames/index.js index 197940d80ca6..52ec6fb89de2 100644 --- a/src/components/DisplayNames/index.js +++ b/src/components/DisplayNames/index.js @@ -1,7 +1,7 @@ import React from 'react'; -import DisplayNamesWithToolTip from './DisplayNamesWithTooltip'; -import DisplayNamesWithoutTooltip from './DisplayNamesWithoutTooltip'; import {defaultProps, propTypes} from './displayNamesPropTypes'; +import DisplayNamesWithoutTooltip from './DisplayNamesWithoutTooltip'; +import DisplayNamesWithToolTip from './DisplayNamesWithTooltip'; function DisplayNames(props) { if (!props.tooltipEnabled) { diff --git a/src/components/DisplayNames/index.native.js b/src/components/DisplayNames/index.native.js index f1b1d7d0b7b5..e0f9635c0132 100644 --- a/src/components/DisplayNames/index.native.js +++ b/src/components/DisplayNames/index.native.js @@ -1,6 +1,6 @@ import React from 'react'; -import {propTypes, defaultProps} from './displayNamesPropTypes'; -import Text from '../Text'; +import Text from '@components/Text'; +import {defaultProps, propTypes} from './displayNamesPropTypes'; // As we don't have to show tooltips of the Native platform so we simply render the full display names list. function DisplayNames(props) { diff --git a/src/components/DistanceEReceipt.js b/src/components/DistanceEReceipt.js index 98f50b1f682f..9a63ff3a9df5 100644 --- a/src/components/DistanceEReceipt.js +++ b/src/components/DistanceEReceipt.js @@ -1,23 +1,23 @@ -import React, {useMemo} from 'react'; -import {View, ScrollView} from 'react-native'; import lodashGet from 'lodash/get'; +import React, {useMemo} from 'react'; +import {ScrollView, View} from 'react-native'; import _ from 'underscore'; -import Text from './Text'; -import styles from '../styles/styles'; -import transactionPropTypes from './transactionPropTypes'; -import * as ReceiptUtils from '../libs/ReceiptUtils'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; -import * as TransactionUtils from '../libs/TransactionUtils'; -import tryResolveUrlFromApiRoot from '../libs/tryResolveUrlFromApiRoot'; -import ThumbnailImage from './ThumbnailImage'; -import useLocalize from '../hooks/useLocalize'; +import EReceiptBackground from '@assets/images/eReceipt_background.svg'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import * as ReceiptUtils from '@libs/ReceiptUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import tryResolveUrlFromApiRoot from '@libs/tryResolveUrlFromApiRoot'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; import Icon from './Icon'; -import themeColors from '../styles/themes/default'; import * as Expensicons from './Icon/Expensicons'; -import EReceiptBackground from '../../assets/images/eReceipt_background.svg'; -import useNetwork from '../hooks/useNetwork'; import PendingMapView from './MapView/PendingMapView'; +import Text from './Text'; +import ThumbnailImage from './ThumbnailImage'; +import transactionPropTypes from './transactionPropTypes'; const propTypes = { /** The transaction for the distance request */ diff --git a/src/components/DistanceMapView/index.android.js b/src/components/DistanceMapView/index.android.js index ea72fb4de299..358b2f483a2b 100644 --- a/src/components/DistanceMapView/index.android.js +++ b/src/components/DistanceMapView/index.android.js @@ -1,13 +1,13 @@ import React, {useState} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import BlockingView from '../BlockingViews/BlockingView'; -import MapView from '../MapView'; -import styles from '../../styles/styles'; -import useNetwork from '../../hooks/useNetwork'; -import useLocalize from '../../hooks/useLocalize'; -import * as Expensicons from '../Icon/Expensicons'; -import * as StyleUtils from '../../styles/StyleUtils'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MapView from '@components/MapView'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import * as distanceMapViewPropTypes from './distanceMapViewPropTypes'; function DistanceMapView(props) { diff --git a/src/components/DistanceMapView/index.js b/src/components/DistanceMapView/index.js index 24bdf99382d1..49f47122dd4a 100644 --- a/src/components/DistanceMapView/index.js +++ b/src/components/DistanceMapView/index.js @@ -1,6 +1,6 @@ import React from 'react'; import _ from 'underscore'; -import MapView from '../MapView'; +import MapView from '@components/MapView'; import * as distanceMapViewPropTypes from './distanceMapViewPropTypes'; function DistanceMapView(props) { diff --git a/src/components/DistanceRequest/DistanceRequestFooter.js b/src/components/DistanceRequest/DistanceRequestFooter.js index eaa02968c388..e476b2fa6d34 100644 --- a/src/components/DistanceRequest/DistanceRequestFooter.js +++ b/src/components/DistanceRequest/DistanceRequestFooter.js @@ -1,22 +1,22 @@ -import React, {useMemo} from 'react'; -import {View} from 'react-native'; -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; import lodashIsNil from 'lodash/isNil'; import PropTypes from 'prop-types'; +import React, {useMemo} from 'react'; +import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import useNetwork from '../../hooks/useNetwork'; -import useLocalize from '../../hooks/useLocalize'; -import theme from '../../styles/themes/default'; -import * as TransactionUtils from '../../libs/TransactionUtils'; -import Button from '../Button'; -import DistanceMapView from '../DistanceMapView'; -import * as Expensicons from '../Icon/Expensicons'; -import PendingMapView from '../MapView/PendingMapView'; -import transactionPropTypes from '../transactionPropTypes'; +import Button from '@components/Button'; +import DistanceMapView from '@components/DistanceMapView'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PendingMapView from '@components/MapView/PendingMapView'; +import transactionPropTypes from '@components/transactionPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import styles from '@styles/styles'; +import theme from '@styles/themes/default'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const MAX_WAYPOINTS = 25; diff --git a/src/components/DistanceRequest/DistanceRequestRenderItem.js b/src/components/DistanceRequest/DistanceRequestRenderItem.js index 0e54635e82cc..0ee45febb21a 100644 --- a/src/components/DistanceRequest/DistanceRequestRenderItem.js +++ b/src/components/DistanceRequest/DistanceRequestRenderItem.js @@ -1,11 +1,11 @@ -import React from 'react'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import PropTypes from 'prop-types'; -import * as Expensicons from '../Icon/Expensicons'; -import MenuItemWithTopDescription from '../MenuItemWithTopDescription'; -import theme from '../../styles/themes/default'; -import useLocalize from '../../hooks/useLocalize'; +import React from 'react'; +import _ from 'underscore'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import useLocalize from '@hooks/useLocalize'; +import theme from '@styles/themes/default'; const propTypes = { /** The waypoints for the distance request */ diff --git a/src/components/DistanceRequest/index.js b/src/components/DistanceRequest/index.js index bd35678273ec..3a41d52eb7f4 100644 --- a/src/components/DistanceRequest/index.js +++ b/src/components/DistanceRequest/index.js @@ -1,32 +1,32 @@ -import React, {useCallback, useEffect, useMemo, useState, useRef} from 'react'; -import {View} from 'react-native'; -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import ROUTES from '../../ROUTES'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; -import * as MapboxToken from '../../libs/actions/MapboxToken'; -import useNetwork from '../../hooks/useNetwork'; -import useLocalize from '../../hooks/useLocalize'; -import Navigation from '../../libs/Navigation/Navigation'; -import reportPropTypes from '../../pages/reportPropTypes'; -import usePrevious from '../../hooks/usePrevious'; -import * as Transaction from '../../libs/actions/Transaction'; -import * as TransactionUtils from '../../libs/TransactionUtils'; -import * as IOUUtils from '../../libs/IOUUtils'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import Button from '../Button'; -import DraggableList from '../DraggableList'; -import transactionPropTypes from '../transactionPropTypes'; -import ScreenWrapper from '../ScreenWrapper'; -import FullPageNotFoundView from '../BlockingViews/FullPageNotFoundView'; -import HeaderWithBackButton from '../HeaderWithBackButton'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Button from '@components/Button'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import DraggableList from '@components/DraggableList'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import transactionPropTypes from '@components/transactionPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import usePrevious from '@hooks/usePrevious'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as IOUUtils from '@libs/IOUUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as MapboxToken from '@userActions/MapboxToken'; +import * as Transaction from '@userActions/Transaction'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import DistanceRequestFooter from './DistanceRequestFooter'; import DistanceRequestRenderItem from './DistanceRequestRenderItem'; -import DotIndicatorMessage from '../DotIndicatorMessage'; const propTypes = { /** The transactionID of this request */ diff --git a/src/components/DotIndicatorMessage.js b/src/components/DotIndicatorMessage.js index fc4d74339d6e..26e42c0b9ec7 100644 --- a/src/components/DotIndicatorMessage.js +++ b/src/components/DotIndicatorMessage.js @@ -1,14 +1,14 @@ -import React from 'react'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; -import stylePropTypes from '../styles/stylePropTypes'; +import _ from 'underscore'; +import * as Localize from '@libs/Localize'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import themeColors from '../styles/themes/default'; import Text from './Text'; -import * as Localize from '../libs/Localize'; const propTypes = { /** diff --git a/src/components/DragAndDrop/Consumer/index.js b/src/components/DragAndDrop/Consumer/index.js index cf21afe627f4..5c9f16bc0bed 100644 --- a/src/components/DragAndDrop/Consumer/index.js +++ b/src/components/DragAndDrop/Consumer/index.js @@ -1,7 +1,7 @@ -import React, {useContext, useEffect} from 'react'; import {Portal} from '@gorhom/portal'; +import React, {useContext, useEffect} from 'react'; +import {DragAndDropContext} from '@components/DragAndDrop/Provider'; import dragAndDropConsumerPropTypes from './dragAndDropConsumerPropTypes'; -import {DragAndDropContext} from '../Provider'; function DragAndDropConsumer({children, onDrop}) { const {isDraggingOver, setOnDropHandler, dropZoneID} = useContext(DragAndDropContext); diff --git a/src/components/DragAndDrop/NoDropZone/index.js b/src/components/DragAndDrop/NoDropZone/index.js index 5573136a3bc7..ac5b759dee63 100644 --- a/src/components/DragAndDrop/NoDropZone/index.js +++ b/src/components/DragAndDrop/NoDropZone/index.js @@ -1,8 +1,8 @@ +import PropTypes from 'prop-types'; import React, {useRef} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import useDragAndDrop from '../../../hooks/useDragAndDrop'; +import useDragAndDrop from '@hooks/useDragAndDrop'; +import styles from '@styles/styles'; const propTypes = { /** Content */ diff --git a/src/components/DragAndDrop/Provider/index.js b/src/components/DragAndDrop/Provider/index.js index f76bf13c99fd..c31b83a7d605 100644 --- a/src/components/DragAndDrop/Provider/index.js +++ b/src/components/DragAndDrop/Provider/index.js @@ -1,11 +1,11 @@ -import _ from 'underscore'; -import React, {useRef, useCallback, useEffect, useMemo} from 'react'; -import {View} from 'react-native'; import {PortalHost} from '@gorhom/portal'; import Str from 'expensify-common/lib/str'; +import React, {useCallback, useEffect, useMemo, useRef} from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import useDragAndDrop from '@hooks/useDragAndDrop'; +import styles from '@styles/styles'; import dragAndDropProviderPropTypes from './dragAndDropProviderPropTypes'; -import styles from '../../../styles/styles'; -import useDragAndDrop from '../../../hooks/useDragAndDrop'; const DragAndDropContext = React.createContext({}); diff --git a/src/components/DraggableList/index.native.tsx b/src/components/DraggableList/index.native.tsx index e3b7558c1e21..d7e42a5f5525 100644 --- a/src/components/DraggableList/index.native.tsx +++ b/src/components/DraggableList/index.native.tsx @@ -1,8 +1,8 @@ import React from 'react'; import DraggableFlatList from 'react-native-draggable-flatlist'; import {FlatList} from 'react-native-gesture-handler'; +import styles from '@styles/styles'; import type {DraggableListProps} from './types'; -import styles from '../../styles/styles'; function DraggableList({renderClone, shouldUsePortal, ...viewProps}: DraggableListProps, ref: React.ForwardedRef>) { return ( diff --git a/src/components/DraggableList/index.tsx b/src/components/DraggableList/index.tsx index ea9ac548e850..287b549d6d0a 100644 --- a/src/components/DraggableList/index.tsx +++ b/src/components/DraggableList/index.tsx @@ -1,9 +1,9 @@ import React, {useCallback} from 'react'; -import {DragDropContext, Droppable, Draggable, type OnDragEndResponder} from 'react-beautiful-dnd'; +import {DragDropContext, Draggable, Droppable, type OnDragEndResponder} from 'react-beautiful-dnd'; import {ScrollView} from 'react-native'; -import useDraggableInPortal from './useDraggableInPortal'; +import styles from '@styles/styles'; import type {DraggableListProps} from './types'; -import styles from '../../styles/styles'; +import useDraggableInPortal from './useDraggableInPortal'; type ReorderParams = { list: T[]; diff --git a/src/components/DraggableList/useDraggableInPortal.ts b/src/components/DraggableList/useDraggableInPortal.ts index 6b7f958d6a3e..3b4610ce1e5e 100644 --- a/src/components/DraggableList/useDraggableInPortal.ts +++ b/src/components/DraggableList/useDraggableInPortal.ts @@ -1,5 +1,5 @@ -import type {DraggableChildrenFn} from 'react-beautiful-dnd'; import {useEffect, useRef} from 'react'; +import type {DraggableChildrenFn} from 'react-beautiful-dnd'; import {createPortal} from 'react-dom'; type DraggableInPortal = { diff --git a/src/components/EReceipt.js b/src/components/EReceipt.js index 84daabb96c9b..7c186216a1fa 100644 --- a/src/components/EReceipt.js +++ b/src/components/EReceipt.js @@ -1,21 +1,21 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import ONYXKEYS from '../ONYXKEYS'; -import * as StyleUtils from '../styles/StyleUtils'; -import transactionPropTypes from './transactionPropTypes'; -import styles from '../styles/styles'; -import * as Expensicons from './Icon/Expensicons'; +import useLocalize from '@hooks/useLocalize'; +import * as CardUtils from '@libs/CardUtils'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import EReceiptThumbnail from './EReceiptThumbnail'; import Icon from './Icon'; +import * as Expensicons from './Icon/Expensicons'; import Text from './Text'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; -import * as CardUtils from '../libs/CardUtils'; -import variables from '../styles/variables'; -import useLocalize from '../hooks/useLocalize'; -import EReceiptThumbnail from './EReceiptThumbnail'; -import CONST from '../CONST'; +import transactionPropTypes from './transactionPropTypes'; const propTypes = { /* TransactionID of the transaction this EReceipt corresponds to */ diff --git a/src/components/EReceiptThumbnail.js b/src/components/EReceiptThumbnail.js index f1bb5b025e2f..fc69601983f8 100644 --- a/src/components/EReceiptThumbnail.js +++ b/src/components/EReceiptThumbnail.js @@ -1,19 +1,19 @@ +import PropTypes from 'prop-types'; import React, {useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import ONYXKEYS from '../ONYXKEYS'; -import * as StyleUtils from '../styles/StyleUtils'; -import transactionPropTypes from './transactionPropTypes'; -import styles from '../styles/styles'; -import * as Expensicons from './Icon/Expensicons'; -import * as MCCIcons from './Icon/MCCIcons'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Icon from './Icon'; -import * as ReportUtils from '../libs/ReportUtils'; -import variables from '../styles/variables'; import * as eReceiptBGs from './Icon/EReceiptBGs'; +import * as Expensicons from './Icon/Expensicons'; +import * as MCCIcons from './Icon/MCCIcons'; import Image from './Image'; -import CONST from '../CONST'; +import transactionPropTypes from './transactionPropTypes'; const propTypes = { /* TransactionID of the transaction this EReceipt corresponds to */ diff --git a/src/components/EmojiPicker/CategoryShortcutBar.js b/src/components/EmojiPicker/CategoryShortcutBar.js index 00fee688f986..bab1e344da40 100644 --- a/src/components/EmojiPicker/CategoryShortcutBar.js +++ b/src/components/EmojiPicker/CategoryShortcutBar.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../../styles/styles'; +import styles from '@styles/styles'; import CategoryShortcutButton from './CategoryShortcutButton'; const propTypes = { diff --git a/src/components/EmojiPicker/CategoryShortcutButton.js b/src/components/EmojiPicker/CategoryShortcutButton.js index a7658ae0542d..132da7c540c2 100644 --- a/src/components/EmojiPicker/CategoryShortcutButton.js +++ b/src/components/EmojiPicker/CategoryShortcutButton.js @@ -1,15 +1,15 @@ -import React, {useState} from 'react'; import PropTypes from 'prop-types'; -import Icon from '../Icon'; -import Tooltip from '../Tooltip'; -import useLocalize from '../../hooks/useLocalize'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; -import getButtonState from '../../libs/getButtonState'; -import themeColors from '../../styles/themes/default'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import CONST from '../../CONST'; +import React, {useState} from 'react'; +import Icon from '@components/Icon'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; const propTypes = { /** The emoji code of the category header */ diff --git a/src/components/EmojiPicker/EmojiPicker.js b/src/components/EmojiPicker/EmojiPicker.js index 5c2f65e24b01..d0ba8f80f94b 100644 --- a/src/components/EmojiPicker/EmojiPicker.js +++ b/src/components/EmojiPicker/EmojiPicker.js @@ -1,15 +1,15 @@ -import React, {useState, useEffect, useRef, forwardRef, useImperativeHandle} from 'react'; +import PropTypes from 'prop-types'; +import React, {forwardRef, useEffect, useImperativeHandle, useRef, useState} from 'react'; import {Dimensions} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; +import PopoverWithMeasuredContent from '@components/PopoverWithMeasuredContent'; +import withViewportOffsetTop from '@components/withViewportOffsetTop'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import calculateAnchorPosition from '@libs/calculateAnchorPosition'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import EmojiPickerMenu from './EmojiPickerMenu'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import PopoverWithMeasuredContent from '../PopoverWithMeasuredContent'; -import withViewportOffsetTop from '../withViewportOffsetTop'; -import * as StyleUtils from '../../styles/StyleUtils'; -import calculateAnchorPosition from '../../libs/calculateAnchorPosition'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; const DEFAULT_ANCHOR_ORIGIN = { horizontal: CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.RIGHT, diff --git a/src/components/EmojiPicker/EmojiPickerButton.js b/src/components/EmojiPicker/EmojiPickerButton.js index 0d1426cbf987..0989e4df88c6 100644 --- a/src/components/EmojiPicker/EmojiPickerButton.js +++ b/src/components/EmojiPicker/EmojiPickerButton.js @@ -1,14 +1,14 @@ -import React, {useEffect, useRef} from 'react'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; -import getButtonState from '../../libs/getButtonState'; -import * as Expensicons from '../Icon/Expensicons'; -import Tooltip from '../Tooltip/PopoverAnchorTooltip'; -import Icon from '../Icon'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; +import React, {useEffect, useRef} from 'react'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Tooltip from '@components/Tooltip/PopoverAnchorTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as EmojiPickerAction from '@userActions/EmojiPickerAction'; const propTypes = { /** Flag to disable the emoji picker button */ diff --git a/src/components/EmojiPicker/EmojiPickerButtonDropdown.js b/src/components/EmojiPicker/EmojiPickerButtonDropdown.js index a1a22d8c50dd..8a5a66444fda 100644 --- a/src/components/EmojiPicker/EmojiPickerButtonDropdown.js +++ b/src/components/EmojiPicker/EmojiPickerButtonDropdown.js @@ -1,17 +1,17 @@ -import React, {useRef, useEffect} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect, useRef} from 'react'; import {View} from 'react-native'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import * as StyleUtils from '../../styles/StyleUtils'; -import getButtonState from '../../libs/getButtonState'; -import * as Expensicons from '../Icon/Expensicons'; -import Tooltip from '../Tooltip'; -import Text from '../Text'; -import Icon from '../Icon'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as EmojiPickerAction from '@userActions/EmojiPickerAction'; +import CONST from '@src/CONST'; const propTypes = { /** Flag to disable the emoji picker button */ diff --git a/src/components/EmojiPicker/EmojiPickerMenu/index.js b/src/components/EmojiPicker/EmojiPickerMenu/index.js index 38a47c9b2914..7dc53e958849 100755 --- a/src/components/EmojiPicker/EmojiPickerMenu/index.js +++ b/src/components/EmojiPicker/EmojiPickerMenu/index.js @@ -1,28 +1,28 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useRef, useState} from 'react'; -import {View, FlatList} from 'react-native'; +import {FlatList, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import emojiAssets from '../../../../assets/emojis'; -import EmojiPickerMenuItem from '../EmojiPickerMenuItem'; -import Text from '../../Text'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import compose from '../../../libs/compose'; -import getOperatingSystem from '../../../libs/getOperatingSystem'; -import * as User from '../../../libs/actions/User'; -import EmojiSkinToneList from '../EmojiSkinToneList'; -import * as EmojiUtils from '../../../libs/EmojiUtils'; -import * as Browser from '../../../libs/Browser'; -import CategoryShortcutBar from '../CategoryShortcutBar'; -import TextInput from '../../TextInput'; -import isEnterWhileComposition from '../../../libs/KeyboardShortcut/isEnterWhileComposition'; -import canFocusInputOnScreenFocus from '../../../libs/canFocusInputOnScreenFocus'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; +import emojiAssets from '@assets/emojis'; +import CategoryShortcutBar from '@components/EmojiPicker/CategoryShortcutBar'; +import EmojiPickerMenuItem from '@components/EmojiPicker/EmojiPickerMenuItem'; +import EmojiSkinToneList from '@components/EmojiPicker/EmojiSkinToneList'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import canFocusInputOnScreenFocus from '@libs/canFocusInputOnScreenFocus'; +import compose from '@libs/compose'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import getOperatingSystem from '@libs/getOperatingSystem'; +import isEnterWhileComposition from '@libs/KeyboardShortcut/isEnterWhileComposition'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Function to add the selected emoji to the main compose text input */ diff --git a/src/components/EmojiPicker/EmojiPickerMenu/index.native.js b/src/components/EmojiPicker/EmojiPickerMenu/index.native.js index b54b67294d40..140dd8f2625c 100644 --- a/src/components/EmojiPicker/EmojiPickerMenu/index.native.js +++ b/src/components/EmojiPicker/EmojiPickerMenu/index.native.js @@ -1,25 +1,25 @@ -import React, {useState, useMemo, useEffect} from 'react'; +import PropTypes from 'prop-types'; +import React, {useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import Animated, {runOnUI, scrollTo, useAnimatedRef} from 'react-native-reanimated'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import compose from '../../../libs/compose'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import emojis from '../../../../assets/emojis'; -import EmojiPickerMenuItem from '../EmojiPickerMenuItem'; -import Text from '../../Text'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import EmojiSkinToneList from '../EmojiSkinToneList'; -import * as EmojiUtils from '../../../libs/EmojiUtils'; -import * as User from '../../../libs/actions/User'; -import TextInput from '../../TextInput'; -import CategoryShortcutBar from '../CategoryShortcutBar'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import useSingleExecution from '../../../hooks/useSingleExecution'; +import _ from 'underscore'; +import emojis from '@assets/emojis'; +import CategoryShortcutBar from '@components/EmojiPicker/CategoryShortcutBar'; +import EmojiPickerMenuItem from '@components/EmojiPicker/EmojiPickerMenuItem'; +import EmojiSkinToneList from '@components/EmojiPicker/EmojiSkinToneList'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useSingleExecution from '@hooks/useSingleExecution'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import compose from '@libs/compose'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Function to add the selected emoji to the main compose text input */ diff --git a/src/components/EmojiPicker/EmojiPickerMenuItem/index.js b/src/components/EmojiPicker/EmojiPickerMenuItem/index.js index 1b3e457f7525..90f7f966172f 100644 --- a/src/components/EmojiPicker/EmojiPickerMenuItem/index.js +++ b/src/components/EmojiPicker/EmojiPickerMenuItem/index.js @@ -1,12 +1,12 @@ -import React, {PureComponent} from 'react'; import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import getButtonState from '../../../libs/getButtonState'; -import Text from '../../Text'; -import PressableWithoutFeedback from '../../Pressable/PressableWithoutFeedback'; -import CONST from '../../../CONST'; -import * as Browser from '../../../libs/Browser'; +import React, {PureComponent} from 'react'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import * as Browser from '@libs/Browser'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { /** The unicode that is used to display the emoji */ diff --git a/src/components/EmojiPicker/EmojiPickerMenuItem/index.native.js b/src/components/EmojiPicker/EmojiPickerMenuItem/index.native.js index 54416a4a2518..099adf620af7 100644 --- a/src/components/EmojiPicker/EmojiPickerMenuItem/index.native.js +++ b/src/components/EmojiPicker/EmojiPickerMenuItem/index.native.js @@ -1,11 +1,11 @@ -import React, {PureComponent} from 'react'; import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import getButtonState from '../../../libs/getButtonState'; -import Text from '../../Text'; -import PressableWithoutFeedback from '../../Pressable/PressableWithoutFeedback'; -import CONST from '../../../CONST'; +import React, {PureComponent} from 'react'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { /** The unicode that is used to display the emoji */ diff --git a/src/components/EmojiPicker/EmojiSkinToneList.js b/src/components/EmojiPicker/EmojiSkinToneList.js index 0c876910e746..edb8bf49e77f 100644 --- a/src/components/EmojiPicker/EmojiSkinToneList.js +++ b/src/components/EmojiPicker/EmojiSkinToneList.js @@ -1,15 +1,15 @@ -import _ from 'underscore'; -import React, {useState, useCallback} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import * as Emojis from '../../../assets/emojis'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import Text from '../Text'; +import React, {useCallback, useState} from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import * as Emojis from '@assets/emojis'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import EmojiPickerMenuItem from './EmojiPickerMenuItem'; import getSkinToneEmojiFromIndex from './getSkinToneEmojiFromIndex'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import CONST from '../../CONST'; const propTypes = { /** Stores user's preferred skin tone */ diff --git a/src/components/EmojiPicker/getSkinToneEmojiFromIndex.js b/src/components/EmojiPicker/getSkinToneEmojiFromIndex.js index 1b0731876f4e..48f9e2177a73 100644 --- a/src/components/EmojiPicker/getSkinToneEmojiFromIndex.js +++ b/src/components/EmojiPicker/getSkinToneEmojiFromIndex.js @@ -1,5 +1,5 @@ import _ from 'underscore'; -import * as Emojis from '../../../assets/emojis'; +import * as Emojis from '@assets/emojis'; /** * Fetch the emoji code of selected skinTone diff --git a/src/components/EmojiSuggestions.js b/src/components/EmojiSuggestions.js index d7f7a8d6091a..2a15cfba995e 100644 --- a/src/components/EmojiSuggestions.js +++ b/src/components/EmojiSuggestions.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import * as EmojiUtils from '../libs/EmojiUtils'; -import Text from './Text'; -import getStyledTextArray from '../libs/GetStyledTextArray'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import getStyledTextArray from '@libs/GetStyledTextArray'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import AutoCompleteSuggestions from './AutoCompleteSuggestions'; +import Text from './Text'; const propTypes = { /** The index of the highlighted emoji */ diff --git a/src/components/EnvironmentBadge.js b/src/components/EnvironmentBadge.js index a83fcedfabe4..a9236fc50abe 100644 --- a/src/components/EnvironmentBadge.js +++ b/src/components/EnvironmentBadge.js @@ -1,10 +1,10 @@ import React from 'react'; -import CONST from '../CONST'; -import Badge from './Badge'; -import styles from '../styles/styles'; -import * as Environment from '../libs/Environment/Environment'; +import useEnvironment from '@hooks/useEnvironment'; +import * as Environment from '@libs/Environment/Environment'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import pkg from '../../package.json'; -import useEnvironment from '../hooks/useEnvironment'; +import Badge from './Badge'; const ENVIRONMENT_SHORT_FORM = { [CONST.ENVIRONMENT.DEV]: 'DEV', diff --git a/src/components/ErrorBoundary/BaseErrorBoundary.js b/src/components/ErrorBoundary/BaseErrorBoundary.js index d626442e81dd..b532ca23b61b 100644 --- a/src/components/ErrorBoundary/BaseErrorBoundary.js +++ b/src/components/ErrorBoundary/BaseErrorBoundary.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {ErrorBoundary} from 'react-error-boundary'; -import BootSplash from '../../libs/BootSplash'; -import GenericErrorPage from '../../pages/ErrorPage/GenericErrorPage'; +import BootSplash from '@libs/BootSplash'; +import GenericErrorPage from '@pages/ErrorPage/GenericErrorPage'; const propTypes = { /* A message posted to `logError` (along with error data) when this component intercepts an error */ diff --git a/src/components/ErrorBoundary/index.js b/src/components/ErrorBoundary/index.js index 4a113fa040dd..c5498eb6f080 100644 --- a/src/components/ErrorBoundary/index.js +++ b/src/components/ErrorBoundary/index.js @@ -1,5 +1,5 @@ +import Log from '@libs/Log'; import BaseErrorBoundary from './BaseErrorBoundary'; -import Log from '../../libs/Log'; BaseErrorBoundary.defaultProps.logError = (errorMessage, error, errorInfo) => { // Log the error to the server diff --git a/src/components/ErrorBoundary/index.native.js b/src/components/ErrorBoundary/index.native.js index 68815acf670f..a7f6a68bb01f 100644 --- a/src/components/ErrorBoundary/index.native.js +++ b/src/components/ErrorBoundary/index.native.js @@ -1,7 +1,6 @@ import crashlytics from '@react-native-firebase/crashlytics'; - +import Log from '@libs/Log'; import BaseErrorBoundary from './BaseErrorBoundary'; -import Log from '../../libs/Log'; BaseErrorBoundary.defaultProps.logError = (errorMessage, error, errorInfo) => { // Log the error to the server diff --git a/src/components/ExceededCommentLength.js b/src/components/ExceededCommentLength.js index 9c785cec0395..43589be566ff 100644 --- a/src/components/ExceededCommentLength.js +++ b/src/components/ExceededCommentLength.js @@ -1,13 +1,13 @@ -import React, {useEffect, useState, useMemo} from 'react'; -import PropTypes from 'prop-types'; import {debounce} from 'lodash'; +import PropTypes from 'prop-types'; +import React, {useEffect, useMemo, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../CONST'; -import * as ReportUtils from '../libs/ReportUtils'; -import useLocalize from '../hooks/useLocalize'; +import useLocalize from '@hooks/useLocalize'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Text from './Text'; -import styles from '../styles/styles'; -import ONYXKEYS from '../ONYXKEYS'; const propTypes = { /** Report ID to get the comment from (used in withOnyx) */ diff --git a/src/components/ExpensifyWordmark.js b/src/components/ExpensifyWordmark.js index dde792e87e22..1fe6aee91e67 100644 --- a/src/components/ExpensifyWordmark.js +++ b/src/components/ExpensifyWordmark.js @@ -1,18 +1,18 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import ProductionLogo from '../../assets/images/expensify-wordmark.svg'; -import DevLogo from '../../assets/images/expensify-logo--dev.svg'; -import StagingLogo from '../../assets/images/expensify-logo--staging.svg'; -import AdHocLogo from '../../assets/images/expensify-logo--adhoc.svg'; -import CONST from '../CONST'; +import AdHocLogo from '@assets/images/expensify-logo--adhoc.svg'; +import DevLogo from '@assets/images/expensify-logo--dev.svg'; +import StagingLogo from '@assets/images/expensify-logo--staging.svg'; +import ProductionLogo from '@assets/images/expensify-wordmark.svg'; +import useEnvironment from '@hooks/useEnvironment'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; -import themeColors from '../styles/themes/default'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import variables from '../styles/variables'; -import useEnvironment from '../hooks/useEnvironment'; const propTypes = { /** Additional styles to add to the component */ diff --git a/src/components/FeatureList.js b/src/components/FeatureList.js index 3e468abea8cc..94bb309edc84 100644 --- a/src/components/FeatureList.js +++ b/src/components/FeatureList.js @@ -1,11 +1,11 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import menuItemPropTypes from './menuItemPropTypes'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; import MenuItem from './MenuItem'; -import styles from '../styles/styles'; -import useLocalize from '../hooks/useLocalize'; +import menuItemPropTypes from './menuItemPropTypes'; import Text from './Text'; const propTypes = { diff --git a/src/components/FixedFooter.tsx b/src/components/FixedFooter.tsx index c44b9bf3d0e0..afda41f16d06 100644 --- a/src/components/FixedFooter.tsx +++ b/src/components/FixedFooter.tsx @@ -1,6 +1,6 @@ import React, {ReactNode} from 'react'; import {StyleProp, View, ViewStyle} from 'react-native'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; type FixedFooterProps = { /** Children to wrap in FixedFooter. */ diff --git a/src/components/FlatList/index.android.js b/src/components/FlatList/index.android.js index d047124da914..fdb3a24667aa 100644 --- a/src/components/FlatList/index.android.js +++ b/src/components/FlatList/index.android.js @@ -1,7 +1,7 @@ +import {useFocusEffect} from '@react-navigation/native'; +import PropTypes from 'prop-types'; import React, {forwardRef, useCallback, useState} from 'react'; import {FlatList} from 'react-native'; -import PropTypes from 'prop-types'; -import {useFocusEffect} from '@react-navigation/native'; const propTypes = { /** Same as for FlatList */ diff --git a/src/components/FloatingActionButton.js b/src/components/FloatingActionButton.js index 947acf801f19..22f88cc53f59 100644 --- a/src/components/FloatingActionButton.js +++ b/src/components/FloatingActionButton.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React, {PureComponent} from 'react'; import {Animated, Easing, View} from 'react-native'; -import PropTypes from 'prop-types'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import themeColors from '../styles/themes/default'; +import PressableWithFeedback from './Pressable/PressableWithFeedback'; import Tooltip from './Tooltip/PopoverAnchorTooltip'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import PressableWithFeedback from './Pressable/PressableWithFeedback'; -import variables from '../styles/variables'; const AnimatedIcon = Animated.createAnimatedComponent(Icon); AnimatedIcon.displayName = 'AnimatedIcon'; diff --git a/src/components/Form.js b/src/components/Form.js index 436af78a2b2c..4d3acf754715 100644 --- a/src/components/Form.js +++ b/src/components/Form.js @@ -1,23 +1,23 @@ -import React, {useState, useEffect, useCallback, useMemo, useRef} from 'react'; import lodashGet from 'lodash/get'; -import {Keyboard, ScrollView, StyleSheet} from 'react-native'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {Keyboard, ScrollView, StyleSheet} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import compose from '../libs/compose'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import * as FormActions from '../libs/actions/FormActions'; -import * as ErrorUtils from '../libs/ErrorUtils'; -import styles from '../styles/styles'; -import CONST from '../CONST'; +import _ from 'underscore'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Visibility from '@libs/Visibility'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as FormActions from '@userActions/FormActions'; +import CONST from '@src/CONST'; import FormAlertWithSubmitButton from './FormAlertWithSubmitButton'; import FormSubmit from './FormSubmit'; +import networkPropTypes from './networkPropTypes'; +import {withNetwork} from './OnyxProvider'; import SafeAreaConsumer from './SafeAreaConsumer'; import ScrollViewWithContext from './ScrollViewWithContext'; -import stylePropTypes from '../styles/stylePropTypes'; -import {withNetwork} from './OnyxProvider'; -import networkPropTypes from './networkPropTypes'; -import Visibility from '../libs/Visibility'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** A unique Onyx key identifying the form */ diff --git a/src/components/Form/FormProvider.js b/src/components/Form/FormProvider.js index 75fef47bdbf8..92baa9727832 100644 --- a/src/components/Form/FormProvider.js +++ b/src/components/Form/FormProvider.js @@ -1,17 +1,17 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {createRef, useCallback, useMemo, useRef, useState} from 'react'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import Visibility from '../../libs/Visibility'; -import * as FormActions from '../../libs/actions/FormActions'; +import _ from 'underscore'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import compose from '@libs/compose'; +import Visibility from '@libs/Visibility'; +import stylePropTypes from '@styles/stylePropTypes'; +import * as FormActions from '@userActions/FormActions'; +import CONST from '@src/CONST'; import FormContext from './FormContext'; import FormWrapper from './FormWrapper'; -import compose from '../../libs/compose'; -import {withNetwork} from '../OnyxProvider'; -import stylePropTypes from '../../styles/stylePropTypes'; -import networkPropTypes from '../networkPropTypes'; -import CONST from '../../CONST'; const propTypes = { /** A unique Onyx key identifying the form */ diff --git a/src/components/Form/FormWrapper.js b/src/components/Form/FormWrapper.js index 82e70b68b3f0..55abcc1fc923 100644 --- a/src/components/Form/FormWrapper.js +++ b/src/components/Form/FormWrapper.js @@ -1,16 +1,15 @@ +import PropTypes from 'prop-types'; import React, {useCallback, useMemo, useRef} from 'react'; import {Keyboard, ScrollView, StyleSheet} from 'react-native'; -import _ from 'underscore'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import FormSubmit from '../FormSubmit'; -import FormAlertWithSubmitButton from '../FormAlertWithSubmitButton'; -import styles from '../../styles/styles'; -import SafeAreaConsumer from '../SafeAreaConsumer'; -import ScrollViewWithContext from '../ScrollViewWithContext'; - -import stylePropTypes from '../../styles/stylePropTypes'; +import _ from 'underscore'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import FormSubmit from '@components/FormSubmit'; +import SafeAreaConsumer from '@components/SafeAreaConsumer'; +import ScrollViewWithContext from '@components/ScrollViewWithContext'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; import errorsPropType from './errorsPropType'; const propTypes = { diff --git a/src/components/Form/InputWrapper.js b/src/components/Form/InputWrapper.js index 8a87bc2f5a5a..99237fd8db43 100644 --- a/src/components/Form/InputWrapper.js +++ b/src/components/Form/InputWrapper.js @@ -1,5 +1,5 @@ -import React, {forwardRef, useContext} from 'react'; import PropTypes from 'prop-types'; +import React, {forwardRef, useContext} from 'react'; import FormContext from './FormContext'; const propTypes = { diff --git a/src/components/FormAlertWithSubmitButton.js b/src/components/FormAlertWithSubmitButton.js index 33d188719d11..1ffbf0d667e2 100644 --- a/src/components/FormAlertWithSubmitButton.js +++ b/src/components/FormAlertWithSubmitButton.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; import Button from './Button'; import FormAlertWrapper from './FormAlertWrapper'; diff --git a/src/components/FormAlertWrapper.js b/src/components/FormAlertWrapper.js index 67e031ce6ab6..87304ee5dc3e 100644 --- a/src/components/FormAlertWrapper.js +++ b/src/components/FormAlertWrapper.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; import React from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import FormHelpMessage from './FormHelpMessage'; +import networkPropTypes from './networkPropTypes'; import {withNetwork} from './OnyxProvider'; import RenderHTML from './RenderHTML'; import Text from './Text'; import TextLink from './TextLink'; -import compose from '../libs/compose'; -import networkPropTypes from './networkPropTypes'; -import styles from '../styles/styles'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import FormHelpMessage from './FormHelpMessage'; const propTypes = { /** Wrapped child components */ diff --git a/src/components/FormElement.js b/src/components/FormElement.js index f46b24708c4c..cc9423a6147f 100644 --- a/src/components/FormElement.js +++ b/src/components/FormElement.js @@ -1,6 +1,6 @@ import React, {forwardRef} from 'react'; import {View} from 'react-native'; -import * as ComponentUtils from '../libs/ComponentUtils'; +import * as ComponentUtils from '@libs/ComponentUtils'; const FormElement = forwardRef((props, ref) => ( ; diff --git a/src/components/Icon/DefaultAvatars.js b/src/components/Icon/DefaultAvatars.js index 2c143f68705d..698c2ce7368c 100644 --- a/src/components/Icon/DefaultAvatars.js +++ b/src/components/Icon/DefaultAvatars.js @@ -1,27 +1,27 @@ -import Avatar1 from '../../../assets/images/avatars/user/default-avatar_1.svg'; -import Avatar2 from '../../../assets/images/avatars/user/default-avatar_2.svg'; -import Avatar3 from '../../../assets/images/avatars/user/default-avatar_3.svg'; -import Avatar4 from '../../../assets/images/avatars/user/default-avatar_4.svg'; -import Avatar5 from '../../../assets/images/avatars/user/default-avatar_5.svg'; -import Avatar6 from '../../../assets/images/avatars/user/default-avatar_6.svg'; -import Avatar7 from '../../../assets/images/avatars/user/default-avatar_7.svg'; -import Avatar8 from '../../../assets/images/avatars/user/default-avatar_8.svg'; -import Avatar9 from '../../../assets/images/avatars/user/default-avatar_9.svg'; -import Avatar10 from '../../../assets/images/avatars/user/default-avatar_10.svg'; -import Avatar11 from '../../../assets/images/avatars/user/default-avatar_11.svg'; -import Avatar12 from '../../../assets/images/avatars/user/default-avatar_12.svg'; -import Avatar13 from '../../../assets/images/avatars/user/default-avatar_13.svg'; -import Avatar14 from '../../../assets/images/avatars/user/default-avatar_14.svg'; -import Avatar15 from '../../../assets/images/avatars/user/default-avatar_15.svg'; -import Avatar16 from '../../../assets/images/avatars/user/default-avatar_16.svg'; -import Avatar17 from '../../../assets/images/avatars/user/default-avatar_17.svg'; -import Avatar18 from '../../../assets/images/avatars/user/default-avatar_18.svg'; -import Avatar19 from '../../../assets/images/avatars/user/default-avatar_19.svg'; -import Avatar20 from '../../../assets/images/avatars/user/default-avatar_20.svg'; -import Avatar21 from '../../../assets/images/avatars/user/default-avatar_21.svg'; -import Avatar22 from '../../../assets/images/avatars/user/default-avatar_22.svg'; -import Avatar23 from '../../../assets/images/avatars/user/default-avatar_23.svg'; -import Avatar24 from '../../../assets/images/avatars/user/default-avatar_24.svg'; +import Avatar1 from '@assets/images/avatars/user/default-avatar_1.svg'; +import Avatar2 from '@assets/images/avatars/user/default-avatar_2.svg'; +import Avatar3 from '@assets/images/avatars/user/default-avatar_3.svg'; +import Avatar4 from '@assets/images/avatars/user/default-avatar_4.svg'; +import Avatar5 from '@assets/images/avatars/user/default-avatar_5.svg'; +import Avatar6 from '@assets/images/avatars/user/default-avatar_6.svg'; +import Avatar7 from '@assets/images/avatars/user/default-avatar_7.svg'; +import Avatar8 from '@assets/images/avatars/user/default-avatar_8.svg'; +import Avatar9 from '@assets/images/avatars/user/default-avatar_9.svg'; +import Avatar10 from '@assets/images/avatars/user/default-avatar_10.svg'; +import Avatar11 from '@assets/images/avatars/user/default-avatar_11.svg'; +import Avatar12 from '@assets/images/avatars/user/default-avatar_12.svg'; +import Avatar13 from '@assets/images/avatars/user/default-avatar_13.svg'; +import Avatar14 from '@assets/images/avatars/user/default-avatar_14.svg'; +import Avatar15 from '@assets/images/avatars/user/default-avatar_15.svg'; +import Avatar16 from '@assets/images/avatars/user/default-avatar_16.svg'; +import Avatar17 from '@assets/images/avatars/user/default-avatar_17.svg'; +import Avatar18 from '@assets/images/avatars/user/default-avatar_18.svg'; +import Avatar19 from '@assets/images/avatars/user/default-avatar_19.svg'; +import Avatar20 from '@assets/images/avatars/user/default-avatar_20.svg'; +import Avatar21 from '@assets/images/avatars/user/default-avatar_21.svg'; +import Avatar22 from '@assets/images/avatars/user/default-avatar_22.svg'; +import Avatar23 from '@assets/images/avatars/user/default-avatar_23.svg'; +import Avatar24 from '@assets/images/avatars/user/default-avatar_24.svg'; export { Avatar1, diff --git a/src/components/Icon/EReceiptBGs.js b/src/components/Icon/EReceiptBGs.js index ff74c0fb83c2..16c23f4a99d4 100644 --- a/src/components/Icon/EReceiptBGs.js +++ b/src/components/Icon/EReceiptBGs.js @@ -1,8 +1,8 @@ -import EReceiptBG_Yellow from '../../../assets/images/eReceiptBGs/eReceiptBG_yellow.png'; -import EReceiptBG_Ice from '../../../assets/images/eReceiptBGs/eReceiptBG_navy.png'; -import EReceiptBG_Blue from '../../../assets/images/eReceiptBGs/eReceiptBG_blue.png'; -import EReceiptBG_Green from '../../../assets/images/eReceiptBGs/eReceiptBG_green.png'; -import EReceiptBG_Tangerine from '../../../assets/images/eReceiptBGs/eReceiptBG_tangerine.png'; -import EReceiptBG_Pink from '../../../assets/images/eReceiptBGs/eReceiptBG_pink.png'; +import EReceiptBG_Blue from '@assets/images/eReceiptBGs/eReceiptBG_blue.png'; +import EReceiptBG_Green from '@assets/images/eReceiptBGs/eReceiptBG_green.png'; +import EReceiptBG_Ice from '@assets/images/eReceiptBGs/eReceiptBG_navy.png'; +import EReceiptBG_Pink from '@assets/images/eReceiptBGs/eReceiptBG_pink.png'; +import EReceiptBG_Tangerine from '@assets/images/eReceiptBGs/eReceiptBG_tangerine.png'; +import EReceiptBG_Yellow from '@assets/images/eReceiptBGs/eReceiptBG_yellow.png'; export {EReceiptBG_Yellow, EReceiptBG_Ice, EReceiptBG_Blue, EReceiptBG_Green, EReceiptBG_Tangerine, EReceiptBG_Pink}; diff --git a/src/components/Icon/Expensicons.js b/src/components/Icon/Expensicons.js index e15db475597d..a4aa6b13cb29 100644 --- a/src/components/Icon/Expensicons.js +++ b/src/components/Icon/Expensicons.js @@ -1,132 +1,132 @@ -import ActiveRoomAvatar from '../../../assets/images/avatars/room.svg'; -import AdminRoomAvatar from '../../../assets/images/avatars/admin-room.svg'; -import Android from '../../../assets/images/android.svg'; -import AnnounceRoomAvatar from '../../../assets/images/avatars/announce-room.svg'; -import Apple from '../../../assets/images/apple.svg'; -import AppleLogo from '../../../assets/images/signIn/apple-logo.svg'; -import ArrowRight from '../../../assets/images/arrow-right.svg'; -import ArrowRightLong from '../../../assets/images/arrow-right-long.svg'; -import ArrowsUpDown from '../../../assets/images/arrows-updown.svg'; -import BackArrow from '../../../assets/images/back-left.svg'; -import Bank from '../../../assets/images/bank.svg'; -import Bell from '../../../assets/images/bell.svg'; -import BellSlash from '../../../assets/images/bellSlash.svg'; -import Bill from '../../../assets/images/bill.svg'; -import Bolt from '../../../assets/images/bolt.svg'; -import Briefcase from '../../../assets/images/briefcase.svg'; -import Bug from '../../../assets/images/bug.svg'; -import Building from '../../../assets/images/building.svg'; -import Calendar from '../../../assets/images/calendar.svg'; -import Camera from '../../../assets/images/camera.svg'; -import Car from '../../../assets/images/car.svg'; -import Cash from '../../../assets/images/cash.svg'; -import ChatBubble from '../../../assets/images/chatbubble.svg'; -import ChatBubbles from '../../../assets/images/chatbubbles.svg'; -import Checkmark from '../../../assets/images/checkmark.svg'; -import Chair from '../../../assets/images/chair.svg'; -import Close from '../../../assets/images/close.svg'; -import ClosedSign from '../../../assets/images/closed-sign.svg'; -import Collapse from '../../../assets/images/collapse.svg'; -import Concierge from '../../../assets/images/concierge.svg'; -import ConciergeAvatar from '../../../assets/images/avatars/concierge-avatar.svg'; -import Connect from '../../../assets/images/connect.svg'; -import Copy from '../../../assets/images/copy.svg'; -import CreditCard from '../../../assets/images/creditcard.svg'; -import Document from '../../../assets/images/document.svg'; -import DeletedRoomAvatar from '../../../assets/images/avatars/deleted-room.svg'; -import DomainRoomAvatar from '../../../assets/images/avatars/domain-room.svg'; -import DotIndicator from '../../../assets/images/dot-indicator.svg'; -import DotIndicatorUnfilled from '../../../assets/images/dot-indicator-unfilled.svg'; -import DownArrow from '../../../assets/images/down.svg'; -import Download from '../../../assets/images/download.svg'; -import DragHandles from '../../../assets/images/drag-handles.svg'; -import Emoji from '../../../assets/images/emoji.svg'; -import EmptyStateRoutePending from '../../../assets/images/emptystate__routepending.svg'; -import Exclamation from '../../../assets/images/exclamation.svg'; -import Exit from '../../../assets/images/exit.svg'; -import ExpensifyCard from '../../../assets/images/expensifycard.svg'; -import ExpensifyWordmark from '../../../assets/images/expensify-wordmark.svg'; -import Expand from '../../../assets/images/expand.svg'; -import Eye from '../../../assets/images/eye.svg'; -import EyeDisabled from '../../../assets/images/eye-disabled.svg'; -import Flag from '../../../assets/images/flag.svg'; -import FlagLevelOne from '../../../assets/images/flag_level_01.svg'; -import FlagLevelTwo from '../../../assets/images/flag_level_02.svg'; -import FlagLevelThree from '../../../assets/images/flag_level_03.svg'; -import Gallery from '../../../assets/images/gallery.svg'; -import Gear from '../../../assets/images/gear.svg'; -import Globe from '../../../assets/images/globe.svg'; -import GoogleLogo from '../../../assets/images/signIn/google-logo.svg'; -import Hashtag from '../../../assets/images/hashtag.svg'; -import Heart from '../../../assets/images/heart.svg'; -import History from '../../../assets/images/history.svg'; -import Hourglass from '../../../assets/images/hourglass.svg'; -import ImageCropCircleMask from '../../../assets/images/image-crop-circle-mask.svg'; -import ImageCropSquareMask from '../../../assets/images/image-crop-square-mask.svg'; -import Info from '../../../assets/images/info.svg'; -import Invoice from '../../../assets/images/invoice.svg'; -import Key from '../../../assets/images/key.svg'; -import Keyboard from '../../../assets/images/keyboard.svg'; -import Link from '../../../assets/images/link.svg'; -import LinkCopy from '../../../assets/images/link-copy.svg'; -import Location from '../../../assets/images/location.svg'; -import Lock from '../../../assets/images/lock.svg'; +import AddReaction from '@assets/images/add-reaction.svg'; +import Android from '@assets/images/android.svg'; +import Apple from '@assets/images/apple.svg'; +import ArrowRightLong from '@assets/images/arrow-right-long.svg'; +import ArrowRight from '@assets/images/arrow-right.svg'; +import UpArrow from '@assets/images/arrow-up.svg'; +import ArrowsUpDown from '@assets/images/arrows-updown.svg'; +import AdminRoomAvatar from '@assets/images/avatars/admin-room.svg'; +import AnnounceRoomAvatar from '@assets/images/avatars/announce-room.svg'; +import ConciergeAvatar from '@assets/images/avatars/concierge-avatar.svg'; +import DeletedRoomAvatar from '@assets/images/avatars/deleted-room.svg'; +import DomainRoomAvatar from '@assets/images/avatars/domain-room.svg'; +import FallbackAvatar from '@assets/images/avatars/fallback-avatar.svg'; +import FallbackWorkspaceAvatar from '@assets/images/avatars/fallback-workspace-avatar.svg'; +import ActiveRoomAvatar from '@assets/images/avatars/room.svg'; +import BackArrow from '@assets/images/back-left.svg'; +import Bank from '@assets/images/bank.svg'; +import Bell from '@assets/images/bell.svg'; +import BellSlash from '@assets/images/bellSlash.svg'; +import Bill from '@assets/images/bill.svg'; +import Bolt from '@assets/images/bolt.svg'; +import Briefcase from '@assets/images/briefcase.svg'; +import Bug from '@assets/images/bug.svg'; +import Building from '@assets/images/building.svg'; +import Calendar from '@assets/images/calendar.svg'; +import Camera from '@assets/images/camera.svg'; +import Car from '@assets/images/car.svg'; +import Cash from '@assets/images/cash.svg'; +import Chair from '@assets/images/chair.svg'; +import ChatBubble from '@assets/images/chatbubble.svg'; +import ChatBubbles from '@assets/images/chatbubbles.svg'; +import Checkmark from '@assets/images/checkmark.svg'; +import Close from '@assets/images/close.svg'; +import ClosedSign from '@assets/images/closed-sign.svg'; +import Collapse from '@assets/images/collapse.svg'; +import Concierge from '@assets/images/concierge.svg'; +import Connect from '@assets/images/connect.svg'; +import Copy from '@assets/images/copy.svg'; +import CreditCard from '@assets/images/creditcard.svg'; +import Document from '@assets/images/document.svg'; +import DotIndicatorUnfilled from '@assets/images/dot-indicator-unfilled.svg'; +import DotIndicator from '@assets/images/dot-indicator.svg'; +import DownArrow from '@assets/images/down.svg'; +import Download from '@assets/images/download.svg'; +import DragAndDrop from '@assets/images/drag-and-drop.svg'; +import DragHandles from '@assets/images/drag-handles.svg'; +import Emoji from '@assets/images/emoji.svg'; +import EmptyStateRoutePending from '@assets/images/emptystate__routepending.svg'; +import EReceiptIcon from '@assets/images/eReceiptIcon.svg'; +import Exclamation from '@assets/images/exclamation.svg'; +import Exit from '@assets/images/exit.svg'; +import Expand from '@assets/images/expand.svg'; +import ExpensifyFooterLogoVertical from '@assets/images/expensify-footer-logo-vertical.svg'; +import ExpensifyFooterLogo from '@assets/images/expensify-footer-logo.svg'; +import ExpensifyWordmark from '@assets/images/expensify-wordmark.svg'; +import ExpensifyCard from '@assets/images/expensifycard.svg'; +import EyeDisabled from '@assets/images/eye-disabled.svg'; +import Eye from '@assets/images/eye.svg'; +import Flag from '@assets/images/flag.svg'; +import FlagLevelOne from '@assets/images/flag_level_01.svg'; +import FlagLevelTwo from '@assets/images/flag_level_02.svg'; +import FlagLevelThree from '@assets/images/flag_level_03.svg'; +import Gallery from '@assets/images/gallery.svg'; +import Gear from '@assets/images/gear.svg'; +import Globe from '@assets/images/globe.svg'; +import Hashtag from '@assets/images/hashtag.svg'; +import Heart from '@assets/images/heart.svg'; +import History from '@assets/images/history.svg'; +import Hourglass from '@assets/images/hourglass.svg'; +import ImageCropCircleMask from '@assets/images/image-crop-circle-mask.svg'; +import ImageCropSquareMask from '@assets/images/image-crop-square-mask.svg'; +import Info from '@assets/images/info.svg'; +import Invoice from '@assets/images/invoice.svg'; +import Key from '@assets/images/key.svg'; +import Keyboard from '@assets/images/keyboard.svg'; +import LinkCopy from '@assets/images/link-copy.svg'; +import Link from '@assets/images/link.svg'; +import Location from '@assets/images/location.svg'; +import Lock from '@assets/images/lock.svg'; +import Luggage from '@assets/images/luggage.svg'; +import MagnifyingGlass from '@assets/images/magnifying-glass.svg'; +import Mail from '@assets/images/mail.svg'; +import Megaphone from '@assets/images/megaphone.svg'; +import Menu from '@assets/images/menu.svg'; +import MoneyBag from '@assets/images/money-bag.svg'; +import MoneyCircle from '@assets/images/money-circle.svg'; +import Monitor from '@assets/images/monitor.svg'; +import NewWindow from '@assets/images/new-window.svg'; +import NewWorkspace from '@assets/images/new-workspace.svg'; +import OfflineCloud from '@assets/images/offline-cloud.svg'; +import Offline from '@assets/images/offline.svg'; +import Paperclip from '@assets/images/paperclip.svg'; +import Paycheck from '@assets/images/paycheck.svg'; +import Pencil from '@assets/images/pencil.svg'; +import Phone from '@assets/images/phone.svg'; +import Pin from '@assets/images/pin.svg'; +import Plus from '@assets/images/plus.svg'; +import Printer from '@assets/images/printer.svg'; +import Profile from '@assets/images/profile.svg'; +import QrCode from '@assets/images/qrcode.svg'; +import QuestionMark from '@assets/images/question-mark-circle.svg'; +import ReceiptSearch from '@assets/images/receipt-search.svg'; +import Receipt from '@assets/images/receipt.svg'; +import Rotate from '@assets/images/rotate-image.svg'; +import RotateLeft from '@assets/images/rotate-left.svg'; +import Send from '@assets/images/send.svg'; +import Shield from '@assets/images/shield.svg'; +import AppleLogo from '@assets/images/signIn/apple-logo.svg'; +import GoogleLogo from '@assets/images/signIn/google-logo.svg'; +import Facebook from '@assets/images/social-facebook.svg'; +import Instagram from '@assets/images/social-instagram.svg'; +import Linkedin from '@assets/images/social-linkedin.svg'; +import Podcast from '@assets/images/social-podcast.svg'; +import Twitter from '@assets/images/social-twitter.svg'; +import Youtube from '@assets/images/social-youtube.svg'; +import Sync from '@assets/images/sync.svg'; +import Task from '@assets/images/task.svg'; +import ThreeDots from '@assets/images/three-dots.svg'; +import Transfer from '@assets/images/transfer.svg'; +import Trashcan from '@assets/images/trashcan.svg'; +import Unlock from '@assets/images/unlock.svg'; +import UploadAlt from '@assets/images/upload-alt.svg'; +import Upload from '@assets/images/upload.svg'; +import User from '@assets/images/user.svg'; +import Users from '@assets/images/users.svg'; +import Wallet from '@assets/images/wallet.svg'; +import Workspace from '@assets/images/workspace-default-avatar.svg'; +import Zoom from '@assets/images/zoom.svg'; import LoungeAccess from './svgs/LoungeAccessIcon'; -import Luggage from '../../../assets/images/luggage.svg'; -import MagnifyingGlass from '../../../assets/images/magnifying-glass.svg'; -import Mail from '../../../assets/images/mail.svg'; -import Megaphone from '../../../assets/images/megaphone.svg'; -import Menu from '../../../assets/images/menu.svg'; -import MoneyBag from '../../../assets/images/money-bag.svg'; -import MoneyCircle from '../../../assets/images/money-circle.svg'; -import Monitor from '../../../assets/images/monitor.svg'; -import NewWindow from '../../../assets/images/new-window.svg'; -import NewWorkspace from '../../../assets/images/new-workspace.svg'; -import Offline from '../../../assets/images/offline.svg'; -import OfflineCloud from '../../../assets/images/offline-cloud.svg'; -import Paperclip from '../../../assets/images/paperclip.svg'; -import Paycheck from '../../../assets/images/paycheck.svg'; -import Pencil from '../../../assets/images/pencil.svg'; -import Phone from '../../../assets/images/phone.svg'; -import Pin from '../../../assets/images/pin.svg'; -import Plus from '../../../assets/images/plus.svg'; -import Printer from '../../../assets/images/printer.svg'; -import Profile from '../../../assets/images/profile.svg'; -import QrCode from '../../../assets/images/qrcode.svg'; -import QuestionMark from '../../../assets/images/question-mark-circle.svg'; -import Receipt from '../../../assets/images/receipt.svg'; -import ReceiptSearch from '../../../assets/images/receipt-search.svg'; -import Rotate from '../../../assets/images/rotate-image.svg'; -import RotateLeft from '../../../assets/images/rotate-left.svg'; -import Send from '../../../assets/images/send.svg'; -import Shield from '../../../assets/images/shield.svg'; -import Sync from '../../../assets/images/sync.svg'; -import ThreeDots from '../../../assets/images/three-dots.svg'; -import Transfer from '../../../assets/images/transfer.svg'; -import Trashcan from '../../../assets/images/trashcan.svg'; -import Unlock from '../../../assets/images/unlock.svg'; -import UpArrow from '../../../assets/images/arrow-up.svg'; -import Upload from '../../../assets/images/upload.svg'; -import UploadAlt from '../../../assets/images/upload-alt.svg'; -import User from '../../../assets/images/user.svg'; -import Users from '../../../assets/images/users.svg'; -import Wallet from '../../../assets/images/wallet.svg'; -import Workspace from '../../../assets/images/workspace-default-avatar.svg'; -import Zoom from '../../../assets/images/zoom.svg'; -import FallbackAvatar from '../../../assets/images/avatars/fallback-avatar.svg'; -import FallbackWorkspaceAvatar from '../../../assets/images/avatars/fallback-workspace-avatar.svg'; -import DragAndDrop from '../../../assets/images/drag-and-drop.svg'; -import ExpensifyFooterLogo from '../../../assets/images/expensify-footer-logo.svg'; -import ExpensifyFooterLogoVertical from '../../../assets/images/expensify-footer-logo-vertical.svg'; -import Twitter from '../../../assets/images/social-twitter.svg'; -import Youtube from '../../../assets/images/social-youtube.svg'; -import Facebook from '../../../assets/images/social-facebook.svg'; -import Podcast from '../../../assets/images/social-podcast.svg'; -import Linkedin from '../../../assets/images/social-linkedin.svg'; -import Instagram from '../../../assets/images/social-instagram.svg'; -import AddReaction from '../../../assets/images/add-reaction.svg'; -import Task from '../../../assets/images/task.svg'; -import EReceiptIcon from '../../../assets/images/eReceiptIcon.svg'; export { ActiveRoomAvatar, diff --git a/src/components/Icon/Illustrations.js b/src/components/Icon/Illustrations.js index c9a86cf8f10c..728e5b830fa6 100644 --- a/src/components/Icon/Illustrations.js +++ b/src/components/Icon/Illustrations.js @@ -1,52 +1,52 @@ -import Abracadabra from '../../../assets/images/product-illustrations/abracadabra.svg'; -import BankArrowPink from '../../../assets/images/product-illustrations/bank-arrow--pink.svg'; -import BankMouseGreen from '../../../assets/images/product-illustrations/bank-mouse--green.svg'; -import BankUserGreen from '../../../assets/images/product-illustrations/bank-user--green.svg'; -import ChatBubbles from '../../../assets/images/simple-illustrations/simple-illustration__chatbubbles.svg'; -import CoffeeMug from '../../../assets/images/simple-illustrations/simple-illustration__coffeemug.svg'; -import ConciergeBlue from '../../../assets/images/product-illustrations/concierge--blue.svg'; -import ConciergeExclamation from '../../../assets/images/product-illustrations/concierge--exclamation.svg'; -import CreditCardsBlue from '../../../assets/images/product-illustrations/credit-cards--blue.svg'; -import EmailAddress from '../../../assets/images/simple-illustrations/simple-illustration__email-address.svg'; -import InvoiceOrange from '../../../assets/images/product-illustrations/invoice--orange.svg'; -import JewelBoxBlue from '../../../assets/images/product-illustrations/jewel-box--blue.svg'; -import JewelBoxGreen from '../../../assets/images/product-illustrations/jewel-box--green.svg'; -import JewelBoxPink from '../../../assets/images/product-illustrations/jewel-box--pink.svg'; -import JewelBoxYellow from '../../../assets/images/product-illustrations/jewel-box--yellow.svg'; -import MagicCode from '../../../assets/images/product-illustrations/magic-code.svg'; -import MoneyEnvelopeBlue from '../../../assets/images/product-illustrations/money-envelope--blue.svg'; -import MoneyMousePink from '../../../assets/images/product-illustrations/money-mouse--pink.svg'; -import ReceiptsSearchYellow from '../../../assets/images/product-illustrations/receipts-search--yellow.svg'; -import ReceiptYellow from '../../../assets/images/product-illustrations/receipt--yellow.svg'; -import RocketBlue from '../../../assets/images/product-illustrations/rocket--blue.svg'; -import RocketOrange from '../../../assets/images/product-illustrations/rocket--orange.svg'; -import SafeBlue from '../../../assets/images/product-illustrations/safe.svg'; -import SanFrancisco from '../../../assets/images/simple-illustrations/simple-illustration__sanfrancisco.svg'; -import TadaYellow from '../../../assets/images/product-illustrations/tada--yellow.svg'; -import TadaBlue from '../../../assets/images/product-illustrations/tada--blue.svg'; -import ToddBehindCloud from '../../../assets/images/product-illustrations/todd-behind-cloud.svg'; -import GpsTrackOrange from '../../../assets/images/product-illustrations/gps-track--orange.svg'; -import ShieldYellow from '../../../assets/images/simple-illustrations/simple-illustration__shield.svg'; -import MoneyReceipts from '../../../assets/images/simple-illustrations/simple-illustration__money-receipts.svg'; -import PinkBill from '../../../assets/images/simple-illustrations/simple-illustration__bill.svg'; -import CreditCardsNew from '../../../assets/images/simple-illustrations/simple-illustration__credit-cards.svg'; -import InvoiceBlue from '../../../assets/images/simple-illustrations/simple-illustration__invoice.svg'; -import LockOpen from '../../../assets/images/simple-illustrations/simple-illustration__lockopen.svg'; -import Lounge from '../../../assets/images/product-illustrations/lounge.svg'; -import Luggage from '../../../assets/images/simple-illustrations/simple-illustration__luggage.svg'; -import MoneyIntoWallet from '../../../assets/images/simple-illustrations/simple-illustration__moneyintowallet.svg'; -import MoneyWings from '../../../assets/images/simple-illustrations/simple-illustration__moneywings.svg'; -import OpenSafe from '../../../assets/images/simple-illustrations/simple-illustration__opensafe.svg'; -import TrackShoe from '../../../assets/images/simple-illustrations/simple-illustration__track-shoe.svg'; -import BankArrow from '../../../assets/images/simple-illustrations/simple-illustration__bank-arrow.svg'; -import ConciergeBubble from '../../../assets/images/simple-illustrations/simple-illustration__concierge-bubble.svg'; -import ConciergeNew from '../../../assets/images/simple-illustrations/simple-illustration__concierge.svg'; -import MoneyBadge from '../../../assets/images/simple-illustrations/simple-illustration__moneybadge.svg'; -import TreasureChest from '../../../assets/images/simple-illustrations/simple-illustration__treasurechest.svg'; -import ThumbsUpStars from '../../../assets/images/simple-illustrations/simple-illustration__thumbsupstars.svg'; -import Hands from '../../../assets/images/product-illustrations/home-illustration-hands.svg'; -import HandEarth from '../../../assets/images/simple-illustrations/simple-illustration__handearth.svg'; -import SmartScan from '../../../assets/images/product-illustrations/simple-illustration__smartscan.svg'; +import Abracadabra from '@assets/images/product-illustrations/abracadabra.svg'; +import BankArrowPink from '@assets/images/product-illustrations/bank-arrow--pink.svg'; +import BankMouseGreen from '@assets/images/product-illustrations/bank-mouse--green.svg'; +import BankUserGreen from '@assets/images/product-illustrations/bank-user--green.svg'; +import ConciergeBlue from '@assets/images/product-illustrations/concierge--blue.svg'; +import ConciergeExclamation from '@assets/images/product-illustrations/concierge--exclamation.svg'; +import CreditCardsBlue from '@assets/images/product-illustrations/credit-cards--blue.svg'; +import GpsTrackOrange from '@assets/images/product-illustrations/gps-track--orange.svg'; +import Hands from '@assets/images/product-illustrations/home-illustration-hands.svg'; +import InvoiceOrange from '@assets/images/product-illustrations/invoice--orange.svg'; +import JewelBoxBlue from '@assets/images/product-illustrations/jewel-box--blue.svg'; +import JewelBoxGreen from '@assets/images/product-illustrations/jewel-box--green.svg'; +import JewelBoxPink from '@assets/images/product-illustrations/jewel-box--pink.svg'; +import JewelBoxYellow from '@assets/images/product-illustrations/jewel-box--yellow.svg'; +import Lounge from '@assets/images/product-illustrations/lounge.svg'; +import MagicCode from '@assets/images/product-illustrations/magic-code.svg'; +import MoneyEnvelopeBlue from '@assets/images/product-illustrations/money-envelope--blue.svg'; +import MoneyMousePink from '@assets/images/product-illustrations/money-mouse--pink.svg'; +import ReceiptYellow from '@assets/images/product-illustrations/receipt--yellow.svg'; +import ReceiptsSearchYellow from '@assets/images/product-illustrations/receipts-search--yellow.svg'; +import RocketBlue from '@assets/images/product-illustrations/rocket--blue.svg'; +import RocketOrange from '@assets/images/product-illustrations/rocket--orange.svg'; +import SafeBlue from '@assets/images/product-illustrations/safe.svg'; +import SmartScan from '@assets/images/product-illustrations/simple-illustration__smartscan.svg'; +import TadaBlue from '@assets/images/product-illustrations/tada--blue.svg'; +import TadaYellow from '@assets/images/product-illustrations/tada--yellow.svg'; +import ToddBehindCloud from '@assets/images/product-illustrations/todd-behind-cloud.svg'; +import BankArrow from '@assets/images/simple-illustrations/simple-illustration__bank-arrow.svg'; +import PinkBill from '@assets/images/simple-illustrations/simple-illustration__bill.svg'; +import ChatBubbles from '@assets/images/simple-illustrations/simple-illustration__chatbubbles.svg'; +import CoffeeMug from '@assets/images/simple-illustrations/simple-illustration__coffeemug.svg'; +import ConciergeBubble from '@assets/images/simple-illustrations/simple-illustration__concierge-bubble.svg'; +import ConciergeNew from '@assets/images/simple-illustrations/simple-illustration__concierge.svg'; +import CreditCardsNew from '@assets/images/simple-illustrations/simple-illustration__credit-cards.svg'; +import EmailAddress from '@assets/images/simple-illustrations/simple-illustration__email-address.svg'; +import HandEarth from '@assets/images/simple-illustrations/simple-illustration__handearth.svg'; +import InvoiceBlue from '@assets/images/simple-illustrations/simple-illustration__invoice.svg'; +import LockOpen from '@assets/images/simple-illustrations/simple-illustration__lockopen.svg'; +import Luggage from '@assets/images/simple-illustrations/simple-illustration__luggage.svg'; +import MoneyReceipts from '@assets/images/simple-illustrations/simple-illustration__money-receipts.svg'; +import MoneyBadge from '@assets/images/simple-illustrations/simple-illustration__moneybadge.svg'; +import MoneyIntoWallet from '@assets/images/simple-illustrations/simple-illustration__moneyintowallet.svg'; +import MoneyWings from '@assets/images/simple-illustrations/simple-illustration__moneywings.svg'; +import OpenSafe from '@assets/images/simple-illustrations/simple-illustration__opensafe.svg'; +import SanFrancisco from '@assets/images/simple-illustrations/simple-illustration__sanfrancisco.svg'; +import ShieldYellow from '@assets/images/simple-illustrations/simple-illustration__shield.svg'; +import ThumbsUpStars from '@assets/images/simple-illustrations/simple-illustration__thumbsupstars.svg'; +import TrackShoe from '@assets/images/simple-illustrations/simple-illustration__track-shoe.svg'; +import TreasureChest from '@assets/images/simple-illustrations/simple-illustration__treasurechest.svg'; export { Abracadabra, diff --git a/src/components/Icon/MCCIcons.js b/src/components/Icon/MCCIcons.js index a704f7d46bc6..922fb274f23d 100644 --- a/src/components/Icon/MCCIcons.js +++ b/src/components/Icon/MCCIcons.js @@ -1,15 +1,15 @@ -import Airlines from '../../../assets/images/MCCGroupIcons/MCC-Airlines.svg'; -import Commuter from '../../../assets/images/MCCGroupIcons/MCC-Commuter.svg'; -import Gas from '../../../assets/images/MCCGroupIcons/MCC-Gas.svg'; -import Goods from '../../../assets/images/MCCGroupIcons/MCC-Goods.svg'; -import Groceries from '../../../assets/images/MCCGroupIcons/MCC-Groceries.svg'; -import Hotel from '../../../assets/images/MCCGroupIcons/MCC-Hotel.svg'; -import Mail from '../../../assets/images/MCCGroupIcons/MCC-Mail.svg'; -import Meals from '../../../assets/images/MCCGroupIcons/MCC-Meals.svg'; -import Rental from '../../../assets/images/MCCGroupIcons/MCC-RentalCar.svg'; -import Services from '../../../assets/images/MCCGroupIcons/MCC-Services.svg'; -import Taxi from '../../../assets/images/MCCGroupIcons/MCC-Taxi.svg'; -import Miscellaneous from '../../../assets/images/MCCGroupIcons/MCC-Misc.svg'; -import Utilities from '../../../assets/images/MCCGroupIcons/MCC-Utilities.svg'; +import Airlines from '@assets/images/MCCGroupIcons/MCC-Airlines.svg'; +import Commuter from '@assets/images/MCCGroupIcons/MCC-Commuter.svg'; +import Gas from '@assets/images/MCCGroupIcons/MCC-Gas.svg'; +import Goods from '@assets/images/MCCGroupIcons/MCC-Goods.svg'; +import Groceries from '@assets/images/MCCGroupIcons/MCC-Groceries.svg'; +import Hotel from '@assets/images/MCCGroupIcons/MCC-Hotel.svg'; +import Mail from '@assets/images/MCCGroupIcons/MCC-Mail.svg'; +import Meals from '@assets/images/MCCGroupIcons/MCC-Meals.svg'; +import Miscellaneous from '@assets/images/MCCGroupIcons/MCC-Misc.svg'; +import Rental from '@assets/images/MCCGroupIcons/MCC-RentalCar.svg'; +import Services from '@assets/images/MCCGroupIcons/MCC-Services.svg'; +import Taxi from '@assets/images/MCCGroupIcons/MCC-Taxi.svg'; +import Utilities from '@assets/images/MCCGroupIcons/MCC-Utilities.svg'; export {Airlines, Commuter, Gas, Goods, Groceries, Hotel, Mail, Meals, Rental, Services, Taxi, Miscellaneous, Utilities}; diff --git a/src/components/Icon/WorkspaceDefaultAvatars.js b/src/components/Icon/WorkspaceDefaultAvatars.js index 0f5490b981bd..53d2ca088118 100644 --- a/src/components/Icon/WorkspaceDefaultAvatars.js +++ b/src/components/Icon/WorkspaceDefaultAvatars.js @@ -1,40 +1,40 @@ -import Workspace0 from '../../../assets/images/avatars/workspace/default-avatar_0.svg'; -import Workspace1 from '../../../assets/images/avatars/workspace/default-avatar_1.svg'; -import Workspace2 from '../../../assets/images/avatars/workspace/default-avatar_2.svg'; -import Workspace3 from '../../../assets/images/avatars/workspace/default-avatar_3.svg'; -import Workspace4 from '../../../assets/images/avatars/workspace/default-avatar_4.svg'; -import Workspace5 from '../../../assets/images/avatars/workspace/default-avatar_5.svg'; -import Workspace6 from '../../../assets/images/avatars/workspace/default-avatar_6.svg'; -import Workspace7 from '../../../assets/images/avatars/workspace/default-avatar_7.svg'; -import Workspace8 from '../../../assets/images/avatars/workspace/default-avatar_8.svg'; -import Workspace9 from '../../../assets/images/avatars/workspace/default-avatar_9.svg'; -import WorkspaceA from '../../../assets/images/avatars/workspace/default-avatar_a.svg'; -import WorkspaceB from '../../../assets/images/avatars/workspace/default-avatar_b.svg'; -import WorkspaceC from '../../../assets/images/avatars/workspace/default-avatar_c.svg'; -import WorkspaceD from '../../../assets/images/avatars/workspace/default-avatar_d.svg'; -import WorkspaceE from '../../../assets/images/avatars/workspace/default-avatar_e.svg'; -import WorkspaceF from '../../../assets/images/avatars/workspace/default-avatar_f.svg'; -import WorkspaceG from '../../../assets/images/avatars/workspace/default-avatar_g.svg'; -import WorkspaceH from '../../../assets/images/avatars/workspace/default-avatar_h.svg'; -import WorkspaceI from '../../../assets/images/avatars/workspace/default-avatar_i.svg'; -import WorkspaceJ from '../../../assets/images/avatars/workspace/default-avatar_j.svg'; -import WorkspaceK from '../../../assets/images/avatars/workspace/default-avatar_k.svg'; -import WorkspaceL from '../../../assets/images/avatars/workspace/default-avatar_l.svg'; -import WorkspaceM from '../../../assets/images/avatars/workspace/default-avatar_m.svg'; -import WorkspaceN from '../../../assets/images/avatars/workspace/default-avatar_n.svg'; -import WorkspaceO from '../../../assets/images/avatars/workspace/default-avatar_o.svg'; -import WorkspaceP from '../../../assets/images/avatars/workspace/default-avatar_p.svg'; -import WorkspaceQ from '../../../assets/images/avatars/workspace/default-avatar_q.svg'; -import WorkspaceR from '../../../assets/images/avatars/workspace/default-avatar_r.svg'; -import WorkspaceS from '../../../assets/images/avatars/workspace/default-avatar_s.svg'; -import WorkspaceT from '../../../assets/images/avatars/workspace/default-avatar_t.svg'; -import WorkspaceU from '../../../assets/images/avatars/workspace/default-avatar_u.svg'; -import WorkspaceV from '../../../assets/images/avatars/workspace/default-avatar_v.svg'; -import WorkspaceW from '../../../assets/images/avatars/workspace/default-avatar_w.svg'; -import WorkspaceX from '../../../assets/images/avatars/workspace/default-avatar_x.svg'; -import WorkspaceY from '../../../assets/images/avatars/workspace/default-avatar_y.svg'; -import WorkspaceZ from '../../../assets/images/avatars/workspace/default-avatar_z.svg'; -import WorkspaceBuilding from '../../../assets/images/avatars/workspace/default-avatar_building.svg'; +import Workspace0 from '@assets/images/avatars/workspace/default-avatar_0.svg'; +import Workspace1 from '@assets/images/avatars/workspace/default-avatar_1.svg'; +import Workspace2 from '@assets/images/avatars/workspace/default-avatar_2.svg'; +import Workspace3 from '@assets/images/avatars/workspace/default-avatar_3.svg'; +import Workspace4 from '@assets/images/avatars/workspace/default-avatar_4.svg'; +import Workspace5 from '@assets/images/avatars/workspace/default-avatar_5.svg'; +import Workspace6 from '@assets/images/avatars/workspace/default-avatar_6.svg'; +import Workspace7 from '@assets/images/avatars/workspace/default-avatar_7.svg'; +import Workspace8 from '@assets/images/avatars/workspace/default-avatar_8.svg'; +import Workspace9 from '@assets/images/avatars/workspace/default-avatar_9.svg'; +import WorkspaceA from '@assets/images/avatars/workspace/default-avatar_a.svg'; +import WorkspaceB from '@assets/images/avatars/workspace/default-avatar_b.svg'; +import WorkspaceBuilding from '@assets/images/avatars/workspace/default-avatar_building.svg'; +import WorkspaceC from '@assets/images/avatars/workspace/default-avatar_c.svg'; +import WorkspaceD from '@assets/images/avatars/workspace/default-avatar_d.svg'; +import WorkspaceE from '@assets/images/avatars/workspace/default-avatar_e.svg'; +import WorkspaceF from '@assets/images/avatars/workspace/default-avatar_f.svg'; +import WorkspaceG from '@assets/images/avatars/workspace/default-avatar_g.svg'; +import WorkspaceH from '@assets/images/avatars/workspace/default-avatar_h.svg'; +import WorkspaceI from '@assets/images/avatars/workspace/default-avatar_i.svg'; +import WorkspaceJ from '@assets/images/avatars/workspace/default-avatar_j.svg'; +import WorkspaceK from '@assets/images/avatars/workspace/default-avatar_k.svg'; +import WorkspaceL from '@assets/images/avatars/workspace/default-avatar_l.svg'; +import WorkspaceM from '@assets/images/avatars/workspace/default-avatar_m.svg'; +import WorkspaceN from '@assets/images/avatars/workspace/default-avatar_n.svg'; +import WorkspaceO from '@assets/images/avatars/workspace/default-avatar_o.svg'; +import WorkspaceP from '@assets/images/avatars/workspace/default-avatar_p.svg'; +import WorkspaceQ from '@assets/images/avatars/workspace/default-avatar_q.svg'; +import WorkspaceR from '@assets/images/avatars/workspace/default-avatar_r.svg'; +import WorkspaceS from '@assets/images/avatars/workspace/default-avatar_s.svg'; +import WorkspaceT from '@assets/images/avatars/workspace/default-avatar_t.svg'; +import WorkspaceU from '@assets/images/avatars/workspace/default-avatar_u.svg'; +import WorkspaceV from '@assets/images/avatars/workspace/default-avatar_v.svg'; +import WorkspaceW from '@assets/images/avatars/workspace/default-avatar_w.svg'; +import WorkspaceX from '@assets/images/avatars/workspace/default-avatar_x.svg'; +import WorkspaceY from '@assets/images/avatars/workspace/default-avatar_y.svg'; +import WorkspaceZ from '@assets/images/avatars/workspace/default-avatar_z.svg'; export { Workspace0, diff --git a/src/components/Icon/index.js b/src/components/Icon/index.js index 5cdd5c79704d..d4d95ca117d4 100644 --- a/src/components/Icon/index.js +++ b/src/components/Icon/index.js @@ -1,10 +1,10 @@ +import PropTypes from 'prop-types'; import React, {PureComponent} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import themeColors from '../../styles/themes/default'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; import IconWrapperStyles from './IconWrapperStyles'; const propTypes = { diff --git a/src/components/Icon/svgs/LoungeAccessIcon.js b/src/components/Icon/svgs/LoungeAccessIcon.js index b00fbb312c85..9117fb24bb42 100644 --- a/src/components/Icon/svgs/LoungeAccessIcon.js +++ b/src/components/Icon/svgs/LoungeAccessIcon.js @@ -1,7 +1,7 @@ +import PropTypes from 'prop-types'; import * as React from 'react'; import Svg, {G, Path, Polygon} from 'react-native-svg'; -import PropTypes from 'prop-types'; -import themeColors from '../../../styles/themes/default'; +import themeColors from '@styles/themes/default'; const propTypes = { /** The fill color for the icon. Can be hex, rgb, rgba, or valid react-native named color such as 'red' or 'blue'. */ diff --git a/src/components/IllustratedHeaderPageLayout.js b/src/components/IllustratedHeaderPageLayout.js index c45f5e2452dd..54a3b0e7b07c 100644 --- a/src/components/IllustratedHeaderPageLayout.js +++ b/src/components/IllustratedHeaderPageLayout.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import Lottie from './Lottie'; -import headerWithBackButtonPropTypes from './HeaderWithBackButton/headerWithBackButtonPropTypes'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; +import React from 'react'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; import HeaderPageLayout from './HeaderPageLayout'; +import headerWithBackButtonPropTypes from './HeaderWithBackButton/headerWithBackButtonPropTypes'; +import Lottie from './Lottie'; const propTypes = { ...headerWithBackButtonPropTypes, diff --git a/src/components/Image/imagePropTypes.js b/src/components/Image/imagePropTypes.js index c02e48eef659..78bd48ba47ec 100644 --- a/src/components/Image/imagePropTypes.js +++ b/src/components/Image/imagePropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; -import stylePropTypes from '../../styles/stylePropTypes'; -import sourcePropTypes from './sourcePropTypes'; +import stylePropTypes from '@styles/stylePropTypes'; import RESIZE_MODES from './resizeModes'; +import sourcePropTypes from './sourcePropTypes'; const imagePropTypes = { /** Styles for the Image */ diff --git a/src/components/Image/index.js b/src/components/Image/index.js index 7434c16c6491..c2800511ff45 100644 --- a/src/components/Image/index.js +++ b/src/components/Image/index.js @@ -1,9 +1,9 @@ +import lodashGet from 'lodash/get'; import React, {useEffect, useMemo} from 'react'; import {Image as RNImage} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; import {defaultProps, imagePropTypes} from './imagePropTypes'; import RESIZE_MODES from './resizeModes'; diff --git a/src/components/Image/index.native.js b/src/components/Image/index.native.js index 9d9ad600b1d4..52ac503081e6 100644 --- a/src/components/Image/index.native.js +++ b/src/components/Image/index.native.js @@ -1,9 +1,9 @@ +import lodashGet from 'lodash/get'; import React from 'react'; import RNFastImage from 'react-native-fast-image'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import {defaultProps, imagePropTypes} from './imagePropTypes'; import RESIZE_MODES from './resizeModes'; diff --git a/src/components/ImageView/index.js b/src/components/ImageView/index.js index 1d90a5723016..09656d700917 100644 --- a/src/components/ImageView/index.js +++ b/src/components/ImageView/index.js @@ -1,13 +1,13 @@ -import React, {useState, useEffect, useRef, useCallback} from 'react'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; import {View} from 'react-native'; -import Image from '../Image'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; -import FullscreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import CONST from '../../CONST'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Image from '@components/Image'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { /** Whether source url requires authentication */ diff --git a/src/components/ImageView/index.native.js b/src/components/ImageView/index.native.js index b365f507a4fc..dd17e2d27a4e 100644 --- a/src/components/ImageView/index.native.js +++ b/src/components/ImageView/index.native.js @@ -1,13 +1,13 @@ -import React, {useState, useRef, useEffect} from 'react'; import PropTypes from 'prop-types'; -import {View, PanResponder} from 'react-native'; +import React, {useEffect, useRef, useState} from 'react'; +import {PanResponder, View} from 'react-native'; import ImageZoom from 'react-native-image-pan-zoom'; import _ from 'underscore'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; -import FullscreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import Image from '../Image'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Image from '@components/Image'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; /** * On the native layer, we use a image library to handle zoom functionality diff --git a/src/components/ImageWithSizeCalculation.js b/src/components/ImageWithSizeCalculation.js index 6aa87d07f23e..5db78e0c1276 100644 --- a/src/components/ImageWithSizeCalculation.js +++ b/src/components/ImageWithSizeCalculation.js @@ -1,9 +1,9 @@ -import _ from 'underscore'; -import React, {useState, useRef, useEffect} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; -import Log from '../libs/Log'; -import styles from '../styles/styles'; +import React, {useEffect, useRef, useState} from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import styles from '@styles/styles'; import FullscreenLoadingIndicator from './FullscreenLoadingIndicator'; import Image from './Image'; diff --git a/src/components/Indicator.js b/src/components/Indicator.js index 24eb20ad5eee..046c3ca523e1 100644 --- a/src/components/Indicator.js +++ b/src/components/Indicator.js @@ -1,21 +1,21 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {StyleSheet, View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import styles from '../styles/styles'; -import ONYXKEYS from '../ONYXKEYS'; -import policyMemberPropType from '../pages/policyMemberPropType'; +import _ from 'underscore'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as UserUtils from '@libs/UserUtils'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import walletTermsPropTypes from '@pages/EnablePayments/walletTermsPropTypes'; +import policyMemberPropType from '@pages/policyMemberPropType'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import {policyPropTypes} from '@pages/workspace/withPolicy'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import ONYXKEYS from '@src/ONYXKEYS'; import bankAccountPropTypes from './bankAccountPropTypes'; import cardPropTypes from './cardPropTypes'; -import userWalletPropTypes from '../pages/EnablePayments/userWalletPropTypes'; -import {policyPropTypes} from '../pages/workspace/withPolicy'; -import walletTermsPropTypes from '../pages/EnablePayments/walletTermsPropTypes'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import * as PaymentMethods from '../libs/actions/PaymentMethods'; -import * as ReimbursementAccountProps from '../pages/ReimbursementAccount/reimbursementAccountPropTypes'; -import * as UserUtils from '../libs/UserUtils'; -import themeColors from '../styles/themes/default'; const propTypes = { /* Onyx Props */ diff --git a/src/components/InlineCodeBlock/WrappedText.js b/src/components/InlineCodeBlock/WrappedText.js index 14bab44f2126..e28f0f6b1f55 100644 --- a/src/components/InlineCodeBlock/WrappedText.js +++ b/src/components/InlineCodeBlock/WrappedText.js @@ -1,10 +1,10 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React, {Fragment} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import Text from '../Text'; -import CONST from '../../CONST'; +import _ from 'underscore'; +import Text from '@components/Text'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; /** * Breaks the text into matrix diff --git a/src/components/InlineCodeBlock/index.js b/src/components/InlineCodeBlock/index.js index 7610ba4fa583..84666931d9b2 100644 --- a/src/components/InlineCodeBlock/index.js +++ b/src/components/InlineCodeBlock/index.js @@ -1,7 +1,7 @@ -import React from 'react'; import _ from 'lodash'; +import React from 'react'; +import Text from '@components/Text'; import inlineCodeBlockPropTypes from './inlineCodeBlockPropTypes'; -import Text from '../Text'; function InlineCodeBlock(props) { const TDefaultRenderer = props.TDefaultRenderer; diff --git a/src/components/InlineCodeBlock/index.native.js b/src/components/InlineCodeBlock/index.native.js index 2aa718832180..ff92ebbbcb9e 100644 --- a/src/components/InlineCodeBlock/index.native.js +++ b/src/components/InlineCodeBlock/index.native.js @@ -1,7 +1,7 @@ import React from 'react'; -import styles from '../../styles/styles'; -import WrappedText from './WrappedText'; +import styles from '@styles/styles'; import inlineCodeBlockPropTypes from './inlineCodeBlockPropTypes'; +import WrappedText from './WrappedText'; function InlineCodeBlock(props) { const TDefaultRenderer = props.TDefaultRenderer; diff --git a/src/components/InlineErrorText.js b/src/components/InlineErrorText.js index ea701a3f6e8e..80438eea8b5f 100644 --- a/src/components/InlineErrorText.js +++ b/src/components/InlineErrorText.js @@ -1,7 +1,7 @@ -import _ from 'underscore'; -import React from 'react'; import PropTypes from 'prop-types'; -import styles from '../styles/styles'; +import React from 'react'; +import _ from 'underscore'; +import styles from '@styles/styles'; import Text from './Text'; const propTypes = { diff --git a/src/components/InlineSystemMessage.tsx b/src/components/InlineSystemMessage.tsx index 31d102590681..e9de0111cd23 100644 --- a/src/components/InlineSystemMessage.tsx +++ b/src/components/InlineSystemMessage.tsx @@ -1,10 +1,10 @@ import React from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; -import theme from '../styles/themes/default'; -import Text from './Text'; -import * as Expensicons from './Icon/Expensicons'; +import styles from '@styles/styles'; +import theme from '@styles/themes/default'; import Icon from './Icon'; +import * as Expensicons from './Icon/Expensicons'; +import Text from './Text'; type InlineSystemMessageProps = { /** Error to display */ diff --git a/src/components/InvertedFlatList/BaseInvertedFlatList.js b/src/components/InvertedFlatList/BaseInvertedFlatList.js index 044143774dd6..802ae373d22a 100644 --- a/src/components/InvertedFlatList/BaseInvertedFlatList.js +++ b/src/components/InvertedFlatList/BaseInvertedFlatList.js @@ -1,10 +1,10 @@ +import PropTypes from 'prop-types'; import React, {forwardRef, useCallback, useRef} from 'react'; -import {View, FlatList as NativeFlatlist} from 'react-native'; +import {FlatList as NativeFlatlist, View} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import * as CollectionUtils from '../../libs/CollectionUtils'; -import FlatList from '../FlatList'; -import variables from '../../styles/variables'; +import FlatList from '@components/FlatList'; +import * as CollectionUtils from '@libs/CollectionUtils'; +import variables from '@styles/variables'; const propTypes = { /** Same as FlatList can be any array of anything */ diff --git a/src/components/InvertedFlatList/CellRendererComponent.js b/src/components/InvertedFlatList/CellRendererComponent.js index 77397aeb4610..2b2d214000bf 100644 --- a/src/components/InvertedFlatList/CellRendererComponent.js +++ b/src/components/InvertedFlatList/CellRendererComponent.js @@ -1,6 +1,6 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; const propTypes = { /** Position index of the list item in a list view */ diff --git a/src/components/InvertedFlatList/index.js b/src/components/InvertedFlatList/index.js index d328ca93575b..14b781759904 100644 --- a/src/components/InvertedFlatList/index.js +++ b/src/components/InvertedFlatList/index.js @@ -1,10 +1,10 @@ -import React, {forwardRef, useEffect, useRef} from 'react'; import PropTypes from 'prop-types'; +import React, {forwardRef, useEffect, useRef} from 'react'; import {DeviceEventEmitter, FlatList, StyleSheet} from 'react-native'; import _ from 'underscore'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import BaseInvertedFlatList from './BaseInvertedFlatList'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; const propTypes = { /** Passed via forwardRef so we can access the FlatList ref */ diff --git a/src/components/KYCWall/BaseKYCWall.js b/src/components/KYCWall/BaseKYCWall.js index ccee8bc4e6a0..d55417a6190a 100644 --- a/src/components/KYCWall/BaseKYCWall.js +++ b/src/components/KYCWall/BaseKYCWall.js @@ -1,19 +1,19 @@ -import _ from 'underscore'; +import lodashGet from 'lodash/get'; import React from 'react'; -import {withOnyx} from 'react-native-onyx'; import {Dimensions} from 'react-native'; -import lodashGet from 'lodash/get'; -import CONST from '../../CONST'; -import Navigation from '../../libs/Navigation/Navigation'; -import AddPaymentMethodMenu from '../AddPaymentMethodMenu'; -import getClickedTargetLocation from '../../libs/getClickedTargetLocation'; -import * as PaymentUtils from '../../libs/PaymentUtils'; -import * as PaymentMethods from '../../libs/actions/PaymentMethods'; -import ONYXKEYS from '../../ONYXKEYS'; -import Log from '../../libs/Log'; -import {propTypes, defaultProps} from './kycWallPropTypes'; -import * as Wallet from '../../libs/actions/Wallet'; -import * as ReportUtils from '../../libs/ReportUtils'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import AddPaymentMethodMenu from '@components/AddPaymentMethodMenu'; +import getClickedTargetLocation from '@libs/getClickedTargetLocation'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PaymentUtils from '@libs/PaymentUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import * as Wallet from '@userActions/Wallet'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './kycWallPropTypes'; // This component allows us to block various actions by forcing the user to first add a default payment method and successfully make it through our Know Your Customer flow // before continuing to take whatever action they originally intended to take. It requires a button as a child and a native event so we can get the coordinates and use it diff --git a/src/components/KYCWall/index.js b/src/components/KYCWall/index.js index 81e7a2d37481..49329c73d474 100644 --- a/src/components/KYCWall/index.js +++ b/src/components/KYCWall/index.js @@ -1,6 +1,6 @@ import React from 'react'; -import {propTypes, defaultProps} from './kycWallPropTypes'; import BaseKYCWall from './BaseKYCWall'; +import {defaultProps, propTypes} from './kycWallPropTypes'; function KYCWall(props) { return ( diff --git a/src/components/KYCWall/kycWallPropTypes.js b/src/components/KYCWall/kycWallPropTypes.js index b585535784dc..58db2c1c1940 100644 --- a/src/components/KYCWall/kycWallPropTypes.js +++ b/src/components/KYCWall/kycWallPropTypes.js @@ -1,12 +1,12 @@ -import _ from 'underscore'; import PropTypes from 'prop-types'; -import userWalletPropTypes from '../../pages/EnablePayments/userWalletPropTypes'; -import bankAccountPropTypes from '../bankAccountPropTypes'; -import cardPropTypes from '../cardPropTypes'; -import iouReportPropTypes from '../../pages/iouReportPropTypes'; -import reimbursementAccountPropTypes from '../../pages/ReimbursementAccount/ReimbursementAccountDraftPropTypes'; -import walletTermsPropTypes from '../../pages/EnablePayments/walletTermsPropTypes'; -import CONST from '../../CONST'; +import _ from 'underscore'; +import bankAccountPropTypes from '@components/bankAccountPropTypes'; +import cardPropTypes from '@components/cardPropTypes'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import walletTermsPropTypes from '@pages/EnablePayments/walletTermsPropTypes'; +import iouReportPropTypes from '@pages/iouReportPropTypes'; +import reimbursementAccountPropTypes from '@pages/ReimbursementAccount/ReimbursementAccountDraftPropTypes'; +import CONST from '@src/CONST'; const propTypes = { /** Route for the Add Bank Account screen for a given navigation stack */ diff --git a/src/components/KeyboardSpacer/BaseKeyboardSpacer.js b/src/components/KeyboardSpacer/BaseKeyboardSpacer.js index 2066f3492373..adab3e2ea66d 100644 --- a/src/components/KeyboardSpacer/BaseKeyboardSpacer.js +++ b/src/components/KeyboardSpacer/BaseKeyboardSpacer.js @@ -1,7 +1,7 @@ -import React, {useState, useEffect, useCallback} from 'react'; +import React, {useCallback, useEffect, useState} from 'react'; import {Dimensions, Keyboard, View} from 'react-native'; -import * as StyleUtils from '../../styles/StyleUtils'; -import {propTypes, defaultProps} from './BaseKeyboardSpacerPropTypes'; +import * as StyleUtils from '@styles/StyleUtils'; +import {defaultProps, propTypes} from './BaseKeyboardSpacerPropTypes'; function BaseKeyboardSpacer(props) { const [keyboardSpace, setKeyboardSpace] = useState(0); diff --git a/src/components/KeyboardSpacer/index.android.js b/src/components/KeyboardSpacer/index.android.js index 15755be70e31..d7c57f7d73c2 100644 --- a/src/components/KeyboardSpacer/index.android.js +++ b/src/components/KeyboardSpacer/index.android.js @@ -3,9 +3,9 @@ * view up with the keyboard allowing the user to see what they are typing. */ import React from 'react'; -import StatusBar from '../../libs/StatusBar'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import StatusBar from '@libs/StatusBar'; import BaseKeyboardSpacer from './BaseKeyboardSpacer'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions'; function KeyboardSpacer() { return ( diff --git a/src/components/KeyboardSpacer/index.ios.js b/src/components/KeyboardSpacer/index.ios.js index 63cae305c362..612ef75c290f 100644 --- a/src/components/KeyboardSpacer/index.ios.js +++ b/src/components/KeyboardSpacer/index.ios.js @@ -3,10 +3,10 @@ * keyboard allowing the user to see what they are typing. */ import React from 'react'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import BaseKeyboardSpacer from './BaseKeyboardSpacer'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions'; -import * as StyleUtils from '../../styles/StyleUtils'; -import CONST from '../../CONST'; function KeyboardSpacer(props) { return ( diff --git a/src/components/LHNOptionsList/LHNOptionsList.js b/src/components/LHNOptionsList/LHNOptionsList.js index 5e07b487c4f7..a06b3314e5a9 100644 --- a/src/components/LHNOptionsList/LHNOptionsList.js +++ b/src/components/LHNOptionsList/LHNOptionsList.js @@ -2,9 +2,9 @@ import PropTypes from 'prop-types'; import React from 'react'; import {FlatList, View} from 'react-native'; import _ from 'underscore'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import OptionRowLHNDataWithFocus from './OptionRowLHNDataWithFocus'; const propTypes = { diff --git a/src/components/LHNOptionsList/OptionRowLHN.js b/src/components/LHNOptionsList/OptionRowLHN.js index 2b992e462e34..f83e0b834287 100644 --- a/src/components/LHNOptionsList/OptionRowLHN.js +++ b/src/components/LHNOptionsList/OptionRowLHN.js @@ -1,34 +1,34 @@ -import _ from 'underscore'; -import React, {useState, useRef, useCallback} from 'react'; -import PropTypes from 'prop-types'; -import {View, StyleSheet} from 'react-native'; -import lodashGet from 'lodash/get'; import {useFocusEffect} from '@react-navigation/native'; -import * as optionRowStyles from '../../styles/optionRowStyles'; -import styles from '../../styles/styles'; -import * as StyleUtils from '../../styles/StyleUtils'; -import DateUtils from '../../libs/DateUtils'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import MultipleAvatars from '../MultipleAvatars'; -import Hoverable from '../Hoverable'; -import DisplayNames from '../DisplayNames'; -import Text from '../Text'; -import SubscriptAvatar from '../SubscriptAvatar'; -import CONST from '../../CONST'; -import themeColors from '../../styles/themes/default'; -import OfflineWithFeedback from '../OfflineWithFeedback'; -import PressableWithSecondaryInteraction from '../PressableWithSecondaryInteraction'; -import * as ReportActionContextMenu from '../../pages/home/report/ContextMenu/ReportActionContextMenu'; -import * as ContextMenuActions from '../../pages/home/report/ContextMenu/ContextMenuActions'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import * as ReportUtils from '../../libs/ReportUtils'; -import useLocalize from '../../hooks/useLocalize'; -import Permissions from '../../libs/Permissions'; -import Tooltip from '../Tooltip'; -import DomUtils from '../../libs/DomUtils'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import ReportActionComposeFocusManager from '../../libs/ReportActionComposeFocusManager'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useRef, useState} from 'react'; +import {StyleSheet, View} from 'react-native'; +import _ from 'underscore'; +import DisplayNames from '@components/DisplayNames'; +import Hoverable from '@components/Hoverable'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MultipleAvatars from '@components/MultipleAvatars'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import PressableWithSecondaryInteraction from '@components/PressableWithSecondaryInteraction'; +import SubscriptAvatar from '@components/SubscriptAvatar'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import DateUtils from '@libs/DateUtils'; +import DomUtils from '@libs/DomUtils'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as ContextMenuActions from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import * as optionRowStyles from '@styles/optionRowStyles'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; const propTypes = { /** Style for hovered state */ diff --git a/src/components/LHNOptionsList/OptionRowLHNData.js b/src/components/LHNOptionsList/OptionRowLHNData.js index e93e3690138e..ebba2ffe0587 100644 --- a/src/components/LHNOptionsList/OptionRowLHNData.js +++ b/src/components/LHNOptionsList/OptionRowLHNData.js @@ -1,21 +1,20 @@ -import {withOnyx} from 'react-native-onyx'; +import {deepEqual} from 'fast-equals'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import PropTypes from 'prop-types'; -import React, {useEffect, useRef, useMemo} from 'react'; -import {deepEqual} from 'fast-equals'; -import SidebarUtils from '../../libs/SidebarUtils'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import OptionRowLHN, {propTypes as basePropTypes, defaultProps as baseDefaultProps} from './OptionRowLHN'; -import * as Report from '../../libs/actions/Report'; -import * as UserUtils from '../../libs/UserUtils'; -import * as ReportActionsUtils from '../../libs/ReportActionsUtils'; -import * as TransactionUtils from '../../libs/TransactionUtils'; - -import participantPropTypes from '../participantPropTypes'; -import CONST from '../../CONST'; -import reportActionPropTypes from '../../pages/home/report/reportActionPropTypes'; +import React, {useEffect, useMemo, useRef} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import participantPropTypes from '@components/participantPropTypes'; +import compose from '@libs/compose'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import SidebarUtils from '@libs/SidebarUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import * as UserUtils from '@libs/UserUtils'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import OptionRowLHN, {defaultProps as baseDefaultProps, propTypes as basePropTypes} from './OptionRowLHN'; const propTypes = { /** Whether row should be focused */ diff --git a/src/components/LHNOptionsList/OptionRowLHNDataWithFocus.js b/src/components/LHNOptionsList/OptionRowLHNDataWithFocus.js index 5e58be79e088..67e90bcbb0e0 100644 --- a/src/components/LHNOptionsList/OptionRowLHNDataWithFocus.js +++ b/src/components/LHNOptionsList/OptionRowLHNDataWithFocus.js @@ -1,6 +1,6 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withCurrentReportID, {withCurrentReportIDPropTypes, withCurrentReportIDDefaultProps} from '../withCurrentReportID'; +import React from 'react'; +import withCurrentReportID, {withCurrentReportIDDefaultProps, withCurrentReportIDPropTypes} from '@components/withCurrentReportID'; import OptionRowLHNData from './OptionRowLHNData'; const propTypes = { diff --git a/src/components/LocaleContextProvider.js b/src/components/LocaleContextProvider.js index b8838f253e74..5fbb7716befe 100644 --- a/src/components/LocaleContextProvider.js +++ b/src/components/LocaleContextProvider.js @@ -1,17 +1,16 @@ -import React, {createContext, useMemo} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {createContext, useMemo} from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; - -import ONYXKEYS from '../ONYXKEYS'; -import * as Localize from '../libs/Localize'; -import DateUtils from '../libs/DateUtils'; -import * as NumberFormatUtils from '../libs/NumberFormatUtils'; -import * as LocaleDigitUtils from '../libs/LocaleDigitUtils'; -import CONST from '../CONST'; -import compose from '../libs/compose'; +import compose from '@libs/compose'; +import DateUtils from '@libs/DateUtils'; +import * as LocaleDigitUtils from '@libs/LocaleDigitUtils'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import * as Localize from '@libs/Localize'; +import * as NumberFormatUtils from '@libs/NumberFormatUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import withCurrentUserPersonalDetails from './withCurrentUserPersonalDetails'; -import * as LocalePhoneNumber from '../libs/LocalePhoneNumber'; const LocaleContext = createContext(null); diff --git a/src/components/LocalePicker.js b/src/components/LocalePicker.js index 435f88e51e53..2c5a6e7b7ec6 100644 --- a/src/components/LocalePicker.js +++ b/src/components/LocalePicker.js @@ -1,15 +1,15 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import compose from '../libs/compose'; -import * as App from '../libs/actions/App'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; +import _ from 'underscore'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as App from '@userActions/App'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Picker from './Picker'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** Indicates which locale the user currently has selected */ diff --git a/src/components/LocationErrorMessage/BaseLocationErrorMessage.js b/src/components/LocationErrorMessage/BaseLocationErrorMessage.js index 3a638f3e999e..786588993cd8 100644 --- a/src/components/LocationErrorMessage/BaseLocationErrorMessage.js +++ b/src/components/LocationErrorMessage/BaseLocationErrorMessage.js @@ -1,16 +1,16 @@ import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import CONST from '../../CONST'; -import colors from '../../styles/colors'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import Text from '../Text'; -import TextLink from '../TextLink'; -import Tooltip from '../Tooltip'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import colors from '@styles/colors'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import * as locationErrorMessagePropTypes from './locationErrorMessagePropTypes'; const propTypes = { diff --git a/src/components/LocationErrorMessage/index.js b/src/components/LocationErrorMessage/index.js index e8ec402401cf..60fb4489799e 100644 --- a/src/components/LocationErrorMessage/index.js +++ b/src/components/LocationErrorMessage/index.js @@ -1,6 +1,6 @@ import React from 'react'; import {Linking} from 'react-native'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import BaseLocationErrorMessage from './BaseLocationErrorMessage'; import * as locationErrorMessagePropTypes from './locationErrorMessagePropTypes'; diff --git a/src/components/Lottie/Lottie.tsx b/src/components/Lottie/Lottie.tsx index 97c7e8fffdd1..cf689224278f 100644 --- a/src/components/Lottie/Lottie.tsx +++ b/src/components/Lottie/Lottie.tsx @@ -1,6 +1,6 @@ -import React, {forwardRef} from 'react'; import LottieView, {LottieViewProps} from 'lottie-react-native'; -import styles from '../../styles/styles'; +import React, {forwardRef} from 'react'; +import styles from '@styles/styles'; const Lottie = forwardRef((props: LottieViewProps, ref) => ( = styles.mapDirectionLayer.layout; const layerPointStyle: Record = styles.mapDirectionLayer.paint; diff --git a/src/components/MapView/MapView.tsx b/src/components/MapView/MapView.tsx index 5f791112da62..c91dc63a3bd1 100644 --- a/src/components/MapView/MapView.tsx +++ b/src/components/MapView/MapView.tsx @@ -1,15 +1,13 @@ -import {View} from 'react-native'; import {useFocusEffect, useNavigation} from '@react-navigation/native'; import Mapbox, {MapState, MarkerView, setAccessToken} from '@rnmapbox/maps'; import {forwardRef, memo, useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react'; -import styles from '../../styles/styles'; - +import {View} from 'react-native'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import Direction from './Direction'; +import {MapViewHandle, MapViewProps} from './MapViewTypes'; import responder from './responder'; import utils from './utils'; -import Direction from './Direction'; -import CONST from '../../CONST'; - -import {MapViewProps, MapViewHandle} from './MapViewTypes'; const MapView = forwardRef(({accessToken, style, mapPadding, styleURL, pitchEnabled, initialState, waypoints, directionCoordinates, onMapReady}, ref) => { const cameraRef = useRef(null); diff --git a/src/components/MapView/MapView.web.tsx b/src/components/MapView/MapView.web.tsx index 78c5a9175594..fe240c1f5121 100644 --- a/src/components/MapView/MapView.web.tsx +++ b/src/components/MapView/MapView.web.tsx @@ -2,22 +2,18 @@ // This is why we have separate components for web and native to handle the specific implementations. // For the web version, we use the Mapbox Web library called react-map-gl, while for the native mobile version, // we utilize a different Mapbox library @rnmapbox/maps tailored for mobile development. - +import mapboxgl from 'mapbox-gl'; +import 'mapbox-gl/dist/mapbox-gl.css'; import React, {forwardRef, useCallback, useEffect, useImperativeHandle, useState} from 'react'; -import {View} from 'react-native'; import Map, {MapRef, Marker} from 'react-map-gl'; -import mapboxgl from 'mapbox-gl'; - -import responder from './responder'; -import utils from './utils'; - -import CONST from '../../CONST'; -import * as StyleUtils from '../../styles/StyleUtils'; -import themeColors from '../../styles/themes/default'; +import {View} from 'react-native'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import Direction from './Direction'; import {MapViewHandle, MapViewProps} from './MapViewTypes'; - -import 'mapbox-gl/dist/mapbox-gl.css'; +import responder from './responder'; +import utils from './utils'; const MapView = forwardRef( ({style, styleURL, waypoints, mapPadding, accessToken, directionCoordinates, initialState = {location: CONST.MAPBOX.DEFAULT_COORDINATE, zoom: CONST.MAPBOX.DEFAULT_ZOOM}}, ref) => { diff --git a/src/components/MapView/PendingMapView.tsx b/src/components/MapView/PendingMapView.tsx index d97d4aaee16f..8a6799035fec 100644 --- a/src/components/MapView/PendingMapView.tsx +++ b/src/components/MapView/PendingMapView.tsx @@ -1,12 +1,12 @@ +import _ from 'lodash'; import React from 'react'; import {View} from 'react-native'; -import _ from 'lodash'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; import {PendingMapViewProps} from './MapViewTypes'; -import BlockingView from '../BlockingViews/BlockingView'; -import * as Expensicons from '../Icon/Expensicons'; function PendingMapView({title = '', subtitle = '', style}: PendingMapViewProps) { const hasTextContent = !_.isEmpty(title) || !_.isEmpty(subtitle); diff --git a/src/components/MapView/responder/index.ts b/src/components/MapView/responder/index.ts index c4c325444f70..f417f7769ae8 100644 --- a/src/components/MapView/responder/index.ts +++ b/src/components/MapView/responder/index.ts @@ -1,3 +1,3 @@ -import SwipeInterceptPanResponder from '../../SwipeInterceptPanResponder'; +import SwipeInterceptPanResponder from '@components/SwipeInterceptPanResponder'; export default SwipeInterceptPanResponder; diff --git a/src/components/MentionSuggestions.js b/src/components/MentionSuggestions.js index 6c0803ca9d64..d18b8947e68d 100644 --- a/src/components/MentionSuggestions.js +++ b/src/components/MentionSuggestions.js @@ -1,16 +1,16 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import * as StyleUtils from '../styles/StyleUtils'; -import Text from './Text'; -import CONST from '../CONST'; -import Avatar from './Avatar'; +import getStyledTextArray from '@libs/GetStyledTextArray'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import AutoCompleteSuggestions from './AutoCompleteSuggestions'; -import getStyledTextArray from '../libs/GetStyledTextArray'; +import Avatar from './Avatar'; import avatarPropTypes from './avatarPropTypes'; +import Text from './Text'; const propTypes = { /** The index of the highlighted mention */ diff --git a/src/components/MenuItem.js b/src/components/MenuItem.js index 3c52c41f1992..08535f1724fb 100644 --- a/src/components/MenuItem.js +++ b/src/components/MenuItem.js @@ -1,31 +1,31 @@ -import _ from 'underscore'; +import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import React, {useEffect, useMemo} from 'react'; import {View} from 'react-native'; -import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import Text from './Text'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import * as StyleUtils from '../styles/StyleUtils'; -import Icon from './Icon'; -import * as Expensicons from './Icon/Expensicons'; -import getButtonState from '../libs/getButtonState'; -import convertToLTR from '../libs/convertToLTR'; +import _ from 'underscore'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import ControlSelection from '@libs/ControlSelection'; +import convertToLTR from '@libs/convertToLTR'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; import Avatar from './Avatar'; import Badge from './Badge'; -import CONST from '../CONST'; +import DisplayNames from './DisplayNames'; +import Hoverable from './Hoverable'; +import Icon from './Icon'; +import * as Expensicons from './Icon/Expensicons'; +import * as defaultWorkspaceAvatars from './Icon/WorkspaceDefaultAvatars'; import menuItemPropTypes from './menuItemPropTypes'; -import SelectCircle from './SelectCircle'; import MultipleAvatars from './MultipleAvatars'; -import * as defaultWorkspaceAvatars from './Icon/WorkspaceDefaultAvatars'; import PressableWithSecondaryInteraction from './PressableWithSecondaryInteraction'; -import * as DeviceCapabilities from '../libs/DeviceCapabilities'; -import ControlSelection from '../libs/ControlSelection'; -import variables from '../styles/variables'; -import * as Session from '../libs/actions/Session'; -import Hoverable from './Hoverable'; -import useWindowDimensions from '../hooks/useWindowDimensions'; import RenderHTML from './RenderHTML'; -import DisplayNames from './DisplayNames'; +import SelectCircle from './SelectCircle'; +import Text from './Text'; const propTypes = menuItemPropTypes; diff --git a/src/components/MenuItemList.js b/src/components/MenuItemList.js index 19253ce8bd94..b9f2e6fc228b 100644 --- a/src/components/MenuItemList.js +++ b/src/components/MenuItemList.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import useSingleExecution from '../hooks/useSingleExecution'; +import useSingleExecution from '@hooks/useSingleExecution'; +import {CONTEXT_MENU_TYPES} from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; import MenuItem from './MenuItem'; import menuItemPropTypes from './menuItemPropTypes'; -import * as ReportActionContextMenu from '../pages/home/report/ContextMenu/ReportActionContextMenu'; -import {CONTEXT_MENU_TYPES} from '../pages/home/report/ContextMenu/ContextMenuActions'; const propTypes = { /** An array of props that are pass to individual MenuItem components */ diff --git a/src/components/MenuItemWithTopDescription.js b/src/components/MenuItemWithTopDescription.js index 94f44a1869b6..8215b7eb3a19 100644 --- a/src/components/MenuItemWithTopDescription.js +++ b/src/components/MenuItemWithTopDescription.js @@ -1,6 +1,6 @@ import React from 'react'; -import menuItemPropTypes from './menuItemPropTypes'; import MenuItem from './MenuItem'; +import menuItemPropTypes from './menuItemPropTypes'; const propTypes = menuItemPropTypes; diff --git a/src/components/MessagesRow.js b/src/components/MessagesRow.js index 8a699265bb56..b843e0dfa61e 100644 --- a/src/components/MessagesRow.js +++ b/src/components/MessagesRow.js @@ -1,17 +1,17 @@ -import React from 'react'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; +import DotIndicatorMessage from './DotIndicatorMessage'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import DotIndicatorMessage from './DotIndicatorMessage'; -import Tooltip from './Tooltip'; -import CONST from '../CONST'; -import * as StyleUtils from '../styles/StyleUtils'; import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; -import stylePropTypes from '../styles/stylePropTypes'; -import useLocalize from '../hooks/useLocalize'; +import Tooltip from './Tooltip'; const propTypes = { /* The messages to display */ diff --git a/src/components/Modal/BaseModal.js b/src/components/Modal/BaseModal.js index d1a906efc951..6ed3b16c676d 100644 --- a/src/components/Modal/BaseModal.js +++ b/src/components/Modal/BaseModal.js @@ -1,20 +1,20 @@ +import PropTypes from 'prop-types'; import React, {forwardRef, useCallback, useEffect, useMemo, useRef} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import ReactNativeModal from 'react-native-modal'; import {useSafeAreaInsets} from 'react-native-safe-area-context'; -import styles from '../../styles/styles'; -import * as Modal from '../../libs/actions/Modal'; -import * as StyleUtils from '../../styles/StyleUtils'; -import themeColors from '../../styles/themes/default'; -import {propTypes as modalPropTypes, defaultProps as modalDefaultProps} from './modalPropTypes'; -import getModalStyles from '../../styles/getModalStyles'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import variables from '../../styles/variables'; -import CONST from '../../CONST'; -import ComposerFocusManager from '../../libs/ComposerFocusManager'; -import useNativeDriver from '../../libs/useNativeDriver'; -import usePrevious from '../../hooks/usePrevious'; +import usePrevious from '@hooks/usePrevious'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import ComposerFocusManager from '@libs/ComposerFocusManager'; +import useNativeDriver from '@libs/useNativeDriver'; +import getModalStyles from '@styles/getModalStyles'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Modal from '@userActions/Modal'; +import CONST from '@src/CONST'; +import {defaultProps as modalDefaultProps, propTypes as modalPropTypes} from './modalPropTypes'; const propTypes = { ...modalPropTypes, diff --git a/src/components/Modal/index.android.js b/src/components/Modal/index.android.js index b5f11a02650a..51745ae6a20f 100644 --- a/src/components/Modal/index.android.js +++ b/src/components/Modal/index.android.js @@ -1,9 +1,9 @@ import React from 'react'; import {AppState} from 'react-native'; -import withWindowDimensions from '../withWindowDimensions'; +import withWindowDimensions from '@components/withWindowDimensions'; +import ComposerFocusManager from '@libs/ComposerFocusManager'; import BaseModal from './BaseModal'; -import {propTypes, defaultProps} from './modalPropTypes'; -import ComposerFocusManager from '../../libs/ComposerFocusManager'; +import {defaultProps, propTypes} from './modalPropTypes'; AppState.addEventListener('focus', () => { ComposerFocusManager.setReadyToFocus(); diff --git a/src/components/Modal/index.ios.js b/src/components/Modal/index.ios.js index d8206d12532d..38f477e2049b 100644 --- a/src/components/Modal/index.ios.js +++ b/src/components/Modal/index.ios.js @@ -1,7 +1,7 @@ import React from 'react'; -import withWindowDimensions from '../withWindowDimensions'; +import withWindowDimensions from '@components/withWindowDimensions'; import BaseModal from './BaseModal'; -import {propTypes, defaultProps} from './modalPropTypes'; +import {defaultProps, propTypes} from './modalPropTypes'; function Modal(props) { return ( diff --git a/src/components/Modal/index.web.js b/src/components/Modal/index.web.js index 065b3a9f210f..3bea0eb58aa9 100644 --- a/src/components/Modal/index.web.js +++ b/src/components/Modal/index.web.js @@ -1,11 +1,11 @@ import React, {useState} from 'react'; -import withWindowDimensions from '../withWindowDimensions'; +import withWindowDimensions from '@components/withWindowDimensions'; +import StatusBar from '@libs/StatusBar'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import BaseModal from './BaseModal'; -import {propTypes, defaultProps} from './modalPropTypes'; -import * as StyleUtils from '../../styles/StyleUtils'; -import themeColors from '../../styles/themes/default'; -import StatusBar from '../../libs/StatusBar'; -import CONST from '../../CONST'; +import {defaultProps, propTypes} from './modalPropTypes'; function Modal(props) { const [previousStatusBarColor, setPreviousStatusBarColor] = useState(); diff --git a/src/components/Modal/modalPropTypes.js b/src/components/Modal/modalPropTypes.js index 58de5a6c57ca..84e610b694e4 100644 --- a/src/components/Modal/modalPropTypes.js +++ b/src/components/Modal/modalPropTypes.js @@ -1,8 +1,8 @@ import PropTypes from 'prop-types'; import _ from 'underscore'; -import CONST from '../../CONST'; -import {windowDimensionsPropTypes} from '../withWindowDimensions'; -import stylePropTypes from '../../styles/stylePropTypes'; +import {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import stylePropTypes from '@styles/stylePropTypes'; +import CONST from '@src/CONST'; const propTypes = { /** Decides whether the modal should cover fullscreen. FullScreen modal has backdrop */ diff --git a/src/components/MoneyReportHeader.js b/src/components/MoneyReportHeader.js index ab0b77c21653..a8fb5390ebb6 100644 --- a/src/components/MoneyReportHeader.js +++ b/src/components/MoneyReportHeader.js @@ -1,28 +1,28 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useMemo} from 'react'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import useLocalize from '../hooks/useLocalize'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import iouReportPropTypes from '@pages/iouReportPropTypes'; +import nextStepPropTypes from '@pages/nextStepPropTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import Button from './Button'; import HeaderWithBackButton from './HeaderWithBackButton'; -import iouReportPropTypes from '../pages/iouReportPropTypes'; -import * as ReportUtils from '../libs/ReportUtils'; -import participantPropTypes from './participantPropTypes'; -import styles from '../styles/styles'; -import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; -import compose from '../libs/compose'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; import MoneyReportHeaderStatusBar from './MoneyReportHeaderStatusBar'; +import participantPropTypes from './participantPropTypes'; import SettlementButton from './SettlementButton'; -import Button from './Button'; -import * as IOU from '../libs/actions/IOU'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; -import reportPropTypes from '../pages/reportPropTypes'; -import nextStepPropTypes from '../pages/nextStepPropTypes'; +import withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions'; const propTypes = { /** The report currently being looked at */ diff --git a/src/components/MoneyReportHeaderStatusBar.js b/src/components/MoneyReportHeaderStatusBar.js index 9c4362b620d1..db6502aa0119 100644 --- a/src/components/MoneyReportHeaderStatusBar.js +++ b/src/components/MoneyReportHeaderStatusBar.js @@ -1,10 +1,10 @@ import React, {useMemo} from 'react'; import {Text, View} from 'react-native'; import _ from 'underscore'; -import styles from '../styles/styles'; -import * as NextStepUtils from '../libs/NextStepUtils'; -import useLocalize from '../hooks/useLocalize'; -import nextStepPropTypes from '../pages/nextStepPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import * as NextStepUtils from '@libs/NextStepUtils'; +import nextStepPropTypes from '@pages/nextStepPropTypes'; +import styles from '@styles/styles'; import RenderHTML from './RenderHTML'; const propTypes = { diff --git a/src/components/MoneyRequestConfirmationList.js b/src/components/MoneyRequestConfirmationList.js index fd3a89d14c86..b60e950b2bbf 100755 --- a/src/components/MoneyRequestConfirmationList.js +++ b/src/components/MoneyRequestConfirmationList.js @@ -1,49 +1,49 @@ -import React, {useCallback, useMemo, useReducer, useState, useEffect} from 'react'; +import {useIsFocused} from '@react-navigation/native'; +import {format} from 'date-fns'; +import {isEmpty} from 'lodash'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useReducer, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import {format} from 'date-fns'; import _ from 'underscore'; -import {View} from 'react-native'; -import lodashGet from 'lodash/get'; -import {useIsFocused} from '@react-navigation/native'; -import {isEmpty} from 'lodash'; -import Text from './Text'; -import styles from '../styles/styles'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import Permissions from '../libs/Permissions'; -import OptionsSelector from './OptionsSelector'; -import ONYXKEYS from '../ONYXKEYS'; -import compose from '../libs/compose'; -import CONST from '../CONST'; -import ButtonWithDropdownMenu from './ButtonWithDropdownMenu'; -import Log from '../libs/Log'; -import SettlementButton from './SettlementButton'; -import ROUTES from '../ROUTES'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from './withCurrentUserPersonalDetails'; -import * as IOUUtils from '../libs/IOUUtils'; -import MenuItemWithTopDescription from './MenuItemWithTopDescription'; -import Navigation from '../libs/Navigation/Navigation'; -import optionPropTypes from './optionPropTypes'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import DistanceRequestUtils from '@libs/DistanceRequestUtils'; +import * as IOUUtils from '@libs/IOUUtils'; +import Log from '@libs/Log'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReceiptUtils from '@libs/ReceiptUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import Button from './Button'; +import ButtonWithDropdownMenu from './ButtonWithDropdownMenu'; +import categoryPropTypes from './categoryPropTypes'; +import ConfirmedRoute from './ConfirmedRoute'; +import FormHelpMessage from './FormHelpMessage'; import * as Expensicons from './Icon/Expensicons'; -import themeColors from '../styles/themes/default'; import Image from './Image'; -import useLocalize from '../hooks/useLocalize'; -import * as ReceiptUtils from '../libs/ReceiptUtils'; -import categoryPropTypes from './categoryPropTypes'; +import MenuItemWithTopDescription from './MenuItemWithTopDescription'; +import optionPropTypes from './optionPropTypes'; +import OptionsSelector from './OptionsSelector'; +import SettlementButton from './SettlementButton'; import Switch from './Switch'; import tagPropTypes from './tagPropTypes'; -import ConfirmedRoute from './ConfirmedRoute'; +import Text from './Text'; import transactionPropTypes from './transactionPropTypes'; -import DistanceRequestUtils from '../libs/DistanceRequestUtils'; -import FormHelpMessage from './FormHelpMessage'; -import * as IOU from '../libs/actions/IOU'; -import * as TransactionUtils from '../libs/TransactionUtils'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import * as MoneyRequestUtils from '../libs/MoneyRequestUtils'; -import {iouDefaultProps, iouPropTypes} from '../pages/iou/propTypes'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from './withCurrentUserPersonalDetails'; const propTypes = { /** Callback to inform parent modal of success */ diff --git a/src/components/MoneyRequestHeader.js b/src/components/MoneyRequestHeader.js index 086e1429baef..cbadbf40ff5c 100644 --- a/src/components/MoneyRequestHeader.js +++ b/src/components/MoneyRequestHeader.js @@ -1,29 +1,29 @@ -import React, {useState, useCallback, useEffect} from 'react'; -import {withOnyx} from 'react-native-onyx'; -import {View} from 'react-native'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useState} from 'react'; +import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import compose from '@libs/compose'; +import * as HeaderUtils from '@libs/HeaderUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import iouReportPropTypes from '@pages/iouReportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import ConfirmModal from './ConfirmModal'; import HeaderWithBackButton from './HeaderWithBackButton'; -import iouReportPropTypes from '../pages/iouReportPropTypes'; -import * as ReportUtils from '../libs/ReportUtils'; -import compose from '../libs/compose'; import * as Expensicons from './Icon/Expensicons'; -import participantPropTypes from './participantPropTypes'; -import styles from '../styles/styles'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import * as IOU from '../libs/actions/IOU'; -import ConfirmModal from './ConfirmModal'; -import useLocalize from '../hooks/useLocalize'; import MoneyRequestHeaderStatusBar from './MoneyRequestHeaderStatusBar'; -import * as TransactionUtils from '../libs/TransactionUtils'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; -import * as HeaderUtils from '../libs/HeaderUtils'; -import reportActionPropTypes from '../pages/home/report/reportActionPropTypes'; +import participantPropTypes from './participantPropTypes'; import transactionPropTypes from './transactionPropTypes'; -import useWindowDimensions from '../hooks/useWindowDimensions'; const propTypes = { /** The report currently being looked at */ diff --git a/src/components/MoneyRequestHeaderStatusBar.js b/src/components/MoneyRequestHeaderStatusBar.js index 31a6e9c0e897..f217d7fc2426 100644 --- a/src/components/MoneyRequestHeaderStatusBar.js +++ b/src/components/MoneyRequestHeaderStatusBar.js @@ -1,7 +1,7 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; import Text from './Text'; const propTypes = { diff --git a/src/components/MoneyRequestSkeletonView.js b/src/components/MoneyRequestSkeletonView.js index 50a7b56b91e3..e03cb78972cf 100644 --- a/src/components/MoneyRequestSkeletonView.js +++ b/src/components/MoneyRequestSkeletonView.js @@ -1,9 +1,9 @@ import React from 'react'; -import {Rect} from 'react-native-svg'; import SkeletonViewContentLoader from 'react-content-loader/native'; -import variables from '../styles/variables'; -import themeColors from '../styles/themes/default'; -import styles from '../styles/styles'; +import {Rect} from 'react-native-svg'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; function MoneyRequestSkeletonView() { return ( diff --git a/src/components/MultipleAvatars.js b/src/components/MultipleAvatars.js index 8866d61d3870..85b6f7995693 100644 --- a/src/components/MultipleAvatars.js +++ b/src/components/MultipleAvatars.js @@ -1,16 +1,16 @@ -import React, {memo, useMemo} from 'react'; import PropTypes from 'prop-types'; +import React, {memo, useMemo} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import Avatar from './Avatar'; -import Tooltip from './Tooltip'; -import Text from './Text'; -import themeColors from '../styles/themes/default'; -import * as StyleUtils from '../styles/StyleUtils'; -import CONST from '../CONST'; -import variables from '../styles/variables'; import avatarPropTypes from './avatarPropTypes'; +import Text from './Text'; +import Tooltip from './Tooltip'; import UserDetailsTooltip from './UserDetailsTooltip'; const propTypes = { diff --git a/src/components/NewDatePicker/CalendarPicker/ArrowIcon.js b/src/components/NewDatePicker/CalendarPicker/ArrowIcon.js index 6d5757323480..cb680a8bc43b 100644 --- a/src/components/NewDatePicker/CalendarPicker/ArrowIcon.js +++ b/src/components/NewDatePicker/CalendarPicker/ArrowIcon.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import * as Expensicons from '../../Icon/Expensicons'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import Icon from '../../Icon'; -import CONST from '../../../CONST'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { /** Specifies if the arrow icon should be disabled or not. */ diff --git a/src/components/NewDatePicker/CalendarPicker/YearPickerModal.js b/src/components/NewDatePicker/CalendarPicker/YearPickerModal.js index 9825109fbb63..5489a9244f68 100644 --- a/src/components/NewDatePicker/CalendarPicker/YearPickerModal.js +++ b/src/components/NewDatePicker/CalendarPicker/YearPickerModal.js @@ -1,14 +1,14 @@ -import React, {useEffect, useMemo, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect, useMemo, useState} from 'react'; import _ from 'underscore'; -import HeaderWithBackButton from '../../HeaderWithBackButton'; -import CONST from '../../../CONST'; -import SelectionList from '../../SelectionList'; -import Modal from '../../Modal'; -import {radioListItemPropTypes} from '../../SelectionList/selectionListPropTypes'; -import useLocalize from '../../../hooks/useLocalize'; -import ScreenWrapper from '../../ScreenWrapper'; -import styles from '../../../styles/styles'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Modal from '@components/Modal'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import {radioListItemPropTypes} from '@components/SelectionList/selectionListPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Whether the modal is visible */ diff --git a/src/components/NewDatePicker/CalendarPicker/generateMonthMatrix.js b/src/components/NewDatePicker/CalendarPicker/generateMonthMatrix.js index 7a3c55305a33..a3497654feec 100644 --- a/src/components/NewDatePicker/CalendarPicker/generateMonthMatrix.js +++ b/src/components/NewDatePicker/CalendarPicker/generateMonthMatrix.js @@ -1,4 +1,4 @@ -import {getDaysInMonth, startOfMonth, getDay, addDays, format} from 'date-fns'; +import {addDays, format, getDay, getDaysInMonth, startOfMonth} from 'date-fns'; /** * Generates a matrix representation of a month's calendar given the year and month. diff --git a/src/components/NewDatePicker/CalendarPicker/index.js b/src/components/NewDatePicker/CalendarPicker/index.js index d03c36997845..0300b4bf476f 100644 --- a/src/components/NewDatePicker/CalendarPicker/index.js +++ b/src/components/NewDatePicker/CalendarPicker/index.js @@ -1,20 +1,20 @@ -import _ from 'underscore'; -import React from 'react'; -import {View} from 'react-native'; +import Str from 'expensify-common/lib/str'; import moment from 'moment'; import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; -import Text from '../../Text'; -import YearPickerModal from './YearPickerModal'; +import React from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import getButtonState from '@libs/getButtonState'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import ArrowIcon from './ArrowIcon'; -import styles from '../../../styles/styles'; import generateMonthMatrix from './generateMonthMatrix'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import CONST from '../../../CONST'; -import getButtonState from '../../../libs/getButtonState'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import PressableWithFeedback from '../../Pressable/PressableWithFeedback'; -import PressableWithoutFeedback from '../../Pressable/PressableWithoutFeedback'; +import YearPickerModal from './YearPickerModal'; const propTypes = { /** An initial value of date string */ diff --git a/src/components/NewDatePicker/index.js b/src/components/NewDatePicker/index.js index 3201388790c9..30e15ac43bfc 100644 --- a/src/components/NewDatePicker/index.js +++ b/src/components/NewDatePicker/index.js @@ -1,16 +1,16 @@ -import React, {useEffect, useState} from 'react'; -import {View} from 'react-native'; +import _ from 'lodash'; import moment from 'moment'; import PropTypes from 'prop-types'; -import _ from 'lodash'; -import TextInput from '../TextInput'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import * as Expensicons from '../Icon/Expensicons'; -import {defaultProps as defaultBaseTextInputPropTypes, propTypes as baseTextInputPropTypes} from '../TextInput/baseTextInputPropTypes'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; +import React, {useEffect, useState} from 'react'; +import {View} from 'react-native'; +import InputWrapper from '@components/Form/InputWrapper'; +import * as Expensicons from '@components/Icon/Expensicons'; +import TextInput from '@components/TextInput'; +import {propTypes as baseTextInputPropTypes, defaultProps as defaultBaseTextInputPropTypes} from '@components/TextInput/baseTextInputPropTypes'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import CalendarPicker from './CalendarPicker'; -import InputWrapper from '../Form/InputWrapper'; const propTypes = { /** diff --git a/src/components/OfflineIndicator.js b/src/components/OfflineIndicator.js index 43cd374421ea..f120fe535834 100644 --- a/src/components/OfflineIndicator.js +++ b/src/components/OfflineIndicator.js @@ -1,16 +1,16 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import {withNetwork} from './OnyxProvider'; -import networkPropTypes from './networkPropTypes'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import variables from '../styles/variables'; +import networkPropTypes from './networkPropTypes'; +import {withNetwork} from './OnyxProvider'; import Text from './Text'; -import styles from '../styles/styles'; -import compose from '../libs/compose'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import * as StyleUtils from '../styles/StyleUtils'; import withWindowDimensions from './withWindowDimensions'; const propTypes = { diff --git a/src/components/OfflineWithFeedback.js b/src/components/OfflineWithFeedback.js index 51f6e410424f..ba893aeb2fe4 100644 --- a/src/components/OfflineWithFeedback.js +++ b/src/components/OfflineWithFeedback.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import CONST from '../CONST'; -import stylePropTypes from '../styles/stylePropTypes'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import shouldRenderOffscreen from '../libs/shouldRenderOffscreen'; +import _ from 'underscore'; +import useNetwork from '@hooks/useNetwork'; +import shouldRenderOffscreen from '@libs/shouldRenderOffscreen'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; import MessagesRow from './MessagesRow'; -import useNetwork from '../hooks/useNetwork'; /** * This component should be used when we are using the offline pattern B (offline with feedback). diff --git a/src/components/Onfido/BaseOnfidoWeb.js b/src/components/Onfido/BaseOnfidoWeb.js index 394996331d5e..5c0f83902e55 100644 --- a/src/components/Onfido/BaseOnfidoWeb.js +++ b/src/components/Onfido/BaseOnfidoWeb.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; -import './index.css'; import lodashGet from 'lodash/get'; -import React, {useEffect, forwardRef} from 'react'; import * as OnfidoSDK from 'onfido-sdk-ui'; +import React, {forwardRef, useEffect} from 'react'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import Log from '@libs/Log'; +import fontFamily from '@styles/fontFamily'; +import fontWeightBold from '@styles/fontWeight/bold'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; +import './index.css'; import onfidoPropTypes from './onfidoPropTypes'; -import CONST from '../../CONST'; -import variables from '../../styles/variables'; -import themeColors from '../../styles/themes/default'; -import fontWeightBold from '../../styles/fontWeight/bold'; -import fontFamily from '../../styles/fontFamily'; -import Log from '../../libs/Log'; -import useLocalize from '../../hooks/useLocalize'; function initializeOnfido({sdkToken, onSuccess, onError, onUserExit, preferredLocale, translate}) { OnfidoSDK.init({ diff --git a/src/components/Onfido/index.native.js b/src/components/Onfido/index.native.js index 424e370b5fe6..ed0578187d3c 100644 --- a/src/components/Onfido/index.native.js +++ b/src/components/Onfido/index.native.js @@ -1,13 +1,13 @@ -import _ from 'underscore'; +import {OnfidoCaptureType, OnfidoCountryCode, OnfidoDocumentType, Onfido as OnfidoSDK} from '@onfido/react-native-sdk'; import lodashGet from 'lodash/get'; import React, {useEffect} from 'react'; import {Alert, Linking} from 'react-native'; -import {Onfido as OnfidoSDK, OnfidoCaptureType, OnfidoDocumentType, OnfidoCountryCode} from '@onfido/react-native-sdk'; +import _ from 'underscore'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import useLocalize from '@hooks/useLocalize'; +import Log from '@libs/Log'; +import CONST from '@src/CONST'; import onfidoPropTypes from './onfidoPropTypes'; -import CONST from '../../CONST'; -import Log from '../../libs/Log'; -import FullscreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import useLocalize from '../../hooks/useLocalize'; function Onfido({sdkToken, onUserExit, onSuccess, onError}) { const {translate} = useLocalize(); diff --git a/src/components/Onfido/index.website.js b/src/components/Onfido/index.website.js index 23e59fb1e08f..12ad1edd8fb9 100644 --- a/src/components/Onfido/index.website.js +++ b/src/components/Onfido/index.website.js @@ -1,5 +1,5 @@ -import React, {useEffect, useRef} from 'react'; import lodashGet from 'lodash/get'; +import React, {useEffect, useRef} from 'react'; import BaseOnfidoWeb from './BaseOnfidoWeb'; import onfidoPropTypes from './onfidoPropTypes'; diff --git a/src/components/OnyxProvider.tsx b/src/components/OnyxProvider.tsx index 8682e832debc..1009a74ef1f7 100644 --- a/src/components/OnyxProvider.tsx +++ b/src/components/OnyxProvider.tsx @@ -1,7 +1,7 @@ import React from 'react'; -import ONYXKEYS from '../ONYXKEYS'; -import createOnyxContext from './createOnyxContext'; +import ONYXKEYS from '@src/ONYXKEYS'; import ComposeProviders from './ComposeProviders'; +import createOnyxContext from './createOnyxContext'; // Set up any providers for individual keys. This should only be used in cases where many components will subscribe to // the same key (e.g. FlatList renderItem components) diff --git a/src/components/OpacityView.js b/src/components/OpacityView.js index daef93cdc09b..ebd261916e65 100644 --- a/src/components/OpacityView.js +++ b/src/components/OpacityView.js @@ -1,9 +1,9 @@ +import PropTypes from 'prop-types'; import React from 'react'; import Animated, {useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; -import PropTypes from 'prop-types'; -import variables from '../styles/variables'; -import * as StyleUtils from '../styles/StyleUtils'; -import shouldRenderOffscreen from '../libs/shouldRenderOffscreen'; +import shouldRenderOffscreen from '@libs/shouldRenderOffscreen'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; const propTypes = { /** diff --git a/src/components/OptionRow.js b/src/components/OptionRow.js index e3ea3acfc2ee..4939c5bac431 100644 --- a/src/components/OptionRow.js +++ b/src/components/OptionRow.js @@ -1,27 +1,27 @@ -import _ from 'underscore'; import lodashGet from 'lodash/get'; -import React, {useState, useEffect, useRef} from 'react'; import PropTypes from 'prop-types'; -import {View, StyleSheet, InteractionManager} from 'react-native'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import optionPropTypes from './optionPropTypes'; +import React, {useEffect, useRef, useState} from 'react'; +import {InteractionManager, StyleSheet, View} from 'react-native'; +import _ from 'underscore'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import Button from './Button'; +import DisplayNames from './DisplayNames'; +import Hoverable from './Hoverable'; import Icon from './Icon'; import * as Expensicons from './Icon/Expensicons'; -import Button from './Button'; import MultipleAvatars from './MultipleAvatars'; -import Hoverable from './Hoverable'; -import DisplayNames from './DisplayNames'; -import themeColors from '../styles/themes/default'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import Text from './Text'; -import SelectCircle from './SelectCircle'; -import SubscriptAvatar from './SubscriptAvatar'; import OfflineWithFeedback from './OfflineWithFeedback'; -import CONST from '../CONST'; -import * as ReportUtils from '../libs/ReportUtils'; +import optionPropTypes from './optionPropTypes'; import PressableWithFeedback from './Pressable/PressableWithFeedback'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; +import SelectCircle from './SelectCircle'; +import SubscriptAvatar from './SubscriptAvatar'; +import Text from './Text'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** Style for hovered state */ diff --git a/src/components/OptionsList/BaseOptionsList.js b/src/components/OptionsList/BaseOptionsList.js index 91fd77dbea30..c7d378cde6e3 100644 --- a/src/components/OptionsList/BaseOptionsList.js +++ b/src/components/OptionsList/BaseOptionsList.js @@ -1,15 +1,15 @@ -import _ from 'underscore'; -import React, {useRef, useEffect, forwardRef, memo} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; -import OptionRow from '../OptionRow'; -import SectionList from '../SectionList'; -import Text from '../Text'; -import {propTypes as optionsListPropTypes, defaultProps as optionsListDefaultProps} from './optionsListPropTypes'; -import OptionsListSkeletonView from '../OptionsListSkeletonView'; -import usePrevious from '../../hooks/usePrevious'; +import React, {forwardRef, memo, useEffect, useRef} from 'react'; +import {View} from 'react-native'; +import _ from 'underscore'; +import OptionRow from '@components/OptionRow'; +import OptionsListSkeletonView from '@components/OptionsListSkeletonView'; +import SectionList from '@components/SectionList'; +import Text from '@components/Text'; +import usePrevious from '@hooks/usePrevious'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import {defaultProps as optionsListDefaultProps, propTypes as optionsListPropTypes} from './optionsListPropTypes'; const propTypes = { /** Determines whether the keyboard gets dismissed in response to a drag */ diff --git a/src/components/OptionsList/index.js b/src/components/OptionsList/index.js index 017d9c23d9ae..36b8e7fccf12 100644 --- a/src/components/OptionsList/index.js +++ b/src/components/OptionsList/index.js @@ -1,10 +1,10 @@ -import React, {forwardRef, useEffect, useRef, useCallback} from 'react'; +import React, {forwardRef, useCallback, useEffect, useRef} from 'react'; import {Keyboard} from 'react-native'; import _ from 'underscore'; +import withWindowDimensions from '@components/withWindowDimensions'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import BaseOptionsList from './BaseOptionsList'; -import withWindowDimensions from '../withWindowDimensions'; -import {propTypes, defaultProps} from './optionsListPropTypes'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; +import {defaultProps, propTypes} from './optionsListPropTypes'; function OptionsList(props) { const isScreenTouched = useRef(false); diff --git a/src/components/OptionsList/index.native.js b/src/components/OptionsList/index.native.js index 7701096fde8f..ab2db4f20967 100644 --- a/src/components/OptionsList/index.native.js +++ b/src/components/OptionsList/index.native.js @@ -1,7 +1,7 @@ import React, {forwardRef} from 'react'; import {Keyboard} from 'react-native'; import BaseOptionsList from './BaseOptionsList'; -import {propTypes, defaultProps} from './optionsListPropTypes'; +import {defaultProps, propTypes} from './optionsListPropTypes'; const OptionsList = forwardRef((props, ref) => ( { const [isScreenTouched, setIsScreenTouched] = useState(false); diff --git a/src/components/SelectionList/selectionListPropTypes.js b/src/components/SelectionList/selectionListPropTypes.js index 58aecb0da1a1..2b53f555134e 100644 --- a/src/components/SelectionList/selectionListPropTypes.js +++ b/src/components/SelectionList/selectionListPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; import _ from 'underscore'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; const commonListItemPropTypes = { /** Whether this item is focused (for arrow key controls) */ diff --git a/src/components/SettlementButton.js b/src/components/SettlementButton.js index 2989fd103850..d2030eac8d7d 100644 --- a/src/components/SettlementButton.js +++ b/src/components/SettlementButton.js @@ -1,22 +1,22 @@ -import React, {useEffect, useMemo} from 'react'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React, {useEffect, useMemo} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import compose from '../libs/compose'; -import Permissions from '../libs/Permissions'; -import useNetwork from '../hooks/useNetwork'; -import useLocalize from '../hooks/useLocalize'; -import * as ReportUtils from '../libs/ReportUtils'; -import iouReportPropTypes from '../pages/iouReportPropTypes'; -import * as PaymentMethods from '../libs/actions/PaymentMethods'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import compose from '@libs/compose'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import iouReportPropTypes from '@pages/iouReportPropTypes'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import ButtonWithDropdownMenu from './ButtonWithDropdownMenu'; +import * as Expensicons from './Icon/Expensicons'; import KYCWall from './KYCWall'; import withNavigation from './withNavigation'; -import * as Expensicons from './Icon/Expensicons'; -import ButtonWithDropdownMenu from './ButtonWithDropdownMenu'; -import * as BankAccounts from '../libs/actions/BankAccounts'; -import ROUTES from '../ROUTES'; const propTypes = { /** Callback to execute when this button is pressed. Receives a single payment type argument. */ diff --git a/src/components/ShowContextMenuContext.js b/src/components/ShowContextMenuContext.js index fff233162d74..6248478e5fea 100644 --- a/src/components/ShowContextMenuContext.js +++ b/src/components/ShowContextMenuContext.js @@ -1,8 +1,8 @@ import React from 'react'; -import * as ReportActionContextMenu from '../pages/home/report/ContextMenu/ReportActionContextMenu'; -import * as ContextMenuActions from '../pages/home/report/ContextMenu/ContextMenuActions'; -import * as DeviceCapabilities from '../libs/DeviceCapabilities'; -import * as ReportUtils from '../libs/ReportUtils'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as ContextMenuActions from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; const ShowContextMenuContext = React.createContext({ anchor: null, diff --git a/src/components/SignInButtons/AppleAuthWrapper/index.ios.js b/src/components/SignInButtons/AppleAuthWrapper/index.ios.js index 9f97182b2e7b..69882d89b1fe 100644 --- a/src/components/SignInButtons/AppleAuthWrapper/index.ios.js +++ b/src/components/SignInButtons/AppleAuthWrapper/index.ios.js @@ -1,6 +1,6 @@ -import {useEffect} from 'react'; import appleAuth from '@invertase/react-native-apple-authentication'; -import * as Session from '../../../libs/actions/Session'; +import {useEffect} from 'react'; +import * as Session from '@userActions/Session'; /** * Apple Sign In wrapper for iOS diff --git a/src/components/SignInButtons/AppleSignIn/index.android.js b/src/components/SignInButtons/AppleSignIn/index.android.js index 48d2bf3cc861..9dc736789c61 100644 --- a/src/components/SignInButtons/AppleSignIn/index.android.js +++ b/src/components/SignInButtons/AppleSignIn/index.android.js @@ -1,10 +1,10 @@ -import React from 'react'; import {appleAuthAndroid} from '@invertase/react-native-apple-authentication'; -import Log from '../../../libs/Log'; -import IconButton from '../IconButton'; -import * as Session from '../../../libs/actions/Session'; -import CONFIG from '../../../CONFIG'; -import CONST from '../../../CONST'; +import React from 'react'; +import IconButton from '@components/SignInButtons/IconButton'; +import Log from '@libs/Log'; +import * as Session from '@userActions/Session'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; /** * Apple Sign In Configuration for Android. diff --git a/src/components/SignInButtons/AppleSignIn/index.desktop.js b/src/components/SignInButtons/AppleSignIn/index.desktop.js index 52ff3ef710b0..cad37d585de4 100644 --- a/src/components/SignInButtons/AppleSignIn/index.desktop.js +++ b/src/components/SignInButtons/AppleSignIn/index.desktop.js @@ -1,10 +1,10 @@ import React from 'react'; import {View} from 'react-native'; -import IconButton from '../IconButton'; -import CONFIG from '../../../CONFIG'; -import ROUTES from '../../../ROUTES'; -import styles from '../../../styles/styles'; -import CONST from '../../../CONST'; +import IconButton from '@components/SignInButtons/IconButton'; +import styles from '@styles/styles'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const appleSignInWebRouteForDesktopFlow = `${CONFIG.EXPENSIFY.NEW_EXPENSIFY_URL}${ROUTES.APPLE_SIGN_IN}`; diff --git a/src/components/SignInButtons/AppleSignIn/index.ios.js b/src/components/SignInButtons/AppleSignIn/index.ios.js index 0c9a8c9e8211..f5c6333dcf7b 100644 --- a/src/components/SignInButtons/AppleSignIn/index.ios.js +++ b/src/components/SignInButtons/AppleSignIn/index.ios.js @@ -1,9 +1,9 @@ -import React from 'react'; import appleAuth from '@invertase/react-native-apple-authentication'; -import Log from '../../../libs/Log'; -import IconButton from '../IconButton'; -import * as Session from '../../../libs/actions/Session'; -import CONST from '../../../CONST'; +import React from 'react'; +import IconButton from '@components/SignInButtons/IconButton'; +import Log from '@libs/Log'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; /** * Apple Sign In method for iOS that returns identityToken. diff --git a/src/components/SignInButtons/AppleSignIn/index.website.js b/src/components/SignInButtons/AppleSignIn/index.website.js index 7046de5068b1..adae0a691e13 100644 --- a/src/components/SignInButtons/AppleSignIn/index.website.js +++ b/src/components/SignInButtons/AppleSignIn/index.website.js @@ -1,13 +1,13 @@ -import React, {useEffect, useState} from 'react'; +import get from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; import Config from 'react-native-config'; -import get from 'lodash/get'; -import getUserLanguage from '../GetUserLanguage'; -import * as Session from '../../../libs/actions/Session'; -import Log from '../../../libs/Log'; -import CONFIG from '../../../CONFIG'; -import CONST from '../../../CONST'; -import withNavigationFocus from '../../withNavigationFocus'; +import getUserLanguage from '@components/SignInButtons/GetUserLanguage'; +import withNavigationFocus from '@components/withNavigationFocus'; +import Log from '@libs/Log'; +import * as Session from '@userActions/Session'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; // react-native-config doesn't trim whitespace on iOS for some reason so we // add a trim() call to lodashGet here to prevent headaches. diff --git a/src/components/SignInButtons/GoogleSignIn/index.desktop.js b/src/components/SignInButtons/GoogleSignIn/index.desktop.js index 95a78f34614b..e69905dcad05 100644 --- a/src/components/SignInButtons/GoogleSignIn/index.desktop.js +++ b/src/components/SignInButtons/GoogleSignIn/index.desktop.js @@ -1,11 +1,11 @@ import React from 'react'; import {View} from 'react-native'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import IconButton from '../IconButton'; -import CONFIG from '../../../CONFIG'; -import ROUTES from '../../../ROUTES'; -import styles from '../../../styles/styles'; -import CONST from '../../../CONST'; +import IconButton from '@components/SignInButtons/IconButton'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = {...withLocalizePropTypes}; diff --git a/src/components/SignInButtons/GoogleSignIn/index.native.js b/src/components/SignInButtons/GoogleSignIn/index.native.js index 099fbfde22fd..c7ac763cfb73 100644 --- a/src/components/SignInButtons/GoogleSignIn/index.native.js +++ b/src/components/SignInButtons/GoogleSignIn/index.native.js @@ -1,10 +1,10 @@ -import React from 'react'; import {GoogleSignin, statusCodes} from '@react-native-google-signin/google-signin'; -import Log from '../../../libs/Log'; -import IconButton from '../IconButton'; -import * as Session from '../../../libs/actions/Session'; -import CONST from '../../../CONST'; -import CONFIG from '../../../CONFIG'; +import React from 'react'; +import IconButton from '@components/SignInButtons/IconButton'; +import Log from '@libs/Log'; +import * as Session from '@userActions/Session'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; /** * Google Sign In method for iOS and android that returns identityToken. diff --git a/src/components/SignInButtons/GoogleSignIn/index.website.js b/src/components/SignInButtons/GoogleSignIn/index.website.js index 5362433142af..7f3a3019c318 100644 --- a/src/components/SignInButtons/GoogleSignIn/index.website.js +++ b/src/components/SignInButtons/GoogleSignIn/index.website.js @@ -1,10 +1,10 @@ +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../withLocalize'; -import * as Session from '../../../libs/actions/Session'; -import CONFIG from '../../../CONFIG'; -import styles from '../../../styles/styles'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; +import CONFIG from '@src/CONFIG'; const propTypes = { /** Whether we're rendering in the Desktop Flow, if so show a different button. */ diff --git a/src/components/SignInButtons/IconButton.js b/src/components/SignInButtons/IconButton.js index 4f1692ddb677..0d18779ea9ba 100644 --- a/src/components/SignInButtons/IconButton.js +++ b/src/components/SignInButtons/IconButton.js @@ -1,11 +1,11 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import CONST from '../../CONST'; -import * as Expensicons from '../Icon/Expensicons'; -import Icon from '../Icon'; +import React from 'react'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** The on press method */ diff --git a/src/components/SignInPageForm/index.native.tsx b/src/components/SignInPageForm/index.native.tsx index 487822c62de9..b39e4d681bbe 100644 --- a/src/components/SignInPageForm/index.native.tsx +++ b/src/components/SignInPageForm/index.native.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import FormElement from '../FormElement'; +import FormElement from '@components/FormElement'; import SignInPageFormProps from './types'; function SignInPageForm(props: SignInPageFormProps) { diff --git a/src/components/SignInPageForm/index.tsx b/src/components/SignInPageForm/index.tsx index fd415dbbd930..1cdc31b33fd9 100644 --- a/src/components/SignInPageForm/index.tsx +++ b/src/components/SignInPageForm/index.tsx @@ -1,5 +1,5 @@ import React, {useEffect, useRef} from 'react'; -import FormElement from '../FormElement'; +import FormElement from '@components/FormElement'; import SignInPageFormProps from './types'; const preventFormDefault = (event: SubmitEvent) => { diff --git a/src/components/SingleOptionSelector.js b/src/components/SingleOptionSelector.js index 889b6a7d1f96..ef212937920e 100644 --- a/src/components/SingleOptionSelector.js +++ b/src/components/SingleOptionSelector.js @@ -1,12 +1,12 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React from 'react'; import {View} from 'react-native'; +import _ from 'underscore'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; import SelectCircle from './SelectCircle'; -import styles from '../styles/styles'; -import CONST from '../CONST'; import Text from './Text'; -import PressableWithoutFeedback from './Pressable/PressableWithoutFeedback'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { diff --git a/src/components/SpacerView.js b/src/components/SpacerView.js index 3b81bbfa0dc5..60ff7fd85e55 100644 --- a/src/components/SpacerView.js +++ b/src/components/SpacerView.js @@ -1,9 +1,9 @@ +import PropTypes from 'prop-types'; import React from 'react'; import Animated, {useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; -import PropTypes from 'prop-types'; -import * as StyleUtils from '../styles/StyleUtils'; -import stylePropTypes from '../styles/stylePropTypes'; -import CONST from '../CONST'; +import stylePropTypes from '@styles/stylePropTypes'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { /** diff --git a/src/components/SplashScreenHider/index.js b/src/components/SplashScreenHider/index.js index a3f3647ede81..9bbddd2a0891 100644 --- a/src/components/SplashScreenHider/index.js +++ b/src/components/SplashScreenHider/index.js @@ -1,6 +1,6 @@ -import {useEffect} from 'react'; import PropTypes from 'prop-types'; -import BootSplash from '../../libs/BootSplash'; +import {useEffect} from 'react'; +import BootSplash from '@libs/BootSplash'; const propTypes = { /** Splash screen has been hidden */ diff --git a/src/components/SplashScreenHider/index.native.js b/src/components/SplashScreenHider/index.native.js index dbfac3331484..711ce9f6fb80 100644 --- a/src/components/SplashScreenHider/index.native.js +++ b/src/components/SplashScreenHider/index.native.js @@ -1,10 +1,10 @@ -import {useCallback, useRef} from 'react'; import PropTypes from 'prop-types'; +import {useCallback, useRef} from 'react'; import {StyleSheet} from 'react-native'; -import Reanimated, {useSharedValue, withTiming, Easing, useAnimatedStyle, runOnJS} from 'react-native-reanimated'; -import BootSplash from '../../libs/BootSplash'; -import Logo from '../../../assets/images/new-expensify-dark.svg'; -import styles from '../../styles/styles'; +import Reanimated, {Easing, runOnJS, useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; +import Logo from '@assets/images/new-expensify-dark.svg'; +import BootSplash from '@libs/BootSplash'; +import styles from '@styles/styles'; const propTypes = { /** Splash screen has been hidden */ diff --git a/src/components/StatePicker/StateSelectorModal.js b/src/components/StatePicker/StateSelectorModal.js index 378dcc4ebc8b..8bda9d5303c8 100644 --- a/src/components/StatePicker/StateSelectorModal.js +++ b/src/components/StatePicker/StateSelectorModal.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; -import React, {useMemo, useEffect} from 'react'; -import PropTypes from 'prop-types'; import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; -import CONST from '../../CONST'; -import Modal from '../Modal'; -import HeaderWithBackButton from '../HeaderWithBackButton'; -import SelectionList from '../SelectionList'; -import useLocalize from '../../hooks/useLocalize'; -import ScreenWrapper from '../ScreenWrapper'; -import styles from '../../styles/styles'; -import searchCountryOptions from '../../libs/searchCountryOptions'; -import StringUtils from '../../libs/StringUtils'; +import PropTypes from 'prop-types'; +import React, {useEffect, useMemo} from 'react'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Modal from '@components/Modal'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import useLocalize from '@hooks/useLocalize'; +import searchCountryOptions from '@libs/searchCountryOptions'; +import StringUtils from '@libs/StringUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Whether the modal is visible */ diff --git a/src/components/StatePicker/index.js b/src/components/StatePicker/index.js index 586abc26f702..c36c7e6b97a0 100644 --- a/src/components/StatePicker/index.js +++ b/src/components/StatePicker/index.js @@ -1,14 +1,14 @@ +import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; +import PropTypes from 'prop-types'; import React, {useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; -import styles from '../../styles/styles'; -import MenuItemWithTopDescription from '../MenuItemWithTopDescription'; -import useLocalize from '../../hooks/useLocalize'; -import FormHelpMessage from '../FormHelpMessage'; +import FormHelpMessage from '@components/FormHelpMessage'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import refPropTypes from '@components/refPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; import StateSelectorModal from './StateSelectorModal'; -import refPropTypes from '../refPropTypes'; const propTypes = { /** Error text to display */ diff --git a/src/components/SubscriptAvatar.js b/src/components/SubscriptAvatar.js index 66d9812d994e..4a232419aff7 100644 --- a/src/components/SubscriptAvatar.js +++ b/src/components/SubscriptAvatar.js @@ -1,13 +1,13 @@ -import React, {memo} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {memo} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import Avatar from './Avatar'; -import CONST from '../CONST'; -import * as StyleUtils from '../styles/StyleUtils'; import avatarPropTypes from './avatarPropTypes'; import UserDetailsTooltip from './UserDetailsTooltip'; diff --git a/src/components/SwipeableView/index.native.tsx b/src/components/SwipeableView/index.native.tsx index ac500f025016..91d851101d4e 100644 --- a/src/components/SwipeableView/index.native.tsx +++ b/src/components/SwipeableView/index.native.tsx @@ -1,6 +1,6 @@ import React, {useRef} from 'react'; import {PanResponder, View} from 'react-native'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import SwipeableViewProps from './types'; function SwipeableView({children, onSwipeDown}: SwipeableViewProps) { diff --git a/src/components/Switch.js b/src/components/Switch.js index 5c8a0da925f3..755cd60f2597 100644 --- a/src/components/Switch.js +++ b/src/components/Switch.js @@ -1,10 +1,10 @@ import PropTypes from 'prop-types'; import React, {useEffect, useRef} from 'react'; import {Animated} from 'react-native'; -import CONST from '../CONST'; -import styles from '../styles/styles'; +import useNativeDriver from '@libs/useNativeDriver'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import PressableWithFeedback from './Pressable/PressableWithFeedback'; -import useNativeDriver from '../libs/useNativeDriver'; const propTypes = { /** Whether the switch is toggled to the on position */ diff --git a/src/components/TabSelector/TabIcon.js b/src/components/TabSelector/TabIcon.js index 85f1cd912ff6..d9d802d2076a 100644 --- a/src/components/TabSelector/TabIcon.js +++ b/src/components/TabSelector/TabIcon.js @@ -1,8 +1,8 @@ -import {StyleSheet, View, Animated} from 'react-native'; -import React from 'react'; import PropTypes from 'prop-types'; -import Icon from '../Icon'; -import themeColors from '../../styles/themes/default'; +import React from 'react'; +import {Animated, StyleSheet, View} from 'react-native'; +import Icon from '@components/Icon'; +import themeColors from '@styles/themes/default'; const propTypes = { /** Icon to display on tab */ diff --git a/src/components/TabSelector/TabLabel.js b/src/components/TabSelector/TabLabel.js index 32c8a384d814..9993e2fe4ed6 100644 --- a/src/components/TabSelector/TabLabel.js +++ b/src/components/TabSelector/TabLabel.js @@ -1,7 +1,7 @@ -import {StyleSheet, View, Text, Animated} from 'react-native'; -import React from 'react'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; +import React from 'react'; +import {Animated, StyleSheet, Text, View} from 'react-native'; +import styles from '@styles/styles'; const propTypes = { /** Title of the tab */ diff --git a/src/components/TabSelector/TabSelector.js b/src/components/TabSelector/TabSelector.js index 3483ec10f804..b6ee359dc4ca 100644 --- a/src/components/TabSelector/TabSelector.js +++ b/src/components/TabSelector/TabSelector.js @@ -1,13 +1,13 @@ -import {View} from 'react-native'; -import React, {useMemo, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useMemo, useState} from 'react'; +import {View} from 'react-native'; import _ from 'underscore'; -import * as Expensicons from '../Icon/Expensicons'; +import * as Expensicons from '@components/Icon/Expensicons'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import TabSelectorItem from './TabSelectorItem'; -import CONST from '../../CONST'; -import useLocalize from '../../hooks/useLocalize'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; const propTypes = { /* Navigation state provided by React Navigation */ diff --git a/src/components/TabSelector/TabSelectorItem.js b/src/components/TabSelector/TabSelectorItem.js index 04a576f9dbf0..94861d0ccbba 100644 --- a/src/components/TabSelector/TabSelectorItem.js +++ b/src/components/TabSelector/TabSelectorItem.js @@ -1,8 +1,8 @@ -import {Animated, StyleSheet} from 'react-native'; -import React from 'react'; import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import PressableWithFeedback from '../Pressable/PressableWithFeedback'; +import React from 'react'; +import {Animated, StyleSheet} from 'react-native'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import styles from '@styles/styles'; import TabIcon from './TabIcon'; import TabLabel from './TabLabel'; diff --git a/src/components/TagPicker/index.js b/src/components/TagPicker/index.js index 05eca664bd0f..d680cea15c8f 100644 --- a/src/components/TagPicker/index.js +++ b/src/components/TagPicker/index.js @@ -1,15 +1,15 @@ -import React, {useMemo, useState} from 'react'; -import _ from 'underscore'; import lodashGet from 'lodash/get'; +import React, {useMemo, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import useLocalize from '../../hooks/useLocalize'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import OptionsSelector from '../OptionsSelector'; -import {propTypes, defaultProps} from './tagPickerPropTypes'; +import _ from 'underscore'; +import OptionsSelector from '@components/OptionsSelector'; +import useLocalize from '@hooks/useLocalize'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './tagPickerPropTypes'; function TagPicker({selectedTag, tag, policyTags, policyRecentlyUsedTags, onSubmit}) { const {translate} = useLocalize(); diff --git a/src/components/TagPicker/tagPickerPropTypes.js b/src/components/TagPicker/tagPickerPropTypes.js index 011885fe0f81..3010ab24a9c1 100644 --- a/src/components/TagPicker/tagPickerPropTypes.js +++ b/src/components/TagPicker/tagPickerPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import tagPropTypes from '../tagPropTypes'; +import tagPropTypes from '@components/tagPropTypes'; const propTypes = { /** The policyID we are getting tags for */ diff --git a/src/components/TaskHeaderActionButton.js b/src/components/TaskHeaderActionButton.js index a16f415f0fd7..b5dbe49fdd8d 100644 --- a/src/components/TaskHeaderActionButton.js +++ b/src/components/TaskHeaderActionButton.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import reportPropTypes from '../pages/reportPropTypes'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; -import styles from '../styles/styles'; +import compose from '@libs/compose'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import ONYXKEYS from '@src/ONYXKEYS'; import Button from './Button'; -import * as Task from '../libs/actions/Task'; -import * as ReportUtils from '../libs/ReportUtils'; -import compose from '../libs/compose'; -import ONYXKEYS from '../ONYXKEYS'; +import withLocalize, {withLocalizePropTypes} from './withLocalize'; const propTypes = { /** The report currently being looked at */ diff --git a/src/components/TestToolMenu.js b/src/components/TestToolMenu.js index 474e4c9bb10c..096bdfd5f97e 100644 --- a/src/components/TestToolMenu.js +++ b/src/components/TestToolMenu.js @@ -1,21 +1,21 @@ -import React from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import styles from '../styles/styles'; -import Switch from './Switch'; -import Text from './Text'; -import * as User from '../libs/actions/User'; -import * as Network from '../libs/actions/Network'; -import * as Session from '../libs/actions/Session'; -import ONYXKEYS from '../ONYXKEYS'; +import * as ApiUtils from '@libs/ApiUtils'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as Network from '@userActions/Network'; +import * as Session from '@userActions/Session'; +import * as User from '@userActions/User'; +import CONFIG from '@src/CONFIG'; +import ONYXKEYS from '@src/ONYXKEYS'; import Button from './Button'; -import TestToolRow from './TestToolRow'; import networkPropTypes from './networkPropTypes'; -import compose from '../libs/compose'; import {withNetwork} from './OnyxProvider'; -import * as ApiUtils from '../libs/ApiUtils'; -import CONFIG from '../CONFIG'; +import Switch from './Switch'; +import TestToolRow from './TestToolRow'; +import Text from './Text'; const propTypes = { /** User object in Onyx */ diff --git a/src/components/TestToolRow.tsx b/src/components/TestToolRow.tsx index 540c9dbc5068..149014893a83 100644 --- a/src/components/TestToolRow.tsx +++ b/src/components/TestToolRow.tsx @@ -1,6 +1,6 @@ import React from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; import Text from './Text'; type TestToolRowProps = { diff --git a/src/components/TestToolsModal.js b/src/components/TestToolsModal.js index 43a74e48df5d..3ae8223b34e7 100644 --- a/src/components/TestToolsModal.js +++ b/src/components/TestToolsModal.js @@ -1,13 +1,13 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import {withOnyx} from 'react-native-onyx'; +import React from 'react'; import {View} from 'react-native'; -import ONYXKEYS from '../ONYXKEYS'; +import {withOnyx} from 'react-native-onyx'; +import styles from '@styles/styles'; +import toggleTestToolsModal from '@userActions/TestTool'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Modal from './Modal'; -import CONST from '../CONST'; -import toggleTestToolsModal from '../libs/actions/TestTool'; import TestToolMenu from './TestToolMenu'; -import styles from '../styles/styles'; const propTypes = { /** Details about modal */ diff --git a/src/components/Text.tsx b/src/components/Text.tsx index 5cb252626d1f..80181156ee3a 100644 --- a/src/components/Text.tsx +++ b/src/components/Text.tsx @@ -2,9 +2,9 @@ import React, {ForwardedRef} from 'react'; // eslint-disable-next-line no-restricted-imports import {Text as RNText, TextProps as RNTextProps, StyleSheet} from 'react-native'; import type {TextStyle} from 'react-native'; -import fontFamily from '../styles/fontFamily'; -import themeColors from '../styles/themes/default'; -import variables from '../styles/variables'; +import fontFamily from '@styles/fontFamily'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; type TextProps = RNTextProps & { /** The color of the text */ diff --git a/src/components/TextInput/BaseTextInput.js b/src/components/TextInput/BaseTextInput.js index 9bfdc79fad68..c9b1944b5b81 100644 --- a/src/components/TextInput/BaseTextInput.js +++ b/src/components/TextInput/BaseTextInput.js @@ -1,28 +1,28 @@ -import _ from 'underscore'; -import React, {useState, useRef, useEffect, useCallback, useMemo} from 'react'; -import {Animated, View, StyleSheet, ActivityIndicator} from 'react-native'; import Str from 'expensify-common/lib/str'; -import RNTextInput from '../RNTextInput'; -import TextInputLabel from './TextInputLabel'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {ActivityIndicator, Animated, StyleSheet, View} from 'react-native'; +import _ from 'underscore'; +import Checkbox from '@components/Checkbox'; +import FormHelpMessage from '@components/FormHelpMessage'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import RNTextInput from '@components/RNTextInput'; +import SwipeInterceptPanResponder from '@components/SwipeInterceptPanResponder'; +import Text from '@components/Text'; +import withLocalize from '@components/withLocalize'; +import * as Browser from '@libs/Browser'; +import getSecureEntryKeyboardType from '@libs/getSecureEntryKeyboardType'; +import isInputAutoFilled from '@libs/isInputAutoFilled'; +import useNativeDriver from '@libs/useNativeDriver'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import * as baseTextInputPropTypes from './baseTextInputPropTypes'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import Text from '../Text'; import * as styleConst from './styleConst'; -import * as StyleUtils from '../../styles/StyleUtils'; -import variables from '../../styles/variables'; -import Checkbox from '../Checkbox'; -import getSecureEntryKeyboardType from '../../libs/getSecureEntryKeyboardType'; -import CONST from '../../CONST'; -import FormHelpMessage from '../FormHelpMessage'; -import isInputAutoFilled from '../../libs/isInputAutoFilled'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import withLocalize from '../withLocalize'; -import useNativeDriver from '../../libs/useNativeDriver'; -import * as Browser from '../../libs/Browser'; -import SwipeInterceptPanResponder from '../SwipeInterceptPanResponder'; +import TextInputLabel from './TextInputLabel'; function BaseTextInput(props) { const initialValue = props.value || props.defaultValue || ''; diff --git a/src/components/TextInput/TextInputLabel/index.js b/src/components/TextInput/TextInputLabel/index.js index 4267099a56ea..f777eff039bd 100644 --- a/src/components/TextInput/TextInputLabel/index.js +++ b/src/components/TextInput/TextInputLabel/index.js @@ -1,8 +1,8 @@ -import React, {useRef, useEffect} from 'react'; +import React, {useEffect, useRef} from 'react'; import {Animated} from 'react-native'; -import styles from '../../../styles/styles'; -import {propTypes, defaultProps} from './TextInputLabelPropTypes'; -import CONST from '../../../CONST'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes} from './TextInputLabelPropTypes'; function TextInputLabel({for: inputId, label, labelTranslateY, labelScale}) { const labelRef = useRef(null); diff --git a/src/components/TextInput/TextInputLabel/index.native.js b/src/components/TextInput/TextInputLabel/index.native.js index 9b065d4c722b..51b231287b1f 100644 --- a/src/components/TextInput/TextInputLabel/index.native.js +++ b/src/components/TextInput/TextInputLabel/index.native.js @@ -1,8 +1,8 @@ import React, {useState} from 'react'; import {Animated} from 'react-native'; -import styles from '../../../styles/styles'; +import * as styleConst from '@components/TextInput/styleConst'; +import styles from '@styles/styles'; import * as TextInputLabelPropTypes from './TextInputLabelPropTypes'; -import * as styleConst from '../styleConst'; function TextInputLabel(props) { const [width, setWidth] = useState(0); diff --git a/src/components/TextInput/index.js b/src/components/TextInput/index.js index 010121282a45..5f6164d3bc9a 100644 --- a/src/components/TextInput/index.js +++ b/src/components/TextInput/index.js @@ -1,12 +1,12 @@ import React, {useEffect, useRef} from 'react'; import _ from 'underscore'; -import styles from '../../styles/styles'; -import * as styleConst from './styleConst'; +import * as Browser from '@libs/Browser'; +import DomUtils from '@libs/DomUtils'; +import Visibility from '@libs/Visibility'; +import styles from '@styles/styles'; import BaseTextInput from './BaseTextInput'; import * as baseTextInputPropTypes from './baseTextInputPropTypes'; -import DomUtils from '../../libs/DomUtils'; -import Visibility from '../../libs/Visibility'; -import * as Browser from '../../libs/Browser'; +import * as styleConst from './styleConst'; function TextInput(props) { const textInputRef = useRef(null); diff --git a/src/components/TextInput/index.native.js b/src/components/TextInput/index.native.js index 059550855c0a..d28824a9977b 100644 --- a/src/components/TextInput/index.native.js +++ b/src/components/TextInput/index.native.js @@ -1,6 +1,6 @@ import React, {forwardRef, useEffect} from 'react'; import {AppState, Keyboard} from 'react-native'; -import styles from '../../styles/styles'; +import styles from '@styles/styles'; import BaseTextInput from './BaseTextInput'; import * as baseTextInputPropTypes from './baseTextInputPropTypes'; diff --git a/src/components/TextInput/styleConst.js b/src/components/TextInput/styleConst.js index f57b3f3ca56d..7d2f3021e3be 100644 --- a/src/components/TextInput/styleConst.js +++ b/src/components/TextInput/styleConst.js @@ -1,4 +1,4 @@ -import variables from '../../styles/variables'; +import variables from '@styles/variables'; const ACTIVE_LABEL_TRANSLATE_Y = 4; const ACTIVE_LABEL_SCALE = 0.8668; diff --git a/src/components/TextInputWithCurrencySymbol/BaseTextInputWithCurrencySymbol.js b/src/components/TextInputWithCurrencySymbol/BaseTextInputWithCurrencySymbol.js index ac0f4ccbe143..ee7abde8c554 100644 --- a/src/components/TextInputWithCurrencySymbol/BaseTextInputWithCurrencySymbol.js +++ b/src/components/TextInputWithCurrencySymbol/BaseTextInputWithCurrencySymbol.js @@ -1,9 +1,9 @@ import React from 'react'; -import AmountTextInput from '../AmountTextInput'; -import CurrencySymbolButton from '../CurrencySymbolButton'; -import * as CurrencyUtils from '../../libs/CurrencyUtils'; -import useLocalize from '../../hooks/useLocalize'; -import * as MoneyRequestUtils from '../../libs/MoneyRequestUtils'; +import AmountTextInput from '@components/AmountTextInput'; +import CurrencySymbolButton from '@components/CurrencySymbolButton'; +import useLocalize from '@hooks/useLocalize'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; import * as textInputWithCurrencySymbolPropTypes from './textInputWithCurrencySymbolPropTypes'; function BaseTextInputWithCurrencySymbol(props) { diff --git a/src/components/TextInputWithCurrencySymbol/index.android.js b/src/components/TextInputWithCurrencySymbol/index.android.js index 57b3c96136e8..f152cd3aa54f 100644 --- a/src/components/TextInputWithCurrencySymbol/index.android.js +++ b/src/components/TextInputWithCurrencySymbol/index.android.js @@ -1,4 +1,4 @@ -import React, {useState, useEffect} from 'react'; +import React, {useEffect, useState} from 'react'; import _ from 'underscore'; import BaseTextInputWithCurrencySymbol from './BaseTextInputWithCurrencySymbol'; import * as textInputWithCurrencySymbolPropTypes from './textInputWithCurrencySymbolPropTypes'; diff --git a/src/components/TextInputWithCurrencySymbol/textInputWithCurrencySymbolPropTypes.js b/src/components/TextInputWithCurrencySymbol/textInputWithCurrencySymbolPropTypes.js index 4e891029e71d..656561c14b14 100644 --- a/src/components/TextInputWithCurrencySymbol/textInputWithCurrencySymbolPropTypes.js +++ b/src/components/TextInputWithCurrencySymbol/textInputWithCurrencySymbolPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import refPropTypes from '../refPropTypes'; +import refPropTypes from '@components/refPropTypes'; const propTypes = { /** A ref to forward to amount text input */ diff --git a/src/components/TextLink.js b/src/components/TextLink.js index 3f7b7ff729c3..79f3d43a7743 100644 --- a/src/components/TextLink.js +++ b/src/components/TextLink.js @@ -1,12 +1,12 @@ -import _ from 'underscore'; -import React from 'react'; import PropTypes from 'prop-types'; -import Text from './Text'; -import styles from '../styles/styles'; -import stylePropTypes from '../styles/stylePropTypes'; -import CONST from '../CONST'; -import * as Link from '../libs/actions/Link'; +import React from 'react'; +import _ from 'underscore'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; import refPropTypes from './refPropTypes'; +import Text from './Text'; const propTypes = { /** Link to open in new tab */ diff --git a/src/components/TextPill.js b/src/components/TextPill.js index a8a4f35b64fb..81bb0ca1e037 100644 --- a/src/components/TextPill.js +++ b/src/components/TextPill.js @@ -1,9 +1,9 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import Text from './Text'; -import styles from '../styles/styles'; -import stylePropTypes from '../styles/stylePropTypes'; -import * as StyleUtils from '../styles/StyleUtils'; const propTypes = { text: PropTypes.string.isRequired, diff --git a/src/components/TextWithEllipsis/index.js b/src/components/TextWithEllipsis/index.js index 1734e24b03b6..8c2cd0dd9557 100644 --- a/src/components/TextWithEllipsis/index.js +++ b/src/components/TextWithEllipsis/index.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import Text from '../Text'; -import styles from '../../styles/styles'; -import stylePropTypes from '../../styles/stylePropTypes'; -import * as StyleUtils from '../../styles/StyleUtils'; +import Text from '@components/Text'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; const propTypes = { /** Leading text before the ellipsis */ diff --git a/src/components/ThreeDotsMenu/index.js b/src/components/ThreeDotsMenu/index.js index ab7ca57ed721..973aa7e5e189 100644 --- a/src/components/ThreeDotsMenu/index.js +++ b/src/components/ThreeDotsMenu/index.js @@ -1,17 +1,17 @@ -import React, {useState, useRef} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useRef, useState} from 'react'; +import {View} from 'react-native'; import _ from 'underscore'; -import Icon from '../Icon'; -import PopoverMenu from '../PopoverMenu'; -import styles from '../../styles/styles'; -import useLocalize from '../../hooks/useLocalize'; -import Tooltip from '../Tooltip/PopoverAnchorTooltip'; -import * as Expensicons from '../Icon/Expensicons'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PopoverMenu from '@components/PopoverMenu'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Tooltip from '@components/Tooltip/PopoverAnchorTooltip'; +import useLocalize from '@hooks/useLocalize'; +import * as Browser from '@libs/Browser'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import ThreeDotsMenuItemPropTypes from './ThreeDotsMenuItemPropTypes'; -import CONST from '../../CONST'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import * as Browser from '../../libs/Browser'; const propTypes = { /** Tooltip for the popup icon */ diff --git a/src/components/ThumbnailImage.js b/src/components/ThumbnailImage.js index 983f806bb2e2..bbd5e27accc1 100644 --- a/src/components/ThumbnailImage.js +++ b/src/components/ThumbnailImage.js @@ -1,12 +1,12 @@ import lodashClamp from 'lodash/clamp'; -import React, {useCallback, useState} from 'react'; -import {View, Dimensions} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useState} from 'react'; +import {Dimensions, View} from 'react-native'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import ImageWithSizeCalculation from './ImageWithSizeCalculation'; -import styles from '../styles/styles'; -import * as StyleUtils from '../styles/StyleUtils'; -import * as DeviceCapabilities from '../libs/DeviceCapabilities'; -import useWindowDimensions from '../hooks/useWindowDimensions'; const propTypes = { /** Source URL for the preview image */ diff --git a/src/components/Tooltip/BaseTooltip.js b/src/components/Tooltip/BaseTooltip.js index 7ef80c552980..3eb905e7a3e5 100644 --- a/src/components/Tooltip/BaseTooltip.js +++ b/src/components/Tooltip/BaseTooltip.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; -import React, {memo, useCallback, useEffect, useRef, useState} from 'react'; -import {Animated} from 'react-native'; import {BoundsObserver} from '@react-ng/bounds-observer'; import Str from 'expensify-common/lib/str'; -import TooltipRenderedOnPageBody from './TooltipRenderedOnPageBody'; -import Hoverable from '../Hoverable'; +import React, {memo, useCallback, useEffect, useRef, useState} from 'react'; +import {Animated} from 'react-native'; +import _ from 'underscore'; +import Hoverable from '@components/Hoverable'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import * as tooltipPropTypes from './tooltipPropTypes'; +import TooltipRenderedOnPageBody from './TooltipRenderedOnPageBody'; import TooltipSense from './TooltipSense'; -import * as DeviceCapabilities from '../../libs/DeviceCapabilities'; -import usePrevious from '../../hooks/usePrevious'; -import useLocalize from '../../hooks/useLocalize'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; const hasHoverSupport = DeviceCapabilities.hasHoverSupport(); diff --git a/src/components/Tooltip/PopoverAnchorTooltip.js b/src/components/Tooltip/PopoverAnchorTooltip.js index bca49ac9b7bc..6123be56544c 100644 --- a/src/components/Tooltip/PopoverAnchorTooltip.js +++ b/src/components/Tooltip/PopoverAnchorTooltip.js @@ -1,8 +1,8 @@ -import React, {useContext, useRef, useMemo} from 'react'; import PropTypes from 'prop-types'; -import {propTypes as tooltipPropTypes, defaultProps as tooltipDefaultProps} from './tooltipPropTypes'; +import React, {useContext, useMemo, useRef} from 'react'; +import {PopoverContext} from '@components/PopoverProvider'; import BaseTooltip from './BaseTooltip'; -import {PopoverContext} from '../PopoverProvider'; +import {defaultProps as tooltipDefaultProps, propTypes as tooltipPropTypes} from './tooltipPropTypes'; const propTypes = { ...tooltipPropTypes, diff --git a/src/components/Tooltip/TooltipRenderedOnPageBody.js b/src/components/Tooltip/TooltipRenderedOnPageBody.js index f61ecaee1059..69d06775ae2a 100644 --- a/src/components/Tooltip/TooltipRenderedOnPageBody.js +++ b/src/components/Tooltip/TooltipRenderedOnPageBody.js @@ -1,10 +1,10 @@ -import React, {useLayoutEffect, useEffect, useState, useRef, useMemo} from 'react'; import PropTypes from 'prop-types'; -import {Animated, View} from 'react-native'; +import React, {useEffect, useLayoutEffect, useMemo, useRef, useState} from 'react'; import ReactDOM from 'react-dom'; -import getTooltipStyles from '../../styles/getTooltipStyles'; -import Text from '../Text'; -import Log from '../../libs/Log'; +import {Animated, View} from 'react-native'; +import Text from '@components/Text'; +import Log from '@libs/Log'; +import getTooltipStyles from '@styles/getTooltipStyles'; const propTypes = { /** Window width */ diff --git a/src/components/Tooltip/TooltipSense.js b/src/components/Tooltip/TooltipSense.js index 76cd25294497..0e551e687cf3 100644 --- a/src/components/Tooltip/TooltipSense.js +++ b/src/components/Tooltip/TooltipSense.js @@ -1,5 +1,5 @@ import _ from 'underscore'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; let active = false; diff --git a/src/components/Tooltip/index.js b/src/components/Tooltip/index.js index 2e6789ec73f6..19a607220e1c 100644 --- a/src/components/Tooltip/index.js +++ b/src/components/Tooltip/index.js @@ -1,7 +1,7 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import {propTypes as tooltipPropTypes, defaultProps as tooltipDefaultProps} from './tooltipPropTypes'; +import React from 'react'; import BaseTooltip from './BaseTooltip'; +import {defaultProps as tooltipDefaultProps, propTypes as tooltipPropTypes} from './tooltipPropTypes'; const propTypes = { ...tooltipPropTypes, diff --git a/src/components/Tooltip/tooltipPropTypes.js b/src/components/Tooltip/tooltipPropTypes.js index 684a102e0339..21df0df07f0d 100644 --- a/src/components/Tooltip/tooltipPropTypes.js +++ b/src/components/Tooltip/tooltipPropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; -import refPropTypes from '../refPropTypes'; -import variables from '../../styles/variables'; -import CONST from '../../CONST'; +import refPropTypes from '@components/refPropTypes'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; const propTypes = { /** The text to display in the tooltip. If text is ommitted, only children will be rendered. */ diff --git a/src/components/UnorderedList.js b/src/components/UnorderedList.js index 4500d9fc3538..de8cb4abd7f8 100644 --- a/src/components/UnorderedList.js +++ b/src/components/UnorderedList.js @@ -1,9 +1,9 @@ +import PropTypes from 'prop-types'; import React from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; +import _ from 'underscore'; +import styles from '@styles/styles'; import Text from './Text'; -import styles from '../styles/styles'; const propTypes = { /** An array of strings to display as an unordered list */ diff --git a/src/components/UnreadActionIndicator.js b/src/components/UnreadActionIndicator.js index ff1090640570..4ba4ded97820 100755 --- a/src/components/UnreadActionIndicator.js +++ b/src/components/UnreadActionIndicator.js @@ -1,8 +1,8 @@ import React from 'react'; import {View} from 'react-native'; -import styles from '../styles/styles'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import Text from './Text'; -import CONST from '../CONST'; import withLocalize, {withLocalizePropTypes} from './withLocalize'; function UnreadActionIndicator(props) { diff --git a/src/components/UpdateAppModal/BaseUpdateAppModal.js b/src/components/UpdateAppModal/BaseUpdateAppModal.js index 7dfa0e7d3a82..07b446172286 100755 --- a/src/components/UpdateAppModal/BaseUpdateAppModal.js +++ b/src/components/UpdateAppModal/BaseUpdateAppModal.js @@ -1,7 +1,7 @@ -import React, {useState, memo} from 'react'; -import {propTypes, defaultProps} from './updateAppModalPropTypes'; -import ConfirmModal from '../ConfirmModal'; -import withLocalize from '../withLocalize'; +import React, {memo, useState} from 'react'; +import ConfirmModal from '@components/ConfirmModal'; +import withLocalize from '@components/withLocalize'; +import {defaultProps, propTypes} from './updateAppModalPropTypes'; function BaseUpdateAppModal({translate, onSubmit}) { const [isModalOpen, setIsModalOpen] = useState(true); diff --git a/src/components/UpdateAppModal/index.desktop.js b/src/components/UpdateAppModal/index.desktop.js index 424b7a616e39..397ce2c75ea3 100644 --- a/src/components/UpdateAppModal/index.desktop.js +++ b/src/components/UpdateAppModal/index.desktop.js @@ -1,7 +1,7 @@ import React from 'react'; +import ELECTRON_EVENTS from '../../../desktop/ELECTRON_EVENTS'; import BaseUpdateAppModal from './BaseUpdateAppModal'; import {propTypes} from './updateAppModalPropTypes'; -import ELECTRON_EVENTS from '../../../desktop/ELECTRON_EVENTS'; function UpdateAppModal(props) { const updateApp = () => { diff --git a/src/components/UserDetailsTooltip/BaseUserDetailsTooltip.web.js b/src/components/UserDetailsTooltip/BaseUserDetailsTooltip.web.js index 5f124cb21467..871173d01b56 100644 --- a/src/components/UserDetailsTooltip/BaseUserDetailsTooltip.web.js +++ b/src/components/UserDetailsTooltip/BaseUserDetailsTooltip.web.js @@ -1,18 +1,18 @@ -import React, {useCallback} from 'react'; -import {View, Text} from 'react-native'; -import {withOnyx} from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; +import React, {useCallback} from 'react'; +import {Text, View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import Avatar from '../Avatar'; -import Tooltip from '../Tooltip'; -import {propTypes, defaultProps} from './userDetailsTooltipPropTypes'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as UserUtils from '../../libs/UserUtils'; -import CONST from '../../CONST'; -import * as LocalePhoneNumber from '../../libs/LocalePhoneNumber'; -import useLocalize from '../../hooks/useLocalize'; +import Avatar from '@components/Avatar'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './userDetailsTooltipPropTypes'; function BaseUserDetailsTooltip(props) { const {translate} = useLocalize(); diff --git a/src/components/UserDetailsTooltip/index.js b/src/components/UserDetailsTooltip/index.js index 86778e4a1019..ea5cd4337071 100644 --- a/src/components/UserDetailsTooltip/index.js +++ b/src/components/UserDetailsTooltip/index.js @@ -1,7 +1,7 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import {propTypes as userDetailsTooltipPropTypes, defaultProps as userDetailsTooltipDefaultProps} from './userDetailsTooltipPropTypes'; +import React from 'react'; import BaseUserDetailsTooltip from './BaseUserDetailsTooltip'; +import {defaultProps as userDetailsTooltipDefaultProps, propTypes as userDetailsTooltipPropTypes} from './userDetailsTooltipPropTypes'; const propTypes = { ...userDetailsTooltipPropTypes, diff --git a/src/components/UserDetailsTooltip/userDetailsTooltipPropTypes.js b/src/components/UserDetailsTooltip/userDetailsTooltipPropTypes.js index f311ed0d18df..538e9ad5348f 100644 --- a/src/components/UserDetailsTooltip/userDetailsTooltipPropTypes.js +++ b/src/components/UserDetailsTooltip/userDetailsTooltipPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import personalDetailsPropType from '../../pages/personalDetailsPropType'; -import avatarPropTypes from '../avatarPropTypes'; +import avatarPropTypes from '@components/avatarPropTypes'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; const propTypes = { /** User's Account ID */ diff --git a/src/components/ValidateCode/ExpiredValidateCodeModal.js b/src/components/ValidateCode/ExpiredValidateCodeModal.js index e31e0772a8c5..f75cc3f19d49 100644 --- a/src/components/ValidateCode/ExpiredValidateCodeModal.js +++ b/src/components/ValidateCode/ExpiredValidateCodeModal.js @@ -1,13 +1,13 @@ import React from 'react'; import {View} from 'react-native'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import Text from '../Text'; -import * as Expensicons from '../Icon/Expensicons'; -import * as Illustrations from '../Icon/Illustrations'; -import variables from '../../styles/variables'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/components/ValidateCode/JustSignedInModal.js b/src/components/ValidateCode/JustSignedInModal.js index e96505470eba..dd6085646120 100644 --- a/src/components/ValidateCode/JustSignedInModal.js +++ b/src/components/ValidateCode/JustSignedInModal.js @@ -1,14 +1,14 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import Text from '../Text'; -import * as Expensicons from '../Icon/Expensicons'; -import * as Illustrations from '../Icon/Illustrations'; -import variables from '../../styles/variables'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/components/ValidateCode/ValidateCodeModal.js b/src/components/ValidateCode/ValidateCodeModal.js index ceebc54a47af..173467d16b14 100644 --- a/src/components/ValidateCode/ValidateCodeModal.js +++ b/src/components/ValidateCode/ValidateCodeModal.js @@ -1,20 +1,20 @@ -import React, {useCallback} from 'react'; -import PropTypes from 'prop-types'; -import {compose} from 'underscore'; -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; import {View} from 'react-native'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import Icon from '../Icon'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import Text from '../Text'; -import * as Expensicons from '../Icon/Expensicons'; -import * as Illustrations from '../Icon/Illustrations'; -import variables from '../../styles/variables'; -import TextLink from '../TextLink'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Session from '../../libs/actions/Session'; +import {withOnyx} from 'react-native-onyx'; +import {compose} from 'underscore'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Code to display. */ diff --git a/src/components/ValuePicker/ValueSelectorModal.js b/src/components/ValuePicker/ValueSelectorModal.js index 23aac4839d2a..0a524a324959 100644 --- a/src/components/ValuePicker/ValueSelectorModal.js +++ b/src/components/ValuePicker/ValueSelectorModal.js @@ -1,12 +1,12 @@ -import React, {useState, useEffect} from 'react'; -import PropTypes from 'prop-types'; import _ from 'lodash'; -import CONST from '../../CONST'; -import HeaderWithBackButton from '../HeaderWithBackButton'; -import SelectionList from '../SelectionList'; -import Modal from '../Modal'; -import ScreenWrapper from '../ScreenWrapper'; -import styles from '../../styles/styles'; +import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Modal from '@components/Modal'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Whether the modal is visible */ diff --git a/src/components/ValuePicker/index.js b/src/components/ValuePicker/index.js index 09573c1fdeca..e9ec200b7a7d 100644 --- a/src/components/ValuePicker/index.js +++ b/src/components/ValuePicker/index.js @@ -1,14 +1,14 @@ +import _ from 'lodash'; +import PropTypes from 'prop-types'; import React, {useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'lodash'; -import styles from '../../styles/styles'; -import MenuItemWithTopDescription from '../MenuItemWithTopDescription'; +import FormHelpMessage from '@components/FormHelpMessage'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import refPropTypes from '@components/refPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; import ValueSelectorModal from './ValueSelectorModal'; -import FormHelpMessage from '../FormHelpMessage'; -import refPropTypes from '../refPropTypes'; -import * as StyleUtils from '../../styles/StyleUtils'; -import variables from '../../styles/variables'; const propTypes = { /** Form Error description */ diff --git a/src/components/VideoChatButtonAndMenu/BaseVideoChatButtonAndMenu.js b/src/components/VideoChatButtonAndMenu/BaseVideoChatButtonAndMenu.js index ed1b71c8fb0f..ceb10de0f909 100755 --- a/src/components/VideoChatButtonAndMenu/BaseVideoChatButtonAndMenu.js +++ b/src/components/VideoChatButtonAndMenu/BaseVideoChatButtonAndMenu.js @@ -1,24 +1,24 @@ -import _ from 'underscore'; -import React, {useState, useRef, useEffect, useCallback} from 'react'; -import {View, Dimensions} from 'react-native'; import PropTypes from 'prop-types'; -import Icon from '../Icon'; -import * as Expensicons from '../Icon/Expensicons'; -import Popover from '../Popover'; -import MenuItem from '../MenuItem'; -import ZoomIcon from '../../../assets/images/zoom-icon.svg'; -import GoogleMeetIcon from '../../../assets/images/google-meet.svg'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from '../withLocalize'; -import compose from '../../libs/compose'; -import Tooltip from '../Tooltip/PopoverAnchorTooltip'; -import {propTypes as videoChatButtonAndMenuPropTypes, defaultProps} from './videoChatButtonAndMenuPropTypes'; -import * as Session from '../../libs/actions/Session'; -import PressableWithoutFeedback from '../Pressable/PressableWithoutFeedback'; -import * as Link from '../../libs/actions/Link'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {Dimensions, View} from 'react-native'; +import _ from 'underscore'; +import GoogleMeetIcon from '@assets/images/google-meet.svg'; +import ZoomIcon from '@assets/images/zoom-icon.svg'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import Popover from '@components/Popover'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Tooltip from '@components/Tooltip/PopoverAnchorTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Link from '@userActions/Link'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import {defaultProps, propTypes as videoChatButtonAndMenuPropTypes} from './videoChatButtonAndMenuPropTypes'; const propTypes = { /** Link to open when user wants to create a new google meet meeting */ diff --git a/src/components/VideoChatButtonAndMenu/index.android.js b/src/components/VideoChatButtonAndMenu/index.android.js index 53f43b73d600..fe19a530aa95 100644 --- a/src/components/VideoChatButtonAndMenu/index.android.js +++ b/src/components/VideoChatButtonAndMenu/index.android.js @@ -1,7 +1,7 @@ import React from 'react'; -import CONST from '../../CONST'; -import {propTypes, defaultProps} from './videoChatButtonAndMenuPropTypes'; +import CONST from '@src/CONST'; import BaseVideoChatButtonAndMenu from './BaseVideoChatButtonAndMenu'; +import {defaultProps, propTypes} from './videoChatButtonAndMenuPropTypes'; // On Android creating a new google meet meeting requires the CALL_PHONE permission in some cases // so we're just opening the google meet app instead, more details: diff --git a/src/components/VideoChatButtonAndMenu/index.js b/src/components/VideoChatButtonAndMenu/index.js index bf3be904103a..f3f657066e54 100644 --- a/src/components/VideoChatButtonAndMenu/index.js +++ b/src/components/VideoChatButtonAndMenu/index.js @@ -1,7 +1,7 @@ import React from 'react'; -import CONST from '../../CONST'; -import {propTypes, defaultProps} from './videoChatButtonAndMenuPropTypes'; +import CONST from '@src/CONST'; import BaseVideoChatButtonAndMenu from './BaseVideoChatButtonAndMenu'; +import {defaultProps, propTypes} from './videoChatButtonAndMenuPropTypes'; function VideoChatButtonAndMenu(props) { return ( diff --git a/src/components/WalletSection.js b/src/components/WalletSection.js index ec8a1680937c..d79d2be0ddc9 100644 --- a/src/components/WalletSection.js +++ b/src/components/WalletSection.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; import React from 'react'; +import styles from '@styles/styles'; import Section from './Section'; -import styles from '../styles/styles'; const propTypes = { /** Contents to display inside the section */ diff --git a/src/components/WalletStatementModal/index.js b/src/components/WalletStatementModal/index.js index b4d87bf4e0e4..59508f8057ab 100644 --- a/src/components/WalletStatementModal/index.js +++ b/src/components/WalletStatementModal/index.js @@ -1,18 +1,18 @@ -import React, {useState} from 'react'; -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import React, {useState} from 'react'; import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import compose from '../../libs/compose'; -import withLocalize from '../withLocalize'; -import ONYXKEYS from '../../ONYXKEYS'; -import {walletStatementPropTypes, walletStatementDefaultProps} from './WalletStatementModalPropTypes'; -import styles from '../../styles/styles'; -import FullScreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import * as Report from '../../libs/actions/Report'; -import CONST from '../../CONST'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import withLocalize from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {walletStatementDefaultProps, walletStatementPropTypes} from './WalletStatementModalPropTypes'; function WalletStatementModal({statementPageURL, session}) { const [isLoading, setIsLoading] = useState(true); diff --git a/src/components/WalletStatementModal/index.native.js b/src/components/WalletStatementModal/index.native.js index 38d1f90af00d..9c2aea8e8ec4 100644 --- a/src/components/WalletStatementModal/index.native.js +++ b/src/components/WalletStatementModal/index.native.js @@ -1,15 +1,15 @@ -import React, {useCallback, useRef} from 'react'; -import {WebView} from 'react-native-webview'; import lodashGet from 'lodash/get'; +import React, {useCallback, useRef} from 'react'; import {withOnyx} from 'react-native-onyx'; +import {WebView} from 'react-native-webview'; import _ from 'underscore'; -import {walletStatementPropTypes, walletStatementDefaultProps} from './WalletStatementModalPropTypes'; -import FullScreenLoadingIndicator from '../FullscreenLoadingIndicator'; -import * as Report from '../../libs/actions/Report'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {walletStatementDefaultProps, walletStatementPropTypes} from './WalletStatementModalPropTypes'; const IOU_ROUTES = [ROUTES.IOU_REQUEST, ROUTES.IOU_SEND]; const renderLoading = () => ; diff --git a/src/components/ZeroWidthView/index.js b/src/components/ZeroWidthView/index.js index 6c3809a40a04..58b2dfa039ef 100644 --- a/src/components/ZeroWidthView/index.js +++ b/src/components/ZeroWidthView/index.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import * as EmojiUtils from '../../libs/EmojiUtils'; -import * as Browser from '../../libs/Browser'; -import Text from '../Text'; +import React from 'react'; +import Text from '@components/Text'; +import * as Browser from '@libs/Browser'; +import * as EmojiUtils from '@libs/EmojiUtils'; const propTypes = { /** If this is the Concierge chat, we'll open the modal for requesting a setup call instead of showing popover menu */ diff --git a/src/components/avatarPropTypes.js b/src/components/avatarPropTypes.js index 915eac995fcb..9ecea0fad778 100644 --- a/src/components/avatarPropTypes.js +++ b/src/components/avatarPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; export default PropTypes.shape({ source: PropTypes.oneOfType([PropTypes.string, PropTypes.func]), diff --git a/src/components/createOnyxContext.tsx b/src/components/createOnyxContext.tsx index a0ac5942b098..f7b2d6cbf297 100644 --- a/src/components/createOnyxContext.tsx +++ b/src/components/createOnyxContext.tsx @@ -1,9 +1,9 @@ -import React, {ComponentType, ForwardRefExoticComponent, ForwardedRef, PropsWithoutRef, ReactNode, RefAttributes, createContext, forwardRef, useContext} from 'react'; -import {withOnyx} from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; -import {OnyxCollectionKey, OnyxKey, OnyxKeyValue, OnyxValues} from '../ONYXKEYS'; -import ChildrenProps from '../types/utils/ChildrenProps'; +import React, {ComponentType, createContext, ForwardedRef, forwardRef, ForwardRefExoticComponent, PropsWithoutRef, ReactNode, RefAttributes, useContext} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import {OnyxCollectionKey, OnyxKey, OnyxKeyValue, OnyxValues} from '@src/ONYXKEYS'; +import ChildrenProps from '@src/types/utils/ChildrenProps'; type OnyxKeys = (OnyxKey | OnyxCollectionKey) & keyof OnyxValues; diff --git a/src/components/menuItemPropTypes.js b/src/components/menuItemPropTypes.js index 4b37e8040d45..d4b12b9cf479 100644 --- a/src/components/menuItemPropTypes.js +++ b/src/components/menuItemPropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; import _ from 'underscore'; -import CONST from '../CONST'; -import stylePropTypes from '../styles/stylePropTypes'; +import stylePropTypes from '@styles/stylePropTypes'; +import CONST from '@src/CONST'; import avatarPropTypes from './avatarPropTypes'; import refPropTypes from './refPropTypes'; diff --git a/src/components/optionPropTypes.js b/src/components/optionPropTypes.js index 709298036f07..d5ef485b8276 100644 --- a/src/components/optionPropTypes.js +++ b/src/components/optionPropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; -import CONST from '../CONST'; -import participantPropTypes from './participantPropTypes'; +import CONST from '@src/CONST'; import avatarPropTypes from './avatarPropTypes'; +import participantPropTypes from './participantPropTypes'; export default PropTypes.shape({ // Text to display diff --git a/src/components/transactionPropTypes.js b/src/components/transactionPropTypes.js index e3e06bb00c01..049fe60630e5 100644 --- a/src/components/transactionPropTypes.js +++ b/src/components/transactionPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; import _ from 'underscore'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; export default PropTypes.shape({ /** The transaction id */ diff --git a/src/components/withCurrentReportID.js b/src/components/withCurrentReportID.js index 18f716981e65..ab1b5abc2395 100644 --- a/src/components/withCurrentReportID.js +++ b/src/components/withCurrentReportID.js @@ -1,8 +1,7 @@ -import React, {createContext, forwardRef, useCallback, useState, useMemo} from 'react'; import PropTypes from 'prop-types'; - -import getComponentDisplayName from '../libs/getComponentDisplayName'; -import Navigation from '../libs/Navigation/Navigation'; +import React, {createContext, forwardRef, useCallback, useMemo, useState} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import Navigation from '@libs/Navigation/Navigation'; const CurrentReportIDContext = createContext(null); diff --git a/src/components/withCurrentUserPersonalDetails.tsx b/src/components/withCurrentUserPersonalDetails.tsx index e1472f280f17..ed580b4dbe4a 100644 --- a/src/components/withCurrentUserPersonalDetails.tsx +++ b/src/components/withCurrentUserPersonalDetails.tsx @@ -1,9 +1,9 @@ -import React, {ComponentType, RefAttributes, ForwardedRef, useMemo} from 'react'; +import React, {ComponentType, ForwardedRef, RefAttributes, useMemo} from 'react'; import {OnyxEntry, withOnyx} from 'react-native-onyx'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; -import ONYXKEYS from '../ONYXKEYS'; -import personalDetailsPropType from '../pages/personalDetailsPropType'; -import type {PersonalDetails, Session} from '../types/onyx'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import ONYXKEYS from '@src/ONYXKEYS'; +import type {PersonalDetails, Session} from '@src/types/onyx'; type CurrentUserPersonalDetails = PersonalDetails | Record; diff --git a/src/components/withEnvironment.tsx b/src/components/withEnvironment.tsx index 0f065eac68fe..1bfc147f0db3 100644 --- a/src/components/withEnvironment.tsx +++ b/src/components/withEnvironment.tsx @@ -1,8 +1,8 @@ -import React, {ComponentType, RefAttributes, ReactNode, ForwardedRef, ReactElement, createContext, useState, useEffect, forwardRef, useContext, useMemo} from 'react'; +import React, {ComponentType, createContext, ForwardedRef, forwardRef, ReactElement, ReactNode, RefAttributes, useContext, useEffect, useMemo, useState} from 'react'; import {ValueOf} from 'type-fest'; -import * as Environment from '../libs/Environment/Environment'; -import CONST from '../CONST'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import * as Environment from '@libs/Environment/Environment'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import CONST from '@src/CONST'; type EnvironmentProviderProps = { /** Actual content wrapped by this component */ diff --git a/src/components/withKeyboardState.js b/src/components/withKeyboardState.js index 3154f7e98d67..d89a4a8228bf 100755 --- a/src/components/withKeyboardState.js +++ b/src/components/withKeyboardState.js @@ -1,7 +1,7 @@ -import React, {forwardRef, createContext, useEffect, useState, useMemo} from 'react'; -import {Keyboard} from 'react-native'; import PropTypes from 'prop-types'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React, {createContext, forwardRef, useEffect, useMemo, useState} from 'react'; +import {Keyboard} from 'react-native'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; const KeyboardStateContext = createContext(null); const keyboardStatePropTypes = { diff --git a/src/components/withLocalize.js b/src/components/withLocalize.js index 65e98f78f312..346d402829bd 100755 --- a/src/components/withLocalize.js +++ b/src/components/withLocalize.js @@ -1,7 +1,7 @@ -import React, {forwardRef} from 'react'; import PropTypes from 'prop-types'; +import React, {forwardRef} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; import {LocaleContext} from './LocaleContextProvider'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; const withLocalizePropTypes = { /** Returns translated string for given locale and phrase */ diff --git a/src/components/withNavigation.tsx b/src/components/withNavigation.tsx index c5842fdacc44..0834eabc2adb 100644 --- a/src/components/withNavigation.tsx +++ b/src/components/withNavigation.tsx @@ -1,6 +1,6 @@ -import React, {ComponentType, ForwardedRef, RefAttributes} from 'react'; import {NavigationProp, useNavigation} from '@react-navigation/native'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React, {ComponentType, ForwardedRef, RefAttributes} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; type WithNavigationProps = { navigation: NavigationProp; diff --git a/src/components/withNavigationFallback.js b/src/components/withNavigationFallback.js index 413d0734507a..a03c1155fa46 100644 --- a/src/components/withNavigationFallback.js +++ b/src/components/withNavigationFallback.js @@ -1,6 +1,6 @@ -import React, {forwardRef, useContext, useMemo} from 'react'; import {NavigationContext} from '@react-navigation/core'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React, {forwardRef, useContext, useMemo} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; import refPropTypes from './refPropTypes'; export default function (WrappedComponent) { diff --git a/src/components/withNavigationFocus.tsx b/src/components/withNavigationFocus.tsx index f3f1d3561d9c..8dcd06ecb4c8 100644 --- a/src/components/withNavigationFocus.tsx +++ b/src/components/withNavigationFocus.tsx @@ -1,6 +1,6 @@ -import React, {ComponentType, ForwardedRef, RefAttributes} from 'react'; import {useIsFocused} from '@react-navigation/native'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React, {ComponentType, ForwardedRef, RefAttributes} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; type WithNavigationFocusProps = { isFocused: boolean; diff --git a/src/components/withTheme.js b/src/components/withTheme.js index 753a75d2c354..1d8af53de01d 100644 --- a/src/components/withTheme.js +++ b/src/components/withTheme.js @@ -1,7 +1,7 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import useTheme from '../styles/themes/useTheme'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import useTheme from '@styles/themes/useTheme'; import refPropTypes from './refPropTypes'; const withThemePropTypes = { diff --git a/src/components/withThemeStyles.js b/src/components/withThemeStyles.js index 63356e20d990..533efa79a580 100644 --- a/src/components/withThemeStyles.js +++ b/src/components/withThemeStyles.js @@ -1,7 +1,7 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import useThemeStyles from '../styles/useThemeStyles'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import React from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import useThemeStyles from '@styles/useThemeStyles'; import refPropTypes from './refPropTypes'; const withThemeStylesPropTypes = { diff --git a/src/components/withToggleVisibilityView.js b/src/components/withToggleVisibilityView.js index c168b49ced20..04c6ab8e8481 100644 --- a/src/components/withToggleVisibilityView.js +++ b/src/components/withToggleVisibilityView.js @@ -1,8 +1,8 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../styles/styles'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import styles from '@styles/styles'; import refPropTypes from './refPropTypes'; const toggleVisibilityViewPropTypes = { diff --git a/src/components/withViewportOffsetTop.tsx b/src/components/withViewportOffsetTop.tsx index e2e1dc2d3484..d6c170b20480 100644 --- a/src/components/withViewportOffsetTop.tsx +++ b/src/components/withViewportOffsetTop.tsx @@ -1,6 +1,6 @@ -import React, {useEffect, forwardRef, useState, ComponentType, RefAttributes, ForwardedRef} from 'react'; -import getComponentDisplayName from '../libs/getComponentDisplayName'; -import addViewportResizeListener from '../libs/VisualViewport'; +import React, {ComponentType, ForwardedRef, forwardRef, RefAttributes, useEffect, useState} from 'react'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import addViewportResizeListener from '@libs/VisualViewport'; type ViewportOffsetTopProps = { // viewportOffsetTop returns the offset of the top edge of the visual viewport from the diff --git a/src/components/withWindowDimensions/index.js b/src/components/withWindowDimensions/index.js index 16e5985e0985..f46624b2f41c 100644 --- a/src/components/withWindowDimensions/index.js +++ b/src/components/withWindowDimensions/index.js @@ -1,11 +1,11 @@ -import React, {forwardRef, createContext, useState, useEffect, useMemo} from 'react'; -import PropTypes from 'prop-types'; import lodashDebounce from 'lodash/debounce'; +import PropTypes from 'prop-types'; +import React, {createContext, forwardRef, useEffect, useMemo, useState} from 'react'; import {Dimensions} from 'react-native'; import {useSafeAreaInsets} from 'react-native-safe-area-context'; -import getComponentDisplayName from '../../libs/getComponentDisplayName'; -import variables from '../../styles/variables'; -import getWindowHeightAdjustment from '../../libs/getWindowHeightAdjustment'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import getWindowHeightAdjustment from '@libs/getWindowHeightAdjustment'; +import variables from '@styles/variables'; const WindowDimensionsContext = createContext(null); const windowDimensionsPropTypes = { diff --git a/src/components/withWindowDimensions/index.native.js b/src/components/withWindowDimensions/index.native.js index 363196b3fd4d..91d81f5fb4e0 100644 --- a/src/components/withWindowDimensions/index.native.js +++ b/src/components/withWindowDimensions/index.native.js @@ -1,10 +1,10 @@ -import React, {forwardRef, createContext, useState, useEffect, useMemo} from 'react'; import PropTypes from 'prop-types'; +import React, {createContext, forwardRef, useEffect, useMemo, useState} from 'react'; import {Dimensions} from 'react-native'; import {useSafeAreaInsets} from 'react-native-safe-area-context'; -import getComponentDisplayName from '../../libs/getComponentDisplayName'; -import variables from '../../styles/variables'; -import getWindowHeightAdjustment from '../../libs/getWindowHeightAdjustment'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import getWindowHeightAdjustment from '@libs/getWindowHeightAdjustment'; +import variables from '@styles/variables'; const WindowDimensionsContext = createContext(null); const windowDimensionsPropTypes = { diff --git a/src/hooks/useArrowKeyFocusManager.js b/src/hooks/useArrowKeyFocusManager.js index 58cecb169249..a633dba5ffc5 100644 --- a/src/hooks/useArrowKeyFocusManager.js +++ b/src/hooks/useArrowKeyFocusManager.js @@ -1,6 +1,6 @@ -import {useState, useEffect, useCallback, useMemo} from 'react'; +import {useCallback, useEffect, useMemo, useState} from 'react'; +import CONST from '@src/CONST'; import useKeyboardShortcut from './useKeyboardShortcut'; -import CONST from '../CONST'; /** * A hook that makes it easy to use the arrow keys to manage focus of items in a list diff --git a/src/hooks/useAutoFocusInput.js b/src/hooks/useAutoFocusInput.js index 6611f867f210..275fed67f52d 100644 --- a/src/hooks/useAutoFocusInput.js +++ b/src/hooks/useAutoFocusInput.js @@ -1,6 +1,6 @@ import {useFocusEffect} from '@react-navigation/native'; -import {useState, useEffect, useRef, useCallback} from 'react'; -import CONST from '../CONST'; +import {useCallback, useEffect, useRef, useState} from 'react'; +import CONST from '@src/CONST'; export default function useAutoFocusInput() { const [isInputInitialized, setIsInputInitialized] = useState(false); diff --git a/src/hooks/useCopySelectionHelper.ts b/src/hooks/useCopySelectionHelper.ts index b41bfb3c4aee..be7830dc6170 100644 --- a/src/hooks/useCopySelectionHelper.ts +++ b/src/hooks/useCopySelectionHelper.ts @@ -1,9 +1,9 @@ -import {useEffect} from 'react'; import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import CONST from '../CONST'; -import KeyboardShortcut from '../libs/KeyboardShortcut'; -import Clipboard from '../libs/Clipboard'; -import SelectionScraper from '../libs/SelectionScraper'; +import {useEffect} from 'react'; +import Clipboard from '@libs/Clipboard'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import SelectionScraper from '@libs/SelectionScraper'; +import CONST from '@src/CONST'; function copySelectionToClipboard() { const selection = SelectionScraper.getCurrentSelection(); diff --git a/src/hooks/useCurrentReportID.js b/src/hooks/useCurrentReportID.js index b22ac55616e8..1b3e4b706c4c 100644 --- a/src/hooks/useCurrentReportID.js +++ b/src/hooks/useCurrentReportID.js @@ -1,5 +1,5 @@ import {useContext} from 'react'; -import {CurrentReportIDContext} from '../components/withCurrentReportID'; +import {CurrentReportIDContext} from '@components/withCurrentReportID'; export default function useCurrentReportID() { return useContext(CurrentReportIDContext); diff --git a/src/hooks/useDebounce.js b/src/hooks/useDebounce.js index 8995a0443b85..874f9d72b276 100644 --- a/src/hooks/useDebounce.js +++ b/src/hooks/useDebounce.js @@ -1,5 +1,5 @@ -import {useEffect, useRef} from 'react'; import lodashDebounce from 'lodash/debounce'; +import {useEffect, useRef} from 'react'; /** * Create and return a debounced function. diff --git a/src/hooks/useDelayedInputFocus.js b/src/hooks/useDelayedInputFocus.js index 2fd94327a588..7a4a64104e48 100644 --- a/src/hooks/useDelayedInputFocus.js +++ b/src/hooks/useDelayedInputFocus.js @@ -1,6 +1,6 @@ -import {useCallback, useRef} from 'react'; import {useFocusEffect} from '@react-navigation/native'; -import CONST from '../CONST'; +import {useCallback, useRef} from 'react'; +import CONST from '@src/CONST'; /** * Focus a text input when a screen is navigated to, after the specified time delay has elapsed. diff --git a/src/hooks/useDragAndDrop.ts b/src/hooks/useDragAndDrop.ts index 27230dd94679..3f0142492d0d 100644 --- a/src/hooks/useDragAndDrop.ts +++ b/src/hooks/useDragAndDrop.ts @@ -1,5 +1,5 @@ -import React, {useEffect, useRef, useState, useCallback} from 'react'; import {useIsFocused} from '@react-navigation/native'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; const COPY_DROP_EFFECT = 'copy'; const NONE_DROP_EFFECT = 'none'; diff --git a/src/hooks/useEnvironment.ts b/src/hooks/useEnvironment.ts index 0b1601ee972a..60e0b4a12394 100644 --- a/src/hooks/useEnvironment.ts +++ b/src/hooks/useEnvironment.ts @@ -1,7 +1,7 @@ import {useContext} from 'react'; -import CONST from '../CONST'; -import {EnvironmentContext} from '../components/withEnvironment'; -import type {EnvironmentContextValue} from '../components/withEnvironment'; +import {EnvironmentContext} from '@components/withEnvironment'; +import type {EnvironmentContextValue} from '@components/withEnvironment'; +import CONST from '@src/CONST'; type UseEnvironment = Partial & { isProduction: boolean; diff --git a/src/hooks/useKeyboardShortcut.js b/src/hooks/useKeyboardShortcut.js index b8e297c966ed..470d29243fe8 100644 --- a/src/hooks/useKeyboardShortcut.js +++ b/src/hooks/useKeyboardShortcut.js @@ -1,6 +1,6 @@ import {useEffect} from 'react'; -import KeyboardShortcut from '../libs/KeyboardShortcut'; -import CONST from '../CONST'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import CONST from '@src/CONST'; /** * Register a keyboard shortcut handler. diff --git a/src/hooks/useKeyboardState.js b/src/hooks/useKeyboardState.js index 8b57fb60f2b6..68e9dbfc2b13 100644 --- a/src/hooks/useKeyboardState.js +++ b/src/hooks/useKeyboardState.js @@ -1,5 +1,5 @@ import {useContext} from 'react'; -import {KeyboardStateContext} from '../components/withKeyboardState'; +import {KeyboardStateContext} from '@components/withKeyboardState'; /** * Hook for getting current state of keyboard diff --git a/src/hooks/useLocalize.js b/src/hooks/useLocalize.js index 7f7a610fca8b..71968cdb6e61 100644 --- a/src/hooks/useLocalize.js +++ b/src/hooks/useLocalize.js @@ -1,5 +1,5 @@ import {useContext} from 'react'; -import {LocaleContext} from '../components/LocaleContextProvider'; +import {LocaleContext} from '@components/LocaleContextProvider'; export default function useLocalize() { return useContext(LocaleContext); diff --git a/src/hooks/useNetwork.ts b/src/hooks/useNetwork.ts index 4405dd7126a5..f9e1a627c5f5 100644 --- a/src/hooks/useNetwork.ts +++ b/src/hooks/useNetwork.ts @@ -1,5 +1,5 @@ -import {useRef, useContext, useEffect} from 'react'; -import {NetworkContext} from '../components/OnyxProvider'; +import {useContext, useEffect, useRef} from 'react'; +import {NetworkContext} from '@components/OnyxProvider'; type UseNetworkProps = { onReconnect?: () => void; diff --git a/src/hooks/usePermissions.ts b/src/hooks/usePermissions.ts index 09e87554b5c3..e60825b610e9 100644 --- a/src/hooks/usePermissions.ts +++ b/src/hooks/usePermissions.ts @@ -1,6 +1,6 @@ import {useContext, useMemo} from 'react'; -import Permissions from '../libs/Permissions'; -import {BetasContext} from '../components/OnyxProvider'; +import {BetasContext} from '@components/OnyxProvider'; +import Permissions from '@libs/Permissions'; type PermissionKey = keyof typeof Permissions; type UsePermissions = Partial>; diff --git a/src/hooks/usePrivatePersonalDetails.js b/src/hooks/usePrivatePersonalDetails.js index 14c1e42e629a..04d90f1ce5de 100644 --- a/src/hooks/usePrivatePersonalDetails.js +++ b/src/hooks/usePrivatePersonalDetails.js @@ -1,7 +1,7 @@ -import {useEffect, useContext} from 'react'; +import {useContext, useEffect} from 'react'; import _ from 'underscore'; -import * as PersonalDetails from '../libs/actions/PersonalDetails'; -import {NetworkContext} from '../components/OnyxProvider'; +import {NetworkContext} from '@components/OnyxProvider'; +import * as PersonalDetails from '@userActions/PersonalDetails'; /** * Hook for fetching private personal details diff --git a/src/hooks/useReportScrollManager/index.native.ts b/src/hooks/useReportScrollManager/index.native.ts index ed9b7968636c..0d4c956b7bd8 100644 --- a/src/hooks/useReportScrollManager/index.native.ts +++ b/src/hooks/useReportScrollManager/index.native.ts @@ -1,5 +1,5 @@ -import {useContext, useCallback} from 'react'; -import {ActionListContext} from '../../pages/home/ReportScreenContext'; +import {useCallback, useContext} from 'react'; +import {ActionListContext} from '@pages/home/ReportScreenContext'; import ReportScrollManagerData from './types'; function useReportScrollManager(): ReportScrollManagerData { diff --git a/src/hooks/useReportScrollManager/index.ts b/src/hooks/useReportScrollManager/index.ts index fd2c884e5b4c..081844fc8c79 100644 --- a/src/hooks/useReportScrollManager/index.ts +++ b/src/hooks/useReportScrollManager/index.ts @@ -1,5 +1,5 @@ -import {useContext, useCallback} from 'react'; -import {ActionListContext} from '../../pages/home/ReportScreenContext'; +import {useCallback, useContext} from 'react'; +import {ActionListContext} from '@pages/home/ReportScreenContext'; import ReportScrollManagerData from './types'; function useReportScrollManager(): ReportScrollManagerData { diff --git a/src/hooks/useReportScrollManager/types.ts b/src/hooks/useReportScrollManager/types.ts index f5ff9b2f35cd..a10238d51f74 100644 --- a/src/hooks/useReportScrollManager/types.ts +++ b/src/hooks/useReportScrollManager/types.ts @@ -1,4 +1,4 @@ -import {ActionListContextType} from '../../pages/home/ReportScreenContext'; +import {ActionListContextType} from '@pages/home/ReportScreenContext'; type ReportScrollManagerData = { ref: ActionListContextType; diff --git a/src/hooks/useSingleExecution.js b/src/hooks/useSingleExecution.js index 0b466252ed58..a2b4ccb4cd53 100644 --- a/src/hooks/useSingleExecution.js +++ b/src/hooks/useSingleExecution.js @@ -1,5 +1,5 @@ +import {useCallback, useRef, useState} from 'react'; import {InteractionManager} from 'react-native'; -import {useCallback, useState, useRef} from 'react'; /** * With any action passed in, it will only allow 1 such action to occur at a time. diff --git a/src/hooks/useWaitForNavigation.js b/src/hooks/useWaitForNavigation.js index 00f4405dff12..81c26d7beb46 100644 --- a/src/hooks/useWaitForNavigation.js +++ b/src/hooks/useWaitForNavigation.js @@ -1,5 +1,5 @@ -import {useEffect, useRef} from 'react'; import {useNavigation} from '@react-navigation/native'; +import {useEffect, useRef} from 'react'; /** * Returns a promise that resolves when navigation finishes. diff --git a/src/hooks/useWindowDimensions/index.native.ts b/src/hooks/useWindowDimensions/index.native.ts index 5b0ec2002201..e0268445fe4e 100644 --- a/src/hooks/useWindowDimensions/index.native.ts +++ b/src/hooks/useWindowDimensions/index.native.ts @@ -1,6 +1,6 @@ // eslint-disable-next-line no-restricted-imports import {useWindowDimensions} from 'react-native'; -import variables from '../../styles/variables'; +import variables from '@styles/variables'; import WindowDimensions from './types'; /** diff --git a/src/hooks/useWindowDimensions/index.ts b/src/hooks/useWindowDimensions/index.ts index f9fee6301d06..ab856bcf8e1b 100644 --- a/src/hooks/useWindowDimensions/index.ts +++ b/src/hooks/useWindowDimensions/index.ts @@ -1,6 +1,6 @@ // eslint-disable-next-line no-restricted-imports import {Dimensions, useWindowDimensions} from 'react-native'; -import variables from '../../styles/variables'; +import variables from '@styles/variables'; import WindowDimensions from './types'; /** diff --git a/src/languages/en.ts b/src/languages/en.ts index 1251e44cfac5..7cdce062faac 100755 --- a/src/languages/en.ts +++ b/src/languages/en.ts @@ -1,84 +1,84 @@ import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; -import CONST from '../CONST'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import CONST from '@src/CONST'; import type { AddressLineParams, - CharacterLimitParams, - MaxParticipantsReachedParams, - ZipCodeExampleFormatParams, - LoggedInAsParams, - NewFaceEnterMagicCodeParams, - WelcomeEnterMagicCodeParams, AlreadySignedInParams, - GoBackMessageParams, - LocalTimeParams, - EditActionParams, - DeleteActionParams, - DeleteConfirmationParams, - BeginningOfChatHistoryDomainRoomPartOneParams, + AmountEachParams, BeginningOfChatHistoryAdminRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartTwo, - WelcomeToRoomParams, - ReportArchiveReasonsClosedParams, - ReportArchiveReasonsMergedParams, - ReportArchiveReasonsRemovedFromPolicyParams, - ReportArchiveReasonsPolicyDeletedParams, - RequestCountParams, - SettleExpensifyCardParams, - RequestAmountParams, - SplitAmountParams, + BeginningOfChatHistoryDomainRoomPartOneParams, + CharacterLimitParams, + ConfirmThatParams, + DateShouldBeAfterParams, + DateShouldBeBeforeParams, + DeleteActionParams, + DeleteConfirmationParams, DidSplitAmountMessageParams, - AmountEachParams, + EditActionParams, + EnterMagicCodeParams, + FormattedMaxLengthParams, + GoBackMessageParams, + GoToRoomParams, + IncorrectZipFormatParams, + InstantSummaryParams, + LocalTimeParams, + LoggedInAsParams, + ManagerApprovedParams, + MaxParticipantsReachedParams, + NewFaceEnterMagicCodeParams, + NoLongerHaveAccessParams, + NotAllowedExtensionParams, + NotYouParams, + OOOEventSummaryFullDayParams, + OOOEventSummaryPartialDayParams, + OurEmailProviderParams, + PaidElsewhereWithAmountParams, + PaidWithExpensifyWithAmountParams, + ParentNavigationSummaryParams, PayerOwesAmountParams, PayerOwesParams, PayerPaidAmountParams, PayerPaidParams, PayerSettledParams, - WaitingOnBankAccountParams, - SettledAfterAddedBankAccountParams, - PaidElsewhereWithAmountParams, - PaidWithExpensifyWithAmountParams, - ThreadRequestReportNameParams, - ThreadSentMoneyReportNameParams, - SizeExceededParams, + RemovedTheRequestParams, + RenamedRoomActionParams, + ReportArchiveReasonsClosedParams, + ReportArchiveReasonsMergedParams, + ReportArchiveReasonsPolicyDeletedParams, + ReportArchiveReasonsRemovedFromPolicyParams, + RequestAmountParams, + RequestCountParams, + RequestedAmountMessageParams, ResolutionConstraintsParams, - NotAllowedExtensionParams, - EnterMagicCodeParams, - TransferParams, - InstantSummaryParams, - NotYouParams, - DateShouldBeBeforeParams, - DateShouldBeAfterParams, - IncorrectZipFormatParams, - WeSentYouMagicSignInLinkParams, - ToValidateLoginParams, - NoLongerHaveAccessParams, - OurEmailProviderParams, - ConfirmThatParams, - UntilTimeParams, - StepCounterParams, - UserIsAlreadyMemberParams, - GoToRoomParams, - WelcomeNoteParams, RoomNameReservedErrorParams, - RenamedRoomActionParams, RoomRenamedToParams, - OOOEventSummaryFullDayParams, - OOOEventSummaryPartialDayParams, - ParentNavigationSummaryParams, - ManagerApprovedParams, - SetTheRequestParams, - UpdatedTheRequestParams, SetTheDistanceParams, - UpdatedTheDistanceParams, - RemovedTheRequestParams, - FormattedMaxLengthParams, - RequestedAmountMessageParams, + SetTheRequestParams, + SettledAfterAddedBankAccountParams, + SettleExpensifyCardParams, + SizeExceededParams, + SplitAmountParams, + StepCounterParams, TagSelectionParams, + ThreadRequestReportNameParams, + ThreadSentMoneyReportNameParams, + ToValidateLoginParams, + TransferParams, TranslationBase, + UntilTimeParams, + UpdatedTheDistanceParams, + UpdatedTheRequestParams, + UserIsAlreadyMemberParams, + WaitingOnBankAccountParams, WalletProgramParams, + WelcomeEnterMagicCodeParams, + WelcomeNoteParams, + WelcomeToRoomParams, + WeSentYouMagicSignInLinkParams, + ZipCodeExampleFormatParams, } from './types'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; type StateValue = { stateISO: string; diff --git a/src/languages/es.ts b/src/languages/es.ts index 537d135f41de..578e027e1d14 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -1,82 +1,82 @@ -import CONST from '../CONST'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import CONST from '@src/CONST'; import type { AddressLineParams, - CharacterLimitParams, - MaxParticipantsReachedParams, - ZipCodeExampleFormatParams, - LoggedInAsParams, - NewFaceEnterMagicCodeParams, - WelcomeEnterMagicCodeParams, AlreadySignedInParams, - GoBackMessageParams, - LocalTimeParams, - EditActionParams, - DeleteActionParams, - DeleteConfirmationParams, - BeginningOfChatHistoryDomainRoomPartOneParams, + AmountEachParams, BeginningOfChatHistoryAdminRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartOneParams, BeginningOfChatHistoryAnnounceRoomPartTwo, - WelcomeToRoomParams, - ReportArchiveReasonsClosedParams, - ReportArchiveReasonsMergedParams, - ReportArchiveReasonsRemovedFromPolicyParams, - ReportArchiveReasonsPolicyDeletedParams, - RequestCountParams, - SettleExpensifyCardParams, - RequestAmountParams, - SplitAmountParams, + BeginningOfChatHistoryDomainRoomPartOneParams, + CharacterLimitParams, + ConfirmThatParams, + DateShouldBeAfterParams, + DateShouldBeBeforeParams, + DeleteActionParams, + DeleteConfirmationParams, DidSplitAmountMessageParams, - AmountEachParams, + EditActionParams, + EnglishTranslation, + EnterMagicCodeParams, + FormattedMaxLengthParams, + GoBackMessageParams, + GoToRoomParams, + IncorrectZipFormatParams, + InstantSummaryParams, + LocalTimeParams, + LoggedInAsParams, + ManagerApprovedParams, + MaxParticipantsReachedParams, + NewFaceEnterMagicCodeParams, + NoLongerHaveAccessParams, + NotAllowedExtensionParams, + NotYouParams, + OOOEventSummaryFullDayParams, + OOOEventSummaryPartialDayParams, + OurEmailProviderParams, + PaidElsewhereWithAmountParams, + PaidWithExpensifyWithAmountParams, + ParentNavigationSummaryParams, PayerOwesAmountParams, PayerOwesParams, PayerPaidAmountParams, PayerPaidParams, PayerSettledParams, - WaitingOnBankAccountParams, + RemovedTheRequestParams, + RenamedRoomActionParams, + ReportArchiveReasonsClosedParams, + ReportArchiveReasonsMergedParams, + ReportArchiveReasonsPolicyDeletedParams, + ReportArchiveReasonsRemovedFromPolicyParams, + RequestAmountParams, + RequestCountParams, + RequestedAmountMessageParams, + ResolutionConstraintsParams, + RoomNameReservedErrorParams, + RoomRenamedToParams, + SetTheDistanceParams, + SetTheRequestParams, SettledAfterAddedBankAccountParams, - PaidElsewhereWithAmountParams, - PaidWithExpensifyWithAmountParams, + SettleExpensifyCardParams, + SizeExceededParams, + SplitAmountParams, + StepCounterParams, + TagSelectionParams, ThreadRequestReportNameParams, ThreadSentMoneyReportNameParams, - SizeExceededParams, - ResolutionConstraintsParams, - NotAllowedExtensionParams, - EnterMagicCodeParams, - TransferParams, - InstantSummaryParams, - NotYouParams, - DateShouldBeBeforeParams, - DateShouldBeAfterParams, - IncorrectZipFormatParams, - WeSentYouMagicSignInLinkParams, ToValidateLoginParams, - NoLongerHaveAccessParams, - OurEmailProviderParams, - ConfirmThatParams, + TransferParams, UntilTimeParams, - StepCounterParams, - UserIsAlreadyMemberParams, - GoToRoomParams, - WelcomeNoteParams, - RoomNameReservedErrorParams, - RenamedRoomActionParams, - RoomRenamedToParams, - OOOEventSummaryFullDayParams, - OOOEventSummaryPartialDayParams, - ParentNavigationSummaryParams, - ManagerApprovedParams, - SetTheRequestParams, - SetTheDistanceParams, - UpdatedTheRequestParams, UpdatedTheDistanceParams, - RemovedTheRequestParams, - FormattedMaxLengthParams, - RequestedAmountMessageParams, - TagSelectionParams, - EnglishTranslation, + UpdatedTheRequestParams, + UserIsAlreadyMemberParams, + WaitingOnBankAccountParams, WalletProgramParams, + WelcomeEnterMagicCodeParams, + WelcomeNoteParams, + WelcomeToRoomParams, + WeSentYouMagicSignInLinkParams, + ZipCodeExampleFormatParams, } from './types'; /* eslint-disable max-len */ diff --git a/src/languages/types.ts b/src/languages/types.ts index 5a1847e31e71..d2a387a329d0 100644 --- a/src/languages/types.ts +++ b/src/languages/types.ts @@ -1,4 +1,4 @@ -import {ReportAction} from '../types/onyx'; +import {ReportAction} from '@src/types/onyx'; import en from './en'; type AddressLineParams = { diff --git a/src/libs/API.ts b/src/libs/API.ts index ce3d6bab19bc..91cf6a7db877 100644 --- a/src/libs/API.ts +++ b/src/libs/API.ts @@ -1,14 +1,14 @@ import Onyx, {OnyxUpdate} from 'react-native-onyx'; import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; +import OnyxRequest from '@src/types/onyx/Request'; +import Response from '@src/types/onyx/Response'; +import pkg from '../../package.json'; import Log from './Log'; -import * as Request from './Request'; import * as Middleware from './Middleware'; import * as SequentialQueue from './Network/SequentialQueue'; -import pkg from '../../package.json'; -import CONST from '../CONST'; import * as Pusher from './Pusher/pusher'; -import OnyxRequest from '../types/onyx/Request'; -import Response from '../types/onyx/Response'; +import * as Request from './Request'; // Setup API middlewares. Each request made will pass through a series of middleware functions that will get called in sequence (each one passing the result of the previous to the next). // Note: The ordering here is intentional as we want to Log, Recheck Connection, Reauthenticate, and Save the Response in Onyx. Errors thrown in one middleware will bubble to the next. diff --git a/src/libs/Accessibility/index.ts b/src/libs/Accessibility/index.ts index 213d28139c2c..5eceda8edcb1 100644 --- a/src/libs/Accessibility/index.ts +++ b/src/libs/Accessibility/index.ts @@ -1,4 +1,4 @@ -import {useEffect, useState, useCallback} from 'react'; +import {useCallback, useEffect, useState} from 'react'; import {AccessibilityInfo, LayoutChangeEvent} from 'react-native'; import moveAccessibilityFocus from './moveAccessibilityFocus'; diff --git a/src/libs/ActiveClientManager/index.native.ts b/src/libs/ActiveClientManager/index.native.ts index 1d455a84a28a..866992bcc841 100644 --- a/src/libs/ActiveClientManager/index.native.ts +++ b/src/libs/ActiveClientManager/index.native.ts @@ -2,8 +2,7 @@ * For native devices, there will never be more than one * client running at a time, so this lib is a big no-op */ - -import {Init, IsReady, IsClientTheLeader} from './types'; +import {Init, IsClientTheLeader, IsReady} from './types'; const init: Init = () => {}; diff --git a/src/libs/ActiveClientManager/index.ts b/src/libs/ActiveClientManager/index.ts index f99f54e84aa5..0baeb2becfce 100644 --- a/src/libs/ActiveClientManager/index.ts +++ b/src/libs/ActiveClientManager/index.ts @@ -3,12 +3,11 @@ * only one tab is processing those saved requests or we would be duplicating data (or creating errors). * This file ensures exactly that by tracking all the clientIDs connected, storing the most recent one last and it considers that last clientID the "leader". */ - -import Onyx from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ActiveClients from '../actions/ActiveClients'; -import {Init, IsReady, IsClientTheLeader} from './types'; +import Onyx from 'react-native-onyx'; +import * as ActiveClients from '@userActions/ActiveClients'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {Init, IsClientTheLeader, IsReady} from './types'; const clientID = Str.guid(); const maxClients = 20; diff --git a/src/libs/ApiUtils.ts b/src/libs/ApiUtils.ts index 87a251ccb086..a15c900b9387 100644 --- a/src/libs/ApiUtils.ts +++ b/src/libs/ApiUtils.ts @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; -import CONFIG from '../CONFIG'; -import CONST from '../CONST'; -import * as Environment from './Environment/Environment'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {Request} from '@src/types/onyx'; import proxyConfig from '../../config/proxyConfig'; -import {Request} from '../types/onyx'; +import * as Environment from './Environment/Environment'; // To avoid rebuilding native apps, native apps use production config for both staging and prod // We use the async environment check because it works on all platforms diff --git a/src/libs/AppStateMonitor/index.ts b/src/libs/AppStateMonitor/index.ts index 5c206579944d..f95fad042b98 100644 --- a/src/libs/AppStateMonitor/index.ts +++ b/src/libs/AppStateMonitor/index.ts @@ -1,5 +1,5 @@ import {AppState, AppStateStatus} from 'react-native'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import shouldReportActivity from './shouldReportActivity'; let appState: AppStateStatus = CONST.APP_STATE.ACTIVE; diff --git a/src/libs/Authentication.ts b/src/libs/Authentication.ts index cec20504dd04..9962fa55b0af 100644 --- a/src/libs/Authentication.ts +++ b/src/libs/Authentication.ts @@ -1,13 +1,13 @@ -import requireParameters from './requireParameters'; -import * as Network from './Network'; -import * as NetworkStore from './Network/NetworkStore'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import Response from '@src/types/onyx/Response'; import updateSessionAuthTokens from './actions/Session/updateSessionAuthTokens'; -import CONFIG from '../CONFIG'; import redirectToSignIn from './actions/SignInRedirect'; -import CONST from '../CONST'; -import Log from './Log'; import * as ErrorUtils from './ErrorUtils'; -import Response from '../types/onyx/Response'; +import Log from './Log'; +import * as Network from './Network'; +import * as NetworkStore from './Network/NetworkStore'; +import requireParameters from './requireParameters'; type Parameters = { useExpensifyLogin?: boolean; diff --git a/src/libs/BootSplash/index.native.ts b/src/libs/BootSplash/index.native.ts index 307d0d62c8dd..9d472aec4a96 100644 --- a/src/libs/BootSplash/index.native.ts +++ b/src/libs/BootSplash/index.native.ts @@ -1,5 +1,5 @@ import {NativeModules} from 'react-native'; -import Log from '../Log'; +import Log from '@libs/Log'; const BootSplash = NativeModules.BootSplash; diff --git a/src/libs/BootSplash/index.ts b/src/libs/BootSplash/index.ts index e58763039129..605e65a21a7b 100644 --- a/src/libs/BootSplash/index.ts +++ b/src/libs/BootSplash/index.ts @@ -1,4 +1,4 @@ -import Log from '../Log'; +import Log from '@libs/Log'; import {VisibilityStatus} from './types'; function resolveAfter(delay: number): Promise { diff --git a/src/libs/Browser/index.web.ts b/src/libs/Browser/index.web.ts index 064358c6bed5..2ce4c5ad2040 100644 --- a/src/libs/Browser/index.web.ts +++ b/src/libs/Browser/index.web.ts @@ -1,6 +1,6 @@ -import CONST from '../../CONST'; -import CONFIG from '../../CONFIG'; -import ROUTES from '../../ROUTES'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; /** * Fetch browser name from UA string diff --git a/src/libs/CardUtils.ts b/src/libs/CardUtils.ts index 52c4f7067acf..0dc483aff50e 100644 --- a/src/libs/CardUtils.ts +++ b/src/libs/CardUtils.ts @@ -1,10 +1,10 @@ import lodash from 'lodash'; import Onyx from 'react-native-onyx'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; +import ONYXKEYS, {OnyxValues} from '@src/ONYXKEYS'; +import * as OnyxTypes from '@src/types/onyx'; +import {Card} from '@src/types/onyx'; import * as Localize from './Localize'; -import * as OnyxTypes from '../types/onyx'; -import ONYXKEYS, {OnyxValues} from '../ONYXKEYS'; -import {Card} from '../types/onyx'; let allCards: OnyxValues[typeof ONYXKEYS.CARD_LIST] = {}; Onyx.connect({ diff --git a/src/libs/Clipboard/index.js b/src/libs/Clipboard/index.js index 6fbaa8eccd31..ff05fcb45d0a 100644 --- a/src/libs/Clipboard/index.js +++ b/src/libs/Clipboard/index.js @@ -1,7 +1,7 @@ import Clipboard from '@react-native-clipboard/clipboard'; import lodashGet from 'lodash/get'; -import CONST from '../../CONST'; -import * as Browser from '../Browser'; +import * as Browser from '@libs/Browser'; +import CONST from '@src/CONST'; const canSetHtml = () => lodashGet(navigator, 'clipboard.write'); diff --git a/src/libs/CollectionUtils.ts b/src/libs/CollectionUtils.ts index ac47633c2e08..3a980906d614 100644 --- a/src/libs/CollectionUtils.ts +++ b/src/libs/CollectionUtils.ts @@ -1,4 +1,4 @@ -import {OnyxCollectionKey} from '../ONYXKEYS'; +import {OnyxCollectionKey} from '@src/ONYXKEYS'; /** * Return the highest item in a numbered collection diff --git a/src/libs/ComposerUtils/getDraftComment.ts b/src/libs/ComposerUtils/getDraftComment.ts index ac3d2f3d09be..97567a42b263 100644 --- a/src/libs/ComposerUtils/getDraftComment.ts +++ b/src/libs/ComposerUtils/getDraftComment.ts @@ -1,5 +1,5 @@ import Onyx, {OnyxEntry} from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; const draftCommentMap: Record> = {}; Onyx.connect({ diff --git a/src/libs/ComposerUtils/index.ts b/src/libs/ComposerUtils/index.ts index 5e2a42fc65dd..5a7da7ca08cf 100644 --- a/src/libs/ComposerUtils/index.ts +++ b/src/libs/ComposerUtils/index.ts @@ -1,6 +1,6 @@ +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import getNumberOfLines from './getNumberOfLines'; import updateNumberOfLines from './updateNumberOfLines'; -import * as DeviceCapabilities from '../DeviceCapabilities'; type Selection = { start: number; diff --git a/src/libs/ComposerUtils/updateIsFullComposerAvailable.ts b/src/libs/ComposerUtils/updateIsFullComposerAvailable.ts index 5d73619482db..761abb8c9c8f 100644 --- a/src/libs/ComposerUtils/updateIsFullComposerAvailable.ts +++ b/src/libs/ComposerUtils/updateIsFullComposerAvailable.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import ComposerProps from './types'; /** diff --git a/src/libs/ComposerUtils/updateNumberOfLines/index.native.ts b/src/libs/ComposerUtils/updateNumberOfLines/index.native.ts index b5c28cfc79e8..df9292ecd690 100644 --- a/src/libs/ComposerUtils/updateNumberOfLines/index.native.ts +++ b/src/libs/ComposerUtils/updateNumberOfLines/index.native.ts @@ -1,6 +1,6 @@ -import styles from '../../../styles/styles'; -import updateIsFullComposerAvailable from '../updateIsFullComposerAvailable'; -import getNumberOfLines from '../getNumberOfLines'; +import getNumberOfLines from '@libs/ComposerUtils/getNumberOfLines'; +import updateIsFullComposerAvailable from '@libs/ComposerUtils/updateIsFullComposerAvailable'; +import styles from '@styles/styles'; import UpdateNumberOfLines from './types'; /** diff --git a/src/libs/ComposerUtils/updateNumberOfLines/types.ts b/src/libs/ComposerUtils/updateNumberOfLines/types.ts index c0650be25433..b0f9ba48ddc2 100644 --- a/src/libs/ComposerUtils/updateNumberOfLines/types.ts +++ b/src/libs/ComposerUtils/updateNumberOfLines/types.ts @@ -1,5 +1,5 @@ import {NativeSyntheticEvent, TextInputContentSizeChangeEventData} from 'react-native'; -import ComposerProps from '../types'; +import ComposerProps from '@libs/ComposerUtils/types'; type UpdateNumberOfLines = (props: ComposerProps, event: NativeSyntheticEvent) => void; diff --git a/src/libs/ControlSelection/index.ts b/src/libs/ControlSelection/index.ts index 9625b4e49787..44d4530bc4fd 100644 --- a/src/libs/ControlSelection/index.ts +++ b/src/libs/ControlSelection/index.ts @@ -1,5 +1,5 @@ +import CustomRefObject from '@src/types/utils/CustomRefObject'; import ControlSelectionModule from './types'; -import CustomRefObject from '../../types/utils/CustomRefObject'; /** * Block selection on the whole app diff --git a/src/libs/ControlSelection/types.ts b/src/libs/ControlSelection/types.ts index 5706a4981d30..d84347fd7ba6 100644 --- a/src/libs/ControlSelection/types.ts +++ b/src/libs/ControlSelection/types.ts @@ -1,4 +1,4 @@ -import CustomRefObject from '../../types/utils/CustomRefObject'; +import CustomRefObject from '@src/types/utils/CustomRefObject'; type ControlSelectionModule = { block: () => void; diff --git a/src/libs/CurrencyUtils.ts b/src/libs/CurrencyUtils.ts index 85ba8340c13e..4829ce115592 100644 --- a/src/libs/CurrencyUtils.ts +++ b/src/libs/CurrencyUtils.ts @@ -1,8 +1,8 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS, {OnyxValues} from '../ONYXKEYS'; -import CONST from '../CONST'; -import BaseLocaleListener from './Localize/LocaleListener/BaseLocaleListener'; +import CONST from '@src/CONST'; +import ONYXKEYS, {OnyxValues} from '@src/ONYXKEYS'; import * as Localize from './Localize'; +import BaseLocaleListener from './Localize/LocaleListener/BaseLocaleListener'; import * as NumberFormatUtils from './NumberFormatUtils'; let currencyList: OnyxValues[typeof ONYXKEYS.CURRENCY_LIST] = {}; diff --git a/src/libs/DateUtils.ts b/src/libs/DateUtils.ts index a6f2860310c2..e03e3dd55680 100644 --- a/src/libs/DateUtils.ts +++ b/src/libs/DateUtils.ts @@ -1,29 +1,28 @@ -import {zonedTimeToUtc, utcToZonedTime, formatInTimeZone} from 'date-fns-tz'; -import {es, enGB} from 'date-fns/locale'; import { - formatDistanceToNow, - subMinutes, addDays, - subDays, - isBefore, - subMilliseconds, - startOfWeek, + endOfDay, endOfWeek, format, - setDefaultOptions, - endOfDay, - isSameDay, + formatDistanceToNow, isAfter, + isBefore, + isSameDay, isSameYear, + setDefaultOptions, + startOfWeek, + subDays, + subMilliseconds, + subMinutes, } from 'date-fns'; - -import Onyx from 'react-native-onyx'; +import {formatInTimeZone, utcToZonedTime, zonedTimeToUtc} from 'date-fns-tz'; +import {enGB, es} from 'date-fns/locale'; import throttle from 'lodash/throttle'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import * as Localize from './Localize'; +import Onyx from 'react-native-onyx'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {Timezone} from '@src/types/onyx/PersonalDetails'; import * as CurrentDate from './actions/CurrentDate'; -import {Timezone} from '../types/onyx/PersonalDetails'; +import * as Localize from './Localize'; let currentUserAccountID: number | undefined; Onyx.connect({ diff --git a/src/libs/DistanceRequestUtils.js b/src/libs/DistanceRequestUtils.js index 32de571c218c..0cc4e39d83af 100644 --- a/src/libs/DistanceRequestUtils.js +++ b/src/libs/DistanceRequestUtils.js @@ -1,5 +1,5 @@ import _ from 'underscore'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; import * as CurrencyUtils from './CurrencyUtils'; import * as PolicyUtils from './PolicyUtils'; diff --git a/src/libs/E2E/API.mock.js b/src/libs/E2E/API.mock.js index 47f445f72222..2c7da3f420a3 100644 --- a/src/libs/E2E/API.mock.js +++ b/src/libs/E2E/API.mock.js @@ -1,14 +1,13 @@ /* eslint-disable rulesdir/no-api-in-views */ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; -import Log from '../Log'; - +import _ from 'underscore'; +import Log from '@libs/Log'; +import mockAuthenticatePusher from './apiMocks/authenticatePusher'; // mock functions import mockBeginSignin from './apiMocks/beginSignin'; -import mockSigninUser from './apiMocks/signinUser'; -import mockAuthenticatePusher from './apiMocks/authenticatePusher'; import mockOpenApp from './apiMocks/openApp'; import mockOpenReport from './apiMocks/openReport'; +import mockSigninUser from './apiMocks/signinUser'; /** * A dictionary which has the name of a API command as key, and a function which diff --git a/src/libs/E2E/actions/e2eLogin.js b/src/libs/E2E/actions/e2eLogin.js index 77576b09d88d..e2202f7e5662 100644 --- a/src/libs/E2E/actions/e2eLogin.js +++ b/src/libs/E2E/actions/e2eLogin.js @@ -1,7 +1,7 @@ /* eslint-disable rulesdir/prefer-onyx-connect-in-libs */ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as Session from '../../actions/Session'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Command for e2e test to automatically sign in a user. diff --git a/src/libs/E2E/client.js b/src/libs/E2E/client.js index c948c7c2c6d2..7e6932d9fce5 100644 --- a/src/libs/E2E/client.js +++ b/src/libs/E2E/client.js @@ -1,5 +1,5 @@ -import Routes from '../../../tests/e2e/server/routes'; import Config from '../../../tests/e2e/config'; +import Routes from '../../../tests/e2e/server/routes'; const SERVER_ADDRESS = `http://localhost:${Config.SERVER_PORT}`; diff --git a/src/libs/E2E/isE2ETestSession.native.js b/src/libs/E2E/isE2ETestSession.native.js index 214e8241c5dc..3c4c19e8ba24 100644 --- a/src/libs/E2E/isE2ETestSession.native.js +++ b/src/libs/E2E/isE2ETestSession.native.js @@ -1,3 +1,3 @@ -import CONFIG from '../../CONFIG'; +import CONFIG from '@src/CONFIG'; export default () => CONFIG.E2E_TESTING; diff --git a/src/libs/E2E/reactNativeLaunchingTest.js b/src/libs/E2E/reactNativeLaunchingTest.js index 13183c1044db..1e0d6a8afa3b 100644 --- a/src/libs/E2E/reactNativeLaunchingTest.js +++ b/src/libs/E2E/reactNativeLaunchingTest.js @@ -1,13 +1,13 @@ /* eslint-disable import/newline-after-import,import/first */ + /** * We are using a separate entry point for the E2E tests. * By doing this, we avoid bundling any E2E testing code * into the actual release app. */ - -import Performance from '../Performance'; -import * as Metrics from '../Metrics'; - +import * as Metrics from '@libs/Metrics'; +import Performance from '@libs/Performance'; +import '../../../index'; import E2EConfig from '../../../tests/e2e/config'; import E2EClient from './client'; @@ -65,5 +65,5 @@ E2EClient.getTestConfig() // start the usual app Performance.markStart('regularAppStart'); -import '../../../index'; + Performance.markEnd('regularAppStart'); diff --git a/src/libs/E2E/tests/appStartTimeTest.e2e.js b/src/libs/E2E/tests/appStartTimeTest.e2e.js index d44fd6ce1195..311b891fcd4c 100644 --- a/src/libs/E2E/tests/appStartTimeTest.e2e.js +++ b/src/libs/E2E/tests/appStartTimeTest.e2e.js @@ -1,7 +1,7 @@ import _ from 'underscore'; -import E2ELogin from '../actions/e2eLogin'; -import Performance from '../../Performance'; -import E2EClient from '../client'; +import E2ELogin from '@libs/E2E/actions/e2eLogin'; +import E2EClient from '@libs/E2E/client'; +import Performance from '@libs/Performance'; const test = () => { // check for login (if already logged in the action will simply resolve) diff --git a/src/libs/E2E/tests/openSearchPageTest.e2e.js b/src/libs/E2E/tests/openSearchPageTest.e2e.js index 3b2d91322cf0..1101a620f413 100644 --- a/src/libs/E2E/tests/openSearchPageTest.e2e.js +++ b/src/libs/E2E/tests/openSearchPageTest.e2e.js @@ -1,9 +1,9 @@ -import E2ELogin from '../actions/e2eLogin'; -import Performance from '../../Performance'; -import E2EClient from '../client'; -import Navigation from '../../Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; +import E2ELogin from '@libs/E2E/actions/e2eLogin'; +import E2EClient from '@libs/E2E/client'; +import Navigation from '@libs/Navigation/Navigation'; +import Performance from '@libs/Performance'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const test = () => { // check for login (if already logged in the action will simply resolve) diff --git a/src/libs/EmojiTrie.ts b/src/libs/EmojiTrie.ts index d0a53acf29c9..2ab950621f87 100644 --- a/src/libs/EmojiTrie.ts +++ b/src/libs/EmojiTrie.ts @@ -1,9 +1,9 @@ import React from 'react'; import {SvgProps} from 'react-native-svg'; -import emojis, {localeEmojis} from '../../assets/emojis'; -import Trie from './Trie'; +import emojis, {localeEmojis} from '@assets/emojis'; +import CONST from '@src/CONST'; import Timing from './actions/Timing'; -import CONST from '../CONST'; +import Trie from './Trie'; type Emoji = { code: string; diff --git a/src/libs/EmojiUtils.js b/src/libs/EmojiUtils.js index 05ad1bd3c2ce..4ade70537b0b 100644 --- a/src/libs/EmojiUtils.js +++ b/src/libs/EmojiUtils.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; import {getUnixTime} from 'date-fns'; import Str from 'expensify-common/lib/str'; -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; import lodashMin from 'lodash/min'; import lodashSum from 'lodash/sum'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import * as Emojis from '@assets/emojis'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import emojisTrie from './EmojiTrie'; -import * as Emojis from '../../assets/emojis'; let frequentlyUsedEmojis = []; Onyx.connect({ diff --git a/src/libs/Environment/Environment.js b/src/libs/Environment/Environment.js index c039b49d33aa..e89c8d74a43a 100644 --- a/src/libs/Environment/Environment.js +++ b/src/libs/Environment/Environment.js @@ -1,8 +1,8 @@ -import Config from 'react-native-config'; import lodashGet from 'lodash/get'; -import CONST from '../../CONST'; +import Config from 'react-native-config'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; import getEnvironment from './getEnvironment'; -import CONFIG from '../../CONFIG'; const ENVIRONMENT_URLS = { [CONST.ENVIRONMENT.DEV]: CONST.DEV_NEW_EXPENSIFY_URL + CONFIG.DEV_PORT, diff --git a/src/libs/Environment/betaChecker/index.android.js b/src/libs/Environment/betaChecker/index.android.js index e74648973c34..18a4290cb634 100644 --- a/src/libs/Environment/betaChecker/index.android.js +++ b/src/libs/Environment/betaChecker/index.android.js @@ -1,9 +1,9 @@ -import semver from 'semver'; import Onyx from 'react-native-onyx'; -import CONST from '../../../CONST'; +import semver from 'semver'; +import * as AppUpdate from '@userActions/AppUpdate'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import pkg from '../../../../package.json'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as AppUpdate from '../../actions/AppUpdate'; let isLastSavedBeta = false; Onyx.connect({ diff --git a/src/libs/Environment/getEnvironment/index.js b/src/libs/Environment/getEnvironment/index.js index a987678d6a6e..bc1c31cf5076 100644 --- a/src/libs/Environment/getEnvironment/index.js +++ b/src/libs/Environment/getEnvironment/index.js @@ -1,6 +1,6 @@ import lodashGet from 'lodash/get'; import Config from 'react-native-config'; -import CONST from '../../../CONST'; +import CONST from '@src/CONST'; /** * Returns a promise that resolves with the current environment string value diff --git a/src/libs/Environment/getEnvironment/index.native.js b/src/libs/Environment/getEnvironment/index.native.js index 73014c4beffb..ca660f9117cb 100644 --- a/src/libs/Environment/getEnvironment/index.native.js +++ b/src/libs/Environment/getEnvironment/index.native.js @@ -1,7 +1,7 @@ import lodashGet from 'lodash/get'; import Config from 'react-native-config'; -import betaChecker from '../betaChecker'; -import CONST from '../../../CONST'; +import betaChecker from '@libs/Environment/betaChecker'; +import CONST from '@src/CONST'; let environment = null; diff --git a/src/libs/ErrorUtils.ts b/src/libs/ErrorUtils.ts index bf4fc0d810a4..99cd8f34b1e7 100644 --- a/src/libs/ErrorUtils.ts +++ b/src/libs/ErrorUtils.ts @@ -1,9 +1,9 @@ -import CONST from '../CONST'; +import CONST from '@src/CONST'; +import {TranslationFlatObject} from '@src/languages/types'; +import {ErrorFields, Errors} from '@src/types/onyx/OnyxCommon'; +import Response from '@src/types/onyx/Response'; import DateUtils from './DateUtils'; import * as Localize from './Localize'; -import Response from '../types/onyx/Response'; -import {ErrorFields, Errors} from '../types/onyx/OnyxCommon'; -import {TranslationFlatObject} from '../languages/types'; function getAuthenticateErrorMessage(response: Response): keyof TranslationFlatObject { switch (response.jsonCode) { diff --git a/src/libs/Firebase/index.native.ts b/src/libs/Firebase/index.native.ts index 2014e2b8bd3e..107b3f8905b3 100644 --- a/src/libs/Firebase/index.native.ts +++ b/src/libs/Firebase/index.native.ts @@ -1,6 +1,6 @@ /* eslint-disable no-unused-vars */ import perf from '@react-native-firebase/perf'; -import * as Environment from '../Environment/Environment'; +import * as Environment from '@libs/Environment/Environment'; import {StartTrace, StopTrace, TraceMap} from './types'; const traceMap: TraceMap = {}; diff --git a/src/libs/Growl.ts b/src/libs/Growl.ts index 33d7311973cb..55bcf88206e9 100644 --- a/src/libs/Growl.ts +++ b/src/libs/Growl.ts @@ -1,5 +1,5 @@ import React from 'react'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; type GrowlRef = { show?: (bodyText: string, type: string, duration: number) => void; diff --git a/src/libs/HeaderUtils.js b/src/libs/HeaderUtils.js index 16d375ea1124..2edca95ecf74 100644 --- a/src/libs/HeaderUtils.js +++ b/src/libs/HeaderUtils.js @@ -1,7 +1,7 @@ -import * as Localize from './Localize'; -import * as Session from './actions/Session'; +import * as Expensicons from '@components/Icon/Expensicons'; import * as Report from './actions/Report'; -import * as Expensicons from '../components/Icon/Expensicons'; +import * as Session from './actions/Session'; +import * as Localize from './Localize'; /** * @param {Object} report diff --git a/src/libs/HttpUtils.js b/src/libs/HttpUtils.js index 5a8185a03038..2df7421ea91c 100644 --- a/src/libs/HttpUtils.js +++ b/src/libs/HttpUtils.js @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import HttpsError from './Errors/HttpsError'; +import alert from '@components/Alert'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as ApiUtils from './ApiUtils'; -import alert from '../components/Alert'; +import HttpsError from './Errors/HttpsError'; let shouldFailAllRequests = false; let shouldForceOffline = false; diff --git a/src/libs/IOUUtils.ts b/src/libs/IOUUtils.ts index d8a916d0dfb0..ff4f2aafc8a8 100644 --- a/src/libs/IOUUtils.ts +++ b/src/libs/IOUUtils.ts @@ -1,7 +1,7 @@ -import CONST from '../CONST'; -import * as TransactionUtils from './TransactionUtils'; +import CONST from '@src/CONST'; +import {Report, Transaction} from '@src/types/onyx'; import * as CurrencyUtils from './CurrencyUtils'; -import {Report, Transaction} from '../types/onyx'; +import * as TransactionUtils from './TransactionUtils'; /** * Calculates the amount per user given a list of participants diff --git a/src/libs/IntlPolyfill/index.native.ts b/src/libs/IntlPolyfill/index.native.ts index 9e578558faed..a044b4c52f0d 100644 --- a/src/libs/IntlPolyfill/index.native.ts +++ b/src/libs/IntlPolyfill/index.native.ts @@ -1,5 +1,5 @@ -import polyfillNumberFormat from './polyfillNumberFormat'; import polyfillListFormat from './polyfillListFormat'; +import polyfillNumberFormat from './polyfillNumberFormat'; import IntlPolyfill from './types'; /** diff --git a/src/libs/IntlPolyfill/polyfillNumberFormat.ts b/src/libs/IntlPolyfill/polyfillNumberFormat.ts index e4fdfef16e2c..1fac01958f05 100644 --- a/src/libs/IntlPolyfill/polyfillNumberFormat.ts +++ b/src/libs/IntlPolyfill/polyfillNumberFormat.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; /** * Check if the locale data is as expected on the device. diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts index d23d558fa1f8..72a4365b87e2 100644 --- a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.native.ts @@ -1,4 +1,4 @@ -import getKeyEventModifiers from '../getKeyEventModifiers'; +import getKeyEventModifiers from '@libs/KeyboardShortcut/getKeyEventModifiers'; import BindHandlerToKeydownEvent from './types'; /** diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts index 8f06c2fe9c2f..8f2eaad25c5b 100644 --- a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/index.ts @@ -1,5 +1,5 @@ -import getKeyEventModifiers from '../getKeyEventModifiers'; -import isEnterWhileComposition from '../isEnterWhileComposition'; +import getKeyEventModifiers from '@libs/KeyboardShortcut/getKeyEventModifiers'; +import isEnterWhileComposition from '@libs/KeyboardShortcut/isEnterWhileComposition'; import BindHandlerToKeydownEvent from './types'; /** diff --git a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts index 6a9aefb30676..2fe9521fa117 100644 --- a/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts +++ b/src/libs/KeyboardShortcut/bindHandlerToKeydownEvent/types.ts @@ -1,4 +1,4 @@ -import type {EventHandler} from '../index'; +import type {EventHandler} from '..'; type KeyCommandEvent = {input: string; modifierFlags?: string}; diff --git a/src/libs/KeyboardShortcut/index.ts b/src/libs/KeyboardShortcut/index.ts index 3109ccda8aaf..249311f92cd2 100644 --- a/src/libs/KeyboardShortcut/index.ts +++ b/src/libs/KeyboardShortcut/index.ts @@ -1,8 +1,8 @@ import Str from 'expensify-common/lib/str'; import * as KeyCommand from 'react-native-key-command'; +import getOperatingSystem from '@libs/getOperatingSystem'; +import CONST from '@src/CONST'; import bindHandlerToKeydownEvent from './bindHandlerToKeydownEvent'; -import getOperatingSystem from '../getOperatingSystem'; -import CONST from '../../CONST'; const operatingSystem = getOperatingSystem(); diff --git a/src/libs/KeyboardShortcut/isEnterWhileComposition.ts b/src/libs/KeyboardShortcut/isEnterWhileComposition.ts index 2a0a2fec110f..51e198f1c2d1 100644 --- a/src/libs/KeyboardShortcut/isEnterWhileComposition.ts +++ b/src/libs/KeyboardShortcut/isEnterWhileComposition.ts @@ -1,6 +1,6 @@ import {NativeSyntheticEvent} from 'react-native'; -import * as Browser from '../Browser'; -import CONST from '../../CONST'; +import * as Browser from '@libs/Browser'; +import CONST from '@src/CONST'; /** * Check if the Enter key was pressed during IME confirmation (i.e. while the text is being composed). diff --git a/src/libs/LocaleDigitUtils.ts b/src/libs/LocaleDigitUtils.ts index e17620aa5427..d9ba23ff4f9f 100644 --- a/src/libs/LocaleDigitUtils.ts +++ b/src/libs/LocaleDigitUtils.ts @@ -1,5 +1,4 @@ import _ from 'lodash'; - import * as NumberFormatUtils from './NumberFormatUtils'; const STANDARD_DIGITS = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '.', '-', ',']; diff --git a/src/libs/LocalePhoneNumber.ts b/src/libs/LocalePhoneNumber.ts index 962040aee049..e50f3be87c84 100644 --- a/src/libs/LocalePhoneNumber.ts +++ b/src/libs/LocalePhoneNumber.ts @@ -1,7 +1,7 @@ -import Onyx from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; import {parsePhoneNumber} from 'awesome-phonenumber'; -import ONYXKEYS from '../ONYXKEYS'; +import Str from 'expensify-common/lib/str'; +import Onyx from 'react-native-onyx'; +import ONYXKEYS from '@src/ONYXKEYS'; let countryCodeByIP: number; Onyx.connect({ diff --git a/src/libs/Localize/LocaleListener/BaseLocaleListener.js b/src/libs/Localize/LocaleListener/BaseLocaleListener.js index 9d4e62c374b0..0f861b20040a 100644 --- a/src/libs/Localize/LocaleListener/BaseLocaleListener.js +++ b/src/libs/Localize/LocaleListener/BaseLocaleListener.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; let preferredLocale = CONST.LOCALES.DEFAULT; diff --git a/src/libs/Localize/index.js b/src/libs/Localize/index.js index a26c7d4ebc10..f2f8cfa1f8b0 100644 --- a/src/libs/Localize/index.js +++ b/src/libs/Localize/index.js @@ -1,15 +1,15 @@ -import _ from 'underscore'; -import lodashGet from 'lodash/get'; import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import * as RNLocalize from 'react-native-localize'; import Onyx from 'react-native-onyx'; -import Log from '../Log'; -import Config from '../../CONFIG'; -import translations from '../../languages/translations'; -import CONST from '../../CONST'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import Config from '@src/CONFIG'; +import CONST from '@src/CONST'; +import translations from '@src/languages/translations'; +import ONYXKEYS from '@src/ONYXKEYS'; import LocaleListener from './LocaleListener'; import BaseLocaleListener from './LocaleListener/BaseLocaleListener'; -import ONYXKEYS from '../../ONYXKEYS'; // Current user mail is needed for handling missing translations let userEmail = ''; diff --git a/src/libs/Log.ts b/src/libs/Log.ts index cf139eec2682..e171e6338ffe 100644 --- a/src/libs/Log.ts +++ b/src/libs/Log.ts @@ -1,12 +1,13 @@ // Making an exception to this rule here since we don't need an "action" for Log and Log should just be used directly. Creating a Log // action would likely cause confusion about which one to use. But most other API methods should happen inside an action file. + /* eslint-disable rulesdir/no-api-in-views */ -import {Merge} from 'type-fest'; import Logger from 'expensify-common/lib/Logger'; -import getPlatform from './getPlatform'; +import {Merge} from 'type-fest'; import pkg from '../../package.json'; -import requireParameters from './requireParameters'; +import getPlatform from './getPlatform'; import * as Network from './Network'; +import requireParameters from './requireParameters'; let timeout: NodeJS.Timeout; diff --git a/src/libs/LoginUtils.ts b/src/libs/LoginUtils.ts index 32f6aece6f96..742f9bfe16ce 100644 --- a/src/libs/LoginUtils.ts +++ b/src/libs/LoginUtils.ts @@ -1,9 +1,9 @@ +import {parsePhoneNumber} from 'awesome-phonenumber'; +import {PUBLIC_DOMAINS} from 'expensify-common/lib/CONST'; import Str from 'expensify-common/lib/str'; import Onyx from 'react-native-onyx'; -import {PUBLIC_DOMAINS} from 'expensify-common/lib/CONST'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; let countryCodeByIP: number; Onyx.connect({ diff --git a/src/libs/Metrics/index.native.ts b/src/libs/Metrics/index.native.ts index 526e5c57a269..373f826e9ca3 100644 --- a/src/libs/Metrics/index.native.ts +++ b/src/libs/Metrics/index.native.ts @@ -1,4 +1,4 @@ -import CONFIG from '../../CONFIG'; +import CONFIG from '@src/CONFIG'; import {CanCaptureOnyxMetrics, CanCapturePerformanceMetrics} from './types'; /** diff --git a/src/libs/Metrics/index.ts b/src/libs/Metrics/index.ts index 7c33f31cb19e..1097826aff24 100644 --- a/src/libs/Metrics/index.ts +++ b/src/libs/Metrics/index.ts @@ -1,4 +1,4 @@ -import CONFIG from '../../CONFIG'; +import CONFIG from '@src/CONFIG'; import {CanCaptureOnyxMetrics, CanCapturePerformanceMetrics} from './types'; // We don't capture performance metrics on web as there are enough tools available diff --git a/src/libs/Middleware/HandleUnusedOptimisticID.ts b/src/libs/Middleware/HandleUnusedOptimisticID.ts index 14f7d08d1fdb..abca86522d2b 100644 --- a/src/libs/Middleware/HandleUnusedOptimisticID.ts +++ b/src/libs/Middleware/HandleUnusedOptimisticID.ts @@ -1,9 +1,9 @@ import _ from 'lodash'; -import ONYXKEYS from '../../ONYXKEYS'; -import Report from '../../types/onyx/Report'; -import {Middleware} from '../Request'; -import * as PersistedRequests from '../actions/PersistedRequests'; -import deepReplaceKeysAndValues from '../deepReplaceKeysAndValues'; +import deepReplaceKeysAndValues from '@libs/deepReplaceKeysAndValues'; +import {Middleware} from '@libs/Request'; +import * as PersistedRequests from '@userActions/PersistedRequests'; +import ONYXKEYS from '@src/ONYXKEYS'; +import Report from '@src/types/onyx/Report'; const handleUnusedOptimisticID: Middleware = (requestResponse, request, isFromSequentialQueue) => requestResponse.then((response) => { diff --git a/src/libs/Middleware/Logging.ts b/src/libs/Middleware/Logging.ts index 171cb4b9ab4c..3ef819298f80 100644 --- a/src/libs/Middleware/Logging.ts +++ b/src/libs/Middleware/Logging.ts @@ -1,7 +1,7 @@ -import Log from '../Log'; -import CONST from '../../CONST'; -import Request from '../../types/onyx/Request'; -import Response from '../../types/onyx/Response'; +import Log from '@libs/Log'; +import CONST from '@src/CONST'; +import Request from '@src/types/onyx/Request'; +import Response from '@src/types/onyx/Response'; import Middleware from './types'; function logRequestDetails(message: string, request: Request, response?: Response | void) { diff --git a/src/libs/Middleware/Reauthentication.ts b/src/libs/Middleware/Reauthentication.ts index aec09227e441..f1f71a85b16c 100644 --- a/src/libs/Middleware/Reauthentication.ts +++ b/src/libs/Middleware/Reauthentication.ts @@ -1,10 +1,10 @@ -import CONST from '../../CONST'; -import * as NetworkStore from '../Network/NetworkStore'; -import * as MainQueue from '../Network/MainQueue'; -import * as Authentication from '../Authentication'; -import * as Request from '../Request'; -import Log from '../Log'; -import NetworkConnection from '../NetworkConnection'; +import * as Authentication from '@libs/Authentication'; +import Log from '@libs/Log'; +import * as MainQueue from '@libs/Network/MainQueue'; +import * as NetworkStore from '@libs/Network/NetworkStore'; +import NetworkConnection from '@libs/NetworkConnection'; +import * as Request from '@libs/Request'; +import CONST from '@src/CONST'; import Middleware from './types'; // We store a reference to the active authentication request so that we are only ever making one request to authenticate at a time. diff --git a/src/libs/Middleware/RecheckConnection.ts b/src/libs/Middleware/RecheckConnection.ts index 5a685d66fd02..1f43b0171800 100644 --- a/src/libs/Middleware/RecheckConnection.ts +++ b/src/libs/Middleware/RecheckConnection.ts @@ -1,5 +1,5 @@ -import CONST from '../../CONST'; -import NetworkConnection from '../NetworkConnection'; +import NetworkConnection from '@libs/NetworkConnection'; +import CONST from '@src/CONST'; import Middleware from './types'; /** diff --git a/src/libs/Middleware/SaveResponseInOnyx.ts b/src/libs/Middleware/SaveResponseInOnyx.ts index 0a279a7425b4..d73a10d98663 100644 --- a/src/libs/Middleware/SaveResponseInOnyx.ts +++ b/src/libs/Middleware/SaveResponseInOnyx.ts @@ -1,7 +1,7 @@ -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as MemoryOnlyKeys from '../actions/MemoryOnlyKeys/MemoryOnlyKeys'; -import * as OnyxUpdates from '../actions/OnyxUpdates'; +import * as MemoryOnlyKeys from '@userActions/MemoryOnlyKeys/MemoryOnlyKeys'; +import * as OnyxUpdates from '@userActions/OnyxUpdates'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import Middleware from './types'; // If we're executing any of these requests, we don't need to trigger our OnyxUpdates flow to update the current data even if our current value is out of diff --git a/src/libs/Middleware/types.ts b/src/libs/Middleware/types.ts index ece210ffe2af..c1d199539b15 100644 --- a/src/libs/Middleware/types.ts +++ b/src/libs/Middleware/types.ts @@ -1,5 +1,5 @@ -import Request from '../../types/onyx/Request'; -import Response from '../../types/onyx/Response'; +import Request from '@src/types/onyx/Request'; +import Response from '@src/types/onyx/Response'; type Middleware = (response: Promise, request: Request, isFromSequentialQueue: boolean) => Promise; diff --git a/src/libs/MoneyRequestUtils.ts b/src/libs/MoneyRequestUtils.ts index 420184973a34..83c66be429d2 100644 --- a/src/libs/MoneyRequestUtils.ts +++ b/src/libs/MoneyRequestUtils.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; /** * Strip comma from the amount diff --git a/src/libs/Navigation/AppNavigator/AuthScreens.js b/src/libs/Navigation/AppNavigator/AuthScreens.js index 3ac6a8025eb9..fdc48aec2010 100644 --- a/src/libs/Navigation/AppNavigator/AuthScreens.js +++ b/src/libs/Navigation/AppNavigator/AuthScreens.js @@ -1,40 +1,40 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {memo, useEffect, useRef} from 'react'; +import {View} from 'react-native'; import Onyx, {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import {View} from 'react-native'; -import CONST from '../../../CONST'; -import * as PersonalDetails from '../../actions/PersonalDetails'; -import * as Pusher from '../../Pusher/pusher'; -import PusherConnectionManager from '../../PusherConnectionManager'; -import ROUTES from '../../../ROUTES'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Timing from '../../actions/Timing'; -import NetworkConnection from '../../NetworkConnection'; -import CONFIG from '../../../CONFIG'; -import KeyboardShortcut from '../../KeyboardShortcut'; -import Navigation from '../Navigation'; -import * as User from '../../actions/User'; -import * as Modal from '../../actions/Modal'; -import * as Report from '../../actions/Report'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import getCurrentUrl from '@libs/Navigation/currentUrl'; +import Navigation from '@libs/Navigation/Navigation'; +import NetworkConnection from '@libs/NetworkConnection'; +import * as Pusher from '@libs/Pusher/pusher'; +import PusherConnectionManager from '@libs/PusherConnectionManager'; +import * as SessionUtils from '@libs/SessionUtils'; +import DemoSetupPage from '@pages/DemoSetupPage'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import DesktopSignInRedirectPage from '@pages/signin/DesktopSignInRedirectPage'; +import styles from '@styles/styles'; +import * as App from '@userActions/App'; +import * as Download from '@userActions/Download'; +import * as Modal from '@userActions/Modal'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import * as Report from '@userActions/Report'; +import * as Session from '@userActions/Session'; +import Timing from '@userActions/Timing'; +import * as User from '@userActions/User'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import NAVIGATORS from '@src/NAVIGATORS'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; import createCustomStackNavigator from './createCustomStackNavigator'; -import SCREENS from '../../../SCREENS'; import defaultScreenOptions from './defaultScreenOptions'; -import * as App from '../../actions/App'; -import * as Download from '../../actions/Download'; -import * as Session from '../../actions/Session'; -import RightModalNavigator from './Navigators/RightModalNavigator'; -import CentralPaneNavigator from './Navigators/CentralPaneNavigator'; -import NAVIGATORS from '../../../NAVIGATORS'; -import DesktopSignInRedirectPage from '../../../pages/signin/DesktopSignInRedirectPage'; -import styles from '../../../styles/styles'; -import * as SessionUtils from '../../SessionUtils'; -import NotFoundPage from '../../../pages/ErrorPage/NotFoundPage'; import getRootNavigatorScreenOptions from './getRootNavigatorScreenOptions'; -import DemoSetupPage from '../../../pages/DemoSetupPage'; -import getCurrentUrl from '../currentUrl'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; +import CentralPaneNavigator from './Navigators/CentralPaneNavigator'; +import RightModalNavigator from './Navigators/RightModalNavigator'; const loadReportAttachments = () => require('../../../pages/home/report/ReportAttachments').default; const loadSidebarScreen = () => require('../../../pages/home/sidebar/SidebarScreen').default; diff --git a/src/libs/Navigation/AppNavigator/ModalStackNavigators.js b/src/libs/Navigation/AppNavigator/ModalStackNavigators.js index 088da657a693..2f0a75a02cc3 100644 --- a/src/libs/Navigation/AppNavigator/ModalStackNavigators.js +++ b/src/libs/Navigation/AppNavigator/ModalStackNavigators.js @@ -1,8 +1,8 @@ -import _ from 'underscore'; +import {CardStyleInterpolators, createStackNavigator} from '@react-navigation/stack'; import React from 'react'; -import {createStackNavigator, CardStyleInterpolators} from '@react-navigation/stack'; -import styles from '../../../styles/styles'; -import SCREENS from '../../../SCREENS'; +import _ from 'underscore'; +import styles from '@styles/styles'; +import SCREENS from '@src/SCREENS'; const defaultSubRouteOptions = { cardStyle: styles.navigationScreenCardStyle, diff --git a/src/libs/Navigation/AppNavigator/Navigators/CentralPaneNavigator.js b/src/libs/Navigation/AppNavigator/Navigators/CentralPaneNavigator.js index 64eadcbe06c3..fc75f3544346 100644 --- a/src/libs/Navigation/AppNavigator/Navigators/CentralPaneNavigator.js +++ b/src/libs/Navigation/AppNavigator/Navigators/CentralPaneNavigator.js @@ -1,10 +1,10 @@ -import React from 'react'; import {createStackNavigator} from '@react-navigation/stack'; -import SCREENS from '../../../../SCREENS'; -import ReportScreenWrapper from '../ReportScreenWrapper'; -import getCurrentUrl from '../../currentUrl'; -import styles from '../../../../styles/styles'; -import FreezeWrapper from '../../FreezeWrapper'; +import React from 'react'; +import ReportScreenWrapper from '@libs/Navigation/AppNavigator/ReportScreenWrapper'; +import getCurrentUrl from '@libs/Navigation/currentUrl'; +import FreezeWrapper from '@libs/Navigation/FreezeWrapper'; +import styles from '@styles/styles'; +import SCREENS from '@src/SCREENS'; const Stack = createStackNavigator(); diff --git a/src/libs/Navigation/AppNavigator/Navigators/Overlay.js b/src/libs/Navigation/AppNavigator/Navigators/Overlay.js index 1b2faff8c5e3..a36f98076d22 100644 --- a/src/libs/Navigation/AppNavigator/Navigators/Overlay.js +++ b/src/libs/Navigation/AppNavigator/Navigators/Overlay.js @@ -1,13 +1,11 @@ -import React from 'react'; -import {Animated, View} from 'react-native'; import {useCardAnimation} from '@react-navigation/stack'; - import PropTypes from 'prop-types'; -import styles from '../../../../styles/styles'; - -import PressableWithoutFeedback from '../../../../components/Pressable/PressableWithoutFeedback'; -import useLocalize from '../../../../hooks/useLocalize'; -import CONST from '../../../../CONST'; +import React from 'react'; +import {Animated, View} from 'react-native'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /* Callback to close the modal */ diff --git a/src/libs/Navigation/AppNavigator/Navigators/RightModalNavigator.js b/src/libs/Navigation/AppNavigator/Navigators/RightModalNavigator.js index 76203763bb0e..de3fb9e79659 100644 --- a/src/libs/Navigation/AppNavigator/Navigators/RightModalNavigator.js +++ b/src/libs/Navigation/AppNavigator/Navigators/RightModalNavigator.js @@ -1,14 +1,13 @@ -import React from 'react'; -import {View} from 'react-native'; import {createStackNavigator} from '@react-navigation/stack'; import PropTypes from 'prop-types'; - -import * as ModalStackNavigators from '../ModalStackNavigators'; -import RHPScreenOptions from '../RHPScreenOptions'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; -import styles from '../../../../styles/styles'; +import React from 'react'; +import {View} from 'react-native'; +import NoDropZone from '@components/DragAndDrop/NoDropZone'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as ModalStackNavigators from '@libs/Navigation/AppNavigator/ModalStackNavigators'; +import RHPScreenOptions from '@libs/Navigation/AppNavigator/RHPScreenOptions'; +import styles from '@styles/styles'; import Overlay from './Overlay'; -import NoDropZone from '../../../../components/DragAndDrop/NoDropZone'; const Stack = createStackNavigator(); diff --git a/src/libs/Navigation/AppNavigator/PublicScreens.js b/src/libs/Navigation/AppNavigator/PublicScreens.js index 7b0afb787278..b50769c7caed 100644 --- a/src/libs/Navigation/AppNavigator/PublicScreens.js +++ b/src/libs/Navigation/AppNavigator/PublicScreens.js @@ -1,14 +1,14 @@ -import React from 'react'; import {createStackNavigator} from '@react-navigation/stack'; -import SignInPage from '../../../pages/signin/SignInPage'; -import ValidateLoginPage from '../../../pages/ValidateLoginPage'; -import LogInWithShortLivedAuthTokenPage from '../../../pages/LogInWithShortLivedAuthTokenPage'; -import SCREENS from '../../../SCREENS'; +import React from 'react'; +import LogInWithShortLivedAuthTokenPage from '@pages/LogInWithShortLivedAuthTokenPage'; +import AppleSignInDesktopPage from '@pages/signin/AppleSignInDesktopPage'; +import GoogleSignInDesktopPage from '@pages/signin/GoogleSignInDesktopPage'; +import SAMLSignInPage from '@pages/signin/SAMLSignInPage'; +import SignInPage from '@pages/signin/SignInPage'; +import UnlinkLoginPage from '@pages/UnlinkLoginPage'; +import ValidateLoginPage from '@pages/ValidateLoginPage'; +import SCREENS from '@src/SCREENS'; import defaultScreenOptions from './defaultScreenOptions'; -import UnlinkLoginPage from '../../../pages/UnlinkLoginPage'; -import AppleSignInDesktopPage from '../../../pages/signin/AppleSignInDesktopPage'; -import GoogleSignInDesktopPage from '../../../pages/signin/GoogleSignInDesktopPage'; -import SAMLSignInPage from '../../../pages/signin/SAMLSignInPage'; const RootStack = createStackNavigator(); diff --git a/src/libs/Navigation/AppNavigator/RHPScreenOptions.js b/src/libs/Navigation/AppNavigator/RHPScreenOptions.js index d7448dcf2314..6adf5bd2b507 100644 --- a/src/libs/Navigation/AppNavigator/RHPScreenOptions.js +++ b/src/libs/Navigation/AppNavigator/RHPScreenOptions.js @@ -1,5 +1,5 @@ import {CardStyleInterpolators} from '@react-navigation/stack'; -import styles from '../../../styles/styles'; +import styles from '@styles/styles'; const RHPScreenOptions = { headerShown: false, diff --git a/src/libs/Navigation/AppNavigator/ReportScreenIDSetter.js b/src/libs/Navigation/AppNavigator/ReportScreenIDSetter.js index 8cfef2439adb..70a33ee34a67 100644 --- a/src/libs/Navigation/AppNavigator/ReportScreenIDSetter.js +++ b/src/libs/Navigation/AppNavigator/ReportScreenIDSetter.js @@ -1,13 +1,13 @@ -import {useEffect} from 'react'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as ReportUtils from '../../ReportUtils'; -import reportPropTypes from '../../../pages/reportPropTypes'; -import * as App from '../../actions/App'; -import usePermissions from '../../../hooks/usePermissions'; -import Navigation from '../Navigation'; +import usePermissions from '@hooks/usePermissions'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import * as App from '@userActions/App'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Available reports that would be displayed in this navigator */ diff --git a/src/libs/Navigation/AppNavigator/ReportScreenWrapper.js b/src/libs/Navigation/AppNavigator/ReportScreenWrapper.js index 542be8ed859e..87a8a4abc687 100644 --- a/src/libs/Navigation/AppNavigator/ReportScreenWrapper.js +++ b/src/libs/Navigation/AppNavigator/ReportScreenWrapper.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; import React from 'react'; -import ReportScreen from '../../../pages/home/ReportScreen'; +import ReportScreen from '@pages/home/ReportScreen'; import ReportScreenIDSetter from './ReportScreenIDSetter'; const propTypes = { diff --git a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.js b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.js index 42caad5b3969..5d3eb38d49dc 100644 --- a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.js +++ b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.js @@ -1,8 +1,8 @@ -import _ from 'underscore'; import {StackRouter} from '@react-navigation/native'; import lodashFindLast from 'lodash/findLast'; -import NAVIGATORS from '../../../../NAVIGATORS'; -import SCREENS from '../../../../SCREENS'; +import _ from 'underscore'; +import NAVIGATORS from '@src/NAVIGATORS'; +import SCREENS from '@src/SCREENS'; /** * @param {Object} state - react-navigation state diff --git a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/index.js b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/index.js index 58be3d2af3da..ae36f4aff9ad 100644 --- a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/index.js +++ b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/index.js @@ -1,9 +1,9 @@ -import React, {useRef} from 'react'; -import PropTypes from 'prop-types'; -import {useNavigationBuilder, createNavigatorFactory} from '@react-navigation/native'; +import {createNavigatorFactory, useNavigationBuilder} from '@react-navigation/native'; import {StackView} from '@react-navigation/stack'; +import PropTypes from 'prop-types'; +import React, {useRef} from 'react'; +import useWindowDimensions from '@hooks/useWindowDimensions'; import CustomRouter from './CustomRouter'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; const propTypes = { /* Determines if the navigator should render the StackView (narrow) or ThreePaneView (wide) */ diff --git a/src/libs/Navigation/AppNavigator/getRootNavigatorScreenOptions.js b/src/libs/Navigation/AppNavigator/getRootNavigatorScreenOptions.js index a7456fb071b4..04784fb9d0e1 100644 --- a/src/libs/Navigation/AppNavigator/getRootNavigatorScreenOptions.js +++ b/src/libs/Navigation/AppNavigator/getRootNavigatorScreenOptions.js @@ -1,8 +1,8 @@ +import getNavigationModalCardStyle from '@styles/getNavigationModalCardStyles'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import CONFIG from '@src/CONFIG'; import modalCardStyleInterpolator from './modalCardStyleInterpolator'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; -import getNavigationModalCardStyle from '../../../styles/getNavigationModalCardStyles'; -import CONFIG from '../../../CONFIG'; const commonScreenOptions = { headerShown: false, diff --git a/src/libs/Navigation/AppNavigator/index.js b/src/libs/Navigation/AppNavigator/index.js index dee8027b2f30..0d03badf37bc 100644 --- a/src/libs/Navigation/AppNavigator/index.js +++ b/src/libs/Navigation/AppNavigator/index.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; const propTypes = { /** If we have an authToken this is true */ diff --git a/src/libs/Navigation/AppNavigator/modalCardStyleInterpolator.js b/src/libs/Navigation/AppNavigator/modalCardStyleInterpolator.js index ec442efbba86..446d195fc466 100644 --- a/src/libs/Navigation/AppNavigator/modalCardStyleInterpolator.js +++ b/src/libs/Navigation/AppNavigator/modalCardStyleInterpolator.js @@ -1,6 +1,6 @@ import {Animated} from 'react-native'; -import variables from '../../../styles/variables'; -import getCardStyles from '../../../styles/cardStyles'; +import getCardStyles from '@styles/cardStyles'; +import variables from '@styles/variables'; export default (isSmallScreenWidth, isFullScreenModal, {current: {progress}, inverted, layouts: {screen}}) => { const translateX = Animated.multiply( diff --git a/src/libs/Navigation/FreezeWrapper.js b/src/libs/Navigation/FreezeWrapper.js index 07b05651a769..592d869dc0de 100644 --- a/src/libs/Navigation/FreezeWrapper.js +++ b/src/libs/Navigation/FreezeWrapper.js @@ -1,7 +1,7 @@ -import React, {useEffect, useState, useRef} from 'react'; +import {useIsFocused, useNavigation, useRoute} from '@react-navigation/native'; import lodashFindIndex from 'lodash/findIndex'; import PropTypes from 'prop-types'; -import {useIsFocused, useNavigation, useRoute} from '@react-navigation/native'; +import React, {useEffect, useRef, useState} from 'react'; import {Freeze} from 'react-freeze'; const propTypes = { diff --git a/src/libs/Navigation/Navigation.js b/src/libs/Navigation/Navigation.js index 6bbf53ffa6ea..ae13e2b07206 100644 --- a/src/libs/Navigation/Navigation.js +++ b/src/libs/Navigation/Navigation.js @@ -1,19 +1,19 @@ +import {getActionFromState} from '@react-navigation/core'; +import {CommonActions, getPathFromState, StackActions} from '@react-navigation/native'; import _ from 'lodash'; import lodashGet from 'lodash/get'; -import {CommonActions, getPathFromState, StackActions} from '@react-navigation/native'; -import {getActionFromState} from '@react-navigation/core'; -import Log from '../Log'; -import linkTo from './linkTo'; -import ROUTES from '../../ROUTES'; -import linkingConfig from './linkingConfig'; -import navigationRef from './navigationRef'; -import NAVIGATORS from '../../NAVIGATORS'; -import originalGetTopmostReportId from './getTopmostReportId'; +import Log from '@libs/Log'; +import CONST from '@src/CONST'; +import NAVIGATORS from '@src/NAVIGATORS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; +import getStateFromPath from './getStateFromPath'; import originalGetTopMostCentralPaneRouteName from './getTopMostCentralPaneRouteName'; import originalGetTopmostReportActionId from './getTopmostReportActionID'; -import getStateFromPath from './getStateFromPath'; -import SCREENS from '../../SCREENS'; -import CONST from '../../CONST'; +import originalGetTopmostReportId from './getTopmostReportId'; +import linkingConfig from './linkingConfig'; +import linkTo from './linkTo'; +import navigationRef from './navigationRef'; let resolveNavigationIsReadyPromise; const navigationIsReadyPromise = new Promise((resolve) => { diff --git a/src/libs/Navigation/NavigationRoot.js b/src/libs/Navigation/NavigationRoot.js index c7a3b14e4fb0..3478f7b8ed8d 100644 --- a/src/libs/Navigation/NavigationRoot.js +++ b/src/libs/Navigation/NavigationRoot.js @@ -1,17 +1,17 @@ -import React, {useRef, useEffect, useContext} from 'react'; +import {DefaultTheme, getPathFromState, NavigationContainer} from '@react-navigation/native'; import PropTypes from 'prop-types'; -import {NavigationContainer, DefaultTheme, getPathFromState} from '@react-navigation/native'; -import {useSharedValue, useAnimatedReaction, interpolateColor, withTiming, withDelay, Easing, runOnJS} from 'react-native-reanimated'; -import useFlipper from '../../hooks/useFlipper'; -import Navigation, {navigationRef} from './Navigation'; -import linkingConfig from './linkingConfig'; +import React, {useContext, useEffect, useRef} from 'react'; +import {Easing, interpolateColor, runOnJS, useAnimatedReaction, useSharedValue, withDelay, withTiming} from 'react-native-reanimated'; +import useCurrentReportID from '@hooks/useCurrentReportID'; +import useFlipper from '@hooks/useFlipper'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import Log from '@libs/Log'; +import StatusBar from '@libs/StatusBar'; +import {SidebarNavigationContext} from '@pages/home/sidebar/SidebarNavigationContext'; +import themeColors from '@styles/themes/default'; import AppNavigator from './AppNavigator'; -import themeColors from '../../styles/themes/default'; -import Log from '../Log'; -import StatusBar from '../StatusBar'; -import useCurrentReportID from '../../hooks/useCurrentReportID'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import {SidebarNavigationContext} from '../../pages/home/sidebar/SidebarNavigationContext'; +import linkingConfig from './linkingConfig'; +import Navigation, {navigationRef} from './Navigation'; // https://reactnavigation.org/docs/themes const navigationTheme = { diff --git a/src/libs/Navigation/OnyxTabNavigator.js b/src/libs/Navigation/OnyxTabNavigator.js index 158160e9aa13..eeed3e0cd270 100644 --- a/src/libs/Navigation/OnyxTabNavigator.js +++ b/src/libs/Navigation/OnyxTabNavigator.js @@ -1,9 +1,9 @@ -import React from 'react'; import {createMaterialTopTabNavigator} from '@react-navigation/material-top-tabs'; -import {withOnyx} from 'react-native-onyx'; import PropTypes from 'prop-types'; -import Tab from '../actions/Tab'; -import ONYXKEYS from '../../ONYXKEYS'; +import React from 'react'; +import {withOnyx} from 'react-native-onyx'; +import Tab from '@userActions/Tab'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** ID of the tab component to be saved in onyx */ diff --git a/src/libs/Navigation/linkTo.js b/src/libs/Navigation/linkTo.js index fcb3bd5df9c5..e77d787ab4f8 100644 --- a/src/libs/Navigation/linkTo.js +++ b/src/libs/Navigation/linkTo.js @@ -1,11 +1,11 @@ import {getActionFromState} from '@react-navigation/core'; import _ from 'lodash'; -import NAVIGATORS from '../../NAVIGATORS'; -import linkingConfig from './linkingConfig'; -import getTopmostReportId from './getTopmostReportId'; +import CONST from '@src/CONST'; +import NAVIGATORS from '@src/NAVIGATORS'; import getStateFromPath from './getStateFromPath'; -import CONST from '../../CONST'; import getTopMostCentralPaneRouteName from './getTopMostCentralPaneRouteName'; +import getTopmostReportId from './getTopmostReportId'; +import linkingConfig from './linkingConfig'; /** * Motivation for this function is described in NAVIGATION.md diff --git a/src/libs/Navigation/linkingConfig.js b/src/libs/Navigation/linkingConfig.js index 79609f551ee4..fff86b684872 100644 --- a/src/libs/Navigation/linkingConfig.js +++ b/src/libs/Navigation/linkingConfig.js @@ -1,7 +1,7 @@ -import ROUTES from '../../ROUTES'; -import SCREENS from '../../SCREENS'; -import CONST from '../../CONST'; -import NAVIGATORS from '../../NAVIGATORS'; +import CONST from '@src/CONST'; +import NAVIGATORS from '@src/NAVIGATORS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; export default { prefixes: ['new-expensify://', 'https://www.expensify.cash', 'https://staging.expensify.cash', 'http://localhost', CONST.NEW_EXPENSIFY_URL, CONST.STAGING_NEW_EXPENSIFY_URL], diff --git a/src/libs/Navigation/shouldPreventDeeplinkPrompt/index.js b/src/libs/Navigation/shouldPreventDeeplinkPrompt/index.js index 861e40eaa24d..23f46cb9808f 100644 --- a/src/libs/Navigation/shouldPreventDeeplinkPrompt/index.js +++ b/src/libs/Navigation/shouldPreventDeeplinkPrompt/index.js @@ -1,4 +1,4 @@ -import CONST from '../../../CONST'; +import CONST from '@src/CONST'; /** * Determines if the deeplink prompt should be shown on the current screen diff --git a/src/libs/Network/MainQueue.ts b/src/libs/Network/MainQueue.ts index 5f069e2d0ed4..3ae0d44680a4 100644 --- a/src/libs/Network/MainQueue.ts +++ b/src/libs/Network/MainQueue.ts @@ -1,7 +1,7 @@ +import * as Request from '@libs/Request'; +import OnyxRequest from '@src/types/onyx/Request'; import * as NetworkStore from './NetworkStore'; import * as SequentialQueue from './SequentialQueue'; -import * as Request from '../Request'; -import OnyxRequest from '../../types/onyx/Request'; // Queue for network requests so we don't lose actions done by the user while offline let networkRequestQueue: OnyxRequest[] = []; diff --git a/src/libs/Network/NetworkStore.ts b/src/libs/Network/NetworkStore.ts index 0910031bdb63..52e4147f1b3c 100644 --- a/src/libs/Network/NetworkStore.ts +++ b/src/libs/Network/NetworkStore.ts @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import Credentials from '../../types/onyx/Credentials'; +import ONYXKEYS from '@src/ONYXKEYS'; +import Credentials from '@src/types/onyx/Credentials'; let credentials: Credentials | null = null; let authToken: string | null = null; diff --git a/src/libs/Network/SequentialQueue.ts b/src/libs/Network/SequentialQueue.ts index 980bbc0efc44..d4aee4a221e5 100644 --- a/src/libs/Network/SequentialQueue.ts +++ b/src/libs/Network/SequentialQueue.ts @@ -1,13 +1,13 @@ import Onyx from 'react-native-onyx'; -import * as PersistedRequests from '../actions/PersistedRequests'; +import * as ActiveClientManager from '@libs/ActiveClientManager'; +import * as Request from '@libs/Request'; +import * as RequestThrottle from '@libs/RequestThrottle'; +import * as PersistedRequests from '@userActions/PersistedRequests'; +import * as QueuedOnyxUpdates from '@userActions/QueuedOnyxUpdates'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import OnyxRequest from '@src/types/onyx/Request'; import * as NetworkStore from './NetworkStore'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ActiveClientManager from '../ActiveClientManager'; -import * as Request from '../Request'; -import * as RequestThrottle from '../RequestThrottle'; -import CONST from '../../CONST'; -import * as QueuedOnyxUpdates from '../actions/QueuedOnyxUpdates'; -import OnyxRequest from '../../types/onyx/Request'; let resolveIsReadyPromise: ((args?: unknown[]) => void) | undefined; let isReadyPromise = new Promise((resolve) => { diff --git a/src/libs/Network/enhanceParameters.ts b/src/libs/Network/enhanceParameters.ts index 54d72a7c6c99..6ff54f94bc88 100644 --- a/src/libs/Network/enhanceParameters.ts +++ b/src/libs/Network/enhanceParameters.ts @@ -1,5 +1,5 @@ -import CONFIG from '../../CONFIG'; -import getPlatform from '../getPlatform'; +import getPlatform from '@libs/getPlatform'; +import CONFIG from '@src/CONFIG'; import * as NetworkStore from './NetworkStore'; /** diff --git a/src/libs/Network/index.ts b/src/libs/Network/index.ts index bf38bc33e95a..4ccb8df01163 100644 --- a/src/libs/Network/index.ts +++ b/src/libs/Network/index.ts @@ -1,10 +1,10 @@ -import * as ActiveClientManager from '../ActiveClientManager'; -import CONST from '../../CONST'; +import * as ActiveClientManager from '@libs/ActiveClientManager'; +import CONST from '@src/CONST'; +import {Request} from '@src/types/onyx'; +import Response from '@src/types/onyx/Response'; +import pkg from '../../../package.json'; import * as MainQueue from './MainQueue'; import * as SequentialQueue from './SequentialQueue'; -import pkg from '../../../package.json'; -import {Request} from '../../types/onyx'; -import Response from '../../types/onyx/Response'; // We must wait until the ActiveClientManager is ready so that we ensure only the "leader" tab processes any persisted requests ActiveClientManager.isReady().then(() => { diff --git a/src/libs/NetworkConnection.ts b/src/libs/NetworkConnection.ts index 663a9c1b37d5..e150b8b650c1 100644 --- a/src/libs/NetworkConnection.ts +++ b/src/libs/NetworkConnection.ts @@ -1,12 +1,12 @@ -import Onyx from 'react-native-onyx'; import NetInfo from '@react-native-community/netinfo'; import throttle from 'lodash/throttle'; +import Onyx from 'react-native-onyx'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import * as NetworkActions from './actions/Network'; import AppStateMonitor from './AppStateMonitor'; import Log from './Log'; -import * as NetworkActions from './actions/Network'; -import CONFIG from '../CONFIG'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; let isOffline = false; let hasPendingNetworkCheck = false; diff --git a/src/libs/NextStepUtils.js b/src/libs/NextStepUtils.js index 78214bac7df9..303f9b2a9925 100644 --- a/src/libs/NextStepUtils.js +++ b/src/libs/NextStepUtils.js @@ -1,5 +1,5 @@ -import _ from 'underscore'; import Str from 'expensify-common/lib/str'; +import _ from 'underscore'; function parseMessage(messageToParse) { let nextStepHTML = ''; diff --git a/src/libs/Notification/LocalNotification/BrowserNotifications.js b/src/libs/Notification/LocalNotification/BrowserNotifications.js index 3199e4c6388d..20d9be48d915 100644 --- a/src/libs/Notification/LocalNotification/BrowserNotifications.js +++ b/src/libs/Notification/LocalNotification/BrowserNotifications.js @@ -1,9 +1,9 @@ // Web and desktop implementation only. Do not import for direct use. Use LocalNotification. import _ from 'underscore'; +import EXPENSIFY_ICON_URL from '@assets/images/expensify-logo-round-clearspace.png'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as AppUpdate from '@userActions/AppUpdate'; import focusApp from './focusApp'; -import * as AppUpdate from '../../actions/AppUpdate'; -import EXPENSIFY_ICON_URL from '../../../../assets/images/expensify-logo-round-clearspace.png'; -import * as ReportUtils from '../../ReportUtils'; const DEFAULT_DELAY = 4000; diff --git a/src/libs/Notification/PushNotification/ForegroundNotifications/index.android.js b/src/libs/Notification/PushNotification/ForegroundNotifications/index.android.js index 0afc8fe10490..b36c0d0c7d18 100644 --- a/src/libs/Notification/PushNotification/ForegroundNotifications/index.android.js +++ b/src/libs/Notification/PushNotification/ForegroundNotifications/index.android.js @@ -1,5 +1,5 @@ import Airship from '@ua/react-native-airship'; -import shouldShowPushNotification from '../shouldShowPushNotification'; +import shouldShowPushNotification from '@libs/Notification/PushNotification/shouldShowPushNotification'; function configureForegroundNotifications() { Airship.push.android.setForegroundDisplayPredicate((pushPayload) => Promise.resolve(shouldShowPushNotification(pushPayload))); diff --git a/src/libs/Notification/PushNotification/ForegroundNotifications/index.ios.js b/src/libs/Notification/PushNotification/ForegroundNotifications/index.ios.js index 17ad1baaebe3..0f0929951a90 100644 --- a/src/libs/Notification/PushNotification/ForegroundNotifications/index.ios.js +++ b/src/libs/Notification/PushNotification/ForegroundNotifications/index.ios.js @@ -1,5 +1,5 @@ import Airship, {iOS} from '@ua/react-native-airship'; -import shouldShowPushNotification from '../shouldShowPushNotification'; +import shouldShowPushNotification from '@libs/Notification/PushNotification/shouldShowPushNotification'; function configureForegroundNotifications() { // Set our default iOS foreground presentation to be loud with a banner diff --git a/src/libs/Notification/PushNotification/backgroundRefresh/index.android.js b/src/libs/Notification/PushNotification/backgroundRefresh/index.android.js index d86589e2f207..b672069727a5 100644 --- a/src/libs/Notification/PushNotification/backgroundRefresh/index.android.js +++ b/src/libs/Notification/PushNotification/backgroundRefresh/index.android.js @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; -import * as App from '../../../actions/App'; -import Visibility from '../../../Visibility'; -import ONYXKEYS from '../../../../ONYXKEYS'; +import Visibility from '@libs/Visibility'; +import * as App from '@userActions/App'; +import ONYXKEYS from '@src/ONYXKEYS'; function getLastOnyxUpdateID() { return new Promise((resolve) => { diff --git a/src/libs/Notification/PushNotification/index.native.js b/src/libs/Notification/PushNotification/index.native.js index 7192ee66a791..8513a88e46d3 100644 --- a/src/libs/Notification/PushNotification/index.native.js +++ b/src/libs/Notification/PushNotification/index.native.js @@ -1,12 +1,12 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; import Airship, {EventType} from '@ua/react-native-airship'; import lodashGet from 'lodash/get'; -import Log from '../../Log'; -import NotificationType from './NotificationType'; -import * as PushNotification from '../../actions/PushNotification'; -import ONYXKEYS from '../../../ONYXKEYS'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import * as PushNotification from '@userActions/PushNotification'; +import ONYXKEYS from '@src/ONYXKEYS'; import ForegroundNotifications from './ForegroundNotifications'; +import NotificationType from './NotificationType'; let isUserOptedInToPushNotifications = false; Onyx.connect({ diff --git a/src/libs/Notification/PushNotification/shouldShowPushNotification.js b/src/libs/Notification/PushNotification/shouldShowPushNotification.js index b9b9d974374c..f25d452a77d5 100644 --- a/src/libs/Notification/PushNotification/shouldShowPushNotification.js +++ b/src/libs/Notification/PushNotification/shouldShowPushNotification.js @@ -1,7 +1,7 @@ import _ from 'underscore'; -import * as Report from '../../actions/Report'; -import Log from '../../Log'; -import * as ReportActionUtils from '../../ReportActionsUtils'; +import Log from '@libs/Log'; +import * as ReportActionUtils from '@libs/ReportActionsUtils'; +import * as Report from '@userActions/Report'; /** * Returns whether the given Airship notification should be shown depending on the current state of the app diff --git a/src/libs/Notification/PushNotification/subscribePushNotification/index.js b/src/libs/Notification/PushNotification/subscribePushNotification/index.js index 45dc8d8a7ae9..c5519b42dc09 100644 --- a/src/libs/Notification/PushNotification/subscribePushNotification/index.js +++ b/src/libs/Notification/PushNotification/subscribePushNotification/index.js @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; +import subscribeToReportCommentPushNotifications from '@libs/Notification/PushNotification/subscribeToReportCommentPushNotifications'; +import ONYXKEYS from '@src/ONYXKEYS'; import PushNotification from '..'; -import subscribeToReportCommentPushNotifications from '../subscribeToReportCommentPushNotifications'; -import ONYXKEYS from '../../../../ONYXKEYS'; /** * Manage push notification subscriptions on sign-in/sign-out. diff --git a/src/libs/Notification/PushNotification/subscribeToReportCommentPushNotifications.js b/src/libs/Notification/PushNotification/subscribeToReportCommentPushNotifications.js index 269d00404a9d..04fd34bf6075 100644 --- a/src/libs/Notification/PushNotification/subscribeToReportCommentPushNotifications.js +++ b/src/libs/Notification/PushNotification/subscribeToReportCommentPushNotifications.js @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; -import PushNotification from './index'; -import ROUTES from '../../../ROUTES'; -import Log from '../../Log'; -import Navigation from '../../Navigation/Navigation'; -import Visibility from '../../Visibility'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import Visibility from '@libs/Visibility'; +import ROUTES from '@src/ROUTES'; import backgroundRefresh from './backgroundRefresh'; +import PushNotification from './index'; /** * Setup reportComment push notification callbacks. diff --git a/src/libs/NumberUtils.ts b/src/libs/NumberUtils.ts index 6e8d0fa4362b..ddbd42243758 100644 --- a/src/libs/NumberUtils.ts +++ b/src/libs/NumberUtils.ts @@ -1,4 +1,4 @@ -import CONST from '../CONST'; +import CONST from '@src/CONST'; /** * Generates a random positive 64 bit numeric string by randomly generating the left, middle, and right parts and concatenating them. Used to generate client-side ids. diff --git a/src/libs/OnyxSelectors/reportWithoutHasDraftSelector.ts b/src/libs/OnyxSelectors/reportWithoutHasDraftSelector.ts index 8819cc8aa47c..9fd89cfdf146 100644 --- a/src/libs/OnyxSelectors/reportWithoutHasDraftSelector.ts +++ b/src/libs/OnyxSelectors/reportWithoutHasDraftSelector.ts @@ -1,4 +1,4 @@ -import {OnyxKeyValue} from '../../ONYXKEYS'; +import {OnyxKeyValue} from '@src/ONYXKEYS'; export default function reportWithoutHasDraftSelector(report: OnyxKeyValue<'report_'>) { if (!report) { diff --git a/src/libs/OptionsListUtils.js b/src/libs/OptionsListUtils.js index 79c480711c4d..74382c8b9065 100644 --- a/src/libs/OptionsListUtils.js +++ b/src/libs/OptionsListUtils.js @@ -1,25 +1,25 @@ /* eslint-disable no-continue */ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; -import lodashOrderBy from 'lodash/orderBy'; +import {parsePhoneNumber} from 'awesome-phonenumber'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; +import lodashOrderBy from 'lodash/orderBy'; import lodashSet from 'lodash/set'; -import Str from 'expensify-common/lib/str'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import * as ReportUtils from './ReportUtils'; -import * as Localize from './Localize'; -import Permissions from './Permissions'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as CollectionUtils from './CollectionUtils'; -import Navigation from './Navigation/Navigation'; -import * as LoginUtils from './LoginUtils'; +import * as ErrorUtils from './ErrorUtils'; import * as LocalePhoneNumber from './LocalePhoneNumber'; -import * as UserUtils from './UserUtils'; -import * as ReportActionUtils from './ReportActionsUtils'; +import * as Localize from './Localize'; +import * as LoginUtils from './LoginUtils'; +import Navigation from './Navigation/Navigation'; +import Permissions from './Permissions'; import * as PersonalDetailsUtils from './PersonalDetailsUtils'; -import * as ErrorUtils from './ErrorUtils'; +import * as ReportActionUtils from './ReportActionsUtils'; +import * as ReportUtils from './ReportUtils'; import * as TransactionUtils from './TransactionUtils'; +import * as UserUtils from './UserUtils'; /** * OptionsListUtils is used to build a list options passed to the OptionsList component. Several different UI views can diff --git a/src/libs/PaymentUtils.ts b/src/libs/PaymentUtils.ts index 380f10589b3f..b37db2584394 100644 --- a/src/libs/PaymentUtils.ts +++ b/src/libs/PaymentUtils.ts @@ -1,10 +1,10 @@ -import BankAccountModel from './models/BankAccount'; -import getBankIcon from '../components/Icon/BankIcons'; -import CONST from '../CONST'; +import getBankIcon from '@components/Icon/BankIcons'; +import CONST from '@src/CONST'; +import BankAccount from '@src/types/onyx/BankAccount'; +import Fund from '@src/types/onyx/Fund'; +import PaymentMethod from '@src/types/onyx/PaymentMethod'; import * as Localize from './Localize'; -import Fund from '../types/onyx/Fund'; -import BankAccount from '../types/onyx/BankAccount'; -import PaymentMethod from '../types/onyx/PaymentMethod'; +import BankAccountModel from './models/BankAccount'; type AccountType = BankAccount['accountType'] | Fund['accountType']; diff --git a/src/libs/Performance.tsx b/src/libs/Performance.tsx index cfb5e258c9f8..45ae0f5cc5f0 100644 --- a/src/libs/Performance.tsx +++ b/src/libs/Performance.tsx @@ -1,15 +1,14 @@ -import React, {Profiler, forwardRef} from 'react'; -import {Alert, InteractionManager} from 'react-native'; -import lodashTransform from 'lodash/transform'; -import isObject from 'lodash/isObject'; import isEqual from 'lodash/isEqual'; -import {Performance as RNPerformance, PerformanceEntry, PerformanceMark, PerformanceMeasure} from 'react-native-performance'; +import isObject from 'lodash/isObject'; +import lodashTransform from 'lodash/transform'; +import React, {forwardRef, Profiler} from 'react'; +import {Alert, InteractionManager} from 'react-native'; +import {PerformanceEntry, PerformanceMark, PerformanceMeasure, Performance as RNPerformance} from 'react-native-performance'; import {PerformanceObserverEntryList} from 'react-native-performance/lib/typescript/performance-observer'; - -import * as Metrics from './Metrics'; -import getComponentDisplayName from './getComponentDisplayName'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; import isE2ETestSession from './E2E/isE2ETestSession'; +import getComponentDisplayName from './getComponentDisplayName'; +import * as Metrics from './Metrics'; type WrappedComponentConfig = {id: string}; diff --git a/src/libs/Permissions.ts b/src/libs/Permissions.ts index 9703a4368abe..2eb1d3b02f25 100644 --- a/src/libs/Permissions.ts +++ b/src/libs/Permissions.ts @@ -1,5 +1,5 @@ -import CONST from '../CONST'; -import Beta from '../types/onyx/Beta'; +import CONST from '@src/CONST'; +import Beta from '@src/types/onyx/Beta'; function canUseAllBetas(betas: Beta[]): boolean { return betas?.includes(CONST.BETAS.ALL); diff --git a/src/libs/PersonalDetailsUtils.js b/src/libs/PersonalDetailsUtils.js index ddb24d62ef26..e346dcde4fc4 100644 --- a/src/libs/PersonalDetailsUtils.js +++ b/src/libs/PersonalDetailsUtils.js @@ -1,10 +1,10 @@ import lodashGet from 'lodash/get'; import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; +import * as LocalePhoneNumber from './LocalePhoneNumber'; import * as Localize from './Localize'; import * as UserUtils from './UserUtils'; -import * as LocalePhoneNumber from './LocalePhoneNumber'; let personalDetails = []; let allPersonalDetails = {}; diff --git a/src/libs/PolicyUtils.ts b/src/libs/PolicyUtils.ts index e33af862f63d..62640a11311a 100644 --- a/src/libs/PolicyUtils.ts +++ b/src/libs/PolicyUtils.ts @@ -1,8 +1,8 @@ -import {OnyxCollection, OnyxEntry} from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import {PersonalDetails, Policy, PolicyMembers, PolicyTags} from '../types/onyx'; +import {OnyxCollection, OnyxEntry} from 'react-native-onyx'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {PersonalDetails, Policy, PolicyMembers, PolicyTags} from '@src/types/onyx'; type MemberEmailsToAccountIDs = Record; type PersonalDetailsList = Record; diff --git a/src/libs/Pusher/pusher.ts b/src/libs/Pusher/pusher.ts index dad963e933fe..dd8af08db229 100644 --- a/src/libs/Pusher/pusher.ts +++ b/src/libs/Pusher/pusher.ts @@ -1,15 +1,15 @@ -import Onyx from 'react-native-onyx'; -import {Channel, ChannelAuthorizerGenerator, Options} from 'pusher-js/with-encryption'; import isObject from 'lodash/isObject'; +import {Channel, ChannelAuthorizerGenerator, Options} from 'pusher-js/with-encryption'; +import Onyx from 'react-native-onyx'; import {LiteralUnion, ValueOf} from 'type-fest'; -import ONYXKEYS from '../../ONYXKEYS'; -import Pusher from './library'; +import Log from '@libs/Log'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {OnyxUpdateEvent, OnyxUpdatesFromServer} from '@src/types/onyx'; +import DeepValueOf from '@src/types/utils/DeepValueOf'; import TYPE from './EventType'; -import Log from '../Log'; -import DeepValueOf from '../../types/utils/DeepValueOf'; +import Pusher from './library'; import {SocketEventName} from './library/types'; -import CONST from '../../CONST'; -import {OnyxUpdateEvent, OnyxUpdatesFromServer} from '../../types/onyx'; type States = { previous: string; diff --git a/src/libs/PusherConnectionManager.ts b/src/libs/PusherConnectionManager.ts index 9b1f6ebe1b2a..a0c5673af729 100644 --- a/src/libs/PusherConnectionManager.ts +++ b/src/libs/PusherConnectionManager.ts @@ -1,9 +1,9 @@ import {ChannelAuthorizationCallback} from 'pusher-js/with-encryption'; -import * as Pusher from './Pusher/pusher'; +import CONST from '@src/CONST'; import * as Session from './actions/Session'; import Log from './Log'; -import CONST from '../CONST'; import {SocketEventName} from './Pusher/library/types'; +import * as Pusher from './Pusher/pusher'; import {EventCallbackError, States} from './Pusher/pusher'; function init() { diff --git a/src/libs/PusherUtils.ts b/src/libs/PusherUtils.ts index d47283f21bbf..e5782d12acd3 100644 --- a/src/libs/PusherUtils.ts +++ b/src/libs/PusherUtils.ts @@ -1,9 +1,9 @@ import {OnyxUpdate} from 'react-native-onyx'; -import CONFIG from '../CONFIG'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; import Log from './Log'; import NetworkConnection from './NetworkConnection'; import * as Pusher from './Pusher/pusher'; -import CONST from '../CONST'; import {PushJSON} from './Pusher/pusher'; type Callback = (data: OnyxUpdate[]) => Promise; diff --git a/src/libs/ReceiptUtils.ts b/src/libs/ReceiptUtils.ts index 13e8a195cccb..38b4823d54c6 100644 --- a/src/libs/ReceiptUtils.ts +++ b/src/libs/ReceiptUtils.ts @@ -1,13 +1,13 @@ import Str from 'expensify-common/lib/str'; import {ImageSourcePropType} from 'react-native'; +import ReceiptDoc from '@assets/images/receipt-doc.png'; +import ReceiptGeneric from '@assets/images/receipt-generic.png'; +import ReceiptHTML from '@assets/images/receipt-html.png'; +import ReceiptSVG from '@assets/images/receipt-svg.png'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; +import {Transaction} from '@src/types/onyx'; import * as FileUtils from './fileDownload/FileUtils'; -import CONST from '../CONST'; -import ReceiptHTML from '../../assets/images/receipt-html.png'; -import ReceiptDoc from '../../assets/images/receipt-doc.png'; -import ReceiptGeneric from '../../assets/images/receipt-generic.png'; -import ReceiptSVG from '../../assets/images/receipt-svg.png'; -import {Transaction} from '../types/onyx'; -import ROUTES from '../ROUTES'; type ThumbnailAndImageURI = { image: ImageSourcePropType | string; diff --git a/src/libs/ReportActionComposeFocusManager.ts b/src/libs/ReportActionComposeFocusManager.ts index 65466fa4a204..9d4039117989 100644 --- a/src/libs/ReportActionComposeFocusManager.ts +++ b/src/libs/ReportActionComposeFocusManager.ts @@ -1,6 +1,6 @@ import React from 'react'; import {TextInput} from 'react-native'; -import ROUTES from '../ROUTES'; +import ROUTES from '@src/ROUTES'; import Navigation from './Navigation/Navigation'; type FocusCallback = () => void; diff --git a/src/libs/ReportActionsUtils.ts b/src/libs/ReportActionsUtils.ts index 5d9b4fbdc9cf..11e11f549682 100644 --- a/src/libs/ReportActionsUtils.ts +++ b/src/libs/ReportActionsUtils.ts @@ -2,15 +2,15 @@ import _ from 'lodash'; import lodashFindLast from 'lodash/findLast'; import Onyx, {OnyxCollection, OnyxEntry, OnyxUpdate} from 'react-native-onyx'; import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import ReportAction, {ReportActions} from '../types/onyx/ReportAction'; -import Report from '../types/onyx/Report'; -import {ActionName} from '../types/onyx/OriginalMessage'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {ActionName} from '@src/types/onyx/OriginalMessage'; +import Report from '@src/types/onyx/Report'; +import ReportAction, {ReportActions} from '@src/types/onyx/ReportAction'; import * as CollectionUtils from './CollectionUtils'; -import Log from './Log'; -import isReportMessageAttachment from './isReportMessageAttachment'; import * as Environment from './Environment/Environment'; +import isReportMessageAttachment from './isReportMessageAttachment'; +import Log from './Log'; type LastVisibleMessage = { lastMessageTranslationKey?: string; diff --git a/src/libs/ReportUtils.js b/src/libs/ReportUtils.js index 2dccc68b74e0..0e9091fd6cb2 100644 --- a/src/libs/ReportUtils.js +++ b/src/libs/ReportUtils.js @@ -1,27 +1,27 @@ /* eslint-disable rulesdir/prefer-underscore-method */ -import _ from 'underscore'; import {format} from 'date-fns'; +import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; import lodashIntersection from 'lodash/intersection'; import Onyx from 'react-native-onyx'; -import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; +import _ from 'underscore'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as defaultWorkspaceAvatars from '@components/Icon/WorkspaceDefaultAvatars'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import * as CurrencyUtils from './CurrencyUtils'; +import DateUtils from './DateUtils'; +import isReportMessageAttachment from './isReportMessageAttachment'; import * as Localize from './Localize'; -import * as Expensicons from '../components/Icon/Expensicons'; +import linkingConfig from './Navigation/linkingConfig'; import Navigation from './Navigation/Navigation'; -import ROUTES from '../ROUTES'; import * as NumberUtils from './NumberUtils'; +import Permissions from './Permissions'; import * as ReportActionsUtils from './ReportActionsUtils'; import * as TransactionUtils from './TransactionUtils'; import * as Url from './Url'; -import Permissions from './Permissions'; -import DateUtils from './DateUtils'; -import linkingConfig from './Navigation/linkingConfig'; -import isReportMessageAttachment from './isReportMessageAttachment'; -import * as defaultWorkspaceAvatars from '../components/Icon/WorkspaceDefaultAvatars'; -import * as CurrencyUtils from './CurrencyUtils'; import * as UserUtils from './UserUtils'; let currentUserEmail; diff --git a/src/libs/Request.ts b/src/libs/Request.ts index 9c4af4aa7e18..335731763ec9 100644 --- a/src/libs/Request.ts +++ b/src/libs/Request.ts @@ -1,9 +1,9 @@ +import Request from '@src/types/onyx/Request'; +import Response from '@src/types/onyx/Response'; import HttpUtils from './HttpUtils'; +import Middleware from './Middleware/types'; import enhanceParameters from './Network/enhanceParameters'; import * as NetworkStore from './Network/NetworkStore'; -import Request from '../types/onyx/Request'; -import Response from '../types/onyx/Response'; -import Middleware from './Middleware/types'; let middlewares: Middleware[] = []; diff --git a/src/libs/RequestThrottle.ts b/src/libs/RequestThrottle.ts index 00dca2ebf61e..36935982afbb 100644 --- a/src/libs/RequestThrottle.ts +++ b/src/libs/RequestThrottle.ts @@ -1,4 +1,4 @@ -import CONST from '../CONST'; +import CONST from '@src/CONST'; import {generateRandomInt} from './NumberUtils'; let requestWaitTime = 0; diff --git a/src/libs/RoomNameInputUtils.ts b/src/libs/RoomNameInputUtils.ts index 2777acee45dd..cff0bbc30274 100644 --- a/src/libs/RoomNameInputUtils.ts +++ b/src/libs/RoomNameInputUtils.ts @@ -1,4 +1,4 @@ -import CONST from '../CONST'; +import CONST from '@src/CONST'; /** * Replaces spaces with dashes diff --git a/src/libs/SelectionScraper/index.js b/src/libs/SelectionScraper/index.js index 44b87deba796..02b3ff8bf61b 100644 --- a/src/libs/SelectionScraper/index.js +++ b/src/libs/SelectionScraper/index.js @@ -1,8 +1,8 @@ import render from 'dom-serializer'; +import Str from 'expensify-common/lib/str'; import {parseDocument} from 'htmlparser2'; import _ from 'underscore'; -import Str from 'expensify-common/lib/str'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; const elementsWillBeSkipped = ['html', 'body']; const tagAttribute = 'data-testid'; diff --git a/src/libs/SessionUtils.ts b/src/libs/SessionUtils.ts index fcbc9a887fa9..6cd20e0b56b2 100644 --- a/src/libs/SessionUtils.ts +++ b/src/libs/SessionUtils.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Determine if the transitioning user is logging in as a new user. diff --git a/src/libs/SidebarUtils.ts b/src/libs/SidebarUtils.ts index bfe7d2281049..79d3280e859e 100644 --- a/src/libs/SidebarUtils.ts +++ b/src/libs/SidebarUtils.ts @@ -1,23 +1,23 @@ /* eslint-disable rulesdir/prefer-underscore-method */ -import Onyx from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; +import Onyx from 'react-native-onyx'; import {ValueOf} from 'type-fest'; -import ONYXKEYS from '../ONYXKEYS'; -import * as ReportUtils from './ReportUtils'; -import * as ReportActionsUtils from './ReportActionsUtils'; -import * as Localize from './Localize'; -import CONST from '../CONST'; -import * as OptionsListUtils from './OptionsListUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {PersonalDetails} from '@src/types/onyx'; +import Beta from '@src/types/onyx/Beta'; +import * as OnyxCommon from '@src/types/onyx/OnyxCommon'; +import Policy from '@src/types/onyx/Policy'; +import Report from '@src/types/onyx/Report'; +import ReportAction, {ReportActions} from '@src/types/onyx/ReportAction'; import * as CollectionUtils from './CollectionUtils'; import * as LocalePhoneNumber from './LocalePhoneNumber'; -import * as UserUtils from './UserUtils'; +import * as Localize from './Localize'; +import * as OptionsListUtils from './OptionsListUtils'; import * as PersonalDetailsUtils from './PersonalDetailsUtils'; -import ReportAction, {ReportActions} from '../types/onyx/ReportAction'; -import Beta from '../types/onyx/Beta'; -import Policy from '../types/onyx/Policy'; -import Report from '../types/onyx/Report'; -import {PersonalDetails} from '../types/onyx'; -import * as OnyxCommon from '../types/onyx/OnyxCommon'; +import * as ReportActionsUtils from './ReportActionsUtils'; +import * as ReportUtils from './ReportUtils'; +import * as UserUtils from './UserUtils'; const visibleReportActionItems: ReportActions = {}; const lastReportActions: ReportActions = {}; diff --git a/src/libs/StartupTimer/index.ts b/src/libs/StartupTimer/index.ts index 421524a70fc8..1cc656b329f4 100644 --- a/src/libs/StartupTimer/index.ts +++ b/src/libs/StartupTimer/index.ts @@ -1,7 +1,6 @@ /** * Web noop as there is no "startup" to time from the native layer. */ - import StartupTimer from './types'; const startupTimer: StartupTimer = { diff --git a/src/libs/StringUtils.ts b/src/libs/StringUtils.ts index 8ef23bb0751b..290380ce2cff 100644 --- a/src/libs/StringUtils.ts +++ b/src/libs/StringUtils.ts @@ -1,5 +1,5 @@ import _ from 'lodash'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; /** * Removes diacritical marks and non-alphabetic and non-latin characters from a string. diff --git a/src/libs/SuggestionUtils.js b/src/libs/SuggestionUtils.js index 9c3e92799334..45641ebb5a0f 100644 --- a/src/libs/SuggestionUtils.js +++ b/src/libs/SuggestionUtils.js @@ -1,4 +1,4 @@ -import CONST from '../CONST'; +import CONST from '@src/CONST'; /** * Return the max available index for arrow manager. diff --git a/src/libs/TransactionUtils.ts b/src/libs/TransactionUtils.ts index abd646fc19f1..a30ba7fc2723 100644 --- a/src/libs/TransactionUtils.ts +++ b/src/libs/TransactionUtils.ts @@ -1,12 +1,12 @@ -import Onyx, {OnyxCollection} from 'react-native-onyx'; import {format, isValid} from 'date-fns'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import DateUtils from './DateUtils'; +import Onyx, {OnyxCollection} from 'react-native-onyx'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {RecentWaypoint, ReportAction, Transaction} from '@src/types/onyx'; +import {Comment, Receipt, Waypoint, WaypointCollection} from '@src/types/onyx/Transaction'; import {isExpensifyCard} from './CardUtils'; +import DateUtils from './DateUtils'; import * as NumberUtils from './NumberUtils'; -import {RecentWaypoint, ReportAction, Transaction} from '../types/onyx'; -import {Receipt, Comment, WaypointCollection, Waypoint} from '../types/onyx/Transaction'; type AdditionalTransactionChanges = {comment?: string; waypoints?: WaypointCollection}; diff --git a/src/libs/UnreadIndicatorUpdater/index.js b/src/libs/UnreadIndicatorUpdater/index.js index 9acf1a17bbc6..9af74f8313c3 100644 --- a/src/libs/UnreadIndicatorUpdater/index.js +++ b/src/libs/UnreadIndicatorUpdater/index.js @@ -1,9 +1,9 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import _ from 'underscore'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import updateUnread from './updateUnread/index'; -import * as ReportUtils from '../ReportUtils'; -import CONST from '../../CONST'; Onyx.connect({ key: ONYXKEYS.COLLECTION.REPORT, diff --git a/src/libs/UnreadIndicatorUpdater/updateUnread/index.website.js b/src/libs/UnreadIndicatorUpdater/updateUnread/index.website.js index 4c829239ef14..56aa7f02509d 100644 --- a/src/libs/UnreadIndicatorUpdater/updateUnread/index.website.js +++ b/src/libs/UnreadIndicatorUpdater/updateUnread/index.website.js @@ -1,7 +1,7 @@ /** * Web browsers have a tab title and favicon which can be updated to show there are unread comments */ -import CONFIG from '../../../CONFIG'; +import CONFIG from '@src/CONFIG'; let unreadTotalCount = 0; /** diff --git a/src/libs/UserUtils.ts b/src/libs/UserUtils.ts index 15bf3c0f1029..f7883609f625 100644 --- a/src/libs/UserUtils.ts +++ b/src/libs/UserUtils.ts @@ -1,10 +1,10 @@ import {SvgProps} from 'react-native-svg'; import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; +import * as defaultAvatars from '@components/Icon/DefaultAvatars'; +import {ConciergeAvatar, FallbackAvatar} from '@components/Icon/Expensicons'; +import CONST from '@src/CONST'; +import Login from '@src/types/onyx/Login'; import hashCode from './hashCode'; -import {ConciergeAvatar, FallbackAvatar} from '../components/Icon/Expensicons'; -import * as defaultAvatars from '../components/Icon/DefaultAvatars'; -import Login from '../types/onyx/Login'; type AvatarRange = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24; diff --git a/src/libs/ValidationUtils.ts b/src/libs/ValidationUtils.ts index b94c240b6e92..5947d45a6f76 100644 --- a/src/libs/ValidationUtils.ts +++ b/src/libs/ValidationUtils.ts @@ -1,14 +1,14 @@ -import {subYears, addYears, startOfDay, endOfMonth, parse, isAfter, isBefore, isValid, isWithinInterval, isSameDay, format} from 'date-fns'; -import {URL_REGEX_WITH_REQUIRED_PROTOCOL} from 'expensify-common/lib/Url'; import {parsePhoneNumber} from 'awesome-phonenumber'; +import {addYears, endOfMonth, format, isAfter, isBefore, isSameDay, isValid, isWithinInterval, parse, startOfDay, subYears} from 'date-fns'; +import {URL_REGEX_WITH_REQUIRED_PROTOCOL} from 'expensify-common/lib/Url'; import isDate from 'lodash/isDate'; import isEmpty from 'lodash/isEmpty'; import isObject from 'lodash/isObject'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; +import {Report} from '@src/types/onyx'; +import * as OnyxCommon from '@src/types/onyx/OnyxCommon'; import * as CardUtils from './CardUtils'; import * as LoginUtils from './LoginUtils'; -import {Report} from '../types/onyx'; -import * as OnyxCommon from '../types/onyx/OnyxCommon'; /** * Implements the Luhn Algorithm, a checksum formula used to validate credit card diff --git a/src/libs/Visibility/index.native.ts b/src/libs/Visibility/index.native.ts index 695df3651da7..42bd56531207 100644 --- a/src/libs/Visibility/index.native.ts +++ b/src/libs/Visibility/index.native.ts @@ -1,6 +1,5 @@ // Mobile apps do not require this check for visibility as // they do not use the Notification lib. - import {AppState} from 'react-native'; import {HasFocus, IsVisible, OnVisibilityChange} from './types'; diff --git a/src/libs/__mocks__/Permissions.ts b/src/libs/__mocks__/Permissions.ts index 66ef64bbb994..e95d13f52803 100644 --- a/src/libs/__mocks__/Permissions.ts +++ b/src/libs/__mocks__/Permissions.ts @@ -1,5 +1,5 @@ -import CONST from '../../CONST'; -import Beta from '../../types/onyx/Beta'; +import CONST from '@src/CONST'; +import Beta from '@src/types/onyx/Beta'; /** * This module is mocked in tests because all the permission methods call canUseAllBetas() and that will diff --git a/src/libs/actions/ActiveClients.ts b/src/libs/actions/ActiveClients.ts index 45fcff402f49..e59fdc14410e 100644 --- a/src/libs/actions/ActiveClients.ts +++ b/src/libs/actions/ActiveClients.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; function setActiveClients(activeClients: string[]): Promise { return Onyx.set(ONYXKEYS.ACTIVE_CLIENTS, activeClients); diff --git a/src/libs/actions/App.js b/src/libs/actions/App.js index 75520d483f98..7ffac85650f3 100644 --- a/src/libs/actions/App.js +++ b/src/libs/actions/App.js @@ -1,25 +1,25 @@ // Do not remove this import until moment package is fully removed. // Issue - https://github.com/Expensify/App/issues/26719 +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import 'moment/locale/es'; import {AppState} from 'react-native'; import Onyx from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; import _ from 'underscore'; -import * as API from '../API'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import Log from '../Log'; -import Performance from '../Performance'; +import * as API from '@libs/API'; +import * as Browser from '@libs/Browser'; +import Log from '@libs/Log'; +import getCurrentUrl from '@libs/Navigation/currentUrl'; +import Navigation from '@libs/Navigation/Navigation'; +import Performance from '@libs/Performance'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as SessionUtils from '@libs/SessionUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import * as Policy from './Policy'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as SessionUtils from '../SessionUtils'; -import getCurrentUrl from '../Navigation/currentUrl'; import * as Session from './Session'; -import * as ReportActionsUtils from '../ReportActionsUtils'; import Timing from './Timing'; -import * as Browser from '../Browser'; let currentUserAccountID; let currentUserEmail; diff --git a/src/libs/actions/AppUpdate.ts b/src/libs/actions/AppUpdate.ts index f0e3c1c3da20..29ee2a4547ab 100644 --- a/src/libs/actions/AppUpdate.ts +++ b/src/libs/actions/AppUpdate.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; function triggerUpdateAvailable() { Onyx.set(ONYXKEYS.UPDATE_AVAILABLE, true); diff --git a/src/libs/actions/BankAccounts.ts b/src/libs/actions/BankAccounts.ts index b957633421b9..8d0c59ab8d60 100644 --- a/src/libs/actions/BankAccounts.ts +++ b/src/libs/actions/BankAccounts.ts @@ -1,16 +1,16 @@ import Onyx from 'react-native-onyx'; -import CONST from '../../CONST'; -import * as API from '../API'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ErrorUtils from '../ErrorUtils'; -import * as PlaidDataProps from '../../pages/ReimbursementAccount/plaidDataPropTypes'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; +import * as API from '@libs/API'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PlaidDataProps from '@pages/ReimbursementAccount/plaidDataPropTypes'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import type PlaidBankAccount from '@src/types/onyx/PlaidBankAccount'; +import type {BankAccountStep, BankAccountSubStep} from '@src/types/onyx/ReimbursementAccount'; +import type {ACHContractStepProps, BankAccountStepProps, CompanyStepProps, OnfidoData, ReimbursementAccountProps, RequestorStepProps} from '@src/types/onyx/ReimbursementAccountDraft'; +import type {OnyxData} from '@src/types/onyx/Request'; import * as ReimbursementAccount from './ReimbursementAccount'; -import type PlaidBankAccount from '../../types/onyx/PlaidBankAccount'; -import type {ACHContractStepProps, BankAccountStepProps, CompanyStepProps, OnfidoData, ReimbursementAccountProps, RequestorStepProps} from '../../types/onyx/ReimbursementAccountDraft'; -import type {OnyxData} from '../../types/onyx/Request'; -import type {BankAccountStep, BankAccountSubStep} from '../../types/onyx/ReimbursementAccount'; export { goToWithdrawalAccountSetupStep, diff --git a/src/libs/actions/CanvasSize.js b/src/libs/actions/CanvasSize.js index 0c4cd88fea70..b313763131b9 100644 --- a/src/libs/actions/CanvasSize.js +++ b/src/libs/actions/CanvasSize.js @@ -1,7 +1,7 @@ -import Onyx from 'react-native-onyx'; import canvasSize from 'canvas-size'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Browser from '../Browser'; +import Onyx from 'react-native-onyx'; +import * as Browser from '@libs/Browser'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Calculate the max area of canvas on this specific platform and save it in onyx diff --git a/src/libs/actions/Card.js b/src/libs/actions/Card.js index 97c902876a3a..126608cf1b47 100644 --- a/src/libs/actions/Card.js +++ b/src/libs/actions/Card.js @@ -1,7 +1,8 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import CONST from '../../CONST'; +import * as API from '@libs/API'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; + /** * @param {Number} cardID */ diff --git a/src/libs/actions/Chronos.ts b/src/libs/actions/Chronos.ts index ce821e524722..76308f225fe4 100644 --- a/src/libs/actions/Chronos.ts +++ b/src/libs/actions/Chronos.ts @@ -1,8 +1,8 @@ import Onyx, {OnyxUpdate} from 'react-native-onyx'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import {ChronosOOOEvent} from '../../types/onyx/OriginalMessage'; +import * as API from '@libs/API'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {ChronosOOOEvent} from '@src/types/onyx/OriginalMessage'; const removeEvent = (reportID: string, reportActionID: string, eventID: string, events: ChronosOOOEvent[]) => { const optimisticData: OnyxUpdate[] = [ diff --git a/src/libs/actions/CloseAccount.ts b/src/libs/actions/CloseAccount.ts index 8a8f395277e1..01b115a23518 100644 --- a/src/libs/actions/CloseAccount.ts +++ b/src/libs/actions/CloseAccount.ts @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Clear CloseAccount error message to hide modal diff --git a/src/libs/actions/Composer.ts b/src/libs/actions/Composer.ts index d3f9ef9814a5..edd42fb801f2 100644 --- a/src/libs/actions/Composer.ts +++ b/src/libs/actions/Composer.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; function setShouldShowComposeInput(shouldShowComposeInput: boolean) { Onyx.set(ONYXKEYS.SHOULD_SHOW_COMPOSE_INPUT, shouldShowComposeInput); diff --git a/src/libs/actions/CurrentDate.ts b/src/libs/actions/CurrentDate.ts index b19a3430e96f..4a382156012b 100644 --- a/src/libs/actions/CurrentDate.ts +++ b/src/libs/actions/CurrentDate.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; function setCurrentDate(currentDate: string) { Onyx.set(ONYXKEYS.CURRENT_DATE, currentDate); diff --git a/src/libs/actions/DemoActions.js b/src/libs/actions/DemoActions.js index e7ce02d2796b..245e475e7ca9 100644 --- a/src/libs/actions/DemoActions.js +++ b/src/libs/actions/DemoActions.js @@ -1,11 +1,11 @@ +import lodashGet from 'lodash/get'; import Config from 'react-native-config'; import Onyx from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import * as API from '../API'; -import * as ReportUtils from '../ReportUtils'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import ONYXKEYS from '../../ONYXKEYS'; +import * as API from '@libs/API'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; let currentUserEmail; Onyx.connect({ diff --git a/src/libs/actions/Device/generateDeviceID/index.android.js b/src/libs/actions/Device/generateDeviceID/index.android.js index f61b860bda7d..41fc946839b7 100644 --- a/src/libs/actions/Device/generateDeviceID/index.android.js +++ b/src/libs/actions/Device/generateDeviceID/index.android.js @@ -1,5 +1,5 @@ -import DeviceInfo from 'react-native-device-info'; import Str from 'expensify-common/lib/str'; +import DeviceInfo from 'react-native-device-info'; const deviceID = DeviceInfo.getDeviceId(); const uniqueID = Str.guid(deviceID); diff --git a/src/libs/actions/Device/index.js b/src/libs/actions/Device/index.js index 8f548b75bd93..8394bf226b12 100644 --- a/src/libs/actions/Device/index.js +++ b/src/libs/actions/Device/index.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Log from '../../Log'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; import generateDeviceID from './generateDeviceID'; import getDeviceInfo from './getDeviceInfo'; diff --git a/src/libs/actions/Download.ts b/src/libs/actions/Download.ts index 06b97d735d39..6eb3b1f05b4b 100644 --- a/src/libs/actions/Download.ts +++ b/src/libs/actions/Download.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Set whether an attachment is being downloaded so that a spinner can be shown. diff --git a/src/libs/actions/EmojiPickerAction.ts b/src/libs/actions/EmojiPickerAction.ts index edf82eb46da3..07b00a508dad 100644 --- a/src/libs/actions/EmojiPickerAction.ts +++ b/src/libs/actions/EmojiPickerAction.ts @@ -1,7 +1,7 @@ -import {ValueOf} from 'type-fest'; import React from 'react'; import {View} from 'react-native'; -import CONST from '../../CONST'; +import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; type AnchorOrigin = { horizontal: ValueOf; diff --git a/src/libs/actions/IOU.js b/src/libs/actions/IOU.js index 150e210c727c..77ab246506ce 100644 --- a/src/libs/actions/IOU.js +++ b/src/libs/actions/IOU.js @@ -1,29 +1,29 @@ -import Onyx from 'react-native-onyx'; -import _ from 'underscore'; +import {format} from 'date-fns'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; import lodashHas from 'lodash/has'; -import Str from 'expensify-common/lib/str'; -import {format} from 'date-fns'; -import CONST from '../../CONST'; -import ROUTES from '../../ROUTES'; -import ONYXKEYS from '../../ONYXKEYS'; -import Navigation from '../Navigation/Navigation'; -import * as Localize from '../Localize'; -import * as API from '../API'; -import * as ReportUtils from '../ReportUtils'; -import * as CurrencyUtils from '../CurrencyUtils'; -import * as ReportActionsUtils from '../ReportActionsUtils'; -import * as IOUUtils from '../IOUUtils'; -import * as OptionsListUtils from '../OptionsListUtils'; -import DateUtils from '../DateUtils'; -import * as TransactionUtils from '../TransactionUtils'; -import * as ErrorUtils from '../ErrorUtils'; -import * as UserUtils from '../UserUtils'; -import * as Report from './Report'; -import * as NumberUtils from '../NumberUtils'; -import ReceiptGeneric from '../../../assets/images/receipt-generic.png'; -import * as LocalePhoneNumber from '../LocalePhoneNumber'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import ReceiptGeneric from '@assets/images/receipt-generic.png'; +import * as API from '@libs/API'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import DateUtils from '@libs/DateUtils'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as IOUUtils from '@libs/IOUUtils'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import * as Localize from '@libs/Localize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as NumberUtils from '@libs/NumberUtils'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import * as UserUtils from '@libs/UserUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import * as Policy from './Policy'; +import * as Report from './Report'; let allPersonalDetails; Onyx.connect({ diff --git a/src/libs/actions/InputFocus/index.desktop.ts b/src/libs/actions/InputFocus/index.desktop.ts index b6cf1aba6138..86a562f0531e 100644 --- a/src/libs/actions/InputFocus/index.desktop.ts +++ b/src/libs/actions/InputFocus/index.desktop.ts @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import ReportActionComposeFocusManager from '../../ReportActionComposeFocusManager'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import ONYXKEYS from '@src/ONYXKEYS'; function inputFocusChange(focus: boolean) { Onyx.set(ONYXKEYS.INPUT_FOCUSED, focus); diff --git a/src/libs/actions/InputFocus/index.website.ts b/src/libs/actions/InputFocus/index.website.ts index 7c044b169a03..8e41e06d7401 100644 --- a/src/libs/actions/InputFocus/index.website.ts +++ b/src/libs/actions/InputFocus/index.website.ts @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as Browser from '../../Browser'; -import ReportActionComposeFocusManager from '../../ReportActionComposeFocusManager'; +import * as Browser from '@libs/Browser'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import ONYXKEYS from '@src/ONYXKEYS'; function inputFocusChange(focus: boolean) { Onyx.set(ONYXKEYS.INPUT_FOCUSED, focus); diff --git a/src/libs/actions/Link.js b/src/libs/actions/Link.js index 06705182a626..0a50bb62ddc8 100644 --- a/src/libs/actions/Link.js +++ b/src/libs/actions/Link.js @@ -1,11 +1,11 @@ -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; -import asyncOpenURL from '../asyncOpenURL'; -import * as API from '../API'; -import * as Environment from '../Environment/Environment'; -import * as Url from '../Url'; +import * as API from '@libs/API'; +import asyncOpenURL from '@libs/asyncOpenURL'; +import * as Environment from '@libs/Environment/Environment'; +import * as Url from '@libs/Url'; +import ONYXKEYS from '@src/ONYXKEYS'; let isNetworkOffline = false; Onyx.connect({ diff --git a/src/libs/actions/MapboxToken.ts b/src/libs/actions/MapboxToken.ts index f795adf0df2b..4596e82a9354 100644 --- a/src/libs/actions/MapboxToken.ts +++ b/src/libs/actions/MapboxToken.ts @@ -1,11 +1,11 @@ import {isAfter} from 'date-fns'; -import Onyx from 'react-native-onyx'; import {AppState, NativeEventSubscription} from 'react-native'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import CONST from '../../CONST'; -import * as ActiveClientManager from '../ActiveClientManager'; -import {MapboxAccessToken, Network} from '../../types/onyx'; +import Onyx from 'react-native-onyx'; +import * as ActiveClientManager from '@libs/ActiveClientManager'; +import * as API from '@libs/API'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {MapboxAccessToken, Network} from '@src/types/onyx'; let authToken: string | null; Onyx.connect({ diff --git a/src/libs/actions/MemoryOnlyKeys/MemoryOnlyKeys.js b/src/libs/actions/MemoryOnlyKeys/MemoryOnlyKeys.js index d46222189804..028bce225909 100644 --- a/src/libs/actions/MemoryOnlyKeys/MemoryOnlyKeys.js +++ b/src/libs/actions/MemoryOnlyKeys/MemoryOnlyKeys.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Log from '../../Log'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; const memoryOnlyKeys = [ONYXKEYS.COLLECTION.REPORT, ONYXKEYS.COLLECTION.POLICY, ONYXKEYS.PERSONAL_DETAILS_LIST]; diff --git a/src/libs/actions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods/index.js b/src/libs/actions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods/index.js index fa62268753db..1d039c8980a9 100644 --- a/src/libs/actions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods/index.js +++ b/src/libs/actions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods/index.js @@ -1,4 +1,4 @@ -import * as MemoryOnlyKeys from '../MemoryOnlyKeys'; +import * as MemoryOnlyKeys from '@userActions/MemoryOnlyKeys/MemoryOnlyKeys'; const exposeGlobalMemoryOnlyKeysMethods = () => { window.enableMemoryOnlyKeys = () => { diff --git a/src/libs/actions/Modal.ts b/src/libs/actions/Modal.ts index ff09731f59a7..5114d5c1f42f 100644 --- a/src/libs/actions/Modal.ts +++ b/src/libs/actions/Modal.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; let closeModal: (isNavigating: boolean) => void; let onModalClose: null | (() => void); diff --git a/src/libs/actions/Network.ts b/src/libs/actions/Network.ts index 212e44f6782d..17580c214376 100644 --- a/src/libs/actions/Network.ts +++ b/src/libs/actions/Network.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; function setIsOffline(isOffline: boolean) { Onyx.merge(ONYXKEYS.NETWORK, {isOffline}); diff --git a/src/libs/actions/OnyxUpdateManager.js b/src/libs/actions/OnyxUpdateManager.js index b6318b784439..21cea452295b 100644 --- a/src/libs/actions/OnyxUpdateManager.js +++ b/src/libs/actions/OnyxUpdateManager.js @@ -1,11 +1,11 @@ import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; -import Log from '../Log'; -import * as SequentialQueue from '../Network/SequentialQueue'; +import Log from '@libs/Log'; +import * as SequentialQueue from '@libs/Network/SequentialQueue'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as App from './App'; import * as OnyxUpdates from './OnyxUpdates'; -import CONST from '../../CONST'; // This file is in charge of looking at the updateIDs coming from the server and comparing them to the last updateID that the client has. // If the client is behind the server, then we need to diff --git a/src/libs/actions/OnyxUpdates.ts b/src/libs/actions/OnyxUpdates.ts index 39a20ae9362a..b44b485ac60f 100644 --- a/src/libs/actions/OnyxUpdates.ts +++ b/src/libs/actions/OnyxUpdates.ts @@ -1,11 +1,11 @@ import Onyx, {OnyxEntry} from 'react-native-onyx'; import {Merge} from 'type-fest'; -import PusherUtils from '../PusherUtils'; -import ONYXKEYS from '../../ONYXKEYS'; +import PusherUtils from '@libs/PusherUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {OnyxUpdateEvent, OnyxUpdatesFromServer, Request} from '@src/types/onyx'; +import Response from '@src/types/onyx/Response'; import * as QueuedOnyxUpdates from './QueuedOnyxUpdates'; -import CONST from '../../CONST'; -import {OnyxUpdatesFromServer, OnyxUpdateEvent, Request} from '../../types/onyx'; -import Response from '../../types/onyx/Response'; // This key needs to be separate from ONYXKEYS.ONYX_UPDATES_FROM_SERVER so that it can be updated without triggering the callback when the server IDs are updated. If that // callback were triggered it would lead to duplicate processing of server updates. diff --git a/src/libs/actions/PaymentMethods.ts b/src/libs/actions/PaymentMethods.ts index fe1b5ebe10e9..dc5b7b83aa8e 100644 --- a/src/libs/actions/PaymentMethods.ts +++ b/src/libs/actions/PaymentMethods.ts @@ -1,14 +1,14 @@ import {createRef} from 'react'; import Onyx, {OnyxUpdate} from 'react-native-onyx'; import {ValueOf} from 'type-fest'; -import ONYXKEYS, {OnyxValues} from '../../ONYXKEYS'; -import * as API from '../API'; -import CONST from '../../CONST'; -import Navigation from '../Navigation/Navigation'; -import * as CardUtils from '../CardUtils'; -import ROUTES from '../../ROUTES'; -import {FilterMethodPaymentType} from '../../types/onyx/WalletTransfer'; -import PaymentMethod from '../../types/onyx/PaymentMethod'; +import * as API from '@libs/API'; +import * as CardUtils from '@libs/CardUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import CONST from '@src/CONST'; +import ONYXKEYS, {OnyxValues} from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import PaymentMethod from '@src/types/onyx/PaymentMethod'; +import {FilterMethodPaymentType} from '@src/types/onyx/WalletTransfer'; type KYCWallRef = { continue?: () => void; diff --git a/src/libs/actions/PersistedRequests.ts b/src/libs/actions/PersistedRequests.ts index d9f4ed020109..c35de9ee94c4 100644 --- a/src/libs/actions/PersistedRequests.ts +++ b/src/libs/actions/PersistedRequests.ts @@ -1,7 +1,7 @@ -import Onyx from 'react-native-onyx'; import isEqual from 'lodash/isEqual'; -import ONYXKEYS from '../../ONYXKEYS'; -import {Request} from '../../types/onyx'; +import Onyx from 'react-native-onyx'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {Request} from '@src/types/onyx'; let persistedRequests: Request[] = []; diff --git a/src/libs/actions/PersonalDetails.js b/src/libs/actions/PersonalDetails.js index 69cf05b89b34..351943ca1f29 100644 --- a/src/libs/actions/PersonalDetails.js +++ b/src/libs/actions/PersonalDetails.js @@ -1,14 +1,14 @@ +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; import Onyx from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import * as API from '../API'; -import * as UserUtils from '../UserUtils'; -import * as LocalePhoneNumber from '../LocalePhoneNumber'; -import ROUTES from '../../ROUTES'; -import Navigation from '../Navigation/Navigation'; +import * as API from '@libs/API'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import Navigation from '@libs/Navigation/Navigation'; +import * as UserUtils from '@libs/UserUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; let currentUserEmail = ''; let currentUserAccountID; diff --git a/src/libs/actions/Plaid.ts b/src/libs/actions/Plaid.ts index 410a8c57d176..ab828eefeece 100644 --- a/src/libs/actions/Plaid.ts +++ b/src/libs/actions/Plaid.ts @@ -1,8 +1,8 @@ import Onyx from 'react-native-onyx'; -import getPlaidLinkTokenParameters from '../getPlaidLinkTokenParameters'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import * as PlaidDataProps from '../../pages/ReimbursementAccount/plaidDataPropTypes'; +import * as API from '@libs/API'; +import getPlaidLinkTokenParameters from '@libs/getPlaidLinkTokenParameters'; +import * as PlaidDataProps from '@pages/ReimbursementAccount/plaidDataPropTypes'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Gets the Plaid Link token used to initialize the Plaid SDK diff --git a/src/libs/actions/Policy.js b/src/libs/actions/Policy.js index 3ce0bc0df6ff..67352526baad 100644 --- a/src/libs/actions/Policy.js +++ b/src/libs/actions/Policy.js @@ -1,19 +1,19 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import lodashUnion from 'lodash/union'; import {PUBLIC_DOMAINS} from 'expensify-common/lib/CONST'; import Str from 'expensify-common/lib/str'; import {escapeRegExp} from 'lodash'; -import * as API from '../API'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import * as NumberUtils from '../NumberUtils'; -import * as OptionsListUtils from '../OptionsListUtils'; -import * as ErrorUtils from '../ErrorUtils'; -import * as ReportUtils from '../ReportUtils'; -import * as PersonalDetailsUtils from '../PersonalDetailsUtils'; -import Log from '../Log'; +import lodashGet from 'lodash/get'; +import lodashUnion from 'lodash/union'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import * as API from '@libs/API'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Log from '@libs/Log'; +import * as NumberUtils from '@libs/NumberUtils'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const allPolicies = {}; Onyx.connect({ diff --git a/src/libs/actions/PushNotification.js b/src/libs/actions/PushNotification.js index b9a75767d8f6..7abbd7b94ba0 100644 --- a/src/libs/actions/PushNotification.js +++ b/src/libs/actions/PushNotification.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; +import * as API from '@libs/API'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as Device from './Device'; let isUserOptedInToPushNotifications = false; diff --git a/src/libs/actions/ReimbursementAccount/deleteFromBankAccountList.js b/src/libs/actions/ReimbursementAccount/deleteFromBankAccountList.js index b640d45683ec..6161066c1c69 100644 --- a/src/libs/actions/ReimbursementAccount/deleteFromBankAccountList.js +++ b/src/libs/actions/ReimbursementAccount/deleteFromBankAccountList.js @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as store from './store'; /** diff --git a/src/libs/actions/ReimbursementAccount/errors.js b/src/libs/actions/ReimbursementAccount/errors.js index 54d881cc4516..fd2eaf852bce 100644 --- a/src/libs/actions/ReimbursementAccount/errors.js +++ b/src/libs/actions/ReimbursementAccount/errors.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as ErrorUtils from '../../ErrorUtils'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Set the current fields with errors. diff --git a/src/libs/actions/ReimbursementAccount/index.js b/src/libs/actions/ReimbursementAccount/index.js index 68774d0ba8b0..0404115f086b 100644 --- a/src/libs/actions/ReimbursementAccount/index.js +++ b/src/libs/actions/ReimbursementAccount/index.js @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import resetFreePlanBankAccount from './resetFreePlanBankAccount'; +import ONYXKEYS from '@src/ONYXKEYS'; import deleteFromBankAccountList from './deleteFromBankAccountList'; +import resetFreePlanBankAccount from './resetFreePlanBankAccount'; export {goToWithdrawalAccountSetupStep, navigateToBankAccountRoute} from './navigation'; export {setBankAccountFormValidationErrors, setPersonalBankAccountFormValidationErrorFields, resetReimbursementAccount, showBankAccountFormValidationError} from './errors'; diff --git a/src/libs/actions/ReimbursementAccount/navigation.js b/src/libs/actions/ReimbursementAccount/navigation.js index 1b75e6f16a58..ebc1862e9c74 100644 --- a/src/libs/actions/ReimbursementAccount/navigation.js +++ b/src/libs/actions/ReimbursementAccount/navigation.js @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import ROUTES from '../../../ROUTES'; -import Navigation from '../../Navigation/Navigation'; +import Navigation from '@libs/Navigation/Navigation'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; /** * Navigate to a specific step in the VBA flow diff --git a/src/libs/actions/ReimbursementAccount/resetFreePlanBankAccount.js b/src/libs/actions/ReimbursementAccount/resetFreePlanBankAccount.js index 388010e99569..37122c107359 100644 --- a/src/libs/actions/ReimbursementAccount/resetFreePlanBankAccount.js +++ b/src/libs/actions/ReimbursementAccount/resetFreePlanBankAccount.js @@ -1,9 +1,9 @@ import Onyx from 'react-native-onyx'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as API from '../../API'; -import * as PlaidDataProps from '../../../pages/ReimbursementAccount/plaidDataPropTypes'; -import * as ReimbursementAccountProps from '../../../pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import * as API from '@libs/API'; +import * as PlaidDataProps from '@pages/ReimbursementAccount/plaidDataPropTypes'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Reset user's reimbursement account. This will delete the bank account. diff --git a/src/libs/actions/ReimbursementAccount/store.js b/src/libs/actions/ReimbursementAccount/store.js index 422c0ffc43dd..4b8549b60b2e 100644 --- a/src/libs/actions/ReimbursementAccount/store.js +++ b/src/libs/actions/ReimbursementAccount/store.js @@ -1,8 +1,8 @@ -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../../ONYXKEYS'; -import BankAccount from '../../models/BankAccount'; +import BankAccount from '@libs/models/BankAccount'; +import ONYXKEYS from '@src/ONYXKEYS'; /** Reimbursement account actively being set up */ let reimbursementAccountInSetup = {}; diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 46994079d605..d7c02a8a1388 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1,33 +1,33 @@ -import {InteractionManager} from 'react-native'; -import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import lodashDebounce from 'lodash/debounce'; +import {format as timezoneFormat, utcToZonedTime} from 'date-fns-tz'; import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import Onyx from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; -import {format as timezoneFormat, utcToZonedTime} from 'date-fns-tz'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Pusher from '../Pusher/pusher'; -import LocalNotification from '../Notification/LocalNotification'; -import Navigation from '../Navigation/Navigation'; -import * as ActiveClientManager from '../ActiveClientManager'; -import Visibility from '../Visibility'; -import ROUTES from '../../ROUTES'; -import * as API from '../API'; -import CONFIG from '../../CONFIG'; -import CONST from '../../CONST'; -import Log from '../Log'; -import * as ReportUtils from '../ReportUtils'; -import DateUtils from '../DateUtils'; -import * as ReportActionsUtils from '../ReportActionsUtils'; -import * as CollectionUtils from '../CollectionUtils'; -import * as EmojiUtils from '../EmojiUtils'; -import * as ErrorUtils from '../ErrorUtils'; -import * as UserUtils from '../UserUtils'; -import * as Welcome from './Welcome'; -import * as PersonalDetailsUtils from '../PersonalDetailsUtils'; -import * as Environment from '../Environment/Environment'; +import lodashDebounce from 'lodash/debounce'; +import lodashGet from 'lodash/get'; +import {InteractionManager} from 'react-native'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import * as ActiveClientManager from '@libs/ActiveClientManager'; +import * as API from '@libs/API'; +import * as CollectionUtils from '@libs/CollectionUtils'; +import DateUtils from '@libs/DateUtils'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import * as Environment from '@libs/Environment/Environment'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import LocalNotification from '@libs/Notification/LocalNotification'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import * as Pusher from '@libs/Pusher/pusher'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import Visibility from '@libs/Visibility'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import * as Session from './Session'; +import * as Welcome from './Welcome'; let currentUserAccountID; Onyx.connect({ diff --git a/src/libs/actions/ReportActions.ts b/src/libs/actions/ReportActions.ts index 3faa1dbe3574..b9cea498a3fa 100644 --- a/src/libs/actions/ReportActions.ts +++ b/src/libs/actions/ReportActions.ts @@ -1,9 +1,9 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import * as ReportActionUtils from '../ReportActionsUtils'; -import * as ReportUtils from '../ReportUtils'; -import ReportAction from '../../types/onyx/ReportAction'; +import * as ReportActionUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ReportAction from '@src/types/onyx/ReportAction'; function clearReportActionErrors(reportID: string, reportAction: ReportAction) { const originalReportID = ReportUtils.getOriginalReportID(reportID, reportAction); diff --git a/src/libs/actions/Session/index.ts b/src/libs/actions/Session/index.ts index 7015fa44da3a..74d2f609ab9b 100644 --- a/src/libs/actions/Session/index.ts +++ b/src/libs/actions/Session/index.ts @@ -1,30 +1,30 @@ -import Onyx, {OnyxUpdate} from 'react-native-onyx'; -import {Linking} from 'react-native'; -import {ValueOf} from 'type-fest'; import throttle from 'lodash/throttle'; -import {ChannelAuthorizationCallback} from 'pusher-js/with-encryption'; import {ChannelAuthorizationData} from 'pusher-js/types/src/core/auth/options'; +import {ChannelAuthorizationCallback} from 'pusher-js/with-encryption'; +import {Linking} from 'react-native'; +import Onyx, {OnyxUpdate} from 'react-native-onyx'; +import {ValueOf} from 'type-fest'; +import * as API from '@libs/API'; +import * as Authentication from '@libs/Authentication'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import * as NetworkStore from '@libs/Network/NetworkStore'; +import * as Pusher from '@libs/Pusher/pusher'; +import * as ReportUtils from '@libs/ReportUtils'; +import Timers from '@libs/Timers'; +import {hideContextMenu} from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import * as Device from '@userActions/Device'; +import redirectToSignIn from '@userActions/SignInRedirect'; +import Timing from '@userActions/Timing'; +import * as Welcome from '@userActions/Welcome'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import Credentials from '@src/types/onyx/Credentials'; +import {AutoAuthState} from '@src/types/onyx/Session'; import clearCache from './clearCache'; -import ONYXKEYS from '../../../ONYXKEYS'; -import redirectToSignIn from '../SignInRedirect'; -import CONFIG from '../../../CONFIG'; -import Log from '../../Log'; -import Timing from '../Timing'; -import CONST from '../../../CONST'; -import Timers from '../../Timers'; -import * as Pusher from '../../Pusher/pusher'; -import * as Authentication from '../../Authentication'; -import * as Welcome from '../Welcome'; -import * as API from '../../API'; -import * as NetworkStore from '../../Network/NetworkStore'; -import Navigation from '../../Navigation/Navigation'; -import * as Device from '../Device'; -import ROUTES from '../../../ROUTES'; -import * as ErrorUtils from '../../ErrorUtils'; -import * as ReportUtils from '../../ReportUtils'; -import {hideContextMenu} from '../../../pages/home/report/ContextMenu/ReportActionContextMenu'; -import Credentials from '../../../types/onyx/Credentials'; -import {AutoAuthState} from '../../../types/onyx/Session'; let sessionAuthTokenType: string | null = ''; let sessionAuthToken: string | null = null; diff --git a/src/libs/actions/Session/updateSessionAuthTokens.ts b/src/libs/actions/Session/updateSessionAuthTokens.ts index 9614face2070..6f90b60ef06d 100644 --- a/src/libs/actions/Session/updateSessionAuthTokens.ts +++ b/src/libs/actions/Session/updateSessionAuthTokens.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; export default function updateSessionAuthTokens(authToken?: string, encryptedAuthToken?: string) { Onyx.merge(ONYXKEYS.SESSION, {authToken, encryptedAuthToken}); diff --git a/src/libs/actions/SignInRedirect.ts b/src/libs/actions/SignInRedirect.ts index 67f5f2d8586f..9ca4e6813567 100644 --- a/src/libs/actions/SignInRedirect.ts +++ b/src/libs/actions/SignInRedirect.ts @@ -1,14 +1,14 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS, {OnyxKey} from '../../ONYXKEYS'; -import * as MainQueue from '../Network/MainQueue'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import HttpUtils from '@libs/HttpUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import navigationRef from '@libs/Navigation/navigationRef'; +import * as MainQueue from '@libs/Network/MainQueue'; +import NetworkConnection from '@libs/NetworkConnection'; +import * as SessionUtils from '@libs/SessionUtils'; +import ONYXKEYS, {OnyxKey} from '@src/ONYXKEYS'; +import SCREENS from '@src/SCREENS'; import * as PersistedRequests from './PersistedRequests'; -import NetworkConnection from '../NetworkConnection'; -import HttpUtils from '../HttpUtils'; -import navigationRef from '../Navigation/navigationRef'; -import SCREENS from '../../SCREENS'; -import Navigation from '../Navigation/Navigation'; -import * as ErrorUtils from '../ErrorUtils'; -import * as SessionUtils from '../SessionUtils'; let currentIsOffline: boolean | undefined; let currentShouldForceOffline: boolean | undefined; diff --git a/src/libs/actions/Tab.ts b/src/libs/actions/Tab.ts index 7acd978d6b1a..a210cef36c73 100644 --- a/src/libs/actions/Tab.ts +++ b/src/libs/actions/Tab.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Sets the selected tab for a given tab ID diff --git a/src/libs/actions/Task.js b/src/libs/actions/Task.js index cc2b58f78b75..76396b1f31b8 100644 --- a/src/libs/actions/Task.js +++ b/src/libs/actions/Task.js @@ -1,20 +1,20 @@ -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import * as ReportUtils from '../ReportUtils'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import CONST from '../../CONST'; -import DateUtils from '../DateUtils'; -import * as OptionsListUtils from '../OptionsListUtils'; -import * as UserUtils from '../UserUtils'; -import * as ErrorUtils from '../ErrorUtils'; -import * as ReportActionsUtils from '../ReportActionsUtils'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import * as LocalePhoneNumber from '../LocalePhoneNumber'; -import * as Localize from '../Localize'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as API from '@libs/API'; +import DateUtils from '@libs/DateUtils'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import * as Localize from '@libs/Localize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; let currentUserEmail; let currentUserAccountID; diff --git a/src/libs/actions/TeachersUnite.js b/src/libs/actions/TeachersUnite.js index 39b9de8c6478..98b1f82629a4 100644 --- a/src/libs/actions/TeachersUnite.js +++ b/src/libs/actions/TeachersUnite.js @@ -1,12 +1,12 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import Navigation from '../Navigation/Navigation'; -import CONST from '../../CONST'; -import * as ReportUtils from '../ReportUtils'; -import * as OptionsListUtils from '../OptionsListUtils'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import * as API from '@libs/API'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; let sessionEmail = ''; let sessionAccountID = 0; diff --git a/src/libs/actions/TestTool.ts b/src/libs/actions/TestTool.ts index 11de9498b7b0..dc7b371bfe12 100644 --- a/src/libs/actions/TestTool.ts +++ b/src/libs/actions/TestTool.ts @@ -1,7 +1,7 @@ import throttle from 'lodash/throttle'; import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; let isTestToolsModalOpen = false; Onyx.connect({ diff --git a/src/libs/actions/Timing.ts b/src/libs/actions/Timing.ts index 13f40bab87c9..0cef2fe4d2b8 100644 --- a/src/libs/actions/Timing.ts +++ b/src/libs/actions/Timing.ts @@ -1,8 +1,8 @@ -import getPlatform from '../getPlatform'; -import * as Environment from '../Environment/Environment'; -import Firebase from '../Firebase'; -import * as API from '../API'; -import Log from '../Log'; +import * as API from '@libs/API'; +import * as Environment from '@libs/Environment/Environment'; +import Firebase from '@libs/Firebase'; +import getPlatform from '@libs/getPlatform'; +import Log from '@libs/Log'; type TimestampData = { startTime: number; diff --git a/src/libs/actions/Transaction.ts b/src/libs/actions/Transaction.ts index 8a7f0f7bd533..a649267c0ae9 100644 --- a/src/libs/actions/Transaction.ts +++ b/src/libs/actions/Transaction.ts @@ -1,14 +1,14 @@ -import Onyx from 'react-native-onyx'; -import lodashHas from 'lodash/has'; -import lodashClone from 'lodash/clone'; import {isEqual} from 'lodash'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as CollectionUtils from '../CollectionUtils'; -import * as API from '../API'; -import CONST from '../../CONST'; -import {RecentWaypoint, Transaction} from '../../types/onyx'; -import {WaypointCollection} from '../../types/onyx/Transaction'; -import * as TransactionUtils from '../TransactionUtils'; +import lodashClone from 'lodash/clone'; +import lodashHas from 'lodash/has'; +import Onyx from 'react-native-onyx'; +import * as API from '@libs/API'; +import * as CollectionUtils from '@libs/CollectionUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {RecentWaypoint, Transaction} from '@src/types/onyx'; +import {WaypointCollection} from '@src/types/onyx/Transaction'; let recentWaypoints: RecentWaypoint[] = []; Onyx.connect({ diff --git a/src/libs/actions/TransactionEdit.js b/src/libs/actions/TransactionEdit.js index 44b489b72c43..78a271f0f8cd 100644 --- a/src/libs/actions/TransactionEdit.js +++ b/src/libs/actions/TransactionEdit.js @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Makes a backup copy of a transaction object that can be restored when the user cancels editing a transaction. diff --git a/src/libs/actions/TwoFactorAuthActions.ts b/src/libs/actions/TwoFactorAuthActions.ts index 0cec7d3c16c8..ccd4e2baf662 100644 --- a/src/libs/actions/TwoFactorAuthActions.ts +++ b/src/libs/actions/TwoFactorAuthActions.ts @@ -1,8 +1,8 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import {TwoFactorAuthStep} from '../../types/onyx/Account'; +import Navigation from '@libs/Navigation/Navigation'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {TwoFactorAuthStep} from '@src/types/onyx/Account'; /** * Clear 2FA data if the flow is interrupted without finishing diff --git a/src/libs/actions/User.js b/src/libs/actions/User.js index f65c20cd7e5b..f7375a5583a6 100644 --- a/src/libs/actions/User.js +++ b/src/libs/actions/User.js @@ -1,22 +1,22 @@ -import _ from 'underscore'; +import {isBefore} from 'date-fns'; import lodashGet from 'lodash/get'; import Onyx from 'react-native-onyx'; -import {isBefore} from 'date-fns'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; -import CONST from '../../CONST'; -import Navigation from '../Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as Pusher from '../Pusher/pusher'; +import _ from 'underscore'; +import * as API from '@libs/API'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as SequentialQueue from '@libs/Network/SequentialQueue'; +import * as Pusher from '@libs/Pusher/pusher'; +import PusherUtils from '@libs/PusherUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import * as Link from './Link'; -import * as SequentialQueue from '../Network/SequentialQueue'; -import PusherUtils from '../PusherUtils'; +import * as OnyxUpdates from './OnyxUpdates'; +import * as PersonalDetails from './PersonalDetails'; import * as Report from './Report'; -import * as ReportActionsUtils from '../ReportActionsUtils'; -import * as ErrorUtils from '../ErrorUtils'; import * as Session from './Session'; -import * as PersonalDetails from './PersonalDetails'; -import * as OnyxUpdates from './OnyxUpdates'; import redirectToSignIn from './SignInRedirect'; let currentUserAccountID = ''; diff --git a/src/libs/actions/Wallet.js b/src/libs/actions/Wallet.js index 9ef4b547d4b4..bfc2a7306434 100644 --- a/src/libs/actions/Wallet.js +++ b/src/libs/actions/Wallet.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as API from '../API'; +import * as API from '@libs/API'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * Fetch and save locally the Onfido SDK token and applicantID diff --git a/src/libs/actions/Welcome.ts b/src/libs/actions/Welcome.ts index 29e0088ed689..7fd7adeafa96 100644 --- a/src/libs/actions/Welcome.ts +++ b/src/libs/actions/Welcome.ts @@ -1,13 +1,13 @@ import Onyx, {OnyxCollection} from 'react-native-onyx'; -import Navigation from '../Navigation/Navigation'; -import * as ReportUtils from '../ReportUtils'; -import ROUTES from '../../ROUTES'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; +import OnyxPolicy from '@src/types/onyx/Policy'; +import Report from '@src/types/onyx/Report'; import * as Policy from './Policy'; -import ONYXKEYS from '../../ONYXKEYS'; -import SCREENS from '../../SCREENS'; -import CONST from '../../CONST'; -import Report from '../../types/onyx/Report'; -import OnyxPolicy from '../../types/onyx/Policy'; let resolveIsReadyPromise: (value?: Promise) => void | undefined; let isReadyPromise = new Promise((resolve) => { diff --git a/src/libs/addEncryptedAuthTokenToURL.ts b/src/libs/addEncryptedAuthTokenToURL.ts index 9bdb83c284ce..ea6f0bc6d34d 100644 --- a/src/libs/addEncryptedAuthTokenToURL.ts +++ b/src/libs/addEncryptedAuthTokenToURL.ts @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; let encryptedAuthToken = ''; Onyx.connect({ diff --git a/src/libs/calculateAnchorPosition.ts b/src/libs/calculateAnchorPosition.ts index 39fb3032ee09..8db4c053aba6 100644 --- a/src/libs/calculateAnchorPosition.ts +++ b/src/libs/calculateAnchorPosition.ts @@ -1,7 +1,7 @@ /* eslint-disable no-console */ -import {ValueOf} from 'type-fest'; import {View} from 'react-native'; -import CONST from '../CONST'; +import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; type AnchorOrigin = { horizontal: ValueOf; diff --git a/src/libs/canFocusInputOnScreenFocus/index.ts b/src/libs/canFocusInputOnScreenFocus/index.ts index be500074d7e3..57baac02245d 100644 --- a/src/libs/canFocusInputOnScreenFocus/index.ts +++ b/src/libs/canFocusInputOnScreenFocus/index.ts @@ -1,4 +1,4 @@ -import * as DeviceCapabilities from '../DeviceCapabilities'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; import CanFocusInputOnScreenFocus from './types'; const canFocusInputOnScreenFocus: CanFocusInputOnScreenFocus = () => !DeviceCapabilities.canUseTouchScreen(); diff --git a/src/libs/convertToLTR/index.android.ts b/src/libs/convertToLTR/index.android.ts index 3a4755b1710f..d73fd3de7a21 100644 --- a/src/libs/convertToLTR/index.android.ts +++ b/src/libs/convertToLTR/index.android.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import ConvertToLTR from './types'; /** diff --git a/src/libs/convertToLTRForComposer/index.ts b/src/libs/convertToLTRForComposer/index.ts index 79c1eaed59a5..37015a755869 100644 --- a/src/libs/convertToLTRForComposer/index.ts +++ b/src/libs/convertToLTRForComposer/index.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import ConvertToLTRForComposer from './types'; function hasRTLCharacters(text: string): boolean { diff --git a/src/libs/fileDownload/FileUtils.js b/src/libs/fileDownload/FileUtils.js index ba06b80f7c43..fab014de302f 100644 --- a/src/libs/fileDownload/FileUtils.js +++ b/src/libs/fileDownload/FileUtils.js @@ -1,7 +1,7 @@ import {Alert, Linking, Platform} from 'react-native'; -import CONST from '../../CONST'; -import * as Localize from '../Localize'; -import DateUtils from '../DateUtils'; +import DateUtils from '@libs/DateUtils'; +import * as Localize from '@libs/Localize'; +import CONST from '@src/CONST'; /** * Show alert on successful attachment download diff --git a/src/libs/fileDownload/getAttachmentDetails.js b/src/libs/fileDownload/getAttachmentDetails.js index 72cbad115681..28b678ffb651 100644 --- a/src/libs/fileDownload/getAttachmentDetails.js +++ b/src/libs/fileDownload/getAttachmentDetails.js @@ -1,5 +1,5 @@ -import CONST from '../../CONST'; -import tryResolveUrlFromApiRoot from '../tryResolveUrlFromApiRoot'; +import tryResolveUrlFromApiRoot from '@libs/tryResolveUrlFromApiRoot'; +import CONST from '@src/CONST'; /** * Extract the thumbnail URL, source URL and the original filename from the HTML. diff --git a/src/libs/fileDownload/index.ios.js b/src/libs/fileDownload/index.ios.js index 95d92f1e3103..1599e919d28a 100644 --- a/src/libs/fileDownload/index.ios.js +++ b/src/libs/fileDownload/index.ios.js @@ -1,8 +1,8 @@ -import RNFetchBlob from 'react-native-blob-util'; import {CameraRoll} from '@react-native-camera-roll/camera-roll'; import lodashGet from 'lodash/get'; +import RNFetchBlob from 'react-native-blob-util'; +import CONST from '@src/CONST'; import * as FileUtils from './FileUtils'; -import CONST from '../../CONST'; /** * Downloads the file to Documents section in iOS diff --git a/src/libs/fileDownload/index.js b/src/libs/fileDownload/index.js index a775576eb365..0b86daf7141f 100644 --- a/src/libs/fileDownload/index.js +++ b/src/libs/fileDownload/index.js @@ -1,5 +1,5 @@ +import * as Link from '@userActions/Link'; import * as FileUtils from './FileUtils'; -import * as Link from '../actions/Link'; /** * Downloading attachment in web, desktop diff --git a/src/libs/focusAndUpdateMultilineInputRange.ts b/src/libs/focusAndUpdateMultilineInputRange.ts index 50c3703239df..92da790e383f 100644 --- a/src/libs/focusAndUpdateMultilineInputRange.ts +++ b/src/libs/focusAndUpdateMultilineInputRange.ts @@ -1,4 +1,5 @@ import {TextInput} from 'react-native'; + /** * Focus a multiline text input and place the cursor at the end of the value (if there is a value in the input). * diff --git a/src/libs/getButtonState.ts b/src/libs/getButtonState.ts index af7c4db6b4ec..6b89e1b7d383 100644 --- a/src/libs/getButtonState.ts +++ b/src/libs/getButtonState.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; type GetButtonState = (isActive: boolean, isPressed: boolean, isComplete: boolean, isDisabled: boolean, isInteractive: boolean) => ValueOf; diff --git a/src/libs/getModalState.js b/src/libs/getModalState.js index 12023a5bdc42..30ff8499809a 100644 --- a/src/libs/getModalState.js +++ b/src/libs/getModalState.js @@ -1,5 +1,5 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; +import ONYXKEYS from '@src/ONYXKEYS'; let modalState = {}; diff --git a/src/libs/getOperatingSystem/index.native.ts b/src/libs/getOperatingSystem/index.native.ts index 38b87f4983b7..f3e856cb14c9 100644 --- a/src/libs/getOperatingSystem/index.native.ts +++ b/src/libs/getOperatingSystem/index.native.ts @@ -1,5 +1,5 @@ import {Platform} from 'react-native'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import GetOperatingSystem from './types'; /** diff --git a/src/libs/getOperatingSystem/index.ts b/src/libs/getOperatingSystem/index.ts index 7adfa27c45fc..630595d97471 100644 --- a/src/libs/getOperatingSystem/index.ts +++ b/src/libs/getOperatingSystem/index.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import GetOperatingSystem from './types'; /** diff --git a/src/libs/getOperatingSystem/types.ts b/src/libs/getOperatingSystem/types.ts index 64bb103db083..a4b3046b4cd9 100644 --- a/src/libs/getOperatingSystem/types.ts +++ b/src/libs/getOperatingSystem/types.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; type OS = ValueOf | null; type GetOperatingSystem = () => OS; diff --git a/src/libs/getPermittedDecimalSeparator/index.js b/src/libs/getPermittedDecimalSeparator/index.js index 9ac4156bc3ff..03fa644fc327 100644 --- a/src/libs/getPermittedDecimalSeparator/index.js +++ b/src/libs/getPermittedDecimalSeparator/index.js @@ -1,6 +1,6 @@ -import getOperatingSystem from '../getOperatingSystem'; +import getOperatingSystem from '@libs/getOperatingSystem'; +import CONST from '@src/CONST'; import getPermittedDecimalSeparatorIOS from './index.ios'; -import CONST from '../../CONST'; export default (localizedSeparator) => { if (getOperatingSystem() === CONST.OS.IOS) { diff --git a/src/libs/getPlaidLinkTokenParameters/index.android.ts b/src/libs/getPlaidLinkTokenParameters/index.android.ts index 39d444abdba2..c7e2aa8efd1e 100644 --- a/src/libs/getPlaidLinkTokenParameters/index.android.ts +++ b/src/libs/getPlaidLinkTokenParameters/index.android.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import GetPlaidLinkTokenParameters from './types'; const getPlaidLinkTokenParameters: GetPlaidLinkTokenParameters = () => ({ diff --git a/src/libs/getPlaidLinkTokenParameters/index.ios.ts b/src/libs/getPlaidLinkTokenParameters/index.ios.ts index 330efad4839a..8c69ddc71bb2 100644 --- a/src/libs/getPlaidLinkTokenParameters/index.ios.ts +++ b/src/libs/getPlaidLinkTokenParameters/index.ios.ts @@ -1,4 +1,4 @@ -import CONFIG from '../../CONFIG'; +import CONFIG from '@src/CONFIG'; import GetPlaidLinkTokenParameters from './types'; const getPlaidLinkTokenParameters: GetPlaidLinkTokenParameters = () => ({ diff --git a/src/libs/getPlaidLinkTokenParameters/index.ts b/src/libs/getPlaidLinkTokenParameters/index.ts index e47629e85d09..570951e3d683 100644 --- a/src/libs/getPlaidLinkTokenParameters/index.ts +++ b/src/libs/getPlaidLinkTokenParameters/index.ts @@ -1,5 +1,5 @@ -import ROUTES from '../../ROUTES'; -import CONFIG from '../../CONFIG'; +import CONFIG from '@src/CONFIG'; +import ROUTES from '@src/ROUTES'; import GetPlaidLinkTokenParameters from './types'; const getPlaidLinkTokenParameters: GetPlaidLinkTokenParameters = () => { diff --git a/src/libs/getPlatform/index.android.ts b/src/libs/getPlatform/index.android.ts index 14ed65ace19d..a0f4edb055af 100644 --- a/src/libs/getPlatform/index.android.ts +++ b/src/libs/getPlatform/index.android.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import Platform from './types'; export default function getPlatform(): Platform { diff --git a/src/libs/getPlatform/index.desktop.ts b/src/libs/getPlatform/index.desktop.ts index c9f5720c541d..0b90b5f121bb 100644 --- a/src/libs/getPlatform/index.desktop.ts +++ b/src/libs/getPlatform/index.desktop.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import Platform from './types'; export default function getPlatform(): Platform { diff --git a/src/libs/getPlatform/index.ios.ts b/src/libs/getPlatform/index.ios.ts index 8c21189b92e7..ee35c8b610bc 100644 --- a/src/libs/getPlatform/index.ios.ts +++ b/src/libs/getPlatform/index.ios.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import Platform from './types'; export default function getPlatform(): Platform { diff --git a/src/libs/getPlatform/index.ts b/src/libs/getPlatform/index.ts index c53963f5b80f..ca87e79170f5 100644 --- a/src/libs/getPlatform/index.ts +++ b/src/libs/getPlatform/index.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import Platform from './types'; export default function getPlatform(): Platform { diff --git a/src/libs/getPlatform/types.ts b/src/libs/getPlatform/types.ts index ceddb4e17224..9c43c696a6f8 100644 --- a/src/libs/getPlatform/types.ts +++ b/src/libs/getPlatform/types.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; type Platform = ValueOf; diff --git a/src/libs/getSecureEntryKeyboardType/index.android.ts b/src/libs/getSecureEntryKeyboardType/index.android.ts index afd808f35b10..bc50e202381b 100644 --- a/src/libs/getSecureEntryKeyboardType/index.android.ts +++ b/src/libs/getSecureEntryKeyboardType/index.android.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import GetSecureEntryKeyboardType from './types'; /** diff --git a/src/libs/isReportMessageAttachment.ts b/src/libs/isReportMessageAttachment.ts index 8d1112261d1f..097f46465dc9 100644 --- a/src/libs/isReportMessageAttachment.ts +++ b/src/libs/isReportMessageAttachment.ts @@ -1,5 +1,5 @@ -import CONST from '../CONST'; -import {Message} from '../types/onyx/ReportAction'; +import CONST from '@src/CONST'; +import {Message} from '@src/types/onyx/ReportAction'; /** * Check whether a report action is Attachment or not. diff --git a/src/libs/localFileDownload/index.android.ts b/src/libs/localFileDownload/index.android.ts index ad13b5c5cfa7..4de6cbd0e940 100644 --- a/src/libs/localFileDownload/index.android.ts +++ b/src/libs/localFileDownload/index.android.ts @@ -1,5 +1,5 @@ import RNFetchBlob from 'react-native-blob-util'; -import * as FileUtils from '../fileDownload/FileUtils'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; import LocalFileDownload from './types'; /** diff --git a/src/libs/localFileDownload/index.ios.ts b/src/libs/localFileDownload/index.ios.ts index 3597ea5f6d3c..5461c6ffc4c4 100644 --- a/src/libs/localFileDownload/index.ios.ts +++ b/src/libs/localFileDownload/index.ios.ts @@ -1,6 +1,6 @@ import {Share} from 'react-native'; import RNFetchBlob from 'react-native-blob-util'; -import * as FileUtils from '../fileDownload/FileUtils'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; import LocalFileDownload from './types'; /** diff --git a/src/libs/localFileDownload/index.ts b/src/libs/localFileDownload/index.ts index 7b9b4973d5c1..2a70a01f88c0 100644 --- a/src/libs/localFileDownload/index.ts +++ b/src/libs/localFileDownload/index.ts @@ -1,4 +1,4 @@ -import * as FileUtils from '../fileDownload/FileUtils'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; import LocalFileDownload from './types'; /** diff --git a/src/libs/migrateOnyx.js b/src/libs/migrateOnyx.js index 2ac9f0d92d91..b65670819418 100644 --- a/src/libs/migrateOnyx.js +++ b/src/libs/migrateOnyx.js @@ -1,8 +1,8 @@ import _ from 'underscore'; import Log from './Log'; +import KeyReportActionsDraftByReportActionID from './migrations/KeyReportActionsDraftByReportActionID'; import PersonalDetailsByAccountID from './migrations/PersonalDetailsByAccountID'; import RenameReceiptFilename from './migrations/RenameReceiptFilename'; -import KeyReportActionsDraftByReportActionID from './migrations/KeyReportActionsDraftByReportActionID'; export default function () { const startTime = Date.now(); diff --git a/src/libs/migrations/CheckForPreviousReportActionID.js b/src/libs/migrations/CheckForPreviousReportActionID.js index a61d9bfb08ec..35f862fd5b3a 100644 --- a/src/libs/migrations/CheckForPreviousReportActionID.js +++ b/src/libs/migrations/CheckForPreviousReportActionID.js @@ -1,7 +1,7 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; -import Log from '../Log'; -import ONYXKEYS from '../../ONYXKEYS'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * @returns {Promise} diff --git a/src/libs/migrations/KeyReportActionsDraftByReportActionID.js b/src/libs/migrations/KeyReportActionsDraftByReportActionID.js index 63282b8743dc..e4b3ebd060f3 100644 --- a/src/libs/migrations/KeyReportActionsDraftByReportActionID.js +++ b/src/libs/migrations/KeyReportActionsDraftByReportActionID.js @@ -1,7 +1,7 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; -import Log from '../Log'; -import ONYXKEYS from '../../ONYXKEYS'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * This migration updates reportActionsDrafts data to be keyed by reportActionID. diff --git a/src/libs/migrations/PersonalDetailsByAccountID.js b/src/libs/migrations/PersonalDetailsByAccountID.js index cf421702fd7a..38c992a6a375 100644 --- a/src/libs/migrations/PersonalDetailsByAccountID.js +++ b/src/libs/migrations/PersonalDetailsByAccountID.js @@ -1,8 +1,8 @@ -import _ from 'underscore'; import lodashHas from 'lodash/has'; import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import Log from '../Log'; +import _ from 'underscore'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; const DEPRECATED_ONYX_KEYS = { // Deprecated personal details object which was keyed by login instead of accountID. diff --git a/src/libs/migrations/RenameReceiptFilename.js b/src/libs/migrations/RenameReceiptFilename.js index b8df705fd7d1..2fcd9662a993 100644 --- a/src/libs/migrations/RenameReceiptFilename.js +++ b/src/libs/migrations/RenameReceiptFilename.js @@ -1,8 +1,8 @@ +import lodashHas from 'lodash/has'; import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import lodashHas from 'lodash/has'; -import ONYXKEYS from '../../ONYXKEYS'; -import Log from '../Log'; +import Log from '@libs/Log'; +import ONYXKEYS from '@src/ONYXKEYS'; // This migration changes the property name on a transaction from receiptFilename to filename so that it matches what is stored in the database export default function () { diff --git a/src/libs/models/BankAccount.js b/src/libs/models/BankAccount.js index faf4cbad34e5..c4366a48aa6a 100644 --- a/src/libs/models/BankAccount.js +++ b/src/libs/models/BankAccount.js @@ -1,8 +1,8 @@ -import _ from 'underscore'; import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; import lodashHas from 'lodash/has'; -import CONST from '../../CONST'; +import _ from 'underscore'; +import CONST from '@src/CONST'; class BankAccount { static STATE = { diff --git a/src/libs/onyxSubscribe.ts b/src/libs/onyxSubscribe.ts index 469a7b810b1f..5e3213cdcf95 100644 --- a/src/libs/onyxSubscribe.ts +++ b/src/libs/onyxSubscribe.ts @@ -1,5 +1,5 @@ import Onyx, {ConnectOptions} from 'react-native-onyx'; -import {OnyxKey} from '../ONYXKEYS'; +import {OnyxKey} from '@src/ONYXKEYS'; /** * Connect to onyx data. Same params as Onyx.connect(), but returns a function to unsubscribe. diff --git a/src/libs/setShouldShowComposeInputKeyboardAware/index.native.ts b/src/libs/setShouldShowComposeInputKeyboardAware/index.native.ts index f5d690db644d..dbfa0c6977b3 100644 --- a/src/libs/setShouldShowComposeInputKeyboardAware/index.native.ts +++ b/src/libs/setShouldShowComposeInputKeyboardAware/index.native.ts @@ -1,5 +1,5 @@ import {EmitterSubscription, Keyboard} from 'react-native'; -import * as Composer from '../actions/Composer'; +import * as Composer from '@userActions/Composer'; import SetShouldShowComposeInputKeyboardAware from './types'; let keyboardDidHideListener: EmitterSubscription | null = null; diff --git a/src/libs/setShouldShowComposeInputKeyboardAware/index.ts b/src/libs/setShouldShowComposeInputKeyboardAware/index.ts index 5ee36834ad5c..a6217fcd761b 100644 --- a/src/libs/setShouldShowComposeInputKeyboardAware/index.ts +++ b/src/libs/setShouldShowComposeInputKeyboardAware/index.ts @@ -1,4 +1,4 @@ -import * as Composer from '../actions/Composer'; +import * as Composer from '@userActions/Composer'; import SetShouldShowComposeInputKeyboardAware from './types'; const setShouldShowComposeInputKeyboardAware: SetShouldShowComposeInputKeyboardAware = (shouldShow) => { diff --git a/src/libs/tryResolveUrlFromApiRoot.ts b/src/libs/tryResolveUrlFromApiRoot.ts index 6bfb5473271e..1aa102323a06 100644 --- a/src/libs/tryResolveUrlFromApiRoot.ts +++ b/src/libs/tryResolveUrlFromApiRoot.ts @@ -1,5 +1,5 @@ -import Config from '../CONFIG'; -import {Request} from '../types/onyx'; +import Config from '@src/CONFIG'; +import {Request} from '@src/types/onyx'; import * as ApiUtils from './ApiUtils'; // Absolute URLs (`/` or `//`) should be resolved from API ROOT diff --git a/src/pages/AddPersonalBankAccountPage.js b/src/pages/AddPersonalBankAccountPage.js index 3e7b2ef214e0..3b802459c98a 100644 --- a/src/pages/AddPersonalBankAccountPage.js +++ b/src/pages/AddPersonalBankAccountPage.js @@ -1,22 +1,22 @@ -import _ from 'underscore'; -import React, {useCallback, useEffect, useState} from 'react'; -import {withOnyx} from 'react-native-onyx'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ScreenWrapper from '../components/ScreenWrapper'; -import Navigation from '../libs/Navigation/Navigation'; -import * as BankAccounts from '../libs/actions/BankAccounts'; -import AddPlaidBankAccount from '../components/AddPlaidBankAccount'; -import getPlaidOAuthReceivedRedirectURI from '../libs/getPlaidOAuthReceivedRedirectURI'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import Form from '../components/Form'; -import ROUTES from '../ROUTES'; +import React, {useCallback, useEffect, useState} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import AddPlaidBankAccount from '@components/AddPlaidBankAccount'; +import ConfirmationPage from '@components/ConfirmationPage'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import getPlaidOAuthReceivedRedirectURI from '@libs/getPlaidOAuthReceivedRedirectURI'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import * as PlaidDataProps from './ReimbursementAccount/plaidDataPropTypes'; -import ConfirmationPage from '../components/ConfirmationPage'; -import * as PaymentMethods from '../libs/actions/PaymentMethods'; -import useLocalize from '../hooks/useLocalize'; const propTypes = { /** Contains plaid data */ diff --git a/src/pages/ConciergePage.js b/src/pages/ConciergePage.js index cfd452f0c952..841ce524b2cb 100644 --- a/src/pages/ConciergePage.js +++ b/src/pages/ConciergePage.js @@ -1,13 +1,13 @@ -import _ from 'underscore'; -import React from 'react'; +import {useFocusEffect} from '@react-navigation/native'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import {useFocusEffect} from '@react-navigation/native'; -import ONYXKEYS from '../ONYXKEYS'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import Navigation from '../libs/Navigation/Navigation'; -import * as Report from '../libs/actions/Report'; -import ROUTES from '../ROUTES'; +import _ from 'underscore'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Report from '@userActions/Report'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Session info for the currently logged in user. */ diff --git a/src/pages/DemoSetupPage.js b/src/pages/DemoSetupPage.js index 5432bea0c806..9cf0f91906c9 100644 --- a/src/pages/DemoSetupPage.js +++ b/src/pages/DemoSetupPage.js @@ -1,11 +1,11 @@ -import React, {useCallback} from 'react'; -import PropTypes from 'prop-types'; import {useFocusEffect} from '@react-navigation/native'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; -import CONST from '../CONST'; -import * as DemoActions from '../libs/actions/DemoActions'; +import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Navigation from '@libs/Navigation/Navigation'; +import * as DemoActions from '@userActions/DemoActions'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Navigation route context info provided by react navigation */ diff --git a/src/pages/DetailsPage.js b/src/pages/DetailsPage.js index 090e6205e925..7f01256cc024 100755 --- a/src/pages/DetailsPage.js +++ b/src/pages/DetailsPage.js @@ -1,33 +1,33 @@ -import React from 'react'; -import {View, ScrollView} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; +import {parsePhoneNumber} from 'awesome-phonenumber'; import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import styles from '../styles/styles'; -import Text from '../components/Text'; -import ONYXKEYS from '../ONYXKEYS'; -import Avatar from '../components/Avatar'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ScreenWrapper from '../components/ScreenWrapper'; +import PropTypes from 'prop-types'; +import React from 'react'; +import {ScrollView, View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import AttachmentModal from '@components/AttachmentModal'; +import AutoUpdateTime from '@components/AutoUpdateTime'; +import Avatar from '@components/Avatar'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import CommunicationsLink from '@components/CommunicationsLink'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import PressableWithoutFocus from '@components/Pressable/PressableWithoutFocus'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import UserDetailsTooltip from '@components/UserDetailsTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import personalDetailsPropType from './personalDetailsPropType'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; -import CommunicationsLink from '../components/CommunicationsLink'; -import UserDetailsTooltip from '../components/UserDetailsTooltip'; -import CONST from '../CONST'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as Expensicons from '../components/Icon/Expensicons'; -import MenuItem from '../components/MenuItem'; -import AttachmentModal from '../components/AttachmentModal'; -import PressableWithoutFocus from '../components/Pressable/PressableWithoutFocus'; -import * as Report from '../libs/actions/Report'; -import OfflineWithFeedback from '../components/OfflineWithFeedback'; -import AutoUpdateTime from '../components/AutoUpdateTime'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import * as UserUtils from '../libs/UserUtils'; const matchType = PropTypes.shape({ params: PropTypes.shape({ diff --git a/src/pages/EditRequestAmountPage.js b/src/pages/EditRequestAmountPage.js index d65fdafb3b59..b986989a81dc 100644 --- a/src/pages/EditRequestAmountPage.js +++ b/src/pages/EditRequestAmountPage.js @@ -1,10 +1,10 @@ -import React, {useCallback, useRef} from 'react'; import {useFocusEffect} from '@react-navigation/native'; import PropTypes from 'prop-types'; -import CONST from '../CONST'; -import useLocalize from '../hooks/useLocalize'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; +import React, {useCallback, useRef} from 'react'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import CONST from '@src/CONST'; import MoneyRequestAmountForm from './iou/steps/MoneyRequestAmountForm'; const propTypes = { diff --git a/src/pages/EditRequestCategoryPage.js b/src/pages/EditRequestCategoryPage.js index c0db5a16b140..b3eacbe1abad 100644 --- a/src/pages/EditRequestCategoryPage.js +++ b/src/pages/EditRequestCategoryPage.js @@ -1,12 +1,12 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import useLocalize from '../hooks/useLocalize'; -import styles from '../styles/styles'; -import Text from '../components/Text'; -import CategoryPicker from '../components/CategoryPicker'; +import React from 'react'; +import CategoryPicker from '@components/CategoryPicker'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; const propTypes = { /** Transaction default category value */ diff --git a/src/pages/EditRequestCreatedPage.js b/src/pages/EditRequestCreatedPage.js index d326e9115afc..5bf421f1d6b0 100644 --- a/src/pages/EditRequestCreatedPage.js +++ b/src/pages/EditRequestCreatedPage.js @@ -1,12 +1,12 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import useLocalize from '../hooks/useLocalize'; -import NewDatePicker from '../components/NewDatePicker'; -import FormProvider from '../components/Form/FormProvider'; +import React from 'react'; +import FormProvider from '@components/Form/FormProvider'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import NewDatePicker from '@components/NewDatePicker'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Transaction defailt created value */ diff --git a/src/pages/EditRequestDescriptionPage.js b/src/pages/EditRequestDescriptionPage.js index 0c0fcad7f60b..6bbe1aa3a4e8 100644 --- a/src/pages/EditRequestDescriptionPage.js +++ b/src/pages/EditRequestDescriptionPage.js @@ -1,17 +1,17 @@ -import React, {useRef, useCallback} from 'react'; -import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {useFocusEffect} from '@react-navigation/native'; -import TextInput from '../components/TextInput'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Form from '../components/Form'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import CONST from '../CONST'; -import useLocalize from '../hooks/useLocalize'; -import * as Browser from '../libs/Browser'; -import updateMultilineInputRange from '../libs/UpdateMultilineInputRange'; +import PropTypes from 'prop-types'; +import React, {useCallback, useRef} from 'react'; +import {View} from 'react-native'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import * as Browser from '@libs/Browser'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Transaction default description value */ diff --git a/src/pages/EditRequestDistancePage.js b/src/pages/EditRequestDistancePage.js index 4eb7340dd410..0fca8aee4be9 100644 --- a/src/pages/EditRequestDistancePage.js +++ b/src/pages/EditRequestDistancePage.js @@ -1,21 +1,21 @@ -import React, {useEffect, useRef} from 'react'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useEffect, useRef} from 'react'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import useLocalize from '../hooks/useLocalize'; -import DistanceRequest from '../components/DistanceRequest'; +import _ from 'underscore'; +import DistanceRequest from '@components/DistanceRequest'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import transactionPropTypes from '@components/transactionPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import usePrevious from '@hooks/usePrevious'; +import Navigation from '@libs/Navigation/Navigation'; +import * as IOU from '@userActions/IOU'; +import * as TransactionEdit from '@userActions/TransactionEdit'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import reportPropTypes from './reportPropTypes'; -import * as IOU from '../libs/actions/IOU'; -import transactionPropTypes from '../components/transactionPropTypes'; -import * as TransactionEdit from '../libs/actions/TransactionEdit'; -import useNetwork from '../hooks/useNetwork'; -import usePrevious from '../hooks/usePrevious'; const propTypes = { /** The transactionID we're currently editing */ diff --git a/src/pages/EditRequestMerchantPage.js b/src/pages/EditRequestMerchantPage.js index 7e15a88a3ab4..e64fd121b4ff 100644 --- a/src/pages/EditRequestMerchantPage.js +++ b/src/pages/EditRequestMerchantPage.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React, {useCallback, useRef} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import TextInput from '../components/TextInput'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Form from '../components/Form'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import CONST from '../CONST'; -import useLocalize from '../hooks/useLocalize'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Transaction default merchant value */ diff --git a/src/pages/EditRequestPage.js b/src/pages/EditRequestPage.js index eedd5bcd10d4..302b7d35a1c9 100644 --- a/src/pages/EditRequestPage.js +++ b/src/pages/EditRequestPage.js @@ -1,35 +1,35 @@ -import React, {useEffect, useMemo} from 'react'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; import lodashValues from 'lodash/values'; +import PropTypes from 'prop-types'; +import React, {useEffect, useMemo} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import ROUTES from '../ROUTES'; -import compose from '../libs/compose'; -import Navigation from '../libs/Navigation/Navigation'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import * as TransactionUtils from '../libs/TransactionUtils'; -import * as IOU from '../libs/actions/IOU'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import Permissions from '../libs/Permissions'; -import tagPropTypes from '../components/tagPropTypes'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import categoryPropTypes from '@components/categoryPropTypes'; +import ScreenWrapper from '@components/ScreenWrapper'; +import tagPropTypes from '@components/tagPropTypes'; +import transactionPropTypes from '@components/transactionPropTypes'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import EditRequestAmountPage from './EditRequestAmountPage'; +import EditRequestCategoryPage from './EditRequestCategoryPage'; +import EditRequestCreatedPage from './EditRequestCreatedPage'; import EditRequestDescriptionPage from './EditRequestDescriptionPage'; +import EditRequestDistancePage from './EditRequestDistancePage'; import EditRequestMerchantPage from './EditRequestMerchantPage'; -import EditRequestCreatedPage from './EditRequestCreatedPage'; -import EditRequestAmountPage from './EditRequestAmountPage'; import EditRequestReceiptPage from './EditRequestReceiptPage'; -import reportPropTypes from './reportPropTypes'; -import EditRequestDistancePage from './EditRequestDistancePage'; -import EditRequestCategoryPage from './EditRequestCategoryPage'; import EditRequestTagPage from './EditRequestTagPage'; -import categoryPropTypes from '../components/categoryPropTypes'; -import ScreenWrapper from '../components/ScreenWrapper'; import reportActionPropTypes from './home/report/reportActionPropTypes'; -import transactionPropTypes from '../components/transactionPropTypes'; +import reportPropTypes from './reportPropTypes'; const propTypes = { /** Route from navigation */ diff --git a/src/pages/EditRequestReceiptPage.js b/src/pages/EditRequestReceiptPage.js index 54ed5a8897a4..9c9daf7c899a 100644 --- a/src/pages/EditRequestReceiptPage.js +++ b/src/pages/EditRequestReceiptPage.js @@ -1,13 +1,13 @@ -import React, {useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useState} from 'react'; import {View} from 'react-native'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import useLocalize from '../hooks/useLocalize'; +import DragAndDropProvider from '@components/DragAndDrop/Provider'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; import ReceiptSelector from './iou/ReceiptSelector'; -import DragAndDropProvider from '../components/DragAndDrop/Provider'; -import styles from '../styles/styles'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/EditRequestTagPage.js b/src/pages/EditRequestTagPage.js index c5ae18f1376c..819a026dc9aa 100644 --- a/src/pages/EditRequestTagPage.js +++ b/src/pages/EditRequestTagPage.js @@ -1,12 +1,12 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import Navigation from '../libs/Navigation/Navigation'; -import useLocalize from '../hooks/useLocalize'; -import ScreenWrapper from '../components/ScreenWrapper'; -import Text from '../components/Text'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import styles from '../styles/styles'; -import TagPicker from '../components/TagPicker'; +import React from 'react'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TagPicker from '@components/TagPicker'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; const propTypes = { /** Transaction default tag value */ diff --git a/src/pages/EditSplitBillPage.js b/src/pages/EditSplitBillPage.js index d10803cd40ea..1342d9297d3e 100644 --- a/src/pages/EditSplitBillPage.js +++ b/src/pages/EditSplitBillPage.js @@ -1,21 +1,21 @@ -import React from 'react'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../CONST'; -import ROUTES from '../ROUTES'; -import ONYXKEYS from '../ONYXKEYS'; -import compose from '../libs/compose'; -import transactionPropTypes from '../components/transactionPropTypes'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as IOU from '../libs/actions/IOU'; -import * as CurrencyUtils from '../libs/CurrencyUtils'; -import Navigation from '../libs/Navigation/Navigation'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import transactionPropTypes from '@components/transactionPropTypes'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import EditRequestAmountPage from './EditRequestAmountPage'; +import EditRequestCreatedPage from './EditRequestCreatedPage'; import EditRequestDescriptionPage from './EditRequestDescriptionPage'; import EditRequestMerchantPage from './EditRequestMerchantPage'; -import EditRequestCreatedPage from './EditRequestCreatedPage'; -import EditRequestAmountPage from './EditRequestAmountPage'; const propTypes = { /** Route from navigation */ diff --git a/src/pages/EnablePayments/ActivateStep.js b/src/pages/EnablePayments/ActivateStep.js index 2badb5595f3b..30e775a0f932 100644 --- a/src/pages/EnablePayments/ActivateStep.js +++ b/src/pages/EnablePayments/ActivateStep.js @@ -1,16 +1,16 @@ -import _ from 'underscore'; import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import * as LottieAnimations from '../../components/LottieAnimations'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; +import _ from 'underscore'; +import ConfirmationPage from '@components/ConfirmationPage'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as LottieAnimations from '@components/LottieAnimations'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import userWalletPropTypes from './userWalletPropTypes'; -import CONST from '../../CONST'; -import * as PaymentMethods from '../../libs/actions/PaymentMethods'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; import walletTermsPropTypes from './walletTermsPropTypes'; -import ConfirmationPage from '../../components/ConfirmationPage'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/EnablePayments/AdditionalDetailsStep.js b/src/pages/EnablePayments/AdditionalDetailsStep.js index 13091ab3f845..f1813062d0d7 100644 --- a/src/pages/EnablePayments/AdditionalDetailsStep.js +++ b/src/pages/EnablePayments/AdditionalDetailsStep.js @@ -1,28 +1,28 @@ -import _ from 'underscore'; -import React from 'react'; +import {parsePhoneNumber} from 'awesome-phonenumber'; +import {subYears} from 'date-fns'; import PropTypes from 'prop-types'; -import {withOnyx} from 'react-native-onyx'; +import React from 'react'; import {View} from 'react-native'; -import {subYears} from 'date-fns'; -import {parsePhoneNumber} from 'awesome-phonenumber'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import DatePicker from '@components/DatePicker'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import TextLink from '@components/TextLink'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import AddressForm from '@pages/ReimbursementAccount/AddressForm'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import * as Wallet from '@userActions/Wallet'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import IdologyQuestions from './IdologyQuestions'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import styles from '../../styles/styles'; -import Text from '../../components/Text'; -import CONST from '../../CONST'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import TextLink from '../../components/TextLink'; -import TextInput from '../../components/TextInput'; -import * as Wallet from '../../libs/actions/Wallet'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import AddressForm from '../ReimbursementAccount/AddressForm'; -import DatePicker from '../../components/DatePicker'; -import Form from '../../components/Form'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../components/withCurrentUserPersonalDetails'; -import * as PersonalDetails from '../../libs/actions/PersonalDetails'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/EnablePayments/EnablePaymentsPage.js b/src/pages/EnablePayments/EnablePaymentsPage.js index 5f1577c3b31b..257eab1d38d3 100644 --- a/src/pages/EnablePayments/EnablePaymentsPage.js +++ b/src/pages/EnablePayments/EnablePaymentsPage.js @@ -1,24 +1,23 @@ -import _ from 'underscore'; import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import * as Wallet from '../../libs/actions/Wallet'; -import ONYXKEYS from '../../ONYXKEYS'; -import FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; -import CONST from '../../CONST'; -import userWalletPropTypes from './userWalletPropTypes'; - +import _ from 'underscore'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Wallet from '@userActions/Wallet'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import ActivateStep from './ActivateStep'; +import AdditionalDetailsStep from './AdditionalDetailsStep'; +import FailedKYC from './FailedKYC'; // Steps import OnfidoStep from './OnfidoStep'; -import AdditionalDetailsStep from './AdditionalDetailsStep'; import TermsStep from './TermsStep'; -import ActivateStep from './ActivateStep'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import FailedKYC from './FailedKYC'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import useLocalize from '../../hooks/useLocalize'; -import useNetwork from '../../hooks/useNetwork'; +import userWalletPropTypes from './userWalletPropTypes'; const propTypes = { /** The user's wallet */ diff --git a/src/pages/EnablePayments/FailedKYC.js b/src/pages/EnablePayments/FailedKYC.js index 26b0625a780a..398537cf7645 100644 --- a/src/pages/EnablePayments/FailedKYC.js +++ b/src/pages/EnablePayments/FailedKYC.js @@ -1,10 +1,10 @@ import React from 'react'; import {View} from 'react-native'; -import CONST from '../../CONST'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import styles from '../../styles/styles'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/EnablePayments/IdologyQuestions.js b/src/pages/EnablePayments/IdologyQuestions.js index b5f30f93361b..a46e6d54a5ed 100644 --- a/src/pages/EnablePayments/IdologyQuestions.js +++ b/src/pages/EnablePayments/IdologyQuestions.js @@ -1,20 +1,20 @@ -import _ from 'underscore'; -import React, {useRef, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useRef, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import useLocalize from '../../hooks/useLocalize'; -import RadioButtons from '../../components/RadioButtons'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import FormScrollView from '../../components/FormScrollView'; -import FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton'; -import OfflineIndicator from '../../components/OfflineIndicator'; -import FixedFooter from '../../components/FixedFooter'; +import _ from 'underscore'; +import FixedFooter from '@components/FixedFooter'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import FormScrollView from '@components/FormScrollView'; +import OfflineIndicator from '@components/OfflineIndicator'; +import RadioButtons from '@components/RadioButtons'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import ONYXKEYS from '@src/ONYXKEYS'; const MAX_SKIP = 1; const SKIP_QUESTION_TEXT = 'Skip Question'; diff --git a/src/pages/EnablePayments/OnfidoPrivacy.js b/src/pages/EnablePayments/OnfidoPrivacy.js index 85ceb03b01d5..c195e0237034 100644 --- a/src/pages/EnablePayments/OnfidoPrivacy.js +++ b/src/pages/EnablePayments/OnfidoPrivacy.js @@ -1,21 +1,21 @@ +import lodashGet from 'lodash/get'; import React, {useRef} from 'react'; import {View} from 'react-native'; -import lodashGet from 'lodash/get'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import FullscreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import styles from '../../styles/styles'; -import TextLink from '../../components/TextLink'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import Text from '../../components/Text'; -import FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton'; -import FormScrollView from '../../components/FormScrollView'; +import _ from 'underscore'; +import FixedFooter from '@components/FixedFooter'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import FormScrollView from '@components/FormScrollView'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import ONYXKEYS from '@src/ONYXKEYS'; import walletOnfidoDataPropTypes from './walletOnfidoDataPropTypes'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import FixedFooter from '../../components/FixedFooter'; const propTypes = { /** Stores various information used to build the UI and call any APIs */ diff --git a/src/pages/EnablePayments/OnfidoStep.js b/src/pages/EnablePayments/OnfidoStep.js index fc856d813683..8b40c88f62fb 100644 --- a/src/pages/EnablePayments/OnfidoStep.js +++ b/src/pages/EnablePayments/OnfidoStep.js @@ -1,18 +1,18 @@ import React, {useCallback} from 'react'; import {withOnyx} from 'react-native-onyx'; -import Onfido from '../../components/Onfido'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import Navigation from '../../libs/Navigation/Navigation'; -import CONST from '../../CONST'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import * as Wallet from '../../libs/actions/Wallet'; -import useLocalize from '../../hooks/useLocalize'; -import Growl from '../../libs/Growl'; +import FullPageOfflineBlockingView from '@components/BlockingViews/FullPageOfflineBlockingView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Onfido from '@components/Onfido'; +import useLocalize from '@hooks/useLocalize'; +import Growl from '@libs/Growl'; +import Navigation from '@libs/Navigation/Navigation'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as Wallet from '@userActions/Wallet'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import OnfidoPrivacy from './OnfidoPrivacy'; import walletOnfidoDataPropTypes from './walletOnfidoDataPropTypes'; -import FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView'; -import ROUTES from '../../ROUTES'; const propTypes = { /** Stores various information used to build the UI and call any APIs */ diff --git a/src/pages/EnablePayments/TermsPage/LongTermsForm.js b/src/pages/EnablePayments/TermsPage/LongTermsForm.js index 4b68635d8ec8..5a925ad4e7c3 100644 --- a/src/pages/EnablePayments/TermsPage/LongTermsForm.js +++ b/src/pages/EnablePayments/TermsPage/LongTermsForm.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; import React from 'react'; import {View} from 'react-native'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import CollapsibleSection from '../../../components/CollapsibleSection'; -import * as Localize from '../../../libs/Localize'; -import CONST from '../../../CONST'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import TextLink from '../../../components/TextLink'; +import _ from 'underscore'; +import CollapsibleSection from '@components/CollapsibleSection'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import * as Localize from '@libs/Localize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const termsData = [ { diff --git a/src/pages/EnablePayments/TermsPage/ShortTermsForm.js b/src/pages/EnablePayments/TermsPage/ShortTermsForm.js index 1b693add95b7..46a1867a2606 100644 --- a/src/pages/EnablePayments/TermsPage/ShortTermsForm.js +++ b/src/pages/EnablePayments/TermsPage/ShortTermsForm.js @@ -1,11 +1,11 @@ import React from 'react'; import {View} from 'react-native'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import * as Localize from '../../../libs/Localize'; -import CONST from '../../../CONST'; -import TextLink from '../../../components/TextLink'; -import userWalletPropTypes from '../userWalletPropTypes'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import * as Localize from '@libs/Localize'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** The user's wallet */ diff --git a/src/pages/EnablePayments/TermsStep.js b/src/pages/EnablePayments/TermsStep.js index c11d8c39bda6..6dff94b7202b 100644 --- a/src/pages/EnablePayments/TermsStep.js +++ b/src/pages/EnablePayments/TermsStep.js @@ -1,21 +1,21 @@ import React, {useEffect, useState} from 'react'; import {ScrollView} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import styles from '../../styles/styles'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import TextLink from '../../components/TextLink'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import Text from '../../components/Text'; -import ShortTermsForm from './TermsPage/ShortTermsForm'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import ONYXKEYS from '@src/ONYXKEYS'; import LongTermsForm from './TermsPage/LongTermsForm'; -import FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton'; -import walletTermsPropTypes from './walletTermsPropTypes'; -import * as ErrorUtils from '../../libs/ErrorUtils'; +import ShortTermsForm from './TermsPage/ShortTermsForm'; import userWalletPropTypes from './userWalletPropTypes'; +import walletTermsPropTypes from './walletTermsPropTypes'; const propTypes = { /** The user's wallet */ diff --git a/src/pages/EnablePayments/walletTermsPropTypes.js b/src/pages/EnablePayments/walletTermsPropTypes.js index 44d153f3b6ff..4420a2dd0861 100644 --- a/src/pages/EnablePayments/walletTermsPropTypes.js +++ b/src/pages/EnablePayments/walletTermsPropTypes.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; import _ from 'underscore'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; /** Prop types related to the Terms step of KYC flow */ export default PropTypes.shape({ diff --git a/src/pages/ErrorPage/ErrorBodyText/index.js b/src/pages/ErrorPage/ErrorBodyText/index.js index 9410d5fe5c1d..d50d15c15cd0 100644 --- a/src/pages/ErrorPage/ErrorBodyText/index.js +++ b/src/pages/ErrorPage/ErrorBodyText/index.js @@ -1,9 +1,9 @@ import React from 'react'; -import Text from '../../../components/Text'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import TextLink from '../../../components/TextLink'; -import CONST from '../../../CONST'; -import styles from '../../../styles/styles'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/ErrorPage/GenericErrorPage.js b/src/pages/ErrorPage/GenericErrorPage.js index 02ab38a1ef20..af551fe5743a 100644 --- a/src/pages/ErrorPage/GenericErrorPage.js +++ b/src/pages/ErrorPage/GenericErrorPage.js @@ -1,21 +1,21 @@ import React from 'react'; -import {View} from 'react-native'; import {useErrorBoundary} from 'react-error-boundary'; -import Icon from '../../components/Icon'; -import defaultTheme from '../../styles/themes/default'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import Text from '../../components/Text'; -import Button from '../../components/Button'; -import LogoWordmark from '../../../assets/images/expensify-wordmark.svg'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import * as Session from '../../libs/actions/Session'; -import variables from '../../styles/variables'; -import styles from '../../styles/styles'; +import {View} from 'react-native'; +import LogoWordmark from '@assets/images/expensify-wordmark.svg'; +import Button from '@components/Button'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import SafeAreaConsumer from '@components/SafeAreaConsumer'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import defaultTheme from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; import ErrorBodyText from './ErrorBodyText'; -import TextLink from '../../components/TextLink'; -import CONST from '../../CONST'; -import SafeAreaConsumer from '../../components/SafeAreaConsumer'; -import * as StyleUtils from '../../styles/StyleUtils'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/ErrorPage/NotFoundPage.js b/src/pages/ErrorPage/NotFoundPage.js index 445e81296566..9ada6b820e8e 100644 --- a/src/pages/ErrorPage/NotFoundPage.js +++ b/src/pages/ErrorPage/NotFoundPage.js @@ -1,6 +1,6 @@ import React from 'react'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import ScreenWrapper from '@components/ScreenWrapper'; // eslint-disable-next-line rulesdir/no-negated-variables function NotFoundPage() { diff --git a/src/pages/FlagCommentPage.js b/src/pages/FlagCommentPage.js index 53da810007ea..ee7b2d8af3c1 100644 --- a/src/pages/FlagCommentPage.js +++ b/src/pages/FlagCommentPage.js @@ -1,27 +1,27 @@ -import React, {useCallback} from 'react'; -import _ from 'underscore'; -import {View, ScrollView} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import reportPropTypes from './reportPropTypes'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import reportActionPropTypes from './home/report/reportActionPropTypes'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import styles from '../styles/styles'; -import Navigation from '../libs/Navigation/Navigation'; -import Text from '../components/Text'; -import * as Expensicons from '../components/Icon/Expensicons'; -import MenuItem from '../components/MenuItem'; -import * as Report from '../libs/actions/Report'; -import CONST from '../CONST'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as ReportActionsUtils from '../libs/ReportActionsUtils'; -import * as Session from '../libs/actions/Session'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; import withReportAndReportActionOrNotFound from './home/report/withReportAndReportActionOrNotFound'; -import ONYXKEYS from '../ONYXKEYS'; +import reportPropTypes from './reportPropTypes'; const propTypes = { /** Array of report actions for this report */ diff --git a/src/pages/GetAssistancePage.js b/src/pages/GetAssistancePage.js index 97b498d758b7..647734a0cde1 100644 --- a/src/pages/GetAssistancePage.js +++ b/src/pages/GetAssistancePage.js @@ -1,23 +1,23 @@ -import React from 'react'; -import {View, ScrollView} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Section from '../components/Section'; -import styles from '../styles/styles'; -import Text from '../components/Text'; -import * as Expensicons from '../components/Icon/Expensicons'; -import * as Illustrations from '../components/Icon/Illustrations'; -import * as Report from '../libs/actions/Report'; -import * as Link from '../libs/actions/Link'; -import CONST from '../CONST'; -import compose from '../libs/compose'; -import ONYXKEYS from '../ONYXKEYS'; -import Navigation from '../libs/Navigation/Navigation'; -import ROUTES from '../ROUTES'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Route object from navigation */ diff --git a/src/pages/KeyboardShortcutsPage.js b/src/pages/KeyboardShortcutsPage.js index 8ac26301e9fb..4caade5b9ec1 100644 --- a/src/pages/KeyboardShortcutsPage.js +++ b/src/pages/KeyboardShortcutsPage.js @@ -1,14 +1,14 @@ import React from 'react'; -import {View, ScrollView} from 'react-native'; +import {ScrollView, View} from 'react-native'; import _ from 'underscore'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ScreenWrapper from '../components/ScreenWrapper'; -import Text from '../components/Text'; -import styles from '../styles/styles'; -import CONST from '../CONST'; -import useLocalize from '../hooks/useLocalize'; -import KeyboardShortcut from '../libs/KeyboardShortcut'; -import MenuItem from '../components/MenuItem'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItem from '@components/MenuItem'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; function KeyboardShortcutsPage() { const {translate} = useLocalize(); diff --git a/src/pages/LogInWithShortLivedAuthTokenPage.js b/src/pages/LogInWithShortLivedAuthTokenPage.js index 875cdf7e8072..84de67e496b5 100644 --- a/src/pages/LogInWithShortLivedAuthTokenPage.js +++ b/src/pages/LogInWithShortLivedAuthTokenPage.js @@ -1,20 +1,20 @@ -import React, {useEffect} from 'react'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import {withOnyx} from 'react-native-onyx'; +import React, {useEffect} from 'react'; import {View} from 'react-native'; -import Text from '../components/Text'; -import * as Session from '../libs/actions/Session'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import Navigation from '../libs/Navigation/Navigation'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import Icon from '../components/Icon'; -import * as Expensicons from '../components/Icon/Expensicons'; -import * as Illustrations from '../components/Icon/Illustrations'; -import useLocalize from '../hooks/useLocalize'; -import TextLink from '../components/TextLink'; -import ONYXKEYS from '../ONYXKEYS'; +import {withOnyx} from 'react-native-onyx'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The parameters needed to authenticate with a short-lived token are in the URL */ diff --git a/src/pages/LogOutPreviousUserPage.js b/src/pages/LogOutPreviousUserPage.js index 9055187def16..8fd0ec144a1f 100644 --- a/src/pages/LogOutPreviousUserPage.js +++ b/src/pages/LogOutPreviousUserPage.js @@ -1,12 +1,12 @@ -import React, {useEffect} from 'react'; -import {Linking} from 'react-native'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {Linking} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; -import * as Session from '../libs/actions/Session'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import * as SessionUtils from '../libs/SessionUtils'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import * as SessionUtils from '@libs/SessionUtils'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The data about the current session which will be set once the user is authenticated and we return to this component as an AuthScreen */ diff --git a/src/pages/NewChatPage.js b/src/pages/NewChatPage.js index 381564b82600..25a1bed4f11a 100755 --- a/src/pages/NewChatPage.js +++ b/src/pages/NewChatPage.js @@ -1,27 +1,27 @@ -import _ from 'underscore'; -import React, {useState, useEffect, useMemo, useCallback} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import OptionsSelector from '../components/OptionsSelector'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import Permissions from '../libs/Permissions'; -import * as ReportUtils from '../libs/ReportUtils'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import * as Report from '../libs/actions/Report'; -import CONST from '../CONST'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions'; -import ScreenWrapper from '../components/ScreenWrapper'; -import KeyboardAvoidingView from '../components/KeyboardAvoidingView'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import * as Browser from '../libs/Browser'; -import compose from '../libs/compose'; +import _ from 'underscore'; +import KeyboardAvoidingView from '@components/KeyboardAvoidingView'; +import OptionsSelector from '@components/OptionsSelector'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useDelayedInputFocus from '@hooks/useDelayedInputFocus'; +import useNetwork from '@hooks/useNetwork'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import personalDetailsPropType from './personalDetailsPropType'; import reportPropTypes from './reportPropTypes'; -import variables from '../styles/variables'; -import useNetwork from '../hooks/useNetwork'; -import useDelayedInputFocus from '../hooks/useDelayedInputFocus'; const propTypes = { /** Beta features list */ diff --git a/src/pages/NewChatSelectorPage.js b/src/pages/NewChatSelectorPage.js index 2ac2ed8177a1..6e970c80b1cb 100755 --- a/src/pages/NewChatSelectorPage.js +++ b/src/pages/NewChatSelectorPage.js @@ -1,17 +1,17 @@ import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import OnyxTabNavigator, {TopTab} from '../libs/Navigation/OnyxTabNavigator'; -import TabSelector from '../components/TabSelector/TabSelector'; -import Permissions from '../libs/Permissions'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TabSelector from '@components/TabSelector/TabSelector'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import OnyxTabNavigator, {TopTab} from '@libs/Navigation/OnyxTabNavigator'; +import Permissions from '@libs/Permissions'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import NewChatPage from './NewChatPage'; import WorkspaceNewRoomPage from './workspace/WorkspaceNewRoomPage'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ScreenWrapper from '../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; const propTypes = { ...windowDimensionsPropTypes, diff --git a/src/pages/PrivateNotes/PrivateNotesEditPage.js b/src/pages/PrivateNotes/PrivateNotesEditPage.js index 962163d3e379..44cba7682719 100644 --- a/src/pages/PrivateNotes/PrivateNotesEditPage.js +++ b/src/pages/PrivateNotes/PrivateNotesEditPage.js @@ -1,33 +1,33 @@ -import React, {useState, useRef, useCallback, useMemo} from 'react'; +import {useFocusEffect} from '@react-navigation/native'; +import ExpensiMark from 'expensify-common/lib/ExpensiMark'; +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useMemo, useRef, useState} from 'react'; import {Keyboard} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import {useFocusEffect} from '@react-navigation/native'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; -import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import _ from 'underscore'; -import withLocalize from '../../components/withLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import TextInput from '../../components/TextInput'; -import CONST from '../../CONST'; -import Text from '../../components/Text'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import reportPropTypes from '../reportPropTypes'; -import personalDetailsPropType from '../personalDetailsPropType'; -import * as Report from '../../libs/actions/Report'; -import useLocalize from '../../hooks/useLocalize'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import updateMultilineInputRange from '../../libs/UpdateMultilineInputRange'; -import ROUTES from '../../ROUTES'; -import * as ReportUtils from '../../libs/ReportUtils'; -import InputWrapper from '../../components/Form/InputWrapper'; -import FormProvider from '../../components/Form/FormProvider'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** All of the personal details for everyone */ diff --git a/src/pages/PrivateNotes/PrivateNotesListPage.js b/src/pages/PrivateNotes/PrivateNotesListPage.js index bd49e74d5f69..ec3905db349e 100644 --- a/src/pages/PrivateNotes/PrivateNotesListPage.js +++ b/src/pages/PrivateNotes/PrivateNotesListPage.js @@ -1,30 +1,30 @@ -import React, {useMemo, useEffect} from 'react'; -import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useEffect, useMemo} from 'react'; import {ScrollView} from 'react-native'; -import Navigation from '../../libs/Navigation/Navigation'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import MenuItem from '../../components/MenuItem'; -import useLocalize from '../../hooks/useLocalize'; -import FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; -import * as Report from '../../libs/actions/Report'; -import personalDetailsPropType from '../personalDetailsPropType'; -import * as UserUtils from '../../libs/UserUtils'; -import reportPropTypes from '../reportPropTypes'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import {withNetwork} from '../../components/OnyxProvider'; -import networkPropTypes from '../../components/networkPropTypes'; -import ROUTES from '../../ROUTES'; -import * as ReportUtils from '../../libs/ReportUtils'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItem from '@components/MenuItem'; +import networkPropTypes from '@components/networkPropTypes'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/PrivateNotes/PrivateNotesViewPage.js b/src/pages/PrivateNotes/PrivateNotesViewPage.js index 6550c9d7d3c3..bb9d96516437 100644 --- a/src/pages/PrivateNotes/PrivateNotesViewPage.js +++ b/src/pages/PrivateNotes/PrivateNotesViewPage.js @@ -1,25 +1,25 @@ -import React from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; import {ScrollView} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import withLocalize from '../../components/withLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import ROUTES from '../../ROUTES'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import reportPropTypes from '../reportPropTypes'; -import personalDetailsPropType from '../personalDetailsPropType'; -import useLocalize from '../../hooks/useLocalize'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import MenuItemWithTopDescription from '../../components/MenuItemWithTopDescription'; -import CONST from '../../CONST'; -import * as ReportUtils from '../../libs/ReportUtils'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** All of the personal details for everyone */ diff --git a/src/pages/ProfilePage.js b/src/pages/ProfilePage.js index 8e0ed04ab94a..ccc5cd14359a 100755 --- a/src/pages/ProfilePage.js +++ b/src/pages/ProfilePage.js @@ -1,43 +1,43 @@ -import {View, ScrollView} from 'react-native'; -import React, {useEffect} from 'react'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; +import {parsePhoneNumber} from 'awesome-phonenumber'; import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import * as Session from '../libs/actions/Session'; -import styles from '../styles/styles'; -import Text from '../components/Text'; -import ONYXKEYS from '../ONYXKEYS'; -import Avatar from '../components/Avatar'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import ScreenWrapper from '../components/ScreenWrapper'; +import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {ScrollView, View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import AttachmentModal from '@components/AttachmentModal'; +import AutoUpdateTime from '@components/AutoUpdateTime'; +import Avatar from '@components/Avatar'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import CommunicationsLink from '@components/CommunicationsLink'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import PressableWithoutFocus from '@components/Pressable/PressableWithoutFocus'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import UserDetailsTooltip from '@components/UserDetailsTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import * as Report from '@userActions/Report'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import personalDetailsPropType from './personalDetailsPropType'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; -import CommunicationsLink from '../components/CommunicationsLink'; -import UserDetailsTooltip from '../components/UserDetailsTooltip'; -import CONST from '../CONST'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as Expensicons from '../components/Icon/Expensicons'; -import MenuItem from '../components/MenuItem'; -import AttachmentModal from '../components/AttachmentModal'; -import PressableWithoutFocus from '../components/Pressable/PressableWithoutFocus'; -import * as Report from '../libs/actions/Report'; -import OfflineWithFeedback from '../components/OfflineWithFeedback'; -import AutoUpdateTime from '../components/AutoUpdateTime'; -import * as UserUtils from '../libs/UserUtils'; -import * as PersonalDetails from '../libs/actions/PersonalDetails'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import BlockingView from '../components/BlockingViews/BlockingView'; -import * as Illustrations from '../components/Icon/Illustrations'; -import variables from '../styles/variables'; -import * as ValidationUtils from '../libs/ValidationUtils'; -import Permissions from '../libs/Permissions'; -import ROUTES from '../ROUTES'; -import MenuItemWithTopDescription from '../components/MenuItemWithTopDescription'; const matchType = PropTypes.shape({ params: PropTypes.shape({ diff --git a/src/pages/ReimbursementAccount/ACHContractStep.js b/src/pages/ReimbursementAccount/ACHContractStep.js index 5f7fce851c85..8f2d2e07998e 100644 --- a/src/pages/ReimbursementAccount/ACHContractStep.js +++ b/src/pages/ReimbursementAccount/ACHContractStep.js @@ -1,23 +1,23 @@ -import _ from 'underscore'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; -import React, {useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useState} from 'react'; import {View} from 'react-native'; -import Str from 'expensify-common/lib/str'; -import Text from '../../components/Text'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import styles from '../../styles/styles'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import TextLink from '../../components/TextLink'; +import _ from 'underscore'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize from '@components/withLocalize'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as FormActions from '@userActions/FormActions'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import IdentityForm from './IdentityForm'; -import withLocalize from '../../components/withLocalize'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import CONST from '../../CONST'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import ONYXKEYS from '../../ONYXKEYS'; -import Form from '../../components/Form'; -import * as FormActions from '../../libs/actions/FormActions'; -import ScreenWrapper from '../../components/ScreenWrapper'; import StepPropTypes from './StepPropTypes'; const propTypes = { diff --git a/src/pages/ReimbursementAccount/AddressForm.js b/src/pages/ReimbursementAccount/AddressForm.js index 5ddea09c6f4e..36fbc6e4c59d 100644 --- a/src/pages/ReimbursementAccount/AddressForm.js +++ b/src/pages/ReimbursementAccount/AddressForm.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import TextInput from '../../components/TextInput'; -import AddressSearch from '../../components/AddressSearch'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import StatePicker from '../../components/StatePicker'; +import AddressSearch from '@components/AddressSearch'; +import StatePicker from '@components/StatePicker'; +import TextInput from '@components/TextInput'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Translate key for Street name */ diff --git a/src/pages/ReimbursementAccount/BankAccountManualStep.js b/src/pages/ReimbursementAccount/BankAccountManualStep.js index 9d0b0c1f5bed..13155d286a5e 100644 --- a/src/pages/ReimbursementAccount/BankAccountManualStep.js +++ b/src/pages/ReimbursementAccount/BankAccountManualStep.js @@ -1,23 +1,23 @@ +import lodashGet from 'lodash/get'; import React, {useCallback} from 'react'; -import _ from 'underscore'; import {Image} from 'react-native'; -import lodashGet from 'lodash/get'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import CONST from '../../CONST'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import Text from '../../components/Text'; -import TextInput from '../../components/TextInput'; -import styles from '../../styles/styles'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import TextLink from '../../components/TextLink'; -import useLocalize from '../../hooks/useLocalize'; -import {withLocalizePropTypes} from '../../components/withLocalize'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import ONYXKEYS from '../../ONYXKEYS'; +import _ from 'underscore'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import TextLink from '@components/TextLink'; +import {withLocalizePropTypes} from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import shouldDelayFocus from '@libs/shouldDelayFocus'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import exampleCheckImage from './exampleCheckImage'; -import Form from '../../components/Form'; -import shouldDelayFocus from '../../libs/shouldDelayFocus'; -import ScreenWrapper from '../../components/ScreenWrapper'; import StepPropTypes from './StepPropTypes'; const propTypes = { diff --git a/src/pages/ReimbursementAccount/BankAccountPlaidStep.js b/src/pages/ReimbursementAccount/BankAccountPlaidStep.js index 3fbf2a138384..06e8c0531e3b 100644 --- a/src/pages/ReimbursementAccount/BankAccountPlaidStep.js +++ b/src/pages/ReimbursementAccount/BankAccountPlaidStep.js @@ -1,23 +1,23 @@ -import React, {useCallback, useEffect} from 'react'; import {useIsFocused} from '@react-navigation/native'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import CONST from '../../CONST'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import withLocalize from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import AddPlaidBankAccount from '../../components/AddPlaidBankAccount'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import TextLink from '../../components/TextLink'; -import Text from '../../components/Text'; -import * as ReimbursementAccount from '../../libs/actions/ReimbursementAccount'; -import Form from '../../components/Form'; -import styles from '../../styles/styles'; -import ScreenWrapper from '../../components/ScreenWrapper'; +import _ from 'underscore'; +import AddPlaidBankAccount from '@components/AddPlaidBankAccount'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as ReimbursementAccount from '@userActions/ReimbursementAccount'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as PlaidDataProps from './plaidDataPropTypes'; import StepPropTypes from './StepPropTypes'; diff --git a/src/pages/ReimbursementAccount/BankAccountStep.js b/src/pages/ReimbursementAccount/BankAccountStep.js index b01b46f69350..f1bc41d44ed5 100644 --- a/src/pages/ReimbursementAccount/BankAccountStep.js +++ b/src/pages/ReimbursementAccount/BankAccountStep.js @@ -1,33 +1,33 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; -import {View, ScrollView} from 'react-native'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; +import Button from '@components/Button'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItem from '@components/MenuItem'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize from '@components/withLocalize'; +import compose from '@libs/compose'; +import getPlaidDesktopMessage from '@libs/getPlaidDesktopMessage'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as Link from '@userActions/Link'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import BankAccountManualStep from './BankAccountManualStep'; import BankAccountPlaidStep from './BankAccountPlaidStep'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import MenuItem from '../../components/MenuItem'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import styles from '../../styles/styles'; -import TextLink from '../../components/TextLink'; -import Icon from '../../components/Icon'; -import themeColors from '../../styles/themes/default'; -import CONST from '../../CONST'; -import withLocalize from '../../components/withLocalize'; -import Text from '../../components/Text'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import ONYXKEYS from '../../ONYXKEYS'; -import compose from '../../libs/compose'; -import Section from '../../components/Section'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import getPlaidDesktopMessage from '../../libs/getPlaidDesktopMessage'; -import CONFIG from '../../CONFIG'; -import ROUTES from '../../ROUTES'; -import Button from '../../components/Button'; -import ScreenWrapper from '../../components/ScreenWrapper'; import StepPropTypes from './StepPropTypes'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; -import * as Link from '../../libs/actions/Link'; const propTypes = { ...StepPropTypes, diff --git a/src/pages/ReimbursementAccount/CompanyStep.js b/src/pages/ReimbursementAccount/CompanyStep.js index 0ca9b1b7ea92..24cfbf5ae4c6 100644 --- a/src/pages/ReimbursementAccount/CompanyStep.js +++ b/src/pages/ReimbursementAccount/CompanyStep.js @@ -1,29 +1,29 @@ -import _ from 'underscore'; +import {parsePhoneNumber} from 'awesome-phonenumber'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useMemo} from 'react'; import {View} from 'react-native'; -import Str from 'expensify-common/lib/str'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import StatePicker from '../../components/StatePicker'; -import CONST from '../../CONST'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import Text from '../../components/Text'; -import DatePicker from '../../components/DatePicker'; -import TextInput from '../../components/TextInput'; -import styles from '../../styles/styles'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import TextLink from '../../components/TextLink'; -import withLocalize from '../../components/withLocalize'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import Picker from '../../components/Picker'; +import _ from 'underscore'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import DatePicker from '@components/DatePicker'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Picker from '@components/Picker'; +import ScreenWrapper from '@components/ScreenWrapper'; +import StatePicker from '@components/StatePicker'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import TextLink from '@components/TextLink'; +import withLocalize from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import AddressForm from './AddressForm'; -import Form from '../../components/Form'; -import ScreenWrapper from '../../components/ScreenWrapper'; import StepPropTypes from './StepPropTypes'; const propTypes = { diff --git a/src/pages/ReimbursementAccount/ContinueBankAccountSetup.js b/src/pages/ReimbursementAccount/ContinueBankAccountSetup.js index 5bde2884be51..52ccc3b87835 100644 --- a/src/pages/ReimbursementAccount/ContinueBankAccountSetup.js +++ b/src/pages/ReimbursementAccount/ContinueBankAccountSetup.js @@ -1,23 +1,23 @@ +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; import React from 'react'; import {ScrollView} from 'react-native'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import Button from '../../components/Button'; -import CONST from '../../CONST'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import MenuItem from '../../components/MenuItem'; -import styles from '../../styles/styles'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import Section from '../../components/Section'; -import Text from '../../components/Text'; +import Button from '@components/Button'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import WorkspaceResetBankAccountModal from '@pages/workspace/WorkspaceResetBankAccountModal'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; -import WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; const propTypes = { /** Bank account currently in setup */ diff --git a/src/pages/ReimbursementAccount/Enable2FAPrompt.js b/src/pages/ReimbursementAccount/Enable2FAPrompt.js index 33424669903f..c768f901508e 100644 --- a/src/pages/ReimbursementAccount/Enable2FAPrompt.js +++ b/src/pages/ReimbursementAccount/Enable2FAPrompt.js @@ -1,13 +1,13 @@ import React from 'react'; import {View} from 'react-native'; -import Text from '../../components/Text'; -import styles from '../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import Section from '../../components/Section'; -import * as Link from '../../libs/actions/Link'; -import ROUTES from '../../ROUTES'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/ReimbursementAccount/EnableStep.js b/src/pages/ReimbursementAccount/EnableStep.js index 6612a0b6ad2f..cb59a4bc97f5 100644 --- a/src/pages/ReimbursementAccount/EnableStep.js +++ b/src/pages/ReimbursementAccount/EnableStep.js @@ -1,29 +1,29 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; -import _ from 'underscore'; import {ScrollView} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import styles from '../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Text from '../../components/Text'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import Button from '../../components/Button'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import MenuItem from '../../components/MenuItem'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import getBankIcon from '../../components/Icon/BankIcons'; +import _ from 'underscore'; +import Button from '@components/Button'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import getBankIcon from '@components/Icon/BankIcons'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import userPropTypes from '@pages/settings/userPropTypes'; +import WorkspaceResetBankAccountModal from '@pages/workspace/WorkspaceResetBankAccountModal'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import * as BankAccounts from '@userActions/ReimbursementAccount'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; -import userPropTypes from '../settings/userPropTypes'; -import Section from '../../components/Section'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import * as Link from '../../libs/actions/Link'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import * as BankAccounts from '../../libs/actions/ReimbursementAccount'; -import WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal'; const propTypes = { /** Bank account currently in setup */ diff --git a/src/pages/ReimbursementAccount/IdentityForm.js b/src/pages/ReimbursementAccount/IdentityForm.js index 20c6e10ec64d..7cd66f3ba086 100644 --- a/src/pages/ReimbursementAccount/IdentityForm.js +++ b/src/pages/ReimbursementAccount/IdentityForm.js @@ -1,12 +1,12 @@ +import {subYears} from 'date-fns'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import {subYears} from 'date-fns'; import _ from 'underscore'; -import TextInput from '../../components/TextInput'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import DatePicker from '../../components/DatePicker'; +import DatePicker from '@components/DatePicker'; +import TextInput from '@components/TextInput'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; import AddressForm from './AddressForm'; const propTypes = { diff --git a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js index 22c5a45a21dc..35fa1261f9dc 100644 --- a/src/pages/ReimbursementAccount/ReimbursementAccountPage.js +++ b/src/pages/ReimbursementAccount/ReimbursementAccountPage.js @@ -1,39 +1,39 @@ -import _ from 'underscore'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; -import {withOnyx} from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import ONYXKEYS from '../../ONYXKEYS'; -import ReimbursementAccountLoadingIndicator from '../../components/ReimbursementAccountLoadingIndicator'; -import Navigation from '../../libs/Navigation/Navigation'; -import CONST from '../../CONST'; -import BankAccount from '../../libs/models/BankAccount'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import styles from '../../styles/styles'; -import getPlaidOAuthReceivedRedirectURI from '../../libs/getPlaidOAuthReceivedRedirectURI'; -import Text from '../../components/Text'; -import {withNetwork} from '../../components/OnyxProvider'; -import networkPropTypes from '../../components/networkPropTypes'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import ReimbursementAccountLoadingIndicator from '@components/ReimbursementAccountLoadingIndicator'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import getPlaidOAuthReceivedRedirectURI from '@libs/getPlaidOAuthReceivedRedirectURI'; +import BankAccount from '@libs/models/BankAccount'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import shouldReopenOnfido from '@libs/shouldReopenOnfido'; +import withPolicy from '@pages/workspace/withPolicy'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import ACHContractStep from './ACHContractStep'; import BankAccountStep from './BankAccountStep'; import CompanyStep from './CompanyStep'; import ContinueBankAccountSetup from './ContinueBankAccountSetup'; -import RequestorStep from './RequestorStep'; -import ValidationStep from './ValidationStep'; -import ACHContractStep from './ACHContractStep'; import EnableStep from './EnableStep'; -import ROUTES from '../../ROUTES'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; import reimbursementAccountDraftPropTypes from './ReimbursementAccountDraftPropTypes'; -import withPolicy from '../workspace/withPolicy'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import shouldReopenOnfido from '../../libs/shouldReopenOnfido'; +import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; +import RequestorStep from './RequestorStep'; +import ValidationStep from './ValidationStep'; const propTypes = { /** Plaid SDK token to use to initialize the widget */ diff --git a/src/pages/ReimbursementAccount/RequestorOnfidoStep.js b/src/pages/ReimbursementAccount/RequestorOnfidoStep.js index 86cf7ae71aa8..851869f9128d 100644 --- a/src/pages/ReimbursementAccount/RequestorOnfidoStep.js +++ b/src/pages/ReimbursementAccount/RequestorOnfidoStep.js @@ -1,18 +1,18 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {ScrollView} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import styles from '../../styles/styles'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import Onfido from '../../components/Onfido'; -import ONYXKEYS from '../../ONYXKEYS'; -import Growl from '../../libs/Growl'; -import CONST from '../../CONST'; -import FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import useLocalize from '../../hooks/useLocalize'; +import FullPageOfflineBlockingView from '@components/BlockingViews/FullPageOfflineBlockingView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Onfido from '@components/Onfido'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import Growl from '@libs/Growl'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; const propTypes = { diff --git a/src/pages/ReimbursementAccount/RequestorStep.js b/src/pages/ReimbursementAccount/RequestorStep.js index 86f1d5077eca..0eddb727d56d 100644 --- a/src/pages/ReimbursementAccount/RequestorStep.js +++ b/src/pages/ReimbursementAccount/RequestorStep.js @@ -1,22 +1,22 @@ +import _ from 'lodash'; +import PropTypes from 'prop-types'; import React, {useCallback, useMemo} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'lodash'; -import styles from '../../styles/styles'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import CONST from '../../CONST'; -import TextLink from '../../components/TextLink'; -import CheckboxWithLabel from '../../components/CheckboxWithLabel'; -import Text from '../../components/Text'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import IdentityForm from './IdentityForm'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import ONYXKEYS from '../../ONYXKEYS'; -import RequestorOnfidoStep from './RequestorOnfidoStep'; -import Form from '../../components/Form'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import useLocalize from '../../hooks/useLocalize'; import {reimbursementAccountPropTypes} from './reimbursementAccountPropTypes'; +import RequestorOnfidoStep from './RequestorOnfidoStep'; const propTypes = { onBackButtonPress: PropTypes.func.isRequired, diff --git a/src/pages/ReimbursementAccount/StepPropTypes.js b/src/pages/ReimbursementAccount/StepPropTypes.js index dc9734c6ecf7..04399230a1ab 100644 --- a/src/pages/ReimbursementAccount/StepPropTypes.js +++ b/src/pages/ReimbursementAccount/StepPropTypes.js @@ -1,7 +1,7 @@ import PropTypes from 'prop-types'; -import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; +import {withLocalizePropTypes} from '@components/withLocalize'; import reimbursementAccountDraftPropTypes from './ReimbursementAccountDraftPropTypes'; -import {withLocalizePropTypes} from '../../components/withLocalize'; +import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; export default { /** The bank account currently in setup */ diff --git a/src/pages/ReimbursementAccount/ValidationStep.js b/src/pages/ReimbursementAccount/ValidationStep.js index a63916db0784..5a0149aa3ba4 100644 --- a/src/pages/ReimbursementAccount/ValidationStep.js +++ b/src/pages/ReimbursementAccount/ValidationStep.js @@ -1,34 +1,34 @@ +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import styles from '../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import * as Report from '../../libs/actions/Report'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import TextInput from '../../components/TextInput'; -import Text from '../../components/Text'; -import BankAccount from '../../libs/models/BankAccount'; -import TextLink from '../../components/TextLink'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ValidationUtils from '../../libs/ValidationUtils'; +import Button from '@components/Button'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItem from '@components/MenuItem'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import BankAccount from '@libs/models/BankAccount'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import WorkspaceResetBankAccountModal from '@pages/workspace/WorkspaceResetBankAccountModal'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import Enable2FAPrompt from './Enable2FAPrompt'; import EnableStep from './EnableStep'; import * as ReimbursementAccountProps from './reimbursementAccountPropTypes'; -import Form from '../../components/Form'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import Section from '../../components/Section'; -import CONST from '../../CONST'; -import Button from '../../components/Button'; -import MenuItem from '../../components/MenuItem'; -import WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal'; -import Enable2FAPrompt from './Enable2FAPrompt'; -import ScreenWrapper from '../../components/ScreenWrapper'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/ReimbursementAccount/exampleCheckImage.js b/src/pages/ReimbursementAccount/exampleCheckImage.js index 071a2eb08289..c3fdbdd3984c 100644 --- a/src/pages/ReimbursementAccount/exampleCheckImage.js +++ b/src/pages/ReimbursementAccount/exampleCheckImage.js @@ -1,6 +1,6 @@ -import exampleCheckImageEn from '../../../assets/images/example-check-image-en.png'; -import exampleCheckImageEs from '../../../assets/images/example-check-image-es.png'; -import CONST from '../../CONST'; +import exampleCheckImageEn from '@assets/images/example-check-image-en.png'; +import exampleCheckImageEs from '@assets/images/example-check-image-es.png'; +import CONST from '@src/CONST'; const images = { [CONST.LOCALES.EN]: exampleCheckImageEn, diff --git a/src/pages/ReimbursementAccount/reimbursementAccountPropTypes.js b/src/pages/ReimbursementAccount/reimbursementAccountPropTypes.js index b1b5f30f7a76..8e94e2ad8f30 100644 --- a/src/pages/ReimbursementAccount/reimbursementAccountPropTypes.js +++ b/src/pages/ReimbursementAccount/reimbursementAccountPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import BankAccount from '../../libs/models/BankAccount'; +import BankAccount from '@libs/models/BankAccount'; const reimbursementAccountPropTypes = PropTypes.shape({ /** Whether we are loading the data via the API */ diff --git a/src/pages/ReportDetailsPage.js b/src/pages/ReportDetailsPage.js index 71eff57a246d..ef28102cc144 100644 --- a/src/pages/ReportDetailsPage.js +++ b/src/pages/ReportDetailsPage.js @@ -1,34 +1,34 @@ -import React, {useMemo} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useMemo} from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import {View, ScrollView} from 'react-native'; -import RoomHeaderAvatars from '../components/RoomHeaderAvatars'; -import compose from '../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import ONYXKEYS from '../ONYXKEYS'; -import ScreenWrapper from '../components/ScreenWrapper'; -import Navigation from '../libs/Navigation/Navigation'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import styles from '../styles/styles'; -import DisplayNames from '../components/DisplayNames'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import * as ReportUtils from '../libs/ReportUtils'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import * as Report from '../libs/actions/Report'; -import participantPropTypes from '../components/participantPropTypes'; -import * as Expensicons from '../components/Icon/Expensicons'; -import ROUTES from '../ROUTES'; -import MenuItem from '../components/MenuItem'; -import Text from '../components/Text'; -import CONST from '../CONST'; -import reportPropTypes from './reportPropTypes'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import DisplayNames from '@components/DisplayNames'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import MultipleAvatars from '@components/MultipleAvatars'; +import ParentNavigationSubtitle from '@components/ParentNavigationSubtitle'; +import participantPropTypes from '@components/participantPropTypes'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import RoomHeaderAvatars from '@components/RoomHeaderAvatars'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import withReportOrNotFound from './home/report/withReportOrNotFound'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import PressableWithoutFeedback from '../components/Pressable/PressableWithoutFeedback'; -import ParentNavigationSubtitle from '../components/ParentNavigationSubtitle'; -import MultipleAvatars from '../components/MultipleAvatars'; +import reportPropTypes from './reportPropTypes'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/ReportParticipantsPage.js b/src/pages/ReportParticipantsPage.js index db56a8006e76..c2179c53126b 100755 --- a/src/pages/ReportParticipantsPage.js +++ b/src/pages/ReportParticipantsPage.js @@ -1,26 +1,26 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import styles from '../styles/styles'; -import ONYXKEYS from '../ONYXKEYS'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import ScreenWrapper from '../components/ScreenWrapper'; -import OptionsList from '../components/OptionsList'; -import ROUTES from '../ROUTES'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import OptionsList from '@components/OptionsList'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import withReportOrNotFound from './home/report/withReportOrNotFound'; import personalDetailsPropType from './personalDetailsPropType'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; -import * as ReportUtils from '../libs/ReportUtils'; import reportPropTypes from './reportPropTypes'; -import withReportOrNotFound from './home/report/withReportOrNotFound'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import CONST from '../CONST'; -import * as UserUtils from '../libs/UserUtils'; -import * as LocalePhoneNumber from '../libs/LocalePhoneNumber'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/ReportWelcomeMessagePage.js b/src/pages/ReportWelcomeMessagePage.js index 11a9c7784c1d..c4d91088eff0 100644 --- a/src/pages/ReportWelcomeMessagePage.js +++ b/src/pages/ReportWelcomeMessagePage.js @@ -1,28 +1,28 @@ -import React, {useCallback, useRef, useState} from 'react'; +import {useFocusEffect} from '@react-navigation/native'; +import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import PropTypes from 'prop-types'; -import {withOnyx} from 'react-native-onyx'; +import React, {useCallback, useRef, useState} from 'react'; import {View} from 'react-native'; -import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import {useFocusEffect} from '@react-navigation/native'; -import compose from '../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import styles from '../styles/styles'; -import reportPropTypes from './reportPropTypes'; +import {withOnyx} from 'react-native-onyx'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import withReportOrNotFound from './home/report/withReportOrNotFound'; -import Text from '../components/Text'; -import TextInput from '../components/TextInput'; -import * as Report from '../libs/actions/Report'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import Form from '../components/Form'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import {policyPropTypes, policyDefaultProps} from './workspace/withPolicy'; -import ROUTES from '../ROUTES'; -import Navigation from '../libs/Navigation/Navigation'; -import updateMultilineInputRange from '../libs/UpdateMultilineInputRange'; +import reportPropTypes from './reportPropTypes'; +import {policyDefaultProps, policyPropTypes} from './workspace/withPolicy'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/RoomInvitePage.js b/src/pages/RoomInvitePage.js index 5021ccdc42d7..71585fefbcd3 100644 --- a/src/pages/RoomInvitePage.js +++ b/src/pages/RoomInvitePage.js @@ -1,31 +1,31 @@ -import React, {useEffect, useMemo, useState, useCallback} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import styles from '../styles/styles'; -import compose from '../libs/compose'; -import ONYXKEYS from '../ONYXKEYS'; -import FormAlertWithSubmitButton from '../components/FormAlertWithSubmitButton'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import CONST from '../CONST'; -import {policyDefaultProps, policyPropTypes} from './workspace/withPolicy'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import useLocalize from '@hooks/useLocalize'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import withReportOrNotFound from './home/report/withReportOrNotFound'; -import reportPropTypes from './reportPropTypes'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import ROUTES from '../ROUTES'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import useLocalize from '../hooks/useLocalize'; -import SelectionList from '../components/SelectionList'; -import * as Report from '../libs/actions/Report'; -import * as ReportUtils from '../libs/ReportUtils'; -import Permissions from '../libs/Permissions'; import personalDetailsPropType from './personalDetailsPropType'; -import * as Browser from '../libs/Browser'; +import reportPropTypes from './reportPropTypes'; +import {policyDefaultProps, policyPropTypes} from './workspace/withPolicy'; const propTypes = { /** Beta features list */ diff --git a/src/pages/RoomMembersPage.js b/src/pages/RoomMembersPage.js index 3a6e3b6fd90f..a2599b3382d7 100644 --- a/src/pages/RoomMembersPage.js +++ b/src/pages/RoomMembersPage.js @@ -1,34 +1,34 @@ -import React, {useMemo, useState, useCallback, useEffect} from 'react'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import styles from '../styles/styles'; -import compose from '../libs/compose'; -import CONST from '../CONST'; -import ONYXKEYS from '../ONYXKEYS'; -import ROUTES from '../ROUTES'; -import Navigation from '../libs/Navigation/Navigation'; -import ScreenWrapper from '../components/ScreenWrapper'; -import FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ConfirmModal from '../components/ConfirmModal'; -import Button from '../components/Button'; -import SelectionList from '../components/SelectionList'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Button from '@components/Button'; +import ConfirmModal from '@components/ConfirmModal'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import withReportOrNotFound from './home/report/withReportOrNotFound'; import personalDetailsPropType from './personalDetailsPropType'; import reportPropTypes from './reportPropTypes'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../components/withCurrentUserPersonalDetails'; -import * as PolicyUtils from '../libs/PolicyUtils'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import * as UserUtils from '../libs/UserUtils'; -import * as Report from '../libs/actions/Report'; -import * as ReportUtils from '../libs/ReportUtils'; -import Permissions from '../libs/Permissions'; -import Log from '../libs/Log'; -import * as Browser from '../libs/Browser'; const propTypes = { /** All personal details asssociated with user */ diff --git a/src/pages/SearchPage.js b/src/pages/SearchPage.js index c671e7b1a096..f312ef2aa307 100755 --- a/src/pages/SearchPage.js +++ b/src/pages/SearchPage.js @@ -1,27 +1,27 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React, {Component} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import OptionsSelector from '../components/OptionsSelector'; -import * as OptionsListUtils from '../libs/OptionsListUtils'; -import * as ReportUtils from '../libs/ReportUtils'; -import ONYXKEYS from '../ONYXKEYS'; -import styles from '../styles/styles'; -import Navigation from '../libs/Navigation/Navigation'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions'; -import * as Report from '../libs/actions/Report'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import ScreenWrapper from '../components/ScreenWrapper'; -import Timing from '../libs/actions/Timing'; -import CONST from '../CONST'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import compose from '../libs/compose'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import OptionsSelector from '@components/OptionsSelector'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Performance from '@libs/Performance'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import Timing from '@userActions/Timing'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import personalDetailsPropType from './personalDetailsPropType'; import reportPropTypes from './reportPropTypes'; -import Performance from '../libs/Performance'; -import networkPropTypes from '../components/networkPropTypes'; -import {withNetwork} from '../components/OnyxProvider'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/ShareCodePage.js b/src/pages/ShareCodePage.js index d6a6b79d3273..b2bc32b381ce 100644 --- a/src/pages/ShareCodePage.js +++ b/src/pages/ShareCodePage.js @@ -1,28 +1,28 @@ +import PropTypes from 'prop-types'; import React from 'react'; -import {View, ScrollView} from 'react-native'; +import {ScrollView, View} from 'react-native'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import ScreenWrapper from '../components/ScreenWrapper'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; -import Navigation from '../libs/Navigation/Navigation'; -import withLocalize, {withLocalizePropTypes} from '../components/withLocalize'; -import QRShareWithDownload from '../components/QRShare/QRShareWithDownload'; -import compose from '../libs/compose'; +import expensifyLogo from '@assets/images/expensify-logo-round-transparent.png'; +import ContextMenuItem from '@components/ContextMenuItem'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import QRShareWithDownload from '@components/QRShare/QRShareWithDownload'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withEnvironment from '@components/withEnvironment'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import Clipboard from '@libs/Clipboard'; +import compose from '@libs/compose'; +import getPlatform from '@libs/getPlatform'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as Url from '@libs/Url'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import reportPropTypes from './reportPropTypes'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../components/withCurrentUserPersonalDetails'; -import styles from '../styles/styles'; -import expensifyLogo from '../../assets/images/expensify-logo-round-transparent.png'; -import * as ReportUtils from '../libs/ReportUtils'; -import MenuItem from '../components/MenuItem'; -import Clipboard from '../libs/Clipboard'; -import * as Expensicons from '../components/Icon/Expensicons'; -import getPlatform from '../libs/getPlatform'; -import CONST from '../CONST'; -import ContextMenuItem from '../components/ContextMenuItem'; -import * as UserUtils from '../libs/UserUtils'; -import ROUTES from '../ROUTES'; -import withEnvironment from '../components/withEnvironment'; -import * as Url from '../libs/Url'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/TeachersUnite/ImTeacherPage.js b/src/pages/TeachersUnite/ImTeacherPage.js index a938abf81b79..62cd4529611b 100644 --- a/src/pages/TeachersUnite/ImTeacherPage.js +++ b/src/pages/TeachersUnite/ImTeacherPage.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as LoginUtils from '../../libs/LoginUtils'; +import * as LoginUtils from '@libs/LoginUtils'; +import ONYXKEYS from '@src/ONYXKEYS'; import ImTeacherUpdateEmailPage from './ImTeacherUpdateEmailPage'; import IntroSchoolPrincipalPage from './IntroSchoolPrincipalPage'; diff --git a/src/pages/TeachersUnite/ImTeacherUpdateEmailPage.js b/src/pages/TeachersUnite/ImTeacherUpdateEmailPage.js index de83c71a01c7..5d7c1d960e3a 100644 --- a/src/pages/TeachersUnite/ImTeacherUpdateEmailPage.js +++ b/src/pages/TeachersUnite/ImTeacherUpdateEmailPage.js @@ -1,15 +1,15 @@ import React from 'react'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import FixedFooter from '../../components/FixedFooter'; -import styles from '../../styles/styles'; -import Button from '../../components/Button'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import variables from '../../styles/variables'; -import useLocalize from '../../hooks/useLocalize'; -import BlockingView from '../../components/BlockingViews/BlockingView'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import Button from '@components/Button'; +import FixedFooter from '@components/FixedFooter'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import ROUTES from '@src/ROUTES'; const propTypes = {}; diff --git a/src/pages/TeachersUnite/IntroSchoolPrincipalPage.js b/src/pages/TeachersUnite/IntroSchoolPrincipalPage.js index 207ff0664053..25997fa9b307 100644 --- a/src/pages/TeachersUnite/IntroSchoolPrincipalPage.js +++ b/src/pages/TeachersUnite/IntroSchoolPrincipalPage.js @@ -1,24 +1,24 @@ +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Form from '../../components/Form'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import TextInput from '../../components/TextInput'; -import Text from '../../components/Text'; -import styles from '../../styles/styles'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import TeachersUnite from '../../libs/actions/TeachersUnite'; -import useLocalize from '../../hooks/useLocalize'; -import * as ValidationUtils from '../../libs/ValidationUtils'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import TeachersUnite from '@userActions/TeachersUnite'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Login list for the user that is signed in */ diff --git a/src/pages/TeachersUnite/KnowATeacherPage.js b/src/pages/TeachersUnite/KnowATeacherPage.js index f6506b96d3f2..d8dcc74faac0 100644 --- a/src/pages/TeachersUnite/KnowATeacherPage.js +++ b/src/pages/TeachersUnite/KnowATeacherPage.js @@ -1,25 +1,25 @@ -import React, {useCallback} from 'react'; +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Form from '../../components/Form'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import * as LoginUtils from '../../libs/LoginUtils'; -import TextInput from '../../components/TextInput'; -import Text from '../../components/Text'; -import styles from '../../styles/styles'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import TeachersUnite from '../../libs/actions/TeachersUnite'; -import useLocalize from '../../hooks/useLocalize'; -import * as ValidationUtils from '../../libs/ValidationUtils'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as LoginUtils from '@libs/LoginUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import TeachersUnite from '@userActions/TeachersUnite'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Login list for the user that is signed in */ diff --git a/src/pages/TeachersUnite/SaveTheWorldPage.js b/src/pages/TeachersUnite/SaveTheWorldPage.js index 5f252c960f8c..76e4c42294c1 100644 --- a/src/pages/TeachersUnite/SaveTheWorldPage.js +++ b/src/pages/TeachersUnite/SaveTheWorldPage.js @@ -1,20 +1,20 @@ +import _ from 'lodash'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import _ from 'lodash'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import SCREENS from '../../SCREENS'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import Text from '../../components/Text'; -import MenuItem from '../../components/MenuItem'; -import IllustratedHeaderPageLayout from '../../components/IllustratedHeaderPageLayout'; -import * as LottieAnimations from '../../components/LottieAnimations'; -import useLocalize from '../../hooks/useLocalize'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import MenuItem from '@components/MenuItem'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { /** The list of this user's policies */ diff --git a/src/pages/UnlinkLoginPage.js b/src/pages/UnlinkLoginPage.js index 67c073820bc0..ecaae0a84482 100644 --- a/src/pages/UnlinkLoginPage.js +++ b/src/pages/UnlinkLoginPage.js @@ -1,14 +1,14 @@ -import React, {useEffect} from 'react'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import {propTypes as validateLinkPropTypes, defaultProps as validateLinkDefaultProps} from './ValidateLoginPage/validateLinkPropTypes'; -import FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator'; -import Navigation from '../libs/Navigation/Navigation'; -import * as Session from '../libs/actions/Session'; -import ROUTES from '../ROUTES'; -import usePrevious from '../hooks/usePrevious'; -import ONYXKEYS from '../ONYXKEYS'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import usePrevious from '@hooks/usePrevious'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {defaultProps as validateLinkDefaultProps, propTypes as validateLinkPropTypes} from './ValidateLoginPage/validateLinkPropTypes'; const propTypes = { /** The accountID and validateCode are passed via the URL */ diff --git a/src/pages/ValidateLoginPage/index.js b/src/pages/ValidateLoginPage/index.js index 0af978172822..6939ee07f665 100644 --- a/src/pages/ValidateLoginPage/index.js +++ b/src/pages/ValidateLoginPage/index.js @@ -1,12 +1,12 @@ -import React, {useEffect} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import {propTypes as validateLinkPropTypes, defaultProps as validateLinkDefaultProps} from './validateLinkPropTypes'; -import FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Session from '../../libs/actions/Session'; -import Navigation from '../../libs/Navigation/Navigation'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps as validateLinkDefaultProps, propTypes as validateLinkPropTypes} from './validateLinkPropTypes'; const propTypes = { /** The accountID and validateCode are passed via the URL */ diff --git a/src/pages/ValidateLoginPage/index.website.js b/src/pages/ValidateLoginPage/index.website.js index 4ac12b3193f3..677abd70f6db 100644 --- a/src/pages/ValidateLoginPage/index.website.js +++ b/src/pages/ValidateLoginPage/index.website.js @@ -1,16 +1,16 @@ -import React, {useEffect} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import {propTypes as validateLinkPropTypes, defaultProps as validateLinkDefaultProps} from './validateLinkPropTypes'; -import FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; -import ValidateCodeModal from '../../components/ValidateCode/ValidateCodeModal'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Session from '../../libs/actions/Session'; -import ExpiredValidateCodeModal from '../../components/ValidateCode/ExpiredValidateCodeModal'; -import Navigation from '../../libs/Navigation/Navigation'; -import CONST from '../../CONST'; -import JustSignedInModal from '../../components/ValidateCode/JustSignedInModal'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import ExpiredValidateCodeModal from '@components/ValidateCode/ExpiredValidateCodeModal'; +import JustSignedInModal from '@components/ValidateCode/JustSignedInModal'; +import ValidateCodeModal from '@components/ValidateCode/ValidateCodeModal'; +import Navigation from '@libs/Navigation/Navigation'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps as validateLinkDefaultProps, propTypes as validateLinkPropTypes} from './validateLinkPropTypes'; const propTypes = { /** The accountID and validateCode are passed via the URL */ diff --git a/src/pages/home/HeaderView.js b/src/pages/home/HeaderView.js index 5b1a7f897c3e..36c48bd48fd2 100644 --- a/src/pages/home/HeaderView.js +++ b/src/pages/home/HeaderView.js @@ -4,37 +4,37 @@ import React, {memo} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import GoogleMeetIcon from '../../../assets/images/google-meet.svg'; -import ZoomIcon from '../../../assets/images/zoom-icon.svg'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; -import DisplayNames from '../../components/DisplayNames'; -import Icon from '../../components/Icon'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import MultipleAvatars from '../../components/MultipleAvatars'; -import ParentNavigationSubtitle from '../../components/ParentNavigationSubtitle'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; -import SubscriptAvatar from '../../components/SubscriptAvatar'; -import TaskHeaderActionButton from '../../components/TaskHeaderActionButton'; -import Text from '../../components/Text'; -import ThreeDotsMenu from '../../components/ThreeDotsMenu'; -import Tooltip from '../../components/Tooltip'; -import participantPropTypes from '../../components/participantPropTypes'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import * as HeaderUtils from '../../libs/HeaderUtils'; -import * as ReportActionsUtils from '../../libs/ReportActionsUtils'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as Link from '../../libs/actions/Link'; -import * as Report from '../../libs/actions/Report'; -import * as Task from '../../libs/actions/Task'; -import compose from '../../libs/compose'; -import * as Session from '../../libs/actions/Session'; -import styles from '../../styles/styles'; -import themeColors from '../../styles/themes/default'; -import reportPropTypes from '../reportPropTypes'; -import reportWithoutHasDraftSelector from '../../libs/OnyxSelectors/reportWithoutHasDraftSelector'; +import GoogleMeetIcon from '@assets/images/google-meet.svg'; +import ZoomIcon from '@assets/images/zoom-icon.svg'; +import DisplayNames from '@components/DisplayNames'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MultipleAvatars from '@components/MultipleAvatars'; +import ParentNavigationSubtitle from '@components/ParentNavigationSubtitle'; +import participantPropTypes from '@components/participantPropTypes'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import SubscriptAvatar from '@components/SubscriptAvatar'; +import TaskHeaderActionButton from '@components/TaskHeaderActionButton'; +import Text from '@components/Text'; +import ThreeDotsMenu from '@components/ThreeDotsMenu'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import * as HeaderUtils from '@libs/HeaderUtils'; +import reportWithoutHasDraftSelector from '@libs/OnyxSelectors/reportWithoutHasDraftSelector'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Link from '@userActions/Link'; +import * as Report from '@userActions/Report'; +import * as Session from '@userActions/Session'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Toggles the navigationMenu open and closed */ diff --git a/src/pages/home/ReportScreen.js b/src/pages/home/ReportScreen.js index f7ab1767aade..2ccc5246da81 100644 --- a/src/pages/home/ReportScreen.js +++ b/src/pages/home/ReportScreen.js @@ -1,45 +1,45 @@ -import React, {useRef, useState, useEffect, useMemo, useCallback} from 'react'; -import {withOnyx} from 'react-native-onyx'; import {useFocusEffect} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import {View} from 'react-native'; -import lodashGet from 'lodash/get'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import styles from '../../styles/styles'; -import ScreenWrapper from '../../components/ScreenWrapper'; +import Banner from '@components/Banner'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import DragAndDropProvider from '@components/DragAndDrop/Provider'; +import MoneyReportHeader from '@components/MoneyReportHeader'; +import MoneyRequestHeader from '@components/MoneyRequestHeader'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ReportActionsSkeletonView from '@components/ReportActionsSkeletonView'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TaskHeaderActionButton from '@components/TaskHeaderActionButton'; +import withCurrentReportID, {withCurrentReportIDDefaultProps, withCurrentReportIDPropTypes} from '@components/withCurrentReportID'; +import withViewportOffsetTop from '@components/withViewportOffsetTop'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import compose from '@libs/compose'; +import getIsReportFullyVisible from '@libs/getIsReportFullyVisible'; +import Navigation from '@libs/Navigation/Navigation'; +import reportWithoutHasDraftSelector from '@libs/OnyxSelectors/reportWithoutHasDraftSelector'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import Visibility from '@libs/Visibility'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportMetadataPropTypes from '@pages/reportMetadataPropTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as ComposerActions from '@userActions/Composer'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import HeaderView from './HeaderView'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as Report from '../../libs/actions/Report'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ReportUtils from '../../libs/ReportUtils'; -import ReportActionsView from './report/ReportActionsView'; -import ReportActionsSkeletonView from '../../components/ReportActionsSkeletonView'; import reportActionPropTypes from './report/reportActionPropTypes'; -import compose from '../../libs/compose'; -import Visibility from '../../libs/Visibility'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import useLocalize from '../../hooks/useLocalize'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; +import ReportActionsView from './report/ReportActionsView'; import ReportFooter from './report/ReportFooter'; -import Banner from '../../components/Banner'; -import reportPropTypes from '../reportPropTypes'; -import reportMetadataPropTypes from '../reportMetadataPropTypes'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import withViewportOffsetTop from '../../components/withViewportOffsetTop'; -import * as ReportActionsUtils from '../../libs/ReportActionsUtils'; -import personalDetailsPropType from '../personalDetailsPropType'; -import getIsReportFullyVisible from '../../libs/getIsReportFullyVisible'; -import MoneyRequestHeader from '../../components/MoneyRequestHeader'; -import MoneyReportHeader from '../../components/MoneyReportHeader'; -import * as ComposerActions from '../../libs/actions/Composer'; import {ActionListContext, ReactionListContext} from './ReportScreenContext'; -import TaskHeaderActionButton from '../../components/TaskHeaderActionButton'; -import DragAndDropProvider from '../../components/DragAndDrop/Provider'; -import usePrevious from '../../hooks/usePrevious'; -import CONST from '../../CONST'; -import withCurrentReportID, {withCurrentReportIDPropTypes, withCurrentReportIDDefaultProps} from '../../components/withCurrentReportID'; -import reportWithoutHasDraftSelector from '../../libs/OnyxSelectors/reportWithoutHasDraftSelector'; const propTypes = { /** Navigation route context info provided by react navigation */ diff --git a/src/pages/home/ReportScreenContext.ts b/src/pages/home/ReportScreenContext.ts index 83f76d8d8e2f..ab85c9e3afb9 100644 --- a/src/pages/home/ReportScreenContext.ts +++ b/src/pages/home/ReportScreenContext.ts @@ -1,4 +1,4 @@ -import {RefObject, createContext} from 'react'; +import {createContext, RefObject} from 'react'; import {FlatList, GestureResponderEvent} from 'react-native'; type ReactionListRef = { diff --git a/src/pages/home/report/AnimatedEmptyStateBackground.js b/src/pages/home/report/AnimatedEmptyStateBackground.js index 6d85e4d7fc85..6091347a24a2 100644 --- a/src/pages/home/report/AnimatedEmptyStateBackground.js +++ b/src/pages/home/report/AnimatedEmptyStateBackground.js @@ -1,11 +1,11 @@ import React from 'react'; import Animated, {SensorType, useAnimatedSensor, useAnimatedStyle, useSharedValue, withSpring} from 'react-native-reanimated'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import * as NumberUtils from '../../../libs/NumberUtils'; -import EmptyStateBackgroundImage from '../../../../assets/images/empty-state_background-fade.png'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import variables from '../../../styles/variables'; -import CONST from '../../../CONST'; +import EmptyStateBackgroundImage from '@assets/images/empty-state_background-fade.png'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as NumberUtils from '@libs/NumberUtils'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; const IMAGE_OFFSET_Y = 75; diff --git a/src/pages/home/report/ContextMenu/BaseReportActionContextMenu.js b/src/pages/home/report/ContextMenu/BaseReportActionContextMenu.js index 91fe38784e9c..18351f86a400 100755 --- a/src/pages/home/report/ContextMenu/BaseReportActionContextMenu.js +++ b/src/pages/home/report/ContextMenu/BaseReportActionContextMenu.js @@ -1,24 +1,24 @@ -import React, {useRef, useMemo, useState, memo} from 'react'; -import {InteractionManager, View} from 'react-native'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React, {memo, useMemo, useRef, useState} from 'react'; +import {InteractionManager, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import getReportActionContextMenuStyles from '../../../../styles/getReportActionContextMenuStyles'; -import ContextMenuItem from '../../../../components/ContextMenuItem'; -import {propTypes as genericReportActionContextMenuPropTypes, defaultProps as GenericReportActionContextMenuDefaultProps} from './genericReportActionContextMenuPropTypes'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; +import _ from 'underscore'; +import ContextMenuItem from '@components/ContextMenuItem'; +import {withBetas} from '@components/OnyxProvider'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useArrowKeyFocusManager from '@hooks/useArrowKeyFocusManager'; +import useKeyboardShortcut from '@hooks/useKeyboardShortcut'; +import useNetwork from '@hooks/useNetwork'; +import compose from '@libs/compose'; +import getReportActionContextMenuStyles from '@styles/getReportActionContextMenuStyles'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import ContextMenuActions, {CONTEXT_MENU_TYPES} from './ContextMenuActions'; -import compose from '../../../../libs/compose'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../../components/withWindowDimensions'; -import {withBetas} from '../../../../components/OnyxProvider'; -import * as Session from '../../../../libs/actions/Session'; +import {defaultProps as GenericReportActionContextMenuDefaultProps, propTypes as genericReportActionContextMenuPropTypes} from './genericReportActionContextMenuPropTypes'; import {hideContextMenu} from './ReportActionContextMenu'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import CONST from '../../../../CONST'; -import useArrowKeyFocusManager from '../../../../hooks/useArrowKeyFocusManager'; -import useKeyboardShortcut from '../../../../hooks/useKeyboardShortcut'; -import useNetwork from '../../../../hooks/useNetwork'; const propTypes = { /** String representing the context menu type [LINK, REPORT_ACTION] which controls context menu choices */ diff --git a/src/pages/home/report/ContextMenu/ContextMenuActions.js b/src/pages/home/report/ContextMenu/ContextMenuActions.js index 4e7118212b49..5a1266d15a42 100644 --- a/src/pages/home/report/ContextMenu/ContextMenuActions.js +++ b/src/pages/home/report/ContextMenu/ContextMenuActions.js @@ -1,27 +1,27 @@ -import React from 'react'; -import _ from 'underscore'; import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import lodashGet from 'lodash/get'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import * as Report from '../../../../libs/actions/Report'; -import * as Download from '../../../../libs/actions/Download'; -import Clipboard from '../../../../libs/Clipboard'; -import * as ReportUtils from '../../../../libs/ReportUtils'; -import * as ReportActionsUtils from '../../../../libs/ReportActionsUtils'; -import * as PersonalDetailsUtils from '../../../../libs/PersonalDetailsUtils'; -import ReportActionComposeFocusManager from '../../../../libs/ReportActionComposeFocusManager'; -import {hideContextMenu, showDeleteModal, clearActiveReportAction} from './ReportActionContextMenu'; -import CONST from '../../../../CONST'; -import getAttachmentDetails from '../../../../libs/fileDownload/getAttachmentDetails'; -import fileDownload from '../../../../libs/fileDownload'; -import addEncryptedAuthTokenToURL from '../../../../libs/addEncryptedAuthTokenToURL'; -import * as Environment from '../../../../libs/Environment/Environment'; -import Permissions from '../../../../libs/Permissions'; -import QuickEmojiReactions from '../../../../components/Reactions/QuickEmojiReactions'; -import MiniQuickEmojiReactions from '../../../../components/Reactions/MiniQuickEmojiReactions'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; -import * as Task from '../../../../libs/actions/Task'; +import React from 'react'; +import _ from 'underscore'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MiniQuickEmojiReactions from '@components/Reactions/MiniQuickEmojiReactions'; +import QuickEmojiReactions from '@components/Reactions/QuickEmojiReactions'; +import addEncryptedAuthTokenToURL from '@libs/addEncryptedAuthTokenToURL'; +import Clipboard from '@libs/Clipboard'; +import * as Environment from '@libs/Environment/Environment'; +import fileDownload from '@libs/fileDownload'; +import getAttachmentDetails from '@libs/fileDownload/getAttachmentDetails'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as Download from '@userActions/Download'; +import * as Report from '@userActions/Report'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; +import {clearActiveReportAction, hideContextMenu, showDeleteModal} from './ReportActionContextMenu'; /** * Gets the HTML version of the message in an action. diff --git a/src/pages/home/report/ContextMenu/MiniReportActionContextMenu/index.js b/src/pages/home/report/ContextMenu/MiniReportActionContextMenu/index.js index 60ed7ed989b0..ef28a2690af4 100644 --- a/src/pages/home/report/ContextMenu/MiniReportActionContextMenu/index.js +++ b/src/pages/home/report/ContextMenu/MiniReportActionContextMenu/index.js @@ -1,11 +1,14 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import {propTypes as genericReportActionContextMenuPropTypes, defaultProps as GenericReportActionContextMenuDefaultProps} from '../genericReportActionContextMenuPropTypes'; -import * as StyleUtils from '../../../../../styles/StyleUtils'; -import BaseReportActionContextMenu from '../BaseReportActionContextMenu'; -import CONST from '../../../../../CONST'; +import _ from 'underscore'; +import BaseReportActionContextMenu from '@pages/home/report/ContextMenu/BaseReportActionContextMenu'; +import { + defaultProps as GenericReportActionContextMenuDefaultProps, + propTypes as genericReportActionContextMenuPropTypes, +} from '@pages/home/report/ContextMenu/genericReportActionContextMenuPropTypes'; +import * as StyleUtils from '@styles/StyleUtils'; +import CONST from '@src/CONST'; const propTypes = { ..._.omit(genericReportActionContextMenuPropTypes, ['isMini']), diff --git a/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.js b/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.js index d342fc225d63..7f60b9d9b4d5 100644 --- a/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.js +++ b/src/pages/home/report/ContextMenu/PopoverReportActionContextMenu.js @@ -1,13 +1,13 @@ -import React, {forwardRef, useEffect, useState, useRef, useImperativeHandle, useCallback} from 'react'; +import React, {forwardRef, useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react'; import {Dimensions} from 'react-native'; import _ from 'underscore'; -import * as Report from '../../../../libs/actions/Report'; -import PopoverWithMeasuredContent from '../../../../components/PopoverWithMeasuredContent'; +import ConfirmModal from '@components/ConfirmModal'; +import PopoverWithMeasuredContent from '@components/PopoverWithMeasuredContent'; +import useLocalize from '@hooks/useLocalize'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as IOU from '@userActions/IOU'; +import * as Report from '@userActions/Report'; import BaseReportActionContextMenu from './BaseReportActionContextMenu'; -import ConfirmModal from '../../../../components/ConfirmModal'; -import * as ReportActionsUtils from '../../../../libs/ReportActionsUtils'; -import * as IOU from '../../../../libs/actions/IOU'; -import useLocalize from '../../../../hooks/useLocalize'; function PopoverReportActionContextMenu(_props, ref) { const {translate} = useLocalize(); diff --git a/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.android.js b/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.android.js index c533a9ca1e3b..93437393a5c5 100644 --- a/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.android.js +++ b/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.android.js @@ -1,6 +1,6 @@ import React from 'react'; -import {View, Animated} from 'react-native'; -import styles from '../../../../../styles/styles'; +import {Animated, View} from 'react-native'; +import styles from '@styles/styles'; import floatingMessageCounterContainerPropTypes from './floatingMessageCounterContainerPropTypes'; function FloatingMessageCounterContainer(props) { diff --git a/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.js b/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.js index 134312aa7af5..2137fa07b573 100644 --- a/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.js +++ b/src/pages/home/report/FloatingMessageCounter/FloatingMessageCounterContainer/index.js @@ -1,6 +1,6 @@ import React from 'react'; import {Animated} from 'react-native'; -import styles from '../../../../../styles/styles'; +import styles from '@styles/styles'; import floatingMessageCounterContainerPropTypes from './floatingMessageCounterContainerPropTypes'; function FloatingMessageCounterContainer(props) { diff --git a/src/pages/home/report/FloatingMessageCounter/index.js b/src/pages/home/report/FloatingMessageCounter/index.js index a4e2d25d9490..a2a0e9a3b21b 100644 --- a/src/pages/home/report/FloatingMessageCounter/index.js +++ b/src/pages/home/report/FloatingMessageCounter/index.js @@ -1,16 +1,16 @@ -import React, {useEffect, useMemo, useCallback} from 'react'; -import {Animated, View} from 'react-native'; import PropTypes from 'prop-types'; -import CONST from '../../../../CONST'; -import styles from '../../../../styles/styles'; -import Button from '../../../../components/Button'; -import Text from '../../../../components/Text'; -import Icon from '../../../../components/Icon'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import themeColors from '../../../../styles/themes/default'; -import useLocalize from '../../../../hooks/useLocalize'; +import React, {useCallback, useEffect, useMemo} from 'react'; +import {Animated, View} from 'react-native'; +import Button from '@components/Button'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import useNativeDriver from '@libs/useNativeDriver'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; import FloatingMessageCounterContainer from './FloatingMessageCounterContainer'; -import useNativeDriver from '../../../../libs/useNativeDriver'; const propTypes = { /** Whether the New Messages indicator is active */ diff --git a/src/pages/home/report/LinkPreviewer.js b/src/pages/home/report/LinkPreviewer.js index 4fcbb0dc0569..ebdab22a1c1e 100644 --- a/src/pages/home/report/LinkPreviewer.js +++ b/src/pages/home/report/LinkPreviewer.js @@ -1,14 +1,14 @@ -import React from 'react'; -import {View, Image} from 'react-native'; +import {uniqBy} from 'lodash'; import PropTypes from 'prop-types'; +import React from 'react'; +import {Image, View} from 'react-native'; import _ from 'underscore'; -import {uniqBy} from 'lodash'; -import Text from '../../../components/Text'; -import TextLink from '../../../components/TextLink'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; -import themeColors from '../../../styles/themes/default'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; const IMAGE_TYPES = ['jpg', 'jpeg', 'png']; const MAX_IMAGE_HEIGHT = 180; diff --git a/src/pages/home/report/ListBoundaryLoader/ListBoundaryLoader.js b/src/pages/home/report/ListBoundaryLoader/ListBoundaryLoader.js index 97e79e96dac7..861f6201a53f 100644 --- a/src/pages/home/report/ListBoundaryLoader/ListBoundaryLoader.js +++ b/src/pages/home/report/ListBoundaryLoader/ListBoundaryLoader.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {ActivityIndicator, View} from 'react-native'; -import PropTypes from 'prop-types'; -import ReportActionsSkeletonView from '../../../../components/ReportActionsSkeletonView'; -import CONST from '../../../../CONST'; -import useNetwork from '../../../../hooks/useNetwork'; -import styles, {stylesGenerator} from '../../../../styles/styles'; -import themeColors from '../../../../styles/themes/default'; +import ReportActionsSkeletonView from '@components/ReportActionsSkeletonView'; +import useNetwork from '@hooks/useNetwork'; +import styles, {stylesGenerator} from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; const propTypes = { /** type of rendered loader. Can be 'header' or 'footer' */ diff --git a/src/pages/home/report/ParticipantLocalTime.js b/src/pages/home/report/ParticipantLocalTime.js index 058346287b11..17f87f0391ea 100644 --- a/src/pages/home/report/ParticipantLocalTime.js +++ b/src/pages/home/report/ParticipantLocalTime.js @@ -1,13 +1,13 @@ -import React, {useState, useEffect} from 'react'; -import {View} from 'react-native'; import lodashGet from 'lodash/get'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import participantPropTypes from '../../../components/participantPropTypes'; -import Text from '../../../components/Text'; -import Timers from '../../../libs/Timers'; -import CONST from '../../../CONST'; -import DateUtils from '../../../libs/DateUtils'; +import React, {useEffect, useState} from 'react'; +import {View} from 'react-native'; +import participantPropTypes from '@components/participantPropTypes'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import DateUtils from '@libs/DateUtils'; +import Timers from '@libs/Timers'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Personal details of the participant */ diff --git a/src/pages/home/report/ReactionList/BaseReactionList.js b/src/pages/home/report/ReactionList/BaseReactionList.js index b082ca510edd..bd1ed436ceaa 100755 --- a/src/pages/home/report/ReactionList/BaseReactionList.js +++ b/src/pages/home/report/ReactionList/BaseReactionList.js @@ -1,19 +1,19 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; import React from 'react'; import {FlatList} from 'react-native'; -import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; -import styles from '../../../../styles/styles'; +import OptionRow from '@components/OptionRow'; +import participantPropTypes from '@components/participantPropTypes'; +import withWindowDimensions from '@components/withWindowDimensions'; +import Navigation from '@libs/Navigation/Navigation'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import HeaderReactionList from './HeaderReactionList'; -import * as UserUtils from '../../../../libs/UserUtils'; -import CONST from '../../../../CONST'; -import participantPropTypes from '../../../../components/participantPropTypes'; import reactionPropTypes from './reactionPropTypes'; -import OptionRow from '../../../../components/OptionRow'; -import variables from '../../../../styles/variables'; -import withWindowDimensions from '../../../../components/withWindowDimensions'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; const propTypes = { /** diff --git a/src/pages/home/report/ReactionList/HeaderReactionList.js b/src/pages/home/report/ReactionList/HeaderReactionList.js index 00611ca12409..49d61f05b191 100644 --- a/src/pages/home/report/ReactionList/HeaderReactionList.js +++ b/src/pages/home/report/ReactionList/HeaderReactionList.js @@ -1,13 +1,13 @@ import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import Text from '../../../../components/Text'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../../components/withWindowDimensions'; -import compose from '../../../../libs/compose'; -import * as EmojiUtils from '../../../../libs/EmojiUtils'; -import * as StyleUtils from '../../../../styles/StyleUtils'; -import styles from '../../../../styles/styles'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; import reactionPropTypes from './reactionPropTypes'; const propTypes = { diff --git a/src/pages/home/report/ReactionList/PopoverReactionList/BasePopoverReactionList.js b/src/pages/home/report/ReactionList/PopoverReactionList/BasePopoverReactionList.js index 32433cc80ca5..a06ed18de957 100644 --- a/src/pages/home/report/ReactionList/PopoverReactionList/BasePopoverReactionList.js +++ b/src/pages/home/report/ReactionList/PopoverReactionList/BasePopoverReactionList.js @@ -1,19 +1,19 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {Dimensions} from 'react-native'; -import lodashGet from 'lodash/get'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../../../components/withLocalize'; -import PopoverWithMeasuredContent from '../../../../../components/PopoverWithMeasuredContent'; -import BaseReactionList from '../BaseReactionList'; -import compose from '../../../../../libs/compose'; -import withCurrentUserPersonalDetails from '../../../../../components/withCurrentUserPersonalDetails'; -import * as PersonalDetailsUtils from '../../../../../libs/PersonalDetailsUtils'; -import * as EmojiUtils from '../../../../../libs/EmojiUtils'; -import CONST from '../../../../../CONST'; -import ONYXKEYS from '../../../../../ONYXKEYS'; -import EmojiReactionsPropTypes from '../../../../../components/Reactions/EmojiReactionsPropTypes'; +import _ from 'underscore'; +import PopoverWithMeasuredContent from '@components/PopoverWithMeasuredContent'; +import EmojiReactionsPropTypes from '@components/Reactions/EmojiReactionsPropTypes'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import BaseReactionList from '@pages/home/report/ReactionList/BaseReactionList'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { reportActionID: PropTypes.string, diff --git a/src/pages/home/report/ReactionList/PopoverReactionList/index.js b/src/pages/home/report/ReactionList/PopoverReactionList/index.js index 327885249843..9f1e7b3113fc 100644 --- a/src/pages/home/report/ReactionList/PopoverReactionList/index.js +++ b/src/pages/home/report/ReactionList/PopoverReactionList/index.js @@ -1,5 +1,5 @@ -import React, {forwardRef, useImperativeHandle, useRef, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {forwardRef, useImperativeHandle, useRef, useState} from 'react'; import BasePopoverReactionList from './BasePopoverReactionList'; const propTypes = { diff --git a/src/pages/home/report/ReportActionCompose/AttachmentPickerWithMenuItems.js b/src/pages/home/report/ReportActionCompose/AttachmentPickerWithMenuItems.js index 36cd9428b738..b4845e943a74 100644 --- a/src/pages/home/report/ReportActionCompose/AttachmentPickerWithMenuItems.js +++ b/src/pages/home/report/ReportActionCompose/AttachmentPickerWithMenuItems.js @@ -1,25 +1,25 @@ +import PropTypes from 'prop-types'; import React, {useMemo} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import styles from '../../../../styles/styles'; -import Icon from '../../../../components/Icon'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import AttachmentPicker from '../../../../components/AttachmentPicker'; -import * as Report from '../../../../libs/actions/Report'; -import PopoverMenu from '../../../../components/PopoverMenu'; -import CONST from '../../../../CONST'; -import Tooltip from '../../../../components/Tooltip/PopoverAnchorTooltip'; -import * as Browser from '../../../../libs/Browser'; -import PressableWithFeedback from '../../../../components/Pressable/PressableWithFeedback'; -import useLocalize from '../../../../hooks/useLocalize'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; -import * as ReportUtils from '../../../../libs/ReportUtils'; -import * as IOU from '../../../../libs/actions/IOU'; -import * as Task from '../../../../libs/actions/Task'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import Permissions from '../../../../libs/Permissions'; +import AttachmentPicker from '@components/AttachmentPicker'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PopoverMenu from '@components/PopoverMenu'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Tooltip from '@components/Tooltip/PopoverAnchorTooltip'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import * as Report from '@userActions/Report'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Beta features list */ diff --git a/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js b/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js index 3972b21b91a7..b7013fe4ff2f 100644 --- a/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js +++ b/src/pages/home/report/ReportActionCompose/ComposerWithSuggestions.js @@ -1,42 +1,42 @@ -import React, {useEffect, useCallback, useState, useRef, useMemo, useImperativeHandle} from 'react'; -import {View, NativeModules, findNodeHandle} from 'react-native'; +import {useIsFocused, useNavigation} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; +import React, {useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState} from 'react'; +import {findNodeHandle, NativeModules, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import {useIsFocused, useNavigation} from '@react-navigation/native'; -import styles from '../../../../styles/styles'; -import themeColors from '../../../../styles/themes/default'; -import Composer from '../../../../components/Composer'; -import containerComposeStyles from '../../../../styles/containerComposeStyles'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; -import CONST from '../../../../CONST'; -import * as Browser from '../../../../libs/Browser'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import * as KeyDownListener from '../../../../libs/KeyboardShortcut/KeyDownPressListener'; -import * as EmojiPickerActions from '../../../../libs/actions/EmojiPickerAction'; -import willBlurTextInputOnTapOutsideFunc from '../../../../libs/willBlurTextInputOnTapOutside'; -import ReportActionComposeFocusManager from '../../../../libs/ReportActionComposeFocusManager'; -import * as ComposerUtils from '../../../../libs/ComposerUtils'; -import * as Report from '../../../../libs/actions/Report'; -import usePrevious from '../../../../hooks/usePrevious'; -import * as EmojiUtils from '../../../../libs/EmojiUtils'; -import * as User from '../../../../libs/actions/User'; -import * as ReportUtils from '../../../../libs/ReportUtils'; -import * as SuggestionUtils from '../../../../libs/SuggestionUtils'; -import * as ReportActionsUtils from '../../../../libs/ReportActionsUtils'; -import canFocusInputOnScreenFocus from '../../../../libs/canFocusInputOnScreenFocus'; +import Composer from '@components/Composer'; +import withKeyboardState from '@components/withKeyboardState'; +import useDebounce from '@hooks/useDebounce'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import canFocusInputOnScreenFocus from '@libs/canFocusInputOnScreenFocus'; +import compose from '@libs/compose'; +import * as ComposerUtils from '@libs/ComposerUtils'; +import getDraftComment from '@libs/ComposerUtils/getDraftComment'; +import convertToLTRForComposer from '@libs/convertToLTRForComposer'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import focusWithDelay from '@libs/focusWithDelay'; +import * as KeyDownListener from '@libs/KeyboardShortcut/KeyDownPressListener'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as SuggestionUtils from '@libs/SuggestionUtils'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import willBlurTextInputOnTapOutsideFunc from '@libs/willBlurTextInputOnTapOutside'; +import containerComposeStyles from '@styles/containerComposeStyles'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as EmojiPickerActions from '@userActions/EmojiPickerAction'; +import * as InputFocus from '@userActions/InputFocus'; +import * as Report from '@userActions/Report'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import {defaultProps, propTypes} from './composerWithSuggestionsProps'; import SilentCommentUpdater from './SilentCommentUpdater'; import Suggestions from './Suggestions'; -import getDraftComment from '../../../../libs/ComposerUtils/getDraftComment'; -import useLocalize from '../../../../hooks/useLocalize'; -import compose from '../../../../libs/compose'; -import withKeyboardState from '../../../../components/withKeyboardState'; -import {propTypes, defaultProps} from './composerWithSuggestionsProps'; -import focusWithDelay from '../../../../libs/focusWithDelay'; -import useDebounce from '../../../../hooks/useDebounce'; -import updateMultilineInputRange from '../../../../libs/UpdateMultilineInputRange'; -import * as InputFocus from '../../../../libs/actions/InputFocus'; -import convertToLTRForComposer from '../../../../libs/convertToLTRForComposer'; const {RNTextInputReset} = NativeModules; diff --git a/src/pages/home/report/ReportActionCompose/ReportActionCompose.js b/src/pages/home/report/ReportActionCompose/ReportActionCompose.js index 891f7fbc903b..f090a942e097 100644 --- a/src/pages/home/report/ReportActionCompose/ReportActionCompose.js +++ b/src/pages/home/report/ReportActionCompose/ReportActionCompose.js @@ -1,43 +1,43 @@ -import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {PortalHost} from '@gorhom/portal'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import {View} from 'react-native'; -import _ from 'underscore'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; import {runOnJS, useAnimatedRef} from 'react-native-reanimated'; -import {PortalHost} from '@gorhom/portal'; -import styles from '../../../../styles/styles'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import * as Report from '../../../../libs/actions/Report'; -import ReportTypingIndicator from '../ReportTypingIndicator'; -import AttachmentModal from '../../../../components/AttachmentModal'; -import compose from '../../../../libs/compose'; -import willBlurTextInputOnTapOutsideFunc from '../../../../libs/willBlurTextInputOnTapOutside'; -import canFocusInputOnScreenFocus from '../../../../libs/canFocusInputOnScreenFocus'; -import CONST from '../../../../CONST'; -import * as ReportUtils from '../../../../libs/ReportUtils'; -import participantPropTypes from '../../../../components/participantPropTypes'; -import ParticipantLocalTime from '../ParticipantLocalTime'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../../components/withCurrentUserPersonalDetails'; -import {withNetwork} from '../../../../components/OnyxProvider'; -import * as User from '../../../../libs/actions/User'; -import EmojiPickerButton from '../../../../components/EmojiPicker/EmojiPickerButton'; -import * as DeviceCapabilities from '../../../../libs/DeviceCapabilities'; -import OfflineIndicator from '../../../../components/OfflineIndicator'; -import ExceededCommentLength from '../../../../components/ExceededCommentLength'; -import ReportDropUI from '../ReportDropUI'; -import reportPropTypes from '../../../reportPropTypes'; -import OfflineWithFeedback from '../../../../components/OfflineWithFeedback'; -import SendButton from './SendButton'; +import _ from 'underscore'; +import AttachmentModal from '@components/AttachmentModal'; +import EmojiPickerButton from '@components/EmojiPicker/EmojiPickerButton'; +import ExceededCommentLength from '@components/ExceededCommentLength'; +import OfflineIndicator from '@components/OfflineIndicator'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import participantPropTypes from '@components/participantPropTypes'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import canFocusInputOnScreenFocus from '@libs/canFocusInputOnScreenFocus'; +import compose from '@libs/compose'; +import getDraftComment from '@libs/ComposerUtils/getDraftComment'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import getModalState from '@libs/getModalState'; +import * as ReportUtils from '@libs/ReportUtils'; +import updatePropsPaperWorklet from '@libs/updatePropsPaperWorklet'; +import willBlurTextInputOnTapOutsideFunc from '@libs/willBlurTextInputOnTapOutside'; +import ParticipantLocalTime from '@pages/home/report/ParticipantLocalTime'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import ReportDropUI from '@pages/home/report/ReportDropUI'; +import ReportTypingIndicator from '@pages/home/report/ReportTypingIndicator'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as EmojiPickerActions from '@userActions/EmojiPickerAction'; +import * as Report from '@userActions/Report'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import AttachmentPickerWithMenuItems from './AttachmentPickerWithMenuItems'; import ComposerWithSuggestions from './ComposerWithSuggestions'; -import reportActionPropTypes from '../reportActionPropTypes'; -import useLocalize from '../../../../hooks/useLocalize'; -import getModalState from '../../../../libs/getModalState'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; -import * as EmojiPickerActions from '../../../../libs/actions/EmojiPickerAction'; -import getDraftComment from '../../../../libs/ComposerUtils/getDraftComment'; -import updatePropsPaperWorklet from '../../../../libs/updatePropsPaperWorklet'; +import SendButton from './SendButton'; const propTypes = { /** A method to call when the form is submitted */ diff --git a/src/pages/home/report/ReportActionCompose/SendButton.js b/src/pages/home/report/ReportActionCompose/SendButton.js index a97dd420e181..061251d13c01 100644 --- a/src/pages/home/report/ReportActionCompose/SendButton.js +++ b/src/pages/home/report/ReportActionCompose/SendButton.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {Gesture, GestureDetector} from 'react-native-gesture-handler'; -import PropTypes from 'prop-types'; -import styles from '../../../../styles/styles'; -import themeColors from '../../../../styles/themes/default'; -import Icon from '../../../../components/Icon'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import CONST from '../../../../CONST'; -import Tooltip from '../../../../components/Tooltip'; -import PressableWithFeedback from '../../../../components/Pressable/PressableWithFeedback'; -import useLocalize from '../../../../hooks/useLocalize'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; const propTypes = { /** Whether the button is disabled */ diff --git a/src/pages/home/report/ReportActionCompose/SilentCommentUpdater.js b/src/pages/home/report/ReportActionCompose/SilentCommentUpdater.js index 4347d6bde8b3..9aa997a892f4 100644 --- a/src/pages/home/report/ReportActionCompose/SilentCommentUpdater.js +++ b/src/pages/home/report/ReportActionCompose/SilentCommentUpdater.js @@ -1,9 +1,9 @@ +import PropTypes from 'prop-types'; import {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import usePrevious from '../../../../hooks/usePrevious'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import useLocalize from '../../../../hooks/useLocalize'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The comment of the report */ diff --git a/src/pages/home/report/ReportActionCompose/SuggestionEmoji.js b/src/pages/home/report/ReportActionCompose/SuggestionEmoji.js index d18b6fc2892d..dc84f77b6311 100644 --- a/src/pages/home/report/ReportActionCompose/SuggestionEmoji.js +++ b/src/pages/home/report/ReportActionCompose/SuggestionEmoji.js @@ -1,14 +1,14 @@ -import React, {useState, useCallback, useRef, useImperativeHandle} from 'react'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useCallback, useImperativeHandle, useRef, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../../../../CONST'; -import useArrowKeyFocusManager from '../../../../hooks/useArrowKeyFocusManager'; -import * as SuggestionsUtils from '../../../../libs/SuggestionUtils'; -import * as EmojiUtils from '../../../../libs/EmojiUtils'; -import EmojiSuggestions from '../../../../components/EmojiSuggestions'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import useLocalize from '../../../../hooks/useLocalize'; +import _ from 'underscore'; +import EmojiSuggestions from '@components/EmojiSuggestions'; +import useArrowKeyFocusManager from '@hooks/useArrowKeyFocusManager'; +import useLocalize from '@hooks/useLocalize'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import * as SuggestionsUtils from '@libs/SuggestionUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as SuggestionProps from './suggestionProps'; /** diff --git a/src/pages/home/report/ReportActionCompose/SuggestionMention.js b/src/pages/home/report/ReportActionCompose/SuggestionMention.js index 67d6ac0632eb..baf93da6ccc4 100644 --- a/src/pages/home/report/ReportActionCompose/SuggestionMention.js +++ b/src/pages/home/report/ReportActionCompose/SuggestionMention.js @@ -1,17 +1,17 @@ -import React, {useState, useCallback, useRef, useImperativeHandle, useEffect} from 'react'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../../../../CONST'; -import useArrowKeyFocusManager from '../../../../hooks/useArrowKeyFocusManager'; -import MentionSuggestions from '../../../../components/MentionSuggestions'; -import * as UserUtils from '../../../../libs/UserUtils'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import * as SuggestionsUtils from '../../../../libs/SuggestionUtils'; -import useLocalize from '../../../../hooks/useLocalize'; -import usePrevious from '../../../../hooks/usePrevious'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import personalDetailsPropType from '../../../personalDetailsPropType'; +import _ from 'underscore'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MentionSuggestions from '@components/MentionSuggestions'; +import useArrowKeyFocusManager from '@hooks/useArrowKeyFocusManager'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import * as SuggestionsUtils from '@libs/SuggestionUtils'; +import * as UserUtils from '@libs/UserUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as SuggestionProps from './suggestionProps'; /** diff --git a/src/pages/home/report/ReportActionCompose/Suggestions.js b/src/pages/home/report/ReportActionCompose/Suggestions.js index 5365aefe13e6..f39a70a960cf 100644 --- a/src/pages/home/report/ReportActionCompose/Suggestions.js +++ b/src/pages/home/report/ReportActionCompose/Suggestions.js @@ -1,7 +1,7 @@ -import React, {useRef, useCallback, useImperativeHandle} from 'react'; import PropTypes from 'prop-types'; -import SuggestionMention from './SuggestionMention'; +import React, {useCallback, useImperativeHandle, useRef} from 'react'; import SuggestionEmoji from './SuggestionEmoji'; +import SuggestionMention from './SuggestionMention'; import * as SuggestionProps from './suggestionProps'; const propTypes = { diff --git a/src/pages/home/report/ReportActionCompose/composerWithSuggestionsProps.js b/src/pages/home/report/ReportActionCompose/composerWithSuggestionsProps.js index 017b5aecb4ae..46d34d407b1c 100644 --- a/src/pages/home/report/ReportActionCompose/composerWithSuggestionsProps.js +++ b/src/pages/home/report/ReportActionCompose/composerWithSuggestionsProps.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import reportActionPropTypes from '../reportActionPropTypes'; -import CONST from '../../../../CONST'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import CONST from '@src/CONST'; const propTypes = { /** Details about any modals being used */ diff --git a/src/pages/home/report/ReportActionItem.js b/src/pages/home/report/ReportActionItem.js index d44c7b8ee4d1..a7a3bc0739f3 100644 --- a/src/pages/home/report/ReportActionItem.js +++ b/src/pages/home/report/ReportActionItem.js @@ -1,78 +1,78 @@ -import _ from 'underscore'; import lodashGet from 'lodash/get'; -import React, {useState, useRef, useEffect, memo, useCallback, useContext, useMemo} from 'react'; -import {InteractionManager, View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {memo, useCallback, useContext, useEffect, useMemo, useRef, useState} from 'react'; +import {InteractionManager, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import reportActionPropTypes from './reportActionPropTypes'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import PressableWithSecondaryInteraction from '../../../components/PressableWithSecondaryInteraction'; -import Hoverable from '../../../components/Hoverable'; -import Button from '../../../components/Button'; -import ReportActionItemSingle from './ReportActionItemSingle'; -import ReportActionItemGrouped from './ReportActionItemGrouped'; -import MoneyRequestAction from '../../../components/ReportActionItem/MoneyRequestAction'; -import ReportActionItemMessage from './ReportActionItemMessage'; -import UnreadActionIndicator from '../../../components/UnreadActionIndicator'; -import ReportActionItemMessageEdit from './ReportActionItemMessageEdit'; -import ReportActionItemCreated from './ReportActionItemCreated'; -import ReportActionItemThread from './ReportActionItemThread'; -import LinkPreviewer from './LinkPreviewer'; -import compose from '../../../libs/compose'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import ControlSelection from '../../../libs/ControlSelection'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; +import _ from 'underscore'; +import Button from '@components/Button'; +import DisplayNames from '@components/DisplayNames'; +import Hoverable from '@components/Hoverable'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import InlineSystemMessage from '@components/InlineSystemMessage'; +import KYCWall from '@components/KYCWall'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {usePersonalDetails, withBlockedFromConcierge, withNetwork, withReportActionsDrafts} from '@components/OnyxProvider'; +import PressableWithSecondaryInteraction from '@components/PressableWithSecondaryInteraction'; +import EmojiReactionsPropTypes from '@components/Reactions/EmojiReactionsPropTypes'; +import ReportActionItemEmojiReactions from '@components/Reactions/ReportActionItemEmojiReactions'; +import RenderHTML from '@components/RenderHTML'; +import ChronosOOOListActions from '@components/ReportActionItem/ChronosOOOListActions'; +import MoneyReportView from '@components/ReportActionItem/MoneyReportView'; +import MoneyRequestAction from '@components/ReportActionItem/MoneyRequestAction'; +import MoneyRequestView from '@components/ReportActionItem/MoneyRequestView'; +import RenameAction from '@components/ReportActionItem/RenameAction'; +import ReportPreview from '@components/ReportActionItem/ReportPreview'; +import TaskAction from '@components/ReportActionItem/TaskAction'; +import TaskPreview from '@components/ReportActionItem/TaskPreview'; +import TaskView from '@components/ReportActionItem/TaskView'; +import {ShowContextMenuContext} from '@components/ShowContextMenuContext'; +import Text from '@components/Text'; +import UnreadActionIndicator from '@components/UnreadActionIndicator'; +import withLocalize from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import usePrevious from '@hooks/usePrevious'; +import compose from '@libs/compose'; +import ControlSelection from '@libs/ControlSelection'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import focusTextInputAfterAnimation from '@libs/focusTextInputAfterAnimation'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import SelectionScraper from '@libs/SelectionScraper'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import {ReactionListContext} from '@pages/home/ReportScreenContext'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as EmojiPickerAction from '@userActions/EmojiPickerAction'; +import * as store from '@userActions/ReimbursementAccount/store'; +import * as Report from '@userActions/Report'; +import * as ReportActions from '@userActions/ReportActions'; +import * as Session from '@userActions/Session'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import * as ContextMenuActions from './ContextMenu/ContextMenuActions'; import MiniReportActionContextMenu from './ContextMenu/MiniReportActionContextMenu'; import * as ReportActionContextMenu from './ContextMenu/ReportActionContextMenu'; -import * as ContextMenuActions from './ContextMenu/ContextMenuActions'; -import * as EmojiPickerAction from '../../../libs/actions/EmojiPickerAction'; -import {usePersonalDetails, withBlockedFromConcierge, withNetwork, withReportActionsDrafts} from '../../../components/OnyxProvider'; -import RenameAction from '../../../components/ReportActionItem/RenameAction'; -import InlineSystemMessage from '../../../components/InlineSystemMessage'; -import styles from '../../../styles/styles'; -import SelectionScraper from '../../../libs/SelectionScraper'; -import focusTextInputAfterAnimation from '../../../libs/focusTextInputAfterAnimation'; -import * as User from '../../../libs/actions/User'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import * as ReportActions from '../../../libs/actions/ReportActions'; -import reportPropTypes from '../../reportPropTypes'; -import {ShowContextMenuContext} from '../../../components/ShowContextMenuContext'; -import ChronosOOOListActions from '../../../components/ReportActionItem/ChronosOOOListActions'; -import ReportActionItemEmojiReactions from '../../../components/Reactions/ReportActionItemEmojiReactions'; -import * as Report from '../../../libs/actions/Report'; -import withLocalize from '../../../components/withLocalize'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import Text from '../../../components/Text'; -import DisplayNames from '../../../components/DisplayNames'; -import ReportPreview from '../../../components/ReportActionItem/ReportPreview'; -import ReportActionItemDraft from './ReportActionItemDraft'; -import TaskPreview from '../../../components/ReportActionItem/TaskPreview'; -import TaskAction from '../../../components/ReportActionItem/TaskAction'; -import EmojiReactionsPropTypes from '../../../components/Reactions/EmojiReactionsPropTypes'; -import TaskView from '../../../components/ReportActionItem/TaskView'; -import MoneyReportView from '../../../components/ReportActionItem/MoneyReportView'; -import * as Session from '../../../libs/actions/Session'; -import MoneyRequestView from '../../../components/ReportActionItem/MoneyRequestView'; import {hideContextMenu} from './ContextMenu/ReportActionContextMenu'; -import * as PersonalDetailsUtils from '../../../libs/PersonalDetailsUtils'; -import * as store from '../../../libs/actions/ReimbursementAccount/store'; -import * as BankAccounts from '../../../libs/actions/BankAccounts'; -import {ReactionListContext} from '../ReportScreenContext'; -import usePrevious from '../../../hooks/usePrevious'; -import Permissions from '../../../libs/Permissions'; -import themeColors from '../../../styles/themes/default'; +import LinkPreviewer from './LinkPreviewer'; import ReportActionItemBasicMessage from './ReportActionItemBasicMessage'; -import RenderHTML from '../../../components/RenderHTML'; +import ReportActionItemCreated from './ReportActionItemCreated'; +import ReportActionItemDraft from './ReportActionItemDraft'; +import ReportActionItemGrouped from './ReportActionItemGrouped'; +import ReportActionItemMessage from './ReportActionItemMessage'; +import ReportActionItemMessageEdit from './ReportActionItemMessageEdit'; +import ReportActionItemSingle from './ReportActionItemSingle'; +import ReportActionItemThread from './ReportActionItemThread'; +import reportActionPropTypes from './reportActionPropTypes'; import ReportAttachmentsContext from './ReportAttachmentsContext'; -import ROUTES from '../../../ROUTES'; -import Navigation from '../../../libs/Navigation/Navigation'; -import KYCWall from '../../../components/KYCWall'; -import userWalletPropTypes from '../../EnablePayments/userWalletPropTypes'; const propTypes = { ...windowDimensionsPropTypes, diff --git a/src/pages/home/report/ReportActionItemBasicMessage.js b/src/pages/home/report/ReportActionItemBasicMessage.js index fa33826d39a4..87997b29b833 100644 --- a/src/pages/home/report/ReportActionItemBasicMessage.js +++ b/src/pages/home/report/ReportActionItemBasicMessage.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; +import Text from '@components/Text'; +import styles from '@styles/styles'; const propTypes = { message: PropTypes.string.isRequired, diff --git a/src/pages/home/report/ReportActionItemCreated.js b/src/pages/home/report/ReportActionItemCreated.js index 50b4a3eb6148..10ebb13302b2 100644 --- a/src/pages/home/report/ReportActionItemCreated.js +++ b/src/pages/home/report/ReportActionItemCreated.js @@ -1,25 +1,25 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {memo} from 'react'; import {View} from 'react-native'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import ONYXKEYS from '../../../ONYXKEYS'; -import ReportWelcomeText from '../../../components/ReportWelcomeText'; -import participantPropTypes from '../../../components/participantPropTypes'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import styles from '../../../styles/styles'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import * as Report from '../../../libs/actions/Report'; -import reportPropTypes from '../../reportPropTypes'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import compose from '../../../libs/compose'; -import withLocalize from '../../../components/withLocalize'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import MultipleAvatars from '../../../components/MultipleAvatars'; -import CONST from '../../../CONST'; +import MultipleAvatars from '@components/MultipleAvatars'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import participantPropTypes from '@components/participantPropTypes'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ReportWelcomeText from '@components/ReportWelcomeText'; +import withLocalize from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import reportWithoutHasDraftSelector from '@libs/OnyxSelectors/reportWithoutHasDraftSelector'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import AnimatedEmptyStateBackground from './AnimatedEmptyStateBackground'; -import reportWithoutHasDraftSelector from '../../../libs/OnyxSelectors/reportWithoutHasDraftSelector'; const propTypes = { /** The id of the report */ diff --git a/src/pages/home/report/ReportActionItemDate.js b/src/pages/home/report/ReportActionItemDate.js index 0e6af2e95636..346a1c2683f0 100644 --- a/src/pages/home/report/ReportActionItemDate.js +++ b/src/pages/home/report/ReportActionItemDate.js @@ -1,10 +1,10 @@ -import React, {memo} from 'react'; import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import compose from '../../../libs/compose'; -import Text from '../../../components/Text'; -import {withCurrentDate} from '../../../components/OnyxProvider'; +import React, {memo} from 'react'; +import {withCurrentDate} from '@components/OnyxProvider'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; const propTypes = { /** UTC timestamp for when the action was created */ diff --git a/src/pages/home/report/ReportActionItemDraft.js b/src/pages/home/report/ReportActionItemDraft.js index b3b66994fb9c..500c4146e608 100644 --- a/src/pages/home/report/ReportActionItemDraft.js +++ b/src/pages/home/report/ReportActionItemDraft.js @@ -1,7 +1,7 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; +import styles from '@styles/styles'; const propTypes = { /** Children view component for this action item */ diff --git a/src/pages/home/report/ReportActionItemFragment.js b/src/pages/home/report/ReportActionItemFragment.js index 57b51ef50519..24e1c6bc1ef6 100644 --- a/src/pages/home/report/ReportActionItemFragment.js +++ b/src/pages/home/report/ReportActionItemFragment.js @@ -1,24 +1,24 @@ -import React, {memo} from 'react'; -import PropTypes from 'prop-types'; import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; +import React, {memo} from 'react'; +import avatarPropTypes from '@components/avatarPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import RenderHTML from '@components/RenderHTML'; +import Text from '@components/Text'; +import UserDetailsTooltip from '@components/UserDetailsTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import ZeroWidthView from '@components/ZeroWidthView'; +import compose from '@libs/compose'; +import convertToLTR from '@libs/convertToLTR'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import editedLabelStyles from '@styles/editedLabelStyles'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; import reportActionFragmentPropTypes from './reportActionFragmentPropTypes'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; -import themeColors from '../../../styles/themes/default'; -import RenderHTML from '../../../components/RenderHTML'; -import Text from '../../../components/Text'; -import * as EmojiUtils from '../../../libs/EmojiUtils'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; -import compose from '../../../libs/compose'; -import convertToLTR from '../../../libs/convertToLTR'; -import {withNetwork} from '../../../components/OnyxProvider'; -import CONST from '../../../CONST'; -import editedLabelStyles from '../../../styles/editedLabelStyles'; -import UserDetailsTooltip from '../../../components/UserDetailsTooltip'; -import avatarPropTypes from '../../../components/avatarPropTypes'; -import ZeroWidthView from '../../../components/ZeroWidthView'; const propTypes = { /** Users accountID */ diff --git a/src/pages/home/report/ReportActionItemGrouped.js b/src/pages/home/report/ReportActionItemGrouped.js index e60bf01835f8..2d55ecbbe037 100644 --- a/src/pages/home/report/ReportActionItemGrouped.js +++ b/src/pages/home/report/ReportActionItemGrouped.js @@ -1,7 +1,7 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; +import styles from '@styles/styles'; const propTypes = { /** Children view component for this action item */ diff --git a/src/pages/home/report/ReportActionItemMessage.js b/src/pages/home/report/ReportActionItemMessage.js index 88223e6480ff..37aaa5adf287 100644 --- a/src/pages/home/report/ReportActionItemMessage.js +++ b/src/pages/home/report/ReportActionItemMessage.js @@ -1,14 +1,14 @@ -import React from 'react'; -import {View, Text} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; +import {Text, View} from 'react-native'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import styles from '../../../styles/styles'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import styles from '@styles/styles'; import ReportActionItemFragment from './ReportActionItemFragment'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; import reportActionPropTypes from './reportActionPropTypes'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; const propTypes = { /** The report action */ diff --git a/src/pages/home/report/ReportActionItemMessageEdit.js b/src/pages/home/report/ReportActionItemMessageEdit.js index be2f10f2f053..589b4c367c25 100644 --- a/src/pages/home/report/ReportActionItemMessageEdit.js +++ b/src/pages/home/report/ReportActionItemMessageEdit.js @@ -1,43 +1,43 @@ +import ExpensiMark from 'expensify-common/lib/ExpensiMark'; +import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; -import React, {useState, useRef, useMemo, useEffect, useCallback} from 'react'; -import {InteractionManager, Keyboard, View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {InteractionManager, Keyboard, View} from 'react-native'; import _ from 'underscore'; -import ExpensiMark from 'expensify-common/lib/ExpensiMark'; -import Str from 'expensify-common/lib/str'; -import reportActionPropTypes from './reportActionPropTypes'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; -import containerComposeStyles from '../../../styles/containerComposeStyles'; -import Composer from '../../../components/Composer'; -import * as Report from '../../../libs/actions/Report'; -import setShouldShowComposeInputKeyboardAware from '../../../libs/setShouldShowComposeInputKeyboardAware'; -import ReportActionComposeFocusManager from '../../../libs/ReportActionComposeFocusManager'; -import EmojiPickerButton from '../../../components/EmojiPicker/EmojiPickerButton'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import Tooltip from '../../../components/Tooltip'; +import Composer from '@components/Composer'; +import EmojiPickerButton from '@components/EmojiPicker/EmojiPickerButton'; +import ExceededCommentLength from '@components/ExceededCommentLength'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import refPropTypes from '@components/refPropTypes'; +import Tooltip from '@components/Tooltip'; +import useKeyboardState from '@hooks/useKeyboardState'; +import useLocalize from '@hooks/useLocalize'; +import useReportScrollManager from '@hooks/useReportScrollManager'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import * as ComposerUtils from '@libs/ComposerUtils'; +import * as EmojiUtils from '@libs/EmojiUtils'; +import focusWithDelay from '@libs/focusWithDelay'; +import onyxSubscribe from '@libs/onyxSubscribe'; +import ReportActionComposeFocusManager from '@libs/ReportActionComposeFocusManager'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import setShouldShowComposeInputKeyboardAware from '@libs/setShouldShowComposeInputKeyboardAware'; +import reportPropTypes from '@pages/reportPropTypes'; +import containerComposeStyles from '@styles/containerComposeStyles'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as EmojiPickerAction from '@userActions/EmojiPickerAction'; +import * as InputFocus from '@userActions/InputFocus'; +import * as Report from '@userActions/Report'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as ReportActionContextMenu from './ContextMenu/ReportActionContextMenu'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import * as EmojiUtils from '../../../libs/EmojiUtils'; -import reportPropTypes from '../../reportPropTypes'; -import ExceededCommentLength from '../../../components/ExceededCommentLength'; -import CONST from '../../../CONST'; -import refPropTypes from '../../../components/refPropTypes'; -import * as ComposerUtils from '../../../libs/ComposerUtils'; -import * as User from '../../../libs/actions/User'; -import PressableWithFeedback from '../../../components/Pressable/PressableWithFeedback'; -import useLocalize from '../../../hooks/useLocalize'; -import useKeyboardState from '../../../hooks/useKeyboardState'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import useReportScrollManager from '../../../hooks/useReportScrollManager'; -import * as EmojiPickerAction from '../../../libs/actions/EmojiPickerAction'; -import focusWithDelay from '../../../libs/focusWithDelay'; -import * as Browser from '../../../libs/Browser'; -import * as InputFocus from '../../../libs/actions/InputFocus'; -import onyxSubscribe from '../../../libs/onyxSubscribe'; -import ONYXKEYS from '../../../ONYXKEYS'; +import reportActionPropTypes from './reportActionPropTypes'; const propTypes = { /** All the data of the action */ diff --git a/src/pages/home/report/ReportActionItemParentAction.js b/src/pages/home/report/ReportActionItemParentAction.js index b67707031372..e2274ce41ae0 100644 --- a/src/pages/home/report/ReportActionItemParentAction.js +++ b/src/pages/home/report/ReportActionItemParentAction.js @@ -1,21 +1,21 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import * as Report from '../../../libs/actions/Report'; -import reportPropTypes from '../../reportPropTypes'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import compose from '../../../libs/compose'; -import withLocalize from '../../../components/withLocalize'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import withLocalize from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as Report from '@userActions/Report'; +import ONYXKEYS from '@src/ONYXKEYS'; +import AnimatedEmptyStateBackground from './AnimatedEmptyStateBackground'; import ReportActionItem from './ReportActionItem'; import reportActionPropTypes from './reportActionPropTypes'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import AnimatedEmptyStateBackground from './AnimatedEmptyStateBackground'; const propTypes = { /** Flag to show, hide the thread divider line */ diff --git a/src/pages/home/report/ReportActionItemSingle.js b/src/pages/home/report/ReportActionItemSingle.js index fc38b102b8e8..329952769a4f 100644 --- a/src/pages/home/report/ReportActionItemSingle.js +++ b/src/pages/home/report/ReportActionItemSingle.js @@ -1,36 +1,36 @@ import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useMemo} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import reportActionPropTypes from './reportActionPropTypes'; -import ReportActionItemFragment from './ReportActionItemFragment'; -import styles from '../../../styles/styles'; +import _ from 'underscore'; +import Avatar from '@components/Avatar'; +import MultipleAvatars from '@components/MultipleAvatars'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {usePersonalDetails} from '@components/OnyxProvider'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import SubscriptAvatar from '@components/SubscriptAvatar'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import UserDetailsTooltip from '@components/UserDetailsTooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import ControlSelection from '@libs/ControlSelection'; +import DateUtils from '@libs/DateUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import ReportActionItemDate from './ReportActionItemDate'; -import Avatar from '../../../components/Avatar'; -import compose from '../../../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import {usePersonalDetails} from '../../../components/OnyxProvider'; -import ControlSelection from '../../../libs/ControlSelection'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import CONST from '../../../CONST'; -import SubscriptAvatar from '../../../components/SubscriptAvatar'; -import reportPropTypes from '../../reportPropTypes'; -import * as UserUtils from '../../../libs/UserUtils'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import UserDetailsTooltip from '../../../components/UserDetailsTooltip'; -import MultipleAvatars from '../../../components/MultipleAvatars'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import themeColors from '../../../styles/themes/default'; -import Permissions from '../../../libs/Permissions'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Text from '../../../components/Text'; -import Tooltip from '../../../components/Tooltip'; -import DateUtils from '../../../libs/DateUtils'; +import ReportActionItemFragment from './ReportActionItemFragment'; +import reportActionPropTypes from './reportActionPropTypes'; const propTypes = { /** All the data of the action */ diff --git a/src/pages/home/report/ReportActionItemThread.js b/src/pages/home/report/ReportActionItemThread.js index 9c688911759e..8d4b76a3c508 100644 --- a/src/pages/home/report/ReportActionItemThread.js +++ b/src/pages/home/report/ReportActionItemThread.js @@ -1,15 +1,15 @@ -import React from 'react'; -import {View, Text} from 'react-native'; import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import * as Report from '../../../libs/actions/Report'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import CONST from '../../../CONST'; -import avatarPropTypes from '../../../components/avatarPropTypes'; -import MultipleAvatars from '../../../components/MultipleAvatars'; -import compose from '../../../libs/compose'; -import PressableWithSecondaryInteraction from '../../../components/PressableWithSecondaryInteraction'; +import React from 'react'; +import {Text, View} from 'react-native'; +import avatarPropTypes from '@components/avatarPropTypes'; +import MultipleAvatars from '@components/MultipleAvatars'; +import PressableWithSecondaryInteraction from '@components/PressableWithSecondaryInteraction'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; const propTypes = { /** List of participant icons for the thread */ diff --git a/src/pages/home/report/ReportActionsList.js b/src/pages/home/report/ReportActionsList.js index 300b1921545d..9549513ed368 100644 --- a/src/pages/home/report/ReportActionsList.js +++ b/src/pages/home/report/ReportActionsList.js @@ -1,29 +1,29 @@ +import {useRoute} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import Animated, {useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated'; import _ from 'underscore'; -import {useRoute} from '@react-navigation/native'; -import lodashGet from 'lodash/get'; -import CONST from '../../../CONST'; -import InvertedFlatList from '../../../components/InvertedFlatList'; -import {withPersonalDetails} from '../../../components/OnyxProvider'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import useNetwork from '../../../hooks/useNetwork'; -import useLocalize from '../../../hooks/useLocalize'; -import useReportScrollManager from '../../../hooks/useReportScrollManager'; -import DateUtils from '../../../libs/DateUtils'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as Report from '../../../libs/actions/Report'; -import compose from '../../../libs/compose'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; -import reportPropTypes from '../../reportPropTypes'; +import InvertedFlatList from '@components/InvertedFlatList'; +import {withPersonalDetails} from '@components/OnyxProvider'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import useReportScrollManager from '@hooks/useReportScrollManager'; +import compose from '@libs/compose'; +import DateUtils from '@libs/DateUtils'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; import FloatingMessageCounter from './FloatingMessageCounter'; -import ReportActionsListItemRenderer from './ReportActionsListItemRenderer'; -import reportActionPropTypes from './reportActionPropTypes'; import ListBoundaryLoader from './ListBoundaryLoader/ListBoundaryLoader'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; +import reportActionPropTypes from './reportActionPropTypes'; +import ReportActionsListItemRenderer from './ReportActionsListItemRenderer'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/home/report/ReportActionsListItemRenderer.js b/src/pages/home/report/ReportActionsListItemRenderer.js index 40b9ee9142b7..0273a3f31805 100644 --- a/src/pages/home/report/ReportActionsListItemRenderer.js +++ b/src/pages/home/report/ReportActionsListItemRenderer.js @@ -1,10 +1,10 @@ import PropTypes from 'prop-types'; import React, {memo} from 'react'; import _ from 'underscore'; -import CONST from '../../../CONST'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import reportPropTypes from '../../reportPropTypes'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import CONST from '@src/CONST'; import ReportActionItem from './ReportActionItem'; import ReportActionItemParentAction from './ReportActionItemParentAction'; import reportActionPropTypes from './reportActionPropTypes'; diff --git a/src/pages/home/report/ReportActionsView.js b/src/pages/home/report/ReportActionsView.js index 108e75051696..f9f029881eef 100755 --- a/src/pages/home/report/ReportActionsView.js +++ b/src/pages/home/report/ReportActionsView.js @@ -1,26 +1,26 @@ -import React, {useRef, useEffect, useContext, useMemo} from 'react'; +import {useIsFocused} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useContext, useEffect, useMemo, useRef} from 'react'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import {useIsFocused} from '@react-navigation/native'; -import * as Report from '../../../libs/actions/Report'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useCopySelectionHelper from '@hooks/useCopySelectionHelper'; +import useInitialValue from '@hooks/useInitialValue'; +import compose from '@libs/compose'; +import getIsReportFullyVisible from '@libs/getIsReportFullyVisible'; +import Performance from '@libs/Performance'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import {ReactionListContext} from '@pages/home/ReportScreenContext'; +import reportPropTypes from '@pages/reportPropTypes'; +import * as Report from '@userActions/Report'; +import Timing from '@userActions/Timing'; +import CONST from '@src/CONST'; +import PopoverReactionList from './ReactionList/PopoverReactionList'; import reportActionPropTypes from './reportActionPropTypes'; -import Timing from '../../../libs/actions/Timing'; -import CONST from '../../../CONST'; -import compose from '../../../libs/compose'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import useCopySelectionHelper from '../../../hooks/useCopySelectionHelper'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Performance from '../../../libs/Performance'; -import {withNetwork} from '../../../components/OnyxProvider'; -import networkPropTypes from '../../../components/networkPropTypes'; import ReportActionsList from './ReportActionsList'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import reportPropTypes from '../../reportPropTypes'; -import PopoverReactionList from './ReactionList/PopoverReactionList'; -import getIsReportFullyVisible from '../../../libs/getIsReportFullyVisible'; -import {ReactionListContext} from '../ReportScreenContext'; -import useInitialValue from '../../../hooks/useInitialValue'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/home/report/ReportAttachments.js b/src/pages/home/report/ReportAttachments.js index 23da908fed17..173a4b5637be 100644 --- a/src/pages/home/report/ReportAttachments.js +++ b/src/pages/home/report/ReportAttachments.js @@ -1,10 +1,10 @@ +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import AttachmentModal from '../../../components/AttachmentModal'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import ROUTES from '../../../ROUTES'; +import AttachmentModal from '@components/AttachmentModal'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Navigation route context info provided by react navigation */ diff --git a/src/pages/home/report/ReportAttachmentsContext.js b/src/pages/home/report/ReportAttachmentsContext.js index a51df01313e5..5602612a6cd6 100644 --- a/src/pages/home/report/ReportAttachmentsContext.js +++ b/src/pages/home/report/ReportAttachmentsContext.js @@ -1,6 +1,6 @@ -import React, {useEffect, useMemo, useRef} from 'react'; import PropTypes from 'prop-types'; -import useCurrentReportID from '../../../hooks/useCurrentReportID'; +import React, {useEffect, useMemo, useRef} from 'react'; +import useCurrentReportID from '@hooks/useCurrentReportID'; const ReportAttachmentsContext = React.createContext(); diff --git a/src/pages/home/report/ReportDetailsShareCodePage.js b/src/pages/home/report/ReportDetailsShareCodePage.js index 7c22726ac82b..0ef2d46029ea 100644 --- a/src/pages/home/report/ReportDetailsShareCodePage.js +++ b/src/pages/home/report/ReportDetailsShareCodePage.js @@ -1,7 +1,7 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import reportPropTypes from '../../reportPropTypes'; -import ShareCodePage from '../../ShareCodePage'; +import React from 'react'; +import reportPropTypes from '@pages/reportPropTypes'; +import ShareCodePage from '@pages/ShareCodePage'; import withReportOrNotFound from './withReportOrNotFound'; const propTypes = { diff --git a/src/pages/home/report/ReportDropUI.js b/src/pages/home/report/ReportDropUI.js index d742346cd769..ae0c941b37e7 100644 --- a/src/pages/home/report/ReportDropUI.js +++ b/src/pages/home/report/ReportDropUI.js @@ -1,12 +1,12 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import DragAndDropConsumer from '../../../components/DragAndDrop/Consumer'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import useLocalize from '../../../hooks/useLocalize'; +import DragAndDropConsumer from '@components/DragAndDrop/Consumer'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; const propTypes = { /** Callback to execute when a file is dropped. */ diff --git a/src/pages/home/report/ReportFooter.js b/src/pages/home/report/ReportFooter.js index 2237e6448504..f3598a92a9eb 100644 --- a/src/pages/home/report/ReportFooter.js +++ b/src/pages/home/report/ReportFooter.js @@ -1,24 +1,24 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import {Keyboard, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import {View, Keyboard} from 'react-native'; -import CONST from '../../../CONST'; +import AnonymousReportFooter from '@components/AnonymousReportFooter'; +import ArchivedReportFooter from '@components/ArchivedReportFooter'; +import OfflineIndicator from '@components/OfflineIndicator'; +import participantPropTypes from '@components/participantPropTypes'; +import SwipeableView from '@components/SwipeableView'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useNetwork from '@hooks/useNetwork'; +import compose from '@libs/compose'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import ReportActionCompose from './ReportActionCompose/ReportActionCompose'; -import AnonymousReportFooter from '../../../components/AnonymousReportFooter'; -import SwipeableView from '../../../components/SwipeableView'; -import OfflineIndicator from '../../../components/OfflineIndicator'; -import ArchivedReportFooter from '../../../components/ArchivedReportFooter'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import useNetwork from '../../../hooks/useNetwork'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; import reportActionPropTypes from './reportActionPropTypes'; -import reportPropTypes from '../../reportPropTypes'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as Session from '../../../libs/actions/Session'; -import participantPropTypes from '../../../components/participantPropTypes'; const propTypes = { /** Report object for the current report */ diff --git a/src/pages/home/report/ReportTypingIndicator.js b/src/pages/home/report/ReportTypingIndicator.js index db97f712d65f..7b2b46b7d097 100755 --- a/src/pages/home/report/ReportTypingIndicator.js +++ b/src/pages/home/report/ReportTypingIndicator.js @@ -1,16 +1,16 @@ -import React, {useMemo} from 'react'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useMemo} from 'react'; import {withOnyx} from 'react-native-onyx'; -import {withNetwork} from '../../../components/OnyxProvider'; -import networkPropTypes from '../../../components/networkPropTypes'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Text from '../../../components/Text'; -import TextWithEllipsis from '../../../components/TextWithEllipsis'; +import _ from 'underscore'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import Text from '@components/Text'; +import TextWithEllipsis from '@components/TextWithEllipsis'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Key-value pairs of user accountIDs/logins and whether or not they are typing. Keys are accountIDs or logins. */ diff --git a/src/pages/home/report/withReportAndReportActionOrNotFound.js b/src/pages/home/report/withReportAndReportActionOrNotFound.js index a14293e71c67..1450ab3fd10a 100644 --- a/src/pages/home/report/withReportAndReportActionOrNotFound.js +++ b/src/pages/home/report/withReportAndReportActionOrNotFound.js @@ -1,19 +1,19 @@ import PropTypes from 'prop-types'; -import React, {useEffect, useCallback} from 'react'; +import React, {useCallback, useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import getComponentDisplayName from '../../../libs/getComponentDisplayName'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import ONYXKEYS from '../../../ONYXKEYS'; -import reportPropTypes from '../../reportPropTypes'; -import reportMetadataPropTypes from '../../reportMetadataPropTypes'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import withWindowDimensions from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import reportMetadataPropTypes from '@pages/reportMetadataPropTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import * as Report from '@userActions/Report'; +import ONYXKEYS from '@src/ONYXKEYS'; import reportActionPropTypes from './reportActionPropTypes'; -import FullscreenLoadingIndicator from '../../../components/FullscreenLoadingIndicator'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as ReportActionsUtils from '../../../libs/ReportActionsUtils'; -import * as Report from '../../../libs/actions/Report'; -import compose from '../../../libs/compose'; -import withWindowDimensions from '../../../components/withWindowDimensions'; export default function (WrappedComponent) { const propTypes = { diff --git a/src/pages/home/report/withReportOrNotFound.tsx b/src/pages/home/report/withReportOrNotFound.tsx index 28d6707b085f..81d1376abd37 100644 --- a/src/pages/home/report/withReportOrNotFound.tsx +++ b/src/pages/home/report/withReportOrNotFound.tsx @@ -1,13 +1,13 @@ /* eslint-disable rulesdir/no-negated-variables */ +import {RouteProp} from '@react-navigation/native'; import React, {ComponentType, ForwardedRef, RefAttributes} from 'react'; import {OnyxEntry, withOnyx} from 'react-native-onyx'; -import {RouteProp} from '@react-navigation/native'; -import getComponentDisplayName from '../../../libs/getComponentDisplayName'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import ONYXKEYS from '../../../ONYXKEYS'; -import FullscreenLoadingIndicator from '../../../components/FullscreenLoadingIndicator'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as OnyxTypes from '../../../types/onyx'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import * as ReportUtils from '@libs/ReportUtils'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import ONYXKEYS from '@src/ONYXKEYS'; +import * as OnyxTypes from '@src/types/onyx'; type OnyxProps = { /** The report currently being looked at */ diff --git a/src/pages/home/sidebar/AvatarWithOptionalStatus.js b/src/pages/home/sidebar/AvatarWithOptionalStatus.js index adf9cdda5cd0..b456788224fb 100644 --- a/src/pages/home/sidebar/AvatarWithOptionalStatus.js +++ b/src/pages/home/sidebar/AvatarWithOptionalStatus.js @@ -1,15 +1,15 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import Text from '../../../components/Text'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import PressableAvatarWithIndicator from './PressableAvatarWithIndicator'; -import Navigation from '../../../libs/Navigation/Navigation'; -import useLocalize from '../../../hooks/useLocalize'; -import styles from '../../../styles/styles'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; const propTypes = { /** Whether the create menu is open or not */ diff --git a/src/pages/home/sidebar/GlobalNavigation/GlobalNavigationMenuItem.js b/src/pages/home/sidebar/GlobalNavigation/GlobalNavigationMenuItem.js index d24960e80ff2..93355fcfd530 100644 --- a/src/pages/home/sidebar/GlobalNavigation/GlobalNavigationMenuItem.js +++ b/src/pages/home/sidebar/GlobalNavigation/GlobalNavigationMenuItem.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../../components/Text'; -import styles from '../../../../styles/styles'; -import * as StyleUtils from '../../../../styles/StyleUtils'; -import Icon from '../../../../components/Icon'; -import CONST from '../../../../CONST'; -import variables from '../../../../styles/variables'; -import PressableWithFeedback from '../../../../components/Pressable/PressableWithFeedback'; +import Icon from '@components/Icon'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; +import CONST from '@src/CONST'; const propTypes = { /** Icon to display */ diff --git a/src/pages/home/sidebar/GlobalNavigation/index.js b/src/pages/home/sidebar/GlobalNavigation/index.js index 1a8e923d1ff6..569ebf6fd0a8 100644 --- a/src/pages/home/sidebar/GlobalNavigation/index.js +++ b/src/pages/home/sidebar/GlobalNavigation/index.js @@ -1,15 +1,15 @@ -import React, {useMemo, useContext} from 'react'; +import React, {useContext, useMemo} from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import styles from '../../../../styles/styles'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import CONST from '../../../../CONST'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; -import useLocalize from '../../../../hooks/useLocalize'; +import * as Expensicons from '@components/Icon/Expensicons'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import {SidebarNavigationContext} from '@pages/home/sidebar/SidebarNavigationContext'; +import SignInOrAvatarWithOptionalStatus from '@pages/home/sidebar/SignInOrAvatarWithOptionalStatus'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import GlobalNavigationMenuItem from './GlobalNavigationMenuItem'; -import {SidebarNavigationContext} from '../SidebarNavigationContext'; -import SignInOrAvatarWithOptionalStatus from '../SignInOrAvatarWithOptionalStatus'; function GlobalNavigation() { const sidebarNavigation = useContext(SidebarNavigationContext); diff --git a/src/pages/home/sidebar/PressableAvatarWithIndicator.js b/src/pages/home/sidebar/PressableAvatarWithIndicator.js index 7b240c108e4e..e798bece339f 100644 --- a/src/pages/home/sidebar/PressableAvatarWithIndicator.js +++ b/src/pages/home/sidebar/PressableAvatarWithIndicator.js @@ -1,17 +1,17 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ import lodashGet from 'lodash/get'; -import React, {useCallback} from 'react'; import PropTypes from 'prop-types'; -import withCurrentUserPersonalDetails from '../../../components/withCurrentUserPersonalDetails'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import AvatarWithIndicator from '../../../components/AvatarWithIndicator'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as UserUtils from '../../../libs/UserUtils'; -import useLocalize from '../../../hooks/useLocalize'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; -import personalDetailsPropType from '../../personalDetailsPropType'; +import React, {useCallback} from 'react'; +import AvatarWithIndicator from '@components/AvatarWithIndicator'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as UserUtils from '@libs/UserUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Whether the create menu is open or not */ diff --git a/src/pages/home/sidebar/SidebarLinks.js b/src/pages/home/sidebar/SidebarLinks.js index d3ff3070466f..0e7d6aa38545 100644 --- a/src/pages/home/sidebar/SidebarLinks.js +++ b/src/pages/home/sidebar/SidebarLinks.js @@ -1,31 +1,31 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ -import React, {useEffect, useRef, useCallback} from 'react'; -import {View, InteractionManager} from 'react-native'; -import _ from 'underscore'; import PropTypes from 'prop-types'; -import styles from '../../../styles/styles'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import ONYXKEYS from '../../../ONYXKEYS'; -import safeAreaInsetPropTypes from '../../safeAreaInsetPropTypes'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import Tooltip from '../../../components/Tooltip'; -import CONST from '../../../CONST'; -import * as App from '../../../libs/actions/App'; -import LHNOptionsList from '../../../components/LHNOptionsList/LHNOptionsList'; -import SidebarUtils from '../../../libs/SidebarUtils'; -import Header from '../../../components/Header'; -import OptionsListSkeletonView from '../../../components/OptionsListSkeletonView'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import * as Session from '../../../libs/actions/Session'; -import KeyboardShortcut from '../../../libs/KeyboardShortcut'; -import onyxSubscribe from '../../../libs/onyxSubscribe'; -import * as ReportActionContextMenu from '../report/ContextMenu/ReportActionContextMenu'; -import Text from '../../../components/Text'; -import useLocalize from '../../../hooks/useLocalize'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; +import React, {useCallback, useEffect, useRef} from 'react'; +import {InteractionManager, View} from 'react-native'; +import _ from 'underscore'; +import Header from '@components/Header'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import LHNOptionsList from '@components/LHNOptionsList/LHNOptionsList'; +import OptionsListSkeletonView from '@components/OptionsListSkeletonView'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import KeyboardShortcut from '@libs/KeyboardShortcut'; +import Navigation from '@libs/Navigation/Navigation'; +import onyxSubscribe from '@libs/onyxSubscribe'; +import SidebarUtils from '@libs/SidebarUtils'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import safeAreaInsetPropTypes from '@pages/safeAreaInsetPropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as App from '@userActions/App'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const basePropTypes = { /** Safe area insets required for mobile devices margins */ diff --git a/src/pages/home/sidebar/SidebarLinksData.js b/src/pages/home/sidebar/SidebarLinksData.js index 394f6c5ddc5a..a5d58768a95d 100644 --- a/src/pages/home/sidebar/SidebarLinksData.js +++ b/src/pages/home/sidebar/SidebarLinksData.js @@ -1,21 +1,21 @@ -import React, {useCallback, useMemo, useRef} from 'react'; -import _ from 'underscore'; import {deepEqual} from 'fast-equals'; -import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useMemo, useRef} from 'react'; import {View} from 'react-native'; -import SidebarUtils from '../../../libs/SidebarUtils'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import withCurrentReportID from '@components/withCurrentReportID'; +import withNavigationFocus from '@components/withNavigationFocus'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as SessionUtils from '@libs/SessionUtils'; +import SidebarUtils from '@libs/SidebarUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import SidebarLinks, {basePropTypes} from './SidebarLinks'; -import withCurrentReportID from '../../../components/withCurrentReportID'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; -import reportPropTypes from '../../reportPropTypes'; -import CONST from '../../../CONST'; -import useLocalize from '../../../hooks/useLocalize'; -import styles from '../../../styles/styles'; -import withNavigationFocus from '../../../components/withNavigationFocus'; -import * as SessionUtils from '../../../libs/SessionUtils'; const propTypes = { ...basePropTypes, diff --git a/src/pages/home/sidebar/SidebarNavigationContext.js b/src/pages/home/sidebar/SidebarNavigationContext.js index 47bda74e052d..d39c24178f8d 100644 --- a/src/pages/home/sidebar/SidebarNavigationContext.js +++ b/src/pages/home/sidebar/SidebarNavigationContext.js @@ -1,9 +1,9 @@ -import React, {useMemo, useCallback, useState} from 'react'; import PropTypes from 'prop-types'; +import React, {useCallback, useMemo, useState} from 'react'; import _ from 'underscore'; -import CONST from '../../../CONST'; -import Navigation from '../../../libs/Navigation/Navigation'; -import GLOBAL_NAVIGATION_MAPPING from '../../../GLOBAL_NAVIGATION_MAPPING'; +import Navigation from '@libs/Navigation/Navigation'; +import CONST from '@src/CONST'; +import GLOBAL_NAVIGATION_MAPPING from '@src/GLOBAL_NAVIGATION_MAPPING'; const propTypes = { /** Children to wrap. The part of app that should have acces to this context */ diff --git a/src/pages/home/sidebar/SidebarScreen/BaseSidebarScreen.js b/src/pages/home/sidebar/SidebarScreen/BaseSidebarScreen.js index 97f1f7eaee20..cd8bff2e5945 100644 --- a/src/pages/home/sidebar/SidebarScreen/BaseSidebarScreen.js +++ b/src/pages/home/sidebar/SidebarScreen/BaseSidebarScreen.js @@ -1,14 +1,14 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import styles from '../../../../styles/styles'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import Timing from '../../../../libs/actions/Timing'; -import CONST from '../../../../CONST'; -import Performance from '../../../../libs/Performance'; -import * as Browser from '../../../../libs/Browser'; -import GlobalNavigation from '../GlobalNavigation'; -import SubNavigation from '../SubNavigation/SubNavigation'; +import ScreenWrapper from '@components/ScreenWrapper'; +import * as Browser from '@libs/Browser'; +import Performance from '@libs/Performance'; +import GlobalNavigation from '@pages/home/sidebar/GlobalNavigation'; +import SubNavigation from '@pages/home/sidebar/SubNavigation/SubNavigation'; +import styles from '@styles/styles'; +import Timing from '@userActions/Timing'; +import CONST from '@src/CONST'; const propTypes = { /** Children to wrap (floating button). */ diff --git a/src/pages/home/sidebar/SidebarScreen/FloatingActionButtonAndPopover.js b/src/pages/home/sidebar/SidebarScreen/FloatingActionButtonAndPopover.js index 340e7a0ed6a8..63c2cc2436d7 100644 --- a/src/pages/home/sidebar/SidebarScreen/FloatingActionButtonAndPopover.js +++ b/src/pages/home/sidebar/SidebarScreen/FloatingActionButtonAndPopover.js @@ -1,31 +1,31 @@ -import React, {useState, useEffect, useRef, useCallback, useImperativeHandle, forwardRef} from 'react'; -import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {forwardRef, useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react'; import {View} from 'react-native'; -import styles from '../../../../styles/styles'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; -import NAVIGATORS from '../../../../NAVIGATORS'; -import SCREENS from '../../../../SCREENS'; -import Permissions from '../../../../libs/Permissions'; -import * as Policy from '../../../../libs/actions/Policy'; -import PopoverMenu from '../../../../components/PopoverMenu'; -import CONST from '../../../../CONST'; -import FloatingActionButton from '../../../../components/FloatingActionButton'; -import compose from '../../../../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import withWindowDimensions from '../../../../components/withWindowDimensions'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import withNavigation from '../../../../components/withNavigation'; -import * as Welcome from '../../../../libs/actions/Welcome'; -import withNavigationFocus from '../../../../components/withNavigationFocus'; -import * as Task from '../../../../libs/actions/Task'; -import * as Session from '../../../../libs/actions/Session'; -import * as IOU from '../../../../libs/actions/IOU'; -import usePrevious from '../../../../hooks/usePrevious'; -import * as App from '../../../../libs/actions/App'; +import {withOnyx} from 'react-native-onyx'; +import FloatingActionButton from '@components/FloatingActionButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PopoverMenu from '@components/PopoverMenu'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withNavigation from '@components/withNavigation'; +import withNavigationFocus from '@components/withNavigationFocus'; +import withWindowDimensions from '@components/withWindowDimensions'; +import usePrevious from '@hooks/usePrevious'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import styles from '@styles/styles'; +import * as App from '@userActions/App'; +import * as IOU from '@userActions/IOU'; +import * as Policy from '@userActions/Policy'; +import * as Session from '@userActions/Session'; +import * as Task from '@userActions/Task'; +import * as Welcome from '@userActions/Welcome'; +import CONST from '@src/CONST'; +import NAVIGATORS from '@src/NAVIGATORS'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; /** * @param {Object} [policy] diff --git a/src/pages/home/sidebar/SidebarScreen/index.js b/src/pages/home/sidebar/SidebarScreen/index.js index 53640fffe559..6f2fa1f9944a 100755 --- a/src/pages/home/sidebar/SidebarScreen/index.js +++ b/src/pages/home/sidebar/SidebarScreen/index.js @@ -1,8 +1,8 @@ import React, {useCallback, useRef} from 'react'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import FreezeWrapper from '@libs/Navigation/FreezeWrapper'; import BaseSidebarScreen from './BaseSidebarScreen'; import FloatingActionButtonAndPopover from './FloatingActionButtonAndPopover'; -import FreezeWrapper from '../../../../libs/Navigation/FreezeWrapper'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; function SidebarScreen(props) { const popoverModal = useRef(null); diff --git a/src/pages/home/sidebar/SidebarScreen/index.native.js b/src/pages/home/sidebar/SidebarScreen/index.native.js index 35c8b876338f..bb4d08d33ea7 100755 --- a/src/pages/home/sidebar/SidebarScreen/index.native.js +++ b/src/pages/home/sidebar/SidebarScreen/index.native.js @@ -1,8 +1,8 @@ import React from 'react'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import FreezeWrapper from '@libs/Navigation/FreezeWrapper'; import BaseSidebarScreen from './BaseSidebarScreen'; import FloatingActionButtonAndPopover from './FloatingActionButtonAndPopover'; -import FreezeWrapper from '../../../../libs/Navigation/FreezeWrapper'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; function SidebarScreen(props) { const {isSmallScreenWidth} = useWindowDimensions(); diff --git a/src/pages/home/sidebar/SignInButton.js b/src/pages/home/sidebar/SignInButton.js index 24b90d778445..9e8722e2e083 100644 --- a/src/pages/home/sidebar/SignInButton.js +++ b/src/pages/home/sidebar/SignInButton.js @@ -1,12 +1,12 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ import React from 'react'; import {View} from 'react-native'; -import PressableWithoutFeedback from '../../../components/Pressable/PressableWithoutFeedback'; -import Button from '../../../components/Button'; -import styles from '../../../styles/styles'; -import * as Session from '../../../libs/actions/Session'; -import useLocalize from '../../../hooks/useLocalize'; -import CONST from '../../../CONST'; +import Button from '@components/Button'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; function SignInButton() { const {translate} = useLocalize(); diff --git a/src/pages/home/sidebar/SignInOrAvatarWithOptionalStatus.js b/src/pages/home/sidebar/SignInOrAvatarWithOptionalStatus.js index 2599ac6b6942..8e41e1c6af6a 100644 --- a/src/pages/home/sidebar/SignInOrAvatarWithOptionalStatus.js +++ b/src/pages/home/sidebar/SignInOrAvatarWithOptionalStatus.js @@ -1,17 +1,17 @@ /* eslint-disable rulesdir/onyx-props-must-have-default */ -import React from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import withCurrentUserPersonalDetails from '../../../components/withCurrentUserPersonalDetails'; -import personalDetailsPropType from '../../personalDetailsPropType'; -import PressableAvatarWithIndicator from './PressableAvatarWithIndicator'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import compose from '@libs/compose'; +import Permissions from '@libs/Permissions'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; import AvatarWithOptionalStatus from './AvatarWithOptionalStatus'; +import PressableAvatarWithIndicator from './PressableAvatarWithIndicator'; import SignInButton from './SignInButton'; -import * as Session from '../../../libs/actions/Session'; -import Permissions from '../../../libs/Permissions'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; const propTypes = { /** The personal details of the person who is logged in */ diff --git a/src/pages/home/sidebar/SubNavigation/SubNavigation.js b/src/pages/home/sidebar/SubNavigation/SubNavigation.js index 0c893b356099..ceb1d40dca50 100644 --- a/src/pages/home/sidebar/SubNavigation/SubNavigation.js +++ b/src/pages/home/sidebar/SubNavigation/SubNavigation.js @@ -1,12 +1,12 @@ -import React, {useEffect} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {View} from 'react-native'; -import styles from '../../../../styles/styles'; -import SidebarLinksData from '../SidebarLinksData'; -import Timing from '../../../../libs/actions/Timing'; -import CONST from '../../../../CONST'; -import Performance from '../../../../libs/Performance'; -import safeAreaInsetPropTypes from '../../../safeAreaInsetPropTypes'; +import Performance from '@libs/Performance'; +import SidebarLinksData from '@pages/home/sidebar/SidebarLinksData'; +import safeAreaInsetPropTypes from '@pages/safeAreaInsetPropTypes'; +import styles from '@styles/styles'; +import Timing from '@userActions/Timing'; +import CONST from '@src/CONST'; const propTypes = { /** Function called when a pinned chat is selected. */ diff --git a/src/pages/iou/IOUCurrencySelection.js b/src/pages/iou/IOUCurrencySelection.js index b8154ac4ceda..c7b5885865df 100644 --- a/src/pages/iou/IOUCurrencySelection.js +++ b/src/pages/iou/IOUCurrencySelection.js @@ -1,24 +1,24 @@ -import React, {useState, useMemo, useCallback, useRef, useEffect} from 'react'; -import {Keyboard} from 'react-native'; +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {Keyboard} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import compose from '../../libs/compose'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import {withNetwork} from '../../components/OnyxProvider'; -import * as CurrencyUtils from '../../libs/CurrencyUtils'; -import * as ReportActionsUtils from '../../libs/ReportActionsUtils'; -import * as ReportUtils from '../../libs/ReportUtils'; -import ROUTES from '../../ROUTES'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; -import SelectionList from '../../components/SelectionList'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportActionsUtils from '@libs/ReportActionsUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; /** * IOU Currency selection for selecting currency diff --git a/src/pages/iou/MoneyRequestCategoryPage.js b/src/pages/iou/MoneyRequestCategoryPage.js index 7431a5deed77..9551004eb1ab 100644 --- a/src/pages/iou/MoneyRequestCategoryPage.js +++ b/src/pages/iou/MoneyRequestCategoryPage.js @@ -1,20 +1,20 @@ -import React from 'react'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import compose from '../../libs/compose'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import useLocalize from '../../hooks/useLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import CategoryPicker from '../../components/CategoryPicker'; -import ONYXKEYS from '../../ONYXKEYS'; -import reportPropTypes from '../reportPropTypes'; -import * as IOU from '../../libs/actions/IOU'; -import styles from '../../styles/styles'; -import Text from '../../components/Text'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; +import CategoryPicker from '@components/CategoryPicker'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; const propTypes = { /** Navigation route context info provided by react navigation */ diff --git a/src/pages/iou/MoneyRequestDatePage.js b/src/pages/iou/MoneyRequestDatePage.js index fdf7b3a0fb30..430af5d9de94 100644 --- a/src/pages/iou/MoneyRequestDatePage.js +++ b/src/pages/iou/MoneyRequestDatePage.js @@ -1,21 +1,21 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as IOU from '../../libs/actions/IOU'; -import * as MoneyRequestUtils from '../../libs/MoneyRequestUtils'; -import NewDatePicker from '../../components/NewDatePicker'; -import useLocalize from '../../hooks/useLocalize'; -import CONST from '../../CONST'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; -import FormProvider from '../../components/Form/FormProvider'; +import FormProvider from '@components/Form/FormProvider'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import NewDatePicker from '@components/NewDatePicker'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; const propTypes = { /** Onyx Props */ diff --git a/src/pages/iou/MoneyRequestDescriptionPage.js b/src/pages/iou/MoneyRequestDescriptionPage.js index cfdbb60b4f0d..c0ed2da2eb7d 100644 --- a/src/pages/iou/MoneyRequestDescriptionPage.js +++ b/src/pages/iou/MoneyRequestDescriptionPage.js @@ -1,25 +1,25 @@ -import React, {useEffect, useRef, useCallback} from 'react'; -import {View} from 'react-native'; -import {withOnyx} from 'react-native-onyx'; import {useFocusEffect} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef} from 'react'; +import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; -import TextInput from '../../components/TextInput'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Form from '../../components/Form'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as IOU from '../../libs/actions/IOU'; -import * as MoneyRequestUtils from '../../libs/MoneyRequestUtils'; -import CONST from '../../CONST'; -import useLocalize from '../../hooks/useLocalize'; -import updateMultilineInputRange from '../../libs/UpdateMultilineInputRange'; -import * as Browser from '../../libs/Browser'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import * as Browser from '@libs/Browser'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; const propTypes = { /** Onyx Props */ diff --git a/src/pages/iou/MoneyRequestEditWaypointPage.js b/src/pages/iou/MoneyRequestEditWaypointPage.js index 68f85848a69e..fc777891109e 100644 --- a/src/pages/iou/MoneyRequestEditWaypointPage.js +++ b/src/pages/iou/MoneyRequestEditWaypointPage.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import WaypointEditor from './WaypointEditor'; const propTypes = { diff --git a/src/pages/iou/MoneyRequestMerchantPage.js b/src/pages/iou/MoneyRequestMerchantPage.js index af20930ffe8d..5c01484310ff 100644 --- a/src/pages/iou/MoneyRequestMerchantPage.js +++ b/src/pages/iou/MoneyRequestMerchantPage.js @@ -1,21 +1,21 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useRef} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import TextInput from '../../components/TextInput'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Form from '../../components/Form'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import * as IOU from '../../libs/actions/IOU'; -import CONST from '../../CONST'; -import useLocalize from '../../hooks/useLocalize'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; const propTypes = { /** Onyx Props */ diff --git a/src/pages/iou/MoneyRequestSelectorPage.js b/src/pages/iou/MoneyRequestSelectorPage.js index 979be64f68e9..17893ce98f0b 100644 --- a/src/pages/iou/MoneyRequestSelectorPage.js +++ b/src/pages/iou/MoneyRequestSelectorPage.js @@ -1,30 +1,30 @@ -import {withOnyx} from 'react-native-onyx'; -import {View} from 'react-native'; -import React, {useEffect, useState} from 'react'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; +import {View} from 'react-native'; +import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../ONYXKEYS'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import TabSelector from '../../components/TabSelector/TabSelector'; -import CONST from '../../CONST'; -import useLocalize from '../../hooks/useLocalize'; -import * as IOUUtils from '../../libs/IOUUtils'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import ReceiptSelector from './ReceiptSelector'; -import * as IOU from '../../libs/actions/IOU'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import DragAndDropProvider from '@components/DragAndDrop/Provider'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TabSelector from '@components/TabSelector/TabSelector'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import compose from '@libs/compose'; +import * as IOUUtils from '@libs/IOUUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import OnyxTabNavigator, {TopTab} from '@libs/Navigation/OnyxTabNavigator'; +import * as ReportUtils from '@libs/ReportUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import NewDistanceRequestPage from './NewDistanceRequestPage'; -import DragAndDropProvider from '../../components/DragAndDrop/Provider'; -import OnyxTabNavigator, {TopTab} from '../../libs/Navigation/OnyxTabNavigator'; +import ReceiptSelector from './ReceiptSelector'; import NewRequestAmountPage from './steps/NewRequestAmountPage'; -import withReportOrNotFound from '../home/report/withReportOrNotFound'; -import compose from '../../libs/compose'; -import reportPropTypes from '../reportPropTypes'; -import * as ReportUtils from '../../libs/ReportUtils'; -import usePrevious from '../../hooks/usePrevious'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/iou/MoneyRequestTagPage.js b/src/pages/iou/MoneyRequestTagPage.js index 2fc37d2c4271..43f2ebde10ba 100644 --- a/src/pages/iou/MoneyRequestTagPage.js +++ b/src/pages/iou/MoneyRequestTagPage.js @@ -1,23 +1,23 @@ -import React from 'react'; -import _ from 'underscore'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import compose from '../../libs/compose'; -import ROUTES from '../../ROUTES'; -import * as IOU from '../../libs/actions/IOU'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import Navigation from '../../libs/Navigation/Navigation'; -import useLocalize from '../../hooks/useLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import TagPicker from '../../components/TagPicker'; -import Text from '../../components/Text'; -import tagPropTypes from '../../components/tagPropTypes'; -import ONYXKEYS from '../../ONYXKEYS'; -import reportPropTypes from '../reportPropTypes'; -import styles from '../../styles/styles'; -import {iouPropTypes, iouDefaultProps} from './propTypes'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TagPicker from '@components/TagPicker'; +import tagPropTypes from '@components/tagPropTypes'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {iouDefaultProps, iouPropTypes} from './propTypes'; const propTypes = { /** Navigation route context info provided by react navigation */ diff --git a/src/pages/iou/NewDistanceRequestPage.js b/src/pages/iou/NewDistanceRequestPage.js index 726350bfca07..fc4549be3b33 100644 --- a/src/pages/iou/NewDistanceRequestPage.js +++ b/src/pages/iou/NewDistanceRequestPage.js @@ -1,13 +1,13 @@ -import React, {useEffect} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import * as IOU from '../../libs/actions/IOU'; -import ONYXKEYS from '../../ONYXKEYS'; -import DistanceRequest from '../../components/DistanceRequest'; -import reportPropTypes from '../reportPropTypes'; -import CONST from '../../CONST'; +import DistanceRequest from '@components/DistanceRequest'; +import reportPropTypes from '@pages/reportPropTypes'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import {iouPropTypes} from './propTypes'; const propTypes = { diff --git a/src/pages/iou/NewDistanceRequestWaypointEditorPage.js b/src/pages/iou/NewDistanceRequestWaypointEditorPage.js index 47dcbc8e4139..269cde577040 100644 --- a/src/pages/iou/NewDistanceRequestWaypointEditorPage.js +++ b/src/pages/iou/NewDistanceRequestWaypointEditorPage.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; +import ONYXKEYS from '@src/ONYXKEYS'; import WaypointEditor from './WaypointEditor'; -import ONYXKEYS from '../../ONYXKEYS'; const propTypes = { /** The transactionID of this request */ diff --git a/src/pages/iou/ReceiptDropUI.js b/src/pages/iou/ReceiptDropUI.js index e38e88b4490a..9c1483663d4b 100644 --- a/src/pages/iou/ReceiptDropUI.js +++ b/src/pages/iou/ReceiptDropUI.js @@ -1,11 +1,11 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {Text, View} from 'react-native'; -import PropTypes from 'prop-types'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import ReceiptUpload from '../../../assets/images/receipt-upload.svg'; -import useLocalize from '../../hooks/useLocalize'; -import DragAndDropConsumer from '../../components/DragAndDrop/Consumer'; +import ReceiptUpload from '@assets/images/receipt-upload.svg'; +import DragAndDropConsumer from '@components/DragAndDrop/Consumer'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** Callback to execute when a file is dropped. */ diff --git a/src/pages/iou/ReceiptSelector/NavigationAwareCamera.js b/src/pages/iou/ReceiptSelector/NavigationAwareCamera.js index e9cb81003979..e4b24f8a0ad8 100644 --- a/src/pages/iou/ReceiptSelector/NavigationAwareCamera.js +++ b/src/pages/iou/ReceiptSelector/NavigationAwareCamera.js @@ -1,8 +1,8 @@ -import React, {useEffect, useRef} from 'react'; -import Webcam from 'react-webcam'; import {useIsFocused} from '@react-navigation/native'; import PropTypes from 'prop-types'; +import React, {useEffect, useRef} from 'react'; import {View} from 'react-native'; +import Webcam from 'react-webcam'; const propTypes = { /* Flag to turn on/off the torch/flashlight - if available */ diff --git a/src/pages/iou/ReceiptSelector/NavigationAwareCamera.native.js b/src/pages/iou/ReceiptSelector/NavigationAwareCamera.native.js index 69678622aae5..9d1b1723e882 100644 --- a/src/pages/iou/ReceiptSelector/NavigationAwareCamera.native.js +++ b/src/pages/iou/ReceiptSelector/NavigationAwareCamera.native.js @@ -1,9 +1,9 @@ -import React, {useEffect, useState} from 'react'; -import {Camera} from 'react-native-vision-camera'; import {useTabAnimation} from '@react-navigation/material-top-tabs'; import {useNavigation} from '@react-navigation/native'; import PropTypes from 'prop-types'; -import CONST from '../../../CONST'; +import React, {useEffect, useState} from 'react'; +import {Camera} from 'react-native-vision-camera'; +import CONST from '@src/CONST'; const propTypes = { /* The index of the tab that contains this camera */ diff --git a/src/pages/iou/ReceiptSelector/index.js b/src/pages/iou/ReceiptSelector/index.js index ca9fe90575e7..672b1458bf8e 100644 --- a/src/pages/iou/ReceiptSelector/index.js +++ b/src/pages/iou/ReceiptSelector/index.js @@ -1,34 +1,34 @@ -import {View, Text, PixelRatio, ActivityIndicator, PanResponder} from 'react-native'; -import React, {useCallback, useContext, useReducer, useRef, useState} from 'react'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React, {useCallback, useContext, useReducer, useRef, useState} from 'react'; +import {ActivityIndicator, PanResponder, PixelRatio, Text, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import * as IOU from '../../../libs/actions/IOU'; -import reportPropTypes from '../../reportPropTypes'; -import CONST from '../../../CONST'; -import ReceiptUpload from '../../../../assets/images/receipt-upload.svg'; -import Button from '../../../components/Button'; -import styles from '../../../styles/styles'; -import CopyTextToClipboard from '../../../components/CopyTextToClipboard'; -import ReceiptDropUI from '../ReceiptDropUI'; -import AttachmentPicker from '../../../components/AttachmentPicker'; -import ConfirmModal from '../../../components/ConfirmModal'; -import ONYXKEYS from '../../../ONYXKEYS'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import useLocalize from '../../../hooks/useLocalize'; -import {DragAndDropContext} from '../../../components/DragAndDrop/Provider'; -import {iouPropTypes, iouDefaultProps} from '../propTypes'; -import * as FileUtils from '../../../libs/fileDownload/FileUtils'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import Icon from '../../../components/Icon'; -import themeColors from '../../../styles/themes/default'; -import Shutter from '../../../../assets/images/shutter.svg'; +import _ from 'underscore'; +import Hand from '@assets/images/hand.svg'; +import ReceiptUpload from '@assets/images/receipt-upload.svg'; +import Shutter from '@assets/images/shutter.svg'; +import AttachmentPicker from '@components/AttachmentPicker'; +import Button from '@components/Button'; +import ConfirmModal from '@components/ConfirmModal'; +import CopyTextToClipboard from '@components/CopyTextToClipboard'; +import {DragAndDropContext} from '@components/DragAndDrop/Provider'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import ReceiptDropUI from '@pages/iou/ReceiptDropUI'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import NavigationAwareCamera from './NavigationAwareCamera'; -import * as Browser from '../../../libs/Browser'; -import Hand from '../../../../assets/images/hand.svg'; -import PressableWithFeedback from '../../../components/Pressable/PressableWithFeedback'; const propTypes = { /** The report on which the request is initiated on */ diff --git a/src/pages/iou/ReceiptSelector/index.native.js b/src/pages/iou/ReceiptSelector/index.native.js index 649b6ea521f3..d47a2c7739a2 100644 --- a/src/pages/iou/ReceiptSelector/index.native.js +++ b/src/pages/iou/ReceiptSelector/index.native.js @@ -1,30 +1,30 @@ -import {ActivityIndicator, Alert, AppState, Text, View} from 'react-native'; -import React, {useCallback, useEffect, useRef, useState} from 'react'; -import {useCameraDevices} from 'react-native-vision-camera'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {ActivityIndicator, Alert, AppState, Text, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import {RESULTS} from 'react-native-permissions'; -import PressableWithFeedback from '../../../components/Pressable/PressableWithFeedback'; -import Icon from '../../../components/Icon'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import AttachmentPicker from '../../../components/AttachmentPicker'; -import styles from '../../../styles/styles'; -import Shutter from '../../../../assets/images/shutter.svg'; -import Hand from '../../../../assets/images/hand.svg'; -import * as IOU from '../../../libs/actions/IOU'; -import themeColors from '../../../styles/themes/default'; -import reportPropTypes from '../../reportPropTypes'; -import CONST from '../../../CONST'; -import Button from '../../../components/Button'; -import useLocalize from '../../../hooks/useLocalize'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Log from '../../../libs/Log'; +import {useCameraDevices} from 'react-native-vision-camera'; +import Hand from '@assets/images/hand.svg'; +import Shutter from '@assets/images/shutter.svg'; +import AttachmentPicker from '@components/AttachmentPicker'; +import Button from '@components/Button'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import useLocalize from '@hooks/useLocalize'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import * as CameraPermission from './CameraPermission'; -import {iouPropTypes, iouDefaultProps} from '../propTypes'; import NavigationAwareCamera from './NavigationAwareCamera'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as FileUtils from '../../../libs/fileDownload/FileUtils'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/iou/SplitBillDetailsPage.js b/src/pages/iou/SplitBillDetailsPage.js index 1c48a4f1a44a..1834907c78ea 100644 --- a/src/pages/iou/SplitBillDetailsPage.js +++ b/src/pages/iou/SplitBillDetailsPage.js @@ -1,28 +1,28 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import personalDetailsPropType from '../personalDetailsPropType'; -import compose from '../../libs/compose'; -import reportActionPropTypes from '../home/report/reportActionPropTypes'; -import reportPropTypes from '../reportPropTypes'; -import transactionPropTypes from '../../components/transactionPropTypes'; -import withReportAndReportActionOrNotFound from '../home/report/withReportAndReportActionOrNotFound'; -import * as TransactionUtils from '../../libs/TransactionUtils'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as IOU from '../../libs/actions/IOU'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import MoneyRequestConfirmationList from '../../components/MoneyRequestConfirmationList'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import MoneyRequestHeaderStatusBar from '../../components/MoneyRequestHeaderStatusBar'; -import useLocalize from '../../hooks/useLocalize'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MoneyRequestConfirmationList from '@components/MoneyRequestConfirmationList'; +import MoneyRequestHeaderStatusBar from '@components/MoneyRequestHeaderStatusBar'; +import ScreenWrapper from '@components/ScreenWrapper'; +import transactionPropTypes from '@components/transactionPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as TransactionUtils from '@libs/TransactionUtils'; +import reportActionPropTypes from '@pages/home/report/reportActionPropTypes'; +import withReportAndReportActionOrNotFound from '@pages/home/report/withReportAndReportActionOrNotFound'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/iou/WaypointEditor.js b/src/pages/iou/WaypointEditor.js index 03ce3cba28bd..944f7e879cb6 100644 --- a/src/pages/iou/WaypointEditor.js +++ b/src/pages/iou/WaypointEditor.js @@ -1,29 +1,29 @@ -import React, {useMemo, useRef, useState} from 'react'; -import _ from 'underscore'; +import {useNavigation} from '@react-navigation/native'; import lodashGet from 'lodash/get'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import {useNavigation} from '@react-navigation/native'; -import AddressSearch from '../../components/AddressSearch'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ONYXKEYS from '../../ONYXKEYS'; -import Form from '../../components/Form'; -import styles from '../../styles/styles'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import useLocalize from '../../hooks/useLocalize'; -import useNetwork from '../../hooks/useNetwork'; -import CONST from '../../CONST'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import ConfirmModal from '../../components/ConfirmModal'; -import * as Transaction from '../../libs/actions/Transaction'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import ROUTES from '../../ROUTES'; -import transactionPropTypes from '../../components/transactionPropTypes'; -import * as ErrorUtils from '../../libs/ErrorUtils'; +import _ from 'underscore'; +import AddressSearch from '@components/AddressSearch'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import ConfirmModal from '@components/ConfirmModal'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import ScreenWrapper from '@components/ScreenWrapper'; +import transactionPropTypes from '@components/transactionPropTypes'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as Transaction from '@userActions/Transaction'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Route params */ diff --git a/src/pages/iou/propTypes/index.js b/src/pages/iou/propTypes/index.js index d41b4cbf1724..a03ed65dda9c 100644 --- a/src/pages/iou/propTypes/index.js +++ b/src/pages/iou/propTypes/index.js @@ -1,6 +1,6 @@ import PropTypes from 'prop-types'; -import CONST from '../../../CONST'; -import participantPropTypes from '../../../components/participantPropTypes'; +import participantPropTypes from '@components/participantPropTypes'; +import CONST from '@src/CONST'; const iouPropTypes = PropTypes.shape({ /** ID (iouType + reportID) of the request */ diff --git a/src/pages/iou/steps/MoneyRequestAmountForm.js b/src/pages/iou/steps/MoneyRequestAmountForm.js index a184294aac11..1ee8c607710a 100644 --- a/src/pages/iou/steps/MoneyRequestAmountForm.js +++ b/src/pages/iou/steps/MoneyRequestAmountForm.js @@ -1,22 +1,22 @@ -import React, {useEffect, useState, useCallback, useRef} from 'react'; -import {ScrollView, View} from 'react-native'; -import PropTypes from 'prop-types'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {ScrollView, View} from 'react-native'; import _ from 'underscore'; -import styles from '../../../styles/styles'; -import BigNumberPad from '../../../components/BigNumberPad'; -import * as CurrencyUtils from '../../../libs/CurrencyUtils'; -import * as MoneyRequestUtils from '../../../libs/MoneyRequestUtils'; -import Button from '../../../components/Button'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; -import TextInputWithCurrencySymbol from '../../../components/TextInputWithCurrencySymbol'; -import useLocalize from '../../../hooks/useLocalize'; -import CONST from '../../../CONST'; -import FormHelpMessage from '../../../components/FormHelpMessage'; -import refPropTypes from '../../../components/refPropTypes'; -import getOperatingSystem from '../../../libs/getOperatingSystem'; -import * as Browser from '../../../libs/Browser'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; +import BigNumberPad from '@components/BigNumberPad'; +import Button from '@components/Button'; +import FormHelpMessage from '@components/FormHelpMessage'; +import refPropTypes from '@components/refPropTypes'; +import TextInputWithCurrencySymbol from '@components/TextInputWithCurrencySymbol'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as Browser from '@libs/Browser'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import getOperatingSystem from '@libs/getOperatingSystem'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const propTypes = { /** IOU amount saved in Onyx */ diff --git a/src/pages/iou/steps/MoneyRequestConfirmPage.js b/src/pages/iou/steps/MoneyRequestConfirmPage.js index 06f4dda04c18..79cf48ce634d 100644 --- a/src/pages/iou/steps/MoneyRequestConfirmPage.js +++ b/src/pages/iou/steps/MoneyRequestConfirmPage.js @@ -1,33 +1,33 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import MoneyRequestConfirmationList from '../../../components/MoneyRequestConfirmationList'; -import CONST from '../../../CONST'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import styles from '../../../styles/styles'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import * as IOU from '../../../libs/actions/IOU'; -import compose from '../../../libs/compose'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import * as OptionsListUtils from '../../../libs/OptionsListUtils'; -import * as MoneyRequestUtils from '../../../libs/MoneyRequestUtils'; -import withLocalize from '../../../components/withLocalize'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails'; -import reportPropTypes from '../../reportPropTypes'; -import personalDetailsPropType from '../../personalDetailsPropType'; -import * as FileUtils from '../../../libs/fileDownload/FileUtils'; -import * as Policy from '../../../libs/actions/Policy'; -import useNetwork from '../../../hooks/useNetwork'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import {iouPropTypes, iouDefaultProps} from '../propTypes'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import useInitialValue from '../../../hooks/useInitialValue'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MoneyRequestConfirmationList from '@components/MoneyRequestConfirmationList'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize from '@components/withLocalize'; +import useInitialValue from '@hooks/useInitialValue'; +import useNetwork from '@hooks/useNetwork'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import compose from '@libs/compose'; +import * as FileUtils from '@libs/fileDownload/FileUtils'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js index b3047588a217..ec5ab3a678bd 100644 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsPage.js @@ -1,22 +1,22 @@ -import React, {useEffect, useRef, useState, useCallback} from 'react'; -import {View} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import CONST from '../../../../CONST'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import ROUTES from '../../../../ROUTES'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useInitialValue from '@hooks/useInitialValue'; +import useLocalize from '@hooks/useLocalize'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import MoneyRequestParticipantsSelector from './MoneyRequestParticipantsSelector'; -import styles from '../../../../styles/styles'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import * as DeviceCapabilities from '../../../../libs/DeviceCapabilities'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import * as IOU from '../../../../libs/actions/IOU'; -import * as MoneyRequestUtils from '../../../../libs/MoneyRequestUtils'; -import {iouPropTypes, iouDefaultProps} from '../../propTypes'; -import useLocalize from '../../../../hooks/useLocalize'; -import useInitialValue from '../../../../hooks/useInitialValue'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js index 27da03b12e98..5d47a51fb73c 100755 --- a/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js +++ b/src/pages/iou/steps/MoneyRequstParticipantsPage/MoneyRequestParticipantsSelector.js @@ -1,21 +1,21 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import styles from '../../../../styles/styles'; -import OptionsSelector from '../../../../components/OptionsSelector'; -import * as OptionsListUtils from '../../../../libs/OptionsListUtils'; -import * as ReportUtils from '../../../../libs/ReportUtils'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import * as Browser from '../../../../libs/Browser'; -import compose from '../../../../libs/compose'; -import CONST from '../../../../CONST'; -import personalDetailsPropType from '../../../personalDetailsPropType'; -import reportPropTypes from '../../../reportPropTypes'; -import refPropTypes from '../../../../components/refPropTypes'; +import OptionsSelector from '@components/OptionsSelector'; +import refPropTypes from '@components/refPropTypes'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Beta features list */ diff --git a/src/pages/iou/steps/NewRequestAmountPage.js b/src/pages/iou/steps/NewRequestAmountPage.js index 15a2c74d8a95..e531e6706f55 100644 --- a/src/pages/iou/steps/NewRequestAmountPage.js +++ b/src/pages/iou/steps/NewRequestAmountPage.js @@ -1,26 +1,26 @@ +import {useFocusEffect} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useRef} from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import {useFocusEffect} from '@react-navigation/native'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import ONYXKEYS from '../../../ONYXKEYS'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import * as CurrencyUtils from '../../../libs/CurrencyUtils'; -import reportPropTypes from '../../reportPropTypes'; -import * as IOU from '../../../libs/actions/IOU'; -import useLocalize from '../../../hooks/useLocalize'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import * as IOUUtils from '@libs/IOUUtils'; +import * as MoneyRequestUtils from '@libs/MoneyRequestUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import {iouDefaultProps, iouPropTypes} from '@pages/iou/propTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as IOU from '@userActions/IOU'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import MoneyRequestAmountForm from './MoneyRequestAmountForm'; -import * as IOUUtils from '../../../libs/IOUUtils'; -import * as MoneyRequestUtils from '../../../libs/MoneyRequestUtils'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; -import styles from '../../../styles/styles'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import {iouPropTypes, iouDefaultProps} from '../propTypes'; -import CONST from '../../../CONST'; const propTypes = { /** React Navigation route */ diff --git a/src/pages/reportPropTypes.js b/src/pages/reportPropTypes.js index b70438171a73..a3bbbda5c0bf 100644 --- a/src/pages/reportPropTypes.js +++ b/src/pages/reportPropTypes.js @@ -1,7 +1,7 @@ -import _ from 'underscore'; import PropTypes from 'prop-types'; -import CONST from '../CONST'; -import avatarPropTypes from '../components/avatarPropTypes'; +import _ from 'underscore'; +import avatarPropTypes from '@components/avatarPropTypes'; +import CONST from '@src/CONST'; export default PropTypes.shape({ /** The specific type of chat */ diff --git a/src/pages/settings/AboutPage/AboutPage.js b/src/pages/settings/AboutPage/AboutPage.js index 36f088487469..8e9618036861 100644 --- a/src/pages/settings/AboutPage/AboutPage.js +++ b/src/pages/settings/AboutPage/AboutPage.js @@ -1,28 +1,28 @@ -import _ from 'underscore'; -import React, {useRef, useMemo} from 'react'; +import React, {useMemo, useRef} from 'react'; import {ScrollView, View} from 'react-native'; import DeviceInfo from 'react-native-device-info'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import TextLink from '../../../components/TextLink'; -import CONST from '../../../CONST'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import Logo from '../../../../assets/images/new-expensify.svg'; +import _ from 'underscore'; +import Logo from '@assets/images/new-expensify.svg'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItemList from '@components/MenuItemList'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useWaitForNavigation from '@hooks/useWaitForNavigation'; +import compose from '@libs/compose'; +import * as Environment from '@libs/Environment/Environment'; +import Navigation from '@libs/Navigation/Navigation'; +import {CONTEXT_MENU_TYPES} from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; import pkg from '../../../../package.json'; -import * as Report from '../../../libs/actions/Report'; -import * as Link from '../../../libs/actions/Link'; -import compose from '../../../libs/compose'; -import * as ReportActionContextMenu from '../../home/report/ContextMenu/ReportActionContextMenu'; -import {CONTEXT_MENU_TYPES} from '../../home/report/ContextMenu/ContextMenuActions'; -import * as Environment from '../../../libs/Environment/Environment'; -import MenuItemList from '../../../components/MenuItemList'; -import useWaitForNavigation from '../../../hooks/useWaitForNavigation'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/AppDownloadLinks.js b/src/pages/settings/AppDownloadLinks.js index 957120846f3b..db86b23fa048 100644 --- a/src/pages/settings/AppDownloadLinks.js +++ b/src/pages/settings/AppDownloadLinks.js @@ -1,20 +1,20 @@ -import _ from 'underscore'; import React from 'react'; import {ScrollView} from 'react-native'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import CONST from '../../CONST'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import MenuItem from '../../components/MenuItem'; -import styles from '../../styles/styles'; -import * as Link from '../../libs/actions/Link'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import * as ReportActionContextMenu from '../home/report/ContextMenu/ReportActionContextMenu'; -import {CONTEXT_MENU_TYPES} from '../home/report/ContextMenu/ContextMenuActions'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import {CONTEXT_MENU_TYPES} from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/InitialSettingsPage.js b/src/pages/settings/InitialSettingsPage.js index 5ed498fcb3d0..bc395b47bffb 100755 --- a/src/pages/settings/InitialSettingsPage.js +++ b/src/pages/settings/InitialSettingsPage.js @@ -1,49 +1,49 @@ import lodashGet from 'lodash/get'; -import React, {useState, useEffect, useRef, useMemo, useCallback} from 'react'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import CurrentUserPersonalDetailsSkeletonView from '../../components/CurrentUserPersonalDetailsSkeletonView'; -import {withNetwork} from '../../components/OnyxProvider'; -import styles from '../../styles/styles'; -import Text from '../../components/Text'; -import * as Session from '../../libs/actions/Session'; -import ONYXKEYS from '../../ONYXKEYS'; -import Tooltip from '../../components/Tooltip'; -import Avatar from '../../components/Avatar'; -import Navigation from '../../libs/Navigation/Navigation'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import MenuItem from '../../components/MenuItem'; -import themeColors from '../../styles/themes/default'; -import SCREENS from '../../SCREENS'; -import ROUTES from '../../ROUTES'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import CONST from '../../CONST'; -import Permissions from '../../libs/Permissions'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../components/withCurrentUserPersonalDetails'; -import * as PaymentMethods from '../../libs/actions/PaymentMethods'; -import bankAccountPropTypes from '../../components/bankAccountPropTypes'; -import cardPropTypes from '../../components/cardPropTypes'; -import * as Wallet from '../../libs/actions/Wallet'; -import walletTermsPropTypes from '../EnablePayments/walletTermsPropTypes'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import ConfirmModal from '../../components/ConfirmModal'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as Link from '../../libs/actions/Link'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes'; -import * as UserUtils from '../../libs/UserUtils'; -import policyMemberPropType from '../policyMemberPropType'; -import * as ReportActionContextMenu from '../home/report/ContextMenu/ReportActionContextMenu'; -import {CONTEXT_MENU_TYPES} from '../home/report/ContextMenu/ContextMenuActions'; -import * as CurrencyUtils from '../../libs/CurrencyUtils'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; -import useLocalize from '../../hooks/useLocalize'; -import useSingleExecution from '../../hooks/useSingleExecution'; -import useWaitForNavigation from '../../hooks/useWaitForNavigation'; -import HeaderPageLayout from '../../components/HeaderPageLayout'; +import _ from 'underscore'; +import Avatar from '@components/Avatar'; +import bankAccountPropTypes from '@components/bankAccountPropTypes'; +import cardPropTypes from '@components/cardPropTypes'; +import ConfirmModal from '@components/ConfirmModal'; +import CurrentUserPersonalDetailsSkeletonView from '@components/CurrentUserPersonalDetailsSkeletonView'; +import HeaderPageLayout from '@components/HeaderPageLayout'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import useSingleExecution from '@hooks/useSingleExecution'; +import useWaitForNavigation from '@hooks/useWaitForNavigation'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import walletTermsPropTypes from '@pages/EnablePayments/walletTermsPropTypes'; +import {CONTEXT_MENU_TYPES} from '@pages/home/report/ContextMenu/ContextMenuActions'; +import * as ReportActionContextMenu from '@pages/home/report/ContextMenu/ReportActionContextMenu'; +import policyMemberPropType from '@pages/policyMemberPropType'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Link from '@userActions/Link'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import * as Session from '@userActions/Session'; +import * as Wallet from '@userActions/Wallet'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Preferences/LanguagePage.js b/src/pages/settings/Preferences/LanguagePage.js index f55e49eb561e..9ef95d599e97 100644 --- a/src/pages/settings/Preferences/LanguagePage.js +++ b/src/pages/settings/Preferences/LanguagePage.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; -import React from 'react'; import PropTypes from 'prop-types'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as App from '../../../libs/actions/App'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; -import SelectionList from '../../../components/SelectionList'; +import React from 'react'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as App from '@userActions/App'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Preferences/PreferencesPage.js b/src/pages/settings/Preferences/PreferencesPage.js index 9e30e99ff38f..c86eed258151 100755 --- a/src/pages/settings/Preferences/PreferencesPage.js +++ b/src/pages/settings/Preferences/PreferencesPage.js @@ -1,24 +1,24 @@ import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; -import Text from '../../../components/Text'; -import CONST from '../../../CONST'; -import * as User from '../../../libs/actions/User'; -import Switch from '../../../components/Switch'; -import TestToolMenu from '../../../components/TestToolMenu'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import IllustratedHeaderPageLayout from '../../../components/IllustratedHeaderPageLayout'; -import * as LottieAnimations from '../../../components/LottieAnimations'; -import SCREENS from '../../../SCREENS'; -import useEnvironment from '../../../hooks/useEnvironment'; -import useLocalize from '../../../hooks/useLocalize'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import Switch from '@components/Switch'; +import TestToolMenu from '@components/TestToolMenu'; +import Text from '@components/Text'; +import useEnvironment from '@hooks/useEnvironment'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { /** The chat priority mode */ diff --git a/src/pages/settings/Preferences/PriorityModePage.js b/src/pages/settings/Preferences/PriorityModePage.js index 38f856825dcc..73c6932b6218 100644 --- a/src/pages/settings/Preferences/PriorityModePage.js +++ b/src/pages/settings/Preferences/PriorityModePage.js @@ -1,18 +1,18 @@ -import _, {compose} from 'underscore'; +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as User from '../../../libs/actions/User'; -import CONST from '../../../CONST'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import SelectionList from '../../../components/SelectionList'; +import _, {compose} from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** The chat priority mode */ diff --git a/src/pages/settings/Preferences/ThemePage.js b/src/pages/settings/Preferences/ThemePage.js index 0dd6115e74e8..7802faecce14 100644 --- a/src/pages/settings/Preferences/ThemePage.js +++ b/src/pages/settings/Preferences/ThemePage.js @@ -1,19 +1,19 @@ -import _ from 'underscore'; +import PropTypes from 'prop-types'; import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import SelectionList from '../../../components/SelectionList'; -import styles from '../../../styles/styles'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import compose from '../../../libs/compose'; -import Text from '../../../components/Text'; -import * as User from '../../../libs/actions/User'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Profile/Contacts/ContactMethodDetailsPage.js b/src/pages/settings/Profile/Contacts/ContactMethodDetailsPage.js index 1c9abcf535f6..c48191957999 100644 --- a/src/pages/settings/Profile/Contacts/ContactMethodDetailsPage.js +++ b/src/pages/settings/Profile/Contacts/ContactMethodDetailsPage.js @@ -1,31 +1,31 @@ import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; -import React, {Component} from 'react'; -import {View, ScrollView, Keyboard} from 'react-native'; import PropTypes from 'prop-types'; +import React, {Component} from 'react'; +import {Keyboard, ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import compose from '../../../../libs/compose'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import MenuItem from '../../../../components/MenuItem'; -import styles from '../../../../styles/styles'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import Text from '../../../../components/Text'; -import OfflineWithFeedback from '../../../../components/OfflineWithFeedback'; -import DotIndicatorMessage from '../../../../components/DotIndicatorMessage'; -import ConfirmModal from '../../../../components/ConfirmModal'; -import * as User from '../../../../libs/actions/User'; -import * as ErrorUtils from '../../../../libs/ErrorUtils'; -import themeColors from '../../../../styles/themes/default'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import ConfirmModal from '@components/ConfirmModal'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import ValidateCodeForm from './ValidateCodeForm'; -import ROUTES from '../../../../ROUTES'; -import FullscreenLoadingIndicator from '../../../../components/FullscreenLoadingIndicator'; -import FullPageNotFoundView from '../../../../components/BlockingViews/FullPageNotFoundView'; -import CONST from '../../../../CONST'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/Contacts/ContactMethodsPage.js b/src/pages/settings/Profile/Contacts/ContactMethodsPage.js index c710013f9a68..fbd7b4340cec 100644 --- a/src/pages/settings/Profile/Contacts/ContactMethodsPage.js +++ b/src/pages/settings/Profile/Contacts/ContactMethodsPage.js @@ -2,24 +2,24 @@ import Str from 'expensify-common/lib/str'; import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; import React from 'react'; -import {View, ScrollView} from 'react-native'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import Button from '../../../../components/Button'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import CONST from '../../../../CONST'; -import compose from '../../../../libs/compose'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import ROUTES from '../../../../ROUTES'; -import styles from '../../../../styles/styles'; -import MenuItem from '../../../../components/MenuItem'; -import Text from '../../../../components/Text'; -import CopyTextToClipboard from '../../../../components/CopyTextToClipboard'; -import OfflineWithFeedback from '../../../../components/OfflineWithFeedback'; -import FixedFooter from '../../../../components/FixedFooter'; +import Button from '@components/Button'; +import CopyTextToClipboard from '@components/CopyTextToClipboard'; +import FixedFooter from '@components/FixedFooter'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/Contacts/NewContactMethodPage.js b/src/pages/settings/Profile/Contacts/NewContactMethodPage.js index e6f55b7cd6cb..9e40ef65dfd6 100644 --- a/src/pages/settings/Profile/Contacts/NewContactMethodPage.js +++ b/src/pages/settings/Profile/Contacts/NewContactMethodPage.js @@ -1,26 +1,26 @@ -import React, {useRef} from 'react'; +import Str from 'expensify-common/lib/str'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useRef} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import Str from 'expensify-common/lib/str'; -import compose from '../../../../libs/compose'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import Text from '../../../../components/Text'; -import TextInput from '../../../../components/TextInput'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import ROUTES from '../../../../ROUTES'; -import styles from '../../../../styles/styles'; -import * as User from '../../../../libs/actions/User'; -import * as LoginUtils from '../../../../libs/LoginUtils'; -import * as ErrorUtils from '../../../../libs/ErrorUtils'; -import CONST from '../../../../CONST'; -import FormProvider from '../../../../components/Form/FormProvider'; -import InputWrapper from '../../../../components/Form/InputWrapper'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as LoginUtils from '@libs/LoginUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/Contacts/ValidateCodeForm/BaseValidateCodeForm.js b/src/pages/settings/Profile/Contacts/ValidateCodeForm/BaseValidateCodeForm.js index 73231cd315ad..3cdbb815f66f 100644 --- a/src/pages/settings/Profile/Contacts/ValidateCodeForm/BaseValidateCodeForm.js +++ b/src/pages/settings/Profile/Contacts/ValidateCodeForm/BaseValidateCodeForm.js @@ -1,28 +1,28 @@ -import React, {useCallback, useState, useEffect, useRef, useImperativeHandle} from 'react'; -import {View} from 'react-native'; +import {useFocusEffect} from '@react-navigation/native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import _ from 'underscore'; +import React, {useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import {useFocusEffect} from '@react-navigation/native'; -import MagicCodeInput from '../../../../../components/MagicCodeInput'; -import * as ErrorUtils from '../../../../../libs/ErrorUtils'; -import withLocalize, {withLocalizePropTypes} from '../../../../../components/withLocalize'; -import ONYXKEYS from '../../../../../ONYXKEYS'; -import compose from '../../../../../libs/compose'; -import styles from '../../../../../styles/styles'; -import OfflineWithFeedback from '../../../../../components/OfflineWithFeedback'; -import * as ValidationUtils from '../../../../../libs/ValidationUtils'; -import * as User from '../../../../../libs/actions/User'; -import Button from '../../../../../components/Button'; -import DotIndicatorMessage from '../../../../../components/DotIndicatorMessage'; -import * as Session from '../../../../../libs/actions/Session'; -import Text from '../../../../../components/Text'; -import {withNetwork} from '../../../../../components/OnyxProvider'; -import PressableWithFeedback from '../../../../../components/Pressable/PressableWithFeedback'; -import themeColors from '../../../../../styles/themes/default'; -import * as StyleUtils from '../../../../../styles/StyleUtils'; -import CONST from '../../../../../CONST'; +import _ from 'underscore'; +import Button from '@components/Button'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import MagicCodeInput from '@components/MagicCodeInput'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import * as Session from '@userActions/Session'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Profile/CustomStatus/StatusPage.js b/src/pages/settings/Profile/CustomStatus/StatusPage.js index 0fa231aec6f1..5d7bb11f4537 100644 --- a/src/pages/settings/Profile/CustomStatus/StatusPage.js +++ b/src/pages/settings/Profile/CustomStatus/StatusPage.js @@ -1,25 +1,25 @@ -import React, {useMemo, useCallback, useEffect} from 'react'; +import lodashGet from 'lodash/get'; +import React, {useCallback, useEffect, useMemo} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes} from '../../../../components/withCurrentUserPersonalDetails'; -import MenuItemWithTopDescription from '../../../../components/MenuItemWithTopDescription'; -import HeaderPageLayout from '../../../../components/HeaderPageLayout'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import withLocalize from '../../../../components/withLocalize'; -import Button from '../../../../components/Button'; -import Text from '../../../../components/Text'; -import MenuItem from '../../../../components/MenuItem'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import * as User from '../../../../libs/actions/User'; -import MobileBackgroundImage from '../../../../../assets/images/money-stack.svg'; -import themeColors from '../../../../styles/themes/default'; -import useLocalize from '../../../../hooks/useLocalize'; -import styles from '../../../../styles/styles'; -import compose from '../../../../libs/compose'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import ROUTES from '../../../../ROUTES'; -import SCREENS from '../../../../SCREENS'; +import MobileBackgroundImage from '@assets/images/money-stack.svg'; +import Button from '@components/Button'; +import HeaderPageLayout from '@components/HeaderPageLayout'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import Text from '@components/Text'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize from '@components/withLocalize'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as User from '@userActions/User'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { ...withCurrentUserPersonalDetailsPropTypes, diff --git a/src/pages/settings/Profile/CustomStatus/StatusSetPage.js b/src/pages/settings/Profile/CustomStatus/StatusSetPage.js index ac04c3ee5d4f..1d26c0e6dec4 100644 --- a/src/pages/settings/Profile/CustomStatus/StatusSetPage.js +++ b/src/pages/settings/Profile/CustomStatus/StatusSetPage.js @@ -1,23 +1,23 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import ROUTES from '../../../../ROUTES'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import compose from '../../../../libs/compose'; -import styles from '../../../../styles/styles'; -import useLocalize from '../../../../hooks/useLocalize'; -import CONST from '../../../../CONST'; -import EmojiPickerButtonDropdown from '../../../../components/EmojiPicker/EmojiPickerButtonDropdown'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import * as User from '../../../../libs/actions/User'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes} from '../../../../components/withCurrentUserPersonalDetails'; -import TextInput from '../../../../components/TextInput'; -import FormProvider from '../../../../components/Form/FormProvider'; -import InputWrapper from '../../../../components/Form/InputWrapper'; +import EmojiPickerButtonDropdown from '@components/EmojiPicker/EmojiPickerButtonDropdown'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** The draft status of the user */ diff --git a/src/pages/settings/Profile/DisplayNamePage.js b/src/pages/settings/Profile/DisplayNamePage.js index 0fe7fa20ce0a..379b5f225310 100644 --- a/src/pages/settings/Profile/DisplayNamePage.js +++ b/src/pages/settings/Profile/DisplayNamePage.js @@ -1,26 +1,26 @@ import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import TextInput from '../../../components/TextInput'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import compose from '../../../libs/compose'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; -import ROUTES from '../../../ROUTES'; -import Navigation from '../../../libs/Navigation/Navigation'; -import FormProvider from '../../../components/Form/FormProvider'; -import InputWrapper from '../../../components/Form/InputWrapper'; -import FullScreenLoadingIndicator from '../../../components/FullscreenLoadingIndicator'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Profile/LoungeAccessPage.js b/src/pages/settings/Profile/LoungeAccessPage.js index 81d63592211b..9c5c43463944 100644 --- a/src/pages/settings/Profile/LoungeAccessPage.js +++ b/src/pages/settings/Profile/LoungeAccessPage.js @@ -1,27 +1,27 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import ONYXKEYS from '../../../ONYXKEYS'; -import userPropTypes from '../userPropTypes'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import useLocalize from '../../../hooks/useLocalize'; -import FeatureList from '../../../components/FeatureList'; -import IllustratedHeaderPageLayout from '../../../components/IllustratedHeaderPageLayout'; -import * as LottieAnimations from '../../../components/LottieAnimations'; -import compose from '../../../libs/compose'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails'; -import LinearGradient from '../../../components/LinearGradient'; -import styles from '../../../styles/styles'; -import Avatar from '../../../components/Avatar'; -import Text from '../../../components/Text'; -import * as UserUtils from '../../../libs/UserUtils'; -import CONST from '../../../CONST'; -import themeColors from '../../../styles/themes/default'; -import * as LocalePhoneNumber from '../../../libs/LocalePhoneNumber'; +import Avatar from '@components/Avatar'; +import FeatureList from '@components/FeatureList'; +import * as Illustrations from '@components/Icon/Illustrations'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import LinearGradient from '@components/LinearGradient'; +import * as LottieAnimations from '@components/LottieAnimations'; +import Text from '@components/Text'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import Navigation from '@libs/Navigation/Navigation'; +import * as UserUtils from '@libs/UserUtils'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import userPropTypes from '@pages/settings/userPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** The session of the logged in person */ diff --git a/src/pages/settings/Profile/PersonalDetails/AddressPage.js b/src/pages/settings/Profile/PersonalDetails/AddressPage.js index 3a49b6901035..a6cb069780b2 100644 --- a/src/pages/settings/Profile/PersonalDetails/AddressPage.js +++ b/src/pages/settings/Profile/PersonalDetails/AddressPage.js @@ -1,27 +1,27 @@ +import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; -import React, {useState, useCallback, useEffect, useMemo} from 'react'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; -import {CONST as COMMON_CONST} from 'expensify-common/lib/CONST'; import {withOnyx} from 'react-native-onyx'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import Form from '../../../../components/Form'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import CONST from '../../../../CONST'; -import TextInput from '../../../../components/TextInput'; -import styles from '../../../../styles/styles'; -import * as PersonalDetails from '../../../../libs/actions/PersonalDetails'; -import * as ValidationUtils from '../../../../libs/ValidationUtils'; -import AddressSearch from '../../../../components/AddressSearch'; -import StatePicker from '../../../../components/StatePicker'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; -import useLocalize from '../../../../hooks/useLocalize'; -import usePrivatePersonalDetails from '../../../../hooks/usePrivatePersonalDetails'; -import FullscreenLoadingIndicator from '../../../../components/FullscreenLoadingIndicator'; -import CountrySelector from '../../../../components/CountrySelector'; +import _ from 'underscore'; +import AddressSearch from '@components/AddressSearch'; +import CountrySelector from '@components/CountrySelector'; +import Form from '@components/Form'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import StatePicker from '@components/StatePicker'; +import TextInput from '@components/TextInput'; +import useLocalize from '@hooks/useLocalize'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/PersonalDetails/CountrySelectionPage.js b/src/pages/settings/Profile/PersonalDetails/CountrySelectionPage.js index 741974776df1..a0c2a02b2cb5 100644 --- a/src/pages/settings/Profile/PersonalDetails/CountrySelectionPage.js +++ b/src/pages/settings/Profile/PersonalDetails/CountrySelectionPage.js @@ -1,15 +1,15 @@ -import React, {useState, useMemo, useCallback} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useMemo, useState} from 'react'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import SelectionList from '../../../../components/SelectionList'; -import searchCountryOptions from '../../../../libs/searchCountryOptions'; -import StringUtils from '../../../../libs/StringUtils'; -import CONST from '../../../../CONST'; -import useLocalize from '../../../../hooks/useLocalize'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import searchCountryOptions from '@libs/searchCountryOptions'; +import StringUtils from '@libs/StringUtils'; +import CONST from '@src/CONST'; const propTypes = { /** Route from navigation */ diff --git a/src/pages/settings/Profile/PersonalDetails/DateOfBirthPage.js b/src/pages/settings/Profile/PersonalDetails/DateOfBirthPage.js index 68d81d64c604..51164fa29dac 100644 --- a/src/pages/settings/Profile/PersonalDetails/DateOfBirthPage.js +++ b/src/pages/settings/Profile/PersonalDetails/DateOfBirthPage.js @@ -1,23 +1,23 @@ +import {subYears} from 'date-fns'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import {subYears} from 'date-fns'; -import CONST from '../../../../CONST'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import ROUTES from '../../../../ROUTES'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import NewDatePicker from '../../../../components/NewDatePicker'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import * as ValidationUtils from '../../../../libs/ValidationUtils'; -import * as PersonalDetails from '../../../../libs/actions/PersonalDetails'; -import compose from '../../../../libs/compose'; -import styles from '../../../../styles/styles'; -import usePrivatePersonalDetails from '../../../../hooks/usePrivatePersonalDetails'; -import FullscreenLoadingIndicator from '../../../../components/FullscreenLoadingIndicator'; -import FormProvider from '../../../../components/Form/FormProvider'; +import FormProvider from '@components/Form/FormProvider'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import NewDatePicker from '@components/NewDatePicker'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/PersonalDetails/LegalNamePage.js b/src/pages/settings/Profile/PersonalDetails/LegalNamePage.js index 8d10c7c85b31..eeb6d8217f9f 100644 --- a/src/pages/settings/Profile/PersonalDetails/LegalNamePage.js +++ b/src/pages/settings/Profile/PersonalDetails/LegalNamePage.js @@ -1,26 +1,26 @@ -import _ from 'underscore'; -import React, {useCallback} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import CONST from '../../../../CONST'; -import * as ValidationUtils from '../../../../libs/ValidationUtils'; -import TextInput from '../../../../components/TextInput'; -import styles from '../../../../styles/styles'; -import * as PersonalDetails from '../../../../libs/actions/PersonalDetails'; -import compose from '../../../../libs/compose'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; -import usePrivatePersonalDetails from '../../../../hooks/usePrivatePersonalDetails'; -import FullscreenLoadingIndicator from '../../../../components/FullscreenLoadingIndicator'; -import * as ErrorUtils from '../../../../libs/ErrorUtils'; -import FormProvider from '../../../../components/Form/FormProvider'; -import InputWrapper from '../../../../components/Form/InputWrapper'; +import _ from 'underscore'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/PersonalDetails/PersonalDetailsInitialPage.js b/src/pages/settings/Profile/PersonalDetails/PersonalDetailsInitialPage.js index 3b695de3fcb7..3a35f65f45ae 100644 --- a/src/pages/settings/Profile/PersonalDetails/PersonalDetailsInitialPage.js +++ b/src/pages/settings/Profile/PersonalDetails/PersonalDetailsInitialPage.js @@ -1,22 +1,22 @@ -import React from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React from 'react'; import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize'; -import ROUTES from '../../../../ROUTES'; -import Text from '../../../../components/Text'; -import styles from '../../../../styles/styles'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import compose from '../../../../libs/compose'; -import MenuItemWithTopDescription from '../../../../components/MenuItemWithTopDescription'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import {withNetwork} from '../../../../components/OnyxProvider'; -import usePrivatePersonalDetails from '../../../../hooks/usePrivatePersonalDetails'; -import FullscreenLoadingIndicator from '../../../../components/FullscreenLoadingIndicator'; -import * as PersonalDetailsUtils from '../../../../libs/PersonalDetailsUtils'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import styles from '@styles/styles'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/ProfilePage.js b/src/pages/settings/Profile/ProfilePage.js index dda3dd4f456a..7ec8e05b76ff 100755 --- a/src/pages/settings/Profile/ProfilePage.js +++ b/src/pages/settings/Profile/ProfilePage.js @@ -1,29 +1,29 @@ import lodashGet from 'lodash/get'; -import React, {useEffect} from 'react'; -import {View, ScrollView} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import AvatarWithImagePicker from '../../../components/AvatarWithImagePicker'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import MenuItem from '../../../components/MenuItem'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import CONST from '../../../CONST'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import compose from '../../../libs/compose'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as UserUtils from '../../../libs/UserUtils'; -import ROUTES from '../../../ROUTES'; -import styles from '../../../styles/styles'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import userPropTypes from '../userPropTypes'; -import * as App from '../../../libs/actions/App'; -import Permissions from '../../../libs/Permissions'; +import AvatarWithImagePicker from '@components/AvatarWithImagePicker'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as UserUtils from '@libs/UserUtils'; +import userPropTypes from '@pages/settings/userPropTypes'; +import styles from '@styles/styles'; +import * as App from '@userActions/App'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Profile/PronounsPage.js b/src/pages/settings/Profile/PronounsPage.js index 232b861a0f35..408da6376853 100644 --- a/src/pages/settings/Profile/PronounsPage.js +++ b/src/pages/settings/Profile/PronounsPage.js @@ -1,22 +1,22 @@ -import _ from 'underscore'; import lodashGet from 'lodash/get'; -import React, {useState, useMemo, useEffect} from 'react'; -import {withOnyx} from 'react-native-onyx'; import PropTypes from 'prop-types'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import CONST from '../../../CONST'; -import ROUTES from '../../../ROUTES'; -import Navigation from '../../../libs/Navigation/Navigation'; -import SelectionList from '../../../components/SelectionList'; -import useLocalize from '../../../hooks/useLocalize'; -import ONYXKEYS from '../../../ONYXKEYS'; -import FullScreenLoadingIndicator from '../../../components/FullscreenLoadingIndicator'; -import compose from '../../../libs/compose'; +import React, {useEffect, useMemo, useState} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import FullScreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import Text from '@components/Text'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withCurrentUserPersonalDetailsPropTypes, diff --git a/src/pages/settings/Profile/TimezoneInitialPage.js b/src/pages/settings/Profile/TimezoneInitialPage.js index 5fd5e1bd7661..d2dec7195087 100644 --- a/src/pages/settings/Profile/TimezoneInitialPage.js +++ b/src/pages/settings/Profile/TimezoneInitialPage.js @@ -1,19 +1,19 @@ import lodashGet from 'lodash/get'; import React from 'react'; import {View} from 'react-native'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import compose from '../../../libs/compose'; -import Switch from '../../../components/Switch'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Switch from '@components/Switch'; +import Text from '@components/Text'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Profile/TimezoneSelectPage.js b/src/pages/settings/Profile/TimezoneSelectPage.js index 6bf0c2e974a4..2586be9fb673 100644 --- a/src/pages/settings/Profile/TimezoneSelectPage.js +++ b/src/pages/settings/Profile/TimezoneSelectPage.js @@ -1,17 +1,17 @@ import lodashGet from 'lodash/get'; import React, {useState} from 'react'; import _ from 'underscore'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import CONST from '../../../CONST'; -import TIMEZONES from '../../../TIMEZONES'; -import * as PersonalDetails from '../../../libs/actions/PersonalDetails'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import SelectionList from '../../../components/SelectionList'; -import useLocalize from '../../../hooks/useLocalize'; -import useInitialValue from '../../../hooks/useInitialValue'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import useInitialValue from '@hooks/useInitialValue'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PersonalDetails from '@userActions/PersonalDetails'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; +import TIMEZONES from '@src/TIMEZONES'; const propTypes = { ...withCurrentUserPersonalDetailsPropTypes, diff --git a/src/pages/settings/Report/NotificationPreferencePage.js b/src/pages/settings/Report/NotificationPreferencePage.js index 43e346150ca8..75e9e0d5c5e8 100644 --- a/src/pages/settings/Report/NotificationPreferencePage.js +++ b/src/pages/settings/Report/NotificationPreferencePage.js @@ -1,18 +1,18 @@ import React from 'react'; import _ from 'underscore'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Navigation from '../../../libs/Navigation/Navigation'; -import compose from '../../../libs/compose'; -import withReportOrNotFound from '../../home/report/withReportOrNotFound'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; -import reportPropTypes from '../../reportPropTypes'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; -import * as Report from '../../../libs/actions/Report'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import SelectionList from '../../../components/SelectionList'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Report/ReportSettingsPage.js b/src/pages/settings/Report/ReportSettingsPage.js index fb88cbd59f25..df23e16e80cd 100644 --- a/src/pages/settings/Report/ReportSettingsPage.js +++ b/src/pages/settings/Report/ReportSettingsPage.js @@ -1,29 +1,29 @@ -import React, {useMemo} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import {View, ScrollView} from 'react-native'; +import React, {useMemo} from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import compose from '../../../libs/compose'; -import Navigation from '../../../libs/Navigation/Navigation'; -import * as Report from '../../../libs/actions/Report'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import useLocalize from '../../../hooks/useLocalize'; -import Text from '../../../components/Text'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import reportPropTypes from '../../reportPropTypes'; -import withReportOrNotFound from '../../home/report/withReportOrNotFound'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import ROUTES from '../../../ROUTES'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import MenuItem from '../../../components/MenuItem'; -import DisplayNames from '../../../components/DisplayNames'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import DisplayNames from '@components/DisplayNames'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Route params */ diff --git a/src/pages/settings/Report/RoomNamePage.js b/src/pages/settings/Report/RoomNamePage.js index 4ce997533378..2ff9b1f1108f 100644 --- a/src/pages/settings/Report/RoomNamePage.js +++ b/src/pages/settings/Report/RoomNamePage.js @@ -1,26 +1,26 @@ -import React, {useCallback, useRef} from 'react'; -import {withOnyx} from 'react-native-onyx'; +import {useIsFocused} from '@react-navigation/native'; import PropTypes from 'prop-types'; +import React, {useCallback, useRef} from 'react'; import {View} from 'react-native'; -import {useIsFocused} from '@react-navigation/native'; -import CONST from '../../../CONST'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Form from '../../../components/Form'; -import ONYXKEYS from '../../../ONYXKEYS'; -import styles from '../../../styles/styles'; -import Navigation from '../../../libs/Navigation/Navigation'; -import compose from '../../../libs/compose'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import withReportOrNotFound from '../../home/report/withReportOrNotFound'; -import reportPropTypes from '../../reportPropTypes'; -import ROUTES from '../../../ROUTES'; -import * as Report from '../../../libs/actions/Report'; -import RoomNameInput from '../../../components/RoomNameInput'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; +import {withOnyx} from 'react-native-onyx'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import RoomNameInput from '@components/RoomNameInput'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Report/WriteCapabilityPage.js b/src/pages/settings/Report/WriteCapabilityPage.js index 174cc57d8d18..c1b417bc28bd 100644 --- a/src/pages/settings/Report/WriteCapabilityPage.js +++ b/src/pages/settings/Report/WriteCapabilityPage.js @@ -1,22 +1,22 @@ import React from 'react'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Navigation from '../../../libs/Navigation/Navigation'; -import compose from '../../../libs/compose'; -import withReportOrNotFound from '../../home/report/withReportOrNotFound'; -import reportPropTypes from '../../reportPropTypes'; -import ROUTES from '../../../ROUTES'; -import * as Report from '../../../libs/actions/Report'; -import * as ReportUtils from '../../../libs/ReportUtils'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; -import * as PolicyUtils from '../../../libs/PolicyUtils'; -import {policyPropTypes, policyDefaultProps} from '../../workspace/withPolicy'; -import SelectionList from '../../../components/SelectionList'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import {policyDefaultProps, policyPropTypes} from '@pages/workspace/withPolicy'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Security/CloseAccountPage.js b/src/pages/settings/Security/CloseAccountPage.js index 763f6c77d774..da4cd7b60e2a 100644 --- a/src/pages/settings/Security/CloseAccountPage.js +++ b/src/pages/settings/Security/CloseAccountPage.js @@ -1,26 +1,26 @@ -import React, {useState, useEffect} from 'react'; +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import * as User from '../../../libs/actions/User'; -import compose from '../../../libs/compose'; -import styles from '../../../styles/styles'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import TextInput from '../../../components/TextInput'; -import Text from '../../../components/Text'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import * as CloseAccount from '../../../libs/actions/CloseAccount'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import ConfirmModal from '../../../components/ConfirmModal'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import FormProvider from '../../../components/Form/FormProvider'; -import InputWrapper from '../../../components/Form/InputWrapper'; +import ConfirmModal from '@components/ConfirmModal'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as CloseAccount from '@userActions/CloseAccount'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Session of currently logged in user */ diff --git a/src/pages/settings/Security/SecuritySettingsPage.js b/src/pages/settings/Security/SecuritySettingsPage.js index dac4ed4f872f..1bd6310ec97f 100644 --- a/src/pages/settings/Security/SecuritySettingsPage.js +++ b/src/pages/settings/Security/SecuritySettingsPage.js @@ -3,19 +3,19 @@ import React, {useMemo} from 'react'; import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../../ONYXKEYS'; -import ROUTES from '../../../ROUTES'; -import SCREENS from '../../../SCREENS'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import IllustratedHeaderPageLayout from '../../../components/IllustratedHeaderPageLayout'; -import * as LottieAnimations from '../../../components/LottieAnimations'; -import MenuItemList from '../../../components/MenuItemList'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import useWaitForNavigation from '../../../hooks/useWaitForNavigation'; -import Navigation from '../../../libs/Navigation/Navigation'; -import compose from '../../../libs/compose'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; +import * as Expensicons from '@components/Icon/Expensicons'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import MenuItemList from '@components/MenuItemList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useWaitForNavigation from '@hooks/useWaitForNavigation'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper.js b/src/pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper.js index 64aa64d07ee5..98df839ce31e 100644 --- a/src/pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper.js +++ b/src/pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper.js @@ -1,12 +1,12 @@ import React from 'react'; -import HeaderWithBackButton from '../../../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../../../components/ScreenWrapper'; -import FullPageOfflineBlockingView from '../../../../../components/BlockingViews/FullPageOfflineBlockingView'; -import * as TwoFactorAuthActions from '../../../../../libs/actions/TwoFactorAuthActions'; +import AnimatedStep from '@components/AnimatedStep'; +import useAnimatedStepContext from '@components/AnimatedStep/useAnimatedStepContext'; +import FullPageOfflineBlockingView from '@components/BlockingViews/FullPageOfflineBlockingView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import styles from '@styles/styles'; +import * as TwoFactorAuthActions from '@userActions/TwoFactorAuthActions'; import StepWrapperPropTypes from './StepWrapperPropTypes'; -import AnimatedStep from '../../../../../components/AnimatedStep'; -import styles from '../../../../../styles/styles'; -import useAnimatedStepContext from '../../../../../components/AnimatedStep/useAnimatedStepContext'; function StepWrapper({ title = '', diff --git a/src/pages/settings/Security/TwoFactorAuth/Steps/CodesStep.js b/src/pages/settings/Security/TwoFactorAuth/Steps/CodesStep.js index ebad8d8bc5d0..6d74a0f91bd9 100644 --- a/src/pages/settings/Security/TwoFactorAuth/Steps/CodesStep.js +++ b/src/pages/settings/Security/TwoFactorAuth/Steps/CodesStep.js @@ -1,28 +1,28 @@ import React, {useEffect, useState} from 'react'; +import {ActivityIndicator, ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import {ActivityIndicator, View, ScrollView} from 'react-native'; import _ from 'underscore'; -import * as Expensicons from '../../../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../../../components/Icon/Illustrations'; -import styles from '../../../../../styles/styles'; -import FixedFooter from '../../../../../components/FixedFooter'; -import Button from '../../../../../components/Button'; -import PressableWithDelayToggle from '../../../../../components/Pressable/PressableWithDelayToggle'; -import Text from '../../../../../components/Text'; -import Section from '../../../../../components/Section'; -import ONYXKEYS from '../../../../../ONYXKEYS'; -import Clipboard from '../../../../../libs/Clipboard'; -import themeColors from '../../../../../styles/themes/default'; -import localFileDownload from '../../../../../libs/localFileDownload'; -import * as Session from '../../../../../libs/actions/Session'; -import CONST from '../../../../../CONST'; -import useTwoFactorAuthContext from '../TwoFactorAuthContext/useTwoFactorAuth'; -import useLocalize from '../../../../../hooks/useLocalize'; -import useWindowDimensions from '../../../../../hooks/useWindowDimensions'; -import StepWrapper from '../StepWrapper/StepWrapper'; -import {defaultAccount, TwoFactorAuthPropTypes} from '../TwoFactorAuthPropTypes'; -import * as TwoFactorAuthActions from '../../../../../libs/actions/TwoFactorAuthActions'; -import FormHelpMessage from '../../../../../components/FormHelpMessage'; +import Button from '@components/Button'; +import FixedFooter from '@components/FixedFooter'; +import FormHelpMessage from '@components/FormHelpMessage'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import PressableWithDelayToggle from '@components/Pressable/PressableWithDelayToggle'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import Clipboard from '@libs/Clipboard'; +import localFileDownload from '@libs/localFileDownload'; +import StepWrapper from '@pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper'; +import useTwoFactorAuthContext from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthContext/useTwoFactorAuth'; +import {defaultAccount, TwoFactorAuthPropTypes} from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Session from '@userActions/Session'; +import * as TwoFactorAuthActions from '@userActions/TwoFactorAuthActions'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; function CodesStep({account = defaultAccount}) { const {translate} = useLocalize(); diff --git a/src/pages/settings/Security/TwoFactorAuth/Steps/DisabledStep.js b/src/pages/settings/Security/TwoFactorAuth/Steps/DisabledStep.js index 2f3b87e69a6e..317e510024b0 100644 --- a/src/pages/settings/Security/TwoFactorAuth/Steps/DisabledStep.js +++ b/src/pages/settings/Security/TwoFactorAuth/Steps/DisabledStep.js @@ -1,13 +1,13 @@ import React from 'react'; -import * as Illustrations from '../../../../../components/Icon/Illustrations'; -import styles from '../../../../../styles/styles'; -import BlockingView from '../../../../../components/BlockingViews/BlockingView'; -import FixedFooter from '../../../../../components/FixedFooter'; -import Button from '../../../../../components/Button'; -import variables from '../../../../../styles/variables'; -import StepWrapper from '../StepWrapper/StepWrapper'; -import useLocalize from '../../../../../hooks/useLocalize'; -import * as TwoFactorAuthActions from '../../../../../libs/actions/TwoFactorAuthActions'; +import BlockingView from '@components/BlockingViews/BlockingView'; +import Button from '@components/Button'; +import FixedFooter from '@components/FixedFooter'; +import * as Illustrations from '@components/Icon/Illustrations'; +import useLocalize from '@hooks/useLocalize'; +import StepWrapper from '@pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as TwoFactorAuthActions from '@userActions/TwoFactorAuthActions'; function DisabledStep() { const {translate} = useLocalize(); diff --git a/src/pages/settings/Security/TwoFactorAuth/Steps/EnabledStep.js b/src/pages/settings/Security/TwoFactorAuth/Steps/EnabledStep.js index 584d6195bbe6..6b0edfc49da3 100644 --- a/src/pages/settings/Security/TwoFactorAuth/Steps/EnabledStep.js +++ b/src/pages/settings/Security/TwoFactorAuth/Steps/EnabledStep.js @@ -1,16 +1,16 @@ import React, {useState} from 'react'; -import {Text, View, ScrollView} from 'react-native'; -import Section from '../../../../../components/Section'; -import * as Illustrations from '../../../../../components/Icon/Illustrations'; -import * as Expensicons from '../../../../../components/Icon/Expensicons'; -import themeColors from '../../../../../styles/themes/default'; -import styles from '../../../../../styles/styles'; -import ConfirmModal from '../../../../../components/ConfirmModal'; -import * as Session from '../../../../../libs/actions/Session'; -import StepWrapper from '../StepWrapper/StepWrapper'; -import CONST from '../../../../../CONST'; -import useLocalize from '../../../../../hooks/useLocalize'; -import useTwoFactorAuthContext from '../TwoFactorAuthContext/useTwoFactorAuth'; +import {ScrollView, Text, View} from 'react-native'; +import ConfirmModal from '@components/ConfirmModal'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import useLocalize from '@hooks/useLocalize'; +import StepWrapper from '@pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper'; +import useTwoFactorAuthContext from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthContext/useTwoFactorAuth'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; function EnabledStep() { const [isConfirmModalVisible, setIsConfirmModalVisible] = useState(false); diff --git a/src/pages/settings/Security/TwoFactorAuth/Steps/SuccessStep.js b/src/pages/settings/Security/TwoFactorAuth/Steps/SuccessStep.js index 308efecf3415..76d5e8a19a46 100644 --- a/src/pages/settings/Security/TwoFactorAuth/Steps/SuccessStep.js +++ b/src/pages/settings/Security/TwoFactorAuth/Steps/SuccessStep.js @@ -1,11 +1,11 @@ import React from 'react'; -import ConfirmationPage from '../../../../../components/ConfirmationPage'; -import * as TwoFactorAuthActions from '../../../../../libs/actions/TwoFactorAuthActions'; -import * as LottieAnimations from '../../../../../components/LottieAnimations'; -import CONST from '../../../../../CONST'; -import StepWrapper from '../StepWrapper/StepWrapper'; -import useTwoFactorAuthContext from '../TwoFactorAuthContext/useTwoFactorAuth'; -import useLocalize from '../../../../../hooks/useLocalize'; +import ConfirmationPage from '@components/ConfirmationPage'; +import * as LottieAnimations from '@components/LottieAnimations'; +import useLocalize from '@hooks/useLocalize'; +import StepWrapper from '@pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper'; +import useTwoFactorAuthContext from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthContext/useTwoFactorAuth'; +import * as TwoFactorAuthActions from '@userActions/TwoFactorAuthActions'; +import CONST from '@src/CONST'; function SuccessStep() { const {setStep} = useTwoFactorAuthContext(); diff --git a/src/pages/settings/Security/TwoFactorAuth/Steps/VerifyStep.js b/src/pages/settings/Security/TwoFactorAuth/Steps/VerifyStep.js index a254b28341f1..440b40c5363c 100644 --- a/src/pages/settings/Security/TwoFactorAuth/Steps/VerifyStep.js +++ b/src/pages/settings/Security/TwoFactorAuth/Steps/VerifyStep.js @@ -1,25 +1,25 @@ +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; -import {withOnyx} from 'react-native-onyx'; import {ScrollView, View} from 'react-native'; -import PropTypes from 'prop-types'; -import * as Session from '../../../../../libs/actions/Session'; -import styles from '../../../../../styles/styles'; -import Button from '../../../../../components/Button'; -import Text from '../../../../../components/Text'; -import ONYXKEYS from '../../../../../ONYXKEYS'; -import TextLink from '../../../../../components/TextLink'; -import Clipboard from '../../../../../libs/Clipboard'; -import FixedFooter from '../../../../../components/FixedFooter'; -import * as Expensicons from '../../../../../components/Icon/Expensicons'; -import PressableWithDelayToggle from '../../../../../components/Pressable/PressableWithDelayToggle'; -import TwoFactorAuthForm from '../TwoFactorAuthForm'; -import QRCode from '../../../../../components/QRCode'; -import expensifyLogo from '../../../../../../assets/images/expensify-logo-round-transparent.png'; -import CONST from '../../../../../CONST'; -import StepWrapper from '../StepWrapper/StepWrapper'; -import useTwoFactorAuthContext from '../TwoFactorAuthContext/useTwoFactorAuth'; -import useLocalize from '../../../../../hooks/useLocalize'; -import {defaultAccount, TwoFactorAuthPropTypes} from '../TwoFactorAuthPropTypes'; +import {withOnyx} from 'react-native-onyx'; +import expensifyLogo from '@assets/images/expensify-logo-round-transparent.png'; +import Button from '@components/Button'; +import FixedFooter from '@components/FixedFooter'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithDelayToggle from '@components/Pressable/PressableWithDelayToggle'; +import QRCode from '@components/QRCode'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import Clipboard from '@libs/Clipboard'; +import StepWrapper from '@pages/settings/Security/TwoFactorAuth/StepWrapper/StepWrapper'; +import useTwoFactorAuthContext from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthContext/useTwoFactorAuth'; +import TwoFactorAuthForm from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm'; +import {defaultAccount, TwoFactorAuthPropTypes} from '@pages/settings/Security/TwoFactorAuth/TwoFactorAuthPropTypes'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const TROUBLESHOOTING_LINK = 'https://community.expensify.com/discussion/7736/faq-troubleshooting-two-factor-authentication-issues/p1?new=1'; diff --git a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/BaseTwoFactorAuthForm.js b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/BaseTwoFactorAuthForm.js index ea51bbc71cf9..d441a6157049 100644 --- a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/BaseTwoFactorAuthForm.js +++ b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/BaseTwoFactorAuthForm.js @@ -1,13 +1,13 @@ -import React, {useCallback, useState, forwardRef, useImperativeHandle} from 'react'; import PropTypes from 'prop-types'; +import React, {forwardRef, useCallback, useImperativeHandle, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; -import MagicCodeInput from '../../../../../components/MagicCodeInput'; -import * as ErrorUtils from '../../../../../libs/ErrorUtils'; -import withLocalize, {withLocalizePropTypes} from '../../../../../components/withLocalize'; -import ONYXKEYS from '../../../../../ONYXKEYS'; -import compose from '../../../../../libs/compose'; -import * as ValidationUtils from '../../../../../libs/ValidationUtils'; -import * as Session from '../../../../../libs/actions/Session'; +import MagicCodeInput from '@components/MagicCodeInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import * as Session from '@userActions/Session'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.android.js b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.android.js index ba7bb2186aa6..5f71da7629dd 100644 --- a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.android.js +++ b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.android.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import BaseTwoFactorAuthForm from './BaseTwoFactorAuthForm'; const propTypes = { diff --git a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.js b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.js index 171322ecb32d..5d361c41e7e3 100644 --- a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.js +++ b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthForm/index.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import BaseTwoFactorAuthForm from './BaseTwoFactorAuthForm'; const propTypes = { diff --git a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthPage.js b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthPage.js index 99aeb4b11f89..99f57a5a5a9d 100644 --- a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthPage.js +++ b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthPage.js @@ -1,5 +1,5 @@ import React from 'react'; -import AnimatedStepProvider from '../../../../components/AnimatedStep/AnimatedStepProvider'; +import AnimatedStepProvider from '@components/AnimatedStep/AnimatedStepProvider'; import TwoFactorAuthSteps from './TwoFactorAuthSteps'; function TwoFactorAuthPage() { diff --git a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthSteps.js b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthSteps.js index df2a4d8e0950..31a33efa3996 100644 --- a/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthSteps.js +++ b/src/pages/settings/Security/TwoFactorAuth/TwoFactorAuthSteps.js @@ -1,16 +1,16 @@ import React, {useCallback, useEffect, useMemo, useState} from 'react'; import {withOnyx} from 'react-native-onyx'; +import useAnimatedStepContext from '@components/AnimatedStep/useAnimatedStepContext'; +import * as TwoFactorAuthActions from '@userActions/TwoFactorAuthActions'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import CodesStep from './Steps/CodesStep'; import DisabledStep from './Steps/DisabledStep'; import EnabledStep from './Steps/EnabledStep'; -import VerifyStep from './Steps/VerifyStep'; import SuccessStep from './Steps/SuccessStep'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import CONST from '../../../../CONST'; -import * as TwoFactorAuthActions from '../../../../libs/actions/TwoFactorAuthActions'; +import VerifyStep from './Steps/VerifyStep'; import TwoFactorAuthContext from './TwoFactorAuthContext'; import {defaultAccount, TwoFactorAuthPropTypes} from './TwoFactorAuthPropTypes'; -import useAnimatedStepContext from '../../../../components/AnimatedStep/useAnimatedStepContext'; function TwoFactorAuthSteps({account = defaultAccount}) { const [currentStep, setCurrentStep] = useState(CONST.TWO_FACTOR_AUTH_STEPS.CODES); diff --git a/src/pages/settings/Wallet/ActivatePhysicalCardPage.js b/src/pages/settings/Wallet/ActivatePhysicalCardPage.js index 0175f2ceac1f..b643f2c54ad3 100644 --- a/src/pages/settings/Wallet/ActivatePhysicalCardPage.js +++ b/src/pages/settings/Wallet/ActivatePhysicalCardPage.js @@ -1,31 +1,31 @@ -import React, {useRef, useCallback, useState, useEffect} from 'react'; -import {View} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import Text from '../../../components/Text'; -import Navigation from '../../../libs/Navigation/Navigation'; -import styles from '../../../styles/styles'; -import MagicCodeInput from '../../../components/MagicCodeInput'; -import * as DeviceCapabilities from '../../../libs/DeviceCapabilities'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; -import * as CardSettings from '../../../libs/actions/Card'; -import BigNumberPad from '../../../components/BigNumberPad'; -import Button from '../../../components/Button'; -import IllustratedHeaderPageLayout from '../../../components/IllustratedHeaderPageLayout'; -import themeColors from '../../../styles/themes/default'; -import SCREENS from '../../../SCREENS'; -import * as LottieAnimations from '../../../components/LottieAnimations'; -import useWindowDimensions from '../../../hooks/useWindowDimensions'; -import ONYXKEYS from '../../../ONYXKEYS'; -import useLocalize from '../../../hooks/useLocalize'; -import ROUTES from '../../../ROUTES'; -import CONST from '../../../CONST'; +import BigNumberPad from '@components/BigNumberPad'; +import Button from '@components/Button'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import MagicCodeInput from '@components/MagicCodeInput'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as CardUtils from '@libs/CardUtils'; +import * as DeviceCapabilities from '@libs/DeviceCapabilities'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as CardSettings from '@userActions/Card'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; import assignedCardPropTypes from './assignedCardPropTypes'; -import * as CardUtils from '../../../libs/CardUtils'; -import useNetwork from '../../../hooks/useNetwork'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Wallet/AddDebitCardPage.js b/src/pages/settings/Wallet/AddDebitCardPage.js index e75c3b2c517e..ff20d518ff5d 100644 --- a/src/pages/settings/Wallet/AddDebitCardPage.js +++ b/src/pages/settings/Wallet/AddDebitCardPage.js @@ -1,27 +1,27 @@ +import PropTypes from 'prop-types'; import React, {useEffect, useRef} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import TextLink from '../../../components/TextLink'; -import useLocalize from '../../../hooks/useLocalize'; -import * as PaymentMethods from '../../../libs/actions/PaymentMethods'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import CheckboxWithLabel from '../../../components/CheckboxWithLabel'; -import StatePicker from '../../../components/StatePicker'; -import TextInput from '../../../components/TextInput'; -import CONST from '../../../CONST'; -import ONYXKEYS from '../../../ONYXKEYS'; -import AddressSearch from '../../../components/AddressSearch'; -import Form from '../../../components/Form'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import usePrevious from '../../../hooks/usePrevious'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import Permissions from '../../../libs/Permissions'; +import AddressSearch from '@components/AddressSearch'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import StatePicker from '@components/StatePicker'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import styles from '@styles/styles'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Wallet/ChooseTransferAccountPage.js b/src/pages/settings/Wallet/ChooseTransferAccountPage.js index 78a9e92326bc..a44e21390b80 100644 --- a/src/pages/settings/Wallet/ChooseTransferAccountPage.js +++ b/src/pages/settings/Wallet/ChooseTransferAccountPage.js @@ -1,21 +1,21 @@ import React from 'react'; -import {withOnyx} from 'react-native-onyx'; import {View} from 'react-native'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import Navigation from '../../../libs/Navigation/Navigation'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import CONST from '../../../CONST'; +import {withOnyx} from 'react-native-onyx'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import PaymentMethodList from './PaymentMethodList'; -import * as PaymentMethods from '../../../libs/actions/PaymentMethods'; -import ROUTES from '../../../ROUTES'; -import MenuItem from '../../../components/MenuItem'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; import walletTransferPropTypes from './walletTransferPropTypes'; -import styles from '../../../styles/styles'; -import * as BankAccounts from '../../../libs/actions/BankAccounts'; const propTypes = { /** Wallet transfer propTypes */ diff --git a/src/pages/settings/Wallet/DangerCardSection.js b/src/pages/settings/Wallet/DangerCardSection.js index bd67ba03c43b..40788753bce7 100644 --- a/src/pages/settings/Wallet/DangerCardSection.js +++ b/src/pages/settings/Wallet/DangerCardSection.js @@ -1,9 +1,9 @@ import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import styles from '../../../styles/styles'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Text from '../../../components/Text'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import styles from '@styles/styles'; const propTypes = { title: PropTypes.string.isRequired, diff --git a/src/pages/settings/Wallet/ExpensifyCardPage.js b/src/pages/settings/Wallet/ExpensifyCardPage.js index 672db26cea82..d6cdbefc471a 100644 --- a/src/pages/settings/Wallet/ExpensifyCardPage.js +++ b/src/pages/settings/Wallet/ExpensifyCardPage.js @@ -3,30 +3,30 @@ import React, {useState} from 'react'; import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import ONYXKEYS from '../../../ONYXKEYS'; -import ROUTES from '../../../ROUTES'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import CardPreview from '../../../components/CardPreview'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import useLocalize from '../../../hooks/useLocalize'; -import * as CurrencyUtils from '../../../libs/CurrencyUtils'; -import Navigation from '../../../libs/Navigation/Navigation'; -import styles from '../../../styles/styles'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as CardUtils from '../../../libs/CardUtils'; -import Button from '../../../components/Button'; -import CardDetails from './WalletPage/CardDetails'; -import * as Card from '../../../libs/actions/Card'; -import MenuItem from '../../../components/MenuItem'; -import CONST from '../../../CONST'; +import Button from '@components/Button'; +import CardPreview from '@components/CardPreview'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import ScreenWrapper from '@components/ScreenWrapper'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import * as CardUtils from '@libs/CardUtils'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import styles from '@styles/styles'; +import theme from '@styles/themes/default'; +import * as Card from '@userActions/Card'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import assignedCardPropTypes from './assignedCardPropTypes'; -import useNetwork from '../../../hooks/useNetwork'; -import theme from '../../../styles/themes/default'; -import DotIndicatorMessage from '../../../components/DotIndicatorMessage'; -import * as Link from '../../../libs/actions/Link'; import DangerCardSection from './DangerCardSection'; +import CardDetails from './WalletPage/CardDetails'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Wallet/PaymentMethodList.js b/src/pages/settings/Wallet/PaymentMethodList.js index 5125832f6eb3..5ba521e94412 100644 --- a/src/pages/settings/Wallet/PaymentMethodList.js +++ b/src/pages/settings/Wallet/PaymentMethodList.js @@ -1,34 +1,34 @@ -import _ from 'underscore'; -import React, {useCallback, useMemo} from 'react'; -import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {FlashList} from '@shopify/flash-list'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useMemo} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../../styles/styles'; -import variables from '../../../styles/variables'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import MenuItem from '../../../components/MenuItem'; -import Button from '../../../components/Button'; -import Text from '../../../components/Text'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import bankAccountPropTypes from '../../../components/bankAccountPropTypes'; -import cardPropTypes from '../../../components/cardPropTypes'; -import * as PaymentUtils from '../../../libs/PaymentUtils'; -import FormAlertWrapper from '../../../components/FormAlertWrapper'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import * as PaymentMethods from '../../../libs/actions/PaymentMethods'; -import useLocalize from '../../../hooks/useLocalize'; -import useNetwork from '../../../hooks/useNetwork'; -import Log from '../../../libs/Log'; -import stylePropTypes from '../../../styles/stylePropTypes'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import getBankIcon from '../../../components/Icon/BankIcons'; +import _ from 'underscore'; +import bankAccountPropTypes from '@components/bankAccountPropTypes'; +import Button from '@components/Button'; +import cardPropTypes from '@components/cardPropTypes'; +import FormAlertWrapper from '@components/FormAlertWrapper'; +import getBankIcon from '@components/Icon/BankIcons'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import * as CardUtils from '@libs/CardUtils'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PaymentUtils from '@libs/PaymentUtils'; +import stylePropTypes from '@styles/stylePropTypes'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import assignedCardPropTypes from './assignedCardPropTypes'; -import * as CardUtils from '../../../libs/CardUtils'; const propTypes = { /** What to do when a menu item is pressed */ diff --git a/src/pages/settings/Wallet/ReportCardLostPage.js b/src/pages/settings/Wallet/ReportCardLostPage.js index 29a588916326..ee6580a0b0f6 100644 --- a/src/pages/settings/Wallet/ReportCardLostPage.js +++ b/src/pages/settings/Wallet/ReportCardLostPage.js @@ -1,27 +1,27 @@ -import React, {useState, useEffect} from 'react'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; import {View} from 'react-native'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import styles from '../../../styles/styles'; -import ONYXKEYS from '../../../ONYXKEYS'; -import SingleOptionSelector from '../../../components/SingleOptionSelector'; -import useLocalize from '../../../hooks/useLocalize'; -import Text from '../../../components/Text'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import usePrivatePersonalDetails from '../../../hooks/usePrivatePersonalDetails'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SingleOptionSelector from '@components/SingleOptionSelector'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import * as CardUtils from '@libs/CardUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import styles from '@styles/styles'; +import * as CardActions from '@userActions/Card'; +import * as FormActions from '@userActions/FormActions'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import assignedCardPropTypes from './assignedCardPropTypes'; -import * as CardUtils from '../../../libs/CardUtils'; -import * as PersonalDetailsUtils from '../../../libs/PersonalDetailsUtils'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import usePrevious from '../../../hooks/usePrevious'; -import * as FormActions from '../../../libs/actions/FormActions'; -import * as CardActions from '../../../libs/actions/Card'; -import FormAlertWithSubmitButton from '../../../components/FormAlertWithSubmitButton'; /** Options for reason selector */ const OPTIONS = [ diff --git a/src/pages/settings/Wallet/ReportVirtualCardFraudPage.js b/src/pages/settings/Wallet/ReportVirtualCardFraudPage.js index 1a51fc4d9453..58e5d2b62c90 100644 --- a/src/pages/settings/Wallet/ReportVirtualCardFraudPage.js +++ b/src/pages/settings/Wallet/ReportVirtualCardFraudPage.js @@ -1,23 +1,23 @@ +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import ROUTES from '../../../ROUTES'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import Navigation from '../../../libs/Navigation/Navigation'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import useLocalize from '../../../hooks/useLocalize'; -import * as Card from '../../../libs/actions/Card'; +import _ from 'underscore'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import usePrevious from '@hooks/usePrevious'; +import * as CardUtils from '@libs/CardUtils'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import NotFoundPage from '@pages/ErrorPage/NotFoundPage'; +import styles from '@styles/styles'; +import * as Card from '@userActions/Card'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import assignedCardPropTypes from './assignedCardPropTypes'; -import * as CardUtils from '../../../libs/CardUtils'; -import ONYXKEYS from '../../../ONYXKEYS'; -import NotFoundPage from '../../ErrorPage/NotFoundPage'; -import usePrevious from '../../../hooks/usePrevious'; -import FormAlertWithSubmitButton from '../../../components/FormAlertWithSubmitButton'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/settings/Wallet/TransferBalancePage.js b/src/pages/settings/Wallet/TransferBalancePage.js index ae54dab569f7..1df07365a1f6 100644 --- a/src/pages/settings/Wallet/TransferBalancePage.js +++ b/src/pages/settings/Wallet/TransferBalancePage.js @@ -1,32 +1,32 @@ -import _ from 'underscore'; -import React, {useEffect} from 'react'; -import {View, ScrollView} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import HeaderWithBackButton from '../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../components/ScreenWrapper'; -import Navigation from '../../../libs/Navigation/Navigation'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import compose from '../../../libs/compose'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import MenuItem from '../../../components/MenuItem'; -import CONST from '../../../CONST'; -import variables from '../../../styles/variables'; -import Text from '../../../components/Text'; -import CurrentWalletBalance from '../../../components/CurrentWalletBalance'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import cardPropTypes from '@components/cardPropTypes'; +import ConfirmationPage from '@components/ConfirmationPage'; +import CurrentWalletBalance from '@components/CurrentWalletBalance'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PaymentUtils from '@libs/PaymentUtils'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import walletTransferPropTypes from './walletTransferPropTypes'; -import * as PaymentMethods from '../../../libs/actions/PaymentMethods'; -import * as PaymentUtils from '../../../libs/PaymentUtils'; -import cardPropTypes from '../../../components/cardPropTypes'; -import userWalletPropTypes from '../../EnablePayments/userWalletPropTypes'; -import ROUTES from '../../../ROUTES'; -import FormAlertWithSubmitButton from '../../../components/FormAlertWithSubmitButton'; -import {withNetwork} from '../../../components/OnyxProvider'; -import ConfirmationPage from '../../../components/ConfirmationPage'; -import * as CurrencyUtils from '../../../libs/CurrencyUtils'; -import FullPageNotFoundView from '../../../components/BlockingViews/FullPageNotFoundView'; const propTypes = { /** User's wallet information */ diff --git a/src/pages/settings/Wallet/WalletEmptyState.js b/src/pages/settings/Wallet/WalletEmptyState.js index f54716e3110a..ad507f62c225 100644 --- a/src/pages/settings/Wallet/WalletEmptyState.js +++ b/src/pages/settings/Wallet/WalletEmptyState.js @@ -1,15 +1,15 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import IllustratedHeaderPageLayout from '../../../components/IllustratedHeaderPageLayout'; -import useLocalize from '../../../hooks/useLocalize'; -import * as LottieAnimations from '../../../components/LottieAnimations'; -import Button from '../../../components/Button'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import FeatureList from '../../../components/FeatureList'; -import themeColors from '../../../styles/themes/default'; -import SCREENS from '../../../SCREENS'; +import React from 'react'; +import Button from '@components/Button'; +import FeatureList from '@components/FeatureList'; +import * as Illustrations from '@components/Icon/Illustrations'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import useLocalize from '@hooks/useLocalize'; +import Navigation from '@libs/Navigation/Navigation'; +import themeColors from '@styles/themes/default'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; const propTypes = { /** The function that is called when a menu item is pressed */ diff --git a/src/pages/settings/Wallet/WalletPage/CardDetails.js b/src/pages/settings/Wallet/WalletPage/CardDetails.js index f38f90fdfcb2..a57792f5fadf 100644 --- a/src/pages/settings/Wallet/WalletPage/CardDetails.js +++ b/src/pages/settings/Wallet/WalletPage/CardDetails.js @@ -1,19 +1,19 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import MenuItemWithTopDescription from '../../../../components/MenuItemWithTopDescription'; -import Clipboard from '../../../../libs/Clipboard'; -import useLocalize from '../../../../hooks/useLocalize'; -import usePrivatePersonalDetails from '../../../../hooks/usePrivatePersonalDetails'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import * as PersonalDetailsUtils from '../../../../libs/PersonalDetailsUtils'; -import PressableWithDelayToggle from '../../../../components/Pressable/PressableWithDelayToggle'; -import styles from '../../../../styles/styles'; -import TextLink from '../../../../components/TextLink'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import ROUTES from '../../../../ROUTES'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import PressableWithDelayToggle from '@components/Pressable/PressableWithDelayToggle'; +import TextLink from '@components/TextLink'; +import useLocalize from '@hooks/useLocalize'; +import usePrivatePersonalDetails from '@hooks/usePrivatePersonalDetails'; +import Clipboard from '@libs/Clipboard'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import styles from '@styles/styles'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Card number */ diff --git a/src/pages/settings/Wallet/WalletPage/WalletPage.js b/src/pages/settings/Wallet/WalletPage/WalletPage.js index 11974446eea6..38d9722e2ed7 100644 --- a/src/pages/settings/Wallet/WalletPage/WalletPage.js +++ b/src/pages/settings/Wallet/WalletPage/WalletPage.js @@ -1,42 +1,42 @@ -import React, {useCallback, useEffect, useState, useRef} from 'react'; -import {ActivityIndicator, View, InteractionManager, ScrollView} from 'react-native'; +import lodashGet from 'lodash/get'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {ActivityIndicator, InteractionManager, ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import PaymentMethodList from '../PaymentMethodList'; -import ROUTES from '../../../../ROUTES'; -import HeaderWithBackButton from '../../../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../../../components/ScreenWrapper'; -import Navigation from '../../../../libs/Navigation/Navigation'; -import styles from '../../../../styles/styles'; -import compose from '../../../../libs/compose'; -import * as BankAccounts from '../../../../libs/actions/BankAccounts'; -import Popover from '../../../../components/Popover'; -import MenuItem from '../../../../components/MenuItem'; -import Text from '../../../../components/Text'; -import Icon from '../../../../components/Icon'; -import * as PaymentMethods from '../../../../libs/actions/PaymentMethods'; -import getClickedTargetLocation from '../../../../libs/getClickedTargetLocation'; -import CurrentWalletBalance from '../../../../components/CurrentWalletBalance'; -import ONYXKEYS from '../../../../ONYXKEYS'; -import Permissions from '../../../../libs/Permissions'; -import AddPaymentMethodMenu from '../../../../components/AddPaymentMethodMenu'; -import CONST from '../../../../CONST'; -import * as Expensicons from '../../../../components/Icon/Expensicons'; -import KYCWall from '../../../../components/KYCWall'; -import {propTypes, defaultProps} from './walletPagePropTypes'; -import {withNetwork} from '../../../../components/OnyxProvider'; -import * as PaymentUtils from '../../../../libs/PaymentUtils'; -import OfflineWithFeedback from '../../../../components/OfflineWithFeedback'; -import ConfirmContent from '../../../../components/ConfirmContent'; -import Button from '../../../../components/Button'; -import themeColors from '../../../../styles/themes/default'; -import variables from '../../../../styles/variables'; -import useLocalize from '../../../../hooks/useLocalize'; -import useWindowDimensions from '../../../../hooks/useWindowDimensions'; -import WalletEmptyState from '../WalletEmptyState'; -import * as Illustrations from '../../../../components/Icon/Illustrations'; -import WalletSection from '../../../../components/WalletSection'; +import AddPaymentMethodMenu from '@components/AddPaymentMethodMenu'; +import Button from '@components/Button'; +import ConfirmContent from '@components/ConfirmContent'; +import CurrentWalletBalance from '@components/CurrentWalletBalance'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import KYCWall from '@components/KYCWall'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import Popover from '@components/Popover'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import WalletSection from '@components/WalletSection'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import compose from '@libs/compose'; +import getClickedTargetLocation from '@libs/getClickedTargetLocation'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PaymentUtils from '@libs/PaymentUtils'; +import Permissions from '@libs/Permissions'; +import PaymentMethodList from '@pages/settings/Wallet/PaymentMethodList'; +import WalletEmptyState from '@pages/settings/Wallet/WalletEmptyState'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as PaymentMethods from '@userActions/PaymentMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {defaultProps, propTypes} from './walletPagePropTypes'; function WalletPage({bankAccountList, betas, cardList, fundList, isLoadingPaymentMethods, network, shouldListenForResize, userWallet, walletTerms}) { const {translate} = useLocalize(); diff --git a/src/pages/settings/Wallet/WalletPage/walletPagePropTypes.js b/src/pages/settings/Wallet/WalletPage/walletPagePropTypes.js index 3c411d7984e4..23bdfe99b086 100644 --- a/src/pages/settings/Wallet/WalletPage/walletPagePropTypes.js +++ b/src/pages/settings/Wallet/WalletPage/walletPagePropTypes.js @@ -1,10 +1,10 @@ import PropTypes from 'prop-types'; -import walletTransferPropTypes from '../walletTransferPropTypes'; -import networkPropTypes from '../../../../components/networkPropTypes'; -import bankAccountPropTypes from '../../../../components/bankAccountPropTypes'; -import cardPropTypes from '../../../../components/cardPropTypes'; -import userWalletPropTypes from '../../../EnablePayments/userWalletPropTypes'; -import walletTermsPropTypes from '../../../EnablePayments/walletTermsPropTypes'; +import bankAccountPropTypes from '@components/bankAccountPropTypes'; +import cardPropTypes from '@components/cardPropTypes'; +import networkPropTypes from '@components/networkPropTypes'; +import userWalletPropTypes from '@pages/EnablePayments/userWalletPropTypes'; +import walletTermsPropTypes from '@pages/EnablePayments/walletTermsPropTypes'; +import walletTransferPropTypes from '@pages/settings/Wallet/walletTransferPropTypes'; const propTypes = { /** Wallet balance transfer props */ diff --git a/src/pages/settings/Wallet/assignedCardPropTypes.js b/src/pages/settings/Wallet/assignedCardPropTypes.js index a8bfc1a2cbd0..a560c0250388 100644 --- a/src/pages/settings/Wallet/assignedCardPropTypes.js +++ b/src/pages/settings/Wallet/assignedCardPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import CONST from '../../../CONST'; +import CONST from '@src/CONST'; /** Assigned Card props */ const assignedCardPropTypes = PropTypes.shape({ diff --git a/src/pages/settings/Wallet/walletTransferPropTypes.js b/src/pages/settings/Wallet/walletTransferPropTypes.js index 8a2ab06c9066..38c65fcfd703 100644 --- a/src/pages/settings/Wallet/walletTransferPropTypes.js +++ b/src/pages/settings/Wallet/walletTransferPropTypes.js @@ -1,5 +1,5 @@ import PropTypes from 'prop-types'; -import CONST from '../../../CONST'; +import CONST from '@src/CONST'; /** Wallet balance transfer props */ const walletTransferPropTypes = PropTypes.shape({ diff --git a/src/pages/signin/AppleSignInDesktopPage/index.website.js b/src/pages/signin/AppleSignInDesktopPage/index.website.js index 10887e0ebdee..867dfddc443d 100644 --- a/src/pages/signin/AppleSignInDesktopPage/index.website.js +++ b/src/pages/signin/AppleSignInDesktopPage/index.website.js @@ -1,6 +1,6 @@ import React from 'react'; -import ThirdPartySignInPage from '../ThirdPartySignInPage'; -import CONST from '../../../CONST'; +import ThirdPartySignInPage from '@pages/signin/ThirdPartySignInPage'; +import CONST from '@src/CONST'; function AppleSignInDesktopPage() { return ; diff --git a/src/pages/signin/ChangeExpensifyLoginLink.js b/src/pages/signin/ChangeExpensifyLoginLink.js index c152a903fbef..f5e526964333 100755 --- a/src/pages/signin/ChangeExpensifyLoginLink.js +++ b/src/pages/signin/ChangeExpensifyLoginLink.js @@ -1,15 +1,15 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import Text from '../../components/Text'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import PressableWithFeedback from '../../components/Pressable/PressableWithFeedback'; -import CONST from '../../CONST'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The credentials of the logged in person */ diff --git a/src/pages/signin/ChooseSSOOrMagicCode.js b/src/pages/signin/ChooseSSOOrMagicCode.js index 32f0776cdbc9..fd3ec85c5cb2 100644 --- a/src/pages/signin/ChooseSSOOrMagicCode.js +++ b/src/pages/signin/ChooseSSOOrMagicCode.js @@ -1,23 +1,23 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import Text from '../../components/Text'; -import Button from '../../components/Button'; -import * as Session from '../../libs/actions/Session'; +import Button from '@components/Button'; +import FormHelpMessage from '@components/FormHelpMessage'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import ChangeExpensifyLoginLink from './ChangeExpensifyLoginLink'; import Terms from './Terms'; -import CONST from '../../CONST'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import useLocalize from '../../hooks/useLocalize'; -import useNetwork from '../../hooks/useNetwork'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import FormHelpMessage from '../../components/FormHelpMessage'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/signin/DesktopRedirectPage.js b/src/pages/signin/DesktopRedirectPage.js index ef6421da23bd..1c2521be09e2 100644 --- a/src/pages/signin/DesktopRedirectPage.js +++ b/src/pages/signin/DesktopRedirectPage.js @@ -1,6 +1,6 @@ import React from 'react'; -import * as App from '../../libs/actions/App'; -import DeeplinkRedirectLoadingIndicator from '../../components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator'; +import DeeplinkRedirectLoadingIndicator from '@components/DeeplinkWrapper/DeeplinkRedirectLoadingIndicator'; +import * as App from '@userActions/App'; /** * Landing page for when a user enters third party login flow on desktop. diff --git a/src/pages/signin/DesktopSignInRedirectPage/index.website.js b/src/pages/signin/DesktopSignInRedirectPage/index.website.js index bec9b5107359..1536b45cf667 100644 --- a/src/pages/signin/DesktopSignInRedirectPage/index.website.js +++ b/src/pages/signin/DesktopSignInRedirectPage/index.website.js @@ -1,5 +1,5 @@ import React from 'react'; -import DesktopRedirectPage from '../DesktopRedirectPage'; +import DesktopRedirectPage from '@pages/signin/DesktopRedirectPage'; function DesktopSignInRedirectPage() { return ; diff --git a/src/pages/signin/EmailDeliveryFailurePage.js b/src/pages/signin/EmailDeliveryFailurePage.js index 5d56980a2b97..a7b690a6151a 100644 --- a/src/pages/signin/EmailDeliveryFailurePage.js +++ b/src/pages/signin/EmailDeliveryFailurePage.js @@ -1,17 +1,17 @@ +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; import {Keyboard, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; -import styles from '../../styles/styles'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import ONYXKEYS from '../../ONYXKEYS'; -import useLocalize from '../../hooks/useLocalize'; -import useKeyboardState from '../../hooks/useKeyboardState'; -import redirectToSignIn from '../../libs/actions/SignInRedirect'; -import CONST from '../../CONST'; -import PressableWithFeedback from '../../components/Pressable/PressableWithFeedback'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import useKeyboardState from '@hooks/useKeyboardState'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import redirectToSignIn from '@userActions/SignInRedirect'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/signin/GoogleSignInDesktopPage/index.website.js b/src/pages/signin/GoogleSignInDesktopPage/index.website.js index 691b82448e31..b9451460dfb0 100644 --- a/src/pages/signin/GoogleSignInDesktopPage/index.website.js +++ b/src/pages/signin/GoogleSignInDesktopPage/index.website.js @@ -1,6 +1,6 @@ import React from 'react'; -import ThirdPartySignInPage from '../ThirdPartySignInPage'; -import CONST from '../../../CONST'; +import ThirdPartySignInPage from '@pages/signin/ThirdPartySignInPage'; +import CONST from '@src/CONST'; function GoogleSignInDesktopPage() { return ; diff --git a/src/pages/signin/Licenses.js b/src/pages/signin/Licenses.js index e3f1026c1e9f..b73d1ad8c47d 100644 --- a/src/pages/signin/Licenses.js +++ b/src/pages/signin/Licenses.js @@ -1,11 +1,11 @@ import React from 'react'; import {View} from 'react-native'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import LocalePicker from '../../components/LocalePicker'; +import LocalePicker from '@components/LocalePicker'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const currentYear = new Date().getFullYear(); diff --git a/src/pages/signin/LoginForm/BaseLoginForm.js b/src/pages/signin/LoginForm/BaseLoginForm.js index 5ce8739beb5f..9529d7fd0d60 100644 --- a/src/pages/signin/LoginForm/BaseLoginForm.js +++ b/src/pages/signin/LoginForm/BaseLoginForm.js @@ -1,38 +1,38 @@ +import {parsePhoneNumber} from 'awesome-phonenumber'; +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; import React, {forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import Str from 'expensify-common/lib/str'; -import {parsePhoneNumber} from 'awesome-phonenumber'; -import styles from '../../../styles/styles'; -import Text from '../../../components/Text'; -import * as Session from '../../../libs/actions/Session'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import compose from '../../../libs/compose'; -import canFocusInputOnScreenFocus from '../../../libs/canFocusInputOnScreenFocus'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import TextInput from '../../../components/TextInput'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import * as LoginUtils from '../../../libs/LoginUtils'; -import withToggleVisibilityView, {toggleVisibilityViewPropTypes} from '../../../components/withToggleVisibilityView'; -import FormAlertWithSubmitButton from '../../../components/FormAlertWithSubmitButton'; -import {withNetwork} from '../../../components/OnyxProvider'; -import networkPropTypes from '../../../components/networkPropTypes'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; -import DotIndicatorMessage from '../../../components/DotIndicatorMessage'; -import * as CloseAccount from '../../../libs/actions/CloseAccount'; -import CONST from '../../../CONST'; -import CONFIG from '../../../CONFIG'; -import AppleSignIn from '../../../components/SignInButtons/AppleSignIn'; -import GoogleSignIn from '../../../components/SignInButtons/GoogleSignIn'; -import isInputAutoFilled from '../../../libs/isInputAutoFilled'; -import * as PolicyUtils from '../../../libs/PolicyUtils'; -import Log from '../../../libs/Log'; -import withNavigationFocus from '../../../components/withNavigationFocus'; -import usePrevious from '../../../hooks/usePrevious'; -import * as MemoryOnlyKeys from '../../../libs/actions/MemoryOnlyKeys/MemoryOnlyKeys'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import AppleSignIn from '@components/SignInButtons/AppleSignIn'; +import GoogleSignIn from '@components/SignInButtons/GoogleSignIn'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withNavigationFocus from '@components/withNavigationFocus'; +import withToggleVisibilityView, {toggleVisibilityViewPropTypes} from '@components/withToggleVisibilityView'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import usePrevious from '@hooks/usePrevious'; +import canFocusInputOnScreenFocus from '@libs/canFocusInputOnScreenFocus'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import isInputAutoFilled from '@libs/isInputAutoFilled'; +import Log from '@libs/Log'; +import * as LoginUtils from '@libs/LoginUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import styles from '@styles/styles'; +import * as CloseAccount from '@userActions/CloseAccount'; +import * as MemoryOnlyKeys from '@userActions/MemoryOnlyKeys/MemoryOnlyKeys'; +import * as Session from '@userActions/Session'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Should we dismiss the keyboard when transitioning away from the page? */ diff --git a/src/pages/signin/LoginForm/index.js b/src/pages/signin/LoginForm/index.js index b9dfbb8dfbb5..91aba70a866f 100644 --- a/src/pages/signin/LoginForm/index.js +++ b/src/pages/signin/LoginForm/index.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import BaseLoginForm from './BaseLoginForm'; const propTypes = { diff --git a/src/pages/signin/LoginForm/index.native.js b/src/pages/signin/LoginForm/index.native.js index dc55ad68e53b..87258e69165f 100644 --- a/src/pages/signin/LoginForm/index.native.js +++ b/src/pages/signin/LoginForm/index.native.js @@ -1,7 +1,7 @@ -import React, {useEffect, useRef} from 'react'; import PropTypes from 'prop-types'; +import React, {useEffect, useRef} from 'react'; +import AppStateMonitor from '@libs/AppStateMonitor'; import BaseLoginForm from './BaseLoginForm'; -import AppStateMonitor from '../../../libs/AppStateMonitor'; const propTypes = { /** Function used to scroll to the top of the page */ diff --git a/src/pages/signin/SAMLSignInPage/index.js b/src/pages/signin/SAMLSignInPage/index.js index 23ce9b93b8cc..67154c8e85fe 100644 --- a/src/pages/signin/SAMLSignInPage/index.js +++ b/src/pages/signin/SAMLSignInPage/index.js @@ -1,16 +1,16 @@ +import PropTypes from 'prop-types'; import React, {useEffect} from 'react'; -import {withOnyx} from 'react-native-onyx'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONFIG from '../../../CONFIG'; -import Icon from '../../../components/Icon'; -import Text from '../../../components/Text'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; -import useLocalize from '../../../hooks/useLocalize'; +import {withOnyx} from 'react-native-onyx'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import CONFIG from '@src/CONFIG'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The credentials of the logged in person */ diff --git a/src/pages/signin/SignInHeroCopy.js b/src/pages/signin/SignInHeroCopy.js index c2caa3ea1296..2cf3adac1022 100644 --- a/src/pages/signin/SignInHeroCopy.js +++ b/src/pages/signin/SignInHeroCopy.js @@ -1,13 +1,13 @@ -import {View} from 'react-native'; import PropTypes from 'prop-types'; import React from 'react'; -import Text from '../../components/Text'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import * as StyleUtils from '../../styles/StyleUtils'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; +import {View} from 'react-native'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; const propTypes = { /** Override the green headline copy */ diff --git a/src/pages/signin/SignInHeroImage.js b/src/pages/signin/SignInHeroImage.js index 6d53aa25e9af..8ed9a168b328 100644 --- a/src/pages/signin/SignInHeroImage.js +++ b/src/pages/signin/SignInHeroImage.js @@ -1,9 +1,9 @@ import React from 'react'; -import Lottie from '../../components/Lottie'; -import * as LottieAnimations from '../../components/LottieAnimations'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; +import Lottie from '@components/Lottie'; +import * as LottieAnimations from '@components/LottieAnimations'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; const propTypes = { ...windowDimensionsPropTypes, diff --git a/src/pages/signin/SignInModal.js b/src/pages/signin/SignInModal.js index f1ce09def084..725209537a6d 100644 --- a/src/pages/signin/SignInModal.js +++ b/src/pages/signin/SignInModal.js @@ -1,10 +1,10 @@ import React from 'react'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; import SignInPage from './SignInPage'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import * as Session from '../../libs/actions/Session'; const propTypes = {}; diff --git a/src/pages/signin/SignInPage.js b/src/pages/signin/SignInPage.js index 18ed29fa0415..30eadf952042 100644 --- a/src/pages/signin/SignInPage.js +++ b/src/pages/signin/SignInPage.js @@ -1,31 +1,31 @@ -import React, {useEffect, useRef, useState} from 'react'; +import Str from 'expensify-common/lib/str'; import PropTypes from 'prop-types'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; +import React, {useEffect, useRef, useState} from 'react'; import {View} from 'react-native'; -import Str from 'expensify-common/lib/str'; +import {withOnyx} from 'react-native-onyx'; import {useSafeAreaInsets} from 'react-native-safe-area-context'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import SignInPageLayout from './SignInPageLayout'; +import _ from 'underscore'; +import useLocalize from '@hooks/useLocalize'; +import useWindowDimensions from '@hooks/useWindowDimensions'; +import * as ActiveClientManager from '@libs/ActiveClientManager'; +import getPlatform from '@libs/getPlatform'; +import * as Localize from '@libs/Localize'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import Performance from '@libs/Performance'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import * as App from '@userActions/App'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import ChooseSSOOrMagicCode from './ChooseSSOOrMagicCode'; +import EmailDeliveryFailurePage from './EmailDeliveryFailurePage'; import LoginForm from './LoginForm'; -import ValidateCodeForm from './ValidateCodeForm'; -import Performance from '../../libs/Performance'; -import * as App from '../../libs/actions/App'; +import SignInPageLayout from './SignInPageLayout'; import UnlinkLoginForm from './UnlinkLoginForm'; -import EmailDeliveryFailurePage from './EmailDeliveryFailurePage'; -import * as Localize from '../../libs/Localize'; -import * as StyleUtils from '../../styles/StyleUtils'; -import useLocalize from '../../hooks/useLocalize'; -import useWindowDimensions from '../../hooks/useWindowDimensions'; -import Log from '../../libs/Log'; -import getPlatform from '../../libs/getPlatform'; -import CONST from '../../CONST'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import ChooseSSOOrMagicCode from './ChooseSSOOrMagicCode'; -import * as ActiveClientManager from '../../libs/ActiveClientManager'; -import * as Session from '../../libs/actions/Session'; +import ValidateCodeForm from './ValidateCodeForm'; const propTypes = { /** The details about the account that the user is signing in with */ diff --git a/src/pages/signin/SignInPageHero.js b/src/pages/signin/SignInPageHero.js index 89e9088d12f2..28cc0b711ae1 100644 --- a/src/pages/signin/SignInPageHero.js +++ b/src/pages/signin/SignInPageHero.js @@ -1,12 +1,12 @@ -import {View} from 'react-native'; import PropTypes from 'prop-types'; import React from 'react'; -import * as StyleUtils from '../../styles/StyleUtils'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import SignInHeroImage from './SignInHeroImage'; +import {View} from 'react-native'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; import SignInHeroCopy from './SignInHeroCopy'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; +import SignInHeroImage from './SignInHeroImage'; const propTypes = { /** Override the green headline copy */ diff --git a/src/pages/signin/SignInPageLayout/BackgroundImage/index.android.js b/src/pages/signin/SignInPageLayout/BackgroundImage/index.android.js index 6ce60fc364fd..9b420753c17a 100644 --- a/src/pages/signin/SignInPageLayout/BackgroundImage/index.android.js +++ b/src/pages/signin/SignInPageLayout/BackgroundImage/index.android.js @@ -1,6 +1,6 @@ import React from 'react'; -import AndroidBackgroundImage from '../../../../../assets/images/home-background--android.svg'; -import styles from '../../../../styles/styles'; +import AndroidBackgroundImage from '@assets/images/home-background--android.svg'; +import styles from '@styles/styles'; import defaultPropTypes from './propTypes'; function BackgroundImage(props) { diff --git a/src/pages/signin/SignInPageLayout/BackgroundImage/index.js b/src/pages/signin/SignInPageLayout/BackgroundImage/index.js index 710f7b373a81..2dc95bd28215 100644 --- a/src/pages/signin/SignInPageLayout/BackgroundImage/index.js +++ b/src/pages/signin/SignInPageLayout/BackgroundImage/index.js @@ -1,8 +1,8 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import MobileBackgroundImage from '../../../../../assets/images/home-background--mobile.svg'; -import DesktopBackgroundImage from '../../../../../assets/images/home-background--desktop.svg'; -import styles from '../../../../styles/styles'; +import React from 'react'; +import DesktopBackgroundImage from '@assets/images/home-background--desktop.svg'; +import MobileBackgroundImage from '@assets/images/home-background--mobile.svg'; +import styles from '@styles/styles'; import defaultPropTypes from './propTypes'; const defaultProps = { diff --git a/src/pages/signin/SignInPageLayout/Footer.js b/src/pages/signin/SignInPageLayout/Footer.js index 2fb5e45db760..f220dd56b613 100644 --- a/src/pages/signin/SignInPageLayout/Footer.js +++ b/src/pages/signin/SignInPageLayout/Footer.js @@ -1,21 +1,21 @@ -import {View} from 'react-native'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; +import {View} from 'react-native'; import _ from 'underscore'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import themeColors from '../../../styles/themes/default'; -import variables from '../../../styles/variables'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import TextLink from '../../../components/TextLink'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import Licenses from '../Licenses'; -import Socials from '../Socials'; -import Hoverable from '../../../components/Hoverable'; -import CONST from '../../../CONST'; -import * as Session from '../../../libs/actions/Session'; -import SignInGradient from '../../../../assets/images/home-fade-gradient--mobile.svg'; +import SignInGradient from '@assets/images/home-fade-gradient--mobile.svg'; +import Hoverable from '@components/Hoverable'; +import * as Expensicons from '@components/Icon/Expensicons'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import Licenses from '@pages/signin/Licenses'; +import Socials from '@pages/signin/Socials'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Session from '@userActions/Session'; +import CONST from '@src/CONST'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/signin/SignInPageLayout/SignInPageContent.js b/src/pages/signin/SignInPageLayout/SignInPageContent.js index 571af6a640b7..14b7b7e004a6 100755 --- a/src/pages/signin/SignInPageLayout/SignInPageContent.js +++ b/src/pages/signin/SignInPageLayout/SignInPageContent.js @@ -1,18 +1,18 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withSafeAreaInsets} from 'react-native-safe-area-context'; -import styles from '../../../styles/styles'; -import ExpensifyWordmark from '../../../components/ExpensifyWordmark'; -import Text from '../../../components/Text'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import SignInPageForm from '../../../components/SignInPageForm'; -import compose from '../../../libs/compose'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import OfflineIndicator from '../../../components/OfflineIndicator'; -import SignInHeroImage from '../SignInHeroImage'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import variables from '../../../styles/variables'; +import ExpensifyWordmark from '@components/ExpensifyWordmark'; +import OfflineIndicator from '@components/OfflineIndicator'; +import SignInPageForm from '@components/SignInPageForm'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import SignInHeroImage from '@pages/signin/SignInHeroImage'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import variables from '@styles/variables'; const propTypes = { /** The children to show inside the layout */ diff --git a/src/pages/signin/SignInPageLayout/index.js b/src/pages/signin/SignInPageLayout/index.js index 21a768aac3b1..627fdd0eaa37 100644 --- a/src/pages/signin/SignInPageLayout/index.js +++ b/src/pages/signin/SignInPageLayout/index.js @@ -1,21 +1,21 @@ -import React, {forwardRef, useRef, useEffect, useImperativeHandle} from 'react'; -import {View, ScrollView} from 'react-native'; -import {withSafeAreaInsets} from 'react-native-safe-area-context'; import PropTypes from 'prop-types'; -import compose from '../../../libs/compose'; -import SignInPageContent from './SignInPageContent'; +import React, {forwardRef, useEffect, useImperativeHandle, useRef} from 'react'; +import {ScrollView, View} from 'react-native'; +import {withSafeAreaInsets} from 'react-native-safe-area-context'; +import SignInGradient from '@assets/images/home-fade-gradient.svg'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import usePrevious from '@hooks/usePrevious'; +import compose from '@libs/compose'; +import SignInPageHero from '@pages/signin/SignInPageHero'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import BackgroundImage from './BackgroundImage'; import Footer from './Footer'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import styles from '../../../styles/styles'; -import SignInPageHero from '../SignInPageHero'; -import * as StyleUtils from '../../../styles/StyleUtils'; +import SignInPageContent from './SignInPageContent'; import scrollViewContentContainerStyles from './signInPageStyles'; -import themeColors from '../../../styles/themes/default'; -import BackgroundImage from './BackgroundImage'; -import SignInGradient from '../../../../assets/images/home-fade-gradient.svg'; -import variables from '../../../styles/variables'; -import usePrevious from '../../../hooks/usePrevious'; const propTypes = { /** The children to show inside the layout */ diff --git a/src/pages/signin/SignInPageLayout/signInPageStyles/index.js b/src/pages/signin/SignInPageLayout/signInPageStyles/index.js index de3cdcc20c0c..b058c78aca86 100644 --- a/src/pages/signin/SignInPageLayout/signInPageStyles/index.js +++ b/src/pages/signin/SignInPageLayout/signInPageStyles/index.js @@ -1,4 +1,4 @@ -import styles from '../../../../styles/styles'; +import styles from '@styles/styles'; // On web, we can use flex to fit the content to fit the viewport within a ScrollView. const scrollViewContentContainerStyles = styles.flex1; diff --git a/src/pages/signin/SignInPageLayout/signInPageStyles/index.native.js b/src/pages/signin/SignInPageLayout/signInPageStyles/index.native.js index 004534709783..76f847f638b9 100644 --- a/src/pages/signin/SignInPageLayout/signInPageStyles/index.native.js +++ b/src/pages/signin/SignInPageLayout/signInPageStyles/index.native.js @@ -1,4 +1,4 @@ -import styles from '../../../../styles/styles'; +import styles from '@styles/styles'; // Using flexGrow on mobile allows the ScrollView container to grow to fit the content. // This is necessary because making the sign-in content fit exactly the viewheight causes the scroll to stop working on mobile. diff --git a/src/pages/signin/Socials.js b/src/pages/signin/Socials.js index f7a866d2023b..b8dddf3f799d 100644 --- a/src/pages/signin/Socials.js +++ b/src/pages/signin/Socials.js @@ -1,14 +1,14 @@ import React from 'react'; import {View} from 'react-native'; import _ from 'underscore'; -import * as Link from '../../libs/actions/Link'; -import Icon from '../../components/Icon'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import themeColors from '../../styles/themes/default'; -import styles from '../../styles/styles'; -import variables from '../../styles/variables'; -import CONST from '../../CONST'; +import Icon from '@components/Icon'; +import * as Expensicons from '@components/Icon/Expensicons'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import variables from '@styles/variables'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; const socialsList = [ { diff --git a/src/pages/signin/Terms.js b/src/pages/signin/Terms.js index 15f7c17a2889..13af9829305d 100644 --- a/src/pages/signin/Terms.js +++ b/src/pages/signin/Terms.js @@ -1,9 +1,9 @@ import React from 'react'; -import styles from '../../styles/styles'; -import CONST from '../../CONST'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; const linkStyles = [styles.textExtraSmallSupporting, styles.link]; diff --git a/src/pages/signin/ThirdPartySignInPage.js b/src/pages/signin/ThirdPartySignInPage.js index fa6aa4d5895e..c480356d5c15 100644 --- a/src/pages/signin/ThirdPartySignInPage.js +++ b/src/pages/signin/ThirdPartySignInPage.js @@ -1,21 +1,21 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {ActivityIndicator, View} from 'react-native'; -import {SafeAreaView} from 'react-native-safe-area-context'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; +import {SafeAreaView} from 'react-native-safe-area-context'; +import AppleSignIn from '@components/SignInButtons/AppleSignIn'; +import GoogleSignIn from '@components/SignInButtons/GoogleSignIn'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import SignInPageLayout from './SignInPageLayout'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import Text from '../../components/Text'; -import TextLink from '../../components/TextLink'; -import AppleSignIn from '../../components/SignInButtons/AppleSignIn'; -import GoogleSignIn from '../../components/SignInButtons/GoogleSignIn'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; -import CONST from '../../CONST'; -import ONYXKEYS from '../../ONYXKEYS'; const propTypes = { /** Which sign in provider we are using. */ diff --git a/src/pages/signin/UnlinkLoginForm.js b/src/pages/signin/UnlinkLoginForm.js index 6807ba74c6f9..d0fc44c1b1f7 100644 --- a/src/pages/signin/UnlinkLoginForm.js +++ b/src/pages/signin/UnlinkLoginForm.js @@ -1,22 +1,22 @@ +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; import React from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Str from 'expensify-common/lib/str'; -import styles from '../../styles/styles'; -import Button from '../../components/Button'; -import Text from '../../components/Text'; -import * as Session from '../../libs/actions/Session'; -import ONYXKEYS from '../../ONYXKEYS'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import redirectToSignIn from '../../libs/actions/SignInRedirect'; -import networkPropTypes from '../../components/networkPropTypes'; -import {withNetwork} from '../../components/OnyxProvider'; -import DotIndicatorMessage from '../../components/DotIndicatorMessage'; -import CONST from '../../CONST'; -import PressableWithFeedback from '../../components/Pressable/PressableWithFeedback'; +import _ from 'underscore'; +import Button from '@components/Button'; +import DotIndicatorMessage from '@components/DotIndicatorMessage'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import styles from '@styles/styles'; +import * as Session from '@userActions/Session'; +import redirectToSignIn from '@userActions/SignInRedirect'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/signin/ValidateCodeForm/BaseValidateCodeForm.js b/src/pages/signin/ValidateCodeForm/BaseValidateCodeForm.js index dc100fffe4f1..2d8f0e98e03c 100755 --- a/src/pages/signin/ValidateCodeForm/BaseValidateCodeForm.js +++ b/src/pages/signin/ValidateCodeForm/BaseValidateCodeForm.js @@ -1,32 +1,32 @@ -import React, {useState, useEffect, useRef, useCallback} from 'react'; -import {View} from 'react-native'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import styles from '../../../styles/styles'; -import Button from '../../../components/Button'; -import Text from '../../../components/Text'; -import themeColors from '../../../styles/themes/default'; -import * as Session from '../../../libs/actions/Session'; -import ONYXKEYS from '../../../ONYXKEYS'; -import CONST from '../../../CONST'; -import ChangeExpensifyLoginLink from '../ChangeExpensifyLoginLink'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import compose from '../../../libs/compose'; -import * as ValidationUtils from '../../../libs/ValidationUtils'; -import canFocusInputOnScreenFocus from '../../../libs/canFocusInputOnScreenFocus'; -import * as ErrorUtils from '../../../libs/ErrorUtils'; -import {withNetwork} from '../../../components/OnyxProvider'; -import networkPropTypes from '../../../components/networkPropTypes'; -import * as User from '../../../libs/actions/User'; -import FormHelpMessage from '../../../components/FormHelpMessage'; -import MagicCodeInput from '../../../components/MagicCodeInput'; -import Terms from '../Terms'; -import PressableWithFeedback from '../../../components/Pressable/PressableWithFeedback'; -import usePrevious from '../../../hooks/usePrevious'; -import * as StyleUtils from '../../../styles/StyleUtils'; -import TextInput from '../../../components/TextInput'; +import Button from '@components/Button'; +import FormHelpMessage from '@components/FormHelpMessage'; +import MagicCodeInput from '@components/MagicCodeInput'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import usePrevious from '@hooks/usePrevious'; +import canFocusInputOnScreenFocus from '@libs/canFocusInputOnScreenFocus'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import ChangeExpensifyLoginLink from '@pages/signin/ChangeExpensifyLoginLink'; +import Terms from '@pages/signin/Terms'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import * as Session from '@userActions/Session'; +import * as User from '@userActions/User'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/signin/ValidateCodeForm/index.android.js b/src/pages/signin/ValidateCodeForm/index.android.js index 1e888d24bc60..9adddf7c92d8 100644 --- a/src/pages/signin/ValidateCodeForm/index.android.js +++ b/src/pages/signin/ValidateCodeForm/index.android.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import BaseValidateCodeForm from './BaseValidateCodeForm'; const defaultProps = {}; diff --git a/src/pages/signin/ValidateCodeForm/index.js b/src/pages/signin/ValidateCodeForm/index.js index 540b6a3e3ed6..35afc283972b 100644 --- a/src/pages/signin/ValidateCodeForm/index.js +++ b/src/pages/signin/ValidateCodeForm/index.js @@ -1,5 +1,5 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import BaseValidateCodeForm from './BaseValidateCodeForm'; const defaultProps = {}; diff --git a/src/pages/tasks/NewTaskDescriptionPage.js b/src/pages/tasks/NewTaskDescriptionPage.js index 15f843853431..c8bd4f8cafd1 100644 --- a/src/pages/tasks/NewTaskDescriptionPage.js +++ b/src/pages/tasks/NewTaskDescriptionPage.js @@ -1,23 +1,23 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import Form from '../../components/Form'; -import TextInput from '../../components/TextInput'; -import Permissions from '../../libs/Permissions'; -import ROUTES from '../../ROUTES'; -import * as Task from '../../libs/actions/Task'; -import updateMultilineInputRange from '../../libs/UpdateMultilineInputRange'; -import CONST from '../../CONST'; -import * as Browser from '../../libs/Browser'; -import useAutoFocusInput from '../../hooks/useAutoFocusInput'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useAutoFocusInput from '@hooks/useAutoFocusInput'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Beta features list */ diff --git a/src/pages/tasks/NewTaskDetailsPage.js b/src/pages/tasks/NewTaskDetailsPage.js index 236003b23c68..0ab3771c28f2 100644 --- a/src/pages/tasks/NewTaskDetailsPage.js +++ b/src/pages/tasks/NewTaskDetailsPage.js @@ -1,24 +1,24 @@ +import PropTypes from 'prop-types'; import React, {useEffect, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import TextInput from '../../components/TextInput'; -import Permissions from '../../libs/Permissions'; -import ROUTES from '../../ROUTES'; -import * as Task from '../../libs/actions/Task'; -import CONST from '../../CONST'; -import * as Browser from '../../libs/Browser'; -import useAutoFocusInput from '../../hooks/useAutoFocusInput'; -import FormProvider from '../../components/Form/FormProvider'; -import InputWrapper from '../../components/Form/InputWrapper'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useAutoFocusInput from '@hooks/useAutoFocusInput'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Beta features list */ diff --git a/src/pages/tasks/NewTaskPage.js b/src/pages/tasks/NewTaskPage.js index f0d2d506c9d8..41cda42ccbd8 100644 --- a/src/pages/tasks/NewTaskPage.js +++ b/src/pages/tasks/NewTaskPage.js @@ -1,27 +1,27 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useEffect, useMemo, useState} from 'react'; import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import Permissions from '../../libs/Permissions'; -import ROUTES from '../../ROUTES'; -import MenuItemWithTopDescription from '../../components/MenuItemWithTopDescription'; -import MenuItem from '../../components/MenuItem'; -import reportPropTypes from '../reportPropTypes'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import * as Task from '../../libs/actions/Task'; -import * as ReportUtils from '../../libs/ReportUtils'; -import FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import * as LocalePhoneNumber from '../../libs/LocalePhoneNumber'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MenuItem from '@components/MenuItem'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import * as LocalePhoneNumber from '@libs/LocalePhoneNumber'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import Permissions from '@libs/Permissions'; +import * as ReportUtils from '@libs/ReportUtils'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Task Creation Data */ diff --git a/src/pages/tasks/NewTaskTitlePage.js b/src/pages/tasks/NewTaskTitlePage.js index f1c14dbe06b8..8508024b45ef 100644 --- a/src/pages/tasks/NewTaskTitlePage.js +++ b/src/pages/tasks/NewTaskTitlePage.js @@ -1,22 +1,22 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import Form from '../../components/Form'; -import TextInput from '../../components/TextInput'; -import Permissions from '../../libs/Permissions'; -import ROUTES from '../../ROUTES'; -import * as Task from '../../libs/actions/Task'; -import CONST from '../../CONST'; -import useAutoFocusInput from '../../hooks/useAutoFocusInput'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import useAutoFocusInput from '@hooks/useAutoFocusInput'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import Permissions from '@libs/Permissions'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Beta features list */ diff --git a/src/pages/tasks/TaskAssigneeSelectorModal.js b/src/pages/tasks/TaskAssigneeSelectorModal.js index bfa3ac884e4a..cb08d2928d88 100644 --- a/src/pages/tasks/TaskAssigneeSelectorModal.js +++ b/src/pages/tasks/TaskAssigneeSelectorModal.js @@ -1,27 +1,27 @@ /* eslint-disable es/no-optional-chaining */ -import React, {useState, useEffect, useMemo, useCallback, useRef} from 'react'; -import {View} from 'react-native'; import lodashGet from 'lodash/get'; -import _ from 'underscore'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import OptionsSelector from '../../components/OptionsSelector'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import Navigation from '../../libs/Navigation/Navigation'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import CONST from '../../CONST'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import personalDetailsPropType from '../personalDetailsPropType'; -import reportPropTypes from '../reportPropTypes'; -import * as ReportUtils from '../../libs/ReportUtils'; -import ROUTES from '../../ROUTES'; -import * as Task from '../../libs/actions/Task'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import withCurrentUserPersonalDetails from '../../components/withCurrentUserPersonalDetails'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import OptionsSelector from '@components/OptionsSelector'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Beta features list */ diff --git a/src/pages/tasks/TaskDescriptionPage.js b/src/pages/tasks/TaskDescriptionPage.js index a757e138d949..5d496fbca6c1 100644 --- a/src/pages/tasks/TaskDescriptionPage.js +++ b/src/pages/tasks/TaskDescriptionPage.js @@ -1,26 +1,26 @@ +import {useFocusEffect} from '@react-navigation/native'; import React, {useCallback, useRef} from 'react'; import {View} from 'react-native'; -import {useFocusEffect} from '@react-navigation/native'; import {withOnyx} from 'react-native-onyx'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import ONYXKEYS from '../../ONYXKEYS'; -import TextInput from '../../components/TextInput'; -import reportPropTypes from '../reportPropTypes'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import * as Task from '../../libs/actions/Task'; -import * as ReportUtils from '../../libs/ReportUtils'; -import CONST from '../../CONST'; -import updateMultilineInputRange from '../../libs/UpdateMultilineInputRange'; -import * as Browser from '../../libs/Browser'; -import Navigation from '../../libs/Navigation/Navigation'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import withCurrentUserPersonalDetails from '../../components/withCurrentUserPersonalDetails'; -import withReportOrNotFound from '../home/report/withReportOrNotFound'; -import FormProvider from '../../components/Form/FormProvider'; -import InputWrapper from '../../components/Form/InputWrapper'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import updateMultilineInputRange from '@libs/UpdateMultilineInputRange'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/tasks/TaskShareDestinationSelectorModal.js b/src/pages/tasks/TaskShareDestinationSelectorModal.js index 2fc8f0eab014..fde02c2a4108 100644 --- a/src/pages/tasks/TaskShareDestinationSelectorModal.js +++ b/src/pages/tasks/TaskShareDestinationSelectorModal.js @@ -1,24 +1,24 @@ /* eslint-disable es/no-optional-chaining */ -import React, {useState, useEffect, useMemo, useCallback, useRef} from 'react'; -import _ from 'underscore'; -import {View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import OptionsSelector from '../../components/OptionsSelector'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import Navigation from '../../libs/Navigation/Navigation'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import CONST from '../../CONST'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import personalDetailsPropType from '../personalDetailsPropType'; -import reportPropTypes from '../reportPropTypes'; -import * as Task from '../../libs/actions/Task'; -import * as ReportUtils from '../../libs/ReportUtils'; -import ROUTES from '../../ROUTES'; +import _ from 'underscore'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import OptionsSelector from '@components/OptionsSelector'; +import ScreenWrapper from '@components/ScreenWrapper'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /* Onyx Props */ diff --git a/src/pages/tasks/TaskTitlePage.js b/src/pages/tasks/TaskTitlePage.js index d7fae27851c9..375a23cc3012 100644 --- a/src/pages/tasks/TaskTitlePage.js +++ b/src/pages/tasks/TaskTitlePage.js @@ -1,24 +1,24 @@ -import _ from 'underscore'; import React, {useCallback, useRef} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import ONYXKEYS from '../../ONYXKEYS'; -import TextInput from '../../components/TextInput'; -import styles from '../../styles/styles'; -import reportPropTypes from '../reportPropTypes'; -import compose from '../../libs/compose'; -import * as Task from '../../libs/actions/Task'; -import * as ReportUtils from '../../libs/ReportUtils'; -import CONST from '../../CONST'; -import Navigation from '../../libs/Navigation/Navigation'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import withCurrentUserPersonalDetails from '../../components/withCurrentUserPersonalDetails'; -import withReportOrNotFound from '../home/report/withReportOrNotFound'; -import FormProvider from '../../components/Form/FormProvider'; -import InputWrapper from '../../components/Form/InputWrapper'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import TextInput from '@components/TextInput'; +import withCurrentUserPersonalDetails from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import withReportOrNotFound from '@pages/home/report/withReportOrNotFound'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as Task from '@userActions/Task'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The report currently being looked at */ diff --git a/src/pages/wallet/WalletStatementPage.js b/src/pages/wallet/WalletStatementPage.js index b220776cd9ef..0d33be70f1b7 100644 --- a/src/pages/wallet/WalletStatementPage.js +++ b/src/pages/wallet/WalletStatementPage.js @@ -1,25 +1,25 @@ -import React, {useEffect} from 'react'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; -import {withOnyx} from 'react-native-onyx'; import {format, getMonth, getYear} from 'date-fns'; import Str from 'expensify-common/lib/str'; -import Navigation from '../../libs/Navigation/Navigation'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import ONYXKEYS from '../../ONYXKEYS'; -import compose from '../../libs/compose'; -import CONFIG from '../../CONFIG'; -import WalletStatementModal from '../../components/WalletStatementModal'; -import * as User from '../../libs/actions/User'; -import fileDownload from '../../libs/fileDownload'; -import Growl from '../../libs/Growl'; -import CONST from '../../CONST'; -import FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView'; -import {withNetwork} from '../../components/OnyxProvider'; -import networkPropTypes from '../../components/networkPropTypes'; -import DateUtils from '../../libs/DateUtils'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import FullPageOfflineBlockingView from '@components/BlockingViews/FullPageOfflineBlockingView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import WalletStatementModal from '@components/WalletStatementModal'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import DateUtils from '@libs/DateUtils'; +import fileDownload from '@libs/fileDownload'; +import Growl from '@libs/Growl'; +import Navigation from '@libs/Navigation/Navigation'; +import * as User from '@userActions/User'; +import CONFIG from '@src/CONFIG'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/WorkspaceInitialPage.js b/src/pages/workspace/WorkspaceInitialPage.js index 5c754a1ef5fb..69c6ee7589e6 100644 --- a/src/pages/workspace/WorkspaceInitialPage.js +++ b/src/pages/workspace/WorkspaceInitialPage.js @@ -1,39 +1,39 @@ -import _ from 'underscore'; import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback, useEffect, useState} from 'react'; -import {View, ScrollView} from 'react-native'; +import {ScrollView, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import styles from '../../styles/styles'; -import Tooltip from '../../components/Tooltip'; -import Text from '../../components/Text'; -import ConfirmModal from '../../components/ConfirmModal'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import * as App from '../../libs/actions/App'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import MenuItem from '../../components/MenuItem'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import compose from '../../libs/compose'; -import Avatar from '../../components/Avatar'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import {policyPropTypes, policyDefaultProps} from './withPolicy'; +import _ from 'underscore'; +import Avatar from '@components/Avatar'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import ConfirmModal from '@components/ConfirmModal'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import Tooltip from '@components/Tooltip'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions from '@components/withWindowDimensions'; +import useSingleExecution from '@hooks/useSingleExecution'; +import useWaitForNavigation from '@hooks/useWaitForNavigation'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import reportPropTypes from '@pages/reportPropTypes'; +import styles from '@styles/styles'; +import * as App from '@userActions/App'; +import * as Policy from '@userActions/Policy'; +import * as ReimbursementAccount from '@userActions/ReimbursementAccount'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {policyDefaultProps, policyPropTypes} from './withPolicy'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; -import reportPropTypes from '../reportPropTypes'; -import * as Policy from '../../libs/actions/Policy'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import CONST from '../../CONST'; -import * as ReimbursementAccount from '../../libs/actions/ReimbursementAccount'; -import ONYXKEYS from '../../ONYXKEYS'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes'; -import * as ReportUtils from '../../libs/ReportUtils'; -import withWindowDimensions from '../../components/withWindowDimensions'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; -import useSingleExecution from '../../hooks/useSingleExecution'; -import useWaitForNavigation from '../../hooks/useWaitForNavigation'; const propTypes = { ...policyPropTypes, diff --git a/src/pages/workspace/WorkspaceInviteMessagePage.js b/src/pages/workspace/WorkspaceInviteMessagePage.js index 1f032ab514d3..1414354b4b38 100644 --- a/src/pages/workspace/WorkspaceInviteMessagePage.js +++ b/src/pages/workspace/WorkspaceInviteMessagePage.js @@ -1,32 +1,32 @@ -import React from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; -import {View, Keyboard} from 'react-native'; +import React from 'react'; +import {Keyboard, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Policy from '../../libs/actions/Policy'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import TextInput from '../../components/TextInput'; -import MultipleAvatars from '../../components/MultipleAvatars'; -import CONST from '../../CONST'; -import * as Link from '../../libs/actions/Link'; -import Text from '../../components/Text'; -import {policyPropTypes, policyDefaultProps} from './withPolicy'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Form from '@components/Form'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MultipleAvatars from '@components/MultipleAvatars'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withNavigationFocus from '@components/withNavigationFocus'; +import compose from '@libs/compose'; +import * as Localize from '@libs/Localize'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import {policyDefaultProps, policyPropTypes} from './withPolicy'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import ROUTES from '../../ROUTES'; -import * as Localize from '../../libs/Localize'; -import Form from '../../components/Form'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import withNavigationFocus from '../../components/withNavigationFocus'; -import PressableWithoutFeedback from '../../components/Pressable/PressableWithoutFeedback'; const personalDetailsPropTypes = PropTypes.shape({ /** The accountID of the person */ diff --git a/src/pages/workspace/WorkspaceInvitePage.js b/src/pages/workspace/WorkspaceInvitePage.js index a21173dd7d98..afb0c55e7d4e 100644 --- a/src/pages/workspace/WorkspaceInvitePage.js +++ b/src/pages/workspace/WorkspaceInvitePage.js @@ -1,27 +1,27 @@ -import React, {useEffect, useMemo, useState} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect, useMemo, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as Policy from '../../libs/actions/Policy'; -import FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import CONST from '../../CONST'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import styles from '@styles/styles'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import {policyDefaultProps, policyPropTypes} from './withPolicy'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import ROUTES from '../../ROUTES'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import * as Browser from '../../libs/Browser'; -import useNetwork from '../../hooks/useNetwork'; -import useLocalize from '../../hooks/useLocalize'; -import SelectionList from '../../components/SelectionList'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; const personalDetailsPropTypes = PropTypes.shape({ diff --git a/src/pages/workspace/WorkspaceMembersPage.js b/src/pages/workspace/WorkspaceMembersPage.js index c886df950674..3ee24b2db1b3 100644 --- a/src/pages/workspace/WorkspaceMembersPage.js +++ b/src/pages/workspace/WorkspaceMembersPage.js @@ -1,38 +1,38 @@ -import React, {useCallback, useEffect, useState, useMemo, useRef} from 'react'; -import _ from 'underscore'; import lodashGet from 'lodash/get'; -import {InteractionManager, View} from 'react-native'; import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; +import {InteractionManager, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import styles from '../../styles/styles'; -import ONYXKEYS from '../../ONYXKEYS'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import Navigation from '../../libs/Navigation/Navigation'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import withLocalize, {withLocalizePropTypes} from '../../components/withLocalize'; -import compose from '../../libs/compose'; -import * as Policy from '../../libs/actions/Policy'; -import * as OptionsListUtils from '../../libs/OptionsListUtils'; -import Button from '../../components/Button'; -import ROUTES from '../../ROUTES'; -import ConfirmModal from '../../components/ConfirmModal'; -import personalDetailsPropType from '../personalDetailsPropType'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Button from '@components/Button'; +import ConfirmModal from '@components/ConfirmModal'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import MessagesRow from '@components/MessagesRow'; +import networkPropTypes from '@components/networkPropTypes'; +import {withNetwork} from '@components/OnyxProvider'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import Text from '@components/Text'; +import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '@components/withCurrentUserPersonalDetails'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import usePrevious from '@hooks/usePrevious'; +import * as Browser from '@libs/Browser'; +import compose from '@libs/compose'; +import Log from '@libs/Log'; +import Navigation from '@libs/Navigation/Navigation'; +import * as OptionsListUtils from '@libs/OptionsListUtils'; +import * as PersonalDetailsUtils from '@libs/PersonalDetailsUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as UserUtils from '@libs/UserUtils'; +import personalDetailsPropType from '@pages/personalDetailsPropType'; +import styles from '@styles/styles'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import {policyDefaultProps, policyPropTypes} from './withPolicy'; -import CONST from '../../CONST'; -import {withNetwork} from '../../components/OnyxProvider'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import networkPropTypes from '../../components/networkPropTypes'; -import * as UserUtils from '../../libs/UserUtils'; -import withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../components/withCurrentUserPersonalDetails'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import usePrevious from '../../hooks/usePrevious'; -import Log from '../../libs/Log'; -import * as PersonalDetailsUtils from '../../libs/PersonalDetailsUtils'; -import MessagesRow from '../../components/MessagesRow'; -import SelectionList from '../../components/SelectionList'; -import Text from '../../components/Text'; -import * as Browser from '../../libs/Browser'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; const propTypes = { diff --git a/src/pages/workspace/WorkspaceNewRoomPage.js b/src/pages/workspace/WorkspaceNewRoomPage.js index c059a54b7c21..05156c89ea61 100644 --- a/src/pages/workspace/WorkspaceNewRoomPage.js +++ b/src/pages/workspace/WorkspaceNewRoomPage.js @@ -1,32 +1,32 @@ -import React, {useState, useEffect, useCallback, useMemo, useRef} from 'react'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react'; import {View} from 'react-native'; -import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import withNavigationFocus from '../../components/withNavigationFocus'; -import * as Report from '../../libs/actions/Report'; -import * as App from '../../libs/actions/App'; -import useLocalize from '../../hooks/useLocalize'; -import styles from '../../styles/styles'; -import RoomNameInput from '../../components/RoomNameInput'; -import KeyboardAvoidingView from '../../components/KeyboardAvoidingView'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import Text from '../../components/Text'; -import TextInput from '../../components/TextInput'; -import Permissions from '../../libs/Permissions'; -import * as ErrorUtils from '../../libs/ErrorUtils'; -import * as ValidationUtils from '../../libs/ValidationUtils'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import Form from '../../components/Form'; -import policyMemberPropType from '../policyMemberPropType'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import compose from '../../libs/compose'; -import variables from '../../styles/variables'; -import useDelayedInputFocus from '../../hooks/useDelayedInputFocus'; -import ValuePicker from '../../components/ValuePicker'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import Form from '@components/Form'; +import KeyboardAvoidingView from '@components/KeyboardAvoidingView'; +import RoomNameInput from '@components/RoomNameInput'; +import ScreenWrapper from '@components/ScreenWrapper'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import ValuePicker from '@components/ValuePicker'; +import withNavigationFocus from '@components/withNavigationFocus'; +import useDelayedInputFocus from '@hooks/useDelayedInputFocus'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import * as ErrorUtils from '@libs/ErrorUtils'; +import Permissions from '@libs/Permissions'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as ValidationUtils from '@libs/ValidationUtils'; +import policyMemberPropType from '@pages/policyMemberPropType'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; +import * as App from '@userActions/App'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** All reports shared with the user */ diff --git a/src/pages/workspace/WorkspacePageWithSections.js b/src/pages/workspace/WorkspacePageWithSections.js index fbe950248062..98e9da3674c1 100644 --- a/src/pages/workspace/WorkspacePageWithSections.js +++ b/src/pages/workspace/WorkspacePageWithSections.js @@ -1,25 +1,25 @@ -import React, {useEffect} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import styles from '../../styles/styles'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import Navigation from '../../libs/Navigation/Navigation'; -import compose from '../../libs/compose'; -import ROUTES from '../../ROUTES'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import ONYXKEYS from '../../ONYXKEYS'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import BankAccount from '../../libs/models/BankAccount'; -import * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes'; -import userPropTypes from '../settings/userPropTypes'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import ScrollViewWithContext from '@components/ScrollViewWithContext'; +import useNetwork from '@hooks/useNetwork'; +import compose from '@libs/compose'; +import BankAccount from '@libs/models/BankAccount'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import userPropTypes from '@pages/settings/userPropTypes'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; -import ScrollViewWithContext from '../../components/ScrollViewWithContext'; -import useNetwork from '../../hooks/useNetwork'; const propTypes = { shouldSkipVBBACall: PropTypes.bool, diff --git a/src/pages/workspace/WorkspaceResetBankAccountModal.js b/src/pages/workspace/WorkspaceResetBankAccountModal.js index ff7bcb51e939..434c09f0ac04 100644 --- a/src/pages/workspace/WorkspaceResetBankAccountModal.js +++ b/src/pages/workspace/WorkspaceResetBankAccountModal.js @@ -1,15 +1,15 @@ import lodashGet from 'lodash/get'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import ConfirmModal from '../../components/ConfirmModal'; -import * as BankAccounts from '../../libs/actions/BankAccounts'; -import * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes'; -import Text from '../../components/Text'; -import styles from '../../styles/styles'; -import BankAccount from '../../libs/models/BankAccount'; -import ONYXKEYS from '../../ONYXKEYS'; -import useLocalize from '../../hooks/useLocalize'; +import ConfirmModal from '@components/ConfirmModal'; +import Text from '@components/Text'; +import useLocalize from '@hooks/useLocalize'; +import BankAccount from '@libs/models/BankAccount'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Reimbursement account data */ diff --git a/src/pages/workspace/WorkspaceSettingsCurrencyPage.js b/src/pages/workspace/WorkspaceSettingsCurrencyPage.js index a8f473bb1a0b..ce1e1d7b8966 100644 --- a/src/pages/workspace/WorkspaceSettingsCurrencyPage.js +++ b/src/pages/workspace/WorkspaceSettingsCurrencyPage.js @@ -1,19 +1,19 @@ -import React, {useState, useCallback} from 'react'; -import _ from 'underscore'; -import {withOnyx} from 'react-native-onyx'; import PropTypes from 'prop-types'; -import useLocalize from '../../hooks/useLocalize'; -import ScreenWrapper from '../../components/ScreenWrapper'; -import HeaderWithBackButton from '../../components/HeaderWithBackButton'; -import SelectionList from '../../components/SelectionList'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; +import React, {useCallback, useState} from 'react'; +import {withOnyx} from 'react-native-onyx'; +import _ from 'underscore'; +import FullPageNotFoundView from '@components/BlockingViews/FullPageNotFoundView'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; +import ScreenWrapper from '@components/ScreenWrapper'; +import SelectionList from '@components/SelectionList'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as Policy from '@userActions/Policy'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import {policyDefaultProps, policyPropTypes} from './withPolicy'; -import * as Policy from '../../libs/actions/Policy'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; const propTypes = { diff --git a/src/pages/workspace/WorkspaceSettingsPage.js b/src/pages/workspace/WorkspaceSettingsPage.js index fd975ebc9247..9d1000179291 100644 --- a/src/pages/workspace/WorkspaceSettingsPage.js +++ b/src/pages/workspace/WorkspaceSettingsPage.js @@ -1,31 +1,31 @@ +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; import React, {useCallback} from 'react'; import {Keyboard, View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import lodashGet from 'lodash/get'; -import ONYXKEYS from '../../ONYXKEYS'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import * as Policy from '../../libs/actions/Policy'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import AvatarWithImagePicker from '../../components/AvatarWithImagePicker'; -import CONST from '../../CONST'; -import TextInput from '../../components/TextInput'; +import Avatar from '@components/Avatar'; +import AvatarWithImagePicker from '@components/AvatarWithImagePicker'; +import Form from '@components/Form'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import withWindowDimensions, {windowDimensionsPropTypes} from '@components/withWindowDimensions'; +import useLocalize from '@hooks/useLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as ReportUtils from '@libs/ReportUtils'; +import * as UserUtils from '@libs/UserUtils'; +import styles from '@styles/styles'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import withPolicy, {policyDefaultProps, policyPropTypes} from './withPolicy'; import WorkspacePageWithSections from './WorkspacePageWithSections'; -import withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy'; -import {withNetwork} from '../../components/OnyxProvider'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import Form from '../../components/Form'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as UserUtils from '../../libs/UserUtils'; -import Avatar from '../../components/Avatar'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions'; -import MenuItemWithTopDescription from '../../components/MenuItemWithTopDescription'; -import Text from '../../components/Text'; -import useLocalize from '../../hooks/useLocalize'; const propTypes = { /** Constant, list of available currencies */ diff --git a/src/pages/workspace/WorkspacesListPage.js b/src/pages/workspace/WorkspacesListPage.js index 5a2e01562cc1..572dd9d1152f 100755 --- a/src/pages/workspace/WorkspacesListPage.js +++ b/src/pages/workspace/WorkspacesListPage.js @@ -1,34 +1,34 @@ +import PropTypes from 'prop-types'; import React, {useMemo} from 'react'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; import _ from 'underscore'; -import Navigation from '../../libs/Navigation/Navigation'; -import ROUTES from '../../ROUTES'; -import ONYXKEYS from '../../ONYXKEYS'; -import CONST from '../../CONST'; -import styles from '../../styles/styles'; -import compose from '../../libs/compose'; -import OfflineWithFeedback from '../../components/OfflineWithFeedback'; -import * as Expensicons from '../../components/Icon/Expensicons'; -import themeColors from '../../styles/themes/default'; -import * as PolicyUtils from '../../libs/PolicyUtils'; -import MenuItem from '../../components/MenuItem'; -import * as Policy from '../../libs/actions/Policy'; -import policyMemberPropType from '../policyMemberPropType'; -import Button from '../../components/Button'; -import * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes'; -import * as ReportUtils from '../../libs/ReportUtils'; -import * as CurrencyUtils from '../../libs/CurrencyUtils'; +import Button from '@components/Button'; +import FeatureList from '@components/FeatureList'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import IllustratedHeaderPageLayout from '@components/IllustratedHeaderPageLayout'; +import * as LottieAnimations from '@components/LottieAnimations'; +import MenuItem from '@components/MenuItem'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import useLocalize from '@hooks/useLocalize'; +import useNetwork from '@hooks/useNetwork'; +import usePermissions from '@hooks/usePermissions'; +import compose from '@libs/compose'; +import * as CurrencyUtils from '@libs/CurrencyUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReportUtils from '@libs/ReportUtils'; +import policyMemberPropType from '@pages/policyMemberPropType'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as App from '@userActions/App'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; +import SCREENS from '@src/SCREENS'; import withPolicyAndFullscreenLoading from './withPolicyAndFullscreenLoading'; -import * as App from '../../libs/actions/App'; -import useLocalize from '../../hooks/useLocalize'; -import useNetwork from '../../hooks/useNetwork'; -import usePermissions from '../../hooks/usePermissions'; -import IllustratedHeaderPageLayout from '../../components/IllustratedHeaderPageLayout'; -import SCREENS from '../../SCREENS'; -import * as LottieAnimations from '../../components/LottieAnimations'; -import * as Illustrations from '../../components/Icon/Illustrations'; -import FeatureList from '../../components/FeatureList'; const propTypes = { /** The list of this user's policies */ diff --git a/src/pages/workspace/bills/WorkspaceBillsFirstSection.js b/src/pages/workspace/bills/WorkspaceBillsFirstSection.js index b0fc0e99c8f9..d71614f8a078 100644 --- a/src/pages/workspace/bills/WorkspaceBillsFirstSection.js +++ b/src/pages/workspace/bills/WorkspaceBillsFirstSection.js @@ -1,20 +1,20 @@ +import Str from 'expensify-common/lib/str'; +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; import {withOnyx} from 'react-native-onyx'; -import Str from 'expensify-common/lib/str'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import CopyTextToClipboard from '../../../components/CopyTextToClipboard'; -import * as Link from '../../../libs/actions/Link'; -import compose from '../../../libs/compose'; -import ONYXKEYS from '../../../ONYXKEYS'; -import userPropTypes from '../../settings/userPropTypes'; -import TextLink from '../../../components/TextLink'; +import CopyTextToClipboard from '@components/CopyTextToClipboard'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import TextLink from '@components/TextLink'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import userPropTypes from '@pages/settings/userPropTypes'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/bills/WorkspaceBillsNoVBAView.js b/src/pages/workspace/bills/WorkspaceBillsNoVBAView.js index 8c16cbb195cc..8bca8e9067ee 100644 --- a/src/pages/workspace/bills/WorkspaceBillsNoVBAView.js +++ b/src/pages/workspace/bills/WorkspaceBillsNoVBAView.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; +import ConnectBankAccountButton from '@components/ConnectBankAccountButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; import WorkspaceBillsFirstSection from './WorkspaceBillsFirstSection'; -import ConnectBankAccountButton from '../../../components/ConnectBankAccountButton'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/bills/WorkspaceBillsPage.js b/src/pages/workspace/bills/WorkspaceBillsPage.js index 5cb590895e0d..c607071a4365 100644 --- a/src/pages/workspace/bills/WorkspaceBillsPage.js +++ b/src/pages/workspace/bills/WorkspaceBillsPage.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; +import React from 'react'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import CONST from '@src/CONST'; import WorkspaceBillsNoVBAView from './WorkspaceBillsNoVBAView'; import WorkspaceBillsVBAView from './WorkspaceBillsVBAView'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; -import CONST from '../../../CONST'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/bills/WorkspaceBillsVBAView.js b/src/pages/workspace/bills/WorkspaceBillsVBAView.js index c35b3400e7d1..08e5349e2e1f 100644 --- a/src/pages/workspace/bills/WorkspaceBillsVBAView.js +++ b/src/pages/workspace/bills/WorkspaceBillsVBAView.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import * as Link from '../../../libs/actions/Link'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; import WorkspaceBillsFirstSection from './WorkspaceBillsFirstSection'; const propTypes = { diff --git a/src/pages/workspace/card/WorkspaceCardNoVBAView.js b/src/pages/workspace/card/WorkspaceCardNoVBAView.js index b1a1dcf0b793..a8ad276dd0ce 100644 --- a/src/pages/workspace/card/WorkspaceCardNoVBAView.js +++ b/src/pages/workspace/card/WorkspaceCardNoVBAView.js @@ -1,13 +1,13 @@ -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {View} from 'react-native'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import UnorderedList from '../../../components/UnorderedList'; -import Section from '../../../components/Section'; -import ConnectBankAccountButton from '../../../components/ConnectBankAccountButton'; +import ConnectBankAccountButton from '@components/ConnectBankAccountButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import UnorderedList from '@components/UnorderedList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/card/WorkspaceCardPage.js b/src/pages/workspace/card/WorkspaceCardPage.js index 2f5527c49cf0..55220b85ce63 100644 --- a/src/pages/workspace/card/WorkspaceCardPage.js +++ b/src/pages/workspace/card/WorkspaceCardPage.js @@ -1,11 +1,11 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; +import React from 'react'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import CONST from '@src/CONST'; import WorkspaceCardNoVBAView from './WorkspaceCardNoVBAView'; import WorkspaceCardVBANoECardView from './WorkspaceCardVBANoECardView'; import WorkspaceCardVBAWithECardView from './WorkspaceCardVBAWithECardView'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; -import CONST from '../../../CONST'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/card/WorkspaceCardVBANoECardView.js b/src/pages/workspace/card/WorkspaceCardVBANoECardView.js index 5c93b8858de4..0ac81230b32e 100644 --- a/src/pages/workspace/card/WorkspaceCardVBANoECardView.js +++ b/src/pages/workspace/card/WorkspaceCardVBANoECardView.js @@ -1,19 +1,19 @@ import React from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import Text from '../../../components/Text'; -import Button from '../../../components/Button'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import UnorderedList from '../../../components/UnorderedList'; -import Section from '../../../components/Section'; -import * as Link from '../../../libs/actions/Link'; -import ONYXKEYS from '../../../ONYXKEYS'; -import compose from '../../../libs/compose'; -import CONST from '../../../CONST'; -import userPropTypes from '../../settings/userPropTypes'; +import Button from '@components/Button'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import UnorderedList from '@components/UnorderedList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import userPropTypes from '@pages/settings/userPropTypes'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; const propTypes = { /** Information about the logged in user's account */ diff --git a/src/pages/workspace/card/WorkspaceCardVBAWithECardView.js b/src/pages/workspace/card/WorkspaceCardVBAWithECardView.js index 7f9971f00c1b..582a85109461 100644 --- a/src/pages/workspace/card/WorkspaceCardVBAWithECardView.js +++ b/src/pages/workspace/card/WorkspaceCardVBAWithECardView.js @@ -1,13 +1,13 @@ import React from 'react'; import {View} from 'react-native'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import UnorderedList from '../../../components/UnorderedList'; -import * as Link from '../../../libs/actions/Link'; -import Section from '../../../components/Section'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import UnorderedList from '@components/UnorderedList'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/workspace/invoices/WorkspaceInvoicesFirstSection.js b/src/pages/workspace/invoices/WorkspaceInvoicesFirstSection.js index 7c47476e1c7b..78fe7cdae1cb 100644 --- a/src/pages/workspace/invoices/WorkspaceInvoicesFirstSection.js +++ b/src/pages/workspace/invoices/WorkspaceInvoicesFirstSection.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import * as Link from '../../../libs/actions/Link'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/invoices/WorkspaceInvoicesNoVBAView.js b/src/pages/workspace/invoices/WorkspaceInvoicesNoVBAView.js index 5348e49ee599..6f334cd10b0a 100644 --- a/src/pages/workspace/invoices/WorkspaceInvoicesNoVBAView.js +++ b/src/pages/workspace/invoices/WorkspaceInvoicesNoVBAView.js @@ -1,13 +1,13 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; +import ConnectBankAccountButton from '@components/ConnectBankAccountButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; import WorkspaceInvoicesFirstSection from './WorkspaceInvoicesFirstSection'; -import ConnectBankAccountButton from '../../../components/ConnectBankAccountButton'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/invoices/WorkspaceInvoicesPage.js b/src/pages/workspace/invoices/WorkspaceInvoicesPage.js index bfc1988211ce..8bc0c4484100 100644 --- a/src/pages/workspace/invoices/WorkspaceInvoicesPage.js +++ b/src/pages/workspace/invoices/WorkspaceInvoicesPage.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; +import React from 'react'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import CONST from '@src/CONST'; import WorkspaceInvoicesNoVBAView from './WorkspaceInvoicesNoVBAView'; import WorkspaceInvoicesVBAView from './WorkspaceInvoicesVBAView'; -import CONST from '../../../CONST'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/invoices/WorkspaceInvoicesVBAView.js b/src/pages/workspace/invoices/WorkspaceInvoicesVBAView.js index 0f7dd8b340fc..0958ba9688e5 100644 --- a/src/pages/workspace/invoices/WorkspaceInvoicesVBAView.js +++ b/src/pages/workspace/invoices/WorkspaceInvoicesVBAView.js @@ -1,14 +1,14 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; import WorkspaceInvoicesFirstSection from './WorkspaceInvoicesFirstSection'; -import * as Link from '../../../libs/actions/Link'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/reimburse/WorkspaceRateAndUnitPage.js b/src/pages/workspace/reimburse/WorkspaceRateAndUnitPage.js index 026441c665a2..14338424e11d 100644 --- a/src/pages/workspace/reimburse/WorkspaceRateAndUnitPage.js +++ b/src/pages/workspace/reimburse/WorkspaceRateAndUnitPage.js @@ -1,28 +1,28 @@ +import lodashGet from 'lodash/get'; import React from 'react'; import {Keyboard, View} from 'react-native'; -import _ from 'underscore'; -import lodashGet from 'lodash/get'; import {withOnyx} from 'react-native-onyx'; -import ONYXKEYS from '../../../ONYXKEYS'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import styles from '../../../styles/styles'; -import compose from '../../../libs/compose'; -import * as Policy from '../../../libs/actions/Policy'; -import * as PolicyUtils from '../../../libs/PolicyUtils'; -import CONST from '../../../CONST'; -import Picker from '../../../components/Picker'; -import TextInput from '../../../components/TextInput'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; -import withPolicy, {policyPropTypes, policyDefaultProps} from '../withPolicy'; -import {withNetwork} from '../../../components/OnyxProvider'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; -import Form from '../../../components/Form'; -import Navigation from '../../../libs/Navigation/Navigation'; -import ROUTES from '../../../ROUTES'; -import getPermittedDecimalSeparator from '../../../libs/getPermittedDecimalSeparator'; -import * as BankAccounts from '../../../libs/actions/BankAccounts'; -import * as ReimbursementAccountProps from '../../ReimbursementAccount/reimbursementAccountPropTypes'; -import * as NumberUtils from '../../../libs/NumberUtils'; +import _ from 'underscore'; +import Form from '@components/Form'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import Picker from '@components/Picker'; +import TextInput from '@components/TextInput'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import getPermittedDecimalSeparator from '@libs/getPermittedDecimalSeparator'; +import Navigation from '@libs/Navigation/Navigation'; +import * as NumberUtils from '@libs/NumberUtils'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import withPolicy, {policyDefaultProps, policyPropTypes} from '@pages/workspace/withPolicy'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; const propTypes = { /** Bank account attached to free plan */ diff --git a/src/pages/workspace/reimburse/WorkspaceReimbursePage.js b/src/pages/workspace/reimburse/WorkspaceReimbursePage.js index 9d1495c2a11f..d19cde6a0553 100644 --- a/src/pages/workspace/reimburse/WorkspaceReimbursePage.js +++ b/src/pages/workspace/reimburse/WorkspaceReimbursePage.js @@ -1,11 +1,11 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; +import React from 'react'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import withPolicy, {policyPropTypes} from '@pages/workspace/withPolicy'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import CONST from '@src/CONST'; import WorkspaceReimburseView from './WorkspaceReimburseView'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; -import CONST from '../../../CONST'; -import compose from '../../../libs/compose'; -import withPolicy, {policyPropTypes} from '../withPolicy'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/reimburse/WorkspaceReimburseSection.js b/src/pages/workspace/reimburse/WorkspaceReimburseSection.js index eb8305f23140..4a6c32287018 100644 --- a/src/pages/workspace/reimburse/WorkspaceReimburseSection.js +++ b/src/pages/workspace/reimburse/WorkspaceReimburseSection.js @@ -1,20 +1,20 @@ -import React, {useState, useEffect} from 'react'; +import lodashGet from 'lodash/get'; import PropTypes from 'prop-types'; +import React, {useEffect, useState} from 'react'; import {ActivityIndicator, View} from 'react-native'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import themeColors from '../../../styles/themes/default'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import * as Link from '../../../libs/actions/Link'; -import BankAccount from '../../../libs/models/BankAccount'; -import * as ReimbursementAccountProps from '../../ReimbursementAccount/reimbursementAccountPropTypes'; -import networkPropTypes from '../../../components/networkPropTypes'; -import CONST from '../../../CONST'; -import ConnectBankAccountButton from '../../../components/ConnectBankAccountButton'; +import ConnectBankAccountButton from '@components/ConnectBankAccountButton'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import networkPropTypes from '@components/networkPropTypes'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import BankAccount from '@libs/models/BankAccount'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import styles from '@styles/styles'; +import themeColors from '@styles/themes/default'; +import * as Link from '@userActions/Link'; +import CONST from '@src/CONST'; const propTypes = { /** Policy values needed in the component */ diff --git a/src/pages/workspace/reimburse/WorkspaceReimburseView.js b/src/pages/workspace/reimburse/WorkspaceReimburseView.js index 6b520b65eff2..5085792ed027 100644 --- a/src/pages/workspace/reimburse/WorkspaceReimburseView.js +++ b/src/pages/workspace/reimburse/WorkspaceReimburseView.js @@ -1,31 +1,31 @@ -import React, {useState, useEffect, useCallback} from 'react'; +import lodashGet from 'lodash/get'; +import PropTypes from 'prop-types'; +import React, {useCallback, useEffect, useState} from 'react'; import {View} from 'react-native'; import {withOnyx} from 'react-native-onyx'; -import PropTypes from 'prop-types'; -import lodashGet from 'lodash/get'; import _ from 'underscore'; -import MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import Navigation from '../../../libs/Navigation/Navigation'; -import CopyTextToClipboard from '../../../components/CopyTextToClipboard'; -import * as Link from '../../../libs/actions/Link'; -import compose from '../../../libs/compose'; -import * as Policy from '../../../libs/actions/Policy'; -import * as PolicyUtils from '../../../libs/PolicyUtils'; -import CONST from '../../../CONST'; -import ROUTES from '../../../ROUTES'; -import ONYXKEYS from '../../../ONYXKEYS'; -import * as ReimbursementAccountProps from '../../ReimbursementAccount/reimbursementAccountPropTypes'; -import {withNetwork} from '../../../components/OnyxProvider'; -import networkPropTypes from '../../../components/networkPropTypes'; +import CopyTextToClipboard from '@components/CopyTextToClipboard'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import MenuItemWithTopDescription from '@components/MenuItemWithTopDescription'; +import networkPropTypes from '@components/networkPropTypes'; +import OfflineWithFeedback from '@components/OfflineWithFeedback'; +import {withNetwork} from '@components/OnyxProvider'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import compose from '@libs/compose'; +import Navigation from '@libs/Navigation/Navigation'; +import * as PolicyUtils from '@libs/PolicyUtils'; +import * as ReimbursementAccountProps from '@pages/ReimbursementAccount/reimbursementAccountPropTypes'; +import styles from '@styles/styles'; +import * as BankAccounts from '@userActions/BankAccounts'; +import * as Link from '@userActions/Link'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; +import ROUTES from '@src/ROUTES'; import WorkspaceReimburseSection from './WorkspaceReimburseSection'; -import * as BankAccounts from '../../../libs/actions/BankAccounts'; -import OfflineWithFeedback from '../../../components/OfflineWithFeedback'; const propTypes = { /** Policy values needed in the component */ diff --git a/src/pages/workspace/travel/WorkspaceTravelNoVBAView.js b/src/pages/workspace/travel/WorkspaceTravelNoVBAView.js index 254162e29aed..67be0fdca9fb 100644 --- a/src/pages/workspace/travel/WorkspaceTravelNoVBAView.js +++ b/src/pages/workspace/travel/WorkspaceTravelNoVBAView.js @@ -1,12 +1,12 @@ +import PropTypes from 'prop-types'; import React from 'react'; import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import ConnectBankAccountButton from '../../../components/ConnectBankAccountButton'; +import ConnectBankAccountButton from '@components/ConnectBankAccountButton'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; const propTypes = { /** The policy ID currently being configured */ diff --git a/src/pages/workspace/travel/WorkspaceTravelPage.js b/src/pages/workspace/travel/WorkspaceTravelPage.js index 8f8a174a5876..a88e180cc7b6 100644 --- a/src/pages/workspace/travel/WorkspaceTravelPage.js +++ b/src/pages/workspace/travel/WorkspaceTravelPage.js @@ -1,10 +1,10 @@ -import React from 'react'; import PropTypes from 'prop-types'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import WorkspacePageWithSections from '../WorkspacePageWithSections'; +import React from 'react'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import WorkspacePageWithSections from '@pages/workspace/WorkspacePageWithSections'; +import CONST from '@src/CONST'; import WorkspaceTravelNoVBAView from './WorkspaceTravelNoVBAView'; import WorkspaceTravelVBAView from './WorkspaceTravelVBAView'; -import CONST from '../../../CONST'; const propTypes = { /** The route object passed to this page from the navigator */ diff --git a/src/pages/workspace/travel/WorkspaceTravelVBAView.js b/src/pages/workspace/travel/WorkspaceTravelVBAView.js index 8156b0334b3d..6d5620d8c939 100644 --- a/src/pages/workspace/travel/WorkspaceTravelVBAView.js +++ b/src/pages/workspace/travel/WorkspaceTravelVBAView.js @@ -1,14 +1,14 @@ import React from 'react'; import {View} from 'react-native'; -import Text from '../../../components/Text'; -import styles from '../../../styles/styles'; -import withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize'; -import * as Expensicons from '../../../components/Icon/Expensicons'; -import * as Illustrations from '../../../components/Icon/Illustrations'; -import Section from '../../../components/Section'; -import * as Link from '../../../libs/actions/Link'; -import * as Report from '../../../libs/actions/Report'; -import CONST from '../../../CONST'; +import * as Expensicons from '@components/Icon/Expensicons'; +import * as Illustrations from '@components/Icon/Illustrations'; +import Section from '@components/Section'; +import Text from '@components/Text'; +import withLocalize, {withLocalizePropTypes} from '@components/withLocalize'; +import styles from '@styles/styles'; +import * as Link from '@userActions/Link'; +import * as Report from '@userActions/Report'; +import CONST from '@src/CONST'; const propTypes = { ...withLocalizePropTypes, diff --git a/src/pages/workspace/withPolicy.js b/src/pages/workspace/withPolicy.js index 19c24c7dad39..cc0865dfcfdd 100644 --- a/src/pages/workspace/withPolicy.js +++ b/src/pages/workspace/withPolicy.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; +import {useNavigationState} from '@react-navigation/native'; import lodashGet from 'lodash/get'; -import React from 'react'; import PropTypes from 'prop-types'; +import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import {useNavigationState} from '@react-navigation/native'; -import CONST from '../../CONST'; -import getComponentDisplayName from '../../libs/getComponentDisplayName'; -import * as Policy from '../../libs/actions/Policy'; -import ONYXKEYS from '../../ONYXKEYS'; -import policyMemberPropType from '../policyMemberPropType'; +import _ from 'underscore'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import policyMemberPropType from '@pages/policyMemberPropType'; +import * as Policy from '@userActions/Policy'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; /** * @param {Object} route diff --git a/src/pages/workspace/withPolicyAndFullscreenLoading.js b/src/pages/workspace/withPolicyAndFullscreenLoading.js index 60522cbfbf05..2911eadccf5f 100644 --- a/src/pages/workspace/withPolicyAndFullscreenLoading.js +++ b/src/pages/workspace/withPolicyAndFullscreenLoading.js @@ -1,13 +1,13 @@ +import isEmpty from 'lodash/isEmpty'; +import omit from 'lodash/omit'; import PropTypes from 'prop-types'; import React from 'react'; import {withOnyx} from 'react-native-onyx'; -import isEmpty from 'lodash/isEmpty'; -import omit from 'lodash/omit'; -import compose from '../../libs/compose'; -import ONYXKEYS from '../../ONYXKEYS'; -import withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy'; -import getComponentDisplayName from '../../libs/getComponentDisplayName'; -import FullscreenLoadingIndicator from '../../components/FullscreenLoadingIndicator'; +import FullscreenLoadingIndicator from '@components/FullscreenLoadingIndicator'; +import compose from '@libs/compose'; +import getComponentDisplayName from '@libs/getComponentDisplayName'; +import ONYXKEYS from '@src/ONYXKEYS'; +import withPolicy, {policyDefaultProps, policyPropTypes} from './withPolicy'; export default function (WrappedComponent) { const propTypes = { diff --git a/src/setup/index.js b/src/setup/index.js index 5e92bff35ba1..aac6f1e4e732 100644 --- a/src/setup/index.js +++ b/src/setup/index.js @@ -1,12 +1,12 @@ import {I18nManager} from 'react-native'; import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../ONYXKEYS'; -import CONST from '../CONST'; +import intlPolyfill from '@libs/IntlPolyfill'; +import * as Metrics from '@libs/Metrics'; +import * as Device from '@userActions/Device'; +import exposeGlobalMemoryOnlyKeysMethods from '@userActions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods'; +import CONST from '@src/CONST'; +import ONYXKEYS from '@src/ONYXKEYS'; import platformSetup from './platformSetup'; -import * as Metrics from '../libs/Metrics'; -import * as Device from '../libs/actions/Device'; -import intlPolyfill from '../libs/IntlPolyfill'; -import exposeGlobalMemoryOnlyKeysMethods from '../libs/actions/MemoryOnlyKeys/exposeGlobalMemoryOnlyKeysMethods'; export default function () { /* diff --git a/src/setup/platformSetup/index.desktop.js b/src/setup/platformSetup/index.desktop.js index 0fff03ed252b..ab485b1855f1 100644 --- a/src/setup/platformSetup/index.desktop.js +++ b/src/setup/platformSetup/index.desktop.js @@ -1,10 +1,10 @@ import {AppRegistry} from 'react-native'; -import Config from '../../CONFIG'; -import LocalNotification from '../../libs/Notification/LocalNotification'; -import DateUtils from '../../libs/DateUtils'; +import DateUtils from '@libs/DateUtils'; +import Navigation from '@libs/Navigation/Navigation'; +import LocalNotification from '@libs/Notification/LocalNotification'; +import Config from '@src/CONFIG'; +import ROUTES from '@src/ROUTES'; import ELECTRON_EVENTS from '../../../desktop/ELECTRON_EVENTS'; -import ROUTES from '../../ROUTES'; -import Navigation from '../../libs/Navigation/Navigation'; export default function () { AppRegistry.runApplication(Config.APP_NAME, { diff --git a/src/setup/platformSetup/index.native.js b/src/setup/platformSetup/index.native.js index 470bef78848f..09a39e13386e 100644 --- a/src/setup/platformSetup/index.native.js +++ b/src/setup/platformSetup/index.native.js @@ -1,8 +1,8 @@ import crashlytics from '@react-native-firebase/crashlytics'; -import CONFIG from '../../CONFIG'; -import PushNotification from '../../libs/Notification/PushNotification'; -import Performance from '../../libs/Performance'; -import subscribeToReportCommentPushNotifications from '../../libs/Notification/PushNotification/subscribeToReportCommentPushNotifications'; +import PushNotification from '@libs/Notification/PushNotification'; +import subscribeToReportCommentPushNotifications from '@libs/Notification/PushNotification/subscribeToReportCommentPushNotifications'; +import Performance from '@libs/Performance'; +import CONFIG from '@src/CONFIG'; export default function () { // We do not want to send crash reports if we are on a locally built release version of the app. diff --git a/src/setup/platformSetup/index.website.js b/src/setup/platformSetup/index.website.js index e859005c9abe..d26268cd94bf 100644 --- a/src/setup/platformSetup/index.website.js +++ b/src/setup/platformSetup/index.website.js @@ -1,13 +1,11 @@ import {AppRegistry} from 'react-native'; - // This is a polyfill for InternetExplorer to support the modern KeyboardEvent.key and KeyboardEvent.code instead of KeyboardEvent.keyCode import 'shim-keyboard-event-key'; - -import checkForUpdates from '../../libs/checkForUpdates'; -import Config from '../../CONFIG'; -import DateUtils from '../../libs/DateUtils'; +import checkForUpdates from '@libs/checkForUpdates'; +import DateUtils from '@libs/DateUtils'; +import Visibility from '@libs/Visibility'; +import Config from '@src/CONFIG'; import pkg from '../../../package.json'; -import Visibility from '../../libs/Visibility'; /** * Download the latest app version from the server, and if it is different than the current one, diff --git a/src/stories/AddressSearch.stories.js b/src/stories/AddressSearch.stories.js index 35f7e3a07596..8b9223bc5ea2 100644 --- a/src/stories/AddressSearch.stories.js +++ b/src/stories/AddressSearch.stories.js @@ -1,5 +1,5 @@ import React, {useState} from 'react'; -import AddressSearch from '../components/AddressSearch'; +import AddressSearch from '@components/AddressSearch'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Banner.stories.js b/src/stories/Banner.stories.js index c7c27cb52352..3a6f454843d1 100644 --- a/src/stories/Banner.stories.js +++ b/src/stories/Banner.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import Banner from '../components/Banner'; +import Banner from '@components/Banner'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Button.stories.js b/src/stories/Button.stories.js index 9fec08800f0a..2bf254b9f382 100644 --- a/src/stories/Button.stories.js +++ b/src/stories/Button.stories.js @@ -1,8 +1,8 @@ /* eslint-disable react/jsx-props-no-spreading */ import React, {useCallback, useState} from 'react'; import {View} from 'react-native'; -import Button from '../components/Button'; -import Text from '../components/Text'; +import Button from '@components/Button'; +import Text from '@components/Text'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/ButtonWithDropdownMenu.stories.js b/src/stories/ButtonWithDropdownMenu.stories.js index 88fa73c20fa1..b87bdc321d45 100644 --- a/src/stories/ButtonWithDropdownMenu.stories.js +++ b/src/stories/ButtonWithDropdownMenu.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import ButtonWithDropdownMenu from '../components/ButtonWithDropdownMenu'; +import ButtonWithDropdownMenu from '@components/ButtonWithDropdownMenu'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Checkbox.stories.js b/src/stories/Checkbox.stories.js index 4a7de2c29753..fc5b63347c71 100644 --- a/src/stories/Checkbox.stories.js +++ b/src/stories/Checkbox.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import Checkbox from '../components/Checkbox'; +import Checkbox from '@components/Checkbox'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/CheckboxWithLabel.stories.js b/src/stories/CheckboxWithLabel.stories.js index 61ec66a6b2f6..e8d45f434b16 100644 --- a/src/stories/CheckboxWithLabel.stories.js +++ b/src/stories/CheckboxWithLabel.stories.js @@ -1,7 +1,7 @@ import React from 'react'; -import CheckboxWithLabel from '../components/CheckboxWithLabel'; -import Text from '../components/Text'; -import styles from '../styles/styles'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import Text from '@components/Text'; +import styles from '@styles/styles'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Composer.stories.js b/src/stories/Composer.stories.js index 50039d7d537a..fc817ef2c86d 100644 --- a/src/stories/Composer.stories.js +++ b/src/stories/Composer.stories.js @@ -1,14 +1,14 @@ import ExpensiMark from 'expensify-common/lib/ExpensiMark'; import React, {useState} from 'react'; -import {View, Image} from 'react-native'; -import Composer from '../components/Composer'; -import RenderHTML from '../components/RenderHTML'; -import Text from '../components/Text'; -import styles from '../styles/styles'; -import themeColors from '../styles/themes/default'; -import * as StyleUtils from '../styles/StyleUtils'; -import CONST from '../CONST'; -import withNavigationFallback from '../components/withNavigationFallback'; +import {Image, View} from 'react-native'; +import Composer from '@components/Composer'; +import RenderHTML from '@components/RenderHTML'; +import Text from '@components/Text'; +import withNavigationFallback from '@components/withNavigationFallback'; +import styles from '@styles/styles'; +import * as StyleUtils from '@styles/StyleUtils'; +import themeColors from '@styles/themes/default'; +import CONST from '@src/CONST'; const ComposerWithNavigation = withNavigationFallback(Composer); diff --git a/src/stories/Datepicker.stories.js b/src/stories/Datepicker.stories.js index c4a002c6f88d..65bbec9d7f39 100644 --- a/src/stories/Datepicker.stories.js +++ b/src/stories/Datepicker.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import DatePicker from '../components/DatePicker'; +import DatePicker from '@components/DatePicker'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/DragAndDrop.stories.js b/src/stories/DragAndDrop.stories.js index eb9b6bbed6f2..c594d059b396 100644 --- a/src/stories/DragAndDrop.stories.js +++ b/src/stories/DragAndDrop.stories.js @@ -1,10 +1,10 @@ -import React, {useState} from 'react'; -import {View, Image} from 'react-native'; import lodashGet from 'lodash/get'; -import Text from '../components/Text'; -import DragAndDropProvider from '../components/DragAndDrop/Provider'; -import DragAndDropConsumer from '../components/DragAndDrop/Consumer'; -import styles from '../styles/styles'; +import React, {useState} from 'react'; +import {Image, View} from 'react-native'; +import DragAndDropConsumer from '@components/DragAndDrop/Consumer'; +import DragAndDropProvider from '@components/DragAndDrop/Provider'; +import Text from '@components/Text'; +import styles from '@styles/styles'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/EReceipt.stories.js b/src/stories/EReceipt.stories.js index 56a79e30980b..d4f2b58cb213 100644 --- a/src/stories/EReceipt.stories.js +++ b/src/stories/EReceipt.stories.js @@ -1,8 +1,8 @@ /* eslint-disable rulesdir/prefer-actions-set-data */ import React from 'react'; import Onyx from 'react-native-onyx'; -import EReceipt from '../components/EReceipt'; -import ONYXKEYS from '../ONYXKEYS'; +import EReceipt from '@components/EReceipt'; +import ONYXKEYS from '@src/ONYXKEYS'; const transactionData = { [`${ONYXKEYS.COLLECTION.TRANSACTION}FAKE_1`]: { diff --git a/src/stories/EReceiptThumbail.stories.js b/src/stories/EReceiptThumbail.stories.js index 3d8e79957172..32d9c00851ab 100644 --- a/src/stories/EReceiptThumbail.stories.js +++ b/src/stories/EReceiptThumbail.stories.js @@ -1,7 +1,7 @@ /* eslint-disable react/jsx-props-no-spreading */ import React from 'react'; import {View} from 'react-native'; -import EReceiptThumbnail from '../components/EReceiptThumbnail'; +import EReceiptThumbnail from '@components/EReceiptThumbnail'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Form.stories.js b/src/stories/Form.stories.js index 3f41edda9992..8bcbaf31b600 100644 --- a/src/stories/Form.stories.js +++ b/src/stories/Form.stories.js @@ -1,18 +1,18 @@ import React, {useState} from 'react'; import {View} from 'react-native'; -import TextInput from '../components/TextInput'; -import Picker from '../components/Picker'; -import StatePicker from '../components/StatePicker'; -import AddressSearch from '../components/AddressSearch'; -import DatePicker from '../components/DatePicker'; -import * as FormActions from '../libs/actions/FormActions'; -import styles from '../styles/styles'; -import CheckboxWithLabel from '../components/CheckboxWithLabel'; -import Text from '../components/Text'; -import NetworkConnection from '../libs/NetworkConnection'; -import CONST from '../CONST'; -import InputWrapper from '../components/Form/InputWrapper'; -import FormProvider from '../components/Form/FormProvider'; +import AddressSearch from '@components/AddressSearch'; +import CheckboxWithLabel from '@components/CheckboxWithLabel'; +import DatePicker from '@components/DatePicker'; +import FormProvider from '@components/Form/FormProvider'; +import InputWrapper from '@components/Form/InputWrapper'; +import Picker from '@components/Picker'; +import StatePicker from '@components/StatePicker'; +import Text from '@components/Text'; +import TextInput from '@components/TextInput'; +import NetworkConnection from '@libs/NetworkConnection'; +import styles from '@styles/styles'; +import * as FormActions from '@userActions/FormActions'; +import CONST from '@src/CONST'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/FormAlertWithSubmitButton.stories.js b/src/stories/FormAlertWithSubmitButton.stories.js index 5ac5404f851d..5d64deb74145 100644 --- a/src/stories/FormAlertWithSubmitButton.stories.js +++ b/src/stories/FormAlertWithSubmitButton.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import FormAlertWithSubmitButton from '../components/FormAlertWithSubmitButton'; +import FormAlertWithSubmitButton from '@components/FormAlertWithSubmitButton'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Header.stories.js b/src/stories/Header.stories.js index 78250fa2c35d..8560fba4b27f 100644 --- a/src/stories/Header.stories.js +++ b/src/stories/Header.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import Header from '../components/Header'; +import Header from '@components/Header'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/HeaderWithBackButton.stories.js b/src/stories/HeaderWithBackButton.stories.js index f7d361feb8c4..38d816b8fdd2 100644 --- a/src/stories/HeaderWithBackButton.stories.js +++ b/src/stories/HeaderWithBackButton.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import HeaderWithBackButton from '../components/HeaderWithBackButton'; +import HeaderWithBackButton from '@components/HeaderWithBackButton'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/InlineSystemMessage.stories.js b/src/stories/InlineSystemMessage.stories.js index 9a4b034ae35b..b7fe21c8b10e 100644 --- a/src/stories/InlineSystemMessage.stories.js +++ b/src/stories/InlineSystemMessage.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import InlineSystemMessage from '../components/InlineSystemMessage'; +import InlineSystemMessage from '@components/InlineSystemMessage'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/MagicCodeInput.stories.js b/src/stories/MagicCodeInput.stories.js index 1ea746dd44ac..14b234996ce1 100644 --- a/src/stories/MagicCodeInput.stories.js +++ b/src/stories/MagicCodeInput.stories.js @@ -1,5 +1,5 @@ import React, {useState} from 'react'; -import MagicCodeInput from '../components/MagicCodeInput'; +import MagicCodeInput from '@components/MagicCodeInput'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/MenuItem.stories.js b/src/stories/MenuItem.stories.js index 7046617fe2ae..47b74b1f0ef8 100644 --- a/src/stories/MenuItem.stories.js +++ b/src/stories/MenuItem.stories.js @@ -1,7 +1,7 @@ import React from 'react'; -import MenuItem from '../components/MenuItem'; -import Chase from '../../assets/images/bankicons/chase.svg'; -import variables from '../styles/variables'; +import Chase from '@assets/images/bankicons/chase.svg'; +import MenuItem from '@components/MenuItem'; +import variables from '@styles/variables'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/OptionRow.stories.js b/src/stories/OptionRow.stories.js index d5ad27f2d939..3096940dda5f 100644 --- a/src/stories/OptionRow.stories.js +++ b/src/stories/OptionRow.stories.js @@ -1,7 +1,8 @@ import React from 'react'; -import OptionRow from '../components/OptionRow'; -import * as Expensicons from '../components/Icon/Expensicons'; -import OnyxProvider from '../components/OnyxProvider'; +import * as Expensicons from '@components/Icon/Expensicons'; +import OnyxProvider from '@components/OnyxProvider'; +import OptionRow from '@components/OptionRow'; + /* eslint-disable react/jsx-props-no-spreading */ /** diff --git a/src/stories/Picker.stories.js b/src/stories/Picker.stories.js index 19b04f9fa79a..b42cfed8f471 100644 --- a/src/stories/Picker.stories.js +++ b/src/stories/Picker.stories.js @@ -1,5 +1,5 @@ import React, {useState} from 'react'; -import Picker from '../components/Picker'; +import Picker from '@components/Picker'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/PopoverMenu.stories.js b/src/stories/PopoverMenu.stories.js index 5f8fb8994e1f..b860a8343309 100644 --- a/src/stories/PopoverMenu.stories.js +++ b/src/stories/PopoverMenu.stories.js @@ -1,9 +1,9 @@ import React from 'react'; import {SafeAreaProvider} from 'react-native-safe-area-context'; -import PopoverMenu from '../components/PopoverMenu'; -import * as Expensicons from '../components/Icon/Expensicons'; -import MenuItem from '../components/MenuItem'; -import themeColors from '../styles/themes/default'; +import * as Expensicons from '@components/Icon/Expensicons'; +import MenuItem from '@components/MenuItem'; +import PopoverMenu from '@components/PopoverMenu'; +import themeColors from '@styles/themes/default'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/ReportActionItemImages.stories.js b/src/stories/ReportActionItemImages.stories.js index b776d9261e60..fe86f50f7e34 100644 --- a/src/stories/ReportActionItemImages.stories.js +++ b/src/stories/ReportActionItemImages.stories.js @@ -1,6 +1,6 @@ import React from 'react'; -import ReportActionItemImages from '../components/ReportActionItem/ReportActionItemImages'; -import PressableWithoutFeedback from '../components/Pressable/PressableWithoutFeedback'; +import PressableWithoutFeedback from '@components/Pressable/PressableWithoutFeedback'; +import ReportActionItemImages from '@components/ReportActionItem/ReportActionItemImages'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/SelectionList.stories.js b/src/stories/SelectionList.stories.js index c4510611306e..28880e1b00d7 100644 --- a/src/stories/SelectionList.stories.js +++ b/src/stories/SelectionList.stories.js @@ -1,10 +1,10 @@ import React, {useMemo, useState} from 'react'; -import _ from 'underscore'; import {View} from 'react-native'; -import SelectionList from '../components/SelectionList'; -import CONST from '../CONST'; -import styles from '../styles/styles'; -import Text from '../components/Text'; +import _ from 'underscore'; +import SelectionList from '@components/SelectionList'; +import Text from '@components/Text'; +import styles from '@styles/styles'; +import CONST from '@src/CONST'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/SubscriptAvatar.stories.js b/src/stories/SubscriptAvatar.stories.js index 08941bd9c19a..9ca055aaa5d8 100644 --- a/src/stories/SubscriptAvatar.stories.js +++ b/src/stories/SubscriptAvatar.stories.js @@ -1,8 +1,8 @@ import React from 'react'; -import SubscriptAvatar from '../components/SubscriptAvatar'; -import * as defaultWorkspaceAvatars from '../components/Icon/WorkspaceDefaultAvatars'; -import * as defaultAvatars from '../components/Icon/DefaultAvatars'; -import CONST from '../CONST'; +import * as defaultAvatars from '@components/Icon/DefaultAvatars'; +import * as defaultWorkspaceAvatars from '@components/Icon/WorkspaceDefaultAvatars'; +import SubscriptAvatar from '@components/SubscriptAvatar'; +import CONST from '@src/CONST'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/TextInput.stories.js b/src/stories/TextInput.stories.js index 098828c65198..dd2fcced68b0 100644 --- a/src/stories/TextInput.stories.js +++ b/src/stories/TextInput.stories.js @@ -1,5 +1,5 @@ import React, {useState} from 'react'; -import TextInput from '../components/TextInput'; +import TextInput from '@components/TextInput'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/stories/Tooltip.stories.js b/src/stories/Tooltip.stories.js index e88c48fcf202..900cd6dedd76 100644 --- a/src/stories/Tooltip.stories.js +++ b/src/stories/Tooltip.stories.js @@ -1,5 +1,5 @@ import React from 'react'; -import Tooltip from '../components/Tooltip'; +import Tooltip from '@components/Tooltip'; /** * We use the Component Story Format for writing stories. Follow the docs here: diff --git a/src/styles/StyleUtils.ts b/src/styles/StyleUtils.ts index 48100b2efb60..f58d2c9a236d 100644 --- a/src/styles/StyleUtils.ts +++ b/src/styles/StyleUtils.ts @@ -2,9 +2,10 @@ import {CSSProperties} from 'react'; import {Animated, DimensionValue, ImageStyle, PressableStateCallbackType, TextStyle, ViewStyle} from 'react-native'; import {EdgeInsets} from 'react-native-safe-area-context'; import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; -import * as Browser from '../libs/Browser'; -import * as UserUtils from '../libs/UserUtils'; +import * as Browser from '@libs/Browser'; +import * as UserUtils from '@libs/UserUtils'; +import CONST from '@src/CONST'; +import {Transaction} from '@src/types/onyx'; import colors from './colors'; import fontFamily from './fontFamily'; import styles from './styles'; @@ -13,7 +14,6 @@ import cursor from './utilities/cursor'; import positioning from './utilities/positioning'; import spacing from './utilities/spacing'; import variables from './variables'; -import {Transaction} from '../types/onyx'; type AllStyles = ViewStyle | TextStyle | ImageStyle; type ParsableStyle = AllStyles | ((state: PressableStateCallbackType) => AllStyles); diff --git a/src/styles/ThemeStylesProvider.tsx b/src/styles/ThemeStylesProvider.tsx index 4e6f91baf34a..25ce1f58b65e 100644 --- a/src/styles/ThemeStylesProvider.tsx +++ b/src/styles/ThemeStylesProvider.tsx @@ -1,9 +1,9 @@ /* eslint-disable react/jsx-props-no-spreading */ import React, {useMemo} from 'react'; -import useTheme from './themes/useTheme'; -import ThemeStylesContext from './ThemeStylesContext'; // TODO: Rename this to "styles" once the app is migrated to theme switching hooks and HOCs import {stylesGenerator as stylesUntyped} from './styles'; +import useTheme from './themes/useTheme'; +import ThemeStylesContext from './ThemeStylesContext'; const styles = stylesUntyped; diff --git a/src/styles/addOutlineWidth/index.native.ts b/src/styles/addOutlineWidth/index.native.ts index 69e2ffaf3a5b..4384a3f811e2 100644 --- a/src/styles/addOutlineWidth/index.native.ts +++ b/src/styles/addOutlineWidth/index.native.ts @@ -2,7 +2,6 @@ * Native platforms don't support the "addOutlineWidth" property, so this * function is a no-op */ - import AddOutlineWidth from './types'; const addOutlineWidth: AddOutlineWidth = (obj) => obj; diff --git a/src/styles/addOutlineWidth/index.ts b/src/styles/addOutlineWidth/index.ts index 6fe2ecf85978..5d99e369b79a 100644 --- a/src/styles/addOutlineWidth/index.ts +++ b/src/styles/addOutlineWidth/index.ts @@ -2,8 +2,7 @@ * Web and desktop platforms support the "addOutlineWidth" property, so it * can be added to the object */ - -import themeDefault from '../themes/default'; +import themeDefault from '@styles/themes/default'; import AddOutlineWidth from './types'; /** diff --git a/src/styles/animation/SpinningIndicatorAnimation.js b/src/styles/animation/SpinningIndicatorAnimation.js index 29044f0d127a..1ae4b1518325 100644 --- a/src/styles/animation/SpinningIndicatorAnimation.js +++ b/src/styles/animation/SpinningIndicatorAnimation.js @@ -1,5 +1,5 @@ import {Animated, Easing} from 'react-native'; -import useNativeDriver from '../../libs/useNativeDriver'; +import useNativeDriver from '@libs/useNativeDriver'; class SpinningIndicatorAnimation { constructor() { diff --git a/src/styles/cardStyles/index.ts b/src/styles/cardStyles/index.ts index 1f28ca4f4b78..b5d3c069b73a 100644 --- a/src/styles/cardStyles/index.ts +++ b/src/styles/cardStyles/index.ts @@ -1,4 +1,4 @@ -import positioning from '../utilities/positioning'; +import positioning from '@styles/utilities/positioning'; import GetCardStyles from './types'; /** diff --git a/src/styles/containerComposeStyles/index.native.ts b/src/styles/containerComposeStyles/index.native.ts index ea525dc652cf..9e1398b8176f 100644 --- a/src/styles/containerComposeStyles/index.native.ts +++ b/src/styles/containerComposeStyles/index.native.ts @@ -1,4 +1,4 @@ -import styles from '../styles'; +import styles from '@styles/styles'; import ContainerComposeStyles from './types'; const containerComposeStyles: ContainerComposeStyles = [styles.textInputComposeSpacing]; diff --git a/src/styles/containerComposeStyles/index.ts b/src/styles/containerComposeStyles/index.ts index fbbf35a20818..0e40adda571e 100644 --- a/src/styles/containerComposeStyles/index.ts +++ b/src/styles/containerComposeStyles/index.ts @@ -1,4 +1,4 @@ -import styles from '../styles'; +import styles from '@styles/styles'; import ContainerComposeStyles from './types'; // We need to set paddingVertical = 0 on web to avoid displaying a normal pointer on some parts of compose box when not in focus diff --git a/src/styles/editedLabelStyles/index.ts b/src/styles/editedLabelStyles/index.ts index 5764735d0dea..339c50d8a4df 100644 --- a/src/styles/editedLabelStyles/index.ts +++ b/src/styles/editedLabelStyles/index.ts @@ -1,5 +1,5 @@ -import display from '../utilities/display'; -import flex from '../utilities/flex'; +import display from '@styles/utilities/display'; +import flex from '@styles/utilities/flex'; import EditedLabelStyles from './types'; const editedLabelStyles: EditedLabelStyles = { diff --git a/src/styles/getContextMenuItemStyles/index.js b/src/styles/getContextMenuItemStyles/index.js index 17f4b82f1290..4116ac75ce05 100644 --- a/src/styles/getContextMenuItemStyles/index.js +++ b/src/styles/getContextMenuItemStyles/index.js @@ -1,5 +1,5 @@ -import styles from '../styles'; -import variables from '../variables'; +import styles from '@styles/styles'; +import variables from '@styles/variables'; export default (windowWidth) => { if (windowWidth > variables.mobileResponsiveWidthBreakpoint) { diff --git a/src/styles/getContextMenuItemStyles/index.native.js b/src/styles/getContextMenuItemStyles/index.native.js index aa7ed19a88d7..cbb048a68d2f 100644 --- a/src/styles/getContextMenuItemStyles/index.native.js +++ b/src/styles/getContextMenuItemStyles/index.native.js @@ -1,3 +1,3 @@ -import styles from '../styles'; +import styles from '@styles/styles'; export default () => [styles.popoverMenuItem]; diff --git a/src/styles/getModalStyles.ts b/src/styles/getModalStyles.ts index d52d29568c2d..55f822693b3e 100644 --- a/src/styles/getModalStyles.ts +++ b/src/styles/getModalStyles.ts @@ -1,7 +1,7 @@ import {ViewStyle} from 'react-native'; import {ModalProps} from 'react-native-modal'; import {ValueOf} from 'type-fest'; -import CONST from '../CONST'; +import CONST from '@src/CONST'; import styles from './styles'; import themeColors from './themes/default'; import variables from './variables'; diff --git a/src/styles/getNavigationModalCardStyles/index.desktop.ts b/src/styles/getNavigationModalCardStyles/index.desktop.ts index 75b5636f9bd8..9e182636ad76 100644 --- a/src/styles/getNavigationModalCardStyles/index.desktop.ts +++ b/src/styles/getNavigationModalCardStyles/index.desktop.ts @@ -1,4 +1,4 @@ -import positioning from '../utilities/positioning'; +import positioning from '@styles/utilities/positioning'; import GetNavigationModalCardStyles from './types'; const getNavigationModalCardStyles: GetNavigationModalCardStyles = () => ({ diff --git a/src/styles/getNavigationModalCardStyles/index.website.ts b/src/styles/getNavigationModalCardStyles/index.website.ts index 75b5636f9bd8..9e182636ad76 100644 --- a/src/styles/getNavigationModalCardStyles/index.website.ts +++ b/src/styles/getNavigationModalCardStyles/index.website.ts @@ -1,4 +1,4 @@ -import positioning from '../utilities/positioning'; +import positioning from '@styles/utilities/positioning'; import GetNavigationModalCardStyles from './types'; const getNavigationModalCardStyles: GetNavigationModalCardStyles = () => ({ diff --git a/src/styles/getPopOverVerticalOffset/index.desktop.ts b/src/styles/getPopOverVerticalOffset/index.desktop.ts index d7c02f95b169..3caab6057a4b 100644 --- a/src/styles/getPopOverVerticalOffset/index.desktop.ts +++ b/src/styles/getPopOverVerticalOffset/index.desktop.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import GetPopOverVerticalOffset from './types'; /** Adds the header padding with vertical offset on desktop */ diff --git a/src/styles/optionRowStyles/index.native.ts b/src/styles/optionRowStyles/index.native.ts index 9c13fdd082a4..6198def8219a 100644 --- a/src/styles/optionRowStyles/index.native.ts +++ b/src/styles/optionRowStyles/index.native.ts @@ -1,4 +1,4 @@ -import styles from '../styles'; +import styles from '@styles/styles'; import CompactContentContainerStyles from './types'; /** diff --git a/src/styles/optionRowStyles/index.ts b/src/styles/optionRowStyles/index.ts index 975f4243842e..d0351be24553 100644 --- a/src/styles/optionRowStyles/index.ts +++ b/src/styles/optionRowStyles/index.ts @@ -1,5 +1,5 @@ +import styles from '@styles/styles'; import CompactContentContainerStyles from './types'; -import styles from '../styles'; const compactContentContainerStyles: CompactContentContainerStyles = styles.alignItemsBaseline; diff --git a/src/styles/styles.ts b/src/styles/styles.ts index c5946801abd7..589c3756042f 100644 --- a/src/styles/styles.ts +++ b/src/styles/styles.ts @@ -6,10 +6,11 @@ import {AnimatableNumericValue, Animated, ImageStyle, TextStyle, ViewStyle} from import {CustomAnimation} from 'react-native-animatable'; import {PickerStyle} from 'react-native-picker-select'; import {MixedStyleDeclaration, MixedStyleRecord} from 'react-native-render-html'; -import CONST from '../CONST'; -import * as Browser from '../libs/Browser'; +import * as Browser from '@libs/Browser'; +import CONST from '@src/CONST'; import addOutlineWidth from './addOutlineWidth'; import codeStyles from './codeStyles'; +import colors from './colors'; import fontFamily from './fontFamily'; import fontWeightBold from './fontWeight/bold'; import getPopOverVerticalOffset from './getPopOverVerticalOffset'; @@ -19,14 +20,16 @@ import pointerEventsAuto from './pointerEventsAuto'; import pointerEventsNone from './pointerEventsNone'; import defaultTheme from './themes/default'; import {ThemeDefault} from './themes/types'; +import borders from './utilities/borders'; import cursor from './utilities/cursor'; import display from './utilities/display'; import flex from './utilities/flex'; +import objectFit from './utilities/objectFit'; import overflow from './utilities/overflow'; import positioning from './utilities/positioning'; import sizing from './utilities/sizing'; import spacing from './utilities/spacing'; -import borders from './utilities/borders'; +import textDecorationLine from './utilities/textDecorationLine'; import textUnderline from './utilities/textUnderline'; import userSelect from './utilities/userSelect'; import visibility from './utilities/visibility'; @@ -34,9 +37,6 @@ import whiteSpace from './utilities/whiteSpace'; import wordBreak from './utilities/wordBreak'; import writingDirection from './utilities/writingDirection'; import variables from './variables'; -import colors from './colors'; -import objectFit from './utilities/objectFit'; -import textDecorationLine from './utilities/textDecorationLine'; type AnchorPosition = { horizontal: number; diff --git a/src/styles/themes/ThemeProvider.js b/src/styles/themes/ThemeProvider.js index f4601712a0bc..58d0baedbe06 100644 --- a/src/styles/themes/ThemeProvider.js +++ b/src/styles/themes/ThemeProvider.js @@ -1,12 +1,11 @@ /* eslint-disable react/jsx-props-no-spreading */ -import React, {useMemo} from 'react'; import PropTypes from 'prop-types'; -import ThemeContext from './ThemeContext'; -import useThemePreference from './useThemePreference'; -import CONST from '../../CONST'; - +import React, {useMemo} from 'react'; +import CONST from '@src/CONST'; // Going to eventually import the light theme here too import darkTheme from './default'; +import ThemeContext from './ThemeContext'; +import useThemePreference from './useThemePreference'; const propTypes = { /** Rendered child component */ diff --git a/src/styles/themes/default.ts b/src/styles/themes/default.ts index b46a7aea97c6..98ff8773fb51 100644 --- a/src/styles/themes/default.ts +++ b/src/styles/themes/default.ts @@ -1,5 +1,5 @@ -import SCREENS from '../../SCREENS'; -import colors from '../colors'; +import colors from '@styles/colors'; +import SCREENS from '@src/SCREENS'; import type {ThemeBase} from './types'; const darkTheme = { diff --git a/src/styles/themes/light.ts b/src/styles/themes/light.ts index 6e8a89a7b9d2..624c7df0caa8 100644 --- a/src/styles/themes/light.ts +++ b/src/styles/themes/light.ts @@ -1,5 +1,5 @@ -import SCREENS from '../../SCREENS'; -import colors from '../colors'; +import colors from '@styles/colors'; +import SCREENS from '@src/SCREENS'; import type {ThemeDefault} from './types'; const lightTheme = { diff --git a/src/styles/themes/types.ts b/src/styles/themes/types.ts index 40b8da361654..59e8001d29fe 100644 --- a/src/styles/themes/types.ts +++ b/src/styles/themes/types.ts @@ -1,4 +1,4 @@ -import DeepRecord from '../../types/utils/DeepRecord'; +import DeepRecord from '@src/types/utils/DeepRecord'; import defaultTheme from './default'; type ThemeBase = DeepRecord; diff --git a/src/styles/themes/useThemePreference.js b/src/styles/themes/useThemePreference.js index 579e9dc97c69..8c26ad931d6d 100644 --- a/src/styles/themes/useThemePreference.js +++ b/src/styles/themes/useThemePreference.js @@ -1,7 +1,7 @@ -import {useState, useEffect, useContext} from 'react'; +import {useContext, useEffect, useState} from 'react'; import {Appearance} from 'react-native'; -import CONST from '../../CONST'; -import {PreferredThemeContext} from '../../components/OnyxProvider'; +import {PreferredThemeContext} from '@components/OnyxProvider'; +import CONST from '@src/CONST'; function useThemePreference() { const [themePreference, setThemePreference] = useState(CONST.THEME.DEFAULT); diff --git a/src/styles/utilities/writingDirection.ts b/src/styles/utilities/writingDirection.ts index 1d9a32122373..f3f249796047 100644 --- a/src/styles/utilities/writingDirection.ts +++ b/src/styles/utilities/writingDirection.ts @@ -1,4 +1,5 @@ import {TextStyle} from 'react-native'; + /** * Writing direction utility styles. * Note: writingDirection isn't supported on Android. Unicode controls are being used for Android diff --git a/src/types/modules/react-native-key-command.d.ts b/src/types/modules/react-native-key-command.d.ts index 6af989e33814..5cac93f2a90b 100644 --- a/src/types/modules/react-native-key-command.d.ts +++ b/src/types/modules/react-native-key-command.d.ts @@ -1,29 +1,31 @@ +/* eslint-disable @typescript-eslint/naming-convention */ declare module 'react-native-key-command' { - declare const constants = { - keyInputDownArrow: 'keyInputDownArrow', - keyInputEscape: 'keyInputEscape', - keyInputLeftArrow: 'keyInputLeftArrow', - keyInputRightArrow: 'keyInputRightArrow', - keyInputUpArrow: 'keyInputUpArrow', - keyInputEnter: 'keyInputEnter', - keyModifierCapsLock: 'keyModifierCapsLock', - keyModifierCommand: 'keyModifierCommand', - keyModifierControl: 'keyModifierControl', - keyModifierControlCommand: 'keyModifierControlCommand', - keyModifierControlOption: 'keyModifierControlOption', - keyModifierControlOptionCommand: 'keyModifierControlOptionCommand', - keyModifierNumericPad: 'keyModifierNumericPad', - keyModifierOption: 'keyModifierOption', - keyModifierOptionCommand: 'keyModifierOptionCommand', - keyModifierShift: 'keyModifierShift', - keyModifierShiftCommand: 'keyModifierShiftCommand', - keyModifierShiftControl: 'keyModifierShiftControl', - keyModifierAlternate: 'keyModifierAlternate', - } as const; + // eslint-disable-next-line no-restricted-syntax + enum constants { + keyInputDownArrow = 'keyInputDownArrow', + keyInputEscape = 'keyInputEscape', + keyInputLeftArrow = 'keyInputLeftArrow', + keyInputRightArrow = 'keyInputRightArrow', + keyInputUpArrow = 'keyInputUpArrow', + keyInputEnter = 'keyInputEnter', + keyModifierCapsLock = 'keyModifierCapsLock', + keyModifierCommand = 'keyModifierCommand', + keyModifierControl = 'keyModifierControl', + keyModifierControlCommand = 'keyModifierControlCommand', + keyModifierControlOption = 'keyModifierControlOption', + keyModifierControlOptionCommand = 'keyModifierControlOptionCommand', + keyModifierNumericPad = 'keyModifierNumericPad', + keyModifierOption = 'keyModifierOption', + keyModifierOptionCommand = 'keyModifierOptionCommand', + keyModifierShift = 'keyModifierShift', + keyModifierShiftCommand = 'keyModifierShiftCommand', + keyModifierShiftControl = 'keyModifierShiftControl', + keyModifierAlternate = 'keyModifierAlternate', + } - type KeyCommandEvent = {input: string; modifierFlags?: string}; + type KeyCommand = {input: string; modifierFlags: string}; - declare function addListener(keyCommand: KeyCommandEvent, callback: (keyCommandEvent: KeyCommand, event: KeyboardEvent) => void): () => void; + declare function addListener(keyCommand: KeyCommand, callback: (keycommandEvent: KeyCommand, event: Event) => void): () => void; // eslint-disable-next-line import/prefer-default-export export {constants, addListener}; diff --git a/src/types/modules/react-native-onyx.d.ts b/src/types/modules/react-native-onyx.d.ts index 4979f8fd0dbb..d603b9f93ae8 100644 --- a/src/types/modules/react-native-onyx.d.ts +++ b/src/types/modules/react-native-onyx.d.ts @@ -1,4 +1,4 @@ -import {OnyxKey, OnyxCollectionKey, OnyxValues} from '../../ONYXKEYS'; +import {OnyxCollectionKey, OnyxKey, OnyxValues} from '@src/ONYXKEYS'; declare module 'react-native-onyx' { // eslint-disable-next-line @typescript-eslint/consistent-type-definitions diff --git a/src/types/modules/react-native.d.ts b/src/types/modules/react-native.d.ts index 0659cc4e4b4a..a816fc77625b 100644 --- a/src/types/modules/react-native.d.ts +++ b/src/types/modules/react-native.d.ts @@ -1,9 +1,11 @@ /* eslint-disable @typescript-eslint/naming-convention */ + /* eslint-disable @typescript-eslint/no-empty-interface */ + /* eslint-disable @typescript-eslint/consistent-type-definitions */ import {CSSProperties, FocusEventHandler, KeyboardEventHandler, MouseEventHandler, PointerEventHandler, UIEventHandler, WheelEventHandler} from 'react'; import 'react-native'; -import {BootSplashModule} from '../../libs/BootSplash/types'; +import {BootSplashModule} from '@libs/BootSplash/types'; declare module 'react-native' { // <------ REACT NATIVE WEB (0.19.0) ------> diff --git a/src/types/onyx/Account.ts b/src/types/onyx/Account.ts index 85b0c2359702..c338924bae55 100644 --- a/src/types/onyx/Account.ts +++ b/src/types/onyx/Account.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type TwoFactorAuthStep = ValueOf | ''; diff --git a/src/types/onyx/BankAccount.ts b/src/types/onyx/BankAccount.ts index 58d9654f0c6f..4a7b6dac7387 100644 --- a/src/types/onyx/BankAccount.ts +++ b/src/types/onyx/BankAccount.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import AccountData from './AccountData'; import * as OnyxCommon from './OnyxCommon'; diff --git a/src/types/onyx/Beta.ts b/src/types/onyx/Beta.ts index d40d05a9ed3d..9216946499e8 100644 --- a/src/types/onyx/Beta.ts +++ b/src/types/onyx/Beta.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; type Beta = ValueOf; diff --git a/src/types/onyx/Card.ts b/src/types/onyx/Card.ts index 395515c1ca08..ae4e86212a00 100644 --- a/src/types/onyx/Card.ts +++ b/src/types/onyx/Card.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type Card = { diff --git a/src/types/onyx/Fund.ts b/src/types/onyx/Fund.ts index e27cc0e20e0e..4e6cbc695a8d 100644 --- a/src/types/onyx/Fund.ts +++ b/src/types/onyx/Fund.ts @@ -1,4 +1,4 @@ -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type AdditionalData = { diff --git a/src/types/onyx/OnyxCommon.ts b/src/types/onyx/OnyxCommon.ts index db82edcb98ff..bafd5e8cbbf0 100644 --- a/src/types/onyx/OnyxCommon.ts +++ b/src/types/onyx/OnyxCommon.ts @@ -1,6 +1,6 @@ -import {ValueOf} from 'type-fest'; import * as React from 'react'; -import CONST from '../../CONST'; +import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; type PendingAction = ValueOf; diff --git a/src/types/onyx/OriginalMessage.ts b/src/types/onyx/OriginalMessage.ts index cd2bf1bbbe42..014cd67a9a2a 100644 --- a/src/types/onyx/OriginalMessage.ts +++ b/src/types/onyx/OriginalMessage.ts @@ -1,6 +1,6 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; -import DeepValueOf from '../utils/DeepValueOf'; +import CONST from '@src/CONST'; +import DeepValueOf from '@src/types/utils/DeepValueOf'; type ActionName = DeepValueOf; diff --git a/src/types/onyx/PaymentMethod.ts b/src/types/onyx/PaymentMethod.ts index 85f3655f49e8..4a9722911bf9 100644 --- a/src/types/onyx/PaymentMethod.ts +++ b/src/types/onyx/PaymentMethod.ts @@ -1,6 +1,6 @@ -import {SvgProps} from 'react-native-svg'; import {CSSProperties} from 'react'; import {ViewStyle} from 'react-native'; +import {SvgProps} from 'react-native-svg'; import BankAccount from './BankAccount'; import Fund from './Fund'; diff --git a/src/types/onyx/PlaidData.ts b/src/types/onyx/PlaidData.ts index a4a6d8e6fe8c..28a1cb324bcb 100644 --- a/src/types/onyx/PlaidData.ts +++ b/src/types/onyx/PlaidData.ts @@ -1,5 +1,5 @@ -import PlaidBankAccount from './PlaidBankAccount'; import * as OnyxCommon from './OnyxCommon'; +import PlaidBankAccount from './PlaidBankAccount'; type PlaidData = { /** Name of the bank */ diff --git a/src/types/onyx/Policy.ts b/src/types/onyx/Policy.ts index e4d77b150a7c..6b115bf0609f 100644 --- a/src/types/onyx/Policy.ts +++ b/src/types/onyx/Policy.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type Policy = { diff --git a/src/types/onyx/ReimbursementAccount.ts b/src/types/onyx/ReimbursementAccount.ts index fc46c9aa3132..75954983371e 100644 --- a/src/types/onyx/ReimbursementAccount.ts +++ b/src/types/onyx/ReimbursementAccount.ts @@ -1,6 +1,6 @@ import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; -import CONST from '../../CONST'; type BankAccountStep = ValueOf; diff --git a/src/types/onyx/Report.ts b/src/types/onyx/Report.ts index 494661b2fb89..6fe9b5fd5099 100644 --- a/src/types/onyx/Report.ts +++ b/src/types/onyx/Report.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type Report = { diff --git a/src/types/onyx/Session.ts b/src/types/onyx/Session.ts index 606723f17b82..faaa493b1286 100644 --- a/src/types/onyx/Session.ts +++ b/src/types/onyx/Session.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type AutoAuthState = ValueOf; diff --git a/src/types/onyx/Transaction.ts b/src/types/onyx/Transaction.ts index d0f17cc2cf01..de5f2eec9f9d 100644 --- a/src/types/onyx/Transaction.ts +++ b/src/types/onyx/Transaction.ts @@ -1,6 +1,6 @@ import {ValueOf} from 'type-fest'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; -import CONST from '../../CONST'; import RecentWaypoint from './RecentWaypoint'; type Waypoint = { diff --git a/src/types/onyx/UserWallet.ts b/src/types/onyx/UserWallet.ts index aae662f62b6f..501e05a31ad0 100644 --- a/src/types/onyx/UserWallet.ts +++ b/src/types/onyx/UserWallet.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; type WalletLinkedAccountType = 'debitCard' | 'bankAccount'; diff --git a/src/types/onyx/WalletTransfer.ts b/src/types/onyx/WalletTransfer.ts index 18b223a0b1ef..e1b1468d6536 100644 --- a/src/types/onyx/WalletTransfer.ts +++ b/src/types/onyx/WalletTransfer.ts @@ -1,5 +1,5 @@ import {ValueOf} from 'type-fest'; -import CONST from '../../CONST'; +import CONST from '@src/CONST'; import * as OnyxCommon from './OnyxCommon'; import PaymentMethod from './PaymentMethod'; diff --git a/src/types/onyx/index.ts b/src/types/onyx/index.ts index b64c1268086e..93a19b39aad3 100644 --- a/src/types/onyx/index.ts +++ b/src/types/onyx/index.ts @@ -1,53 +1,53 @@ import Account from './Account'; -import Request from './Request'; +import AccountData from './AccountData'; +import BankAccount from './BankAccount'; +import Beta from './Beta'; +import BlockedFromConcierge from './BlockedFromConcierge'; +import Card from './Card'; import Credentials from './Credentials'; +import Currency from './Currency'; +import CustomStatusDraft from './CustomStatusDraft'; +import Download from './Download'; +import Form, {AddDebitCardForm} from './Form'; +import FrequentlyUsedEmoji from './FrequentlyUsedEmoji'; +import Fund from './Fund'; import IOU from './IOU'; +import Login from './Login'; +import MapboxAccessToken from './MapboxAccessToken'; import Modal from './Modal'; import Network from './Network'; -import CustomStatusDraft from './CustomStatusDraft'; +import {OnyxUpdateEvent, OnyxUpdatesFromServer} from './OnyxUpdatesFromServer'; +import PersonalBankAccount from './PersonalBankAccount'; import PersonalDetails from './PersonalDetails'; -import PrivatePersonalDetails from './PrivatePersonalDetails'; -import Task from './Task'; -import Currency from './Currency'; -import ScreenShareRequest from './ScreenShareRequest'; -import User from './User'; -import Login from './Login'; -import Session from './Session'; -import Beta from './Beta'; -import BlockedFromConcierge from './BlockedFromConcierge'; import PlaidData from './PlaidData'; -import UserWallet from './UserWallet'; -import WalletOnfido from './WalletOnfido'; -import WalletAdditionalDetails from './WalletAdditionalDetails'; -import WalletTerms from './WalletTerms'; -import BankAccount from './BankAccount'; -import Card from './Card'; -import Fund from './Fund'; -import WalletStatement from './WalletStatement'; -import PersonalBankAccount from './PersonalBankAccount'; -import FrequentlyUsedEmoji from './FrequentlyUsedEmoji'; -import ReimbursementAccount from './ReimbursementAccount'; -import ReimbursementAccountDraft from './ReimbursementAccountDraft'; -import WalletTransfer from './WalletTransfer'; -import MapboxAccessToken from './MapboxAccessToken'; -import {OnyxUpdatesFromServer, OnyxUpdateEvent} from './OnyxUpdatesFromServer'; -import Download from './Download'; -import PolicyMember, {PolicyMembers} from './PolicyMember'; import Policy from './Policy'; import PolicyCategory from './PolicyCategory'; +import PolicyMember, {PolicyMembers} from './PolicyMember'; +import PolicyTag, {PolicyTags} from './PolicyTag'; +import PrivatePersonalDetails from './PrivatePersonalDetails'; +import RecentlyUsedCategories from './RecentlyUsedCategories'; +import RecentlyUsedTags from './RecentlyUsedTags'; +import RecentWaypoint from './RecentWaypoint'; +import ReimbursementAccount from './ReimbursementAccount'; +import ReimbursementAccountDraft from './ReimbursementAccountDraft'; import Report from './Report'; -import ReportMetadata from './ReportMetadata'; import ReportAction, {ReportActions} from './ReportAction'; -import ReportActionsDrafts from './ReportActionsDrafts'; import ReportActionReactions from './ReportActionReactions'; +import ReportActionsDrafts from './ReportActionsDrafts'; +import ReportMetadata from './ReportMetadata'; +import Request from './Request'; +import ScreenShareRequest from './ScreenShareRequest'; import SecurityGroup from './SecurityGroup'; +import Session from './Session'; +import Task from './Task'; import Transaction from './Transaction'; -import Form, {AddDebitCardForm} from './Form'; -import RecentWaypoint from './RecentWaypoint'; -import RecentlyUsedCategories from './RecentlyUsedCategories'; -import RecentlyUsedTags from './RecentlyUsedTags'; -import PolicyTag, {PolicyTags} from './PolicyTag'; -import AccountData from './AccountData'; +import User from './User'; +import UserWallet from './UserWallet'; +import WalletAdditionalDetails from './WalletAdditionalDetails'; +import WalletOnfido from './WalletOnfido'; +import WalletStatement from './WalletStatement'; +import WalletTerms from './WalletTerms'; +import WalletTransfer from './WalletTransfer'; export type { Account, diff --git a/tests/actions/IOUTest.js b/tests/actions/IOUTest.js index 7b780802e9b8..2c6b94a2d7d5 100644 --- a/tests/actions/IOUTest.js +++ b/tests/actions/IOUTest.js @@ -1,24 +1,24 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; +import _ from 'underscore'; import CONST from '../../src/CONST'; -import ONYXKEYS from '../../src/ONYXKEYS'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import * as IOU from '../../src/libs/actions/IOU'; -import * as TestHelper from '../utils/TestHelper'; -import DateUtils from '../../src/libs/DateUtils'; -import * as NumberUtils from '../../src/libs/NumberUtils'; -import * as ReportActions from '../../src/libs/actions/ReportActions'; -import * as ReportUtils from '../../src/libs/ReportUtils'; -import * as Report from '../../src/libs/actions/Report'; import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; -import waitForNetworkPromises from '../utils/waitForNetworkPromises'; -import * as ReportActionsUtils from '../../src/libs/ReportActionsUtils'; import * as PolicyActions from '../../src/libs/actions/Policy'; -import * as PersonalDetailsUtils from '../../src/libs/PersonalDetailsUtils'; +import * as Report from '../../src/libs/actions/Report'; +import * as ReportActions from '../../src/libs/actions/ReportActions'; import * as User from '../../src/libs/actions/User'; -import PusherHelper from '../utils/PusherHelper'; +import DateUtils from '../../src/libs/DateUtils'; import Navigation from '../../src/libs/Navigation/Navigation'; +import * as NumberUtils from '../../src/libs/NumberUtils'; +import * as PersonalDetailsUtils from '../../src/libs/PersonalDetailsUtils'; +import * as ReportActionsUtils from '../../src/libs/ReportActionsUtils'; +import * as ReportUtils from '../../src/libs/ReportUtils'; +import ONYXKEYS from '../../src/ONYXKEYS'; import ROUTES from '../../src/ROUTES'; +import PusherHelper from '../utils/PusherHelper'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import waitForNetworkPromises from '../utils/waitForNetworkPromises'; jest.mock('../../src/libs/Navigation/Navigation', () => ({ navigate: jest.fn(), diff --git a/tests/actions/ReportTest.js b/tests/actions/ReportTest.js index 025c226b3fb8..a94db507637b 100644 --- a/tests/actions/ReportTest.js +++ b/tests/actions/ReportTest.js @@ -1,23 +1,23 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; -import lodashGet from 'lodash/get'; +import {afterEach, beforeAll, beforeEach, describe, expect, it} from '@jest/globals'; import {utcToZonedTime} from 'date-fns-tz'; -import {beforeEach, beforeAll, afterEach, describe, it, expect} from '@jest/globals'; -import ONYXKEYS from '../../src/ONYXKEYS'; +import lodashGet from 'lodash/get'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; import CONST from '../../src/CONST'; -import * as Report from '../../src/libs/actions/Report'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import PusherHelper from '../utils/PusherHelper'; -import * as TestHelper from '../utils/TestHelper'; -import Log from '../../src/libs/Log'; +import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; import * as PersistedRequests from '../../src/libs/actions/PersistedRequests'; +import * as Report from '../../src/libs/actions/Report'; import * as User from '../../src/libs/actions/User'; -import * as ReportUtils from '../../src/libs/ReportUtils'; import DateUtils from '../../src/libs/DateUtils'; +import Log from '../../src/libs/Log'; import * as SequentialQueue from '../../src/libs/Network/SequentialQueue'; -import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; -import waitForNetworkPromises from '../utils/waitForNetworkPromises'; +import * as ReportUtils from '../../src/libs/ReportUtils'; +import ONYXKEYS from '../../src/ONYXKEYS'; import getIsUsingFakeTimers from '../utils/getIsUsingFakeTimers'; +import PusherHelper from '../utils/PusherHelper'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import waitForNetworkPromises from '../utils/waitForNetworkPromises'; const UTC = 'UTC'; jest.mock('../../src/libs/actions/Report', () => { diff --git a/tests/actions/SessionTest.js b/tests/actions/SessionTest.js index 4ecb2a33b763..f7d7f8ed5835 100644 --- a/tests/actions/SessionTest.js +++ b/tests/actions/SessionTest.js @@ -1,17 +1,16 @@ -import Onyx from 'react-native-onyx'; import {beforeEach, jest, test} from '@jest/globals'; -import HttpUtils from '../../src/libs/HttpUtils'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import ONYXKEYS from '../../src/ONYXKEYS'; -import * as TestHelper from '../utils/TestHelper'; +import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; -import PushNotification from '../../src/libs/Notification/PushNotification'; import * as App from '../../src/libs/actions/App'; import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; - +import HttpUtils from '../../src/libs/HttpUtils'; +import PushNotification from '../../src/libs/Notification/PushNotification'; // This lib needs to be imported, but it has nothing to export since all it contains is an Onyx connection // eslint-disable-next-line no-unused-vars import subscribePushNotification from '../../src/libs/Notification/PushNotification/subscribePushNotification'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; // We are mocking this method so that we can later test to see if it was called and what arguments it was called with. // We test HttpUtils.xhr() since this means that our API command turned into a network request and isn't only queued. diff --git a/tests/perf-test/ReportActionsList.perf-test.js b/tests/perf-test/ReportActionsList.perf-test.js index dcd40dd1e03f..f4dcd969923f 100644 --- a/tests/perf-test/ReportActionsList.perf-test.js +++ b/tests/perf-test/ReportActionsList.perf-test.js @@ -1,20 +1,20 @@ -import {measurePerformance} from 'reassure'; +import {fireEvent, screen} from '@testing-library/react-native'; import Onyx from 'react-native-onyx'; -import {screen, fireEvent} from '@testing-library/react-native'; -import ReportActionsList from '../../src/pages/home/report/ReportActionsList'; +import {measurePerformance} from 'reassure'; import ComposeProviders from '../../src/components/ComposeProviders'; +import {LocaleContextProvider} from '../../src/components/LocaleContextProvider'; import OnyxProvider from '../../src/components/OnyxProvider'; -import {ReportAttachmentsProvider} from '../../src/pages/home/report/ReportAttachmentsContext'; import {WindowDimensionsProvider} from '../../src/components/withWindowDimensions'; -import {LocaleContextProvider} from '../../src/components/LocaleContextProvider'; +import * as Localize from '../../src/libs/Localize'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import ReportActionsList from '../../src/pages/home/report/ReportActionsList'; +import {ReportAttachmentsProvider} from '../../src/pages/home/report/ReportAttachmentsContext'; +import {ActionListContext, ReactionListContext} from '../../src/pages/home/ReportScreenContext'; +import variables from '../../src/styles/variables'; import * as LHNTestUtils from '../utils/LHNTestUtils'; +import PusherHelper from '../utils/PusherHelper'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; -import PusherHelper from '../utils/PusherHelper'; -import variables from '../../src/styles/variables'; -import {ActionListContext, ReactionListContext} from '../../src/pages/home/ReportScreenContext'; -import ONYXKEYS from '../../src/ONYXKEYS'; -import * as Localize from '../../src/libs/Localize'; jest.setTimeout(60000); diff --git a/tests/perf-test/SelectionList.perf-test.js b/tests/perf-test/SelectionList.perf-test.js index e78970a04012..f8e358db9d5c 100644 --- a/tests/perf-test/SelectionList.perf-test.js +++ b/tests/perf-test/SelectionList.perf-test.js @@ -1,6 +1,6 @@ +import {fireEvent} from '@testing-library/react-native'; import React, {useState} from 'react'; import {measurePerformance} from 'reassure'; -import {fireEvent} from '@testing-library/react-native'; import _ from 'underscore'; import SelectionList from '../../src/components/SelectionList'; import variables from '../../src/styles/variables'; diff --git a/tests/perf-test/SidebarLinks.perf-test.js b/tests/perf-test/SidebarLinks.perf-test.js index 7c2d91b3356c..f6819d40a48f 100644 --- a/tests/perf-test/SidebarLinks.perf-test.js +++ b/tests/perf-test/SidebarLinks.perf-test.js @@ -1,13 +1,13 @@ -import {measurePerformance} from 'reassure'; -import Onyx from 'react-native-onyx'; import {fireEvent, screen} from '@testing-library/react-native'; +import Onyx from 'react-native-onyx'; +import {measurePerformance} from 'reassure'; import _ from 'underscore'; -import * as LHNTestUtils from '../utils/LHNTestUtils'; import CONST from '../../src/CONST'; import ONYXKEYS from '../../src/ONYXKEYS'; +import variables from '../../src/styles/variables'; +import * as LHNTestUtils from '../utils/LHNTestUtils'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; -import variables from '../../src/styles/variables'; /** * Performance tests with Reassure can require big timeouts as all runs diff --git a/tests/ui/UnreadIndicatorsTest.js b/tests/ui/UnreadIndicatorsTest.js index 5615e0b67729..54808d2b618d 100644 --- a/tests/ui/UnreadIndicatorsTest.js +++ b/tests/ui/UnreadIndicatorsTest.js @@ -1,29 +1,29 @@ -import React from 'react'; -import Onyx from 'react-native-onyx'; -import {Linking, AppState} from 'react-native'; import {fireEvent, render, screen, waitFor} from '@testing-library/react-native'; -import lodashGet from 'lodash/get'; -import {subMinutes, format, addSeconds, subSeconds} from 'date-fns'; +import {addSeconds, format, subMinutes, subSeconds} from 'date-fns'; import {utcToZonedTime} from 'date-fns-tz'; +import lodashGet from 'lodash/get'; +import React from 'react'; +import {AppState, Linking} from 'react-native'; +import Onyx from 'react-native-onyx'; import App from '../../src/App'; +import CONFIG from '../../src/CONFIG'; import CONST from '../../src/CONST'; -import ONYXKEYS from '../../src/ONYXKEYS'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import waitForBatchedUpdatesWithAct from '../utils/waitForBatchedUpdatesWithAct'; -import * as TestHelper from '../utils/TestHelper'; -import appSetup from '../../src/setup'; -import fontWeightBold from '../../src/styles/fontWeight/bold'; import * as AppActions from '../../src/libs/actions/App'; -import * as NumberUtils from '../../src/libs/NumberUtils'; -import LocalNotification from '../../src/libs/Notification/LocalNotification'; import * as Report from '../../src/libs/actions/Report'; +import * as User from '../../src/libs/actions/User'; import * as CollectionUtils from '../../src/libs/CollectionUtils'; import DateUtils from '../../src/libs/DateUtils'; -import * as User from '../../src/libs/actions/User'; +import * as Localize from '../../src/libs/Localize'; +import LocalNotification from '../../src/libs/Notification/LocalNotification'; +import * as NumberUtils from '../../src/libs/NumberUtils'; import * as Pusher from '../../src/libs/Pusher/pusher'; import PusherConnectionManager from '../../src/libs/PusherConnectionManager'; -import CONFIG from '../../src/CONFIG'; -import * as Localize from '../../src/libs/Localize'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import appSetup from '../../src/setup'; +import fontWeightBold from '../../src/styles/fontWeight/bold'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import waitForBatchedUpdatesWithAct from '../utils/waitForBatchedUpdatesWithAct'; // We need a large timeout here as we are lazy loading React Navigation screens and this test is running against the entire mounted App jest.setTimeout(30000); diff --git a/tests/unit/APITest.js b/tests/unit/APITest.js index 395f1438b666..474ccbf36328 100644 --- a/tests/unit/APITest.js +++ b/tests/unit/APITest.js @@ -1,18 +1,17 @@ import Onyx from 'react-native-onyx'; import _ from 'underscore'; - -import * as TestHelper from '../utils/TestHelper'; -import HttpUtils from '../../src/libs/HttpUtils'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import ONYXKEYS from '../../src/ONYXKEYS'; import CONST from '../../src/CONST'; -import * as NetworkStore from '../../src/libs/Network/NetworkStore'; import * as PersistedRequests from '../../src/libs/actions/PersistedRequests'; -import * as MainQueue from '../../src/libs/Network/MainQueue'; import * as API from '../../src/libs/API'; +import HttpUtils from '../../src/libs/HttpUtils'; +import * as MainQueue from '../../src/libs/Network/MainQueue'; +import * as NetworkStore from '../../src/libs/Network/NetworkStore'; import * as SequentialQueue from '../../src/libs/Network/SequentialQueue'; import * as Request from '../../src/libs/Request'; import * as RequestThrottle from '../../src/libs/RequestThrottle'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import waitForNetworkPromises from '../utils/waitForNetworkPromises'; jest.mock('../../src/libs/Log'); diff --git a/tests/unit/CalendarPickerTest.js b/tests/unit/CalendarPickerTest.js index 3b3b123cd946..5d0c22459710 100644 --- a/tests/unit/CalendarPickerTest.js +++ b/tests/unit/CalendarPickerTest.js @@ -1,8 +1,8 @@ -import {render, fireEvent, within} from '@testing-library/react-native'; -import {format, eachMonthOfInterval, subYears, addYears} from 'date-fns'; -import DateUtils from '../../src/libs/DateUtils'; +import {fireEvent, render, within} from '@testing-library/react-native'; +import {addYears, eachMonthOfInterval, format, subYears} from 'date-fns'; import CalendarPicker from '../../src/components/NewDatePicker/CalendarPicker'; import CONST from '../../src/CONST'; +import DateUtils from '../../src/libs/DateUtils'; DateUtils.setLocale(CONST.LOCALES.EN); const fullYear = new Date().getFullYear(); diff --git a/tests/unit/CurrencyUtilsTest.js b/tests/unit/CurrencyUtilsTest.js index ba61775f30da..89e1e2ffb3be 100644 --- a/tests/unit/CurrencyUtilsTest.js +++ b/tests/unit/CurrencyUtilsTest.js @@ -1,11 +1,10 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../src/ONYXKEYS'; +import _ from 'underscore'; import CONST from '../../src/CONST'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import * as CurrencyUtils from '../../src/libs/CurrencyUtils'; import LocaleListener from '../../src/libs/Localize/LocaleListener'; - +import ONYXKEYS from '../../src/ONYXKEYS'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; // This file can get outdated. In that case, you can follow these steps to update it: // - open your browser console and navigate to the Network tab // - refresh the App diff --git a/tests/unit/DateUtilsTest.js b/tests/unit/DateUtilsTest.js index 91590eb955b2..4b76e0f496c8 100644 --- a/tests/unit/DateUtilsTest.js +++ b/tests/unit/DateUtilsTest.js @@ -1,6 +1,6 @@ -import Onyx from 'react-native-onyx'; +import {addDays, addMinutes, format, setHours, setMinutes, subDays, subHours, subMinutes, subSeconds} from 'date-fns'; import {format as tzFormat, utcToZonedTime} from 'date-fns-tz'; -import {addMinutes, subHours, subMinutes, subSeconds, format, setMinutes, setHours, subDays, addDays} from 'date-fns'; +import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; import DateUtils from '../../src/libs/DateUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; diff --git a/tests/unit/EmojiTest.js b/tests/unit/EmojiTest.js index d10da618480e..4da29027de86 100644 --- a/tests/unit/EmojiTest.js +++ b/tests/unit/EmojiTest.js @@ -1,14 +1,14 @@ -import _ from 'underscore'; import {getUnixTime} from 'date-fns'; -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; import Emoji from '../../assets/emojis'; +import CONST from '../../src/CONST'; +import * as User from '../../src/libs/actions/User'; import * as EmojiUtils from '../../src/libs/EmojiUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; -import * as User from '../../src/libs/actions/User'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import * as TestHelper from '../utils/TestHelper'; -import CONST from '../../src/CONST'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; describe('EmojiTest', () => { it('matches all the emojis in the list', () => { diff --git a/tests/unit/IOUUtilsTest.js b/tests/unit/IOUUtilsTest.js index 9785acf68317..ac04b74a0ca5 100644 --- a/tests/unit/IOUUtilsTest.js +++ b/tests/unit/IOUUtilsTest.js @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; import * as IOUUtils from '../../src/libs/IOUUtils'; import * as ReportUtils from '../../src/libs/ReportUtils'; +import * as TransactionUtils from '../../src/libs/TransactionUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import currencyList from './currencyList.json'; -import * as TransactionUtils from '../../src/libs/TransactionUtils'; function initCurrencyList() { Onyx.init({ diff --git a/tests/unit/LocalePhoneNumberTest.js b/tests/unit/LocalePhoneNumberTest.js index 1435e0819fa4..99f53e7f980a 100644 --- a/tests/unit/LocalePhoneNumberTest.js +++ b/tests/unit/LocalePhoneNumberTest.js @@ -1,6 +1,6 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../src/ONYXKEYS'; import * as LocalePhoneNumber from '../../src/libs/LocalePhoneNumber'; +import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; const ES_NUMBER = '+34702474537'; diff --git a/tests/unit/LocalizeTests.js b/tests/unit/LocalizeTests.js index 921cf158a47c..4c89d587fc06 100644 --- a/tests/unit/LocalizeTests.js +++ b/tests/unit/LocalizeTests.js @@ -1,8 +1,8 @@ import Onyx from 'react-native-onyx'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import CONST from '../../src/CONST'; -import ONYXKEYS from '../../src/ONYXKEYS'; import * as Localize from '../../src/libs/Localize'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; describe('localize', () => { beforeAll(() => { diff --git a/tests/unit/LoginUtilsTest.js b/tests/unit/LoginUtilsTest.js index e49d710b8f49..b27ffdbb3897 100644 --- a/tests/unit/LoginUtilsTest.js +++ b/tests/unit/LoginUtilsTest.js @@ -1,7 +1,7 @@ import Onyx from 'react-native-onyx'; +import * as LoginUtils from '../../src/libs/LoginUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import * as LoginUtils from '../../src/libs/LoginUtils'; describe('LoginUtils', () => { beforeAll(() => { diff --git a/tests/unit/MiddlewareTest.js b/tests/unit/MiddlewareTest.js index db020ea924ed..85148cdb40e0 100644 --- a/tests/unit/MiddlewareTest.js +++ b/tests/unit/MiddlewareTest.js @@ -1,12 +1,12 @@ import Onyx from 'react-native-onyx'; +import HttpUtils from '../../src/libs/HttpUtils'; +import * as MainQueue from '../../src/libs/Network/MainQueue'; import * as NetworkStore from '../../src/libs/Network/NetworkStore'; -import * as Request from '../../src/libs/Request'; import * as SequentialQueue from '../../src/libs/Network/SequentialQueue'; +import * as Request from '../../src/libs/Request'; +import ONYXKEYS from '../../src/ONYXKEYS'; import * as TestHelper from '../utils/TestHelper'; import waitForNetworkPromises from '../utils/waitForNetworkPromises'; -import ONYXKEYS from '../../src/ONYXKEYS'; -import * as MainQueue from '../../src/libs/Network/MainQueue'; -import HttpUtils from '../../src/libs/HttpUtils'; Onyx.init({ keys: ONYXKEYS, diff --git a/tests/unit/MigrationTest.js b/tests/unit/MigrationTest.js index 3139f7efc97f..4bd739a08a59 100644 --- a/tests/unit/MigrationTest.js +++ b/tests/unit/MigrationTest.js @@ -1,11 +1,11 @@ import Onyx from 'react-native-onyx'; import _ from 'underscore'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import Log from '../../src/libs/Log'; -import PersonalDetailsByAccountID from '../../src/libs/migrations/PersonalDetailsByAccountID'; import CheckForPreviousReportActionID from '../../src/libs/migrations/CheckForPreviousReportActionID'; import KeyReportActionsDraftByReportActionID from '../../src/libs/migrations/KeyReportActionsDraftByReportActionID'; +import PersonalDetailsByAccountID from '../../src/libs/migrations/PersonalDetailsByAccountID'; import ONYXKEYS from '../../src/ONYXKEYS'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; jest.mock('../../src/libs/getPlatform'); diff --git a/tests/unit/NetworkTest.js b/tests/unit/NetworkTest.js index bd45ae3c2187..9a90a100769f 100644 --- a/tests/unit/NetworkTest.js +++ b/tests/unit/NetworkTest.js @@ -1,20 +1,19 @@ -import _ from 'underscore'; import Onyx from 'react-native-onyx'; - -import * as TestHelper from '../utils/TestHelper'; -import HttpUtils from '../../src/libs/HttpUtils'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import ONYXKEYS from '../../src/ONYXKEYS'; +import _ from 'underscore'; import CONST from '../../src/CONST'; -import * as Network from '../../src/libs/Network'; -import * as NetworkStore from '../../src/libs/Network/NetworkStore'; -import * as Session from '../../src/libs/actions/Session'; +import * as App from '../../src/libs/actions/App'; +import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; import * as PersistedRequests from '../../src/libs/actions/PersistedRequests'; +import * as Session from '../../src/libs/actions/Session'; +import HttpUtils from '../../src/libs/HttpUtils'; import Log from '../../src/libs/Log'; +import * as Network from '../../src/libs/Network'; import * as MainQueue from '../../src/libs/Network/MainQueue'; -import * as App from '../../src/libs/actions/App'; +import * as NetworkStore from '../../src/libs/Network/NetworkStore'; import NetworkConnection from '../../src/libs/NetworkConnection'; -import OnyxUpdateManager from '../../src/libs/actions/OnyxUpdateManager'; +import ONYXKEYS from '../../src/ONYXKEYS'; +import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; jest.mock('../../src/libs/Log'); diff --git a/tests/unit/OptionsListUtilsTest.js b/tests/unit/OptionsListUtilsTest.js index 7a9fbb558455..5d18608a3de4 100644 --- a/tests/unit/OptionsListUtilsTest.js +++ b/tests/unit/OptionsListUtilsTest.js @@ -1,11 +1,11 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; import {View} from 'react-native'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; +import CONST from '../../src/CONST'; import * as OptionsListUtils from '../../src/libs/OptionsListUtils'; import * as ReportUtils from '../../src/libs/ReportUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import CONST from '../../src/CONST'; describe('OptionsListUtils', () => { // Given a set of reports with both single participants and multiple participants some pinned and some not diff --git a/tests/unit/ReportActionItemSingleTest.js b/tests/unit/ReportActionItemSingleTest.js index d6b46eb55414..55cae01c19f1 100644 --- a/tests/unit/ReportActionItemSingleTest.js +++ b/tests/unit/ReportActionItemSingleTest.js @@ -1,5 +1,5 @@ -import Onyx from 'react-native-onyx'; import {cleanup, screen} from '@testing-library/react-native'; +import Onyx from 'react-native-onyx'; import * as LHNTestUtils from '../utils/LHNTestUtils'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; diff --git a/tests/unit/ReportActionsUtilsTest.js b/tests/unit/ReportActionsUtilsTest.js index 2f02203bad64..9973515c44de 100644 --- a/tests/unit/ReportActionsUtilsTest.js +++ b/tests/unit/ReportActionsUtilsTest.js @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; +import * as ReportActionsUtils from '../../src/libs/ReportActionsUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; +import * as LHNTestUtils from '../utils/LHNTestUtils'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; -import * as ReportActionsUtils from '../../src/libs/ReportActionsUtils'; -import * as LHNTestUtils from '../utils/LHNTestUtils'; describe('ReportActionsUtils', () => { beforeAll(() => diff --git a/tests/unit/ReportUtilsTest.js b/tests/unit/ReportUtilsTest.js index 26257b469939..2b836f8eb0bf 100644 --- a/tests/unit/ReportUtilsTest.js +++ b/tests/unit/ReportUtilsTest.js @@ -1,10 +1,10 @@ import Onyx from 'react-native-onyx'; import _ from 'underscore'; import CONST from '../../src/CONST'; -import ONYXKEYS from '../../src/ONYXKEYS'; import * as ReportUtils from '../../src/libs/ReportUtils'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import ONYXKEYS from '../../src/ONYXKEYS'; import * as LHNTestUtils from '../utils/LHNTestUtils'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; // Be sure to include the mocked permissions library or else the beta tests won't work jest.mock('../../src/libs/Permissions'); diff --git a/tests/unit/RequestTest.js b/tests/unit/RequestTest.js index fb1032e70cfe..823b05fd4e0e 100644 --- a/tests/unit/RequestTest.js +++ b/tests/unit/RequestTest.js @@ -1,6 +1,6 @@ import * as Request from '../../src/libs/Request'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; import * as TestHelper from '../utils/TestHelper'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; beforeAll(() => { global.fetch = TestHelper.getGlobalFetchMock(); diff --git a/tests/unit/SidebarFilterTest.js b/tests/unit/SidebarFilterTest.js index 18e499d89293..23a958e3aa9d 100644 --- a/tests/unit/SidebarFilterTest.js +++ b/tests/unit/SidebarFilterTest.js @@ -1,12 +1,12 @@ import {cleanup, screen} from '@testing-library/react-native'; -import Onyx from 'react-native-onyx'; import lodashGet from 'lodash/get'; -import * as LHNTestUtils from '../utils/LHNTestUtils'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; +import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; import DateUtils from '../../src/libs/DateUtils'; import * as Localize from '../../src/libs/Localize'; +import * as LHNTestUtils from '../utils/LHNTestUtils'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; // Be sure to include the mocked permissions library or else the beta tests won't work jest.mock('../../src/libs/Permissions'); diff --git a/tests/unit/SidebarOrderTest.js b/tests/unit/SidebarOrderTest.js index 4a693d679b86..72b3a0c2f631 100644 --- a/tests/unit/SidebarOrderTest.js +++ b/tests/unit/SidebarOrderTest.js @@ -1,13 +1,13 @@ -import Onyx from 'react-native-onyx'; import {cleanup, screen} from '@testing-library/react-native'; import lodashGet from 'lodash/get'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; -import * as LHNTestUtils from '../utils/LHNTestUtils'; +import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; +import * as Report from '../../src/libs/actions/Report'; import DateUtils from '../../src/libs/DateUtils'; import * as Localize from '../../src/libs/Localize'; -import * as Report from '../../src/libs/actions/Report'; +import * as LHNTestUtils from '../utils/LHNTestUtils'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; // Be sure to include the mocked Permissions and Expensicons libraries or else the beta tests won't work jest.mock('../../src/libs/Permissions'); diff --git a/tests/unit/SidebarTest.js b/tests/unit/SidebarTest.js index 1b5daa323da5..4bd0795aa3b9 100644 --- a/tests/unit/SidebarTest.js +++ b/tests/unit/SidebarTest.js @@ -1,11 +1,11 @@ -import Onyx from 'react-native-onyx'; import {cleanup, screen} from '@testing-library/react-native'; import lodashGet from 'lodash/get'; -import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; -import * as LHNTestUtils from '../utils/LHNTestUtils'; +import Onyx from 'react-native-onyx'; import CONST from '../../src/CONST'; import * as Localize from '../../src/libs/Localize'; +import * as LHNTestUtils from '../utils/LHNTestUtils'; +import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; +import wrapOnyxWithWaitForBatchedUpdates from '../utils/wrapOnyxWithWaitForBatchedUpdates'; // Be sure to include the mocked Permissions and Expensicons libraries or else the beta tests won't work jest.mock('../../src/libs/Permissions'); diff --git a/tests/unit/ValidationUtilsTest.js b/tests/unit/ValidationUtilsTest.js index a9e0b1b61128..bdc1f11948ae 100644 --- a/tests/unit/ValidationUtilsTest.js +++ b/tests/unit/ValidationUtilsTest.js @@ -1,4 +1,4 @@ -import {addDays, format, subYears, startOfDay} from 'date-fns'; +import {addDays, format, startOfDay, subYears} from 'date-fns'; import CONST from '../../src/CONST'; const ValidationUtils = require('../../src/libs/ValidationUtils'); diff --git a/tests/unit/enhanceParametersTest.js b/tests/unit/enhanceParametersTest.js index fb2ccc86ad79..513206b42614 100644 --- a/tests/unit/enhanceParametersTest.js +++ b/tests/unit/enhanceParametersTest.js @@ -1,8 +1,8 @@ import Onyx from 'react-native-onyx'; -import ONYXKEYS from '../../src/ONYXKEYS'; +import CONFIG from '../../src/CONFIG'; import enhanceParameters from '../../src/libs/Network/enhanceParameters'; +import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from '../utils/waitForBatchedUpdates'; -import CONFIG from '../../src/CONFIG'; beforeEach(() => Onyx.clear()); diff --git a/tests/unit/loginTest.js b/tests/unit/loginTest.js index c8bcc6c6f00f..a1b59cfcb998 100644 --- a/tests/unit/loginTest.js +++ b/tests/unit/loginTest.js @@ -1,10 +1,8 @@ /** * @format */ - -import 'react-native'; import React from 'react'; - +import 'react-native'; // Note: `react-test-renderer` renderer must be required after react-native. import renderer from 'react-test-renderer'; import App from '../../src/App'; diff --git a/tests/utils/LHNTestUtils.js b/tests/utils/LHNTestUtils.js index 6e7d4390b4e9..9898063cc496 100644 --- a/tests/utils/LHNTestUtils.js +++ b/tests/utils/LHNTestUtils.js @@ -1,17 +1,17 @@ -import React from 'react'; -import PropTypes from 'prop-types'; import {render} from '@testing-library/react-native'; +import PropTypes from 'prop-types'; +import React from 'react'; import ComposeProviders from '../../src/components/ComposeProviders'; -import OnyxProvider from '../../src/components/OnyxProvider'; import {LocaleContextProvider} from '../../src/components/LocaleContextProvider'; -import SidebarLinksData from '../../src/pages/home/sidebar/SidebarLinksData'; -import ReportActionItemSingle from '../../src/pages/home/report/ReportActionItemSingle'; -import {EnvironmentProvider} from '../../src/components/withEnvironment'; +import OnyxProvider from '../../src/components/OnyxProvider'; import {CurrentReportIDContextProvider} from '../../src/components/withCurrentReportID'; +import {EnvironmentProvider} from '../../src/components/withEnvironment'; import CONST from '../../src/CONST'; import DateUtils from '../../src/libs/DateUtils'; -import reportPropTypes from '../../src/pages/reportPropTypes'; +import ReportActionItemSingle from '../../src/pages/home/report/ReportActionItemSingle'; import reportActionPropTypes from '../../src/pages/home/report/reportActionPropTypes'; +import SidebarLinksData from '../../src/pages/home/sidebar/SidebarLinksData'; +import reportPropTypes from '../../src/pages/reportPropTypes'; // we have to mock `useIsFocused` because it's used in the SidebarLinks component const mockedNavigate = jest.fn(); diff --git a/tests/utils/PusherHelper.js b/tests/utils/PusherHelper.js index b763f4ebb28f..3d0ce1404a91 100644 --- a/tests/utils/PusherHelper.js +++ b/tests/utils/PusherHelper.js @@ -1,7 +1,7 @@ -import * as Pusher from '../../src/libs/Pusher/pusher'; -import PusherConnectionManager from '../../src/libs/PusherConnectionManager'; import CONFIG from '../../src/CONFIG'; import CONST from '../../src/CONST'; +import * as Pusher from '../../src/libs/Pusher/pusher'; +import PusherConnectionManager from '../../src/libs/PusherConnectionManager'; const CHANNEL_NAME = `${CONST.PUSHER.PRIVATE_USER_CHANNEL_PREFIX}1${CONFIG.PUSHER.SUFFIX}`; diff --git a/tests/utils/TestHelper.js b/tests/utils/TestHelper.js index 4c658f004894..03f5416a92fb 100644 --- a/tests/utils/TestHelper.js +++ b/tests/utils/TestHelper.js @@ -1,12 +1,12 @@ -import _ from 'underscore'; -import Onyx from 'react-native-onyx'; import Str from 'expensify-common/lib/str'; +import Onyx from 'react-native-onyx'; +import _ from 'underscore'; import CONST from '../../src/CONST'; import * as Session from '../../src/libs/actions/Session'; import HttpUtils from '../../src/libs/HttpUtils'; +import * as NumberUtils from '../../src/libs/NumberUtils'; import ONYXKEYS from '../../src/ONYXKEYS'; import waitForBatchedUpdates from './waitForBatchedUpdates'; -import * as NumberUtils from '../../src/libs/NumberUtils'; /** * @param {String} login diff --git a/tests/utils/bumpVersion.mjs b/tests/utils/bumpVersion.mjs index e9ab115382ce..19471ee7f905 100644 --- a/tests/utils/bumpVersion.mjs +++ b/tests/utils/bumpVersion.mjs @@ -1,5 +1,4 @@ #!/usr/bin/env node - import {incrementVersion} from '../../.github/libs/versionUpdater.js'; const version = process.argv[2]; diff --git a/tests/utils/getPreviousVersion.mjs b/tests/utils/getPreviousVersion.mjs index fb4acd625070..31ca672776fa 100644 --- a/tests/utils/getPreviousVersion.mjs +++ b/tests/utils/getPreviousVersion.mjs @@ -1,5 +1,4 @@ #!/usr/bin/env node - import {getPreviousVersion} from '../../.github/libs/versionUpdater.js'; const currentVersion = process.argv[2]; diff --git a/tests/utils/getPullRequestsMergedBetween.mjs b/tests/utils/getPullRequestsMergedBetween.mjs index 05dedaa3e4f1..0afb1499e67f 100755 --- a/tests/utils/getPullRequestsMergedBetween.mjs +++ b/tests/utils/getPullRequestsMergedBetween.mjs @@ -1,5 +1,4 @@ #!/usr/bin/env node - import GitUtils from '../../.github/libs/GitUtils.js'; const fromRef = process.argv[2]; diff --git a/tests/utils/waitForBatchedUpdates.js b/tests/utils/waitForBatchedUpdates.js index 2c4dbec250bc..c9d7a99fa1fb 100644 --- a/tests/utils/waitForBatchedUpdates.js +++ b/tests/utils/waitForBatchedUpdates.js @@ -1,4 +1,5 @@ import getIsUsingFakeTimers from './getIsUsingFakeTimers'; + /** * Method which waits for all asynchronous JS to stop executing before proceeding. This helps test things like actions * that expect some Onyx value to be available. This way we do not have to explicitly wait for an action to finish diff --git a/wdyr.js b/wdyr.js index 5f790b922d9e..ad1edaa5a075 100644 --- a/wdyr.js +++ b/wdyr.js @@ -1,8 +1,7 @@ // Implements Why Did You Render (WDYR) in Dev - +import lodashGet from 'lodash/get'; import React from 'react'; import Config from 'react-native-config'; -import lodashGet from 'lodash/get'; const useWDYR = lodashGet(Config, 'USE_WDYR') === 'true'; From 23898a19c4fc3dd08b9e94b96f89dda84b9388af Mon Sep 17 00:00:00 2001 From: Mahesh Vagicherla Date: Sat, 28 Oct 2023 20:06:49 +0530 Subject: [PATCH 105/105] fix typecheck issue --- src/types/modules/react-native-key-command.d.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/types/modules/react-native-key-command.d.ts b/src/types/modules/react-native-key-command.d.ts index 5cac93f2a90b..4c7f07bd6d7e 100644 --- a/src/types/modules/react-native-key-command.d.ts +++ b/src/types/modules/react-native-key-command.d.ts @@ -23,9 +23,9 @@ declare module 'react-native-key-command' { keyModifierAlternate = 'keyModifierAlternate', } - type KeyCommand = {input: string; modifierFlags: string}; + type KeyCommand = {input: string; modifierFlags?: string}; - declare function addListener(keyCommand: KeyCommand, callback: (keycommandEvent: KeyCommand, event: Event) => void): () => void; + declare function addListener(keyCommand: KeyCommand, callback: (keycommandEvent: KeyCommand, event: KeyboardEvent) => void): () => void; // eslint-disable-next-line import/prefer-default-export export {constants, addListener};