mirror of
https://github.com/friendica/friendica
synced 2025-01-25 12:19:46 +00:00
4d39164c1e
* Rewrite to Proxy class: - introduced new Friendica\Network\Proxy class for in exchange of proxy_*() functions - moved also all PROXY_* constants there as Proxy::* - removed now no longer needed mod/proxy.php loading as composer's auto-load will do this for us - renamed those proxy_*() functions to better names: + proxy_init() -> Proxy::init() (public) + proxy_url() -> Proxy::proxifyUrl() (public) + proxy_parse_html() -> Proxy::proxifyHtml() (public) + proxy_is_local_image() -> Proxy::isLocalImage() (private) + proxy_parse_query() -> Proxy::parseQuery() (private) + proxy_img_cb() -> Proxy::replaceUrl() (private) * Ops, need to set $a here ... * CR request: - moved Proxy class to Friendica\Module - extended BaseModule * Ops, no need for own instance of $a when self::getApp() is around. * Proxy-rewrite: - proxy_url() and proxy_parse_html() are both non-module functions (now methods) - so they must be splitted into a seperate class - also the SIZE_* and DEFAULT_TIME constants are both not relevant to module * No instances from utility classes * Fixed error: - proxify*() is now located in `Friendica\Util\ProxyUtils` * Moved back to original place, ops? How did they move here? Well, it was not intended by me. * Removed duplicate (left-over from split) constants and static array. Thank to MrPetovan finding it. * Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
404 lines
12 KiB
PHP
404 lines
12 KiB
PHP
<?php
|
|
/**
|
|
* Name: Vier
|
|
* Version: 1.2
|
|
* Author: Fabio <http://kirgroup.com/profile/fabrixxm>
|
|
* Author: Ike <http://pirati.ca/profile/heluecht>
|
|
* Author: Beanow <https://fc.oscp.info/profile/beanow>
|
|
* Maintainer: Ike <http://pirati.ca/profile/heluecht>
|
|
* Description: "Vier" is a very compact and modern theme. It uses the font awesome font library: http://fortawesome.github.com/Font-Awesome/
|
|
*/
|
|
|
|
use Friendica\App;
|
|
use Friendica\Content\ForumManager;
|
|
use Friendica\Core\Addon;
|
|
use Friendica\Core\Config;
|
|
use Friendica\Core\L10n;
|
|
use Friendica\Core\PConfig;
|
|
use Friendica\Core\System;
|
|
use Friendica\Database\DBA;
|
|
use Friendica\Model\Contact;
|
|
use Friendica\Model\GContact;
|
|
use Friendica\Util\Proxy as ProxyUtils;
|
|
|
|
function vier_init(App $a)
|
|
{
|
|
$a->theme_events_in_profile = false;
|
|
|
|
$a->set_template_engine('smarty3');
|
|
|
|
if (!empty($a->argv[0]) && $a->argv[0] . defaults($a->argv, 1, '') === "profile".$a->user['nickname'] || $a->argv[0] === "network" && local_user()) {
|
|
vier_community_info();
|
|
|
|
$a->page['htmlhead'] .= "<link rel='stylesheet' type='text/css' href='view/theme/vier/wide.css' media='screen and (min-width: 1300px)'/>\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";
|
|
}
|
|
/// @todo deactivated since it doesn't work with desktop browsers at the moment
|
|
//$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(BBcode, id) {
|
|
var tmpStr = $("#comment-edit-text-" + id).val();
|
|
if (tmpStr == "") {
|
|
$("#comment-edit-text-" + id).addClass("comment-edit-text-full");
|
|
$("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
|
|
openMenu("comment-edit-submit-wrapper-" + id);
|
|
}
|
|
|
|
textarea = document.getElementById("comment-edit-text-" +id);
|
|
if (document.selection) {
|
|
textarea.focus();
|
|
selected = document.selection.createRange();
|
|
selected.text = "["+BBcode+"]" + selected.text + "[/"+BBcode+"]";
|
|
} else if (textarea.selectionStart || textarea.selectionStart == "0") {
|
|
var start = textarea.selectionStart;
|
|
var end = textarea.selectionEnd;
|
|
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
function showThread(id) {
|
|
$("#collapsed-comments-" + id).show()
|
|
$("#collapsed-comments-" + id + " .collapsed-comments").show()
|
|
}
|
|
function hideThread(id) {
|
|
$("#collapsed-comments-" + id).hide()
|
|
$("#collapsed-comments-" + id + " .collapsed-comments").hide()
|
|
}
|
|
|
|
function cmtBbOpen(id) {
|
|
$("#comment-edit-bb-" + id).show();
|
|
}
|
|
function cmtBbClose(id) {
|
|
$("#comment-edit-bb-" + id).hide();
|
|
}
|
|
</script>
|
|
EOT;
|
|
|
|
if ($a->is_mobile || $a->is_tablet) {
|
|
$a->page['htmlhead'] .= <<< EOT
|
|
<script>
|
|
$(document).ready(function() {
|
|
$(".mobile-aside-toggle a").click(function(e){
|
|
e.preventDefault();
|
|
$("aside").toggleClass("show");
|
|
});
|
|
$(".tabs").click(function(e){
|
|
$(this).toggleClass("show");
|
|
});
|
|
});
|
|
</script>
|
|
EOT;
|
|
}
|
|
|
|
// Hide the left menu bar
|
|
/// @TODO maybe move this static array out where it should belong?
|
|
if (empty($a->page['aside']) && in_array($a->argv[0], ["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() && !$admin) {
|
|
$result = PConfig::get(local_user(), "vier", $key);
|
|
if (!is_null($result)) {
|
|
return $result;
|
|
}
|
|
}
|
|
|
|
$result = Config::get("vier", $key);
|
|
if (!is_null($result)) {
|
|
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 = System::baseUrl();
|
|
$aside['$url'] = $url;
|
|
|
|
// comunity_profiles
|
|
if ($show_profiles) {
|
|
$r = GContact::suggestionQuery(local_user(), 0, 9);
|
|
|
|
$tpl = get_markup_template('ch_directory_item.tpl');
|
|
if (DBA::isResult($r)) {
|
|
$aside['$comunity_profiles_title'] = L10n::t('Community Profiles');
|
|
$aside['$comunity_profiles_items'] = [];
|
|
|
|
foreach ($r as $rr) {
|
|
$entry = replace_macros($tpl, [
|
|
'$id' => $rr['id'],
|
|
'$profile_link' => 'follow/?url='.urlencode($rr['url']),
|
|
'$photo' => ProxyUtils::proxifyUrl($rr['photo'], false, ProxyUtils::SIZE_MICRO),
|
|
'$alt_text' => $rr['name'],
|
|
]);
|
|
$aside['$comunity_profiles_items'][] = $entry;
|
|
}
|
|
}
|
|
}
|
|
|
|
// last 9 users
|
|
if ($show_lastusers) {
|
|
$publish = (Config::get('system', 'publish_all') ? '' : " AND `publish` = 1 ");
|
|
$order = " ORDER BY `register_date` DESC ";
|
|
|
|
$tpl = get_markup_template('ch_directory_item.tpl');
|
|
|
|
$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
|
|
);
|
|
|
|
if (DBA::isResult($r)) {
|
|
$aside['$lastusers_title'] = L10n::t('Last users');
|
|
$aside['$lastusers_items'] = [];
|
|
|
|
foreach ($r as $rr) {
|
|
$profile_link = 'profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
|
|
$entry = replace_macros($tpl, [
|
|
'$id' => $rr['id'],
|
|
'$profile_link' => $profile_link,
|
|
'$photo' => $a->remove_baseurl($rr['thumb']),
|
|
'$alt_text' => $rr['name']]);
|
|
$aside['$lastusers_items'][] = $entry;
|
|
}
|
|
}
|
|
}
|
|
|
|
//right_aside FIND FRIENDS
|
|
if ($show_friends && local_user()) {
|
|
$nv = [];
|
|
$nv['findpeople'] = L10n::t('Find People');
|
|
$nv['desc'] = L10n::t('Enter name or interest');
|
|
$nv['label'] = L10n::t('Connect/Follow');
|
|
$nv['hint'] = L10n::t('Examples: Robert Morgenstein, Fishing');
|
|
$nv['findthem'] = L10n::t('Find');
|
|
$nv['suggest'] = L10n::t('Friend Suggestions');
|
|
$nv['similar'] = L10n::t('Similar Interests');
|
|
$nv['random'] = L10n::t('Random Profile');
|
|
$nv['inv'] = L10n::t('Invite Friends');
|
|
$nv['directory'] = L10n::t('Global Directory');
|
|
$nv['global_dir'] = get_server();
|
|
$nv['local_directory'] = L10n::t('Local Directory');
|
|
|
|
$aside['$nv'] = $nv;
|
|
}
|
|
|
|
//Community_Pages at right_aside
|
|
if ($show_pages && local_user()) {
|
|
$cid = null;
|
|
if (x($_GET, 'cid') && intval($_GET['cid']) != 0) {
|
|
$cid = $_GET['cid'];
|
|
}
|
|
|
|
//sort by last updated item
|
|
$lastitem = true;
|
|
|
|
$contacts = ForumManager::getList($a->user['uid'], $lastitem, true, true);
|
|
$total = count($contacts);
|
|
$visible_forums = 10;
|
|
|
|
if (count($contacts)) {
|
|
$id = 0;
|
|
|
|
foreach ($contacts as $contact) {
|
|
$selected = (($cid == $contact['id']) ? ' forum-selected' : '');
|
|
|
|
$entry = [
|
|
'url' => 'network?f=&cid=' . $contact['id'],
|
|
'external_url' => Contact::magicLink($contact['url']),
|
|
'name' => $contact['name'],
|
|
'cid' => $contact['id'],
|
|
'selected' => $selected,
|
|
'micro' => System::removedBaseUrl(ProxyUtils::proxifyUrl($contact['micro'], false, ProxyUtils::SIZE_MICRO)),
|
|
'id' => ++$id,
|
|
];
|
|
$entries[] = $entry;
|
|
}
|
|
|
|
|
|
$tpl = get_markup_template('widget_forumlist_right.tpl');
|
|
|
|
$page = replace_macros(
|
|
$tpl,
|
|
[
|
|
'$title' => L10n::t('Forums'),
|
|
'$forums' => $entries,
|
|
'$link_desc' => L10n::t('External link to forum'),
|
|
'$total' => $total,
|
|
'$visible_forums' => $visible_forums,
|
|
'$showmore' => L10n::t('show more')]
|
|
);
|
|
|
|
$aside['$page'] = $page;
|
|
}
|
|
}
|
|
// END Community Page
|
|
|
|
// helpers
|
|
if ($show_helpers) {
|
|
$r = [];
|
|
|
|
$helperlist = Config::get("vier", "helperlist");
|
|
|
|
$helpers = explode(",", $helperlist);
|
|
|
|
if ($helpers) {
|
|
$query = "";
|
|
foreach ($helpers as $index => $helper) {
|
|
if ($query != "") {
|
|
$query .= ",";
|
|
}
|
|
|
|
$query .= "'".DBA::escape(normalise_link(trim($helper)))."'";
|
|
}
|
|
|
|
$r = q("SELECT `url`, `name` FROM `gcontact` WHERE `nurl` IN (%s)", $query);
|
|
}
|
|
|
|
foreach ($r as $index => $helper) {
|
|
$r[$index]["url"] = Contact::magicLink($helper["url"]);
|
|
}
|
|
|
|
$r[] = ["url" => "help/Quick-Start-guide", "name" => L10n::t("Quick Start")];
|
|
|
|
$tpl = get_markup_template('ch_helpers.tpl');
|
|
|
|
if ($r) {
|
|
$helpers = [];
|
|
$helpers['title'] = ["", L10n::t('Help'), "", ""];
|
|
|
|
$aside['$helpers_items'] = [];
|
|
|
|
foreach ($r as $rr) {
|
|
$entry = replace_macros($tpl, [
|
|
'$url' => $rr['url'],
|
|
'$title' => $rr['name'],
|
|
]);
|
|
$aside['$helpers_items'][] = $entry;
|
|
}
|
|
|
|
$aside['$helpers'] = $helpers;
|
|
}
|
|
}
|
|
// end helpers
|
|
|
|
// connectable services
|
|
if ($show_services) {
|
|
/// @TODO This whole thing is hard-coded, better rewrite to Intercepting Filter Pattern (future-todo)
|
|
$r = [];
|
|
|
|
if (Addon::isEnabled("appnet")) {
|
|
$r[] = ["photo" => "images/appnet.png", "name" => "App.net"];
|
|
}
|
|
|
|
if (Addon::isEnabled("buffer")) {
|
|
$r[] = ["photo" => "images/buffer.png", "name" => "Buffer"];
|
|
}
|
|
|
|
if (Addon::isEnabled("blogger")) {
|
|
$r[] = ["photo" => "images/blogger.png", "name" => "Blogger"];
|
|
}
|
|
|
|
if (Addon::isEnabled("dwpost")) {
|
|
$r[] = ["photo" => "images/dreamwidth.png", "name" => "Dreamwidth"];
|
|
}
|
|
|
|
if (Addon::isEnabled("fbpost")) {
|
|
$r[] = ["photo" => "images/facebook.png", "name" => "Facebook"];
|
|
}
|
|
|
|
if (Addon::isEnabled("ifttt")) {
|
|
$r[] = ["photo" => "addon/ifttt/ifttt.png", "name" => "IFTTT"];
|
|
}
|
|
|
|
if (Addon::isEnabled("statusnet")) {
|
|
$r[] = ["photo" => "images/gnusocial.png", "name" => "GNU Social"];
|
|
}
|
|
|
|
if (Addon::isEnabled("gpluspost")) {
|
|
$r[] = ["photo" => "images/googleplus.png", "name" => "Google+"];
|
|
}
|
|
|
|
/// @TODO old-lost code (and below)?
|
|
//if (Addon::isEnabled("ijpost")) {
|
|
// $r[] = array("photo" => "images/", "name" => "");
|
|
//}
|
|
|
|
if (Addon::isEnabled("libertree")) {
|
|
$r[] = ["photo" => "images/libertree.png", "name" => "Libertree"];
|
|
}
|
|
|
|
//if (Addon::isEnabled("ljpost")) {
|
|
// $r[] = array("photo" => "images/", "name" => "");
|
|
//}
|
|
|
|
if (Addon::isEnabled("pumpio")) {
|
|
$r[] = ["photo" => "images/pumpio.png", "name" => "pump.io"];
|
|
}
|
|
|
|
if (Addon::isEnabled("tumblr")) {
|
|
$r[] = ["photo" => "images/tumblr.png", "name" => "Tumblr"];
|
|
}
|
|
|
|
if (Addon::isEnabled("twitter")) {
|
|
$r[] = ["photo" => "images/twitter.png", "name" => "Twitter"];
|
|
}
|
|
|
|
if (Addon::isEnabled("wppost")) {
|
|
$r[] = ["photo" => "images/wordpress.png", "name" => "Wordpress"];
|
|
}
|
|
|
|
if (function_exists("imap_open") && !Config::get("system", "imap_disabled") && !Config::get("system", "dfrn_only")) {
|
|
$r[] = ["photo" => "images/mail.png", "name" => "E-Mail"];
|
|
}
|
|
|
|
$tpl = get_markup_template('ch_connectors.tpl');
|
|
|
|
if (DBA::isResult($r)) {
|
|
$con_services = [];
|
|
$con_services['title'] = ["", L10n::t('Connect Services'), "", ""];
|
|
$aside['$con_services'] = $con_services;
|
|
|
|
foreach ($r as $rr) {
|
|
$entry = replace_macros($tpl, [
|
|
'$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);
|
|
}
|