2016-03-28 14:29:05 +00:00
< ? php
/*
* Name : frio
2016-06-13 08:57:42 +00:00
* Description : Bootstrap V3 theme . The theme is currently under construction , so it is far from finished . For further information have a look at the < a href = " https://github.com/friendica/friendica/tree/develop/view/theme/frio/README.md " > ReadMe </ a >.
2018-09-05 16:31:09 +00:00
* Version : V . 0.8 . 5
2016-03-28 14:29:05 +00:00
* Author : Rabuzarus < https :// friendica . kommune4 . de / profile / rabuzarus >
2017-01-09 12:06:08 +00:00
*
2016-03-28 14:29:05 +00:00
*/
2018-02-05 00:23:49 +00:00
2017-04-30 04:07:00 +00:00
use Friendica\App ;
2018-02-05 00:23:49 +00:00
use Friendica\Content\Text\Plaintext ;
2018-01-15 14:50:06 +00:00
use Friendica\Content\Widget ;
2018-12-26 15:06:05 +00:00
use Friendica\Core\Hook ;
2018-10-29 21:20:46 +00:00
use Friendica\Core\Logger ;
2018-10-31 17:25:38 +00:00
use Friendica\Core\Renderer ;
2019-05-26 20:15:38 +00:00
use Friendica\Core\Session ;
2018-07-21 12:40:21 +00:00
use Friendica\Database\DBA ;
2019-12-15 23:36:31 +00:00
use Friendica\DI ;
2018-10-13 09:35:51 +00:00
use Friendica\Model ;
2018-10-14 18:03:22 +00:00
use Friendica\Module ;
2018-11-08 15:14:37 +00:00
use Friendica\Util\Strings ;
2017-04-30 04:07:00 +00:00
2018-01-01 20:05:09 +00:00
function frio_init ( App $a )
{
2019-01-20 02:54:10 +00:00
global $frio ;
$frio = 'view/theme/frio' ;
2016-06-20 11:44:11 +00:00
// disable the events module link in the profile tab
$a -> theme_events_in_profile = false ;
2018-01-09 04:52:54 +00:00
$a -> videowidth = 622 ;
2016-06-20 11:44:11 +00:00
2018-10-31 17:25:38 +00:00
Renderer :: setActiveTemplateEngine ( 'smarty3' );
2016-03-28 14:29:05 +00:00
2016-05-28 11:07:24 +00:00
// if the device is a mobile device set js is_mobile
// variable so the js scripts can use this information
2019-12-16 00:12:07 +00:00
if ( DI :: mode () -> isMobile () || DI :: mode () -> isMobile ()) {
2019-12-30 19:02:09 +00:00
DI :: page ()[ 'htmlhead' ] .= <<< EOT
2017-10-20 13:21:42 +00:00
< script type = " text/javascript " >
2016-05-28 11:07:24 +00:00
var is_mobile = 1 ;
</ script >
EOT ;
2018-01-01 20:05:09 +00:00
}
2016-03-28 14:29:05 +00:00
}
2018-01-01 20:05:09 +00:00
function frio_install ()
{
2018-12-26 15:06:05 +00:00
Hook :: register ( 'prepare_body_final' , 'view/theme/frio/theme.php' , 'frio_item_photo_links' );
Hook :: register ( 'item_photo_menu' , 'view/theme/frio/theme.php' , 'frio_item_photo_menu' );
Hook :: register ( 'contact_photo_menu' , 'view/theme/frio/theme.php' , 'frio_contact_photo_menu' );
Hook :: register ( 'nav_info' , 'view/theme/frio/theme.php' , 'frio_remote_nav' );
Hook :: register ( 'acl_lookup_end' , 'view/theme/frio/theme.php' , 'frio_acl_lookup' );
Hook :: register ( 'display_item' , 'view/theme/frio/theme.php' , 'frio_display_item' );
2016-03-28 14:29:05 +00:00
2018-10-29 21:20:46 +00:00
Logger :: log ( 'installed theme frio' );
2016-03-28 14:29:05 +00:00
}
2016-04-14 12:07:20 +00:00
/**
2020-01-19 06:05:23 +00:00
* Replace friendica photo links hook
2017-01-09 12:06:08 +00:00
*
2016-04-14 12:07:20 +00:00
* This function does replace the links to photos
* of other friendica users . Original the photos are
* linked to the photo page . Now they will linked directly
* to the photo file . This function is nessesary to use colorbox
* in the network stream
2017-01-09 12:06:08 +00:00
*
* @ param App $a Unused but required by hook definition
2016-04-14 12:07:20 +00:00
* @ param array $body_info The item and its html output
*/
2017-11-29 12:52:27 +00:00
function frio_item_photo_links ( App $a , & $body_info )
{
2018-02-05 00:23:49 +00:00
$occurence = 0 ;
2018-04-25 00:12:43 +00:00
$p = Plaintext :: getBoundariesPosition ( $body_info [ 'html' ], '<a' , '>' );
2018-01-01 20:05:09 +00:00
while ( $p !== false && ( $occurence ++ < 500 )) {
2016-04-14 12:07:20 +00:00
$link = substr ( $body_info [ 'html' ], $p [ 'start' ], $p [ 'end' ] - $p [ 'start' ]);
2018-01-15 13:05:12 +00:00
$matches = [];
2016-04-14 12:07:20 +00:00
2018-04-25 00:12:43 +00:00
preg_match ( '/\/photos\/[\w]+\/image\/([\w]+)/' , $link , $matches );
2018-01-01 20:05:09 +00:00
if ( $matches ) {
2016-04-14 12:07:20 +00:00
// Replace the link for the photo's page with a direct link to the photo itself
$newlink = str_replace ( $matches [ 0 ], " /photo/ { $matches [ 1 ] } " , $link );
// Add a "quiet" parameter to any redir links to prevent the "XX welcomes YY" info boxes
2018-04-25 00:12:43 +00:00
$newlink = preg_replace ( '/href="([^"]+)\/redir\/([^"]+)&url=([^"]+)"/' , 'href="$1/redir/$2&quiet=1&url=$3"' , $newlink );
2016-04-14 12:07:20 +00:00
2018-01-01 20:05:09 +00:00
// Having any arguments to the link for Colorbox causes it to fetch base64 code instead of the image
2018-04-25 00:12:43 +00:00
$newlink = preg_replace ( '/\/[?&]zrl=([^&"]+)/' , '' , $newlink );
2016-04-14 12:07:20 +00:00
$body_info [ 'html' ] = str_replace ( $link , $newlink , $body_info [ 'html' ]);
}
2018-04-25 00:12:43 +00:00
$p = Plaintext :: getBoundariesPosition ( $body_info [ 'html' ], '<a' , '>' , $occurence );
2016-04-14 12:07:20 +00:00
}
}
2016-04-16 22:55:43 +00:00
/**
2020-01-19 06:05:23 +00:00
* Replace links of the item_photo_menu hook
2017-01-09 12:06:08 +00:00
*
2016-04-16 22:55:43 +00:00
* This function replaces the original poke and the message links
* to call the addToModal javascript function so this pages can
* be loaded in a bootstrap modal
2017-01-09 12:06:08 +00:00
*
* @ param App $a Unused but required by the hook definition
2016-04-16 22:55:43 +00:00
* @ param array $arr Contains item data and the original photo_menu
*/
2018-01-01 20:05:09 +00:00
function frio_item_photo_menu ( App $a , & $arr )
{
2018-04-25 00:12:43 +00:00
foreach ( $arr [ 'menu' ] as $k => $v ) {
2020-04-20 15:42:27 +00:00
if ( strpos ( $v , '/poke' ) === 0 || strpos ( $v , 'message/new/' ) === 0 ) {
2018-04-25 00:12:43 +00:00
$v = 'javascript:addToModal(\'' . $v . '\'); return false;' ;
$arr [ 'menu' ][ $k ] = $v ;
2016-04-16 22:55:43 +00:00
}
}
}
2016-04-19 00:06:02 +00:00
2016-04-20 17:32:19 +00:00
/**
2020-01-19 06:05:23 +00:00
* Replace links of the contact_photo_menu
2017-01-09 12:06:08 +00:00
*
2016-04-20 17:32:19 +00:00
* This function replaces the original poke and the message links
* to call the addToModal javascript function so this pages can
* be loaded in a bootstrap modal
2016-04-20 17:59:44 +00:00
* Additionally the profile , status and photo page links will be changed
* to don ' t open in a new tab if the contact is a friendica contact .
2017-01-09 12:06:08 +00:00
*
2017-04-30 04:17:49 +00:00
* @ param App $a The app data
2016-04-20 17:32:19 +00:00
* @ param array $args Contains contact data and the original photo_menu
*/
2018-01-01 20:05:09 +00:00
function frio_contact_photo_menu ( App $a , & $args )
{
2018-04-25 00:12:43 +00:00
$cid = $args [ 'contact' ][ 'id' ];
2018-08-25 13:48:00 +00:00
if ( ! empty ( $args [ 'menu' ][ 'poke' ])) {
$pokelink = $args [ 'menu' ][ 'poke' ][ 1 ];
} else {
$pokelink = '' ;
}
if ( ! empty ( $args [ 'menu' ][ 'poke' ])) {
$pmlink = $args [ 'menu' ][ 'pm' ][ 1 ];
} else {
$pmlink = '' ;
}
2016-04-20 17:32:19 +00:00
2016-04-20 17:59:44 +00:00
// Set the the indicator for opening the status, profile and photo pages
// in a new tab to false if the contact a dfrn (friendica) contact
// We do this because we can go back on foreign friendica pages throuhg
// friendicas "magic-link" which indicates a friendica user on froreign
// friendica servers as remote user or visitor
//
2017-01-09 12:06:08 +00:00
// The value for opening in a new tab is e.g. when
2018-04-25 00:12:43 +00:00
// $args['menu']['status'][2] is true. If the value of the [2] key is true
2016-04-20 17:59:44 +00:00
// and if it's a friendica contact we set it to false
2018-04-25 00:12:43 +00:00
foreach ( $args [ 'menu' ] as $k => $v ) {
if ( $k === 'status' || $k === 'profile' || $k === 'photos' ) {
$v [ 2 ] = (( $args [ 'contact' ][ 'network' ] === 'dfrn' ) ? false : true );
$args [ 'menu' ][ $k ][ 2 ] = $v [ 2 ];
2016-04-20 17:59:44 +00:00
}
}
2016-04-20 17:32:19 +00:00
// Add to pm and poke links a new key with the value 'modal'.
// Later we can make conditions in the corresponing templates (e.g.
// contact_template.tpl)
2020-04-20 15:42:27 +00:00
if ( strpos ( $pokelink , $cid . '/poke' ) !== false ) {
2018-04-25 00:12:43 +00:00
$args [ 'menu' ][ 'poke' ][ 3 ] = 'modal' ;
2018-01-01 20:05:09 +00:00
}
2016-04-20 17:32:19 +00:00
2018-01-01 20:05:09 +00:00
if ( strpos ( $pmlink , 'message/new/' . $cid ) !== false ) {
2018-04-25 00:12:43 +00:00
$args [ 'menu' ][ 'pm' ][ 3 ] = 'modal' ;
2018-01-01 20:05:09 +00:00
}
2016-04-20 17:32:19 +00:00
}
2016-04-19 00:06:02 +00:00
/**
2020-01-19 06:05:23 +00:00
* Construct remote nav menu
2017-01-09 12:06:08 +00:00
*
2016-04-19 00:06:02 +00:00
* It creates a remote baseurl form $_SESSION for remote users and friendica
2017-01-09 12:06:08 +00:00
* visitors . This url will be added to some of the nav links . With this behaviour
2016-04-19 00:06:02 +00:00
* the user will come back to her / his own pages on his / her friendica server .
* Not all possible links are available ( notifications , administrator , manage ,
* notes aren ' t available because we have no way the check remote permissions ) ..
* Some links will point to the local pages because the user would expect
* local page ( these pages are : search , community , help , apps , directory ) .
2017-01-09 12:06:08 +00:00
*
2017-04-30 04:17:49 +00:00
* @ param App $a The App class
2016-04-19 00:06:02 +00:00
* @ param array $nav The original nav menu
*/
2018-01-01 20:05:09 +00:00
function frio_remote_nav ( $a , & $nav )
{
2016-04-19 00:06:02 +00:00
// get the homelink from $_XSESSION
2018-10-13 09:35:51 +00:00
$homelink = Model\Profile :: getMyURL ();
2018-01-01 20:05:09 +00:00
if ( ! $homelink ) {
2019-05-26 20:15:38 +00:00
$homelink = Session :: get ( 'visitor_home' , '' );
2018-01-01 20:05:09 +00:00
}
2016-04-19 00:06:02 +00:00
// split up the url in it's parts (protocol,domain/directory, /profile/, nickname
// I'm not familiar with regex, so someone might find a better solutionen
2017-01-09 12:06:08 +00:00
//
2016-04-19 00:06:02 +00:00
// E.g $homelink = 'https://friendica.domain.com/profile/mickey' should result in an array
// with 0 => 'https://friendica.domain.com/profile/mickey' 1 => 'https://',
// 2 => 'friendica.domain.com' 3 => '/profile/' 4 => 'mickey'
2017-01-09 12:06:08 +00:00
//
2016-04-19 00:06:02 +00:00
//$server_url = preg_match('/^(https?:\/\/.*?)\/profile\//2', $homelink);
preg_match ( '/^(https?:\/\/)?(.*?)(\/profile\/)(.*)/' , $homelink , $url_parts );
// Construct the server url of the visitor. So we could link back to his/her own menu.
// And construct a webbie (e.g. mickey@friendica.domain.com for the search in gcontact
// We use the webbie for search in gcontact because we don't know if gcontact table stores
// the right value if its http or https protocol
2018-02-14 05:07:26 +00:00
$webbie = '' ;
2018-01-01 20:05:09 +00:00
if ( count ( $url_parts )) {
2016-04-19 00:06:02 +00:00
$server_url = $url_parts [ 1 ] . $url_parts [ 2 ];
$webbie = $url_parts [ 4 ] . '@' . $url_parts [ 2 ];
}
// since $userinfo isn't available for the hook we write it to the nav array
// this isn't optimal because the contact query will be done now twice
2020-07-09 19:08:09 +00:00
if ( local_user () && ! empty ( $a -> user [ 'uid' ])) {
2016-04-19 00:06:02 +00:00
// empty the server url for local user because we won't need it
$server_url = '' ;
// user info
2017-01-09 09:37:37 +00:00
$r = q ( " SELECT `micro` FROM `contact` WHERE `uid` = %d AND `self` " , intval ( $a -> user [ 'uid' ]));
2017-01-09 12:06:08 +00:00
2019-12-15 23:36:31 +00:00
$r [ 0 ][ 'photo' ] = ( DBA :: isResult ( $r ) ? DI :: baseUrl () -> remove ( $r [ 0 ][ 'micro' ]) : 'images/person-48.jpg' );
2016-04-19 00:06:02 +00:00
$r [ 0 ][ 'name' ] = $a -> user [ 'username' ];
2017-08-03 05:50:44 +00:00
} elseif ( ! local_user () && remote_user ()) {
2016-04-19 00:06:02 +00:00
$r = q ( " SELECT `name`, `nick`, `micro` AS `photo` FROM `contact` WHERE `id` = %d " , intval ( remote_user ()));
2020-01-18 19:52:34 +00:00
$nav [ 'remote' ] = DI :: l10n () -> t ( 'Guest' );
2018-10-13 09:35:51 +00:00
} elseif ( Model\Profile :: getMyURL ()) {
2016-04-19 00:06:02 +00:00
$r = q ( " SELECT `name`, `nick`, `photo` FROM `gcontact`
WHERE `addr` = '%s' AND `network` = 'dfrn' " ,
2018-07-21 13:10:13 +00:00
DBA :: escape ( $webbie ));
2020-01-18 19:52:34 +00:00
$nav [ 'remote' ] = DI :: l10n () -> t ( 'Visitor' );
2017-08-03 05:50:44 +00:00
} else {
$r = false ;
2016-04-19 00:06:02 +00:00
}
2019-01-27 12:21:18 +00:00
$remoteUser = null ;
2018-07-21 12:46:04 +00:00
if ( DBA :: isResult ( $r )) {
2018-01-15 13:05:12 +00:00
$nav [ 'userinfo' ] = [
2018-07-21 12:46:04 +00:00
'icon' => ( DBA :: isResult ( $r ) ? $r [ 0 ][ 'photo' ] : 'images/person-48.jpg' ),
2018-01-01 20:05:09 +00:00
'name' => $r [ 0 ][ 'name' ],
2018-01-15 13:05:12 +00:00
];
2019-01-27 12:21:18 +00:00
$remoteUser = $r [ 0 ];
2018-01-01 20:05:09 +00:00
}
2016-04-19 00:06:02 +00:00
2019-01-27 12:21:18 +00:00
if ( ! local_user () && ! empty ( $server_url ) && ! is_null ( $remoteUser )) {
2016-04-19 00:06:02 +00:00
// user menu
2020-01-18 19:52:34 +00:00
$nav [ 'usermenu' ][] = [ $server_url . '/profile/' . $remoteUser [ 'nick' ], DI :: l10n () -> t ( 'Status' ), '' , DI :: l10n () -> t ( 'Your posts and conversations' )];
2020-01-28 00:21:18 +00:00
$nav [ 'usermenu' ][] = [ $server_url . '/profile/' . $remoteUser [ 'nick' ] . '/profile' , DI :: l10n () -> t ( 'Profile' ), '' , DI :: l10n () -> t ( 'Your profile page' )];
2020-01-18 19:52:34 +00:00
$nav [ 'usermenu' ][] = [ $server_url . '/photos/' . $remoteUser [ 'nick' ], DI :: l10n () -> t ( 'Photos' ), '' , DI :: l10n () -> t ( 'Your photos' )];
$nav [ 'usermenu' ][] = [ $server_url . '/videos/' . $remoteUser [ 'nick' ], DI :: l10n () -> t ( 'Videos' ), '' , DI :: l10n () -> t ( 'Your videos' )];
$nav [ 'usermenu' ][] = [ $server_url . '/events/' , DI :: l10n () -> t ( 'Events' ), '' , DI :: l10n () -> t ( 'Your events' )];
2016-04-19 00:06:02 +00:00
// navbar links
2020-01-18 19:52:34 +00:00
$nav [ 'network' ] = [ $server_url . '/network' , DI :: l10n () -> t ( 'Network' ), '' , DI :: l10n () -> t ( 'Conversations from your friends' )];
$nav [ 'events' ] = [ $server_url . '/events' , DI :: l10n () -> t ( 'Events' ), '' , DI :: l10n () -> t ( 'Events and Calendar' )];
$nav [ 'messages' ] = [ $server_url . '/message' , DI :: l10n () -> t ( 'Messages' ), '' , DI :: l10n () -> t ( 'Private mail' )];
$nav [ 'settings' ] = [ $server_url . '/settings' , DI :: l10n () -> t ( 'Settings' ), '' , DI :: l10n () -> t ( 'Account settings' )];
$nav [ 'contacts' ] = [ $server_url . '/contact' , DI :: l10n () -> t ( 'Contacts' ), '' , DI :: l10n () -> t ( 'Manage/edit friends and contacts' )];
2020-01-19 20:21:13 +00:00
$nav [ 'sitename' ] = DI :: config () -> get ( 'config' , 'sitename' );
2016-04-19 00:06:02 +00:00
}
}
2018-01-01 20:05:09 +00:00
2016-04-28 19:35:33 +00:00
/**
2020-01-19 20:44:01 +00:00
* Search for contacts
2017-01-09 12:06:08 +00:00
*
2016-04-28 19:35:33 +00:00
* This function search for a users contacts . The code is copied from contact search
2018-10-13 11:29:56 +00:00
* in / src / Module / Contact . php . With this function the contacts will permitted to acl_lookup ()
2017-01-09 12:06:08 +00:00
* and can grabbed as json . For this we use the type = " r " . This is usful to to let js
2016-04-28 19:35:33 +00:00
* grab the contact data .
* We use this to give the data to textcomplete and have a filter function at the
* contact page .
2017-01-09 12:06:08 +00:00
*
2016-12-20 20:16:01 +00:00
* @ param App $a The app data @ TODO Unused
2016-04-28 19:35:33 +00:00
* @ param array $results The array with the originals from acl_lookup ()
*/
2018-01-01 20:05:09 +00:00
function frio_acl_lookup ( App $a , & $results )
{
2018-11-30 14:06:22 +00:00
$nets = ! empty ( $_GET [ 'nets' ]) ? Strings :: escapeTags ( trim ( $_GET [ 'nets' ])) : '' ;
2016-04-28 19:35:33 +00:00
// we introduce a new search type, r should do the same query like it's
2018-10-13 11:29:56 +00:00
// done in /src/Module/Contact.php for connections
2018-04-25 00:12:43 +00:00
if ( $results [ 'type' ] !== 'r' ) {
2018-01-21 17:39:47 +00:00
return ;
}
2016-04-28 19:35:33 +00:00
2018-02-14 05:07:26 +00:00
$sql_extra = '' ;
2018-04-25 00:12:43 +00:00
if ( $results [ 'search' ]) {
2018-11-08 15:30:45 +00:00
$search_txt = DBA :: escape ( Strings :: protectSprintf ( preg_quote ( $results [ 'search' ])));
2018-07-21 13:10:13 +00:00
$sql_extra .= " AND (`attag` LIKE '%% " . $search_txt . " %%' OR `name` LIKE '%% " . $search_txt . " %%' OR `nick` LIKE '%% " . $search_txt . " %%') " ;
2018-01-21 17:39:47 +00:00
}
2016-04-28 19:35:33 +00:00
2018-01-21 17:39:47 +00:00
if ( $nets ) {
2018-07-21 13:10:13 +00:00
$sql_extra .= sprintf ( " AND network = '%s' " , DBA :: escape ( $nets ));
2018-01-21 17:39:47 +00:00
}
2016-04-28 19:35:33 +00:00
2018-02-14 05:07:26 +00:00
$total = 0 ;
2018-01-21 17:39:47 +00:00
$r = q ( " SELECT COUNT(*) AS `total` FROM `contact`
2019-01-12 13:28:14 +00:00
WHERE `uid` = % d AND NOT `self` AND NOT `deleted` AND NOT `pending` $sql_extra " , intval( $_SESSION['uid'] ));
2018-07-21 12:46:04 +00:00
if ( DBA :: isResult ( $r )) {
2018-04-25 00:12:43 +00:00
$total = $r [ 0 ][ 'total' ];
2018-01-21 17:39:47 +00:00
}
2016-04-28 19:35:33 +00:00
2018-01-21 17:39:47 +00:00
$sql_extra3 = Widget :: unavailableNetworks ();
2016-04-28 19:35:33 +00:00
2019-01-12 13:28:14 +00:00
$r = q ( " SELECT * FROM `contact` WHERE `uid` = %d AND NOT `self` AND NOT `deleted` AND NOT `pending` $sql_extra $sql_extra3 ORDER BY `name` ASC LIMIT %d, %d " ,
2018-01-21 17:39:47 +00:00
intval ( $_SESSION [ 'uid' ]), intval ( $results [ 'start' ]), intval ( $results [ 'count' ])
);
2016-04-28 19:35:33 +00:00
2018-01-21 17:39:47 +00:00
$contacts = [];
2016-04-28 19:35:33 +00:00
2018-07-21 12:46:04 +00:00
if ( DBA :: isResult ( $r )) {
2018-01-21 17:39:47 +00:00
foreach ( $r as $rr ) {
2018-10-14 18:03:22 +00:00
$contacts [] = Module\Contact :: getContactTemplateVars ( $rr );
2018-01-21 17:39:47 +00:00
}
2016-04-28 19:35:33 +00:00
}
2018-01-21 17:39:47 +00:00
2018-04-25 00:12:43 +00:00
$results [ 'items' ] = $contacts ;
$results [ 'tot' ] = $total ;
2016-06-25 10:21:13 +00:00
}
2017-08-02 13:52:11 +00:00
/**
2020-01-19 06:05:23 +00:00
* Manipulate the data of the item
2018-01-01 20:05:09 +00:00
*
2017-08-02 13:52:11 +00:00
* At the moment we use this function to add some own stuff to the item menu
2018-01-01 20:05:09 +00:00
*
2017-08-02 13:52:11 +00:00
* @ param App $a App $a The app data
* @ param array $arr Array with the item and the item actions < br >
* 'item' => Array with item data < br >
* 'output' => Array with item actions < br >
*/
2018-01-01 20:05:09 +00:00
function frio_display_item ( App $a , & $arr )
{
2017-08-02 13:52:11 +00:00
// Add subthread to the item menu
2018-01-15 13:05:12 +00:00
$subthread = [];
2018-06-19 16:27:54 +00:00
if (
local_user ()
&& local_user () == $arr [ 'item' ][ 'uid' ]
2020-05-28 16:02:36 +00:00
&& $arr [ 'item' ][ 'gravity' ] == GRAVITY_PARENT
2018-06-19 16:27:54 +00:00
&& ! $arr [ 'item' ][ 'self' ])
{
2018-01-15 13:05:12 +00:00
$subthread = [
2017-08-02 13:52:11 +00:00
'menu' => 'follow_thread' ,
2020-01-18 19:52:34 +00:00
'title' => DI :: l10n () -> t ( 'Follow Thread' ),
2020-03-05 07:16:47 +00:00
'action' => 'dosubthread(' . $arr [ 'item' ][ 'id' ] . ');' ,
2017-08-02 13:52:11 +00:00
'href' => '#'
2018-01-15 13:05:12 +00:00
];
2017-08-02 13:52:11 +00:00
}
$arr [ 'output' ][ 'subthread' ] = $subthread ;
}
2020-02-19 15:28:57 +00:00
/**
* @ param int | null $uid
* @ return string
* @ see \Friendica\Core\Theme :: getBackgroundColor ()
*/
function frio_get_background_color ( int $uid = null )
{
$background_color = DI :: config () -> get ( 'frio' , 'background_color' ) ? : '#ededed' ;
if ( $uid ) {
$background_color = DI :: pConfig () -> get ( $uid , 'frio' , 'background_color' ) ? : $background_color ;
}
$scheme = DI :: config () -> get ( 'frio' , 'scheme' , DI :: config () -> get ( 'frio' , 'schema' ));
$scheme = Strings :: sanitizeFilePathItem ( $scheme );
if ( $scheme && ( $scheme != '---' ) && file_exists ( 'view/theme/frio/scheme/' . $scheme . '.php' )) {
$schemefile = 'view/theme/frio/scheme/' . $scheme . '.php' ;
require_once $schemefile ;
}
return $background_color ;
}
/**
* @ param int | null $uid
* @ return string
* @ see \Friendica\Core\Theme :: getThemeColor ()
*/
function frio_get_theme_color ( int $uid = null )
{
$nav_bg = DI :: config () -> get ( 'frio' , 'nav_bg' ) ? : '#708fa0' ;
if ( $uid ) {
$nav_bg = DI :: pConfig () -> get ( $uid , 'frio' , 'background_color' ) ? : $nav_bg ;
}
$scheme = DI :: config () -> get ( 'frio' , 'scheme' , DI :: config () -> get ( 'frio' , 'schema' ));
$scheme = Strings :: sanitizeFilePathItem ( $scheme );
if ( $scheme && ( $scheme != '---' ) && file_exists ( 'view/theme/frio/scheme/' . $scheme . '.php' )) {
$schemefile = 'view/theme/frio/scheme/' . $scheme . '.php' ;
require_once $schemefile ;
}
return $nav_bg ;
}