2023-11-07 12:35:05 +09:00
|
|
|
import { StoryFn, Meta } from '@storybook/react';
|
2022-10-08 15:05:52 -07:00
|
|
|
import { RecoilRoot } from 'recoil';
|
2022-09-07 09:00:28 +02:00
|
|
|
import { OfflineBanner } from './OfflineBanner';
|
2022-09-03 20:38:52 +02:00
|
|
|
import OfflineState from '../../../stories/assets/mocks/offline-state.png';
|
2022-05-20 12:32:26 -07:00
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
const meta = {
|
2022-05-20 12:32:26 -07:00
|
|
|
title: 'owncast/Layout/Offline Banner',
|
|
|
|
component: OfflineBanner,
|
|
|
|
parameters: {
|
|
|
|
design: {
|
|
|
|
type: 'image',
|
|
|
|
url: OfflineState,
|
|
|
|
scale: 0.5,
|
|
|
|
},
|
|
|
|
docs: {
|
|
|
|
description: {
|
|
|
|
component: `When the stream is offline the player should be replaced by this banner that can support custom text and notify actions.`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2023-11-07 12:35:05 +09:00
|
|
|
} satisfies Meta<typeof OfflineBanner>;
|
2022-05-20 12:32:26 -07:00
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export default meta;
|
|
|
|
|
|
|
|
const Template: StoryFn<typeof OfflineBanner> = args => (
|
2022-10-08 15:05:52 -07:00
|
|
|
<RecoilRoot>
|
|
|
|
<OfflineBanner {...args} />
|
|
|
|
</RecoilRoot>
|
|
|
|
);
|
2022-05-20 12:32:26 -07:00
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleDefaultWithNotifications = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: true,
|
|
|
|
lastLive: new Date(),
|
|
|
|
},
|
2022-05-20 12:32:26 -07:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleDefaultWithDateAndFediverse = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Dull stream 31337',
|
|
|
|
lastLive: new Date(),
|
|
|
|
notificationsEnabled: false,
|
|
|
|
fediverseAccount: 'streamer@coolstream.biz',
|
|
|
|
},
|
2022-10-08 15:05:52 -07:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleCustomWithDateAndNotifications = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Dull stream 31337',
|
|
|
|
customText:
|
|
|
|
'This is some example offline text that a streamer can leave for a visitor of the page.',
|
|
|
|
lastLive: new Date(),
|
|
|
|
notificationsEnabled: true,
|
|
|
|
},
|
2022-10-08 15:05:52 -07:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleDefaultWithNotificationsAndFediverse = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: true,
|
|
|
|
fediverseAccount: 'streamer@coolstream.biz',
|
|
|
|
lastLive: new Date(),
|
|
|
|
},
|
2022-10-08 15:05:52 -07:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleDefaultWithoutNotifications = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: false,
|
|
|
|
lastLive: new Date(),
|
|
|
|
},
|
2022-10-08 15:05:52 -07:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ExampleCustomTextWithoutNotifications = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
streamName: 'Dull stream 31337',
|
|
|
|
customText:
|
|
|
|
'This is some example offline text that a streamer can leave for a visitor of the page.',
|
|
|
|
},
|
2022-05-20 12:32:26 -07:00
|
|
|
};
|