Files
Inventory/app/composables/useDocuments.js
2025-09-17 11:40:50 +02:00

127 lines
3.6 KiB
JavaScript

import { ref } from 'vue'
import { useApi } from './useApi'
import { useToast } from './useToast'
const documents = ref([])
const loading = ref(false)
const fileToBase64 = (file) =>
new Promise((resolve, reject) => {
const reader = new FileReader()
reader.onload = () => resolve(reader.result)
reader.onerror = () => reject(new Error(`Lecture du fichier ${file.name} impossible`))
reader.readAsDataURL(file)
})
export function useDocuments() {
const { get, post, delete: del } = useApi()
const { showError, showSuccess } = useToast()
const loadDocuments = async () => {
loading.value = true
try {
const result = await get('/documents')
if (result.success) {
documents.value = result.data
}
return result
} catch (error) {
console.error('Erreur lors du chargement des documents:', error)
showError("Impossible de charger les documents")
return { success: false, error: error.message }
} finally {
loading.value = false
}
}
const loadDocumentsBySite = async (siteId) => {
if (!siteId) return { success: false, error: 'Aucun site sélectionné' }
loading.value = true
try {
const result = await get(`/documents/site/${siteId}`)
if (result.success) {
documents.value = result.data
}
return result
} catch (error) {
console.error('Erreur lors du chargement des documents du site:', error)
showError("Impossible de charger les documents du site")
return { success: false, error: error.message }
} finally {
loading.value = false
}
}
const uploadDocuments = async ({ files = [], context = {} }) => {
if (!files.length) return { success: false, error: 'Aucun fichier sélectionné' }
loading.value = true
const created = []
try {
for (const file of files) {
const dataUrl = await fileToBase64(file)
const payload = {
name: file.name,
filename: file.name,
mimeType: file.type || 'application/octet-stream',
size: file.size,
path: dataUrl,
...context,
}
const result = await post('/documents', payload)
if (result.success) {
created.push(result.data)
showSuccess(`Document "${file.name}" ajouté`)
} else if (result.error) {
showError(`Erreur sur ${file.name} : ${result.error}`)
}
}
if (created.length) {
documents.value = [...created, ...documents.value]
return { success: true, data: created }
}
return { success: false, error: 'Aucun document ajouté' }
} catch (error) {
console.error('Erreur lors de l\'upload des documents:', error)
showError("Échec de l'ajout des documents")
return { success: false, error: error.message }
} finally {
loading.value = false
}
}
const deleteDocument = async (id) => {
if (!id) return { success: false, error: 'Identifiant manquant' }
loading.value = true
try {
const result = await del(`/documents/${id}`)
if (result.success) {
documents.value = documents.value.filter(doc => doc.id !== id)
showSuccess('Document supprimé')
}
return result
} catch (error) {
console.error('Erreur lors de la suppression du document:', error)
showError("Impossible de supprimer le document")
return { success: false, error: error.message }
} finally {
loading.value = false
}
}
return {
documents,
loading,
loadDocuments,
loadDocumentsBySite,
uploadDocuments,
deleteDocument,
}
}