/* * Copyright 2011 John Ahlroos * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * 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 fi.jasoft.dragdroplayouts; import java.util.Map; import com.vaadin.event.Transferable; import com.vaadin.event.dd.DropHandler; import com.vaadin.event.dd.DropTarget; import com.vaadin.event.dd.TargetDetails; import com.vaadin.event.dd.TargetDetailsImpl; import com.vaadin.terminal.PaintException; import com.vaadin.terminal.PaintTarget; import com.vaadin.terminal.gwt.client.MouseEventDetails; import com.vaadin.terminal.gwt.client.ui.dd.VerticalDropLocation; import com.vaadin.ui.ClientWidget; import com.vaadin.ui.Component; import com.vaadin.ui.VerticalSplitPanel; import fi.jasoft.dragdroplayouts.client.ui.Constants; import fi.jasoft.dragdroplayouts.client.ui.LayoutDragMode; import fi.jasoft.dragdroplayouts.client.ui.VDDVerticalSplitPanel; import fi.jasoft.dragdroplayouts.client.ui.interfaces.VHasDragMode; import fi.jasoft.dragdroplayouts.client.ui.util.IframeCoverUtility; import fi.jasoft.dragdroplayouts.events.LayoutBoundTransferable; import fi.jasoft.dragdroplayouts.interfaces.DragFilter; import fi.jasoft.dragdroplayouts.interfaces.LayoutDragSource; import fi.jasoft.dragdroplayouts.interfaces.ShimSupport; @SuppressWarnings("serial") @ClientWidget(VDDVerticalSplitPanel.class) public class DDVerticalSplitPanel extends VerticalSplitPanel implements LayoutDragSource, DropTarget, ShimSupport { /** * The drop handler which handles dropped components in the layout. */ private DropHandler dropHandler; /** * Specifies if dragging components is allowed and if so how it should be * visualized */ private LayoutDragMode dragMode = LayoutDragMode.NONE; // Are the iframes shimmed private boolean iframeShims = true; /** * A filter for dragging components. */ private DragFilter dragFilter = DragFilter.ALL; /** * Contains the location and other information about the drop. */ public class VerticalSplitPanelTargetDetails extends TargetDetailsImpl { private Component over; protected VerticalSplitPanelTargetDetails( Map<String, Object> rawDropData) { super(rawDropData, DDVerticalSplitPanel.this); if (getDropLocation() == VerticalDropLocation.TOP) { over = getFirstComponent(); } else if (getDropLocation() == VerticalDropLocation.BOTTOM) { over = getSecondComponent(); } else { over = DDVerticalSplitPanel.this; } } /** * The component over which the drop was made. * * @return Null if the drop was not over a component, else the component */ public Component getOverComponent() { return over; } /** * Some details about the mouse event * * @return details about the actual event that caused the event details. * Practically mouse move or mouse up. */ public MouseEventDetails getMouseEvent() { return MouseEventDetails .deSerialize((String) getData(Constants.DROP_DETAIL_MOUSE_EVENT)); } /** * Get the horizontal position of the dropped component within the * underlying cell. * * @return The drop location */ public VerticalDropLocation getDropLocation() { return VerticalDropLocation.valueOf((String) getData(Constants.DROP_DETAIL_VERTICAL_DROP_LOCATION)); } } /* * (non-Javadoc) * * @see * com.vaadin.event.dd.DropTarget#translateDropTargetDetails(java.util.Map) */ public TargetDetails translateDropTargetDetails( Map<String, Object> clientVariables) { return new VerticalSplitPanelTargetDetails(clientVariables); } /** * Get the transferable created by a drag event. */ public Transferable getTransferable(Map<String, Object> rawVariables) { return new LayoutBoundTransferable(this, rawVariables); } /** * Returns the drop handler which handles drop events from dropping * components on the layout. Returns Null if dropping is disabled. */ public DropHandler getDropHandler() { return dropHandler; } /** * Sets the current handler which handles dropped components on the layout. * By setting a drop handler dropping components on the layout is enabled. * By setting the dropHandler to null dropping is disabled. * * @param dropHandler * The drop handler to handle drop events or null to disable * dropping */ public void setDropHandler(DropHandler dropHandler) { if(this.dropHandler != dropHandler){ this.dropHandler = dropHandler; requestRepaint(); } } /** * Returns the mode of which dragging is visualized. * * @return */ public LayoutDragMode getDragMode() { return dragMode; } /** * Enables dragging components from the layout. * * @param mode * The mode of which how the dragging should be visualized. */ public void setDragMode(LayoutDragMode mode) { if(dragMode != mode){ dragMode = mode; requestRepaint(); } } /* * (non-Javadoc) * * @see * com.vaadin.ui.AbstractOrderedLayout#translateDropTargetDetails(java.util * .Map) */ @Override public void paintContent(PaintTarget target) throws PaintException { super.paintContent(target); // Add drop handler if (dropHandler != null) { dropHandler.getAcceptCriterion().paint(target); } // Drag mode target.addAttribute(VHasDragMode.DRAGMODE_ATTRIBUTE, dragMode.ordinal()); // Shims target.addAttribute(IframeCoverUtility.SHIM_ATTRIBUTE, iframeShims); // Paint the dragfilter into the paint target new DragFilterPaintable(this).paint(target); } /** * {@inheritDoc} */ public void setShim(boolean shim) { if(iframeShims != shim){ iframeShims = shim; requestRepaint(); } } /** * {@inheritDoc} */ public boolean isShimmed() { return iframeShims; } /** * {@inheritDoc} */ public DragFilter getDragFilter() { return dragFilter; } /** * {@inheritDoc} */ public void setDragFilter(DragFilter dragFilter) { if(this.dragFilter != dragFilter){ this.dragFilter = dragFilter; requestRepaint(); } } }