Bug 20168: Update of the OPAC bootstrap template to bootstrap v4
[koha.git] / koha-tmpl / opac-tmpl / bootstrap / en / modules / opac-messaging.tt
1 [% USE Koha %]
2 [% INCLUDE 'doc-head-open.inc' %]
3 <title>[% IF ( LibraryNameTitle ) %][% IF ( LibraryNameTitle ) %][% LibraryNameTitle | html %][% ELSE %]Koha online[% END %][% ELSE %]Koha online[% END %] catalog &rsaquo; Your messaging settings</title>
4 [% INCLUDE 'doc-head-close.inc' %]
5 [% BLOCK cssinclude %][% END %]
6 </head>
7 [% INCLUDE 'bodytag.inc' bodyid='opac-messaging' %]
8 [% INCLUDE 'masthead.inc' %]
9
10 <div class="main">
11     <nav aria-label="breadcrumb">
12         <ul class="breadcrumb">
13             <li class="breadcrumb-item">
14                 <a href="/cgi-bin/koha/opac-main.pl">Home</a>
15             </li>
16             <li class="breadcrumb-item">
17                 <a href="/cgi-bin/koha/opac-user.pl">[% INCLUDE 'patron-title.inc' patron = logged_in_user %]</a>
18             </li>
19             <li class="breadcrumb-item" aria-current="IsPatronPage">
20                 <a href="#">Your messaging settings</a>
21             </li>
22         </ul>
23     </nav>
24
25     <div class="container-fluid">
26         <div class="row">
27             <div class="col col-lg-2 order-2 order-lg-1">
28                 <div id="navigation">
29                     [% INCLUDE 'navigation.inc' IsPatronPage=1 %]
30                 </div>
31             </div>
32             <div class="col-md-12 col-lg-10 order-1">
33
34                 [% IF Koha.Preference( 'EnhancedMessagingPreferencesOPAC' )  %]
35                     <div id="usermessaging" class="maincontent">
36                         <h3>Your messaging settings</h3>
37                         [% IF ( settings_updated ) %]
38                             <div class="alert alert-success"><h4>Settings updated</h4></div>
39                         [% END %]
40                         <form action="/cgi-bin/koha/opac-messaging.pl" method="post" name="opacmessaging">
41                             <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
42                             <input type="hidden" name="modify" value="yes" />
43
44                                 <table class="table table-bordered table-condensed table-striped">
45                                     <thead>
46                                         <tr>
47                                             <th>&nbsp;</th>
48                                             <th>Days in advance</th>
49                                             [% IF ( SMSSendDriver ) %]<th>SMS</th>[% END %]
50                                             [% IF ( TalkingTechItivaPhone ) %]<th>Phone</th>[% END %]
51                                             <th>Email</th>
52                                             <th>Digests only <i id="info_digests" data-toggle="tooltip" title="You can ask for a digest to reduce the number of messages. Messages will be saved and sent as a single message." data-placement="right" class="fa fa-info-circle"></i></th>
53                                         </tr>
54                                     </thead>
55                                     <tbody>
56                                     [% FOREACH messaging_preference IN messaging_preferences %]
57                                         <tr>
58                                             <td>[% IF ( messaging_preference.Item_Due ) %]Item due
59                                                 [% ELSIF ( messaging_preference.Advance_Notice ) %]Advance notice
60                                                 [% ELSIF ( messaging_preference.Upcoming_Events ) %]Upcoming events
61                                                 [% ELSIF ( messaging_preference.Hold_Filled ) %]Hold filled
62                                                 [% ELSIF ( messaging_preference.Item_Check_in ) %]Item check-in
63                                                 [% ELSIF ( messaging_preference.Item_Checkout ) %]Item checkout
64                                                 [% ELSE %]Unknown [% END %]</td>
65                                             [% IF ( messaging_preference.takes_days ) %]
66                                                 <td><select class="input-mini" name="[% messaging_preference.message_attribute_id | html %]-DAYS">
67                                                 [% FOREACH select_day IN messaging_preference.select_days %]
68                                                     [% IF ( select_day.selected ) %]
69                                                         <option value="[% select_day.day | html %]" selected="selected">[% select_day.day | html %]</option>
70                                                     [% ELSE %]
71                                                         <option value="[% select_day.day | html %]">[% select_day.day | html %]</option>
72                                                     [% END %]
73                                                 [% END %]
74                                                 </select></td>
75                                             [% ELSE %]
76                                                 <td>-</td>
77                                             [% END %]
78                                             [% IF ( SMSSendDriver ) %]
79                                                 [% IF ( messaging_preference.transport_sms ) %]
80                                                     <td>
81                                                         [% IF ( messaging_preference.transports_sms ) %]
82                                                         <input type="checkbox" id="sms[% messaging_preference.message_attribute_id | html %]" name="[% messaging_preference.message_attribute_id | html %]" value="sms" checked="checked" />
83                                                         [% ELSE %]
84                                                             <input type="checkbox" id="sms[% messaging_preference.message_attribute_id | html %]" name="[% messaging_preference.message_attribute_id | html %]" value="sms" />
85                                                         [% END %]
86                                                     </td>
87                                                 [% ELSE %]
88                                                     <td>-</td>
89                                                 [% END %]
90                                             [% END %]
91                                             [% IF ( TalkingTechItivaPhone ) %]
92                                                 [% IF ( messaging_preference.transport_phone ) %]
93                                                 <td>
94                                                 [% IF ( messaging_preference.transports_phone ) %]
95                                                 <input type="checkbox"
96                                                             id="phone[% messaging_preference.message_attribute_id | html %]"
97                                                             name="[% messaging_preference.message_attribute_id | html %]"
98                                                             value="phone" checked="checked" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
99                                                 [% ELSE %]
100                                                 <input type="checkbox"
101                                                             id="phone[% messaging_preference.message_attribute_id | html %]"
102                                                             name="[% messaging_preference.message_attribute_id | html %]"
103                                                             value="phone" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
104                                                 [% END %]
105                                                 </td>
106                                                 [% ELSE %]
107                                                     <td>-</td>
108                                                 [% END %]
109                                             [% END %]
110
111                                             [% IF ( messaging_preference.transport_email ) %]
112                                                 <td>
113                                                     [% IF ( messaging_preference.transports_email ) %]
114                                                         <input type="checkbox" id="email[% messaging_preference.message_attribute_id | html %]" name="[% messaging_preference.message_attribute_id | html %]" value="email" checked="checked" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
115                                                     [% ELSE %]
116                                                         <input type="checkbox" id="email[% messaging_preference.message_attribute_id | html %]" name="[% messaging_preference.message_attribute_id | html %]" value="email" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
117                                                     [% END %]
118                                                 </td>
119                                             [% ELSE %]
120                                                 <td>-</td>
121                                             [% END %]
122
123                                             [% IF ( messaging_preference.has_digest ) %]
124                                                 <td>
125                                                     [% IF ( messaging_preference.digest ) %]
126                                                         <input type="checkbox" id="digest[% messaging_preference.message_attribute_id | html %]" value="[% messaging_preference.message_attribute_id | html %]" name="digest" checked="checked" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
127                                                     [% ELSE %]
128                                                         <input type="checkbox" id="digest[% messaging_preference.message_attribute_id | html %]" value="[% messaging_preference.message_attribute_id | html %]" name="digest" onclick = "document.opacmessaging.none[% messaging_preference.message_attribute_id | html %].checked=false;" />
129                                                     [% END %]
130                                                 </td>
131                                             [% ELSE %]
132                                             <td>-</td>
133                                             [% END %]
134
135                                         </tr>
136                                     [% END # / FOREACH messaging_preferences%]
137                                 </tbody>
138                             </table>
139
140                             [% IF ( SMSSendDriver || Koha.Preference('TranslateNotices') ) %]
141                                 <fieldset class="rows">
142                                     <ol>
143                                         [% IF ( SMSSendDriver ) %]
144                                             <li>
145                                                 <strong>Notice:</strong> Some charges for text messages may be incurred when using this service. Please check with your mobile service provider if you have questions.
146                                             </li>
147                                             <li>
148                                                 <label for="SMSnumber">SMS number:</label>
149                                                 <input type="text" id="SMSnumber" name="SMSnumber" value="[% SMSnumber | html %]" pattern="^\+?[1-9]\d{1,14}$" />
150                                                 <div class="hint">Please enter numbers only. <strong>(123) 456-7890</strong> would be entered as <strong>1234567890</strong>.</div>
151                                             </li>
152
153                                             [% IF ( SMSSendDriver == 'Email' ) %]
154                                                 <li>
155                                                     <label for="sms_provider_id">SMS provider:</label>
156                                                     <select id="sms_provider_id" name="sms_provider_id">
157                                                         <option value="">Unknown</option>
158                                                         [% FOREACH s IN sms_providers %]
159                                                             [% IF s.id == sms_provider_id %]
160                                                                 <option value="[% s.id | html %]" selected="selected">[% s.name | html %]</option>
161                                                             [% ELSE %]
162                                                                 <option value="[% s.id | html %]">[% s.name | html %]</option>
163                                                             [% END %]
164                                                         [% END %]
165                                                     </select>
166                                                     <div class="hint">Please contact a library staff member if you are unsure of your mobile service provider, or you do not see your provider in this list.</div>
167                                                 </li>
168                                             [% END # /IF ( SMSSendDriver == 'Email' ) %]
169                                         [% END # /IF SMSSendDriver %]
170
171                                         [% IF Koha.Preference('TranslateNotices') %]
172                                             <li>
173                                                 <label for="lang">Preferred language for notices: </label>
174                                                 <select id="lang" name="lang">
175                                                     <option value="default">Default</option>
176                                                     [% FOR language IN languages %]
177                                                         [% FOR sublanguage IN language.sublanguages_loop %]
178                                                             [% IF language.plural %]
179                                                                 [% IF sublanguage.rfc4646_subtag == patron_lang %]
180                                                                     <option value="[% sublanguage.rfc4646_subtag | html %]" selected="selected">[% sublanguage.native_description | html %] [% sublanguage.region_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
181                                                                 [% ELSE %]
182                                                                     <option value="[% sublanguage.rfc4646_subtag | html %]">[% sublanguage.native_description | html %] [% sublanguage.region_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
183                                                                 [% END %]
184                                                             [% ELSE %]
185                                                                 [% IF sublanguage.rfc4646_subtag == patron_lang %]
186                                                                     <option value="[% sublanguage.rfc4646_subtag | html %]" selected="selected">[% sublanguage.native_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
187                                                                 [% ELSE %]
188                                                                     <option value="[% sublanguage.rfc4646_subtag | html %]">[% sublanguage.native_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
189                                                                 [% END %]
190                                                             [% END # /IF language.plural %]
191                                                         [% END # /FOR sublanguage %]
192                                                     [% END #/FOR language %]
193                                                 </select> <!-- /#lang -->
194                                             </li>
195                                         [% END #/IF Koha.Preference('TranslateNotices') %]
196                                     </ol>
197                                 </fieldset>
198                             [% END #/IF SMSSendDriver || Koha.Preference('TranslateNotices') %]
199
200                             <fieldset class="action">
201                                 <input type="submit" value="Submit changes" class="btn btn-primary" />
202                                 <a class="cancel" href="/cgi-bin/koha/opac-user.pl">Cancel</a>
203                             </fieldset>
204                         </form>
205                     </div> <!-- / #usermessaging -->
206                 [% ELSE %]
207                     <h4>You are not allowed to call this page directly</h4>
208                 [% END # /IF Koha.Preference( 'EnhancedMessagingPreferencesOPAC' ) %]
209            </div> <!-- / .col-lg-10 -->
210         </div> <!-- / .row -->
211     </div> <!-- / .container-fluid -->
212 </div> <!-- / .main -->
213
214 [% INCLUDE 'opac-bottom.inc' %]
215 [% BLOCK jsinclude %]
216     <script>
217         $(document).ready(function(){
218             $(".none").click(function(){
219                 if($(this).attr("checked")){
220                     var rowid = $(this).attr("id");
221                     newid = Number(rowid.replace("none",""))
222                     $("#sms"+newid).removeAttr("checked");
223                     $("#email"+newid).removeAttr("checked");
224                     $("#digest"+newid).removeAttr("checked");
225                     $("#rss"+newid).removeAttr("checked");
226                 }
227             });
228             $("#info_digests").tooltip();
229         });
230
231         function normalizeSMS(value){
232             let has_plus = value.charAt(0) === '+';
233             let new_value = value.replace(/\D/g,'');
234             if ( has_plus ) new_value = '+' + new_value;
235             return new_value;
236         }
237
238         var sms_input = document.getElementById('SMSnumber');
239
240         if (typeof sms_input !== 'undefined' && sms_input !== null) {
241             sms_input.addEventListener('keyup', function(){
242                 var field = sms_input.value;
243                 sms_input.value = normalizeSMS(field);
244             });
245
246             sms_input.addEventListener('paste', function(event) {
247                 let paste = (event.clipboardData || window.clipboardData).getData('text');
248                 setTimeout(function () {
249                 sms_input.value = normalizeSMS(paste);
250                 }, 100);
251             });
252         }
253     </script>
254 [% END %]