Hello,
Packt Publishing asked me to review the book JSF 2.0 Cookbook. I’ll post a detailed review after I finish reading it.
In the meantime go and have a look to what the book is offering:
Demetrio
Hello,
Packt Publishing asked me to review the book JSF 2.0 Cookbook. I’ll post a detailed review after I finish reading it.
In the meantime go and have a look to what the book is offering:
Demetrio
Some times it can happen you need to re-render a block that includes the RichFaces editor: if the user is using to edit a piece of text, after the re-rendering the caret goes back to the first place so if the user were writing he’d have to manually move it every time it happens.
The solution to this problem (that you can use also for other purposes) is a javascript piece of code found on the TinyMCE forum, adapted for the RichFaces specific case:
<script type="text/javascript"> function moveCaretToTheEnd(editor_jsf_id) { var editor_id = editor_jsf_id + 'TextArea'; var ed = tinyMCE.getInstanceById(editor_id); var root = ed.dom.getRoot(); // This gets the root node of the editor window var lastnode = root.childNodes[root.childNodes.length - 1]; if (tinymce.isGecko) { // But firefox places the selection outside of that tag, so we need to go one level deeper: lastnode = lastnode.childNodes[lastnode.childNodes.length - 1]; } // Now, we select the node ed.selection.select(lastnode); // And collapse the selection to the end to put the caret there: ed.selection.collapse(false); } </script>
The only change I had to do is on the first line of the script as the id of the component we have to pass to get the editor instance is
To discover the id of the component we can use the built-in RichFaces function rich:clientId in this way (example in a poll component):
<a :poll reRender="currentChatMsgs,recipientList,threadFoldedSection" oncomplete="moveCaretToTheEnd('#{rich:clientId('myEditorJsfId')}')" enabled="true"/>
Demetrio Filocamo
——
JBoss RichFaces 3.3 (book) – http://www.packtpub.com/jboss-richfaces-3-3
Learn RichFaces step by step developing a sample application.
Hello,
I’ll try to write more on my blog and keep you update about every technique I use and that can be very useful to you as well.
Today I needed to submit a form with an editor element when the user pressed the “return” key (instead of creating a new line).
The code is not so complicate but as the rich:editor uses the TinyMCE component you have to search all around to find the right way. Better to have a complete solution.
It consists on creating an handler onKeyPress and call a javascript function (created by a:jsFunction) to submit our form. Simpler doing then saying it.
Let’s start by including the editor in the standard way (form, editor, submit button):
<h :form> <rich :editor value="#{editorBean.myValue}" /> <a :commandButton value="Send" reRender="something"/> </h>
I’ve kept it simple (stripped out all the params and attribute I use) to target only our problem.
Let’s define a javascript function handler for our use case:
<script type="text/javascript"> function returnSubmit(ed) { ed.onKeyPress.add(function(ed, e) { var keyCode = e.keyCode || e.which || e.charCode; if (keyCode == 13) { // My return key handler code here } }); } </script>
The ed variable will be passed by the editor; let’s configure our new function to the onsetup editor event:
<h :form> <rich :editor value="#{editorBean.myValue}" onsetup="returnSubmit(ed)" /> <a :commandButton value="Send" reRender="something"/> </h>
Now we have a function that is called for each keyPress event, and inside it we can execute something on “return” key press.
What we have to do is to submit the form, the best way is to create an Ajax javascript function using a:jsFunction: in this way we can do standard Ajax updates also reRendering elements, submitting params and all the thing we are used to
Let’s create the function:
<h :form> <rich :editor value="#{editorBean.myValue}" onsetup="returnSubmit(ed)" /> <a :commandButton value="Send" reRender="something"/> <a :jsFunction name="submitForm" reRender="something"/> </h>
Now we have to insert it into the handler and it’s done!
Here it is the whole code:
<script type="text/javascript"> function returnSubmit(ed) { ed.onKeyPress.add(function(ed, e) { var keyCode = e.keyCode || e.which || e.charCode; if (keyCode == 13) { // My return key handler code here submitForm(); } }); } </script>
<h :form> <rich :editor value="#{editorBean.myValue}" onsetup="returnSubmit(ed)" /> <a :commandButton value="Send" reRender="something"/> <a :jsFunction name="submitForm" reRender="something"/> </h>
Another tip
If with the js function you reRender components, do some action, set some property etc., to avoid duplication of code in the commandButton you can use the same js function into the button using the onclick attribute:
<h :form> <rich :editor value="#{editorBean.myValue}" onsetup="returnSubmit(ed)" /> <a :commandButton value="Send" onclick="submitForm();"/> <a :jsFunction name="submitForm" action="#{myBean.myAction}" oncomplete="doSomething();" reRender="first,second"> <f :setPropertyActionListener value="valueToSet" target="#{myBean.firstValue}"/> </a> </h>
Demetrio Filocamo
——
JBoss RichFaces 3.3 (book) – http://www.packtpub.com/jboss-richfaces-3-3
Learn RichFaces step by step developing a sample application.
An introduction to JBoss RichFaces framework and to the book JBoss RichFaces (Packt) by Demetrio Filocamo.
RichFaces is a very useful open source framework that allows you to add Ajax capability to your JSF application (using the standard JSF components) without the need to write JavaScript code and manage JavaScript compatibility between browsers.
You can read more about the book here: http://www.packtpub.com/jboss-richfaces-3-3
Hi guys,
I’m going to read and then review for Packt Publishing the new book JSF 1.2 Components by lan Hlavats, the developer behing JSF ToolBox for Dreamweaver. The book is about the most important JSF component frameworks we can use to empower our application. So starting from the Standard JSF Components we’ll go through Facelets, Apache Tomahawk, Apache Trinidad, ICEfaces, JBoss Seam JSF Components and JBoss RichFaces.
It is also technically reviewed by very know guys on JSF field like Cagatay Civici (PMC member of open source JSF implementation Apache MyFaces and the project leader of popular PrimeFaces framework), Ted Goddard (Chief Software Architect at ICEsoft Technologies and is the technical leader for ICEfaces), Kito D. Mann (editor-in-chief of JSF Central – www.jsfcentral.com – and the author of JavaServer Faces in Action – Manning) and others.
I’ll come back soon with something to say, in the meantime you can download the sample chapter about the Facelets Components by clicking here, or buy the book from the Packt website!
Thanks
Demetrio
Hi all,
the book I’ve worked on the last months has finally been published!!
JBoss RichFaces is a rich component library for JavaServer Faces and an AJAX framework that allows easy integration of Ajax capabilities into complex business applications. Do you wish to eliminate the time involved in writing JavaScript code and managing JavaScript-compatibility between browsers to build an Ajax web application quickly?
This book goes beyond the documentation to teach you how to do that. It will show you how to get the most out of JBoss RichFaces by explaining the key components and how you can use them to enhance your applications. Most importantly, you will learn how to integrate Ajax into your applications without using JavaScript, but only standard JSF components. You will learn how to create and customize your own components and add them to your new or existing applications.
First, the book introduces you to JBoss RichFaces and its components. It uses many examples of Ajax components which, among others, include: Calendar, Data Table, ToolTip, ToolBar, Menu, RichEditor, and Drag ‘n’ Drop. All these components will help you create the web site you always imagined. Key aspects of the RichFaces framework such as the Ajax framework, skinnability, and Component Development Kit (CDK) will help you customize the look of your web application. As you progress through the book, you will see a sample application that shows you how to build an advanced contact manager. You’re also going to be amazed to know about the advanced topics you will learn such as developing new components, new skins, optimizing a web application, inserting components dynamically using Java instead of XHTML, and using JavaScript to manage components. This book is more than a reference with component example code: it’s a manual that will guide you, step by step, through the development of a real Ajax JSF web application.
What This Book Covers
Example chapter
You can download a sample chapter, Chapter 8: Skin Customization, by clicking here.
Where to buy it
You can buy JBoss RichFaces 3.3 from the Packt Publishing website.
Free shipping to the US, UK, Europe and selected Asian countries. For more information, please read the Packt Publishing shipping policy.
Alternatively, you can buy the book from Amazon, BN.com, Computer Manuals and most internet book retailers.
Thank you!
Demetrio
Adding Cache support to a Seam project (Seam 2.1.x) it’s very simple and it is described in the official Seam developer documentation, anyways it doesn’t explain the exact steps to accomplish the task into an EAR project, I’m writing them to make your life even more simple
And the following declaration:
<cache:jboss-cache-provider configuration=”META-INF/treecache.xml” />
And here you find the way how to use it in your projects.
Hope you liked it.
Demetrio
Adding a one-to-one relationship with shared primary key can become a difficult task if the main table key is an auto-generated one.
Even the Hibernate Annotations documentation example only works with not auto-generated id, if you try to use an auto incremental id, for example,
it’s impossible to persist the 2 tables at the same time.
Surfing on the net I’ve seen some ppl with this kind of problem (I suppose one-to-one relationships are not so common, don’t know why) and most of ppl use the foreign-key approach that works ok but it’s not clean from my point of view, so I wanted to find a solution for my case.
The original example from the Hibernate Annotations Documentation is:
@Entity
public class Body {
@Id
public Long getId() { return id; }
@OneToOne(cascade = CascadeType.ALL)
@PrimaryKeyJoinColumn
public Heart getHeart() {
return heart;
}
…
}
@Entity
public class Heart {
@Id
public Long getId() { … }
}
As you can see this as not auto generated id and will not work just putting the @GeneratedValue annotation.
The final solution is:
@Entity
public class Body {
@Id
@GeneratedValue(strategy = IDENTITY)
public Long getId() { return id; }
@OneToOne(cascade = CascadeType.ALL)
@PrimaryKeyJoinColumn
public Heart getHeart() {
return heart;
}
…
}
@Entity
public class Heart {
@Id
@GeneratedValue(generator=”foreign”)
@GenericGenerator(name=”foreign”, strategy = “foreign”, parameters = {@Parameter(name=”property”, value=”body”)})
public Long getId() { …}
@OneToOne(mappedBy=”heart”)
public Body getBody() { … }
}
I had a little problem while working on a JBoss Seam project: I used the MySQL decimal(10,2) type for price value but, while running seam tests, the hbm2ddl schema validator gave me this error:
Caused by: org.hibernate.HibernateException: Wrong column type: shippingCost, expected: numeric(10,0)
[testng] at org.hibernate.mapping.Table.validateColumns(Table.java:261)
[testng] at org.hibernate.cfg.Configuration.validateSchema(Configuration.java:1083)
[testng] at org.hibernate.tool.hbm2ddl.SchemaValidator.validate(SchemaValidator.java:116)
[testng] at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:317)
[testng] at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1294)
[testng] at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:918)
[testng] at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:656)
[testng] … 68 more
The problem is that hbm2java usa a wrong column definition for the entity property, in fact the @Column annotation on the property was:
@Column(name = “shippingCost”, nullable = false, precision = 10)
The solution is simple, just change it to:
@Column(name = “shippingCost”, nullable = false, precision = 10, scale=2, columnDefinition=”decimal(10,2)”)
Now the type is correctly defined and the schema validator doesn’t return any error.
Demetrio
Ho trovato questo post del 2001 sulla Programmazione Windows tra le mie cose salvate, è vecchio ma ancora divertente
Al principio, c’erano le API di Windows e “l’inferno delle DLL”, che roba e’? direte voi, semplice! E’ quella condizione per cui si installa un nuovo programma e 1) il programma non funziona e 2) tutto il resto smette di funzionare. Questo perche’ quel coglione che ha scritto l’installazione ha fatto in modo che questa sovrascrivesse 100 DLL di sistema che erano gia’ presenti, mentre non ne ha sovrascritte altre 100.
Dopo un po’ di tempo Microsoft invento’ VERSIOINFO, cioe’ la possibilita’ di ficcare dentro la DLL un numero di versione che il programma di installazione fatto bene (nessuno quindi) dovrebbe verificare per evitare di sovrascrivere una DLL piu’ nuova con una piu’ vecchia. OOOOOOOHHHHH!!!!
Ma nello stesso tempo, un altro gruppo di sviluppo all’interno di Microsoft stessa scopri’ un baco colossale nel DDE: che non lo avevano fatto loro! Cosi’ inventarono OLE, che e’ come il DDE, ma diverso, e proclamarono che l’OLE avrebbe risolto “l’inferno delle DLL”.
Ma poco tempo dopo, Microsoft “vide la luce” e le MFC emersero come soluzione ad ogni problema possibile immaginabile, be’ OLE non se ne stette seduto sugli allori, cosi’ riemerse come COM, che e’ come OLE, ma diverso (!).
Ma un altro gruppo di sviluppatori Microsoft scopri’ un baco colossale nelle MFC: non le avevano scritte loro! Essi procedettero a correggere il problema introducendo le ATL, che sono come le MFC, ma diverse, e nello stesso tempo si diedero da fare per nascondere tutti quei bei dettagli relativi a COM (o era OLE?) che il gruppo COM stava cercando di spiegarci.
Questo spinse il gruppo COM a cambiare nome, cosi’ vide la luce ActiveX, che e’ esattamente come OLE (o COM?) ma diverso, inoltre utilizza un’innovativo sistema di interfacce che (indovina un po’) elimina “l’inferno delle DLL”, non solo, ma rende anche il nostro codice scaricabile da Internet (insieme a tutti i virus dell’universo).
Come un figlio misconosciuto, il gruppo OS richiamo’ l’attenzione sul nuovo nato: Cairo che nessuno riusci’ mai a spiegare, lasciamo perdere poi produrre e distribuire. Nonostante cio’ questi introdussero un’affascinante meccanismo di protezione dei file che era espressamente pensato per eliminare l’inferno delle DLL!
A questo punto pero’, il gruppo di sviluppo linguaggi scopri’ un terribile errore in Java: non lo avevano fatto loro! Il rimedio fu la creazione di “J” o Jole o ActiveJ, che era come Java, ma diverso… tutto questo era molto eccitante, ma Sun apri’ un contenzioso contro Microsoft sostenendo che c’e’ un limite al quantitativo di schifezze che puoi rilasciare in un determinato tempo, e questo mise fine a “J” (o era Jole?).
Ovviamente tutto questo distolse l’attenzione da ActiveX (o era COM?), i quali pero’ ritornarono alla ribalta con COM+ (ma non avrebbe dovuto essere ActiveX+?) ed MTS (che non ho mai capito perche’ sia solo ‘MTS’ e non abbia dentro un qualche ‘Active’ o ‘+’ o ‘COM’…).
Nello stesso tempo pero’, un altro gruppo se ne usci’ con Windows DNA, che pero’ scomparve prima che io avessi avuto il tempo di capire a che cosa era uguale pero’ diverso…
Recentemente poi, Microsoft ha scoperto un altro terribile errore in Internet: che non lo hanno fatto loro! Ecco quindi la creazione di .NET, che e’ come Internet, ma con piu’ marketing. E che (sia chiaro questo) eliminera’ l’inferno delle DLL! Inoltre introduce un bellissimo linguaggio detto C# (c’era un errore terribile in Java come detto prima), e distribuira’ un bellissimo runtime che consentira’ di eseguire i programmi (c’e’ un errore terribile nel farlo fare alla CPU), inoltre include un esclusivo sistema di login centralizzato (c’e’ un errore terribile nel non inserire tutte le vostre password in un server Microsoft) e che rivoluzionera’ il modo di programmare…
Ma intanto, il gruppo OS e’ ritornato alla ribalta, hanno scoperto un errore colossale in Windows NT: non lo hanno fatto loro! (a no?), ma hanno pronta la soluzione: Window XP! (perche’ non Windows XP+ o ActiveWindows?) il quale (indovina un po’) eliminera’ l’inferno delle DLL!
…io intanto continuo ad usare Linux…
Davide Bianchi
13 Febbraio 2001