Owen Leonard
a6abaca8d0
This patch modifies the staff client "Additional tools" templates so that JavaScript is included in the footer instead of the header: - Calendar - CSV profiles - Log viewer - News - Task scheduler - Edit quotes for QOTD feature - Upload Note that the log viewer template has been modified so that the "interface" variable (passed to the template to provide the correct path to staff client assets) isn't overwritten by an "interface" variable required by the log viewer. To test, apply the patch and test the JavaScript-driven features of each modified template: All button controls, DataTables functionality, form validation, etc. Signed-off-by: Claire Gravely <claire.gravely@bsz-bw.de> Signed-off-by: Josef Moravec <josef.moravec@gmail.com> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
541 lines
29 KiB
Text
541 lines
29 KiB
Text
[% USE Branches %]
|
|
[% SET footerjs = 1 %]
|
|
[% INCLUDE 'doc-head-open.inc' %]
|
|
<title>Koha › Tools › [% Branches.GetName( branch ) %] calendar</title>
|
|
[% INCLUDE 'doc-head-close.inc' %]
|
|
<link rel="stylesheet" type="text/css" href="[% interface %]/[% theme %]/css/datatables.css" />
|
|
<style type="text/css"> .key { padding : 3px; white-space:nowrap; line-height:230%; }
|
|
.ui-datepicker { font-size : 150%; }
|
|
.ui-datepicker th, .ui-datepicker .ui-datepicker-title select { font-size : 80%; }
|
|
.ui-datepicker td a { padding : .5em; }
|
|
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { font-size : 80%; }
|
|
.key { padding : 3px; white-space:nowrap; line-height:230%; }
|
|
.normalday { background-color : #EDEDED; color : Black; border : 1px solid #BCBCBC; }
|
|
.exception { background-color : #b3d4ff; color : Black; border : 1px solid #BCBCBC; }
|
|
.holiday { background-color : #ffaeae; color : Black; border : 1px solid #BCBCBC; }
|
|
.repeatableweekly { background-color : #FFFF99; color : Black; border : 1px solid #BCBCBC; }
|
|
.repeatableyearly { background-color : #FFCC66; color : Black; border : 1px solid #BCBCBC; }
|
|
td.exception a.ui-state-default { background: #b3d4ff none; color : Black; border : 1px solid #BCBCBC; }
|
|
td.holiday a.ui-state-default { background: #ffaeae none; color : Black; border : 1px solid #BCBCBC; }
|
|
td.repeatableweekly a.ui-state-default { background: #FFFF99 none; color : Black; border : 1px solid #BCBCBC; }
|
|
td.repeatableyearly a.ui-state-default { background: #FFCC66 none; color : Black; border : 1px solid #BCBCBC; }
|
|
.information { z-index : 1; background-color : #DCD2F1; width : 300px; display : none; border : 1px solid #000000; color : #000000; font-size : 8pt; font-weight : bold; background-color : #FFD700; cursor : pointer; padding : 2px; }
|
|
.panel { z-index : 1; display : none; border : 3px solid #CCC; padding : 3px; margin-top: .3em; background-color: #FEFEFE; } fieldset.brief { border : 0; margin-top: 0; }
|
|
#showHoliday { margin : .5em 0; } h1 select { width: 20em; } div.yui-b fieldset.brief ol { font-size:100%; } div.yui-b fieldset.brief li, div.yui-b fieldset.brief li.radio { padding:0.2em 0; } .help { margin:.3em 0;border:1px solid #EEE;padding:.3em .7em; font-size : 90%; } #holidayweeklyrepeatable, #holidaysyearlyrepeatable, #holidaysunique, #holidayexceptions { font-size : 90%; margin-bottom : 1em;} .calendar td, .calendar th, .calendar .button, .calendar tbody .day { padding : .7em; font-size: 110%; } .calendar { width: auto; border : 0; }
|
|
</style>
|
|
</head>
|
|
<body id="tools_holidays" class="tools">
|
|
[% INCLUDE 'header.inc' %]
|
|
[% INCLUDE 'cat-search.inc' %]
|
|
|
|
<div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> › <a href="/cgi-bin/koha/tools/tools-home.pl">Tools</a> › [% Branches.GetName( branch ) %] calendar</div>
|
|
|
|
<div id="doc3" class="yui-t1">
|
|
|
|
<div id="bd">
|
|
<div id="yui-main">
|
|
<div class="yui-b">
|
|
<h2>[% Branches.GetName( branch ) %] calendar</h2>
|
|
<div class="yui-g">
|
|
<div class="yui-u first">
|
|
<label for="branch">Define the holidays for:</label>
|
|
<select id="branch" name="branch">
|
|
[% PROCESS options_for_libraries libraries => Branches.all( selected => branch ) %]
|
|
</select>
|
|
|
|
<!-- ******************************** FLAT PANELS ******************************************* -->
|
|
<!-- ***** Makes all the flat panel to deal with holidays ***** -->
|
|
<!-- **************************************************************************************** -->
|
|
|
|
<!-- ********************** Panel for showing already loaded holidays *********************** -->
|
|
<div class="panel" id="showHoliday">
|
|
<form action="/cgi-bin/koha/tools/exceptionHolidays.pl" method="post">
|
|
<input type="hidden" id="showHolidayType" name="showHolidayType" value="" />
|
|
<fieldset class="brief">
|
|
<h3>Edit this holiday</h3>
|
|
<span id="holtype"></span>
|
|
<ol>
|
|
<li>
|
|
<strong>Library:</strong> <span id="showBranchNameOutput"></span>
|
|
<input type="hidden" id="showBranchName" name="showBranchName" />
|
|
</li>
|
|
<li>
|
|
<strong>From date:</strong>
|
|
<span id="showDaynameOutput"></span>,
|
|
|
|
[% IF ( dateformat == "us" ) %]<span id="showMonthOutput"></span>/<span id="showDayOutput"></span>/<span id="showYearOutput"></span>[% ELSIF ( dateformat == "metric") %]<span id="showDayOutput"></span>/<span id="showMonthOutput"></span>/<span id="showYearOutput"></span>[% ELSIF ( dateformat == "dmydot") %]<span id="showDayOutput"></span>.<span id="showMonthOutput"></span>.<span id="showYearOutput"></span>[% ELSE %]<span id="showYearOutput"></span>/<span id="showMonthOutput"></span>/<span id="showDayOutput"></span>[% END %]
|
|
|
|
<input type="hidden" id="showDayname" name="showDayname" />
|
|
<input type="hidden" id="showWeekday" name="showWeekday" />
|
|
<input type="hidden" id="showDay" name="showDay" />
|
|
<input type="hidden" id="showMonth" name="showMonth" />
|
|
<input type="hidden" id="showYear" name="showYear" />
|
|
</li>
|
|
<li class="dateinsert">
|
|
<b>To Date : </b>
|
|
<input type="text" id="datecancelrange" name="datecancelrange" size="20" value="[% datecancelrange %]" class="datepicker"/>
|
|
</li>
|
|
<li><label for="showTitle">Title: </label><input type="text" name="showTitle" id="showTitle" size="35" /></li>
|
|
<!-- showTitle is necessary for exception radio button to work properly -->
|
|
<li>
|
|
<label for="showDescription">Description:</label>
|
|
<textarea rows="2" cols="40" id="showDescription" name="showDescription"></textarea>
|
|
</li>
|
|
<li class="radio"><div id="exceptionPosibility" style="position:static">
|
|
<input type="radio" name="showOperation" id="showOperationExc" value="exception" /> <label for="showOperationExc">Generate an exception for this repeated holiday.</label>
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">You can make an exception for this holiday rule. This means that you will be able to say that for a repeatable holiday there is one day which is going to be an exception.</div>
|
|
</div></li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationExcRange" value="exceptionrange" />
|
|
<label for="showOperationExcRange">Generate exceptions on a range of dates.</label>
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">You can make an exception on a range of dates repeated yearly.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationDel" value="delete" /> <label for="showOperationDel" id="showOperationDelLabel">Delete this holiday</label>
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will delete this holiday rule. If it is a repeatable holiday, this option checks for possible exceptions. If an exception exists, this option will remove the exception and set the date to a regular holiday.</div></li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationDelRange" value="deleterange" /> <label for="showOperationDelRange" id="showOperationDelLabelRange">Delete the single holidays on a range</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will delete the single holidays rules only. The repeatable holidays and exceptions will not be deleted.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationDelRangeRepeat" value="deleterangerepeat" /> <label for="showOperationDelRangeRepeat" id="showOperationDelLabelRangeRepeat">Delete the repeated holidays on a range</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will delete the repeated holidays rules only. The repeatable holidays will be deleted but not the exceptions.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationDelRangeRepeatExcept" value="deleterangerepeatexcept" /> <label for="showOperationDelRangeRepeatExcept" id="showOperationDelLabelRangeRepeatExcept">Delete the exceptions on a range</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will delete the exceptions inside a given range. Be careful about your scope range; if it is oversized you could slow down Koha.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="showOperation" id="showOperationEdit" value="edit" checked="checked" /> <label for="showOperationEdit">Edit this holiday</label>
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will save changes to the holiday's title and description. If the information for a repeatable holiday is modified, it affects all of the dates on which the holiday is repeated.</div></li>
|
|
</ol>
|
|
<fieldset class="action">
|
|
<input type="submit" name="submit" value="Save" />
|
|
<a href="#" class="cancel hidePanel showHoliday">Cancel</a>
|
|
</fieldset>
|
|
</fieldset>
|
|
</form>
|
|
</div>
|
|
|
|
<!-- ***************************** Panel to deal with new holidays ********************** -->
|
|
<div class="panel" id="newHoliday">
|
|
<form action="/cgi-bin/koha/tools/newHolidays.pl" method="post">
|
|
<fieldset class="brief">
|
|
<h3>Add new holiday</h3>
|
|
<ol>
|
|
<li>
|
|
<strong>Library:</strong>
|
|
<span id="newBranchNameOutput"></span>
|
|
<input type="hidden" id="newBranchName" name="newBranchName" />
|
|
</li>
|
|
<li>
|
|
<strong>From date:</strong>
|
|
<span id="newDaynameOutput"></span>,
|
|
|
|
[% IF ( dateformat == "us" ) %]<span id="newMonthOutput"></span>/<span id="newDayOutput"></span>/<span id="newYearOutput"></span>[% ELSIF ( dateformat == "metric" ) %]<span id="newDayOutput"></span>/<span id="newMonthOutput"></span>/<span id="newYearOutput"></span>[% ELSIF ( dateformat == "dmydot" ) %]<span id="newDayOutput"></span>.<span id="newMonthOutput"></span>.<span id="newYearOutput"></span>[% ELSE %]<span id="newYearOutput"></span>/<span id="newMonthOutput"></span>/<span id="newDayOutput"></span>[% END %]
|
|
|
|
<input type="hidden" id="newDayname" name="showDayname" />
|
|
<input type="hidden" id="newWeekday" name="newWeekday" />
|
|
<input type="hidden" id="newDay" name="newDay" />
|
|
<input type="hidden" id="newMonth" name="newMonth" />
|
|
<input type="hidden" id="newYear" name="newYear" />
|
|
</li>
|
|
<li class="dateinsert">
|
|
<b>To date: </b>
|
|
<input type="text" id="dateofrange" name="dateofrange" size="20" value="[% dateofrange %]" class="datepicker" />
|
|
</li>
|
|
<li><label for="title">Title: </label><input type="text" name="newTitle" id="title" size="35" /></li>
|
|
<li><label for="newDescription">Description:</label>
|
|
<textarea rows="2" cols="40" id="newDescription" name="newDescription"></textarea>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="newOperation" id="newOperationOnce" value="holiday" checked="checked" />
|
|
<label for="newOperationOnce">Holiday only on this day</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">Make a single holiday. For example, selecting August 1, 2012 will make it a holiday, but will not affect August 1 in other years.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="newOperation" id="newOperationDay" value="weekday" />
|
|
<label for="newOperationDay">Holiday repeated every same day of the week</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">Make this weekday a holiday, every week. For example, if your library is closed on Saturdays, use this option to make every Saturday a holiday.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="newOperation" id="newOperationYear" value="repeatable" />
|
|
<label for="newOperationYear">Holiday repeated yearly on the same date</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">This will take this day and month as a reference to make it a holiday. Through this option, you can repeat this rule for every year. For example, selecting August 1 will make August 1 a holiday every year.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="newOperation" id="newOperationField" value="holidayrange" />
|
|
<label for="newOperationField">Holidays on a range</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">Make a single holiday on a range. For example, selecting August 1, 2012 and August 10, 2012 will make all days between August 1 and 10 a holiday, but will not affect August 1-10 in other years.</div>
|
|
</li>
|
|
<li class="radio"><input type="radio" name="newOperation" id="newOperationFieldyear" value="holidayrangerepeat" />
|
|
<label for="newOperationFieldyear">Holidays repeated yearly on a range</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">Make a single holiday on a range repeated yearly. For example, selecting August 1, 2012 and August 10, 2012 will make all days between August 1 and 10 a holiday, and will affect August 1-10 in other years.</div>
|
|
</li>
|
|
<li class="checkbox">
|
|
<input type="checkbox" name="allBranches" id="allBranches" />
|
|
<label for="allBranches">Copy to all libraries</label>.
|
|
<a href="#" class="helptext">[?]</a>
|
|
<div class="hint">If checked, this holiday will be copied to all libraries. If the holiday already exists for a library, no change is made.</div>
|
|
</li></ol>
|
|
<fieldset class="action">
|
|
<input type="submit" name="submit" value="Save" />
|
|
<a href="#" class="cancel hidePanel newHoliday">Cancel</a>
|
|
</fieldset>
|
|
</fieldset>
|
|
</form>
|
|
</div>
|
|
|
|
<!-- *************************************************************************************** -->
|
|
<!-- ****** END OF FLAT PANELS ****** -->
|
|
<!-- *************************************************************************************** -->
|
|
|
|
<!-- ************************************************************************************** -->
|
|
<!-- ****** MAIN SCREEN CODE ****** -->
|
|
<!-- ************************************************************************************** -->
|
|
<h3>Calendar information</h3>
|
|
<div id="jcalendar-container"></div>
|
|
|
|
<div style="margin-top: 2em;">
|
|
<form action="copy-holidays.pl" method="post">
|
|
<input type="hidden" name="from_branchcode" value="[% branch %]" />
|
|
<label for="branchcode">Copy holidays to:</label>
|
|
<select id="branchcode" name="branchcode">
|
|
<option value=""></option>
|
|
[% FOREACH l IN Branches.all() %]
|
|
<option value="[% l.branchcode %]">[% l.branchname %]</option>
|
|
[% END %]
|
|
</select>
|
|
<input type="submit" value="Copy" />
|
|
</form>
|
|
</div>
|
|
|
|
</div>
|
|
<div class="yui-u">
|
|
<div class="help">
|
|
<h4>Hints</h4>
|
|
<ul>
|
|
<li>Search in the calendar the day you want to set as holiday.</li>
|
|
<li>Click the date to add or edit a holiday.</li>
|
|
<li>Enter a title and description for the holiday.</li>
|
|
<li>Specify how the holiday should repeat.</li>
|
|
<li>Click Save to finish.</li>
|
|
</ul>
|
|
<h4>Key</h4>
|
|
<p>
|
|
<span class="key normalday">Working day</span>
|
|
<span class="key holiday">Unique holiday</span>
|
|
<span class="key repeatableweekly">Holiday repeating weekly</span>
|
|
<span class="key repeatableyearly">Holiday repeating yearly</span>
|
|
<span class="key exception">Holiday exception</span>
|
|
</p>
|
|
</div>
|
|
<div id="holiday-list">
|
|
<!-- Exceptions First -->
|
|
<!-- this will probably always have the least amount of data -->
|
|
[% IF ( EXCEPTION_HOLIDAYS_LOOP ) %]
|
|
<h3>Exceptions</h3>
|
|
<table id="holidayexceptions">
|
|
<thead><tr>
|
|
<th class="exception">Date</th>
|
|
<th class="exception">Title</th>
|
|
<th class="exception">Description</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
[% FOREACH EXCEPTION_HOLIDAYS_LOO IN EXCEPTION_HOLIDAYS_LOOP %]
|
|
<tr>
|
|
<td><a href="/cgi-bin/koha/tools/holidays.pl?branch=[% branch %]&calendardate=[% EXCEPTION_HOLIDAYS_LOO.DATE %]"><span title="[% EXCEPTION_HOLIDAYS_LOO.DATE_SORT %]">[% EXCEPTION_HOLIDAYS_LOO.DATE %]</span></a></td>
|
|
<td>[% EXCEPTION_HOLIDAYS_LOO.TITLE |html %]</td>
|
|
<td>[% EXCEPTION_HOLIDAYS_LOO.DESCRIPTION |html %]</td>
|
|
</tr>
|
|
[% END %]
|
|
</tbody>
|
|
</table>
|
|
[% END %]
|
|
|
|
[% IF ( WEEK_DAYS_LOOP ) %]
|
|
<h3>Weekly - Repeatable holidays</h3>
|
|
<table id="holidayweeklyrepeatable">
|
|
<thead>
|
|
<tr>
|
|
<th class="repeatableweekly">Day of week</th>
|
|
<th class="repeatableweekly">Title</th>
|
|
<th class="repeatableweekly">Description</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
[% FOREACH WEEK_DAYS_LOO IN WEEK_DAYS_LOOP %]
|
|
<tr>
|
|
<td>[% WEEK_DAYS_LOO.KEY %]</td>
|
|
</td>
|
|
<td>[% WEEK_DAYS_LOO.TITLE |html %]</td>
|
|
<td>[% WEEK_DAYS_LOO.DESCRIPTION |html %]</td>
|
|
</tr>
|
|
[% END %]
|
|
</tbody>
|
|
</table>
|
|
[% END %]
|
|
|
|
[% IF ( DAY_MONTH_HOLIDAYS_LOOP ) %]
|
|
<h3>Yearly - Repeatable holidays</h3>
|
|
<table id="holidaysyearlyrepeatable">
|
|
<thead>
|
|
<tr>
|
|
[% IF ( dateformat == "metric" ) %]
|
|
<th class="repeatableyearly">Day/month</th>
|
|
[% ELSE %]
|
|
<th class="repeatableyearly">Month/day</th>
|
|
[% END %]
|
|
<th class="repeatableyearly">Title</th>
|
|
<th class="repeatableyearly">Description</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
[% FOREACH DAY_MONTH_HOLIDAYS_LOO IN DAY_MONTH_HOLIDAYS_LOOP %]
|
|
<tr>
|
|
<td><span title="[% DAY_MONTH_HOLIDAYS_LOO.DATE_SORT %]">[% DAY_MONTH_HOLIDAYS_LOO.DATE %]</span></td>
|
|
<td>[% DAY_MONTH_HOLIDAYS_LOO.TITLE |html %]</td>
|
|
<td>[% DAY_MONTH_HOLIDAYS_LOO.DESCRIPTION |html %]</td>
|
|
</tr>
|
|
[% END %]
|
|
</tbody>
|
|
</table>
|
|
[% END %]
|
|
|
|
[% IF ( HOLIDAYS_LOOP ) %]
|
|
<h3>Unique holidays</h3>
|
|
<table id="holidaysunique">
|
|
<thead>
|
|
<tr>
|
|
<th class="holiday">Date</th>
|
|
<th class="holiday">Title</th>
|
|
<th class="holiday">Description</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
[% FOREACH HOLIDAYS_LOO IN HOLIDAYS_LOOP %]
|
|
<tr>
|
|
<td><a href="/cgi-bin/koha/tools/holidays.pl?branch=[% branch %]&calendardate=[% HOLIDAYS_LOO.DATE %]"><span title="[% HOLIDAYS_LOO.DATE_SORT %]">[% HOLIDAYS_LOO.DATE %]</span></a></td>
|
|
<td>[% HOLIDAYS_LOO.TITLE |html %]</td>
|
|
<td>[% HOLIDAYS_LOO.DESCRIPTION.replace('\\\r\\\n', '<br />') |html %]</td>
|
|
</tr>
|
|
[% END %]
|
|
</tbody>
|
|
</table>
|
|
[% END %]
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="yui-b noprint">
|
|
[% INCLUDE 'tools-menu.inc' %]
|
|
</div>
|
|
</div>
|
|
|
|
[% MACRO jsinclude BLOCK %]
|
|
[% INCLUDE 'calendar.inc' %]
|
|
[% INCLUDE 'datatables.inc' %]
|
|
<script type="text/javascript" src="[% interface %]/[% theme %]/js/tools-menu.js"></script>
|
|
<script type="text/javascript">
|
|
var weekdays = new Array(_("Sundays"),_("Mondays"),_("Tuesdays"),_("Wednesdays"),_("Thursdays"),_("Fridays"),_("Saturdays"));
|
|
|
|
/* Creates all the structures to deal with all different kinds of holidays */
|
|
var week_days = new Array();
|
|
var holidays = new Array();
|
|
var holidates = new Array();
|
|
var exception_holidays = new Array();
|
|
var day_month_holidays = new Array();
|
|
var hola= "[% code %]";
|
|
[% FOREACH WEEK_DAYS_LOO IN WEEK_DAYS_LOOP %]
|
|
week_days["[% WEEK_DAYS_LOO.KEY %]"] = {title:"[% WEEK_DAYS_LOO.TITLE | replace('"','\"') |html %]", description:"[% WEEK_DAYS_LOO.DESCRIPTION | replace('"','\"') |html %]"};
|
|
[% END %]
|
|
[% FOREACH HOLIDAYS_LOO IN HOLIDAYS_LOOP %]
|
|
holidates.push("[% HOLIDAYS_LOO.KEY %]");
|
|
holidays["[% HOLIDAYS_LOO.KEY %]"] = {title:"[% HOLIDAYS_LOO.TITLE | replace('"','\"') |html %]", description:"[% HOLIDAYS_LOO.DESCRIPTION | replace('"','\"') |html %]"};
|
|
[% END %]
|
|
[% FOREACH EXCEPTION_HOLIDAYS_LOO IN EXCEPTION_HOLIDAYS_LOOP %]
|
|
exception_holidays["[% EXCEPTION_HOLIDAYS_LOO.KEY %]"] = {title:"[% EXCEPTION_HOLIDAYS_LOO.TITLE | replace('"','\"') |html %]", description:"[% EXCEPTION_HOLIDAYS_LOO.DESCRIPTION | replace('"','\"') |html %]"};
|
|
[% END %]
|
|
[% FOREACH DAY_MONTH_HOLIDAYS_LOO IN DAY_MONTH_HOLIDAYS_LOOP %]
|
|
day_month_holidays["[% DAY_MONTH_HOLIDAYS_LOO.KEY %]"] = {title:"[% DAY_MONTH_HOLIDAYS_LOO.TITLE | replace('"','\"') |html %]", description:"[% DAY_MONTH_HOLIDAYS_LOO.DESCRIPTION | replace('"','\"') |html %]"};
|
|
[% END %]
|
|
|
|
function holidayOperation(formObject, opType) {
|
|
var op = document.getElementsByName('operation');
|
|
op[0].value = opType;
|
|
formObject.submit();
|
|
}
|
|
|
|
// This function shows the "Show Holiday" panel //
|
|
function showHoliday (exceptionPosibility, dayName, day, month, year, weekDay, title, description, holidayType) {
|
|
$("#newHoliday").slideUp("fast");
|
|
$("#showHoliday").slideDown("fast");
|
|
$('#showDaynameOutput').html(dayName);
|
|
$('#showDayname').val(dayName);
|
|
$('#showBranchNameOutput').html($("#branch :selected").text());
|
|
$('#showBranchName').val($("#branch").val());
|
|
$('#showDayOutput').html(day);
|
|
$('#showDay').val(day);
|
|
$('#showMonthOutput').html(month);
|
|
$('#showMonth').val(month);
|
|
$('#showYearOutput').html(year);
|
|
$('#showYear').val(year);
|
|
$('#showDescription').val(description);
|
|
$('#showWeekday:first').val(weekDay);
|
|
$('#showTitle').val(title);
|
|
$('#showHolidayType').val(holidayType);
|
|
|
|
if (holidayType == 'exception') {
|
|
$("#showOperationDelLabel").html(_("Delete this exception."));
|
|
$("#holtype").attr("class","key exception").html(_("Holiday exception"));
|
|
} else if(holidayType == 'weekday') {
|
|
$("#showOperationDelLabel").html(_("Delete this holiday."));
|
|
$("#holtype").attr("class","key repeatableweekly").html(_("Holiday repeating weekly"));
|
|
} else if(holidayType == 'daymonth') {
|
|
$("#showOperationDelLabel").html(_("Delete this holiday."));
|
|
$("#holtype").attr("class","key repeatableyearly").html(_("Holiday repeating yearly"));
|
|
} else {
|
|
$("#showOperationDelLabel").html(_("Delete this holiday."));
|
|
$("#holtype").attr("class","key holiday").html(_("Unique holiday"));
|
|
}
|
|
|
|
if (exceptionPosibility == 1) {
|
|
$("#exceptionPosibility").parent().show();
|
|
} else {
|
|
$("#exceptionPosibility").parent().hide();
|
|
}
|
|
}
|
|
|
|
// This function shows the "Add Holiday" panel //
|
|
function newHoliday (dayName, day, month, year, weekDay) {
|
|
$("#showHoliday").slideUp("fast");
|
|
$("#newHoliday").slideDown("fast");
|
|
$("#newDaynameOutput").html(dayName);
|
|
$("#newDayname").val(dayName);
|
|
$("#newBranchNameOutput").html($('#branch :selected').text());
|
|
$("#newBranchName").val($('#branch').val());
|
|
$("#newDayOutput").html(day);
|
|
$("#newDay").val(day);
|
|
$("#newMonthOutput").html(month);
|
|
$("#newMonth").val(month);
|
|
$("#newYearOutput").html(year);
|
|
$("#newYear").val(year);
|
|
$("#newWeekday:first").val(weekDay);
|
|
}
|
|
|
|
function hidePanel(aPanelName) {
|
|
$("#"+aPanelName).slideUp("fast");
|
|
}
|
|
|
|
function changeBranch () {
|
|
var branch = $("#branch option:selected").val();
|
|
location.href='/cgi-bin/koha/tools/holidays.pl?branch=' + branch + '&calendardate=' + "[% calendardate %]";
|
|
}
|
|
|
|
function Help() {
|
|
newin=window.open("/cgi-bin/koha/help.pl","KohaHelp",'width=600,height=600,toolbar=false,scrollbars=yes');
|
|
}
|
|
|
|
/* This function gives css clases to each kind of day */
|
|
function dateStatusHandler(date) {
|
|
date = new Date(date);
|
|
var day = date.getDate();
|
|
var month = date.getMonth() + 1;
|
|
var year = date.getFullYear();
|
|
var weekDay = date.getDay();
|
|
var dayMonth = month + '/' + day;
|
|
var dateString = year + '/' + month + '/' + day;
|
|
if (exception_holidays[dateString] != null) {
|
|
return [true, "exception", _("Exception: %s").format(exception_holidays[dateString].title)];
|
|
} else if ( week_days[weekDay] != null ){
|
|
return [true, "repeatableweekly", _("Weekly holiday: %s").format(week_days[weekDay].title)];
|
|
} else if ( day_month_holidays[dayMonth] != null ) {
|
|
return [true, "repeatableyearly", _("Yearly holiday: %s").format(day_month_holidays[dayMonth].title)];
|
|
} else if (holidays[dateString] != null) {
|
|
return [true, "holiday", _("Single holiday: %s").format(holidays[dateString].title)];
|
|
} else {
|
|
return [true, "normalday", _("Normal day")];
|
|
}
|
|
}
|
|
|
|
/* This function is in charge of showing the correct panel considering the kind of holiday */
|
|
function dateChanged(calendar) {
|
|
calendar = new Date(calendar);
|
|
var day = calendar.getDate();
|
|
var month = calendar.getMonth() + 1;
|
|
var year = calendar.getFullYear();
|
|
var weekDay = calendar.getDay();
|
|
var dayName = weekdays[weekDay];
|
|
var dayMonth = month + '/' + day;
|
|
var dateString = year + '/' + month + '/' + day;
|
|
if (holidays[dateString] != null) {
|
|
showHoliday(0, dayName, day, month, year, weekDay, holidays[dateString].title, holidays[dateString].description, 'ymd');
|
|
} else if (exception_holidays[dateString] != null) {
|
|
showHoliday(0, dayName, day, month, year, weekDay, exception_holidays[dateString].title, exception_holidays[dateString].description, 'exception');
|
|
} else if (week_days[weekDay] != null) {
|
|
showHoliday(1, dayName, day, month, year, weekDay, week_days[weekDay].title, week_days[weekDay].description, 'weekday');
|
|
} else if (day_month_holidays[dayMonth] != null) {
|
|
showHoliday(1, dayName, day, month, year, weekDay, day_month_holidays[dayMonth].title, day_month_holidays[dayMonth].description, 'daymonth');
|
|
} else {
|
|
newHoliday(dayName, day, month, year, weekDay);
|
|
}
|
|
};
|
|
|
|
$(document).ready(function() {
|
|
|
|
$(".hint").hide();
|
|
$("#branch").change(function(){
|
|
changeBranch();
|
|
});
|
|
$("#holidayweeklyrepeatable>tbody>tr").each(function(){
|
|
var first_td = $(this).find('td').first();
|
|
first_td.html(weekdays[first_td.html()]);
|
|
});
|
|
$("#holidayweeklyrepeatable").dataTable($.extend(true, {}, dataTablesDefaults, {
|
|
"sDom": 't',
|
|
"bPaginate": false
|
|
}));
|
|
$("#holidayexceptions,#holidaysyearlyrepeatable,#holidaysunique").dataTable($.extend(true, {}, dataTablesDefaults, {
|
|
"sDom": 't',
|
|
"aoColumns": [
|
|
{ "sType": "title-string" },null,null
|
|
],
|
|
"bPaginate": false
|
|
}));
|
|
$("a.helptext").click(function(){
|
|
$(this).parent().find(".hint").toggle(); return false;
|
|
});
|
|
$("#dateofrange").datepicker();
|
|
$("#datecancelrange").datepicker();
|
|
$("#dateofrange").each(function () { this.value = "" });
|
|
$("#datecancelrange").each(function () { this.value = "" });
|
|
$("#jcalendar-container").datepicker({
|
|
beforeShowDay: function(thedate) {
|
|
var day = thedate.getDate();
|
|
var month = thedate.getMonth() + 1;
|
|
var year = thedate.getFullYear();
|
|
var dateString = year + '/' + month + '/' + day;
|
|
return dateStatusHandler(dateString);
|
|
},
|
|
onSelect: function(dateText, inst) {
|
|
dateChanged($(this).datepicker("getDate"));
|
|
},
|
|
defaultDate: new Date("[% keydate %]")
|
|
});
|
|
$(".hidePanel").on("click",function(){
|
|
if( $(this).hasClass("showHoliday") ){
|
|
hidePanel("showHoliday");
|
|
} else {
|
|
hidePanel("newHoliday");
|
|
}
|
|
})
|
|
});
|
|
</script>
|
|
[% END %]
|
|
|
|
[% INCLUDE 'intranet-bottom.inc' %]
|