forked from Ivasoft/mattermost-mobile
* MM_35115: ADDED select_server screen
* MM_35115: ADDED select_server screen
* MM_35115: ADDED files on which select_server is dependent
* MM_35115: ADDED react-native-button
* MM_35115: Fixing TS issues [IN PROGRESS]
* MM_35115: Started withObservables [IN PROGRESS]
* MM_35115: Started withObservables [IN PROGRESS]
* MM_35115: withObservables - defaulting when no connection is available [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Removed resetPing action [IN PROGRESS]
* MM_35115: ADDED app/client
* MM_35115: Preparing scheduleExpiredNotification
* MM_35115: Adding some todos
* Server & LoginOptions
* Use default server if available and autoconnect if configured
* Fix login header & manual server url
* MM_35115: Login Options[IN PROGRESS]
* MM_35115: Login screen - email [IN PROGRESS]
* MM_35115: Login screen - email [IN PROGRESS]
* MM_35115: Login screen - email - login api call [IN PROGRESS]
* MM_35115: Login screen - email - login api call [IN PROGRESS]
* MM_35115: Login screen - email - saving to server db [IN PROGRESS]
* MM_35115: Login screen - email - saving to System, Preferences to db [IN PROGRESS]
* MM_35115: Login screen - enforcing unique check on System entity [IN PROGRESS]
* MM_35115: Login screen - writing TeamMembership [IN PROGRESS]
* MM_35115: Login screen - writing Teams [IN PROGRESS]
* MM_35115: Login screen [IN PROGRESS]
* MM_35115: Login screen- Refactored DataOperator handlers [IN PROGRESS]
* MM_35115: Login screen - Proper clean up [IN PROGRESS]
* MM_35115: Login screen - completeLogin [IN PROGRESS]
* MM_35115: Improving DataOperator
* MM_35115: Improving DataOperator
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: Removing unused app/queries folder
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Adding roles for MYTEAM
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Adding rn-fetch-blob for Android
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Added test setup
* MM_35115: Fix database utils
* MM_35115: ADDED loadRolesIfNeeded
* MM_35115: Fix TS issue
* MM_35115: ADDED Tests setup
* MM_35115: Fix TS issues
* MM_35115: Fix TS issues
* MM_35115: Fix TS issues
* MM_35115: Added alternative to site name
* MM_35115: Added alternative to site name
* MM_35115: Removed hardcoded values
* MM_35115: Clean up
* MM_35115 - Fixed Android platform check instead of hermes
* MM_35115 - Replaced emptyErrorHandlingFunction with emptyFunction
* MM_35115 : Implemented TS fixes
* Update index.ts
* MM-35115 - Fix react-test-renderer issue
* MM_35115 - Optimizing DatabaseManager
* MM_35115 : Implemented getDatabaseConnection
* MM_35115 : Refactoring set/getActiveDatabase to use flag record
* MM_35115 : Refactored active database to use flag in Global entity
* MM_35115 : Updated manual database manager test
* MM_35115 : Fix operator/utils/test
* MM_35115 : Fix for base_handler
* MM_35115 : Fix test issues with Handlers
* MM_35115 : Fix test issues with prepareRecords
* MM_35115 : Fix wrapper test issue
* MM_35115 : Updated getMostRecentServerConnection to return the serverUrl as well as the connection
* MM_35115 : Refactored the way we call DataOperator
* MM_35115 : Updated database manager mock
* Add getMostRecentServerUrl function (#5440)
* fix: add getMostRecentServerUrl func
* fix: add ts and tsx to editorconfig
* fix: rename functions
* fix: return type
* Fix unit test setup
* fix login screen unit tests
* MM-36205 [GEKIDOU] Login Flow SSO (#5454)
* MM_35115: Starting LoginOptions SSO
* MM_36205: SSO [IN PROGRESS]
* MM_36205 : SSO [ IN PROGRESS ]
* Update sso_with_redirect_url.tsx
* MM_36205 : SSO Tests [ IN PROGRESS ]
* MM_36205 : Passing serverUrl to SSO screen
* Update sso.test.tsx
* Fix ViewTypes imports and keyMirror method
* MM_36205 : Code clean up
* Fix : Clean up imports
* Update: Aligning with PR 5452
* Fix: AndroidManifest file to include redirection ofr scheme mmauthbeta
* refactor: SSO Login method via Gitlab now navigates to Channel screen
* refactor: SSO Login without redirectURL is also working
* feat: SSO - main test completed
* feat: ADDED test for sso_with_redirect_url
* fix : eslint correction
* fix: Updated Loading component name
* fix : code clean up from reviews
* fix: reviews check
* fix: Added mmauthbeta into info.plist
* Revert "fix: Added mmauthbeta into info.plist"
This reverts commit d87cc23f5b.
* Update Info.plist
* Update AppDelegate.m
* feat: ADDED Forgot Password - Test [ IN PROGRESS ]
* feat: Forgot Password - Completed & Tested
* fix: Including MFA screen [ IN PROGRESS ]
* MFA - Properly tested
* Properly testing forgot_password screen
* Fix login.test.tsx
* Fix SSO method calls chain
* Update index.tsx
* Sort imports for sceen/navigation
* fix: Reviews
* Update signing + act in test
* Removed todo comment on MFA
* feedback review
* fix login tests
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
* App initialization refactor (#5430)
* fix: initial init refactor
* fix: await isServerPresent
* fix: more refactor
* fix: move out launch functions
* fix: remove comment
* fix: update credential functions
* fix: refactor launch functions
* fix: deep link parsing
* fix: lint change
* fix: update deeplink and notification handlers
* fix: indentation
* fix: add relaunchApp
* fix eslint
* refactor launchProps and autoconnect server for deeplink
* fix: use undefined
* fix: define OptionalLaunchProps
* fix: Android - handle server URL in push notification
* fix: rename func
* fix: use boolean launchError instead
* fix: use DatabaseModule
* fix: use DatabaseHelper instead
* fix: remove unnecessary null check
* fix: iOS - support for serverUrl
* fix: iOS - extract serverUrl in reply action
* fix: iOS - expose objc specific func
* fix: remove unnecessary deviceToken param
* fix: return if device is untrusted
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
* fix: bye bye modulePaths
* fix: ios build
* chore: remove unused aliases from babel.config
* chore: fix dependency format in package-lock.json
* chore: remove transparent window background color for android AppTheme
* chore: remove mattermost.js and use index.ts as app entry
* fix: login flow screens theme
* fix: Launch types
* chore: remove OptionalLaunchProps type
* fix: url utils unit tests
* chore: update en.json
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
212 lines
4.4 KiB
TypeScript
212 lines
4.4 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
type AppManifest = {
|
|
app_id: string;
|
|
display_name: string;
|
|
description?: string;
|
|
homepage_url?: string;
|
|
root_url: string;
|
|
};
|
|
|
|
type AppModalState = {
|
|
form: AppForm;
|
|
call: AppCallRequest;
|
|
};
|
|
|
|
type AppsState = {
|
|
bindings: AppBinding[];
|
|
};
|
|
|
|
type AppBinding = {
|
|
app_id: string;
|
|
location?: string;
|
|
icon?: string;
|
|
|
|
// Label is the (usually short) primary text to display at the location.
|
|
// - For LocationPostMenu is the menu item text.
|
|
// - For LocationChannelHeader is the dropdown text.
|
|
// - For LocationCommand is the name of the command
|
|
label: string;
|
|
|
|
// Hint is the secondary text to display
|
|
// - LocationPostMenu: not used
|
|
// - LocationChannelHeader: tooltip
|
|
// - LocationCommand: the "Hint" line
|
|
hint?: string;
|
|
|
|
// Description is the (optional) extended help text, used in modals and autocomplete
|
|
description?: string;
|
|
|
|
role_id?: string;
|
|
depends_on_team?: boolean;
|
|
depends_on_channel?: boolean;
|
|
depends_on_user?: boolean;
|
|
depends_on_post?: boolean;
|
|
|
|
// A Binding is either to a Call, or is a "container" for other locations -
|
|
// i.e. menu sub-items or subcommands.
|
|
call?: AppCall;
|
|
bindings?: AppBinding[];
|
|
form?: AppForm;
|
|
};
|
|
|
|
type AppCallValues = {
|
|
[name: string]: any;
|
|
};
|
|
|
|
type AppCallType = string;
|
|
|
|
type AppCall = {
|
|
path: string;
|
|
expand?: AppExpand;
|
|
state?: any;
|
|
};
|
|
|
|
type AppCallRequest = AppCall & {
|
|
context: AppContext;
|
|
values?: AppCallValues;
|
|
raw_command?: string;
|
|
selected_field?: string;
|
|
query?: string;
|
|
};
|
|
|
|
type AppCallResponseType = string;
|
|
|
|
type AppCallResponse<Res = unknown> = {
|
|
type: AppCallResponseType;
|
|
markdown?: string;
|
|
data?: Res;
|
|
error?: string;
|
|
navigate_to_url?: string;
|
|
use_external_browser?: boolean;
|
|
call?: AppCall;
|
|
form?: AppForm;
|
|
app_metadata?: AppMetadataForClient;
|
|
};
|
|
|
|
type AppMetadataForClient = {
|
|
bot_user_id: string;
|
|
bot_username: string;
|
|
};
|
|
|
|
type AppContext = {
|
|
app_id: string;
|
|
location?: string;
|
|
acting_user_id?: string;
|
|
user_id?: string;
|
|
channel_id?: string;
|
|
team_id?: string;
|
|
post_id?: string;
|
|
root_id?: string;
|
|
props?: AppContextProps;
|
|
user_agent?: string;
|
|
};
|
|
|
|
type AppContextProps = {
|
|
[name: string]: string;
|
|
};
|
|
|
|
type AppExpandLevel = string;
|
|
|
|
type AppExpand = {
|
|
app?: AppExpandLevel;
|
|
acting_user?: AppExpandLevel;
|
|
channel?: AppExpandLevel;
|
|
config?: AppExpandLevel;
|
|
mentioned?: AppExpandLevel;
|
|
parent_post?: AppExpandLevel;
|
|
post?: AppExpandLevel;
|
|
root_post?: AppExpandLevel;
|
|
team?: AppExpandLevel;
|
|
user?: AppExpandLevel;
|
|
};
|
|
|
|
type AppForm = {
|
|
title?: string;
|
|
header?: string;
|
|
footer?: string;
|
|
icon?: string;
|
|
submit_buttons?: string;
|
|
cancel_button?: boolean;
|
|
submit_on_cancel?: boolean;
|
|
fields: AppField[];
|
|
call?: AppCall;
|
|
depends_on?: string[];
|
|
};
|
|
|
|
type AppFormValue = string | AppSelectOption | boolean | null;
|
|
type AppFormValues = {[name: string]: AppFormValue};
|
|
|
|
type AppSelectOption = {
|
|
label: string;
|
|
value: string;
|
|
icon_data?: string;
|
|
};
|
|
|
|
type AppFieldType = string;
|
|
|
|
// This should go in mattermost-redux
|
|
type AppField = {
|
|
|
|
// Name is the name of the JSON field to use.
|
|
name: string;
|
|
type: AppFieldType;
|
|
is_required?: boolean;
|
|
readonly?: boolean;
|
|
|
|
// Present (default) value of the field
|
|
value?: AppFormValue;
|
|
|
|
description?: string;
|
|
|
|
label?: string;
|
|
hint?: string;
|
|
position?: number;
|
|
|
|
modal_label?: string;
|
|
|
|
// Select props
|
|
refresh?: boolean;
|
|
options?: AppSelectOption[];
|
|
multiselect?: boolean;
|
|
|
|
// Text props
|
|
subtype?: string;
|
|
min_length?: number;
|
|
max_length?: number;
|
|
};
|
|
|
|
type AutocompleteSuggestion = {
|
|
suggestion: string;
|
|
complete?: string;
|
|
description?: string;
|
|
hint?: string;
|
|
iconData?: string;
|
|
};
|
|
|
|
type AutocompleteSuggestionWithComplete = AutocompleteSuggestion & {
|
|
complete: string;
|
|
};
|
|
|
|
type AutocompleteElement = AppField;
|
|
type AutocompleteStaticSelect = AutocompleteElement & {
|
|
options: AppSelectOption[];
|
|
};
|
|
|
|
type AutocompleteDynamicSelect = AutocompleteElement;
|
|
|
|
type AutocompleteUserSelect = AutocompleteElement;
|
|
|
|
type AutocompleteChannelSelect = AutocompleteElement;
|
|
|
|
type FormResponseData = {
|
|
errors?: {
|
|
[field: string]: string;
|
|
};
|
|
};
|
|
|
|
type AppLookupResponse = {
|
|
items: AppSelectOption[];
|
|
};
|