web: allow users to associate a Fluksometer with their account

This commit is contained in:
Bart Van Der Meerssche 2010-03-08 22:06:23 +00:00
parent 3d8636611e
commit e6743f610c
2 changed files with 71 additions and 5 deletions

View File

@ -22,9 +22,63 @@
// //
/** /**
* Callback function for the user/x/devices page * Callback function for the user/x/devices page's drupal_get_form
*
* @ingroup forms
* @see _logger_account_devices_validate
* @see _logger_account_devices_submit
* @see theme_logger_account_devices
*/ */
function _logger_account_devices() { function _logger_account_devices() {
$form['serial'] = array(
'#type' => 'textfield',
'#size' => 10,
'#maxlength' => 10,
'#required' => TRUE,
);
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Add device'),
);
$form['#validate'][] = '_logger_account_devices_validate';
$form['#submit'][] = '_logger_account_devices_submit';
$form['#theme'] = 'logger_account_devices';
return $form;
}
function _logger_account_devices_validate($form, &$form_state) {
$serial = $form_state['values']['serial'];
if (strlen($serial) == 10 && is_numeric(substr($serial, 2, 9))) {
if (db_result(db_query("SELECT COUNT(*) FROM {logger_devices} WHERE serial = %d AND uid = %d", substr($serial, 2, 9), 0)) == 0) {
form_set_error('serial', t('Please specify a valid serial number.'));
}
}
else {
form_set_error('serial', t('Please specify a proper 10-character serial number.'));
}
}
function _logger_account_devices_submit($form, &$form_state) {
global $user;
$serial = substr($form_state['values']['serial'], 2, 9);
$device = db_result(db_query("SELECT device FROM {logger_devices} WHERE serial = %d", $serial));
db_query("UPDATE {logger_devices} SET uid = %d WHERE serial = %d", $user->uid, $serial);
db_query("UPDATE {logger_meters} SET uid = %d WHERE device = '%s'", $user->uid, $device);
drupal_set_message(t("The device is now associated with your account."));
}
/**
* Theme function for displaying the devices form
*
* @ingroup themeable
*
* @param $form
* The device form array.
*/
function theme_logger_account_devices($form) {
global $user; global $user;
$rows = array(); $rows = array();
@ -55,11 +109,18 @@ function _logger_account_devices() {
$rows[] = $row; $rows[] = $row;
} }
return theme('logger_account_devices_list', $rows); $rows[] = array(drupal_render($form['serial']), array('data' => drupal_render($form['submit']), 'colspan' => 3));
$output = drupal_render($form);
$output .= theme('logger_account_devices_list', $rows);
return $output;
} }
/** /**
* Theme function for displaying the user's devices * Theme function for displaying the list of devices
*
* @ingroup themeable
* *
* @param $items * @param $items
* An array of table rows. * An array of table rows.

View File

@ -178,7 +178,8 @@ function logger_menu() {
); );
$items['user/%user_uid_optional/devices'] = array( $items['user/%user_uid_optional/devices'] = array(
'title' => 'Devices', 'title' => 'Devices',
'page callback' => '_logger_account_devices', 'page callback' => 'drupal_get_form',
'page arguments' => array('_logger_account_devices'),
'access callback' => '_logger_account_access', 'access callback' => '_logger_account_access',
'access arguments' => array('logger', 1), 'access arguments' => array('logger', 1),
'type' => MENU_LOCAL_TASK, 'type' => MENU_LOCAL_TASK,
@ -487,6 +488,10 @@ function logger_theme() {
'logger_item_list' => array( 'logger_item_list' => array(
'arguments' => array('items' => NULL, 'title' => NULL), 'arguments' => array('items' => NULL, 'title' => NULL),
), ),
'logger_account_devices' => array(
'arguments' => array('form' => NULL),
'file' => 'logger.admin.inc',
),
'logger_account_devices_list' => array( 'logger_account_devices_list' => array(
'arguments' => array('items' => NULL), 'arguments' => array('items' => NULL),
'file' => 'logger.admin.inc', 'file' => 'logger.admin.inc',