/* * 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.wcm; import java.io.BufferedInputStream; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileInputStream; import java.io.Serializable; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; 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.config.Config; import org.alfresco.config.ConfigElement; import org.alfresco.config.ConfigService; import org.alfresco.model.ContentModel; import org.alfresco.model.WCMModel; import org.alfresco.repo.avm.AVMNodeConverter; import org.alfresco.repo.content.MimetypeMap; import org.alfresco.service.cmr.avm.AVMService; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.namespace.QName; import org.alfresco.web.app.Application; import org.alfresco.web.bean.content.BaseContentWizard; import org.alfresco.web.data.IDataContainer; import org.alfresco.web.data.QuickSort; import org.alfresco.web.forms.*; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.w3c.dom.Document; /** * Bean implementation for the "Create Web Content Wizard" dialog */ public class CreateWebContentWizard extends BaseContentWizard { private static final Log logger = LogFactory.getLog(CreateWebContentWizard.class); protected String content = null; protected String formName; protected List createMimeTypes; protected String createdPath = null; protected List renditions = null; protected FormInstanceData formInstanceData = null; /** AVM service bean reference */ protected AVMService avmService; /** AVM Browse Bean reference */ protected AVMBrowseBean avmBrowseBean; /** * @param avmService The AVMService to set. */ public void setAvmService(AVMService avmService) { this.avmService = avmService; } /** * @param avmBrowseBean The AVMBrowseBean to set. */ public void setAvmBrowseBean(AVMBrowseBean avmBrowseBean) { this.avmBrowseBean = avmBrowseBean; } // ------------------------------------------------------------------------------ // Wizard implementation @Override protected String finishImpl(FacesContext context, String outcome) throws Exception { // return the default outcome return outcome; } // ------------------------------------------------------------------------------ // Helper methods /** * Save the specified content using the currently set wizard attributes * * @param fileContent File content to save * @param strContent String content to save */ protected void saveContent(File fileContent, String strContent) throws Exception { if (logger.isDebugEnabled()) logger.debug("saving file content to " + this.fileName); // get the parent path of the location to save the content String path = this.avmBrowseBean.getCurrentPath(); if (MimetypeMap.MIMETYPE_XML.equals(this.mimeType) && this.formName != null) { final FormsService fs = FormsService.getInstance(); final Document formInstanceData = (fileContent != null ? fs.parseXML(fileContent) : fs.parseXML(strContent)); path = this.getForm().getOutputPathForFormInstanceData(path, this.fileName, formInstanceData); final String[] sb = AVMNodeConverter.SplitBase(path); path = sb[0]; this.fileName = sb[1]; fs.makeAllDirectories(path); } if (logger.isDebugEnabled()) logger.debug("creating file " + this.fileName + " in " + path); // put the content of the file into the AVM store if (fileContent != null) { avmService.createFile(path, this.fileName, new BufferedInputStream(new FileInputStream(fileContent))); } else { avmService.createFile(path, this.fileName, new ByteArrayInputStream((strContent == null ? "" : strContent).getBytes())); } // remember the created path this.createdPath = path + '/' + this.fileName; // add titled aspect for the read/edit properties screens final NodeRef formInstanceDataNodeRef = AVMNodeConverter.ToNodeRef(-1, this.createdPath); Map titledProps = new HashMap(1, 1.0f); titledProps.put(ContentModel.PROP_TITLE, this.fileName); this.nodeService.addAspect(formInstanceDataNodeRef, ContentModel.ASPECT_TITLED, titledProps); this.formInstanceData = new FormInstanceDataImpl(formInstanceDataNodeRef); if (MimetypeMap.MIMETYPE_XML.equals(this.mimeType) && this.formName != null) { final Form form = this.getForm(); form.registerFormInstanceData(formInstanceDataNodeRef); this.renditions = FormsService.getInstance().generateRenditions(formInstanceDataNodeRef); } } @Override public void init(Map parameters) { super.init(parameters); this.content = null; this.inlineEdit = true; this.formName = null; this.mimeType = MimetypeMap.MIMETYPE_XML; } @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; } // ------------------------------------------------------------------------------ // 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 the available forms that can be created. */ public List getFormChoices() { final Collection
ttl = FormsService.getInstance().getForms(); final List sil = new ArrayList(ttl.size()); for (Form tt : ttl) { sil.add(new SelectItem(tt.getName(), tt.getName())); } final QuickSort sorter = new QuickSort(sil, "label", true, IDataContainer.SORT_CASEINSENSITIVE); sorter.sort(); return sil; } /** * @return Returns a list of mime types to allow the user to select from */ public List getCreateMimeTypes() { if (this.createMimeTypes == null) { 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; } public String getFormName() { return this.formName; } public Form getForm() { final FormsService ts = FormsService.getInstance(); return ts.getForm(this.getFormName()); } /** * @param form Sets the currently selected form */ public void setFormName(final String formName) { this.formName = formName; } /** * @return Returns the wrapper instance data for feeding the xml * content to the form processor. */ public FormProcessor.InstanceData getInstanceData() { return new FormProcessor.InstanceData() { private final FormsService ts = FormsService.getInstance(); public Document getContent() { try { final String content = CreateWebContentWizard.this.getContent(); return content != null ? this.ts.parseXML(content) : null; } catch (Exception e) { e.printStackTrace(); return null; } } public void setContent(final Document d) { CreateWebContentWizard.this.setContent(ts.writeXMLToString(d)); } }; } public FormInstanceData getFormInstanceData() throws Exception { if (this.formInstanceData == null) { this.saveContent(null, this.content); } return this.formInstanceData; } public List getRenditions() { return this.renditions; } /** * @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("content_type"), bundle.getString("Location")}, new String[] {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; } }