]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/xul/staff_client/server/main/simple_auth.xul
LP1615805 No inputs after submit in patron search (AngularJS)
[working/Evergreen.git] / Open-ILS / xul / staff_client / server / main / simple_auth.xul
1 <?xml version="1.0"?>
2 <!-- Application: Evergreen Staff Client -->
3 <!-- Screen: Example Template for remote xul -->
4 <!--
5  vim:noet:sw=4:ts=4:
6 -->
7
8 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
9 <!-- STYLESHEETS -->
10 <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
11 <?xml-stylesheet href="/xul/server/skin/global.css" type="text/css"?>
12 <?xml-stylesheet href="/xul/server/skin/simple_auth.css" type="text/css"?>
13
14 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
15 <!-- LOCALIZATION -->
16 <!DOCTYPE window PUBLIC "" ""[
17     <!--#include virtual="/opac/locale/${locale}/lang.dtd"-->
18 ]>
19
20 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
21 <!-- OVERLAYS -->
22 <?xul-overlay href="/xul/server/OpenILS/util_overlay.xul"?>
23
24 <window id="simple_auth_win" oils_persist="height width sizemode"
25     onload="try { my_init(); font_helper(); persist_helper(); } catch(E) { alert(E); }"
26     xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
27
28     <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
29     <!-- BEHAVIOR -->
30         <script type="text/javascript">
31         var myPackageDir = 'open_ils_staff_client'; var IAMXUL = true; var g = {};
32     </script>
33         <scripts id="openils_util_scripts"/>
34
35     <script type="text/javascript" src="/xul/server/main/JSAN.js"/>
36     <script>
37     <![CDATA[
38
39         var offlineStrings = document.getElementById('offlineStrings');
40         var login_type = 'temp';
41
42         function my_init() {
43             try {
44                 if (typeof JSAN == 'undefined') { 
45                     throw( offlineStrings.getString('common.jsan.missing'));
46                 }
47                 JSAN.errorLevel = "die"; // none, warn, or die
48                 JSAN.addRepository('/xul/server/');
49                 JSAN.use('util.error'); g.error = new util.error();
50                 g.error.sdump('D_TRACE','my_init() for simple_auth.xul');
51
52                 JSAN.use('OpenILS.data'); g.data = new OpenILS.data(); g.data.init({'via':'stash'});
53                 g.data.temporary_session = ''; g.data.stash('temporary_session');
54
55                 $('server').value = g.data.server_unadorned;
56
57                 login_type = xul_param('login_type') || 'temp';
58                 addCSSClass(document.documentElement,login_type)
59                 if(login_type == 'ochange')
60                     $('change_type_row').hidden = false;
61
62                 if (xul_param('desc_brief')) {
63                     $('desc').hidden = false;
64                     $('desc_brief').appendChild( document.createTextNode( xul_param('desc_brief') ) );
65                 }
66                 if (xul_param('desc_full')) {
67                     $('desc').hidden = false;
68                     $('desc_full').appendChild( document.createTextNode( xul_param('desc_full') ) );
69                 }
70
71                 $('username').focus();
72
73                 $('username').addEventListener('keypress',handle_keypress,false);
74                 $('password').addEventListener('keypress',handle_keypress,false);
75
76             } catch(E) {
77                 var err_msg =  offlineStrings.getFormattedString('common.exception', ['simple_auth.xul', E]);
78                 try { g.error.sdump('D_ERROR',err_msg); } catch(E) { dump(err_msg); }
79                 alert(err_msg);
80             }
81         }
82
83         function $(id) { return document.getElementById(id); }
84
85         function handle_keypress(ev) {
86             if ( (! ev.keyCode) || (ev.keyCode != 13) ) return;
87             switch(ev.target) {
88                 case $('username') : $('password').focus(); break;
89                 case $('password') : authorize(); break;
90                 default: break;
91             }
92         }
93
94         function authorize() {
95             try {
96                 var my_login_type = login_type;
97                 var is_perm = false;
98                 if(login_type == 'ochange') {
99                     my_login_type = $('change_type').value;
100                     if(my_login_type == 'perm') {
101                         my_login_type = 'staff';
102                         is_perm = true;
103                     }
104                 }
105                 JSAN.use('auth.session');
106                 g.session = new auth.session(
107                     {
108                         'name_prompt' : $('username'),
109                         'password_prompt' : $('password'),
110                         'server_prompt' : $('server'),
111                     },
112                     my_login_type
113                 );
114                 g.session.on_init = function() { 
115                     try {
116                         JSAN.use('util.network'); var n = new util.network();
117                         var staff = n.simple_request('FM_AU_RETRIEVE_VIA_SESSION',[ g.session.key ]);
118                         g.data.temporary_session = {  // old way because of local chrome still out there
119                             'key' : g.session.key, 
120                             'authtime' : g.session.authtime, 
121                             'usr' : js2JSON(staff),
122                             'is_perm' : is_perm,
123                             'login_type' : my_login_type
124                         }
125                         g.data.stash('temporary_session');
126                         xulG.temporary_session = g.data.temporary_session;
127                         window.close();
128                     } catch(E) {
129                         g.error.standard_unexpected_error_alert('simple_auth.session.on_init',E);
130                     }
131                 }
132                 g.session.on_init_error = function() { 
133                     $('password').value = '';
134                     $('username').focus();
135                     $('username').select();
136                  }
137                 g.session.init();
138             } catch(E) {
139                 alert(E);
140             }
141         }
142
143     ]]>
144     </script>
145
146     <commandset id="simple_auth_cmds">
147         <command id="cmd_broken" />
148     </commandset>
149
150     <vbox id="simple_auth_main" flex="1">
151     <groupbox id="desc" hidden="true">
152         <caption label="&staff.main.simple_auth.exception.label;"/>
153         <description id="desc_brief" style="color: red"/>
154         <description id="desc_full"/>
155     </groupbox>
156     <groupbox>
157         <caption label="&staff.main.simple_auth.authorization.label;"/>
158         <grid>
159             <columns><column /><column /><column flex="1" /></columns>
160             <rows>
161                 <row>
162                     <label value="&common.username.label;" control="username" accesskey="&common.username.accesskey;"/>
163                     <textbox id="username" />
164                 </row>
165                 <row>
166                     <label value="&staff.auth.password_prompt;" control="password" accesskey="&staff.auth.password_prompt.accesskey;"/>
167                     <textbox id="password" type="password"/>
168                 </row>
169                 <row id="change_type_row" hidden="true">
170                     <label value="&staff.auth.change_type.label;" control="change_type" accesskey="&staff.auth.change_type.accesskey;"/>
171                     <menulist id="change_type">
172                         <menupopup>
173                                 <menuitem label="&staff.auth.change_type_temporary;" value="temp" selected="true"/>
174                                 <menuitem label="&staff.auth.change_type_staff;" value="staff"/>
175                                 <menuitem label="&staff.auth.change_type_permanent;" value="perm"/>
176                         </menupopup>
177                     </menulist>
178                     <description>&staff.auth.change_type_description;</description>
179                 </row>
180                 <row>
181                     <button label="&common.cancel;" accesskey="&common.cancel.accesskey;" oncommand="window.close()"/>
182                     <button label="&staff.main.simple_auth.authorize.label;" accesskey="&staff.main.simple_auth.authorize.accesskey;" oncommand="authorize()"/>
183                 </row>
184             </rows>
185         </grid>
186         <label id="server" hidden="true"/>
187     </groupbox>
188     <spacer flex="1"/>
189     </vbox>
190 </window>
191