mirror of https://github.com/BOINC/boinc.git
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:
parent
2f44572dbb
commit
eb5a2e0c5d
|
@ -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');
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue