Show conversations in network default view ordered by activity
This commit is contained in:
		
					parent
					
						
							
								fdd372a798
							
						
					
				
			
			
				commit
				
					
						694e74d54d
					
				
			
		
					 1 changed files with 20 additions and 7 deletions
				
			
		|  | @ -311,21 +311,29 @@ function network_content(&$a, $update = 0) { | ||||||
| 	else { | 	else { | ||||||
| 
 | 
 | ||||||
| 		// Normal conversation view
 | 		// Normal conversation view
 | ||||||
|  | 		// Show conversation by activity date
 | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
| 		// First fetch a known number of parent items
 | 		// First fetch a known number of parent items
 | ||||||
| 
 | 
 | ||||||
| 		$r = q("SELECT `item`.`id` AS `item_id`, `contact`.`uid` AS `contact_uid`
 | 		$r = q("SELECT `item`.`id` AS `item_id`, `contact`.`uid` AS `contact_uid`
 | ||||||
| 			FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 			, (SELECT `_com`.`parent`,max(`_com`.`created`) as `created` | ||||||
|  | 				FROM `item` AS `_com`  | ||||||
|  | 				WHERE `_com`.`uid`=%d AND `_com`.`parent`!=`id`  | ||||||
|  | 				GROUP BY `_com`.`parent` ORDER BY `created` DESC) AS `com`  | ||||||
|  | 			WHERE `item`.`id`=`com`.`parent` AND | ||||||
|  | 			`item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			AND `item`.`parent` = `item`.`id` | 			 | ||||||
| 			$sql_extra | 			$sql_extra | ||||||
| 			ORDER BY `item`.`created` DESC LIMIT %d ,%d ",
 | 			ORDER BY `com`.`created` DESC LIMIT %d ,%d ",
 | ||||||
|  | 			intval(local_user()), | ||||||
| 			intval(local_user()), | 			intval(local_user()), | ||||||
| 			intval($a->pager['start']), | 			intval($a->pager['start']), | ||||||
| 			intval($a->pager['itemspage']) | 			intval($a->pager['itemspage']) | ||||||
| 		); | 		); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 		// Then fetch all the children of the parents that are on this page
 | 		// Then fetch all the children of the parents that are on this page
 | ||||||
| 
 | 
 | ||||||
| 		$parents_arr = array(); | 		$parents_arr = array(); | ||||||
|  | @ -340,13 +348,18 @@ function network_content(&$a, $update = 0) { | ||||||
| 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | ||||||
| 				`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 				`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 				FROM `item`, (SELECT `p`.`id`,`p`.`created` FROM `item` AS `p` WHERE `p`.`parent`=`p`.`id`) as `parentitem`, `contact` | 				FROM `item`, `contact`, | ||||||
|  | 					(SELECT `_com`.`parent`,max(`_com`.`created`) as `created` | ||||||
|  | 					FROM `item` AS `_com`  | ||||||
|  | 					WHERE `_com`.`uid`=%d AND `_com`.`parent`!=`id`  | ||||||
|  | 					GROUP BY `_com`.`parent` ORDER BY `created` DESC) AS `com`  | ||||||
| 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 				AND `contact`.`id` = `item`.`contact-id` | 				AND `contact`.`id` = `item`.`contact-id` | ||||||
| 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 				AND `item`.`parent` = `parentitem`.`id` AND `item`.`parent` IN ( %s ) | 				AND `item`.`parent` = `com`.`parent` AND `item`.`parent` IN ( %s ) | ||||||
| 				$sql_extra | 				$sql_extra | ||||||
| 				ORDER BY `parentitem`.`created`  DESC, `item`.`gravity` ASC, `item`.`created` ASC ",
 | 				ORDER BY `com`.`created`  DESC, `item`.`gravity` ASC, `item`.`created` ASC ",
 | ||||||
|  | 				intval(local_user()), | ||||||
| 				intval(local_user()), | 				intval(local_user()), | ||||||
| 				dbesc($parents_str) | 				dbesc($parents_str) | ||||||
| 			); | 			); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue