Adapt ot new third parties
authorMathieu Baudier <mbaudier@argeo.org>
Sat, 7 May 2022 09:04:22 +0000 (11:04 +0200)
committerMathieu Baudier <mbaudier@argeo.org>
Sat, 7 May 2022 09:04:22 +0000 (11:04 +0200)
Makefile
org.argeo.app.theme.default/OSGI-INF/cmsTheme.xml
org.argeo.app.theme.default/bnd.bnd
org.argeo.app.ui/bnd.bnd
org.argeo.app.ui/src/org/argeo/app/ui/osgi/BundleSuiteTheme.java [new file with mode: 0644]
sdk/argeo-build

index 7a9417e89daaabbd749c36859f0e51e5c7ca4fcf..f93dc35c0dc9916a6df55876614c29b49c8a0daa 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -21,7 +21,7 @@ org.argeo.tp \
 org.argeo.tp.apache \
 org.argeo.tp.jetty \
 org.argeo.tp.eclipse.equinox \
-org.argeo.tp.eclipse.rap \
+org.argeo.tp.eclipse.rwt \
 org.argeo.tp.jcr \
 org.argeo.tp.formats \
 org.argeo.tp.gis \
index 1a4e589009b49ae9c77fbc374b18dcbdc999e3e9..dde85b060af03d27ec6267519f6e629afea8581a 100644 (file)
@@ -1,6 +1,6 @@
 <?xml version="1.0" encoding="UTF-8"?>
 <scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" activate="init" deactivate="destroy" name="Argeo Suite Default Theme">
-   <implementation class="org.argeo.cms.swt.osgi.BundleCmsSwtTheme"/>
+   <implementation class="org.argeo.app.ui.osgi.BundleSuiteTheme"/>
    <service>
       <provide interface="org.argeo.api.cms.CmsTheme"/>
    </service>
index 45dc19ece6f0a5ef8971041c2d8d9c35ae245c91..dfaaa7a4bb0f6ed4d61439280953cbf880effd5b 100644 (file)
@@ -1,7 +1,12 @@
 Service-Component:\
 OSGI-INF/cmsTheme.xml
 
+Private-Package: *
+
+Export-Package: !*
+
 Import-Package:\
+org.argeo.app.ui.osgi,\
 org.argeo.cms.swt.osgi,\
 javax.servlet.*;version="[3,5)",\
 *
\ No newline at end of file
index e36f7057184e97dbae4018b35593dfafa94f8934..482a9ff39d21647159519c4024fe5858781e3d3d 100644 (file)
@@ -26,6 +26,7 @@ OSGI-INF/documentUiProvider.xml,\
 
 
 Import-Package:\
+org.argeo.cms.osgi,\
 org.argeo.cms.ui.widgets,\
 org.eclipse.swt,\
 org.osgi.framework,\
diff --git a/org.argeo.app.ui/src/org/argeo/app/ui/osgi/BundleSuiteTheme.java b/org.argeo.app.ui/src/org/argeo/app/ui/osgi/BundleSuiteTheme.java
new file mode 100644 (file)
index 0000000..10a67c5
--- /dev/null
@@ -0,0 +1,106 @@
+package org.argeo.app.ui.osgi;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.lang.System.Logger;
+import java.lang.System.Logger.Level;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.batik.transcoder.TranscoderException;
+import org.apache.batik.transcoder.TranscoderInput;
+import org.apache.batik.transcoder.TranscoderOutput;
+import org.apache.batik.transcoder.image.ImageTranscoder;
+import org.apache.batik.transcoder.image.PNGTranscoder;
+import org.argeo.cms.swt.osgi.BundleCmsSwtTheme;
+import org.eclipse.swt.graphics.Image;
+import org.eclipse.swt.graphics.ImageData;
+import org.eclipse.swt.widgets.Display;
+import org.osgi.framework.BundleContext;
+
+/** Theme which can dynamically create icons from SVG data. */
+public class BundleSuiteTheme extends BundleCmsSwtTheme {
+       private final static Logger logger = System.getLogger(BundleSuiteTheme.class.getName());
+
+       private Map<String, Map<Integer, Image>> imageCache = Collections.synchronizedMap(new HashMap<>());
+
+       private Map<Integer, ImageTranscoder> transcoders = Collections.synchronizedMap(new HashMap<>());
+
+       @Override
+       public Image getIcon(String name, Integer preferredSize) {
+               String path = "icons/types/svg/" + name + ".svg";
+               return createImageFromSvg(path, preferredSize);
+       }
+
+       protected Image createImageFromSvg(String path, Integer preferredSize) {
+               Image image = null;
+               if (imageCache.containsKey(path)) {
+                       image = imageCache.get(path).get(preferredSize);
+               }
+               if (image != null)
+                       return image;
+               ImageData imageData = loadFromSvg(path, preferredSize);
+               image = new Image(Display.getDefault(), imageData);
+               if (!imageCache.containsKey(path))
+                       imageCache.put(path, Collections.synchronizedMap(new HashMap<>()));
+               imageCache.get(path).put(preferredSize, image);
+               return image;
+       }
+
+       protected ImageData loadFromSvg(String path, int size) {
+               ImageTranscoder transcoder = null;
+               synchronized (this) {
+                       transcoder = transcoders.get(size);
+                       if (transcoder == null) {
+                               transcoder = new PNGTranscoder();
+                               transcoder.addTranscodingHint(PNGTranscoder.KEY_WIDTH, (float) size);
+                               transcoder.addTranscodingHint(PNGTranscoder.KEY_HEIGHT, (float) size);
+                               transcoders.put(size, transcoder);
+                       }
+               }
+               ImageData imageData;
+               try (InputStream in = getResourceAsStream(path); ByteArrayOutputStream out = new ByteArrayOutputStream();) {
+                       if (in == null)
+                               throw new IllegalArgumentException(path + " not found");
+                       TranscoderInput input = new TranscoderInput(in);
+                       TranscoderOutput output = new TranscoderOutput(out);
+                       transcoder.transcode(input, output);
+                       try (InputStream imageIn = new ByteArrayInputStream(out.toByteArray())) {
+                               imageData = new ImageData(imageIn);
+                       }
+                       logger.log(Level.DEBUG, () -> "Generated " + size + "x" + size + " PNG icon from " + path);
+               } catch (IOException | TranscoderException e) {
+                       throw new RuntimeException("Cannot transcode SVG " + path, e);
+               }
+
+               return imageData;
+       }
+
+       @Override
+       public void init(BundleContext bundleContext, Map<String, String> properties) {
+               super.init(bundleContext, properties);
+
+               // preload all icons
+//             paths: for (String p : getImagesPaths()) {
+//                     if (!p.endsWith(".svg"))
+//                             continue paths;
+//                     createImageFromSvg(p, getDefaultIconSize());
+//             }
+       }
+
+       @Override
+       public void destroy(BundleContext bundleContext, Map<String, String> properties) {
+               Display display = Display.getDefault();
+               if (display != null)
+                       for (String path : imageCache.keySet()) {
+                               for (Image image : imageCache.get(path).values()) {
+                                       display.syncExec(() -> image.dispose());
+                               }
+                       }
+               super.destroy(bundleContext, properties);
+       }
+
+}
index 90dfe68dd0a8f9510939b2a276aed3d79e563bb2..2cb8a40febfe1b42ab2aebecbf6e0ec06b2c5e4d 160000 (submodule)
@@ -1 +1 @@
-Subproject commit 90dfe68dd0a8f9510939b2a276aed3d79e563bb2
+Subproject commit 2cb8a40febfe1b42ab2aebecbf6e0ec06b2c5e4d