mirror of
https://github.com/go-gitea/gitea.git
synced 2025-10-24 09:59:54 +02: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});
|
|
}
|