Skip to content

Commit

Permalink
Merge pull request #192 from abes-esr/ITEM-431-infobulle-et-couleur
Browse files Browse the repository at this point in the history
Item 431 infobulle et couleur
  • Loading branch information
EryneKL authored Dec 11, 2024
2 parents 5884f37 + 9bcfc5f commit bcf0949
Show file tree
Hide file tree
Showing 11 changed files with 208 additions and 256 deletions.
39 changes: 39 additions & 0 deletions src/components/ButtonsActions/BtnArchive.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
<template>
<v-tooltip v-if="canArchive(demande)" text="Archiver">
<template v-slot:activator="{ props }">
<v-btn v-bind="props"
variant="text"
icon="mdi-archive"
color="archived"
@click="archiverDemande(demande)"
aria-label="Archiver"></v-btn>
</template>
</v-tooltip>
</template>
<script setup>
import itemService from '@/service/ItemService';
const emits = defineEmits(['clicked', 'onError']);
const props = defineProps({
demande: {
required: true
}
});
//Action d'archivage ou suppression selon état de la demande dans le TDB
function canArchive(item) {
return item.etatDemande === 'Terminé';
}
//Archivage d'une demande
function archiverDemande(item) {
itemService.archiverDemande(item.type, item.id)
.then(() => {
emits('clicked');
})
.catch(error => {
emits('onError', error);
});
}
</script>
32 changes: 32 additions & 0 deletions src/components/ButtonsActions/BtnRestore.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
<template>
<v-tooltip v-if="demande.etatDemande === 'Archivé'" text="Restaurer">
<template v-slot:activator="{ props }">
<v-btn v-bind="props"
variant="text"
color="success"
icon="mdi-package-up"
@click="restaurerDemande(demande)"></v-btn>
</template>
</v-tooltip>
</template>
<script setup>
import itemService from '@/service/ItemService';
const emits = defineEmits(['clicked', 'onError']);
const props = defineProps({
demande: {
required: true
}
});
function restaurerDemande(item) {
itemService.restaurerDemande(item.id, item.type)
.then(() => {
emits('clicked');
})
.catch(error => {
emits('onError', error);
});
}
</script>
34 changes: 34 additions & 0 deletions src/components/ButtonsActions/BtnStop.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
<template>
<v-tooltip v-if="canStop(demande)" text="Annuler">
<template v-slot:activator="{ props }">
<v-btn v-bind="props"
icon="mdi-stop"
variant="text"
color="error"
@click="dialog = true">
</v-btn>
</template>
</v-tooltip>
<dialog-confirmation-stop v-model="dialog" :id="demande.id" @clicked="emits('clicked')" @on-error="throwError">
</dialog-confirmation-stop>
</template>
<script setup>
import DialogConfirmationStop from '@/components/Dialog/DialogConfirmationStop.vue';
import { ref } from 'vue';
const emits = defineEmits(['clicked', 'onError']);
const props = defineProps({
demande: {
required: true
}
});
const dialog = ref(false);
function canStop(item) {
return item.etatDemande === 'En cours de traitement' || item.etatDemande === 'En attente';
}
function throwError(error) {
emits('onError', error);
}
</script>
33 changes: 33 additions & 0 deletions src/components/ButtonsActions/BtnSuppression.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
<template>
<v-tooltip v-if="canCancel(demande)" text="Supprimer">
<template v-slot:activator="{ props }">
<v-btn v-bind="props"
icon="mdi-delete"
variant="text"
@click="dialog = true">
</v-btn>
</template>
</v-tooltip>
<dialog-suppression v-model="dialog" :demande="demande" @supp="emits('clicked')" @on-error="throwError">
</dialog-suppression>
</template>
<script setup>
import { ref } from 'vue';
import DialogSuppression from '@/components/Dialog/DialogSuppression.vue';
const emits = defineEmits(['clicked', 'onError']);
const props = defineProps({
demande: {
required: true,
}
});
const dialog = ref(false);
function canCancel(item) {
return item.etatDemande !== 'Terminé' && item.etatDemande !== 'En cours de traitement' && item.etatDemande !== 'En attente';
}
function throwError(error) {
emits('onError', error);
}
</script>
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
<script setup>
import itemService from '@/service/ItemService';
const emits = defineEmits(['stop', 'onError']);
const emits = defineEmits(['clicked', 'onError']);
const dialog = defineModel();
const props = defineProps({
id: {
Expand All @@ -31,7 +31,7 @@ function stopDemande() {
})
.finally(() => {
dialog.value = false;
emits('stop');
emits('clicked');
});
}
</script>
19 changes: 10 additions & 9 deletions src/components/Dialog/DialogSuppression.vue
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
<v-card>
<v-card-title>Suppression</v-card-title>
<v-divider></v-divider>
<v-card-text>Êtes-vous certain de vouloir supprimer définitivement cette demande ?</v-card-text>
<v-card-text>Êtes-vous certain de vouloir supprimer définitivement la demande N°{{ demande.id }} ?</v-card-text>
<v-card-actions>

<v-container class="d-flex justify-space-between">
Expand All @@ -28,7 +28,7 @@ import router from '@/router';
import { ref } from 'vue';
const dialog = defineModel();
const emits = defineEmits(['supp'])
const emits = defineEmits(['supp']);
const props = defineProps({
returnToAccueil: {
required: false,
Expand All @@ -38,21 +38,22 @@ const props = defineProps({
required: true,
type: Object
}
})
});
const isLoading = ref(false);
function confirm() {
isLoading.value = true;
itemService.deleteDemande(props.demande.id, props.demande.type)
.then(()=>{
if(props.returnToAccueil){
.then(() => {
if (props.returnToAccueil) {
router.push('/accueil');
}
emits('supp');
}).finally(() => {
isLoading.value = false;
dialog.value = false;
})
})
.finally(() => {
isLoading.value = false;
dialog.value = false;
});
}
function cancel() {
Expand Down
28 changes: 0 additions & 28 deletions src/components/Supp/BtnStop.vue

This file was deleted.

62 changes: 15 additions & 47 deletions src/views/Exemplarisation/ExempTable.vue
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@
</v-tooltip>
</v-chip>
</v-container>
<v-data-table :headers="filteredHeadingsDemandes" :items="contentsDemandesFrontFiltered" :items-length="totalItemsFound"
<v-data-table :headers="filteredHeadingsDemandes" :items="contentsDemandesFrontFiltered"
:items-length="totalItemsFound"
:loading="!isDataLoaded" show-expand :sort-by="sortBy"
item-key="id"
>
Expand Down Expand Up @@ -119,31 +120,35 @@
</td>
<td class="text-center">
<!-- Colonne Action -->
<v-btn v-if="canArchive(item)" variant="plain" icon="mdi-archive" @click="archiverDemande(item)"></v-btn>
<v-btn v-else-if="canCancel(item)" variant="plain" icon="mdi-delete" @click="supprimerDemande(item)"></v-btn>
<v-btn v-if="item.etatDemande === 'Archivé'" variant="plain" icon="mdi-package-up" @click="restaurerDemande(item)"></v-btn>
<btn-archive :demande="item" @clicked="loadItems(item.type)"
@on-error="throwError" aria-label="Archiver"></btn-archive>
<btn-suppression :demande="item" @clicked="loadItems(item.type)"
@on-error="throwError" aria-label="Supprimer"></btn-suppression>
<btn-restore :demande="item" @clicked="loadItems(item.type)"
@on-error="throwError" aria-label="Restaurer"></btn-restore>
</td>
</tr>
</template>
</v-data-table>
<dialog-suppression v-model="suppDialog" :demande="suppDemande"
@supp="loadItems('EXEMP')"></dialog-suppression>
</template>

<script setup>
import { computed, onBeforeUnmount, onMounted, ref } from 'vue';
import router from '@/router';
import DialogSuppression from '@/components/Dialog/DialogSuppression.vue';
import DialogCommentaire from '@/components/Dialog/DialogCommentaire.vue';
import itemService from '@/service/ItemService';
import MenuDownloadFile from '@/components/MenuDownloadFile.vue';
import moment from 'moment';
import {useAuthStore} from '@/store/authStore'
import { useAuthStore } from '@/store/authStore';
import BtnSuppression from '@/components/ButtonsActions/BtnSuppression.vue';
import BtnArchive from '@/components/ButtonsActions/BtnArchive.vue';
import BtnRestore from '@/components/ButtonsActions/BtnRestore.vue';
//Emit
const emit = defineEmits(['backendError', 'backendSuccess']);
//Data
const isAdmin = useAuthStore().isAdmin();
const isAdmin = useAuthStore()
.isAdmin();
const extendedAllILN = ref(false);
const headingsDemandes = [
Expand Down Expand Up @@ -249,7 +254,7 @@ const headingsDemandes = [
];
const filteredHeadingsDemandes = computed(() =>
headingsDemandes.filter(heading => heading.display !== false)
)
);
const listStatut = [
'En saisie',
Expand Down Expand Up @@ -359,43 +364,6 @@ function filterItems() {
});
}
//Action d'archivage ou suppression selon état de la demande dans le TDB
function canArchive(item) {
return item.etatDemande === 'Terminé';
}
function canCancel(item) {
return item.etatDemande !== 'Terminé' && item.etatDemande !== 'En cours de traitement' && item.etatDemande !== 'En attente';
}
//Suppression d'une demande
function supprimerDemande(item) {
suppDialog.value = true;
suppDemande.value = item;
}
function restaurerDemande(item) {
itemService.restaurerDemande(item.id, "EXEMP").then(() => {
loadItems('EXEMP');
}).catch(error => {
console.error(error);
emit('backendError', error);
});
}
//Archivage d'une demande
async function archiverDemande(item) {
try {
await itemService.archiverDemande('EXEMP', item.id);
// Mettre à jour les données après l'archivage réussi
await loadItems('EXEMP');
emit('backendSuccess');
} catch (error) {
console.error(error);
emit('backendError', error);
}
}
function onRowClick(item) {
if (item.etatDemande === 'En préparation' || item.etatDemande === 'A compléter' || item.etatDemande === 'En simulation') {
router.push('/exemplarisation/' + item.id);
Expand Down
Loading

0 comments on commit bcf0949

Please sign in to comment.