diff --git a/src/CONST.ts b/src/CONST.ts index 4870dd0a12fe..2a415d61d4e6 100755 --- a/src/CONST.ts +++ b/src/CONST.ts @@ -1484,6 +1484,10 @@ const CONST = { OTHER_INVISIBLE_CHARACTERS: /[\u3164]/g, REPORT_FIELD_TITLE: /{report:([a-zA-Z]+)}/g, + + PATH_WITHOUT_POLICY_ID: /\/w\/[a-zA-Z0-9]+(\/|$)/, + + POLICY_ID_FROM_PATH: /\/w\/([a-zA-Z0-9]+)(\/|$)/, }, PRONOUNS: { @@ -3168,6 +3172,7 @@ const CONST = { SUBSCRIPT_ICON_SIZE: 8, MINIMUM_WORKSPACES_TO_SHOW_SEARCH: 8, }, + REPORT_FIELD_TITLE_FIELD_ID: 'text_title', } as const; diff --git a/src/components/AvatarWithImagePicker.js b/src/components/AvatarWithImagePicker.js index 0048a183a2af..fddcbb354d38 100644 --- a/src/components/AvatarWithImagePicker.js +++ b/src/components/AvatarWithImagePicker.js @@ -91,6 +91,7 @@ const propTypes = { /** Indicates if picker feature should be disabled */ disabled: PropTypes.bool, + /** Executed once click on view photo option */ onViewPhotoPress: PropTypes.func, diff --git a/src/libs/Navigation/AppNavigator/createCustomBottomTabNavigator/index.tsx b/src/libs/Navigation/AppNavigator/createCustomBottomTabNavigator/index.tsx index 448606d85d99..e6ecfccb47ee 100644 --- a/src/libs/Navigation/AppNavigator/createCustomBottomTabNavigator/index.tsx +++ b/src/libs/Navigation/AppNavigator/createCustomBottomTabNavigator/index.tsx @@ -17,6 +17,7 @@ type CustomNavigatorProps = DefaultNavigatorOptions): StackNavigationState { const routesToRender = [state.routes.at(-1)] as NavigationStateRoute[]; + // We need to render at least one HOME screen to make sure everything load properly. if (routesToRender[0].name !== SCREENS.HOME) { const routeToRender = state.routes.find((route) => route.name === SCREENS.HOME); diff --git a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.ts b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.ts index c175620ec24e..e69045822253 100644 --- a/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.ts +++ b/src/libs/Navigation/AppNavigator/createCustomStackNavigator/CustomRouter.ts @@ -38,7 +38,7 @@ function compareAndAdaptState(state: StackNavigationState) { const topmostBottomTabRoute = getTopmostBottomTabRoute(state); const isSmallScreenWidth = getIsSmallScreenWidth(); - // This solutions is heurestis and will work for our cases. We may need to improve it in the future if we will have more cases to handle. + // This solutions is heuristics and will work for our cases. We may need to improve it in the future if we will have more cases to handle. if (topmostBottomTabRoute && !isSmallScreenWidth) { const fullScreenRoute = state.routes.find((route) => route.name === NAVIGATORS.FULL_SCREEN_NAVIGATOR); @@ -84,7 +84,7 @@ function compareAndAdaptState(state: StackNavigationState) { // If there is central pane route in state and template state has one, we need to check if they are the same. if (topmostCentralPaneRouteExtracted && templateCentralPaneRouteExtracted && topmostCentralPaneRouteExtracted.name !== templateCentralPaneRouteExtracted.name) { // Not every RHP screen has matching central pane defined. In that case we use the REPORT screen as default for initial screen. - // But we don't want to ovverride the central pane for those screens as they may be opened with different central panes under the overlay. + // But we don't want to override the central pane for those screens as they may be opened with different central panes under the overlay. // e.g. i-know-a-teacher may be opened with different central panes under the overlay if (templateCentralPaneRouteExtracted.name === SCREENS.REPORT) { return; diff --git a/src/libs/Navigation/AppNavigator/getPartialStateDiff.ts b/src/libs/Navigation/AppNavigator/getPartialStateDiff.ts index fddb10038156..a5cecf276e9e 100644 --- a/src/libs/Navigation/AppNavigator/getPartialStateDiff.ts +++ b/src/libs/Navigation/AppNavigator/getPartialStateDiff.ts @@ -23,11 +23,11 @@ type GetPartialStateDiffReturnType = { }; /** - * This function returns partial additive diff beteween the two states. - * The partial diff have information which bottom tab, central pane and full screen screens we need to push to go from state to templateState + * This function returns partial additive diff between the two states. + * The partial diff has information which bottom tab, central pane and full screen screens we need to push to go from state to templateState. * @param state - Current state. * @param templateState - Desired state generated with getAdaptedStateFromPath. - * @param metainfo - Additional info from getAdaptedStateFromPath funciton. + * @param metainfo - Additional info from getAdaptedStateFromPath function. * @returns The screen options object */ function getPartialStateDiff(state: State, templateState: State, metainfo: Metainfo): GetPartialStateDiffReturnType { @@ -60,8 +60,8 @@ function getPartialStateDiff(state: State, templateState: St } } - // This one is heurestic and may need to improved if we will be able to navigate from modal screen with full screen in background to another modal screen with full screen in background. - // For now this simple check is enought. + // This one is heuristic and may need to be improved if we will be able to navigate from modal screen with full screen in background to another modal screen with full screen in background. + // For now this simple check is enough. if (metainfo.isFullScreenNavigatorMandatory) { const stateTopmostFullScreen = state.routes.filter((route) => route.name === NAVIGATORS.FULL_SCREEN_NAVIGATOR).at(-1); const templateStateTopmostFullScreen = templateState.routes.filter((route) => route.name === NAVIGATORS.FULL_SCREEN_NAVIGATOR).at(-1) as NavigationPartialRoute; diff --git a/src/libs/Navigation/linkTo.ts b/src/libs/Navigation/linkTo.ts index d43f69eaa28e..2c7c9357af26 100644 --- a/src/libs/Navigation/linkTo.ts +++ b/src/libs/Navigation/linkTo.ts @@ -226,7 +226,7 @@ export default function linkTo(navigation: NavigationContainerRef): boolean { } function extractPolicyIDFromPath(path: string) { - return path.match(/\/w\/([a-zA-Z0-9]+)(\/|$)/)?.[1]; + return path.match(CONST.REGEX.POLICY_ID_FROM_PATH)?.[1]; } function getPathWithoutPolicyID(path: string) { - return path.replace(/\/w\/[a-zA-Z0-9]+(\/|$)/, '/'); + return path.replace(CONST.REGEX.PATH_WITHOUT_POLICY_ID, '/'); } function getPolicyMembersByIdWithoutCurrentUser(policyMembers: OnyxCollection, currentPolicyID?: string, currentUserAccountID?: number) { diff --git a/src/libs/actions/Report.ts b/src/libs/actions/Report.ts index 028c409ee8fa..41362c90135d 100644 --- a/src/libs/actions/Report.ts +++ b/src/libs/actions/Report.ts @@ -1830,7 +1830,7 @@ function showReportActionNotification(reportID: string, reportAction: ReportActi Modal.close(() => { const policyID = lastVisitedPath && extractPolicyIDFromPath(lastVisitedPath); const policyMembersAccountIDs = policyID ? getPolicyMemberAccountIDs(policyID) : []; - const reportBelongsToWorkspace = policyID ? doesReportBelongToWorkspace(report, policyMembersAccountIDs, policyID) : true; + const reportBelongsToWorkspace = policyID ? doesReportBelongToWorkspace(report, policyMembersAccountIDs, policyID) : false; if (!reportBelongsToWorkspace) { Navigation.navigateWithSwitchPolicyID({policyID: undefined, route: ROUTES.HOME}); } diff --git a/src/pages/home/sidebar/AllSettingsScreen.tsx b/src/pages/home/sidebar/AllSettingsScreen.tsx index 200c7ca634b7..6e7447244a4d 100644 --- a/src/pages/home/sidebar/AllSettingsScreen.tsx +++ b/src/pages/home/sidebar/AllSettingsScreen.tsx @@ -33,7 +33,7 @@ function AllSettingsScreen({policies, policyMembers}: AllSettingsScreenProps) { const {isSmallScreenWidth} = useWindowDimensions(); /** - * Retuns a list of menu items data for "everything" settings + * Retuns a list of menu items data for All workspaces settings * @returns {Object} object with translationKey, style and items */ const menuItems = useMemo(() => { diff --git a/src/pages/workspace/WorkspacePageWithSections.tsx b/src/pages/workspace/WorkspacePageWithSections.tsx index 27a27766136a..54b4cca84e9e 100644 --- a/src/pages/workspace/WorkspacePageWithSections.tsx +++ b/src/pages/workspace/WorkspacePageWithSections.tsx @@ -65,6 +65,7 @@ type WorkspacePageWithSectionsProps = WithPolicyAndFullscreenLoadingProps & /** Should show the back button. It is used when in RHP. */ shouldShowBackButton?: boolean; + /** Whether the offline indicator should be shown in wide screen devices */ shouldShowOfflineIndicatorInWideScreen?: boolean; /** Whether to show this page to non admin policy members */ diff --git a/src/pages/workspace/WorkspacesListPage.tsx b/src/pages/workspace/WorkspacesListPage.tsx index 5b499fe7a3ee..9b763120b30d 100755 --- a/src/pages/workspace/WorkspacesListPage.tsx +++ b/src/pages/workspace/WorkspacesListPage.tsx @@ -300,8 +300,8 @@ function WorkspacesListPage({policies, allPolicyMembers, reimbursementAccount, r iconFill: theme.textLight, fallbackIcon: Expensicons.FallbackWorkspaceAvatar, policyID: policy.id, - adminRoom: policyRooms?.[policy.id].adminRoom ?? policy.chatReportIDAdmins?.toString(), - announceRoom: policyRooms?.[policy.id].announceRoom ?? policy.chatReportIDAnnounce?.toString(), + adminRoom: policyRooms?.[policy.id]?.adminRoom ?? policy.chatReportIDAdmins?.toString(), + announceRoom: policyRooms?.[policy.id]?.announceRoom ?? policy.chatReportIDAnnounce?.toString(), ownerAccountID: policy.ownerAccountID, role: policy.role, type: policy.type, diff --git a/src/types/onyx/Policy.ts b/src/types/onyx/Policy.ts index 53347f3318c2..966c9f2139da 100644 --- a/src/types/onyx/Policy.ts +++ b/src/types/onyx/Policy.ts @@ -151,6 +151,7 @@ type Policy = { /** When tax tracking is enabled */ isTaxTrackingEnabled?: boolean; + /** ReportID of the admins room for this workspace */ chatReportIDAdmins?: number; chatReportIDAnnounce?: number;