Remove bundle
[gpl/argeo-suite.git] / swt / org.argeo.app.geo.swt / src / org / argeo / app / geo / swt / SwtJSMapPart.java
index 16fa83edb96bd13a129f059d90ba4a351ac6bfb4..ad1a9faa9989afff42dbc158dc1f8b68184aa400 100644 (file)
@@ -1,70 +1,32 @@
 package org.argeo.app.geo.swt;
 
-import java.util.Locale;
-import java.util.concurrent.CompletableFuture;
 import java.util.concurrent.CompletionStage;
 import java.util.function.Consumer;
 import java.util.function.Function;
-
-import org.argeo.api.cms.CmsLog;
+import org.argeo.app.geo.GeoUtils;
 import org.argeo.app.geo.ux.JsImplementation;
 import org.argeo.app.geo.ux.MapPart;
-import org.argeo.cms.swt.CmsSwtUtils;
-import org.eclipse.swt.SWT;
-import org.eclipse.swt.browser.Browser;
-import org.eclipse.swt.browser.BrowserFunction;
-import org.eclipse.swt.browser.ProgressEvent;
-import org.eclipse.swt.browser.ProgressListener;
-import org.eclipse.swt.layout.GridData;
+import org.argeo.app.swt.js.SwtBrowserJsPart;
 import org.eclipse.swt.widgets.Composite;
 
 /**
- * An SWT implementation of {@link MapPart} based on JavaScript execute in a
- * {@link Browser} control.
+ * An SWT implementation of {@link MapPart} based on JavaScript.
  */
-public class SwtJSMapPart extends Composite implements MapPart {
+public class SwtJSMapPart extends SwtBrowserJsPart implements MapPart {
        static final long serialVersionUID = 2713128477504858552L;
 
-       private final static CmsLog log = CmsLog.getLog(SwtJSMapPart.class);
-
-       private final static String GLOBAL_THIS_ = "globalThis.";
-
-       private final Browser browser;
+       private String jsImplementation = JsImplementation.OPENLAYERS_MAP_PART.getJsClass();
+       private final String mapName;// = "argeoMap";
 
-       private final CompletableFuture<Boolean> pageLoaded = new CompletableFuture<>();
+       public SwtJSMapPart(String mapName, Composite parent, int style) {
+               super(parent, style, "/pkg/org.argeo.app.js/geo.html");
+               this.mapName = mapName;
+       }
 
-       private String jsImplementation = JsImplementation.OPENLAYERS_MAP_PART.getJsClass();
-       private String mapVar = "argeoMap";
-
-       public SwtJSMapPart(Composite parent, int style) {
-               super(parent, style);
-               parent.setLayout(CmsSwtUtils.noSpaceGridLayout());
-               setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));
-               setLayout(CmsSwtUtils.noSpaceGridLayout());
-
-               browser = new Browser(this, SWT.BORDER);
-               browser.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));
-
-               browser.setUrl("/pkg/org.argeo.app.geo.js/index.html");
-               browser.addProgressListener(new ProgressListener() {
-                       static final long serialVersionUID = 1L;
-
-                       @Override
-                       public void completed(ProgressEvent event) {
-                               try {
-                                       // create map
-                                       browser.execute(getJsMapVar() + " = new " + jsImplementation + "();");
-                                       pageLoaded.complete(true);
-                               } catch (Exception e) {
-                                       log.error("Cannot create map in browser", e);
-                                       pageLoaded.complete(false);
-                               }
-                       }
-
-                       @Override
-                       public void changed(ProgressEvent event) {
-                       }
-               });
+       @Override
+       protected void init() {
+               // create map
+               doExecute(getJsMapVar() + " = new " + jsImplementation + "('" + mapName + "');");
        }
 
        /*
@@ -77,8 +39,13 @@ public class SwtJSMapPart extends Composite implements MapPart {
        }
 
        @Override
-       public void addUrlLayer(String url, GeoFormat format) {
-               callMapMethod("addUrlLayer('%s', '%s')", url, format.name());
+       public void addUrlLayer(String url, GeoFormat format, String style) {
+               callMapMethod("addUrlLayer('%s', '%s', %s, false)", url, format.name(), style);
+       }
+
+       public void addCssUrlLayer(String url, GeoFormat format, String css) {
+               String style = GeoUtils.createSldFromCss("layer", "Layer", css);
+               callMapMethod("addUrlLayer('%s', '%s', '%s', true)", url, format.name(), style);
        }
 
        @Override
@@ -95,32 +62,8 @@ public class SwtJSMapPart extends Composite implements MapPart {
                return callMethod(getJsMapVar(), methodCall, args);
        }
 
-       protected CompletionStage<Object> callMethod(String jsObject, String methodCall, Object... args) {
-               return evaluate(jsObject + '.' + methodCall, args);
-       }
-
        private String getJsMapVar() {
-               return GLOBAL_THIS_ + mapVar;
-       }
-
-       /**
-        * Execute this JavaScript on the client side after making sure that the page
-        * has been loaded and the map object has been created.
-        * 
-        * @param js   the JavaScript code, possibly formatted according to
-        *             {@link String#format}, with {@link Locale#ROOT} as locale (for
-        *             stability of decimal separator, as expected by JavaScript.
-        * @param args the optional arguments of
-        *             {@link String#format(String, Object...)}
-        */
-       protected CompletionStage<Object> evaluate(String js, Object... args) {
-               CompletableFuture<Object> res = pageLoaded.thenApply((ready) -> {
-                       if (!ready)
-                               throw new IllegalStateException("Map " + mapVar + " is not initialised.");
-                       Object result = browser.evaluate(String.format(Locale.ROOT, js, args));
-                       return result;
-               });
-               return res.minimalCompletionStage();
+               return getJsVarName(mapName);
        }
 
        /*
@@ -147,19 +90,10 @@ public class SwtJSMapPart extends Composite implements MapPart {
        }
 
        protected void addCallback(String suffix, Function<Object[], Object> toDo) {
-               pageLoaded.thenAccept((ready) -> {
-                       // browser functions must be directly on window (RAP specific)
-                       new BrowserFunction(browser, mapVar + "__on" + suffix) {
-
-                               @Override
-                               public Object function(Object[] arguments) {
-                                       Object result = toDo.apply(arguments);
-                                       return result;
-                               }
-
-                       };
-                       browser.execute(getJsMapVar() + ".callbacks['on" + suffix + "']=window." + mapVar + "__on" + suffix + ";");
-                       callMethod(mapVar, "enable" + suffix + "()");
+               getReadyStage().thenAccept((ready) -> {
+                       String functionName = createJsFunction(mapName + "__on" + suffix, toDo);
+                       doExecute(getJsMapVar() + ".callbacks['on" + suffix + "']=" + functionName + ";");
+                       callMethod(mapName, "enable" + suffix + "()");
                });
        }
 }