Visually separate "Private" & "Public" sharing in File/Share
[pithos-web-client] / src / gr / grnet / pithos / web / client / FolderPropertiesDialog.java
index e3fcfb7..9531dcf 100644 (file)
@@ -1,5 +1,5 @@
 /*\r
- * Copyright 2011-2012 GRNET S.A. All rights reserved.\r
+ * Copyright 2011-2013 GRNET S.A. All rights reserved.\r
  *\r
  * Redistribution and use in source and binary forms, with or\r
  * without modification, are permitted provided that the following\r
  */\r
 package gr.grnet.pithos.web.client;\r
 \r
-import gr.grnet.pithos.web.client.foldertree.Folder;\r
-import gr.grnet.pithos.web.client.rest.PutRequest;\r
-import gr.grnet.pithos.web.client.rest.RestException;\r
-\r
 import com.google.gwt.core.client.GWT;\r
 import com.google.gwt.core.client.Scheduler;\r
 import com.google.gwt.dom.client.NativeEvent;\r
-import com.google.gwt.event.dom.client.ChangeEvent;\r
-import com.google.gwt.event.dom.client.ChangeHandler;\r
-import com.google.gwt.event.dom.client.ClickEvent;\r
-import com.google.gwt.event.dom.client.ClickHandler;\r
-import com.google.gwt.event.dom.client.KeyCodes;\r
-import com.google.gwt.event.dom.client.KeyDownEvent;\r
+import com.google.gwt.event.dom.client.*;\r
 import com.google.gwt.http.client.Response;\r
 import com.google.gwt.i18n.client.DateTimeFormat;\r
 import com.google.gwt.user.client.Command;\r
 import com.google.gwt.user.client.Event.NativePreviewEvent;\r
-import com.google.gwt.user.client.ui.Anchor;\r
-import com.google.gwt.user.client.ui.Button;\r
-import com.google.gwt.user.client.ui.DialogBox;\r
-import com.google.gwt.user.client.ui.FlexTable;\r
-import com.google.gwt.user.client.ui.HasHorizontalAlignment;\r
-import com.google.gwt.user.client.ui.Label;\r
-import com.google.gwt.user.client.ui.TextBox;\r
-import com.google.gwt.user.client.ui.VerticalPanel;\r
+import com.google.gwt.user.client.ui.*;\r
+import gr.grnet.pithos.web.client.foldertree.Folder;\r
+import gr.grnet.pithos.web.client.rest.PutRequest;\r
+import gr.grnet.pithos.web.client.rest.RestException;\r
 \r
 /**\r
  * The 'Folder properties' dialog box implementation.\r
@@ -67,86 +54,103 @@ public class FolderPropertiesDialog extends DialogBox {
 \r
     protected Pithos app;\r
 \r
-       /**\r
-        * The widget that holds the folderName of the folder.\r
-        */\r
-       TextBox folderName = new TextBox();\r
+    /**\r
+     * The widget that holds the folderName of the folder.\r
+     */\r
+    TextBox folderName = new TextBox();\r
 \r
-       /**\r
-        * A flag that denotes whether the dialog will be used to create or modify a\r
-        * folder.\r
-        */\r
-       private final boolean create;\r
+    /**\r
+     * A flag that denotes whether the dialog will be used to create or modify a\r
+     * folder.\r
+     */\r
+    private final boolean create;\r
 \r
-       final Folder folder;\r
+    final Folder folder;\r
 \r
-       final VerticalPanel inner;\r
+    final VerticalPanel inner;\r
 \r
-       /**\r
-        * The widget's constructor.\r
-        */\r
-       public FolderPropertiesDialog(final Pithos app, boolean _create,  Folder selected) {\r
+    /**\r
+     * The widget's constructor.\r
+     */\r
+    public FolderPropertiesDialog(final Pithos app, boolean _create, Folder selected) {\r
         this.app = app;\r
-               Anchor close = new Anchor("close");\r
-               close.addStyleName("close");\r
-               close.addClickHandler(new ClickHandler() {\r
-                       \r
-                       @Override\r
-                       public void onClick(ClickEvent event) {\r
-                               hide();\r
-                       }\r
-               });\r
-\r
-               setGlassEnabled(true);\r
-               setStyleName("pithos-DialogBox");\r
-\r
-               // Enable IE selection for the dialog (must disable it upon closing it)\r
-               Pithos.enableIESelection();\r
-\r
-               create = _create;\r
-               \r
-               folder = selected;\r
-\r
-               // Use this opportunity to set the dialog's caption.\r
-               if (create)\r
-                       setText("Create folder");\r
-               else\r
-                       setText("Folder properties");\r
-\r
-               // Outer contains inner and buttons\r
-               VerticalPanel outer = new VerticalPanel();\r
-               outer.add(close);\r
-               // Inner contains generalPanel and permPanel\r
-               inner = new VerticalPanel();\r
-               inner.addStyleName("inner");\r
-\r
-               VerticalPanel generalPanel = new VerticalPanel();\r
+        Anchor close = new Anchor("close");\r
+        close.addStyleName("close");\r
+        close.addClickHandler(new ClickHandler() {\r
+\r
+            @Override\r
+            public void onClick(ClickEvent event) {\r
+                hide();\r
+            }\r
+        });\r
+\r
+        setGlassEnabled(true);\r
+        setStyleName("pithos-DialogBox");\r
+\r
+        // Enable IE selection for the dialog (must disable it upon closing it)\r
+        Pithos.enableIESelection();\r
+\r
+        create = _create;\r
+\r
+        folder = selected;\r
+\r
+        // Use this opportunity to set the dialog's caption.\r
+        if(create) {\r
+            setText("Create folder");\r
+        }\r
+        else {\r
+            setText("Folder properties");\r
+        }\r
+\r
+        // Outer contains inner and buttons\r
+        VerticalPanel outer = new VerticalPanel();\r
+        outer.add(close);\r
+        // Inner contains generalPanel and permPanel\r
+        inner = new VerticalPanel();\r
+        inner.addStyleName("inner");\r
+\r
+        VerticalPanel generalPanel = new VerticalPanel();\r
         FlexTable generalTable = new FlexTable();\r
         generalTable.setText(0, 0, "Name");\r
         generalTable.setText(1, 0, "Parent");\r
         generalTable.setText(2, 0, "Creator");\r
         generalTable.setText(3, 0, "Last modified");\r
 \r
-               folderName.setText(create ? "" : folder.getName());\r
+        folderName.setText(create ? "" : folder.getName());\r
         folderName.setReadOnly(folder.isContainer() && !create);\r
         generalTable.setWidget(0, 1, folderName);\r
 \r
         final Label folderNameNote = new Label("Please note that slashes ('/') are not allowed in folder names.", true);\r
-               folderNameNote.setVisible(false);\r
-               folderNameNote.setStylePrimaryName("gss-readForAllNote");\r
-               generalTable.setWidget(0, 2, folderNameNote);\r
-               \r
-        if (create)\r
+        folderNameNote.setVisible(false);\r
+        folderNameNote.setStylePrimaryName("gss-readForAllNote");\r
+        generalTable.setWidget(0, 2, folderNameNote);\r
+\r
+        if(create) {\r
             generalTable.setText(1, 1, folder.getName());\r
-        else\r
+        }\r
+        else {\r
             generalTable.setText(1, 1, folder.getParent().getName());\r
-        if (create)\r
-               generalTable.setText(2, 1, app.getUserID());\r
-        else\r
-               generalTable.setText(2, 1, folder.getOwner());\r
+        }\r
+        if(create) {\r
+            generalTable.setText(2, 1, app.getCurrentUserDisplayNameOrID());\r
+        }\r
+        else {\r
+            final String ownerID = folder.getOwnerID();\r
+            final String displayName = app.getDisplayNameForUserID(ownerID);\r
+            final String ownerDisplayName;\r
+            if(displayName == null) {\r
+                // FIXME: Get the actual display name and do not use the id\r
+                ownerDisplayName = ownerID;\r
+            }\r
+            else {\r
+                ownerDisplayName = displayName;\r
+            }\r
+            generalTable.setText(2, 1, ownerDisplayName);\r
+        }\r
         DateTimeFormat formatter = DateTimeFormat.getFormat("d/M/yyyy h:mm a");\r
-        if(folder.getLastModified() != null)\r
+        if(folder.getLastModified() != null) {\r
             generalTable.setText(3, 1, formatter.format(folder.getLastModified()));\r
+        }\r
         generalTable.getFlexCellFormatter().setStyleName(0, 0, "props-labels");\r
         generalTable.getFlexCellFormatter().setStyleName(1, 0, "props-labels");\r
         generalTable.getFlexCellFormatter().setStyleName(2, 0, "props-labels");\r
@@ -161,160 +165,170 @@ public class FolderPropertiesDialog extends DialogBox {
 \r
         outer.add(inner);\r
 \r
-               // Create the 'Create/Update' button, along with a listener that hides the dialog\r
-               // when the button is clicked and quits the application.\r
-               String okLabel;\r
-               if (create)\r
-                       okLabel = "Create";\r
-               else\r
-                       okLabel = "Update";\r
-               final Button ok = new Button(okLabel, new ClickHandler() {\r
-                       @Override\r
-                       public void onClick(ClickEvent event) {\r
-                               createOrUpdateFolder();\r
-                               closeDialog();\r
-                       }\r
-               });\r
-               ok.addStyleName("button");\r
-               outer.add(ok);\r
+        // Create the 'Create/Update' button, along with a listener that hides the dialog\r
+        // when the button is clicked and quits the application.\r
+        String okLabel;\r
+        if(create) {\r
+            okLabel = "Create";\r
+        }\r
+        else {\r
+            okLabel = "Update";\r
+        }\r
+        final Button ok = new Button(okLabel, new ClickHandler() {\r
+            @Override\r
+            public void onClick(ClickEvent event) {\r
+                createOrUpdateFolder();\r
+                closeDialog();\r
+            }\r
+        });\r
+        ok.addStyleName("button");\r
+        outer.add(ok);\r
         outer.setCellHorizontalAlignment(inner, HasHorizontalAlignment.ALIGN_CENTER);\r
 \r
         folderName.addChangeHandler(new ChangeHandler() {\r
-                       \r
-                       @Override\r
-                       public void onChange(ChangeEvent event) {\r
-                               if(folderName.getText().contains("/")) {\r
-                                       folderNameNote.setVisible(true);\r
-                                       ok.setEnabled(false);\r
-                               }\r
-                               else {\r
-                                       folderNameNote.setVisible(false);\r
-                                       ok.setEnabled(true);\r
-                               }\r
-                       }\r
-               });\r
+\r
+            @Override\r
+            public void onChange(ChangeEvent event) {\r
+                if(folderName.getText().contains("/")) {\r
+                    folderNameNote.setVisible(true);\r
+                    ok.setEnabled(false);\r
+                }\r
+                else {\r
+                    folderNameNote.setVisible(false);\r
+                    ok.setEnabled(true);\r
+                }\r
+            }\r
+        });\r
 \r
         setWidget(outer);\r
-       }\r
-\r
-       @Override\r
-       public void center() {\r
-               super.center();\r
-               folderName.setFocus(true);\r
-       }\r
-\r
-       @Override\r
-       protected void onPreviewNativeEvent(NativePreviewEvent preview) {\r
-               super.onPreviewNativeEvent(preview);\r
-\r
-               NativeEvent evt = preview.getNativeEvent();\r
-               if (evt.getType().equals(KeyDownEvent.getType().getName()))\r
-                       // Use the popup's key preview hooks to close the dialog when either\r
-                       // enter or escape is pressed.\r
-                       switch (evt.getKeyCode()) {\r
-                               case KeyCodes.KEY_ENTER:\r
-                                       createOrUpdateFolder();\r
+    }\r
+\r
+    @Override\r
+    public void center() {\r
+        super.center();\r
+        folderName.setFocus(true);\r
+    }\r
+\r
+    @Override\r
+    protected void onPreviewNativeEvent(NativePreviewEvent preview) {\r
+        super.onPreviewNativeEvent(preview);\r
+\r
+        NativeEvent evt = preview.getNativeEvent();\r
+        if(evt.getType().equals(KeyDownEvent.getType().getName()))\r
+        // Use the popup's key preview hooks to close the dialog when either\r
+        // enter or escape is pressed.\r
+        {\r
+            switch(evt.getKeyCode()) {\r
+                case KeyCodes.KEY_ENTER:\r
+                    createOrUpdateFolder();\r
+                    closeDialog();\r
+                    break;\r
+                case KeyCodes.KEY_ESCAPE:\r
                     closeDialog();\r
-                                       break;\r
-                               case KeyCodes.KEY_ESCAPE:\r
-                                       closeDialog();\r
-                                       break;\r
-                       }\r
-       }\r
-\r
-\r
-       /**\r
-        * Enables IE selection prevention and hides the dialog\r
-        * (we disable the prevention on creation of the dialog)\r
-        */\r
-       public void closeDialog() {\r
-               Pithos.preventIESelection();\r
-               hide();\r
-       }\r
-\r
-       /**\r
-        * Generate an RPC request to create a new folder.\r
-        */\r
-       private void createFolder() {\r
-               String name = folderName.getText().trim();\r
-               if (name.length() == 0)\r
-                       return;\r
+                    break;\r
+            }\r
+        }\r
+    }\r
+\r
+\r
+    /**\r
+     * Enables IE selection prevention and hides the dialog\r
+     * (we disable the prevention on creation of the dialog)\r
+     */\r
+    public void closeDialog() {\r
+        Pithos.preventIESelection();\r
+        hide();\r
+    }\r
+\r
+    /**\r
+     * Generate an RPC request to create a new folder.\r
+     */\r
+    private void createFolder() {\r
+        String name = folderName.getText().trim();\r
+        if(name.length() == 0) {\r
+            return;\r
+        }\r
         String path = folder.getUri() + "/" + name;\r
-        PutRequest createFolder = new PutRequest(app.getApiPath(), folder.getOwner(), path) {\r
+        PutRequest createFolder = new PutRequest(app.getApiPath(), folder.getOwnerID(), path) {\r
             @Override\r
             public void onSuccess(Resource result) {\r
                 app.updateFolder(folder, true, new Command() {\r
-                                       \r
-                                       @Override\r
-                                       public void execute() {\r
-                                               app.updateStatistics();\r
-                                       }\r
-                               }, true);\r
+\r
+                    @Override\r
+                    public void execute() {\r
+                        app.updateStatistics();\r
+                    }\r
+                }, true);\r
             }\r
 \r
             @Override\r
             public void onError(Throwable t) {\r
-                               GWT.log("", t);\r
-                               app.setError(t);\r
-                               if (t instanceof RestException) {\r
-                                       app.displayError("Unable to create folder:" + ((RestException) t).getHttpStatusText());\r
-                               }\r
-                               else\r
-                                       app.displayError("System error creating folder:" + t.getMessage());\r
+                GWT.log("", t);\r
+                app.setError(t);\r
+                if(t instanceof RestException) {\r
+                    app.displayError("Unable to create folder:" + ((RestException) t).getHttpStatusText());\r
+                }\r
+                else {\r
+                    app.displayError("System error creating folder:" + t.getMessage());\r
+                }\r
             }\r
 \r
-                       @Override\r
-                       protected void onUnauthorized(Response response) {\r
-                               app.sessionExpired();\r
-                       }\r
-       };\r
+            @Override\r
+            protected void onUnauthorized(Response response) {\r
+                app.sessionExpired();\r
+            }\r
+        };\r
         createFolder.setHeader("X-Auth-Token", app.getUserToken());\r
         createFolder.setHeader("Accept", "*/*");\r
         createFolder.setHeader("Content-Length", "0");\r
         createFolder.setHeader("Content-Type", "application/directory");\r
         Scheduler.get().scheduleDeferred(createFolder);\r
-       }\r
-\r
-       /**\r
-        * Upon closing the dialog by clicking OK or pressing ENTER this method does\r
-        * the actual work of modifying folder properties or creating a new Folder\r
-        * depending on the value of the create field\r
-        */\r
-       protected void createOrUpdateFolder() {\r
-               if (create)\r
-                       createFolder();\r
-               else\r
-                       updateFolder();\r
-\r
-       }\r
-\r
-       private void updateFolder() {\r
+    }\r
+\r
+    /**\r
+     * Upon closing the dialog by clicking OK or pressing ENTER this method does\r
+     * the actual work of modifying folder properties or creating a new Folder\r
+     * depending on the value of the create field\r
+     */\r
+    protected void createOrUpdateFolder() {\r
+        if(create) {\r
+            createFolder();\r
+        }\r
+        else {\r
+            updateFolder();\r
+        }\r
+\r
+    }\r
+\r
+    private void updateFolder() {\r
         final String newName = folderName.getText().trim();\r
-        if (newName.length() == 0)\r
-               return;\r
-        if (!folder.isContainer() && !folder.getName().equals(newName)) {\r
+        if(newName.length() == 0) {\r
+            return;\r
+        }\r
+        if(!folder.isContainer() && !folder.getName().equals(newName)) {\r
             final String path = folder.getParent().getUri() + "/" + newName;\r
-            app.copyFolder(folder, folder.getOwner(), path, true, new Command() {\r
-                               \r
-                               @Override\r
-                               public void execute() {\r
+            app.copyFolder(folder, folder.getOwnerID(), path, true, new Command() {\r
+\r
+                @Override\r
+                public void execute() {\r
                     app.updateFolder(folder.getParent(), false, new Command() {\r
-                               \r
-                               @Override\r
-                               public void execute() {\r
-                                       app.updateMySharedRoot();\r
-                               }\r
-                       }, true);\r
-                               }\r
-                       });\r
+\r
+                        @Override\r
+                        public void execute() {\r
+                            app.updateMySharedRoot();\r
+                        }\r
+                    }, true);\r
+                }\r
+            });\r
         }\r
-        else\r
+        else {\r
             app.updateFolder(folder.getParent(), false, new Command() {\r
-                       \r
-                       @Override\r
-                       public void execute() {\r
-                               app.updateMySharedRoot();\r
-                       }\r
-               }, true);\r
-       }\r
+\r
+                @Override\r
+                public void execute() {\r
+                    app.updateMySharedRoot();\r
+                }\r
+            }, true);\r
+        }\r
+    }\r
 }\r