2022-04-27 23:19:20 -07:00
import React from 'react' ;
import { ComponentStory , ComponentMeta } from '@storybook/react' ;
2022-10-21 22:24:29 -07:00
import { action } from '@storybook/addon-actions' ;
2022-09-07 09:00:28 +02:00
import { ActionButton } from './ActionButton' ;
2022-04-27 23:19:20 -07:00
export default {
2022-05-17 14:24:48 -07:00
title : 'owncast/Components/Action Buttons/Single button' ,
2022-05-07 16:13:06 -07:00
component : ActionButton ,
2022-05-12 20:52:19 -07:00
parameters : {
docs : {
description : {
component : ` An **Action Button** or **External Action Button** is a button that is used to trigger either an internal or external action. Many will show a modal, but they can also open a new tab to allow navigating to external pages. They are rendered horizontally within the Action Button Row. ` ,
} ,
} ,
} ,
2022-05-07 16:13:06 -07:00
} as ComponentMeta < typeof ActionButton > ;
2022-04-27 23:19:20 -07:00
2022-10-21 22:24:29 -07:00
const itemSelected = a = > {
console . log ( 'itemSelected' , a ) ;
action ( a . title ) ;
} ;
const Template : ComponentStory < typeof ActionButton > = args = > (
< ActionButton externalActionSelected = { itemSelected } { ...args } / >
) ;
2022-04-27 23:19:20 -07:00
// eslint-disable-next-line @typescript-eslint/no-unused-vars
export const Example1 = Template . bind ( { } ) ;
Example1 . args = {
action : {
url : 'https://owncast.online/docs' ,
title : 'Documentation' ,
description : 'Owncast Documentation' ,
icon : 'https://owncast.online/images/logo.svg' ,
color : '#5232c8' ,
openExternally : false ,
} ,
} ;
export const Example2 = Template . bind ( { } ) ;
Example2 . args = {
action : {
url : 'https://opencollective.com/embed/owncast/donate' ,
title : 'Support Owncast' ,
description : 'Contribute to Owncast' ,
icon : 'https://opencollective.com/static/images/opencollective-icon.svg' ,
color : '#2b4863' ,
openExternally : false ,
} ,
} ;