All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.wicketstuff.jwicket.ui.dragdrop.DraggableBehavior Maven / Gradle / Ivy

Go to download

WicketJQuery by Stefan Lindner has been renamed to jWicket, mavenized, and migrated to WicketStuff. This Wicketstuff version supercedes the original version which was available at http://subversion.visionet.de/project/WicketJQuery/wiki

There is a newer version: 9.7.0
Show newest version
package org.wicketstuff.jwicket.ui.dragdrop;


import org.apache.wicket.Component;
import org.apache.wicket.ajax.AjaxRequestTarget;
import org.apache.wicket.request.Request;
import org.wicketstuff.jwicket.*;
import org.wicketstuff.jwicket.ui.AbstractJqueryUiEmbeddedBehavior;


/**
 * You can add an instance of this class to a Wicket {@link Component} to make it
 * draggable. An instance of this class can be added to one and only one
 * {@link Component}. Another {@link Component} that should have exactly the
 * same draggable behavior needs it's own instance.
 */
public class DraggableBehavior extends AbstractDragDropBehavior {

    private static final long serialVersionUID = 1L;
    public static final JQueryResourceReference jQueryUiDraggableJs
            = JQuery.isDebug()
            ? new JQueryResourceReference(DraggableBehavior.class, "jquery.ui.draggable.js")
            : new JQueryResourceReference(DraggableBehavior.class, "jquery.ui.draggable.min.js");

    private JsMap options = new JsMap();


    public DraggableBehavior() {
        super(AbstractJqueryUiEmbeddedBehavior.jQueryUiWidgetJs,
                AbstractJqueryUiEmbeddedBehavior.jQueryUiMouseJs,
                SpecialKeys.specialKeysJs,
                jQueryUiDraggableJs);
    }


    /**
     * handles the event processing during dragging.
     */
    @Override
    protected void respond(final AjaxRequestTarget target) {
        Component component = getComponent();
        Request request;

        if (component != null && (request = component.getRequest()) != null) {
            EventType dragEventType = EventType.stringToType(request.getRequestParameters().getParameterValue(EventType.IDENTIFIER).toString());

            if (component instanceof IDraggable) {
                IDraggable draggableComponent = (IDraggable) component;
                if (dragEventType == EventType.DRAG_START) {
                    draggableComponent.onDragStart(target, new SpecialKeys(request));
                } else if (dragEventType == EventType.DRAG_END) {
                    draggableComponent.onDragStop(target, new SpecialKeys(request));
                } else if (dragEventType == EventType.DRAG) {
                    draggableComponent.onDrag(target, new SpecialKeys(request));
                }
            }


            if (dragEventType == EventType.DRAG_START) {
                onDragStart(target, new SpecialKeys(request));
            } else if (dragEventType == EventType.DRAG_END) {
                onDragStop(target, new SpecialKeys(request));
            } else if (dragEventType == EventType.DRAG) {
                onDrag(target, new SpecialKeys(request));
            }
        }
    }


    private String name = null;

    /**
     * Sets the name of this draggable. The name can be used by a droppable
     * componen to distinguish between allowed and forbidden droppables.
     *
     * @param value the name
     * @return this object
     */
    public DraggableBehavior setName(final String value) {
        this.name = value;
        return this;
    }

    /**
     * Get the name of this draggable
     *
     * @return The draggable's name
     */
    public String getName() {
        return this.name;
    }


    /**
     * Sets the 'addClasses' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code true} or {@code false}.
     * @return this object
     */
    public DraggableBehavior setAddClasses(final boolean value) {
        if (value) {
            this.options.remove("addClasses");
        } else {
            this.options.put("addClasses", value);
        }
        return this;
    }

    public DraggableBehavior setAddClasses(final AjaxRequestTarget target, final boolean value) {
        setAddClasses(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','addClasses'," + value + ");");
        return this;
    }


    /**
     * Sets the 'axis' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code 'x'} or {@code 'y'}.
     * @return this object
     */
    public DraggableBehavior setAxis(final char value) {
        if (value != 'x' && value != 'y') {
            this.options.remove("axis");
        } else {
            this.options.put("axis", String.valueOf(value));
        }
        return this;
    }

    public DraggableBehavior setAxis(final AjaxRequestTarget target, final char value) {
        setAxis(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','axis','" + value + "');");
        return this;
    }


    /**
     * Sets the 'cursor' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value a {@link CssCursor}
     * @return this object
     */
    public DraggableBehavior setCursor(final CssCursor value) {
        if (value == null) {
            this.options.remove("cursor");
        } else {
            this.options.put("cursor", value.getName());
        }
        return this;
    }

    public DraggableBehavior setCursor(final AjaxRequestTarget target, final CssCursor value) {
        setCursor(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','cursor','" + value.getName() + "');");
        return this;
    }


    /**
     * Sets the 'cursorAt' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param position a {@link CssPosition}
     * @return this object
     */
    public DraggableBehavior setCursorAt(final CssPosition position, final int offset) {
        if (position == null) {
            this.options.remove("cursorAt");
        } else {
            this.options.put("cursorAt", new JsOption(position.getName(), offset));
        }
        return this;
    }

    public DraggableBehavior setCursorAt(final AjaxRequestTarget target, final CssPosition position, final int offset) {
        setCursorAt(position, offset);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','cursorAt',{" + position.getName() + ":" + offset + "});");
        return this;
    }


    /**
     * Sets the 'cursorAt' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param position1 a {@link CssPosition}
     * @param offset1   the offset from {@code position1}
     * @param position2 a {@link CssPosition}
     * @param offset2   the offset from {@code position2}
     * @return this object
     */
    public DraggableBehavior setCursorAt(final CssPosition position1, final int offset1, final CssPosition position2, final int offset2) {
        if (position1 == null || position2 == null) {
            this.options.remove("cursorAt");
        } else {
            this.options.put("cursorAt", new JsOption(position1.getName(), offset1), new JsOption(position2.getName(), offset2));
        }
        return this;
    }

    public DraggableBehavior setCursorAt(final AjaxRequestTarget target, final CssPosition position1, final int offset1, final CssPosition position2, final int offset2) {
        setCursorAt(position1, offset1, position2, offset2);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','cursorAt',{" + position1.getName() + ":" + offset1 + "," + position2.getName() + ":" + offset2 + "});");
        return this;
    }


    /**
     * Sets the 'delay' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the delay in ms
     * @return this object
     */
    public DraggableBehavior setDelay(final int value) {
        if (value <= 0) {
            this.options.remove("delay");
        } else {
            this.options.put("delay", value);
        }
        return this;
    }

    public DraggableBehavior setDelay(final AjaxRequestTarget target, final int value) {
        setDelay(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','delay'," + value + ");");
        return this;
    }


    /**
     * Sets the 'distance' property for this draggable. Please consult the
     * jquery documentation for a detailled description of this property.
     *
     * @param value the value of this property.
     * @return this object
     */
    public DraggableBehavior setDistance(final int value) {
        if (value <= 1) {
            this.options.remove("distance");
        } else {
            this.options.put("distance", value);
        }
        return this;
    }

    public DraggableBehavior setDistance(final AjaxRequestTarget target, final int value) {
        setDistance(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','distance'," + value + ");");
        return this;
    }


    /**
     * Sets the 'grid' property for this draggable. Please consult the
     * jquery documentation for a detailled description of this property.
     *
     * @param x the stepping along the x axis
     * @param y the stepping along the y axis
     * @return this object
     */
    public DraggableBehavior setGrid(final int x, final int y) {
        if (x <= 1 && y <= 1) {
            this.options.remove("grid");
        } else {
            this.options.put("grid", x, y);
        }
        return this;
    }

    public DraggableBehavior setGrid(final AjaxRequestTarget target, final int x, final int y) {
        setGrid(x, y);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','grid',[" + x + "," + y + "]);");
        return this;
    }


    /**
     * Sets the 'helper' property for this draggable. Please consult the
     * jquery documentation for a detailled description of this property.
     *
     * @param value {@code original} or {@code clone}
     * @return this object
     */
    public DraggableBehavior setDistance(final String value) {
        if (value == null) {
            this.options.remove("helper");
        } else {
            this.options.put("helper", value);
        }
        return this;
    }

    public DraggableBehavior setDistance(final AjaxRequestTarget target, final String value) {
        setDistance(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','helper','" + value + "');");
        return this;
    }


    /**
     * Sets the 'iframeFix' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code true} or {@code false}.
     * @return this object
     */
    public DraggableBehavior setIframeFix(final boolean value) {
        if (!value) {
            this.options.remove("iframeFix");
        } else {
            this.options.put("iframeFix", value);
        }
        return this;
    }

    public DraggableBehavior setIframeFix(final AjaxRequestTarget target, final boolean value) {
        setIframeFix(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','iframeFix'," + value + ");");
        return this;
    }


    /**
     * Sets the 'opacity' property for this draggable. Please consult the
     * jquery documentation for a detailled description of this property.
     *
     * @param value the opacity between 0 (transparent) and 1 (not transparent).
     * @return this object
     */
    public DraggableBehavior setOpacity(final double value) {
        if (value < 0) {
            this.options.remove("opacity");
        } else {
            this.options.put("opacity", value);
        }
        return this;
    }

    public DraggableBehavior setOpacity(final AjaxRequestTarget target, final double value) {
        setOpacity(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','opacity'," + value + ");");
        return this;
    }


    /**
     * Sets the 'refreshPositions' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code true} or {@code false}.
     * @return this object
     */
    public DraggableBehavior setRefreshPositions(final boolean value) {
        if (!value) {
            this.options.remove("refreshPositions");
        } else {
            this.options.put("refreshPositions", value);
        }
        return this;
    }

    public DraggableBehavior setRefreshPositions(final AjaxRequestTarget target, final boolean value) {
        setRefreshPositions(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','refreshPositions'," + value + ");");
        return this;
    }


    public static enum DragRevertMode {

        NEVER("false", false),
        ALWAYS("true", true),
        VALID("valid"),
        INVALID("invalid");

        private final String value;
        private final Boolean booleanValue;

        private DragRevertMode(final String value, final boolean booleanValue) {
            this.value = value;
            this.booleanValue = booleanValue;
        }

        private DragRevertMode(final String value) {
            this.value = value;
            this.booleanValue = null;
        }

        public String getValue() {
            return this.value;
        }

        public Boolean getBooleanValue() {
            return this.booleanValue;
        }

        public String toString() {
            return this.value;
        }
    }


    /**
     * Sets the 'revert' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the revert behavior
     * @return this object
     */
    public DraggableBehavior setRevert(final DragRevertMode value) {
        if (value == null) {
            this.options.remove("revert");
        } else {
            if (value.getBooleanValue() != null) {
                this.options.put("revert", value.getBooleanValue());
            } else {
                this.options.put("revert", value.getValue());
            }
        }
        return this;
    }

    public DraggableBehavior setRevert(final AjaxRequestTarget target, final DragRevertMode value) {
        setRevert(value);
        if (value.getBooleanValue() != null) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','revert'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','revert','" + value + "');");
        }
        return this;
    }


    /**
     * Sets the 'revertDuration' property for this draggable. Please consult the
     * jquery documentation for a detailled description of this property.
     *
     * @param value the duration of the revert animation
     * @return this object
     */
    public DraggableBehavior setRevertDuration(final int value) {
        if (value < 0) {
            this.options.remove("revertDuration");
        } else {
            this.options.put("revertDuration", value);
        }
        return this;
    }

    public DraggableBehavior setRevertDuration(final AjaxRequestTarget target, final int value) {
        setRevertDuration(value);
        if (value >= 0) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','revertDuration'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','revertDuration',0);");
        }
        return this;
    }


    /**
     * Sets the 'scroll' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code true} or {@code false}.
     * @return this object
     */
    public DraggableBehavior setScroll(final boolean value) {
        if (value) {
            this.options.remove("scroll");
        } else {
            this.options.put("scroll", value);
        }
        return this;
    }

    public DraggableBehavior setScroll(final AjaxRequestTarget target, final boolean value) {
        setScroll(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','scroll'," + value + ");");
        return this;
    }


    /**
     * Sets the 'scrollSensitivity' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the scroll sensitivity in px
     * @return this object
     */
    public DraggableBehavior setScrollSensitivity(final int value) {
        if (value == 20) {
            this.options.remove("scrollSensitivity");
        } else {
            this.options.put("scrollSensitivity", value);
        }
        return this;
    }

    public DraggableBehavior setScrollSensitivity(final AjaxRequestTarget target, final int value) {
        setScrollSensitivity(value);
        if (value > 0) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','scrollSensitivity'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','scrollSensitivity',0);");
        }
        return this;
    }


    /**
     * Sets the 'scrollSpeed' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the scroll speed in px
     * @return this object
     */
    public DraggableBehavior setScrollSpeed(final int value) {
        if (value == 20) {
            this.options.remove("scrollSpeed");
        } else {
            this.options.put("scrollSpeed", value);
        }
        return this;
    }

    public DraggableBehavior setScrollSpeed(final AjaxRequestTarget target, final int value) {
        setScrollSpeed(value);
        if (value > 0) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','scrollSpeed'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','scrollSpeed',0);");
        }
        return this;
    }


    /**
     * Sets the 'snap' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value {@code true} or {@code false}.
     * @return this object
     */
    public DraggableBehavior setSnap(final boolean value) {
        if (!value) {
            this.options.remove("snap");
        } else {
            this.options.put("snap", value);
        }
        return this;
    }

    public DraggableBehavior setSnap(final AjaxRequestTarget target, final boolean value) {
        setSnap(value);
        target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','snap'," + value + ");");
        return this;
    }

    public static enum DragHelperMode {

        ORIGINAL("original"),
        CLONE("clone");

        private final String value;

        private DragHelperMode(final String value) {
            this.value = value;
        }

        public String getValue() {
            return this.value;
        }

        public String toString() {
            return this.value;
        }
    }

    /**
     * Sets the 'helper' property for this draggable with a function. Please
     * consult the jQuery documentation for a detailed description of this property.
     * DraggableHelper can be used for values of "original" and "clone", or
     * a custom function can be used.
     *
     * @param function
     * @return this object
     */
    public DraggableBehavior setHelper(final String function) {
        if (function == null) {
            this.options.remove("helper");
        } else {
            this.options.put("helper", new JsFunction(function));
        }
        return this;
    }

    public DraggableBehavior setHelper(final AjaxRequestTarget target, final String function) {
        setHelper(function);
        if (function != null) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','helper'," + function + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','helper','original');");
        }
        return this;
    }

    /**
     * Sets the 'helper' property for this draggable to either "original"
     * or "clone". Please consult the jQuery documentation for a detailed
     * description of this property.
     *
     * @param value
     * @return this object
     */
    public DraggableBehavior setHelper(final DragHelperMode value) {
        if (value == null) {
            this.options.remove("helper");
        } else {
            this.options.put("helper", value.getValue());
        }
        return this;
    }

    public DraggableBehavior setHelper(final AjaxRequestTarget target, final DragHelperMode value) {
        setHelper(value);
        if (value != null) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','helper','" + value + "');");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','helper','original');");
        }
        return this;
    }

    public static enum DragSnapMode {

        INNER("inner"),
        OUTER("outer"),
        BOTH("both");

        private final String value;

        private DragSnapMode(final String value) {
            this.value = value;
        }

        public String getValue() {
            return this.value;
        }

        public String toString() {
            return this.value;
        }
    }

    /**
     * Sets the 'snapMode' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the revert behavior
     * @return this object
     */
    public DraggableBehavior setSnapMode(final DragSnapMode value) {
        if (value == null) {
            this.options.remove("snapMode");
        } else {
            this.options.put("snapMode", value.getValue());
        }
        return this;
    }

    public DraggableBehavior setSnapMode(final AjaxRequestTarget target, final DragSnapMode value) {
        setSnapMode(value);
        if (value != null) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','snapMode','" + value + "');");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','snapMode','both');");
        }
        return this;
    }


    /**
     * Sets the 'snapTolerance' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the scroll speed in px
     * @return this object
     */
    public DraggableBehavior setSnapTolerance(final int value) {
        if (value == 20) {
            this.options.remove("snapTolerance");
        } else {
            this.options.put("snapTolerance", value);
        }
        return this;
    }

    public DraggableBehavior setSnapTolerance(final AjaxRequestTarget target, final int value) {
        setSnapTolerance(value);
        if (value != 20) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','snapTolerance'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','snapTolerance',0);");
        }
        return this;
    }


    /**
     * Sets the 'zIndex' property for this draggable. Please consult the
     * jQuery documentation for a detailled description of this property.
     *
     * @param value the scroll speed in px
     * @return this object
     */
    public DraggableBehavior setZIndex(final long value) {
        if (value <= 0) {
            this.options.remove("zIndex");
        } else {
            this.options.put("zIndex", value);
        }
        return this;
    }

    public DraggableBehavior setZIndex(final AjaxRequestTarget target, final int value) {
        setZIndex(value);
        if (value > 0) {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','zIndex'," + value + ");");
        } else {
            target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('option','zIndex',false);");
        }
        return this;
    }


    private boolean onDragStopNotificationWanted = false;

    /**
     * If set to {@code true}, the callback-Method {@link #onDragStop(AjaxRequestTarget, SpecialKeys)}
     * is called when the drag operation ends.
     * 

* Be careful when using this in conjunction with {@link DroppableBehavior#onDrop(AjaxRequestTarget, Component, SpecialKeys)}. * The Ajax calls issued by jQuery are processed asynchronous. So it my happen that the * onDrop event reaches Wicket before the onDragStop event. This will cause * an Exception in Wicket's internal processing if you replaced the dragged component with a new one * in your onDrop handler becaus the dragged component no longer exists in wickets store when * the onDragStop event is processed by Wicket. * * @param value {@code true} or {@code false}. * @return this object */ public DraggableBehavior setWantOnDragStopNotification(final boolean value) { this.onDragStopNotificationWanted = value; return this; } private boolean onDragNotificationWanted = false; /** * If set to {@code true}, the callback-Method {@link #onDrag(AjaxRequestTarget, SpecialKeys)} * is called every time the mouse moves during the drag operation. * Be careful using this callback because it can generate a lot of Ajax calls. *

* See {@link #setWantOnDragStartNotification(boolean) for a serious warning! * * @param value {@code true} or {@code false}. * @return this object */ public DraggableBehavior setWantOnDragNotification(final boolean value) { this.onDragNotificationWanted = value; return this; } private boolean onDragStartNotificationWanted = false; /** * If set to {@code true}, the callback-Method {@link #onDragStart(AjaxRequestTarget, SpecialKeys)} * is called when the drag operation starts. * * @param value {@code true} or {@code false}. * @return this object */ public DraggableBehavior setWantOnDragStartNotification(final boolean value) { this.onDragStartNotificationWanted = value; return this; } /** * If you have set {@link #setWantOnDragStartNotification(boolean)} to {@code true} * this method is called when the drag operation starts. You can override this * method to perform some action when dragging starts. * * @param target the AjaxRequestTarget of the drag operation. * @param specialKeys the special keys that were pressed when the event occurs */ protected void onDragStart(final AjaxRequestTarget target, final SpecialKeys specialKeys) { } /** * If you have set {@link #setWantOnDragNotification(boolean)} to {@code true} * this method is called whenever ths mouse moves during the drag operation. * You can override this method to perform some action during the drag operation. * * @param target the AjaxRequestTarget of the drag operation. * @param specialKeys the special keys that were pressed when the event occurs */ protected void onDrag(final AjaxRequestTarget target, final SpecialKeys specialKeys) { } /** * If you have set {@link #setWantOnDragStopNotification(boolean)} to {@code true} * this method is called when the drag operation stops. You can override this * method to perform some action when dragging stops. * * @param target the AjaxRequestTarget of the drag operation. * @param specialKeys the special keys that were pressed when the event occurs */ protected void onDragStop(final AjaxRequestTarget target, final SpecialKeys specialKeys) { } /** * Disable the dragging * * @param target An AjaxRequestTarget */ public void disable(final AjaxRequestTarget target) { target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('disable');"); } /** * Enable the dragging * * @param target An AjaxRequestTarget */ public void enable(final AjaxRequestTarget target) { target.appendJavaScript("jQuery('#" + getComponent().getMarkupId() + "').draggable('enable');"); } @Override /** * For internal use only. */ protected JsBuilder getJsBuilder() { if (this.onDragStopNotificationWanted) { this.options.put(EventType.DRAG_END.getEventName(), new JsFunction("function() { wicketAjaxGet('" + // TODO_WICKET15 ? // this.getCallbackUrl(false) + this.getCallbackUrl() + "&" + EventType.IDENTIFIER + "=" + EventType.DRAG_END + "&keys='+jQuery.jWicketSpecialKeysGetPressed()" + "); }")); } else { this.options.remove(EventType.DRAG_END.getEventName()); } if (this.onDragNotificationWanted) { this.options.put(EventType.DRAG.getEventName(), new JsFunction("function() { wicketAjaxGet('" + this.getCallbackUrl() + "&" + EventType.IDENTIFIER + "=" + EventType.DRAG + "&keys='+jQuery.jWicketSpecialKeysGetPressed()" + "); }")); } else { this.options.remove(EventType.DRAG.getEventName()); } if (this.onDragStartNotificationWanted) { this.options.put(EventType.DRAG_START.getEventName(), new JsFunction("function() { wicketAjaxGet('" + this.getCallbackUrl() + "&" + EventType.IDENTIFIER + "=" + EventType.DRAG_START + "&keys='+jQuery.jWicketSpecialKeysGetPressed()" + "); }")); } else { this.options.remove(EventType.DRAG_START.getEventName()); } JsBuilder builder = new JsBuilder(); builder.append("jQuery('#" + getComponent().getMarkupId() + "').draggable("); builder.append("{"); builder.append(this.options.toString(this.rawOptions)); builder.append("}"); builder.append(");"); if (this.name != null) { builder.append(new JsFunction("\njQuery(function(){jQuery('#" + getComponent().getMarkupId() + "').attr('" + DraggablesAcceptedByDroppable.DRAG_NAME_IDENTIFIER + "', '" + this.name + "');});")); } return builder; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy