2023-01-03 19:55:46 +00:00
|
|
|
// Copyright 2016 Signal Messenger, LLC
|
2021-09-29 20:23:06 +00:00
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2024-01-29 20:09:54 +00:00
|
|
|
import React, { useCallback } from 'react';
|
2021-09-29 20:23:06 +00:00
|
|
|
|
2024-01-29 20:09:54 +00:00
|
|
|
import type { ShowToastAction } from '../../state/ducks/toast';
|
2023-03-02 20:55:40 +00:00
|
|
|
import type { AttachmentDraftType } from '../../types/Attachment';
|
2021-10-26 19:15:33 +00:00
|
|
|
import type { LocalizerType } from '../../types/Util';
|
2024-01-29 20:09:54 +00:00
|
|
|
import { ToastType } from '../../types/Toast';
|
2021-09-29 20:23:06 +00:00
|
|
|
import {
|
2021-10-15 18:51:58 +00:00
|
|
|
useStartRecordingShortcut,
|
2021-09-29 20:23:06 +00:00
|
|
|
useKeyboardShortcuts,
|
|
|
|
} from '../../hooks/useKeyboardShortcuts';
|
|
|
|
|
|
|
|
export type PropsType = {
|
|
|
|
conversationId: string;
|
2021-11-15 21:54:33 +00:00
|
|
|
draftAttachments: ReadonlyArray<AttachmentDraftType>;
|
2021-09-29 20:23:06 +00:00
|
|
|
i18n: LocalizerType;
|
2023-01-05 00:22:36 +00:00
|
|
|
startRecording: (id: string) => unknown;
|
2024-01-29 20:09:54 +00:00
|
|
|
showToast: ShowToastAction;
|
2021-09-29 20:23:06 +00:00
|
|
|
};
|
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function AudioCapture({
|
2021-09-29 20:23:06 +00:00
|
|
|
conversationId,
|
|
|
|
draftAttachments,
|
|
|
|
i18n,
|
|
|
|
startRecording,
|
2024-01-29 20:09:54 +00:00
|
|
|
showToast,
|
2022-11-18 00:45:19 +00:00
|
|
|
}: PropsType): JSX.Element {
|
2023-01-05 00:22:36 +00:00
|
|
|
const recordConversation = useCallback(
|
|
|
|
() => startRecording(conversationId),
|
|
|
|
[conversationId, startRecording]
|
|
|
|
);
|
|
|
|
const startRecordingShortcut = useStartRecordingShortcut(recordConversation);
|
2021-09-29 20:23:06 +00:00
|
|
|
useKeyboardShortcuts(startRecordingShortcut);
|
|
|
|
|
2023-03-02 20:55:40 +00:00
|
|
|
const handleClick = useCallback(() => {
|
|
|
|
if (draftAttachments.length) {
|
2024-01-29 20:09:54 +00:00
|
|
|
showToast({ toastType: ToastType.VoiceNoteMustBeTheOnlyAttachment });
|
2023-03-02 20:55:40 +00:00
|
|
|
} else {
|
|
|
|
startRecording(conversationId);
|
2021-09-29 20:23:06 +00:00
|
|
|
}
|
2024-01-29 20:09:54 +00:00
|
|
|
}, [conversationId, draftAttachments, showToast, startRecording]);
|
2021-09-29 20:23:06 +00:00
|
|
|
|
|
|
|
return (
|
2024-01-29 20:09:54 +00:00
|
|
|
<div className="AudioCapture">
|
|
|
|
<button
|
|
|
|
aria-label={i18n('icu:voiceRecording--start')}
|
|
|
|
className="AudioCapture__microphone"
|
|
|
|
onClick={handleClick}
|
|
|
|
title={i18n('icu:voiceRecording--start')}
|
|
|
|
type="button"
|
|
|
|
/>
|
|
|
|
</div>
|
2021-09-29 20:23:06 +00:00
|
|
|
);
|
2022-11-18 00:45:19 +00:00
|
|
|
}
|