refactor: fix type errors of MkCropperDialog
This commit is contained in:
parent
18ba024cbb
commit
f275fc9cdf
3 changed files with 40 additions and 29 deletions
|
@ -68,40 +68,48 @@ let cropper: Cropper | null = null;
|
||||||
const loading = ref(true);
|
const loading = ref(true);
|
||||||
|
|
||||||
const ok = async () => {
|
const ok = async () => {
|
||||||
const promise = new Promise<entities.DriveFile>(async (res) => {
|
async function UploadCroppedImg(): Promise<entities.DriveFile> {
|
||||||
const croppedCanvas = await cropper?.getCropperSelection()?.$toCanvas();
|
const croppedCanvas = await cropper?.getCropperSelection()?.$toCanvas();
|
||||||
croppedCanvas.toBlob((blob) => {
|
|
||||||
|
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();
|
const formData = new FormData();
|
||||||
formData.append("file", blob);
|
formData.append("file", blob);
|
||||||
if (defaultStore.state.uploadFolder) {
|
if (defaultStore.state.uploadFolder) {
|
||||||
formData.append("folderId", defaultStore.state.uploadFolder);
|
formData.append("folderId", defaultStore.state.uploadFolder);
|
||||||
}
|
}
|
||||||
|
|
||||||
fetch(apiUrl + "/drive/files/create", {
|
const response = await fetch(`${apiUrl}/drive/files/create`, {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
body: formData,
|
body: formData,
|
||||||
headers: {
|
headers: {
|
||||||
authorization: `Bearer ${me.token}`,
|
authorization: `Bearer ${me!.token}`,
|
||||||
},
|
},
|
||||||
})
|
|
||||||
.then((response) => response.json())
|
|
||||||
.then((f) => {
|
|
||||||
res(f);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
return await response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
const promise = UploadCroppedImg();
|
||||||
|
|
||||||
os.promiseDialog(promise);
|
os.promiseDialog(promise);
|
||||||
|
|
||||||
const f = await promise;
|
const f = await promise;
|
||||||
|
|
||||||
emit("ok", f);
|
emit("ok", f);
|
||||||
dialogEl.value.close();
|
dialogEl.value!.close();
|
||||||
};
|
};
|
||||||
|
|
||||||
const cancel = () => {
|
const cancel = () => {
|
||||||
emit("cancel");
|
emit("cancel");
|
||||||
dialogEl.value.close();
|
dialogEl.value!.close();
|
||||||
};
|
};
|
||||||
|
|
||||||
const onImageLoad = () => {
|
const onImageLoad = () => {
|
||||||
|
@ -114,7 +122,7 @@ const onImageLoad = () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
cropper = new Cropper(imgEl.value, {});
|
cropper = new Cropper(imgEl.value!, {});
|
||||||
|
|
||||||
const computedStyle = getComputedStyle(document.documentElement);
|
const computedStyle = getComputedStyle(document.documentElement);
|
||||||
|
|
||||||
|
@ -127,13 +135,13 @@ onMounted(() => {
|
||||||
selection.outlined = true;
|
selection.outlined = true;
|
||||||
|
|
||||||
window.setTimeout(() => {
|
window.setTimeout(() => {
|
||||||
cropper.getCropperImage()!.$center("contain");
|
cropper!.getCropperImage()!.$center("contain");
|
||||||
selection.$center();
|
selection.$center();
|
||||||
}, 100);
|
}, 100);
|
||||||
|
|
||||||
// モーダルオープンアニメーションが終わったあとで再度調整
|
// モーダルオープンアニメーションが終わったあとで再度調整
|
||||||
window.setTimeout(() => {
|
window.setTimeout(() => {
|
||||||
cropper.getCropperImage()!.$center("contain");
|
cropper!.getCropperImage()!.$center("contain");
|
||||||
selection.$center();
|
selection.$center();
|
||||||
}, 500);
|
}, 500);
|
||||||
});
|
});
|
||||||
|
|
|
@ -54,7 +54,10 @@
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="body">
|
<div class="body">
|
||||||
<slot></slot>
|
<slot
|
||||||
|
:width="width"
|
||||||
|
:height="height"
|
||||||
|
></slot>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</FocusTrap>
|
</FocusTrap>
|
||||||
|
|
|
@ -125,12 +125,12 @@ export const apiWithDialog = ((
|
||||||
return promise;
|
return promise;
|
||||||
}) as typeof api;
|
}) as typeof api;
|
||||||
|
|
||||||
export function promiseDialog<T extends Promise<any>>(
|
export function promiseDialog<T>(
|
||||||
promise: T,
|
promise: Promise<T>,
|
||||||
onSuccess?: ((res: any) => void) | null,
|
onSuccess?: ((res: T) => void) | null,
|
||||||
onFailure?: ((err: Error) => void) | null,
|
onFailure?: ((err: Error) => void) | null,
|
||||||
text?: string,
|
text?: string,
|
||||||
): T {
|
): Promise<T> {
|
||||||
const showing = ref(true);
|
const showing = ref(true);
|
||||||
const success = ref(false);
|
const success = ref(false);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue