X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=org.argeo.suite.ui%2Fsrc%2Forg%2Fargeo%2Fsuite%2Fui%2FSuiteUiUtils.java;h=21d8d937dda6dcd2719646e6887a9b00d565f6e7;hb=3cf66bc01bb8ad4c55139ae01be5a5bdb3759e2c;hp=8e9a9d5d641968693a6364f6cba86696ef0d256b;hpb=f709e4a3ae06e51f767eee8152b393eb1df97df4;p=gpl%2Fargeo-suite.git
diff --git a/org.argeo.suite.ui/src/org/argeo/suite/ui/SuiteUiUtils.java b/org.argeo.suite.ui/src/org/argeo/suite/ui/SuiteUiUtils.java
index 8e9a9d5..21d8d93 100644
--- a/org.argeo.suite.ui/src/org/argeo/suite/ui/SuiteUiUtils.java
+++ b/org.argeo.suite.ui/src/org/argeo/suite/ui/SuiteUiUtils.java
@@ -7,17 +7,26 @@ import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
+import org.argeo.api.cms.CmsEditable;
+import org.argeo.api.cms.CmsEvent;
+import org.argeo.api.cms.CmsStyle;
+import org.argeo.api.cms.CmsTheme;
+import org.argeo.api.cms.CmsView;
+import org.argeo.cms.LocaleUtils;
import org.argeo.cms.Localized;
-import org.argeo.cms.ui.CmsEditable;
-import org.argeo.cms.ui.CmsTheme;
-import org.argeo.cms.ui.dialogs.LightweightDialog;
-import org.argeo.cms.ui.util.CmsIcon;
+import org.argeo.cms.auth.CurrentUser;
+import org.argeo.cms.swt.CmsIcon;
+import org.argeo.cms.swt.CmsSwtUtils;
+import org.argeo.cms.swt.dialogs.LightweightDialog;
+import org.argeo.cms.ui.util.CmsLink;
import org.argeo.cms.ui.util.CmsUiUtils;
import org.argeo.eclipse.ui.EclipseUiUtils;
import org.argeo.entity.EntityNames;
import org.argeo.entity.EntityType;
import org.argeo.jcr.Jcr;
+import org.argeo.jcr.JcrException;
import org.argeo.jcr.JcrUtils;
+import org.argeo.suite.SuiteRole;
import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.ScrolledComposite;
import org.eclipse.swt.events.MouseEvent;
@@ -31,6 +40,7 @@ import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Text;
+import org.osgi.service.event.Event;
/** UI utilities related to the APAF project. */
public class SuiteUiUtils {
@@ -42,19 +52,19 @@ public class SuiteUiUtils {
/** creates a title bar composite with label and optional button */
public static void addTitleBar(Composite parent, String title, Boolean isEditable) {
Composite titleBar = new Composite(parent, SWT.NONE);
- titleBar.setLayoutData(CmsUiUtils.fillWidth());
- CmsUiUtils.style(titleBar, SuiteStyle.titleContainer);
+ titleBar.setLayoutData(CmsSwtUtils.fillWidth());
+ CmsSwtUtils.style(titleBar, SuiteStyle.titleContainer);
- titleBar.setLayout(CmsUiUtils.noSpaceGridLayout(new GridLayout(2, false)));
+ titleBar.setLayout(CmsSwtUtils.noSpaceGridLayout(new GridLayout(2, false)));
Label titleLbl = new Label(titleBar, SWT.NONE);
titleLbl.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, true));
- CmsUiUtils.style(titleLbl, SuiteStyle.titleLabel);
+ CmsSwtUtils.style(titleLbl, SuiteStyle.titleLabel);
titleLbl.setText(title);
if (isEditable) {
Button editBtn = new Button(titleBar, SWT.PUSH);
editBtn.setLayoutData(new GridData(SWT.CENTER, SWT.CENTER, false, false));
- CmsUiUtils.style(editBtn, SuiteStyle.inlineButton);
+ CmsSwtUtils.style(editBtn, SuiteStyle.inlineButton);
editBtn.setText("Edit");
}
}
@@ -63,7 +73,7 @@ public class SuiteUiUtils {
Label lbl = new Label(parent, SWT.WRAP);
lbl.setText(label);
// lbl.setLayoutData(new GridData(SWT.LEAD, SWT.CENTER, true, true));
- CmsUiUtils.style(lbl, SuiteStyle.simpleLabel);
+ CmsSwtUtils.style(lbl, SuiteStyle.simpleLabel);
return lbl;
}
@@ -78,20 +88,20 @@ public class SuiteUiUtils {
if (message != null)
txt.setMessage(message);
txt.setLayoutData(new GridData(SWT.LEAD, SWT.CENTER, true, true));
- CmsUiUtils.style(txt, SuiteStyle.simpleText);
+ CmsSwtUtils.style(txt, SuiteStyle.simpleText);
return txt;
}
public static Text addFormInputField(Composite parent, String placeholder) {
Text txt = new Text(parent, SWT.BORDER);
- GridData gridData = CmsUiUtils.fillWidth();
+ GridData gridData = CmsSwtUtils.fillWidth();
txt.setLayoutData(gridData);
if (placeholder != null)
txt.setText(placeholder);
- CmsUiUtils.style(txt, SuiteStyle.simpleInput);
+ CmsSwtUtils.style(txt, SuiteStyle.simpleInput);
return txt;
}
@@ -100,11 +110,11 @@ public class SuiteUiUtils {
Composite lineComposite = new Composite(parent, SWT.NONE);
lineComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
lineComposite.setLayout(new GridLayout(2, false));
- CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
+ CmsSwtUtils.style(lineComposite, SuiteStyle.formLine);
addFormLabel(lineComposite, label);
Text txt = addFormTextField(lineComposite, text, null);
txt.setEditable(false);
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -113,7 +123,7 @@ public class SuiteUiUtils {
Composite lineComposite = new Composite(parent, SWT.NONE);
lineComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
lineComposite.setLayout(new GridLayout(2, false));
- CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
+ CmsSwtUtils.style(lineComposite, SuiteStyle.formLine);
addFormLabel(lineComposite, label);
String text = Jcr.get(node, property);
// int style = cmsEditable.isEditing() ? SWT.WRAP : SWT.WRAP;
@@ -126,7 +136,7 @@ public class SuiteUiUtils {
} else {
txt.setEditable(false);
}
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -134,10 +144,10 @@ public class SuiteUiUtils {
Composite lineComposite = new Composite(parent, SWT.NONE);
lineComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
lineComposite.setLayout(new GridLayout(2, false));
- CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
+ CmsSwtUtils.style(lineComposite, SuiteStyle.formLine);
addFormLabel(lineComposite, label);
Text txt = addFormInputField(lineComposite, placeholder);
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -149,14 +159,14 @@ public class SuiteUiUtils {
Composite lineComposite = new Composite(parent, SWT.NONE);
lineComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
lineComposite.setLayout(new GridLayout(3, false));
- CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
+ CmsSwtUtils.style(lineComposite, SuiteStyle.formLine);
Label offsetLbl = new Label(lineComposite, SWT.NONE);
GridData gridData = new GridData();
gridData.widthHint = offset;
offsetLbl.setLayoutData(gridData);
addFormLabel(lineComposite, label);
Text txt = addFormTextField(lineComposite, text, null);
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -168,7 +178,7 @@ public class SuiteUiUtils {
addFormLabel(parent, label);
Text txt = addFormTextField(parent, text, null);
txt.setEditable(false);
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -189,7 +199,7 @@ public class SuiteUiUtils {
} else {
txt.setEditable(false);
}
- txt.setLayoutData(CmsUiUtils.fillWidth());
+ txt.setLayoutData(CmsSwtUtils.fillWidth());
return txt;
}
@@ -205,7 +215,7 @@ public class SuiteUiUtils {
Composite lineComposite = new Composite(parent, SWT.NONE);
lineComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
lineComposite.setLayout(new GridLayout(2, true));
- CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
+ CmsSwtUtils.style(lineComposite, SuiteStyle.formLine);
addFormLabel(lineComposite, label);
return addPicture(lineComposite, fileNode);
@@ -216,6 +226,11 @@ public class SuiteUiUtils {
}
public static Label addPicture(Composite parent, Node fileNode, Integer maxWidth) throws RepositoryException {
+ return addPicture(parent, fileNode, maxWidth, null);
+ }
+
+ public static Label addPicture(Composite parent, Node fileNode, Integer maxWidth, Node link)
+ throws RepositoryException {
Node content = fileNode.getNode(Node.JCR_CONTENT);
// TODO move it deeper in the middleware.
if (!content.isNodeType(EntityType.box.get())) {
@@ -254,79 +269,128 @@ public class SuiteUiUtils {
height = Math.round(ratio * height);
}
Label img = new Label(parent, SWT.NONE);
- CmsUiUtils.markup(img);
- img.setText(CmsUiUtils.img(fileNode, width.toString(), height.toString()));
+ CmsSwtUtils.markup(img);
+ StringBuffer txt = new StringBuffer();
+ String target = toLink(link);
+ if (target != null)
+ txt.append("");
+ txt.append(CmsUiUtils.img(fileNode, width.toString(), height.toString()));
+ if (target != null)
+ txt.append("");
+ img.setText(txt.toString());
if (parent.getLayout() instanceof GridLayout) {
GridData gd = new GridData(SWT.CENTER, SWT.CENTER, false, false);
gd.widthHint = width.intValue();
gd.heightHint = height.intValue();
img.setLayoutData(gd);
}
- img.addMouseListener(new MouseListener() {
- private static final long serialVersionUID = -1362242049325206168L;
- @Override
- public void mouseUp(MouseEvent e) {
- }
+ if (target == null)
+ img.addMouseListener(new MouseListener() {
+ private static final long serialVersionUID = -1362242049325206168L;
- @Override
- public void mouseDown(MouseEvent e) {
- }
+ @Override
+ public void mouseUp(MouseEvent e) {
+ }
- @Override
- public void mouseDoubleClick(MouseEvent e) {
- LightweightDialog dialog = new LightweightDialog(img.getShell()) {
-
- @Override
- protected Control createDialogArea(Composite parent) {
- parent.setLayout(new GridLayout());
- ScrolledComposite scroll = new ScrolledComposite(parent, SWT.H_SCROLL | SWT.V_SCROLL);
- scroll.setLayoutData(CmsUiUtils.fillAll());
- scroll.setLayout(CmsUiUtils.noSpaceGridLayout());
- scroll.setExpandHorizontal(true);
- scroll.setExpandVertical(true);
- // scroll.setAlwaysShowScrollBars(true);
-
- Composite c = new Composite(scroll, SWT.NONE);
- scroll.setContent(c);
- c.setLayout(new GridLayout());
- c.setLayoutData(CmsUiUtils.fillAll());
- Label bigImg = new Label(c, SWT.NONE);
- CmsUiUtils.markup(bigImg);
- bigImg.setText(CmsUiUtils.img(fileNode, Jcr.get(content, EntityNames.SVG_WIDTH),
- Jcr.get(content, EntityNames.SVG_HEIGHT)));
- bigImg.setLayoutData(new GridData(SWT.CENTER, SWT.CENTER, true, true));
- return bigImg;
- }
-
- @Override
- protected Point getInitialSize() {
- Point shellSize = img.getShell().getSize();
- return new Point(shellSize.x - 100, shellSize.y - 100);
- }
-
- };
- dialog.open();
- }
- });
+ @Override
+ public void mouseDown(MouseEvent e) {
+ }
+
+ @Override
+ public void mouseDoubleClick(MouseEvent e) {
+ LightweightDialog dialog = new LightweightDialog(img.getShell()) {
+
+ @Override
+ protected Control createDialogArea(Composite parent) {
+ parent.setLayout(new GridLayout());
+ ScrolledComposite scroll = new ScrolledComposite(parent, SWT.H_SCROLL | SWT.V_SCROLL);
+ scroll.setLayoutData(CmsSwtUtils.fillAll());
+ scroll.setLayout(CmsSwtUtils.noSpaceGridLayout());
+ scroll.setExpandHorizontal(true);
+ scroll.setExpandVertical(true);
+ // scroll.setAlwaysShowScrollBars(true);
+
+ Composite c = new Composite(scroll, SWT.NONE);
+ scroll.setContent(c);
+ c.setLayout(new GridLayout());
+ c.setLayoutData(CmsSwtUtils.fillAll());
+ Label bigImg = new Label(c, SWT.NONE);
+ CmsSwtUtils.markup(bigImg);
+ bigImg.setText(CmsUiUtils.img(fileNode, Jcr.get(content, EntityNames.SVG_WIDTH),
+ Jcr.get(content, EntityNames.SVG_HEIGHT)));
+ bigImg.setLayoutData(new GridData(SWT.CENTER, SWT.CENTER, true, true));
+ return bigImg;
+ }
+
+ @Override
+ protected Point getInitialSize() {
+ Point shellSize = img.getShell().getSize();
+ return new Point(shellSize.x - 100, shellSize.y - 100);
+ }
+
+ };
+ dialog.open();
+ }
+ });
return img;
}
- public static Button createLayerButton(Composite parent, String layer, Localized msg, CmsIcon icon) {
- CmsTheme theme = CmsTheme.getCmsTheme(parent);
+ public static String toLink(Node node) {
+ return node != null ? "#" + CmsUiUtils.cleanPathForUrl(SuiteApp.nodeToState(node)) : null;
+ }
+
+ public static Control addLink(Composite parent, String label, Node node, CmsStyle style)
+ throws RepositoryException {
+ String target = toLink(node);
+ CmsLink link = new CmsLink(label, target, style);
+ return link.createUi(parent, node);
+ }
+
+ public static Control addExternalLink(Composite parent, String label, String url, String plainCssAnchorClass,
+ boolean newWindow) throws RepositoryException {
+ Label lbl = new Label(parent, SWT.NONE);
+ CmsSwtUtils.markup(lbl);
+ StringBuilder txt = new StringBuilder();
+ txt.append("");
+ txt.append(label);
+ txt.append("");
+ lbl.setText(txt.toString());
+ return lbl;
+ }
+
+ public static boolean isCoworker(CmsView cmsView) {
+ boolean coworker = cmsView.doAs(() -> CurrentUser.isInRole(SuiteRole.coworker.dn()));
+ return coworker;
+ }
+
+ public static boolean isTopic(Event event, CmsEvent cmsEvent) {
+ return event.getTopic().equals(cmsEvent.topic());
+ }
+
+ public static Button createLayerButton(Composite parent, String layer, Localized msg, CmsIcon icon,
+ ClassLoader l10nClassLoader) {
+ CmsTheme theme = CmsSwtUtils.getCmsTheme(parent);
Button button = new Button(parent, SWT.PUSH);
- CmsUiUtils.style(button, SuiteStyle.leadPane);
+ CmsSwtUtils.style(button, SuiteStyle.leadPane);
if (icon != null)
button.setImage(icon.getBigIcon(theme));
button.setLayoutData(new GridData(SWT.CENTER, SWT.BOTTOM, true, false));
// button.setToolTipText(msg.lead());
if (msg != null) {
- Label lbl = new Label(parent, SWT.NONE);
- CmsUiUtils.style(lbl, SuiteStyle.leadPane);
- lbl.setText(msg.lead());
+ Label lbl = new Label(parent, SWT.CENTER);
+ CmsSwtUtils.style(lbl, SuiteStyle.leadPane);
+ String txt = LocaleUtils.lead(msg, l10nClassLoader);
+// String txt = msg.lead();
+ lbl.setText(txt);
lbl.setLayoutData(new GridData(SWT.CENTER, SWT.TOP, true, false));
}
- CmsUiUtils.sendEventOnSelect(button, SuiteEvent.switchLayer.topic(), SuiteEvent.LAYER, layer);
+ CmsSwtUtils.sendEventOnSelect(button, SuiteEvent.switchLayer.topic(), SuiteEvent.LAYER, layer);
return button;
}