diff options
Diffstat (limited to 'pages/friends')
| -rw-r--r-- | pages/friends/collections/add.php | 22 | ||||
| -rw-r--r-- | pages/friends/collections/pickercallback.php | 59 | ||||
| -rw-r--r-- | pages/friends/collections/view.php | 21 | ||||
| -rw-r--r-- | pages/friends/index.php | 35 | ||||
| -rw-r--r-- | pages/friends/of.php | 35 | 
5 files changed, 172 insertions, 0 deletions
diff --git a/pages/friends/collections/add.php b/pages/friends/collections/add.php new file mode 100644 index 000000000..60f7586ba --- /dev/null +++ b/pages/friends/collections/add.php @@ -0,0 +1,22 @@ +<?php +/** + * Elgg add a collection of friends + * + * @package Elgg.Core + * @subpackage Social.Collections + */ + +// You need to be logged in for this one +gatekeeper(); + +$title = elgg_echo('friends:collections:add'); + +$content = elgg_view_title($title); + +$content .= elgg_view_form('friends/collections/add', array(), array( +	'friends' => get_user_friends(elgg_get_logged_in_user_guid(), "", 9999), +)); + +$body = elgg_view_layout('one_sidebar', array('content' => $content)); + +echo elgg_view_page(elgg_echo('friends:collections:add'), $body); diff --git a/pages/friends/collections/pickercallback.php b/pages/friends/collections/pickercallback.php new file mode 100644 index 000000000..c6ed61cf0 --- /dev/null +++ b/pages/friends/collections/pickercallback.php @@ -0,0 +1,59 @@ +<?php +/** + * Elgg friends picker callback + * + * @package Elgg.Core + * @subpackage Social.Collections + */ + +// Load Elgg engine +require_once(dirname(dirname(dirname(dirname(__FILE__)))) . "/engine/start.php"); + +$site_url = elgg_get_site_url(); + +// Get callback type (list or picker) +$type = get_input('type', 'picker'); + +$collection = (int) get_input('collection', 0); +$members = get_members_of_access_collection($collection, true); +if (!$members) { +	$members = array(); +} + +$friendspicker = (int) get_input('friendspicker', 0); + +// Get page owner (bomb out if there isn't one) +$pageowner = elgg_get_page_owner_entity(); +if (!$pageowner) { +	forward(); +	exit; +} + +// Depending on the view type, launch a different view +switch($type) { +	case 'list': +		$js_segment = elgg_view('core/friends/tablelistcountupdate', array( +			'friendspicker' => $friendspicker, +			'count' => sizeof($members), +		)); +		$content = elgg_view('core/friends/tablelist', array( +			'entities' => $members, +			'content' => $js_segment, +		)); +		break; +	default: +		$friends = $pageowner->getFriends('', 9999); + +		$content = elgg_view('input/friendspicker', array( +			'entities' => $friends, +			'value' => $members, +			'callback' => true, +			'friendspicker' => $friendspicker, +			'collection_id' => $collection, +			'formtarget' => $site_url . 'action/friends/collections/edit', +		)); +		break; +} + +// Output the content +echo $content;
\ No newline at end of file diff --git a/pages/friends/collections/view.php b/pages/friends/collections/view.php new file mode 100644 index 000000000..0d72fe788 --- /dev/null +++ b/pages/friends/collections/view.php @@ -0,0 +1,21 @@ +<?php +/** + * Elgg collections of friends + * + * @package Elgg.Core + * @subpackage Social.Collections + */ + +$title = elgg_echo('friends:collections'); +elgg_register_title_button('collections', 'add'); + +$content = elgg_view_access_collections(elgg_get_logged_in_user_guid()); + +$body = elgg_view_layout('content', array( +	'filter' => false, +	'content' => $content, +	'title' => $title, +	'context' => 'collections', +)); + +echo elgg_view_page($title, $body); diff --git a/pages/friends/index.php b/pages/friends/index.php new file mode 100644 index 000000000..63518a413 --- /dev/null +++ b/pages/friends/index.php @@ -0,0 +1,35 @@ +<?php +/** + * Elgg friends page + * + * @package Elgg.Core + * @subpackage Social.Friends + */ + +$owner = elgg_get_page_owner_entity(); +if (!$owner) { +	// unknown user so send away (@todo some sort of 404 error) +	forward(); +} + +$title = elgg_echo("friends:owned", array($owner->name)); + +$options = array( +	'relationship' => 'friend', +	'relationship_guid' => $owner->getGUID(), +	'inverse_relationship' => FALSE, +	'type' => 'user', +	'full_view' => FALSE +); +$content = elgg_list_entities_from_relationship($options); +if (!$content) { +	$content = elgg_echo('friends:none'); +} + +$params = array( +	'content' => $content, +	'title' => $title, +); +$body = elgg_view_layout('one_sidebar', $params); + +echo elgg_view_page($title, $body); diff --git a/pages/friends/of.php b/pages/friends/of.php new file mode 100644 index 000000000..aa9ee8bee --- /dev/null +++ b/pages/friends/of.php @@ -0,0 +1,35 @@ +<?php +/** + * Elgg friends of page + * + * @package Elgg.Core + * @subpackage Social.Friends + */ + +$owner = elgg_get_page_owner_entity(); +if (!$owner) { +	// unknown user so send away (@todo some sort of 404 error) +	forward(); +} + +$title = elgg_echo("friends:of:owned", array($owner->name)); + +$options = array( +	'relationship' => 'friend', +	'relationship_guid' => $owner->getGUID(), +	'inverse_relationship' => TRUE, +	'type' => 'user', +	'full_view' => FALSE +); +$content = elgg_list_entities_from_relationship($options); +if (!$content) { +	$content = elgg_echo('friends:none'); +} + +$params = array( +	'content' => $content, +	'title' => $title, +); +$body = elgg_view_layout('one_sidebar', $params); + +echo elgg_view_page($title, $body);  | 
