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'] =
-'' .
-'' . sprintf( t('Blocked %s - Click to open/close'),$word ) . '
' . $b['html'] . '
';
+ $b['html'] = '' . sprintf( t('Blocked %s - Click to open/close'),$word ) . '
' . $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();
}