2016-01-29 18:39:50 +01:00
|
|
|
/*
|
|
|
|
* create.js
|
2017-01-15 19:07:31 +01:00
|
|
|
* Copyright (c) 2017 thegrumpydictator@gmail.com
|
|
|
|
* This software may be modified and distributed under the terms of the Creative Commons Attribution-ShareAlike 4.0 International License.
|
2016-12-23 07:02:45 +01:00
|
|
|
*
|
|
|
|
* See the LICENSE file for details.
|
2016-01-29 18:39:50 +01:00
|
|
|
*/
|
|
|
|
|
2017-01-02 12:09:46 +01:00
|
|
|
/** global: what, title, breadcrumbs, middleCrumbName, button, piggiesLength, txt, doSwitch, middleCrumbUrl */
|
2017-01-02 10:34:01 +01:00
|
|
|
|
2015-02-24 21:10:25 +01:00
|
|
|
$(document).ready(function () {
|
2015-05-24 20:41:14 +02:00
|
|
|
"use strict";
|
2015-03-26 22:52:49 +01:00
|
|
|
|
2016-01-29 18:39:50 +01:00
|
|
|
// respond to switch buttons when
|
|
|
|
// creating stuff:
|
2017-01-02 10:34:01 +01:00
|
|
|
if (doSwitch == true) {
|
2015-06-03 17:32:50 +02:00
|
|
|
updateButtons();
|
|
|
|
updateForm();
|
|
|
|
updateLayout();
|
2017-01-15 19:07:31 +01:00
|
|
|
updateDescription();
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
|
2017-01-15 20:05:40 +01:00
|
|
|
if (!Modernizr.inputtypes.date) {
|
|
|
|
$('input[type="date"]').datepicker(
|
|
|
|
{
|
|
|
|
dateFormat: 'yy-mm-dd'
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2017-01-15 19:07:31 +01:00
|
|
|
// get JSON things:
|
|
|
|
getJSONautocomplete();
|
2015-06-03 17:32:50 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
2017-01-15 19:07:31 +01:00
|
|
|
function updateDescription() {
|
|
|
|
$.getJSON('json/transaction-journals/' + what).done(function (data) {
|
|
|
|
$('input[name="description"]').typeahead('destroy');
|
|
|
|
$('input[name="description"]').typeahead({source: data});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getJSONautocomplete() {
|
|
|
|
|
|
|
|
// for withdrawals
|
|
|
|
$.getJSON('json/expense-accounts').done(function (data) {
|
|
|
|
$('input[name="destination_account_name"]').typeahead({source: data});
|
|
|
|
});
|
|
|
|
|
|
|
|
// for tags:
|
|
|
|
if ($('input[name="tags"]').length > 0) {
|
|
|
|
$.getJSON('json/tags').done(function (data) {
|
|
|
|
|
|
|
|
var opt = {
|
|
|
|
typeahead: {
|
|
|
|
source: data,
|
|
|
|
afterSelect: function () {
|
|
|
|
this.$element.val("");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
$('input[name="tags"]').tagsinput(
|
|
|
|
opt
|
|
|
|
);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// for deposits
|
|
|
|
$.getJSON('json/revenue-accounts').done(function (data) {
|
|
|
|
$('input[name="source_account_name"]').typeahead({source: data});
|
|
|
|
});
|
|
|
|
|
|
|
|
$.getJSON('json/categories').done(function (data) {
|
|
|
|
$('input[name="category"]').typeahead({source: data});
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-06-03 17:32:50 +02:00
|
|
|
function updateLayout() {
|
|
|
|
"use strict";
|
|
|
|
$('#subTitle').text(title[what]);
|
|
|
|
$('.breadcrumb .active').text(breadcrumbs[what]);
|
|
|
|
$('.breadcrumb li:nth-child(2)').html('<a href="' + middleCrumbUrl[what] + '">' + middleCrumbName[what] + '</a>');
|
2015-06-20 21:55:55 +02:00
|
|
|
$('#transaction-btn').text(button[what]);
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateForm() {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
$('input[name="what"]').val(what);
|
|
|
|
switch (what) {
|
|
|
|
case 'withdrawal':
|
2016-04-29 17:29:13 +02:00
|
|
|
// show source_id and dest_name:
|
|
|
|
$('#source_account_id_holder').show();
|
|
|
|
$('#destination_account_name_holder').show();
|
|
|
|
|
|
|
|
// hide others:
|
|
|
|
$('#source_account_name_holder').hide();
|
|
|
|
$('#destination_account_id_holder').hide();
|
|
|
|
|
|
|
|
// show budget:
|
2015-06-03 17:32:50 +02:00
|
|
|
$('#budget_id_holder').show();
|
|
|
|
|
2016-04-29 17:29:13 +02:00
|
|
|
// hide piggy bank:
|
|
|
|
$('#piggy_bank_id_holder').hide();
|
2015-06-03 17:32:50 +02:00
|
|
|
|
2016-04-29 17:29:13 +02:00
|
|
|
// copy destination account name to
|
|
|
|
// source account name:
|
|
|
|
if ($('#ffInput_destination_account_name').val().length > 0) {
|
|
|
|
$('#ffInput_source_account_name').val($('#ffInput_destination_account_name').val());
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'deposit':
|
2016-04-29 17:29:13 +02:00
|
|
|
// show source_name and dest_id:
|
|
|
|
$('#source_account_name_holder').show();
|
|
|
|
$('#destination_account_id_holder').show();
|
|
|
|
|
|
|
|
// hide others:
|
|
|
|
$('#source_account_id_holder').hide();
|
|
|
|
$('#destination_account_name_holder').hide();
|
|
|
|
|
|
|
|
// hide budget
|
2015-06-03 17:32:50 +02:00
|
|
|
$('#budget_id_holder').hide();
|
2016-04-29 17:29:13 +02:00
|
|
|
|
|
|
|
// hide piggy bank
|
2015-06-03 17:32:50 +02:00
|
|
|
$('#piggy_bank_id_holder').hide();
|
|
|
|
|
2016-04-29 17:29:13 +02:00
|
|
|
if ($('#ffInput_source_account_name').val().length > 0) {
|
|
|
|
$('#ffInput_destination_account_name').val($('#ffInput_source_account_name').val());
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'transfer':
|
2016-04-29 17:29:13 +02:00
|
|
|
// show source_id and dest_id:
|
|
|
|
$('#source_account_id_holder').show();
|
|
|
|
$('#destination_account_id_holder').show();
|
|
|
|
|
|
|
|
// hide others:
|
|
|
|
$('#source_account_name_holder').hide();
|
|
|
|
$('#destination_account_name_holder').hide();
|
|
|
|
|
|
|
|
|
|
|
|
// hide budget
|
2015-06-03 17:32:50 +02:00
|
|
|
$('#budget_id_holder').hide();
|
|
|
|
if (piggiesLength === 0) {
|
|
|
|
$('#piggy_bank_id_holder').hide();
|
|
|
|
} else {
|
|
|
|
$('#piggy_bank_id_holder').show();
|
|
|
|
}
|
|
|
|
break;
|
2017-01-02 12:18:29 +01:00
|
|
|
default:
|
|
|
|
// no action.
|
|
|
|
break;
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function updateButtons() {
|
|
|
|
"use strict";
|
|
|
|
$('.switch').each(function (i, v) {
|
|
|
|
var button = $(v);
|
|
|
|
|
|
|
|
// remove click event:
|
|
|
|
button.unbind('click');
|
|
|
|
// new click event:
|
|
|
|
button.bind('click', clickButton);
|
|
|
|
|
|
|
|
if (button.data('what') == what) {
|
|
|
|
button.removeClass('btn-default').addClass('btn-info').html('<i class="fa fa-fw fa-check"></i> ' + txt[button.data('what')]);
|
|
|
|
} else {
|
|
|
|
button.removeClass('btn-info').addClass('btn-default').text(txt[button.data('what')]);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function clickButton(e) {
|
|
|
|
"use strict";
|
|
|
|
var button = $(e.target);
|
|
|
|
var newWhat = button.data('what');
|
|
|
|
if (newWhat != what) {
|
|
|
|
what = newWhat;
|
|
|
|
updateButtons();
|
|
|
|
updateForm();
|
|
|
|
updateLayout();
|
2017-01-15 19:07:31 +01:00
|
|
|
updateDescription();
|
2015-06-03 17:32:50 +02:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|