12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- // @flow
-
- import React, { useCallback } from 'react';
- import { useTranslation } from 'react-i18next';
- import { View } from 'react-native';
- import { Button } from 'react-native-paper';
- import { useDispatch } from 'react-redux';
-
- import { setKnockingParticipantApproval } from '../../../lobby/actions.native';
- import { MediaState } from '../../constants';
-
- import ParticipantItem from './ParticipantItem';
- import styles from './styles';
-
- type Props = {
-
- /**
- * Participant reference
- */
- participant: Object
- };
-
- export const LobbyParticipantItem = ({ participant: p }: Props) => {
- const dispatch = useDispatch();
- const admit = useCallback(() => dispatch(setKnockingParticipantApproval(p.id, true), [ dispatch ]));
- const reject = useCallback(() => dispatch(setKnockingParticipantApproval(p.id, false), [ dispatch ]));
- const { t } = useTranslation();
-
- return (
- <ParticipantItem
- audioMuteState = { MediaState.Muted }
- participant = { p }
- videoMuteState = { MediaState.ForceMuted }>
- <View style = { styles.lobbyParticipantItem }>
- <Button
- children = { t('lobby.admit') }
- contentStyle = { styles.participantActionsButtonContent }
- labelStyle = { styles.participantActionsButtonText }
- mode = 'contained'
- onPress = { admit }
- style = { styles.participantActionsButtonAdmit } />
- <Button
- children = { t('lobby.reject') }
- contentStyle = { styles.participantActionsButtonContent }
- labelStyle = { styles.participantActionsButtonText }
- mode = 'contained'
- onPress = { reject }
- style = { styles.participantActionsButtonReject } />
- </View>
- </ParticipantItem>
- );
- };
|