signal-desktop/ts/components/CallingHeader.tsx

170 lines
5.8 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2020 Signal Messenger, LLC
2020-11-17 15:07:53 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
import type { ReactNode } from 'react';
2020-11-20 19:39:50 +00:00
import classNames from 'classnames';
import React from 'react';
import type { LocalizerType } from '../types/Util';
import { CallViewMode } from '../types/Calling';
import { Tooltip } from './Tooltip';
import { Theme } from '../util/theme';
import { ContextMenu } from './ContextMenu';
2020-11-17 15:07:53 +00:00
export type PropsType = {
callViewMode?: CallViewMode;
2020-11-17 15:07:53 +00:00
i18n: LocalizerType;
isGroupCall?: boolean;
2021-09-18 00:20:29 +00:00
message?: ReactNode;
onCancel?: () => void;
participantCount: number;
2020-11-23 21:37:39 +00:00
title?: string;
2020-11-17 15:07:53 +00:00
togglePip?: () => void;
toggleSettings: () => void;
changeCallView?: (mode: CallViewMode) => void;
2020-11-17 15:07:53 +00:00
};
2022-11-18 00:45:19 +00:00
export function CallingHeader({
callViewMode,
changeCallView,
2020-11-17 15:07:53 +00:00
i18n,
isGroupCall = false,
2020-11-23 21:37:39 +00:00
message,
onCancel,
participantCount,
2020-11-23 21:37:39 +00:00
title,
2020-11-17 15:07:53 +00:00
togglePip,
toggleSettings,
2022-11-18 00:45:19 +00:00
}: PropsType): JSX.Element {
return (
<div className="module-calling__header">
{title ? (
<div className="module-calling__header--header-name">{title}</div>
) : null}
{message ? (
<div className="module-ongoing-call__header-message">{message}</div>
) : null}
<div className="module-calling-tools">
{isGroupCall &&
participantCount > 2 &&
callViewMode &&
changeCallView && (
<div className="module-calling-tools__button">
<ContextMenu
ariaLabel={i18n('icu:calling__change-view')}
i18n={i18n}
menuOptions={[
{
icon: 'CallSettingsButton__Icon--PaginatedView',
label: i18n('icu:calling__view_mode--paginated'),
onClick: () => changeCallView(CallViewMode.Paginated),
value: CallViewMode.Paginated,
},
{
icon: 'CallSettingsButton__Icon--OverflowView',
label: i18n('icu:calling__view_mode--overflow'),
onClick: () => changeCallView(CallViewMode.Overflow),
value: CallViewMode.Overflow,
},
{
icon: 'CallSettingsButton__Icon--SpeakerView',
label: i18n('icu:calling__view_mode--speaker'),
onClick: () => changeCallView(CallViewMode.Speaker),
value: CallViewMode.Speaker,
},
]}
theme={Theme.Dark}
popperOptions={{
placement: 'bottom',
strategy: 'absolute',
}}
value={
// If it's Presentation we want to still show Speaker as selected
callViewMode === CallViewMode.Presentation
? CallViewMode.Speaker
: callViewMode
}
2023-10-25 13:40:22 +00:00
>
<Tooltip
content={i18n('icu:calling__change-view')}
className="CallingButton__tooltip"
theme={Theme.Dark}
>
<div className="CallSettingsButton__Button">
<span
className={classNames(
'CallSettingsButton__Icon',
getCallViewIconClassname(callViewMode)
)}
/>
</div>
</Tooltip>
</ContextMenu>
</div>
)}
2023-10-25 13:40:22 +00:00
<div className="module-calling-tools__button">
<Tooltip
content={i18n('icu:callingDeviceSelection__settings')}
className="CallingButton__tooltip"
theme={Theme.Dark}
>
<button
aria-label={i18n('icu:callingDeviceSelection__settings')}
className="CallSettingsButton__Button"
onClick={toggleSettings}
type="button"
>
<span className="CallSettingsButton__Icon CallSettingsButton__Icon--Settings" />
</button>
</Tooltip>
</div>
{togglePip && (
<div className="module-calling-tools__button">
<Tooltip
content={i18n('icu:calling__pip--on')}
className="CallingButton__tooltip"
theme={Theme.Dark}
>
<button
aria-label={i18n('icu:calling__pip--on')}
className="CallSettingsButton__Button"
onClick={togglePip}
type="button"
>
<span className="CallSettingsButton__Icon CallSettingsButton__Icon--Pip" />
</button>
</Tooltip>
</div>
)}
2022-11-18 00:45:19 +00:00
{onCancel && (
<div className="module-calling-tools__button">
2023-10-25 13:40:22 +00:00
<Tooltip
content={i18n('icu:cancel')}
theme={Theme.Dark}
className="CallingButton__tooltip"
>
2022-11-18 00:45:19 +00:00
<button
2023-03-30 00:03:25 +00:00
aria-label={i18n('icu:cancel')}
2023-10-25 13:40:22 +00:00
className="CallSettingsButton__Button CallSettingsButton__Button--Cancel"
2022-11-18 00:45:19 +00:00
onClick={onCancel}
type="button"
2023-10-25 13:40:22 +00:00
>
<span className="CallSettingsButton__Icon CallSettingsButton__Icon--Cancel" />
</button>
2022-11-18 00:45:19 +00:00
</Tooltip>
</div>
)}
</div>
2020-11-17 15:07:53 +00:00
</div>
2022-11-18 00:45:19 +00:00
);
}
const CALL_VIEW_MODE_ICON_CLASSNAMES: Record<CallViewMode, string> = {
[CallViewMode.Overflow]: 'CallSettingsButton__Icon--OverflowView',
[CallViewMode.Paginated]: 'CallSettingsButton__Icon--PaginatedView',
[CallViewMode.Speaker]: 'CallSettingsButton__Icon--SpeakerView',
[CallViewMode.Presentation]: 'CallSettingsButton__Icon--SpeakerView',
};
export function getCallViewIconClassname(viewMode: CallViewMode): string {
return CALL_VIEW_MODE_ICON_CLASSNAMES[viewMode];
}