]> git.mxchange.org Git - friendica-addons.git/blobdiff - superblock/superblock.php
Merge pull request #418 from tobiasd/20170707-es
[friendica-addons.git] / superblock / superblock.php
index 41abb47146d0534953fb00c2261fd147b9d00948..c86c6aadc7950635703bbced3789e2c0eaade93f 100755 (executable)
@@ -6,7 +6,7 @@
  * Description: block people
  * Version: 1.0
  * Author: Mike Macgirvin <http://macgirvin.com/profile/mike>
- * 
+ *
  */
 
 function superblock_install() {
@@ -15,6 +15,8 @@ function superblock_install() {
        register_hook('plugin_settings_post', 'addon/superblock/superblock.php', 'superblock_addon_settings_post');
        register_hook('conversation_start', 'addon/superblock/superblock.php', 'superblock_conversation_start');
        register_hook('item_photo_menu', 'addon/superblock/superblock.php', 'superblock_item_photo_menu');
+       register_hook('enotify_store', 'addon/superblock/superblock.php', 'superblock_enotify_store');
+
 }
 
 
@@ -24,6 +26,7 @@ function superblock_uninstall() {
        unregister_hook('plugin_settings_post', 'addon/superblock/superblock.php', 'superblock_addon_settings_post');
        unregister_hook('conversation_start', 'addon/superblock/superblock.php', 'superblock_conversation_start');
        unregister_hook('item_photo_menu', 'addon/superblock/superblock.php', 'superblock_item_photo_menu');
+       unregister_hook('enotify_store', 'addon/superblock/superblock.php', 'superblock_enotify_store');
 
 }
 
@@ -33,29 +36,34 @@ function superblock_uninstall() {
 
 function superblock_addon_settings(&$a,&$s) {
 
-       if(! local_user())
+       if(! local_user()) {
                return;
+       }
 
-    /* Add our stylesheet to the page so we can make our settings look nice */
-
-    $a->page['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->get_baseurl() . '/addon/superblock/superblock.css' . '" media="all" />' . "\r\n";
+       /* Add our stylesheet to the page so we can make our settings look nice */
 
+       $a->page['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->get_baseurl() . '/addon/superblock/superblock.css' . '" media="all" />' . "\r\n";
 
        $words = get_pconfig(local_user(),'system','blocked');
-       if(! $words)
+       if(! $words) {
                $words = '';
+       }
 
-    $s .= '<div class="settings-block">';
-    $s .= '<h3>' . t('"Superblock" Settings') . '</h3>';
-    $s .= '<div id="superblock-wrapper">';
-    $s .= '<label id="superblock-label" for="superblock-words">' . t('Comma separated profile URLS to block') . ' </label>';
-    $s .= '<textarea id="superblock-words" type="text" name="superblock-words" >' . htmlspecialchars($words) . '</textarea>';
-    $s .= '</div><div class="clear"></div>';
+       $s .= '<span id="settings_superblock_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_superblock_expanded\'); openClose(\'settings_superblock_inflated\');">';
+       $s .= '<h3>' . t('"Superblock"') . '</h3>';
+       $s .= '</span>';
+       $s .= '<div id="settings_superblock_expanded" class="settings-block" style="display: none;">';
+       $s .= '<span class="fakelink" onclick="openClose(\'settings_superblock_expanded\'); openClose(\'settings_superblock_inflated\');">';
+       $s .= '<h3>' . t('"Superblock"') . '</h3>';
+       $s .= '</span>';
+       $s .= '<div id="superblock-wrapper">';
+       $s .= '<label id="superblock-label" for="superblock-words">' . t('Comma separated profile URLS to block') . ' </label>';
+       $s .= '<textarea id="superblock-words" type="text" name="superblock-words" >' . htmlspecialchars($words) . '</textarea>';
+       $s .= '</div><div class="clear"></div>';
 
-    $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="superblock-submit" name="superblock-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
+       $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="superblock-submit" name="superblock-submit" class="settings-submit" value="' . t('Save Settings') . '" /></div></div>';
 
        return;
-
 }
 
 function superblock_addon_settings_post(&$a,&$b) {
@@ -69,6 +77,35 @@ function superblock_addon_settings_post(&$a,&$b) {
        }
 }
 
+function superblock_enotify_store(&$a,&$b) {
+
+       $words = get_pconfig($b['uid'],'system','blocked');
+       if($words) {
+               $arr = explode(',',$words);
+       }
+       else {
+               return;
+       }
+
+       $found = false;
+       if(count($arr)) {
+               foreach($arr as $word) {
+                       if(! strlen(trim($word))) {
+                               continue;
+                       }
+
+                       if(link_compare($b['url'],$word)) {
+                               $found = true;
+                               break;
+                       }
+               }
+       }
+       if($found) {
+               $b['abort'] = true;
+       }
+}
+
+
 function superblock_conversation_start(&$a,&$b) {
 
        if(! local_user())
@@ -108,7 +145,7 @@ function superblock_item_photo_menu(&$a,&$b) {
                }
        }
 
-       $b['menu'][ t('Block Completely')] = 'javascript:superblockBlock(\'' . $author . '\');';
+       $b['menu'][ t('Block Completely')] = 'javascript:superblockBlock(\'' . $author . '\'); return false;';
 }
 
 function superblock_module() {}