refactor: fix type errors of MkCropperDialog

This commit is contained in:
Lhcfl 2024-04-11 00:14:36 +08:00
parent 18ba024cbb
commit f275fc9cdf
3 changed files with 40 additions and 29 deletions

View file

@ -68,40 +68,48 @@ let cropper: Cropper | null = null;
const loading = ref(true);
const ok = async () => {
const promise = new Promise<entities.DriveFile>(async (res) => {
async function UploadCroppedImg(): Promise<entities.DriveFile> {
const croppedCanvas = await cropper?.getCropperSelection()?.$toCanvas();
croppedCanvas.toBlob((blob) => {
const formData = new FormData();
formData.append("file", blob);
if (defaultStore.state.uploadFolder) {
formData.append("folderId", defaultStore.state.uploadFolder);
}
fetch(apiUrl + "/drive/files/create", {
method: "POST",
body: formData,
headers: {
authorization: `Bearer ${me.token}`,
},
})
.then((response) => response.json())
.then((f) => {
res(f);
});
const blob = await new Promise<Blob | null>((resolve) =>
croppedCanvas!.toBlob((blob) => resolve(blob)),
);
// MDN says `null` may be passed if the image cannot be created for any reason.
// But I don't think this is reachable for normal case.
if (blob == null) {
throw "Cropping image failed.";
}
const formData = new FormData();
formData.append("file", blob);
if (defaultStore.state.uploadFolder) {
formData.append("folderId", defaultStore.state.uploadFolder);
}
const response = await fetch(`${apiUrl}/drive/files/create`, {
method: "POST",
body: formData,
headers: {
authorization: `Bearer ${me!.token}`,
},
});
});
return await response.json();
}
const promise = UploadCroppedImg();
os.promiseDialog(promise);
const f = await promise;
emit("ok", f);
dialogEl.value.close();
dialogEl.value!.close();
};
const cancel = () => {
emit("cancel");
dialogEl.value.close();
dialogEl.value!.close();
};
const onImageLoad = () => {
@ -114,7 +122,7 @@ const onImageLoad = () => {
};
onMounted(() => {
cropper = new Cropper(imgEl.value, {});
cropper = new Cropper(imgEl.value!, {});
const computedStyle = getComputedStyle(document.documentElement);
@ -127,13 +135,13 @@ onMounted(() => {
selection.outlined = true;
window.setTimeout(() => {
cropper.getCropperImage()!.$center("contain");
cropper!.getCropperImage()!.$center("contain");
selection.$center();
}, 100);
// 調
window.setTimeout(() => {
cropper.getCropperImage()!.$center("contain");
cropper!.getCropperImage()!.$center("contain");
selection.$center();
}, 500);
});

View file

@ -54,7 +54,10 @@
</button>
</div>
<div class="body">
<slot></slot>
<slot
:width="width"
:height="height"
></slot>
</div>
</div>
</FocusTrap>

View file

@ -125,12 +125,12 @@ export const apiWithDialog = ((
return promise;
}) as typeof api;
export function promiseDialog<T extends Promise<any>>(
promise: T,
onSuccess?: ((res: any) => void) | null,
export function promiseDialog<T>(
promise: Promise<T>,
onSuccess?: ((res: T) => void) | null,
onFailure?: ((err: Error) => void) | null,
text?: string,
): T {
): Promise<T> {
const showing = ref(true);
const success = ref(false);