Files
mattermost-mobile/app/screens/index.tsx
Avinash Lingaloo 7f91a6a78a Gekidou - Account Screen (#5708)
* 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>
2021-10-12 19:24:24 +04:00

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)));
}