forked from Ivasoft/mattermost-mobile
* Initial commit post input * Fix message posting, add create direct channel and minor fixes * Fix "is typing" and "react to last post" behaviour * Some reordering, better handling of upload error, properly clear draft on send message, and fix minor progress bar misbehavior * Add keyboard listener for shift-enter, add selection between video or photo while attaching, add alert when trying to attach more than you are allowed, add paste functionality, minor fixes and reordering * Add library patch * Fix lint * Address feedback * Address feedback * Add missing negation * Check for group name and fix typo on draft comparisons * Address feedback * Address feedback * Address feedback * Address feedback * Fix several bugs * Remove @app imports * Address feedback * fix post list & post draft layout on iOS * Fix post draft cursor position * Fix file upload route * Allow to pick multiple images using the image picker * accurately get the channel member count * remove android cursor workaround * Remove local const INPUT_LINE_HEIGHT * move getPlaceHolder out of the component * use substring instead of legacy substr for hardward keyboard * Move onAppStateChange above the effects * Fix camera action bottom sheet * no need to memo SendButton * properly use memberCount in sender handler * Refactor how to get memberCount * Fix queryRecentPostsInThread * Remove unused isDirectChannelVisible && isGroupChannelVisible util functions * rename errorBadUser to errorUnkownUser * extract localized strings * use ClientErrorProps instead of ClientError * Minor improvements Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
38 lines
869 B
TypeScript
38 lines
869 B
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import React, {useState} from 'react';
|
|
|
|
import DraftInput from '../draft_input';
|
|
|
|
type Props = {
|
|
testID?: string;
|
|
channelId: string;
|
|
rootId: string;
|
|
|
|
// Send Handler
|
|
sendMessage: () => void;
|
|
maxMessageLength: number;
|
|
canSend: boolean;
|
|
|
|
// Draft Handler
|
|
value: string;
|
|
uploadFileError: React.ReactNode;
|
|
files: FileInfo[];
|
|
clearDraft: () => void;
|
|
updateValue: (value: string) => void;
|
|
addFiles: (files: FileInfo[]) => void;
|
|
}
|
|
|
|
export default function CursorPositionHandler(props: Props) {
|
|
const [pos, setCursorPosition] = useState(0);
|
|
|
|
return (
|
|
<DraftInput
|
|
{...props}
|
|
cursorPosition={pos}
|
|
updateCursorPosition={setCursorPosition}
|
|
/>
|
|
);
|
|
}
|