/* * 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.clipboard; import java.util.ArrayList; import java.util.List; import java.util.Map; import javax.faces.context.FacesContext; import javax.faces.event.ActionEvent; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.StoreRef; import org.alfresco.web.app.Application; import org.alfresco.web.app.context.UIContextService; import org.alfresco.web.ui.common.Utils; import org.alfresco.web.ui.common.component.UIActionLink; import org.alfresco.web.ui.repo.component.shelf.UIClipboardShelfItem; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * Bean backing the Clipboard shelf functionality. *

* The clipboard bean is responsible for processing Cut/Copy requests to the clipboard * and for executing the various Paste calls available to the user. * * @author Kevin Roast */ public class ClipboardBean { private static Log logger = LogFactory.getLog(ClipboardBean.class); /** I18N messages */ private static final String MSG_ERROR_PASTE = "error_paste"; /** Current state of the clipboard items */ private List items = new ArrayList(4); // ------------------------------------------------------------------------------ // Bean property getters and setters /** * @return Returns a list representing the items on the user clipboard. */ public List getItems() { return this.items; } /** * @param items List representing the items on the user clipboard. */ public void setItems(List items) { this.items = items; } // ------------------------------------------------------------------------------ // Navigation action event handlers /** * Action handler called to add a node to the clipboard for a Copy operation */ public void copyNode(ActionEvent event) { UIActionLink link = (UIActionLink)event.getComponent(); Map params = link.getParameterMap(); String ref = params.get("ref"); if (ref != null && ref.length() != 0) { addClipboardNode(new NodeRef(ref), ClipboardStatus.COPY); } } /** * Action handler called to add a node to the clipboard for a Cut operation */ public void cutNode(ActionEvent event) { UIActionLink link = (UIActionLink)event.getComponent(); Map params = link.getParameterMap(); String ref = params.get("ref"); if (ref != null && ref.length() != 0) { addClipboardNode(new NodeRef(ref), ClipboardStatus.CUT); } } /** * Action handler call from the browse screen to Paste All clipboard items into the current Space */ public void pasteAll(ActionEvent event) { performPasteItems(-1, UIClipboardShelfItem.ACTION_PASTE_ALL); } /** * Action handler called to paste one or all items from the clipboard */ public void pasteItem(ActionEvent event) { UIClipboardShelfItem.ClipboardEvent clipEvent = (UIClipboardShelfItem.ClipboardEvent)event; int index = clipEvent.Index; if (index >= this.items.size()) { throw new IllegalStateException("Clipboard attempting paste a non existent item index: " + index); } performPasteItems(index, clipEvent.Action); } /** * Perform a paste for the specified clipboard item(s) * * @param index of clipboard item to paste or -1 for all * @param action the clipboard action to perform (see UIClipboardShelfItem) */ private void performPasteItems(int index, int action) { try { if (index == -1) { // paste all for (int i=0; i