/* * Copyright (C) 2005 Alfresco, Inc. * * Licensed under the Mozilla Public License version 1.1 * with a permitted attribution clause. You may obtain a * copy of the License at * * http://www.alfresco.org/legal/license.txt * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, * either express or implied. See the License for the specific * language governing permissions and limitations under the * License. */ package org.alfresco.web.bean; import java.io.Serializable; import java.text.MessageFormat; import java.util.Collection; 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.model.ContentModel; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.TemplateNode; import org.alfresco.service.cmr.security.PermissionService; import org.alfresco.service.namespace.QName; import org.alfresco.web.app.AlfrescoNavigationHandler; import org.alfresco.web.app.Application; 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; /** * Backing bean provided access to the details of a Space * * @author Kevin Roast */ public class SpaceDetailsBean extends BaseDetailsBean { private static final String OUTCOME_RETURN = "showSpaceDetails"; private static final String MSG_HAS_FOLLOWING_CATEGORIES = "has_following_categories_space"; private static final String MSG_NO_CATEGORIES_APPLIED = "no_categories_applied_space"; private static final String MSG_ERROR_UPDATE_CATEGORY = "error_update_category"; private static final String MSG_ERROR_ASPECT_CLASSIFY = "error_aspect_classify_space"; /** PermissionService bean reference */ protected PermissionService permissionService; /** Category details */ private NodeRef addedCategory; private List categories; // ------------------------------------------------------------------------------ // Construction /** * Default constructor */ public SpaceDetailsBean() { // initial state of some panels that don't use the default panels.put("rules-panel", false); } // ------------------------------------------------------------------------------ // Bean property getters and setters /** * @param permissionService The PermissionService to set. */ public void setPermissionService(PermissionService permissionService) { this.permissionService = permissionService; } /** * Returns the Node this bean is currently representing * * @return The Node */ public Node getNode() { return this.browseBean.getActionSpace(); } /** * Returns the Space this bean is currently representing * * @return The Space Node */ public Node getSpace() { return getNode(); } /** * Resolve the actual document Node from any Link object that may be proxying it * * @return current document Node or document Node resolved from any Link object */ protected Node getLinkResolvedNode() { Node space = getSpace(); if (ContentModel.TYPE_FOLDERLINK.equals(space.getType())) { NodeRef destRef = (NodeRef)space.getProperties().get(ContentModel.PROP_LINK_DESTINATION); if (nodeService.exists(destRef)) { space = new Node(destRef); } } return space; } /** * Returns a model for use by a template on the Space Details page. * * @return model containing current current space info. */ @SuppressWarnings("unchecked") public Map getTemplateModel() { HashMap model = new HashMap(1, 1.0f); FacesContext fc = FacesContext.getCurrentInstance(); TemplateNode spaceNode = new TemplateNode(getSpace().getNodeRef(), Repository.getServiceRegistry(fc), imageResolver); model.put("space", spaceNode); return model; } /** * @see org.alfresco.web.bean.BaseDetailsBean#getPropertiesPanelId() */ protected String getPropertiesPanelId() { return "space-props"; } /** * @see org.alfresco.web.bean.BaseDetailsBean#getReturnOutcome() */ protected String getReturnOutcome() { return OUTCOME_RETURN; } // ------------------------------------------------------------------------------ // Action event handlers /** * Navigates to next item in the list of Spaces */ public void nextItem(ActionEvent event) { boolean foundNextItem = false; UIActionLink link = (UIActionLink)event.getComponent(); Map params = link.getParameterMap(); String id = params.get("id"); if (id != null && id.length() != 0) { List nodes = this.browseBean.getNodes(); if (nodes.size() > 1) { // perform a linear search - this is slow but stateless // otherwise we would have to manage state of last selected node // this gets very tricky as this bean is instantiated once and never // reset - it does not know when the document has changed etc. for (int i=0; i params = link.getParameterMap(); String id = params.get("id"); if (id != null && id.length() != 0) { List nodes = this.browseBean.getNodes(); if (nodes.size() > 1) { // see above for (int i=0; i"); for (Object obj : categories) { if (obj instanceof NodeRef) { if (this.nodeService.exists((NodeRef)obj)) { builder.append("
  • "); builder.append(Repository.getNameForNode(this.nodeService, (NodeRef)obj)); builder.append("
  • "); } } } builder.append(""); html = builder.toString(); } } return html; } /** * Event handler called to setup the categories for editing * * @param event The event */ public void setupCategoriesForEdit(ActionEvent event) { this.categories = (List)this.nodeService.getProperty(getSpace().getNodeRef(), ContentModel.PROP_CATEGORIES); } /** * Returns a Map of the initial categories on the node keyed by the NodeRef * * @return Map of initial categories */ public List getCategories() { return this.categories; } /** * Sets the categories Map * * @param categories */ public void setCategories(List categories) { this.categories = categories; } /** * Returns the last category added from the multi value editor * * @return The last category added */ public NodeRef getAddedCategory() { return this.addedCategory; } /** * Sets the category added from the multi value editor * * @param addedCategory The added category */ public void setAddedCategory(NodeRef addedCategory) { this.addedCategory = addedCategory; } /** * Updates the categories for the current document * * @return The outcome */ public String saveCategories() { String outcome = "cancel"; UserTransaction tx = null; try { tx = Repository.getUserTransaction(FacesContext.getCurrentInstance()); tx.begin(); // firstly retrieve all the properties for the current node Map updateProps = this.nodeService.getProperties( getSpace().getNodeRef()); // create a node ref representation of the selected id and set the new properties updateProps.put(ContentModel.PROP_CATEGORIES, (Serializable)this.categories); // set the properties on the node this.nodeService.setProperties(getSpace().getNodeRef(), updateProps); // commit the transaction tx.commit(); // reset the state of the current document so it reflects the changes just made getSpace().reset(); outcome = "finish"; } catch (Throwable e) { try { if (tx != null) {tx.rollback();} } catch (Exception ex) {} Utils.addErrorMessage(MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), MSG_ERROR_UPDATE_CATEGORY), e.getMessage()), e); } return outcome; } /** * Applies the classifiable aspect to the current document */ public void applyClassifiable() { UserTransaction tx = null; try { tx = Repository.getUserTransaction(FacesContext.getCurrentInstance()); tx.begin(); // add the general classifiable aspect to the node this.nodeService.addAspect(getSpace().getNodeRef(), ContentModel.ASPECT_GEN_CLASSIFIABLE, null); // commit the transaction tx.commit(); // reset the state of the current document getSpace().reset(); } catch (Throwable e) { // rollback the transaction try { if (tx != null) {tx.rollback();} } catch (Exception ex) {} Utils.addErrorMessage(MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), MSG_ERROR_ASPECT_CLASSIFY), e.getMessage()), e); } } /** * Returns whether the current sapce is locked * * @return true if the document is checked out */ public boolean isLocked() { return getSpace().isLocked(); } }