1 <& /elements/header.html, mt('Preferences for [_1]', $FS::CurrentUser::CurrentUser->username) &>
3 % my $js_form_validate = { 'pref_form' => { 'name' => 'pref_form' } };
5 <FORM METHOD="POST" NAME="pref_form" ACTION="pref-process.html">
7 <& /elements/error.html &>
9 <& /elements/alert.html &>
11 % if ( FS::Auth->auth_class->can('change_password') ) {
13 <FONT CLASS="fsinnerbox-title"><% emt('Change password (leave blank for no change)') %></FONT>
14 <TABLE CLASS="fsinnerbox">
17 <TH ALIGN="right"><% emt("Current password:") %> </TH>
18 <TD><INPUT TYPE="password" NAME="_password"></TD>
22 <TH ALIGN="right"><% emt("New password:") %> </TH>
23 <TD><INPUT TYPE="password" NAME="new_password"></TD>
27 <TH ALIGN="right"><% emt("Re-enter new password:") %> </TH>
28 <TD><INPUT TYPE="password" NAME="new_password2"></TD>
36 <FONT CLASS="fsinnerbox-title"><% emt("Interface") %></FONT>
37 <TABLE CLASS="fsinnerbox">
40 <TH ALIGN="right"><% emt("Locale:") %> </TH>
42 <SELECT NAME="locale">
43 % foreach my $locale ( @locales ) {
44 % my %info = FS::Locales->locale_info($locale);
45 % my $selected = ($locale eq $curuser->option('locale'))
47 <OPTION VALUE="<% $locale %>" <%$selected%>><% $info{name} %> (<% $info{country} %>)
54 <TH ALIGN="right" STYLE="vertical-align:top"><% emt("Menu location:") %> </TH>
56 <INPUT TYPE="radio" NAME="menu_position" VALUE="left" onClick="document.images['menu_example'].src='../images/menu-left-example.png';" <% $menu_position eq 'left' ? ' CHECKED' : ''%>> <% emt("Left") %><BR>
57 <INPUT TYPE="radio" NAME="menu_position" VALUE="top" onClick="document.images['menu_example'].src='../images/menu-top-example.png';" <% $menu_position eq 'top' ? ' CHECKED' : ''%>> <% emt("Top") %> <BR>
59 <TD><IMG NAME="menu_example" SRC="../images/menu-<% $menu_position %>-example.png"></TD>
63 <TH ALIGN="right"><% emt("Enable mobile-friendly menu:") %> </TH>
65 <INPUT TYPE="checkbox" NAME="mobile_menu" VALUE="Y"
66 <% $curuser->option('mobile_menu') ? 'CHECKED' : '' %>>
71 <TH ALIGN="right"><% emt("Default customer view:") %> </TH>
73 <SELECT NAME="default_customer_view">
74 % foreach my $view ( keys %customer_views ) {
76 % $customer_views{$view} eq $curuser->option('default_customer_view')
79 <OPTION VALUE="<%$customer_views{$view}%>" <%$selected%>><% emt($view) %></OPTION>
85 % my $history_order = $curuser->option('history_order') || 'oldest';
87 <TH ALIGN="right"><% emt("Customer history sort order:") %> </TH>
89 <& /elements/select.html,
90 field => 'history_order',
91 curr_value => $history_order,
92 options => [ 'oldest', 'newest' ],
93 labels => { 'oldest' => mt('Oldest first'),
94 'newest' => mt('Newest first'),
101 <TH ALIGN="right"><% emt("Spreadsheet download format:") %> </TH>
103 <SELECT NAME="spreadsheet_format">
104 % my $xls = $curuser->option('spreadsheet_format') eq 'XLS';
105 % my $xlsx = $curuser->option('spreadsheet_format') eq 'XLSX';
106 <OPTION VALUE=""></OPTION>
107 <OPTION VALUE="XLS"<% $xls ? 'SELECTED' : '' %>>XLS (Excel 97/2000/XP)
109 <OPTION VALUE="XLSX"<% $xlsx ? 'SELECTED' : ''%>>XLSX (Excel 2007+)
116 <TH ALIGN="right" COLSPAN=1><% emt("Disable HTML editor for customer notes:") %> </TH>
117 <TD ALIGN="left" COLSPAN=2>
118 <INPUT TYPE="checkbox" NAME="disable_html_editor" VALUE="1" <% $curuser->option('disable_html_editor') ? 'CHECKED' : '' %>>
123 <TH ALIGN="right" COLSPAN=1><% emt("Disable submission on Enter key - one-time charges:") %> </TH>
124 <TD ALIGN="left" COLSPAN=2>
125 <INPUT TYPE="checkbox" NAME="disable_enter_submit_onetimecharge" VALUE="1" <% $curuser->option('disable_enter_submit_onetimecharge') ? 'CHECKED' : '' %>>
130 <TH ALIGN="right"><% emt("Don't copy MAC address delimiters to clipboard") %></TH>
131 <TD ALIGN="left" COLSPAN=2>
132 <INPUT TYPE="checkbox" NAME="enable_mask_clipboard_hack" VALUE="1" <% $curuser->option('enable_mask_clipboard_hack') ? 'CHECKED' : '' %>>
137 <TH ALIGN="right"><% emt("When printing, scale HTML documents to fit on a letter-size page") %></TH>
139 <INPUT TYPE="checkbox" NAME="printtofit" VALUE="Y" <% $curuser->option('printtofit') ? 'CHECKED' : '' %>>
144 <TH ALIGN="right"><% emt("How many recently-modified customers displayed on dashboard") %></TH>
145 <TD ALIGN="left" COLSPAN=2>
146 <INPUT TYPE="text" NAME="dashboard_customers" VALUE="<% $curuser->option('dashboard_customers') %>"></TD>
150 % my $validate_field_cve = 'customer_view_emails';
151 % $js_form_validate->{pref_form}->{validate_fields}{$validate_field_cve} = 'digits: true';
152 % $js_form_validate->{pref_form}->{error_message}{$validate_field_cve} = 'Please only enter numbers here.';
155 <TH ALIGN="right"><% emt("How many recent outbound emails to show in customer view") %></TH>
156 <TD ALIGN="left" COLSPAN=2>
157 <INPUT TYPE="text" ID="<% $validate_field_cve %>" NAME="<% $validate_field_cve %>" VALUE="<% $curuser->option('customer_view_emails') %>"></TD>
165 <FONT CLASS="fsinnerbox-title"><% emt("Email Address") %></FONT>
166 <TABLE CLASS="fsinnerbox">
169 <TH><% emt("Email Address(es) (comma separated) ") %></TH>
171 <TD><INPUT TYPE="text" NAME="email_address" VALUE="<% $email_address %>">
179 <FONT CLASS="fsinnerbox-title"><% emt("Development") %></FONT>
180 <TABLE CLASS="fsinnerbox">
183 <TH><% emt("Show customer package timestamps:") %> </TH>
184 <TD><INPUT TYPE="checkbox" NAME="cust_pkg-display_times" VALUE="1" <% $curuser->option('cust_pkg-display_times') ? 'CHECKED' : '' %>></TD>
187 <TH><% emt("Show internal package numbers:") %> </TH>
188 <TD><INPUT TYPE="checkbox" NAME="show_pkgnum" VALUE="1" <% $curuser->option('show_pkgnum') ? 'CHECKED' : '' %>></TD>
191 <TH><% emt("Show config item counts:") %> </TH>
192 <TD><INPUT TYPE="checkbox" NAME="show_confitem_counts" VALUE="1" <% $curuser->option('show_confitem_counts') ? 'CHECKED' : '' %>></TD>
195 <TH><% emt("Show export data on service view (when available):") %> </TH>
196 <TD><INPUT TYPE="checkbox" NAME="export_getsettings" VALUE="1" <% $curuser->option('export_getsettings') ? 'CHECKED' : '' %>></TD>
199 <TH><% emt("Show database profiling (when available):") %> </TH>
200 <TD><INPUT TYPE="checkbox" NAME="show_db_profile" VALUE="1" <% $curuser->option('show_db_profile') ? 'CHECKED' : '' %>></TD>
203 <TH><% emt("Save database profiling logs (when available):") %> </TH>
204 <TD><INPUT TYPE="checkbox" NAME="save_db_profile" VALUE="1" <% $curuser->option('save_db_profile') ? 'CHECKED' : '' %>></TD>
207 <TH><% emt("Save temporary invoice typesetting files:") %> </TH>
208 <TD><INPUT TYPE="checkbox" NAME="save_tmp_typesetting" VALUE="1" <% $curuser->option('save_tmp_typesetting') ? 'CHECKED' : '' %>></TD>
214 % if ( $curuser->access_right('Employee preference telephony integration') ) {
216 <% emt("SNOM integration") %>
217 <% ntable("#cccccc",2) %>
220 <TH ALIGN="right"><% emt("SNOM IP address") %></TH>
221 <TD><INPUT TYPE="text" NAME="snom-ip" VALUE="<% $curuser->option('snom-ip') %>"></TD>
225 <TH ALIGN="right"><% emt("SNOM HTTP username (if necessary)") %></TH>
226 <TD><INPUT TYPE="text" NAME="snom-username" VALUE="<% $curuser->option('snom-username') %>"></TD>
230 <TH ALIGN="right"><% emt("SNOM HTTP password (if necessary)") %></TH>
231 <TD><INPUT TYPE="password" NAME="snom-password" VALUE="<% $curuser->option('snom-password') %>"></TD>
237 <% emt("OR")%><BR><BR>
239 <% emt("Vonage integration (see") %> <a href="https://secure.click2callu.com/"><% emt("Click2Call") %></a>)
240 <% ntable("#cccccc",2) %>
243 <TH ALIGN="right"><% emt("Vonage phone number") %></TH>
244 <TD><INPUT TYPE="text" NAME="vonage-fromnumber" VALUE="<% $curuser->option('vonage-fromnumber') %>"></TD>
248 <TH ALIGN="right"><% emt("Vonage username") %></TH>
249 <TD><INPUT TYPE="text" NAME="vonage-username" VALUE="<% $curuser->option('vonage-username') %>"></TD>
253 <TH ALIGN="right"><% emt("Vonage password") %></TH>
254 <TD><INPUT TYPE="password" NAME="vonage-password" VALUE="<% $curuser->option('vonage-password') %>"></TD>
262 % foreach my $prop (qw( height width availHeight availWidth colorDepth )) {
263 <INPUT TYPE="hidden" NAME="<% $prop %>" VALUE="">
264 <SCRIPT TYPE="text/javascript">
265 document.pref_form.<% $prop %>.value = screen.<% $prop %>;
269 <INPUT TYPE="submit" VALUE="<% emt("Update preferences") %>">
272 % 'formvalidation' => $js_form_validate,
274 <% include("/elements/footer.html", %footerdata) %>
276 %#<&/elements/footer.html &>
280 my $curuser = $FS::CurrentUser::CurrentUser;
282 #false laziness w/view/cust_main.cgi and Conf.pm (cust_main-default_view)
284 tie my %customer_views, 'Tie::IxHash',
285 'Basics' => 'basics',
286 'Notes' => 'notes', #notes and files?
287 'Tickets' => 'tickets',
288 'Appointments' => 'appointments',
289 'Quotations' => 'quotations',
290 'Packages' => 'packages',
291 'Payment History' => 'payment_history',
293 $customer_views{'Change History'} = 'change_history'
294 if $curuser->access_right('View customer history');
296 # XSS via your own preferences? seems unlikely, but nice try anyway...
297 ( $curuser->option('menu_position') || 'top' )
298 =~ /^(\w+)$/ or die "illegal menu_position";
299 my $menu_position = $1;
300 ( $curuser->option('email_address') )
301 =~ /^([,\w\@.\-]*)$/ or die "illegal email_address"; #too late
302 my $email_address = $1;
304 my $conf = new FS::Conf;
306 my @locales = $conf->config('available-locales');
310 @locales = FS::Locales->locales ;