X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=blockem%2Fblockem.php;h=9134bd0b654fea63fdfaeba3bd3fc01a4d4c4a08;hb=f75d96e5bc0eda7118717f38da913f82a1aecb56;hp=4fff2148571ac9a04ed058623b9bba4540f72bea;hpb=1069db936ba5a14482247740ea4bf53c8000ab52;p=friendica-addons.git diff --git a/blockem/blockem.php b/blockem/blockem.php old mode 100644 new mode 100755 index 4fff2148..9134bd0b --- a/blockem/blockem.php +++ b/blockem/blockem.php @@ -11,16 +11,21 @@ function blockem_install() { register_hook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); + register_hook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); register_hook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); register_hook('plugin_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); - + register_hook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); + register_hook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); } function blockem_uninstall() { unregister_hook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); + unregister_hook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); unregister_hook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); unregister_hook('plugin_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); + unregister_hook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); + unregister_hook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); } @@ -30,7 +35,6 @@ function blockem_uninstall() { function blockem_addon_settings(&$a,&$s) { - if(! local_user()) return; @@ -47,7 +51,7 @@ function blockem_addon_settings(&$a,&$s) { $s .= '

' . t('"Blockem" Settings') . '

'; $s .= '
'; $s .= ''; - $s .= ''; + $s .= ''; $s .= '
'; $s .= '
'; @@ -98,9 +102,95 @@ function blockem_prepare_body(&$a,&$b) { } if($found) { $rnd = random_string(8); - $b['item']['author-avatar'] = $a->get_baseurl() . "/images/default-profile-sm.jpg"; - $b['html'] = -'' . -''; + $b['html'] = ''; + } +} + + +function blockem_display_item(&$a,&$b) { + if(strstr($b['output']['body'],'id="blockem-wrap-')) + $b['output']['thumb'] = $a->get_baseurl() . "/images/default-profile-sm.jpg"; +} + + +function blockem_conversation_start(&$a,&$b) { + + if(! local_user()) + return; + + $words = get_pconfig(local_user(),'blockem','words'); + if($words) { + $a->data['blockem'] = explode(',',$words); + } + $a->page['htmlhead'] .= <<< EOT + + + +EOT; + +} + +function blockem_item_photo_menu(&$a,&$b) { + + if((! local_user()) || ($b['item']['self'])) + return; + + $blocked = false; + $author = $b['item']['author-link']; + if(is_array($a->data['blockem'])) { + foreach($a->data['blockem'] as $bloke) { + if(link_compare($bloke,$author)) { + $blocked = true; + break; + } + } } + if($blocked) + $b['menu'][ t('Unblock Author')] = 'javascript:blockemUnblock("' . $author . '");'; + else + $b['menu'][ t('Block Author')] = 'javascript:blockemBlock("' . $author . '");'; +} + +function blockem_module() {} + + +function blockem_init(&$a) { + + if(! local_user()) + return; + + $words = get_pconfig(local_user(),'blockem','words'); + + if(array_key_exists('block',$_GET) && $_GET['block']) { + if(strlen($words)) + $words .= ','; + $words .= trim($_GET['block']); + } + if(array_key_exists('unblock',$_GET) && $_GET['unblock']) { + $arr = explode(',',$words); + $newarr = array(); + + if(count($arr)) { + foreach($arr as $x) { + if(! link_compare(trim($x),trim($_GET['unblock']))) + $newarr[] = $x; + } + } + $words = implode(',',$newarr); + } + + set_pconfig(local_user(),'blockem','words',$words); + info( t('blockem settings updated') . EOL ); + killme(); }