I have 2 tables with same number of columns with some spans inside each table cell. I'm using jquery Ui draggable and droppable to drag and drop spans from one table to another.
$(document).ready(function() {
var ind;
$('#tblTrailer td span').draggable({
revert: "invalid",
zIndex: 100,
start: function(event, ui) {
var foo = $(ui.helper).parent(); // should return td
ind = foo.index();
$(ui.helper).css({
padding: "2.5px 5px",
border: "1px solid #ddd",
background: "#f2f2f2"
});
console.log(ind);
}
});
$('#tblTrailerBooking tr td').droppable({
accept: "#tblTrailer td span",
activeClass: "ui-state-highlight",
drop: function(ev, ui) {
$(ui.draggable).detach().css({
top: 'auto',
left: 'auto',
background: '#f3f3f3'
}).appendTo(this);
}
});
});
body {
font-size: 14px;
font-family: sans-serif;
}
table {
border-collapse: collapse;
width: 100%;
}
table tr td,
table tr th {
border: 1px solid #999;
width: 12.5%;
}
table td span {
display: block;
text-align: center;
transition: all 0.5s linear;
}
<link href="//code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
<script src="//code.jquery.com/ui/1.9.2/jquery-ui.js"></script>
<table id="tblTrailer" class="table table-bordered mrg-0 resource-table">
<thead>
<tr>
<th>Resources</th>
<th>Sep 1</th>
<th>Sep 2</th>
<th>Sep 3</th>
<th>Sep 4</th>
<th>Sep 5</th>
<th>Sep 6</th>
<th>Sep 7</th>
</tr>
</thead>
<tbody>
<tr>
<td>Trailer</td>
<td>
<span class="trailer">TRI-001</span>
<span class="trailer">TRI-101</span>
</td>
<td>
<span class="trailer">TRI-102</span>
<span class="trailer">TRI-202</span>
</td>
<td><span class="trailer">TRI-003</span>
</td>
<td>
<span class="trailer">TRI-004</span>
<span class="trailer">TRI-104</span>
</td>
<td>
<span class="trailer">TRI-005</span>
<span class="trailer">TRI-105</span>
</td>
<td><span class="trailer">TRI-006</span>
</td>
<td>
<span class="trailer">TRI-007</span>
<span class="trailer">TRI-107</span>
</td>
</tr>
<tr>
<td>Prime Movers</td>
<td><span class="prime">PMS-001</span>
</td>
<td>
<span class="prime">PMS-002</span>
<span class="prime">PMS-102</span>
<span class="prime">PMS-202</span>
</td>
<td>
<span class="prime">PMS-003</span>
<span class="prime">PMS-103</span>
</td>
<td><span class="prime">PMS-004</span>
</td>
<td>
<span class="prime">PMS-005</span>
<span class="prime">PMS-105</span>
</td>
<td><span class="prime">PMS-006</span>
</td>
<td>
<span class="prime">PMS-007</span>
<span class="prime">PMS-107</span>
</td>
</tr>
<tr>
<td>Drivers</td>
<td><span class="driver">DRV-001</span>
</td>
<td>
<span class="driver">DRV-002</span>
<span class="driver">DRV-102</span>
</td>
<td>
<span class="driver">DRV-003</span>
<span class="driver">DRV-103</span>
</td>
<td>
<span class="driver">DRV-004</span>
<span class="driver">DRV-104</span>
</td>
<td><span class="driver">DRV-005</span>
</td>
<td>
<span class="driver">DRV-006</span>
<span class="driver">DRV-106</span>
</td>
<td>
<span class="driver">DRV-007</span>
<span class="driver">DRV-107</span>
</td>
</tr>
</tbody>
</table>
<br />
<table id="tblTrailerBooking" class="table table-bordered mrg-0 resource-table">
<thead>
<tr>
<th>Booking No.</th>
<th>Sep 1</th>
<th>Sep 2</th>
<th>Sep 3</th>
<th>Sep 4</th>
<th>Sep 5</th>
<th>Sep 6</th>
<th>Sep 7</th>
</tr>
</thead>
<tbody>
<tr>
<td>B0001</td>
<td>
<span class="trailer">TRI-201</span>
<span class="prime">PMS-101</span>
</td>
<td>
<span class="trailer">TRI-002</span>
<span class="prime">PMS-302</span>
<span class="driver">DRV-102</span>
</td>
<td></td>
<td><span class="prime">PMS-304</span>
</td>
<td></td>
<td><span class="driver">DRV-006</span>
</td>
<td><span class="trailer">TRI-007</span>
</td>
</tr>
<tr>
<td>B0002</td>
<td>
<span class="trailer">TRI-201</span>
<span class="prime">PMS-101</span>
</td>
<td>
<span class="trailer">TRI-002</span>
<span class="prime">PMS-302</span>
<span class="driver">DRV-102</span>
</td>
<td></td>
<td><span class="prime">PMS-304</span>
</td>
<td><span class="driver">DRV-005</span>
</td>
<td></td>
<td><span class="trailer">TRI-007</span>
</td>
</tr>
<tr>
<td>B0003</td>
<td>
<span class="trailer">TRI-201</span>
<span>PMS-101</span>
</td>
<td>
<span class="trailer">TRI-002</span>
<span class="prime">PMS-302</span>
<span class="trailer">DRV-102</span>
</td>
<td><span class="driver">PMS-303</span>
</td>
<td></td>
<td></td>
<td><span class="driver">DRV-006</span>
</td>
<td><span class="trailer">TRI-007</span>
</td>
</tr>
</tbody>
</table>
I would like to insert the spans to the respective columns of second table. And second table should not allow more than 3 spans in a cell one each from each rows of first table. Tried the solution provided here: https://stackoverflow.com/a/788292/1201322 with no luck.
JS Fiddle link: https://jsfiddle.net/ravimallya/Le6jdd8c/ .
Edit: I might not explained it clearly.
In first table, you can see 3 rows; whereas second one has booking numbers. For each day each booking number should need to have each row content from first table. For Ex: for B001, we can add a driver for sep 1, but we can't for sep 2 as sep 2 all fulfilled. For sep 3, we have to add all three (a truck, a prime mover, and a driver from sep 3 of first table. We should not drop from any other day.
I Hope now I'm clear.