Solved

JQuery Drag and Drop questions

Posted on 2011-09-21
1
493 Views
Last Modified: 2012-06-21
I have done a fair amount of work with HTML forms, but never using Drag and Drop with JQuery.  I got roped into this for a non-profit that I do some volunteer for from time to time.  They want to change their form based system for ordering supplies to one where you can drag them.  They thought that looked cooler than the cart page they have now.

It is a fairly simple drag and drop.  I borrowed the code from an example, and made some modifications from there.   Eventually, if I can get this to work, then I will dynamically get things from the database, format, etc.  I figure that if somebody that knows what they are doing (as opposed to me) I could see how it should be done and learn something.

However, I have reached the limit of my JQuery expertise, at least for now until I work with it more.

My big issues now are these:

I need to put the little X thingy inside the table, that is the delete button.  I see where this is done by adding this to the HTML, but it puts it in front.  Is it possible to put this where the X is in my table?  I am sure it is, just not sure the best way.

I can get the attribute, like the model number, but how could I get the other form attributes, like quantity, hidden form elements, etc. for the dragged items?  I know I can post the form and get them, but is there a way to get them without posting? I have these in the HTML, and if I post the form, I can get them, but would like to do some checking prior to posting, but just for the dragged items.  Would I just put the form tags around the div for the dragged items?

I need to figure out which item is being dropped so I can adjust the item list.  I want to keep a count of the items dragged, and adjust them, and also a list of what has been dropped so that you can’t drag the same item twice.  The drop per item using the X thingy works, but if I wanted to do something else with the remove I need to know what item has been dropped.

Can the item dragged be removed from the left list when it is dropped to the right?  That would cure the issue with keeping track of what is dropped and preventing a second drop of the same item.

I have attached the files, html, javaScript, Css and images that make it work.

Sorry if this is pretty basic, but I just started working with JQuery a couple days ago, and DnD yesterday.

Thanks,
Bob


 
DnD.css
DnD.js
DnD-Test.html
jquery-1.5.min.js
jquery-ui-1.8.9.custom.min.js
1.jpg
2.jpg
3.jpg
5.jpg
4.jpg
6.jpg
0
Comment
Question by:Bob_pyle
1 Comment
 
LVL 3

Accepted Solution

by:
mykde earned 500 total points
ID: 36578546
Can the item dragged be removed from the left list when it is dropped to the right?  That would cure the issue with keeping track of what is dropped and preventing a second drop of the same item.

Yes

Add this line to your DnD.js:
$("#"+itemid).hide();

Open in new window


like so:
var item = ui.draggable.html();
            var itemid = ui.draggable.attr("id");
            var html = '<div class="item ivote">';
            html = html + '<div class="divrm">';
            html = html + '<a onclick="remove(this)" class="remove ' + itemid + '">&times;</a>';
            html = html + '<div/>' + item + '</div>';
            $("#votes").append(html);
            $("#"+itemid).hide();
            //alert("Dropped item - " + item);
            //alert("Dropped html - " + html);
            // update total votes
            total_items++;
            $("#citem").html(total_items);
            //alert("After Items - " + total_items);
            // expand ballot box items
            if (total_items > 4) {
                $("#votes").animate({ width: "+=120" }, 'slow');
            }

Open in new window

0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

Suggested Solutions

ASP.NET AJAX callbacks to web service are becoming very popular and unavoidable these days. The feel that the user gets when only a part of the page is updated without even hindering the UI is the advantage that the callbacks offer. The wait for the…
There is basically two types of AJAX request in mootools. Request  and Request.HTML Request: Request is the basic XHR request class in MooTools. While not extremely useful on its own, it provides the basic functionality for both Request.HTM…
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…
You have products, that come in variants and want to set different prices for them? Watch this micro tutorial that describes how to configure prices for Magento super attributes. Assigning simple products to configurable: We assigned simple products…

707 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now