Files
btpxpress-frontend/target/classes/META-INF/resources/stock.xhtml
dahoud 0fad42ccaf refactor: Suppression de 13 écrans redondants
Nettoyage des doublons pour éviter la redondance :

Suppressions (liste.xhtml redondants avec écrans racine):
- devis/liste.xhtml
- employes/liste.xhtml
- equipes/liste.xhtml
- factures/liste.xhtml
- maintenance/liste.xhtml
- materiels/liste.xhtml
- messages/liste.xhtml
- notifications/liste.xhtml
- planning/liste.xhtml
- rapports/liste.xhtml
- stock/liste.xhtml

Suppressions (inconsistance nouveau/nouvelle):
- equipes/nouvelle.xhtml
- factures/nouvelle.xhtml

Stratégie:
- Un seul écran liste par module (racine)
- Standardisation sur nouveau.xhtml

Résultat: 163 écrans restants (vs 176 avant)
2025-11-07 22:36:04 +00:00

122 lines
7.6 KiB
HTML

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui"
template="/WEB-INF/template.xhtml">
<ui:define name="title">Stock - BTP Xpress</ui:define>
<ui:define name="content">
<div class="layout-dashboard">
<div class="grid">
<div class="col-12">
<div class="card">
<div class="flex align-items-center justify-content-between mb-3">
<h1>Gestion du Stock</h1>
<p:commandButton value="Nouvel article" icon="pi pi-box"
action="#{stockView.createNew()}"
styleClass="ui-button-primary"/>
</div>
</div>
</div>
<div class="col-12">
<ui:include src="/WEB-INF/components/liste-filters.xhtml">
<ui:param name="formId" value="filtresForm"/>
<ui:param name="viewBean" value="#{stockView}"/>
<ui:param name="tableId" value="stocksTable"/>
<ui:define name="filter-fields">
<div class="grid">
<div class="col-12 md:col-3">
<h:outputLabel for="filtreReference" value="Référence"/>
<p:inputText id="filtreReference" value="#{stockView.filtreReference}"
placeholder="Rechercher par référence..." style="width: 100%;"/>
</div>
<div class="col-12 md:col-3">
<h:outputLabel for="filtreDesignation" value="Désignation"/>
<p:inputText id="filtreDesignation" value="#{stockView.filtreDesignation}"
placeholder="Rechercher par désignation..." style="width: 100%;"/>
</div>
<div class="col-12 md:col-3">
<h:outputLabel for="filtreCategorie" value="Catégorie"/>
<p:selectOneMenu id="filtreCategorie" value="#{stockView.filtreCategorie}" style="width: 100%;">
<f:selectItem itemLabel="Tous" itemValue="TOUS"/>
<f:selectItem itemLabel="Matériaux" itemValue="MATERIAUX"/>
<f:selectItem itemLabel="Outillage" itemValue="OUTILLAGE"/>
<f:selectItem itemLabel="Équipement" itemValue="EQUIPEMENT"/>
<f:selectItem itemLabel="Consommables" itemValue="CONSOMMABLES"/>
</p:selectOneMenu>
</div>
<div class="col-12 md:col-3">
<h:outputLabel for="filtreStatut" value="Statut"/>
<p:selectOneMenu id="filtreStatut" value="#{stockView.filtreStatut}" style="width: 100%;">
<f:selectItem itemLabel="Tous" itemValue="TOUS"/>
<f:selectItem itemLabel="Disponible" itemValue="DISPONIBLE"/>
<f:selectItem itemLabel="En rupture" itemValue="EN_RUPTURE"/>
<f:selectItem itemLabel="Seuil d'alerte" itemValue="SEUIL_ALERTE"/>
</p:selectOneMenu>
</div>
</div>
</ui:define>
</ui:include>
</div>
<div class="col-12">
<ui:include src="/WEB-INF/components/liste-table.xhtml">
<ui:param name="formId" value="stocksForm"/>
<ui:param name="tableId" value="stocksTable"/>
<ui:param name="viewBean" value="#{stockView}"/>
<ui:param name="var" value="stock"/>
<ui:param name="title" value="Inventaire du stock"/>
<ui:param name="createPath" value="/stock/nouveau"/>
<ui:define name="columns">
<p:column headerText="Référence" sortBy="#{stock.reference}">
<h:outputText value="#{stock.reference}"/>
</p:column>
<p:column headerText="Désignation" sortBy="#{stock.designation}">
<h:outputText value="#{stock.designation}"/>
</p:column>
<p:column headerText="Catégorie" sortBy="#{stock.categorie}">
<p:tag value="#{stock.categorie}" severity="info"/>
</p:column>
<p:column headerText="Quantité disponible">
<h:outputText value="#{stock.quantiteDisponible}"
style="#{stockView.isEnAlerte(stock) ? 'color: red; font-weight: bold;' : ''}"/>
<h:outputText value=" #{stock.uniteMesure}"/>
<h:outputText value=" ⚠️" rendered="#{stockView.isEnAlerte(stock)}"
title="Stock en alerte" style="color: red;"/>
</p:column>
<p:column headerText="Seuil d'alerte">
<h:outputText value="#{stock.seuilAlerte}"/>
<h:outputText value=" #{stock.uniteMesure}"/>
</p:column>
<p:column headerText="Prix unitaire">
<h:outputText value="#{stock.prixUnitaire}">
<f:converter converterId="fcfaConverter"/>
</h:outputText>
<h:outputText value=" Fcfa"/>
</p:column>
<p:column headerText="Valeur totale">
<h:outputText value="#{stock.quantiteDisponible * stock.prixUnitaire}">
<f:converter converterId="fcfaConverter"/>
</h:outputText>
<h:outputText value=" Fcfa"/>
</p:column>
<p:column headerText="Statut" sortBy="#{stock.statut}">
<p:tag value="#{stock.statut}"
severity="#{stock.statut == 'DISPONIBLE' ? 'success' : 'danger'}"/>
</p:column>
<p:column headerText="Actions" style="width: 150px;">
<p:commandButton icon="pi pi-eye" title="Voir les détails"
styleClass="ui-button-text"
action="#{stockView.viewDetails(stock.id)}"/>
</p:column>
</ui:define>
</ui:include>
</div>
</div>
</div>
</ui:define>
</ui:composition>