X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=mod%2Fcommon.php;h=5a40663f9eb6445e48f44d5c4e82ac08639e9dc9;hb=8bdc906013461464b475c4f10918adff8730dea6;hp=852388c1493125bdcc28fafcd6db6229322d0c14;hpb=3d9a9614e232a3ff207803be1092b1d42bcadde6;p=friendica.git
diff --git a/mod/common.php b/mod/common.php
index 852388c149..5a40663f9e 100644
--- a/mod/common.php
+++ b/mod/common.php
@@ -1,61 +1,154 @@
argv[1];
+ $uid = intval($a->argv[2]);
+ $cid = intval($a->argv[3]);
+ $zcid = 0;
+
+ if (! local_user()) {
notice( t('Permission denied.') . EOL);
return;
}
- if($a->argc > 1)
- $cid = intval($a->argv[1]);
- if(! $cid)
+ if ($cmd !== 'loc' && $cmd != 'rem') {
+ return;
+ }
+
+ if (! $uid) {
return;
+ }
- $c = q("select name, url, photo from contact where id = %d and uid = %d limit 1",
- intval($cid),
- intval(local_user())
- );
+ if ($cmd === 'loc' && $cid) {
+ $c = q("SELECT `name`, `url`, `photo` FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
+ intval($cid),
+ intval($uid)
+ );
+ /// @TODO Handle $c with dbm::is_result()
+ $a->page['aside'] = "";
+ profile_load($a, "", 0, get_contact_details_by_url($c[0]["url"]));
+ } else {
+ $c = q("SELECT `name`, `url`, `photo` FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
+ intval($uid)
+ );
+ /// @TODO Handle $c with dbm::is_result()
- $a->page['aside'] .= '
'
- . '
' . $c[0]['name'] . '
'
- . '
'
- . '
'
- . '
';
-
+ $vcard_widget .= replace_macros(get_markup_template("vcard-widget.tpl"),array(
+ '$name' => htmlentities($c[0]['name']),
+ '$photo' => $c[0]['photo'],
+ 'url' => 'contacts/' . $cid
+ ));
- if(! count($c))
+ if (! x($a->page,'aside')) {
+ $a->page['aside'] = '';
+ }
+ $a->page['aside'] .= $vcard_widget;
+ }
+
+ if (! dbm::is_result($c)) {
return;
+ }
- $o .= '' . t('Common Friends') . '
';
+ if(! $cid) {
+ if(get_my_url()) {
+ $r = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d LIMIT 1",
+ dbesc(normalise_link(get_my_url())),
+ intval($profile_uid)
+ );
+ if (dbm::is_result($r))
+ $cid = $r[0]['id'];
+ else {
+ $r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
+ dbesc(normalise_link(get_my_url()))
+ );
+ if (dbm::is_result($r))
+ $zcid = $r[0]['id'];
+ }
+ }
+ }
-// $o .= '' . sprintf( t('You and %s'),$c[0]['name']) . '
';
+ if ($cid == 0 && $zcid == 0) {
+ return;
+ }
+ if ($cid) {
+ $t = count_common_friends($uid, $cid);
+ } else {
+ $t = count_common_friends_zcid($uid, $zcid);
+ }
- $r = common_friends(local_user(),$cid);
+ if (count($t)) {
+ $a->set_pager_total($t);
+ } else {
+ notice( t('No contacts in common.') . EOL);
+ return $o;
+ }
+
+
+ if ($cid) {
+ $r = common_friends($uid, $cid, $a->pager['start'], $a->pager['itemspage']);
+ } else {
+ $r = common_friends_zcid($uid, $zcid, $a->pager['start'], $a->pager['itemspage']);
+ }
- if(! count($r)) {
- $o .= t('No friends in common.');
+
+ if (! dbm::is_result($r)) {
return $o;
}
- $tpl = get_markup_template('common_friends.tpl');
+ $id = 0;
- foreach($r as $rr) {
-
- $o .= replace_macros($tpl,array(
- '$url' => $rr['url'],
- '$name' => $rr['name'],
- '$photo' => $rr['photo'],
- '$tags' => ''
- ));
+ foreach ($r as $rr) {
+
+ //get further details of the contact
+ $contact_details = get_contact_details_by_url($rr['url'], $uid);
+
+ // $rr['id'] is needed to use contact_photo_menu()
+ /// @TODO Adding '/" here avoids E_NOTICE on missing constants
+ $rr['id'] = $rr['cid'];
+
+ $photo_menu = '';
+ $photo_menu = contact_photo_menu($rr);
+
+ $entry = array(
+ 'url' => $rr['url'],
+ 'itemurl' => (($contact_details['addr'] != "") ? $contact_details['addr'] : $rr['url']),
+ 'name' => $contact_details['name'],
+ 'thumb' => proxy_url($contact_details['thumb'], false, PROXY_SIZE_THUMB),
+ 'img_hover' => htmlentities($contact_details['name']),
+ 'details' => $contact_details['location'],
+ 'tags' => $contact_details['keywords'],
+ 'about' => $contact_details['about'],
+ 'account_type' => account_type($contact_details),
+ 'network' => network_to_name($contact_details['network'], $contact_details['url']),
+ 'photo_menu' => $photo_menu,
+ 'id' => ++$id,
+ );
+ $entries[] = $entry;
}
- $o .= cleardiv();
-// $o .= paginate($a);
+ if ($cmd === 'loc' && $cid && $uid == local_user()) {
+ $tab_str = contacts_tab($a, $cid, 4);
+ } else {
+ $title = t('Common Friends');
+ }
+
+ $tpl = get_markup_template('viewcontact_template.tpl');
+
+ $o .= replace_macros($tpl,array(
+ '$title' => $title,
+ '$tab_str' => $tab_str,
+ '$contacts' => $entries,
+ '$paginate' => paginate($a),
+ ));
+
return $o;
}