| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 | // @flow
import React from 'react';
import { Text, TouchableHighlight } from 'react-native';
import { useDispatch } from 'react-redux';
import { createReactionMenuEvent, sendAnalytics } from '../../../analytics';
import { translate } from '../../../base/i18n';
import type { StyleType } from '../../../base/styles';
import { addReactionToBuffer } from '../../actions.any';
import { REACTIONS } from '../../constants';
export type ReactionStyles = {
    /**
     * Style for the button.
     */
    style: StyleType,
    /**
     * Underlay color for the button.
     */
    underlayColor: StyleType,
    /**
     * Style for the emoji text on the button.
     */
    emoji: StyleType,
    /**
     * Style for the label text on the button.
     */
    text?: StyleType,
    /**
     * Style for text container. Used on raise hand button.
     */
    container?: StyleType
}
/**
 * The type of the React {@code Component} props of {@link ReactionButton}.
 */
type Props = {
    /**
     * Collection of styles for the button.
     */
    styles: ReactionStyles,
    /**
     * The reaction to be sent
     */
    reaction: string,
    /**
     * Invoked to obtain translated strings.
     */
    t: Function
};
/**
 * An implementation of a button to send a reaction.
 *
 * @returns {ReactElement}
 */
function ReactionButton({
    styles,
    reaction,
    t
}: Props) {
    const dispatch = useDispatch();
    /**
     * Handles clicking / pressing the button.
     *
     * @returns {void}
     */
    function _onClick() {
        dispatch(addReactionToBuffer(reaction));
        sendAnalytics(createReactionMenuEvent(reaction));
    }
    return (
        <TouchableHighlight
            accessibilityLabel = { t(`toolbar.accessibilityLabel.${reaction}`) }
            accessibilityRole = 'button'
            onPress = { _onClick }
            style = { styles.style }
            underlayColor = { styles.underlayColor }>
            <Text style = { styles.emoji }>{REACTIONS[reaction].emoji}</Text>
        </TouchableHighlight>
    );
}
export default translate(ReactionButton);
 |