Fix user avatar and banner selector on web (#490)
This commit is contained in:
		
							parent
							
								
									c8157d6d38
								
							
						
					
					
						commit
						1ab8f31517
					
				
					 3 changed files with 11 additions and 9 deletions
				
			
		|  | @ -14,7 +14,7 @@ interface PickedFile { | ||||||
| 
 | 
 | ||||||
| export async function openPicker( | export async function openPicker( | ||||||
|   _store: RootStoreModel, |   _store: RootStoreModel, | ||||||
|   opts: PickerOpts, |   opts?: PickerOpts, | ||||||
| ): Promise<RNImage[]> { | ): Promise<RNImage[]> { | ||||||
|   const res = await selectFile(opts) |   const res = await selectFile(opts) | ||||||
|   const dim = await getImageDim(res.uri) |   const dim = await getImageDim(res.uri) | ||||||
|  | @ -70,11 +70,11 @@ export async function openCropper( | ||||||
|  *   src/lib/hooks/usePermissions.ts |  *   src/lib/hooks/usePermissions.ts | ||||||
|  * so that it gets appropriately updated. |  * so that it gets appropriately updated. | ||||||
|  */ |  */ | ||||||
| function selectFile(opts: PickerOpts): Promise<PickedFile> { | function selectFile(opts?: PickerOpts): Promise<PickedFile> { | ||||||
|   return new Promise((resolve, reject) => { |   return new Promise((resolve, reject) => { | ||||||
|     var input = document.createElement('input') |     var input = document.createElement('input') | ||||||
|     input.type = 'file' |     input.type = 'file' | ||||||
|     input.accept = opts.mediaType === 'photo' ? 'image/*' : '*/*' |     input.accept = opts?.mediaType === 'photo' ? 'image/*' : '*/*' | ||||||
|     input.onchange = e => { |     input.onchange = e => { | ||||||
|       const target = e.target as HTMLInputElement |       const target = e.target as HTMLInputElement | ||||||
|       const file = target?.files?.[0] |       const file = target?.files?.[0] | ||||||
|  |  | ||||||
|  | @ -79,7 +79,10 @@ export function UserAvatar({ | ||||||
|         if (!(await requestPhotoAccessIfNeeded())) { |         if (!(await requestPhotoAccessIfNeeded())) { | ||||||
|           return |           return | ||||||
|         } |         } | ||||||
|         const items = await openPicker(store) |         const items = await openPicker(store, { | ||||||
|  |           mediaType: 'photo', | ||||||
|  |           multiple: false, | ||||||
|  |         }) | ||||||
| 
 | 
 | ||||||
|         onSelectNewAvatar?.( |         onSelectNewAvatar?.( | ||||||
|           await openCropper(store, { |           await openCropper(store, { | ||||||
|  |  | ||||||
|  | @ -38,9 +38,7 @@ export function UserBanner({ | ||||||
|         } |         } | ||||||
|         onSelectNewBanner?.( |         onSelectNewBanner?.( | ||||||
|           await openCamera(store, { |           await openCamera(store, { | ||||||
|             // compressImageMaxWidth: 3000, TODO needed?
 |  | ||||||
|             width: 3000, |             width: 3000, | ||||||
|             // compressImageMaxHeight: 1000, TODO needed?
 |  | ||||||
|             height: 1000, |             height: 1000, | ||||||
|           }), |           }), | ||||||
|         ) |         ) | ||||||
|  | @ -54,14 +52,15 @@ export function UserBanner({ | ||||||
|         if (!(await requestPhotoAccessIfNeeded())) { |         if (!(await requestPhotoAccessIfNeeded())) { | ||||||
|           return |           return | ||||||
|         } |         } | ||||||
|         const items = await openPicker(store) |         const items = await openPicker(store, { | ||||||
|  |           mediaType: 'photo', | ||||||
|  |           multiple: false, | ||||||
|  |         }) | ||||||
|         onSelectNewBanner?.( |         onSelectNewBanner?.( | ||||||
|           await openCropper(store, { |           await openCropper(store, { | ||||||
|             mediaType: 'photo', |             mediaType: 'photo', | ||||||
|             path: items[0].path, |             path: items[0].path, | ||||||
|             // compressImageMaxWidth: 3000, TODO needed?
 |  | ||||||
|             width: 3000, |             width: 3000, | ||||||
|             // compressImageMaxHeight: 1000, TODO needed?
 |  | ||||||
|             height: 1000, |             height: 1000, | ||||||
|           }), |           }), | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue