Introduce bearing node type.
[gpl/argeo-suite.git] / org.argeo.suite.ui / src / org / argeo / suite / ui / SuiteUiUtils.java
index ace189c2bef68b0dea152f4f5b50632cebef22c4..085dd4f099eace84f6556bc1ff37cea191e13e32 100644 (file)
@@ -9,21 +9,29 @@ import javax.jcr.Session;
 
 import org.argeo.api.NodeConstants;
 import org.argeo.cms.Localized;
+import org.argeo.cms.ui.CmsEditable;
 import org.argeo.cms.ui.dialogs.CmsWizardDialog;
 import org.argeo.cms.ui.util.CmsUiUtils;
 import org.argeo.eclipse.ui.EclipseUiUtils;
+import org.argeo.eclipse.ui.dialogs.LightweightDialog;
 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.eclipse.jface.window.Window;
 import org.eclipse.jface.wizard.Wizard;
 import org.eclipse.swt.SWT;
+import org.eclipse.swt.custom.ScrolledComposite;
+import org.eclipse.swt.events.MouseEvent;
+import org.eclipse.swt.events.MouseListener;
 import org.eclipse.swt.graphics.ImageData;
+import org.eclipse.swt.graphics.Point;
 import org.eclipse.swt.layout.GridData;
 import org.eclipse.swt.layout.GridLayout;
 import org.eclipse.swt.widgets.Button;
 import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Control;
 import org.eclipse.swt.widgets.Label;
 import org.eclipse.swt.widgets.Shell;
 import org.eclipse.swt.widgets.Text;
@@ -58,13 +66,17 @@ public class SuiteUiUtils {
        public static Label addFormLabel(Composite parent, String label) {
                Label lbl = new Label(parent, SWT.WRAP);
                lbl.setText(label);
-               //lbl.setLayoutData(new GridData(SWT.LEAD, SWT.CENTER, true, true));
+               // lbl.setLayoutData(new GridData(SWT.LEAD, SWT.CENTER, true, true));
                CmsUiUtils.style(lbl, SuiteStyle.simpleLabel);
                return lbl;
        }
 
        public static Text addFormTextField(Composite parent, String text, String message) {
-               Text txt = new Text(parent, SWT.WRAP);
+               return addFormTextField(parent, text, message, SWT.NONE);
+       }
+
+       public static Text addFormTextField(Composite parent, String text, String message, int style) {
+               Text txt = new Text(parent, style);
                if (text != null)
                        txt.setText(text);
                if (message != null)
@@ -95,6 +107,29 @@ public class SuiteUiUtils {
                CmsUiUtils.style(lineComposite, SuiteStyle.formLine);
                addFormLabel(lineComposite, label);
                Text txt = addFormTextField(lineComposite, text, null);
+               txt.setEditable(false);
+               txt.setLayoutData(CmsUiUtils.fillWidth());
+               return txt;
+       }
+
+       public static Text addFormLine(Composite parent, String label, Node node, String property,
+                       CmsEditable cmsEditable) {
+               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);
+               addFormLabel(lineComposite, label);
+               String text = Jcr.get(node, property);
+//             int style = cmsEditable.isEditing() ? SWT.WRAP : SWT.WRAP;
+               Text txt = addFormTextField(lineComposite, text, null, SWT.WRAP);
+               if (cmsEditable != null && cmsEditable.isEditing()) {
+                       txt.addModifyListener((e) -> {
+                               Jcr.set(node, property, txt.getText());
+                               Jcr.save(node);
+                       });
+               } else {
+                       txt.setEditable(false);
+               }
                txt.setLayoutData(CmsUiUtils.fillWidth());
                return txt;
        }
@@ -131,11 +166,33 @@ public class SuiteUiUtils {
 
        /** creates a single vertical-block composite for key:value display */
        public static Text addFormColumn(Composite parent, String label, String text) {
-               Composite columnComposite = new Composite(parent, SWT.NONE);
-               columnComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
-               columnComposite.setLayout(new GridLayout(1, false));
-               addFormLabel(columnComposite, label);
-               Text txt = addFormTextField(columnComposite, text, null);
+//             Composite columnComposite = new Composite(parent, SWT.NONE);
+//             columnComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
+//             columnComposite.setLayout(new GridLayout(1, false));
+               addFormLabel(parent, label);
+               Text txt = addFormTextField(parent, text, null);
+               txt.setEditable(false);
+               txt.setLayoutData(CmsUiUtils.fillWidth());
+               return txt;
+       }
+
+       public static Text addFormColumn(Composite parent, String label, Node node, String property,
+                       CmsEditable cmsEditable) {
+//             Composite columnComposite = new Composite(parent, SWT.NONE);
+//             columnComposite.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
+//             columnComposite.setLayout(new GridLayout(1, false));
+               addFormLabel(parent, label);
+               String text = Jcr.get(node, property);
+//             int style = cmsEditable.isEditing() ? SWT.WRAP : SWT.WRAP;
+               Text txt = addFormTextField(parent, text, null, SWT.WRAP);
+               if (cmsEditable != null && cmsEditable.isEditing()) {
+                       txt.addModifyListener((e) -> {
+                               Jcr.set(node, property, txt.getText());
+                               Jcr.save(node);
+                       });
+               } else {
+                       txt.setEditable(false);
+               }
                txt.setLayoutData(CmsUiUtils.fillWidth());
                return txt;
        }
@@ -187,8 +244,58 @@ public class SuiteUiUtils {
                Label img = new Label(parent, SWT.NONE);
                CmsUiUtils.markup(img);
                img.setText(CmsUiUtils.img(fileNode, width.toString(), height.toString()));
-               if (parent.getLayout() instanceof GridLayout)
-                       img.setLayoutData(new GridData(SWT.CENTER, SWT.CENTER, false, false));
+               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() {
+
+                       @Override
+                       public void mouseUp(MouseEvent e) {
+                       }
+
+                       @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(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();
+                       }
+               });
                return img;
        }