Compare commits

...

3 commits

Author SHA1 Message Date
Slava Petrov
a6b96f716a fuck conflict 2024-12-20 17:47:21 +03:00
Slava Petrov
7d6a8fbbbf feat(global): news on left menu
Co-Authored-By: Vladimir Barinov <22993408+veselcraft@users.noreply.github.com>
2024-12-20 17:45:38 +03:00
Slava Petrov
7977a84b49 added locale 2024-12-20 16:57:30 +03:00
6 changed files with 27 additions and 9 deletions

View file

@ -7,7 +7,7 @@ use Chandler\Security\Authenticator;
use Latte\Engine as TemplatingEngine; use Latte\Engine as TemplatingEngine;
use openvk\Web\Models\Entities\IP; use openvk\Web\Models\Entities\IP;
use openvk\Web\Themes\Themepacks; use openvk\Web\Themes\Themepacks;
use openvk\Web\Models\Repositories\{IPs, Users, APITokens, Tickets, Reports, CurrentUser}; use openvk\Web\Models\Repositories\{IPs, Users, APITokens, Tickets, Reports, CurrentUser, Posts};
use WhichBrowser; use WhichBrowser;
abstract class OpenVKPresenter extends SimplePresenter abstract class OpenVKPresenter extends SimplePresenter
@ -207,6 +207,17 @@ abstract class OpenVKPresenter extends SimplePresenter
$userValidated = 0; $userValidated = 0;
$cacheTime = OPENVK_ROOT_CONF["openvk"]["preferences"]["nginxCacheTime"] ?? 0; $cacheTime = OPENVK_ROOT_CONF["openvk"]["preferences"]["nginxCacheTime"] ?? 0;
if(OPENVK_ROOT_CONF['openvk']['preferences']['news']['show']) {
$post = (new Posts)->getPostsFromUsersWall(-OPENVK_ROOT_CONF['openvk']['preferences']['news']['groupId'], 1, 1);
$post = iterator_to_array($post)[0];
$text = wordwrap($post->getText(false), 150, '\n', false);
$text = explode('\n', $text)[0];
$this->template->newsText = $text;
$this->template->newsLink = '/wall' . $post->getPrettyId();
}
if(!is_null($user)) { if(!is_null($user)) {
$this->user = (object) []; $this->user = (object) [];
$this->user->raw = $user; $this->user->raw = $user;
@ -363,4 +374,4 @@ abstract class OpenVKPresenter extends SimplePresenter
return false; return false;
} }
} }
} }

View file

@ -240,12 +240,12 @@
</a> </a>
</div> </div>
<div id="news" n:if="OPENVK_ROOT_CONF['openvk']['preferences']['news']['enable']"> <div id="news" n:if="OPENVK_ROOT_CONF['openvk']['preferences']['news']['show']">
<b>{_news} </b> <b>{_news} </b>
<hr size="1"> <hr size="1">
<text>{php echo OPENVK_ROOT_CONF['openvk']['preferences']['news']['title'];}</text> <text>{$newsText}...</text>
<br><br> <br><br>
<a href="{php echo OPENVK_ROOT_CONF['openvk']['preferences']['news']['link'];}">Подробнее »</a> <a href="{$newsLink}">{_news_more}</a>
</div> </div>
<div n:if="OPENVK_ROOT_CONF['openvk']['preferences']['commerce'] && $thisUser->getCoins() != 0" id="votesBalance"> <div n:if="OPENVK_ROOT_CONF['openvk']['preferences']['commerce'] && $thisUser->getCoins() != 0" id="votesBalance">

View file

@ -2314,8 +2314,7 @@ li {
user-select: none; user-select: none;
} }
#news b #news b {
{
color: #8A0000; color: #8A0000;
font-size: 12px; font-size: 12px;
} }

View file

@ -1059,6 +1059,8 @@
"time_today" = "today"; "time_today" = "today";
"time_yesterday" = "yesterday"; "time_yesterday" = "yesterday";
"news" = "News";
"news_more" = "More »";
"points" = "Votes"; "points" = "Votes";
"points_count" = "votes"; "points_count" = "votes";
"on_your_account" = "on your account"; "on_your_account" = "on your account";

View file

@ -1010,6 +1010,9 @@
"time_minutes_ago" = "$1 минут назад"; "time_minutes_ago" = "$1 минут назад";
"time_today" = "сегодня"; "time_today" = "сегодня";
"time_yesterday" = "вчера"; "time_yesterday" = "вчера";
"news" = "Новости";
"news_more" = "Подробнее »";
"points" = "Голоса"; "points" = "Голоса";
"points_count" = "голосов"; "points_count" = "голосов";
"on_your_account" = "на вашем счету"; "on_your_account" = "на вашем счету";

View file

@ -112,6 +112,9 @@ openvk:
defaultMobileTheme: "" defaultMobileTheme: ""
defaultFeaturePhoneTheme: "" defaultFeaturePhoneTheme: ""
logs: true logs: true
news:
show: false
groupId: 1
telemetry: telemetry:
plausible: plausible: