2023-11-07 12:35:05 +09:00
|
|
|
import { useEffect } from 'react';
|
|
|
|
import { StoryFn, Meta } from '@storybook/react';
|
2022-12-05 23:13:55 -08:00
|
|
|
import { RecoilRoot, useSetRecoilState } from 'recoil';
|
2022-09-07 09:00:28 +02:00
|
|
|
import { UserDropdown } from './UserDropdown';
|
2022-12-05 23:13:55 -08:00
|
|
|
import { CurrentUser } from '../../../interfaces/current-user';
|
|
|
|
import { currentUserAtom } from '../../stores/ClientConfigStore';
|
2022-04-27 23:19:20 -07:00
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
const meta = {
|
2022-05-17 14:24:48 -07:00
|
|
|
title: 'owncast/Components/User settings menu',
|
2022-05-08 09:41:47 +02:00
|
|
|
component: UserDropdown,
|
2022-04-27 23:19:20 -07:00
|
|
|
parameters: {},
|
2023-11-07 12:35:05 +09:00
|
|
|
} satisfies Meta<typeof UserDropdown>;
|
|
|
|
|
|
|
|
export default meta;
|
2022-04-27 23:19:20 -07:00
|
|
|
|
2022-04-29 15:09:53 -07:00
|
|
|
// This component uses Recoil internally so wrap it in a RecoilRoot.
|
2022-12-05 23:13:55 -08:00
|
|
|
const Example = args => {
|
|
|
|
const setCurrentUser = useSetRecoilState<CurrentUser>(currentUserAtom);
|
|
|
|
|
|
|
|
useEffect(
|
|
|
|
() =>
|
|
|
|
setCurrentUser({
|
|
|
|
id: '1',
|
|
|
|
displayName: 'Test User',
|
|
|
|
displayColor: 3,
|
|
|
|
isModerator: false,
|
|
|
|
}),
|
|
|
|
[],
|
|
|
|
);
|
|
|
|
|
2023-05-22 18:56:44 -07:00
|
|
|
return <UserDropdown id="user-menu" {...args} />;
|
2022-12-05 23:13:55 -08:00
|
|
|
};
|
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
const Template: StoryFn<typeof UserDropdown> = args => (
|
2022-04-29 15:09:53 -07:00
|
|
|
<RecoilRoot>
|
2022-12-05 23:13:55 -08:00
|
|
|
<Example {...args} />
|
2022-04-29 15:09:53 -07:00
|
|
|
</RecoilRoot>
|
|
|
|
);
|
2022-04-27 23:19:20 -07:00
|
|
|
|
2023-11-07 12:35:05 +09:00
|
|
|
export const ChatEnabled = {
|
|
|
|
render: Template,
|
|
|
|
|
|
|
|
args: {
|
|
|
|
username: 'test-user',
|
|
|
|
},
|
2022-04-29 15:09:53 -07:00
|
|
|
};
|