diff options
-rw-r--r-- | include/nav.php | 15 | ||||
-rw-r--r-- | mod/intro.php | 99 | ||||
-rw-r--r-- | view/tpl/intros.tpl | 16 | ||||
-rw-r--r-- | view/tpl/intros_header.tpl | 1 | ||||
-rw-r--r-- | view/tpl/nav.tpl | 13 |
5 files changed, 113 insertions, 31 deletions
diff --git a/include/nav.php b/include/nav.php index 5008b6269..24449409b 100644 --- a/include/nav.php +++ b/include/nav.php @@ -119,14 +119,6 @@ EOT; $gdirpath = 'directory'; - if(strlen(get_config('system','singleuser'))) { - $gdir = dirname(get_config('system','directory_submit_url')); - if(strlen($gdir)) - $gdirpath = $gdir; - } - elseif(! get_config('system','no_community_page')) - $nav['community'] = array('community', t('Community'), "", t('Conversations on this site')); - $nav['directory'] = array($gdirpath, t('Directory'), "", t('People directory')); /** @@ -141,9 +133,8 @@ EOT; $nav['home'] = array('channel/' . $channel['channel_address'], t('Home'), "", t('Your posts and conversations')); - if($channel['channel_pageflags'] == PAGE_NORMAL) { - $nav['introductions'] = array('notifications/intros', t('Introductions'), "", t('Connection Requests')); - } + $nav['intros'] = array('intro', t('Introductions'), "", t('New Connections')); + $nav['notifications'] = array('notifications', t('Notifications'), "", t('Notifications')); $nav['notifications']['all']=array('notifications/system', t('See all notifications'), "", ""); @@ -212,7 +203,7 @@ function nav_set_selected($item){ 'network' => null, 'home' => null, 'profiles' => null, - 'introductions' => null, + 'intros' => null, 'notifications' => null, 'messages' => null, 'directory' => null, diff --git a/mod/intro.php b/mod/intro.php new file mode 100644 index 000000000..4b9d63629 --- /dev/null +++ b/mod/intro.php @@ -0,0 +1,99 @@ +<?php + +function intro_post(&$a) { + if(! local_user()) + return; + if(! intval($_REQUEST['contact_id'])) + return; + + $flags = 0; + if($_REQUEST['submit'] == t('Approve')) { + ; + } + elseif($_REQUEST['submit'] == t('Block')) { + $flags = ABOOK_FLAG_BLOCKED; + } + elseif($_REQUEST['submit'] == t('Ignore')) { + $flags = ABOOK_FLAG_IGNORED; + } + if(intval($_REQUEST['hidden'])) + $flags |= ABOOK_FLAG_HIDDEN; + + $r = q("update abook set abook_flags = %d where abook_channel = %d and abook_id = %d limit 1", + intval($flags), + intval(local_user()), + intval($_REQUEST['contact_id']) + ); + if($r) + info( t('Connection updated.') . EOL); + else + notice( t('Connection update failed.') . EOL); + +} + + + +function intro_content(&$a) { + + if( ! local_user()) { + notice( t('Permission denied.') . EOL); + return; + } + + + $o = replace_macros(get_markup_template('intros_header.tpl'),array( + '$title' => t('Introductions and Connection Requests') + )); + + $r = q("select count(abook_id) as total from abook where abook_channel = %d and (abook_flags & %d) and not (abook_flags & %d) ", + intval(local_user()), + intval(ABOOK_FLAG_PENDING), + intval(ABOOK_FLAG_SELF) + ); + if($r) { + $a->set_pager_total($r[0]['total']); + if(! intval($r[0]['total'])) { + notice( t('No pending introductions.') . EOL); + return; + } + } + else { + notice( t('System error. Please try again later.') . EOL); + return; + } + + $r = q("select abook.*, xchan.* from abook left join xchan on abook_xchan = xchan_hash where abook_channel = %d and (abook_flags & %d) and not (abook_flags & %d) LIMIT %d, %d", + intval(local_user()), + intval(ABOOK_FLAG_PENDING), + intval(ABOOK_FLAG_SELF), + intval($a->pager['start']), + intval($a->pager['itemspage']) + ); + + if($r) { + + $tpl = get_markup_template("intros.tpl"); + + foreach($r as $rr) { + $o .= replace_macros($tpl,array( + '$uid' => local_user(), + + '$contact_id' => $rr['abook_id'], + '$photo' => ((x($rr,'xchan_photo_l')) ? $rr['xchan_photo_l'] : "images/person-175.jpg"), + '$fullname' => $rr['xchan_name'], + '$hidden' => array('hidden', t('Hide this contact from others'), ($rr['abook_flags'] & ABOOK_FLAG_HIDDEN), ''), + '$activity' => array('activity', t('Post a new friend activity'), (intval(get_pconfig(local_user(),'system','post_newfriend')) ? '1' : 0), t('if applicable')), + '$url' => zid($rr['xchan_url']), + '$approve' => t('Approve'), + '$block' => t('Block'), + '$ignore' => t('Ignore'), + '$discard' => t('Discard') + + )); + } + } + + $o .= paginate($a); + return $o; + +}
\ No newline at end of file diff --git a/view/tpl/intros.tpl b/view/tpl/intros.tpl index e7fd53ca4..6d1f1baa0 100644 --- a/view/tpl/intros.tpl +++ b/view/tpl/intros.tpl @@ -1,27 +1,17 @@ <div class="intro-wrapper" id="intro-$contact_id" > -<p class="intro-desc">$str_notifytype $notify_type</p> <div class="intro-fullname" id="intro-fullname-$contact_id" >$fullname</div> <a class="intro-url-link" id="intro-url-link-$contact_id" href="$url" ><img id="photo-$contact_id" class="intro-photo" src="$photo" width="175" height=175" title="$fullname" alt="$fullname" /></a> -<div class="intro-knowyou">$knowyou</div> -<div class="intro-note" id="intro-note-$contact_id">$note</div> <div class="intro-wrapper-end" id="intro-wrapper-end-$contact_id"></div> -<form class="intro-form" action="notifications/$intro_id" method="post"> +<form class="intro-form" action="intro" method="post"> <input class="intro-submit-ignore" type="submit" name="submit" value="$ignore" /> +<input class="intro-submit-block" type="submit" name="submit" value="$block" /> <input class="intro-submit-discard" type="submit" name="submit" value="$discard" /> -</form> -<div class="intro-form-end"></div> - -<form class="intro-approve-form" action="dfrn_confirm" method="post"> {{inc field_checkbox.tpl with $field=$hidden }}{{endinc}} -{{inc field_checkbox.tpl with $field=$activity }}{{endinc}} -<input type="hidden" name="dfrn_id" value="$dfrn_id" > -<input type="hidden" name="intro_id" value="$intro_id" > +{# {{ inc field_checkbox.tpl with $field=$activity }}{{endinc}} #} <input type="hidden" name="contact_id" value="$contact_id" > -$dfrn_text - <input class="intro-submit-approve" type="submit" name="submit" value="$approve" /> </form> </div> diff --git a/view/tpl/intros_header.tpl b/view/tpl/intros_header.tpl new file mode 100644 index 000000000..17afd0cbd --- /dev/null +++ b/view/tpl/intros_header.tpl @@ -0,0 +1 @@ +<h3>$title</h3> diff --git a/view/tpl/nav.tpl b/view/tpl/nav.tpl index d2e525756..5e909e172 100644 --- a/view/tpl/nav.tpl +++ b/view/tpl/nav.tpl @@ -26,12 +26,6 @@ </li> {{ endif }} - {{ if $nav.community }} - <li id="nav-community-link" class="nav-menu $sel.community"> - <a class="$nav.community.2" href="$nav.community.0" title="$nav.community.3" >$nav.community.1</a> - </li> - {{ endif }} - {{ if $nav.network }} <li id="nav-network-link" class="nav-menu $sel.network"> <a class="$nav.network.2" href="$nav.network.0" title="$nav.network.3" >$nav.network.1</a> @@ -45,6 +39,13 @@ </li> {{ endif }} + {{ if $nav.intros }} + <li id="nav-intros-link" class="nav-menu $sel.intros"> + <a class="$nav.intros.2" href="$nav.intros.0" title="$nav.intros.3" >$nav.intros.1</a> + <span id="intro-update" class="nav-notify"></span> + </li> + {{ endif }} + {{ if $nav.notifications }} |