2022-04-27 23:19:20 -07:00
import React from 'react' ;
import { ComponentStory , ComponentMeta } 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 >
) ;
export default {
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 .
` ,
} ,
} ,
} ,
2022-04-27 23:19:20 -07:00
} as ComponentMeta < typeof BrowserNotifyModal > ;
// eslint-disable-next-line @typescript-eslint/no-unused-vars
2023-05-20 21:15:25 -07:00
const Template : ComponentStory < typeof BrowserNotifyModal > = ( ) = > (
2022-05-29 21:52:38 -07:00
< RecoilRoot >
< Example / >
< / RecoilRoot >
) ;
2022-04-27 23:19:20 -07:00
// eslint-disable-next-line @typescript-eslint/no-unused-vars
export const Basic = Template . bind ( { } ) ;