2023-11-07 12:35:05 +09:00
import { StoryFn , Meta } from '@storybook/react' ;
2022-05-29 21:52:38 -07:00
import { RecoilRoot } from 'recoil' ;
2022-09-07 09:00:28 +02:00
import { BrowserNotifyModal } from './BrowserNotifyModal' ;
2022-09-03 20:38:52 +02:00
import BrowserNotifyModalMock from '../../../stories/assets/mocks/notify-modal.png' ;
2022-04-27 23:19:20 -07:00
const Example = ( ) = > (
< div >
2022-05-12 14:45:56 -07:00
< BrowserNotifyModal / >
2022-04-27 23:19:20 -07:00
< / div >
) ;
2023-11-07 12:35:05 +09:00
const meta = {
2022-05-12 14:45:56 -07:00
title : 'owncast/Modals/Browser Notifications' ,
2022-04-27 23:19:20 -07:00
component : BrowserNotifyModal ,
2022-05-12 20:52:19 -07:00
parameters : {
2023-03-12 22:10:17 -07:00
chromatic : { diffThreshold : 0.9 } ,
2022-05-12 20:52:19 -07:00
design : {
type : 'image' ,
url : BrowserNotifyModalMock ,
scale : 0.5 ,
} ,
docs : {
description : {
component : ` The notify modal allows an end user to get notified when the stream goes live via [Browser Push Notifications](https://developers.google.com/web/ilt/pwa/introduction-to-push-notifications) It must:
2022-09-03 20:38:52 +02:00
2022-05-12 20:52:19 -07:00
- Verify the browser supports notifications .
- Handle errors that come back from the server .
- Have an enabled and disabled state with accurate information about each .
` ,
} ,
} ,
} ,
2023-11-07 12:35:05 +09:00
} satisfies Meta < typeof BrowserNotifyModal > ;
2022-04-27 23:19:20 -07:00
2023-11-07 12:35:05 +09:00
export default meta ;
const Template : StoryFn < typeof BrowserNotifyModal > = ( ) = > (
2022-05-29 21:52:38 -07:00
< RecoilRoot >
< Example / >
< / RecoilRoot >
) ;
2022-04-27 23:19:20 -07:00
2023-11-07 12:35:05 +09:00
export const Basic = {
render : Template ,
} ;