2022-05-20 23:23:46 +03:00
|
|
|
import React from 'react';
|
|
|
|
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
2022-07-21 06:42:23 +03:00
|
|
|
import { RecoilRoot } from 'recoil';
|
2022-09-07 10:00:28 +03:00
|
|
|
import { ChatModerationDetailsModal } from './ChatModerationDetailsModal';
|
2022-05-20 23:23:46 +03:00
|
|
|
|
2022-07-21 06:42:23 +03:00
|
|
|
const mocks = {
|
|
|
|
mocks: [
|
|
|
|
{
|
|
|
|
// The "matcher" determines if this
|
|
|
|
// mock should respond to the current
|
|
|
|
// call to fetch().
|
|
|
|
matcher: {
|
|
|
|
name: 'response',
|
|
|
|
url: 'glob:/api/moderation/chat/user/*',
|
|
|
|
},
|
|
|
|
// If the "matcher" matches the current
|
|
|
|
// fetch() call, the fetch response is
|
|
|
|
// built using this "response".
|
|
|
|
response: {
|
|
|
|
status: 200,
|
|
|
|
body: {
|
|
|
|
user: {
|
|
|
|
id: 'hjFPU967R',
|
|
|
|
displayName: 'focused-snyder',
|
|
|
|
displayColor: 2,
|
|
|
|
createdAt: '2022-07-12T13:08:31.406505322-07:00',
|
|
|
|
previousNames: ['focused-snyder'],
|
|
|
|
scopes: ['MODERATOR'],
|
|
|
|
isBot: false,
|
|
|
|
authenticated: false,
|
|
|
|
},
|
|
|
|
connectedClients: [
|
|
|
|
{
|
|
|
|
messageCount: 3,
|
|
|
|
userAgent:
|
|
|
|
'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.127 Safari/537.36',
|
|
|
|
connectedAt: '2022-07-20T16:45:07.796685618-07:00',
|
|
|
|
geo: 'N/A',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
messages: [
|
|
|
|
{
|
|
|
|
id: 'bQp8UJR4R',
|
|
|
|
timestamp: '2022-07-20T16:53:41.938083228-07:00',
|
|
|
|
user: null,
|
|
|
|
body: 'test message 3',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'ubK88Jg4R',
|
|
|
|
timestamp: '2022-07-20T16:53:39.675531279-07:00',
|
|
|
|
user: null,
|
|
|
|
body: 'test message 2',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: '20v8UJRVR',
|
|
|
|
timestamp: '2022-07-20T16:53:37.551084121-07:00',
|
|
|
|
user: null,
|
|
|
|
body: 'test message 1',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
};
|
|
|
|
|
2022-05-20 23:23:46 +03:00
|
|
|
export default {
|
|
|
|
title: 'owncast/Chat/Moderation modal',
|
|
|
|
component: ChatModerationDetailsModal,
|
|
|
|
parameters: {
|
2022-07-21 06:42:23 +03:00
|
|
|
fetchMock: mocks,
|
2022-05-20 23:23:46 +03:00
|
|
|
docs: {
|
|
|
|
description: {
|
|
|
|
component: `This should be a modal that gives the moderator more details about the user such as:
|
|
|
|
- When the user was created
|
|
|
|
- Other names they've used
|
|
|
|
- If they're authenticated, and using what method (IndieAuth, FediAuth)
|
|
|
|
`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
} as ComponentMeta<typeof ChatModerationDetailsModal>;
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
2022-09-07 10:00:28 +03:00
|
|
|
const Template: ComponentStory<typeof ChatModerationDetailsModal> = () => (
|
2022-07-21 06:42:23 +03:00
|
|
|
<RecoilRoot>
|
|
|
|
<ChatModerationDetailsModal userId="testuser123" accessToken="fakeaccesstoken4839" />
|
|
|
|
</RecoilRoot>
|
2022-05-20 23:23:46 +03:00
|
|
|
);
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
2022-07-17 03:30:05 +03:00
|
|
|
export const Example = Template.bind({});
|