fix: Fix glitchy iOS media attachment drag interactions (#35057)
This commit is contained in:
		
					parent
					
						
							
								af6ee7f230
							
						
					
				
			
			
				commit
				
					
						69f298731e
					
				
			
		
					 3 changed files with 51 additions and 38 deletions
				
			
		|  | @ -22,10 +22,11 @@ import { useAppDispatch, useAppSelector } from 'mastodon/store'; | |||
| export const Upload: React.FC<{ | ||||
|   id: string; | ||||
|   dragging?: boolean; | ||||
|   draggable?: boolean; | ||||
|   overlay?: boolean; | ||||
|   tall?: boolean; | ||||
|   wide?: boolean; | ||||
| }> = ({ id, dragging, overlay, tall, wide }) => { | ||||
| }> = ({ id, dragging, draggable = true, overlay, tall, wide }) => { | ||||
|   const dispatch = useAppDispatch(); | ||||
|   const media = useAppSelector((state) => | ||||
|     ( | ||||
|  | @ -71,6 +72,7 @@ export const Upload: React.FC<{ | |||
|     <div | ||||
|       className={classNames('compose-form__upload media-gallery__item', { | ||||
|         dragging, | ||||
|         draggable, | ||||
|         overlay, | ||||
|         'media-gallery__item--tall': tall, | ||||
|         'media-gallery__item--wide': wide, | ||||
|  |  | |||
|  | @ -116,6 +116,10 @@ export const UploadForm: React.FC = () => { | |||
|     [dispatch, setActiveId], | ||||
|   ); | ||||
| 
 | ||||
|   const handleDragCancel = useCallback(() => { | ||||
|     setActiveId(null); | ||||
|   }, [setActiveId]); | ||||
| 
 | ||||
|   const accessibility: { | ||||
|     screenReaderInstructions: ScreenReaderInstructions; | ||||
|     announcements: Announcements; | ||||
|  | @ -158,32 +162,46 @@ export const UploadForm: React.FC = () => { | |||
|         <div | ||||
|           className={`compose-form__uploads media-gallery media-gallery--layout-${mediaIds.size}`} | ||||
|         > | ||||
|           <DndContext | ||||
|             sensors={sensors} | ||||
|             collisionDetection={closestCenter} | ||||
|             onDragStart={handleDragStart} | ||||
|             onDragEnd={handleDragEnd} | ||||
|             accessibility={accessibility} | ||||
|           > | ||||
|             <SortableContext | ||||
|               items={mediaIds.toArray()} | ||||
|               strategy={rectSortingStrategy} | ||||
|           {mediaIds.size === 1 ? ( | ||||
|             <Upload | ||||
|               id={mediaIds.first()} | ||||
|               dragging={false} | ||||
|               draggable={false} | ||||
|               tall | ||||
|               wide | ||||
|             /> | ||||
|           ) : ( | ||||
|             <DndContext | ||||
|               sensors={sensors} | ||||
|               collisionDetection={closestCenter} | ||||
|               onDragStart={handleDragStart} | ||||
|               onDragEnd={handleDragEnd} | ||||
|               onDragCancel={handleDragCancel} | ||||
|               onDragAbort={handleDragCancel} | ||||
|               accessibility={accessibility} | ||||
|             > | ||||
|               {mediaIds.map((id, idx) => ( | ||||
|                 <Upload | ||||
|                   key={id} | ||||
|                   id={id} | ||||
|                   dragging={id === activeId} | ||||
|                   tall={mediaIds.size < 3 || (mediaIds.size === 3 && idx === 0)} | ||||
|                   wide={mediaIds.size === 1} | ||||
|                 /> | ||||
|               ))} | ||||
|             </SortableContext> | ||||
|               <SortableContext | ||||
|                 items={mediaIds.toArray()} | ||||
|                 strategy={rectSortingStrategy} | ||||
|               > | ||||
|                 {mediaIds.map((id, idx) => ( | ||||
|                   <Upload | ||||
|                     key={id} | ||||
|                     id={id} | ||||
|                     dragging={id === activeId} | ||||
|                     tall={ | ||||
|                       mediaIds.size < 3 || (mediaIds.size === 3 && idx === 0) | ||||
|                     } | ||||
|                     wide={mediaIds.size === 1} | ||||
|                   /> | ||||
|                 ))} | ||||
|               </SortableContext> | ||||
| 
 | ||||
|             <DragOverlay> | ||||
|               {activeId ? <Upload id={activeId as string} overlay /> : null} | ||||
|             </DragOverlay> | ||||
|           </DndContext> | ||||
|               <DragOverlay> | ||||
|                 {activeId ? <Upload id={activeId as string} overlay /> : null} | ||||
|               </DragOverlay> | ||||
|             </DndContext> | ||||
|           )} | ||||
|         </div> | ||||
|       )} | ||||
|     </> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue