aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorFriendika <info@friendika.com>2011-06-27 03:03:58 -0700
committerFriendika <info@friendika.com>2011-06-27 03:03:58 -0700
commit06a4c0f703d64cae1e72c2901742e3c101623a7b (patch)
treecfc3fa108c6a8ea470f216ff3e5fc15c22b86b96 /include
parentc410c9013c062a9a4fce1f887572a1b1c951afbe (diff)
downloadvolse-hubzilla-06a4c0f703d64cae1e72c2901742e3c101623a7b.tar.gz
volse-hubzilla-06a4c0f703d64cae1e72c2901742e3c101623a7b.tar.bz2
volse-hubzilla-06a4c0f703d64cae1e72c2901742e3c101623a7b.zip
ignore current contact on friend suggestion picker
Diffstat (limited to 'include')
-rw-r--r--include/acl_selectors.php19
1 files changed, 15 insertions, 4 deletions
diff --git a/include/acl_selectors.php b/include/acl_selectors.php
index c19a0f5d3..c3e26082e 100644
--- a/include/acl_selectors.php
+++ b/include/acl_selectors.php
@@ -48,14 +48,22 @@ function contact_selector($selname, $selclass, $preselected = false, $options) {
$mutual = false;
$networks = null;
$single = false;
+ $exclude = false;
+ $size = 4;
+
+ if(is_array($options)) {
+ if(x($options,'size'))
+ $size = $options['size'];
- if($is_array($options)) {
if(x($options,'mutual_friends'))
$mutual = true;
if(x($options,'single'))
$single = true;
if(x($options,'multiple'))
$single = false;
+ if(x($options,'exclude'))
+ $exclude = $options['exclude'];
+
if(x($options,'networks')) {
switch($options['networks']) {
case 'DFRN_ONLY':
@@ -79,7 +87,7 @@ function contact_selector($selname, $selclass, $preselected = false, $options) {
}
}
- $x = array('options' => $options, 'single' => $single, 'mutual' => $mutual, 'networks' => $networks);
+ $x = array('options' => $options, 'size' => $size, 'single' => $single, 'mutual' => $mutual, 'exclude' => $exclude, 'networks' => $networks);
call_hooks('contact_select_options', $x);
@@ -91,6 +99,9 @@ function contact_selector($selname, $selclass, $preselected = false, $options) {
$sql_extra .= sprintf(" AND `rel` = %d ", intval(REL_BUD));
}
+ if(intval($x['exclude']))
+ $sql_extra .= sprintf(" AND `id` != %d ", intval($x['exclude']));
+
if(is_array($x['networks']) && count($x['networks'])) {
for($y = 0; $y < count($x['networks']) ; $y ++)
$x['networks'][$y] = "'" . dbesc($x['networks'][$y]) . "'";
@@ -99,9 +110,9 @@ function contact_selector($selname, $selclass, $preselected = false, $options) {
}
if($x['single'])
- $o .= "<select name=\"$selname\" id=\"$selclass\" class=\"$selclass\" size=\"$size\" >\r\n";
+ $o .= "<select name=\"$selname\" id=\"$selclass\" class=\"$selclass\" size=\"" . $x['size'] . "\" >\r\n";
else
- $o .= "<select name=\"{$selname}[]\" id=\"$selclass\" class=\"$selclass\" multiple=\"multiple\" size=\"$size\" >\r\n";
+ $o .= "<select name=\"{$selname}[]\" id=\"$selclass\" class=\"$selclass\" multiple=\"multiple\" size=\"" . $x['size'] . "$\" >\r\n";
$r = q("SELECT `id`, `name`, `url`, `network` FROM `contact`
WHERE `uid` = %d AND `self` = 0 AND `blocked` = 0 AND `pending` = 0 AND `notify` != ''