community home: add admin settings form #476
|
@ -6,10 +6,10 @@
|
||||||
* Author: Fabio Comuni <http://kirgroup.com/profile/fabrixxm>
|
* Author: Fabio Comuni <http://kirgroup.com/profile/fabrixxm>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use Friendica\Core\Config;
|
||||||
|
|
||||||
require_once('mod/community.php');
|
require_once('mod/community.php');
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
|
||||||
|
|
||||||
function communityhome_install() {
|
function communityhome_install() {
|
||||||
register_hook('home_content', 'addon/communityhome/communityhome.php', 'communityhome_home');
|
register_hook('home_content', 'addon/communityhome/communityhome.php', 'communityhome_home');
|
||||||
|
@ -21,6 +21,41 @@ function communityhome_uninstall() {
|
||||||
logger("removed communityhome");
|
logger("removed communityhome");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function communityhome_getopts() {
|
||||||
|
return [
|
||||||
|
'hidelogin'=>t('Hide login form'),
|
||||||
|
'showlastusers'=>t('Show last new users'),
|
||||||
|
'showactiveusers'=>t('Show last active users'),
|
||||||
|
'showlastphotos'=>t('Show last photos'),
|
||||||
|
'showlastlike'=>t('Show last liked items'),
|
||||||
|
'showcommunitystream'=>t('Show community stream')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
function communityhome_plugin_admin(&$a, &$o) {
|
||||||
|
$tpl = get_markup_template( 'settings.tpl', 'addon/communityhome/' );
|
||||||
|
|
||||||
|
$opts = communityhome_getopts();
|
||||||
|
$ctx = [
|
||||||
|
'$submit' => t("Submit"),
|
||||||
|
'$fields' => [],
|
||||||
|
];
|
||||||
|
foreach($opts as $k=>$v) {
|
||||||
|
$ctx['fields'][] = ['communityhome_'.$k, $v, Config::get('communityhome', $k)];
|
||||||
|
}
|
||||||
|
$o = replace_macros($tpl, $ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
function communityhome_plugin_admin_post(&$a,&$b) {
|
||||||
|
if(x($_POST,'communityhome-submit')) {
|
||||||
|
$opts = communityhome_getopts();
|
||||||
|
foreach($opts as $k=>$v) {
|
||||||
|
Config::set('communityhome', $k, x($_POST,'communityhome_'.$k));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function communityhome_home(&$a, &$o){
|
function communityhome_home(&$a, &$o){
|
||||||
// custom css
|
// custom css
|
||||||
$a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="'.$a->get_baseurl().'/addon/communityhome/communityhome.css" media="all" />';
|
$a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="'.$a->get_baseurl().'/addon/communityhome/communityhome.css" media="all" />';
|
||||||
|
@ -35,15 +70,16 @@ function communityhome_home(&$a, &$o){
|
||||||
// login form
|
// login form
|
||||||
$aside['$login_title'] = t('Login');
|
$aside['$login_title'] = t('Login');
|
||||||
$aside['$login_form'] = login(($a->config['register_policy'] == REGISTER_CLOSED) ? false : true);
|
$aside['$login_form'] = login(($a->config['register_policy'] == REGISTER_CLOSED) ? false : true);
|
||||||
} else
|
} else {
|
||||||
$aside = array(
|
$aside = array(
|
||||||
//'$tab_1' => t('Login'),
|
//'$tab_1' => t('Login'),
|
||||||
//'$tab_2' => t('OpenID'),
|
//'$tab_2' => t('OpenID'),
|
||||||
//'$noOid' => Config::get('system','no_openid'),
|
//'$noOid' => Config::get('system','no_openid'),
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// last 12 users
|
// last 12 users
|
||||||
if (Config::get('communityhome','showlastusers')===true){
|
if (Config::get('communityhome','showlastusers')){
|
||||||
$aside['$lastusers_title'] = t('Latest users');
|
$aside['$lastusers_title'] = t('Latest users');
|
||||||
$aside['$lastusers_items'] = array();
|
$aside['$lastusers_items'] = array();
|
||||||
$sql_extra = "";
|
$sql_extra = "";
|
||||||
|
@ -74,7 +110,7 @@ function communityhome_home(&$a, &$o){
|
||||||
}
|
}
|
||||||
// 12 most active users (by posts and contacts)
|
// 12 most active users (by posts and contacts)
|
||||||
// this query don't work on some mysql versions
|
// this query don't work on some mysql versions
|
||||||
if (Config::get('communityhome','showactiveusers')===true){
|
if (Config::get('communityhome','showactiveusers')){
|
||||||
$r = q("SELECT `uni`.`contacts`,`uni`.`items`, `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname` FROM
|
$r = q("SELECT `uni`.`contacts`,`uni`.`items`, `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname` FROM
|
||||||
(SELECT COUNT(*) as `contacts`, `uid` FROM `contact` WHERE `self`=0 GROUP BY `uid`) AS `con`,
|
(SELECT COUNT(*) as `contacts`, `uid` FROM `contact` WHERE `self`=0 GROUP BY `uid`) AS `con`,
|
||||||
(SELECT COUNT(*) as `items`, `uid` FROM `item` WHERE `item`.`changed` > DATE(NOW() - INTERVAL 1 MONTH) AND `item`.`wall` = 1 GROUP BY `uid`) AS `ite`,
|
(SELECT COUNT(*) as `items`, `uid` FROM `item` WHERE `item`.`changed` > DATE(NOW() - INTERVAL 1 MONTH) AND `item`.`wall` = 1 GROUP BY `uid`) AS `ite`,
|
||||||
|
@ -99,14 +135,14 @@ function communityhome_home(&$a, &$o){
|
||||||
'$id' => $rr['id'],
|
'$id' => $rr['id'],
|
||||||
'$profile_link' => $profile_link,
|
'$profile_link' => $profile_link,
|
||||||
'$photo' => $rr[$photo],
|
'$photo' => $rr[$photo],
|
||||||
'$alt_text' => sprintf("%s (%s posts, %s contacts)",$rr['name'], ($rr['items']?$rr['items']:'0'), ($rr['contacts']?$rr['contacts']:'0'))
|
'$photo_user' => sprintf("%s (%s posts, %s contacts)",$rr['name'], ($rr['items']?$rr['items']:'0'), ($rr['contacts']?$rr['contacts']:'0'))
|
||||||
));
|
));
|
||||||
$aside['$activeusers_items'][] = $entry;
|
$aside['$activeusers_items'][] = $entry;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// last 12 photos
|
// last 12 photos
|
||||||
if (Config::get('communityhome','showlastphotos')===true){
|
if (Config::get('communityhome','showlastphotos')){
|
||||||
$aside['$photos_title'] = t('Latest photos');
|
$aside['$photos_title'] = t('Latest photos');
|
||||||
$aside['$photos_items'] = array();
|
$aside['$photos_items'] = array();
|
||||||
$r = q("SELECT `photo`.`id`, `photo`.`resource-id`, `photo`.`scale`, `photo`.`desc`, `user`.`nickname`, `user`.`username` FROM
|
$r = q("SELECT `photo`.`id`, `photo`.`resource-id`, `photo`.`scale`, `photo`.`desc`, `user`.`nickname`, `user`.`username` FROM
|
||||||
|
@ -136,7 +172,8 @@ function communityhome_home(&$a, &$o){
|
||||||
'$id' => $rr['id'],
|
'$id' => $rr['id'],
|
||||||
'$profile_link' => $photo_page,
|
'$profile_link' => $photo_page,
|
||||||
'$photo' => $photo_url,
|
'$photo' => $photo_url,
|
||||||
'$alt_text' => $rr['username']." : ".$rr['desc'],
|
'$photo_user' => $rr['username'],
|
||||||
|
'$photo_title' => $rr['desc']
|
||||||
));
|
));
|
||||||
|
|
||||||
$aside['$photos_items'][] = $entry;
|
$aside['$photos_items'][] = $entry;
|
||||||
|
@ -145,7 +182,7 @@ function communityhome_home(&$a, &$o){
|
||||||
}
|
}
|
||||||
|
|
||||||
// last 10 liked items
|
// last 10 liked items
|
||||||
if (Config::get('communityhome','showlastlike')===true){
|
if (Config::get('communityhome','showlastlike')){
|
||||||
$aside['$like_title'] = t('Latest likes');
|
$aside['$like_title'] = t('Latest likes');
|
||||||
$aside['$like_items'] = array();
|
$aside['$like_items'] = array();
|
||||||
$r = q("SELECT `T1`.`created`, `T1`.`liker`, `T1`.`liker-link`, `item`.* FROM
|
$r = q("SELECT `T1`.`created`, `T1`.`liker`, `T1`.`liker-link`, `item`.* FROM
|
||||||
|
@ -199,7 +236,7 @@ function communityhome_home(&$a, &$o){
|
||||||
if(file_exists('home.html'))
|
if(file_exists('home.html'))
|
||||||
$o = file_get_contents('home.html');
|
$o = file_get_contents('home.html');
|
||||||
|
|
||||||
if (Config::get('communityhome','showcommunitystream')===true){
|
if (Config::get('communityhome','showcommunitystream')){
|
||||||
$oldset = Config::get('system','community_page_style');
|
$oldset = Config::get('system','community_page_style');
|
||||||
if ($oldset == CP_NO_COMMUNITY_PAGE)
|
if ($oldset == CP_NO_COMMUNITY_PAGE)
|
||||||
Config::set('system','community_page_style', CP_USERS_ON_SERVER);
|
Config::set('system','community_page_style', CP_USERS_ON_SERVER);
|
||||||
|
|
|
@ -2,8 +2,8 @@
|
||||||
<div class="directory-item" id="directory-item-{{$id}}" >
|
<div class="directory-item" id="directory-item-{{$id}}" >
|
||||||
<div class="directory-photo-wrapper" id="directory-photo-wrapper-{{$id}}" >
|
<div class="directory-photo-wrapper" id="directory-photo-wrapper-{{$id}}" >
|
||||||
<div class="directory-photo" id="directory-photo-{{$id}}" >
|
<div class="directory-photo" id="directory-photo-{{$id}}" >
|
||||||
<a href="{{$profile}}-link" class="directory-profile-link" id="directory-profile-link-{{$id}}" >
|
<a href="{{$profile_link}}" class="directory-profile-link" id="directory-profile-link-{{$id}}" >
|
||||||
<img class="directory-photo-img" src="{{$photo}}" alt="{{$alt}}-text" title="{{$alt}}-text" />
|
<img class="directory-photo-img" src="{{$photo}}" alt="{{$photo_user}} {{if $photo_title}}: {{$photo_title}}{{/if}}" title="{{$alt_text}}" />
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
9
communityhome/templates/settings.tpl
Normal file
9
communityhome/templates/settings.tpl
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<div id="communityhome-wrapper">
|
||||||
|
{{foreach $fields as $field}}
|
||||||
|
{{include file="field_checkbox.tpl" field=$field}}
|
||||||
|
{{/foreach}}
|
||||||
|
</div>
|
||||||
|
<div class="settings-submit-wrapper" >
|
||||||
|
<input type="submit" id="communityhome-submit" name="communityhome-submit" class="settings-submit" value="{{$submit}}" />
|
||||||
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue