]> git.mxchange.org Git - friendica-addons.git/commitdiff
page updates
authorfriendica <info@friendica.com>
Tue, 19 Jun 2012 09:30:44 +0000 (02:30 -0700)
committerfriendica <info@friendica.com>
Tue, 19 Jun 2012 09:30:44 +0000 (02:30 -0700)
page/page.php

index 129af41249f05a5a4cb03fc8d580524dfcec9f29..4ae471bace2d766f8b2059e29094a465e203345f 100755 (executable)
  */
 
 function page_install() {
-       register_hook('page_end', 'addon/page/page.php', 'page_page_end');
+       register_hook('network_mod_init', 'addon/page/page.php', 'page_network_mod_init');
+       register_hook('plugin_settings', 'addon/page/page.php', 'page_plugin_settings');
+       register_hook('plugin_settings_post', 'addon/page/page.php', 'page_plugin_settings_post');
+
 }
 
 function page_uninstall() {
+       unregister_hook('network_mod_init', 'addon/page/page.php', 'page_network_mod_init');
+       unregister_hook('plugin_settings', 'addon/page/page.php', 'page_plugin_settings');
+       unregister_hook('plugin_settings_post', 'addon/page/page.php', 'page_plugin_settings_post');
+
+       // remove only - obsolete
        unregister_hook('page_end', 'addon/page/page.php', 'page_page_end');
 }
 
@@ -71,5 +79,75 @@ function page_page_end($a,&$b) {
                $a->page['aside'] = $page . $a->page['aside'];
 }
 
+function page_network_mod_init($a,$b) {
+
+       $page = '<div id="page-sidebar" class="widget">
+                       <div class="title tool">
+                       <h3>'.t("Forums").'</h3></div>
+                       <div id="sidebar-page-list"><ul>';
+
+       $show_total = intval(get_pconfig(local_user(),'page','max_pages'));
+       if($show_total === false)
+               $show_total = 6;
+       $contacts = page_getpage($a->user['uid']);
+
+       $total_shown = 0;
+       $more = false;
+
+       foreach($contacts as $contact) {
+               $page .= '<li style="list-style-type: none;" class="tool"><img height="20" width="20" src="' . $contact['micro'] .'" alt="' . $contact['url'] . '" /> <a href="'.$a->get_baseurl().'/redir/'.$contact["id"].'" title="' . $contact['url'] . '" class="label" target="external-link">'.
+                               $contact["name"]."</a></li>";
+               $total_shown ++;
+               if(($show_total) && ($total_shown == $show_total)) {
+                       $more = true;
+                       $page .= '</ul><div id="hide-comments-page-widget" class="fakelink" onclick="showHideComments(\'page-widget\');" >' . t('show more') 
+                               . '</div><div id="collapsed-comments-page-widget" style="display: none;" ><ul>';
+               } 
+       }
+       if($more)
+               $page .= '</div>';
+       $page .= "</ul></div></div>";
+       if (sizeof($contacts) > 0)
+               $a->page['aside'] = $page . $a->page['aside'];
+}
+
+function page_plugin_settings_post($a,$post) {
+       if(! local_user() || (! x($_POST,'page-settings-submit')))
+               return;
+
+       set_pconfig(local_user(),'page','max_pages',intval($_POST['page_max_pages']));
+       info( t('Page settings updated.') . EOL);
+}
+
+
+function page_plugin_settings(&$a,&$s) {
+
+       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/page/page.css' . '" media="all" />' . "\r\n";
+
+       /* Get the current state of our config variable */
+
+       $max_pages = get_pconfig(local_user(),'page','max_pages');
+       if($max_pages === false)
+               $max_pages = 6;
+       
+       /* Add some HTML to the existing form */
+
+       $s .= '<div class="settings-block">';
+       $s .= '<h3>' . t('Page Settings') . '</h3>';
+       $s .= '<div id="page-settings-wrapper">';
+       $s .= '<label id="page-settings-label" for="page-max-pages">' . t('How many forums to display on sidebar without paging') . '</label>';
+       $s .= '<input id="page-max-pages" type="text" name="page_max_pages" value="' . intval($max_pages) . '" ' . '/>';
+       $s .= '</div><div class="clear"></div>';
+
+       /* provide a submit button */
+
+       $s .= '<div class="settings-submit-wrapper" ><input type="submit" name="page-settings-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
+
+}