web: theme the fluksonians block into a table and locate it under the chart
This commit is contained in:
parent
862466ad2c
commit
f91fd01bac
1 changed files with 75 additions and 42 deletions
|
@ -38,6 +38,16 @@ define('ORANGE', 'F37E2B');
|
||||||
define('YELLOW', 'FBEB0D');
|
define('YELLOW', 'FBEB0D');
|
||||||
define('PURPLE', 'A052A0');
|
define('PURPLE', 'A052A0');
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implementation of hook_init().
|
||||||
|
*/
|
||||||
|
function logger_init() {
|
||||||
|
global $user;
|
||||||
|
// Workaround for collapse.js not being loaded within _logger_fluksonians_form when block caching is on.
|
||||||
|
if ($user->uid > 0) drupal_add_js('misc/collapse.js');
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of hook_perm().
|
* Implementation of hook_perm().
|
||||||
*/
|
*/
|
||||||
|
@ -387,7 +397,7 @@ function _logger_add($uid) {
|
||||||
user_relationships_request_relationship($user->uid, $uid, $rtid, TRUE);
|
user_relationships_request_relationship($user->uid, $uid, $rtid, TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_logger_cache_clear('subscriptions');
|
_logger_cache_clear('fluksonians');
|
||||||
}
|
}
|
||||||
$destination = drupal_get_destination();
|
$destination = drupal_get_destination();
|
||||||
drupal_goto($destination);
|
drupal_goto($destination);
|
||||||
|
@ -407,7 +417,7 @@ function _logger_remove($rid) {
|
||||||
watchdog('relationships', 'attempt to delete rid %rid by non-authorized user %uid', array('%rid' => $rid, '%uid' => $user->uid), WATCHDOG_ERROR);
|
watchdog('relationships', 'attempt to delete rid %rid by non-authorized user %uid', array('%rid' => $rid, '%uid' => $user->uid), WATCHDOG_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
_logger_cache_clear('subscriptions');
|
_logger_cache_clear('fluksonians');
|
||||||
$destination = drupal_get_destination();
|
$destination = drupal_get_destination();
|
||||||
drupal_goto($destination);
|
drupal_goto($destination);
|
||||||
}
|
}
|
||||||
|
@ -492,19 +502,12 @@ function logger_block($op = 'list', $delta = 0, $edit = array()) {
|
||||||
|
|
||||||
switch ($op) {
|
switch ($op) {
|
||||||
case 'list':
|
case 'list':
|
||||||
$blocks['subscriptions']['info'] = t('Subscriptions');
|
|
||||||
$blocks['subscriptions']['status'] = TRUE;
|
|
||||||
$blocks['subscriptions']['region'] = 'right';
|
|
||||||
$blocks['subscriptions']['weight'] = 0;
|
|
||||||
$blocks['subscriptions']['pages'] = '<front>\nlogger/\nlogger/*';
|
|
||||||
$blocks['subscriptions']['cache'] = BLOCK_CACHE_PER_USER;
|
|
||||||
|
|
||||||
$blocks['fluksonians']['info'] = t('Fluksonians');
|
$blocks['fluksonians']['info'] = t('Fluksonians');
|
||||||
$blocks['fluksonians']['status'] = TRUE;
|
$blocks['fluksonians']['status'] = TRUE;
|
||||||
$blocks['fluksonians']['region'] = 'right';
|
$blocks['fluksonians']['region'] = 'content';
|
||||||
$blocks['fluksonians']['weight'] = 1;
|
$blocks['fluksonians']['weight'] = 1;
|
||||||
$blocks['fluksonians']['pages'] = '<front>\nlogger/\nlogger/*';
|
$blocks['fluksonians']['pages'] = '<front>\nlogger/\nlogger/*';
|
||||||
$blocks['fluksonians']['cache'] = BLOCK_CACHE_GLOBAL;
|
$blocks['fluksonians']['cache'] = BLOCK_CACHE_PER_USER;
|
||||||
|
|
||||||
$blocks['unit']['info'] = t('Unit');
|
$blocks['unit']['info'] = t('Unit');
|
||||||
$blocks['unit']['status'] = TRUE;
|
$blocks['unit']['status'] = TRUE;
|
||||||
|
@ -526,37 +529,8 @@ function logger_block($op = 'list', $delta = 0, $edit = array()) {
|
||||||
//pass along our current destination in the query string so that logger_add and logger_remove can return after processing their task
|
//pass along our current destination in the query string so that logger_add and logger_remove can return after processing their task
|
||||||
$destination = drupal_get_destination();
|
$destination = drupal_get_destination();
|
||||||
|
|
||||||
if ($delta == 'subscriptions' && user_access('logger')) {
|
if ($delta == 'fluksonians' && user_access('logger')) {
|
||||||
$result = db_query("SELECT u.uid, u.name, ur.rid
|
$block['content'] = drupal_get_form('_logger_fluksonians_form');
|
||||||
FROM ({users} u
|
|
||||||
INNER JOIN {user_relationships} ur ON u.uid = ur.requestee_id)
|
|
||||||
INNER JOIN {user_relationship_types} urt ON ur.rtid = urt.rtid
|
|
||||||
WHERE ur.requester_id = %d AND urt.name = '%s'
|
|
||||||
ORDER BY ur.rid", $user->uid, 'subscription');
|
|
||||||
|
|
||||||
$items = array();
|
|
||||||
while ($subscription = db_fetch_object($result)) {
|
|
||||||
$items[] = l('[x]', 'logger/remove/'. $subscription->rid, array('attributes' => array('title' => "unsubscribe from ". $subscription->name ."'s stream"), 'query' => $destination, 'alias' => TRUE)) .' '. l($subscription->name, 'user/'. $subscription->uid, array('alias' => FALSE));
|
|
||||||
}
|
|
||||||
$block['subject'] = t('Subscriptions');
|
|
||||||
$block['content'] = theme('logger_item_list', $items);
|
|
||||||
}
|
|
||||||
|
|
||||||
elseif ($delta == 'fluksonians' && user_access('logger')) {
|
|
||||||
// list all users having the fluksionian role for now
|
|
||||||
// to be replaced by a real buddylist later on
|
|
||||||
$result = db_query("SELECT u.uid, u.name
|
|
||||||
FROM ({users} u
|
|
||||||
INNER JOIN {users_roles} ur ON u.uid = ur.uid)
|
|
||||||
INNER JOIN {role} r ON ur.rid = r.rid
|
|
||||||
WHERE r.name = '%s'
|
|
||||||
ORDER BY u.name", 'fluksonian', $user->uid);
|
|
||||||
$items = array();
|
|
||||||
while ($fluksonian = db_fetch_object($result)) {
|
|
||||||
$items[] = l('[+]', 'logger/add/'. $fluksonian->uid, array('attributes' => array('title' => "subscribe to ". $fluksonian->name ."'s stream"), 'query' => $destination, 'alias' => TRUE)) .' '. l($fluksonian->name, 'user/'. $fluksonian->uid, array('alias' => FALSE));
|
|
||||||
}
|
|
||||||
$block['subject'] = t('Fluksonians');
|
|
||||||
$block['content'] = theme('logger_item_list', $items);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
elseif ($delta == 'unit' && user_access('logger')) {
|
elseif ($delta == 'unit' && user_access('logger')) {
|
||||||
|
@ -614,6 +588,65 @@ function theme_logger_item_list($items, $title = NULL) {
|
||||||
return $output;
|
return $output;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates the fluksonians block form.
|
||||||
|
*/
|
||||||
|
function _logger_fluksonians_form() {
|
||||||
|
global $user;
|
||||||
|
$fluksonians = db_query("SELECT u.uid, u.name
|
||||||
|
FROM ({users} u
|
||||||
|
INNER JOIN {users_roles} ur ON u.uid = ur.uid)
|
||||||
|
INNER JOIN {role} r ON ur.rid = r.rid
|
||||||
|
WHERE r.name = '%s' AND NOT u.uid = %d
|
||||||
|
ORDER BY u.name", 'fluksonian', $user->uid);
|
||||||
|
|
||||||
|
$subscriptions = db_query("SELECT u.uid, u.name, ur.rid
|
||||||
|
FROM ({users} u
|
||||||
|
INNER JOIN {user_relationships} ur ON u.uid = ur.requestee_id)
|
||||||
|
INNER JOIN {user_relationship_types} urt ON ur.rtid = urt.rtid
|
||||||
|
WHERE ur.requester_id = %d AND urt.name = '%s'
|
||||||
|
ORDER BY u.name", $user->uid, 'subscription');
|
||||||
|
|
||||||
|
$i = 0;
|
||||||
|
$rows = array();
|
||||||
|
$row = array();
|
||||||
|
$subscription = db_fetch_object($subscriptions);
|
||||||
|
|
||||||
|
while ($fluksonian = db_fetch_object($fluksonians)) {
|
||||||
|
if ($i > 4) {
|
||||||
|
$rows[] = $row;
|
||||||
|
$row = array();
|
||||||
|
$i = 0;
|
||||||
|
}
|
||||||
|
if ($fluksonian->uid == $subscription->uid) {
|
||||||
|
$row[] = l('[x]', 'logger/remove/'. $subscription->rid, array('attributes' => array('title' => "unsubscribe from ". $subscription->name ."'s stream"), 'query' => $destination, 'alias' => TRUE)) .' '. l($subscription->name, 'user/'. $subscription->uid, array('alias' => FALSE));
|
||||||
|
$subscription = db_fetch_object($subscriptions);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$row[] = l('[+]', 'logger/add/'. $fluksonian->uid, array('attributes' => array('title' => "subscribe to ". $fluksonian->name ."'s stream"), 'query' => $destination, 'ali
|
||||||
|
as' => TRUE)) .' '. l($fluksonian->name, 'user/'. $fluksonian->uid, array('alias' => FALSE));
|
||||||
|
}
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
$rows[] = $row;
|
||||||
|
|
||||||
|
$form['fluksonians'] = array(
|
||||||
|
'#type' => 'fieldset',
|
||||||
|
'#title' => t('Fluksonians'),
|
||||||
|
'#description' => t('Select the Fluksonians you wish to add to [+] or clear from [x] the chart.'),
|
||||||
|
'#collapsible' => TRUE,
|
||||||
|
'#collapsed' => TRUE,
|
||||||
|
);
|
||||||
|
$form['fluksonians']['list'] = array(
|
||||||
|
'#type' => 'item',
|
||||||
|
//'#title' => t('Title'),
|
||||||
|
'#value' => theme('table', array(), $rows),
|
||||||
|
);
|
||||||
|
|
||||||
|
return $form;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Access callback ensuring the user account tabs are visible only to the
|
* Access callback ensuring the user account tabs are visible only to the
|
||||||
* owner.
|
* owner.
|
||||||
|
|
Loading…
Reference in a new issue