[open-ils-commits] [GIT] Evergreen ILS branch master updated. 906ccbb6679f04518e7af0fbf651b4e473a68fdc
Evergreen Git
git at git.evergreen-ils.org
Tue Aug 14 16:32:18 EDT 2012
This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "Evergreen ILS".
The branch, master has been updated
via 906ccbb6679f04518e7af0fbf651b4e473a68fdc (commit)
via 2b900d3ce4440174d94bf30e12a51f786297be8a (commit)
via 7713b1782558d275b783d18d3c618c9756f556f1 (commit)
from aac4d806af6b3eaebc15a660c99c0f39eb49f14d (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
- Log -----------------------------------------------------------------
commit 906ccbb6679f04518e7af0fbf651b4e473a68fdc
Author: Bill Erickson <berick at esilibrary.com>
Date: Fri Aug 10 14:59:50 2012 -0400
Default to current fiscal year in ACQ order upload
* Adds a new API call to determine the current fiscal year for a given
org unit: open-ils.acq.org_unit.current_fiscal_year
* Use open-ils.acq.org_unit.current_fiscal_year to populate the correct
fiscal year in the ACQ order upload selector.
This addresses part 2 of LP 1031927
Signed-off-by: Bill Erickson <berick at esilibrary.com>
Signed-off-by: Lebbeous Fogle-Weekley <lebbeous at esilibrary.com>
diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Financials.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Financials.pm
index df0d3bc..217013a 100644
--- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Financials.pm
+++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Financials.pm
@@ -1347,6 +1347,43 @@ sub process_fiscal_rollover {
return undef;
}
+__PACKAGE__->register_method(
+ method => 'org_fiscal_year',
+ api_name => 'open-ils.acq.org_unit.current_fiscal_year',
+ signature => {
+ desc => q/
+ Returns the current fiscal year for the given org unit.
+ If no fiscal year is configured, the current calendar
+ year is returned.
+ /,
+ params => [
+ {desc => 'Authentication token', type => 'string'},
+ {desc => 'Org unit ID', type => 'number'}
+ ],
+ return => {desc => 'Year as a string (e.g. "2012")'}
+ }
+);
+
+sub org_fiscal_year {
+ my($self, $conn, $auth, $org_id) = @_;
+
+ my $e = new_editor(authtoken => $auth);
+ return $e->event unless $e->checkauth;
+
+ my $year = $e->json_query({
+ select => {acqfy => ['year']},
+ from => {acqfy => {acqfc => {join => 'aou'}}},
+ where => {
+ '+acqfy' => {
+ year_begin => {'<=' => 'now'},
+ year_end => {'>=' => 'now'},
+ },
+ '+aou' => {id => $org_id}
+ }
+ })->[0];
+
+ return $year ? $year->{year} : DateTime->now->year;
+}
1;
diff --git a/Open-ILS/web/js/ui/default/acq/picklist/upload.js b/Open-ILS/web/js/ui/default/acq/picklist/upload.js
index 1361685..1eb2933 100644
--- a/Open-ILS/web/js/ui/default/acq/picklist/upload.js
+++ b/Open-ILS/web/js/ui/default/acq/picklist/upload.js
@@ -39,7 +39,10 @@ function init() {
orgLimitPerms : ['CREATE_PICKLIST', 'CREATE_PURCHASE_ORDER'],
parentNode : dojo.byId('acq-pl-upload-agency'),
}).build(
- function(w) { orderAgencyWidget = w }
+ function(w) {
+ orderAgencyWidget = w
+ dojo.connect(orderAgencyWidget, 'onChange', setDefaultFiscalYear);
+ }
);
vlAgent = new VLAgent();
@@ -58,6 +61,24 @@ function init() {
);
}
+function setDefaultFiscalYear(org) {
+ org = org || orderAgencyWidget.attr('value');
+
+ if (org) {
+
+ fieldmapper.standardRequest(
+ ['open-ils.acq', 'open-ils.acq.org_unit.current_fiscal_year'],
+ { params : [openils.User.authtoken, org],
+ async : true,
+ oncomplete : function(r) {
+ var year = openils.Util.readResponse(r);
+ acqUploadYearSelector.attr('value', year);
+ }
+ }
+ );
+ }
+}
+
function acqUploadRecords() {
openils.Util.show('acq-pl-upload-progress');
var picklist = acqPlUploadPlSelector.attr('value');
@@ -180,9 +201,9 @@ function loadYearSelector() {
yearStore.items = yearStore.items.sort().reverse();
acqUploadYearSelector.store = new dojo.data.ItemFileReadStore({data:yearStore});
- // default to this year
- // TODO: current fiscal year
- acqUploadYearSelector.setValue(new Date().getFullYear().toString());
+ // until an ordering agency is selected, default to the
+ // fiscal year of the workstation
+ setDefaultFiscalYear(new openils.User().user.ws_ou());
}
}
);
commit 2b900d3ce4440174d94bf30e12a51f786297be8a
Author: Bill Erickson <berick at esilibrary.com>
Date: Fri Aug 10 14:59:29 2012 -0400
Enable pcrud access to fiscal year / fiscal calendar
Signed-off-by: Bill Erickson <berick at esilibrary.com>
Signed-off-by: Lebbeous Fogle-Weekley <lebbeous at esilibrary.com>
diff --git a/Open-ILS/examples/fm_IDL.xml b/Open-ILS/examples/fm_IDL.xml
index 739bf83..f7ef3fa 100644
--- a/Open-ILS/examples/fm_IDL.xml
+++ b/Open-ILS/examples/fm_IDL.xml
@@ -7003,7 +7003,7 @@ SELECT usr,
</links>
</class>
- <class id="acqfc" controller="open-ils.cstore" oils_obj:fieldmapper="acq::fiscal_calendar" oils_persist:tablename="acq.fiscal_calendar" reporter:label="Fiscal Calendar">
+ <class id="acqfc" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="acq::fiscal_calendar" oils_persist:tablename="acq.fiscal_calendar" reporter:label="Fiscal Calendar">
<fields oils_persist:primary="id" oils_persist:sequence="acq.fiscal_calendar_id_seq">
<field reporter:label="Fiscal Calendar ID" name="id" reporter:datatype="id" reporter:selector='name'/>
<field reporter:label="Fiscal Calendar Name" name="name" reporter:datatype="text"/>
@@ -7012,21 +7012,17 @@ SELECT usr,
<links>
<link field="years" reltype="has_many" map="" key="calendar" class="acqfy"/>
</links>
- <!--
- For now, we don't have pcrud as one of the controllers, so the permacrud section is moot.
- But here's what it should look like if we ever do use pcrud.
- -->
<permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
<actions>
<create permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
- <retrieve permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
+ <retrieve permission="STAFF_LOGIN" global_required="true"/>
<update permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
<delete permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
</actions>
</permacrud>
</class>
- <class id="acqfy" controller="open-ils.cstore" oils_obj:fieldmapper="acq::fiscal_year" oils_persist:tablename="acq.fiscal_year" reporter:label="Fiscal Year">
+ <class id="acqfy" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="acq::fiscal_year" oils_persist:tablename="acq.fiscal_year" reporter:label="Fiscal Year">
<fields oils_persist:primary="id" oils_persist:sequence="acq.fiscal_year_id_seq">
<field reporter:label="Fiscal Year ID" name="id" reporter:datatype="id" reporter:selector='year'/>
<field reporter:label="Calendar" name="calendar" reporter:datatype="link"/>
@@ -7037,14 +7033,10 @@ SELECT usr,
<links>
<link field="calendar" reltype="has_a" key="id" map="" class="acqfc"/>
</links>
- <!--
- For now, we don't have pcrud as one of the controllers, so the permacrud section is moot.
- But here's what it should look like if we ever do use pcrud.
- -->
<permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
<actions>
<create permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
- <retrieve permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
+ <retrieve permission="STAFF_LOGIN" global_required="true"/>
<update permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
<delete permission="ADMIN_ACQ_FISCAL_YEAR" global_required="true"/>
</actions>
commit 7713b1782558d275b783d18d3c618c9756f556f1
Author: Bill Erickson <berick at esilibrary.com>
Date: Fri Aug 10 14:06:36 2012 -0400
Fiscal year selector in ACQ order record upload
* Support a 'fiscal_year' parameter to ACQ order record upload API.
* Adds a new "Fiscal Year" selector to the upload form to facilitate
uploading orders to different fiscal years.
This partially resolves LP 1031927 by allowing manual selection of the
correct fiscal year.
Signed-off-by: Bill Erickson <berick at esilibrary.com>
Signed-off-by: Lebbeous Fogle-Weekley <lebbeous at esilibrary.com>
diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Order.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Order.pm
index aa8a45d..8bbb550 100644
--- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Order.pm
+++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Acq/Order.pm
@@ -1331,6 +1331,7 @@ sub upload_records {
my $activate_po = $args->{activate_po};
my $vandelay = $args->{vandelay};
my $ordering_agency = $args->{ordering_agency} || $e->requestor->ws_ou;
+ my $fiscal_year = $args->{fiscal_year} || DateTime->now->year;
my $po;
my $evt;
@@ -1410,7 +1411,8 @@ sub upload_records {
$mgr->respond;
$li->provider($provider); # flesh it, we'll need it later
- import_lineitem_details($mgr, $ordering_agency, $li) or return $mgr->editor->die_event;
+ import_lineitem_details($mgr, $ordering_agency, $li, $fiscal_year)
+ or return $mgr->editor->die_event;
$mgr->respond;
push(@li_list, $li->id);
@@ -1478,7 +1480,7 @@ sub extract_po_name {
}
sub import_lineitem_details {
- my($mgr, $ordering_agency, $li) = @_;
+ my($mgr, $ordering_agency, $li, $fiscal_year) = @_;
my $holdings = $mgr->editor->json_query({from => ['acq.extract_provider_holding_data', $li->id]});
return 1 unless @$holdings;
@@ -1491,7 +1493,7 @@ sub import_lineitem_details {
while(1) {
# create a lineitem detail for each copy in the data
- my $compiled = extract_lineitem_detail_data($mgr, $org_path, $holdings, $idx);
+ my $compiled = extract_lineitem_detail_data($mgr, $org_path, $holdings, $idx, $fiscal_year);
last unless defined $compiled;
return 0 unless $compiled;
@@ -1527,7 +1529,7 @@ sub import_lineitem_details {
# return hash on success, 0 on error, undef on no more holdings
sub extract_lineitem_detail_data {
- my($mgr, $org_path, $holdings, $index) = @_;
+ my($mgr, $org_path, $holdings, $index, $fiscal_year) = @_;
my @data_list = grep { $_->{holding} eq $index } @$holdings;
return undef unless @data_list;
@@ -1553,7 +1555,7 @@ sub extract_lineitem_detail_data {
# search up the org tree for the most appropriate fund
for my $org (@$org_path) {
$fund = $mgr->editor->search_acq_fund(
- {org => $org, code => $code, year => DateTime->now->year}, {idlist => 1})->[0];
+ {org => $org, code => $code, year => $fiscal_year}, {idlist => 1})->[0];
last if $fund;
}
}
diff --git a/Open-ILS/src/templates/acq/picklist/upload.tt2 b/Open-ILS/src/templates/acq/picklist/upload.tt2
index 6d04d7f..d88bd23 100644
--- a/Open-ILS/src/templates/acq/picklist/upload.tt2
+++ b/Open-ILS/src/templates/acq/picklist/upload.tt2
@@ -32,6 +32,16 @@
<select jsId='acqPlUploadPlSelector' dojoType='dijit.form.ComboBox'></select>
</td>
</tr>
+ <tr id='acq-pl-upload-year'>
+ <td>[% l('Fiscal Year') %]</td>
+ <td>
+ <select dojoType="dijit.form.FilteringSelect"
+ jsId="acqUploadYearSelector"
+ labelAttr="year"
+ searchAttr="year">
+ </select>
+ </td>
+ </tr>
<tr><td colspan='2'><hr/></td></tr>
[% PROCESS vlagent_form vl_show_copy_option=1 %]
diff --git a/Open-ILS/web/js/ui/default/acq/picklist/upload.js b/Open-ILS/web/js/ui/default/acq/picklist/upload.js
index 1a6653a..1361685 100644
--- a/Open-ILS/web/js/ui/default/acq/picklist/upload.js
+++ b/Open-ILS/web/js/ui/default/acq/picklist/upload.js
@@ -22,6 +22,8 @@ var usingNewPl = false;
function init() {
dojo.byId('acq-pl-upload-ses').value = openils.User.authtoken;
+ loadYearSelector();
+
new openils.widget.AutoFieldWidget({
fmClass : 'acqpo',
fmField : 'provider',
@@ -104,7 +106,8 @@ function acqHandlePostUpload(key, plId) {
ordering_agency : orderAgencyWidget.attr('value'),
create_po : acqPlUploadCreatePo.attr('value'),
activate_po : acqPlUploadActivatePo.attr('value'),
- vandelay : vlAgent.values()
+ vandelay : vlAgent.values(),
+ fiscal_year : acqUploadYearSelector.attr('value')
};
fieldmapper.standardRequest(
@@ -161,6 +164,31 @@ function acqHandlePostUpload(key, plId) {
);
}
+function loadYearSelector() {
+
+ fieldmapper.standardRequest(
+ ['open-ils.acq', 'open-ils.acq.fund.org.years.retrieve'],
+ { async : true,
+ params : [openils.User.authtoken, {}, {limit_perm : 'VIEW_FUND'}],
+ oncomplete : function(r) {
+
+ var yearList = openils.Util.readResponse(r);
+ if(!yearList) return;
+ yearList = yearList.map(function(year){return {year:year+''};}); // dojo wants strings
+
+ var yearStore = {identifier:'year', name:'year', items:yearList};
+ yearStore.items = yearStore.items.sort().reverse();
+ acqUploadYearSelector.store = new dojo.data.ItemFileReadStore({data:yearStore});
+
+ // default to this year
+ // TODO: current fiscal year
+ acqUploadYearSelector.setValue(new Date().getFullYear().toString());
+ }
+ }
+ );
+}
+
+
openils.Util.addOnLoad(init);
-----------------------------------------------------------------------
Summary of changes:
Open-ILS/examples/fm_IDL.xml | 16 ++-----
.../lib/OpenILS/Application/Acq/Financials.pm | 37 ++++++++++++++
.../perlmods/lib/OpenILS/Application/Acq/Order.pm | 12 +++--
Open-ILS/src/templates/acq/picklist/upload.tt2 | 10 ++++
Open-ILS/web/js/ui/default/acq/picklist/upload.js | 53 +++++++++++++++++++-
5 files changed, 109 insertions(+), 19 deletions(-)
hooks/post-receive
--
Evergreen ILS
More information about the open-ils-commits
mailing list