aboutsummaryrefslogtreecommitdiff
path: root/mod/categories/start.php
diff options
context:
space:
mode:
Diffstat (limited to 'mod/categories/start.php')
-rw-r--r--mod/categories/start.php74
1 files changed, 39 insertions, 35 deletions
diff --git a/mod/categories/start.php b/mod/categories/start.php
index dd6da16d5..0aacf11e7 100644
--- a/mod/categories/start.php
+++ b/mod/categories/start.php
@@ -1,66 +1,51 @@
<?php
-
/**
* Elgg categories plugin
*
* @package ElggCategories
- * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
- * @author Curverider Ltd <info@elgg.com>
- * @copyright Curverider Ltd 2008-2010
- * @link http://elgg.com/
*/
+elgg_register_event_handler('init', 'system', 'categories_init');
+
/**
* Initialise categories plugin
*
*/
function categories_init() {
- global $CONFIG;
-
- elgg_extend_view('css', 'categories/css');
+ elgg_extend_view('css/elgg', 'categories/css');
- register_action('categories/save',false,$CONFIG->pluginspath . 'categories/actions/save.php',true);
+ elgg_register_page_handler('categories', 'categories_page_handler');
- register_page_handler('categories', 'categories_page_handler');
+ elgg_register_event_handler('update', 'all', 'categories_save');
+ elgg_register_event_handler('create', 'all', 'categories_save');
+ // To keep the category plugins in the settings area and because we have to do special stuff,
+ // handle saving ourself.
+ elgg_register_plugin_hook_handler('action', 'plugins/settings/save', 'categories_save_site_categories');
}
-/**
- * Set up admin menu item
- *
- */
-function categories_pagesetup() {
- if (get_context() == 'admin' && isadminloggedin()) {
- global $CONFIG;
- add_submenu_item(elgg_echo('categories:settings'), $CONFIG->wwwroot . 'mod/categories/settings.php');
- }
-}
/**
- * Page handler
- *
+ * Category page handler
+ * @return bool
*/
function categories_page_handler() {
-
- include(dirname(__FILE__) . "/listing.php");
+ include(dirname(__FILE__) . "/pages/categories/listing.php");
return true;
}
/**
- * Save site categories
+ * Save categories to object upon save / edit
*
*/
function categories_save($event, $object_type, $object) {
-
if ($object instanceof ElggEntity) {
-
$marker = get_input('universal_category_marker');
if ($marker == 'on') {
-
$categories = get_input('universal_categories_list');
-
+
if (empty($categories)) {
$categories = array();
}
@@ -68,12 +53,31 @@ function categories_save($event, $object_type, $object) {
$object->universal_categories = $categories;
}
}
-
- return true;
+ return TRUE;
}
+/**
+ * Saves the site categories.
+ *
+ * @param type $hook
+ * @param type $type
+ * @param type $value
+ * @param type $params
+ */
+function categories_save_site_categories($hook, $type, $value, $params) {
+ $plugin_id = get_input('plugin_id');
+ if ($plugin_id != 'categories') {
+ return $value;
+ }
+
+ $categories = get_input('categories');
+ $categories = string_to_tag_array($categories);
+
+ $site = elgg_get_site_entity();
+ $site->categories = $categories;
+ system_message(elgg_echo("categories:save:success"));
+
+ elgg_delete_admin_notice('categories_admin_notice_no_categories');
-register_elgg_event_handler('init','system','categories_init');
-register_elgg_event_handler('pagesetup','system','categories_pagesetup');
-register_elgg_event_handler('update','all','categories_save');
-register_elgg_event_handler('create','all','categories_save');
+ forward(REFERER);
+} \ No newline at end of file