Use CMS bundle theme.
authorMathieu Baudier <mbaudier@argeo.org>
Sat, 7 May 2022 09:53:03 +0000 (11:53 +0200)
committerMathieu Baudier <mbaudier@argeo.org>
Sat, 7 May 2022 09:53:03 +0000 (11:53 +0200)
org.argeo.app.theme.default/OSGI-INF/cmsTheme.xml
org.argeo.app.theme.default/bnd.bnd
org.argeo.app.ui/src/org/argeo/app/ui/osgi/BundleSuiteTheme.java [deleted file]
sdk/argeo-build

index dde85b060af03d27ec6267519f6e629afea8581a..7d3c221334b6204fc9aa978016d55db6ce7b6c40 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.app.ui.osgi.BundleSuiteTheme"/>
+   <implementation class="org.argeo.cms.swt.osgi.BundleSvgTheme"/>
    <service>
       <provide interface="org.argeo.api.cms.CmsTheme"/>
    </service>
index dfaaa7a4bb0f6ed4d61439280953cbf880effd5b..48c958615f24c64ed825ebea67706a081a94d41f 100644 (file)
@@ -6,7 +6,6 @@ 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
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
deleted file mode 100644 (file)
index 10a67c5..0000000
+++ /dev/null
@@ -1,106 +0,0 @@
-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 2cb8a40febfe1b42ab2aebecbf6e0ec06b2c5e4d..0d5780a1346ab30294998a894fe8b63d1de9f5d6 160000 (submodule)
@@ -1 +1 @@
-Subproject commit 2cb8a40febfe1b42ab2aebecbf6e0ec06b2c5e4d
+Subproject commit 0d5780a1346ab30294998a894fe8b63d1de9f5d6