mirror of
https://github.com/owncast/owncast.git
synced 2025-01-04 23:57:41 +03:00
69f217f758
* feat(mobile): refactor mobile chat into modal - Make page always scrollable - Move mobile chat into a standalone modal * fix(test): split out mobile browser test specs * fix(mobile): force chat button to render on top of footer * fix: some small updates from review * fix: hide/show hide chat menu option based on width * fix: chat button icon getting cut off * chore(tests): add browser tests for mobile chat modal * chore(tests): add story for ChatModal component * fix(test): quiet shellcheck * fix: remove unused import * fix(tests): silence storybook linting warning * fix(ui): reposition chat modal button icon with transform
89 lines
3.1 KiB
TypeScript
89 lines
3.1 KiB
TypeScript
import { Dispatch, FC, SetStateAction } from 'react';
|
|
import dynamic from 'next/dynamic';
|
|
import { Skeleton } from 'antd';
|
|
import { ExternalAction } from '../../../interfaces/external-action';
|
|
import { ActionButtonMenu } from '../../action-buttons/ActionButtonMenu/ActionButtonMenu';
|
|
import { ActionButtonRow } from '../../action-buttons/ActionButtonRow/ActionButtonRow';
|
|
import { FollowButton } from '../../action-buttons/FollowButton';
|
|
import { NotifyButton } from '../../action-buttons/NotifyButton';
|
|
import styles from './Content.module.scss';
|
|
import { ActionButton } from '../../action-buttons/ActionButton/ActionButton';
|
|
|
|
interface ActionButtonProps {
|
|
supportFediverseFeatures: boolean;
|
|
externalActions: ExternalAction[];
|
|
supportsBrowserNotifications: boolean;
|
|
showNotifyReminder: any;
|
|
setShowFollowModal: Dispatch<SetStateAction<boolean>>;
|
|
setShowNotifyModal: Dispatch<SetStateAction<boolean>>;
|
|
disableNotifyReminderPopup: () => void;
|
|
setExternalActionToDisplay: any;
|
|
externalActionSelected: (action: ExternalAction) => void;
|
|
}
|
|
|
|
const NotifyReminderPopup = dynamic(
|
|
() => import('../NotifyReminderPopup/NotifyReminderPopup').then(mod => mod.NotifyReminderPopup),
|
|
{
|
|
ssr: false,
|
|
loading: () => <Skeleton loading active paragraph={{ rows: 8 }} />,
|
|
},
|
|
);
|
|
|
|
const ActionButtons: FC<ActionButtonProps> = ({
|
|
supportFediverseFeatures,
|
|
supportsBrowserNotifications,
|
|
showNotifyReminder,
|
|
setShowFollowModal,
|
|
setShowNotifyModal,
|
|
disableNotifyReminderPopup,
|
|
externalActions,
|
|
setExternalActionToDisplay,
|
|
externalActionSelected,
|
|
}) => {
|
|
const externalActionButtons = externalActions.map(action => (
|
|
<ActionButton
|
|
key={action.url || action.html}
|
|
action={action}
|
|
externalActionSelected={externalActionSelected}
|
|
/>
|
|
));
|
|
|
|
return (
|
|
<>
|
|
<div className={styles.desktopActionButtons}>
|
|
<ActionButtonRow>
|
|
{externalActionButtons}
|
|
{supportFediverseFeatures && (
|
|
<FollowButton size="small" onClick={() => setShowFollowModal(true)} />
|
|
)}
|
|
{supportsBrowserNotifications && (
|
|
<NotifyReminderPopup
|
|
open={showNotifyReminder}
|
|
notificationClicked={() => setShowNotifyModal(true)}
|
|
notificationClosed={() => disableNotifyReminderPopup()}
|
|
>
|
|
<NotifyButton onClick={() => setShowNotifyModal(true)} />
|
|
</NotifyReminderPopup>
|
|
)}
|
|
</ActionButtonRow>
|
|
</div>
|
|
<div className={styles.mobileActionButtons}>
|
|
{(supportsBrowserNotifications ||
|
|
supportsBrowserNotifications ||
|
|
externalActionButtons.length > 0) && (
|
|
<ActionButtonMenu
|
|
className={styles.actionButtonMenu}
|
|
showFollowItem={supportFediverseFeatures}
|
|
showNotifyItem={supportsBrowserNotifications}
|
|
actions={externalActions}
|
|
externalActionSelected={setExternalActionToDisplay}
|
|
notifyItemSelected={() => setShowNotifyModal(true)}
|
|
followItemSelected={() => setShowFollowModal(true)}
|
|
/>
|
|
)}
|
|
</div>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default ActionButtons;
|