Bug 12905: funds with children could not be deleted

The interface should prevent to delete funds with children.
Otherwise the relationship is broken and problems occur:
1/ You don't see the orphan fund in the fund list
2/ You cannot edit the orphan fund amount ('Fund amount exceeds parent
allocation').

This patch:
- adds a JS check, template side
- adds a check in the perl script (should never be true)
- adds an updatedatabase check, in order to alert users with inconsistent data.

Test plan:
Verify you are not allow to delete a fund with children.

Signed-off-by: Paola Rossi <paola.rossi@cineca.it>

Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@gmail.com>
This commit is contained in:
Jonathan Druart 2014-11-10 10:45:25 +01:00 committed by Tomas Cohen Arazi
parent 74640683f0
commit 522e9c5861
3 changed files with 38 additions and 1 deletions

View file

@ -231,6 +231,10 @@ if ($op eq 'add_form') {
# END $OP eq DELETE_CONFIRM
# called by delete_confirm, used to effectively confirm deletion of data in DB
} elsif ( $op eq 'delete_confirmed' ) {
if ( BudgetHasChildren( $budget_id ) ) {
# We should never be here, the interface does not provide this action.
die("Delete a fund with children is not possible");
}
my $rc = DelBudget($budget_id);
$op = 'list';
} elsif( $op eq 'add_validate' ) {
@ -330,6 +334,8 @@ if ( $op eq 'list' ) {
@budget_hierarchy = reverse(@budget_hierarchy);
$budget->{budget_hierarchy} = \@budget_hierarchy;
$budget->{budget_has_children} = BudgetHasChildren( $budget->{budget_id} );
}
my $budget_period_total = $period->{budget_period_total};

View file

@ -9669,6 +9669,28 @@ if ( CheckVersion($DBversion) ) {
SetVersion ($DBversion);
}
$DBversion = "3.18.00.001";
if ( CheckVersion($DBversion) ) {
my $orphan_budgets = $dbh->selectall_arrayref(q|
SELECT budget_id, budget_name, budget_code
FROM aqbudgets
WHERE budget_parent_id IS NOT NULL
AND budget_parent_id NOT IN (
SELECT DISTINCT budget_id FROM aqbudgets
)
|, { Slice => {} } );
if ( @$orphan_budgets ) {
for my $b ( @$orphan_budgets ) {
print "Fund $b->{budget_name} (code:$b->{budget_code}, id:$b->{budget_id}) does not have a parent, it may cause problem\n";
}
print "Upgrade to $DBversion done (Bug 12905: Check budget integrity: FAIL)\n";
} else {
print "Upgrade to $DBversion done (Bug 12905: Check budget integrity: OK)\n";
}
SetVersion($DBversion);
}
=head1 FUNCTIONS
=head2 TableExists($table)

View file

@ -225,6 +225,11 @@ var MSG_PARENT_BENEATH_BUDGET = "- " + _("New budget-parent is beneath budget")
$("#filterbutton").click(function() {
$("#fundfilters").slideToggle(0);
});
$(".deletefund-disabled").on("click", function(e){
e.preventDefault();
alert("This fund has children. It cannot be deleted.");
});
});
//]]>
</script>
@ -398,7 +403,11 @@ var MSG_PARENT_BENEATH_BUDGET = "- " + _("New budget-parent is beneath budget")
</a>
<ul class="dropdown-menu pull-right" role="menu" aria-labelledby="budgetactions[% budget.budget_id %]_[% budget.budget_period_id %]">
<li><a href="/cgi-bin/koha/admin/aqbudgets.pl?op=add_form&amp;budget_id=[% budget.budget_id %]&amp;budget_period_id=[% budget.budget_period_id %]" >Edit</a></li>
<li><a href="/cgi-bin/koha/admin/aqbudgets.pl?op=delete_confirm&amp;budget_id=[% budget.budget_id %]&amp;budget_period_id=[% budget.budget_period_id %]">Delete</a></li>
[% IF budget.budget_has_children %]
<li class="disabled"><a href="#" class="deletefund-disabled" data-toggle="tooltip" data-placement="left" title="This fund has children">Delete</a></li>
[% ELSE %]
<li><a href="/cgi-bin/koha/admin/aqbudgets.pl?op=delete_confirm&amp;budget_id=[% budget.budget_id %]&amp;budget_period_id=[% budget.budget_period_id %]">Delete</a></li>
[% END %]
<li><a href="/cgi-bin/koha/admin/aqbudgets.pl?op=add_form&amp;budget_parent_id=[% budget.budget_id %]&amp;budget_period_id=[% budget.budget_period_id %]">Add child fund</a></li>
</ul>
</div>