001/*
002 * (C) Copyright 2011 Nuxeo SA (http://nuxeo.com/) and others.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 *
016 * Contributors:
017 *     Anahide Tchertchian
018 */
019package org.nuxeo.ecm.automation.jsf.operations;
020
021import org.nuxeo.ecm.automation.OperationContext;
022import org.nuxeo.ecm.automation.core.Constants;
023import org.nuxeo.ecm.automation.core.annotations.Context;
024import org.nuxeo.ecm.automation.core.annotations.Operation;
025import org.nuxeo.ecm.automation.core.annotations.OperationMethod;
026import org.nuxeo.ecm.automation.jsf.OperationHelper;
027import org.nuxeo.ecm.core.api.DocumentModel;
028
029/**
030 * Creates a document (equivalent to clicking on the 'create' button on a document creation form).
031 *
032 * @since 5.4.2
033 */
034@Operation(id = CreateDocumentInUI.ID, category = Constants.CAT_UI, requires = Constants.SEAM_CONTEXT, label = "Create Document in UI", description = "Creates a document in UI, "
035        + "as if user was hitting the 'Create' button on a the document creation form. "
036        + "It assumes that the contextual 'changeableDocument' document from the Seam context has been updated "
037        + "to hold properties defined for creation. It will navigate to the newly created document context, "
038        + "set its view as outcome, and return the newly created document.")
039public class CreateDocumentInUI {
040
041    public static final String ID = "Seam.CreateDocumentInUI";
042
043    @Context
044    protected OperationContext ctx;
045
046    @OperationMethod
047    public DocumentModel run() {
048        ctx.put(SeamOperation.OUTCOME, OperationHelper.getDocumentActions().saveDocument());
049        return OperationHelper.getNavigationContext().getCurrentDocument();
050    }
051
052}