[% FOR note IN li.lineitem_notes %]
[% IF note.vendor_public == 't' %]
[% note.value %]
[% END %]
[% END %]
[% END %]
Subtotal
[% subtotal %]
Total Line Item Count: [% target.lineitems.size %]
$$);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(4, 'lineitems.lineitem_details.fund'),
(4, 'lineitems.lineitem_details.location'),
(4, 'lineitems.lineitem_details.owning_lib'),
(4, 'ordering_agency.mailing_address'),
(4, 'ordering_agency.billing_address'),
(4, 'provider.addresses'),
(4, 'lineitems.attributes'),
(4, 'lineitems.lineitem_notes'),
(4, 'notes');
INSERT INTO action_trigger.cleanup ( module, description ) VALUES (
'CreateHoldNotification',
oils_i18n_gettext(
'CreateHoldNotification',
'Creates a hold_notification record for each notified hold',
'atclean',
'description'
)
);
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, delay, delay_field, group_field, cleanup_success, template)
VALUES (5, 'f', 1, 'Hold Ready for Pickup Email Notification', 'hold.available', 'HoldIsAvailable', 'SendEmail', '30 minutes', 'shelf_time', 'usr', 'CreateHoldNotification',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Hold Available Notification
Dear [% user.family_name %], [% user.first_given_name %]
The item(s) you requested are available for pickup from the Library.
[% FOR hold IN target %]
Title: [% hold.current_copy.call_number.record.simple_record.title %]
Author: [% hold.current_copy.call_number.record.simple_record.author %]
Call Number: [% hold.current_copy.call_number.label %]
Barcode: [% hold.current_copy.barcode %]
Library: [% hold.pickup_lib.name %]
[% END %]
$$);
INSERT INTO action_trigger.hook (
key,
core_type,
description,
passive
) VALUES (
'hold_request.shelf_expires_soon',
'ahr',
'A hold on the shelf will expire there soon.',
TRUE
);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(5, 'current_copy.call_number.record.simple_record'),
(5, 'usr'),
(5, 'pickup_lib.billing_address');
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
delay,
delay_field,
group_field,
template
) VALUES (
7,
FALSE,
1,
'Hold Expires from Shelf Soon',
'hold_request.shelf_expires_soon',
'HoldIsAvailable',
'SendEmail',
'- 1 DAY',
'shelf_expire_time',
'usr',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Hold Available Notification
Dear [% user.family_name %], [% user.first_given_name %]
You requested holds on the following item(s), which are available for
pickup, but these holds will soon expire.
[% FOR hold IN target %]
[%- data = helpers.get_copy_bib_basics(hold.current_copy.id) -%]
Title: [% data.title %]
Author: [% data.author %]
Library: [% hold.pickup_lib.name %]
[% END %]
$$
);
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES
( 7, 'current_copy'),
( 7, 'pickup_lib.billing_address'),
( 7, 'usr');
-- long wait hold request notifications
INSERT INTO action_trigger.hook (
key,
core_type,
description,
passive
) VALUES (
'hold_request.long_wait',
'ahr',
'A patron has been waiting on a hold to be fulfilled for a long time.',
TRUE
);
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
delay,
delay_field,
group_field,
template
) VALUES (
9,
FALSE,
1,
'Hold waiting for pickup for long time',
'hold_request.long_wait',
'NOOP_True',
'SendEmail',
'6 MONTHS',
'request_time',
'usr',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Long Wait Hold Notification
Dear [% user.family_name %], [% user.first_given_name %]
You requested hold(s) on the following item(s), but unfortunately
we have not been able to fulfill your request after a considerable
length of time. If you would still like to receive these items,
no action is required.
[% FOR hold IN target %]
Title: [% hold.bib_rec.bib_record.simple_record.title %]
Author: [% hold.bib_rec.bib_record.simple_record.author %]
[% END %]
$$
);
INSERT INTO action_trigger.environment (event_def, path)
VALUES
(9, 'pickup_lib'),
(9, 'usr'),
(9, 'bib_rec.bib_record.simple_record');
-- trigger data related to acq user requests
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES (
'aur.ordered',
'aur',
oils_i18n_gettext(
'aur.ordered',
'A patron acquisition request has been marked On-Order.',
'ath',
'description'
),
TRUE
), (
'aur.received',
'aur',
oils_i18n_gettext(
'aur.received',
'A patron acquisition request has been marked Received.',
'ath',
'description'
),
TRUE
), (
'aur.cancelled',
'aur',
oils_i18n_gettext(
'aur.cancelled',
'A patron acquisition request has been marked Cancelled.',
'ath',
'description'
),
TRUE
), (
'aur.created',
'aur',
oils_i18n_gettext(
'aur.created',
'A patron has made an acquisitions request.',
'ath',
'description'
),
TRUE
), (
'aur.rejected',
'aur',
oils_i18n_gettext(
'aur.rejected',
'A patron acquisition request has been rejected.',
'ath',
'description'
),
TRUE
)
;
INSERT INTO action_trigger.validator (module,description) VALUES (
'Acq::UserRequestOrdered',
oils_i18n_gettext(
'Acq::UserRequestOrdered',
'Tests to see if the corresponding Line Item has a state of "on-order".',
'atval',
'description'
)
), (
'Acq::UserRequestReceived',
oils_i18n_gettext(
'Acq::UserRequestReceived',
'Tests to see if the corresponding Line Item has a state of "received".',
'atval',
'description'
)
), (
'Acq::UserRequestCancelled',
oils_i18n_gettext(
'Acq::UserRequestCancelled',
'Tests to see if the corresponding Line Item has a state of "cancelled".',
'atval',
'description'
)
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
template
) VALUES (
15,
FALSE,
1,
'Email Notice: Patron Acquisition Request marked On-Order.',
'aur.ordered',
'Acq::UserRequestOrdered',
'SendEmail',
$$
[%- USE date -%]
[%- SET li = target.lineitem; -%]
[%- SET user = target.usr -%]
[%- SET title = helpers.get_li_attr("title", "", li.attributes) -%]
[%- SET author = helpers.get_li_attr("author", "", li.attributes) -%]
[%- SET edition = helpers.get_li_attr("edition", "", li.attributes) -%]
[%- SET isbn = helpers.get_li_attr("isbn", "", li.attributes) -%]
[%- SET publisher = helpers.get_li_attr("publisher", "", li.attributes) -%]
[%- SET pubdate = helpers.get_li_attr("pubdate", "", li.attributes) -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Acquisition Request Notification
Dear [% user.family_name %], [% user.first_given_name %]
Our records indicate the following acquisition request has been placed on order.
Title: [% title %]
[% IF author %]Author: [% author %][% END %]
[% IF edition %]Edition: [% edition %][% END %]
[% IF isbn %]ISBN: [% isbn %][% END %]
[% IF publisher %]Publisher: [% publisher %][% END %]
[% IF pubdate %]Publication Date: [% pubdate %][% END %]
Lineitem ID: [% li.id %]
$$
), (
16,
FALSE,
1,
'Email Notice: Patron Acquisition Request marked Received.',
'aur.received',
'Acq::UserRequestReceived',
'SendEmail',
$$
[%- USE date -%]
[%- SET li = target.lineitem; -%]
[%- SET user = target.usr -%]
[%- SET title = helpers.get_li_attr("title", "", li.attributes) %]
[%- SET author = helpers.get_li_attr("author", "", li.attributes) %]
[%- SET edition = helpers.get_li_attr("edition", "", li.attributes) %]
[%- SET isbn = helpers.get_li_attr("isbn", "", li.attributes) %]
[%- SET publisher = helpers.get_li_attr("publisher", "", li.attributes) -%]
[%- SET pubdate = helpers.get_li_attr("pubdate", "", li.attributes) -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Acquisition Request Notification
Dear [% user.family_name %], [% user.first_given_name %]
Our records indicate the materials for the following acquisition request have been received.
Title: [% title %]
[% IF author %]Author: [% author %][% END %]
[% IF edition %]Edition: [% edition %][% END %]
[% IF isbn %]ISBN: [% isbn %][% END %]
[% IF publisher %]Publisher: [% publisher %][% END %]
[% IF pubdate %]Publication Date: [% pubdate %][% END %]
Lineitem ID: [% li.id %]
$$
), (
17,
FALSE,
1,
'Email Notice: Patron Acquisition Request marked Cancelled.',
'aur.cancelled',
'Acq::UserRequestCancelled',
'SendEmail',
$$
[%- USE date -%]
[%- SET li = target.lineitem; -%]
[%- SET user = target.usr -%]
[%- SET title = helpers.get_li_attr("title", "", li.attributes) %]
[%- SET author = helpers.get_li_attr("author", "", li.attributes) %]
[%- SET edition = helpers.get_li_attr("edition", "", li.attributes) %]
[%- SET isbn = helpers.get_li_attr("isbn", "", li.attributes) %]
[%- SET publisher = helpers.get_li_attr("publisher", "", li.attributes) -%]
[%- SET pubdate = helpers.get_li_attr("pubdate", "", li.attributes) -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Acquisition Request Notification
Dear [% user.family_name %], [% user.first_given_name %]
Our records indicate the following acquisition request has been cancelled.
Title: [% title %]
[% IF author %]Author: [% author %][% END %]
[% IF edition %]Edition: [% edition %][% END %]
[% IF isbn %]ISBN: [% isbn %][% END %]
[% IF publisher %]Publisher: [% publisher %][% END %]
[% IF pubdate %]Publication Date: [% pubdate %][% END %]
Lineitem ID: [% li.id %]
$$
), (
18,
FALSE,
1,
'Email Notice: Acquisition Request created.',
'aur.created',
'NOOP_True',
'SendEmail',
$$
[%- USE date -%]
[%- SET user = target.usr -%]
[%- SET title = target.title -%]
[%- SET author = target.author -%]
[%- SET isxn = target.isxn -%]
[%- SET publisher = target.publisher -%]
[%- SET pubdate = target.pubdate -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Acquisition Request Notification
Dear [% user.family_name %], [% user.first_given_name %]
Our records indicate that you have made the following acquisition request:
Title: [% title %]
[% IF author %]Author: [% author %][% END %]
[% IF edition %]Edition: [% edition %][% END %]
[% IF isbn %]ISXN: [% isxn %][% END %]
[% IF publisher %]Publisher: [% publisher %][% END %]
[% IF pubdate %]Publication Date: [% pubdate %][% END %]
$$
), (
19,
FALSE,
1,
'Email Notice: Acquisition Request Rejected.',
'aur.rejected',
'NOOP_True',
'SendEmail',
$$
[%- USE date -%]
[%- SET user = target.usr -%]
[%- SET title = target.title -%]
[%- SET author = target.author -%]
[%- SET isxn = target.isxn -%]
[%- SET publisher = target.publisher -%]
[%- SET pubdate = target.pubdate -%]
[%- SET cancel_reason = target.cancel_reason.description -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Acquisition Request Notification
Dear [% user.family_name %], [% user.first_given_name %]
Our records indicate the following acquisition request has been rejected for this reason: [% cancel_reason %]
Title: [% title %]
[% IF author %]Author: [% author %][% END %]
[% IF edition %]Edition: [% edition %][% END %]
[% IF isbn %]ISBN: [% isbn %][% END %]
[% IF publisher %]Publisher: [% publisher %][% END %]
[% IF pubdate %]Publication Date: [% pubdate %][% END %]
$$
)
;
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES
( 15, 'lineitem' ),
( 15, 'lineitem.attributes' ),
( 15, 'usr' ),
( 16, 'lineitem' ),
( 16, 'lineitem.attributes' ),
( 16, 'usr' ),
( 17, 'lineitem' ),
( 17, 'lineitem.attributes' ),
( 17, 'usr' ),
( 18, 'usr' ),
( 19, 'usr' ),
( 19, 'cancel_reason' )
;
INSERT INTO action_trigger.hook (key,core_type,description) VALUES ('password.reset_request','aupr','Patron has requested a self-serve password reset');
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, delay, template)
VALUES (20, 'f', 1, 'Password reset request notification', 'password.reset_request', 'NOOP_True', 'SendEmail', '00:00:01',
$$
[%- USE date -%]
[%- user = target.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || user.home_ou.email || default_sender %]
Subject: [% user.home_ou.name %]: library account password reset request
You have received this message because you, or somebody else, requested a reset
of your library system password. If you did not request a reset of your library
system password, just ignore this message and your current password will
continue to work.
If you did request a reset of your library system password, please perform
the following steps to continue the process of resetting your password:
1. Open the following link in a web browser: https://[% params.hostname %]/eg/opac/password_reset/[% target.uuid %]
The browser displays a password reset form.
2. Enter your new password in the password reset form in the browser. You must
enter the password twice to ensure that you do not make a mistake. If the
passwords match, you will then be able to log in to your library system account
with the new password.
$$);
INSERT INTO action_trigger.environment ( event_def, path) VALUES
( 20, 'usr' );
INSERT INTO action_trigger.environment ( event_def, path) VALUES
( 20, 'usr.home_ou' );
INSERT INTO action_trigger.hook (key, core_type, description, passive)
VALUES (
'format.acqcle.html',
'acqcle',
'Formats claim events into a voucher',
TRUE
);
INSERT INTO action_trigger.event_definition (
id, active, owner, name, hook, group_field,
validator, reactor, granularity, template
) VALUES (
21,
TRUE,
1,
'Claim Voucher',
'format.acqcle.html',
'claim',
'NOOP_True',
'ProcessTemplate',
'print-on-demand',
$$
[%- USE date -%]
[%- SET claim = target.0.claim -%]
No. [% invoice.inv_ident %]
[% IF invoice.inv_type %]
/ Type:[% invoice.inv_type %]
[% END %]
[% BLOCK ent_with_address %]
[% ent_label %]: [% ent.name %] ([% ent.code %])
[% IF ent.addresses.0 %]
[% SET addr = ent.addresses.0 %]
[% addr.street1 %]
[% IF addr.street2 %][% addr.street2 %] [% END %]
[% addr.city %],
[% IF addr.county %] [% addr.county %], [% END %]
[% IF addr.state %] [% addr.state %] [% END %]
[% IF addr.post_code %][% addr.post_code %][% END %]
[% IF addr.country %] [% addr.country %] [% END %]
[% END %]
[% IF ent.phone %] Phone: [% ent.phone %] [% END %]
[% IF ent.fax_phone %] Fax: [% ent.fax_phone %] [% END %]
[% IF ent.url %] URL: [% ent.url %] [% END %]
[% IF ent.email %] E-mail: [% ent.email %] [% END %]
[% END %]
[% INCLUDE ent_with_address
ent = invoice.provider
ent_label = "Provider" %]
[% INCLUDE ent_with_address
ent = invoice.shipper
ent_label = "Shipper" %]
[% helpers.format_date(invoice.recv_date) %] by
[% invoice.recv_method %]
[% IF invoice.note %]
Note
[% invoice.note %]
[% END %]
[% FOR entry IN invoice.entries %]
[% IF entry.lineitem %]
Title: [% helpers.get_li_attr(
"title", "", entry.lineitem.attributes
) %]
Author: [% helpers.get_li_attr(
"author", "", entry.lineitem.attributes
) %]
[% END %]
[% IF entry.purchase_order %]
(PO: [% entry.purchase_order.name %])
[% END %]
Invoice item count: [% entry.inv_item_count %]
[% IF entry.phys_item_count %]
/ Physical item count: [% entry.phys_item_count %]
[% END %]
[% IF entry.cost_billed %]
Cost billed: [% entry.cost_billed %]
[% IF entry.billed_per_item %](per item)[% END %]
[% END %]
[% IF entry.actual_cost %]
Actual cost: [% entry.actual_cost %]
[% END %]
[% IF entry.amount_paid %]
Amount paid: [% entry.amount_paid %]
[% END %]
[% IF entry.note %]Note: [% entry.note %][% END %]
[% END %]
[% FOR item IN invoice.items %]
[% IF item.inv_item_type %]
Item Type: [% item.inv_item_type %]
[% END %]
[% IF item.title %]Title/Description:
[% item.title %]
[% END %]
[% IF item.author %]Author: [% item.author %] [% END %]
[% IF item.purchase_order %]PO: [% item.purchase_order %] [% END %]
[% IF item.note %]Note: [% item.note %] [% END %]
[% IF item.cost_billed %]
Cost billed: [% item.cost_billed %]
[% END %]
[% IF item.actual_cost %]
Actual cost: [% item.actual_cost %]
[% END %]
[% IF item.amount_paid %]
Amount paid: [% item.amount_paid %]
[% END %]
[% END %]
Amounts spent per fund:
[% FOR blob IN user_data %]
[% blob.fund.code %] ([% blob.fund.year %]):
$[% blob.total %]
[% END %]
[% END %]$$
);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(22, 'provider'),
(22, 'provider.addresses'),
(22, 'shipper'),
(22, 'shipper.addresses'),
(22, 'receiver'),
(22, 'entries'),
(22, 'entries.purchase_order'),
(22, 'entries.lineitem'),
(22, 'entries.lineitem.attributes'),
(22, 'items')
;
SELECT SETVAL('action_trigger.event_definition_id_seq'::TEXT, 100);
-- Hold cancel action/trigger hooks
INSERT INTO action_trigger.hook (key,core_type,description) VALUES (
'hold_request.cancel.expire_no_target',
'ahr',
'A hold is cancelled because no copies were found'
);
INSERT INTO action_trigger.hook (key,core_type,description) VALUES (
'hold_request.cancel.expire_holds_shelf',
'ahr',
'A hold is cancelled because it was on the holds shelf too long'
);
INSERT INTO action_trigger.hook (key,core_type,description) VALUES (
'hold_request.cancel.staff',
'ahr',
'A hold is cancelled because it was cancelled by staff'
);
INSERT INTO action_trigger.hook (key,core_type,description) VALUES (
'hold_request.cancel.patron',
'ahr',
'A hold is cancelled by the patron'
);
-- in-db indexing normalizers
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'NACO Normalize',
'Apply NACO normalization rules to the extracted text. See http://www.loc.gov/catdir/pcc/naco/normrule-2.html for details.',
'naco_normalize',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Normalize date range',
'Split date ranges in the form of "XXXX-YYYY" into "XXXX YYYY" for proper index.',
'split_date_range',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'NACO Normalize -- retain first comma',
'Apply NACO normalization rules to the extracted text, retaining the first comma. See http://www.loc.gov/catdir/pcc/naco/normrule-2.html for details.',
'naco_normalize_keep_comma',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Strip Diacritics',
'Convert text to NFD form and remove non-spacing combining marks.',
'remove_diacritics',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Remove Parenthesized Substring',
'Remove any parenthesized substrings from the extracted text, such as the agency code preceding authority record control numbers in subfield 0.',
'remove_paren_substring',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Up-case',
'Convert text upper case.',
'uppercase',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Down-case',
'Convert text lower case.',
'lowercase',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Extract Dewey-like number',
'Extract a string of numeric characters that resembles a DDC number.',
'call_number_dewey',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Left truncation',
'Discard the specified number of characters from the left side of the string.',
'left_trunc',
1
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Right truncation',
'Include only the specified number of characters from the left side of the string.',
'right_trunc',
1
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'First word',
'Include only the first space-separated word of a string.',
'first_word',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'ISBN 10/13 conversion',
'Translate ISBN10 to ISBN13 and vice versa.',
'translate_isbn1013',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Replace',
'Replace all occurences of first parameter in the string with the second parameter.',
'replace',
2
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Trim Surrounding Space',
'Trim leading and trailing spaces from extracted text.',
'btrim',
0
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Generic Mapping Normalizer',
'Map values or sets of values to new values',
'generic_map_normalizer',
1
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Coded Value Map Normalizer',
'Applies coded_value_map mapping of values',
'coded_value_map_normalizer',
1
);
INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES (
'Search Normalize',
'Apply search normalization rules to the extracted text. A less extreme version of NACO normalization.',
'search_normalize',
0
);
-- make use of the index normalizers
INSERT INTO config.metabib_field_index_norm_map (field,norm)
SELECT m.id,
i.id
FROM config.metabib_field m,
config.index_normalizer i
WHERE i.func IN ('search_normalize','split_date_range')
AND m.id NOT IN (18, 19);
INSERT INTO config.metabib_field_index_norm_map (field,norm,pos)
SELECT m.id,
i.id,
2
FROM config.metabib_field m,
config.index_normalizer i
WHERE i.func IN ('translate_isbn1013')
AND m.id IN (18);
INSERT INTO config.metabib_field_index_norm_map (field,norm,params)
SELECT m.id,
i.id,
$$["-",""]$$
FROM config.metabib_field m,
config.index_normalizer i
WHERE i.func IN ('replace')
AND m.id IN (19);
INSERT INTO config.metabib_field_index_norm_map (field,norm,params)
SELECT m.id,
i.id,
$$[" ",""]$$
FROM config.metabib_field m,
config.index_normalizer i
WHERE i.func IN ('replace')
AND m.id IN (19);
INSERT INTO config.metabib_field_index_norm_map (field,norm,pos)
SELECT m.id,
i.id,
-1
FROM config.metabib_field m,
config.index_normalizer i
WHERE i.func = 'remove_paren_substring'
AND m.id IN (28);
INSERT INTO config.record_attr_index_norm_map (attr,norm,pos)
SELECT m.name, i.id, 0
FROM config.record_attr_definition m,
config.index_normalizer i
WHERE i.func IN ('content_or_null')
AND m.name IN ('titlesort', 'authorsort');
INSERT INTO config.record_attr_index_norm_map (attr,norm,pos)
SELECT m.name, i.id, 0
FROM config.record_attr_definition m,
config.index_normalizer i
WHERE i.func IN ('integer_or_null')
AND m.name IN ('date1', 'date2', 'pubdate');
INSERT INTO config.record_attr_index_norm_map (attr,norm,pos)
SELECT m.name, i.id, 0
FROM config.record_attr_definition m,
config.index_normalizer i
WHERE i.func IN ('approximate_low_date')
AND m.name IN ('date1', 'pubdate');
INSERT INTO config.record_attr_index_norm_map (attr,norm,pos)
SELECT m.name, i.id, 0
FROM config.record_attr_definition m,
config.index_normalizer i
WHERE i.func IN ('approximate_high_date')
AND m.name IN ('date2');
-- Sample Pre-due Notice --
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, delay, delay_field, group_field, max_delay, template)
VALUES (6, 'f', 1, '3 Day Courtesy Notice', 'checkout.due', 'CircIsOpen', 'SendEmail', '-3 days', 'due_date', 'usr', '-2 days',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Courtesy Notice
Dear [% user.family_name %], [% user.first_given_name %]
As a reminder, the following items are due in 3 days.
[% FOR circ IN target %]
Title: [% circ.target_copy.call_number.record.simple_record.title %]
Barcode: [% circ.target_copy.barcode %]
Due: [% date.format(helpers.format_date(circ.due_date), '%Y-%m-%d') %]
Item Cost: [% helpers.get_copy_price(circ.target_copy) %]
Library: [% circ.circ_lib.name %]
Library Phone: [% circ.circ_lib.phone %]
[% END %]
$$);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(6, 'target_copy.call_number.record.simple_record'),
(6, 'usr'),
(6, 'circ_lib.billing_address');
-- Additional A/T Reactors
INSERT INTO action_trigger.reactor (module,description) VALUES
( 'ApplyPatronPenalty',
oils_i18n_gettext(
'ApplyPatronPenalty',
'Applies the configured penalty to a patron. Required named environment variables are "user", which refers to the user object, and "context_org", which refers to the org_unit object that acts as the focus for the penalty.',
'atreact',
'description'
)
);
INSERT INTO action_trigger.reactor (module,description) VALUES
( 'SendFile',
oils_i18n_gettext(
'SendFile',
'Build and transfer a file to a remote server. Required parameter "remote_host" specifying target server. Optional parameters: remote_user, remote_password, remote_account, port, type (FTP, SFTP or SCP), and debug.',
'atreact',
'description'
)
);
-- self-check checkout receipt
INSERT INTO action_trigger.hook (key, core_type, description, passive)
VALUES (
'format.selfcheck.checkout',
'circ',
'Formats circ objects for self-checkout receipt',
TRUE
);
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, group_field, granularity, template )
VALUES (
10,
TRUE,
1,
'Self-Checkout Receipt',
'format.selfcheck.checkout',
'NOOP_True',
'ProcessTemplate',
'usr',
'print-on-demand',
$$
[%- USE date -%]
[%- SET user = target.0.usr -%]
[%- SET lib = target.0.circ_lib -%]
[%- SET lib_addr = target.0.circ_lib.billing_address -%]
[%- SET hours = lib.hours_of_operation -%]
Open Holds: [% helpers.bre_open_hold_count(li.eg_bib_id) %]
[% IF li.distribution_formulas.size > 0 %]
[% SET forms = [] %]
[% FOREACH form IN li.distribution_formulas; forms.push(form.formula.name); END %]
Distribution Formulas: [% forms.join(',') %]
[% END %]
[% IF li.lineitem_notes.size > 0 %]
Lineitem Notes:
[%- FOR note IN li.lineitem_notes -%]
[% IF note.alert_text %]
[% note.alert_text.code -%]
[% IF note.value -%]
: [% note.value %]
[% END %]
[% ELSE %]
[% note.value -%]
[% END %]
[% END %]
[% END %]
Branch
Barcode
Call Number
Fund
Shelving Location
Recd.
Notes
[% FOREACH detail IN li.lineitem_details.sort('owning_lib') %]
[%
IF detail.eg_copy_id;
SET copy = detail.eg_copy_id;
SET cn_label = copy.call_number.label;
ELSE;
SET copy = detail;
SET cn_label = detail.cn_label;
END
%]
[% detail.owning_lib.shortname %]
[% IF copy.barcode %][% detail.barcode %][% END %]
[% IF cn_label %][% cn_label %][% END %]
[% IF detail.fund %][% detail.fund.code %] ([% detail.fund.year %])[% END %]
[% copy.location.name %]
[% IF detail.recv_time %][% detail.recv_time %][% END %]
[% detail.note %]
[% END %]
$$
);
INSERT INTO action_trigger.environment (event_def, path) VALUES
( 14, 'attributes' ),
( 14, 'lineitem_notes' ),
( 14, 'lineitem_notes.alert_text' ),
( 14, 'distribution_formulas.formula' ),
( 14, 'lineitem_details' ),
( 14, 'lineitem_details.owning_lib' ),
( 14, 'lineitem_details.fund' ),
( 14, 'lineitem_details.location' ),
( 14, 'lineitem_details.eg_copy_id' ),
( 14, 'lineitem_details.eg_copy_id.call_number' ),
( 14, 'lineitem_details.eg_copy_id.location' )
;
INSERT INTO action_trigger.environment ( event_def, path) VALUES
( 13, 'open_billable_transactions_summary.circulation' );
INSERT INTO action_trigger.validator (module, description)
VALUES (
'Acq::PurchaseOrderEDIRequired',
oils_i18n_gettext(
'Acq::PurchaseOrderEDIRequired',
'Purchase order is delivered via EDI',
'atval',
'description'
)
);
INSERT INTO action_trigger.reactor (module, description)
VALUES (
'GeneratePurchaseOrderJEDI',
oils_i18n_gettext(
'GeneratePurchaseOrderJEDI',
'Creates purchase order JEDI (JSON EDI) for subsequent EDI processing',
'atreact',
'description'
)
);
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, cleanup_success, cleanup_failure, delay, delay_field, group_field, template)
VALUES (23, true, 1, 'PO JEDI', 'acqpo.activated', 'Acq::PurchaseOrderEDIRequired', 'GeneratePurchaseOrderJEDI', NULL, NULL, '00:00:00', NULL, NULL,
$$[%- USE date -%]
[%# start JEDI document
# Vendor specific kludges:
# BT - vendcode goes to NAD/BY *suffix* w/ 91 qualifier
# INGRAM - vendcode goes to NAD/BY *segment* w/ 91 qualifier (separately)
# BRODART - vendcode goes to FTX segment (lineitem level)
-%]
[%-
IF target.provider.edi_default.vendcode && target.provider.code == 'BRODART';
xtra_ftx = target.provider.edi_default.vendcode;
END;
-%]
[%- BLOCK big_block -%]
{
"recipient":"[% target.provider.san %]",
"sender":"[% target.ordering_agency.mailing_address.san %]",
"body": [{
"ORDERS":[ "order", {
"po_number":[% target.id %],
"date":"[% date.format(date.now, '%Y%m%d') %]",
"buyer":[
[% IF target.provider.edi_default.vendcode && (target.provider.code == 'BT' || target.provider.name.match('(?i)^BAKER & TAYLOR')) -%]
{"id-qualifier": 91, "id":"[% target.ordering_agency.mailing_address.san _ ' ' _ target.provider.edi_default.vendcode %]"}
[%- ELSIF target.provider.edi_default.vendcode && target.provider.code == 'INGRAM' -%]
{"id":"[% target.ordering_agency.mailing_address.san %]"},
{"id-qualifier": 91, "id":"[% target.provider.edi_default.vendcode %]"}
[%- ELSE -%]
{"id":"[% target.ordering_agency.mailing_address.san %]"}
[%- END -%]
],
"vendor":[
[%- # target.provider.name (target.provider.id) -%]
"[% target.provider.san %]",
{"id-qualifier": 92, "id":"[% target.provider.id %]"}
],
"currency":"[% target.provider.currency_type %]",
"items":[
[%- FOR li IN target.lineitems %]
{
"line_index":"[% li.id %]",
"identifiers":[ [%-# li.isbns = helpers.get_li_isbns(li.attributes) %]
[% FOR isbn IN helpers.get_li_isbns(li.attributes) -%]
[% IF isbn.length == 13 -%]
{"id-qualifier":"EN","id":"[% isbn %]"},
[% ELSE -%]
{"id-qualifier":"IB","id":"[% isbn %]"},
[%- END %]
[% END %]
{"id-qualifier":"IN","id":"[% li.id %]"}
],
"price":[% li.estimated_unit_price || '0.00' %],
"desc":[
{"BTI":"[% helpers.get_li_attr_jedi('title', '', li.attributes) %]"},
{"BPU":"[% helpers.get_li_attr_jedi('publisher', '', li.attributes) %]"},
{"BPD":"[% helpers.get_li_attr_jedi('pubdate', '', li.attributes) %]"},
{"BPH":"[% helpers.get_li_attr_jedi('pagination','', li.attributes) %]"}
],
[%- ftx_vals = [];
FOR note IN li.lineitem_notes;
NEXT UNLESS note.vendor_public == 't';
ftx_vals.push(note.value);
END;
IF xtra_ftx; ftx_vals.unshift(xtra_ftx); END;
IF ftx_vals.size == 0; ftx_vals.unshift(''); END; # BT needs FTX+LIN for every LI, even if it is an empty one
-%]
"free-text":[
[% FOR note IN ftx_vals -%] "[% note %]"[% UNLESS loop.last %], [% END %][% END %]
],
"quantity":[% li.lineitem_details.size %]
}[% UNLESS loop.last %],[% END %]
[%-# TODO: lineitem details (later) -%]
[% END %]
],
"line_items":[% target.lineitems.size %]
}] [%# close ORDERS array %]
}] [%# close body array %]
}
[% END %]
[% tempo = PROCESS big_block; helpers.escape_json(tempo) %]
$$
);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(23, 'lineitems.attributes'),
(23, 'lineitems.lineitem_details'),
(23, 'lineitems.lineitem_notes'),
(23, 'ordering_agency.mailing_address'),
(23, 'provider'),
(23, 'provider.edi_default');
INSERT INTO action_trigger.reactor (module, description) VALUES (
'AstCall', 'Possibly place a phone call with Asterisk'
);
INSERT INTO
action_trigger.event_definition (
id, active, owner, name, hook, validator, reactor,
cleanup_success, cleanup_failure, delay, delay_field, group_field,
max_delay, granularity, usr_field, opt_in_setting, template
) VALUES (
24,
FALSE,
1,
'Telephone Overdue Notice',
'checkout.due', 'NOOP_True', 'AstCall',
DEFAULT, DEFAULT, '5 seconds', 'due_date', 'usr',
DEFAULT, DEFAULT, DEFAULT, DEFAULT,
$$
[% phone = target.0.usr.day_phone | replace('[\s\-\(\)]', '') -%]
[% IF phone.match('^[2-9]') %][% country = 1 %][% ELSE %][% country = '' %][% END -%]
Channel: [% channel_prefix %]/[% country %][% phone %]
Context: overdue-test
MaxRetries: 1
RetryTime: 60
WaitTime: 30
Extension: 10
Archive: 1
Set: eg_user_id=[% target.0.usr.id %]
Set: items=[% target.size %]
Set: titlestring=[% titles = [] %][% FOR circ IN target %][% titles.push(circ.target_copy.call_number.record.simple_record.title) %][% END %][% titles.join(". ") %]
$$
);
INSERT INTO
action_trigger.environment (id, event_def, path)
VALUES
(DEFAULT, 24, 'target_copy.call_number.record.simple_record'),
(DEFAULT, 24, 'usr')
;
-- 0285.data.history_format.sql
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES (
'circ.format.history.email',
'circ',
oils_i18n_gettext(
'circ.format.history.email',
'An email has been requested for a circ history.',
'ath',
'description'
),
FALSE
)
,(
'circ.format.history.print',
'circ',
oils_i18n_gettext(
'circ.format.history.print',
'A circ history needs to be formatted for printing.',
'ath',
'description'
),
FALSE
)
,(
'ahr.format.history.email',
'ahr',
oils_i18n_gettext(
'ahr.format.history.email',
'An email has been requested for a hold request history.',
'ath',
'description'
),
FALSE
)
,(
'ahr.format.history.print',
'ahr',
oils_i18n_gettext(
'ahr.format.history.print',
'A hold request history needs to be formatted for printing.',
'ath',
'description'
),
FALSE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
group_field,
granularity,
template
) VALUES (
25,
TRUE,
1,
'circ.history.email',
'circ.format.history.email',
'NOOP_True',
'SendEmail',
'usr',
NULL,
$$
[%- USE date -%]
[%- SET user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Circulation History
[% FOR circ IN target %]
[% helpers.get_copy_bib_basics(circ.target_copy.id).title %]
Barcode: [% circ.target_copy.barcode %]
Checked Out: [% date.format(helpers.format_date(circ.xact_start), '%Y-%m-%d') %]
Due Date: [% date.format(helpers.format_date(circ.due_date), '%Y-%m-%d') %]
Returned: [% date.format(helpers.format_date(circ.checkin_time), '%Y-%m-%d') %]
[% END %]
$$
)
,(
26,
TRUE,
1,
'circ.history.print',
'circ.format.history.print',
'NOOP_True',
'ProcessTemplate',
'usr',
'print-on-demand',
$$
[%- USE date -%]
[% date.format %]
[% user.family_name %], [% user.first_given_name %]
[% FOR circ IN target %]
$$
)
;
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES
( 25, 'target_copy')
,( 25, 'usr' )
,( 26, 'target_copy' )
,( 26, 'usr' )
,( 27, 'current_copy' )
,( 27, 'usr' )
,( 28, 'current_copy' )
,( 28, 'usr' )
;
-- 0289.data.payment_receipt_format.sql
-- 0326.data.payment_receipt_format.sql
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES (
'money.format.payment_receipt.email',
'mp',
oils_i18n_gettext(
'money.format.payment_receipt.email',
'An email has been requested for a payment receipt.',
'ath',
'description'
),
FALSE
)
,(
'money.format.payment_receipt.print',
'mp',
oils_i18n_gettext(
'money.format.payment_receipt.print',
'A payment receipt needs to be formatted for printing.',
'ath',
'description'
),
FALSE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
group_field,
granularity,
template
) VALUES (
29,
TRUE,
1,
'money.payment_receipt.email',
'money.format.payment_receipt.email',
'NOOP_True',
'SendEmail',
'xact.usr',
NULL,
$$
[%- USE date -%]
[%- SET user = target.0.xact.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Payment Receipt
[% date.format -%]
[%- SET xact_mp_hash = {} -%]
[%- FOR mp IN target %][%# Template is hooked around payments, but let us make the receipt focused on transactions -%]
[%- SET xact_id = mp.xact.id -%]
[%- IF ! xact_mp_hash.defined( xact_id ) -%][%- xact_mp_hash.$xact_id = { 'xact' => mp.xact, 'payments' => [] } -%][%- END -%]
[%- xact_mp_hash.$xact_id.payments.push(mp) -%]
[%- END -%]
[%- FOR xact_id IN xact_mp_hash.keys.sort -%]
[%- SET xact = xact_mp_hash.$xact_id.xact %]
Transaction ID: [% xact_id %]
[% IF xact.circulation %][% helpers.get_copy_bib_basics(xact.circulation.target_copy).title %]
[% ELSE %]Miscellaneous
[% END %]
Line item billings:
[%- SET mb_type_hash = {} -%]
[%- FOR mb IN xact.billings %][%# Group billings by their btype -%]
[%- IF mb.voided == 'f' -%]
[%- SET mb_type = mb.btype.id -%]
[%- IF ! mb_type_hash.defined( mb_type ) -%][%- mb_type_hash.$mb_type = { 'sum' => 0.00, 'billings' => [] } -%][%- END -%]
[%- IF ! mb_type_hash.$mb_type.defined( 'first_ts' ) -%][%- mb_type_hash.$mb_type.first_ts = mb.billing_ts -%][%- END -%]
[%- mb_type_hash.$mb_type.last_ts = mb.billing_ts -%]
[%- mb_type_hash.$mb_type.sum = mb_type_hash.$mb_type.sum + mb.amount -%]
[%- mb_type_hash.$mb_type.billings.push( mb ) -%]
[%- END -%]
[%- END -%]
[%- FOR mb_type IN mb_type_hash.keys.sort -%]
[%- IF mb_type == 1 %][%-# Consolidated view of overdue billings -%]
$[% mb_type_hash.$mb_type.sum %] for [% mb_type_hash.$mb_type.billings.0.btype.name %]
on [% mb_type_hash.$mb_type.first_ts %] through [% mb_type_hash.$mb_type.last_ts %]
[%- ELSE -%][%# all other billings show individually %]
[% FOR mb IN mb_type_hash.$mb_type.billings %]
$[% mb.amount %] for [% mb.btype.name %] on [% mb.billing_ts %] [% mb.note %]
[% END %]
[% END %]
[% END %]
Line item payments:
[% FOR mp IN xact_mp_hash.$xact_id.payments %]
Payment ID: [% mp.id %]
Paid [% mp.amount %] via [% SWITCH mp.payment_type -%]
[% CASE "cash_payment" %]cash
[% CASE "check_payment" %]check
[% CASE "credit_card_payment" %]credit card (
[%- SET cc_chunks = mp.credit_card_payment.cc_number.replace(' ','').chunk(4); -%]
[%- cc_chunks.slice(0, -1+cc_chunks.max).join.replace('\S','X') -%]
[% cc_chunks.last -%]
exp [% mp.credit_card_payment.expire_month %]/[% mp.credit_card_payment.expire_year -%]
)
[% CASE "credit_payment" %]credit
[% CASE "forgive_payment" %]forgiveness
[% CASE "goods_payment" %]goods
[% CASE "work_payment" %]work
[%- END %] on [% mp.payment_ts %] [% mp.note %]
[% END %]
[% END %]
$$
)
,(
30,
TRUE,
1,
'money.payment_receipt.print',
'money.format.payment_receipt.print',
'NOOP_True',
'ProcessTemplate',
'xact.usr',
'print-on-demand',
$$
[%- USE date -%][%- SET user = target.0.xact.usr -%]
[% date.format %]
[% SET xact_mp_hash = {} %]
[% FOR mp IN target %][%# Template is hooked around payments, but let us make the receipt focused on transactions %]
[% SET xact_id = mp.xact.id %]
[% IF ! xact_mp_hash.defined( xact_id ) %][% xact_mp_hash.$xact_id = { 'xact' => mp.xact, 'payments' => [] } %][% END %]
[% xact_mp_hash.$xact_id.payments.push(mp) %]
[% END %]
[% FOR xact_id IN xact_mp_hash.keys.sort %]
[% SET xact = xact_mp_hash.$xact_id.xact %]
Transaction ID: [% xact_id %]
[% IF xact.circulation %][% helpers.get_copy_bib_basics(xact.circulation.target_copy).title %]
[% ELSE %]Miscellaneous
[% END %]
Line item billings:
[% SET mb_type_hash = {} %]
[% FOR mb IN xact.billings %][%# Group billings by their btype %]
[% IF mb.voided == 'f' %]
[% SET mb_type = mb.btype.id %]
[% IF ! mb_type_hash.defined( mb_type ) %][% mb_type_hash.$mb_type = { 'sum' => 0.00, 'billings' => [] } %][% END %]
[% IF ! mb_type_hash.$mb_type.defined( 'first_ts' ) %][% mb_type_hash.$mb_type.first_ts = mb.billing_ts %][% END %]
[% mb_type_hash.$mb_type.last_ts = mb.billing_ts %]
[% mb_type_hash.$mb_type.sum = mb_type_hash.$mb_type.sum + mb.amount %]
[% mb_type_hash.$mb_type.billings.push( mb ) %]
[% END %]
[% END %]
[% FOR mb_type IN mb_type_hash.keys.sort %]
[% IF mb_type == 1 %][%# Consolidated view of overdue billings %]
$[% mb_type_hash.$mb_type.sum %] for [% mb_type_hash.$mb_type.billings.0.btype.name %]
on [% mb_type_hash.$mb_type.first_ts %] through [% mb_type_hash.$mb_type.last_ts %]
[% ELSE %][%# all other billings show individually %]
[% FOR mb IN mb_type_hash.$mb_type.billings %]
$[% mb.amount %] for [% mb.btype.name %] on [% mb.billing_ts %] [% mb.note %]
[% END %]
[% END %]
[% END %]
Line item payments:
[% FOR mp IN xact_mp_hash.$xact_id.payments %]
Payment ID: [% mp.id %]
Paid [% mp.amount %] via [% SWITCH mp.payment_type -%]
[% CASE "cash_payment" %]cash
[% CASE "check_payment" %]check
[% CASE "credit_card_payment" %]credit card (
[%- SET cc_chunks = mp.credit_card_payment.cc_number.replace(' ','').chunk(4); -%]
[%- cc_chunks.slice(0, -1+cc_chunks.max).join.replace('\S','X') -%]
[% cc_chunks.last -%]
exp [% mp.credit_card_payment.expire_month %]/[% mp.credit_card_payment.expire_year -%]
)
[% CASE "credit_payment" %]credit
[% CASE "forgive_payment" %]forgiveness
[% CASE "goods_payment" %]goods
[% CASE "work_payment" %]work
[%- END %] on [% mp.payment_ts %] [% mp.note %]
[% END %]
[% END %]
$$
)
;
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES -- for fleshing mp objects
( 29, 'xact')
,( 29, 'xact.usr')
,( 29, 'xact.grocery' )
,( 29, 'xact.circulation' )
,( 29, 'xact.summary' )
,( 29, 'credit_card_payment')
,( 29, 'xact.billings')
,( 29, 'xact.billings.btype')
,( 30, 'xact')
,( 30, 'xact.usr')
,( 30, 'xact.grocery' )
,( 30, 'xact.circulation' )
,( 30, 'xact.summary' )
,( 30, 'credit_card_payment')
,( 30, 'xact.billings')
,( 30, 'xact.billings.btype')
;
-- 0294.data.bre_format.sql
INSERT INTO container.biblio_record_entry_bucket_type( code, label ) VALUES (
'temp',
oils_i18n_gettext(
'temp',
'Temporary bucket which gets deleted after use.',
'cbrebt',
'label'
)
);
INSERT INTO action_trigger.cleanup ( module, description ) VALUES (
'DeleteTempBiblioBucket',
oils_i18n_gettext(
'DeleteTempBiblioBucket',
'Deletes a cbreb object used as a target if it has a btype of "temp"',
'atclean',
'description'
)
);
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES (
'biblio.format.record_entry.email',
'cbreb',
oils_i18n_gettext(
'biblio.format.record_entry.email',
'An email has been requested for one or more biblio record entries.',
'ath',
'description'
),
FALSE
)
,(
'biblio.format.record_entry.print',
'cbreb',
oils_i18n_gettext(
'biblio.format.record_entry.print',
'One or more biblio record entries need to be formatted for printing.',
'ath',
'description'
),
FALSE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
cleanup_success,
cleanup_failure,
group_field,
granularity,
template
) VALUES (
31,
TRUE,
1,
'biblio.record_entry.email',
'biblio.format.record_entry.email',
'NOOP_True',
'SendEmail',
'DeleteTempBiblioBucket',
'DeleteTempBiblioBucket',
'owner',
NULL,
$$
[%- USE date -%]
[%- SET user = target.0.owner -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Bibliographic Records
[% FOR cbreb IN target %]
[% FOR cbrebi IN cbreb.items %]
Bib ID# [% cbrebi.target_biblio_record_entry.id %] ISBN: [% crebi.target_biblio_record_entry.simple_record.isbn %]
Title: [% cbrebi.target_biblio_record_entry.simple_record.title %]
Author: [% cbrebi.target_biblio_record_entry.simple_record.author %]
Publication Year: [% cbrebi.target_biblio_record_entry.simple_record.pubdate %]
[% END %]
[% END %]
$$
)
,(
32,
TRUE,
1,
'biblio.record_entry.print',
'biblio.format.record_entry.print',
'NOOP_True',
'ProcessTemplate',
'DeleteTempBiblioBucket',
'DeleteTempBiblioBucket',
'owner',
'print-on-demand',
$$
[%- USE date -%]
[% FOR cbreb IN target %]
[% FOR cbrebi IN cbreb.items %]
$$
)
;
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES -- for fleshing cbreb objects
( 31, 'owner' )
,( 31, 'items' )
,( 31, 'items.target_biblio_record_entry' )
,( 31, 'items.target_biblio_record_entry.simple_record' )
,( 31, 'items.target_biblio_record_entry.call_numbers' )
,( 31, 'items.target_biblio_record_entry.fixed_fields' )
,( 31, 'items.target_biblio_record_entry.notes' )
,( 31, 'items.target_biblio_record_entry.full_record_entries' )
,( 32, 'owner' )
,( 32, 'items' )
,( 32, 'items.target_biblio_record_entry' )
,( 32, 'items.target_biblio_record_entry.simple_record' )
,( 32, 'items.target_biblio_record_entry.call_numbers' )
,( 32, 'items.target_biblio_record_entry.fixed_fields' )
,( 32, 'items.target_biblio_record_entry.notes' )
,( 32, 'items.target_biblio_record_entry.full_record_entries' )
;
INSERT INTO acq.invoice_item_type (code,name) VALUES ('TAX',oils_i18n_gettext('TAX', 'Tax', 'aiit', 'name'));
INSERT INTO acq.invoice_item_type (code,name) VALUES ('PRO',oils_i18n_gettext('PRO', 'Processing Fee', 'aiit', 'name'));
INSERT INTO acq.invoice_item_type (code,name) VALUES ('SHP',oils_i18n_gettext('SHP', 'Shipping Charge', 'aiit', 'name'));
INSERT INTO acq.invoice_item_type (code,name) VALUES ('HND',oils_i18n_gettext('HND', 'Handling Charge', 'aiit', 'name'));
INSERT INTO acq.invoice_item_type (code,name) VALUES ('ITM',oils_i18n_gettext('ITM', 'Non-library Item', 'aiit', 'name'));
INSERT INTO acq.invoice_item_type (code,name) VALUES ('SUB',oils_i18n_gettext('SUB', 'Serial Subscription', 'aiit', 'name'));
INSERT INTO acq.invoice_method (code,name) VALUES ('EDI',oils_i18n_gettext('EDI', 'EDI', 'acqim', 'name'));
INSERT INTO acq.invoice_method (code,name) VALUES ('PPR',oils_i18n_gettext('PPR', 'Paper', 'acqit', 'name'));
INSERT INTO acq.cancel_reason ( id, org_unit, label, description ) VALUES (
1, 1, 'invalid_isbn', oils_i18n_gettext( 1, 'ISBN is unrecognizable', 'acqcr', 'label' ));
INSERT INTO acq.cancel_reason ( id, org_unit, label, description ) VALUES (
2, 1, 'postpone', oils_i18n_gettext( 2, 'Title has been postponed', 'acqcr', 'label' ));
INSERT INTO acq.cancel_reason ( id, org_unit, label, description, keep_debits ) VALUES (
3, 1, 'delivered_but_lost',
oils_i18n_gettext( 2, 'Delivered but not received; presumed lost', 'acqcr', 'label' ), TRUE );
INSERT INTO acq.cancel_reason (keep_debits, id, org_unit, label, description) VALUES
('t',( 1+1000), 1, 'Added', 'The information is to be or has been added.'),
('f',( 2+1000), 1, 'Deleted', 'The information is to be or has been deleted.'),
('t',( 3+1000), 1, 'Changed', 'The information is to be or has been changed.'),
('t',( 4+1000), 1, 'No action', 'This line item is not affected by the actual message.'),
('t',( 5+1000), 1, 'Accepted without amendment', 'This line item is entirely accepted by the seller.'),
('t',( 6+1000), 1, 'Accepted with amendment', 'This line item is accepted but amended by the seller.'),
('f',( 7+1000), 1, 'Not accepted', 'This line item is not accepted by the seller.'),
('t',( 8+1000), 1, 'Schedule only', 'Code specifying that the message is a schedule only.'),
('t',( 9+1000), 1, 'Amendments', 'Code specifying that amendments are requested/notified.'),
('f',( 10+1000), 1, 'Not found', 'This line item is not found in the referenced message.'),
('t',( 11+1000), 1, 'Not amended', 'This line is not amended by the buyer.'),
('t',( 12+1000), 1, 'Line item numbers changed', 'Code specifying that the line item numbers have changed.'),
('t',( 13+1000), 1, 'Buyer has deducted amount', 'Buyer has deducted amount from payment.'),
('t',( 14+1000), 1, 'Buyer claims against invoice', 'Buyer has a claim against an outstanding invoice.'),
('t',( 15+1000), 1, 'Charge back by seller', 'Factor has been requested to charge back the outstanding item.'),
('t',( 16+1000), 1, 'Seller will issue credit note', 'Seller agrees to issue a credit note.'),
('t',( 17+1000), 1, 'Terms changed for new terms', 'New settlement terms have been agreed.'),
('t',( 18+1000), 1, 'Abide outcome of negotiations', 'Factor agrees to abide by the outcome of negotiations between seller and buyer.'),
('t',( 19+1000), 1, 'Seller rejects dispute', 'Seller does not accept validity of dispute.'),
('t',( 20+1000), 1, 'Settlement', 'The reported situation is settled.'),
('t',( 21+1000), 1, 'No delivery', 'Code indicating that no delivery will be required.'),
('t',( 22+1000), 1, 'Call-off delivery', 'A request for delivery of a particular quantity of goods to be delivered on a particular date (or within a particular period).'),
('t',( 23+1000), 1, 'Proposed amendment', 'A code used to indicate an amendment suggested by the sender.'),
('t',( 24+1000), 1, 'Accepted with amendment, no confirmation required', 'Accepted with changes which require no confirmation.'),
('t',( 25+1000), 1, 'Equipment provisionally repaired', 'The equipment or component has been provisionally repaired.'),
('t',( 26+1000), 1, 'Included', 'Code indicating that the entity is included.'),
('t',( 27+1000), 1, 'Verified documents for coverage', 'Upon receipt and verification of documents we shall cover you when due as per your instructions.'),
('t',( 28+1000), 1, 'Verified documents for debit', 'Upon receipt and verification of documents we shall authorize you to debit our account with you when due.'),
('t',( 29+1000), 1, 'Authenticated advice for coverage', 'On receipt of your authenticated advice we shall cover you when due as per your instructions.'),
('t',( 30+1000), 1, 'Authenticated advice for authorization', 'On receipt of your authenticated advice we shall authorize you to debit our account with you when due.'),
('t',( 31+1000), 1, 'Authenticated advice for credit', 'On receipt of your authenticated advice we shall credit your account with us when due.'),
('t',( 32+1000), 1, 'Credit advice requested for direct debit', 'A credit advice is requested for the direct debit.'),
('t',( 33+1000), 1, 'Credit advice and acknowledgement for direct debit', 'A credit advice and acknowledgement are requested for the direct debit.'),
('t',( 34+1000), 1, 'Inquiry', 'Request for information.'),
('t',( 35+1000), 1, 'Checked', 'Checked.'),
('t',( 36+1000), 1, 'Not checked', 'Not checked.'),
('f',( 37+1000), 1, 'Cancelled', 'Discontinued.'),
('t',( 38+1000), 1, 'Replaced', 'Provide a replacement.'),
('t',( 39+1000), 1, 'New', 'Not existing before.'),
('t',( 40+1000), 1, 'Agreed', 'Consent.'),
('t',( 41+1000), 1, 'Proposed', 'Put forward for consideration.'),
('t',( 42+1000), 1, 'Already delivered', 'Delivery has taken place.'),
('t',( 43+1000), 1, 'Additional subordinate structures will follow', 'Additional subordinate structures will follow the current hierarchy level.'),
('t',( 44+1000), 1, 'Additional subordinate structures will not follow', 'No additional subordinate structures will follow the current hierarchy level.'),
('t',( 45+1000), 1, 'Result opposed', 'A notification that the result is opposed.'),
('t',( 46+1000), 1, 'Auction held', 'A notification that an auction was held.'),
('t',( 47+1000), 1, 'Legal action pursued', 'A notification that legal action has been pursued.'),
('t',( 48+1000), 1, 'Meeting held', 'A notification that a meeting was held.'),
('t',( 49+1000), 1, 'Result set aside', 'A notification that the result has been set aside.'),
('t',( 50+1000), 1, 'Result disputed', 'A notification that the result has been disputed.'),
('t',( 51+1000), 1, 'Countersued', 'A notification that a countersuit has been filed.'),
('t',( 52+1000), 1, 'Pending', 'A notification that an action is awaiting settlement.'),
('f',( 53+1000), 1, 'Court action dismissed', 'A notification that a court action will no longer be heard.'),
('t',( 54+1000), 1, 'Referred item, accepted', 'The item being referred to has been accepted.'),
('f',( 55+1000), 1, 'Referred item, rejected', 'The item being referred to has been rejected.'),
('t',( 56+1000), 1, 'Debit advice statement line', 'Notification that the statement line is a debit advice.'),
('t',( 57+1000), 1, 'Credit advice statement line', 'Notification that the statement line is a credit advice.'),
('t',( 58+1000), 1, 'Grouped credit advices', 'Notification that the credit advices are grouped.'),
('t',( 59+1000), 1, 'Grouped debit advices', 'Notification that the debit advices are grouped.'),
('t',( 60+1000), 1, 'Registered', 'The name is registered.'),
('f',( 61+1000), 1, 'Payment denied', 'The payment has been denied.'),
('t',( 62+1000), 1, 'Approved as amended', 'Approved with modifications.'),
('t',( 63+1000), 1, 'Approved as submitted', 'The request has been approved as submitted.'),
('f',( 64+1000), 1, 'Cancelled, no activity', 'Cancelled due to the lack of activity.'),
('t',( 65+1000), 1, 'Under investigation', 'Investigation is being done.'),
('t',( 66+1000), 1, 'Initial claim received', 'Notification that the initial claim was received.'),
('f',( 67+1000), 1, 'Not in process', 'Not in process.'),
('f',( 68+1000), 1, 'Rejected, duplicate', 'Rejected because it is a duplicate.'),
('f',( 69+1000), 1, 'Rejected, resubmit with corrections', 'Rejected but may be resubmitted when corrected.'),
('t',( 70+1000), 1, 'Pending, incomplete', 'Pending because of incomplete information.'),
('t',( 71+1000), 1, 'Under field office investigation', 'Investigation by the field is being done.'),
('t',( 72+1000), 1, 'Pending, awaiting additional material', 'Pending awaiting receipt of additional material.'),
('t',( 73+1000), 1, 'Pending, awaiting review', 'Pending while awaiting review.'),
('t',( 74+1000), 1, 'Reopened', 'Opened again.'),
('t',( 75+1000), 1, 'Processed by primary, forwarded to additional payer(s)', 'This request has been processed by the primary payer and sent to additional payer(s).'),
('t',( 76+1000), 1, 'Processed by secondary, forwarded to additional payer(s)', 'This request has been processed by the secondary payer and sent to additional payer(s).'),
('t',( 77+1000), 1, 'Processed by tertiary, forwarded to additional payer(s)', 'This request has been processed by the tertiary payer and sent to additional payer(s).'),
('t',( 78+1000), 1, 'Previous payment decision reversed', 'A previous payment decision has been reversed.'),
('t',( 79+1000), 1, 'Not our claim, forwarded to another payer(s)', 'A request does not belong to this payer but has been forwarded to another payer(s).'),
('t',( 80+1000), 1, 'Transferred to correct insurance carrier', 'The request has been transferred to the correct insurance carrier for processing.'),
('t',( 81+1000), 1, 'Not paid, predetermination pricing only', 'Payment has not been made and the enclosed response is predetermination pricing only.'),
('t',( 82+1000), 1, 'Documentation claim', 'The claim is for documentation purposes only, no payment required.'),
('t',( 83+1000), 1, 'Reviewed', 'Assessed.'),
('f',( 84+1000), 1, 'Repriced', 'This price was changed.'),
('t',( 85+1000), 1, 'Audited', 'An official examination has occurred.'),
('t',( 86+1000), 1, 'Conditionally paid', 'Payment has been conditionally made.'),
('t',( 87+1000), 1, 'On appeal', 'Reconsideration of the decision has been applied for.'),
('t',( 88+1000), 1, 'Closed', 'Shut.'),
('t',( 89+1000), 1, 'Reaudited', 'A subsequent official examination has occurred.'),
('t',( 90+1000), 1, 'Reissued', 'Issued again.'),
('t',( 91+1000), 1, 'Closed after reopening', 'Reopened and then closed.'),
('t',( 92+1000), 1, 'Redetermined', 'Determined again or differently.'),
('t',( 93+1000), 1, 'Processed as primary', 'Processed as the first.'),
('t',( 94+1000), 1, 'Processed as secondary', 'Processed as the second.'),
('t',( 95+1000), 1, 'Processed as tertiary', 'Processed as the third.'),
('t',( 96+1000), 1, 'Correction of error', 'A correction to information previously communicated which contained an error.'),
('t',( 97+1000), 1, 'Single credit item of a group', 'Notification that the credit item is a single credit item of a group of credit items.'),
('t',( 98+1000), 1, 'Single debit item of a group', 'Notification that the debit item is a single debit item of a group of debit items.'),
('t',( 99+1000), 1, 'Interim response', 'The response is an interim one.'),
('t',(100+1000), 1, 'Final response', 'The response is an final one.'),
('t',(101+1000), 1, 'Debit advice requested', 'A debit advice is requested for the transaction.'),
('t',(102+1000), 1, 'Transaction not impacted', 'Advice that the transaction is not impacted.'),
('t',(103+1000), 1, 'Patient to be notified', 'The action to take is to notify the patient.'),
('t',(104+1000), 1, 'Healthcare provider to be notified', 'The action to take is to notify the healthcare provider.'),
('t',(105+1000), 1, 'Usual general practitioner to be notified', 'The action to take is to notify the usual general practitioner.'),
('t',(106+1000), 1, 'Advice without details', 'An advice without details is requested or notified.'),
('t',(107+1000), 1, 'Advice with details', 'An advice with details is requested or notified.'),
('t',(108+1000), 1, 'Amendment requested', 'An amendment is requested.'),
('t',(109+1000), 1, 'For information', 'Included for information only.'),
('f',(110+1000), 1, 'Withdraw', 'A code indicating discontinuance or retraction.'),
('t',(111+1000), 1, 'Delivery date change', 'The action / notiification is a change of the delivery date.'),
('f',(112+1000), 1, 'Quantity change', 'The action / notification is a change of quantity.'),
('t',(113+1000), 1, 'Resale and claim', 'The identified items have been sold by the distributor to the end customer, and compensation for the loss of inventory value is claimed.'),
('t',(114+1000), 1, 'Resale', 'The identified items have been sold by the distributor to the end customer.'),
('t',(115+1000), 1, 'Prior addition', 'This existing line item becomes available at an earlier date.');
-- We won't necessarily use all of these, but they are here for completeness.
-- Source is the EDI spec 6063 codelist, eg: http://www.stylusstudio.com/edifact/D04B/6063.htm
-- Values are the EDI code value + 1200
INSERT INTO acq.cancel_reason (org_unit, keep_debits, id, label, description) VALUES
(1, 't', 1201, 'Discrete quantity', 'Individually separated and distinct quantity.'),
(1, 't', 1202, 'Charge', 'Quantity relevant for charge.'),
(1, 't', 1203, 'Cumulative quantity', 'Quantity accumulated.'),
(1, 't', 1204, 'Interest for overdrawn account', 'Interest for overdrawing the account.'),
(1, 't', 1205, 'Active ingredient dose per unit', 'The dosage of active ingredient per unit.'),
(1, 't', 1206, 'Auditor', 'The number of entities that audit accounts.'),
(1, 't', 1207, 'Branch locations, leased', 'The number of branch locations being leased by an entity.'),
(1, 't', 1208, 'Inventory quantity at supplier''s subject to inspection by', 'customer Quantity of goods which the customer requires the supplier to have in inventory and which may be inspected by the customer if desired.'),
(1, 't', 1209, 'Branch locations, owned', 'The number of branch locations owned by an entity.'),
(1, 't', 1210, 'Judgements registered', 'The number of judgements registered against an entity.'),
(1, 't', 1211, 'Split quantity', 'Part of the whole quantity.'),
(1, 't', 1212, 'Despatch quantity', 'Quantity despatched by the seller.'),
(1, 't', 1213, 'Liens registered', 'The number of liens registered against an entity.'),
(1, 't', 1214, 'Livestock', 'The number of animals kept for use or profit.'),
(1, 't', 1215, 'Insufficient funds returned cheques', 'The number of cheques returned due to insufficient funds.'),
(1, 't', 1216, 'Stolen cheques', 'The number of stolen cheques.'),
(1, 't', 1217, 'Quantity on hand', 'The total quantity of a product on hand at a location. This includes as well units awaiting return to manufacturer, units unavailable due to inspection procedures and undamaged stock available for despatch, resale or use.'),
(1, 't', 1218, 'Previous quantity', 'Quantity previously referenced.'),
(1, 't', 1219, 'Paid-in security shares', 'The number of security shares issued and for which full payment has been made.'),
(1, 't', 1220, 'Unusable quantity', 'Quantity not usable.'),
(1, 't', 1221, 'Ordered quantity', '[6024] The quantity which has been ordered.'),
(1, 't', 1222, 'Quantity at 100%', 'Equivalent quantity at 100% purity.'),
(1, 't', 1223, 'Active ingredient', 'Quantity at 100% active agent content.'),
(1, 't', 1224, 'Inventory quantity at supplier''s not subject to inspection', 'by customer Quantity of goods which the customer requires the supplier to have in inventory but which will not be checked by the customer.'),
(1, 't', 1225, 'Retail sales', 'Quantity of retail point of sale activity.'),
(1, 't', 1226, 'Promotion quantity', 'A quantity associated with a promotional event.'),
(1, 't', 1227, 'On hold for shipment', 'Article received which cannot be shipped in its present form.'),
(1, 't', 1228, 'Military sales quantity', 'Quantity of goods or services sold to a military organization.'),
(1, 't', 1229, 'On premises sales', 'Sale of product in restaurants or bars.'),
(1, 't', 1230, 'Off premises sales', 'Sale of product directly to a store.'),
(1, 't', 1231, 'Estimated annual volume', 'Volume estimated for a year.'),
(1, 't', 1232, 'Minimum delivery batch', 'Minimum quantity of goods delivered at one time.'),
(1, 't', 1233, 'Maximum delivery batch', 'Maximum quantity of goods delivered at one time.'),
(1, 't', 1234, 'Pipes', 'The number of tubes used to convey a substance.'),
(1, 't', 1235, 'Price break from', 'The minimum quantity of a quantity range for a specified (unit) price.'),
(1, 't', 1236, 'Price break to', 'Maximum quantity to which the price break applies.'),
(1, 't', 1237, 'Poultry', 'The number of domestic fowl.'),
(1, 't', 1238, 'Secured charges registered', 'The number of secured charges registered against an entity.'),
(1, 't', 1239, 'Total properties owned', 'The total number of properties owned by an entity.'),
(1, 't', 1240, 'Normal delivery', 'Quantity normally delivered by the seller.'),
(1, 't', 1241, 'Sales quantity not included in the replenishment', 'calculation Sales which will not be included in the calculation of replenishment requirements.'),
(1, 't', 1242, 'Maximum supply quantity, supplier endorsed', 'Maximum supply quantity endorsed by a supplier.'),
(1, 't', 1243, 'Buyer', 'The number of buyers.'),
(1, 't', 1244, 'Debenture bond', 'The number of fixed-interest bonds of an entity backed by general credit rather than specified assets.'),
(1, 't', 1245, 'Debentures filed against directors', 'The number of notices of indebtedness filed against an entity''s directors.'),
(1, 't', 1246, 'Pieces delivered', 'Number of pieces actually received at the final destination.'),
(1, 't', 1247, 'Invoiced quantity', 'The quantity as per invoice.'),
(1, 't', 1248, 'Received quantity', 'The quantity which has been received.'),
(1, 't', 1249, 'Chargeable distance', '[6110] The distance between two points for which a specific tariff applies.'),
(1, 't', 1250, 'Disposition undetermined quantity', 'Product quantity that has not yet had its disposition determined.'),
(1, 't', 1251, 'Inventory category transfer', 'Inventory that has been moved from one inventory category to another.'),
(1, 't', 1252, 'Quantity per pack', 'Quantity for each pack.'),
(1, 't', 1253, 'Minimum order quantity', 'Minimum quantity of goods for an order.'),
(1, 't', 1254, 'Maximum order quantity', 'Maximum quantity of goods for an order.'),
(1, 't', 1255, 'Total sales', 'The summation of total quantity sales.'),
(1, 't', 1256, 'Wholesaler to wholesaler sales', 'Sale of product to other wholesalers by a wholesaler.'),
(1, 't', 1257, 'In transit quantity', 'A quantity that is en route.'),
(1, 't', 1258, 'Quantity withdrawn', 'Quantity withdrawn from a location.'),
(1, 't', 1259, 'Numbers of consumer units in the traded unit', 'Number of units for consumer sales in a unit for trading.'),
(1, 't', 1260, 'Current inventory quantity available for shipment', 'Current inventory quantity available for shipment.'),
(1, 't', 1261, 'Return quantity', 'Quantity of goods returned.'),
(1, 't', 1262, 'Sorted quantity', 'The quantity that is sorted.'),
(1, 'f', 1263, 'Sorted quantity rejected', 'The sorted quantity that is rejected.'),
(1, 't', 1264, 'Scrap quantity', 'Remainder of the total quantity after split deliveries.'),
(1, 'f', 1265, 'Destroyed quantity', 'Quantity of goods destroyed.'),
(1, 't', 1266, 'Committed quantity', 'Quantity a party is committed to.'),
(1, 't', 1267, 'Estimated reading quantity', 'The value that is estimated to be the reading of a measuring device (e.g. meter).'),
(1, 't', 1268, 'End quantity', 'The quantity recorded at the end of an agreement or period.'),
(1, 't', 1269, 'Start quantity', 'The quantity recorded at the start of an agreement or period.'),
(1, 't', 1270, 'Cumulative quantity received', 'Cumulative quantity of all deliveries of this article received by the buyer.'),
(1, 't', 1271, 'Cumulative quantity ordered', 'Cumulative quantity of all deliveries, outstanding and scheduled orders.'),
(1, 't', 1272, 'Cumulative quantity received end of prior year', 'Cumulative quantity of all deliveries of the product received by the buyer till end of prior year.'),
(1, 't', 1273, 'Outstanding quantity', 'Difference between quantity ordered and quantity received.'),
(1, 't', 1274, 'Latest cumulative quantity', 'Cumulative quantity after complete delivery of all scheduled quantities of the product.'),
(1, 't', 1275, 'Previous highest cumulative quantity', 'Cumulative quantity after complete delivery of all scheduled quantities of the product from a prior schedule period.'),
(1, 't', 1276, 'Adjusted corrector reading', 'A corrector reading after it has been adjusted.'),
(1, 't', 1277, 'Work days', 'Number of work days, e.g. per respective period.'),
(1, 't', 1278, 'Cumulative quantity scheduled', 'Adding the quantity actually scheduled to previous cumulative quantity.'),
(1, 't', 1279, 'Previous cumulative quantity', 'Cumulative quantity prior the actual order.'),
(1, 't', 1280, 'Unadjusted corrector reading', 'A corrector reading before it has been adjusted.'),
(1, 't', 1281, 'Extra unplanned delivery', 'Non scheduled additional quantity.'),
(1, 't', 1282, 'Quantity requirement for sample inspection', 'Required quantity for sample inspection.'),
(1, 't', 1283, 'Backorder quantity', 'The quantity of goods that is on back-order.'),
(1, 't', 1284, 'Urgent delivery quantity', 'Quantity for urgent delivery.'),
(1, 'f', 1285, 'Previous order quantity to be cancelled', 'Quantity ordered previously to be cancelled.'),
(1, 't', 1286, 'Normal reading quantity', 'The value recorded or read from a measuring device (e.g. meter) in the normal conditions.'),
(1, 't', 1287, 'Customer reading quantity', 'The value recorded or read from a measuring device (e.g. meter) by the customer.'),
(1, 't', 1288, 'Information reading quantity', 'The value recorded or read from a measuring device (e.g. meter) for information purposes.'),
(1, 't', 1289, 'Quality control held', 'Quantity of goods held pending completion of a quality control assessment.'),
(1, 't', 1290, 'As is quantity', 'Quantity as it is in the existing circumstances.'),
(1, 't', 1291, 'Open quantity', 'Quantity remaining after partial delivery.'),
(1, 't', 1292, 'Final delivery quantity', 'Quantity of final delivery to a respective order.'),
(1, 't', 1293, 'Subsequent delivery quantity', 'Quantity delivered to a respective order after it''s final delivery.'),
(1, 't', 1294, 'Substitutional quantity', 'Quantity delivered replacing previous deliveries.'),
(1, 't', 1295, 'Redelivery after post processing', 'Quantity redelivered after post processing.'),
(1, 'f', 1296, 'Quality control failed', 'Quantity of goods which have failed quality control.'),
(1, 't', 1297, 'Minimum inventory', 'Minimum stock quantity on which replenishment is based.'),
(1, 't', 1298, 'Maximum inventory', 'Maximum stock quantity on which replenishment is based.'),
(1, 't', 1299, 'Estimated quantity', 'Quantity estimated.'),
(1, 't', 1300, 'Chargeable weight', 'The weight on which charges are based.'),
(1, 't', 1301, 'Chargeable gross weight', 'The gross weight on which charges are based.'),
(1, 't', 1302, 'Chargeable tare weight', 'The tare weight on which charges are based.'),
(1, 't', 1303, 'Chargeable number of axles', 'The number of axles on which charges are based.'),
(1, 't', 1304, 'Chargeable number of containers', 'The number of containers on which charges are based.'),
(1, 't', 1305, 'Chargeable number of rail wagons', 'The number of rail wagons on which charges are based.'),
(1, 't', 1306, 'Chargeable number of packages', 'The number of packages on which charges are based.'),
(1, 't', 1307, 'Chargeable number of units', 'The number of units on which charges are based.'),
(1, 't', 1308, 'Chargeable period', 'The period of time on which charges are based.'),
(1, 't', 1309, 'Chargeable volume', 'The volume on which charges are based.'),
(1, 't', 1310, 'Chargeable cubic measurements', 'The cubic measurements on which charges are based.'),
(1, 't', 1311, 'Chargeable surface', 'The surface area on which charges are based.'),
(1, 't', 1312, 'Chargeable length', 'The length on which charges are based.'),
(1, 't', 1313, 'Quantity to be delivered', 'The quantity to be delivered.'),
(1, 't', 1314, 'Number of passengers', 'Total number of passengers on the conveyance.'),
(1, 't', 1315, 'Number of crew', 'Total number of crew members on the conveyance.'),
(1, 't', 1316, 'Number of transport documents', 'Total number of air waybills, bills of lading, etc. being reported for a specific conveyance.'),
(1, 't', 1317, 'Quantity landed', 'Quantity of goods actually arrived.'),
(1, 't', 1318, 'Quantity manifested', 'Quantity of goods contracted for delivery by the carrier.'),
(1, 't', 1319, 'Short shipped', 'Indication that part of the consignment was not shipped.'),
(1, 't', 1320, 'Split shipment', 'Indication that the consignment has been split into two or more shipments.'),
(1, 't', 1321, 'Over shipped', 'The quantity of goods shipped that exceeds the quantity contracted.'),
(1, 't', 1322, 'Short-landed goods', 'If quantity of goods actually landed is less than the quantity which appears in the documentation. This quantity is the difference between these quantities.'),
(1, 't', 1323, 'Surplus goods', 'If quantity of goods actually landed is more than the quantity which appears in the documentation. This quantity is the difference between these quantities.'),
(1, 'f', 1324, 'Damaged goods', 'Quantity of goods which have deteriorated in transport such that they cannot be used for the purpose for which they were originally intended.'),
(1, 'f', 1325, 'Pilferage goods', 'Quantity of goods stolen during transport.'),
(1, 'f', 1326, 'Lost goods', 'Quantity of goods that disappeared in transport.'),
(1, 't', 1327, 'Report difference', 'The quantity concerning the same transaction differs between two documents/messages and the source of this difference is a typing error.'),
(1, 't', 1328, 'Quantity loaded', 'Quantity of goods loaded onto a means of transport.'),
(1, 't', 1329, 'Units per unit price', 'Number of units per unit price.'),
(1, 't', 1330, 'Allowance', 'Quantity relevant for allowance.'),
(1, 't', 1331, 'Delivery quantity', 'Quantity required by buyer to be delivered.'),
(1, 't', 1332, 'Cumulative quantity, preceding period, planned', 'Cumulative quantity originally planned for the preceding period.'),
(1, 't', 1333, 'Cumulative quantity, preceding period, reached', 'Cumulative quantity reached in the preceding period.'),
(1, 't', 1334, 'Cumulative quantity, actual planned', 'Cumulative quantity planned for now.'),
(1, 't', 1335, 'Period quantity, planned', 'Quantity planned for this period.'),
(1, 't', 1336, 'Period quantity, reached', 'Quantity reached during this period.'),
(1, 't', 1337, 'Cumulative quantity, preceding period, estimated', 'Estimated cumulative quantity reached in the preceding period.'),
(1, 't', 1338, 'Cumulative quantity, actual estimated', 'Estimated cumulative quantity reached now.'),
(1, 't', 1339, 'Cumulative quantity, preceding period, measured', 'Surveyed cumulative quantity reached in the preceding period.'),
(1, 't', 1340, 'Cumulative quantity, actual measured', 'Surveyed cumulative quantity reached now.'),
(1, 't', 1341, 'Period quantity, measured', 'Surveyed quantity reached during this period.'),
(1, 't', 1342, 'Total quantity, planned', 'Total quantity planned.'),
(1, 't', 1343, 'Quantity, remaining', 'Quantity remaining.'),
(1, 't', 1344, 'Tolerance', 'Plus or minus tolerance expressed as a monetary amount.'),
(1, 't', 1345, 'Actual stock', 'The stock on hand, undamaged, and available for despatch, sale or use.'),
(1, 't', 1346, 'Model or target stock', 'The stock quantity required or planned to have on hand, undamaged and available for use.'),
(1, 't', 1347, 'Direct shipment quantity', 'Quantity to be shipped directly to a customer from a manufacturing site.'),
(1, 't', 1348, 'Amortization total quantity', 'Indication of final quantity for amortization.'),
(1, 't', 1349, 'Amortization order quantity', 'Indication of actual share of the order quantity for amortization.'),
(1, 't', 1350, 'Amortization cumulated quantity', 'Indication of actual cumulated quantity of previous and actual amortization order quantity.'),
(1, 't', 1351, 'Quantity advised', 'Quantity advised by supplier or shipper, in contrast to quantity actually received.'),
(1, 't', 1352, 'Consignment stock', 'Quantity of goods with an external customer which is still the property of the supplier. Payment for these goods is only made to the supplier when the ownership has been transferred between the trading partners.'),
(1, 't', 1353, 'Statistical sales quantity', 'Quantity of goods sold in a specified period.'),
(1, 't', 1354, 'Sales quantity planned', 'Quantity of goods required to meet future demands. - Market intelligence quantity.'),
(1, 't', 1355, 'Replenishment quantity', 'Quantity required to maintain the requisite on-hand stock of goods.'),
(1, 't', 1356, 'Inventory movement quantity', 'To specify the quantity of an inventory movement.'),
(1, 't', 1357, 'Opening stock balance quantity', 'To specify the quantity of an opening stock balance.'),
(1, 't', 1358, 'Closing stock balance quantity', 'To specify the quantity of a closing stock balance.'),
(1, 't', 1359, 'Number of stops', 'Number of times a means of transport stops before arriving at destination.'),
(1, 't', 1360, 'Minimum production batch', 'The quantity specified is the minimum output from a single production run.'),
(1, 't', 1361, 'Dimensional sample quantity', 'The quantity defined is a sample for the purpose of validating dimensions.'),
(1, 't', 1362, 'Functional sample quantity', 'The quantity defined is a sample for the purpose of validating function and performance.'),
(1, 't', 1363, 'Pre-production quantity', 'Quantity of the referenced item required prior to full production.'),
(1, 't', 1364, 'Delivery batch', 'Quantity of the referenced item which constitutes a standard batch for deliver purposes.'),
(1, 't', 1365, 'Delivery batch multiple', 'The multiples in which delivery batches can be supplied.'),
(1, 't', 1366, 'All time buy', 'The total quantity of the referenced covering all future needs. Further orders of the referenced item are not expected.'),
(1, 't', 1367, 'Total delivery quantity', 'The total quantity required by the buyer to be delivered.'),
(1, 't', 1368, 'Single delivery quantity', 'The quantity required by the buyer to be delivered in a single shipment.'),
(1, 't', 1369, 'Supplied quantity', 'Quantity of the referenced item actually shipped.'),
(1, 't', 1370, 'Allocated quantity', 'Quantity of the referenced item allocated from available stock for delivery.'),
(1, 't', 1371, 'Maximum stackability', 'The number of pallets/handling units which can be safely stacked one on top of another.'),
(1, 't', 1372, 'Amortisation quantity', 'The quantity of the referenced item which has a cost for tooling amortisation included in the item price.'),
(1, 't', 1373, 'Previously amortised quantity', 'The cumulative quantity of the referenced item which had a cost for tooling amortisation included in the item price.'),
(1, 't', 1374, 'Total amortisation quantity', 'The total quantity of the referenced item which has a cost for tooling amortisation included in the item price.'),
(1, 't', 1375, 'Number of moulds', 'The number of pressing moulds contained within a single piece of the referenced tooling.'),
(1, 't', 1376, 'Concurrent item output of tooling', 'The number of related items which can be produced simultaneously with a single piece of the referenced tooling.'),
(1, 't', 1377, 'Periodic capacity of tooling', 'Maximum production output of the referenced tool over a period of time.'),
(1, 't', 1378, 'Lifetime capacity of tooling', 'Maximum production output of the referenced tool over its productive lifetime.'),
(1, 't', 1379, 'Number of deliveries per despatch period', 'The number of deliveries normally expected to be despatched within each despatch period.'),
(1, 't', 1380, 'Provided quantity', 'The quantity of a referenced component supplied by the buyer for manufacturing of an ordered item.'),
(1, 't', 1381, 'Maximum production batch', 'The quantity specified is the maximum output from a single production run.'),
(1, 'f', 1382, 'Cancelled quantity', 'Quantity of the referenced item which has previously been ordered and is now cancelled.'),
(1, 't', 1383, 'No delivery requirement in this instruction', 'This delivery instruction does not contain any delivery requirements.'),
(1, 't', 1384, 'Quantity of material in ordered time', 'Quantity of the referenced material within the ordered time.'),
(1, 'f', 1385, 'Rejected quantity', 'The quantity of received goods rejected for quantity reasons.'),
(1, 't', 1386, 'Cumulative quantity scheduled up to accumulation start date', 'The cumulative quantity scheduled up to the accumulation start date.'),
(1, 't', 1387, 'Quantity scheduled', 'The quantity scheduled for delivery.'),
(1, 't', 1388, 'Number of identical handling units', 'Number of identical handling units in terms of type and contents.'),
(1, 't', 1389, 'Number of packages in handling unit', 'The number of packages contained in one handling unit.'),
(1, 't', 1390, 'Despatch note quantity', 'The item quantity specified on the despatch note.'),
(1, 't', 1391, 'Adjustment to inventory quantity', 'An adjustment to inventory quantity.'),
(1, 't', 1392, 'Free goods quantity', 'Quantity of goods which are free of charge.'),
(1, 't', 1393, 'Free quantity included', 'Quantity included to which no charge is applicable.'),
(1, 't', 1394, 'Received and accepted', 'Quantity which has been received and accepted at a given location.'),
(1, 'f', 1395, 'Received, not accepted, to be returned', 'Quantity which has been received but not accepted at a given location and which will consequently be returned to the relevant party.'),
(1, 'f', 1396, 'Received, not accepted, to be destroyed', 'Quantity which has been received but not accepted at a given location and which will consequently be destroyed.'),
(1, 't', 1397, 'Reordering level', 'Quantity at which an order may be triggered to replenish.'),
(1, 't', 1399, 'Inventory withdrawal quantity', 'Quantity which has been withdrawn from inventory since the last inventory report.'),
(1, 't', 1400, 'Free quantity not included', 'Free quantity not included in ordered quantity.'),
(1, 't', 1401, 'Recommended overhaul and repair quantity', 'To indicate the recommended quantity of an article required to support overhaul and repair activities.'),
(1, 't', 1402, 'Quantity per next higher assembly', 'To indicate the quantity required for the next higher assembly.'),
(1, 't', 1403, 'Quantity per unit of issue', 'Provides the standard quantity of an article in which one unit can be issued.'),
(1, 't', 1404, 'Cumulative scrap quantity', 'Provides the cumulative quantity of an item which has been identified as scrapped.'),
(1, 't', 1405, 'Publication turn size', 'The quantity of magazines or newspapers grouped together with the spine facing alternate directions in a bundle.'),
(1, 't', 1406, 'Recommended maintenance quantity', 'Recommended quantity of an article which is required to meet an agreed level of maintenance.'),
(1, 't', 1407, 'Labour hours', 'Number of labour hours.'),
(1, 't', 1408, 'Quantity requirement for maintenance and repair of', 'equipment Quantity of the material needed to maintain and repair equipment.'),
(1, 't', 1409, 'Additional replenishment demand quantity', 'Incremental needs over and above normal replenishment calculations, but not intended to permanently change the model parameters.'),
(1, 't', 1410, 'Returned by consumer quantity', 'Quantity returned by a consumer.'),
(1, 't', 1411, 'Replenishment override quantity', 'Quantity to override the normal replenishment model calculations, but not intended to permanently change the model parameters.'),
(1, 't', 1412, 'Quantity sold, net', 'Net quantity sold which includes returns of saleable inventory and other adjustments.'),
(1, 't', 1413, 'Transferred out quantity', 'Quantity which was transferred out of this location.'),
(1, 't', 1414, 'Transferred in quantity', 'Quantity which was transferred into this location.'),
(1, 't', 1415, 'Unsaleable quantity', 'Quantity of inventory received which cannot be sold in its present condition.'),
(1, 't', 1416, 'Consumer reserved quantity', 'Quantity reserved for consumer delivery or pickup and not yet withdrawn from inventory.'),
(1, 't', 1417, 'Out of inventory quantity', 'Quantity of inventory which was requested but was not available.'),
(1, 't', 1418, 'Quantity returned, defective or damaged', 'Quantity returned in a damaged or defective condition.'),
(1, 't', 1419, 'Taxable quantity', 'Quantity subject to taxation.'),
(1, 't', 1420, 'Meter reading', 'The numeric value of measure units counted by a meter.'),
(1, 't', 1421, 'Maximum requestable quantity', 'The maximum quantity which may be requested.'),
(1, 't', 1422, 'Minimum requestable quantity', 'The minimum quantity which may be requested.'),
(1, 't', 1423, 'Daily average quantity', 'The quantity for a defined period divided by the number of days of the period.'),
(1, 't', 1424, 'Budgeted hours', 'The number of budgeted hours.'),
(1, 't', 1425, 'Actual hours', 'The number of actual hours.'),
(1, 't', 1426, 'Earned value hours', 'The number of earned value hours.'),
(1, 't', 1427, 'Estimated hours', 'The number of estimated hours.'),
(1, 't', 1428, 'Level resource task quantity', 'Quantity of a resource that is level for the duration of the task.'),
(1, 't', 1429, 'Available resource task quantity', 'Quantity of a resource available to complete a task.'),
(1, 't', 1430, 'Work time units', 'Quantity of work units of time.'),
(1, 't', 1431, 'Daily work shifts', 'Quantity of work shifts per day.'),
(1, 't', 1432, 'Work time units per shift', 'Work units of time per work shift.'),
(1, 't', 1433, 'Work calendar units', 'Work calendar units of time.'),
(1, 't', 1434, 'Elapsed duration', 'Quantity representing the elapsed duration.'),
(1, 't', 1435, 'Remaining duration', 'Quantity representing the remaining duration.'),
(1, 't', 1436, 'Original duration', 'Quantity representing the original duration.'),
(1, 't', 1437, 'Current duration', 'Quantity representing the current duration.'),
(1, 't', 1438, 'Total float time', 'Quantity representing the total float time.'),
(1, 't', 1439, 'Free float time', 'Quantity representing the free float time.'),
(1, 't', 1440, 'Lag time', 'Quantity representing lag time.'),
(1, 't', 1441, 'Lead time', 'Quantity representing lead time.'),
(1, 't', 1442, 'Number of months', 'The number of months.'),
(1, 't', 1443, 'Reserved quantity customer direct delivery sales', 'Quantity of products reserved for sales delivered direct to the customer.'),
(1, 't', 1444, 'Reserved quantity retail sales', 'Quantity of products reserved for retail sales.'),
(1, 't', 1445, 'Consolidated discount inventory', 'A quantity of inventory supplied at consolidated discount terms.'),
(1, 't', 1446, 'Returns replacement quantity', 'A quantity of goods issued as a replacement for a returned quantity.'),
(1, 't', 1447, 'Additional promotion sales forecast quantity', 'A forecast of additional quantity which will be sold during a period of promotional activity.'),
(1, 't', 1448, 'Reserved quantity', 'Quantity reserved for specific purposes.'),
(1, 't', 1449, 'Quantity displayed not available for sale', 'Quantity displayed within a retail outlet but not available for sale.'),
(1, 't', 1450, 'Inventory discrepancy', 'The difference recorded between theoretical and physical inventory.'),
(1, 't', 1451, 'Incremental order quantity', 'The incremental quantity by which ordering is carried out.'),
(1, 't', 1452, 'Quantity requiring manipulation before despatch', 'A quantity of goods which needs manipulation before despatch.'),
(1, 't', 1453, 'Quantity in quarantine', 'A quantity of goods which are held in a restricted area for quarantine purposes.'),
(1, 't', 1454, 'Quantity withheld by owner of goods', 'A quantity of goods which has been withheld by the owner of the goods.'),
(1, 't', 1455, 'Quantity not available for despatch', 'A quantity of goods not available for despatch.'),
(1, 't', 1456, 'Quantity awaiting delivery', 'Quantity of goods which are awaiting delivery.'),
(1, 't', 1457, 'Quantity in physical inventory', 'A quantity of goods held in physical inventory.'),
(1, 't', 1458, 'Quantity held by logistic service provider', 'Quantity of goods under the control of a logistic service provider.'),
(1, 't', 1459, 'Optimal quantity', 'The optimal quantity for a given purpose.'),
(1, 't', 1460, 'Delivery quantity balance', 'The difference between the scheduled quantity and the quantity delivered to the consignee at a given date.'),
(1, 't', 1461, 'Cumulative quantity shipped', 'Cumulative quantity of all shipments.'),
(1, 't', 1462, 'Quantity suspended', 'The quantity of something which is suspended.'),
(1, 't', 1463, 'Control quantity', 'The quantity designated for control purposes.'),
(1, 't', 1464, 'Equipment quantity', 'A count of a quantity of equipment.'),
(1, 't', 1465, 'Factor', 'Number by which the measured unit has to be multiplied to calculate the units used.'),
(1, 't', 1466, 'Unsold quantity held by wholesaler', 'Unsold quantity held by the wholesaler.'),
(1, 't', 1467, 'Quantity held by delivery vehicle', 'Quantity of goods held by the delivery vehicle.'),
(1, 't', 1468, 'Quantity held by retail outlet', 'Quantity held by the retail outlet.'),
(1, 'f', 1469, 'Rejected return quantity', 'A quantity for return which has been rejected.'),
(1, 't', 1470, 'Accounts', 'The number of accounts.'),
(1, 't', 1471, 'Accounts placed for collection', 'The number of accounts placed for collection.'),
(1, 't', 1472, 'Activity codes', 'The number of activity codes.'),
(1, 't', 1473, 'Agents', 'The number of agents.'),
(1, 't', 1474, 'Airline attendants', 'The number of airline attendants.'),
(1, 't', 1475, 'Authorised shares', 'The number of shares authorised for issue.'),
(1, 't', 1476, 'Employee average', 'The average number of employees.'),
(1, 't', 1477, 'Branch locations', 'The number of branch locations.'),
(1, 't', 1478, 'Capital changes', 'The number of capital changes made.'),
(1, 't', 1479, 'Clerks', 'The number of clerks.'),
(1, 't', 1480, 'Companies in same activity', 'The number of companies doing business in the same activity category.'),
(1, 't', 1481, 'Companies included in consolidated financial statement', 'The number of companies included in a consolidated financial statement.'),
(1, 't', 1482, 'Cooperative shares', 'The number of cooperative shares.'),
(1, 't', 1483, 'Creditors', 'The number of creditors.'),
(1, 't', 1484, 'Departments', 'The number of departments.'),
(1, 't', 1485, 'Design employees', 'The number of employees involved in the design process.'),
(1, 't', 1486, 'Physicians', 'The number of medical doctors.'),
(1, 't', 1487, 'Domestic affiliated companies', 'The number of affiliated companies located within the country.'),
(1, 't', 1488, 'Drivers', 'The number of drivers.'),
(1, 't', 1489, 'Employed at location', 'The number of employees at the specified location.'),
(1, 't', 1490, 'Employed by this company', 'The number of employees at the specified company.'),
(1, 't', 1491, 'Total employees', 'The total number of employees.'),
(1, 't', 1492, 'Employees shared', 'The number of employees shared among entities.'),
(1, 't', 1493, 'Engineers', 'The number of engineers.'),
(1, 't', 1494, 'Estimated accounts', 'The estimated number of accounts.'),
(1, 't', 1495, 'Estimated employees at location', 'The estimated number of employees at the specified location.'),
(1, 't', 1496, 'Estimated total employees', 'The total estimated number of employees.'),
(1, 't', 1497, 'Executives', 'The number of executives.'),
(1, 't', 1498, 'Agricultural workers', 'The number of agricultural workers.'),
(1, 't', 1499, 'Financial institutions', 'The number of financial institutions.'),
(1, 't', 1500, 'Floors occupied', 'The number of floors occupied.'),
(1, 't', 1501, 'Foreign related entities', 'The number of related entities located outside the country.'),
(1, 't', 1502, 'Group employees', 'The number of employees within the group.'),
(1, 't', 1503, 'Indirect employees', 'The number of employees not associated with direct production.'),
(1, 't', 1504, 'Installers', 'The number of employees involved with the installation process.'),
(1, 't', 1505, 'Invoices', 'The number of invoices.'),
(1, 't', 1506, 'Issued shares', 'The number of shares actually issued.'),
(1, 't', 1507, 'Labourers', 'The number of labourers.'),
(1, 't', 1508, 'Manufactured units', 'The number of units manufactured.'),
(1, 't', 1509, 'Maximum number of employees', 'The maximum number of people employed.'),
(1, 't', 1510, 'Maximum number of employees at location', 'The maximum number of people employed at a location.'),
(1, 't', 1511, 'Members in group', 'The number of members within a group.'),
(1, 't', 1512, 'Minimum number of employees at location', 'The minimum number of people employed at a location.'),
(1, 't', 1513, 'Minimum number of employees', 'The minimum number of people employed.'),
(1, 't', 1514, 'Non-union employees', 'The number of employees not belonging to a labour union.'),
(1, 't', 1515, 'Floors', 'The number of floors in a building.'),
(1, 't', 1516, 'Nurses', 'The number of nurses.'),
(1, 't', 1517, 'Office workers', 'The number of workers in an office.'),
(1, 't', 1518, 'Other employees', 'The number of employees otherwise categorised.'),
(1, 't', 1519, 'Part time employees', 'The number of employees working on a part time basis.'),
(1, 't', 1520, 'Accounts payable average overdue days', 'The average number of days accounts payable are overdue.'),
(1, 't', 1521, 'Pilots', 'The number of pilots.'),
(1, 't', 1522, 'Plant workers', 'The number of workers within a plant.'),
(1, 't', 1523, 'Previous number of accounts', 'The number of accounts which preceded the current count.'),
(1, 't', 1524, 'Previous number of branch locations', 'The number of branch locations which preceded the current count.'),
(1, 't', 1525, 'Principals included as employees', 'The number of principals which are included in the count of employees.'),
(1, 't', 1526, 'Protested bills', 'The number of bills which are protested.'),
(1, 't', 1527, 'Registered brands distributed', 'The number of registered brands which are being distributed.'),
(1, 't', 1528, 'Registered brands manufactured', 'The number of registered brands which are being manufactured.'),
(1, 't', 1529, 'Related business entities', 'The number of related business entities.'),
(1, 't', 1530, 'Relatives employed', 'The number of relatives which are counted as employees.'),
(1, 't', 1531, 'Rooms', 'The number of rooms.'),
(1, 't', 1532, 'Salespersons', 'The number of salespersons.'),
(1, 't', 1533, 'Seats', 'The number of seats.'),
(1, 't', 1534, 'Shareholders', 'The number of shareholders.'),
(1, 't', 1535, 'Shares of common stock', 'The number of shares of common stock.'),
(1, 't', 1536, 'Shares of preferred stock', 'The number of shares of preferred stock.'),
(1, 't', 1537, 'Silent partners', 'The number of silent partners.'),
(1, 't', 1538, 'Subcontractors', 'The number of subcontractors.'),
(1, 't', 1539, 'Subsidiaries', 'The number of subsidiaries.'),
(1, 't', 1540, 'Law suits', 'The number of law suits.'),
(1, 't', 1541, 'Suppliers', 'The number of suppliers.'),
(1, 't', 1542, 'Teachers', 'The number of teachers.'),
(1, 't', 1543, 'Technicians', 'The number of technicians.'),
(1, 't', 1544, 'Trainees', 'The number of trainees.'),
(1, 't', 1545, 'Union employees', 'The number of employees who are members of a labour union.'),
(1, 't', 1546, 'Number of units', 'The quantity of units.'),
(1, 't', 1547, 'Warehouse employees', 'The number of employees who work in a warehouse setting.'),
(1, 't', 1548, 'Shareholders holding remainder of shares', 'Number of shareholders owning the remainder of shares.'),
(1, 't', 1549, 'Payment orders filed', 'Number of payment orders filed.'),
(1, 't', 1550, 'Uncovered cheques', 'Number of uncovered cheques.'),
(1, 't', 1551, 'Auctions', 'Number of auctions.'),
(1, 't', 1552, 'Units produced', 'The number of units produced.'),
(1, 't', 1553, 'Added employees', 'Number of employees that were added to the workforce.'),
(1, 't', 1554, 'Number of added locations', 'Number of locations that were added.'),
(1, 't', 1555, 'Total number of foreign subsidiaries not included in', 'financial statement The total number of foreign subsidiaries not included in the financial statement.'),
(1, 't', 1556, 'Number of closed locations', 'Number of locations that were closed.'),
(1, 't', 1557, 'Counter clerks', 'The number of clerks that work behind a flat-topped fitment.'),
(1, 't', 1558, 'Payment experiences in the last 3 months', 'The number of payment experiences received for an entity over the last 3 months.'),
(1, 't', 1559, 'Payment experiences in the last 12 months', 'The number of payment experiences received for an entity over the last 12 months.'),
(1, 't', 1560, 'Total number of subsidiaries not included in the financial', 'statement The total number of subsidiaries not included in the financial statement.'),
(1, 't', 1561, 'Paid-in common shares', 'The number of paid-in common shares.'),
(1, 't', 1562, 'Total number of domestic subsidiaries not included in', 'financial statement The total number of domestic subsidiaries not included in the financial statement.'),
(1, 't', 1563, 'Total number of foreign subsidiaries included in financial statement', 'The total number of foreign subsidiaries included in the financial statement.'),
(1, 't', 1564, 'Total number of domestic subsidiaries included in financial statement', 'The total number of domestic subsidiaries included in the financial statement.'),
(1, 't', 1565, 'Total transactions', 'The total number of transactions.'),
(1, 't', 1566, 'Paid-in preferred shares', 'The number of paid-in preferred shares.'),
(1, 't', 1567, 'Employees', 'Code specifying the quantity of persons working for a company, whose services are used for pay.'),
(1, 't', 1568, 'Active ingredient dose per unit, dispensed', 'The dosage of active ingredient per dispensed unit.'),
(1, 't', 1569, 'Budget', 'Budget quantity.'),
(1, 't', 1570, 'Budget, cumulative to date', 'Budget quantity, cumulative to date.'),
(1, 't', 1571, 'Actual units', 'The number of actual units.'),
(1, 't', 1572, 'Actual units, cumulative to date', 'The number of cumulative to date actual units.'),
(1, 't', 1573, 'Earned value', 'Earned value quantity.'),
(1, 't', 1574, 'Earned value, cumulative to date', 'Earned value quantity accumulated to date.'),
(1, 't', 1575, 'At completion quantity, estimated', 'The estimated quantity when a project is complete.'),
(1, 't', 1576, 'To complete quantity, estimated', 'The estimated quantity required to complete a project.'),
(1, 't', 1577, 'Adjusted units', 'The number of adjusted units.'),
(1, 't', 1578, 'Number of limited partnership shares', 'Number of shares held in a limited partnership.'),
(1, 't', 1579, 'National business failure incidences', 'Number of firms in a country that discontinued with a loss to creditors.'),
(1, 't', 1580, 'Industry business failure incidences', 'Number of firms in a specific industry that discontinued with a loss to creditors.'),
(1, 't', 1581, 'Business class failure incidences', 'Number of firms in a specific class that discontinued with a loss to creditors.'),
(1, 't', 1582, 'Mechanics', 'Number of mechanics.'),
(1, 't', 1583, 'Messengers', 'Number of messengers.'),
(1, 't', 1584, 'Primary managers', 'Number of primary managers.'),
(1, 't', 1585, 'Secretaries', 'Number of secretaries.'),
(1, 't', 1586, 'Detrimental legal filings', 'Number of detrimental legal filings.'),
(1, 't', 1587, 'Branch office locations, estimated', 'Estimated number of branch office locations.'),
(1, 't', 1588, 'Previous number of employees', 'The number of employees for a previous period.'),
(1, 't', 1589, 'Asset seizers', 'Number of entities that seize assets of another entity.'),
(1, 't', 1590, 'Out-turned quantity', 'The quantity discharged.'),
(1, 't', 1591, 'Material on-board quantity, prior to loading', 'The material in vessel tanks, void spaces, and pipelines prior to loading.'),
(1, 't', 1592, 'Supplier estimated previous meter reading', 'Previous meter reading estimated by the supplier.'),
(1, 't', 1593, 'Supplier estimated latest meter reading', 'Latest meter reading estimated by the supplier.'),
(1, 't', 1594, 'Customer estimated previous meter reading', 'Previous meter reading estimated by the customer.'),
(1, 't', 1595, 'Customer estimated latest meter reading', 'Latest meter reading estimated by the customer.'),
(1, 't', 1596, 'Supplier previous meter reading', 'Previous meter reading done by the supplier.'),
(1, 't', 1597, 'Supplier latest meter reading', 'Latest meter reading recorded by the supplier.'),
(1, 't', 1598, 'Maximum number of purchase orders allowed', 'Maximum number of purchase orders that are allowed.'),
(1, 't', 1599, 'File size before compression', 'The size of a file before compression.'),
(1, 't', 1600, 'File size after compression', 'The size of a file after compression.'),
(1, 't', 1601, 'Securities shares', 'Number of shares of securities.'),
(1, 't', 1602, 'Patients', 'Number of patients.'),
(1, 't', 1603, 'Completed projects', 'Number of completed projects.'),
(1, 't', 1604, 'Promoters', 'Number of entities who finance or organize an event or a production.'),
(1, 't', 1605, 'Administrators', 'Number of administrators.'),
(1, 't', 1606, 'Supervisors', 'Number of supervisors.'),
(1, 't', 1607, 'Professionals', 'Number of professionals.'),
(1, 't', 1608, 'Debt collectors', 'Number of debt collectors.'),
(1, 't', 1609, 'Inspectors', 'Number of individuals who perform inspections.'),
(1, 't', 1610, 'Operators', 'Number of operators.'),
(1, 't', 1611, 'Trainers', 'Number of trainers.'),
(1, 't', 1612, 'Active accounts', 'Number of accounts in a current or active status.'),
(1, 't', 1613, 'Trademarks used', 'Number of trademarks used.'),
(1, 't', 1614, 'Machines', 'Number of machines.'),
(1, 't', 1615, 'Fuel pumps', 'Number of fuel pumps.'),
(1, 't', 1616, 'Tables available', 'Number of tables available for use.'),
(1, 't', 1617, 'Directors', 'Number of directors.'),
(1, 't', 1618, 'Freelance debt collectors', 'Number of debt collectors who work on a freelance basis.'),
(1, 't', 1619, 'Freelance salespersons', 'Number of salespersons who work on a freelance basis.'),
(1, 't', 1620, 'Travelling employees', 'Number of travelling employees.'),
(1, 't', 1621, 'Foremen', 'Number of workers with limited supervisory responsibilities.'),
(1, 't', 1622, 'Production workers', 'Number of employees engaged in production.'),
(1, 't', 1623, 'Employees not including owners', 'Number of employees excluding business owners.'),
(1, 't', 1624, 'Beds', 'Number of beds.'),
(1, 't', 1625, 'Resting quantity', 'A quantity of product that is at rest before it can be used.'),
(1, 't', 1626, 'Production requirements', 'Quantity needed to meet production requirements.'),
(1, 't', 1627, 'Corrected quantity', 'The quantity has been corrected.'),
(1, 't', 1628, 'Operating divisions', 'Number of divisions operating.'),
(1, 't', 1629, 'Quantitative incentive scheme base', 'Quantity constituting the base for the quantitative incentive scheme.'),
(1, 't', 1630, 'Petitions filed', 'Number of petitions that have been filed.'),
(1, 't', 1631, 'Bankruptcy petitions filed', 'Number of bankruptcy petitions that have been filed.'),
(1, 't', 1632, 'Projects in process', 'Number of projects in process.'),
(1, 't', 1633, 'Changes in capital structure', 'Number of modifications made to the capital structure of an entity.'),
(1, 't', 1634, 'Detrimental legal filings against directors', 'The number of legal filings that are of a detrimental nature that have been filed against the directors.'),
(1, 't', 1635, 'Number of failed businesses of directors', 'The number of failed businesses with which the directors have been associated.'),
(1, 't', 1636, 'Professor', 'The number of professors.'),
(1, 't', 1637, 'Seller', 'The number of sellers.'),
(1, 't', 1638, 'Skilled worker', 'The number of skilled workers.'),
(1, 't', 1639, 'Trademark represented', 'The number of trademarks represented.'),
(1, 't', 1640, 'Number of quantitative incentive scheme units', 'Number of units allocated to a quantitative incentive scheme.'),
(1, 't', 1641, 'Quantity in manufacturing process', 'Quantity currently in the manufacturing process.'),
(1, 't', 1642, 'Number of units in the width of a layer', 'Number of units which make up the width of a layer.'),
(1, 't', 1643, 'Number of units in the depth of a layer', 'Number of units which make up the depth of a layer.'),
(1, 't', 1644, 'Return to warehouse', 'A quantity of products sent back to the warehouse.'),
(1, 't', 1645, 'Return to the manufacturer', 'A quantity of products sent back from the manufacturer.'),
(1, 't', 1646, 'Delta quantity', 'An increment or decrement to a quantity.'),
(1, 't', 1647, 'Quantity moved between outlets', 'A quantity of products moved between outlets.'),
(1, 't', 1648, 'Pre-paid invoice annual consumption, estimated', 'The estimated annual consumption used for a prepayment invoice.'),
(1, 't', 1649, 'Total quoted quantity', 'The sum of quoted quantities.'),
(1, 't', 1650, 'Requests pertaining to entity in last 12 months', 'Number of requests received in last 12 months pertaining to the entity.'),
(1, 't', 1651, 'Total inquiry matches', 'Number of instances which correspond with the inquiry.'),
(1, 't', 1652, 'En route to warehouse quantity', 'A quantity of products that is en route to a warehouse.'),
(1, 't', 1653, 'En route from warehouse quantity', 'A quantity of products that is en route from a warehouse.'),
(1, 't', 1654, 'Quantity ordered but not yet allocated from stock', 'A quantity of products which has been ordered but which has not yet been allocated from stock.'),
(1, 't', 1655, 'Not yet ordered quantity', 'The quantity which has not yet been ordered.'),
(1, 't', 1656, 'Net reserve power', 'The reserve power available for the net.'),
(1, 't', 1657, 'Maximum number of units per shelf', 'Maximum number of units of a product that can be placed on a shelf.'),
(1, 't', 1658, 'Stowaway', 'Number of stowaway(s) on a conveyance.'),
(1, 't', 1659, 'Tug', 'The number of tugboat(s).'),
(1, 't', 1660, 'Maximum quantity capability of the package', 'Maximum quantity of a product that can be contained in a package.'),
(1, 't', 1661, 'Calculated', 'The calculated quantity.'),
(1, 't', 1662, 'Monthly volume, estimated', 'Volume estimated for a month.'),
(1, 't', 1663, 'Total number of persons', 'Quantity representing the total number of persons.'),
(1, 't', 1664, 'Tariff Quantity', 'Quantity of the goods in the unit as required by Customs for duty/tax/fee assessment. These quantities may also be used for other fiscal or statistical purposes.'),
(1, 't', 1665, 'Deducted tariff quantity', 'Quantity deducted from tariff quantity to reckon duty/tax/fee assessment bases.'),
(1, 't', 1666, 'Advised but not arrived', 'Goods are advised by the consignor or supplier, but have not yet arrived at the destination.'),
(1, 't', 1667, 'Received but not available', 'Goods have been received in the arrival area but are not yet available.'),
(1, 't', 1668, 'Goods blocked for transshipment process', 'Goods are physically present, but can not be ordered because they are scheduled for a transshipment process.'),
(1, 't', 1669, 'Goods blocked for cross docking process', 'Goods are physically present, but can not be ordered because they are scheduled for a cross docking process.'),
(1, 't', 1670, 'Chargeable number of trailers', 'The number of trailers on which charges are based.'),
(1, 't', 1671, 'Number of packages for a set', 'Number of packages used to pack the individual items in a grouping of merchandise that is sold together as a single trade item.'),
(1, 't', 1672, 'Number of items in a set', 'The number of individual items in a grouping of merchandise that is sold together as a single trade item.'),
(1, 't', 1673, 'Order sizing factor', 'A trade item specification other than gross, net weight, or volume for a trade item or a transaction, used for order sizing and pricing purposes.'),
(1, 't', 1674, 'Number of different next lower level trade items', 'Value indicates the number of differrent next lower level trade items contained in a complex trade item.'),
(1, 't', 1675, 'Agreed maximum buying quantity', 'The agreed maximum quantity of the trade item that may be purchased.'),
(1, 't', 1676, 'Agreed minimum buying quantity', 'The agreed minimum quantity of the trade item that may be purchased.'),
(1, 't', 1677, 'Free quantity of next lower level trade item', 'The numeric quantity of free items in a combination pack. The unit of measure used for the free quantity of the next lower level must be the same as the unit of measure of the Net Content of the Child Trade Item.'),
(1, 't', 1678, 'Marine Diesel Oil bunkers on board, on arrival', 'Number of Marine Diesel Oil (MDO) bunkers on board when the vessel arrives in the port.'),
(1, 't', 1679, 'Marine Diesel Oil bunkers, loaded', 'Number of Marine Diesel Oil (MDO) bunkers taken on in the port.'),
(1, 't', 1680, 'Intermediate Fuel Oil bunkers on board, on arrival', 'Number of Intermediate Fuel Oil (IFO) bunkers on board when the vessel arrives in the port.'),
(1, 't', 1681, 'Intermediate Fuel Oil bunkers, loaded', 'Number of Intermediate Fuel Oil (IFO) bunkers taken on in the port.'),
(1, 't', 1682, 'Bunker C bunkers on board, on arrival', 'Number of Bunker C, or Number 6 fuel oil bunkers on board when the vessel arrives in the port.'),
(1, 't', 1683, 'Bunker C bunkers, loaded', 'Number of Bunker C, or Number 6 fuel oil bunkers, taken on in the port.'),
(1, 't', 1684, 'Number of individual units within the smallest packaging', 'unit Total number of individual units contained within the smallest unit of packaging.'),
(1, 't', 1685, 'Percentage of constituent element', 'The part of a product or material that is composed of the constituent element, as a percentage.'),
(1, 't', 1686, 'Quantity to be decremented (LPCO)', 'Quantity to be decremented from the allowable quantity on a License, Permit, Certificate, or Other document (LPCO).'),
(1, 't', 1687, 'Regulated commodity count', 'The number of regulated items.'),
(1, 't', 1688, 'Number of passengers, embarking', 'The number of passengers going aboard a conveyance.'),
(1, 't', 1689, 'Number of passengers, disembarking', 'The number of passengers disembarking the conveyance.'),
(1, 't', 1690, 'Constituent element or component quantity', 'The specific quantity of the identified constituent element.')
;
-- ZZZ, 'Mutually defined', 'As agreed by the trading partners.'),
INSERT INTO config.global_flag (name, label, enabled)
VALUES (
'circ.holds.usr_not_requestor',
oils_i18n_gettext(
'circ.holds.usr_not_requestor',
'Holds: When testing hold matrix matchpoints, use the profile group of the receiving user instead of that of the requestor (affects staff-placed holds)',
'cgf',
'label'
),
TRUE
);
INSERT INTO config.global_flag (name, label, enabled)
VALUES (
'circ.holds.empty_issuance_ok',
oils_i18n_gettext(
'circ.holds.empty_issuance_ok',
'Holds: Allow holds on empty issuances',
'cgf',
'label'
),
TRUE
);
INSERT INTO config.global_flag (name, label) -- defaults to enabled=FALSE
VALUES (
'ingest.disable_authority_linking',
oils_i18n_gettext(
'ingest.disable_authority_linking',
'Authority Automation: Disable bib-authority link tracking',
'cgf',
'label'
)
);
INSERT INTO config.global_flag (name, label) -- defaults to enabled=FALSE
VALUES (
'ingest.disable_authority_auto_update',
oils_i18n_gettext(
'ingest.disable_authority_auto_update',
'Authority Automation: Disable automatic authority updating (requires link tracking)',
'cgf',
'label'
)
);
INSERT INTO config.global_flag (name, label, enabled)
VALUES (
'cat.bib.use_id_for_tcn',
oils_i18n_gettext(
'cat.bib.use_id_for_tcn',
'Cat: Use Internal ID for TCN Value',
'cgf',
'label'
),
TRUE
);
INSERT INTO config.global_flag (name,label,enabled)
VALUES (
'history.circ.retention_age',
oils_i18n_gettext('history.circ.retention_age', 'Historical Circulation Retention Age', 'cgf', 'label'),
TRUE
),(
'history.circ.retention_count',
oils_i18n_gettext('history.circ.retention_count', 'Historical Circulations per Copy', 'cgf', 'label'),
TRUE
);
INSERT INTO config.global_flag (name, label, enabled)
VALUES (
'cat.maintain_control_numbers',
oils_i18n_gettext(
'cat.maintain_control_numbers',
'Cat: Maintain 001/003/035 according to the MARC21 specification',
'cgf',
'label'
),
TRUE
);
INSERT INTO config.global_flag (name, label, enabled)
VALUES (
'circ.opac_renewal.use_original_circ_lib',
oils_i18n_gettext(
'circ.opac_renewal.use_original_circ_lib',
'Circ: Use original circulation library on opac renewal instead of user home library',
'cgf',
'label'
),
FALSE
);
INSERT INTO config.usr_setting_type (name,opac_visible,label,description,datatype)
VALUES (
'history.circ.retention_age',
TRUE,
oils_i18n_gettext('history.circ.retention_age','Historical Circulation Retention Age','cust','label'),
oils_i18n_gettext('history.circ.retention_age','Historical Circulation Retention Age','cust','description'),
'interval'
),(
'history.circ.retention_start',
FALSE,
oils_i18n_gettext('history.circ.retention_start','Historical Circulation Retention Start Date','cust','label'),
oils_i18n_gettext('history.circ.retention_start','Historical Circulation Retention Start Date','cust','description'),
'date'
);
INSERT INTO config.usr_setting_type (name,opac_visible,label,description,datatype)
VALUES (
'history.hold.retention_age',
TRUE,
oils_i18n_gettext('history.hold.retention_age','Historical Hold Retention Age','cust','label'),
oils_i18n_gettext('history.hold.retention_age','Historical Hold Retention Age','cust','description'),
'interval'
),(
'history.hold.retention_start',
TRUE,
oils_i18n_gettext('history.hold.retention_start','Historical Hold Retention Start Date','cust','label'),
oils_i18n_gettext('history.hold.retention_start','Historical Hold Retention Start Date','cust','description'),
'interval'
),(
'history.hold.retention_count',
TRUE,
oils_i18n_gettext('history.hold.retention_count','Historical Hold Retention Count','cust','label'),
oils_i18n_gettext('history.hold.retention_count','Historical Hold Retention Count','cust','description'),
'integer'
);
-- 0311.data.query-seed-datatypes.sql
-- Define the most common datatypes in query.datatype. Note that none of
-- these stock datatypes specifies a width or precision.
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (1, 'SMALLINT', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (2, 'INTEGER', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (3, 'BIGINT', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (4, 'DECIMAL', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (5, 'NUMERIC', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (6, 'REAL', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (7, 'DOUBLE PRECISION', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (8, 'SERIAL', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (9, 'BIGSERIAL', true);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (10, 'MONEY', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (11, 'VARCHAR', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (12, 'CHAR', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (13, 'TEXT', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (14, '"char"', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (15, 'NAME', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (16, 'BYTEA', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (17, 'TIMESTAMP WITHOUT TIME ZONE', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (18, 'TIMESTAMP WITH TIME ZONE', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (19, 'DATE', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (20, 'TIME WITHOUT TIME ZONE', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (21, 'TIME WITH TIME ZONE', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (22, 'INTERVAL', false);
INSERT INTO query.datatype (id, datatype_name, is_numeric )
VALUES (23, 'BOOLEAN', false);
INSERT INTO config.usr_setting_type (name, opac_visible, label, description, datatype)
VALUES (
'opac.default_sort',
TRUE,
oils_i18n_gettext(
'opac.default_sort',
'OPAC Default Search Sort',
'cust',
'label'
),
oils_i18n_gettext(
'opac.default_sort',
'OPAC Default Search Sort',
'cust',
'description'
),
'string'
);
-- 0355.data.missing_pieces_format.sql
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES
( 'circ.format.missing_pieces.slip.print',
'circ',
oils_i18n_gettext(
'circ.format.missing_pieces.slip.print',
'A missing pieces slip needs to be formatted for printing.',
'ath',
'description'
),
FALSE
)
,( 'circ.format.missing_pieces.letter.print',
'circ',
oils_i18n_gettext(
'circ.format.missing_pieces.letter.print',
'A missing pieces patron letter needs to be formatted for printing.',
'ath',
'description'
),
FALSE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
group_field,
granularity,
template
) VALUES (
33,
TRUE,
1,
'circ.missing_pieces.slip.print',
'circ.format.missing_pieces.slip.print',
'NOOP_True',
'ProcessTemplate',
'usr',
'print-on-demand',
$$
[%- USE date -%]
[%- SET user = target.0.usr -%]
$$
)
,(
34,
TRUE,
1,
'circ.missing_pieces.letter.print',
'circ.format.missing_pieces.letter.print',
'NOOP_True',
'ProcessTemplate',
'usr',
'print-on-demand',
$$
[%- USE date -%]
[%- SET user = target.0.usr -%]
[% date.format %]
Dear [% user.prefix %] [% user.first_given_name %] [% user.family_name %],
We are missing pieces for the following returned items:
[% FOR circ IN target %]
Barcode: [% circ.target_copy.barcode %] Transaction ID: [% circ.id %] Due: [% circ.due_date.format %]
[% helpers.get_copy_bib_basics(circ.target_copy.id).title %]
[% END %]
Please return these pieces as soon as possible.
Thanks!
Library Staff
$$
)
;
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES -- for fleshing circ objects
( 33, 'usr')
,( 33, 'target_copy')
,( 33, 'target_copy.circ_lib')
,( 33, 'target_copy.circ_lib.mailing_address')
,( 33, 'target_copy.circ_lib.billing_address')
,( 33, 'target_copy.call_number')
,( 33, 'target_copy.call_number.owning_lib')
,( 33, 'target_copy.call_number.owning_lib.mailing_address')
,( 33, 'target_copy.call_number.owning_lib.billing_address')
,( 33, 'circ_lib')
,( 33, 'circ_lib.mailing_address')
,( 33, 'circ_lib.billing_address')
,( 34, 'usr')
,( 34, 'target_copy')
,( 34, 'target_copy.circ_lib')
,( 34, 'target_copy.circ_lib.mailing_address')
,( 34, 'target_copy.circ_lib.billing_address')
,( 34, 'target_copy.call_number')
,( 34, 'target_copy.call_number.owning_lib')
,( 34, 'target_copy.call_number.owning_lib.mailing_address')
,( 34, 'target_copy.call_number.owning_lib.billing_address')
,( 34, 'circ_lib')
,( 34, 'circ_lib.mailing_address')
,( 34, 'circ_lib.billing_address')
;
-- 0384.data.hold_pull_list_template.sql
INSERT INTO action_trigger.hook (key,core_type,description,passive)
VALUES (
'ahr.format.pull_list',
'ahr',
oils_i18n_gettext(
'ahr.format.pull_list',
'Format holds pull list for printing',
'ath',
'description'
),
FALSE
);
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
group_field,
granularity,
template
) VALUES (
35,
TRUE,
1,
'Holds Pull List',
'ahr.format.pull_list',
'NOOP_True',
'ProcessTemplate',
'pickup_lib',
'print-on-demand',
$$
[%- USE date -%]
[%
# Sort the holds into copy-location buckets
# In the main print loop, sort each bucket by callnumber before printing
SET holds_list = [];
SET loc_data = [];
SET current_location = target.0.current_copy.location.id;
FOR hold IN target;
IF current_location != hold.current_copy.location.id;
SET current_location = hold.current_copy.location.id;
holds_list.push(loc_data);
SET loc_data = [];
END;
SET hold_data = {
'hold' => hold,
'callnumber' => hold.current_copy.call_number.label
};
loc_data.push(hold_data);
END;
holds_list.push(loc_data)
%]
Title
Author
Shelving Location
Call Number
Barcode/Part
Patron
[% FOR loc_data IN holds_list %]
[% FOR hold_data IN loc_data.sort('callnumber') %]
[%
SET hold = hold_data.hold;
SET copy_data = helpers.get_copy_bib_basics(hold.current_copy.id);
%]
[% copy_data.title | truncate %]
[% copy_data.author | truncate %]
[% hold.current_copy.location.name %]
[% hold.current_copy.call_number.label %]
[% hold.current_copy.barcode %]
[% FOR part IN hold.current_copy.parts %]
[% part.part.label %]
[% END %]
[% hold.usr.card.barcode %]
[% END %]
[% END %]
$$
);
INSERT INTO action_trigger.environment (
event_def,
path
) VALUES
(35, 'current_copy.location'),
(35, 'current_copy.call_number'),
(35, 'usr.card'),
(35, 'pickup_lib'),
(35, 'current_copy.parts'),
(35, 'current_copy.parts.part')
;
-- 0412.data.trigger.validator.HoldIsCancelled.sql
INSERT INTO action_trigger.validator (module, description) VALUES (
'HoldIsCancelled',
oils_i18n_gettext(
'HoldIsCancelled',
'Check whether a hold request is cancelled.',
'atval',
'description'
)
);
-- 0448.data.trigger.circ.staff_age_to_lost.sql
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES
( 'circ.staff_age_to_lost',
'circ',
oils_i18n_gettext(
'circ.staff_age_to_lost',
'An overdue circulation should be aged to a Lost status.',
'ath',
'description'
),
TRUE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
delay_field
) VALUES (
36,
FALSE,
1,
'circ.staff_age_to_lost',
'circ.staff_age_to_lost',
'CircIsOverdue',
'MarkItemLost',
'due_date'
)
;
INSERT INTO action_trigger.hook (key,core_type,description)
VALUES ('circ.recall.target', 'circ', 'A checked-out copy has been recalled for a hold.');
INSERT INTO action_trigger.event_definition (id, owner, name, hook, validator, reactor, group_field, template)
VALUES (37, 1, 'Item Recall Email Notice', 'circ.recall.target', 'NOOP_True', 'SendEmail', 'usr',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Item Recall Notification
Dear [% user.family_name %], [% user.first_given_name %]
The following item which you have checked out has been recalled so that
another patron can have access to the item:
[% FOR circ IN target %]
Title: [% circ.target_copy.call_number.record.simple_record.title %]
Barcode: [% circ.target_copy.barcode %]
Now Due: [% date.format(helpers.format_date(circ.due_date), '%Y-%m-%d') %]
Library: [% circ.circ_lib.name %]
If this item is not returned by the new due date, fines will be assessed at
the rate of [% circ.recurring_fine %] every [% circ.fine_interval %].
[% END %]
$$
);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(37, 'target_copy.call_number.record.simple_record'),
(37, 'usr'),
(37, 'circ_lib.billing_address')
;
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'general.unknown', oils_i18n_gettext('general.unknown', 'Import or Overlay failed', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.item.duplicate.barcode', oils_i18n_gettext('import.item.duplicate.barcode', 'Import failed due to barcode collision', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.item.invalid.circ_modifier', oils_i18n_gettext('import.item.invalid.circ_modifier', 'Import failed due to invalid circulation modifier', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.item.invalid.location', oils_i18n_gettext('import.item.invalid.location', 'Import failed due to invalid copy location', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.duplicate.sysid', oils_i18n_gettext('import.duplicate.sysid', 'Import failed due to system id collision', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.duplicate.tcn', oils_i18n_gettext('import.duplicate.sysid', 'Import failed due to system id collision', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.missing.sysid', oils_i18n_gettext('overlay.missing.sysid', 'Overlay failed due to missing system id', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.auth.duplicate.acn', oils_i18n_gettext('import.auth.duplicate.acn', 'Import failed due to Accession Number collision', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.xml.malformed', oils_i18n_gettext('import.xml.malformed', 'Malformed record cause Import failure', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.xml.malformed', oils_i18n_gettext('overlay.xml.malformed', 'Malformed record cause Overlay failure', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.record.quality', oils_i18n_gettext('overlay.record.quality', 'New record had insufficient quality', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.status', oils_i18n_gettext('import.item.invalid.status', 'Invalid value for "status"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.price', oils_i18n_gettext('import.item.invalid.price', 'Invalid value for "price"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.deposit_amount', oils_i18n_gettext('import.item.invalid.deposit_amount', 'Invalid value for "deposit_amount"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.owning_lib', oils_i18n_gettext('import.item.invalid.owning_lib', 'Invalid value for "owning_lib"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.circ_lib', oils_i18n_gettext('import.item.invalid.circ_lib', 'Invalid value for "circ_lib"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.copy_number', oils_i18n_gettext('import.item.invalid.copy_number', 'Invalid value for "copy_number"', 'vie', 'description') );
INSERT INTO vandelay.import_error ( code, description ) VALUES (
'import.item.invalid.circ_as_type', oils_i18n_gettext('import.item.invalid.circ_as_type', 'Invalid value for "circ_as_type"', 'vie', 'description') );
-- Event def for email notice for hold cancelled due to lack of target -----
INSERT INTO action_trigger.event_definition (id, active, owner, name, hook, validator, reactor, delay, delay_field, group_field, template)
VALUES (38, FALSE, 1,
'Hold Cancelled (No Target) Email Notification',
'hold_request.cancel.expire_no_target',
'HoldIsCancelled', 'SendEmail', '30 minutes', 'cancel_time', 'usr',
$$
[%- USE date -%]
[%- user = target.0.usr -%]
To: [%- params.recipient_email || user.email %]
From: [%- params.sender_email || default_sender %]
Subject: Hold Request Cancelled
Dear [% user.family_name %], [% user.first_given_name %]
The following holds were cancelled because no items were found to fullfil the hold.
[% FOR hold IN target %]
Title: [% hold.bib_rec.bib_record.simple_record.title %]
Author: [% hold.bib_rec.bib_record.simple_record.author %]
Library: [% hold.pickup_lib.name %]
Request Date: [% date.format(helpers.format_date(hold.rrequest_time), '%Y-%m-%d') %]
[% END %]
$$);
INSERT INTO action_trigger.environment (event_def, path) VALUES
(38, 'usr'),
(38, 'pickup_lib'),
(38, 'bib_rec.bib_record.simple_record');
----------------------------------------------------------------
-- Seed data for queued record/item exports
----------------------------------------------------------------
INSERT INTO action_trigger.hook (key,core_type,description,passive) VALUES (
'vandelay.queued_bib_record.print',
'vqbr',
oils_i18n_gettext(
'vandelay.queued_bib_record.print',
'Print output has been requested for records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.queued_bib_record.csv',
'vqbr',
oils_i18n_gettext(
'vandelay.queued_bib_record.csv',
'CSV output has been requested for records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.queued_bib_record.email',
'vqbr',
oils_i18n_gettext(
'vandelay.queued_bib_record.email',
'An email has been requested for records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.queued_auth_record.print',
'vqar',
oils_i18n_gettext(
'vandelay.queued_auth_record.print',
'Print output has been requested for records in an Importer Authority Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.queued_auth_record.csv',
'vqar',
oils_i18n_gettext(
'vandelay.queued_auth_record.csv',
'CSV output has been requested for records in an Importer Authority Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.queued_auth_record.email',
'vqar',
oils_i18n_gettext(
'vandelay.queued_auth_record.email',
'An email has been requested for records in an Importer Authority Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.import_items.print',
'vii',
oils_i18n_gettext(
'vandelay.import_items.print',
'Print output has been requested for Import Items from records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.import_items.csv',
'vii',
oils_i18n_gettext(
'vandelay.import_items.csv',
'CSV output has been requested for Import Items from records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
,(
'vandelay.import_items.email',
'vii',
oils_i18n_gettext(
'vandelay.import_items.email',
'An email has been requested for Import Items from records in an Importer Bib Queue.',
'ath',
'description'
),
FALSE
)
;
INSERT INTO action_trigger.event_definition (
id,
active,
owner,
name,
hook,
validator,
reactor,
group_field,
granularity,
template
) VALUES (
39,
TRUE,
1,
'Print Output for Queued Bib Records',
'vandelay.queued_bib_record.print',
'NOOP_True',
'ProcessTemplate',
'queue.owner',
'print-on-demand',
$$
[%- USE date -%]
Queue ID: [% target.0.queue.id %]
Queue Name: [% target.0.queue.name %]
Queue Type: [% target.0.queue.queue_type %]
Complete? [% target.0.queue.complete %]
[% FOR vqbr IN target %]
=-=-=
Title of work | [% helpers.get_queued_bib_attr('title',vqbr.attributes) %]
Author of work | [% helpers.get_queued_bib_attr('author',vqbr.attributes) %]
Language of work | [% helpers.get_queued_bib_attr('language',vqbr.attributes) %]
Pagination | [% helpers.get_queued_bib_attr('pagination',vqbr.attributes) %]
ISBN | [% helpers.get_queued_bib_attr('isbn',vqbr.attributes) %]
ISSN | [% helpers.get_queued_bib_attr('issn',vqbr.attributes) %]
Price | [% helpers.get_queued_bib_attr('price',vqbr.attributes) %]
Accession Number | [% helpers.get_queued_bib_attr('rec_identifier',vqbr.attributes) %]
TCN Value | [% helpers.get_queued_bib_attr('eg_tcn',vqbr.attributes) %]
TCN Source | [% helpers.get_queued_bib_attr('eg_tcn_source',vqbr.attributes) %]
Internal ID | [% helpers.get_queued_bib_attr('eg_identifier',vqbr.attributes) %]
Publisher | [% helpers.get_queued_bib_attr('publisher',vqbr.attributes) %]
Publication Date | [% helpers.get_queued_bib_attr('pubdate',vqbr.attributes) %]
Edition | [% helpers.get_queued_bib_attr('edition',vqbr.attributes) %]
Item Barcode | [% helpers.get_queued_bib_attr('item_barcode',vqbr.attributes) %]
Import Error | [% vqbr.import_error %]
Error Detail | [% vqbr.error_detail %]
Match Count | [% vqbr.matches.size %]
[% END %]