firefly-iii/public/js/accounts.js

83 lines
2.1 KiB
JavaScript
Raw Normal View History

2015-06-27 05:04:53 -05:00
/* global $, lineChart, accountID, token */
2015-05-24 11:22:41 -05:00
// Return a helper with preserved width of cells
var fixHelper = function (e, ui) {
"use strict";
ui.children().each(function () {
$(this).width($(this).width());
});
return ui;
};
2015-02-21 05:16:41 -06:00
2015-05-24 11:22:41 -05:00
$(function () {
"use strict";
2015-06-27 05:04:53 -05:00
if (typeof(lineChart) === "function" && typeof accountID !== 'undefined') {
2015-09-25 13:25:22 -05:00
2015-06-27 05:04:53 -05:00
lineChart('chart/account/' + accountID, 'overview-chart');
2015-02-21 05:16:41 -06:00
}
2015-03-27 07:20:48 -05:00
// sortable!
2015-05-24 11:22:41 -05:00
if (typeof $(".sortable-table tbody").sortable !== "undefined") {
2015-03-27 07:20:48 -05:00
$(".sortable-table tbody").sortable(
{
helper: fixHelper,
items: 'tr:not(.ignore)',
stop: sortStop,
handle: '.handle'
}
).disableSelection();
2015-09-25 13:25:22 -05:00
} else {
console.log('its null');
2015-03-27 07:20:48 -05:00
}
});
function sortStop(event, ui) {
2015-05-24 11:22:41 -05:00
"use strict";
2015-03-27 07:20:48 -05:00
var current = $(ui.item);
2015-09-25 13:25:22 -05:00
console.log('sort stop');
2015-03-27 07:20:48 -05:00
var thisDate = current.data('date');
var originalBG = current.css('backgroundColor');
2015-05-24 11:22:41 -05:00
if (current.prev().data('date') !== thisDate && current.next().data('date') !== thisDate) {
2015-03-27 07:20:48 -05:00
// animate something with color:
current.animate({
backgroundColor: "#d9534f"
}, 200, function () {
$(this).animate({
backgroundColor: originalBG
}, 200);
});
return false;
}
// do update
var list = $('tr[data-date="' + thisDate + '"]');
var submit = [];
$.each(list, function (i, v) {
var row = $(v);
var id = row.data('id');
submit.push(id);
});
// do extra animation when done?
$.post('/transaction/reorder', {items: submit, date: thisDate, _token: token});
current.animate({
backgroundColor: "#5cb85c"
}, 200, function () {
$(this).animate({
backgroundColor: originalBG
}, 200);
});
//else update some order thing bla bla.
//check if the item above OR under this one have the same date
//if not. return false
}