mirror of
https://github.com/makeplane/plane.git
synced 2025-12-25 08:09:33 +01:00
* chore: added attachment upload progress * chore: add debounce while updating the upload status * chore: update percentage calc logic * chore: update debounce interval
40 lines
967 B
TypeScript
40 lines
967 B
TypeScript
import axios, { AxiosRequestConfig } from "axios";
|
|
// services
|
|
import { APIService } from "@/services/api.service";
|
|
|
|
export class FileUploadService extends APIService {
|
|
private cancelSource: any;
|
|
|
|
constructor() {
|
|
super("");
|
|
}
|
|
|
|
async uploadFile(
|
|
url: string,
|
|
data: FormData,
|
|
uploadProgressHandler?: AxiosRequestConfig["onUploadProgress"]
|
|
): Promise<void> {
|
|
this.cancelSource = axios.CancelToken.source();
|
|
return this.post(url, data, {
|
|
headers: {
|
|
"Content-Type": "multipart/form-data",
|
|
},
|
|
cancelToken: this.cancelSource.token,
|
|
withCredentials: false,
|
|
onUploadProgress: uploadProgressHandler,
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
if (axios.isCancel(error)) {
|
|
console.log(error.message);
|
|
} else {
|
|
throw error?.response?.data;
|
|
}
|
|
});
|
|
}
|
|
|
|
cancelUpload() {
|
|
this.cancelSource.cancel("Upload canceled");
|
|
}
|
|
}
|