X-Git-Url: http://git.argeo.org/?p=gpl%2Fargeo-suite.git;a=blobdiff_plain;f=org.argeo.suite.ui%2Fsrc%2Forg%2Fargeo%2Fsuite%2Fui%2FDefaultEditionLayer.java;h=c65cff50088aff32d38ecb7386f85a96a94d5bb1;hp=2070d9004e8b96ce0c6813b6416a74c794d030b9;hb=8f189b5bdc0a67de24367ebfc12bd382dab939c7;hpb=4f10468a32db84b4a3d799f116e6ef73a7b4d158 diff --git a/org.argeo.suite.ui/src/org/argeo/suite/ui/DefaultEditionLayer.java b/org.argeo.suite.ui/src/org/argeo/suite/ui/DefaultEditionLayer.java index 2070d90..c65cff5 100644 --- a/org.argeo.suite.ui/src/org/argeo/suite/ui/DefaultEditionLayer.java +++ b/org.argeo.suite.ui/src/org/argeo/suite/ui/DefaultEditionLayer.java @@ -1,5 +1,9 @@ package org.argeo.suite.ui; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + import javax.jcr.Node; import javax.jcr.RepositoryException; @@ -7,6 +11,7 @@ import org.argeo.cms.ui.CmsTheme; import org.argeo.cms.ui.CmsUiProvider; import org.argeo.cms.ui.util.CmsUiUtils; import org.argeo.cms.ui.widgets.TabbedArea; +import org.argeo.util.LangUtils; import org.eclipse.swt.SWT; import org.eclipse.swt.custom.SashForm; import org.eclipse.swt.layout.GridLayout; @@ -17,6 +22,7 @@ import org.eclipse.swt.widgets.Control; public class DefaultEditionLayer implements SuiteLayer { private CmsUiProvider entryArea; private CmsUiProvider workArea; + private List weights = new ArrayList<>(); @Override public Control createUi(Composite parent, Node context) throws RepositoryException { @@ -57,6 +63,10 @@ public class DefaultEditionLayer implements SuiteLayer { tabbedArea.open(uiProvider, context); } + public void init(Map properties) { + weights = LangUtils.toStringList(properties.get(Property.weights.name())); + } + public void setEntryArea(CmsUiProvider entryArea) { this.entryArea = entryArea; } @@ -94,8 +104,17 @@ public class DefaultEditionLayer implements SuiteLayer { entryArea = new Composite(this, SWT.NONE); editorArea = new Composite(this, SWT.NONE); } - int[] weights = new int[] { 3000, 7000 }; - setWeights(weights); + + if (weights.size() != 0) { + int[] actualWeight = new int[weights.size()]; + for (int i = 0; i < weights.size(); i++) { + actualWeight[i] = Integer.parseInt(weights.get(i)); + setWeights(actualWeight); + } + } else { + int[] actualWeights = new int[] { 3000, 7000 }; + setWeights(actualWeights); + } editorArea.setLayout(new GridLayout()); if (DefaultEditionLayer.this.workArea == null) {