mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	1. Enable [strictFunctionTypes](https://www.typescriptlang.org/tsconfig/#strictFunctionTypes) 2. Introduce `DOMEvent` helper type which sets `e.target`. Surely not totally correct with that `Partial` but seems to work. 3. Various type-related refactors, change objects in `eventsource.sharedworker.ts` to `Map`.
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {showElem, type DOMEvent} from '../../utils/dom.ts';
 | |
| 
 | |
| type CropperOpts = {
 | |
|   container: HTMLElement,
 | |
|   imageSource: HTMLImageElement,
 | |
|   fileInput: HTMLInputElement,
 | |
| }
 | |
| 
 | |
| export 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);
 | |
|     }
 | |
|   });
 | |
| }
 |