Account credentials page

Renamed "Account Info" page to "Credentials"; rearranged form, moving Name and Timezone preferences to Community section. (DBOINCP-49)
This commit is contained in:
Tristan Olive 2013-09-16 13:30:21 -04:00
parent 2f44572dbb
commit eb5a2e0c5d
3 changed files with 115 additions and 34 deletions

View File

@ -66,7 +66,7 @@ function boinc_standard_menu_default_menu_links() {
'menu_name' => 'primary-links', 'menu_name' => 'primary-links',
'link_path' => 'user/me/edit', 'link_path' => 'user/me/edit',
'router_path' => 'user/%/edit', 'router_path' => 'user/%/edit',
'link_title' => 'Account Info', 'link_title' => 'Credentials',
'options' => array( 'options' => array(
'attributes' => array( 'attributes' => array(
'title' => '', 'title' => '',
@ -82,7 +82,7 @@ function boinc_standard_menu_default_menu_links() {
); );
// Translatables // Translatables
// Included for use with string extractors like potx. // Included for use with string extractors like potx.
t('Account Info'); t('Credentials');
t('BOINC'); t('BOINC');
t('Dashboard'); t('Dashboard');
t('Home'); t('Home');

View File

@ -436,26 +436,16 @@ function boincuser_form_alter(&$form, $form_state, $form_id) {
$form['account']['name']['#size'] = 40; $form['account']['name']['#size'] = 40;
$form['account']['mail']['#size'] = 40; $form['account']['mail']['#size'] = 40;
$form['account']['pass']['#size'] = 17;
// Add the BOINC user name (non-unique, user editable)
if (!$edit['boincuser_name']) $edit['boincuser_name'] = $account->boincuser_name;
$form['account']['boincuser_name'] = array(
'#type' => 'textfield',
'#title' => t('Name'),
'#default_value' => $edit['boincuser_name'],
'#maxlength' => USERNAME_MAX_LENGTH,
'#required' => TRUE,
'#description' => t(''),
'#size' => 40
);
if (!$reset_pass AND ($user->uid == $account->uid OR !user_access('administer users'))) { if (!$reset_pass AND ($user->uid == $account->uid OR !user_access('administer users'))) {
// Add a password authenticator, required to change email or pw // Add a password authenticator, required to change email or pw
$form['account']['current_pass'] = array( $form['account']['current_pass'] = array(
'#type' => 'password', '#type' => 'password',
'#title' => t('Current password'), '#title' => t('Enter your password to save changes'),
'#description' => t('Enter your current password if changing your email '#description' => t('Enter your current password if changing your email
address or password.'), address or password.'),
'#size' => 25 '#size' => 17
); );
} }
@ -489,24 +479,29 @@ function boincuser_form_alter(&$form, $form_state, $form_id) {
</div>', </div>',
); );
$form['account']['separator_bottom'] = array(
'#value' => '<div class="separator buttons"></div>'
);
$form['submit']['#value'] = t('Save changes');
// Rearrange form elements // Rearrange form elements
$form['account']['boincuser_name']['#weight'] = 0;
$form['account']['mail']['#weight'] = 5; $form['account']['mail']['#weight'] = 5;
$form['account']['current_pass']['#weight'] = 10;
$form['account']['pass']['#weight'] = 15; $form['account']['pass']['#weight'] = 15;
$form['account']['user_id']['#weight'] = 50; $form['account']['user_id']['#weight'] = 50;
$form['account']['account_key']['#weight'] = 55; $form['account']['account_key']['#weight'] = 55;
$form['account']['weak_account_key']['#weight'] = 60; $form['account']['weak_account_key']['#weight'] = 60;
$form['account']['cpid']['#weight'] = 65; $form['account']['cpid']['#weight'] = 65;
$form['account']['separator_bottom']['#weight'] = 999;
$form['account']['current_pass']['#weight'] = 1000;
// Remove redundant / unnecessary form elements // Remove redundant / unnecessary form elements
//echo '<pre>' . print_r($form, true) . '</pre>';
unset($form['theme_select']); unset($form['theme_select']);
// These are on the Community preferences form (boincwork module) // These are on the Community preferences form (boincwork module)
unset($form['signature_settings']);
unset($form['enable_pm_mail']); unset($form['enable_pm_mail']);
unset($form['friend_notification']); unset($form['friend_notification']);
unset($form['signature_settings']);
unset($form['timezone']);
// Internal fields to indicate where these user changes are taking place // Internal fields to indicate where these user changes are taking place
array_unshift($form, array( array_unshift($form, array(
@ -601,6 +596,27 @@ function boincuser_form_alter(&$form, $form_state, $form_id) {
} }
} }
/**
* Implementation of hook_elements()
* @see http://api.drupal.org/api/drupal/developer--hooks--core.php/function/hook_elements/6
*/
function boincuser_elements() {
$type['password_confirm']['#process'][] = 'boincuser_process_password_confirm';
return $type;
}
/**
* This madness is required to change the password field label on the user
* profile form
*/
function boincuser_process_password_confirm($element) {
// Check if parent element is "account".
if ($element['#array_parents'][0] == 'account') {
$element['pass1']['#title'] = t('Change password');
}
return $element;
}
/** /**
* Implementation of hook_theme() * Implementation of hook_theme()
* Register theme functions for use in this module. * Register theme functions for use in this module.

View File

@ -513,7 +513,7 @@ function boincwork_generalprefs_form(&$form_state, $venue, $prefs_preset = null,
$form['prefs']['form control tabs'] = array( $form['prefs']['form control tabs'] = array(
'#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>' '#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>'
); );
if ($venue != 'generic') { if ($venue AND $venue != 'generic') {
global $base_path; global $base_path;
$form['prefs']['form control tabs']['#value'] .= '<li class="tab">' . $form['prefs']['form control tabs']['#value'] .= '<li class="tab">' .
l(t('Clear'), "account/prefs/computing/clear/{$venue}", l(t('Clear'), "account/prefs/computing/clear/{$venue}",
@ -527,7 +527,10 @@ function boincwork_generalprefs_form(&$form_state, $venue, $prefs_preset = null,
) . '</li>'; ) . '</li>';
} }
$form['prefs']['view control'] = array( $form['prefs']['view control'] = array(
'#value' => '<li class="first alt tab">' . l('(' . t('Show comparison view') . ')', 'account/prefs/computing/combined') . '</li></ul>' '#value' => '<li class="first alt tab">' . l('(' . t('Show comparison view') . ')', 'account/prefs/computing/combined') . '</li>'
);
$form['prefs']['form control tabs suffix'] = array(
'#value' => '</ul>'
); );
$form['#submit'][] = 'boincwork_generalprefs_form_submit'; $form['#submit'][] = 'boincwork_generalprefs_form_submit';
@ -875,7 +878,7 @@ function boincwork_projectprefs_form(&$form_state, $venue) {
$form['prefs']['form control tabs'] = array( $form['prefs']['form control tabs'] = array(
'#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>' '#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>'
); );
if ($venue != 'generic') { if ($venue AND $venue != 'generic') {
global $base_path; global $base_path;
$form['prefs']['form control tabs']['#value'] .= '<li class="tab">' . $form['prefs']['form control tabs']['#value'] .= '<li class="tab">' .
l(t('Clear'), "account/prefs/project/clear/{$venue}", l(t('Clear'), "account/prefs/project/clear/{$venue}",
@ -889,7 +892,10 @@ function boincwork_projectprefs_form(&$form_state, $venue) {
) . '</li>'; ) . '</li>';
} }
$form['prefs']['view control'] = array( $form['prefs']['view control'] = array(
'#value' => '<li class="first alt tab">' . l('(' . t('Show comparison view') . ')', 'account/prefs/project/combined') . '</li></ul>' '#value' => '<li class="first alt tab">' . l('(' . t('Show comparison view') . ')', 'account/prefs/project/combined') . '</li>'
);
$form['prefs']['form control tabs suffix'] = array(
'#value' => '</ul>'
); );
return $form; return $form;
@ -1024,6 +1030,7 @@ function boincwork_projectprefs_form_submit($form, &$form_state) {
*/ */
function communityprefs_form(&$form_state) { function communityprefs_form(&$form_state) {
global $user; global $user;
$account = user_load($user->uid);
$form = array(); $form = array();
// Standard option sets // Standard option sets
@ -1034,10 +1041,40 @@ function communityprefs_form(&$form_state) {
$default = array( $default = array(
'pm_send_notification' => '', // This is set already in pm_email_notify_user 'pm_send_notification' => '', // This is set already in pm_email_notify_user
'friend_notification' => isset($user->friend_notification) ? $user->friend_notification : 0, 'friend_notification' => isset($account->friend_notification) ? $account->friend_notification : 0,
'comments_per_page' => (isset($user->comments_per_page) AND $user->comments_per_page) ? $user->comments_per_page : variable_get('comment_default_per_page_forum', 50) 'comments_per_page' => (isset($account->comments_per_page) AND $account->comments_per_page) ? $account->comments_per_page : variable_get('comment_default_per_page_forum', 50)
); );
// General options
$form['general'] = array(
'#type' => 'fieldset',
'#title' => t('General settings'),
'#weight' => 0,
'#collapsible' => TRUE,
'#collapsed' => FALSE
);
// Add the BOINC user name (non-unique, user editable)
$form['general']['boincuser_name'] = array(
'#type' => 'textfield',
'#title' => t('Name'),
'#default_value' => $account->boincuser_name,
'#maxlength' => USERNAME_MAX_LENGTH,
'#required' => TRUE,
'#description' => t(''),
'#size' => 40
);
// Time zone
if (variable_get('configurable_timezones', 1)) {
$zones = _system_zonelist();
$form['general']['timezone'] = array(
'#type' => 'select',
'#title' => t('Time zone'),
'#default_value' => ($account->timezone !== NULL) ? $account->timezone : variable_get('date_default_timezone', 0),
'#options' => $zones,
'#description' => '',
);
}
// Notification options // Notification options
$form['notifications'] = array( $form['notifications'] = array(
'#type' => 'fieldset', '#type' => 'fieldset',
@ -1047,7 +1084,7 @@ function communityprefs_form(&$form_state) {
'#collapsed' => FALSE '#collapsed' => FALSE
); );
// Pull in private message notification handling and tweak the form // Pull in private message notification handling and tweak the form
$pm_notify = pm_email_notify_user('form', $edit, $user, 'account'); $pm_notify = pm_email_notify_user('form', $edit, $account, 'account');
$form['notifications']['pm_send_notifications'] = array_replace( $form['notifications']['pm_send_notifications'] = array_replace(
$pm_notify['enable_pm_mail']['pm_send_notifications'], $pm_notify['enable_pm_mail']['pm_send_notifications'],
array( array(
@ -1091,29 +1128,37 @@ function communityprefs_form(&$form_state) {
'#type' => 'textarea', '#type' => 'textarea',
'#title' => t('Signature'), '#title' => t('Signature'),
'#description' => t('Your signature will be publicly displayed at the end of your comments.'), '#description' => t('Your signature will be publicly displayed at the end of your comments.'),
'#default_value' => $user->signature '#default_value' => $account->signature
); );
// Prevent a "validation error" message when the user attempts to save with a default value they // Prevent a "validation error" message when the user attempts to save with a default value they
// do not have access to. // do not have access to.
if (!filter_access($user->signature_format) && empty($_POST)) { if (!filter_access($account->signature_format) && empty($_POST)) {
drupal_set_message(t("The signature input format has been set to a format you don't have access to. It will be changed to a format you have access to when you save this page.")); drupal_set_message(t("The signature input format has been set to a format you don't have access to. It will be changed to a format you have access to when you save this page."));
$edit['signature_format'] = FILTER_FORMAT_DEFAULT; $edit['signature_format'] = FILTER_FORMAT_DEFAULT;
} }
$form['forums']['signature_format'] = filter_form($user->signature_format, NULL, array('signature_format')); $form['forums']['signature_format'] = filter_form($account->signature_format, NULL, array('signature_format'));
} }
$form['separator_bottom'] = array(
'#value' => '<div class="separator buttons"></div>',
'#weight' => 999,
);
// Form control // Form control
$form['prefs']['form control tabs prefix'] = array( $form['form control tabs prefix'] = array(
'#value' => '<ul class="form-control tab-list">' '#value' => '<ul class="form-control tab-list">'
); );
$form['prefs']['submit'] = array( $form['submit'] = array(
'#prefix' => '<li class="first tab">', '#prefix' => '<li class="first tab">',
'#type' => 'submit', '#type' => 'submit',
'#value' => t('Save changes'), '#value' => t('Save changes'),
'#suffix' => '</li>' '#suffix' => '</li>'
); );
$form['prefs']['form control tabs'] = array( $form['form control tabs'] = array(
'#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li></ul>' '#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>'
);
$form['form control tabs suffix'] = array(
'#value' => '</ul>'
); );
return $form; return $form;
@ -1123,12 +1168,25 @@ function communityprefs_form(&$form_state) {
* Handle post-validation submission of community preferences form. * Handle post-validation submission of community preferences form.
*/ */
function communityprefs_form_submit($form, &$form_state) { function communityprefs_form_submit($form, &$form_state) {
require_boinc('db');
global $user; global $user;
$account = user_load($user->uid);
$boinc_user = lookup_user_id($account->boincuser_id);
$edit= $form_state['values']; $edit= $form_state['values'];
// Display name
if ($edit['boincuser_name'] != $boinc_user->name) {
$boincuser_name = $edit['boincuser_name'];
$result = $boinc_user->update(
"name='{$boincuser_name}'"
);
}
// Private message settings
pm_email_notify_user('submit', $edit, $user); pm_email_notify_user('submit', $edit, $user);
// All other settings
user_save($user, array( user_save($user, array(
'signature' => $edit['signature'], 'signature' => $edit['signature'],
'signature_format' => $edit['signature_format'], 'signature_format' => $edit['signature_format'],
'timezone' => $edit['timezone'],
'friend_notification' => $edit['friend_notification'], 'friend_notification' => $edit['friend_notification'],
'comments_per_page' => $edit['comments_per_page'] 'comments_per_page' => $edit['comments_per_page']
)); ));
@ -1185,6 +1243,10 @@ function boincwork_privacyprefs_form(&$form_state) {
'#default_value' => $default['privacy']['show_hosts'] '#default_value' => $default['privacy']['show_hosts']
); );
$form['prefs']['separator_bottom'] = array(
'#value' => '<div class="separator buttons"></div>'
);
// Form control // Form control
$form['prefs']['form control tabs prefix'] = array( $form['prefs']['form control tabs prefix'] = array(
'#value' => '<ul class="form-control tab-list">' '#value' => '<ul class="form-control tab-list">'
@ -1196,7 +1258,10 @@ function boincwork_privacyprefs_form(&$form_state) {
'#suffix' => '</li>' '#suffix' => '</li>'
); );
$form['prefs']['form control tabs'] = array( $form['prefs']['form control tabs'] = array(
'#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li></ul>' '#value' => '<li class="tab">' . l(t('Cancel'), $_GET['q']) . '</li>'
);
$form['prefs']['form control tabs suffix'] = array(
'#value' => '</ul>'
); );
return $form; return $form;