Files
timelapse-frontend/js/core/routes.js
2025-04-27 14:59:24 +02:00

261 lines
6.8 KiB
JavaScript

// Global variables
let global_project_list;
let current_project = "";
function formatDate(isoString) {
const date = new Date(isoString);
const options = {
year: "numeric",
month: "long",
day: "numeric",
hour: "numeric",
minute: "numeric",
second: "numeric",
timeZoneName: "short",
};
return date.toLocaleString("en-US", options);
}
// Function to get data from API
function getAllProject() {
return $.ajax({
url: api_url.concat("/projects"),
method: "GET",
dataType: "json"
}).then((data) => {
return data;
});
}
function getSingleProject(id) {
return $.ajax({
url: api_url.concat("/projects/"+id),
method: "GET",
dataType: "json"
}).then((data) => {
return data;
});
}
async function getDataMetrics(projectId){
try {
const response = await $.ajax({
url: api_url.concat(`/projects/${projectId}/measurements`),
method: "GET",
dataType: "json",
});
return response;
} catch (error) {
console.log("no data for this project")
return error.status;
}
}
async function getDataProjectVideosFromApi(id) {
try {
const response = await $.ajax({
url: api_url.concat(`/projects/${id}/videos`),
method: "GET",
dataType: "json",
});
// If the request is successful, store the data in the cache and return it
return response;
} catch (error) {
return(error.status)
}
}
async function getDataVideoFromApi(id) {
try {
const response = await $.ajax({
url: api_url.concat(`/videos/${id}`),
method: "GET",
dataType: "json",
});
// If the request is successful, store the data in the cache and return it
return response;
} catch (error) {
alert("Error fetching data:", error);
throw error; // Re-throw the error to handle it outside the function if needed
}
}
async function postNewVideo(project_id, measurements_id, name_video, resolution, duration) {
try {
const measures = JSON.stringify(measurements_id);
const mydata = JSON.stringify({
project_id: project_id,
measurement_ids: measures, // Ensure this matches the expected field name
name: name_video,
resolution: resolution,
duration: duration
});
const response = await $.ajax({
url: api_url.concat(`/videos/`),
method: "POST",
dataType: "json",
contentType: "application/json",
data: mydata
});
alert("Video posted successfully:", response);
} catch (error) {
alert("Error posting video:", error);
throw error;
}
}
async function PostNewProject(nameProject, description){
try {
if(description.length==0){
description="Non renseignée"
}
const mydata = JSON.stringify({
name: nameProject,
description: description
});
const response = await $.ajax({
url: api_url.concat(`/projects`),
method: "POST",
dataType: "json",
contentType: "application/json",
data: mydata
});
alert("Video posted successfully:", response);
location.reload();
} catch (error) {
alert("Error posting video:", error);
throw error;
}
}
async function deleteProject(id){
try {
const response = await $.ajax({
url: api_url.concat(`/projects/${id}`),
method: "DELETE",
}).then(()=>{
alert("Projet supprimé avec succès")
location.reload();
})
} catch (error) {
alert("Error deleting project, project id :"+ id+"\n error :"+error);
throw error;
}
}
async function deleteVideo(id){
try {
const response = await $.ajax({
url: api_url.concat(`/videos/${id}`),
method: "DELETE",
}).then(()=>{
alert("Video supprimé avec succès")
location.reload();
})
} catch (error) {
alert("Error deleting video, video id :"+ id+"\n error :"+error);
throw error;
}
}
async function renderVideo(id){
try {
const mydata = JSON.stringify({
info:"none"
});
const response = await $.ajax({
url: api_url.concat(`/videos/render/`+id),
method: "POST",
dataType: "json",
contentType: "application/json",
data: mydata
});
alert("Video rendered successfully:", response);
} catch (error) {
alert("Error rendering video:", error);
throw error;
}
}
async function start_timelapse(id,frequency,nbimages){
try {
// Utilisation de plusieurs formats possibles pour garantir que le backend reçoit l'ID
const mydata = JSON.stringify({
project_id: id, // Format avec underscore (convention standard REST)
projectId: id, // Format camelCase
id: id, // Format simple
interval: frequency,
nb_images: nbimages
});
console.log("Données envoyées à /procedure/start:", mydata); // Log pour débogage
const response = await $.ajax({
url: api_url.concat(`/procedure/start`),
method: "POST",
dataType: "json",
contentType: "application/json",
data: mydata
});
alert("Configuration de la caméra réussie");
return response;
} catch (error) {
console.error("Erreur détaillée:", error); // Log plus détaillé de l'erreur
alert("Erreur lors de la configuration de la caméra: " + error);
throw error;
}
}
async function stopCamera(id){
try {
const mydata = JSON.stringify({
info:"None"
});
const response = await $.ajax({
url: api_url.concat(`/procedure/stop`),
method: "POST",
dataType: "json",
contentType: "application/json",
data: mydata
});
alert("La caméra a été arrêtée avec succès");
return response;
} catch (error) {
alert("Erreur lors de l'arrêt de la caméra : " + error);
throw error;
}
}
async function manualUpload(imageFile, projectId, timestamp, temperature, humidity) {
try {
// Create FormData to send the file and metadata
const formData = new FormData();
formData.append('image', imageFile);
formData.append('projectId', projectId);
formData.append('timestamp', timestamp);
formData.append('temperature', temperature);
formData.append('humidity', humidity);
const response = await $.ajax({
url: api_url.concat("/camera/upload"),
method: "POST",
data: formData,
processData: false, // Prevents jQuery from converting FormData to string
contentType: false, // Lets browser set the content type with boundary
});
alert("Image uploaded successfully");
return response;
} catch (error) {
alert("Error uploading image: " + error);
throw error;
}
}