activity widget - like the forum widget but represents unseen activity by author. Still experimental until it can be tested with diaspora xchans, which may require additional urlencoding.
This commit is contained in:
@@ -321,6 +321,7 @@ class Channel extends \Zotlabs\Web\Controller {
|
|||||||
'$static' => $static,
|
'$static' => $static,
|
||||||
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
||||||
'$search' => '',
|
'$search' => '',
|
||||||
|
'$xchan' => '',
|
||||||
'$order' => '',
|
'$order' => '',
|
||||||
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
||||||
'$file' => '',
|
'$file' => '',
|
||||||
|
@@ -165,6 +165,7 @@ class Display extends \Zotlabs\Web\Controller {
|
|||||||
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
||||||
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
||||||
'$search' => '',
|
'$search' => '',
|
||||||
|
'$xchan' => '',
|
||||||
'$order' => '',
|
'$order' => '',
|
||||||
'$file' => '',
|
'$file' => '',
|
||||||
'$cats' => '',
|
'$cats' => '',
|
||||||
|
@@ -118,8 +118,8 @@ class Network extends \Zotlabs\Web\Controller {
|
|||||||
$cmax = ((x($_GET,'cmax')) ? intval($_GET['cmax']) : 99);
|
$cmax = ((x($_GET,'cmax')) ? intval($_GET['cmax']) : 99);
|
||||||
$firehose = ((x($_GET,'fh')) ? intval($_GET['fh']) : 0);
|
$firehose = ((x($_GET,'fh')) ? intval($_GET['fh']) : 0);
|
||||||
$file = ((x($_GET,'file')) ? $_GET['file'] : '');
|
$file = ((x($_GET,'file')) ? $_GET['file'] : '');
|
||||||
|
$xchan = ((x($_GET,'xchan')) ? $_GET['xchan'] : '');
|
||||||
|
|
||||||
$deftag = '';
|
$deftag = '';
|
||||||
|
|
||||||
if(x($_GET,'search') || x($_GET,'file'))
|
if(x($_GET,'search') || x($_GET,'file'))
|
||||||
@@ -257,6 +257,26 @@ class Network extends \Zotlabs\Web\Controller {
|
|||||||
goaway(z_root() . '/network');
|
goaway(z_root() . '/network');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
elseif($xchan) {
|
||||||
|
$r = q("select * from xchan where xchan_hash = '%s'",
|
||||||
|
dbesc($xchan)
|
||||||
|
);
|
||||||
|
if($r) {
|
||||||
|
$sql_extra = " AND item.parent IN ( SELECT DISTINCT parent FROM item WHERE true $sql_options AND uid = " . intval(local_channel()) . " AND ( author_xchan = '" . dbesc($xchan) . "' or owner_xchan = '" . dbesc($xchan) . "' ) $item_normal ) ";
|
||||||
|
$title = replace_macros(get_markup_template("section_title.tpl"),array(
|
||||||
|
'$title' => '<a href="' . zid($r[0]['xchan_url']) . '" ><img src="' . zid($r[0]['xchan_photo_s']) . '" alt="' . urlencode($r[0]['xchan_name']) . '" /></a> <a href="' . zid($r[0]['xchan_url']) . '" >' . $r[0]['xchan_name'] . '</a>'
|
||||||
|
));
|
||||||
|
$o = $tabs;
|
||||||
|
$o .= $title;
|
||||||
|
$o .= $status_editor;
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
notice( t('Invalid channel.') . EOL);
|
||||||
|
goaway(z_root() . '/network');
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
if(x($category)) {
|
if(x($category)) {
|
||||||
$sql_extra .= protect_sprintf(term_query('item', $category, TERM_CATEGORY));
|
$sql_extra .= protect_sprintf(term_query('item', $category, TERM_CATEGORY));
|
||||||
@@ -302,6 +322,7 @@ class Network extends \Zotlabs\Web\Controller {
|
|||||||
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
||||||
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
||||||
'$search' => (($search) ? $search : ''),
|
'$search' => (($search) ? $search : ''),
|
||||||
|
'$xchan' => $xchan,
|
||||||
'$order' => $order,
|
'$order' => $order,
|
||||||
'$file' => $file,
|
'$file' => $file,
|
||||||
'$cats' => $category,
|
'$cats' => $category,
|
||||||
|
@@ -57,6 +57,7 @@ class Pubstream extends \Zotlabs\Web\Controller {
|
|||||||
'$static' => $static,
|
'$static' => $static,
|
||||||
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
||||||
'$search' => '',
|
'$search' => '',
|
||||||
|
'$xchan' => '',
|
||||||
'$order' => 'comment',
|
'$order' => 'comment',
|
||||||
'$file' => '',
|
'$file' => '',
|
||||||
'$cats' => '',
|
'$cats' => '',
|
||||||
|
@@ -130,6 +130,7 @@ class Search extends \Zotlabs\Web\Controller {
|
|||||||
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
'$list' => ((x($_REQUEST,'list')) ? intval($_REQUEST['list']) : 0),
|
||||||
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
'$page' => ((\App::$pager['page'] != 1) ? \App::$pager['page'] : 1),
|
||||||
'$search' => (($tag) ? urlencode('#') : '') . $search,
|
'$search' => (($tag) ? urlencode('#') : '') . $search,
|
||||||
|
'$xchan' => '',
|
||||||
'$order' => '',
|
'$order' => '',
|
||||||
'$file' => '',
|
'$file' => '',
|
||||||
'$cats' => '',
|
'$cats' => '',
|
||||||
|
@@ -277,8 +277,8 @@ class Channel {
|
|||||||
if($email_changed && \App::$config['system']['register_policy'] == REGISTER_VERIFY) {
|
if($email_changed && \App::$config['system']['register_policy'] == REGISTER_VERIFY) {
|
||||||
|
|
||||||
// FIXME - set to un-verified, blocked and redirect to logout
|
// FIXME - set to un-verified, blocked and redirect to logout
|
||||||
// Why? Are we verifying people or email addresses?
|
// Q: Why? Are we verifying people or email addresses?
|
||||||
|
// A: the policy is to verify email addresses
|
||||||
}
|
}
|
||||||
|
|
||||||
goaway(z_root() . '/settings' );
|
goaway(z_root() . '/settings' );
|
||||||
|
@@ -854,6 +854,11 @@ function tag_sort_length($a,$b) {
|
|||||||
return((mb_strlen($b) < mb_strlen($a)) ? (-1) : 1);
|
return((mb_strlen($b) < mb_strlen($a)) ? (-1) : 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function total_sort($a,$b) {
|
||||||
|
if($a['total'] == $b['total'])
|
||||||
|
return 0;
|
||||||
|
return(($b['total'] < $a['total']) ? 1 : (-1));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -1494,6 +1494,67 @@ function widget_forums($arr) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function widget_activity($arr) {
|
||||||
|
|
||||||
|
if(! local_channel())
|
||||||
|
return '';
|
||||||
|
|
||||||
|
$o = '';
|
||||||
|
|
||||||
|
if(is_array($arr) && array_key_exists('limit',$arr))
|
||||||
|
$limit = " limit " . intval($limit) . " ";
|
||||||
|
else
|
||||||
|
$limit = '';
|
||||||
|
|
||||||
|
$perms_sql = item_permissions_sql(local_channel()) . item_normal();
|
||||||
|
|
||||||
|
$r = q("select owner_xchan, author_xchan from item where item_unseen = 1 and uid = %d $perms_sql",
|
||||||
|
intval(local_channel())
|
||||||
|
);
|
||||||
|
|
||||||
|
$contributors = [];
|
||||||
|
$arr = [];
|
||||||
|
|
||||||
|
if($r) {
|
||||||
|
foreach($r as $rv) {
|
||||||
|
if(array_key_exists($rv['owner_xchan'],$contributors))
|
||||||
|
$contributors[$rv['owner_xchan']] ++;
|
||||||
|
else
|
||||||
|
$contributors[$rv['owner_xchan']] = 1;
|
||||||
|
if($rv['owner_xchan'] === $rv['author_xchan'])
|
||||||
|
continue;
|
||||||
|
if(array_key_exists($rv['author_xchan'],$contributors))
|
||||||
|
$contributors[$rv['author_xchan']] ++;
|
||||||
|
else
|
||||||
|
$contributors[$rv['author_xchan']] = 1;
|
||||||
|
}
|
||||||
|
foreach($contributors as $k => $v) {
|
||||||
|
$arr[] = [ 'author_xchan' => $k, 'total' => $v ];
|
||||||
|
}
|
||||||
|
usort($arr,'total_sort');
|
||||||
|
xchan_query($arr);
|
||||||
|
}
|
||||||
|
|
||||||
|
$x = [ 'entries' => $arr ];
|
||||||
|
call_hooks('activity_widget',$x);
|
||||||
|
$arr = $x['entries'];
|
||||||
|
|
||||||
|
if($arr) {
|
||||||
|
$o .= '<div class="widget">';
|
||||||
|
$o .= '<h3>' . t('Activity','widget') . '</h3><ul class="nav nav-pills nav-stacked">';
|
||||||
|
|
||||||
|
foreach($arr as $rv) {
|
||||||
|
$o .= '<li><a href="network?f=&xchan=' . urlencode($rv['author_xchan']) . '" ><span class="badge pull-right">' . ((intval($rv['total'])) ? intval($rv['total']) : '') . '</span><img src="' . $rv['author']['xchan_photo_s'] . '" style="width: 16px; height: 16px;" /> ' . $rv['author']['xchan_name'] . '</a></li>';
|
||||||
|
}
|
||||||
|
$o .= '</ul></div>';
|
||||||
|
}
|
||||||
|
return $o;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function widget_tasklist($arr) {
|
function widget_tasklist($arr) {
|
||||||
|
|
||||||
if (! local_channel())
|
if (! local_channel())
|
||||||
|
@@ -20,6 +20,7 @@
|
|||||||
var bParam_static = {{$static}};
|
var bParam_static = {{$static}};
|
||||||
|
|
||||||
var bParam_search = "{{$search}}";
|
var bParam_search = "{{$search}}";
|
||||||
|
var bParam_xchan = "{{$xchan}}";
|
||||||
var bParam_order = "{{$order}}";
|
var bParam_order = "{{$order}}";
|
||||||
var bParam_file = "{{$file}}";
|
var bParam_file = "{{$file}}";
|
||||||
var bParam_cats = "{{$cats}}";
|
var bParam_cats = "{{$cats}}";
|
||||||
@@ -47,6 +48,7 @@
|
|||||||
if(bParam_list != 0) bCmd = bCmd + "&list=" + bParam_list;
|
if(bParam_list != 0) bCmd = bCmd + "&list=" + bParam_list;
|
||||||
if(bParam_fh != 0) bCmd = bCmd + "&fh=" + bParam_fh;
|
if(bParam_fh != 0) bCmd = bCmd + "&fh=" + bParam_fh;
|
||||||
if(bParam_search != "") bCmd = bCmd + "&search=" + bParam_search;
|
if(bParam_search != "") bCmd = bCmd + "&search=" + bParam_search;
|
||||||
|
if(bParam_xchan != "") bCmd = bCmd + "&xchan=" + bParam_xchan;
|
||||||
if(bParam_order != "") bCmd = bCmd + "&order=" + bParam_order;
|
if(bParam_order != "") bCmd = bCmd + "&order=" + bParam_order;
|
||||||
if(bParam_file != "") bCmd = bCmd + "&file=" + bParam_file;
|
if(bParam_file != "") bCmd = bCmd + "&file=" + bParam_file;
|
||||||
if(bParam_cats != "") bCmd = bCmd + "&cat=" + bParam_cats;
|
if(bParam_cats != "") bCmd = bCmd + "&cat=" + bParam_cats;
|
||||||
|
Reference in New Issue
Block a user