+package org.argeo.suite.ui;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+import javax.jcr.Node;
+import javax.jcr.RepositoryException;
+import javax.jcr.Session;
+
+import org.argeo.api.NodeConstants;
+import org.argeo.cms.ui.dialogs.CmsWizardDialog;
+import org.argeo.cms.ui.util.CmsUiUtils;
+import org.argeo.entity.EntityNames;
+import org.argeo.entity.EntityType;
+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.graphics.ImageData;
+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.Label;
+import org.eclipse.swt.widgets.Shell;
+import org.eclipse.swt.widgets.Text;
+
+/** UI utilities related to the APAF project. */
+public class SuiteUiUtils {
+
+ /** Singleton. */
+ private 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.setLayout(CmsUiUtils.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);
+ 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);
+ editBtn.setText("Edit");
+ }
+ }
+
+ 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));
+ CmsUiUtils.style(lbl, SuiteStyle.simpleLabel);
+ return lbl;
+ }
+
+ public static Text addFormTextField(Composite parent, String text, String message) {
+ Text txt = new Text(parent, SWT.WRAP);
+ if (text != null)
+ txt.setText(text);
+ if (message != null)
+ txt.setMessage(message);
+ txt.setLayoutData(new GridData(SWT.LEAD, SWT.CENTER, true, true));
+ CmsUiUtils.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();
+ txt.setLayoutData(gridData);
+
+ if (placeholder != null)
+ txt.setText(placeholder);
+
+ CmsUiUtils.style(txt, SuiteStyle.simpleInput);
+ return txt;
+ }
+
+ /** creates a single horizontal-block composite for key:value display */
+ public static Text addFormLine(Composite parent, String label, String text) {
+ 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);
+ addFormLabel(lineComposite, label);
+ Text txt = addFormTextField(lineComposite, text, null);
+ txt.setLayoutData(CmsUiUtils.fillWidth());
+ return txt;
+ }
+
+ public static Text addFormInput(Composite parent, String label, String placeholder) {
+ 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);
+ addFormLabel(lineComposite, label);
+ Text txt = addFormInputField(lineComposite, placeholder);
+ txt.setLayoutData(CmsUiUtils.fillWidth());
+ return txt;
+ }
+
+ /**
+ * creates a single horizontal-block composite for key:value display, with
+ * offset value
+ */
+ public static Text addFormLine(Composite parent, String label, String text, Integer offset) {
+ 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);
+ 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());
+ return txt;
+ }
+
+ /** 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);
+ txt.setLayoutData(CmsUiUtils.fillWidth());
+ return txt;
+ }
+
+ public static Label addFormPicture(Composite parent, String label, Node fileNode) throws RepositoryException {
+ 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);
+ addFormLabel(lineComposite, label);
+
+ return addPicture(lineComposite, fileNode);
+ }
+
+ public static Label addPicture(Composite parent, Node fileNode) throws RepositoryException {
+ return addPicture(parent, fileNode, null);
+ }
+
+ public static Label addPicture(Composite parent, Node fileNode, Integer maxWidth) throws RepositoryException {
+ Node content = fileNode.getNode(Node.JCR_CONTENT);
+ // TODO move it deeper in the middleware.
+ if (!content.isNodeType(EntityType.box.get())) {
+ try (InputStream in = JcrUtils.getFileAsStream(fileNode)) {
+ ImageData imageData = new ImageData(in);
+ content.addMixin(EntityType.box.get());
+ content.setProperty(EntityNames.SVG_WIDTH, imageData.width);
+ content.setProperty(EntityNames.SVG_HEIGHT, imageData.height);
+ content.getSession().save();
+ } catch (IOException e) {
+ throw new IllegalStateException(e);
+ }
+ }
+
+ Long width = content.getProperty(EntityNames.SVG_WIDTH).getLong();
+ Long height = content.getProperty(EntityNames.SVG_HEIGHT).getLong();
+ if (maxWidth != null && width > maxWidth) {
+ Double ratio = maxWidth.doubleValue() / width.doubleValue();
+ width = maxWidth.longValue();
+ height = Math.round(ratio * height);
+ }
+ 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));
+ return img;
+ }
+
+ public static String createAndConfigureEntity(Shell shell, Session referenceSession, String mainMixin,
+ String... additionnalProps) {
+
+ Session tmpSession = null;
+ Session mainSession = null;
+ try {
+ // FIXME would not work if home is another physical workspace
+ tmpSession = referenceSession.getRepository().login(NodeConstants.HOME_WORKSPACE);
+ Node draftNode = null;
+ for (int i = 0; i < additionnalProps.length - 1; i += 2) {
+ draftNode.setProperty(additionnalProps[i], additionnalProps[i + 1]);
+ }
+ Wizard wizard = null;
+ CmsWizardDialog dialog = new CmsWizardDialog(shell, wizard);
+ // WizardDialog dialog = new WizardDialog(shell, wizard);
+ if (dialog.open() == Window.OK) {
+ String parentPath = null;// "/" + appService.getBaseRelPath(mainMixin);
+ // FIXME it should be possible to specify the workspace
+ mainSession = referenceSession.getRepository().login();
+ Node parent = mainSession.getNode(parentPath);
+ Node task = null;// appService.publishEntity(parent, mainMixin, draftNode);
+// task = appService.saveEntity(task, false);
+ referenceSession.refresh(true);
+ return task.getPath();
+ }
+ return null;
+ } catch (RepositoryException e1) {
+ throw new JcrException(
+ "Unable to create " + mainMixin + " entity with session " + referenceSession.toString(), e1);
+ } finally {
+ JcrUtils.logoutQuietly(tmpSession);
+ JcrUtils.logoutQuietly(mainSession);
+ }
+ }
+
+}