Let's say you want to replace all email addresses from string to some clickable element or maybe add custom handler. I'll show you a way how to do it.
For the purpose of this example, we will assume that server side response to the client some information that contains different email addresses. Something like this:
<b>Main requirements:</b><br/>Expertise in Java, Spring Framework, Hibernate, JMS, Enterprise Integration Platforms.<br/>Experience with GWT, JavaScript, JQuery.<br/>Strong object oriented programming concepts: Ability to develop flexible and scalable concept.<br/>Strong understanding of GoF Design Patterns, J2EE Patterns and anti-patterns.<br/> <b>Nice to Have:</b><br/>Experience working with coherent, terracotta technology.<br/>Experience in Subversion, Maven.<br/>Outstanding analytical and communication skills.<br/><br/>Unix/Linux Experience.<br/>Client contact details: first@gmail.com<br/>Email your resume in Word to: second@gmail.com
But we need to hide the addresses from the UI (so that they do not appear in plain text within HTML) and replace to anchors with text "Send an email message".
Next I will show the code in chunks, with a bit of comments for each chunk.
The first things we should do its write a method that replaces each email address that matches the regular expression.
The first things we should do its write a method that replaces each email address that matches the regular expression.
Next step we will find all <a></a> elements and convert them into GWT#anchors.
/**
* How to extract all emails from string and replace them.
* Search and replacement e-mails.
*
* @author Dmitry Nikolaenko
*
*/
public final class StringUtils {
public static final String EMAIL_REGEXP =
"([_A-Za-z0-9-]+)(\\.[_A-Za-z0-9-]+)*@[A-Za-z0-9-]+(\\.[A-Za-z0-9-]+)*(\\.[A-Za-z]{2,})";
/**
* Only constructed by ourselves. Class contains only static methods.
*/
private StringUtils() {}
/**
* Replaces each email that matches the regular expression.
*
* @param text the <code>String</code> that is contained required text to handle
* @return the resulting <tt>String</tt>
*/
public static String replaceEmail(final String text) {
// array without any emails
String[] words = text.split(EMAIL_REGEXP);
String emails = text;
String result = text;
if (words.length > 1) {
// gather only emails in one string
for (String word : words) {
if (!word.trim().isEmpty()) {
emails = emails.replace(word, " ").trim();
}
}
if (!emails.isEmpty()) {
// execute replacement for pattern
for (String word : emails.split(" ")) {
if (text.contains(word)) {
result = result.replaceAll(word, constructReplacement(word));
}
}
}
}
return result;
}
private static String constructReplacement(final String email) {
// String#format() doesn't work in GWT
//return String.format("<a href=\"mailto:%s\">%s</a>", email, email);
return new StringBuilder("<a href=mailto:").append(email).
append(">").append("Send email").append("</a>").toString();
}
}
RootPanel.get().add(new Button("Change click handler for emails") {{
addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
NodeList<Element> anchors = html.getElement().getElementsByTagName("a");
for (int i = 0; i < anchors.getLength(); i++) {
Element anchor = anchors.getItem(i);
final Anchor email = new Anchor(anchor.getInnerHTML());
email.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
Window.alert("Send an email message");
}
});
html.addAndReplaceElement(email, anchor);
}
}
});
}});
After(after data processing):
Here's a link to the source code.
Комментариев нет:
Отправить комментарий