ElggBlog */ function blog_runonce() { if (!update_subtype('object', 'blog', 'ElggBlog')) { add_subtype('object', 'blog', 'ElggBlog'); } } /** * Dispatches blog pages. * URLs take the form of * All blogs: pg/blog/all * User's blogs: pg/blog/owner/ * Friends' blog: pg/blog/friends/ * User's archives: pg/blog/archives/// * Blog post: pg/blog/view// * New post: pg/blog/add/<guid> * Edit post: pg/blog/edit/<guid>/<revision> * Preview post: pg/blog/preview/<guid> * Group blog: pg/blog/group/<guid>/owner * * Title is ignored * * @todo no archives for all blogs or friends * * @param array $page * @return NULL */ function blog_page_handler($page) { elgg_load_library('elgg:blog'); // @todo remove the forwarder in 1.9 // forward to correct URL for bookmarks pre-1.7.5 blog_url_forwarder($page); // push all blogs breadcrumb elgg_push_breadcrumb(elgg_echo('blog:blogs'), "pg/blog/all/"); if (!isset($page[0])) { $page[0] = 'all'; } $page_type = $page[0]; switch ($page_type) { case 'owner': $user = get_user_by_username($page[1]); $params = blog_get_page_content_list($user->guid); break; case 'friends': $user = get_user_by_username($page[1]); $params = blog_get_page_content_friends($user->guid); break; case 'archive': $user = get_user_by_username($page[1]); $params = blog_get_page_content_archive($user->guid, $page[2], $page[3]); break; case 'view': $params = blog_get_page_content_read($page[1]); break; case 'add': gatekeeper(); $params = blog_get_page_content_edit($page_type, $page[1]); break; case 'edit': gatekeeper(); $params = blog_get_page_content_edit($page_type, $page[1], $page[2]); break; case 'group': $params = blog_get_page_content_list($page[1]); break; case 'all': default: $title = elgg_echo('blog:title:all_blogs'); $params = blog_get_page_content_list(); break; } $params['sidebar'] .= elgg_view('blog/sidebar', array('page' => $page_type)); $body = elgg_view_layout('content', $params); echo elgg_view_page($params['title'], $body); } /** * Format and return the URL for blogs. * * @param ElggObject $entity Blog object * @return string URL of blog. */ function blog_url_handler($entity) { if (!$entity->getOwnerEntity()) { // default to a standard view if no owner. return FALSE; } $friendly_title = elgg_get_friendly_title($entity->title); return "pg/blog/view/{$entity->guid}/$friendly_title"; } /** * Add a menu item to an ownerblock */ function blog_owner_block_menu($hook, $type, $return, $params) { if (elgg_instanceof($params['entity'], 'user')) { $url = "pg/blog/owner/{$params['entity']->username}"; $item = new ElggMenuItem('blog', elgg_echo('blog'), $url); $return[] = $item; } else { if ($params['entity']->blog_enable != "no") { $url = "pg/blog/group/{$params['entity']->guid}/owner"; $item = new ElggMenuItem('blog', elgg_echo('blog:group'), $url); $return[] = $item; } } return $return; } /** * Register blogs with ECML. */ function blog_ecml_views_hook($hook, $entity_type, $return_value, $params) { $return_value['object/blog'] = elgg_echo('blog:blogs'); return $return_value; }