mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
. Version History list for a file (available in the File Details screen)
- View previous file version content - Sorted by most recent version first - Revert to a previous version action . Some more changes to Create Web Project wizard from Usability Review git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@4756 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -127,7 +127,12 @@ public class AVMNode extends Node implements Map<String, Object>
|
||||
{
|
||||
return this.avmRef.getPath();
|
||||
}
|
||||
|
||||
|
||||
public final AVMNodeDescriptor getDescriptor()
|
||||
{
|
||||
return avmRef;
|
||||
}
|
||||
|
||||
public int getVersion()
|
||||
{
|
||||
return this.version;
|
||||
|
@@ -16,11 +16,31 @@
|
||||
*/
|
||||
package org.alfresco.web.bean.wcm;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.text.MessageFormat;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Date;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import javax.faces.context.FacesContext;
|
||||
import javax.faces.event.ActionEvent;
|
||||
import javax.transaction.UserTransaction;
|
||||
|
||||
import org.alfresco.repo.avm.AVMNodeConverter;
|
||||
import org.alfresco.repo.avm.actions.AVMRevertToVersionAction;
|
||||
import org.alfresco.service.cmr.action.Action;
|
||||
import org.alfresco.service.cmr.action.ActionService;
|
||||
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
||||
import org.alfresco.util.Pair;
|
||||
import org.alfresco.web.app.Application;
|
||||
import org.alfresco.web.app.servlet.DownloadContentServlet;
|
||||
import org.alfresco.web.bean.repository.Node;
|
||||
import org.alfresco.web.bean.repository.Repository;
|
||||
import org.alfresco.web.ui.common.Utils;
|
||||
import org.alfresco.web.ui.common.component.UIActionLink;
|
||||
import org.alfresco.web.ui.common.component.data.UIRichList;
|
||||
|
||||
/**
|
||||
* Backing bean for File Details page.
|
||||
@@ -29,6 +49,36 @@ import org.alfresco.web.ui.common.Utils;
|
||||
*/
|
||||
public class FileDetailsBean extends AVMDetailsBean
|
||||
{
|
||||
/** Action service bean reference */
|
||||
private ActionService actionService;
|
||||
|
||||
|
||||
// ------------------------------------------------------------------------------
|
||||
// Construction
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
public FileDetailsBean()
|
||||
{
|
||||
super();
|
||||
|
||||
// initial state of some panels that don't use the default
|
||||
panels.put("version-history-panel", false);
|
||||
}
|
||||
|
||||
|
||||
// ------------------------------------------------------------------------------
|
||||
// Bean getters and setters
|
||||
|
||||
/**
|
||||
* @param actionService The actionService to set.
|
||||
*/
|
||||
public void setActionService(ActionService actionService)
|
||||
{
|
||||
this.actionService = actionService;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.alfresco.web.bean.wcm.AVMDetailsBean#getAvmNode()
|
||||
*/
|
||||
@@ -92,4 +142,81 @@ public class FileDetailsBean extends AVMDetailsBean
|
||||
{
|
||||
return (List)this.avmBrowseBean.getFiles();
|
||||
}
|
||||
|
||||
/**
|
||||
* @return version history list for a node
|
||||
*/
|
||||
public List<Map<String, Object>> getVersionHistory()
|
||||
{
|
||||
AVMNode avmNode = getAvmNode();
|
||||
List<AVMNodeDescriptor> history = this.avmService.getHistory(avmNode.getDescriptor(), -1);
|
||||
List<Map<String, Object>> wrappers = new ArrayList<Map<String, Object>>(history.size());
|
||||
for (AVMNodeDescriptor record : history)
|
||||
{
|
||||
Map<String, Object> wrapper = new HashMap<String, Object>(4, 1.0f);
|
||||
wrapper.put("version", record.getVersionID());
|
||||
wrapper.put("strVersion", Integer.toString(record.getVersionID()));
|
||||
wrapper.put("modifiedDate", new Date(record.getModDate()));
|
||||
List<Pair<Integer, String>> paths = this.avmService.getPaths(record);
|
||||
if (paths.size() != 0)
|
||||
{
|
||||
// display the first path as any will show the same content
|
||||
Pair<Integer, String> path = paths.get(0);
|
||||
wrapper.put("url", DownloadContentServlet.generateBrowserURL(
|
||||
AVMNodeConverter.ToNodeRef(path.getFirst(), path.getSecond()), avmNode.getName()));
|
||||
}
|
||||
wrappers.add(wrapper);
|
||||
}
|
||||
return wrappers;
|
||||
}
|
||||
|
||||
/**
|
||||
* Revert a node back to a previous version
|
||||
*/
|
||||
public void revertNode(ActionEvent event)
|
||||
{
|
||||
UIActionLink link = (UIActionLink)event.getComponent();
|
||||
Map<String, String> params = link.getParameterMap();
|
||||
int version = Integer.parseInt(params.get("version"));
|
||||
|
||||
UserTransaction tx = null;
|
||||
try
|
||||
{
|
||||
FacesContext context = FacesContext.getCurrentInstance();
|
||||
tx = Repository.getUserTransaction(context, false);
|
||||
tx.begin();
|
||||
|
||||
Map<String, Serializable> args = new HashMap<String, Serializable>(1, 1.0f);
|
||||
List<AVMNodeDescriptor> history = this.avmService.getHistory(getAvmNode().getDescriptor(), -1);
|
||||
// the history list should contain the version ID we are looking for
|
||||
for (AVMNodeDescriptor record : history)
|
||||
{
|
||||
if (record.getVersionID() == version)
|
||||
{
|
||||
// the action expects the HEAD revision as the noderef and
|
||||
// the to-revert param as the previous version to revert to
|
||||
Action action = this.actionService.createAction(AVMRevertToVersionAction.NAME, args);
|
||||
args.put(AVMRevertToVersionAction.TOREVERT, record);
|
||||
this.actionService.executeAction(action, getAvmNode().getNodeRef());
|
||||
|
||||
// clear the version history list after a revert ready for refresh
|
||||
UIRichList versionList = (UIRichList)link.findComponent("version-history-list");
|
||||
versionList.setValue(null);
|
||||
|
||||
// reset the action node reference as the version ID has changed
|
||||
avmBrowseBean.setAvmActionNode(new AVMNode(avmService.lookup(-1, getAvmNode().getPath())));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
tx.commit();
|
||||
}
|
||||
catch (Throwable err)
|
||||
{
|
||||
err.printStackTrace(System.err);
|
||||
Utils.addErrorMessage(MessageFormat.format(Application.getMessage(
|
||||
FacesContext.getCurrentInstance(), Repository.ERROR_GENERIC), err.getMessage()), err);
|
||||
try { if (tx != null) {tx.rollback();} } catch (Exception tex) {}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -324,9 +324,11 @@ public class UIUserSandboxes extends SelfRenderingComponent
|
||||
out.write("<table cellspacing=2 cellpadding=2 border=0 width=100%><tr><td>");
|
||||
// show the icon for the sandbox as a clickable browse link image
|
||||
// this is currently identical to the sandbox_browse action as below
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
UIActionLink browseAction = aquireAction(
|
||||
context, mainStore, username, ACT_SANDBOX_ICON, WebResources.IMAGE_USERSANDBOX_32,
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "browseSandbox"));
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "browseSandbox");
|
||||
browseAction.setShowLink(false);
|
||||
Utils.encodeRecursive(context, browseAction);
|
||||
out.write("</td><td width=100%>");
|
||||
out.write("<b>");
|
||||
out.write(bundle.getString(MSG_USERNAME));
|
||||
@@ -337,6 +339,11 @@ public class UIUserSandboxes extends SelfRenderingComponent
|
||||
out.write(")</td><td><nobr>");
|
||||
|
||||
// direct actions for a sandbox
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
context, mainStore, username, ACT_SANDBOX_BROWSE, "/images/icons/space_small.gif",
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "browseSandbox"));
|
||||
out.write(" ");
|
||||
|
||||
String websiteUrl = AVMConstants.buildWebappUrl(mainStore, getWebapp());
|
||||
Map requestMap = context.getExternalContext().getRequestMap();
|
||||
requestMap.put(REQUEST_PREVIEW_REF, websiteUrl);
|
||||
@@ -349,24 +356,20 @@ public class UIUserSandboxes extends SelfRenderingComponent
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
context, mainStore, username, ACT_SANDBOX_SUBMITALL, "/images/icons/submit_all.gif",
|
||||
"#{AVMBrowseBean.setupAllItemsAction}", "dialog:submitSandboxItems"));
|
||||
out.write(" ");
|
||||
out.write(" ");
|
||||
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
context, mainStore, username, ACT_SANDBOX_REVERTALL, "/images/icons/revert_all.gif",
|
||||
"#{AVMBrowseBean.setupAllItemsAction}", "dialog:revertAllItems"));
|
||||
out.write(" ");
|
||||
out.write(" ");
|
||||
|
||||
if (isManager)
|
||||
{
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
context, mainStore, username, ACT_REMOVE_SANDBOX, "/images/icons/delete_sandbox.gif",
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "dialog:deleteSandbox"));
|
||||
out.write(" ");
|
||||
}
|
||||
|
||||
Utils.encodeRecursive(context, aquireAction(
|
||||
context, mainStore, username, ACT_SANDBOX_BROWSE, "/images/icons/space_small.gif",
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "browseSandbox"));
|
||||
out.write("</nobr></td></tr>");
|
||||
|
||||
// modified items panel
|
||||
@@ -674,11 +677,11 @@ public class UIUserSandboxes extends SelfRenderingComponent
|
||||
// output multi-select actions for this user
|
||||
out.write("<tr><td colspan=8>");
|
||||
out.write(bundle.getString(MSG_SELECTED));
|
||||
out.write(": ");
|
||||
out.write(": ");
|
||||
Utils.encodeRecursive(fc, aquireAction(
|
||||
fc, userStore, username, ACT_SANDBOX_SUBMITSELECTED, "/images/icons/submit_all.gif",
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "dialog:submitSandboxItems"));
|
||||
out.write(" ");
|
||||
out.write(" ");
|
||||
Utils.encodeRecursive(fc, aquireAction(
|
||||
fc, userStore, username, ACT_SANDBOX_REVERTSELECTED, "/images/icons/revert_all.gif",
|
||||
"#{AVMBrowseBean.setupSandboxAction}", "dialog:revertSelectedItems"));
|
||||
@@ -925,7 +928,7 @@ public class UIUserSandboxes extends SelfRenderingComponent
|
||||
control.setRendererType(UIActions.RENDERER_ACTIONLINK);
|
||||
control.setId(id);
|
||||
control.setValue(Application.getMessage(fc, name));
|
||||
control.setShowLink(icon != null ? false : true);
|
||||
//control.setShowLink(icon != null ? false : true);
|
||||
control.setImage(icon);
|
||||
|
||||
if (actionListener != null)
|
||||
|
Reference in New Issue
Block a user