Configure Maven repository for unionflow-server-api dependency

This commit is contained in:
dahoud
2025-12-10 01:12:54 +00:00
commit 2910809949
1173 changed files with 435718 additions and 0 deletions

View File

@@ -0,0 +1,185 @@
<!DOCTYPE html>
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://xmlns.jcp.org/jsf/html"
xmlns:f="http://xmlns.jcp.org/jsf/core"
xmlns:ui="http://xmlns.jcp.org/jsf/facelets"
xmlns:p="http://primefaces.org/ui"
template="/templates/main-template.xhtml">
<ui:param name="page" value="#{cotisationsGestionBean}"/>
<ui:define name="title">Rapports Financiers - UnionFlow</ui:define>
<ui:define name="content">
<!-- En-tête -->
<ui:include src="/templates/components/layout/page-header.xhtml">
<ui:param name="icon" value="pi pi-chart-bar text-purple-500" />
<ui:param name="title" value="Rapports Financiers" />
<ui:param name="description" value="Analyse et rapports détaillés sur les cotisations et paiements" />
<ui:define name="actions">
<h:form id="formActionsRapports">
<div class="flex gap-2">
<ui:include src="/templates/components/buttons/button-primary.xhtml">
<ui:param name="value" value="Générer rapport" />
<ui:param name="icon" value="pi pi-file-pdf" />
<ui:param name="action" value="#{cotisationsBean.genererRapportFinancier}" />
</ui:include>
<ui:include src="/templates/components/buttons/button-icon.xhtml">
<ui:param name="icon" value="pi pi-refresh" />
<ui:param name="action" value="#{cotisationsBean.actualiser}" />
<ui:param name="update" value="@form" />
<ui:param name="title" value="Actualiser" />
<ui:param name="rounded" value="true" />
<ui:param name="text" value="false" />
<ui:param name="styleClass" value="ui-button-outlined ui-button-secondary" />
</ui:include>
</div>
</h:form>
</ui:define>
</ui:include>
<!-- Vue d'ensemble -->
<div class="grid">
<div class="col-12 md:col-8">
<div class="card">
<h5>
<i class="pi pi-chart-line mr-2"></i>
Évolution des Paiements (12 derniers mois)
</h5>
<div class="flex flex-column gap-2 mt-3">
<ui:repeat value="#{cotisationsBean.evolutionPaiements}" var="evolution">
<div class="flex align-items-center gap-3">
<div class="text-600" style="width: 60px;">#{evolution.mois}</div>
<div class="flex-1">
<div class="flex align-items-center gap-2">
<div class="bg-blue-500 border-round"
style="width: #{evolution.hauteur}px; height: 20px; min-width: 10px;"></div>
<span class="text-600 text-sm">#{evolution.montantFormatte}</span>
</div>
</div>
</div>
</ui:repeat>
</div>
</div>
</div>
<div class="col-12 md:col-4">
<div class="card">
<h5>
<i class="pi pi-chart-pie mr-2"></i>
Répartition par Méthode
</h5>
<div class="flex flex-column gap-3 mt-3">
<ui:repeat value="#{cotisationsBean.repartitionMethodes}" var="methode">
<div>
<div class="flex justify-content-between mb-1">
<span class="font-medium">#{methode.methode}</span>
<span class="text-600">#{methode.pourcentageInt}%</span>
</div>
<p:progressBar value="#{methode.pourcentageInt}"
showValue="false" />
</div>
</ui:repeat>
</div>
</div>
</div>
</div>
<!-- Statistiques détaillées -->
<div class="grid">
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.totalCollecteFormatte}" />
<ui:param name="label" value="Total Collecté" />
<ui:param name="icon" value="pi pi-wallet" />
<ui:param name="bgColor" value="green" />
</ui:include>
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.objectifAnnuelFormatte}" />
<ui:param name="label" value="Objectif Annuel" />
<ui:param name="icon" value="pi pi-target" />
<ui:param name="bgColor" value="blue" />
</ui:include>
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.moyenneMensuelleFormattee}" />
<ui:param name="label" value="Moyenne Mensuelle" />
<ui:param name="icon" value="pi pi-chart-line" />
<ui:param name="bgColor" value="orange" />
</ui:include>
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.tauxRecouvrementInt}%" />
<ui:param name="label" value="Taux de Recouvrement" />
<ui:param name="icon" value="pi pi-percentage" />
<ui:param name="bgColor" value="purple" />
</ui:include>
</div>
<!-- Résumé des cotisations -->
<div class="card">
<h5>
<i class="pi pi-list mr-2"></i>
Résumé des Cotisations
</h5>
<div class="grid mt-3">
<div class="col-12 md:col-6">
<h6 class="mb-3">Par Statut</h6>
<div class="flex flex-column gap-2">
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Payées</span>
<p:tag value="#{cotisationsBean.compterParStatut('PAYEE')}"
severity="success" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Partiellement payées</span>
<p:tag value="#{cotisationsBean.compterParStatut('PARTIELLEMENT_PAYEE')}"
severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">En attente</span>
<p:tag value="#{cotisationsBean.compterParStatut('EN_ATTENTE')}"
severity="warning" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">En retard</span>
<p:tag value="#{cotisationsBean.compterParStatut('EN_RETARD')}"
severity="danger" />
</div>
</div>
</div>
<div class="col-12 md:col-6">
<h6 class="mb-3">Par Type</h6>
<div class="flex flex-column gap-2">
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Mensuelle</span>
<p:tag value="#{cotisationsBean.compterParType('MENSUELLE')}" severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Trimestrielle</span>
<p:tag value="#{cotisationsBean.compterParType('TRIMESTRIELLE')}" severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Semestrielle</span>
<p:tag value="#{cotisationsBean.compterParType('SEMESTRIELLE')}" severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Annuelle</span>
<p:tag value="#{cotisationsBean.compterParType('ANNUELLE')}" severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Adhésion</span>
<p:tag value="#{cotisationsBean.compterParType('ADHESION')}" severity="info" />
</div>
<div class="flex justify-content-between align-items-center p-2 border-round surface-50">
<span class="font-medium">Exceptionnelle</span>
<p:tag value="#{cotisationsBean.compterParType('EXCEPTIONNELLE')}" severity="info" />
</div>
</div>
</div>
</div>
</div>
</ui:define>
</ui:composition>