diff options
| -rw-r--r-- | mod/blog/actions/blog/auto_save_revision.php | 89 | ||||
| -rw-r--r-- | mod/blog/actions/blog/save.php | 217 | ||||
| -rw-r--r-- | mod/blog/actions/blog/save_draft.php | 146 | ||||
| -rw-r--r-- | mod/blog/blog_lib.php | 78 | ||||
| -rw-r--r-- | mod/blog/languages/en.php | 7 | ||||
| -rw-r--r-- | mod/blog/start.php | 71 | ||||
| -rw-r--r-- | mod/blog/views/default/blog/forms/edit.php | 90 | ||||
| -rw-r--r-- | mod/blog/views/default/blog/sidebar_edit.php | 65 | ||||
| -rw-r--r-- | mod/blog/views/default/blog/sidebar_menu.php | 6 | ||||
| -rw-r--r-- | mod/blog/views/default/blog/sidebar_revisions.php | 70 | ||||
| -rw-r--r-- | mod/blog/views/default/object/blog.php | 25 | 
11 files changed, 427 insertions, 437 deletions
| diff --git a/mod/blog/actions/blog/auto_save_revision.php b/mod/blog/actions/blog/auto_save_revision.php new file mode 100644 index 000000000..fa9010e90 --- /dev/null +++ b/mod/blog/actions/blog/auto_save_revision.php @@ -0,0 +1,89 @@ +<?php +/** + * Action called by AJAX periodic auto saving when editing. + * + * @package Blog + * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 + * @author Curverider Ltd + * @copyright Curverider Ltd 2008-2010 + * @link http://elgg.org/ + */ + +$guid = get_input('guid'); +$user = get_loggedin_user(); +$title = get_input('title'); +$description = get_input('description'); +$excerpt = get_input('excerpt'); + +// because get_input() doesn't use the default if the input is '' +if (empty($excerpt)) { +	$excerpt = $description; +} + +// store errors to pass along +$error = FALSE; + +if ($title && $description) { + +	if ($guid) { +		$entity = get_entity($guid); +		if (elgg_instanceof($entity, 'object', 'blog') && $entity->canEdit()) { +			$blog = $entity; +		} else { +			$error = elgg_echo('blog:error:post_not_found'); +		} +	} else { +		$blog = new ElggObject(); +		$blog->subtype = 'blog'; + +		// force draft and private for autosaves. +		$blog->status = 'unsaved_draft'; +		$blog->access_id = ACCESS_PRIVATE; +		$blog->title = $title; +		$blog->description = $description; +		$blog->excerpt = blog_make_excerpt($excerpt); +		// must be present or doesn't show up when metadata sorting. +		$blog->publish_date = time(); +		if (!$blog->save()) { +			$error = elgg_echo('blog:error:cannot_save'); +		} +	} + +	// creat draft annotation +	if (!$error) { +		// annotations don't have a "time_updated" so +		// we have to delete everything or the times are wrong. + +		// don't save if nothing changed +		if ($auto_save_annotations = $blog->getAnnotations('blog_auto_save', 1)) { +			$auto_save = $auto_save_annotations[0]; +		} else { +			$auto_save == FALSE; +		} + +		if (!$auto_save) { +			$annotation_id = $blog->annotate('blog_auto_save', $description); +		} elseif ($auto_save instanceof ElggAnnotation && $auto_save->value != $description) { +			$blog->clearAnnotations('blog_auto_save'); +			$annotation_id = $blog->annotate('blog_auto_save', $description); +		} elseif ($auto_save instanceof ElggAnnotation && $auto_save->value == $description) { +			// this isn't an error because we have an up to date annotation. +			$annotation_id = $auto_save->id; +		} + +		if (!$annotation_id) { +			$error = elgg_echo('blog:error:cannot_auto_save'); +		} +	} +} else { +	$error = elgg_echo('blog:error:missing:description'); +} + +if ($error) { +	$json = array('success' => FALSE, 'message' => $error); +	echo json_encode($json); +} else { +	$msg = elgg_echo('blog:message:saved'); +	$json = array('success' => TRUE, 'message' => $msg, 'guid' => $blog->getGUID()); +	echo json_encode($json); +}
\ No newline at end of file diff --git a/mod/blog/actions/blog/save.php b/mod/blog/actions/blog/save.php index eade7cad8..0ca063496 100644 --- a/mod/blog/actions/blog/save.php +++ b/mod/blog/actions/blog/save.php @@ -9,16 +9,16 @@   * @link http://elgg.org/   */ -elgg_make_sticky_form(); - -// edit or create a new entity -$guid = get_input('guid'); -$user = get_loggedin_user(); -$ajax = get_input('ajax'); +// start a new sticky form session in case of failure +//elgg_make_sticky_form();  // store errors to pass along  $error = FALSE;  $error_forward_url = $_SERVER['HTTP_REFERER']; +$user = get_loggedin_user(); + +// edit or create a new entity +$guid = get_input('guid');  if ($guid) {  	$entity = get_entity($guid); @@ -29,10 +29,15 @@ if ($guid) {  		forward(get_input('forward', $_SERVER['HTTP_REFERER']));  	}  	$success_forward_url = get_input('forward', $blog->getURL()); + +	// save some data for revisions once we save the new edit +	$revision_value = $blog->description; +	$new_post = FALSE;  } else {  	$blog = new ElggObject();  	$blog->subtype = 'blog';  	$success_forward_url = get_input('forward'); +	$new_post = TRUE;  }  // set defaults and required values. @@ -40,7 +45,7 @@ $values = array(  	'title' => '',  	'description' => '',  	'status' => 'draft', -	//'publish_date' => time(), +	'publish_date' => time(),  	'access_id' => ACCESS_DEFAULT,  	'comments_on' => 'On',  	'excerpt' => '', @@ -48,13 +53,9 @@ $values = array(  	'container_guid' => ''  ); +// fail if a required entity isn't set  $required = array('title', 'description'); -foreach ($values as $name => $default) { -	$values[$name] = get_input($name, $default); -} - -  // load from POST and do sanity and access checking  foreach ($values as $name => $default) {  	$value = get_input($name, $default); @@ -77,17 +78,16 @@ foreach ($values as $name => $default) {  			break;  		case 'excerpt': -			// restrict to 300 chars  			if ($value) { -				$value = substr(strip_tags($value), 0, 300); +				$value = blog_make_excerpt($value);  			} else { -				$value = substr(strip_tags($values['description']), 0, 300); +				$value = blog_make_excerpt($values['description']);  			}  			$values[$name] = $value;  			break;  		case 'container_guid': -			// this can't be empty. +			// this can't be empty or saving the base entity fails  			if (!empty($value)) {  				if (can_write_to_container($user->getGUID(), $value)) {  					$values[$name] = $value; @@ -99,6 +99,13 @@ foreach ($values as $name => $default) {  			}  			break; +		case 'publish_date': +			if (empty($value)) { +				$value = time(); +			} +			$values[$name] = $value; +			break; +  		// don't try to set the guid  		case 'guid':  			unset($values['guid']); @@ -113,170 +120,44 @@ foreach ($values as $name => $default) {  // assign values to the entity, stopping on error.  if (!$error) {  	foreach ($values as $name => $value) { -		if (!$blog->$name = $value) { -			$error = elgg_echo('blog:error:cannot_save1' . $name); +		if (FALSE === ($blog->$name = $value)) { +			$error = elgg_echo('blog:error:cannot_save' . "$name=$value");  			break;  		}  	}  }  // only try to save base entity if no errors -if (!$error && !$blog->save()) { -	$error = elgg_echo('blog:error:cannot_save'); -} - -// forward with success or failure -if ($ajax) { -	if ($error) { -		$json = array('success' => FALSE, 'message' => $error); -		echo json_encode($json); -	} else { -		$msg = elgg_echo('blog:message:saved'); -		$json = array('success' => TRUE, 'message' => $msg, 'guid' => $blog->getGUID()); -		echo json_encode($json); -	} -} else { -	if ($error) { -		register_error($error); -		forward($error_forward_url); -	} else { -		system_message(elgg_echo('blog:message:saved')); -		forward($success_forward_url); -	} -} - - - -/* - * This might have been a good idea. - * It's not. +if (!$error) { +	if ($blog->save()) { +		// remove sticky form entries +		elgg_clear_sticky_form(); -// edit or create a new entity -$guid = get_input('guid'); -$user = get_loggedin_user(); -$ajax = get_input('ajax', FALSE); +		// remove autosave draft if exists +		$blog->clearAnnotations('blog_auto_save'); -// store errors to pass along -$error = FALSE; -$error_forward_url = $_SERVER['HTTP_REFERER']; +		// if this was an edit, create a revision +		if (!$new_post && $revision_value) { +			// create a revision annotation +			$blog->annotate('blog_revision', $revision_value); +		} -if ($guid) { -	$entity = get_entity($guid); -	if (elgg_instanceof($entity, 'object', 'blog') && $entity->canEdit()) { -		$blog = $entity; +		system_message(elgg_echo('blog:message:saved')); +		forward($success_forward_url);  	} else { -		register_error(elgg_echo('blog:error:post_not_found')); -		forward(get_input('forward', $_SERVER['HTTP_REFERER'])); -	} -	$success_forward_url = get_input('forward', $blog->getURL()); -} else { -	$blog = new ElggObject(); -	$blog->subtype = 'blog'; -	$success_forward_url = get_input('forward'); -} - -// set defaults and required values. -$values = array( -	'title' => '', -	'description' => '', -	'access_id' => ACCESS_DEFAULT, -	'comments_on' => 'On', -	'excerpt' => '', -	'tags' => '', -	'container_guid' => '' -); - -$required = array('title', 'description'); - -foreach ($values as $name => $default) { -	$values[$name] = get_input($name, $default); -} - - -// load from POST and do sanity and access checking -foreach ($values as $name => $default) { - -	if ($error) { -		break; -	} - -	$value = get_input($name, $default); - -	if (in_array($name, $required) && empty($value)) { -		register_error(elgg_echo("blog:error:missing:$name")); +		register_error(elgg_echo('blog:error:cannot_save'));  		forward($error_forward_url);  	} - -	switch ($name) { -		case 'tags': -			$values[$name] = string_to_tag_array($value); -			break; - -		case 'excerpt': -			// restrict to 300 chars -			if ($value) { -				$value = substr(strip_tags($value), 0, 300); -			} else { -				$value = substr(strip_tags($values['description']), 0, 300); -			} -			$values[$name] = $value; -			break; - -		case 'container_guid': -			// this can't be empty. -			if (!empty($value)) { -				if (can_write_to_container($user->getGUID(), $value)) { -					$values[$name] = $value; -				} else { -					$error = elgg_echo("blog:error:cannot_write_to_container"); -				} -			} else { -				unset($values[$name]); -			} -			break; - -		// don't try to set the guid -		case 'guid': -			unset($values['guid']); -			break; - -		default: -			$values[$name] = $value; -			break; -	} -} - -// assign values to the entity, stopping on error. -foreach ($values as $name => $value) { -	if (!$blog->$name = $value) { -		$error = elgg_echo('blog:error:cannot_save'); -		break; -	} -} - -// only try to save base entity if no errors -if (!$error && !$blog->save()) { -	$error = elgg_echo('blog:error:cannot_save'); -} - -// forward or return ajax data. -if ($ajax) { -	if ($error) { -		$json = array('success' => FALSE, 'message' => $error); -		echo json_encode($json); -	} else { -		$msg = elgg_echo('blog:message:saved'); -		$json = array('success' => TRUE, 'message' => $msg); -		echo json_encode($json); -	}  } else { -	if ($error) { -		register_error($error); -		forward($error_forward_url); -	} else { -		system_message(elgg_echo('blog:message:saved')); -		forward($success_forward_url); -	} +	register_error($error); +	forward($error_forward_url);  } -*/
\ No newline at end of file +// forward with success or failure +if ($error) { +	register_error($error); +	forward($error_forward_url); +} else { +	system_message(elgg_echo('blog:message:saved')); +	forward($success_forward_url); +}
\ No newline at end of file diff --git a/mod/blog/actions/blog/save_draft.php b/mod/blog/actions/blog/save_draft.php deleted file mode 100644 index 64a79c667..000000000 --- a/mod/blog/actions/blog/save_draft.php +++ /dev/null @@ -1,146 +0,0 @@ -<?php -/** - * Save blog entity - * - * @package Blog - * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 - * @author Curverider Ltd - * @copyright Curverider Ltd 2008-2010 - * @link http://elgg.org/ - */ - -elgg_make_sticky_form(); - -// edit or create a new entity -$guid = get_input('guid'); -$user = get_loggedin_user(); -$ajax = get_input('ajax'); - -// store errors to pass along -$error = FALSE; -$error_forward_url = $_SERVER['HTTP_REFERER']; - -if ($guid) { -	$entity = get_entity($guid); -	if (elgg_instanceof($entity, 'object', 'blog') && $entity->canEdit()) { -		$blog = $entity; -	} else { -		register_error(elgg_echo('blog:error:post_not_found')); -		forward(get_input('forward', $_SERVER['HTTP_REFERER'])); -	} -	$success_forward_url = get_input('forward', $blog->getURL()); -} else { -	$blog = new ElggObject(); -	$blog->subtype = 'blog'; -	$success_forward_url = get_input('forward'); -} - -// set defaults and required values. -$values = array( -	'title' => '', -	'description' => '', -	'status' => 'draft', -	//'publish_date' => '', -	'access_id' => ACCESS_DEFAULT, -	'comments_on' => 'On', -	'excerpt' => '', -	'tags' => '', -	'container_guid' => '' -); - -$required = array('title', 'description'); - -foreach ($values as $name => $default) { -	$values[$name] = get_input($name, $default); -} - - -// load from POST and do sanity and access checking -foreach ($values as $name => $default) { -	$value = get_input($name, $default); - -	if (in_array($name, $required) && empty($value)) { -		$error = elgg_echo("blog:error:missing:$name"); -	} - -	if ($error) { -		break; -	} - -	switch ($name) { -		case 'tags': -			if ($value) { -				$values[$name] = string_to_tag_array($value); -			} else { -				unset ($values[$name]); -			} -			break; - -		case 'excerpt': -			// restrict to 300 chars -			if ($value) { -				$value = substr(strip_tags($value), 0, 300); -			} else { -				$value = substr(strip_tags($values['description']), 0, 300); -			} -			$values[$name] = $value; -			break; - -		case 'container_guid': -			// this can't be empty. -			if (!empty($value)) { -				if (can_write_to_container($user->getGUID(), $value)) { -					$values[$name] = $value; -				} else { -					$error = elgg_echo("blog:error:cannot_write_to_container"); -				} -			} else { -				unset($values[$name]); -			} -			break; - -		// don't try to set the guid -		case 'guid': -			unset($values['guid']); -			break; - -		default: -			$values[$name] = $value; -			break; -	} -} - -// assign values to the entity, stopping on error. -if (!$error) { -	foreach ($values as $name => $value) { -		if (!$blog->$name = $value) { -			$error = elgg_echo('blog:error:cannot_save'); -			break; -		} -	} -} - -// only try to save base entity if no errors -if (!$error && !$blog->save()) { -	$error = elgg_echo('blog:error:cannot_save'); -} - -// forward with success or failure -if ($ajax) { -	if ($error) { -		$json = array('success' => FALSE, 'message' => $error); -		echo json_encode($json); -	} else { -		$msg = elgg_echo('blog:message:saved'); -		$json = array('success' => TRUE, 'message' => $msg, 'guid' => $blog->getGUID()); -		echo json_encode($json); -	} -} else { -	if ($error) { -		register_error($error); -		forward($error_forward_url); -	} else { -		system_message(elgg_echo('blog:message:saved')); -		forward($success_forward_url); -	} -}
\ No newline at end of file diff --git a/mod/blog/blog_lib.php b/mod/blog/blog_lib.php index 0fe1b80d4..993728dcc 100644 --- a/mod/blog/blog_lib.php +++ b/mod/blog/blog_lib.php @@ -16,54 +16,85 @@   * @param int $guid of a blog entity.   * @return string html   */ -function blog_get_page_content_read($owner_guid, $guid) { +function blog_get_page_content_read($owner_guid = NULL, $guid = NULL) { +	$content = elgg_view('page_elements/content_header', array('context' => $context, 'type' => 'blog')); +  	if ($guid) {  		$blog = get_entity($guid);  		if (!elgg_instanceof($blog, 'object', 'blog') && $blog->status == 'final') { -			$content = elgg_echo('blog:error:post_not_found'); +			$content .= elgg_echo('blog:error:post_not_found');  		} else {  			elgg_push_breadcrumb($blog->title, $blog->getURL()); -			$content = elgg_view_entity($blog, TRUE); +			$content .= elgg_view_entity($blog, TRUE);  		}  	} else { -		$content = elgg_list_entities_from_metadata(array( +		$options = array(  			'type' => 'object',  			'subtype' => 'blog', -			'owner_guid' => $owner_guid,  			'full_view' => FALSE, -			'metadata_name_value_pair' => array('name' => 'status', 'value' => 'final') -		)); +			'order_by_metadata' => array('name'=>'publish_date', 'direction'=>'DESC', 'as'=>'int') +		); + +		if ($owner_guid) { +			$options['owner_guid'] = $owner_guid; +		} + +		// show all posts for admin or users looking at their own blogs +		// show only published posts for other users. +		if (!(isadminloggedin() || (isloggedin() && $owner_guid == get_loggedin_userid()))) { +			$options['metadata_name_value_pairs'] = array( +				array('name' => 'status', 'value' => 'published'), +				array('name' => 'publish_date', 'operand' => '<', 'value' => time()) +			); +		} + +		$content .= elgg_list_entities_from_metadata($options);  	} -	return $content; +	return array('content' => $content);  }  /**   * Returns HTML to edit a blog post.   *   * @param int $guid + * @param int annotation id optional revision to edit   * @return string html   */ -function blog_get_page_content_edit($guid) { +function blog_get_page_content_edit($guid, $revision = NULL) {  	$vars = array();  	if ($guid) { -		$blog = get_entity($guid); -		$vars['entity'] = $blog; +		$blog = get_entity((int)$guid); + +		if (elgg_instanceof($blog, 'object', 'blog') && $blog->canEdit()) { +			$vars['entity'] = $blog; + +			if ($revision) { +				$revision = get_annotation((int)$revision); +				$vars['revision'] = $revision; + +				if (!$revision || !($revision->entity_guid == $guid)) { +					$content = elgg_echo('blog:error:revision_not_found'); +				} +			} + +			elgg_push_breadcrumb($blog->title, $blog->getURL()); +			elgg_push_breadcrumb(elgg_echo('edit')); -		if (!elgg_instanceof($blog, 'object', 'blog') || !$blog->canEdit()) { +			$content = elgg_view('blog/forms/edit', $vars); +			$sidebar = elgg_view('blog/sidebar_revisions', array('entity' => $blog)); +			//$sidebar .= elgg_view('blog/sidebar_related'); +		} else {  			$content = elgg_echo('blog:error:post_not_found');  		} - -		elgg_push_breadcrumb($blog->title, $blog->getURL()); -		elgg_push_breadcrumb(elgg_echo('edit'));  	} else {  		elgg_push_breadcrumb(elgg_echo('blog:new')); +		$content = elgg_view('blog/forms/edit', $vars); +		//$sidebar = elgg_view('blog/sidebar_related');  	} -	$content = elgg_view('blog/forms/edit', $vars); - -	return $content; +	return array('content' => $content, 'sidebar' => $sidebar);  }  /** @@ -175,7 +206,12 @@ function blog_save_blog($info) {  	return $return;  } - -class ElggBlog extends ElggObject { - +/** + * Returns an appropriate excerpt for a blog. + * + * @param string $text + * @return string + */ +function blog_make_excerpt($text) { +	return substr(strip_tags($text), 0, 300);  }
\ No newline at end of file diff --git a/mod/blog/languages/en.php b/mod/blog/languages/en.php index e8db1716e..4d448856e 100644 --- a/mod/blog/languages/en.php +++ b/mod/blog/languages/en.php @@ -6,6 +6,9 @@  $english = array(  	'item:object:blog' => 'Blog', +	'blog:blogs' => 'Blogs', +	'blog:owned_blogs' => '%s blogs', +	'blog:revisions' => 'Revisions',  	'blog:blog' => 'Blog',  	'blog:yours' => 'Your blog', @@ -27,11 +30,15 @@ $english = array(  	'blog:status:published' => 'Published',  	'blog:revision' => 'Revision', +	'blog:auto_saved_revision' => 'Auto Saved Revision',  	// messages  	'blog:message:saved' => 'Blog post saved.',  	'blog:error:cannot_save' => 'Cannot save blog post.',  	'blog:error:cannot_write_to_container' => 'Insufficient access to save blog to group.', +	'blog:messages:warning:draft' => 'There is an unsaved draft of this post!', +	'blog:edit_revision_notice' => '(Old version)', +  );  add_translation('en', $english);
\ No newline at end of file diff --git a/mod/blog/start.php b/mod/blog/start.php index b3a8e32ee..bf0d3fb56 100644 --- a/mod/blog/start.php +++ b/mod/blog/start.php @@ -39,7 +39,6 @@ function blog_init() {  	elgg_extend_view('css', 'blog/css');  	register_page_handler('blog', 'blog_page_handler'); -	register_page_handler('blog_ajax', 'blog_ajax_page_handler');  	register_entity_url_handler('blog_url_handler', 'object', 'blog'); @@ -60,6 +59,7 @@ function blog_init() {  	$action_path = dirname(__FILE__) . '/actions/blog';  	register_action('blog/save', FALSE, "$action_path/save.php"); +	register_action('blog/auto_save_revision', FALSE, "$action_path/auto_save_revision.php");  	register_action('blog/delete', FALSE, "$action_path/delete.php");  } @@ -111,13 +111,13 @@ function blog_page_handler($page) {  		switch ($action) {  			case 'read':  				$title = sprintf(elgg_echo('blog:title:user_blogs'), $user->name); -				$content = elgg_view('page_elements/content_header', array('context' => $content, 'type' => 'blog')); -				$content .= blog_get_page_content_read($user->getGUID(), $page2); +				$content_info = blog_get_page_content_read($user->getGUID(), $page2);  				break;  			case 'new':  			case 'edit': -				$content = blog_get_page_content_edit($page2); +				//$sidebar = elgg_view('blog/sidebar_edit', array('blog_guid' => $page2)); +				$content_info = blog_get_page_content_edit($page2, $page3);  				break;  			case 'archives': @@ -136,17 +136,14 @@ function blog_page_handler($page) {  		}  	} else {  		$title = elgg_echo('blog:title:all_blogs'); -		$content = elgg_view('page_elements/content_header', array('context' => $content, 'type' => 'blog')); -		$content .= elgg_list_entities_from_metadata(array( -			'type' => 'object', -			'subtype' => 'blog', -			'full_view' => FALSE, -			'metadata_name_value_pair' => array('name' => 'status', 'value' => 'final') -		)); +		$content_info = blog_get_page_content_read();  	} -	$sidebar = elgg_view('blog/sidebar_menu'); -	$content = elgg_view('navigation/breadcrumbs') . $content; +	$sidebar .= elgg_view('blog/sidebar_menu'); +	if (isset($content_info['sidebar'])) { +		$sidebar .= $content_info['sidebar']; +	} +	$content = elgg_view('navigation/breadcrumbs') . $content_info['content'];  	$body = elgg_view_layout('one_column_with_sidebar', $content, $sidebar); @@ -154,52 +151,6 @@ function blog_page_handler($page) {  }  /** - * Handles ajax calls for blog. - * - * @param array $page - */ -function blog_ajax_page_handler($page) { -	$action = isset($page[0]) ? $page[0] : FALSE; - -	var_dump($page); - -	switch ($action) { -		case 'save_draft': -			// @todo recycle the save action -			$values = array( -				'title' => '', -				'description' => '', -				'status' => 'draft', -				'access_id' => ACCESS_DEFAULT, -				'comments_on' => 'On', -				'excerpt' => '', -				'tags' => '', -				'container_guid' => '', -				'guid' => '' -			); - -			foreach ($values as $name => $default) { -				$values[$name] = get_input($name, $default); -			} - - - -			/* -			If a title and body, create a blog post marked as a draft and update the -			GUID -			*/ -			break; - -		default: -			$content = 0; -			break; -	} - -	exit; -} - - -/**   * Format and return the correct URL for blogs.   *   * @param ElggObject $entity @@ -220,4 +171,4 @@ function blog_url_handler($entity) {  } -register_elgg_event_handler('init', 'system', 'blog_init');
\ No newline at end of file +register_elgg_event_handler('init', 'system', 'blog_init'); diff --git a/mod/blog/views/default/blog/forms/edit.php b/mod/blog/views/default/blog/forms/edit.php index b19898573..83ee8208e 100644 --- a/mod/blog/views/default/blog/forms/edit.php +++ b/mod/blog/views/default/blog/forms/edit.php @@ -9,11 +9,12 @@   * @link http://elgg.org/   */ +// input names => defaults  $values = array(  	'title' => NULL,  	'description' => NULL, -	'status' => 'final', -	//'publish_date' => NULL, +	'status' => 'published', +	'publish_date' => NULL,  	'access_id' => ACCESS_DEFAULT,  	'comments_on' => 'On',  	'excerpt' => NULL, @@ -25,17 +26,42 @@ $values = array(  $forward = $_SERVER['HTTP_REFERER'];  $action_buttons = ''; -$guid_input = '';  $delete_link = ''; +$draft_warning = '';  // if entity is set, we're editing.  if (isset ($vars['entity'])) {  	$blog = $vars['entity'];  	if ($blog && ($blog instanceof ElggObject) && ($blog->getSubtype() == 'blog')) { -		foreach (array_keys($values) as $field) { -			$values[$field] = $blog->$field; -		} +		// passed in values override sticky values in input views +		// if in a sticky form, don't send the overrides and let the view figure it out. +		//if (!elgg_is_sticky_form()) { +			foreach (array_keys($values) as $field) { +				$values[$field] = $blog->$field; +			} + +			// load the revision annotation if requested +			if (isset($vars['revision']) && $vars['revision'] instanceof ElggAnnotation && $vars['revision']->entity_guid == $blog->getGUID()) { +				$revision = $vars['revision']; +				$values['description'] = $vars['revision']->value; +			} + +			// display a notice if there's an autosaved annotation +			// and we're not editing it. +			if ($auto_save_annotations = $blog->getAnnotations('blog_auto_save', 1)) { +				$auto_save = $auto_save_annotations[0]; +			} else { +				$auto_save == FALSE; +			} + +			if ($auto_save && $auto_save->id != $revision->id) { +				$draft_warning = '<span class="message warning">' +					. elgg_echo('blog:messages:warning:draft') +					. '</span>'; +			} + +		//}  	} else {  		echo elgg_echo('blog:error:post_not_found');  		return FALSE; @@ -48,8 +74,6 @@ if (isset ($vars['entity'])) {  		'text' => elgg_echo('delete'),  		'class' => 'action_button disabled'  	)); - -	$guid_input = elgg_view('input/hidden', array('internalname' => 'guid', 'value' => $values['guid']));  }  $save_button = elgg_view('input/submit', array('value' => elgg_echo('save'), 'class' => 'submit_button')); @@ -77,7 +101,7 @@ $body_input = elgg_view('input/longtext', array(  ));  $save_status = elgg_echo('blog:save_status'); -$never = elgg_echo('never'); +$never = elgg_echo('blog:never');  $status_label = elgg_echo('blog:status');  $status_input = elgg_view('input/pulldown', array( @@ -85,8 +109,8 @@ $status_input = elgg_view('input/pulldown', array(  	'internalid' => 'blog_status',  	'value' => $values['status'],  	'options_values' => array( -		'draft' => elgg_echo('blog:draft'), -		'final' => elgg_echo('blog:final') +		'draft' => elgg_echo('blog:status:draft'), +		'published' => elgg_echo('blog:status:published')  	)  )); @@ -121,12 +145,20 @@ $publish_date_input = elgg_view('input/datepicker', array(  // hidden inputs  //$container_guid_input = elgg_view('input/hidden', array('internalname' => 'container_guid', 'value' => $values['container_guid'])); +$guid_input = elgg_view('input/hidden', array('internalname' => 'guid', 'value' => $values['guid']));  $forward_input = elgg_view('input/hidden', array('internalname' => 'forward', 'value' => $forward)); -$page_title = elgg_echo('blog:edit')." ".$values['title']; +$page_title = elgg_echo('blog:edit') . " " . $values['title']; + +// display notice if editing an old revision +if (isset($vars['revision']) && $vars['revision'] instanceof ElggAnnotation) { +	$page_title .= ' ' . elgg_echo('blog:edit_revision_notice'); +}  $form_body = <<<___END  <h2>$page_title</h2> +$draft_warning +  <p class="margin_top">  	<label for="blog_title">$title_label</label>  	$title_input @@ -137,13 +169,12 @@ $form_body = <<<___END  $excerpt_input  </p> -<p> -	<label for="blog_description">$body_label</label> -	$body_input -</p> +<label for="blog_description">$body_label</label> +$body_input +<br />  <p id="blog_save_status"> -	$save_status:<span id="blog_save_status_time">$never</span> +	$save_status <span id="blog_save_status_time">$never</span>  </p>  <p> @@ -190,6 +221,8 @@ echo elgg_view('input/form', array(  	'body' => $form_body  )); +elgg_clear_sticky_form('blog'); +  ?>  <script type="text/javascript"> @@ -201,13 +234,16 @@ echo elgg_view('input/form', array(  	function blogSaveDraftCallback(data, textStatus, XHR) {  		if (textStatus == 'success' && data.success == true) {  			var form = $('form[name=blog_post]'); -			form.append('<input type="hidden" name="guid" value="' + data.guid + '" />'); + +			// update the guid input element for new posts that now have a guid +			form.find('input[name=guid]').val(data.guid); + +			oldDescription = form.find('textarea[name=description]').val();  			var d = new Date();  			var mins = d.getMinutes() + '';  			if (mins.length == 1) mins = '0' + mins;  			$("#blog_save_status_time").html(d.getHours() + ":" + mins); -  		} else {  			$("#blog_save_status_time").html("<?php echo elgg_echo('error'); ?>");  		} @@ -218,16 +254,16 @@ echo elgg_view('input/form', array(  			tinyMCE.triggerSave();  		} -		// only save when content exists +		// only save on changed content  		var form = $('form[name=blog_post]'); -		var title = form.children('input[name=title]').val(); -		var description = form.children('textarea[name=description]').val(); +		var description = form.find('textarea[name=description]').val(); +		var title = form.find('input[name=title]').val(); -		if (!(title && description)) { +		if (!(description && title) || (description == oldDescription)) {  			return false;  		} -		var draftURL = "<?php echo $vars['url']; ?>action/blog/save?ajax=1"; +		var draftURL = "<?php echo $vars['url']; ?>action/blog/auto_save_revision";  		var postData = form.serializeArray();  		// force draft status @@ -238,10 +274,12 @@ echo elgg_view('input/form', array(  		});  		$.post(draftURL, postData, blogSaveDraftCallback, 'json'); -  	} -	$(document).ready(function(){ +	$(document).ready(function() { +		// get a copy of the body to compare for auto save +		oldDescription = $('form[name=blog_post]').find('textarea[name=description]').val(); +  		$('#excerpt.excerpt').each(function(){  			var allowed = 200; diff --git a/mod/blog/views/default/blog/sidebar_edit.php b/mod/blog/views/default/blog/sidebar_edit.php new file mode 100644 index 000000000..d75c28aad --- /dev/null +++ b/mod/blog/views/default/blog/sidebar_edit.php @@ -0,0 +1,65 @@ +<?php +/** + * Blog sidebar menu for editing / creating a blog post. + * + * @package Blog + * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 + * @author Curverider Ltd + * @copyright Curverider Ltd 2008-2010 + * @link http://elgg.org/ + */ + +//If editing a post, show the previous revisions and drafts. +$blog_guid = isset($vars['blog_guid']) ? $vars['blog_guid'] : FALSE; +$blog = get_entity($blog_guid); + +if (elgg_instanceof($blog, 'object', 'blog') && $blog->canEdit()) { +	$revisions = array(); +	if ($auto_save_annotations = $blog->getAnnotations('blog_auto_save', 1)) { +		$revisions[] = $auto_save_annotations[0]; +	} + +	// count(FALSE) == 1!  AHHH!!! +	if ($saved_revisions = $blog->getAnnotations('blog_revision', 10, 0, 'time_created DESC')) { +		$revision_count = count($saved_revisions); +	} else { +		$revision_count = 0; +	} + +	$revisions = array_merge($revisions, $saved_revisions); +} + +if ($revisions) { +	echo '<ul class="blog_revisions">'; +	$load_base_url = "{$vars['url']}pg/blog/{$owner->username}/edit/{$blog->getGUID()}/"; + +	foreach ($revisions as $revision) { +		$time = friendly_time($revision->time_created); +		$load = elgg_view('output/url', array( +			'href' => $load_base_url . $revision->id, +			'text' => elgg_echo('load') +		)); + + +		if ($revision->name == 'blog_auto_save') { +			$name = elgg_echo('blog:auto_saved_revision'); +			$text = "$name: $time $load"; +			$class = 'class="auto_saved"'; +		} else { +			$name = elgg_echo('blog:revision'); +			$text = "$name: $time $load"; +			$class = 'class="auto_saved"'; + +			$revision_count--; +		} + +		echo <<<___END +<li $class> +$text +</li> + +___END; +	} + +	echo '</ul>'; +}
\ No newline at end of file diff --git a/mod/blog/views/default/blog/sidebar_menu.php b/mod/blog/views/default/blog/sidebar_menu.php index 71bb1ec39..8ecec9a53 100644 --- a/mod/blog/views/default/blog/sidebar_menu.php +++ b/mod/blog/views/default/blog/sidebar_menu.php @@ -31,14 +31,8 @@ Owned blogs;  $loggedin_user = get_loggedin_user();  $page_owner = page_owner_entity(); -if ($loggedin_user) { - -}  ?> -<ul class="submenu"> -	<li><a href="">Drafts</a></li> -</ul>  <?php  	// include a view for plugins to extend  	echo elgg_view("blogs/sidebar", array("object_type" => 'blog')); diff --git a/mod/blog/views/default/blog/sidebar_revisions.php b/mod/blog/views/default/blog/sidebar_revisions.php new file mode 100644 index 000000000..f777316ec --- /dev/null +++ b/mod/blog/views/default/blog/sidebar_revisions.php @@ -0,0 +1,70 @@ +<?php +/** + * Blog sidebar menu showing revisions + * + * @package Blog + * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 + * @author Curverider Ltd + * @copyright Curverider Ltd 2008-2010 + * @link http://elgg.org/ + */ + +//If editing a post, show the previous revisions and drafts. +$blog = isset($vars['entity']) ? $vars['entity'] : FALSE; + + +if (elgg_instanceof($blog, 'object', 'blog') && $blog->canEdit()) { +	$owner = $blog->getOwnerEntity(); +	$revisions = array(); + +	if ($auto_save_annotations = $blog->getAnnotations('blog_auto_save', 1)) { +		$revisions[] = $auto_save_annotations[0]; +	} + +	// count(FALSE) == 1!  AHHH!!! +	if ($saved_revisions = $blog->getAnnotations('blog_revision', 10, 0, 'time_created DESC')) { +		$revision_count = count($saved_revisions); +	} else { +		$revision_count = 0; +	} + +	$revisions = array_merge($revisions, $saved_revisions); + +	if ($revisions) { +		echo '<h3>' . elgg_echo('blog:revisions') . '</h3>'; + +		$n = count($revisions); + +		echo '<ul class="blog_revisions">'; +		$load_base_url = "{$vars['url']}pg/blog/{$owner->username}/edit/{$blog->getGUID()}/"; + +		foreach ($revisions as $revision) { +			$time = friendly_time($revision->time_created); +			$load = elgg_view('output/url', array( +				'href' => $load_base_url . $revision->id, +				'text' => elgg_echo('load') +			)); + +			if ($revision->name == 'blog_auto_save') { +				$name = elgg_echo('blog:auto_saved_revision'); +				$text = "$name: $time $load"; +				$class = 'class="auto_saved"'; +			} else { +				$name = elgg_echo('blog:revision') . " $n"; +				$text = "$name: $time $load"; +				$class = 'class="auto_saved"'; +			} + +			$n--; + +			echo <<<___END +<li $class> +$text +</li> + +___END; +		} + +		echo '</ul>'; +	} +}
\ No newline at end of file diff --git a/mod/blog/views/default/object/blog.php b/mod/blog/views/default/object/blog.php index f1240256a..4a8541261 100644 --- a/mod/blog/views/default/object/blog.php +++ b/mod/blog/views/default/object/blog.php @@ -24,9 +24,10 @@ $excerpt = $blog->excerpt;  $body = $blog->description;  $owner_icon = elgg_view("profile/icon",array('entity' => $owner, 'size' => 'tiny'));  $tags = elgg_view('output/tags', array('tags' => $blog->tags)); -$date = friendly_time($blog->time_created); +$date = friendly_time($blog->publish_date); -if ($blog->comments_on == 'Yes') { +// The "on" status changes for comments, so best to check for !Off +if ($blog->comments_on != 'Off') {  	$comments_count = elgg_count_comments($blog);  	$comments_link = "<a href=\"{$blog->getURL()}#annotations\">" . sprintf(elgg_echo("comments"), $comments_count) . '</a>';  } else { @@ -34,27 +35,31 @@ if ($blog->comments_on == 'Yes') {  }  // links to delete or edit. +$edit = '';  if ($blog->canEdit()) {  	$edit_url = "{$vars['url']}pg/blog/{$owner->username}/edit/{$blog->getGUID()}/";  	$edit_link = "<a href=\"$edit_url\">" . elgg_echo('edit') . '</a>';  	$delete_url = "{$vars['url']}action/blog/delete?guid={$blog->getGUID()}"; -	$delete_link = "<span class='delete_button'>".elgg_view('output/confirmlink', array( +	$delete_link = "<span class='delete_button'>" . elgg_view('output/confirmlink', array(  		'href' => $delete_url,  		'text' => elgg_echo('delete'),  		'confirm' => elgg_echo('deleteconfirm') -	))."</span>"; +	)) . "</span>"; -	$edit = "$edit_link $delete_link"; -} else { -	$edit = ''; +	$status = ''; +	if ($blog->status != 'published') { +		$status_text = elgg_echo("blog:status:{$blog->status}"); +		$status = "<span class='blog_status'>$status_text</a>"; +	} + +	$edit = "$status $edit_link $delete_link";  }  	// include a view for plugins to extend  	$edit = elgg_view("blogs/options", array("object_type" => 'blog')) .$edit;  if ($full) { -	// The "on" status changes for comments, so best to check for !Off  	if ($blog->comments_on != 'Off') {  		$comments = elgg_view_comments($blog);  	} else { @@ -67,7 +72,7 @@ echo <<<___END  <div class="blogpost clearfloat">  	<div id="content_header" class="clearfloat">  		<div class="content_header_title"><h2>$owner_title</h2></div> -	</div>	 +	</div>  	<div class="entity_listing_icon">  		$owner_icon  	</div> @@ -90,7 +95,7 @@ ___END;  } else {  	echo <<<___END -<div class="blog entity_listing clearfloat"> +<div class="blog $status_class entity_listing clearfloat">  	<div class="entity_listing_icon">  		$owner_icon  	</div> | 
