]> git.mxchange.org Git - friendica.git/commitdiff
ignore current contact on friend suggestion picker
authorFriendika <info@friendika.com>
Mon, 27 Jun 2011 10:03:58 +0000 (03:03 -0700)
committerFriendika <info@friendika.com>
Mon, 27 Jun 2011 10:03:58 +0000 (03:03 -0700)
include/acl_selectors.php
mod/fsuggest.php

index c19a0f5d3fb720c8f7dbb22b11e73acdd13153b6..c3e26082e3eb498f1c1a88d0fbeef724a1c86398 100644 (file)
@@ -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` != ''
index 29fb79cfb1394a45f2061029cd4ffa9bdbb8b770..dc95fb8e16bd67f4ff1559a036068aa824757bbd 100644 (file)
@@ -103,8 +103,8 @@ function fsuggest_content(&$a) {
 
        $o .= '<form action="fsuggest/' . $contact_id . '" method="post" >';
 
-       // TODO: selector should have an option to ignore the recipient
-       $o .= contact_select('suggest','suggest-select', $preselect, 4, true);
+       $o .= contact_selector('suggest','suggest-select', false, 
+               array('size' => 4, 'exclude' => $contact_id, 'networks' => 'DFRN_ONLY', 'single' => true));
 
 
        $o .= '<input type="submit" name="submit" value="' . t('Submit') . '" />';