JSF/Tomahawk

Cette page a été rédigée il y a fort fort longtemps, et n'a pas tellement été mise à jour.

 

Vous savez, moi je ne crois pas qu'il y ait de bonne ou de mauvaise page. Moi, si je devais résumer mon wiki aujourd'hui avec vous, je dirais que c'est d'abord des rencontres. Des gens qui m'ont tendu la main, peut-être à un moment où je ne pouvais pas, où j'étais seul chez moi. Et c'est assez curieux de se dire que les hasards, les rencontres forgent une destinée... Parce que quand on a le goût de la chose, quand on a le goût de la chose bien faite, le beau geste, parfois on ne trouve pas l'interlocuteur en face je dirais, le miroir qui vous aide à avancer. Alors ça n'est pas mon cas, comme je disais là, puisque moi au contraire, j'ai pu ; et je dis merci au wiki, je lui dis merci, je chante le wiki, je danse le wiki... je ne suis qu'amour ! Et finalement, quand des gens me disent « Mais comment fais-tu pour avoir cette humanité ? », je leur réponds très simplement que c'est ce goût de l'amour, ce goût donc qui m'a poussé aujourd'hui à entreprendre une construction logicielle... mais demain qui sait ? Peut-être simplement à me mettre au service de la communauté, à faire le don, le don de soi.

Upload d’un fichier

Lorsque l’on utilise le composant <t:inputFileUpload>, il faut ajouter l’attribut enctype="multipart/form-data" au formulaire. Si cet attribut est absent, le message suivant est généré EvaluationException: Exception while invoking expression #{myBean.save}.

<h:form id="myForm" enctype="multipart/form-data">
  <t:inputFileUpload id="txtImage"
                     accept="image/*"
                     value="#{myBean.imageFile}"
                     storage="file"
                     styleClass="fileUploadInput"
                     required="true"
                     maxlength="200000"/>
  ...
  <h:commandButton id="btnValider" value="Valider" actionListener="#{myBean.save}"/>
</h:form>

Extensions Filter

Certains composants Tomahawk nécessite l’utilisation du filtre d’extensions de MyFaces. Ce filtre permet notamment à Tomahawk de télécharger des ressources associées aux composants (des images, des fichiers javascript…​), ressources qui sont stockées dans le fichier jar de Tomahawk. Par exemple, le composant Picklist utilise le fichier picklist.js qui est téléchargé via une URI du type /myapp/faces/myFacesExtensionResource/xxx/picklist.js.

A noter que le mapping du filtre ne correspond pas forcément au mapping de votre servlet. Ainsi, si la servlet est mappée suivant le pattern *.jsf, le filtre doit tout de même intercepter /faces/myFacesExtensionResource/*.

<filter-mapping>
  <filter-name>extensionsFilter</filter-name>
  <url-pattern>/faces/myFacesExtensionResource/*</url-pattern>
</filter-mapping>