[% USE raw %]
[% USE Koha %]
[% USE Branches %]
[% USE KohaDates %]
[% USE Price %]
[% USE ItemTypes %]
[% USE AuthorisedValues %]
[% INCLUDE 'doc-head-open.inc' %]
<title>Placing a hold &rsaquo; [% IF ( LibraryNameTitle ) %][% LibraryNameTitle | html %][% ELSE %]Koha online[% END %] catalog</title>
[% INCLUDE 'doc-head-close.inc' %]
[% BLOCK cssinclude %][% END %]
</head>

[% INCLUDE 'bodytag.inc' bodyid='opac-holds' %]
[% INCLUDE 'masthead.inc' %]

<div class="main">
    [% WRAPPER breadcrumbs %]
        [% WRAPPER breadcrumb_item bc_active= 1 %]
            <span>Placing a hold</span>
        [% END %]
    [% END #/ WRAPPER breadcrumbs %]

    <div class="container">
        <div id="holds" class="maincontent">
            <h1>Placing a hold</h1>
            [% IF ( message ) %]
                <div id="holdmessages" class="alert">
                    <p>Sorry, you cannot place holds.</p>
                    <ul>
                        [% IF ( GNA ) %]
                            <li id="gna">
                                According to our records, we don't have up-to-date contact information. Please contact the library.
                                <a href="/cgi-bin/koha/opac-memberentry.pl">[% IF ( Koha.Preference('OPACPatronDetails') ) %]<span>Update your contact information</span>[% ELSE %]<span>Go to your contact information</span>[% END %]</a>
                                [% IF ( Koha.Preference('OPACPatronDetails') ) %]<em>(Please note: there may be a delay in restoring your account if you submit online.)</em>[% END %]
                            </li>
                        [% END %]

                        [% IF ( lost ) %]
                            <li id="lost">
                                Your library card has been marked as lost or stolen.<br />
                                <em>If this is an error, please take your library card to the circulation desk at your local library and the error will be corrected.</em>
                            </li>
                        [% END %]

                        [% IF ( debarred ) %]
                            <li id="debarred">
                                Your account has been frozen.
                                [% IF debarred_comment %]
                                    Comment:
                                    <span id="userdebarred_comment">
                                        <strong>
                                            [% IF debarred_comment.search('OVERDUES_PROCESS') %]
                                                Restriction added by overdues process [% debarred_comment.remove('OVERDUES_PROCESS ') | html_line_break %]
                                            [% ELSE %]
                                                [% debarred_comment | html_line_break %]
                                            [% END %]
                                        </strong>
                                    </span>
                                [% END %]

                                [% IF debarred_date && debarred_date != '9999-12-31' %]
                                    End date:
                                    <span id="userdebarred_date">[% debarred_date | $KohaDates %]</span>
                                [% END %]
                                <br /><em>Usually the reason for freezing an account is old overdues or damage fees. If shows your account to be clear, please contact the library.</em> <a href="/cgi-bin/koha/opac-account.pl">Go to your account page</a>
                            </li>
                        [% END %]

                        [% IF ( too_much_oweing ) %]
                            <li id="too_much_oweing">
                                You have unpaid fines. Amount: [% too_much_oweing | $Price %].
                            </li>
                        [% END %]

                        [% IF ( too_many_reserves ) %]
                            <li id="too_many_reserves">
                                Sorry, you cannot place more than [% too_many_reserves | html %] holds.
                            </li>
                        [% END %]

                        [% IF ( bad_biblionumber ) %]
                            <li id="bad_biblionumber">
                                ERROR: No record found for record ID [% bad_biblionumber | html %].
                            </li>
                        [% END %]

                        [% IF ( no_items_selected ) %]
                            <li id="no_items_selected">
                                You must select at least one item.
                            </li>
                        [% END %]

                        [% IF ( no_branch_selected ) %]
                            <li id="no_branch_selected">
                                You must select a library for pickup.
                            </li>
                        [% END %]

                        [% IF ( no_biblionumber ) %]
                            <li id="no_biblionumber">
                               ERROR: No record ID specified.
                           </li>
                        [% END %]

                        [% IF ( bad_data ) %]
                            <li id="bad_data">
                                ERROR: Internal error: incomplete hold request.
                            </li>
                        [% END %]

                        [% IF ( expired_patron ) %]
                            <li id="expired_patron">
                                Your library card has expired. Please contact your librarian if you wish to renew your card.
                            </li>
                        [% END %]

                        [% IF ( no_pickup_locations ) %]
                            <li id="no_pickup_locations">
                                None of the libraries are available for pickup location.
                            </li>
                        [% END %]
                    </ul>
                </div> <!-- /.message -->
            [% ELSE # /IF message %]

                [% IF ( none_available && multi_hold ) %]
                    <div id="none_available" class="alert">
                        Sorry, none of these titles can be placed on hold.
                    </div>
                [% END %]

            [% END # / IF message %]

            [% UNLESS ( message ) %]
                [% UNLESS ( none_available ) %]
                    <h2>Confirm holds for:[% INCLUDE 'patron-title.inc' patron = logged_in_user %] ([% logged_in_user.cardnumber | html %])</h2>
                [% END # / UNLESS none_available %]

                [% IF ( new_reserves_allowed ) %]
                    <div id="new_reserves_allowed" class="alert">
                        <strong>Sorry,</strong> you can only place [% new_reserves_allowed | html %] more holds. Please uncheck the checkboxes for the items you wish to not place holds on.
                    </div>
                [% END %]

            <form action="/cgi-bin/koha/opac-reserve.pl" method="post" id="hold-request-form">
                <legend class="sr-only">Hold requests</legend>
                <input type="hidden" name="place_reserve" value="1"/>
                <!-- These values are set dynamically by js -->
                    <input type="hidden" name="biblionumbers" id="biblionumbers"/>
                    <input type="hidden" name="selecteditems" id="selections"/>
                    <div id="bigloop">

                        [% FOREACH bibitemloo IN bibitemloop %]
                            <div class="holdrow">
                                [% IF bibitemloo.forced_hold_level %]
                                    <div class="alert alert-info forced_hold_level">
                                        [% IF bibitemloo.forced_hold_level == 'item' %]
                                            <span>You already have at least one item level hold on this title.
                                            All further holds must be item level.</span>
                                        [% ELSE %]
                                            <span>You already have at least one record level hold on this title.
                                            All further holds must be record level.</span>
                                        [% END %]
                                    </div>
                                [% END %]

                                [% IF ( bibitemloo.reserve_charge ) %]
                                    <div class="alert" id="reserve_fee">
                                        [% IF Koha.Preference('HoldFeeMode') == 'any_time_is_collected' %]
                                            <span>You will be charged a hold fee of [% bibitemloo.reserve_charge | $Price %] when you collect this item</span>
                                        [% ELSE %]
                                            <span>You will be charged a hold fee of [% bibitemloo.reserve_charge | $Price %] for placing this hold</span>
                                        [% END %]
                                    </div>
                                [% END %]

                                <p>
                                    [% IF ( bibitemloo.holdable ) %]
                                        <input class="reserve_mode" name="reserve_mode" type="hidden" value="single"/>
                                        <input class="single_bib" name="single_bib" type="hidden" value="[% bibitemloo.biblionumber | html %]"/>
                                        <span class="confirmjs_hold" title="[% bibitemloo.biblionumber | html %]" style="padding:.3em"></span>
                                        <span class="confirm_nonjs">
                                            <input type="radio" class="confirmbox checkitem [% bibitemloo.biblionumber | html %]" name="[% bibitemloo.biblionumber | html %]" checked="checked" id="single_[% bibitemloo.biblionumber | html %]" value="any" />
                                            <label class="confirm_label" for="single_[% bibitemloo.biblionumber | html %]">Place a hold on </label>
                                        </span>
                                    [% END # / bibitemloo.holdable %]

                                    [% INCLUDE 'biblio-title.inc' biblio=bibitemloo link=> 1%]

                                    [% IF ( bibitemloo.author ) %],  by [% bibitemloo.author | html %][% END %]
                                </p>

                                [% UNLESS ( bibitemloo.holdable ) %]
                                    [% IF ( bibitemloo.ageRestricted ) %]
                                        <div class="alert alert-warning">Sorry, you are too young to place a hold for this item.</div>
                                    [% END %]
                                    [% IF ( bibitemloo.already_reserved ) %]
                                        <div class="alert alert-warning">You have already requested this title.</div>
                                    [% ELSIF ( bibitemloo.recall ) %]
                                        <div class="alert alert-warning">You have already placed a recall on this title.</div>
                                    [% ELSE %]
                                        [% IF bibitemloo.alreadypossession %]
                                            <div class="alert alert-warning">This title cannot be requested because it's already in your possession.</div>
                                        [% ELSIF bibitemloo.tooManyReserves %]
                                            <div class="alert alert-warning">This title cannot be requested because you reached the maximum number of holds.</div>
                                        [% ELSIF bibitemloo.tooManyHoldsForThisRecord %]
                                            <div class="alert alert-warning">This title cannot be requested because you exceeded max holds per record.</div>
                                        [% ELSIF bibitemloo.tooManyReservesToday %]
                                            <div class="alert alert-warning">This title cannot be requested because you reached the daily hold limit.</div>
                                        [% ELSIF bibitemloo.itemAlreadyOnHold %]
                                            <div class="alert alert-warning">This title cannot be requested because you already have hold for this item.</div>
                                        [% ELSE %]
                                            [% UNLESS ( bibitemloo.bib_available ) %]
                                                <div class="alert">There are no items that can be placed on hold.</div>
                                            [% ELSE %]
                                                <div class="alert">This title cannot be requested.</div>
                                            [% END %]
                                        [% END # / UNLESS bibitemloo.already_patron_possession %]
                                    [% END # / IF bibitemloo.already_reserved %]
                                [% END # / UNLESS bibitemloo.holdable %]

                                [% IF ( bibitemloo.holdable ) %]
                                    <fieldset class="rows">
                                        <ul>
                                            <!-- HOLDABLE -->
                                            [% UNLESS ( item_level_itypes ) %]
                                                <li class="itype">
                                                    <span class="label">Item type: </span>
                                                    [% IF ( bibitemloo.imageurl ) %]<img src="[% bibitemloo.imageurl | html %]" alt="" />[% END %]
                                                    <span class="itypetext">[% bibitemloo.translated_description | html %]</span>
                                                </li>
                                            [% END %]

                                            [% SET OPACShowHoldQueueDetails = Koha.Preference('OPACShowHoldQueueDetails') %]
                                            [% IF OPACShowHoldQueueDetails == 'holds_priority' || OPACShowHoldQueueDetails == 'priority' %]
                                                <li class="priority">
                                                    <span class="label">Your priority: </span>
                                                    [% bibitemloo.rank | html %]
                                                </li>
                                            [% END %]

                                            [% IF OPACShowHoldQueueDetails == 'holds_priority' || OPACShowHoldQueueDetails == 'holds' %]
                                                <li class="holds-count">
                                                    <span class="label">Number of holds: </span>
                                                    [% bibitemloo.reservecount | html %]
                                                </li>
                                            [% END %]

                                            [% UNLESS ( singleBranchMode ) %]
                                                [% IF ( bibitemloo.holdable && Koha.Preference('OPACAllowUserToChooseBranch')) %]
                                                    <li class="branch">
                                                        <label for="branch_[% bibitemloo.biblionumber | html %]">Pick up location:</label>
                                                        [% UNLESS ( bibitemloo.holdable ) %]
                                                            <select name="branch" id="branch_[% bibitemloo.biblionumber | html %]" disabled="disabled">
                                                                [% PROCESS options_for_libraries libraries => Branches.pickup_locations({ search_params => { biblio => bibitemloo.biblionumber, patron => logged_in_user }, selected => branch }) %]
                                                            </select>
                                                        [% ELSE %]
                                                            [% SET at_least_one_library_not_available_for_pickup = 0 %]
                                                            <select name="branch" id="branch_[% bibitemloo.biblionumber | html %]">
                                                                [% FOREACH library IN Branches.pickup_locations({ search_params => { biblio => bibitemloo.biblionumber, patron => logged_in_user }, selected => branch }) %]
                                                                    [% SET pickup_available_at = bibitemloo.not_available_at.grep('^' _ library.branchcode _ '$').size ? 0 : 1 %]
                                                                    [% IF library.selected AND pickup_available_at %]
                                                                        <option value="[% library.branchcode | html %]" selected="selected" >[% library.branchname | html %]</option>
                                                                    [% ELSIF pickup_available_at %]
                                                                        <option value="[% library.branchcode | html %]">[% library.branchname | html %]</option>
                                                                    [% ELSE %]
                                                                        [% SET at_least_one_library_not_available_for_pickup = 1 %]
                                                                        <option value="[% library.branchcode | html %]" disabled="disabled" title="At least one item is available at this library">[% library.branchname | html %]</option>
                                                                    [% END %]
                                                                [% END %]
                                                            </select>
                                                            [% IF at_least_one_library_not_available_for_pickup %]
                                                                <div class="at_least_one_library_not_available_note">Note: Library policy does not allow hold/pickup of an item available locally. Please come to the library to retrieve these items</div>
                                                            [% END %]
                                                        [% END # / UNLESS bibitemloo.holdable %]
                                                    </li>
                                                [% END # / IF bibitemloo.holdable && Koha.Preference('OPACAllowUserToChooseBranch') %]
                                            [% END # / UNLESS singleBranchMode %]
                                        </ul>

                                        <a class="toggle-hold-options" id="toggle-hold-options-[% bibitemloo.biblionumber | html %]" style="display:none;" href="#">Show more options</a>

                                        <div id="hold-options-[% bibitemloo.biblionumber | html %]" class="hold-options">

                                            <ul>
                                                [% IF ( reserve_in_future ) %]
                                                    <li>
                                                        <label for="from[% bibitemloo.biblionumber | html %]">Hold starts on date:</label>
                                                        <input type="text" name="reserve_date_[% bibitemloo.biblionumber | html %]" id="from[% bibitemloo.biblionumber | html %]" data-start_for="to[% bibitemloo.biblionumber | html %]" data-flatpickr-futureinclusive="true" size="10" class="flatpickr holddatefrom" value="[% KohaDates.datetime_from_string | $KohaDates dateformat => 'iso' %]" />
                                                        <span class="date-format from" data-biblionumber="[% bibitemloo.biblionumber | html %]">[% INCLUDE 'date-format.inc' %]</span>
                                                        <div class="required_label" style="display:none;">Required</div>
                                                    </li>
                                                [% END %]

                                                <li>
                                                    <label for="to[% bibitemloo.biblionumber | html %]">Hold not needed after:</label>
                                                    <input type="text" name="expiration_date_[% bibitemloo.biblionumber | html %]" id="to[% bibitemloo.biblionumber | html %]" size="10" data-flatpickr-future="true" class="flatpickr futuredate" />
                                                    <span class="date-format to" data-biblionumber="[% bibitemloo.biblionumber | html %]">[% INCLUDE 'date-format.inc' %]</span>
                                                    <div class="required_label" style="display:none;">Required</div>
                                                </li>

                                                [% IF Koha.Preference('AllowHoldItemTypeSelection') %]
                                                    <li>
                                                        <label for="itemtype">Request specific item type:</label>
                                                        <select name="itemtype" id="itemtype">
                                                            <option value="">Any item type</option>
                                                            [% FOREACH i IN bibitemloo.allowed_item_types %]
                                                                <option value="[% i | html %]">[% ItemTypes.GetDescription( i ) | html %]</option>
                                                            [%- END %]
                                                        </select>
                                                    </li>
                                                [% END %]

                                                [% UNLESS bibitemloo.forced_hold_level && ( bibitemloo.forced_hold_level == 'item' || bibitemloo.forced_hold_level == 'record' ) %]
                                                    [% IF Koha.Preference('EnableItemGroupHolds') && bibitemloo.object.item_groups.count %]
                                                        <li>
                                                            <label for="itemtype">Request specific item group:</label>
                                                            <select name="item_group_id_[% bibitemloo.biblionumber | html %]" id="item_group_id_[% bibitemloo.biblionumber | html %]">
                                                                <option value="">Any item group</option>
                                                                [% FOREACH g IN bibitemloo.object.item_groups.search({}, { order_by => ['display_order'] }) %]
                                                                    [% IF g.items.count %]
                                                                        <option value="[% g.id | html %]">[% g.description | html %]</option>
                                                                    [% END %]
                                                                [% END %]
                                                            </select>
                                                        </li>
                                                    [% END %]
                                                [% END %]

                                                [% IF ( OpacHoldNotes ) %]
                                                    <li>
                                                        <div class="notesrow" id="notesrow_[% bibitemloo.biblionumber | html %]">
                                                            <label for="holdnotes_[% bibitemloo.biblionumber | html %]">Hold notes:</label>
                                                            <textarea id="holdnotes_[% bibitemloo.biblionumber | html %]" rows="2" cols="30" name="notes_[% bibitemloo.biblionumber | html %]" >[% bibitemloo.holdnotes | html %]</textarea>
                                                        </div>
                                                    </li>
                                                [% END # / IF OpacHoldNotes %]

                                                [% IF bibitemloo.itemholdable %]
                                                    <!-- ITEM HOLDS -->
                                                    <li class="lradio place_on_type" style="display:none;">
                                                        [% UNLESS bibitemloo.forced_hold_level == 'item' || bibitemloo.forced_hold_level == 'item_group' || bibitemloo.force_hold %]
                                                            <label class="radio inline" for="reqany_[% bibitemloo.biblionumber | html %]">Next available item</label>
                                                            <input type="radio" name="reqtype_[% bibitemloo.biblionumber | html %]"
                                                                    id="reqany_[% bibitemloo.biblionumber | html %]"
                                                                    class="selectany"
                                                                    value="Any"
                                                                    checked="checked"
                                                            />
                                                        [% END %]
                                                        <label class="radio inline" for="reqspecific_[% bibitemloo.biblionumber | html %]">A specific item</label>
                                                        <input type="radio" name="reqtype_[% bibitemloo.biblionumber | html %]"
                                                               id="reqspecific_[% bibitemloo.biblionumber | html %]"
                                                               class="selectspecific"
                                                               value="Specific"
                                                        />
                                                    </li>
                                                [% END # / IF bibitemloo.itemholdable %]
                                            </ul>

                                            [% IF bibitemloo.itemholdable %]
                                                <div id="copiesrow_[% bibitemloo.biblionumber | html %]" class="copiesrow">
                                                <table class="table table-bordered table-striped itemstable">
                                                    <caption>Select a specific item:</caption>
                                                    <thead>
                                                        <tr>
                                                        <th>Copy number</th>
                                                        [% IF ( item_level_itypes ) %]
                                                            <th>Item type</th>
                                                        [% END %]
                                                        <th>Barcode</th>
                                                        [% UNLESS ( singleBranchMode ) %]
                                                            <th>Home library</th>
                                                            <th>Last location</th>
                                                        [% END %]
                                                        [% IF ( itemdata_ccode ) %]
                                                            <th>Collection</th>
                                                        [% END %]
                                                        <th>Call number</th>
                                                        [% IF ( itemdata_enumchron ) %]
                                                            <th>Vol info</th>
                                                        [% END %]
                                                        <th>Notes</th>
                                                        <th>Information</th>
                                                        </tr>
                                                    </thead>
                                                    <tbody>

                                                    [% SET unholdable_items = 0 %]
                                                    [% FOREACH itemLoo IN bibitemloo.itemLoop %]
                                                        [% IF ( itemLoo.available ) %]
                                                            [% IF ( itemLoo.checkout ) %]
                                                                <tr class="holdable onloan">
                                                            [% ELSE %]
                                                                <tr class="holdable">
                                                            [% END %]
                                                                    <td class="copynumber" data-order="[% itemLoo.copynumber | html %]">
                                                                        <input type="radio" class="checkitem checkitem_[% bibitemloo.biblionumber | html %]" name="checkitem_[% bibitemloo.biblionumber | html %]" value="[% itemLoo.itemnumber | html %]" />
                                                        [% ELSE %]
                                                            [% SET unholdable_items = 1 %]
                                                            [% IF ( itemLoo.checkout ) %]
                                                                <tr class="unholdable onloan" style="display:none;">
                                                            [% ELSE %]
                                                                <tr class="unholdable" style="display:none;">
                                                            [% END %]
                                                                    <td class="copynumber">
                                                                        <input disabled="disabled" type="radio" aria-label="Cannot be put on hold" class="checkitem" name="checkitem" value="[% itemLoo.itemnumber | html %]"
                                                                           style="display:none;" />
                                                                    <i class="fa fa-times danger" aria-hidden="true" title="Cannot be put on hold"></i>
                                                        [% END %]
                                                                [% IF ( itemLoo.copynumber ) %]
                                                                    [% itemLoo.copynumber | html %]
                                                                [% END %]
                                                            </td> [%# copynumber %]

                                                            [% IF ( item_level_itypes ) %]
                                                                <td class="itype">
                                                                    [% UNLESS ( Koha.Preference('OpacNoItemTypeImages') ) %]
                                                                        [% IF ( itemLoo.imageurl ) %]
                                                                            <img src="[% itemLoo.imageurl | html %]" alt="" />
                                                                        [% END %]
                                                                    [% END %]
                                                                    <span class="itypetext">[% itemLoo.translated_description | html %]</span>
                                                                </td>
                                                            [% END %]

                                                            <td class="barcode">[% itemLoo.barcode | html %]</td>
                                                            [% UNLESS ( singleBranchMode ) %]
                                                                <td class="homebranch">[% Branches.GetName( itemLoo.homebranch) | html %]</td>
                                                                <td class="holdingbranch">[% Branches.GetName( itemLoo.holdingbranch ) | html %]</td>
                                                            [% END %]
                                                            [% IF ( itemdata_ccode ) %]
                                                                <td class="ccode"> [% IF ( itemLoo.ccode ) %][% AuthorisedValues.GetDescriptionByKohaField( kohafield => 'items.ccode', authorised_value => itemLoo.ccode, opac => 1 ) | html %][% END %]</td>
                                                            [% END %]
                                                            <td class="call_no">[% itemLoo.itemcallnumber | html %]</td>
                                                            [% IF ( itemdata_enumchron ) %]
                                                                <td class="vol_info">[% itemLoo.enumchron | html %]</td>
                                                            [% END %]
                                                            <td class="itemnotes">
                                                                [% itemLoo.itemnotes | html %]
                                                            </td>
                                                            <td class="information">
                                                                [% IF ( itemLoo.checkout.date_due) %]
                                                                    <span class="checkedout">Due [% itemLoo.checkout.date_due| $KohaDates as_due_date => 1 %]</span>
                                                                [% ELSIF ( itemLoo.transfertwhen ) %]
                                                                    <span class="intransit">In transit from [% Branches.GetName( itemLoo.transfertfrom ) | html %] to [% Branches.GetName( itemLoo.transfertto ) | html %] since [% itemLoo.transfertwhen | $KohaDates %]</span>
                                                                [% END %]

                                                                [% IF ( itemLoo.itemlost == 1 || itemLoo.itemlost == 2 ) %] [%# FIXME Why only for 1 or 2? Shouldn't we test for withdrawn as well? %]
                                                                    <span class="lost">Unavailable (lost or missing)</span>
                                                                [% END %]

                                                                [% IF ( itemLoo.notforloan ) %]
                                                                    <span class="notforloan">Not for loan ([% AuthorisedValues.GetDescriptionByKohaField( kohafield => 'items.notforloan', authorised_value => itemLoo.notforloan ) %])</span>
                                                                [% END %]

                                                                [% IF ( itemLoo.first_hold ) %]
                                                                    <span class="waiting">
                                                                        [% IF ( itemLoo.waitingdate ) %]
                                                                            <span>Waiting for patron at [% Branches.GetName( itemLoo.ExpectedAtLibrary ) | html %] since [% itemLoo.waitingdate | $KohaDates %]</span>
                                                                        [% ELSIF ( itemLoo.reservedate ) %]
                                                                            <span>On hold for patron expected at [% Branches.GetName( itemLoo.ExpectedAtLibrary ) | html %] since [% itemLoo.reservedate | $KohaDates %]</span>
                                                                        [% ELSE %]
                                                                            <span>On hold for patron expected at [% Branches.GetName( itemLoo.ExpectedAtLibrary ) | html %]</span>
                                                                        [% END %]
                                                                    </span>
                                                                [% ELSE %]
                                                                    <span class="notonhold">Not on hold</span>
                                                                [% END # / IF ( itemLoo.first_hold )%]
                                                            </td>
                                                        </tr>
                                                    [% END # / FOREACH itemLoo IN bibitemloo.itemLoop%]
                                                    </tbody>
                                                </table> <!-- / #copiesrow_[% bibitemloo.biblionumber | html %] -->
                                                [% IF unholdable_items %]
                                                <button id="show_unholdable" class="btn btn-primary toggle_unholdable unholdable">Show unholdable items</button>
                                                <button id="hide_unholdable" class="btn btn-primary toggle_unholdable unholdable" style="display:none;">Hide unholdable items</button>
                                                [% END %]
                                                </div>
                                            [% END # / IF ( bibitemloo.itemholdable )%]
                                        </div> <!-- / #hold-options-[% bibitemloo.biblionumber | html %] -->
                                    </fieldset>
                                [% END # / IF ( bibitemloo.holdable ) %]
                            </div> <!-- / .holdrow -->
                        [% END # / FOREACH bibitemloo IN bibitemloop %]
                    </div><!-- #bigloop -->

                    [% UNLESS ( none_available ) %]
                        <input type="submit" value="Confirm hold" class="btn btn-primary placehold" />
                    [% END %]

                </form>
            [% END # / UNLESS message %]
        </div> <!-- / #holds -->
    </div> <!-- / .container -->
</div> <!-- / .main -->
[% INCLUDE 'opac-bottom.inc' %]
[% BLOCK jsinclude %]
[% INCLUDE 'calendar.inc' %]
[% INCLUDE 'datatables.inc' %]
<script>
    var MSG_NO_ITEM_SELECTED = _("Expecting a specific item selection.");
    var MSG_EMPTY_START_DATE = _("Hold start date should be filled.");
    var MSG_EMPTY_END_DATE   = _("Hold expiration date should be filled.");

    $(document).ready(function() {

        $(".toggle_unholdable").click(function(e){
            e.preventDefault();
            $(this).parent('div').find(".unholdable").toggle();
        });

        $("#hold-request-form").preventDoubleFormSubmit();
        var copiesRowId = null;
        var wasSpecific = false;
        var lastCopiesRowId = null;

        $(".toggle-hold-options").show();
        $(".hold-options").hide();
        var OPACMandatoryHoldDates = "[% Koha.Preference('OPACMandatoryHoldDates') | html %]";
        if( OPACMandatoryHoldDates == "start" || OPACMandatoryHoldDates == "both" ) {
            $(".holddatefrom").val("").prop( 'required', true ).siblings(".required_label").addClass('required').show();
        }
        if( OPACMandatoryHoldDates == "end"   || OPACMandatoryHoldDates == "both" ) {
            $(".futuredate").prop( 'required', true ).siblings(".required_label").addClass('required').show();
        }

        $(".checkitem").parent().click(function(e){
            if(e.target.tagName.toLowerCase() == 'td'){
                $(this).find("input.checkitem").each( function() {
                    $(this).attr('checked', 'checked');
                });
            }
        });

        // click on a first td check the confirmjs checkbox
        $("td.hold").click(function(e){
          if(e.target.tagName.toLowerCase() == 'td'){
            $(this).find("input.confirmjs").each( function() {
               $(this).attr('checked', !$(this).attr('checked'));
               $(this).change();
            });
          }
        });

        $(".toggle-hold-options").on("click",function(e){
            e.preventDefault();
            toggleLink = $(this);
            var optionsID = this.id.replace("toggle-hold-options-","");
            $("#hold-options-"+optionsID).toggle(0, function() {
                toggleLink.text($(this).is(':visible') ? _("Hide options") : _("Show more options"));
            });
        });
        if( $(".holddatefrom").prop('required') || $(".futuredate").prop('required') ) $(".toggle-hold-options").click();

        // Hides all 'specific copy' table rows on load.
        $(".copiesrow").hide();

        [% FOREACH bibitemloo IN bibitemloop %]
          [% IF bibitemloo.force_hold %]
            if( $("#to[% bibitemloo.biblionumber | html %]").parent(":hidden").length )
                $("#toggle-hold-options-[% bibitemloo.biblionumber | html %]").click();
            $("#reqspecific_[% bibitemloo.biblionumber | html %]").click();
            $("#copiesrow_[% bibitemloo.biblionumber | html %]").show();
          [% END %]
        [% END %]

        // Replace non-JS single-selection with multi-selection capability.
        $(".reserve_mode").val("multi");
        $(".confirm_nonjs").remove();
        $(".confirmjs_hold").each(function(){
            var bib = $(this).attr("title");
            var html = "<label><input type =\"checkbox\" class=\"confirmjs\" checked=\"checked\"";
            html += "value=\"" + bib + "\" id=\"" + bib + "\" /> " + _("Place a hold on") + " </label> ";
            $(this).html(html);
        });
        $(".confirmjs_nohold").each(function(){
            var bib = $(this).attr("title");
            var html = "<label><input type =\"checkbox\" class=\"confirmjs\" disabled=\"disabled\"";
            html += "value=\"" + bib + "\" id=\"" + bib + "\" />" + _("Place a hold on: ") + "</label>";
            $(this).html(html);
        });

        // expand or collapse the copiesrow tr
        function toggle_copiesrow(biblioNum) {
            var checkbox = $("input:checkbox[value='"+biblioNum+"']");
            newCopiesRowId = "#copiesrow_" + biblioNum;
            var select_specific = $("#reqspecific_"+biblioNum).is(":checked");
            // If the checkbox is checked AND we want a specific item, we display the items block
            if ( $(checkbox).is(":checked") && select_specific ) {
                if ( $(`#item_group_id_${biblioNum}`).length ) {
                    $(`#item_group_id_${biblioNum}`).val("").attr('disabled', 'disabled');
                }
                $(newCopiesRowId).show();
            } else {
                if ( $(`#item_group_id_${biblioNum}`).length ) {
                    $(`#item_group_id_${biblioNum}`).removeAttr('disabled');
                }
                $(newCopiesRowId).hide();
            }
        };

        $("#place_on_hdr").show();

        $(".place_on_type").show();
        // onload, selectany is checked
        $(".selectany").attr("checked", "checked");


        // On confirmsjs change
        $(".confirmjs").change(function(){
            var id = suffixOf($(this).attr("id"), "_");
            // If I m checked, I enable radio buttons
            if ( $(this).is(":checked") ) {
                $("#reqspecific_" + id).attr("disabled", false);
                $("#reqany_" + id).attr("disabled", false);
            }
            // Else its are disabled
            else {
                $("#reqspecific_" + id).attr("disabled", "disabled");
                $("#reqany_" + id).attr("disabled", "disabled");
            }
            // expand or collaspe the items block
            toggle_copiesrow(id);
        });

        // When 'specific copy' or 'first available' radio button is clicked
        $(".selectspecific, .selectany").click(function() {
            var id = suffixOf($(this).attr("id"), "_");
            toggle_copiesrow(id);
        });

        // Show or hide holds notes
        $(".shownotes").click(function(){
            biblioNum = suffixOf($(this).attr("id"), "_");
            $("#notesrow_"+biblioNum).toggle();
        });

        // When 'Place Hold' button is clicked
        $(".placehold").click(function(){
            var biblionumbers = "";
            var selections = "";

            [% IF new_reserves_allowed %]
                if ($(".confirmjs:checked").size() > [% new_reserves_allowed | html %] ) {
                    alert(MSG_MAX_HOLDS_EXCEEDED);
                    return false;
                }
            [% END %]

            if ($(".confirmjs:checked").size() == 0) {
                alert( _("No item was selected") );
                return false;
            }

            // Find the items with the 'Hold' box checked
            var badBib = null;
            $(".confirmjs:checked").each(function() {
                var biblioNum = $(this).val();
                biblionumbers += biblioNum + "/";
                selections += biblioNum + "/";

                // If required hold note is empty, make it visible
                if( $("#holdnotes_"+biblioNum).attr( 'required' ) && $("#holdnotes_"+biblioNum).val() == '' ) {
                    if( !$("#hold-options-"+biblioNum).is(':visible')) {
                        $("#toggle-hold-options-"+biblioNum).click();
                    }
                }

                if( $(".holddatefrom").prop('required') && $("#from"+ biblioNum).val() == '' ) {
                    alert(MSG_EMPTY_START_DATE);
                    badBib = biblioNum;
                    if( $("#from"+biblioNum).parent(":hidden").length ) $("#toggle-hold-options-"+biblioNum).trigger('click');
                    $("#from"+biblioNum).siblings('.flatpickr_wrapper').find('.flatpickr-input').trigger('focus');
                    return false;
                } else if( $(".futuredate").prop('required') && $("#to"+ biblioNum).val() == '' ) {
                    alert(MSG_EMPTY_END_DATE);
                    badBib = biblioNum;
                    if( $("#to"+biblioNum).parent(":hidden").length ) $("#toggle-hold-options-"+biblioNum).trigger('click');
                    $("#to"+biblioNum).siblings('.flatpickr_wrapper').find('.flatpickr-input').trigger('focus');
                    return false;
                }

                // If the 'specific copy' radio button is checked
                if ($("#reqspecific_" + biblioNum + ":checked").size() > 0) {
                    // Find the selected copy
                    var item = $(".checkitem_" + biblioNum + ":checked");
                    if ($(item).size() == 0) {
                        alert(MSG_NO_ITEM_SELECTED);
                        badBib = biblioNum;
                        return false;
                    } else {
                      selections += $(item).val();
                    }
                }
                selections += "/";

                // Add the pickup location
                var branchSel = $("#branch_" + biblioNum);
                if (branchSel.size() > 0) {
                    selections += $(branchSel).val();
                }
                selections += "/";
                return true;
            });

            if (badBib) { // alert has been raised already
                return false;
            }

            $("#selections").val(selections);
            $("#biblionumbers").val(biblionumbers);

            return true;
        });
        $(".itemstable").each(function(){
            $(this).DataTable({
                dom: "t",
                initComplete: function() {
                    this.find("input:radio").first().prop("checked", true );
                },
                paging: false
            });
        });
    });
</script>
[% END %]
