Draggable element inside another draggable element

mjanisz1

Here in the fiddle is more less what i want to do: http://jsfiddle.net/EUZS5/2/ .

I have different elements in a swiper and in some slides inside there is a draggable element.

Currently when i drag the arrow it also pulls the slide (which is not the behaviour i want:))

I tried to use 'stopPropagation' on drag event but it does not help to prevent the slide from moving.

Any ideas how to achieve this? Im using hammerjs and idangerous.swiper.

$(document).ready(function(){
    var mySwiper = new Swiper('.swiper-container',{
    pagination: '.pagination',
    paginationClickable: true
 })

var left;

$('.arrow').hammer({}).on("dragstart", function(ev) {
    left = $(this).css('left').replace(/[^-\d\.]/g, '');
})
$('.arrow').hammer({}).on("dragright", function(ev) {
                var distance = parseFloat(left)+parseFloat(ev.gesture.deltaX);
                $(this).css('left', distance+'px');
            })
$('.arrow').hammer({}).on("dragleft", function(ev) {
                var distance = parseFloat(left)+parseFloat(ev.gesture.deltaX);
                $(this).css('left', distance+'px');

            })
                            });
cjspurgeon

You can do this by adding some 'no-swiping' settings to idangerous swiper, and then adding that class when the arrow is dragged.

Fiddle here: http://jsfiddle.net/cspurgeon/EUZS5/3/

New iDangerous settings:

var mySwiper = new Swiper('.swiper-container',{
    pagination: '.pagination',
    paginationClickable: true,
    noSwiping: true,
    noSwipingClass: 'no-swiping'    
 })

Relevant event listeners for arrow mousedown, and drag.

$('.arrow').on('mousedown', function(e) {
    // disable swiper when user clicks on arrow
    $(this).parents('.swiper-wrapper').addClass('no-swiping');
});
$('.arrow').on('mouseup dragend', function(e) {
    // re-enable when user is done
    $(this).parents('.swiper-wrapper').removeClass('no-swiping');
});

Note: you need the dragend because the mouse isn't always over the arrow when the user releases it. But you can't use dragstart because it appears to fire after the swipe event is triggered.

iDangerous noSwiping documentation here: http://www.idangero.us/sliders/swiper/api.php

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

From Dev

draggable inside Canvas element

From Dev

Not draggable element inside Draggable one went wrong

From Dev

Fixed element inside draggable fixed element

From Dev

Swap draggable element to mouse cursor on drop of another draggable

From Dev

Swap draggable element to mouse cursor on drop of another draggable

From Dev

Draggable an element which is inside a droppable one

From Dev

Where was dropped the draggable element?

From Dev

Set bounds for draggable element

From Dev

pure javascript draggable element

From Dev

Get ID of draggable element

From Dev

Limit a Draggable Element JS

From Dev

Get JQueryUI Draggable Element

From Dev

Limit a Draggable Element JS

From Dev

Automatic drag an ".draggable" element

From Dev

Apply a Draggable Container Above Another Absolutely Positioned Element

From Dev

Clone draggable element jQuery UI

From Dev

Make an element draggable diagonally / on path

From Dev

How to return the draggable element into the options?

From Dev

jsPlumb draggable element javascript function

From Dev

Jquery Draggable and Resizable on Same element

From Dev

How to get the "index" of a draggable element?

From Dev

Make an element draggable diagonally / on path

From Dev

jQuery UI Draggable on droppable element

From Dev

Making element draggable after toggleClass

From Dev

Issue dragging element contained in a draggable element

From Dev

Selected HTML DIV element draggable using JQueryUi draggable

From Dev

jQuery ui draggable element gets under other draggable elements

From Dev

How can I make a nested element not draggable in a draggable container?

From Dev

Jquery: Move a draggable element among containers

Related Related

HotTag

Archive