]> git.mxchange.org Git - friendica.git/commitdiff
have fun...
authorfriendica <info@friendica.com>
Fri, 20 Jul 2012 01:17:16 +0000 (18:17 -0700)
committerfriendica <info@friendica.com>
Fri, 20 Jul 2012 01:17:16 +0000 (18:17 -0700)
boot.php
include/conversation.php
include/text.php
mod/poke.php [new file with mode: 0644]
view/poke_content.tpl [new file with mode: 0644]

index 2e83bbb7f42d463ff40598140734ef0a7f3d0c9c..4f52db86385b380ecd50e923aadedd0b33bbb227 100644 (file)
--- a/boot.php
+++ b/boot.php
@@ -215,7 +215,7 @@ define ( 'TERM_OBJ_PHOTO', 2 );
  * various namespaces we may need to parse
  */
 
-define ( 'NAMESPACE_ZOT',             'http://purl.org/macgirvin/zot' );
+define ( 'NAMESPACE_ZOT',             'http://purl.org/zot' );
 define ( 'NAMESPACE_DFRN' ,           'http://purl.org/macgirvin/dfrn/1.0' );
 define ( 'NAMESPACE_THREAD' ,         'http://purl.org/syndication/thread/1.0' );
 define ( 'NAMESPACE_TOMB' ,           'http://purl.org/atompub/tombstones/1.0' );
@@ -250,6 +250,8 @@ define ( 'ACTIVITY_UPDATE',      NAMESPACE_ACTIVITY_SCHEMA . 'update' );
 define ( 'ACTIVITY_TAG',         NAMESPACE_ACTIVITY_SCHEMA . 'tag' );
 define ( 'ACTIVITY_FAVORITE',    NAMESPACE_ACTIVITY_SCHEMA . 'favorite' );
 
+define ( 'ACTIVITY_POKE',        NAMESPACE_ZOT . '/activity/poke' );
+
 define ( 'ACTIVITY_OBJ_COMMENT', NAMESPACE_ACTIVITY_SCHEMA . 'comment' );
 define ( 'ACTIVITY_OBJ_NOTE',    NAMESPACE_ACTIVITY_SCHEMA . 'note' );
 define ( 'ACTIVITY_OBJ_PERSON',  NAMESPACE_ACTIVITY_SCHEMA . 'person' );
index 546e27db67fa772985493f09a4e65cf3b04e88f5..44cd92c3918ff5df4769aafdf17110503f653da2 100644 (file)
@@ -162,6 +162,49 @@ function localize_item(&$item){
                $item['body'] = sprintf( t('%1$s is now friends with %2$s'), $A, $B)."\n\n\n".$Bphoto;
 
        }
+       if (stristr($item['verb'],ACTIVITY_POKE)) {
+               $verb = urldecode(substr($item['verb'],strpos($item['verb'],'#')+1));
+               if(! $verb)
+                       return;
+               if ($item['object-type']=="" || $item['object-type']!== ACTIVITY_OBJ_PERSON) return;
+
+               $Aname = $item['author-name'];
+               $Alink = $item['author-link'];
+               
+               $xmlhead="<"."?xml version='1.0' encoding='UTF-8' ?".">";
+               
+               $obj = parse_xml_string($xmlhead.$item['object']);
+               $links = parse_xml_string($xmlhead."<links>".unxmlify($obj->link)."</links>");
+               
+               $Bname = $obj->title;
+               $Blink = ""; $Bphoto = "";
+               foreach ($links->link as $l){
+                       $atts = $l->attributes();
+                       switch($atts['rel']){
+                               case "alternate": $Blink = $atts['href'];
+                               case "photo": $Bphoto = $atts['href'];
+                       }
+                       
+               }
+               
+               $A = '[url=' . zrl($Alink) . ']' . $Aname . '[/url]';
+               $B = '[url=' . zrl($Blink) . ']' . $Bname . '[/url]';
+               if ($Bphoto!="") $Bphoto = '[url=' . zrl($Blink) . '][img=80x80]' . $Bphoto . '[/img][/url]';
+
+               // we can't have a translation string with three positions but no distinguishable text
+               // So here is the translate string.
+
+               $txt = t('%1$s poked %2$s');
+
+               // now translate the verb
+
+               $txt = str_replace( t('poked'), t($verb), $txt);
+
+               // then do the sprintf on the translation string
+
+               $item['body'] = sprintf($txt, $A, $B). "\n\n\n" . $Bphoto;
+
+       }
     if ($item['verb']===ACTIVITY_TAG){
                $r = q("SELECT * from `item`,`contact` WHERE 
                `item`.`contact-id`=`contact`.`id` AND `item`.`uri`='%s';",
index 83819d095071f678df7bb3f298bf9777884a421a..a390a2855fdf8f38b24cbfaa8c8492a2aed5e479 100644 (file)
@@ -706,6 +706,20 @@ function linkify($s) {
        return($s);
 }}
 
+function get_poke_verbs() {
+       
+       // index is present tense verb
+       // value is array containing past tense verb, translation of present, translation of past
+
+       $arr = array(
+               'poke' => array( 'poked', t('poke'), t('poked')),
+               'prod' => array( 'prodded', t('prod'), t('prodded')),
+               'slap' => array( 'slapped', t('slap'), t('slapped')),
+               'finger' => array( 'fingered', t('finger'), t('fingered'))
+       );
+       call_hooks('poke_verbs', $arr);
+       return $arr;
+}
 
 /**
  * 
diff --git a/mod/poke.php b/mod/poke.php
new file mode 100644 (file)
index 0000000..29b732f
--- /dev/null
@@ -0,0 +1,149 @@
+<?php
+
+require_once('include/security.php');
+require_once('include/bbcode.php');
+require_once('include/items.php');
+
+
+function poke_init(&$a) {
+
+       if(! local_user())
+               return;
+
+       $uid = local_user();
+       $verb = notags(trim($_GET['verb']));
+       
+       if(! $verb) 
+               return;
+
+       $verbs = get_poke_verbs();
+
+       if(! array_key_exists($verb,$verbs))
+               return;
+
+       $activity = ACTIVITY_POKE . '#' . urlencode($verbs[$verb][0]);
+
+       $contact_id = intval($_GET['cid']);
+       if(! $contact_id)
+               return;
+
+
+       logger('poke: verb ' . $verb . ' contact ' . $contact_id, LOGGER_DEBUG);
+
+
+       $r = q("SELECT * FROM `contact` WHERE `id` = %d and  `uid` = %d LIMIT 1",
+               intval($contact_id),
+               intval($uid)
+       );
+
+       if(! count($r)) {
+               logger('poke: no contact ' . $contact_id);
+               return;
+       }
+
+       $target = $r[0];
+
+       $poster = $a->contact;
+
+       $uri = item_new_uri($a->get_hostname(),$owner_uid);
+
+       $arr = array();
+
+       $arr['uid']           = $uid;
+       $arr['uri']           = $uri;
+       $arr['parent-uri']    = $uri;
+       $arr['type']          = 'activity';
+       $arr['wall']          = 1;
+       $arr['contact-id']    = $target['id'];
+       $arr['owner-name']    = $poster['name'];
+       $arr['owner-link']    = $poster['url'];
+       $arr['owner-avatar']  = $poster['thumb'];
+       $arr['author-name']   = $poster['name'];
+       $arr['author-link']   = $poster['url'];
+       $arr['author-avatar'] = $poster['thumb'];
+       $arr['title']         = '';
+       $arr['allow_cid']     = $a->user['allow_cid'];
+       $arr['allow_gid']     = $a->user['allow_gid'];
+       $arr['deny_cid']      = $a->user['deny_cid'];
+       $arr['deny_gid']      = $a->user['deny_gid'];
+       $arr['last-child']    = 1;
+       $arr['visible']       = 1;
+       $arr['verb']          = $activity;
+       $arr['object-type']   = ACTIVITY_OBJ_PERSON;
+
+       $arr['origin']        = 1;
+       $arr['body']          = '[url=' . $poster['url'] . ']' . $poster['name'] . '[/url]' . ' ' . t($verbs[$verb][0]) . ' ' . '[url=' . $target['url'] . ']' . $target['name'] . '[/url]';
+
+       $arr['object'] = '<object><type>' . ACTIVITY_OBJ_PERSON . '</type><title>' . $target['name'] . '</title><id>' . $a->get_baseurl() . '/contact/' . $target['id'] . '</id>';
+       $arr['object'] .= '<link>' . xmlify('<link rel="alternate" type="text/html" href="' . $target['url'] . '" />' . "\n");
+
+       $arr['object'] .= xmlify('<link rel="photo" type="image/jpeg" href="' . $target['photo'] . '" />' . "\n");
+       $arr['object'] .= '</link></object>' . "\n";
+
+       $item_id = item_store($arr);
+       if($item_id) {
+               q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d LIMIT 1",
+                       dbesc($a->get_baseurl() . '/display/' . $poster['nickname'] . '/' . $item_id),
+                       intval($uid),
+                       intval($item_id)
+               );
+               proc_run('php',"include/notifier.php","tag","$item_id");
+       }
+
+
+       call_hooks('post_local_end', $arr);
+
+       proc_run('php',"include/notifier.php","like","$post_id");
+
+       return;
+}
+
+
+
+function poke_content(&$a) {
+
+       $base = $a->get_baseurl();
+
+       $a->page['htmlhead'] .= '<script src="' . $a->get_baseurl(true) . '/library/jquery_ac/friendica.complete.js" ></script>';
+       $a->page['htmlhead'] .= <<< EOT
+
+<script>$(document).ready(function() { 
+       var a; 
+       a = $("#recip").autocomplete({ 
+               serviceUrl: '$base/acl',
+               minChars: 2,
+               width: 350,
+               onSelect: function(value,data) {
+                       $("#recip-complete").val(data);
+               }                       
+       });
+       a.setOptions({ params: { type: 'a' }});
+
+
+}); 
+
+</script>
+EOT;
+
+
+       $verbs = get_poke_verbs();
+
+       $shortlist = array();
+       foreach($verbs as $k => $v)
+               $shortlist[] = array($k,$v[1]);
+
+
+       $tpl = get_markup_template('poke_content.tpl');
+
+       $o = replace_macros($tpl,array(
+               '$title' => t('Poke/Prod'),
+               '$desc' => t('poke, prod or do other things to somebody'),
+               '$clabel' => t('Recipient'),
+               '$choice' => t('Choose what you wish to do to recipient'),
+               '$verbs' => $shortlist,
+               '$submit' => t('Submit')
+       ));
+
+       return $o;
+
+}
\ No newline at end of file
diff --git a/view/poke_content.tpl b/view/poke_content.tpl
new file mode 100644 (file)
index 0000000..09b3d8d
--- /dev/null
@@ -0,0 +1,29 @@
+<h3>$title</h3>
+
+<div id="poke-desc">$desc</div>
+
+<form action="poke" method="get">
+<br />
+<br />
+
+<div id="poke-recip-label">$clabel</div>
+<br />
+<input id="recip" type="text" size="64" maxlength="255" value="" name="pokename" autocomplete="off">
+<input id="recip-complete" type="hidden" value="" name="cid">
+
+<br />
+<br />
+<div id="poke-action-label">$choice</div>
+<br />
+<br />
+<select name="verb" id="poke-verb-select" >
+{{ for $verbs as $v }}
+<option value="$v.0">$v.1</option>
+{{ endfor }}
+</select>
+<br />
+<br />
+
+<input type="submit" name="submit" value="$submit" />
+</form>
+