Créer Eclipse RAP Widget à partir de ClientScripting widget
2. ClientScripting-Based Widget
Supposons que vous ayez un Widget écrit en JavaScript, vous souhaitez créer un RAP Widget basé sur le JavaScript widget ci-dessus. C'est tout à fait possible.
L'exemple LogJS est un widget écrit en javascript, il comprend 2 fichiers logjs.js & logjs.css. Notre objectif est de créer un widget sur RAP qui utilise LogJS.
L'exemple LogJS est un widget écrit en javascript, il comprend 2 fichiers logjs.js & logjs.css. Notre objectif est de créer un widget sur RAP qui utilise LogJS.
data:image/s3,"s3://crabby-images/68586/685861b2e95ba63ec310dbf34cf1a787950f5286" alt=""
L'image de LogJS sur des pages html
data:image/s3,"s3://crabby-images/d3b7d/d3b7d6ee856c3d4ddeb6e014e4010b643f955c29" alt=""
logjs.js
function LogJS(element) {
this.div = document.createElement("div");
this.div.className = 'logjs';
element.appendChild(this.div);
this.div.innerHTML = "<p>INFO: Loaded APR based Apache Tomcat Native library 1.1.22.</p>";
this.appendInfo = function(text) {
this.div.innerHTML = this.div.innerHTML
+ "<p class='info'>INFO: "+ text +"</p>";
};
this.appendErr = function(text) {
this.div.innerHTML = this.div.innerHTML
+ "<p class='err'>ERROR: "+ text +"</p>";
};
this.appendWarn = function(text) {
this.div.innerHTML = this.div.innerHTML
+ "<p class='warn'>WARN: "+ text +"</p>";
};
this.clearAll = function() {
this.div.innerHTML = "";
};
}
logjs.css
.logjs {
width: 100%;
height: 100%;
margin: 0px;
padding: 5px;
border: 1px solid #C4C4C4;
color: #0AC005;
background-color: #111111;
font: 13px Verdana, "Lucida Sans", Arial, Helvetica, sans-serif;
white-space: nowrap;
overflow-y: scroll;
overflow-x: scroll;
}
.logjs p {
margin: 0px;
padding: 0px;
}
.logjs .info {
}
.logjs .err {
color: red;
}
.logjs .warn {
color: yellow;
}
index.html
<html>
<head>
<script type="text/javascript" src="logjs.js"></script>
<link rel="stylesheet" type="text/css" href="logjs.css" />
</head>
<body>
<div id="logjs1" style="width: 500px; height: 300px;"></div>
<br><br>
<button onclick="appendInfo('Starting Servlet Engine: Apache Tomcat/7.0.23')">Add Info Line</button>
<button onclick="appendErr('Starting Servlet Engine: Apache Tomcat/7.0.23')">Add Error Line</button>
<button onclick="appendWarn('Starting Servlet Engine: Apache Tomcat/7.0.23')">Add Warn Line</button>
<script type="text/javascript">
var element = document.getElementById('logjs1');
var logjs = new LogJS(element);
function appendErr(text) {
logjs.appendErr(text);
}
function appendWarn(text) {
logjs.appendWarn(text);
}
function appendInfo(text) {
logjs.appendInfo(text);
}
</script>
</body>
</html>
3. RAPTarget
Tout d'abord, nous devons créer un projet pour configurer l'environnement RAP. Essentiellement, c'est la déclaration de la bibliothèque RAP.
Créez un Java project - RAPTarget.
data:image/s3,"s3://crabby-images/8fe26/8fe2602293e123cedfdb1ebdc56e5556093a3ce4" alt=""
Create file "Target Define"
data:image/s3,"s3://crabby-images/d2fdb/d2fdbca9dfaf89a30046c23d43e06b3498bf15f5" alt=""
data:image/s3,"s3://crabby-images/fde4e/fde4e927687f3590d66b5971482cfdf56b11859f" alt=""
data:image/s3,"s3://crabby-images/bd4ca/bd4cac5ff7cc2a8f0dbc22b24d81f06b719d78de" alt=""
Ajoutez la bibliothèque
data:image/s3,"s3://crabby-images/81f83/81f83d9ab5a096ecd51ac76fce9a1064ec7dbf37" alt=""
Déclarez la bibliothèque RAP
- Name: RAP Runtime 2.3
- Location: http://download.eclipse.org/rt/rap/2.3
data:image/s3,"s3://crabby-images/d7ea5/d7ea50678133aa74b57f664d4b71ad48185d7261" alt=""
data:image/s3,"s3://crabby-images/ab7f4/ab7f4ee564310517a5ebdedd036b759601475500" alt=""
Cliquez sur "Set as Target Platform" pour que la bibliothèque RAP fonctionne avec tout projet dans l'espace de travail (workspace).
data:image/s3,"s3://crabby-images/9ad1e/9ad1e3005348ff0588b2466c415b487f699cf24e" alt=""
4. Créer un Plugin Project - LogComposite
- File/New/Other...
data:image/s3,"s3://crabby-images/c04ab/c04ab1b339999d807e723c3246886996f5103f8d" alt=""
Saisissez :
- Project Name: LogComposite
data:image/s3,"s3://crabby-images/b6019/b60190bb71f07a6fa9babb8e01986f90525e9454" alt=""
Ne sélectionnez aucun modèle (Template).
data:image/s3,"s3://crabby-images/5d7ab/5d7ab8e3330f91a04eed113a80e2b64a5fc8ea66" alt=""
Votre projet a été créé :
data:image/s3,"s3://crabby-images/4fa76/4fa7665d8f6bf91e66e27fa7325838dbad5386ef" alt=""
Déclarez les plugins requis pour ce plugin :
- org.eclipse.rap.ui
- org.eclipse.equinox.http.registry
data:image/s3,"s3://crabby-images/ef6c0/ef6c028a575897304373c807799f176c07e72f44" alt=""
Vous devez créer un paquet logjsreources et copier les fichiers javascript, style relatifs dans ce package. Comme l'illustration ci-dessous :
data:image/s3,"s3://crabby-images/497e0/497e0a6b511294d60e6eb55f0113e986f8fc458c" alt=""
Ensuite, créez 2 fichiers javascript :
- rap-handler.js
- Agissant comme l'intermédiaire de communication entre RAP Widget et ClientScripting-based Widget.
- load-css-file.js
- Ce fichier fait la tâche de charger des fichiers css sur la page Web (en particulier, c'est logjs.css).
data:image/s3,"s3://crabby-images/c2212/c2212d76c5de0fa50c816a6eb068ab28feb2fe86" alt=""
load-css-file.js
//
var cssId = 'logjs-css-file';
if (!document.getElementById(cssId))
{
var head = document.getElementsByTagName('head')[0];
var link = document.createElement('link');
link.id = cssId;
link.rel = 'stylesheet';
link.type = 'text/css';
link.href = '/rwt-resources/logjs/logjs.css';
link.media = 'all';
head.appendChild(link);
}
rap-handler.js
(function() {
'use strict';
rap.registerTypeHandler("o7planning.LogComposite", {
factory : function(properties) {
return new o7planning.LogComposite(properties);
},
destructor : "destroy",
properties : [ "abc" ],
events : [],
methods : [ 'appendWarn', 'appendErr', 'appendInfo', 'clearAll' ]
});
if (!window.o7planning) {
window.o7planning = {};
}
// Constructor
o7planning.LogComposite = function(properties) {
bindAll(this, [ "layout", "onReady", "onSend", "onRender", "onChange" ]);// @custom
this.parent = rap.getObject(properties.parent);
this.element = document.createElement("div");
this.parent.append(this.element);
this.parent.addListener("Resize", this.layout);
this.logjs = new LogJS(this.element);
// Render interface
rap.on("render", this.onRender);
};
o7planning.LogComposite.prototype = {
ready : false,
onChange : function() {
},
onReady : function() {
},
// Render interface in Client
onRender : function() {
if (this.element.parentNode) {
rap.off("render", this.onRender);
rap.on("render", this.onRender);
rap.on("send", this.onSend);
}
},
//
onSend : function() {
},
destroy : function() {
rap.off("send", this.onSend);
try {
this.element.parentNode.removeChild(this.element);
} catch (e) {
try {
console
.log('error call this.element.parentNode.removeChild(this.element) :'
+ e);
} catch (e) {
}
}
},
layout : function() {
if (this.ready) {
var area = this.parent.getClientArea();
this.element.style.left = area[0] + "px";
this.element.style.top = area[1] + "px";
this.editor.resize(area[2], area[3]);
}
},
setAbc : function(abc) {
},
appendErr : function(json) {
var text= json["text"];
this.logjs.appendErr(text);
},
appendWarn : function(json) {
var text= json["text"];
this.logjs.appendWarn(text);
},
appendInfo : function(json) {
var text= json["text"];
this.logjs.appendInfo(text);
},
clearAll : function() {
this.logjs.clearAll();
}
};
var bind = function(context, method) {
return function() {
return method.apply(context, arguments);
};
};
var bindAll = function(context, methodNames) {
for (var i = 0; i < methodNames.length; i++) {
var method = context[methodNames[i]];
context[methodNames[i]] = bind(context, method);
}
};
var async = function(context, func) {
window.setTimeout(function() {
func.apply(context);
}, 0);
};
}());
LogComposite est un Widget qui s'étend de la classe Composite et possède une certaine méthode comme LogJS
- appendErr
- appendInfo
- appendWarn
- clearAll
data:image/s3,"s3://crabby-images/f94fb/f94fb7bd3dcf1a03968eeb55d1ed0fc9bd02e736" alt=""
LogComposite.java
package org.o7planning.customwidget.logcomposite;
import java.io.IOException;
import java.io.InputStream;
import org.eclipse.rap.json.JsonObject;
import org.eclipse.rap.json.JsonValue;
import org.eclipse.rap.rwt.RWT;
import org.eclipse.rap.rwt.client.service.JavaScriptLoader;
import org.eclipse.rap.rwt.remote.AbstractOperationHandler;
import org.eclipse.rap.rwt.remote.Connection;
import org.eclipse.rap.rwt.remote.OperationHandler;
import org.eclipse.rap.rwt.remote.RemoteObject;
import org.eclipse.rap.rwt.service.ResourceManager;
import org.eclipse.rap.rwt.widgets.WidgetUtil;
import org.eclipse.swt.widgets.Composite;
public class LogComposite extends Composite {
private static final long serialVersionUID = -8590973451146216709L;
private RemoteObject remoteObject;
// The directory containing the file js, css.
private static final String REAL_RESOURCE_PATH = "logjsresources";
private static final String REGISTER_PATH = "logjs";
private static final String REMOTE_TYPE = "o7planning.LogComposite";
private final String[] FILENAMES = { "logjs.css", "logjs.js" ,"load-css-file.js" , "rap-handler.js" };
private final OperationHandler operationHandler = new AbstractOperationHandler() {
private static final long serialVersionUID = -1979566336567602883L;
@Override
public void handleSet(JsonObject properties) {
System.out.println("##### handleSet ..:");
JsonValue textValue = properties.get("text");
if (textValue != null) {
// text = textValue.asString();
}
}
@Override
public void handleCall(String method, JsonObject parameters) {
System.out.println("##### handleCall ..:" + method);
}
@Override
public void handleNotify(String event, JsonObject properties) {
System.out.println("##### handleNotify ..:" + event);
if (event.equals("dirty")) {
}
}
};
/**
* Create the composite.
*
* @param parent
* @param style
*/
public LogComposite(Composite parent, int style) {
super(parent, style);
// Note: Catching error when viewed on WindowBuilder
try {
registerResources();
loadJavaScript();
Connection connection = RWT.getUISession().getConnection();
remoteObject = connection.createRemoteObject(REMOTE_TYPE);
remoteObject.setHandler(operationHandler);
//
remoteObject.set("parent", WidgetUtil.getId(this));
} catch (Exception e) {
e.printStackTrace();
// throw new RuntimeException(e);
}
}
@Override
public void dispose() {
super.dispose();
// Call destroy() function in rap-handler.js
remoteObject.destroy();
}
// Load the js files required at Client.
private void loadJavaScript() {
JavaScriptLoader jsLoader = RWT.getClient().getService(
JavaScriptLoader.class);
ResourceManager resourceManager = RWT.getResourceManager();
// Load file logjs.js into page
jsLoader.require(resourceManager.getLocation(REGISTER_PATH + "/"
+ "logjs.js"));
// Load file load-css-file.js into page
jsLoader.require(resourceManager.getLocation(REGISTER_PATH + "/"
+ "load-css-file.js"));
// Load file rap-handler.js into page.
jsLoader.require(resourceManager.getLocation(REGISTER_PATH + "/"
+ "rap-handler.js"));
}
private void registerResources() throws IOException {
ResourceManager resourceManager = RWT.getResourceManager();
for (String fileName : FILENAMES) {
// After registering, you can access on your browser:
// (http://localhost:port/rwt-resources/logjs/abc.js )
// logjs/abc.js
String path = REGISTER_PATH + "/" + fileName;
// Check this resource has been registered yet.
boolean isRegistered = resourceManager.isRegistered(path);
if (!isRegistered) {
ClassLoader classLoader = LogComposite.class.getClassLoader();
// Real Path (in src)
// logjsresources/abc.js
String realPath = REAL_RESOURCE_PATH + "/" + fileName;
InputStream inputStream = classLoader
.getResourceAsStream(realPath);
if (inputStream == null) {
throw new IOException("File not found " + realPath);
}
try {
// Register resource
resourceManager.register(path, inputStream);
} finally {
inputStream.close();
}
}
}
}
@Override
protected void checkSubclass() {
}
public void appendWarn(String text) {
System.out.println("appendWarn");
JsonObject obj= new JsonObject();
obj.add("text", text);
this.remoteObject.call("appendWarn", obj);
}
public void appendErr(String text) {
System.out.println("appendErr");
JsonObject obj= new JsonObject();
obj.add("text", text);
this.remoteObject.call("appendErr", obj);
}
public void appendInfo(String text) {
System.out.println("appendInfo");
JsonObject obj= new JsonObject();
obj.add("text", text);
this.remoteObject.call("appendInfo", obj);
}
public void clearAll() {
System.out.println("clearAll");
this.remoteObject.call("clearAll", new JsonObject());
}
}
Vous devez exporter le package org.o7planning.customwidget.logcomposite, pour permettre aux autres plugins à utiliser la classe LogComposite dans ce plugin.
data:image/s3,"s3://crabby-images/00679/00679cd2d7260440b11de2447d1d609d7b459b43" alt=""
5. Test LogComposite
Vous devez créer un projet pour vérifier LogComposite. Ici, je crée une basic RAP application.
- File/New/Other...
data:image/s3,"s3://crabby-images/e6bb4/e6bb418962439b074a97439a7e1035bd1b2a10a6" alt=""
data:image/s3,"s3://crabby-images/ab782/ab782e69b059efbc8a61eee1e614fa836cc391b0" alt=""
data:image/s3,"s3://crabby-images/589c5/589c53ba88e8bba485f037ae38c3adca3b4145cf" alt=""
data:image/s3,"s3://crabby-images/56026/56026fd594d032c4662a9788796e348237aa890d" alt=""
data:image/s3,"s3://crabby-images/95617/95617ff360931b86bc491df03365e0ee8fd42b78" alt=""
Enregistrez pour utiliser LogComposite plugin
data:image/s3,"s3://crabby-images/30312/303126e0d0ea2dc8be4f6ba8b974f3dc0f68b39c" alt=""
L'ouverture du code de la classe BasicEntryPoint modifié qui vous permet de concevoir l'interface sur WindowBuilder.
data:image/s3,"s3://crabby-images/629b5/629b57c73dde52410f925c09819f0e3608fd1b13" alt=""
@Override
protected void createContents(Composite parent) {
// Change code, to enable open with WindowBuilder.
parent.setLayout(new FillLayout());
Composite main = new Composite(parent, SWT.NONE);
}
Cliquez sur le bouton droit de la class BasicEntryPoint et sélectionnez "Open with/WindowBuilder Editor".
data:image/s3,"s3://crabby-images/cbbbd/cbbbd99828524afcd421fdbb0429b3df0bf3d7b9" alt=""
data:image/s3,"s3://crabby-images/c381d/c381dd14fd644704c27fc41df9ac4b1ad0dfc66a" alt=""
data:image/s3,"s3://crabby-images/628cb/628cb6e21454d5fb2ced175b8e1425b9fe660420" alt=""
data:image/s3,"s3://crabby-images/8cd5d/8cd5da70895381ebee8a3ea1858a39cfda0db855" alt=""
data:image/s3,"s3://crabby-images/8a4d3/8a4d3a20236addf18c2beb4220870e3ece72aa7f" alt=""
data:image/s3,"s3://crabby-images/d5f79/d5f79e6fcc1c33a47bb402db2f36c2ab8beb9c62" alt=""
LogComposite est disponible sur Palette, comme les autres Widget, vous pouvez facilement le glisser et déposer dans votre interface de conception.
data:image/s3,"s3://crabby-images/75d07/75d0766129732be70cffca5d0d36c73d51f02705" alt=""
data:image/s3,"s3://crabby-images/b33ec/b33ecf181915c6e8ca574b8429edebf291e360f2" alt=""
BasicEntryPoint.java
package simplerapapplication;
import org.eclipse.rap.rwt.application.AbstractEntryPoint;
import org.eclipse.swt.SWT;
import org.eclipse.swt.events.SelectionAdapter;
import org.eclipse.swt.events.SelectionEvent;
import org.eclipse.swt.layout.FillLayout;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.layout.RowLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.o7planning.customwidget.logcomposite.LogComposite;
public class BasicEntryPoint extends AbstractEntryPoint {
private LogComposite logComposite;
/**
* @wbp.parser.entryPoint
*/
@Override
protected void createContents(Composite parent) {
parent.setLayout(new FillLayout());
Composite main = new Composite(parent, SWT.NONE);
main.setLayout(new GridLayout(1, false));
logComposite = new LogComposite(main, SWT.BORDER);
logComposite.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true, 1, 1));
Composite composite = new Composite(main, SWT.NONE);
composite.setLayout(new RowLayout(SWT.HORIZONTAL));
composite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false, 1, 1));
Button btnNewButton = new Button(composite, SWT.NONE);
btnNewButton.addSelectionListener(new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
allErrorLine();
}
});
btnNewButton.setText("Add Error Line");
Button btnNewButton_1 = new Button(composite, SWT.NONE);
btnNewButton_1.addSelectionListener(new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
addWarningLine();
}
});
btnNewButton_1.setText("Add Warning Line");
Button btnNewButton_2 = new Button(composite, SWT.NONE);
btnNewButton_2.addSelectionListener(new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
clearAll();
}
});
btnNewButton_2.setText("Clear ALL");
}
private void allErrorLine() {
logComposite.appendErr("Starting Servlet Engine: Apache Tomcat/7.0.23");
}
private void addWarningLine() {
logComposite.appendWarn("Starting Servlet Engine: Apache Tomcat/7.0.23");
}
private void clearAll() {
logComposite.clearAll();
}
}
Exécution de l’application :
Cliquez sur le bouton droit sur le projet "SimpleRAPApplication", sélectionnez :
- Run As/RAP Application
data:image/s3,"s3://crabby-images/1e11f/1e11fdab39fe643b8257f19a50895a611c17712e" alt=""
L'erreur ci-dessus montre que vous avez besoin de configurer RAPruntime avant d'exécuter l'application.
data:image/s3,"s3://crabby-images/b9184/b9184d331485bb12bf277e16ea26b938170d0aa7" alt=""
data:image/s3,"s3://crabby-images/109ca/109ca107a6325e5785cc7270e3d01215579c130d" alt=""
data:image/s3,"s3://crabby-images/e6aed/e6aed4f11b9d78fb13ddc7a1b9d4f5ff95b2ee80" alt=""
Le résultat de l'exécution de l'application :
data:image/s3,"s3://crabby-images/3f539/3f53950ef86101fa65b92a67ea5d797fc3f2321c" alt=""
Eclipse RAP
- Installer RAP Tools pour Eclipse
- Quelle plate-forme devez-vous choisir pour développer des applications de bureau Java?
- Le Tutoriel Eclipse RAP pour débutant - Application e4 Workbench
- Installation de la plate-forme cible Eclipse RAP (RAP Target Platform)
- Créer Eclipse RAP Widget à partir de ClientScripting widget
- Installer RAP e4 Tooling pour Eclipse
Show More
Tutoriels Eclipse Technology
- Installer Tycho pour Eclipse
- Tutoriel Java OSGi pour débutant
- Créer un projet Java OSGi avec Maven et Tycho
- Installer WindowBuilder pour Eclipse
- Quelle plate-forme devez-vous choisir pour développer des applications de bureau Java?
- Programmation de l'application Java Desktop à l'aide de SWT
- Le Tutoriel de Eclipse JFace
- Installation de la plate-forme cible Eclipse RAP (RAP Target Platform)
- Installer RAP e4 Tooling pour Eclipse
- Créer Eclipse RAP Widget à partir de ClientScripting widget
- Le Tutoriel Eclipse RCP 4 pour débutant - Application e4 Workbench
- Installer RAP Tools pour Eclipse
- Le Tutoriel Eclipse RAP pour débutant - Application e4 Workbench
Show More