Merge branch 'master', remote-tracking branch 'remotes/upstream/master'
* remotes/upstream/master: diabook-themes: more improvements in theme.php, add titles to bbcode under coment-box diabook-theme: tryied to improve performance a bit diabook-theme: fix footer/impressum missing param provide "service_class" identifier which will let us provide service_class limits such as number of FB friends, etc. delineate the new profile changes from the rest of the text how did that happen? shuffle results of remote_common_friends widget only validate once perform basic validation * master:
This commit is contained in:
commit
02dc116a9c
11
boot.php
11
boot.php
|
@ -11,7 +11,7 @@ require_once('include/cache.php');
|
||||||
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
||||||
define ( 'FRIENDICA_VERSION', '2.3.1329' );
|
define ( 'FRIENDICA_VERSION', '2.3.1329' );
|
||||||
define ( 'DFRN_PROTOCOL_VERSION', '2.23' );
|
define ( 'DFRN_PROTOCOL_VERSION', '2.23' );
|
||||||
define ( 'DB_UPDATE_VERSION', 1142 );
|
define ( 'DB_UPDATE_VERSION', 1143 );
|
||||||
|
|
||||||
define ( 'EOL', "<br />\r\n" );
|
define ( 'EOL', "<br />\r\n" );
|
||||||
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
||||||
|
@ -1520,9 +1520,12 @@ function get_my_url() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function zrl_init(&$a) {
|
function zrl_init(&$a) {
|
||||||
proc_run('php','include/gprobe.php',bin2hex(get_my_url()));
|
$tmp_str = get_my_url();
|
||||||
$arr = array('zrl' => get_my_url(), 'url' => $a->cmd);
|
if(validate_url($tmp_str)) {
|
||||||
call_hooks('zrl_init',$arr);
|
proc_run('php','include/gprobe.php',bin2hex($tmp_str));
|
||||||
|
$arr = array('zrl' => $tmp_str, 'url' => $a->cmd);
|
||||||
|
call_hooks('zrl_init',$arr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function zrl($s,$force = false) {
|
function zrl($s,$force = false) {
|
||||||
|
|
|
@ -1027,6 +1027,7 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
`account_expired` tinyint(1) NOT NULL DEFAULT '0',
|
`account_expired` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`account_expires_on` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`account_expires_on` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
`expire_notification_sent` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`expire_notification_sent` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
|
`service_class` char(32) NOT NULL,
|
||||||
`allow_cid` mediumtext NOT NULL,
|
`allow_cid` mediumtext NOT NULL,
|
||||||
`allow_gid` mediumtext NOT NULL,
|
`allow_gid` mediumtext NOT NULL,
|
||||||
`deny_cid` mediumtext NOT NULL,
|
`deny_cid` mediumtext NOT NULL,
|
||||||
|
@ -1042,7 +1043,8 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
KEY `verified` (`verified`),
|
KEY `verified` (`verified`),
|
||||||
KEY `unkmail` (`unkmail`),
|
KEY `unkmail` (`unkmail`),
|
||||||
KEY `cntunkmail` (`cntunkmail`),
|
KEY `cntunkmail` (`cntunkmail`),
|
||||||
KEY `account_removed` (`account_removed`)
|
KEY `account_removed` (`account_removed`),
|
||||||
|
KEY `service_class` (`service_class`)
|
||||||
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
-- --------------------------------------------------------
|
-- --------------------------------------------------------
|
||||||
|
|
|
@ -146,11 +146,19 @@ function common_friends_visitor_widget($profile_uid) {
|
||||||
$cid = local_user();
|
$cid = local_user();
|
||||||
else {
|
else {
|
||||||
if(get_my_url()) {
|
if(get_my_url()) {
|
||||||
$r = q("select id from gcontact where nurl = '%s' limit 1",
|
$r = q("select id from contact where nurl = '%s' and uid = %d limit 1",
|
||||||
dbesc(normalise_link(get_my_url()))
|
dbesc(normalise_link(get_my_url())),
|
||||||
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
if(count($r))
|
if(count($r))
|
||||||
$zcid = $r[0]['id'];
|
$cid = $r[0]['id'];
|
||||||
|
else {
|
||||||
|
$r = q("select id from gcontact where nurl = '%s' limit 1",
|
||||||
|
dbesc(normalise_link(get_my_url()))
|
||||||
|
);
|
||||||
|
if(count($r))
|
||||||
|
$zcid = $r[0]['id'];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,14 +170,14 @@ function common_friends_visitor_widget($profile_uid) {
|
||||||
if($cid)
|
if($cid)
|
||||||
$t = count_common_friends($profile_uid,$cid);
|
$t = count_common_friends($profile_uid,$cid);
|
||||||
else
|
else
|
||||||
$t = count_common_friends($profile_uid,$cid);
|
$t = count_common_friends_zcid($profile_uid,$zcid);
|
||||||
if(! $t)
|
if(! $t)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if($cid)
|
if($cid)
|
||||||
$r = common_friends($profile_uid,$cid,5);
|
$r = common_friends($profile_uid,$cid,5,true);
|
||||||
else
|
else
|
||||||
$r = common_friends_zcid($profile_uid,$zcid);
|
$r = common_friends_zcid($profile_uid,$zcid,5,true);
|
||||||
|
|
||||||
return replace_macros(get_markup_template('remote_friends_common.tpl'), array(
|
return replace_macros(get_markup_template('remote_friends_common.tpl'), array(
|
||||||
'$desc' => sprintf( tt("%d friend in common", "%d friends in common", $t), $t),
|
'$desc' => sprintf( tt("%d friend in common", "%d friends in common", $t), $t),
|
||||||
|
|
|
@ -182,13 +182,18 @@ function count_common_friends($uid,$cid) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function common_friends($uid,$cid,$limit=9999) {
|
function common_friends($uid,$cid,$limit=9999,$shuffle = false) {
|
||||||
|
|
||||||
|
if($shuffle)
|
||||||
|
$sql_extra = " order by rand() ";
|
||||||
|
else
|
||||||
|
$sql_extra = " order by `gcontact`.`name` asc ";
|
||||||
|
|
||||||
$r = q("SELECT `gcontact`.*
|
$r = q("SELECT `gcontact`.*
|
||||||
FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id`
|
FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id`
|
||||||
where `glink`.`cid` = %d and `glink`.`uid` = %d
|
where `glink`.`cid` = %d and `glink`.`uid` = %d
|
||||||
and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and id != %d )
|
and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and id != %d )
|
||||||
order by `gcontact`.`name` asc limit 0, %d",
|
sql_extra limit 0, %d",
|
||||||
intval($cid),
|
intval($cid),
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($uid),
|
intval($uid),
|
||||||
|
@ -217,13 +222,18 @@ function count_common_friends_zcid($uid,$zcid) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function common_friends_zcid($uid,$zcid,$limit = 6) {
|
function common_friends_zcid($uid,$zcid,$limit = 9999,$shuffle) {
|
||||||
|
|
||||||
|
if($shuffle)
|
||||||
|
$sql_extra = " order by rand() ";
|
||||||
|
else
|
||||||
|
$sql_extra = " order by `gcontact`.`name` asc ";
|
||||||
|
|
||||||
$r = q("SELECT `gcontact`.*
|
$r = q("SELECT `gcontact`.*
|
||||||
FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id`
|
FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id`
|
||||||
where `glink`.`zcid` = %d
|
where `glink`.`zcid` = %d
|
||||||
and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 )
|
and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 )
|
||||||
order by `gcontact`.`name` asc limit 0, %d",
|
$sql_extra limit 0, %d",
|
||||||
intval($zcid),
|
intval($zcid),
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($limit)
|
intval($limit)
|
||||||
|
|
|
@ -328,7 +328,7 @@ function profile_activity($changed, $value) {
|
||||||
$prof = '[url=' . $self[0]['url'] . '?tab=profile' . ']' . t('public profile') . '[/url]';
|
$prof = '[url=' . $self[0]['url'] . '?tab=profile' . ']' . t('public profile') . '[/url]';
|
||||||
|
|
||||||
if($t == 1 && strlen($value)) {
|
if($t == 1 && strlen($value)) {
|
||||||
$message = sprintf( t('%1$s changed %2$s to %3$s'), $A, $changes, $value);
|
$message = sprintf( t('%1$s changed %2$s to "%3$s"'), $A, $changes, $value);
|
||||||
$message .= "\n\n" . sprintf( t(' - Visit %1$s\'s %2$s'), $A, $prof);
|
$message .= "\n\n" . sprintf( t(' - Visit %1$s\'s %2$s'), $A, $prof);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
11
update.php
11
update.php
|
@ -1,6 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
define( 'UPDATE_VERSION' , 1142 );
|
define( 'UPDATE_VERSION' , 1143 );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -1239,3 +1239,12 @@ function update_1141() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function update_1142() {
|
||||||
|
$r = q("alter table user add service_class char(32) not null after expire_notification_sent, add index(service_class) ");
|
||||||
|
if(! $r)
|
||||||
|
return UPDATE_FAILED ;
|
||||||
|
return UPDATE_SUCCESS ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,101 @@
|
||||||
|
<script type="text/javascript" src="$baseurl/view/theme/diabook/js/jquery.autogrow.textarea.js"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
});
|
||||||
|
function tautogrow(id){
|
||||||
|
$("textarea#comment-edit-text-" +id).autogrow();
|
||||||
|
};
|
||||||
|
$(document).ready(function() {
|
||||||
|
$("iframe").each(function(){
|
||||||
|
var ifr_source = $(this).attr("src");
|
||||||
|
var wmode = "wmode=transparent";
|
||||||
|
if(ifr_source.indexOf("?") != -1) {
|
||||||
|
var getQString = ifr_source.split("?");
|
||||||
|
var oldString = getQString[1];
|
||||||
|
var newString = getQString[0];
|
||||||
|
$(this).attr("src",newString+"?"+wmode+"&"+oldString);
|
||||||
|
}
|
||||||
|
else $(this).attr("src",ifr_source+"?"+wmode);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
function yt_iframe() {
|
||||||
|
|
||||||
|
$("iframe").load(function() {
|
||||||
|
var ifr_src = $(this).contents().find("body iframe").attr("src");
|
||||||
|
$("iframe").contents().find("body iframe").attr("src", ifr_src+"&wmode=transparent");
|
||||||
|
});
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
function scrolldown(){
|
||||||
|
$("html, body").animate({scrollTop:$(document).height()}, "slow");
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
function scrolltop(){
|
||||||
|
$("html, body").animate({scrollTop:0}, "slow");
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
$(window).scroll(function () {
|
||||||
|
|
||||||
|
var footer_top = $(document).height() - 30;
|
||||||
|
$("div#footerbox").css("top", footer_top);
|
||||||
|
|
||||||
|
var scrollInfo = $(window).scrollTop();
|
||||||
|
|
||||||
|
if (scrollInfo <= "900"){
|
||||||
|
$("a#top").attr("id","down");
|
||||||
|
$("a#down").attr("onclick","scrolldown()");
|
||||||
|
$("img#scroll_top_bottom").attr("src","view/theme/diabook/icons/scroll_bottom.png");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (scrollInfo > "900"){
|
||||||
|
$("a#down").attr("id","top");
|
||||||
|
$("a#top").attr("onclick","scrolltop()");
|
||||||
|
$("img#scroll_top_bottom").attr("src","view/theme/diabook/icons/scroll_top.png");
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
function insertFormatting(comment,BBcode,id) {
|
||||||
|
|
||||||
|
var tmpStr = $("#comment-edit-text-" + id).val();
|
||||||
|
if(tmpStr == comment) {
|
||||||
|
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();
|
||||||
|
if (BBcode == "url"){
|
||||||
|
selected.text = "["+BBcode+"]" + "http://" + selected.text + "[/"+BBcode+"]";
|
||||||
|
} else
|
||||||
|
selected.text = "["+BBcode+"]" + selected.text + "[/"+BBcode+"]";
|
||||||
|
} else if (textarea.selectionStart || textarea.selectionStart == "0") {
|
||||||
|
var start = textarea.selectionStart;
|
||||||
|
var end = textarea.selectionEnd;
|
||||||
|
if (BBcode == "url"){
|
||||||
|
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + "http://" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
|
||||||
|
} else
|
||||||
|
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
function cmtBbOpen(id) {
|
||||||
|
$(".comment-edit-bb-" + id).show();
|
||||||
|
}
|
||||||
|
function cmtBbClose(id) {
|
||||||
|
$(".comment-edit-bb-" + id).hide();
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -13,13 +13,13 @@
|
||||||
<div class="comment-edit-photo-end"></div>
|
<div class="comment-edit-photo-end"></div>
|
||||||
<textarea id="comment-edit-text-$id" class="comment-edit-text-empty" name="body" onFocus="commentOpen(this,$id);tautogrow($id);cmtBbOpen($id);" >$comment</textarea>
|
<textarea id="comment-edit-text-$id" class="comment-edit-text-empty" name="body" onFocus="commentOpen(this,$id);tautogrow($id);cmtBbOpen($id);" >$comment</textarea>
|
||||||
<div class="comment-edit-bb-$id" style="display:none;">
|
<div class="comment-edit-bb-$id" style="display:none;">
|
||||||
<a class="icon bb-image" style="cursor: pointer;" onclick="insertFormatting('$comment','img',$id);">img</a>
|
<a class="icon bb-image" style="cursor: pointer;" title="$edimg" onclick="insertFormatting('$comment','img',$id);">img</a>
|
||||||
<a class="icon bb-url" style="cursor: pointer;" onclick="insertFormatting('$comment','url',$id);">url</a>
|
<a class="icon bb-url" style="cursor: pointer;" title="$edurl" onclick="insertFormatting('$comment','url',$id);">url</a>
|
||||||
<a class="icon bb-video" style="cursor: pointer;" onclick="insertFormatting('$comment','video',$id);">video</a>
|
<a class="icon bb-video" style="cursor: pointer;" title="$edvideo" onclick="insertFormatting('$comment','video',$id);">video</a>
|
||||||
<a class="icon underline" style="cursor: pointer;" onclick="insertFormatting('$comment','u',$id);">u</a>
|
<a class="icon underline" style="cursor: pointer;" title="$eduline" onclick="insertFormatting('$comment','u',$id);">u</a>
|
||||||
<a class="icon italic" style="cursor: pointer;" onclick="insertFormatting('$comment','i',$id);">i</a>
|
<a class="icon italic" style="cursor: pointer;" title="$editalic" onclick="insertFormatting('$comment','i',$id);">i</a>
|
||||||
<a class="icon bold" style="cursor: pointer;" onclick="insertFormatting('$comment','b',$id);">b</a>
|
<a class="icon bold" style="cursor: pointer;" title="$edbold" onclick="insertFormatting('$comment','b',$id);">b</a>
|
||||||
<a class="icon quote" style="cursor: pointer;" onclick="insertFormatting('$comment','quote',$id);">quote</a>
|
<a class="icon quote" style="cursor: pointer;" title="$edquote" onclick="insertFormatting('$comment','quote',$id);">quote</a>
|
||||||
</div>
|
</div>
|
||||||
{{ if $qcomment }}
|
{{ if $qcomment }}
|
||||||
<select id="qcomment-select-$id" name="qcomment-$id" class="qcomment" onchange="qCommentInsert(this,$id);" >
|
<select id="qcomment-select-$id" name="qcomment-$id" class="qcomment" onchange="qCommentInsert(this,$id);" >
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="close_helpers">
|
<div id="close_helpers">
|
||||||
{{ if $lastusers_title }}
|
{{ if $helpers }}
|
||||||
<h3>$helpers.title.1<a id="close_helpers_icon" onClick="close_helpers()" class="icon close_box" title="close"></a></h3>
|
<h3>$helpers.title.1<a id="close_helpers_icon" onClick="close_helpers()" class="icon close_box" title="close"></a></h3>
|
||||||
<a href="http://kakste.com/profile/newhere" title="@NewHere" style="margin-left: 10px; " target="blank">NewHere</a><br>
|
<a href="http://kakste.com/profile/newhere" title="@NewHere" style="margin-left: 10px; " target="blank">NewHere</a><br>
|
||||||
<a href="https://helpers.pyxis.uberspace.de/profile/helpers" style="margin-left: 10px; " title="Friendica Support" target="blank">Friendica Support</a><br>
|
<a href="https://helpers.pyxis.uberspace.de/profile/helpers" style="margin-left: 10px; " title="Friendica Support" target="blank">Friendica Support</a><br>
|
||||||
|
@ -26,7 +26,7 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="close_services">
|
<div id="close_services">
|
||||||
{{ if $lastusers_title }}
|
{{ if $con_services }}
|
||||||
<h3>$con_services.title.1<a id="close_services_icon" onClick="close_services()" class="icon close_box" title="close"></a></h3>
|
<h3>$con_services.title.1<a id="close_services_icon" onClick="close_services()" class="icon close_box" title="close"></a></h3>
|
||||||
<div id="right_service_icons" style="margin-left: 16px; margin-top: 5px;">
|
<div id="right_service_icons" style="margin-left: 16px; margin-top: 5px;">
|
||||||
<a href="$url/facebook"><img alt="Facebook" src="view/theme/diabook/icons/facebook.png" title="Facebook"></a>
|
<a href="$url/facebook"><img alt="Facebook" src="view/theme/diabook/icons/facebook.png" title="Facebook"></a>
|
||||||
|
|
|
@ -202,7 +202,7 @@
|
||||||
// default styling
|
// default styling
|
||||||
a: { textDecoration: 'none', color: '#3B5998' },
|
a: { textDecoration: 'none', color: '#3B5998' },
|
||||||
bird: { width: '50px', height: '20px', position: 'absolute', left: '-30px', top: '-20px', border: 'none' },
|
bird: { width: '50px', height: '20px', position: 'absolute', left: '-30px', top: '-20px', border: 'none' },
|
||||||
container: { overflow: 'hidden', backgroundColor: '', height: '360px' },
|
container: { overflow: 'hidden', backgroundColor: '', height: '600px' },
|
||||||
fail: { background: '#6cc5c3 url(http://cloud.github.com/downloads/malsup/twitter/failwhale.png) no-repeat 50% 50%', height: '100%', padding: '10px' },
|
fail: { background: '#6cc5c3 url(http://cloud.github.com/downloads/malsup/twitter/failwhale.png) no-repeat 50% 50%', height: '100%', padding: '10px' },
|
||||||
frame: { border: '0px solid #C2CFF1', borderRadius: '0px', '-moz-border-radius': '0px', '-webkit-border-radius': '0px' },
|
frame: { border: '0px solid #C2CFF1', borderRadius: '0px', '-moz-border-radius': '0px', '-webkit-border-radius': '0px' },
|
||||||
tweet: { padding: '5px 10px', clear: 'left' },
|
tweet: { padding: '5px 10px', clear: 'left' },
|
||||||
|
|
|
@ -3,13 +3,20 @@
|
||||||
/*
|
/*
|
||||||
* Name: Diabook
|
* Name: Diabook
|
||||||
* Description: Diabook: report bugs and request here: http://pad.toktan.org/p/diabook or contact me : thomas_bierey@friendica.eu
|
* Description: Diabook: report bugs and request here: http://pad.toktan.org/p/diabook or contact me : thomas_bierey@friendica.eu
|
||||||
* Version: (Version: 1.024)
|
* Version: (Version: 1.025)
|
||||||
* Author:
|
* Author:
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
$a = get_app();
|
||||||
|
$a->theme_info = array(
|
||||||
|
'family' => 'diabook',
|
||||||
|
'version' => '1.025'
|
||||||
|
);
|
||||||
|
|
||||||
|
function diabook_init(&$a) {
|
||||||
|
|
||||||
//print diabook-version for debugging
|
//print diabook-version for debugging
|
||||||
$diabook_version = "Diabook (Version: 1.024)";
|
$diabook_version = "Diabook (Version: 1.025)";
|
||||||
$a->page['htmlhead'] .= sprintf('<script "%s" ></script>', $diabook_version);
|
$a->page['htmlhead'] .= sprintf('<script "%s" ></script>', $diabook_version);
|
||||||
|
|
||||||
//change css on network and profilepages
|
//change css on network and profilepages
|
||||||
|
@ -34,228 +41,8 @@ if ($color=="green") $color_path = "/diabook-green/";
|
||||||
if ($color=="dark") $color_path = "/diabook-dark/";
|
if ($color=="dark") $color_path = "/diabook-dark/";
|
||||||
|
|
||||||
|
|
||||||
/**
|
//profile_side at networkpages
|
||||||
* prints last community activity
|
if ($a->argv[0] === "network" && local_user()){
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function diabook_community_info(){
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
|
|
||||||
// comunity_profiles
|
|
||||||
$aside['$comunity_profilest_title'] = t('Community Profiles');
|
|
||||||
$aside['$comunity_profiles_items'] = array();
|
|
||||||
$r = q("select gcontact.* from gcontact left join glink on glink.gcid = gcontact.id
|
|
||||||
where glink.cid = 0 and glink.uid = 0 order by rand() limit 9");
|
|
||||||
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
|
||||||
if(count($r)) {
|
|
||||||
$photo = 'photo';
|
|
||||||
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' => zrl($rr['url']),
|
|
||||||
'$photo' => $rr[$photo],
|
|
||||||
'$alt-text' => $rr['name'],
|
|
||||||
));
|
|
||||||
$aside['$comunity_profiles_items'][] = $entry;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// last 12 users
|
|
||||||
$aside['$lastusers_title'] = t('Last users');
|
|
||||||
$aside['$lastusers_items'] = array();
|
|
||||||
$sql_extra = "";
|
|
||||||
$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 $sql_extra $order LIMIT %d , %d ",
|
|
||||||
0,
|
|
||||||
9
|
|
||||||
);
|
|
||||||
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
|
||||||
if(count($r)) {
|
|
||||||
$photo = 'thumb';
|
|
||||||
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' => $rr[$photo],
|
|
||||||
'$alt-text' => $rr['name'],
|
|
||||||
));
|
|
||||||
$aside['$lastusers_items'][] = $entry;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// last 10 liked items
|
|
||||||
$aside['$like_title'] = t('Last likes');
|
|
||||||
$aside['$like_items'] = array();
|
|
||||||
$r = q("SELECT `T1`.`created`, `T1`.`liker`, `T1`.`liker-link`, `item`.* FROM
|
|
||||||
(SELECT `parent-uri`, `created`, `author-name` AS `liker`,`author-link` AS `liker-link`
|
|
||||||
FROM `item` WHERE `verb`='http://activitystrea.ms/schema/1.0/like' GROUP BY `parent-uri` ORDER BY `created` DESC) AS T1
|
|
||||||
INNER JOIN `item` ON `item`.`uri`=`T1`.`parent-uri`
|
|
||||||
WHERE `T1`.`liker-link` LIKE '%s%%' OR `item`.`author-link` LIKE '%s%%'
|
|
||||||
GROUP BY `uri`
|
|
||||||
ORDER BY `T1`.`created` DESC
|
|
||||||
LIMIT 0,5",
|
|
||||||
$a->get_baseurl(),$a->get_baseurl()
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($r as $rr) {
|
|
||||||
$author = '<a href="' . $rr['liker-link'] . '">' . $rr['liker'] . '</a>';
|
|
||||||
$objauthor = '<a href="' . $rr['author-link'] . '">' . $rr['author-name'] . '</a>';
|
|
||||||
|
|
||||||
//var_dump($rr['verb'],$rr['object-type']); killme();
|
|
||||||
switch($rr['verb']){
|
|
||||||
case 'http://activitystrea.ms/schema/1.0/post':
|
|
||||||
switch ($rr['object-type']){
|
|
||||||
case 'http://activitystrea.ms/schema/1.0/event':
|
|
||||||
$post_type = t('event');
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$post_type = t('status');
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if ($rr['resource-id']){
|
|
||||||
$post_type = t('photo');
|
|
||||||
$m=array(); preg_match("/\[url=([^]]*)\]/", $rr['body'], $m);
|
|
||||||
$rr['plink'] = $m[1];
|
|
||||||
} else {
|
|
||||||
$post_type = t('status');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$plink = '<a href="' . $rr['plink'] . '">' . $post_type . '</a>';
|
|
||||||
|
|
||||||
$aside['$like_items'][] = sprintf( t('%1$s likes %2$s\'s %3$s'), $author, $objauthor, $plink);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// last 12 photos
|
|
||||||
$aside['$photos_title'] = t('Last photos');
|
|
||||||
$aside['$photos_items'] = array();
|
|
||||||
$r = q("SELECT `photo`.`id`, `photo`.`resource-id`, `photo`.`scale`, `photo`.`desc`, `user`.`nickname`, `user`.`username` FROM
|
|
||||||
(SELECT `resource-id`, MAX(`scale`) as maxscale FROM `photo`
|
|
||||||
WHERE `profile`=0 AND `contact-id`=0 AND `album` NOT IN ('Contact Photos', '%s', 'Profile Photos', '%s')
|
|
||||||
AND `allow_cid`='' AND `allow_gid`='' AND `deny_cid`='' AND `deny_gid`='' GROUP BY `resource-id`) AS `t1`
|
|
||||||
INNER JOIN `photo` ON `photo`.`resource-id`=`t1`.`resource-id` AND `photo`.`scale` = `t1`.`maxscale`,
|
|
||||||
`user`
|
|
||||||
WHERE `user`.`uid` = `photo`.`uid`
|
|
||||||
AND `user`.`blockwall`=0
|
|
||||||
AND `user`.`hidewall`=0
|
|
||||||
ORDER BY `photo`.`edited` DESC
|
|
||||||
LIMIT 0, 9",
|
|
||||||
dbesc(t('Contact Photos')),
|
|
||||||
dbesc(t('Profile Photos'))
|
|
||||||
);
|
|
||||||
if(count($r)) {
|
|
||||||
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
|
||||||
foreach($r as $rr) {
|
|
||||||
$photo_page = $a->get_baseurl() . '/photos/' . $rr['nickname'] . '/image/' . $rr['resource-id'];
|
|
||||||
$photo_url = $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['scale'] .'.jpg';
|
|
||||||
|
|
||||||
$entry = replace_macros($tpl,array(
|
|
||||||
'$id' => $rr['id'],
|
|
||||||
'$profile-link' => $photo_page,
|
|
||||||
'$photo' => $photo_url,
|
|
||||||
'$alt-text' => $rr['username']." : ".$rr['desc'],
|
|
||||||
));
|
|
||||||
|
|
||||||
$aside['$photos_items'][] = $entry;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//right_aside FIND FRIENDS
|
|
||||||
if(local_user()) {
|
|
||||||
$nv = array();
|
|
||||||
$nv['title'] = Array("", t('Find Friends'), "", "");
|
|
||||||
$nv['directory'] = Array('directory', t('Local Directory'), "", "");
|
|
||||||
$nv['global_directory'] = Array('http://dir.friendica.com/', 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="http://dir.friendika.com/directory">
|
|
||||||
<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 Page
|
|
||||||
if(local_user()) {
|
|
||||||
$page = '<div id="" >
|
|
||||||
<h3 style="margin-top:0px;">'.t("Community Pages").'<a id="close_pages_icon" onClick="close_pages()" class="icon close_box" title="close"></a></h3></div>
|
|
||||||
<div id=""><ul style="margin-left: 7px;margin-top: 0px;padding-left: 0px;padding-top: 0px;">';
|
|
||||||
|
|
||||||
$pagelist = array();
|
|
||||||
|
|
||||||
$contacts = q("SELECT `id`, `url`, `name`, `micro`FROM `contact`
|
|
||||||
WHERE `network`= 'dfrn' AND `forum` = 1 AND `uid` = %d
|
|
||||||
ORDER BY `name` ASC",
|
|
||||||
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;
|
|
||||||
|
|
||||||
foreach($contacts as $contact) {
|
|
||||||
$page .= '<li style="list-style-type: none;" class="tool"><img height="20" width="20" style="float: left; margin-right: 3px;" src="' . $contact['micro'] .'" alt="' . $contact['url'] . '" /> <a href="'.$a->get_baseurl().'/redir/'.$contact["id"].'" style="margin-top: 2px; word-wrap: break-word; width: 132px;" title="' . $contact['url'] . '" class="label" target="external-link">'.
|
|
||||||
$contact["name"]."</a></li>";
|
|
||||||
}
|
|
||||||
$page .= '</ul></div></div>';
|
|
||||||
//if (sizeof($contacts) > 0)
|
|
||||||
|
|
||||||
$aside['$page'] = $page;
|
|
||||||
}
|
|
||||||
//END Community Page
|
|
||||||
//helpers
|
|
||||||
$helpers = array();
|
|
||||||
$helpers['title'] = Array("", t('Help or @NewHere ?'), "", "");
|
|
||||||
|
|
||||||
$aside['$helpers'] = $helpers;
|
|
||||||
//end helpers
|
|
||||||
//connectable services
|
|
||||||
$con_services = array();
|
|
||||||
$con_services['title'] = Array("", t('Connect Services'), "", "");
|
|
||||||
|
|
||||||
$aside['$con_services'] = $con_services;
|
|
||||||
//end connectable services
|
|
||||||
|
|
||||||
|
|
||||||
//get_baseurl
|
|
||||||
$url = $a->get_baseurl($ssl_state);
|
|
||||||
$aside['$url'] = $url;
|
|
||||||
|
|
||||||
$tpl = file_get_contents(dirname(__file__).'/communityhome.tpl');
|
|
||||||
$a->page['right_aside'] = replace_macros($tpl, $aside);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//profile_side at networkpages
|
|
||||||
if ($a->argv[0] === "network" && local_user()){
|
|
||||||
|
|
||||||
// USER MENU
|
// USER MENU
|
||||||
if(local_user()) {
|
if(local_user()) {
|
||||||
|
@ -278,10 +65,10 @@ if ($a->argv[0] === "network" && local_user()){
|
||||||
|
|
||||||
$tpl = get_markup_template('profile_side.tpl');
|
$tpl = get_markup_template('profile_side.tpl');
|
||||||
|
|
||||||
$a->page['aside'] .= replace_macros($tpl, array(
|
$a->page['aside'] = replace_macros($tpl, array(
|
||||||
'$userinfo' => $userinfo,
|
'$userinfo' => $userinfo,
|
||||||
'$ps' => $ps,
|
'$ps' => $ps,
|
||||||
));
|
)).$a->page['aside'];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,12 +82,12 @@ if ($a->argv[0] === "network" && local_user()){
|
||||||
if($resolution == "normal") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-network.css";}
|
if($resolution == "normal") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-network.css";}
|
||||||
if($resolution == "wide") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-network-wide.css";}
|
if($resolution == "wide") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-network-wide.css";}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//right_aside at profile pages
|
//right_aside at profile pages
|
||||||
if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname']){
|
if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname']){
|
||||||
if($ccCookie != "9") {
|
if($ccCookie != "9") {
|
||||||
// COMMUNITY
|
// COMMUNITY
|
||||||
diabook_community_info();
|
diabook_community_info();
|
||||||
|
@ -310,155 +97,78 @@ if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname']){
|
||||||
if($resolution == "wide") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-profile-wide.css";}
|
if($resolution == "wide") {$cssFile = $a->get_baseurl($ssl_state)."/view/theme/diabook".$color_path."style-profile-wide.css";}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// custom css
|
|
||||||
if (!is_null($cssFile)) $a->page['htmlhead'] .= sprintf('<link rel="stylesheet" type="text/css" href="%s" />', $cssFile);
|
|
||||||
|
|
||||||
//footer
|
|
||||||
$tpl = get_markup_template('footer.tpl');
|
|
||||||
$a->page['footer'] .= replace_macros($tpl, array());
|
|
||||||
|
|
||||||
//load jquery.cookie.js
|
|
||||||
$cookieJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.cookie.js";
|
|
||||||
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s"></script>', $cookieJS);
|
|
||||||
|
|
||||||
//load jquery.ae.image.resize.js
|
|
||||||
$imageresizeJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.ae.image.resize.js";
|
|
||||||
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s" ></script>', $imageresizeJS);
|
|
||||||
|
|
||||||
//load jquery.autogrow-textarea.js
|
|
||||||
$autogrowJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.autogrow.textarea.js";
|
|
||||||
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s" ></script>', $autogrowJS);
|
|
||||||
|
|
||||||
//load jquery.twitter.search.js
|
|
||||||
$twitterJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.twitter.search.js";
|
|
||||||
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s" ></script>', $twitterJS);
|
|
||||||
|
|
||||||
//js scripts
|
|
||||||
|
|
||||||
//check if community_home-plugin is activated and change css
|
|
||||||
$nametocheck = "communityhome";
|
|
||||||
$r = q("select id from addon where name = '%s' and installed = 1", dbesc($nametocheck));
|
|
||||||
if(count($r) == "1") {
|
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '
|
//js scripts
|
||||||
<script>
|
//load jquery.cookie.js
|
||||||
$(document).ready(function() {
|
$cookieJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.cookie.js";
|
||||||
|
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s"></script>', $cookieJS);
|
||||||
|
|
||||||
|
//load jquery.ae.image.resize.js
|
||||||
|
$imageresizeJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.ae.image.resize.js";
|
||||||
|
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s" ></script>', $imageresizeJS);
|
||||||
|
|
||||||
|
//load jquery.twitter.search.js
|
||||||
|
if($_COOKIE['close_twitter'] != "1") {
|
||||||
|
$twitterJS = $a->get_baseurl($ssl_state)."/view/theme/diabook/js/jquery.twitter.search.js";
|
||||||
|
$a->page['htmlhead'] .= sprintf('<script language="JavaScript" src="%s" ></script>', $twitterJS);
|
||||||
|
}
|
||||||
|
|
||||||
|
$a->page['htmlhead'] .= '
|
||||||
|
<script>
|
||||||
|
|
||||||
|
$(function() {
|
||||||
|
$("a.lightbox").fancybox(); // Select all links with lightbox class
|
||||||
|
});
|
||||||
|
|
||||||
|
$(window).load(function() {
|
||||||
|
var footer_top = $(document).height() - 30;
|
||||||
|
$("div#footerbox").attr("style", "border-top: 1px solid #D2D2D2; width: 70%;right: 15%;position: absolute;top:"+footer_top+"px;");
|
||||||
|
});
|
||||||
|
</script>';
|
||||||
|
|
||||||
|
//check if twitterbox is active and print
|
||||||
|
if($_COOKIE['close_twitter'] != "1") {
|
||||||
|
$a->page['htmlhead'] .= '
|
||||||
|
<script>
|
||||||
|
$(function() {
|
||||||
|
$("#twitter").twitterSearch({
|
||||||
|
term: "friendica",
|
||||||
|
animInSpeed: 250,
|
||||||
|
bird: false,
|
||||||
|
avatar: false,
|
||||||
|
colorExterior: "#fff",
|
||||||
|
title: "Last Tweets",
|
||||||
|
timeout: 10000 });
|
||||||
|
});
|
||||||
|
</script>';}
|
||||||
|
|
||||||
|
//check if community_home-plugin is activated and change css
|
||||||
|
$nametocheck = "communityhome";
|
||||||
|
$r = q("select id from addon where name = '%s' and installed = 1", dbesc($nametocheck));
|
||||||
|
if(count($r) == "1") {
|
||||||
|
|
||||||
|
$a->page['htmlhead'] .= '
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
$("div#login-submit-wrapper").attr("style","padding-top: 120px;");
|
$("div#login-submit-wrapper").attr("style","padding-top: 120px;");
|
||||||
});
|
});
|
||||||
</script>';
|
</script>';
|
||||||
}
|
}
|
||||||
|
//comment-edit-wrapper on photo_view
|
||||||
//comment-edit-wrapper on photo_view
|
if ($a->argv[0].$a->argv[2] === "photos"."image"){
|
||||||
if ($a->argv[0].$a->argv[2] === "photos"."image"){
|
$a->page['htmlhead'] .= '
|
||||||
|
<script>
|
||||||
$a->page['htmlhead'] .= '
|
$(function(){
|
||||||
<script>
|
|
||||||
$(function(){
|
|
||||||
|
|
||||||
$(".comment-edit-form").css("display","table");
|
$(".comment-edit-form").css("display","table");
|
||||||
|
|
||||||
});
|
});
|
||||||
</script>';
|
</script>';
|
||||||
}
|
}
|
||||||
|
//restore right hand col at settingspage
|
||||||
$a->page['htmlhead'] .= '
|
if($a->argv[0] === "settings" && local_user()) {
|
||||||
|
$a->page['htmlhead'] .= '
|
||||||
<script>
|
<script>
|
||||||
|
function restore_boxes(){
|
||||||
$(function() {
|
|
||||||
$("a.lightbox").fancybox(); // Select all links with lightbox class
|
|
||||||
$("#twitter").twitterSearch({
|
|
||||||
term: "friendica",
|
|
||||||
animInSpeed: 250,
|
|
||||||
bird: false,
|
|
||||||
avatar: false,
|
|
||||||
colorExterior: "#fff",
|
|
||||||
title: "Last Tweets",
|
|
||||||
timeout: 10000 });
|
|
||||||
});
|
|
||||||
|
|
||||||
$(window).load(function() {
|
|
||||||
var footer_top = $(document).height() - 30;
|
|
||||||
$("div#footerbox").attr("style", "border-top: 1px solid #D2D2D2; width: 70%;right: 15%;position: absolute;top:"+footer_top+"px;");
|
|
||||||
});
|
|
||||||
</script>';
|
|
||||||
|
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
|
||||||
|
|
||||||
function tautogrow(id){
|
|
||||||
$("textarea#comment-edit-text-" +id).autogrow();
|
|
||||||
};
|
|
||||||
</script>';
|
|
||||||
|
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '
|
|
||||||
<script>
|
|
||||||
|
|
||||||
$(document).ready(function() {
|
|
||||||
$("iframe").each(function(){
|
|
||||||
var ifr_source = $(this).attr("src");
|
|
||||||
var wmode = "wmode=transparent";
|
|
||||||
if(ifr_source.indexOf("?") != -1) {
|
|
||||||
var getQString = ifr_source.split("?");
|
|
||||||
var oldString = getQString[1];
|
|
||||||
var newString = getQString[0];
|
|
||||||
$(this).attr("src",newString+"?"+wmode+"&"+oldString);
|
|
||||||
}
|
|
||||||
else $(this).attr("src",ifr_source+"?"+wmode);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
function yt_iframe() {
|
|
||||||
|
|
||||||
$("iframe").load(function() {
|
|
||||||
var ifr_src = $(this).contents().find("body iframe").attr("src");
|
|
||||||
$("iframe").contents().find("body iframe").attr("src", ifr_src+"&wmode=transparent");
|
|
||||||
});
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
function scrolldown(){
|
|
||||||
$("html, body").animate({scrollTop:$(document).height()}, "slow");
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
|
|
||||||
function scrolltop(){
|
|
||||||
$("html, body").animate({scrollTop:0}, "slow");
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
|
|
||||||
$(window).scroll(function () {
|
|
||||||
|
|
||||||
|
|
||||||
var scrollInfo = $(window).scrollTop();
|
|
||||||
|
|
||||||
if (scrollInfo <= "900"){
|
|
||||||
$("a#top").attr("id","down");
|
|
||||||
$("a#down").attr("onclick","scrolldown()");
|
|
||||||
$("img#scroll_top_bottom").attr("src","view/theme/diabook/icons/scroll_bottom.png");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (scrollInfo > "900"){
|
|
||||||
$("a#down").attr("id","top");
|
|
||||||
$("a#top").attr("onclick","scrolltop()");
|
|
||||||
$("img#scroll_top_bottom").attr("src","view/theme/diabook/icons/scroll_top.png");
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
</script>';
|
|
||||||
|
|
||||||
if($a->argv[0] === "settings" && local_user()) {
|
|
||||||
$a->page['htmlhead'] .= '
|
|
||||||
<script>
|
|
||||||
function restore_boxes(){
|
|
||||||
$.cookie("close_pages","2", { expires: 365, path: "/" });
|
$.cookie("close_pages","2", { expires: 365, path: "/" });
|
||||||
$.cookie("close_helpers","2", { expires: 365, path: "/" });
|
$.cookie("close_helpers","2", { expires: 365, path: "/" });
|
||||||
$.cookie("close_profiles","2", { expires: 365, path: "/" });
|
$.cookie("close_profiles","2", { expires: 365, path: "/" });
|
||||||
|
@ -469,25 +179,22 @@ function restore_boxes(){
|
||||||
$.cookie("close_lastphotos","2", { expires: 365, path: "/" });
|
$.cookie("close_lastphotos","2", { expires: 365, path: "/" });
|
||||||
$.cookie("close_lastlikes","2", { expires: 365, path: "/" });
|
$.cookie("close_lastlikes","2", { expires: 365, path: "/" });
|
||||||
alert("Right-hand column was restored. Please refresh your browser");
|
alert("Right-hand column was restored. Please refresh your browser");
|
||||||
}
|
}
|
||||||
</script>';}
|
</script>';}
|
||||||
|
|
||||||
|
if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname'] or $a->argv[0] === "network" && local_user()){
|
||||||
|
$a->page['htmlhead'] .= '
|
||||||
|
<script>
|
||||||
|
|
||||||
|
$(function() {
|
||||||
|
|
||||||
if ($a->argv[0].$a->argv[1] === "profile".$a->user['nickname'] or $a->argv[0] === "network" && local_user()){
|
|
||||||
$a->page['htmlhead'] .= '
|
|
||||||
<script>
|
|
||||||
|
|
||||||
$(function() {
|
|
||||||
$(".oembed.photo img").aeImageResize({height: 400, width: 400});
|
$(".oembed.photo img").aeImageResize({height: 400, width: 400});
|
||||||
});
|
});
|
||||||
</script>';
|
</script>';
|
||||||
|
|
||||||
|
|
||||||
if($ccCookie != "9") {
|
if($ccCookie != "9") {
|
||||||
$a->page['htmlhead'] .= '
|
$a->page['htmlhead'] .= '
|
||||||
<script>
|
<script>
|
||||||
$("right_aside").ready(function(){
|
$("right_aside").ready(function(){
|
||||||
|
|
||||||
if($.cookie("close_pages") == "1")
|
if($.cookie("close_pages") == "1")
|
||||||
{
|
{
|
||||||
|
@ -534,91 +241,297 @@ $("right_aside").ready(function(){
|
||||||
document.getElementById( "close_lastlikes" ).style.display = "none";
|
document.getElementById( "close_lastlikes" ).style.display = "none";
|
||||||
};}
|
};}
|
||||||
|
|
||||||
);
|
);
|
||||||
|
|
||||||
function close_pages(){
|
function close_pages(){
|
||||||
document.getElementById( "close_pages" ).style.display = "none";
|
document.getElementById( "close_pages" ).style.display = "none";
|
||||||
$.cookie("close_pages","1", { expires: 365, path: "/" });
|
$.cookie("close_pages","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_profiles(){
|
function close_profiles(){
|
||||||
document.getElementById( "close_profiles" ).style.display = "none";
|
document.getElementById( "close_profiles" ).style.display = "none";
|
||||||
$.cookie("close_profiles","1", { expires: 365, path: "/" });
|
$.cookie("close_profiles","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_helpers(){
|
function close_helpers(){
|
||||||
document.getElementById( "close_helpers" ).style.display = "none";
|
document.getElementById( "close_helpers" ).style.display = "none";
|
||||||
$.cookie("close_helpers","1", { expires: 365, path: "/" });
|
$.cookie("close_helpers","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_services(){
|
function close_services(){
|
||||||
document.getElementById( "close_services" ).style.display = "none";
|
document.getElementById( "close_services" ).style.display = "none";
|
||||||
$.cookie("close_services","1", { expires: 365, path: "/" });
|
$.cookie("close_services","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_friends(){
|
function close_friends(){
|
||||||
document.getElementById( "close_friends" ).style.display = "none";
|
document.getElementById( "close_friends" ).style.display = "none";
|
||||||
$.cookie("close_friends","1", { expires: 365, path: "/" });
|
$.cookie("close_friends","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_twitter(){
|
function close_twitter(){
|
||||||
document.getElementById( "twitter" ).style.display = "none";
|
document.getElementById( "twitter" ).style.display = "none";
|
||||||
$.cookie("close_twitter","1", { expires: 365, path: "/" });
|
$.cookie("close_twitter","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_lastusers(){
|
function close_lastusers(){
|
||||||
document.getElementById( "close_lastusers" ).style.display = "none";
|
document.getElementById( "close_lastusers" ).style.display = "none";
|
||||||
$.cookie("close_lastusers","1", { expires: 365, path: "/" });
|
$.cookie("close_lastusers","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_lastphotos(){
|
function close_lastphotos(){
|
||||||
document.getElementById( "close_lastphotos" ).style.display = "none";
|
document.getElementById( "close_lastphotos" ).style.display = "none";
|
||||||
$.cookie("close_lastphotos","1", { expires: 365, path: "/" });
|
$.cookie("close_lastphotos","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
|
|
||||||
function close_lastlikes(){
|
function close_lastlikes(){
|
||||||
document.getElementById( "close_lastlikes" ).style.display = "none";
|
document.getElementById( "close_lastlikes" ).style.display = "none";
|
||||||
$.cookie("close_lastlikes","1", { expires: 365, path: "/" });
|
$.cookie("close_lastlikes","1", { expires: 365, path: "/" });
|
||||||
};
|
};
|
||||||
</script>';}}
|
</script>';}
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '
|
|
||||||
|
|
||||||
<script>
|
|
||||||
function insertFormatting(comment,BBcode,id) {
|
|
||||||
|
|
||||||
var tmpStr = $("#comment-edit-text-" + id).val();
|
|
||||||
if(tmpStr == comment) {
|
|
||||||
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();
|
|
||||||
if (BBcode == "url"){
|
|
||||||
selected.text = "["+BBcode+"]" + "http://" + selected.text + "[/"+BBcode+"]";
|
|
||||||
} else
|
|
||||||
selected.text = "["+BBcode+"]" + selected.text + "[/"+BBcode+"]";
|
|
||||||
} else if (textarea.selectionStart || textarea.selectionStart == "0") {
|
|
||||||
var start = textarea.selectionStart;
|
|
||||||
var end = textarea.selectionEnd;
|
|
||||||
if (BBcode == "url"){
|
|
||||||
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + "http://" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
|
|
||||||
} else
|
|
||||||
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
|
|
||||||
}
|
}
|
||||||
return true;
|
//end js scripts
|
||||||
|
|
||||||
|
// custom css
|
||||||
|
if (!is_null($cssFile)) $a->page['htmlhead'] .= sprintf('<link rel="stylesheet" type="text/css" href="%s" />', $cssFile);
|
||||||
|
|
||||||
|
//footer
|
||||||
|
$tpl = get_markup_template('footer.tpl');
|
||||||
|
$a->page['footer'] .= replace_macros($tpl, array());
|
||||||
|
|
||||||
|
//
|
||||||
|
js_in_foot();
|
||||||
}
|
}
|
||||||
|
|
||||||
function cmtBbOpen(id) {
|
|
||||||
$(".comment-edit-bb-" + id).show();
|
|
||||||
}
|
|
||||||
function cmtBbClose(id) {
|
|
||||||
$(".comment-edit-bb-" + id).hide();
|
|
||||||
}
|
|
||||||
|
|
||||||
</script> ';
|
function diabook_community_info() {
|
||||||
|
$a = get_app();
|
||||||
|
// comunity_profiles
|
||||||
|
if($_COOKIE['close_profiles'] != "1") {
|
||||||
|
$aside['$comunity_profilest_title'] = t('Community Profiles');
|
||||||
|
$aside['$comunity_profiles_items'] = array();
|
||||||
|
$r = q("select gcontact.* from gcontact left join glink on glink.gcid = gcontact.id
|
||||||
|
where glink.cid = 0 and glink.uid = 0 order by rand() limit 9");
|
||||||
|
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
||||||
|
if(count($r)) {
|
||||||
|
$photo = 'photo';
|
||||||
|
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' => zrl($rr['url']),
|
||||||
|
'$photo' => $rr[$photo],
|
||||||
|
'$alt-text' => $rr['name'],
|
||||||
|
));
|
||||||
|
$aside['$comunity_profiles_items'][] = $entry;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
// last 12 users
|
||||||
|
if($_COOKIE['close_lastusers'] != "1") {
|
||||||
|
$aside['$lastusers_title'] = t('Last users');
|
||||||
|
$aside['$lastusers_items'] = array();
|
||||||
|
$sql_extra = "";
|
||||||
|
$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 $sql_extra $order LIMIT %d , %d ",
|
||||||
|
0,
|
||||||
|
9
|
||||||
|
);
|
||||||
|
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
||||||
|
if(count($r)) {
|
||||||
|
$photo = 'thumb';
|
||||||
|
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' => $rr[$photo],
|
||||||
|
'$alt-text' => $rr['name'],
|
||||||
|
));
|
||||||
|
$aside['$lastusers_items'][] = $entry;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
// last 10 liked items
|
||||||
|
if($_COOKIE['close_lastlikes'] != "1") {
|
||||||
|
$aside['$like_title'] = t('Last likes');
|
||||||
|
$aside['$like_items'] = array();
|
||||||
|
$r = q("SELECT `T1`.`created`, `T1`.`liker`, `T1`.`liker-link`, `item`.* FROM
|
||||||
|
(SELECT `parent-uri`, `created`, `author-name` AS `liker`,`author-link` AS `liker-link`
|
||||||
|
FROM `item` WHERE `verb`='http://activitystrea.ms/schema/1.0/like' GROUP BY `parent-uri` ORDER BY `created` DESC) AS T1
|
||||||
|
INNER JOIN `item` ON `item`.`uri`=`T1`.`parent-uri`
|
||||||
|
WHERE `T1`.`liker-link` LIKE '%s%%' OR `item`.`author-link` LIKE '%s%%'
|
||||||
|
GROUP BY `uri`
|
||||||
|
ORDER BY `T1`.`created` DESC
|
||||||
|
LIMIT 0,5",
|
||||||
|
$a->get_baseurl(),$a->get_baseurl()
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach ($r as $rr) {
|
||||||
|
$author = '<a href="' . $rr['liker-link'] . '">' . $rr['liker'] . '</a>';
|
||||||
|
$objauthor = '<a href="' . $rr['author-link'] . '">' . $rr['author-name'] . '</a>';
|
||||||
|
|
||||||
|
//var_dump($rr['verb'],$rr['object-type']); killme();
|
||||||
|
switch($rr['verb']){
|
||||||
|
case 'http://activitystrea.ms/schema/1.0/post':
|
||||||
|
switch ($rr['object-type']){
|
||||||
|
case 'http://activitystrea.ms/schema/1.0/event':
|
||||||
|
$post_type = t('event');
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$post_type = t('status');
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if ($rr['resource-id']){
|
||||||
|
$post_type = t('photo');
|
||||||
|
$m=array(); preg_match("/\[url=([^]]*)\]/", $rr['body'], $m);
|
||||||
|
$rr['plink'] = $m[1];
|
||||||
|
} else {
|
||||||
|
$post_type = t('status');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$plink = '<a href="' . $rr['plink'] . '">' . $post_type . '</a>';
|
||||||
|
|
||||||
|
$aside['$like_items'][] = sprintf( t('%1$s likes %2$s\'s %3$s'), $author, $objauthor, $plink);
|
||||||
|
|
||||||
|
}}
|
||||||
|
|
||||||
|
// last 12 photos
|
||||||
|
if($_COOKIE['close_photos'] != "1") {
|
||||||
|
$aside['$photos_title'] = t('Last photos');
|
||||||
|
$aside['$photos_items'] = array();
|
||||||
|
$r = q("SELECT `photo`.`id`, `photo`.`resource-id`, `photo`.`scale`, `photo`.`desc`, `user`.`nickname`, `user`.`username` FROM
|
||||||
|
(SELECT `resource-id`, MAX(`scale`) as maxscale FROM `photo`
|
||||||
|
WHERE `profile`=0 AND `contact-id`=0 AND `album` NOT IN ('Contact Photos', '%s', 'Profile Photos', '%s')
|
||||||
|
AND `allow_cid`='' AND `allow_gid`='' AND `deny_cid`='' AND `deny_gid`='' GROUP BY `resource-id`) AS `t1`
|
||||||
|
INNER JOIN `photo` ON `photo`.`resource-id`=`t1`.`resource-id` AND `photo`.`scale` = `t1`.`maxscale`,
|
||||||
|
`user`
|
||||||
|
WHERE `user`.`uid` = `photo`.`uid`
|
||||||
|
AND `user`.`blockwall`=0
|
||||||
|
AND `user`.`hidewall`=0
|
||||||
|
ORDER BY `photo`.`edited` DESC
|
||||||
|
LIMIT 0, 9",
|
||||||
|
dbesc(t('Contact Photos')),
|
||||||
|
dbesc(t('Profile Photos'))
|
||||||
|
);
|
||||||
|
if(count($r)) {
|
||||||
|
$tpl = file_get_contents( dirname(__file__).'/ch_directory_item.tpl');
|
||||||
|
foreach($r as $rr) {
|
||||||
|
$photo_page = $a->get_baseurl() . '/photos/' . $rr['nickname'] . '/image/' . $rr['resource-id'];
|
||||||
|
$photo_url = $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['scale'] .'.jpg';
|
||||||
|
|
||||||
|
$entry = replace_macros($tpl,array(
|
||||||
|
'$id' => $rr['id'],
|
||||||
|
'$profile-link' => $photo_page,
|
||||||
|
'$photo' => $photo_url,
|
||||||
|
'$alt-text' => $rr['username']." : ".$rr['desc'],
|
||||||
|
));
|
||||||
|
|
||||||
|
$aside['$photos_items'][] = $entry;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
//right_aside FIND FRIENDS
|
||||||
|
if($_COOKIE['close_friends'] != "1") {
|
||||||
|
if(local_user()) {
|
||||||
|
$nv = array();
|
||||||
|
$nv['title'] = Array("", t('Find Friends'), "", "");
|
||||||
|
$nv['directory'] = Array('directory', t('Local Directory'), "", "");
|
||||||
|
$nv['global_directory'] = Array('http://dir.friendica.com/', 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="http://dir.friendika.com/directory">
|
||||||
|
<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($_COOKIE['close_pages'] != "1") {
|
||||||
|
if(local_user()) {
|
||||||
|
$page = '<div id="" >
|
||||||
|
<h3 style="margin-top:0px;">'.t("Community Pages").'<a id="close_pages_icon" onClick="close_pages()" class="icon close_box" title="close"></a></h3></div>
|
||||||
|
<div id=""><ul style="margin-left: 7px;margin-top: 0px;padding-left: 0px;padding-top: 0px;">';
|
||||||
|
|
||||||
|
$pagelist = array();
|
||||||
|
|
||||||
|
$contacts = q("SELECT `id`, `url`, `name`, `micro`FROM `contact`
|
||||||
|
WHERE `network`= 'dfrn' AND `forum` = 1 AND `uid` = %d
|
||||||
|
ORDER BY `name` ASC",
|
||||||
|
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;
|
||||||
|
|
||||||
|
foreach($contacts as $contact) {
|
||||||
|
$page .= '<li style="list-style-type: none;" class="tool"><img height="20" width="20" style="float: left; margin-right: 3px;" src="' . $contact['micro'] .'" alt="' . $contact['url'] . '" /> <a href="'.$a->get_baseurl().'/redir/'.$contact["id"].'" style="margin-top: 2px; word-wrap: break-word; width: 132px;" title="' . $contact['url'] . '" class="label" target="external-link">'.
|
||||||
|
$contact["name"]."</a></li>";
|
||||||
|
}
|
||||||
|
$page .= '</ul></div></div>';
|
||||||
|
//if (sizeof($contacts) > 0)
|
||||||
|
$aside['$page'] = $page;
|
||||||
|
}}
|
||||||
|
//END Community Page
|
||||||
|
|
||||||
|
//helpers
|
||||||
|
if($_COOKIE['close_helpers'] != "1") {
|
||||||
|
$helpers = array();
|
||||||
|
$helpers['title'] = Array("", t('Help or @NewHere ?'), "", "");
|
||||||
|
$aside['$helpers'] = $helpers;
|
||||||
|
}
|
||||||
|
//end helpers
|
||||||
|
//connectable services
|
||||||
|
if($_COOKIE['close_services'] != "1") {
|
||||||
|
$con_services = array();
|
||||||
|
$con_services['title'] = Array("", t('Connect Services'), "", "");
|
||||||
|
$aside['$con_services'] = $con_services;
|
||||||
|
}
|
||||||
|
//end connectable services
|
||||||
|
//get_baseurl
|
||||||
|
$url = $a->get_baseurl($ssl_state);
|
||||||
|
$aside['$url'] = $url;
|
||||||
|
//print right_aside
|
||||||
|
$tpl = file_get_contents(dirname(__file__).'/communityhome.tpl');
|
||||||
|
$a->page['right_aside'] = replace_macros($tpl, $aside);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function js_in_foot() {
|
||||||
|
/** @purpose insert stuff in bottom of page
|
||||||
|
*/
|
||||||
|
$a = get_app();
|
||||||
|
$baseurl = $a->get_baseurl($ssl_state);
|
||||||
|
$bottom['$baseurl'] = $baseurl;
|
||||||
|
$tpl = file_get_contents(dirname(__file__) . '/bottom.tpl');
|
||||||
|
$a->page['footer'] = $a->page['footer'].replace_macros($tpl, $bottom);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user