use Friendica\App;
use Friendica\Content\ForumManager;
use Friendica\Core\Addon;
-use Friendica\Core\Config;
-use Friendica\Core\L10n;
use Friendica\Core\Renderer;
use Friendica\Core\Search;
use Friendica\Database\DBA;
use Friendica\DI;
use Friendica\Model\Contact;
-use Friendica\Model\GContact;
-use Friendica\Util\Proxy as ProxyUtils;
use Friendica\Util\Strings;
function vier_init(App $a)
Renderer::setActiveTemplateEngine('smarty3');
- if (!empty($a->argv[0]) && ($a->argv[0] . ($a->argv[1] ?? '')) === ('profile' . $a->user['nickname']) || $a->argv[0] === 'network' && local_user()) {
+ $args = DI::args();
+
+ if ($args->get(0) === 'profile' && $args->get(1) === ($a->user['nickname'] ?? '') || $args->get(0) === 'network' && local_user()
+ ) {
vier_community_info();
DI::page()['htmlhead'] .= "<link rel='stylesheet' type='text/css' href='view/theme/vier/wide.css' media='screen and (min-width: 1300px)'/>\n";
// Hide the left menu bar
/// @TODO maybe move this static array out where it should belong?
- if (empty(DI::page()['aside']) && in_array($a->argv[0], ["community", "events", "help", "delegation", "notifications",
+ if (empty(DI::page()['aside']) && in_array($args->get(0), ["community", "events", "help", "delegation", "notifications",
"probe", "webfinger", "login", "invite", "credits"])) {
DI::page()['htmlhead'] .= "<link rel='stylesheet' href='view/theme/vier/hide.css' />";
}
}
}
- $result = Config::get("vier", $key);
+ $result = DI::config()->get("vier", $key);
if (!is_null($result)) {
return $result;
}
function vier_community_info()
{
- $a = DI::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);
// comunity_profiles
if ($show_profiles) {
- $r = GContact::suggestionQuery(local_user(), 0, 9);
+ $contacts = Contact\Relation::getSuggestions(local_user(), 0, 9);
$tpl = Renderer::getMarkupTemplate('ch_directory_item.tpl');
- if (DBA::isResult($r)) {
+ if (DBA::isResult($contacts)) {
$aside['$comunity_profiles_title'] = DI::l10n()->t('Community Profiles');
$aside['$comunity_profiles_items'] = [];
- foreach ($r as $rr) {
+ foreach ($contacts as $contact) {
$entry = Renderer::replaceMacros($tpl, [
- '$id' => $rr['id'],
- '$profile_link' => 'follow/?url='.urlencode($rr['url']),
- '$photo' => ProxyUtils::proxifyUrl($rr['photo'], false, ProxyUtils::SIZE_MICRO),
- '$alt_text' => $rr['name'],
+ '$id' => $contact['id'],
+ '$profile_link' => 'follow/?url='.urlencode($contact['url']),
+ '$photo' => Contact::getMicro($contact),
+ '$alt_text' => $contact['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 ";
+ $condition = ['blocked' => false];
+ if (!DI::config()->get('system', 'publish_all')) {
+ $condition['publish'] = true;
+ }
$tpl = Renderer::getMarkupTemplate('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
- );
+ $profiles = DBA::selectToArray('owner-view', [], $condition, ['order' => ['register_date' => true], 'limit' => [0, 9]]);
- if (DBA::isResult($r)) {
+ if (DBA::isResult($profiles)) {
$aside['$lastusers_title'] = DI::l10n()->t('Last users');
$aside['$lastusers_items'] = [];
- foreach ($r as $rr) {
- $profile_link = 'profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
+ foreach ($profiles as $profile) {
+ $profile_link = 'profile/' . ((strlen($profile['nickname'])) ? $profile['nickname'] : $profile['uid']);
$entry = Renderer::replaceMacros($tpl, [
- '$id' => $rr['id'],
+ '$id' => $profile['id'],
'$profile_link' => $profile_link,
- '$photo' => DI::baseUrl()->remove($rr['thumb']),
- '$alt_text' => $rr['name']]);
+ '$photo' => DI::baseUrl()->remove($profile['thumb']),
+ '$alt_text' => $profile['name']]);
$aside['$lastusers_items'][] = $entry;
}
}
//Community_Pages at right_aside
if ($show_pages && local_user()) {
- $cid = $_GET['cid'] ?? null;
-
- //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?cid=' . $contact['id'],
- 'external_url' => Contact::magicLink($contact['url']),
- 'name' => $contact['name'],
- 'cid' => $contact['id'],
- 'selected' => $selected,
- 'micro' => DI::baseUrl()->remove(ProxyUtils::proxifyUrl($contact['micro'], false, ProxyUtils::SIZE_MICRO)),
- 'id' => ++$id,
- ];
- $entries[] = $entry;
- }
-
-
- $tpl = Renderer::getMarkupTemplate('widget_forumlist_right.tpl');
-
- $page = Renderer::replaceMacros(
- $tpl,
- [
- '$title' => DI::l10n()->t('Forums'),
- '$forums' => $entries,
- '$link_desc' => DI::l10n()->t('External link to forum'),
- '$total' => $total,
- '$visible_forums' => $visible_forums,
- '$showmore' => DI::l10n()->t('show more')]
- );
-
- $aside['$page'] = $page;
- }
+ $aside['$page'] = ForumManager::widget('network/forum', local_user());;
}
// END Community Page
if ($show_helpers) {
$r = [];
- $helperlist = Config::get("vier", "helperlist");
+ $helperlist = DI::config()->get("vier", "helperlist");
$helpers = explode(",", $helperlist);
if ($helpers) {
- $query = "";
- foreach ($helpers as $index => $helper) {
- if ($query != "") {
- $query .= ",";
- }
-
- $query .= "'".DBA::escape(Strings::normaliseLink(trim($helper)))."'";
+ foreach ($helpers as $helper) {
+ $urls[] = Strings::normaliseLink(trim($helper));
}
-
- $r = q("SELECT `url`, `name` FROM `gcontact` WHERE `nurl` IN (%s)", $query);
+ $r = DBA::selectToArray('contact', ['url', 'name'], ['uid' => 0, 'nurl' => $urls]);
}
foreach ($r as $index => $helper) {
$r[] = ["photo" => "images/wordpress.png", "name" => "Wordpress"];
}
- if (function_exists("imap_open") && !Config::get("system", "imap_disabled") && !Config::get("system", "dfrn_only")) {
+ if (function_exists("imap_open") && !DI::config()->get("system", "imap_disabled") && !DI::config()->get("system", "dfrn_only")) {
$r[] = ["photo" => "images/mail.png", "name" => "E-Mail"];
}
$tpl = Renderer::getMarkupTemplate('communityhome.tpl');
DI::page()['right_aside'] = Renderer::replaceMacros($tpl, $aside);
}
+
+/**
+ * @param int|null $uid
+ * @return null
+ * @see \Friendica\Core\Theme::getBackgroundColor()
+ * @TODO Implement this function
+ */
+function vier_get_background_color(int $uid = null)
+{
+ return null;
+}
+
+/**
+ * @param int|null $uid
+ * @return null
+ * @see \Friendica\Core\Theme::getThemeColor()
+ * @TODO Implement this function
+ */
+function vier_get_theme_color(int $uid = null)
+{
+ return null;
+}