| 
									
										
										
										
											2023-01-03 11:55:46 -08:00
										 |  |  | // Copyright 2020 Signal Messenger, LLC
 | 
					
						
							| 
									
										
										
										
											2020-10-30 15:34:04 -05:00
										 |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | import * as React from 'react'; | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | import type { Meta } from '@storybook/react'; | 
					
						
							| 
									
										
										
										
											2022-11-16 12:18:02 -08:00
										 |  |  | import { DurationInSeconds } from '../../util/durations'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { Props } from './TimerNotification'; | 
					
						
							|  |  |  | import { TimerNotification } from './TimerNotification'; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 12:52:08 -07:00
										 |  |  | const { i18n } = window.SignalContext; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export default { | 
					
						
							|  |  |  |   title: 'Components/Conversation/TimerNotification', | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   argTypes: { | 
					
						
							|  |  |  |     type: { | 
					
						
							|  |  |  |       control: { type: 'select' }, | 
					
						
							|  |  |  |       options: ['fromOther', 'fromMe', 'fromSync'], | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |     disabled: { control: { type: 'boolean' } }, | 
					
						
							|  |  |  |     expireTimer: { control: { type: 'number' } }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   args: { | 
					
						
							|  |  |  |     i18n, | 
					
						
							|  |  |  |     type: 'fromOther', | 
					
						
							|  |  |  |     title: '', | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							|  |  |  |     expireTimer: DurationInSeconds.fromHours(0), | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | } satisfies Meta<Props>; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | export function SetByOther(args: Props): JSX.Element { | 
					
						
							|  |  |  |   const props: Props = { | 
					
						
							|  |  |  |     ...args, | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							| 
									
										
										
										
											2022-11-16 12:18:02 -08:00
										 |  |  |     expireTimer: DurationInSeconds.fromHours(1), | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     type: 'fromOther', | 
					
						
							|  |  |  |     title: 'Mr. Fire', | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <TimerNotification {...props} /> | 
					
						
							|  |  |  |       <div style={{ padding: '1em' }} /> | 
					
						
							| 
									
										
										
										
											2021-05-03 18:24:40 -05:00
										 |  |  |       <TimerNotification {...props} disabled /> | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | export function SetByOtherWithALongName(args: Props): JSX.Element { | 
					
						
							| 
									
										
										
										
											2021-09-02 16:23:27 -05:00
										 |  |  |   const longName = '🦴🧩📴'.repeat(50); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   const props: Props = { | 
					
						
							|  |  |  |     ...args, | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							| 
									
										
										
										
											2022-11-16 12:18:02 -08:00
										 |  |  |     expireTimer: DurationInSeconds.fromHours(1), | 
					
						
							| 
									
										
										
										
											2021-09-02 16:23:27 -05:00
										 |  |  |     type: 'fromOther', | 
					
						
							|  |  |  |     title: longName, | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2021-09-02 16:23:27 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <TimerNotification {...props} /> | 
					
						
							|  |  |  |       <div style={{ padding: '1em' }} /> | 
					
						
							|  |  |  |       <TimerNotification {...props} disabled /> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | export function SetByYou(args: Props): JSX.Element { | 
					
						
							|  |  |  |   const props: Props = { | 
					
						
							|  |  |  |     ...args, | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							| 
									
										
										
										
											2022-11-16 12:18:02 -08:00
										 |  |  |     expireTimer: DurationInSeconds.fromHours(1), | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     type: 'fromMe', | 
					
						
							|  |  |  |     title: 'Mr. Fire', | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <TimerNotification {...props} /> | 
					
						
							|  |  |  |       <div style={{ padding: '1em' }} /> | 
					
						
							| 
									
										
										
										
											2021-05-03 18:24:40 -05:00
										 |  |  |       <TimerNotification {...props} disabled /> | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  | export function SetBySync(args: Props): JSX.Element { | 
					
						
							|  |  |  |   const props: Props = { | 
					
						
							|  |  |  |     ...args, | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							| 
									
										
										
										
											2022-11-16 12:18:02 -08:00
										 |  |  |     expireTimer: DurationInSeconds.fromHours(1), | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     type: 'fromSync', | 
					
						
							|  |  |  |     title: 'Mr. Fire', | 
					
						
							| 
									
										
										
										
											2023-10-11 12:06:43 -07:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <TimerNotification {...props} /> | 
					
						
							|  |  |  |       <div style={{ padding: '1em' }} /> | 
					
						
							| 
									
										
										
										
											2021-05-03 18:24:40 -05:00
										 |  |  |       <TimerNotification {...props} disabled /> | 
					
						
							| 
									
										
										
										
											2020-08-25 17:41:43 -07:00
										 |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-18 13:01:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | export function SetByUnknownContact(args: Props): JSX.Element { | 
					
						
							|  |  |  |   const props: Props = { | 
					
						
							|  |  |  |     ...args, | 
					
						
							|  |  |  |     disabled: false, | 
					
						
							|  |  |  |     expireTimer: DurationInSeconds.fromHours(1), | 
					
						
							|  |  |  |     type: 'fromMember', | 
					
						
							|  |  |  |     title: 'Unknown contact', | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <TimerNotification {...props} /> | 
					
						
							|  |  |  |       <div style={{ padding: '1em' }} /> | 
					
						
							|  |  |  |       <TimerNotification {...props} disabled /> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } |