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)
112 lines
6.8 KiB
HTML
112 lines
6.8 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">Matériels - 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 des Matériels</h1>
|
|
<p:commandButton value="Nouveau matériel" icon="pi pi-wrench"
|
|
action="#{materielView.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="#{materielView}"/>
|
|
<ui:param name="tableId" value="materielsTable"/>
|
|
<ui:define name="filter-fields">
|
|
<div class="grid">
|
|
<div class="col-12 md:col-4">
|
|
<h:outputLabel for="filtreNom" value="Nom"/>
|
|
<p:inputText id="filtreNom" value="#{materielView.filtreNom}"
|
|
placeholder="Rechercher par nom..." style="width: 100%;"/>
|
|
</div>
|
|
<div class="col-12 md:col-4">
|
|
<h:outputLabel for="filtreType" value="Type"/>
|
|
<p:selectOneMenu id="filtreType" value="#{materielView.filtreType}" style="width: 100%;">
|
|
<f:selectItem itemLabel="Tous" itemValue="TOUS"/>
|
|
<f:selectItem itemLabel="Engin" itemValue="ENGIN"/>
|
|
<f:selectItem itemLabel="Outil" itemValue="OUTIL"/>
|
|
<f:selectItem itemLabel="Véhicule" itemValue="VEHICULE"/>
|
|
<f:selectItem itemLabel="Équipement" itemValue="EQUIPEMENT"/>
|
|
</p:selectOneMenu>
|
|
</div>
|
|
<div class="col-12 md:col-4">
|
|
<h:outputLabel for="filtreStatut" value="Statut"/>
|
|
<p:selectOneMenu id="filtreStatut" value="#{materielView.filtreStatut}" style="width: 100%;">
|
|
<f:selectItem itemLabel="Tous" itemValue="TOUS"/>
|
|
<f:selectItem itemLabel="Disponible" itemValue="DISPONIBLE"/>
|
|
<f:selectItem itemLabel="En service" itemValue="EN_SERVICE"/>
|
|
<f:selectItem itemLabel="En maintenance" itemValue="EN_MAINTENANCE"/>
|
|
<f:selectItem itemLabel="Hors service" itemValue="HORS_SERVICE"/>
|
|
</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="materielsForm"/>
|
|
<ui:param name="tableId" value="materielsTable"/>
|
|
<ui:param name="viewBean" value="#{materielView}"/>
|
|
<ui:param name="var" value="materiel"/>
|
|
<ui:param name="title" value="Liste des matériels"/>
|
|
<ui:param name="createPath" value="/materiels/nouveau"/>
|
|
<ui:define name="columns">
|
|
<p:column headerText="Nom" sortBy="#{materiel.nom}">
|
|
<h:outputText value="#{materiel.nom}"/>
|
|
</p:column>
|
|
<p:column headerText="Type" sortBy="#{materiel.type}">
|
|
<p:tag value="#{materiel.type}" severity="info"/>
|
|
</p:column>
|
|
<p:column headerText="Marque" sortBy="#{materiel.marque}">
|
|
<h:outputText value="#{materiel.marque}"/>
|
|
</p:column>
|
|
<p:column headerText="Modèle">
|
|
<h:outputText value="#{materiel.modele}"/>
|
|
</p:column>
|
|
<p:column headerText="N° série">
|
|
<h:outputText value="#{materiel.numeroSerie}"/>
|
|
</p:column>
|
|
<p:column headerText="Valeur d'achat">
|
|
<h:outputText value="#{materiel.valeurAchat}">
|
|
<f:converter converterId="fcfaConverter"/>
|
|
</h:outputText>
|
|
<h:outputText value=" Fcfa"/>
|
|
</p:column>
|
|
<p:column headerText="Date achat" sortBy="#{materiel.dateAchat}">
|
|
<h:outputText value="#{materiel.dateAchat}">
|
|
<f:convertDateTime pattern="dd/MM/yyyy"/>
|
|
</h:outputText>
|
|
</p:column>
|
|
<p:column headerText="Statut" sortBy="#{materiel.statut}">
|
|
<p:tag value="#{materiel.statut}"
|
|
severity="#{materiel.statut == 'DISPONIBLE' ? 'success' : (materiel.statut == 'HORS_SERVICE' ? 'danger' : 'warning')}"/>
|
|
</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="#{materielView.viewDetails(materiel.id)}"/>
|
|
</p:column>
|
|
</ui:define>
|
|
</ui:include>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</ui:define>
|
|
</ui:composition>
|