From 12c908bf37942a9ac65da380ea24fe3003bafc2a Mon Sep 17 00:00:00 2001
From: einhverfr <einhverfr@4979c152-3d1c-0410-bac9-87ea11338e46>
Date: Tue, 12 Jun 2007 17:13:50 +0000
Subject: Committing Aurynn's changes to Reconciliation logic

git-svn-id: https://ledger-smb.svn.sourceforge.net/svnroot/ledger-smb/trunk@1268 4979c152-3d1c-0410-bac9-87ea11338e46
---
 scripts/Reconciliation.pl | 158 ++++++++++++++++++++++++++++++++++++++++++++++
 scripts/employees.pl      |  43 +++++++++++++
 2 files changed, 201 insertions(+)
 create mode 100644 scripts/Reconciliation.pl
 create mode 100644 scripts/employees.pl

(limited to 'scripts')

diff --git a/scripts/Reconciliation.pl b/scripts/Reconciliation.pl
new file mode 100644
index 00000000..189eecb4
--- /dev/null
+++ b/scripts/Reconciliation.pl
@@ -0,0 +1,158 @@
+=pod
+
+=head1 NAME
+
+=cut
+
+package LedgerSMB::Scripts::Reconciliation;
+
+use LedgerSMB::Template;
+use LedgerSMB::DBObject::Reconciliation;
+
+=pod
+
+=over
+
+=item display_report($self, $request, $user)
+
+Renders out the selected report given by the incoming variable report_id.
+Returns HTML, or raises an error from being unable to find the selected
+report_id.
+
+=back
+
+=cut
+
+sub display_report {
+    
+    my $recon = LedgerSMB::Employee->new(base => $request, copy => 'all'); 
+    my $template = LedgerSMB::Template->new( user=>$user, 
+        template => "reconciliation_report.html", language => $user->{language},
+            format=>'html'
+        );
+    my $report = $recon->get_report();
+    my $total = $recon->get_total();
+    $template->render({report=>$report, total=>$total});
+}
+
+sub search {
+    my $search = LedgerSMB::Employee->new(base => $request, copy => 'all');
+    $employee->{search_results} = $employee->search();
+    my $template = LedgerSMB::Template->new( user => $user, 
+	template => 'employee_search.html', language => $user->{language}, 
+        format => 'html');
+    $template->render($employee);
+}
+
+=pod
+
+=over
+
+=item correct ($self, $request, $user)
+
+Requires report_id, entry_id.
+
+Correct is a strange one. Based on the type of transaction listed in the
+report, it will run one of several correction functions in the database.
+This is to prevent arbitrary editing of the database by unscrupulous users.
+
+=back
+
+=cut
+
+sub correct {
+    
+    my $recon = LedgerSMB::DBObject::Reconciliation->new(base => $request, copy => 'all');
+     
+    my $template = LedgerSMB::Template->new( user => $user, 
+	template => 'reconciliation_correct.html', language => $user->{language}, 
+        format => 'html');
+    $recon->correct_entry();
+    $template->render($recon->get_report());
+}
+
+=pod
+
+=over
+
+=item new_report ($self, $request, $user)
+
+Creates a new report, from a selectable set of bank statements that have been
+received (or can be received from, depending on implementation)
+
+Allows for an optional selection key, which will return the new report after
+it has been created.
+
+=back
+
+=cut
+
+sub new_report {
+    # how are we going to allow this to be created? Grr.
+    # probably select a list of statements that are available to build 
+    # reconciliation reports with.
+    
+    my $template;
+    my $recon = LedgerSMB::DBObject::Reconciliation->new(base => $request, copy => 'all');
+    my $return;
+    if ($request->{selection}) {
+        
+        $template = LedgerSMB::Template->new( user => $user, 
+    	template => 'reconciliation_report.html', language => $user->{language}, 
+            format => 'html');
+            
+        $template->render($recon->new_report());
+    } 
+    else {
+        
+        # Generate the list of available bank statements/bank statements that
+        # we have access to.
+    }
+    return $return;
+    
+}
+
+=pod
+
+=over
+
+=item ($self, $request, $user)
+
+Requires report_id
+
+Approves the given report based on id. Generally, the roles should be 
+configured so as to disallow the same user from approving, as created the report.
+
+Returns a success page on success, returns a new report on failure, showing 
+the uncorrected entries.
+
+=back
+
+=cut
+
+sub approve {
+    
+    my $recon = LedgerSMB::DBObject::Reconciliation->new(base => request, copy=> 'all');
+    
+    my $template;
+    my $report;
+    if ($recon->approve()) {
+        
+        $template = LedgerSMB::Template->new( user => $user, 
+    	template => 'reconciliation_approve.html', language => $user->{language}, 
+            format => 'html');
+    }
+    else {
+        
+        $template = LedgerSMB::Template->new( user => $user, 
+    	template => 'reconciliation_report.html', language => $user->{language}, 
+            format => 'html');
+        $report = $recon->get_report();
+        ## relies on foreknowledge in the template
+        ## we basically tell the template, we can't approve, this uncorrected
+        ## error is preventing us.
+        $report->{ error } = { approval => 1 }; 
+    }
+    $template->render($report);
+}
+1;
\ No newline at end of file
diff --git a/scripts/employees.pl b/scripts/employees.pl
new file mode 100644
index 00000000..fa9ec05f
--- /dev/null
+++ b/scripts/employees.pl
@@ -0,0 +1,43 @@
+# The handler, prior to handing the execution off to this script will create a
+# $request object from the LedgerSMB namespace.  This object contains the http
+# request parameters, db connections, and the like.  A $user object is also 
+# created
+#
+# Entrence points are functions which do not begin with an underscore (_)
+use LedgerSMB::Template;
+
+sub save {
+    my $employee = LedgerSMB::Employee->new(base => $request, copy => 'all');
+    $employee->save();
+    &_display;
+}
+
+sub search {
+    my $search = LedgerSMB::Employee->new(base => $request, copy => 'all');
+    $employee->{search_results} = $employee->search();
+    my $template = LedgerSMB::Template->new( user => $user, 
+	template => 'employee_search.html', language => $user->{language}, 
+        format => 'html');
+    $template->render($employee);
+}
+
+sub add {
+    my $employee = LedgerSMB::Employee->new(base => $request, copy => 'all');
+    &_display;
+}
+
+sub edit {
+    my $employee = LedgerSMB::Employee->new(base => $request, copy => 'all');
+    $employee->get();
+    &_display;
+}
+
+sub _display {
+    my $template = LedgerSMB::Template->new( user => $user, 
+	template => 'employee.html', language => $user->{language}, 
+        format => 'html');
+    $template->render($employee);
+
+}
+
+1;
-- 
cgit v1.2.3