// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactNode } from 'react'; import React, { forwardRef } from 'react'; import classNames from 'classnames'; export enum SystemMessageKind { Normal = 'Normal', Danger = 'Danger', Error = 'Error', } export type PropsType = { icon: | 'audio-incoming' | 'audio-missed' | 'audio-outgoing' | 'group' | 'group-access' | 'group-add' | 'group-approved' | 'group-avatar' | 'group-decline' | 'group-edit' | 'group-leave' | 'group-remove' | 'group-summary' | 'info' | 'phone' | 'profile' | 'safety-number' | 'session-refresh' | 'thread' | 'timer' | 'timer-disabled' | 'unsupported' | 'unsupported--can-process' | 'verified' | 'verified-not' | 'video' | 'video-incoming' | 'video-missed' | 'video-outgoing' | 'warning' | 'payment-event' | 'merge'; contents: ReactNode; button?: ReactNode; kind?: SystemMessageKind; }; export const SystemMessage = forwardRef( function SystemMessageInner( { icon, contents, button, kind = SystemMessageKind.Normal }, ref ) { return (
{contents}
{button && (
{button}
)}
); } );