| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | // Copyright 2022 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | import type { Meta, ReactRenderer, StoryFn } from '@storybook/react'; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | import type { PlayFunction } from '@storybook/csf'; | 
					
						
							|  |  |  | import React from 'react'; | 
					
						
							|  |  |  | import { v4 as uuid } from 'uuid'; | 
					
						
							| 
									
										
										
										
											2024-07-08 11:23:27 -07:00
										 |  |  | import { expect, fn, within, userEvent } from '@storybook/test'; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | import { action } from '@storybook/addon-actions'; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | import type { PropsType } from './MyStories'; | 
					
						
							|  |  |  | import enMessages from '../../_locales/en/messages.json'; | 
					
						
							| 
									
										
										
										
											2022-11-10 08:51:39 -07:00
										 |  |  | import { MY_STORY_ID } from '../types/Stories'; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | import { MyStories } from './MyStories'; | 
					
						
							| 
									
										
										
										
											2022-11-16 17:10:11 -05:00
										 |  |  | import { SendStatus } from '../messages/MessageSendState'; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation'; | 
					
						
							|  |  |  | import { getFakeMyStory } from '../test-both/helpers/getFakeStory'; | 
					
						
							|  |  |  | import { setupI18n } from '../util/setupI18n'; | 
					
						
							|  |  |  | import { sleep } from '../util/sleep'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const i18n = setupI18n('en', enMessages); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   title: 'Components/MyStories', | 
					
						
							|  |  |  |   component: MyStories, | 
					
						
							|  |  |  |   argTypes: { | 
					
						
							| 
									
										
										
										
											2022-10-25 15:18:42 -07:00
										 |  |  |     hasViewReceiptSetting: { | 
					
						
							|  |  |  |       control: 'boolean', | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  |   }, | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   args: { | 
					
						
							|  |  |  |     i18n, | 
					
						
							| 
									
										
										
										
											2024-07-08 11:23:27 -07:00
										 |  |  |     onBack: fn(action('onBack')), | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |     onDelete: action('onDelete'), | 
					
						
							| 
									
										
										
										
											2024-07-08 11:23:27 -07:00
										 |  |  |     onForward: fn(action('onForward')), | 
					
						
							|  |  |  |     onSave: fn(action('onSave')), | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |     hasViewReceiptSetting: false, | 
					
						
							| 
									
										
										
										
											2024-01-29 12:09:54 -08:00
										 |  |  |     renderToastManager: () => <i />, | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |     queueStoryDownload: action('queueStoryDownload'), | 
					
						
							|  |  |  |     retryMessageSend: action('retryMessageSend'), | 
					
						
							|  |  |  |     viewStory: action('viewStory'), | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | } satisfies Meta<PropsType>; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | // eslint-disable-next-line react/function-component-definition
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | const Template: StoryFn<PropsType> = args => <MyStories {...args} />; | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const NoStories = Template.bind({}); | 
					
						
							|  |  |  | NoStories.args = { | 
					
						
							|  |  |  |   myStories: [], | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | const interactionTest: PlayFunction<ReactRenderer, PropsType> = async ({ | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  |   args, | 
					
						
							|  |  |  |   canvasElement, | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const canvas = within(canvasElement); | 
					
						
							|  |  |  |   const [btnDownload] = canvas.getAllByLabelText('Download story'); | 
					
						
							|  |  |  |   await userEvent.click(btnDownload); | 
					
						
							|  |  |  |   await expect(args.onSave).toHaveBeenCalled(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   const btnBack = canvas.getByText('Back'); | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  |   await userEvent.click(btnBack); | 
					
						
							|  |  |  |   await expect(args.onBack).toHaveBeenCalled(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const [btnCtxMenu] = canvas.getAllByLabelText('Context menu'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   await userEvent.click(btnCtxMenu); | 
					
						
							|  |  |  |   await sleep(300); | 
					
						
							|  |  |  |   const [btnFwd] = canvas.getAllByLabelText('Forward'); | 
					
						
							|  |  |  |   await userEvent.click(btnFwd); | 
					
						
							|  |  |  |   await expect(args.onForward).toHaveBeenCalled(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const SingleListStories = Template.bind({}); | 
					
						
							|  |  |  | SingleListStories.args = { | 
					
						
							| 
									
										
										
										
											2022-11-10 08:51:39 -07:00
										 |  |  |   myStories: [getFakeMyStory(MY_STORY_ID)], | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | SingleListStories.play = interactionTest; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const MultiListStories = Template.bind({}); | 
					
						
							|  |  |  | MultiListStories.args = { | 
					
						
							|  |  |  |   myStories: [ | 
					
						
							| 
									
										
										
										
											2022-11-10 08:51:39 -07:00
										 |  |  |     getFakeMyStory(MY_STORY_ID), | 
					
						
							| 
									
										
										
										
											2022-06-30 20:52:03 -04:00
										 |  |  |     getFakeMyStory(uuid(), 'Cool Peeps'), | 
					
						
							|  |  |  |     getFakeMyStory(uuid(), 'Family'), | 
					
						
							|  |  |  |   ], | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | MultiListStories.play = interactionTest; | 
					
						
							| 
									
										
										
										
											2022-11-16 17:10:11 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const FailedSentStory = Template.bind({}); | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   const myStory = getFakeMyStory(MY_STORY_ID); | 
					
						
							|  |  |  |   FailedSentStory.args = { | 
					
						
							|  |  |  |     myStories: [ | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         ...myStory, | 
					
						
							|  |  |  |         stories: myStory.stories.map((story, index) => { | 
					
						
							|  |  |  |           if (index === 0) { | 
					
						
							|  |  |  |             return { | 
					
						
							|  |  |  |               ...story, | 
					
						
							|  |  |  |               sendState: [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                   recipient: getDefaultConversation(), | 
					
						
							|  |  |  |                   status: SendStatus.Failed, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |               ], | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           return story; | 
					
						
							|  |  |  |         }), | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       getFakeMyStory(uuid(), 'Cool Peeps'), | 
					
						
							|  |  |  |     ], | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } |