Files
mattermost-mobile/types/api/apps.d.ts

221 lines
4.9 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;
}
type AppModalState = {
form: AppForm;
call: AppCallRequest;
}
type AppsState = {
bindings: AppBinding[];
bindingsForms: AppCommandFormMap;
threadBindings: AppBinding[];
threadBindingsForms: AppCommandFormMap;
threadBindingsChannelId: string;
pluginEnabled: boolean;
};
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 an action (makes a call), a Form, or is a
// "container" for other locations - i.e. menu sub-items or subcommands.
bindings?: AppBinding[];
form?: AppForm;
submit?: AppCall;
};
type AppCallValues = {
[name: string]: any;
};
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;
text?: string;
data?: Res;
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;
track_as_submit?: boolean;
};
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[];
// source is used in 2 cases:
// - if submit is not set, it is used to fetch the submittable form from
// the app.
// - if a select field change triggers a refresh, the form is refreshed
// from source.
source?: AppCall;
// submit is called when one of the submit buttons is pressed, or the
// command is executed.
submit?: AppCall;
depends_on?: string[];
};
type AppFormValue = string | boolean | number | AppSelectOption | AppSelectOption[] | 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;
lookup?: AppCall;
// Text props
subtype?: string;
min_length?: number;
max_length?: number;
};
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[];
}
type AppCommandFormMap = {[location: string]: AppForm}
type DoAppCallResult<Res=unknown> = {
data?: AppCallResponse<Res>;
error?: AppCallResponse<Res>;
}