diff options
| author | ben <ben@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-08-11 17:50:24 +0000 | 
|---|---|---|
| committer | ben <ben@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-08-11 17:50:24 +0000 | 
| commit | 257ee6be21a824b3b76647395bf0c04f9be24785 (patch) | |
| tree | d7be4d192a4d0e814f423ad567342b5c0cc665ad /engine/lib/entities.php | |
| parent | 83636f01b355131698848b116b2f5d890580b047 (diff) | |
| download | elgg-257ee6be21a824b3b76647395bf0c04f9be24785.tar.gz elgg-257ee6be21a824b3b76647395bf0c04f9be24785.tar.bz2 | |
Added latest content to the front page
git-svn-id: https://code.elgg.org/elgg/trunk@1847 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'engine/lib/entities.php')
| -rw-r--r-- | engine/lib/entities.php | 74 | 
1 files changed, 65 insertions, 9 deletions
| diff --git a/engine/lib/entities.php b/engine/lib/entities.php index 4cbc4eccc..afc8eed3c 100644 --- a/engine/lib/entities.php +++ b/engine/lib/entities.php @@ -1312,9 +1312,6 @@  		if ($subtype === false || $subtype === null || $subtype === 0)  			return false; -		 -		$type = sanitise_string($type); -		$subtype = get_subtype_id($type, $subtype);  		if ($order_by == "") $order_by = "time_created desc";  		$order_by = sanitise_string($order_by); @@ -1325,11 +1322,37 @@  			$site_guid = $CONFIG->site_guid;  		$where = array(); -		 -		if ($type != "") -			$where[] = "type='$type'"; -		if ($subtype!=="") -			$where[] = "subtype=$subtype"; +		
 +		if (is_array($type)) {
 +			
 +			$tempwhere = "";
 +			if (sizeof($type))
 +			foreach($type as $typekey => $subtypearray) {
 +				foreach($subtypearray as $subtypeval) {
 +					$typekey = sanitise_string($typekey);
 +					if (!empty($subtypeval)) {
 +						$subtypeval = (int) get_subtype_id($typekey, $subtypeval);
 +					} else {
 +						$subtypeval = 0;
 +					}
 +					if (!empty($tempwhere)) $tempwhere .= " or ";
 +					$tempwhere .= "(type = '{$typekey}' and subtype = {$subtypeval})";
 +				}								
 +			}
 +			if (!empty($tempwhere)) $where[] = "({$tempwhere})";
 +			
 +		} else {
 +		
 +			$type = sanitise_string($type);
 +			$subtype = get_subtype_id($type, $subtype);
 +			 +			if ($type != "") +				$where[] = "type='$type'"; +			if ($subtype!=="") +				$where[] = "subtype=$subtype";
 +				
 +		}
 +			  		if ($owner_guid != "") {  			if (!is_array($owner_guid)) {
  				$owner_array = array($owner_guid); @@ -1370,7 +1393,6 @@  		if (!$count) {  			$query .= " order by $order_by";  			if ($limit) $query .= " limit $offset, $limit"; // Add order and limit -  			$dt = get_data($query, "entity_row_to_elggstar");  			return $dt;  		} else { @@ -1943,6 +1965,40 @@  			set_input('guid',$page[0]);  			@include($CONFIG->path . "entities/index.php");  		} +	}
 +	
 +	/**
 +	 * Returns a viewable list of entities based on the registered types
 +	 *
 +	 * @see elgg_view_entity_list
 +	 * 
 +	 * @param string $type The type of entity (eg "user", "object" etc)
 +	 * @param string $subtype The arbitrary subtype of the entity
 +	 * @param int $owner_guid The GUID of the owning user
 +	 * @param int $limit The number of entities to display per page (default: 10)
 +	 * @param true|false $fullview Whether or not to display the full view (default: true)
 +	 * @param true|false $viewtypetoggle Whether or not to allow gallery view 
 +	 * @return string A viewable list of entities
 +	 */
 +	function list_registered_entities($owner_guid = 0, $limit = 10, $fullview = true, $viewtypetoggle = false) {
 +		
 +		$typearray = array();
 +		
 +		if ($object_types = get_registered_entity_types()) {
 +			foreach($object_types as $object_type => $subtype_array) {
 +				if (is_array($subtype_array) && sizeof($subtype_array))
 +					foreach($subtype_array as $object_subtype) {
 +						$typearray[$object_type][] = $object_subtype;
 +					}
 +			}
 +		}
 +		
 +		$offset = (int) get_input('offset');
 +		$count = get_entities($typearray, '', $owner_guid, "", $limit, $offset, true);
 +		$entities = get_entities($typearray, '', $owner_guid, "", $limit, $offset);
 +
 +		return elgg_view_entity_list($entities, $count, $offset, $limit, $fullview, $viewtypetoggle);
 +		
  	}  	/** | 
