| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350 | 
							- <?php
 
- namespace AU\ViewsCounter;
 
- /**
 
-  * Increment the views counter for any elgg entity
 
-  */
 
- function increment_views_counter($entity_guid) {
 
- 	$entity = get_entity($entity_guid);
 
- 	if ($entity) {
 
- 		$user = elgg_get_logged_in_user_entity();
 
- 		// If there is no loggedin user then lets updated the common views counter for all not loggedin users that has owner equal zero
 
- 		$user_guid = ($user) ? ($user->guid) : 0;
 
- 		$options = array(
 
- 			'types' => array($entity->type),
 
- 			'guids' => array($entity_guid),
 
- 			'annotation_names' => array('views_counter'),
 
- 			'annotation_owner_guids' => array($user_guid)
 
- 		);
 
- 		if ($entity->getSubtype()) {
 
- 			$options['subtypes'] = array($entity->getSubtype());
 
- 		}
 
- 		$views_counter = elgg_get_annotations($options);
 
- 		// Update the last view time for this entity to the current time
 
- 		update_last_view_time($entity_guid, $user_guid);
 
- 		if ($views_counter) {
 
- 			return update_annotation($views_counter[0]->id, 'views_counter', $views_counter[0]->value + 1, 'integer', $user_guid, ACCESS_PUBLIC);
 
- 		} else {
 
- 			return create_annotation($entity->guid, 'views_counter', 1, 'integer', $user_guid, ACCESS_PUBLIC);
 
- 		}
 
- 	}
 
- }
 
- /**
 
-  * Update the last view time for this entity to the current time
 
-  * 
 
-  * @param $entity_guid
 
-  * @param $user_guid
 
-  */
 
- function update_last_view_time($entity_guid, $user_guid) {
 
- 	$entity = get_entity($entity_guid);
 
- 	if (!$user = get_entity($user_guid)) {
 
- 		$user = elgg_get_logged_in_user_entity();
 
- 	}
 
- 	if ($entity && $user) {
 
- 		// Get the last view annotation that has the last view time saved
 
- 		$options = array(
 
- 			'types' => array($entity->type),
 
- 			'guids' => array($entity_guid),
 
- 			'annotation_owner_guids' => array($user->guid),
 
- 			'annotation_names' => array('last_view_time')
 
- 		);
 
- 		if ($entity->getSubtype()) {
 
- 			$options['subtypes'] = array($entity->getSubtype());
 
- 		}
 
- 		$last_view_time = elgg_get_annotations($options);
 
- 		// It should exists only one annotation that has the last view time
 
- 		$last_view_time = $last_view_time[0];
 
- 		if ($last_view_time) {
 
- 			// Update the value of last view time with the current time
 
- 			return update_annotation($last_view_time->id, 'last_view_time', time(), 'integer', $user->guid, 2);
 
- 		} else {
 
- 			// Create one annotation with the current time that means the last view time
 
- 			return create_annotation($entity->guid, 'last_view_time', time(), 'integer', $user->guid, 2);
 
- 		}
 
- 	}
 
- }
 
- /**
 
-  * Get the number of views for an elgg entity
 
-  * 
 
-  * @param unknown_type $entity_guid
 
-  * @param unknown_type $owner_guid
 
-  * @return Ambigous <number, boolean>
 
-  */
 
- function get_views_counter($entity_guid, $owner_guid = 0) {
 
- 	$options = array(
 
- 		'guids' => array($entity_guid),
 
- 		'annotation_names' => array('views_counter'),
 
- 		'annotation_calculation' => 'sum'
 
- 	);
 
- 	if ($owner_guid) {
 
- 		$options['annotation_owner_guid'] = $owner_guid;
 
- 	}
 
- 	$views_counter = elgg_get_annotations($options);
 
- 	return $views_counter ? $views_counter : 0;
 
- }
 
- /**
 
-  * Try to set the views counter on the views files based on the pattern followed by elgg for displaying entities
 
-  */
 
- function set_views_counter() {
 
- 	$vc_list = elgg_get_plugin_setting('add_views_counter', PLUGIN_ID);
 
- 	if ($vc_list) {
 
- 		$add_views_counter = unserialize($vc_list);
 
- 	}
 
- 	else {
 
- 		$add_views_counter = array();
 
- 	}
 
- 	
 
- 	if (is_array($add_views_counter) && count($add_views_counter)) {
 
- 		foreach ($add_views_counter as $subtype) {
 
- 			
 
- 			// give plugins an option to use custom views if necessary
 
- 			$params = array('subtype' => $subtype);
 
- 			$handled = elgg_trigger_plugin_hook('views_counter', 'set_counter', $params, false);
 
- 			if ($handled) {
 
- 				continue; // already taken care of
 
- 			}
 
- 			
 
- 			switch ($subtype) {
 
- 				case '':
 
- 					break;
 
- 				case 'user':
 
- 					elgg_extend_view('profile/details', 'views_counter_pageowner', 490);
 
- 					break;
 
- 				case 'group':
 
- 					elgg_extend_view('groups/profile/layout', 'views_counter_pageowner', 490);
 
- 					break;
 
- 				case 'au_set':
 
- 					elgg_extend_view('page/layouts/au_configurable_widgets', 'views_counter_pageowner', 490);
 
- 					break;
 
- 				default:
 
- 					elgg_extend_view('object/' . $subtype, 'views_counter', 490);
 
- 					break;
 
- 			}
 
- 		}
 
- 	}
 
- }
 
- /**
 
-  * Get the valid types for add views counter plugin
 
-  */
 
- function get_valid_types_for_views_counter() {
 
- 	$statistics = get_entity_statistics();
 
- 	$valid_types = array('user', 'group');
 
- 	foreach ($statistics['object'] as $subtype => $counter) {
 
- 		if ($subtype != 'plugin' && $subtype != '__base__') {
 
- 			$valid_types[] = $subtype;
 
- 		}
 
- 	}
 
- 	return $valid_types;
 
- }
 
- /**
 
-  * Try to add the views counter for an entity based on the settings of the views_counter plugin
 
-  * 
 
-  * @param $entity_guid
 
-  */
 
- function add_views_counter($entity_guid) {
 
- 	static $added_entities;
 
- 	
 
- 	if (!is_array($added_entities)) {
 
- 		$added_entities = array();
 
- 	}
 
- 	
 
- 	if (in_array($entity_guid, $added_entities)) {
 
- 		return false; // we've already added this view
 
- 	}
 
- 	
 
- 	$entity = get_entity($entity_guid);
 
- 	
 
- 	if (!$entity) {
 
- 		return false;
 
- 	}
 
- 	// save this guid so we know it's been processed in the future
 
- 	$added_entities[] = $entity_guid;
 
- 	
 
- 	// Get the added types for add a views counter
 
- 	$added_types = unserialize(elgg_get_plugin_setting('add_views_counter', PLUGIN_ID));
 
- 	// Get the types set up by the admin to not allow the views counter
 
- 	$removed_types = unserialize(elgg_get_plugin_setting('remove_views_counter', PLUGIN_ID));
 
- 	// Save the subtype
 
- 	$subtype = $entity->getSubtype();
 
- 	$subtype = ($subtype) ? ($subtype) : $entity->type;
 
- 	// If the entity has a added type then increment the views counter
 
- 	if (in_array($subtype, $added_types)) {
 
- 		return increment_views_counter($entity->guid);
 
- 	} else if (!in_array($subtype, $removed_types)) {
 
- 		// If the views counter is being added for a subtype that was not set up by the admin then let's set the plugin setting now
 
- 		if (!in_array($subtype, $added_types)) {
 
- 			$added_types[] = $subtype;
 
- 			elgg_set_plugin_setting('add_views_counter', serialize($added_types), PLUGIN_ID);
 
- 		}
 
- 		return increment_views_counter($entity->guid);
 
- 	}
 
- 	return false;
 
- }
 
- /**
 
-  * Return an array of entities ordered by the number of views
 
-  * 
 
-  * @param $options
 
-  */
 
- function get_entities_by_views_counter($options) {
 
- 	$dbprefix = elgg_get_config('dbprefix');
 
- 	// Select the sum of the views counter returned by the JOIN
 
- 	$select = 'sum(ms.string) as views_counter';
 
- 	if (is_array($options['selects'])) {
 
- 		$options['selects'][] = $select;
 
- 	} else if ($options['selects']) {
 
- 		$options['selects'] = array($options['selects'], $select);
 
- 	} else {
 
- 		$options['selects'] = array($select);
 
- 	}
 
- 	// Get the annotations "views_counter" for each entity
 
- 	$metastring_id = elgg_get_metastring_id('views_counter');
 
- 	$join = 'LEFT JOIN ' . $dbprefix . 'annotations a ON a.entity_guid = e.guid AND a.name_id = ' . $metastring_id;
 
- 	if (is_array($options['joins'])) {
 
- 		$options['joins'][] = $join;
 
- 	} else if ($options['joins']) {
 
- 		$options['joins'] = array($options['joins'], $join);
 
- 	} else {
 
- 		$options['joins'] = array($join);
 
- 	}
 
- 	// JOIN the value of the annotations. The value of each views counter...
 
- 	$options['joins'][] = 'LEFT JOIN ' . $dbprefix . 'metastrings ms ON a.entity_guid = e.guid AND a.name_id = ' . $metastring_id . ' AND a.value_id = ms.id';
 
- 	// Check if the user does not want to list by best average any value different of: 'desc' 
 
- 	if ($options['order_by'] != 'asc') {
 
- 		$options['order_by'] = ' views_counter desc, e.time_created desc';
 
- 	} else {
 
- 		$options['order_by'] = ' views_counter asc, e.time_created desc';
 
- 	}
 
- 	// Group the result of JOIN annotations by entity because each entity may have infinite annotations "generic_rate"
 
- 	$options['group_by'] .= ' e.guid ';
 
- 	// Let the elgg_get_entities() function make do work for us :)
 
- 	$entities = elgg_get_entities($options);
 
- 	return $entities;
 
- }
 
- /**
 
-  * Get the class in accordance to the plugin settings
 
-  * 
 
-  */
 
- function get_views_counter_class() {
 
- 	$remove_css = elgg_get_plugin_setting('remove_css_class', PLUGIN_ID);
 
- 	if (!$remove_css || $remove_css == 'no') {
 
- 		$class = 'views_counter';
 
- 	}
 
- 	$float = elgg_get_plugin_setting('float_direction', 'views_counter');
 
- 	if ($float == 'none') {
 
- 		$float = '';
 
- 	}
 
- 	$class .= ' ' . $float;
 
- 	return $class;
 
- }
 
- /**
 
-  * Get the last view time of a user for an entity
 
-  * 
 
-  * @param unknown_type $entity_guid
 
-  * @param unknown_type $user_guid
 
-  * @return boolean
 
-  */
 
- function get_last_view_time($entity_guid, $user_guid) {
 
- 	$entity = get_entity($entity_guid);
 
- 	if ($entity) {
 
- 		$user = get_entity($user_guid);
 
- 		if (!$user) {
 
- 			$user = elgg_get_logged_in_user_entity();
 
- 		}
 
- 		// Try to get the metadata views counter, if there is views counter then We may know which time the user made the last saw for this this entity
 
- 		$options = array(
 
- 			'guids' => array($entity_guid),
 
- 			'types' => array($entity->type),
 
- 			'annotation_names' => array('last_view_time'),
 
- 			'annotation_owner_guids' => array($user->guid)
 
- 		);
 
- 		if ($entity->getSubtype()) {
 
- 			$options['subtypes'] = array($entity->getSubtype());
 
- 		}
 
- 		$last_view_time = elgg_get_annotations($options);
 
- 		$last_view_time = $last_view_time[0];
 
- 		if ($last_view_time) {
 
- 			return $last_view_time->value;
 
- 		}
 
- 	}
 
- 	return false;
 
- }
 
- /**
 
-  * Check if the user did see the last update for an entity based on
 
-  * the last view time annotation and the updated time for the elgg entity
 
-  * 
 
-  * @param $entity_guid
 
-  * @param $user_guid
 
-  */
 
- function did_see_last_update($entity_guid, $user_guid) {
 
- 	$entity = get_entity($entity_guid);
 
- 	if ($entity) {
 
- 		$user = get_entity($user_guid);
 
- 		if (!$user) {
 
- 			$user = elgg_get_logged_in_user_entity();
 
- 		}
 
- 		$last_view_time = get_last_view_time($entity->guid, $user->guid);
 
- 		$last_view_time = ($last_view_time) ? ($last_view_time) : 0;
 
- 		if ($entity->time_updated > $last_view_time) {
 
- 			return true;
 
- 		} else {
 
- 			return false;
 
- 		}
 
- 	}
 
- 	return null;
 
- }
 
 
  |