* 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) {
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);
+}