X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.suite.e4.rap%2Fsrc%2Forg%2Fargeo%2Fsuite%2Fe4%2Frap%2Fsettings%2FArgeoRapApp.java;h=bb4fae976e63ee422e0f7f490d9818a7ea0195cc;hb=a548c15bfb23ed0120a6558b40d8b0362c9ba956;hp=169ea6232837ae6ff79c1ab00fbd41c6741e614b;hpb=3c876e81b463a82e9ac7b456e126a3e5dd2fef09;p=gpl%2Fargeo-suite.git diff --git a/org.argeo.suite.e4.rap/src/org/argeo/suite/e4/rap/settings/ArgeoRapApp.java b/org.argeo.suite.e4.rap/src/org/argeo/suite/e4/rap/settings/ArgeoRapApp.java index 169ea62..bb4fae9 100644 --- a/org.argeo.suite.e4.rap/src/org/argeo/suite/e4/rap/settings/ArgeoRapApp.java +++ b/org.argeo.suite.e4.rap/src/org/argeo/suite/e4/rap/settings/ArgeoRapApp.java @@ -1,6 +1,7 @@ package org.argeo.suite.e4.rap.settings; import java.util.Enumeration; +import java.util.Map; import org.apache.commons.io.FilenameUtils; import org.apache.commons.logging.Log; @@ -10,23 +11,42 @@ import org.argeo.cms.ui.util.CmsTheme; import org.eclipse.rap.rwt.application.Application; import org.eclipse.rap.rwt.client.WebClient; import org.osgi.framework.Bundle; +import org.osgi.framework.BundleContext; /** Argeo RAP app. */ public class ArgeoRapApp extends AbstractRapE4App { private final static Log log = LogFactory.getLog(ArgeoRapApp.class); - private Bundle bundle; private CmsTheme cmsTheme; private String baseE4xmi = "/e4xmi"; + private Bundle bundle; - public ArgeoRapApp(Bundle bundle, CmsTheme cmsTheme) { - this.bundle = bundle; + public ArgeoRapApp(BundleContext bundleContext, Bundle bundle, CmsTheme cmsTheme) { + setBundleContext(bundleContext); this.cmsTheme = cmsTheme; + this.bundle = bundle; setLifeCycleUri("bundleclass://org.argeo.suite.e4.rap/org.argeo.suite.e4.rap.ArgeoSuiteLoginLifecycle"); String contextName = "argeo/" + FilenameUtils.getExtension(bundle.getSymbolicName()); setContextName(contextName); } + public ArgeoRapApp() { + setLifeCycleUri("bundleclass://org.argeo.suite.e4.rap/org.argeo.suite.e4.rap.ArgeoSuiteLoginLifecycle"); + } + + @Override + public void init(BundleContext bundleContext, Map properties) { + super.init(bundleContext, properties); + // super must be first + if (getBaseProperties().containsKey(CmsTheme.CMS_THEME_BUNDLE_PROPERTY)) { + String cmsThemeBundle = getBaseProperties().get(CmsTheme.CMS_THEME_BUNDLE_PROPERTY); + cmsTheme = new CmsTheme(getBundleContext(), cmsThemeBundle); + } else { + cmsTheme = new CmsTheme(getBundleContext(), CmsTheme.DEFAULT_CMS_THEME_BUNDLE); + } + bundle = bundleContext.getBundle(); + } + @Override protected void addEntryPoints(Application application) { if (cmsTheme != null)