| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import React, { useCallback, useEffect, useState } from 'react'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { AvatarColorPicker } from './AvatarColorPicker'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { AvatarColorType } from '../types/Colors'; | 
					
						
							|  |  |  | import type { AvatarDataType } from '../types/Avatar'; | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  | import { AvatarModalButtons } from './AvatarModalButtons'; | 
					
						
							|  |  |  | import { AvatarPreview } from './AvatarPreview'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { LocalizerType } from '../types/Util'; | 
					
						
							| 
									
										
										
										
											2021-09-23 17:49:05 -07:00
										 |  |  | import { avatarDataToBytes } from '../util/avatarDataToBytes'; | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = { | 
					
						
							|  |  |  |   avatarData: AvatarDataType; | 
					
						
							|  |  |  |   i18n: LocalizerType; | 
					
						
							|  |  |  |   onClose: (avatarData?: AvatarDataType) => unknown; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function AvatarIconEditor({ | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  |   avatarData: initialAvatarData, | 
					
						
							|  |  |  |   i18n, | 
					
						
							|  |  |  |   onClose, | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | }: PropsType): JSX.Element { | 
					
						
							| 
									
										
										
										
											2021-09-23 17:49:05 -07:00
										 |  |  |   const [avatarBuffer, setAvatarBuffer] = useState<Uint8Array | undefined>(); | 
					
						
							| 
									
										
										
										
											2021-11-11 16:43:05 -06:00
										 |  |  |   const [avatarData, setAvatarData] = | 
					
						
							|  |  |  |     useState<AvatarDataType>(initialAvatarData); | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const onColorSelected = useCallback( | 
					
						
							|  |  |  |     (color: AvatarColorType) => { | 
					
						
							|  |  |  |       setAvatarData({ | 
					
						
							|  |  |  |         ...avatarData, | 
					
						
							|  |  |  |         color, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     [avatarData] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     let shouldCancel = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async function loadAvatar() { | 
					
						
							| 
									
										
										
										
											2021-09-23 17:49:05 -07:00
										 |  |  |       const buffer = await avatarDataToBytes(avatarData); | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  |       if (!shouldCancel) { | 
					
						
							|  |  |  |         setAvatarBuffer(buffer); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-12-21 10:41:48 -08:00
										 |  |  |     void loadAvatar(); | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return () => { | 
					
						
							|  |  |  |       shouldCancel = true; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, [avatarData, setAvatarBuffer]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const hasChanges = avatarData !== initialAvatarData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <AvatarPreview | 
					
						
							|  |  |  |         avatarColor={avatarData.color} | 
					
						
							|  |  |  |         avatarValue={avatarBuffer} | 
					
						
							|  |  |  |         conversationTitle={avatarData.text} | 
					
						
							|  |  |  |         i18n={i18n} | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |       <hr className="AvatarEditor__divider" /> | 
					
						
							| 
									
										
										
										
											2021-08-06 17:35:25 -04:00
										 |  |  |       <AvatarColorPicker | 
					
						
							|  |  |  |         i18n={i18n} | 
					
						
							|  |  |  |         onColorSelected={onColorSelected} | 
					
						
							|  |  |  |         selectedColor={avatarData.color} | 
					
						
							|  |  |  |       /> | 
					
						
							| 
									
										
										
										
											2021-08-05 20:17:05 -04:00
										 |  |  |       <AvatarModalButtons | 
					
						
							|  |  |  |         hasChanges={hasChanges} | 
					
						
							|  |  |  |         i18n={i18n} | 
					
						
							|  |  |  |         onCancel={onClose} | 
					
						
							|  |  |  |         onSave={() => | 
					
						
							|  |  |  |           onClose({ | 
					
						
							|  |  |  |             ...avatarData, | 
					
						
							|  |  |  |             buffer: avatarBuffer, | 
					
						
							|  |  |  |           }) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } |