]> git.mxchange.org Git - friendica.git/blobdiff - view/theme/vier/theme.php
aside bar as menu in mobile
[friendica.git] / view / theme / vier / theme.php
index 91e34e78247bae5c6bbb28faaf47760ef39676ec..f7b52dc35c8bd685a70e25989ce2d7628c283e72 100644 (file)
@@ -9,30 +9,34 @@
  * Description: "Vier" is a very compact and modern theme. It uses the font awesome font library: http://fortawesome.github.com/Font-Awesome/
  */
 
+require_once("mod/nodeinfo.php");
+require_once("mod/proxy.php");
+require_once("include/socgraph.php");
+
 function vier_init(&$a) {
-set_template_engine($a, 'smarty3');
 
-$baseurl = $a->get_baseurl();
+       $a->theme_events_in_profile = false;
+
+       set_template_engine($a, 'smarty3');
+
+       $baseurl = $a->get_baseurl();
 
-$a->theme_info = array();
+       $a->theme_info = array();
 
-$style = get_pconfig(local_user(), 'vier', 'style');
+       if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname'] or $a->argv[0] === "network" && local_user()) {
+               vier_community_info();
 
-if ($style == "")
-       $style = get_config('vier', 'style');
+               $a->page['htmlhead'] .= "<link rel='stylesheet' type='text/css' href='view/theme/vier/wide.css' media='screen and (min-width: 1300px)'/>\n";
+       }
 
-if ($style == "flat")
-       $a->page['htmlhead'] .= '<link rel="stylesheet" href="view/theme/vier/flat.css" type="text/css" media="screen"/>'."\n";
-else if ($style == "netcolour")
-       $a->page['htmlhead'] .= '<link rel="stylesheet" href="view/theme/vier/netcolour.css" type="text/css" media="screen"/>'."\n";
-else if ($style == "breathe")
-       $a->page['htmlhead'] .= '<link rel="stylesheet" href="view/theme/vier/breathe.css" type="text/css" media="screen"/>'."\n";
-else if ($style == "plus")
-       $a->page['htmlhead'] .= '<link rel="stylesheet" href="view/theme/vier/plus.css" type="text/css" media="screen"/>'."\n";
-else if ($style == "dark")
-       $a->page['htmlhead'] .= '<link rel="stylesheet" href="view/theme/vier/dark.css" type="text/css" media="screen"/>'."\n";
+       if ($a->is_mobile || $a->is_tablet) {
+               $a->page['htmlhead'] .= '<meta name=viewport content="width=device-width, initial-scale=1">'."\n";
+               $a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="view/theme/vier/mobile.css" media="screen"/>'."\n";
+       }
+               $a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="view/theme/vier/mobile.css" media="screen and (max-width: 1000px)"/>'."\n";
 
 $a->page['htmlhead'] .= <<< EOT
+<link rel='stylesheet' type='text/css' href='view/theme/vier/narrow.css' media='screen and (max-width: 1100px)' />
 <script type="text/javascript">
 
 function insertFormatting(comment,BBcode,id) {
@@ -82,7 +86,282 @@ function cmtBbOpen(id) {
 function cmtBbClose(id) {
        $("#comment-edit-bb-" + id).hide();
 }
+
+$(document).ready(function() {
+       $(".mobile-aside-toggle a").click(function(e){
+               e.preventDefault();
+               $("aside").toggleClass("show");
+       });
+});
+
 </script>
 EOT;
+
+       // Hide the left menu bar
+       if (($a->page['aside'] == "") AND in_array($a->argv[0], array("community", "events", "help", "manage", "notifications",
+                                                                       "probe", "webfinger", "login", "invite", "credits")))
+               $a->page['htmlhead'] .= "<link rel='stylesheet' href='view/theme/vier/hide.css' />";
+}
+
+function get_vier_config($key, $default = false, $admin = false) {
+       if (local_user() AND !$admin) {
+               $result = get_pconfig(local_user(), "vier", $key);
+               if ($result !== false)
+                       return $result;
+       }
+
+       $result = get_config("vier", $key);
+       if ($result !== false)
+               return $result;
+
+       return $default;
 }
 
+function vier_community_info() {
+       $a = get_app();
+
+       $show_pages      = get_vier_config("show_pages", 1);
+       $show_profiles   = get_vier_config("show_profiles", 1);
+       $show_helpers    = get_vier_config("show_helpers", 1);
+       $show_services   = get_vier_config("show_services", 1);
+       $show_friends    = get_vier_config("show_friends", 1);
+       $show_lastusers  = get_vier_config("show_lastusers", 1);
+
+       //get_baseurl
+       $url = $a->get_baseurl($ssl_state);
+       $aside['$url'] = $url;
+
+       // comunity_profiles
+       if($show_profiles) {
+
+               $r = suggestion_query(local_user(), 0, 9);
+
+               $tpl = get_markup_template('ch_directory_item.tpl');
+               if(count($r)) {
+
+                       $aside['$comunity_profiles_title'] = t('Community Profiles');
+                       $aside['$comunity_profiles_items'] = array();
+
+                       foreach($r as $rr) {
+                               $entry = replace_macros($tpl,array(
+                                       '$id' => $rr['id'],
+                                       //'$profile_link' => zrl($rr['url']),
+                                       '$profile_link' => $a->get_baseurl().'/follow/?url='.urlencode($rr['url']),
+                                       '$photo' => proxy_url($rr['photo'], false, PROXY_SIZE_MICRO),
+                                       '$alt_text' => $rr['name'],
+                               ));
+                               $aside['$comunity_profiles_items'][] = $entry;
+                       }
+               }
+       }
+
+       // last 9 users
+       if($show_lastusers) {
+               $publish = (get_config('system','publish_all') ? '' : " AND `publish` = 1 ");
+               $order = " ORDER BY `register_date` DESC ";
+
+               $r = q("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`
+                               FROM `profile` LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
+                               WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $order LIMIT %d , %d ",
+                               0, 9);
+
+               $tpl = get_markup_template('ch_directory_item.tpl');
+               if(count($r)) {
+
+                       $aside['$lastusers_title'] = t('Last users');
+                       $aside['$lastusers_items'] = array();
+
+                       foreach($r as $rr) {
+                               $profile_link = $a->get_baseurl() . '/profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
+                               $entry = replace_macros($tpl,array(
+                                       '$id' => $rr['id'],
+                                       '$profile_link' => $profile_link,
+                                       '$photo' => $a->get_cached_avatar_image($rr['thumb']),
+                                       '$alt_text' => $rr['name']));
+                               $aside['$lastusers_items'][] = $entry;
+                       }
+               }
+       }
+
+       //right_aside FIND FRIENDS
+       if ($show_friends AND local_user()) {
+               $nv = array();
+               $nv['title'] = Array("", t('Find Friends'), "", "");
+               $nv['directory'] = Array('directory', t('Local Directory'), "", "");
+               $nv['global_directory'] = Array(get_server(), t('Global Directory'), "", "");
+               $nv['match'] = Array('match', t('Similar Interests'), "", "");
+               $nv['suggest'] = Array('suggest', t('Friend Suggestions'), "", "");
+               $nv['invite'] = Array('invite', t('Invite Friends'), "", "");
+
+               $nv['search'] = '<form name="simple_bar" method="get" action="'.$a->get_baseurl().'/dirfind">
+                                               <span class="sbox_l"></span>
+                                               <span class="sbox">
+                                               <input type="text" name="search" size="13" maxlength="50">
+                                               </span>
+                                               <span class="sbox_r" id="srch_clear"></span>';
+
+               $aside['$nv'] = $nv;
+       }
+
+       //Community_Pages at right_aside
+       if($show_pages AND local_user()) {
+
+               $pagelist = array();
+
+               $contacts = q("SELECT `id`, `url`, `name`, `micro` FROM `contact`
+                               WHERE `network`= '%s' AND `uid` = %d AND (`forum` OR `prv`) AND
+                                       NOT `hidden` AND NOT `blocked` AND
+                                       NOT `archive` AND NOT `pending` AND
+                                       `success_update` > `failure_update`
+                               ORDER BY `name` ASC",
+                               dbesc(NETWORK_DFRN), intval($a->user['uid']));
+
+               $pageD = array();
+
+               // Look if the profile is a community page
+               foreach($contacts as $contact) {
+                       $pageD[] = array("url"=>$contact["url"], "name"=>$contact["name"], "id"=>$contact["id"], "micro"=>$contact['micro']);
+               };
+
+               $contacts = $pageD;
+
+               if ($contacts) {
+                       $page = '
+                               <h3>'.t("Community Pages").'</h3>
+                               <div id="forum-list-right">';
+
+                       foreach($contacts as $contact) {
+                               $page .= '<div role="menuitem"><a href="' . $a->get_baseurl() . '/redir/' . $contact["id"] . '" title="'.t('External link to forum').'" class="label sparkle" target="_blank"><img class="forumlist-img" height="20" width="20" src="' . $contact['micro'] .'" alt="'.t('External link to forum').'" /></a> <a href="' . $a->get_baseurl() . '/network?f=&cid=' . $contact['id'] . '" >' . $contact["name"]."</a></div>";
+                       }
+
+                       $page .= '</div>';
+                       $aside['$page'] = $page;
+               }
+       }
+       //END Community Page
+
+       //helpers
+       if($show_helpers) {
+               $r = array();
+
+               $helperlist = get_config("vier", "helperlist");
+
+               $helpers = explode(",",$helperlist);
+
+               if ($helpers) {
+                       $query = "";
+                       foreach ($helpers AS $index=>$helper) {
+                               if ($query != "")
+                                       $query .= ",";
+
+                               $query .= "'".dbesc(normalise_link(trim($helper)))."'";
+                       }
+
+                       $r = q("SELECT `url`, `name` FROM `gcontact` WHERE `nurl` IN (%s)", $query);
+               }
+
+               foreach ($r AS $index => $helper)
+                       $r[$index]["url"] = zrl($helper["url"]);
+
+               $r[] = Array("url" => "help/Quick-Start-guide", "name" => t("Quick Start"));
+
+               $tpl = get_markup_template('ch_helpers.tpl');
+
+               if ($r) {
+
+                       $helpers = array();
+                       $helpers['title'] = Array("", t('Help'), "", "");
+
+                       $aside['$helpers_items'] = array();
+
+                       foreach($r as $rr) {
+                               $entry = replace_macros($tpl,array(
+                                       '$url' => $rr['url'],
+                                       '$title' => $rr['name'],
+                               ));
+                               $aside['$helpers_items'][] = $entry;
+                       }
+
+                       $aside['$helpers'] = $helpers;
+               }
+       }
+       //end helpers
+
+       //connectable services
+       if ($show_services) {
+
+               $r = array();
+
+               if (nodeinfo_plugin_enabled("appnet"))
+                       $r[] = array("photo" => "images/appnet.png", "name" => "App.net");
+
+               if (nodeinfo_plugin_enabled("buffer"))
+                       $r[] = array("photo" => "images/buffer.png", "name" => "Buffer");
+
+               if (nodeinfo_plugin_enabled("blogger"))
+                       $r[] = array("photo" => "images/blogger.png", "name" => "Blogger");
+
+               if (nodeinfo_plugin_enabled("dwpost"))
+                       $r[] = array("photo" => "images/dreamwidth.png", "name" => "Dreamwidth");
+
+               if (nodeinfo_plugin_enabled("fbpost"))
+                       $r[] = array("photo" => "images/facebook.png", "name" => "Facebook");
+
+               if (nodeinfo_plugin_enabled("ifttt"))
+                       $r[] = array("photo" => "addon/ifttt/ifttt.png", "name" => "IFTTT");
+
+               if (nodeinfo_plugin_enabled("statusnet"))
+                       $r[] = array("photo" => "images/gnusocial.png", "name" => "GNU Social");
+
+               if (nodeinfo_plugin_enabled("gpluspost"))
+                       $r[] = array("photo" => "images/googleplus.png", "name" => "Google+");
+
+               //if (nodeinfo_plugin_enabled("ijpost"))
+               //      $r[] = array("photo" => "images/", "name" => "");
+
+               if (nodeinfo_plugin_enabled("libertree"))
+                       $r[] = array("photo" => "images/libertree.png", "name" => "Libertree");
+
+               //if (nodeinfo_plugin_enabled("ljpost"))
+               //      $r[] = array("photo" => "images/", "name" => "");
+
+               if (nodeinfo_plugin_enabled("pumpio"))
+                       $r[] = array("photo" => "images/pumpio.png", "name" => "pump.io");
+
+               if (nodeinfo_plugin_enabled("tumblr"))
+                       $r[] = array("photo" => "images/tumblr.png", "name" => "Tumblr");
+
+               if (nodeinfo_plugin_enabled("twitter"))
+                       $r[] = array("photo" => "images/twitter.png", "name" => "Twitter");
+
+               if (nodeinfo_plugin_enabled("wppost"))
+                       $r[] = array("photo" => "images/wordpress", "name" => "Wordpress");
+
+               if(function_exists("imap_open") AND !get_config("system","imap_disabled") AND !get_config("system","dfrn_only"))
+                       $r[] = array("photo" => "images/mail", "name" => "E-Mail");
+
+               $tpl = get_markup_template('ch_connectors.tpl');
+
+               if(count($r)) {
+
+                       $con_services = array();
+                       $con_services['title'] = Array("", t('Connect Services'), "", "");
+                       $aside['$con_services'] = $con_services;
+
+                       foreach($r as $rr) {
+                               $entry = replace_macros($tpl,array(
+                                       '$url' => $url,
+                                       '$photo' => $rr['photo'],
+                                       '$alt_text' => $rr['name'],
+                               ));
+                               $aside['$connector_items'][] = $entry;
+                       }
+               }
+
+       }
+       //end connectable services
+
+       //print right_aside
+       $tpl = get_markup_template('communityhome.tpl');
+       $a->page['right_aside'] = replace_macros($tpl, $aside);
+}