Various fixes; added full name to account data; do never transfer unchecked

This commit is contained in:
Florian "flowdy" Heß 2017-02-02 22:23:23 +01:00
parent ba30ec40a2
commit 8b1a68f07b
12 changed files with 66 additions and 31 deletions

View File

@ -4,7 +4,7 @@ package TrsrDB::Account;
use base qw/DBIx::Class::Core/; use base qw/DBIx::Class::Core/;
__PACKAGE__->table('Account'); __PACKAGE__->table('Account');
__PACKAGE__->add_columns(qw/ID type altId IBAN/); __PACKAGE__->add_columns(qw/ID name type altId IBAN/);
__PACKAGE__->set_primary_key('ID'); __PACKAGE__->set_primary_key('ID');
__PACKAGE__->has_many( __PACKAGE__->has_many(

View File

@ -30,24 +30,37 @@ sub upsert {
my $account_rs = $db->resultset("Account"); my $account_rs = $db->resultset("Account");
my $account; my $account;
if ( my $name = $self->stash("account") ) { if ( my $name = $self->stash("account") ) {
$self->stash( name => $name ); $self->stash( id => $name );
$account = $account_rs->find($name); $account = $account_rs->find($name);
} }
else { else {
$self->stash( name => undef ); $self->stash( id => undef );
$account = $account_rs->new({}); $account = $account_rs->new({});
} }
$self->stash( account => $account ); $self->stash( account => $account );
my $iban = $self->param("IBAN") // $account->IBAN;
if ( $self->req->method eq 'POST' ) { if ( $self->req->method eq 'POST' ) {
my $p = $self->req->params->to_hash;
if ( $p->{IBAN} eq q{*} ) {
$p->{IBAN} = q{};
}
elsif ( !$iban ) {
delete $p->{IBAN};
}
for my $field ($account->result_source->columns) { for my $field ($account->result_source->columns) {
my $value = $self->param($field); my $value = $p->{ $field };
$account->$field($value); $account->$field($value);
} }
$account->update_or_insert(); $account->update_or_insert();
$self->redirect_to("home"); $self->redirect_to("home");
} }
else { else {
if ( defined( $iban ) ) {
$iban = q{*} if !$iban;
$account->IBAN($iban);
}
my @types = $account_rs->search({ type => { '!=' => q// } }, { my @types = $account_rs->search({ type => { '!=' => q// } }, {
columns => ['type'], distinct => 1 columns => ['type'], distinct => 1
})->get_column("type")->all; })->get_column("type")->all;
@ -78,22 +91,22 @@ sub transfer {
my $db = $self->app->db; my $db = $self->app->db;
my $account = $db->resultset("Account")->find( $self->stash("account") ); my $account = $db->resultset("Account")->find( $self->stash("account") );
my $credits = $account->available_credits; my $credits_rs = $account->available_credits;
my $arrears = $account->current_arrears; my $arrears_rs = $account->current_arrears;
if ( $self->req->method eq 'POST' ) { my $credit_ids = $self->every_param('credits');
$db->make_transfers( my $arrear_ids = $self->every_param('debits');
$self->every_param('credits')
=> $self->every_param('debits') if ( $self->req->method eq 'POST' && @$credit_ids && @$arrear_ids ) {
); $db->make_transfers( $credit_ids => $arrear_ids );
} }
if ( !( $credits->count && $arrears->count ) ) { if ( !( $credits_rs->count && $arrears_rs->count ) ) {
$self->redirect_to('home'); $self->redirect_to('home');
return; return;
} }
$self->stash( credits => $credits, arrears => $arrears ); $self->stash( credits => $credits_rs, arrears => $arrears_rs );
return; return;

View File

@ -52,7 +52,7 @@ sub upsert {
return; return;
} }
for my $field ( qw/account date purpose category value/ ) { for my $field ( qw/date purpose category value/ ) {
my $value = $self->param($field); my $value = $self->param($field);
$value = undef if !length $value; $value = undef if !length $value;
$credit->$field($value); $credit->$field($value);

View File

@ -1,5 +1,6 @@
CREATE TABLE Account ( CREATE TABLE Account (
ID PRIMARY KEY NOT NULL, ID PRIMARY KEY NOT NULL,
name,
type NOT NULL, type NOT NULL,
altId NOT NULL, -- e.g. when type "member", no. in external member table altId NOT NULL, -- e.g. when type "member", no. in external member table
IBAN -- target account for returned payments (set '' to enable IBAN -- target account for returned payments (set '' to enable

View File

@ -71,6 +71,7 @@ table.history p.linked-credit {
input, textarea { input, textarea {
border: 1px solid #ddd; border: 1px solid #ddd;
padding: 2px;
} }
dl dt { dl dt {
@ -88,6 +89,7 @@ dl dd {
select { select {
border: 1px solid #ddd; border: 1px solid #ddd;
background-color:transparent; background-color:transparent;
padding: 2px;
} }
.help { .help {

View File

@ -17,7 +17,7 @@
<%= $inter_header->($t) %> <%= $inter_header->($t) %>
% } % }
% my $u = $account->ID; % my $u = $account->ID;
<tr><th><a href="/account/<%= $u %>"><%= $u %></a></th> <tr><th><a href="/account/<%= $u %>" title="<%= $account->name %>"><%= $u %></a></th>
<td class="even_until"><%= $bal->even_until // "never" %></td><td class="number"><%== money $bal->arrears %></td><td><a href="<%= $u %>/debits"><img class="icon" alt="List" src="/list.svg" alt="List"></td><td><a title="Add a debit" href="<%= $u %>/out"><img class="icon" src="/add-debit.svg" alt="Charge"></a></td> <td class="even_until"><%= $bal->even_until // "never" %></td><td class="number"><%== money $bal->arrears %></td><td><a href="<%= $u %>/debits"><img class="icon" alt="List" src="/list.svg" alt="List"></td><td><a title="Add a debit" href="<%= $u %>/out"><img class="icon" src="/add-debit.svg" alt="Charge"></a></td>
<td class="centered"> <td class="centered">
% my $which = ($bal->arrears && 1) + ($bal->available && 1); % my $which = ($bal->arrears && 1) + ($bal->available && 1);

View File

@ -1,6 +1,6 @@
% title 'Make transfers for ' . $account; % title 'Make transfers for ' . $account;
<p>Check at least one item of both tables. Make sure they correspond in regard to their purposes. <em><strong>Caution:</strong> When you do not check any items in either table, this effectively is to check all in it!</em></p> <p>Check at least one item of both tables. Make sure they correspond in regard to their purposes.</em></p>
<form method="post"> <form method="post">

View File

@ -1,17 +1,20 @@
% title $name ? "Account $name" : "Create account"; % title $id ? "Account $id" : "Create account";
% my %r; % my %r;
% $r{ID} = begin % $r{ID} = begin
<input id="ID" name="ID" value="<%= $account->ID %>"> <input id="ID" name="ID" value="<%= $account->ID %>">
% end % end
% $r{name} = begin
<input id="name" name="name" value="<%= $account->name %>">
% end
% $r{type} = begin % $r{type} = begin
<input id="type" name="type" value="<%= $account->type %>"> (<%= join(", ", @$types) %> or a new?) <input id="type" name="type" value="<%= $account->type %>"> (Currently there: <%= join(", ", @$types) %>)
% end % end
% $r{altId} = begin % $r{altId} = begin
<input id="altId" name="altId" value="<%= $account->altId %>"> <input id="altId" name="altId" value="<%= $account->altId %>">
% end % end
% $r{IBAN} = begin % $r{IBAN} = begin
<input id="IBAN" name="IBAN" value="<%= $account->IBAN %>"> <input id="IBAN" name="IBAN" value="<%= $account->IBAN %>"> (may also be empty or '*' s. help)
% end % end
<form method="post"> <form method="post">
@ -32,4 +35,9 @@
<button type="submit">Submit</button> <button type="submit">Submit</button>
</form> </form>
% my $help = begin
<p><strong>What to input into "IBAN"?</strong> To restrict outgoing payments from that account to a certain bank account, insert its account number. To allow outgoing payment to any bank account, input wildcard (*). To disallow outgoing payment from that account, input nothing.</p>
<p>When inserting a proper number, this number must be included in all outgoing payments from that account. Outgoing payments differ from internal payments in that transferCredit is undefined.</p>
% end
% stash help => $help;

View File

@ -92,6 +92,6 @@
% } % }
% } % }
<button type="submit">Submit</button> <p><button type="submit">Submit</button></p>
</form> </form>

View File

@ -6,7 +6,14 @@
<tr><th>Id</th><th>Date</th><th>Purpose</th><th>value</th><th>paid</th><th>to</th></tr> <tr><th>Id</th><th>Date</th><th>Purpose</th><th>value</th><th>paid</th><th>to</th></tr>
% while ( my $debit = $debits->next ) { % while ( my $debit = $debits->next ) {
% my $tgt = $debit->target; % my $tgt = $debit->target;
<tr><td><a href="/debit/<%= $debit->billId %>"><%= $debit->billId %></a></td><td><%= $debit->date %></td><td><%== nl2br $debit->purpose %></td><td class="number"><%== money $debit->value %></td><td class="number <%= $debit->paid < $debit->value ? "mark" : "" %>"><%== money $debit->paid %><td><a href="/credit/<%= $tgt->credId %>"><%= $tgt->account->ID %></a></tr> <tr><td><a href="/debit/<%= $debit->billId %>"><%= $debit->billId %></a></td><td><%= $debit->date %></td><td><%== nl2br $debit->purpose %></td><td class="number"><%== money $debit->value %></td><td class="number <%= $debit->paid < $debit->value ? "mark" : "" %>"><%== money $debit->paid %><td>
% if ( $tgt ) {
<a href="/credit/<%= $tgt->credId %>"><%= $tgt->account->ID %></a>
% }
% else {
(outgoing)
% }
</td></tr>
% } % }
</table> </table>

View File

@ -30,9 +30,8 @@
% end % end
% $r{targetCredit} = begin % $r{targetCredit} = begin
% if ( !@$targets ) { % if ( !@$targets ) {
<p style="color:red;">There are no target credits available. Target credits are credits of other accounts that either still have a value of 0, or which have already been targetted. Please create a target credit record first, because all debits must refer to one so settlements can be fulfilled.</p> <div style="color:red;">There are no target credits available. Target credits are credits of other accounts that either still have a value of 0, or which have already been targetted. Please create a target credit record first, because all debits must refer to one so settlements can be fulfilled.</div>
% $targets = [ ['', '', ''] ]; % $targets = [ ['', '', ''] ];
oops
% } % }
% my $cmpacc = $targets->[0][1]; % my $cmpacc = $targets->[0][1];
% my $target = $debit->targetCredit // ''; % my $target = $debit->targetCredit // '';
@ -103,7 +102,7 @@ oops
<h2>Pay with credits</h2> <h2>Pay with credits</h2>
% my $credits = app->db->resultset("Account")->find($account)->available_credits; % my $credits = app->db->resultset("Account")->find($account)->available_credits;
% if ( $credits->count() ) { % if ( $credits->count() ) {
<p><%= $debit->value && $debit->value == $debit->value ? "The debt is already settled. Unless you revoke any incomings above, there is no point in checking" : "Check" %> <%= %used_credits ? "other" : "" %> credits you want to <strong>pay this debit</strong> with:</p> <p><%= $debit->value && $debit->value == $debit->paid ? "The debt is already settled. Unless you revoke any incomings above, there is no point in checking" : "Check" %> <%= %used_credits ? "other" : "" %> credits you want to <strong>pay this debit</strong> with:</p>
<table> <table>
<tr><th>S</th><th>date</th><th>purpose</th><th>to spend</th><th>note</th></tr> <tr><th>S</th><th>date</th><th>purpose</th><th>to spend</th><th>note</th></tr>
% while ( my $c = $credits->next ) { % while ( my $c = $credits->next ) {
@ -122,6 +121,6 @@ oops
% } % }
% } % }
<button type="submit">Submit</button> <p><button type="submit">Submit</button></p>
</form> </form>

View File

@ -12,12 +12,17 @@
% } % }
<form method="post" action="/login"><p> <form method="post" action="/login"><p>
User id: <input name="user" type="text" placeholder="user id or email" value="<%= param('user') %>"><br> <dl>
Password: <input name="password" type="password"><br> <dt>User id</dt>
<dd><input name="user" type="text" placeholder="user id or email" value="<%= param('user') %>"></dd>
<dt>Password</dt>
<dd><input name="password" type="password"></dd>
% if ( my $token = param 'token' ) { % if ( my $token = param 'token' ) {
Repeat: <input name="samepassword" type="password"><br> <dt>Repeat</dt>
<input type="hidden" name="token" value="<%= $token %>"><br> <dd><input name="samepassword" type="password">
<input type="hidden" name="token" value="<%= $token %>">
</dd>
% } % }
<button type="submit">Login</button> <p><button type="submit">Login</button></p>
</p></form> </form>