aboutsummaryrefslogtreecommitdiff
path: root/pages/friends/collections
diff options
context:
space:
mode:
Diffstat (limited to 'pages/friends/collections')
-rw-r--r--pages/friends/collections/add.php26
-rw-r--r--pages/friends/collections/pickercallback.php71
-rw-r--r--pages/friends/collections/view.php23
3 files changed, 120 insertions, 0 deletions
diff --git a/pages/friends/collections/add.php b/pages/friends/collections/add.php
new file mode 100644
index 000000000..51425db37
--- /dev/null
+++ b/pages/friends/collections/add.php
@@ -0,0 +1,26 @@
+<?php
+/**
+ * Elgg add a collection of friends
+ *
+ * @package Elgg
+ * @subpackage Core
+ */
+
+// You need to be logged in for this one
+gatekeeper();
+
+$title = elgg_echo('friends:collections:add');
+
+$content = elgg_view_title($title);
+
+$form_body = elgg_view('forms/friends/collections/edit', array(
+ 'friends' => get_user_friends(elgg_get_logged_in_user_guid(), "", 9999)
+));
+$content .= elgg_view('input/form', array(
+ 'action' => 'action/friends/collections/add',
+ 'body' => $form_body,
+));
+
+$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..8da44d8c0
--- /dev/null
+++ b/pages/friends/collections/pickercallback.php
@@ -0,0 +1,71 @@
+<?php
+/**
+ * Elgg friends picker callback
+ *
+ * @package Elgg
+ * @subpackage Core
+ */
+
+// 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);
+ $params = array(
+ 'collection' => get_access_collection($collection),
+ 'friends' => $friends,
+ 'friendspicker' => $friendspicker,
+ );
+ $content = elgg_view_form('friends/collections/edit', array(), $params);
+ /*
+ $form_body = elgg_view('input/hidden', array(
+ 'name' => 'collection_id',
+ 'value' => get_access_collection($collection)->id,
+ ));
+ $content = elgg_view('input/friendspicker', array(
+ 'entities' => $friends,
+ 'value' => $members,
+ 'callback' => true,
+ 'friendspicker' => $friendspicker,
+ 'formcontents' => $form_body,
+ '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..fa7527f4d
--- /dev/null
+++ b/pages/friends/collections/view.php
@@ -0,0 +1,23 @@
+<?php
+/**
+ * Elgg collections of friends
+ *
+ * @package Elgg
+ * @subpackage Core
+ */
+
+// You need to be logged in for this one
+gatekeeper();
+
+$title = elgg_echo('friends:collections');
+
+$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);