/* * 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.Iterator; 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.dictionary.DataTypeDefinition; import org.alfresco.service.cmr.dictionary.DictionaryService; import org.alfresco.service.cmr.dictionary.PropertyDefinition; import org.alfresco.service.cmr.repository.InvalidNodeRefException; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.NodeService; import org.alfresco.service.namespace.QName; 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.Utils.URLMode; /** * Backing bean for the edit link properties dialog * * @author kevinr */ public class LinkPropertiesBean { protected NodeService nodeService; protected DictionaryService dictionaryService; protected BrowseBean browseBean; protected NavigationBean navigator; private Node editableNode; /** * Returns the node being edited * * @return The node being edited */ public Node getEditableNode() { return this.editableNode; } /** * Event handler called to setup the link object for property editing * * @param event The event */ public void setupFileLinkForAction(ActionEvent event) { this.editableNode = new Node(this.browseBean.getDocument().getNodeRef()); } /** * Event handler called to setup the link object for property editing * * @param event The event */ public void setupFolderLinkForAction(ActionEvent event) { this.editableNode = new Node(this.browseBean.getActionSpace().getNodeRef()); } /** * @return Human readable version of the Path to the destination object */ public String getDestinationPath() { NodeRef destRef = (NodeRef)this.editableNode.getProperties().get(ContentModel.PROP_LINK_DESTINATION); return Repository.getNamePath( this.nodeService, this.nodeService.getPath(destRef), null, "/", null); } /** * Returns the URL to access the details page for the current document link object * * @return The bookmark URL */ public String getFileLinkBookmarkUrl() { NodeRef destRef = (NodeRef)this.browseBean.getDocument().getProperties().get(ContentModel.PROP_LINK_DESTINATION); return Utils.generateURL(FacesContext.getCurrentInstance(), new Node(destRef), URLMode.SHOW_DETAILS); } /** * Returns the URL to access the details page for the current document link object * * @return The bookmark URL */ public String getSpaceLinkDestinationUrl() { NodeRef destRef = (NodeRef)this.browseBean.getActionSpace().getProperties().get(ContentModel.PROP_LINK_DESTINATION); return Utils.generateURL(FacesContext.getCurrentInstance(), new Node(destRef), URLMode.SHOW_DETAILS); } /** * Event handler used to save the edited properties back to the repository * * @return The outcome */ public String save() { String outcome = "cancelEdit"; // setup the dispatch context as it is required for correct cancel/finish back to link dialog this.navigator.setupDispatchContext(this.editableNode); UserTransaction tx = null; try { tx = Repository.getUserTransaction(FacesContext.getCurrentInstance()); tx.begin(); NodeRef nodeRef = this.editableNode.getNodeRef(); Map props = this.editableNode.getProperties(); // get the name and move the node as necessary String name = (String)props.get(ContentModel.PROP_NAME); //if (name != null) //{ // fileFolderService.rename(nodeRef, name); //} Map properties = this.nodeService.getProperties(nodeRef); // we need to put all the properties from the editable bag back into // the format expected by the repository // deal with adding the "titled" aspect if required String title = (String)props.get(ContentModel.PROP_TITLE); String description = (String)props.get(ContentModel.PROP_DESCRIPTION); if (title != null || description != null) { // add the aspect to be sure it's present nodeService.addAspect(nodeRef, ContentModel.ASPECT_TITLED, null); // other props will get added later in setProperties() } // add the remaining properties Iterator iterProps = props.keySet().iterator(); while (iterProps.hasNext()) { String propName = iterProps.next(); QName qname = QName.createQName(propName); // make sure the property is represented correctly Serializable propValue = (Serializable)props.get(propName); // check for empty strings when using number types, set to null in this case if ((propValue != null) && (propValue instanceof String) && (propValue.toString().length() == 0)) { PropertyDefinition propDef = this.dictionaryService.getProperty(qname); if (propDef != null) { if (propDef.getDataType().getName().equals(DataTypeDefinition.DOUBLE) || propDef.getDataType().getName().equals(DataTypeDefinition.FLOAT) || propDef.getDataType().getName().equals(DataTypeDefinition.INT) || propDef.getDataType().getName().equals(DataTypeDefinition.LONG)) { propValue = null; } } } properties.put(qname, propValue); } // send the properties back to the repository this.nodeService.setProperties(nodeRef, properties); // commit the transaction tx.commit(); // set the outcome to refresh outcome = "finishEdit"; // reset any document held by the browse bean as it's just been updated // if this is a space link then it doesn't matter anyway this.browseBean.getDocument().reset(); } catch (InvalidNodeRefException err) { // rollback the transaction try { if (tx != null) {tx.rollback();} } catch (Exception ex) {} Utils.addErrorMessage(MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), Repository.ERROR_NODEREF), new Object[] {this.browseBean.getDocument().getId()}) ); // this failure means the node no longer exists - we cannot show the doc properties screen outcome = "browse"; } catch (Throwable e) { // rollback the transaction try { if (tx != null) {tx.rollback();} } catch (Exception ex) {} Utils.addErrorMessage(MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), Repository.ERROR_GENERIC), e.getMessage()), e); } return outcome; } public String cancel() { // setup the dispatch context as it is required for correct cancel/finish back to link dialog this.navigator.setupDispatchContext(this.editableNode); return "cancelEdit"; } public Map getProperties() { return this.editableNode.getProperties(); } /** * @return Returns the nodeService. */ public NodeService getNodeService() { return this.nodeService; } /** * @param nodeService The nodeService to set. */ public void setNodeService(NodeService nodeService) { this.nodeService = nodeService; } /** * Sets the DictionaryService to use when persisting metadata * * @param dictionaryService The DictionaryService */ public void setDictionaryService(DictionaryService dictionaryService) { this.dictionaryService = dictionaryService; } /** * @return The BrowseBean */ public BrowseBean getBrowseBean() { return this.browseBean; } /** * @param browseBean The BrowseBean to set. */ public void setBrowseBean(BrowseBean browseBean) { this.browseBean = browseBean; } /** * @param navigator The NavigationBean to set. */ public void setNavigator(NavigationBean navigator) { this.navigator = navigator; } }