mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 23:46:22 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {showElem, type DOMEvent} from '../../utils/dom.ts';
 | |
| 
 | |
| type CropperOpts = {
 | |
|   container: HTMLElement,
 | |
|   imageSource: HTMLImageElement,
 | |
|   fileInput: HTMLInputElement,
 | |
| }
 | |
| 
 | |
| async function initCompCropper({container, fileInput, imageSource}: CropperOpts) {
 | |
|   const {default: Cropper} = await import(/* webpackChunkName: "cropperjs" */'cropperjs');
 | |
|   let currentFileName = '';
 | |
|   let currentFileLastModified = 0;
 | |
|   const cropper = new Cropper(imageSource, {
 | |
|     aspectRatio: 1,
 | |
|     viewMode: 2,
 | |
|     autoCrop: false,
 | |
|     crop() {
 | |
|       const canvas = cropper.getCroppedCanvas();
 | |
|       canvas.toBlob((blob) => {
 | |
|         const croppedFileName = currentFileName.replace(/\.[^.]{3,4}$/, '.png');
 | |
|         const croppedFile = new File([blob], croppedFileName, {type: 'image/png', lastModified: currentFileLastModified});
 | |
|         const dataTransfer = new DataTransfer();
 | |
|         dataTransfer.items.add(croppedFile);
 | |
|         fileInput.files = dataTransfer.files;
 | |
|       });
 | |
|     },
 | |
|   });
 | |
| 
 | |
|   fileInput.addEventListener('input', (e: DOMEvent<Event, HTMLInputElement>) => {
 | |
|     const files = e.target.files;
 | |
|     if (files?.length > 0) {
 | |
|       currentFileName = files[0].name;
 | |
|       currentFileLastModified = files[0].lastModified;
 | |
|       const fileURL = URL.createObjectURL(files[0]);
 | |
|       imageSource.src = fileURL;
 | |
|       cropper.replace(fileURL);
 | |
|       showElem(container);
 | |
|     }
 | |
|   });
 | |
| }
 | |
| 
 | |
| export async function initAvatarUploaderWithCropper(fileInput: HTMLInputElement) {
 | |
|   const panel = fileInput.nextElementSibling as HTMLElement;
 | |
|   if (!panel?.matches('.cropper-panel')) throw new Error('Missing cropper panel for avatar uploader');
 | |
|   const imageSource = panel.querySelector<HTMLImageElement>('.cropper-source');
 | |
|   await initCompCropper({container: panel, fileInput, imageSource});
 | |
| }
 |