/* * #%L * Alfresco Repository WAR Community * %% * Copyright (C) 2005 - 2016 Alfresco Software Limited * %% * This file is part of the Alfresco software. * If the software was purchased under a paid Alfresco license, the terms of * the paid license agreement will prevail. Otherwise, the software is * provided under the following open source license terms: * * Alfresco is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Alfresco is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Alfresco. If not, see . * #L% */ package org.alfresco.web.bean.content; import java.text.MessageFormat; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.ResourceBundle; import javax.faces.context.FacesContext; import javax.faces.event.ValueChangeEvent; import javax.faces.model.SelectItem; import org.alfresco.model.ContentModel; import org.alfresco.repo.content.MimetypeMap; import org.alfresco.service.cmr.model.FileExistsException; 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.data.IDataContainer; import org.alfresco.web.data.QuickSort; import org.alfresco.web.ui.common.Utils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.springframework.extensions.config.Config; import org.springframework.extensions.config.ConfigElement; import org.springframework.extensions.config.ConfigService; /** * Bean implementation for the "Create Content Wizard" dialog * * @author gavinc */ public class CreateContentWizard extends BaseContentWizard { private static final long serialVersionUID = -2740634368271194418L; protected String content = null; protected List createMimeTypes; private static Log logger = LogFactory.getLog(CreateContentWizard.class); // ------------------------------------------------------------------------------ // Wizard implementation @Override public String finish() { String result = super.finish(); return result; } @Override protected String finishImpl(FacesContext context, String outcome) throws Exception { saveContent(null, this.content); // return the default outcome return outcome; } @Override public void init(Map parameters) { super.init(parameters); this.content = null; this.inlineEdit = true; this.mimeType = MimetypeMap.MIMETYPE_HTML; } @Override public boolean getNextButtonDisabled() { // TODO: Allow the next button state to be configured so that // wizard implementations don't have to worry about // checking step numbers boolean disabled = false; int step = Application.getWizardManager().getCurrentStep(); switch(step) { case 1: { disabled = (this.fileName == null || this.fileName.length() == 0); break; } } return disabled; } @Override public boolean getFinishButtonDisabled() { boolean disabled = false; int step = Application.getWizardManager().getCurrentStep(); switch(step) { case 1: { disabled = (this.fileName == null || this.fileName.length() == 0); break; } } return disabled; } @Override protected String doPostCommitProcessing(FacesContext context, String outcome) { // as we were successful, go to the set properties dialog if asked // to otherwise just return if (this.showOtherProperties) { // check whether the created node is checked out, if a 'check out' // rule is present in the space the new node will be and an // attempt to modify the properties will cause an error (ALF-438) if (getNodeService().hasAspect(this.createdNode, ContentModel.ASPECT_LOCKABLE)) { Utils.addErrorMessage(Application.getMessage(FacesContext.getCurrentInstance(), MSG_NODE_LOCKED)); return outcome; } else { // we are going to immediately edit the properties so we need // to setup the BrowseBean context appropriately this.browseBean.setDocument(new Node(this.createdNode)); return getDefaultFinishOutcome() + AlfrescoNavigationHandler.OUTCOME_SEPARATOR + "dialog:setContentProperties"; } } else { return outcome; } } // ------------------------------------------------------------------------------ // Bean Getters and Setters /** * @return Returns the content from the edited form. */ public String getContent() { return this.content; } /** * @param content The content to edit (should be clear initially) */ public void setContent(String content) { this.content = content; } /** * @return Returns a list of mime types to allow the user to select from */ public List getCreateMimeTypes() { if ((this.createMimeTypes == null) || (Application.isDynamicConfig(FacesContext.getCurrentInstance()))) { FacesContext context = FacesContext.getCurrentInstance(); // add the well known object type to start with this.createMimeTypes = new ArrayList(5); // add the configured create mime types to the list ConfigService svc = Application.getConfigService(context); Config wizardCfg = svc.getConfig("Content Wizards"); if (wizardCfg != null) { ConfigElement typesCfg = wizardCfg.getConfigElement("create-mime-types"); if (typesCfg != null) { for (ConfigElement child : typesCfg.getChildren()) { String currentMimeType = child.getAttribute("name"); if (currentMimeType != null) { String label = getSummaryMimeType(currentMimeType); this.createMimeTypes.add(new SelectItem(currentMimeType, label)); } } // make sure the list is sorted by the label QuickSort sorter = new QuickSort(this.objectTypes, "label", true, IDataContainer.SORT_CASEINSENSITIVE); sorter.sort(); } else { logger.warn("Could not find 'create-mime-types' configuration element"); } } else { logger.warn("Could not find 'Content Wizards' configuration section"); } } return this.createMimeTypes; } /** * @return Returns the summary data for the wizard. */ public String getSummary() { ResourceBundle bundle = Application.getBundle(FacesContext.getCurrentInstance()); // TODO: show first few lines of content here? return buildSummary( new String[] {bundle.getString("file_name"), bundle.getString("type"), bundle.getString("content_type")}, new String[] {Utils.encode(this.fileName), getSummaryObjectType(), getSummaryMimeType(this.mimeType)}); } // ------------------------------------------------------------------------------ // Action event handlers /** * Create content type value changed by the user */ public void createContentChanged(ValueChangeEvent event) { // clear the content as HTML is not compatible with the plain text box etc. this.content = null; } @Override protected String formatErrorMessage(Throwable exception) { if (exception instanceof FileExistsException) { return MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), Repository.ERROR_EXISTS), ((FileExistsException)exception).getName()); } else { return MessageFormat.format(Application.getMessage( FacesContext.getCurrentInstance(), "error_content"), exception.getMessage()); } } }