[drupal] add a sensor block for pro users
This commit is contained in:
parent
415bcdda48
commit
c8414867bd
1 changed files with 74 additions and 0 deletions
|
@ -643,6 +643,13 @@ function logger_block($op = 'list', $delta = 0, $edit = array()) {
|
||||||
$blocks['fluksonians']['pages'] = '<front>\nlogger/\nlogger/*';
|
$blocks['fluksonians']['pages'] = '<front>\nlogger/\nlogger/*';
|
||||||
$blocks['fluksonians']['cache'] = BLOCK_NO_CACHE;
|
$blocks['fluksonians']['cache'] = BLOCK_NO_CACHE;
|
||||||
|
|
||||||
|
$blocks['sensors']['info'] = t('Sensors');
|
||||||
|
$blocks['sensors']['status'] = TRUE;
|
||||||
|
$blocks['sensors']['region'] = 'content';
|
||||||
|
$blocks['sensors']['weight'] = 1;
|
||||||
|
$blocks['sensors']['pages'] = '<front>\nlogger/\nlogger/*';
|
||||||
|
$blocks['sensors']['cache'] = BLOCK_NO_CACHE;
|
||||||
|
|
||||||
$blocks['unit']['info'] = t('Unit');
|
$blocks['unit']['info'] = t('Unit');
|
||||||
$blocks['unit']['status'] = TRUE;
|
$blocks['unit']['status'] = TRUE;
|
||||||
$blocks['unit']['region'] = 'right';
|
$blocks['unit']['region'] = 'right';
|
||||||
|
@ -667,6 +674,10 @@ function logger_block($op = 'list', $delta = 0, $edit = array()) {
|
||||||
$block['content'] = drupal_get_form('_logger_fluksonians_form');
|
$block['content'] = drupal_get_form('_logger_fluksonians_form');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
elseif ($delta == 'sensors' && user_access('logger')) {
|
||||||
|
$block['content'] = drupal_get_form('_logger_sensors_form');
|
||||||
|
}
|
||||||
|
|
||||||
elseif ($delta == 'unit' && user_access('logger') && strrpos(' ' . $_GET['q'] . '/electricity', 'logger/electricity')) {
|
elseif ($delta == 'unit' && user_access('logger') && strrpos(' ' . $_GET['q'] . '/electricity', 'logger/electricity')) {
|
||||||
$unit = db_result(db_query("SELECT electricity_unit
|
$unit = db_result(db_query("SELECT electricity_unit
|
||||||
FROM {logger_users}
|
FROM {logger_users}
|
||||||
|
@ -807,6 +818,69 @@ as' => TRUE)) .' '. l($fluksonian->name, 'user/'. $fluksonian->uid, array('alias
|
||||||
return $form;
|
return $form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates the sensors block form.
|
||||||
|
*/
|
||||||
|
function _logger_sensors_form() {
|
||||||
|
function unix_to_userlocaltime($unix) {
|
||||||
|
global $user;
|
||||||
|
$unix_local = gmdate('r', $unix + $user->timezone);
|
||||||
|
return substr($unix_local, 0, strlen($unix_local) - 6);
|
||||||
|
}
|
||||||
|
|
||||||
|
global $user;
|
||||||
|
$destination = drupal_get_destination();
|
||||||
|
|
||||||
|
if (strrpos(' ' . $_GET['q'] . '/electricity', 'logger/electricity')) {
|
||||||
|
$type = 'electricity';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$type = 'water';
|
||||||
|
}
|
||||||
|
|
||||||
|
$sensors = db_query("SELECT meter, access, function, value, chart
|
||||||
|
FROM {logger_meters}
|
||||||
|
WHERE uid = %d and type = '%s'", $user->uid, $type);
|
||||||
|
|
||||||
|
$i = 0;
|
||||||
|
$rows = array();
|
||||||
|
$row = array();
|
||||||
|
|
||||||
|
while ($sensor = db_fetch_object($sensors)) {
|
||||||
|
if ($sensor->chart) {
|
||||||
|
$row[] = l('[x]', 'logger/sensor/remove/' . $sensor->meter, array('attributes' => array('title' => "remove ". $sensor->function . " from the chart"), 'query' => $destination, 'alias' => TRUE));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$row[] = l('[+]', 'logger/sensor/add/' . $sensor->meter, array('attributes' => array('title' => "add ". $sensor->function . " to the chart"), 'query' => $destination, 'alias' => TRUE));
|
||||||
|
}
|
||||||
|
|
||||||
|
$row[] = $sensor->function;
|
||||||
|
$row[] = $sensor->meter;
|
||||||
|
$row[] = unix_to_userlocaltime($sensor->access);
|
||||||
|
$row[] = $sensor->value;
|
||||||
|
|
||||||
|
$rows[] = $row;
|
||||||
|
$row = array();
|
||||||
|
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
$form['sensors'] = array(
|
||||||
|
'#type' => 'fieldset',
|
||||||
|
'#title' => t('Sensors'),
|
||||||
|
'#description' => t('Select the sensors you wish to add to [+] or remove from [x] the chart.'),
|
||||||
|
'#collapsible' => TRUE,
|
||||||
|
'#collapsed' => TRUE,
|
||||||
|
);
|
||||||
|
$form['sensors']['list'] = array(
|
||||||
|
'#type' => 'item',
|
||||||
|
//'#title' => t('Title'),
|
||||||
|
'#value' => theme('table', array(t('Chart'), t('Function'), t('Sensor'), t('Last Reporting'), t('Counter')), $rows),
|
||||||
|
);
|
||||||
|
|
||||||
|
return $form;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of hook_form_alter().
|
* Implementation of hook_form_alter().
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue