Show display name in FilePropertiesDialog
[pithos-web-client] / src / gr / grnet / pithos / web / client / FolderPropertiesDialog.java
index 0a343fd..db3393a 100644 (file)
@@ -1,5 +1,5 @@
 /*\r
- * Copyright 2011 GRNET S.A. All rights reserved.\r
+ * Copyright 2011-2012 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 com.google.gwt.core.client.Scheduler;\r
-import com.google.gwt.event.dom.client.KeyDownEvent;\r
-import com.google.gwt.user.client.Command;\r
-import gr.grnet.pithos.web.client.foldertree.File;\r
 import gr.grnet.pithos.web.client.foldertree.Folder;\r
-import gr.grnet.pithos.web.client.foldertree.Resource;\r
-import gr.grnet.pithos.web.client.rest.PostRequest;\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.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.DecoratedTabPanel;\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.HorizontalPanel;\r
-import com.google.gwt.user.client.ui.TabPanel;\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 java.util.Iterator;\r
-import java.util.Map;\r
 \r
 /**\r
  * The 'Folder properties' dialog box implementation.\r
@@ -75,7 +70,7 @@ public class FolderPropertiesDialog extends DialogBox {
        /**\r
         * The widget that holds the folderName of the folder.\r
         */\r
-       private TextBox folderName = new TextBox();\r
+       TextBox folderName = new TextBox();\r
 \r
        /**\r
         * A flag that denotes whether the dialog will be used to create or modify a\r
@@ -83,18 +78,16 @@ public class FolderPropertiesDialog extends DialogBox {
         */\r
        private final boolean create;\r
 \r
-       protected PermissionsList permList;\r
-\r
        final Folder folder;\r
 \r
-       final TabPanel inner;\r
+       final VerticalPanel inner;\r
 \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();\r
+               Anchor close = new Anchor("close");\r
                close.addStyleName("close");\r
                close.addClickHandler(new ClickHandler() {\r
                        \r
@@ -104,7 +97,6 @@ public class FolderPropertiesDialog extends DialogBox {
                        }\r
                });\r
 \r
-               setAnimationEnabled(true);\r
                setGlassEnabled(true);\r
                setStyleName("pithos-DialogBox");\r
 \r
@@ -125,10 +117,8 @@ public class FolderPropertiesDialog extends DialogBox {
                VerticalPanel outer = new VerticalPanel();\r
                outer.add(close);\r
                // Inner contains generalPanel and permPanel\r
-               inner = new DecoratedTabPanel();\r
-               inner.setAnimationEnabled(true);\r
+               inner = new VerticalPanel();\r
                inner.addStyleName("inner");\r
-               inner.getDeckPanel().addStyleName("pithos-TabPanelBottom");\r
 \r
                VerticalPanel generalPanel = new VerticalPanel();\r
         FlexTable generalTable = new FlexTable();\r
@@ -136,15 +126,24 @@ public class FolderPropertiesDialog extends DialogBox {
         generalTable.setText(1, 0, "Parent");\r
         generalTable.setText(2, 0, "Creator");\r
         generalTable.setText(3, 0, "Last modified");\r
-        folderName.setText(create ? "" : folder.getName());\r
+\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
             generalTable.setText(1, 1, folder.getName());\r
         else\r
-            generalTable.setText(1, 1, folder.getPrefix());\r
-        generalTable.setText(2, 1, "");\r
+            generalTable.setText(1, 1, folder.getParent().getName());\r
+        if (create)\r
+               generalTable.setText(2, 1, app.getCurrentUserDisplayNameOrID());\r
+        else\r
+               generalTable.setText(2, 1, folder.getOwner());\r
         DateTimeFormat formatter = DateTimeFormat.getFormat("d/M/yyyy h:mm a");\r
         if(folder.getLastModified() != null)\r
             generalTable.setText(3, 1, formatter.format(folder.getLastModified()));\r
@@ -158,44 +157,7 @@ public class FolderPropertiesDialog extends DialogBox {
         generalTable.getFlexCellFormatter().setStyleName(3, 1, "props-values");\r
         generalTable.setCellSpacing(4);\r
         generalPanel.add(generalTable);\r
-        inner.add(generalPanel, "General");\r
-\r
-        VerticalPanel permPanel = new VerticalPanel();\r
-        FilePropertiesDialog.Images images = GWT.create(FilePropertiesDialog.Images.class);\r
-        boolean permsReadonly = folder.getInheritedPermissionsFrom() != null || folder.existChildrenPermissions();\r
-        permList = new PermissionsList(images, folder.getPermissions(), folder.getOwner(), permsReadonly);\r
-        permPanel.add(permList);\r
-\r
-        if (!permsReadonly) {\r
-            HorizontalPanel permButtons = new HorizontalPanel();\r
-            Button add = new Button("Add Group", new ClickHandler() {\r
-                @Override\r
-                public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
-                    PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, false);\r
-                    dlg.center();\r
-                }\r
-            });\r
-            permButtons.add(add);\r
-            permButtons.setCellHorizontalAlignment(add, HasHorizontalAlignment.ALIGN_CENTER);\r
-\r
-            Button addUser = new Button("Add User", new ClickHandler() {\r
-                @Override\r
-                public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
-                    PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, true);\r
-                    dlg.center();\r
-                }\r
-            });\r
-            addUser.getElement().setId("folderPropertiesDialog.button.addUser");\r
-            permButtons.add(addUser);\r
-            permButtons.setCellHorizontalAlignment(addUser, HasHorizontalAlignment.ALIGN_CENTER);\r
-            permButtons.setSpacing(8);\r
-            permButtons.addStyleName("gss-TabPanelBottom");\r
-            permPanel.add(permButtons);\r
-        }\r
-\r
-        if (!create)\r
-            inner.add(permPanel, "Sharing");\r
-        inner.selectTab(0);\r
+        inner.add(generalPanel);\r
 \r
         outer.add(inner);\r
 \r
@@ -206,9 +168,9 @@ public class FolderPropertiesDialog extends DialogBox {
                        okLabel = "Create";\r
                else\r
                        okLabel = "Update";\r
-               Button ok = new Button(okLabel, new ClickHandler() {\r
+               final Button ok = new Button(okLabel, new ClickHandler() {\r
                        @Override\r
-                       public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
+                       public void onClick(ClickEvent event) {\r
                                createOrUpdateFolder();\r
                                closeDialog();\r
                        }\r
@@ -217,6 +179,21 @@ public class FolderPropertiesDialog extends DialogBox {
                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
         setWidget(outer);\r
        }\r
 \r
@@ -259,23 +236,26 @@ public class FolderPropertiesDialog extends DialogBox {
         * Generate an RPC request to create a new folder.\r
         */\r
        private void createFolder() {\r
-               String name = folderName.getText();\r
+               String name = folderName.getText().trim();\r
+               if (name.length() == 0)\r
+                       return;\r
         String path = folder.getUri() + "/" + name;\r
         PutRequest createFolder = new PutRequest(app.getApiPath(), folder.getOwner(), path) {\r
             @Override\r
-            public void onSuccess(@SuppressWarnings("unused") Resource result) {\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
-                               });\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
@@ -288,10 +268,10 @@ public class FolderPropertiesDialog extends DialogBox {
                                app.sessionExpired();\r
                        }\r
        };\r
-        createFolder.setHeader("X-Auth-Token", app.getToken());\r
+        createFolder.setHeader("X-Auth-Token", app.getUserToken());\r
         createFolder.setHeader("Accept", "*/*");\r
         createFolder.setHeader("Content-Length", "0");\r
-        createFolder.setHeader("Content-Type", "application/folder");\r
+        createFolder.setHeader("Content-Type", "application/directory");\r
         Scheduler.get().scheduleDeferred(createFolder);\r
        }\r
 \r
@@ -309,139 +289,32 @@ public class FolderPropertiesDialog extends DialogBox {
        }\r
 \r
        private void updateFolder() {\r
-        final Map<String, Boolean[]> perms = (permList.hasChanges() ? permList.getPermissions() : null);\r
         final String newName = folderName.getText().trim();\r
+        if (newName.length() == 0)\r
+               return;\r
         if (!folder.isContainer() && !folder.getName().equals(newName)) {\r
             final String path = folder.getParent().getUri() + "/" + newName;\r
-            PutRequest newFolder = new PutRequest(app.getApiPath(), folder.getParent().getOwner(), path) {\r
-                @Override\r
-                public void onSuccess(@SuppressWarnings("unused") Resource result) {\r
-                    Iterator<File> iter = folder.getFiles().iterator();\r
-                    app.copyFiles(iter, folder.getParent().getOwner(), folder.getParent().getUri() + "/" + newName, new Command() {\r
-                        @Override\r
-                        public void execute() {\r
-                            Iterator<Folder> iterf = folder.getSubfolders().iterator();\r
-                            app.copySubfolders(iterf, folder.getParent().getOwner(), folder.getParent().getUri() + "/" + newName, new Command() {\r
-                                @Override\r
-                                public void execute() {\r
-                                    app.deleteFolder(folder);\r
-                                    updateMetadata(path + "?update=", perms);\r
-                                }\r
-                            });\r
-                        }\r
-                    });\r
-                }\r
-\r
-                @Override\r
-                public void onError(Throwable t) {\r
-                    GWT.log("", t);\r
-                    if(t instanceof RestException){\r
-                        app.displayError("Unable to update folder: " + ((RestException) t).getHttpStatusText());\r
-                    }\r
-                    else\r
-                        app.displayError("System error modifying folder: " + t.getMessage());\r
-                }\r
-\r
+            app.copyFolder(folder, folder.getOwner(), path, true, new Command() {\r
+                               \r
                                @Override\r
-                               protected void onUnauthorized(Response response) {\r
-                                       app.sessionExpired();\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
-            newFolder.setHeader("X-Auth-Token", app.getToken());\r
-            newFolder.setHeader("Content-Type", "application/folder");\r
-            newFolder.setHeader("Accept", "*/*");\r
-            newFolder.setHeader("Content-Length", "0");\r
-            Scheduler.get().scheduleDeferred(newFolder);\r
+                       });\r
         }\r
         else\r
-            updateMetadata(folder.getUri() + "?update=", perms);\r
-       }\r
-\r
-       protected void updateMetadata(final String path, final Map<String, Boolean[]> newPermissions) {\r
-        if (newPermissions != null) {\r
-            PostRequest updateFolder = new PostRequest(app.getApiPath(), folder.getOwner(), path) {\r
-                @Override\r
-                public void onSuccess(@SuppressWarnings("unused") Resource result) {\r
-                    app.updateFolder(folder.getParent(), false, null);\r
-                }\r
-\r
-                @Override\r
-                public void onError(Throwable t) {\r
-                    GWT.log("", t);\r
-                    if (t instanceof RestException) {\r
-                       if (((RestException) t).getHttpStatusCode() == Response.SC_NOT_FOUND) { //Probably a virtual folder\r
-                            final String path1 = folder.getUri();\r
-                            PutRequest newFolder = new PutRequest(app.getApiPath(), folder.getOwner(), path1) {\r
-                                @Override\r
-                                public void onSuccess(@SuppressWarnings("unused") Resource result) {\r
-                                       updateMetadata(path, newPermissions);\r
-                                }\r
-\r
-                                @Override\r
-                                public void onError(Throwable _t) {\r
-                                    GWT.log("", _t);\r
-                                    if(_t instanceof RestException){\r
-                                        app.displayError("Unable to update folder: " + ((RestException) _t).getHttpStatusText());\r
-                                    }\r
-                                    else\r
-                                        app.displayError("System error modifying folder: " + _t.getMessage());\r
-                                }\r
-\r
-                                               @Override\r
-                                               protected void onUnauthorized(Response response) {\r
-                                                       app.sessionExpired();\r
-                                               }\r
-                            };\r
-                            newFolder.setHeader("X-Auth-Token", app.getToken());\r
-                            newFolder.setHeader("Content-Type", "application/folder");\r
-                            newFolder.setHeader("Accept", "*/*");\r
-                            newFolder.setHeader("Content-Length", "0");\r
-                            Scheduler.get().scheduleDeferred(newFolder);\r
-                       }\r
-                       else if (((RestException) t).getHttpStatusCode() == Response.SC_CONFLICT) {\r
-                               app.displayError("Cannot set permissions. Probably subfolders or files already have permissions set");\r
-                       }\r
-                       else\r
-                               app.displayError("Wrror modifying folder: " + t.getMessage());\r
-                    }\r
-                    else\r
-                       app.displayError("System error modifying folder: " + t.getMessage());\r
-                }\r
-\r
-                               @Override\r
-                               protected void onUnauthorized(Response response) {\r
-                                       app.sessionExpired();\r
-                               }\r
-            };\r
-            updateFolder.setHeader("X-Auth-Token", app.getToken());\r
-            String readPermHeader = "read=";\r
-            String writePermHeader = "write=";\r
-            for (String u : newPermissions.keySet()) {\r
-                Boolean[] p = newPermissions.get(u);\r
-                if (p[0] != null && p[0])\r
-                    readPermHeader += u + ",";\r
-                if (p[1] != null && p[1])\r
-                    writePermHeader += u + ",";\r
-            }\r
-            if (readPermHeader.endsWith("="))\r
-                readPermHeader = "";\r
-            else if (readPermHeader.endsWith(","))\r
-                readPermHeader = readPermHeader.substring(0, readPermHeader.length() - 1);\r
-            if (writePermHeader.endsWith("="))\r
-                writePermHeader = "";\r
-            else if (writePermHeader.endsWith(","))\r
-                writePermHeader = writePermHeader.substring(0, writePermHeader.length() - 1);\r
-            String permHeader = readPermHeader +  ((readPermHeader.length()  > 0 && writePermHeader.length() > 0) ?  ";" : "") + writePermHeader;\r
-            if (permHeader.length() == 0)\r
-                permHeader="~";\r
-            updateFolder.setHeader("X-Object-Sharing", permHeader);\r
-            Scheduler.get().scheduleDeferred(updateFolder);\r
-        }\r
-        else\r
-            app.updateFolder(folder.getParent(), false, null);\r
-    }\r
-\r
-       public void selectTab(int _tab) {\r
-               inner.selectTab(_tab);\r
+            app.updateFolder(folder.getParent(), false, new Command() {\r
+                       \r
+                       @Override\r
+                       public void execute() {\r
+                               app.updateMySharedRoot();\r
+                       }\r
+               }, true);\r
        }\r
 }\r