forked from Ivasoft/mattermost-mobile
* Added DrawerItem component
* WIP Account Screen
* Added react-native-paper
* Added StatusLabel Component
* Extracted i18n
* TS fix DrawerItem component
* WIP Account Screen
* Added server name label under log out
* Updated translation
* WIP
* Fixes the Offline text style
* Added Metropolis fonts
* WIP
* Typo clean up
* WIP
* WIP
* WIP
* Added server display name
* Writing OpenSans properly
* WIP
* WIP
* Added OptionsModal
* Opening OptionsModal
* Added translation keys
* Writes status to local db
* Fix missing translation
* Fix OptionModal not dismissing
* Pushing status to server
* Refactored
* Added CustomStatusExpiry component
* Added sub components
* Added CustomLabel
* CustomStatus WIP
* Added Custom Status screen WIP
* WIP - unsetCustomStatus and CustomStatus constant
* WIP
* WIP
* WIP
* WIP
* WIP
* WIP
* WIP
* Retrieving RecentCustomStatuses from Preferences table
* WIP
* WIP
* WIP
* Added Clear After Modal
* WIP - Transations
* WIP
* Done with showing modal cst
* wip
* Clear After Modal - DONE
* fix
* Added missing API calls
* wip
* Causing screen refresh
* wip
* WIP
* WIP
* WIP
* Code clean up
* Added OOO alert box
* Refactored Options-Item
* Refactored OptionsModalList component
* Opening 'status' in BottomSheet instead of OptionsModal
* AddReaction screen - WIP
* Add Reaction screen - WIP
* Added EmojiPickerRow
* Added @components/emoji_picker - WIP
* Emoji Picker - WIP
* WIP
* WIP
* WIP
* SectionList - WIP
* Installed react-native-section_list_get_item_layout
* Adding API calls - WIP
* WIP
* Search Bar component - WIP
* WIP
* WIP
* WIP
* Rendering Emoticons now - have to tackle some fixmes
* Code clean up
* Code clean up - WIP
* Code clean up
* WIP
* Major clean up
* wip
* WIP
* Fix rendering issue with SectionIcons and SearchBar
* Tackled the CustomEmojiPage
* Code clean up
* WIP
* Done with loading User Profiles for Custom Emoji
* Code clean up
* Code Clean up
* Fix screen Account
* Added missing sql file for IOS Pod
* Updated Podfile.lock
* Using queryConfig instead of queryCommonSystemValues
* Fix - Custom status
* Fix - Custom Status - Error
* Fix - Clear Pass Status - WIP
* Fix - Custom Status Clear
* Need to fix CST clear
* WIP
* Status clear - working
* Using catchError operator
* remove unnecessary prop
* Status BottomSheet now has colored indicators
* Added KeyboardTrackingView from 'react-native-keyboard-tracking-view'
* Code clean up
* WIP
* code clean up
* Added a safety check
* Fix - Display suggestions
* Code clean up based on PR Review
* Code clean up
* Code clean up
* Code clean up
* Corrections
* Fix tsc
* TS fix
* Removed unnecessary prop
* Fix SearchBar Ts
* Updated tests
* Delete search_bar.test.js.snap
* Merge branch 'gekidou' into gekidou_account_screen
* Revert "Merge branch 'gekidou' into gekidou_account_screen"
This reverts commit 5defc31321.
* Fix fonts
* Refactor home account screen
* fix theme provider
* refactor bottom sheet
* remove paper provider
* update drawer item snapshots
* Remove options modal screen
* remove react-native-ui-lib dependency
* Refactor & fix custom status & navigation (including tablet)
* Refactor emoji picker
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
242 lines
8.9 KiB
TypeScript
242 lines
8.9 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {withManagedConfig} from '@mattermost/react-native-emm';
|
|
import React from 'react';
|
|
import {IntlProvider} from 'react-intl';
|
|
import {Platform, StyleProp, ViewStyle} from 'react-native';
|
|
import {gestureHandlerRootHOC} from 'react-native-gesture-handler';
|
|
import {Navigation, NavigationFunctionComponent} from 'react-native-navigation';
|
|
import {SafeAreaProvider} from 'react-native-safe-area-context';
|
|
|
|
import {Screens} from '@constants';
|
|
import {withServerDatabase} from '@database/components';
|
|
import {DEFAULT_LOCALE, getTranslations} from '@i18n';
|
|
|
|
// TODO: Remove this and uncomment screens as they get added
|
|
/* eslint-disable */
|
|
|
|
const withGestures = (screen: NavigationFunctionComponent, styles: StyleProp<ViewStyle>) => {
|
|
if (Platform.OS === 'android') {
|
|
return gestureHandlerRootHOC(screen, styles);
|
|
}
|
|
|
|
return screen;
|
|
};
|
|
|
|
const withIntl = (Screen: React.ComponentType) => {
|
|
return function IntlEnabledComponent(props: any) {
|
|
return (
|
|
<IntlProvider
|
|
locale={DEFAULT_LOCALE}
|
|
messages={getTranslations()}
|
|
>
|
|
<Screen {...props}/>
|
|
</IntlProvider>
|
|
);
|
|
}
|
|
}
|
|
|
|
const withSafeAreaInsets = (Screen: React.ComponentType) => {
|
|
return function SafeAreaInsets(props: any){
|
|
return (
|
|
<SafeAreaProvider>
|
|
<Screen {...props} />
|
|
</SafeAreaProvider>
|
|
)
|
|
}
|
|
}
|
|
|
|
Navigation.setLazyComponentRegistrator((screenName) => {
|
|
let screen: any|undefined;
|
|
let extraStyles: StyleProp<ViewStyle>;
|
|
switch (screenName) {
|
|
case Screens.ABOUT:
|
|
screen = withServerDatabase(require('@screens/about').default);
|
|
break;
|
|
// case 'AdvancedSettings':
|
|
// screen = require('@screens/settings/advanced_settings').default;
|
|
// break;
|
|
case Screens.BOTTOM_SHEET:
|
|
screen = withServerDatabase(require('@screens/bottom_sheet').default);
|
|
break;
|
|
case Screens.CHANNEL:
|
|
screen = withServerDatabase(require('@screens/channel').default);
|
|
break;
|
|
case Screens.CUSTOM_STATUS:
|
|
screen = withServerDatabase(require('@screens/custom_status').default);
|
|
break;
|
|
case Screens.CUSTOM_STATUS_CLEAR_AFTER:
|
|
screen = withServerDatabase(require('@screens/custom_status_clear_after').default);
|
|
break;
|
|
case Screens.EMOJI_PICKER:
|
|
screen = withServerDatabase(require('@screens/emoji_picker').default);
|
|
break;
|
|
// case 'ChannelAddMembers':
|
|
// screen = require('@screens/channel_add_members').default;
|
|
// break;
|
|
// case 'ChannelInfo':
|
|
// screen = require('@screens/channel_info').default;
|
|
// break;
|
|
// case 'ChannelMembers':
|
|
// screen = require('@screens/channel_members').default;
|
|
// break;
|
|
// case 'ChannelNotificationPreference':
|
|
// screen = require('@screens/channel_notification_preference').default;
|
|
// break;
|
|
// case 'ClientUpgrade':
|
|
// screen = require('@screens/client_upgrade').default;
|
|
// break;
|
|
// case 'ClockDisplaySettings':
|
|
// screen = require('@screens/settings/clock_display').default;
|
|
// break;
|
|
// case 'Code':
|
|
// screen = require('@screens/code').default;
|
|
// break;
|
|
// case 'CreateChannel':
|
|
// screen = require('@screens/create_channel').default;
|
|
// break;
|
|
// case 'DisplaySettings':
|
|
// screen = require('@screens/settings/display_settings').default;
|
|
// break;
|
|
// case 'EditChannel':
|
|
// screen = require('@screens/edit_channel').default;
|
|
// break;
|
|
// case 'EditPost':
|
|
// screen = require('@screens/edit_post').default;
|
|
// break;
|
|
// case 'EditProfile':
|
|
// screen = require('@screens/edit_profile').default;
|
|
// break;
|
|
// case 'ErrorTeamsList':
|
|
// screen = require('@screens/error_teams_list').default;
|
|
// break;
|
|
// case 'ExpandedAnnouncementBanner':
|
|
// screen = require('@screens/expanded_announcement_banner').default;
|
|
// break;
|
|
// case 'FlaggedPosts':
|
|
// screen = require('@screens/flagged_posts').default;
|
|
// break;
|
|
case Screens.FORGOT_PASSWORD:
|
|
screen = require('@screens/forgot_password').default;
|
|
break;
|
|
// case 'Gallery':
|
|
// screen = require('@screens/gallery').default;
|
|
// break;
|
|
// case 'InteractiveDialog':
|
|
// screen = require('@screens/interactive_dialog').default;
|
|
// break;
|
|
case Screens.LOGIN:
|
|
screen = require('@screens/login').default;
|
|
break;
|
|
case Screens.LOGIN_OPTIONS:
|
|
screen = require('@screens/login_options').default;
|
|
break;
|
|
// case 'LongPost':
|
|
// screen = require('@screens/long_post').default;
|
|
// break;
|
|
// case 'MainSidebar':
|
|
// screen = require('app/components/sidebars/main').default;
|
|
// break;
|
|
case Screens.MFA:
|
|
screen = require('@screens/mfa').default;
|
|
break;
|
|
// case 'MoreChannels':
|
|
// screen = require('@screens/more_channels').default;
|
|
// break;
|
|
// case 'MoreDirectMessages':
|
|
// screen = require('@screens/more_dms').default;
|
|
// break;
|
|
// case 'Notification':
|
|
// extraStyles = Platform.select({android: {flex: undefined, height: 100}});
|
|
// screen = require('@screens/notification/index.tsx').default;
|
|
// break;
|
|
// case 'NotificationSettings':
|
|
// screen = require('@screens/settings/notification_settings').default;
|
|
// break;
|
|
// case 'NotificationSettingsAutoResponder':
|
|
// screen = require('@screens/settings/notification_settings_auto_responder').default;
|
|
// break;
|
|
// case 'NotificationSettingsEmail':
|
|
// screen = require('@screens/settings/notification_settings_email').default;
|
|
// break;
|
|
// case 'NotificationSettingsMentions':
|
|
// screen = require('@screens/settings/notification_settings_mentions').default;
|
|
// break;
|
|
// case 'NotificationSettingsMentionsKeywords':
|
|
// screen = require('@screens/settings/notification_settings_mentions_keywords').default;
|
|
// break;
|
|
// case 'NotificationSettingsMobile':
|
|
// screen = require('@screens/settings/notification_settings_mobile').default;
|
|
// break;
|
|
// case 'Permalink':
|
|
// screen = require('@screens/permalink').default;
|
|
// break;
|
|
// case 'PinnedPosts':
|
|
// screen = require('@screens/pinned_posts').default;
|
|
// break;
|
|
// case 'PostOptions':
|
|
// screen = require('@screens/post_options').default;
|
|
// break;
|
|
// case 'ReactionList':
|
|
// screen = require('@screens/reaction_list').default;
|
|
// break;
|
|
// case 'RecentMentions':
|
|
// screen = require('@screens/recent_mentions').default;
|
|
// break;
|
|
// case 'Search':
|
|
// screen = require('@screens/search').default;
|
|
// break;
|
|
// case 'SelectorScreen':
|
|
// screen = require('@screens/selector_screen').default;
|
|
// break;
|
|
// case 'SelectTeam':
|
|
// screen = require('@screens/select_team').default;
|
|
// break;
|
|
// case 'SelectTimezone':
|
|
// screen = require('@screens/settings/timezone/select_timezone').default;
|
|
// break;
|
|
// case 'Settings':
|
|
// screen = require('@screens/settings/general').default;
|
|
// break;
|
|
// case 'SettingsSidebar':
|
|
// screen = require('app/components/sidebars/settings').default;
|
|
// break;
|
|
// case 'SidebarSettings':
|
|
// screen = require('@screens/settings/sidebar').default;
|
|
// break;
|
|
case Screens.SSO:
|
|
screen = require('@screens/sso').default;
|
|
break;
|
|
// case 'Table':
|
|
// screen = require('@screens/table').default;
|
|
// break;
|
|
// case 'TermsOfService':
|
|
// screen = require('@screens/terms_of_service').default;
|
|
// break;
|
|
// case 'ThemeSettings':
|
|
// screen = require('@screens/settings/theme').default;
|
|
// break;
|
|
// case 'Thread':
|
|
// screen = require('@screens/thread').default;
|
|
// break;
|
|
// case 'TimezoneSettings':
|
|
// screen = require('@screens/settings/timezone').default;
|
|
// break;
|
|
// case 'UserProfile':
|
|
// screen = require('@screens/user_profile').default;
|
|
// break;
|
|
}
|
|
|
|
if (screen) {
|
|
Navigation.registerComponent(screenName, () => withSafeAreaInsets(withGestures(withIntl(withManagedConfig(screen)), extraStyles)));
|
|
}
|
|
});
|
|
|
|
export function registerScreens() {
|
|
const homeScreen = require('@screens/home').default;
|
|
const serverScreen = require('@screens/server').default;
|
|
Navigation.registerComponent(Screens.SERVER, () => withIntl(withManagedConfig(serverScreen)));
|
|
Navigation.registerComponent(Screens.HOME, () => withSafeAreaInsets(withGestures(withIntl(withServerDatabase(withManagedConfig(homeScreen))), undefined)));
|
|
}
|