package gr.grnet.pithos.web.client.othersharedtree;
-import gr.grnet.pithos.web.client.FolderContextMenu;
-import gr.grnet.pithos.web.client.Pithos;
-import gr.grnet.pithos.web.client.SharingUsers;
-import gr.grnet.pithos.web.client.foldertree.AccountResource;
-import gr.grnet.pithos.web.client.foldertree.Folder;
-import gr.grnet.pithos.web.client.othersharedtree.OtherSharedTreeView.Templates;
-import gr.grnet.pithos.web.client.rest.GetRequest;
-import gr.grnet.pithos.web.client.rest.RestException;
-
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.Map;
-
import com.google.gwt.cell.client.AbstractCell;
import com.google.gwt.cell.client.Cell;
import com.google.gwt.cell.client.TextCell;
import com.google.gwt.core.client.GWT;
import com.google.gwt.core.client.Scheduler;
import com.google.gwt.event.dom.client.ContextMenuEvent;
+import com.google.gwt.http.client.Request;
import com.google.gwt.http.client.Response;
import com.google.gwt.http.client.URL;
+import com.google.gwt.json.client.JSONObject;
import com.google.gwt.safehtml.shared.SafeHtml;
import com.google.gwt.safehtml.shared.SafeHtmlBuilder;
import com.google.gwt.text.shared.SafeHtmlRenderer;
import com.google.gwt.view.client.ListDataProvider;
import com.google.gwt.view.client.SingleSelectionModel;
import com.google.gwt.view.client.TreeViewModel;
+import gr.grnet.pithos.web.client.FolderContextMenu;
+import gr.grnet.pithos.web.client.Pithos;
+import gr.grnet.pithos.web.client.SharingUsers;
+import gr.grnet.pithos.web.client.catalog.GetUserCatalogs;
+import gr.grnet.pithos.web.client.catalog.UserCatalogs;
+import gr.grnet.pithos.web.client.foldertree.AccountResource;
+import gr.grnet.pithos.web.client.foldertree.Folder;
+import gr.grnet.pithos.web.client.othersharedtree.OtherSharedTreeView.Templates;
+import gr.grnet.pithos.web.client.rest.GetRequest;
+import gr.grnet.pithos.web.client.rest.RestException;
+
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
public class OtherSharedTreeViewModel implements TreeViewModel {
protected Pithos app;
- String dummy = "No shares by others yet";
+ final String dummy = "No shares by others yet";
private Cell<Folder> folderCell = new AbstractCell<Folder>(ContextMenuEvent.getType().getName()) {
- @Override
+ @Override
public void render(Context context, Folder folder, SafeHtmlBuilder safeHtmlBuilder) {
String html = AbstractImagePrototype.create(OtherSharedTreeView.images.folderYellow()).getHTML();
- safeHtmlBuilder.appendHtmlConstant(html).appendHtmlConstant(" ");
+ safeHtmlBuilder.appendHtmlConstant(html).appendHtmlConstant(" ");
safeHtmlBuilder.append(Templates.INSTANCE.nameSpan(folder.getName()));
}
@Override
public void onBrowserEvent(Context context, com.google.gwt.dom.client.Element parent, final Folder folder, com.google.gwt.dom.client.NativeEvent event, ValueUpdater<Folder> valueUpdater) {
- if (event.getType().equals(ContextMenuEvent.getType().getName())) {
- final int x = event.getClientX();
- final int y = event.getClientY();
+ if(event.getType().equals(ContextMenuEvent.getType().getName())) {
+ final int x = event.getClientX();
+ final int y = event.getClientY();
OtherSharedTreeViewModel.this.selectionModel.setSelected(folder, true);
app.scheduleFolderHeadCommand(folder, new Command() {
-
- @Override
- public void execute() {
- FolderContextMenu menu = new FolderContextMenu(app, OtherSharedTreeView.images, app.getSelectedTree(), folder);
- menu.setPopupPosition(x, y);
- menu.show();
- }
- });
+
+ @Override
+ public void execute() {
+ FolderContextMenu menu = new FolderContextMenu(app, OtherSharedTreeView.images, app.getSelectedTree(), folder);
+ menu.setPopupPosition(x, y);
+ menu.show();
+ }
+ });
}
}
};
- protected ListDataProvider<String> userLevelDataProvider = new ListDataProvider<String>();
+ protected ListDataProvider<String> userLevelDataProviderForIDs = new ListDataProvider<String>();
+// protected ListDataProvider<String> userLevelDataProviderForDisplayNames = new ListDataProvider<String>();
protected Map<String, ListDataProvider<Folder>> userDataProviderMap = new HashMap<String, ListDataProvider<Folder>>();
private Map<Folder, ListDataProvider<Folder>> dataProviderMap = new HashMap<Folder, ListDataProvider<Folder>>();
-
+
protected SingleSelectionModel<Folder> selectionModel;
public OtherSharedTreeViewModel(Pithos _app, SingleSelectionModel<Folder> selectionModel) {
@Override
public <T> NodeInfo<?> getNodeInfo(T value) {
- if (value == null) {
- fetchSharingUsers(null);
- return new DefaultNodeInfo<String>(userLevelDataProvider, new TextCell(new SafeHtmlRenderer<String>() {
-
- @Override
- public SafeHtml render(String object) {
+ if(value == null) {
+// LOG("getNodeInfo(null), calling fetchSharingUsers(null)");
+ fetchSharingUsers(null);
+// LOG("getNodeInfo(null), called fetchSharingUsers(null)");
+ return new DefaultNodeInfo<String>(userLevelDataProviderForIDs, new TextCell(new SafeHtmlRenderer<String>() {
+ @Override
+ public SafeHtml render(String object) {
+ final String displayName = app.getUserDisplayNameForID(object);
+// LOG("render(userID = "+object+"), displayName = " + displayName);
SafeHtmlBuilder builder = new SafeHtmlBuilder();
- render(object, builder);
+ render(displayName, builder);
return builder.toSafeHtml();
- }
+ }
- @Override
- public void render(String object, SafeHtmlBuilder builder) {
- if (!object.equals(dummy)) {
- String html = AbstractImagePrototype.create(OtherSharedTreeView.images.myShared()).getHTML();
- builder.appendHtmlConstant(html).appendHtmlConstant(" ");
+ @Override
+ public void render(String object, SafeHtmlBuilder builder) {
+ if(!object.equals(dummy)) {
+// LOG("render(userID [not dummy] = "+object+")");
+ String html = AbstractImagePrototype.create(OtherSharedTreeView.images.myShared()).getHTML();
+ builder.appendHtmlConstant(html).appendHtmlConstant(" ");
}
+ final String displayName = app.getUserDisplayNameForID(object);
builder.append(OtherSharedTreeView.Templates.INSTANCE.nameSpan(object));
- }
- }), null, null);
+ }
+ }), null, null);
}
- else if (value instanceof String) {
- String username = (String) value;
- if (userDataProviderMap.get(username) == null) {
- userDataProviderMap.put(username, new ListDataProvider<Folder>());
- }
- final ListDataProvider<Folder> dataProvider = userDataProviderMap.get(username);
- fetchSharedContainers(username, dataProvider, null);
- return new DefaultNodeInfo<Folder>(dataProvider, folderCell, selectionModel, null);
+ else if(value instanceof String) {
+// LOG("getNodeInfo(String "+value+"), called with userID");
+ final String userID = (String) value;
+
+ if(userDataProviderMap.get(userID) == null) {
+ userDataProviderMap.put(userID, new ListDataProvider<Folder>());
+ }
+ final ListDataProvider<Folder> userIDDataProvider = userDataProviderMap.get(userID);
+ fetchSharedContainers(userID, userIDDataProvider, null);
+
+ return new DefaultNodeInfo<Folder>(userIDDataProvider, folderCell, selectionModel, null);
}
else {
+// LOG("getNodeInfo(Folder "+value+"), called with a folder");
final Folder f = (Folder) value;
- if (dataProviderMap.get(f) == null) {
+ if(dataProviderMap.get(f) == null) {
dataProviderMap.put(f, new ListDataProvider<Folder>());
}
final ListDataProvider<Folder> dataProvider = dataProviderMap.get(f);
}
}
+// native void LOG(String message) /*-{
+// console.log(message );
+// }-*/;
+
private void fetchSharingUsers(final Command callback) {
GetRequest<SharingUsers> getSharingUsers = new GetRequest<SharingUsers>(SharingUsers.class, app.getApiPath(), "", "?format=json") {
@Override
public void onSuccess(final SharingUsers _result) {
- userLevelDataProvider.getList().clear();
- userLevelDataProvider.getList().addAll(_result.getUsers());
- if (userLevelDataProvider.getList().isEmpty())
- userLevelDataProvider.getList().add(dummy);
- Iterator<String> iter = _result.getUsers().iterator();
- fetchSharedContainers(iter, callback);
+ userLevelDataProviderForIDs.getList().clear();
+
+ final List<String> userIDs = _result.getUserIDs();
+// for(String userID : userIDs) {
+// LOG("fetchSharingUsers(): userID =" + userID);
+// }
+ final List<String> userIDsWithUnknownDisplayNames = app.filterUserIDsWithUnknownDisplayName(userIDs);
+// for(String userID : userIDsWithUnknownDisplayNames) {
+// LOG("fetchSharingUsers(): userID (with unknown name) =" + userID);
+// }
+
+ userLevelDataProviderForIDs.getList().addAll(userIDs);
+ if(userLevelDataProviderForIDs.getList().isEmpty()) {
+ userLevelDataProviderForIDs.getList().add(dummy);
+// userLevelDataProviderForDisplayNames.getList().add(dummy);
+ } else {
+// userLevelDataProviderForDisplayNames.getList().addAll(app.getUserDisplayNamesForIDs(userIDs));
+ }
+
+ if(userIDsWithUnknownDisplayNames.size() == 0) {
+ // All display names are known, so we proceed directly
+ fetchSharedContainers(userLevelDataProviderForIDs.getList().iterator(), callback);
+ } else {
+ // First fetch unknown display names and then proceed
+ new GetUserCatalogs(app, userIDsWithUnknownDisplayNames) {
+ @Override
+ public void onSuccess(Request request, Response response, JSONObject result, UserCatalogs userCatalogs) {
+// for(Map.Entry<String, String> entry : userCatalogs) {
+// final String id = entry.getKey();
+// final String name = entry.getValue();
+// LOG("mapping: userID("+id+") -> name("+name+")");
+// }
+
+ // Update the cached user catalogs
+ app.getUserCatalogs().updateFrom(userCatalogs);
+
+ fetchSharedContainers(userLevelDataProviderForIDs.getList().iterator(), callback);
+ }
+
+ @Override
+ public void onError(Request request, Throwable t) {
+ super.onError(request, t);
+ app.setError(t);
+ }
+ }.scheduleDeferred();
+ }
}
@Override
public void onError(Throwable t) {
GWT.log("Error getting folder", t);
- app.setError(t);
- if (t instanceof RestException)
+ app.setError(t);
+ if(t instanceof RestException) {
app.displayError("Error getting folder: " + ((RestException) t).getHttpStatusText());
- else
+ }
+ else {
app.displayError("System error fetching folder: " + t.getMessage());
+ }
}
- @Override
- protected void onUnauthorized(Response response) {
- app.sessionExpired();
- }
+ @Override
+ protected void onUnauthorized(Response response) {
+ app.sessionExpired();
+ }
};
getSharingUsers.setHeader("X-Auth-Token", app.getUserToken());
Scheduler.get().scheduleDeferred(getSharingUsers);
- }
-
- protected void fetchSharedContainers(final Iterator<String> iter, final Command callback) {
- if (iter.hasNext()) {
- String username = iter.next();
- if (userDataProviderMap.get(username) == null) {
- userDataProviderMap.put(username, new ListDataProvider<Folder>());
- }
- final ListDataProvider<Folder> dataProvider = userDataProviderMap.get(username);
- fetchSharedContainers(username, dataProvider, new Command() {
-
- @Override
- public void execute() {
- fetchSharedContainers(iter, callback);
-
- }
- });
- }
- else
- if (callback != null)
- callback.execute();
- }
-
- @Override
+ }
+
+ protected void fetchSharedContainers(final Iterator<String> userIDsIterator, final Command callback) {
+ if(userIDsIterator.hasNext()) {
+ String userID = userIDsIterator.next();
+ if(userDataProviderMap.get(userID) == null) {
+ userDataProviderMap.put(userID, new ListDataProvider<Folder>());
+ }
+ final ListDataProvider<Folder> dataProvider = userDataProviderMap.get(userID);
+ fetchSharedContainers(userID, dataProvider, new Command() {
+
+ @Override
+ public void execute() {
+ fetchSharedContainers(userIDsIterator, callback);
+
+ }
+ });
+ }
+ else if(callback != null) {
+ callback.execute();
+ }
+ }
+
+ @Override
public boolean isLeaf(Object o) {
- if (o == null)
- return userLevelDataProvider.getList().isEmpty();
- else if (o instanceof Folder) {
- Folder f = (Folder) o;
- return f.getSubfolders().isEmpty();
+ if(o == null) {
+ boolean result = userLevelDataProviderForIDs.getList().isEmpty();
+// LOG("isLeaf(null) ==> " + result);
+ return result;
+ }
+ else if(o instanceof Folder) {
+ Folder folder = (Folder) o;
+ boolean result = folder.getSubfolders().isEmpty();
+// LOG("isLeaf(Folder "+folder+") ==> " + result);
+ return result;
+ }
+ else {
+ ListDataProvider<Folder> dp = userDataProviderMap.get(o);
+ if(dp != null) {
+ boolean result = dp.getList().isEmpty();
+// LOG("isLeaf("+o.getClass().getName()+" "+o+") ==> " + result);
+ return result;
+ }
+// LOG("isLeaf("+o.getClass().getName()+" "+o+") ==> (true)");
+ return true;
}
- else {
- ListDataProvider<Folder> dp = userDataProviderMap.get(o);
- if (dp != null)
- return dp.getList().isEmpty();
- return true;
- }
}
- private void fetchSharedContainers(final String username, final ListDataProvider<Folder> dataProvider, final Command callback) {
- GetRequest<AccountResource> getUserSharedContainers = new GetRequest<AccountResource>(AccountResource.class, app.getApiPath(), username, "?format=json") {
-
- @Override
- public void onSuccess(AccountResource _result) {
- final ListDataProvider<Folder> tempProvider = new ListDataProvider<Folder>();
- Iterator<Folder> iter = _result.getContainers().iterator();
- fetchFolder(username, iter, tempProvider, new Command() {
-
- @Override
- public void execute() {
- dataProvider.getList().clear();
- dataProvider.getList().addAll(tempProvider.getList());
- if (callback != null)
- callback.execute();
- }
- });
- }
-
- @Override
- public void onError(Throwable t) {
+ private void fetchSharedContainers(final String userID, final ListDataProvider<Folder> dataProvider, final Command callback) {
+ GetRequest<AccountResource> getUserSharedContainers = new GetRequest<AccountResource>(AccountResource.class, app.getApiPath(), userID, "?format=json") {
+
+ @Override
+ public void onSuccess(AccountResource _result) {
+ final ListDataProvider<Folder> tempProvider = new ListDataProvider<Folder>();
+ Iterator<Folder> folderIterator = _result.getContainers().iterator();
+ fetchFolder(userID, folderIterator, tempProvider, new Command() {
+
+ @Override
+ public void execute() {
+ dataProvider.getList().clear();
+ dataProvider.getList().addAll(tempProvider.getList());
+ if(callback != null) {
+ callback.execute();
+ }
+ }
+ });
+ }
+
+ @Override
+ public void onError(Throwable t) {
GWT.log("Error getting account", t);
- app.setError(t);
- if (t instanceof RestException)
+ app.setError(t);
+ if(t instanceof RestException) {
app.displayError("Error getting account: " + ((RestException) t).getHttpStatusText());
- else
+ }
+ else {
app.displayError("System error fetching user data: " + t.getMessage());
- }
+ }
+ }
- @Override
- protected void onUnauthorized(Response response) {
- app.sessionExpired();
- }
- };
- getUserSharedContainers.setHeader("X-Auth-Token", app.getUserToken());
- Scheduler.get().scheduleDeferred(getUserSharedContainers);
- }
+ @Override
+ protected void onUnauthorized(Response response) {
+ app.sessionExpired();
+ }
+ };
+ getUserSharedContainers.setHeader("X-Auth-Token", app.getUserToken());
+ Scheduler.get().scheduleDeferred(getUserSharedContainers);
+ }
- protected void fetchFolder(final String username, final Iterator<Folder> iter, final ListDataProvider<Folder> dataProvider, final Command callback) {
- if (iter.hasNext()) {
- final Folder f = iter.next();
+ protected void fetchFolder(final String userID, final Iterator<Folder> folderIterator, final ListDataProvider<Folder> dataProvider, final Command callback) {
+ if(folderIterator.hasNext()) {
+ final Folder f = folderIterator.next();
String path = "/" + f.getContainer() + "?format=json&delimiter=/&prefix=" + URL.encodeQueryString(f.getPrefix());
- GetRequest<Folder> getFolder = new GetRequest<Folder>(Folder.class, app.getApiPath(), username, path, f) {
+ GetRequest<Folder> getFolder = new GetRequest<Folder>(Folder.class, app.getApiPath(), userID, path, f) {
@Override
public void onSuccess(Folder _result) {
- dataProvider.getList().add(_result);
- fetchFolder(username, iter, dataProvider, callback);
+ dataProvider.getList().add(_result);
+ fetchFolder(userID, folderIterator, dataProvider, callback);
}
@Override
public void onError(Throwable t) {
GWT.log("Error getting folder", t);
- app.setError(t);
- if (t instanceof RestException)
+ app.setError(t);
+ if(t instanceof RestException) {
app.displayError("Error getting folder: " + ((RestException) t).getHttpStatusText());
- else
+ }
+ else {
app.displayError("System error fetching folder: " + t.getMessage());
+ }
}
- @Override
- protected void onUnauthorized(Response response) {
- app.sessionExpired();
- }
+ @Override
+ protected void onUnauthorized(Response response) {
+ app.sessionExpired();
+ }
};
getFolder.setHeader("X-Auth-Token", app.getUserToken());
Scheduler.get().scheduleDeferred(getFolder);
}
- else if (callback != null)
+ else if(callback != null) {
callback.execute();
+ }
}
public Folder getSelection() {
}
public void updateFolder(Folder folder, boolean showfiles, Command callback) {
- if (dataProviderMap.get(folder) == null) {
+ if(dataProviderMap.get(folder) == null) {
dataProviderMap.put(folder, new ListDataProvider<Folder>());
}
final ListDataProvider<Folder> dataProvider = dataProviderMap.get(folder);
GetRequest<Folder> getFolder = new GetRequest<Folder>(Folder.class, app.getApiPath(), f.getOwnerID(), path, f) {
@Override
public void onSuccess(final Folder _result) {
- if (showfiles)
+ if(showfiles) {
app.showFiles(_result);
+ }
Iterator<Folder> iter = _result.getSubfolders().iterator();
fetchFolder(_result.getOwnerID(), iter, dataProvider, new Command() {
@Override
dataProvider.getList().clear();
dataProvider.getList().addAll(_result.getSubfolders());
app.getOtherSharedTreeView().updateChildren(f);
- if (callback != null)
- callback.execute();
+ if(callback != null) {
+ callback.execute();
+ }
}
});
}
@Override
public void onError(Throwable t) {
GWT.log("Error getting folder", t);
- app.setError(t);
- if (t instanceof RestException)
+ app.setError(t);
+ if(t instanceof RestException) {
app.displayError("Error getting folder: " + ((RestException) t).getHttpStatusText());
- else
+ }
+ else {
app.displayError("System error fetching folder: " + t.getMessage());
+ }
}
- @Override
- protected void onUnauthorized(Response response) {
- app.sessionExpired();
- }
+ @Override
+ protected void onUnauthorized(Response response) {
+ app.sessionExpired();
+ }
};
getFolder.setHeader("X-Auth-Token", app.getUserToken());
Scheduler.get().scheduleDeferred(getFolder);
}
-
+
public void initialize(Command callback) {
- fetchSharingUsers(callback);
+ fetchSharingUsers(callback);
}
}