import { Meta, StoryFn, StoryObj } from '@storybook/react'; import { MutableSnapshot, RecoilRoot } from 'recoil'; import { makeEmptyClientConfig } from '../../../interfaces/client-config.model'; import { ServerStatus, makeEmptyServerStatus } from '../../../interfaces/server-status.model'; import { accessTokenAtom, appStateAtom, chatMessagesAtom, ChatState, chatStateAtom, clientConfigStateAtom, currentUserAtom, fatalErrorStateAtom, isMobileAtom, isVideoPlayingAtom, serverStatusState, } from '../../stores/ClientConfigStore'; import { Main } from './Main'; import { ClientConfigServiceContext } from '../../../services/client-config-service'; import { ChatServiceContext } from '../../../services/chat-service'; import { ServerStatusServiceContext, ServerStatusStaticService, } from '../../../services/status-service'; import { clientConfigServiceMockOf } from '../../../services/client-config-service.mock'; import chatServiceMockOf from '../../../services/chat-service.mock'; import serverStatusServiceMockOf from '../../../services/status-service.mock'; import { VideoSettingsServiceContext } from '../../../services/video-settings-service'; import videoSettingsServiceMockOf from '../../../services/video-settings-service.mock'; import { spidermanUser } from '../../../interfaces/user.fixture'; import { exampleChatHistory } from '../../../interfaces/chat-message.fixture'; const meta = { title: 'owncast/Layout/Main', parameters: { layout: 'fullscreen', }, } satisfies Meta; export default meta; // mock the Websocket to prevent ani webhook calls from being made in storybook // @ts-ignore window.WebSocket = () => {}; type StateInitializer = (mutableState: MutableSnapshot) => void; const composeStateInitializers = (...fns: Array): StateInitializer => state => fns.forEach(fn => fn?.(state)); const defaultClientConfig = { ...makeEmptyClientConfig(), logo: 'http://localhost:8080/logo', name: "Spiderman's super serious stream", summary: 'Strong Spidey stops supervillains! Streamed Saturdays & Sundays.', extraPageContent: 'Spiderman is **cool**', }; const defaultServerStatus = makeEmptyServerStatus(); const onlineServerStatus: ServerStatus = { ...defaultServerStatus, online: true, viewerCount: 5, }; const initializeDefaultState = (mutableState: MutableSnapshot) => { mutableState.set(appStateAtom, { videoAvailable: false, chatAvailable: false, }); mutableState.set(clientConfigStateAtom, defaultClientConfig); mutableState.set(chatStateAtom, ChatState.VISIBLE); mutableState.set(accessTokenAtom, 'token'); mutableState.set(currentUserAtom, { ...spidermanUser, isModerator: false, }); mutableState.set(serverStatusState, defaultServerStatus); mutableState.set(isMobileAtom, false); mutableState.set(chatMessagesAtom, exampleChatHistory); mutableState.set(isVideoPlayingAtom, false); mutableState.set(fatalErrorStateAtom, null); }; const ClientConfigServiceMock = clientConfigServiceMockOf(defaultClientConfig); const ChatServiceMock = chatServiceMockOf(exampleChatHistory, { ...spidermanUser, accessToken: 'some fake token', }); const DefaultServerStatusServiceMock = serverStatusServiceMockOf(defaultServerStatus); const OnlineServerStatusServiceMock = serverStatusServiceMockOf(onlineServerStatus); const VideoSettingsServiceMock = videoSettingsServiceMockOf([]); const Template: StoryFn = ({ initializeState, ServerStatusServiceMock = DefaultServerStatusServiceMock, ...args }: { initializeState: (mutableState: MutableSnapshot) => void; ServerStatusServiceMock: ServerStatusStaticService; }) => (
); export const OfflineDesktop: StoryObj = { render: Template, parameters: { chromatic: { diffThreshold: 0.88 }, }, }; export const OfflineMobile: StoryObj = { render: Template, args: { initializeState: (mutableState: MutableSnapshot) => { mutableState.set(isMobileAtom, true); }, }, parameters: { viewport: { defaultViewport: 'mobile1', }, }, }; export const OfflineTablet: StoryObj = { render: Template, parameters: { viewport: { defaultViewport: 'tablet', }, }, }; export const Online: StoryObj = { render: Template, args: { ServerStatusServiceMock: OnlineServerStatusServiceMock, }, parameters: { chromatic: { diffThreshold: 0.88 }, }, }; export const OnlineMobile: StoryObj = { render: Template, args: { ServerStatusServiceMock: OnlineServerStatusServiceMock, initializeState: (mutableState: MutableSnapshot) => { mutableState.set(isMobileAtom, true); }, }, parameters: { viewport: { defaultViewport: 'mobile1', }, }, }; export const OnlineTablet: StoryObj = { render: Template, args: { ServerStatusServiceMock: OnlineServerStatusServiceMock, }, parameters: { viewport: { defaultViewport: 'tablet', }, }, };