2022-05-20 12:32:26 -07:00
|
|
|
import React from 'react';
|
|
|
|
import { ComponentStory, ComponentMeta } 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
|
|
|
|
|
|
|
export default {
|
|
|
|
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.`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
} as ComponentMeta<typeof OfflineBanner>;
|
|
|
|
|
2022-10-08 15:05:52 -07:00
|
|
|
const Template: ComponentStory<typeof OfflineBanner> = args => (
|
|
|
|
<RecoilRoot>
|
|
|
|
<OfflineBanner {...args} />
|
|
|
|
</RecoilRoot>
|
|
|
|
);
|
2022-05-20 12:32:26 -07:00
|
|
|
|
2022-10-08 15:05:52 -07:00
|
|
|
export const ExampleDefaultWithNotifications = Template.bind({});
|
|
|
|
ExampleDefaultWithNotifications.args = {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: true,
|
|
|
|
lastLive: new Date(),
|
2022-05-20 12:32:26 -07:00
|
|
|
};
|
|
|
|
|
2022-10-08 15:05:52 -07:00
|
|
|
export const ExampleDefaultWithDateAndFediverse = Template.bind({});
|
|
|
|
ExampleDefaultWithDateAndFediverse.args = {
|
|
|
|
streamName: 'Dull stream 31337',
|
|
|
|
lastLive: new Date(),
|
|
|
|
notificationsEnabled: false,
|
|
|
|
fediverseAccount: 'streamer@coolstream.biz',
|
|
|
|
};
|
|
|
|
|
|
|
|
export const ExampleCustomWithDateAndNotifications = Template.bind({});
|
|
|
|
ExampleCustomWithDateAndNotifications.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,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const ExampleDefaultWithNotificationsAndFediverse = Template.bind({});
|
|
|
|
ExampleDefaultWithNotificationsAndFediverse.args = {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: true,
|
|
|
|
fediverseAccount: 'streamer@coolstream.biz',
|
|
|
|
lastLive: new Date(),
|
|
|
|
};
|
|
|
|
|
|
|
|
export const ExampleDefaultWithoutNotifications = Template.bind({});
|
|
|
|
ExampleDefaultWithoutNotifications.args = {
|
|
|
|
streamName: 'Cool stream 42',
|
|
|
|
notificationsEnabled: false,
|
|
|
|
lastLive: new Date(),
|
|
|
|
};
|
|
|
|
|
|
|
|
export const ExampleCustomTextWithoutNotifications = Template.bind({});
|
|
|
|
ExampleCustomTextWithoutNotifications.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
|
|
|
};
|