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,229 @@
<!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">Relances de Cotisations - 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-send text-orange-500" />
<ui:param name="title" value="Relances de Cotisations" />
<ui:param name="description" value="Gestion et envoi des relances pour les cotisations en retard" />
<ui:define name="actions">
<h:form id="formActionsRelances">
<div class="flex gap-2">
<ui:include src="/templates/components/buttons/button-warning.xhtml">
<ui:param name="value" value="Relances groupées" />
<ui:param name="icon" value="pi pi-send" />
<ui:param name="onclick" value="PF('dlgRelancesGroupes').show();" />
</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>
<!-- Statistiques de relances -->
<div class="grid">
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.cotisationsEnRetard}" />
<ui:param name="label" value="Cotisations en Retard" />
<ui:param name="icon" value="pi pi-exclamation-triangle" />
<ui:param name="bgColor" value="orange" />
</ui:include>
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.statistiques.montantRetardFormatte}" />
<ui:param name="label" value="Montant en Retard" />
<ui:param name="icon" value="pi pi-clock" />
<ui:param name="bgColor" value="red" />
</ui:include>
<ui:include src="/templates/components/cards/stat-card.xhtml">
<ui:param name="value" value="#{cotisationsBean.rappelsEnAttente.size()}" />
<ui:param name="label" value="Rappels en Attente" />
<ui:param name="icon" value="pi pi-bell" />
<ui:param name="bgColor" value="purple" />
</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="blue" />
</ui:include>
</div>
<!-- Liste des rappels en attente -->
<div class="card">
<h5>
<i class="pi pi-bell mr-2"></i>
Rappels en Attente
</h5>
<p:dataTable id="dtRappels"
value="#{cotisationsBean.rappelsEnAttente}"
var="rappel"
paginator="true"
rows="20"
emptyMessage="Aucun rappel en attente">
<p:column headerText="Membre" sortBy="#{rappel.nomMembre}">
<div>
<div class="font-medium">#{rappel.nomMembre}</div>
<div class="text-600 text-sm">#{rappel.club}</div>
</div>
</p:column>
<p:column headerText="Montant Dû" sortBy="#{rappel.montantDu}" style="width:120px">
<h:outputText value="#{rappel.montantDuFormatte}" styleClass="font-bold" />
</p:column>
<p:column headerText="Jours de Retard" sortBy="#{rappel.joursRetard}" style="width:120px">
<h:outputText value="#{rappel.joursRetard} jour(s)" />
</p:column>
<p:column headerText="Priorité" sortBy="#{rappel.priorite}" style="width:120px">
<p:tag value="#{rappel.priorite}"
severity="#{rappel.prioriteSeverity}" />
</p:column>
<p:column headerText="Actions" style="width:150px">
<ui:include src="/templates/components/buttons/button-warning.xhtml">
<ui:param name="value" value="Envoyer" />
<ui:param name="icon" value="pi pi-send" />
<ui:param name="action" value="#{cotisationsBean.envoyerRappel}" />
<ui:param name="update" value="@form" />
<ui:param name="styleClass" value="p-button-sm" />
</ui:include>
</p:column>
</p:dataTable>
</div>
<!-- Cotisations en retard -->
<div class="card">
<h:form id="formRelances">
<h5>Cotisations en Retard</h5>
<p:dataTable id="dtRetard"
value="#{cotisationsBean.cotisationsFiltrees}"
var="cotisation"
filteredValue="#{cotisationsBean.cotisationsFiltrees}"
paginator="true"
rows="20"
emptyMessage="Aucune cotisation en retard"
selection="#{cotisationsBean.cotisationsSelectionnees}"
selectionMode="multiple">
<f:facet name="header">
<div class="flex align-items-center justify-content-between">
<span>Cotisations nécessitant une relance</span>
<div class="flex gap-2">
<ui:include src="/templates/components/buttons/button-warning.xhtml">
<ui:param name="value" value="Relancer sélectionnées" />
<ui:param name="icon" value="pi pi-send" />
<ui:param name="action" value="#{cotisationsBean.envoyerRappelsGroupes}" />
<ui:param name="update" value="@form" />
<ui:param name="disabled" value="#{empty cotisationsBean.cotisationsSelectionnees}" />
<ui:param name="outlined" value="true" />
</ui:include>
</div>
</div>
</f:facet>
<p:column selectionMode="multiple" style="width:50px" />
<p:column headerText="Membre" sortBy="#{cotisation.nomMembre}">
<div>
<div class="font-medium">#{cotisation.nomMembre}</div>
<div class="text-600 text-sm">#{cotisation.numeroMembre}</div>
</div>
</p:column>
<p:column headerText="Type" sortBy="#{cotisation.typeCotisation}" style="width:120px">
<p:tag value="#{cotisation.typeCotisationLibelle}" severity="info" />
</p:column>
<p:column headerText="Montant Dû" sortBy="#{cotisation.montantDu}" style="width:120px">
<h:outputText value="#{cotisation.montantDuFormatte}" styleClass="font-bold" />
</p:column>
<p:column headerText="Échéance" sortBy="#{cotisation.dateEcheance}" style="width:120px">
<h:outputText value="#{cotisation.dateEcheanceFormatee}" />
</p:column>
<p:column headerText="Jours Retard" style="width:120px">
<h:outputText value="#{cotisation.joursRetard} jour(s)"
styleClass="#{cotisation.joursRetard > 30 ? 'text-red-500 font-bold' : cotisation.joursRetard > 15 ? 'text-orange-500' : 'text-yellow-500'}" />
</p:column>
<p:column headerText="Actions" style="width:150px">
<div class="flex gap-1">
<p:commandButton icon="pi pi-send"
title="Envoyer un rappel"
styleClass="p-button-rounded p-button-text p-button-warning"
action="#{cotisationsBean.envoyerRappel(cotisation)}"
update="@form" />
</div>
</p:column>
</p:dataTable>
</h:form>
</div>
<!-- Dialog Relances Groupées -->
<p:dialog header="Relances Groupées" widgetVar="dlgRelancesGroupes" modal="true" width="500" resizable="false">
<h:form id="formRelancesGroupes">
<div class="ui-fluid">
<div class="field">
<p:outputLabel for="messageRelance" value="Message de relance" />
<p:inputTextarea id="messageRelance"
rows="5"
styleClass="w-full"
placeholder="Message personnalisé pour les relances..." />
</div>
<div class="field">
<p:selectBooleanCheckbox id="relanceUrgente" />
<p:outputLabel for="relanceUrgente" value=" Marquer comme urgente" />
</div>
<div class="surface-50 p-3 border-round">
<div class="font-medium mb-2">Destinataires :</div>
<div class="text-600 text-sm">#{cotisationsBean.cotisationsSelectionnees.size()} cotisation(s) sélectionnée(s)</div>
</div>
</div>
<div class="flex justify-content-end gap-2 mt-3">
<ui:include src="/templates/components/buttons/button-secondary.xhtml">
<ui:param name="value" value="Annuler" />
<ui:param name="icon" value="pi pi-times" />
<ui:param name="onclick" value="PF('dlgRelancesGroupes').hide();" />
<ui:param name="outlined" value="true" />
</ui:include>
<ui:include src="/templates/components/buttons/button-warning.xhtml">
<ui:param name="value" value="Envoyer les relances" />
<ui:param name="icon" value="pi pi-send" />
<ui:param name="action" value="#{cotisationsBean.envoyerRappelsGroupes}" />
<ui:param name="update" value="@form :formRelances" />
<ui:param name="oncomplete" value="PF('dlgRelancesGroupes').hide();" />
</ui:include>
</div>
</h:form>
</p:dialog>
</ui:define>
</ui:composition>