| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 | <?php/** * Define a usernotification. * @author Valentin CARRUESCO * @category Plugin * @license MIT */class UserNotification extends Entity{	public $id,$notification,$user,$read;	protected $TABLE_NAME = 'user_notification';	public $fields =	array(		'id' => 'key',		'notification' => 'int',		'user' => 'string',		'read' => 'boolean'	);	public $joins = array(		'notification' => 'Notification'	);	public static function byUser($myUser,$options = array()){		require_once(__DIR__.SLASH.'Notification.class.php');		$options = array_merge(array(			'limit' => 100,			'unread' => false,			'types' => array()		),$options);		//Création des user_notification absentes pour les notification pinned		foreach(Notification::staticQuery("SELECT n.id FROM {{table}} n LEFT JOIN `user_notification` un ON un.notification = n.id AND un.user=? WHERE n.pinned=? AND un.id IS NULL",array($myUser->login,1),true) as $pinneds){			$userNotification = new UserNotification();			$userNotification->notification = $pinneds->id;			$userNotification->user = $myUser->login;			$userNotification->read = 0;			$userNotification->save();		}		//récuperation des user_notifications		$query = 'SELECT *, un.id as id FROM {{table}} un LEFT JOIN '.Notification::tableName().' n ON un.notification=n.id 					WHERE un.user=? AND (n.start<? OR n.start IS NULL) AND (n.end>? OR n.end IS NULL) ';		$data = array($myUser->login,time(),time());		if($options['unread']===true){			$query .= 'AND (un.read = ?)';			$data[] = 0;		}		if(count($options['types'])!=0){			$query .= ' and n.type IN ('.str_repeat('?,', count($options['types']) - 1) . '?'.')';			$data = array_merge($data, $options['types']);		} 		$query .= ' ORDER BY n.created DESC LIMIT '.$options['limit'];				return UserNotification::staticQuery($query,$data);	}	public static function get_unreads_count($myUser,$key=null) {				require_once(__DIR__.SLASH.'Notification.class.php');		$query = 'SELECT COUNT(*) unread, n.type FROM {{table}} un INNER JOIN '.Notification::tableName().' n ON un.notification=n.id WHERE un.user=? AND (n.start<? OR n.start IS NULL) AND (n.end>? OR n.end IS NULL) AND (un.read = ?) GROUP BY n.type';		$unreads = array();		foreach (UserNotification::staticQuery($query, array($myUser->login,time(),time(),0)) as $unread)			$unreads['detailled'][$unread['type']] = $unread['unread'];		$unreads['total'] = isset($unreads['detailled']) ? array_sum($unreads['detailled']) : 0;		$unreads['compact'] = $unreads['total'] > 5 ? '5+' : $unreads['total'];		return isset($key) && isset($unreads[$key]) ? $unreads[$key] : $unreads;	}}?>
 |