Notify => Notification
Notifs => Notifications
This commit is contained in:
		
					parent
					
						
							
								e59a9fbef7
							
						
					
				
			
			
				commit
				
					
						0f932ae723
					
				
			
		
					 19 changed files with 250 additions and 254 deletions
				
			
		|  | @ -5905,7 +5905,7 @@ function api_friendica_notification($type) | |||
| 	if ($a->argc!==3) { | ||||
| 		throw new BadRequestException("Invalid argument count"); | ||||
| 	} | ||||
| 	$notes = DI::notify()->getAll([], ['seen' => 'ASC', 'date' => 'DESC'], 50); | ||||
| 	$notes = DI::notification()->getAll([], ['seen' => 'ASC', 'date' => 'DESC'], 50); | ||||
| 
 | ||||
| 	if ($type == "xml") { | ||||
| 		$xmlnotes = []; | ||||
|  | @ -5947,7 +5947,7 @@ function api_friendica_notification_seen($type) | |||
| 
 | ||||
| 	$id = (!empty($_REQUEST['id']) ? intval($_REQUEST['id']) : 0); | ||||
| 
 | ||||
| 	$nm = DI::notify(); | ||||
| 	$nm = DI::notification(); | ||||
| 	$note = $nm->getByID($id); | ||||
| 	if (is_null($note)) { | ||||
| 		throw new BadRequestException("Invalid argument"); | ||||
|  |  | |||
|  | @ -516,7 +516,7 @@ function notification($params) | |||
| 
 | ||||
| 		$notify_id = DBA::lastInsertId(); | ||||
| 
 | ||||
| 		$itemlink = DI::baseUrl().'/notify/view/'.$notify_id; | ||||
| 		$itemlink = DI::baseUrl().'/notification/view/'.$notify_id; | ||||
| 		$msg = Renderer::replaceMacros($epreamble, ['$itemlink' => $itemlink]); | ||||
| 		$msg_cache = format_notification_message($datarray['name_cache'], strip_tags(BBCode::convert($msg))); | ||||
| 
 | ||||
|  |  | |||
|  | @ -443,7 +443,7 @@ function ping_get_notifications($uid) | |||
| 				); | ||||
| 			} | ||||
| 
 | ||||
| 			$notification["href"] = DI::baseUrl() . "/notify/view/" . $notification["id"]; | ||||
| 			$notification["href"] = DI::baseUrl() . "/notification/view/" . $notification["id"]; | ||||
| 
 | ||||
| 			if ($notification["visible"] | ||||
| 				&& !$notification["deleted"] | ||||
|  |  | |||
|  | @ -257,11 +257,11 @@ abstract class DI | |||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @return Model\Notify | ||||
| 	 * @return Model\Notification | ||||
| 	 */ | ||||
| 	public static function notify() | ||||
| 	public static function notification() | ||||
| 	{ | ||||
| 		return self::$dice->create(Model\Notify::class); | ||||
| 		return self::$dice->create(Model\Notification::class); | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ use Friendica\Network\HTTPException; | |||
|  * Methods for read and write notifications from/to database | ||||
|  *  or for formatting notifications | ||||
|  */ | ||||
| final class Notify | ||||
| final class Notification | ||||
| { | ||||
| 	/** @var int The default limit of notifies per page */ | ||||
| 	const DEFAULT_PAGE_LIMIT = 80; | ||||
|  | @ -172,8 +172,8 @@ final class Notify | |||
| 	/** | ||||
| 	 * Format the notification query in an usable array | ||||
| 	 * | ||||
| 	 * @param array  $notifies The array from the db query | ||||
| 	 * @param string $ident    The notifications identifier (e.g. network) | ||||
| 	 * @param array  $notifications The array from the db query | ||||
| 	 * @param string $ident         The notifications identifier (e.g. network) | ||||
| 	 * | ||||
| 	 * @return array | ||||
| 	 *                       string 'label' => The type of the notification | ||||
|  | @ -186,126 +186,126 @@ final class Notify | |||
| 	 *                       bool 'seen' => Is the notification marked as "seen" | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	private function formatList(array $notifies, string $ident = "") | ||||
| 	private function formatList(array $notifications, string $ident = "") | ||||
| 	{ | ||||
| 		$formattedNotifies = []; | ||||
| 
 | ||||
| 		foreach ($notifies as $notify) { | ||||
| 		foreach ($notifications as $notification) { | ||||
| 			// Because we use different db tables for the notification query
 | ||||
| 			// we have sometimes $notify['unseen'] and sometimes $notify['seen].
 | ||||
| 			// So we will have to transform $notify['unseen']
 | ||||
| 			if (array_key_exists('unseen', $notify)) { | ||||
| 				$notify['seen'] = ($notify['unseen'] > 0 ? false : true); | ||||
| 			// we have sometimes $notification['unseen'] and sometimes $notification['seen].
 | ||||
| 			// So we will have to transform $notification['unseen']
 | ||||
| 			if (array_key_exists('unseen', $notification)) { | ||||
| 				$notification['seen'] = ($notification['unseen'] > 0 ? false : true); | ||||
| 			} | ||||
| 
 | ||||
| 			// For feed items we use the user's contact, since the avatar is mostly self choosen.
 | ||||
| 			if (!empty($notify['network']) && $notify['network'] == Protocol::FEED) { | ||||
| 				$notify['author-avatar'] = $notify['contact-avatar']; | ||||
| 			if (!empty($notification['network']) && $notification['network'] == Protocol::FEED) { | ||||
| 				$notification['author-avatar'] = $notification['contact-avatar']; | ||||
| 			} | ||||
| 
 | ||||
| 			// Depending on the identifier of the notification we need to use different defaults
 | ||||
| 			switch ($ident) { | ||||
| 				case self::SYSTEM: | ||||
| 					$default_item_label = 'notify'; | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/notify/view/' . $notify['id']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notify['photo'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notify['url']; | ||||
| 					$default_item_text  = strip_tags(BBCode::convert($notify['msg'])); | ||||
| 					$default_item_when  = DateTimeFormat::local($notify['date'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notify['date']); | ||||
| 					$default_item_label = 'notification'; | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/notification/view/' . $notification['id']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notification['photo'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notification['url']; | ||||
| 					$default_item_text  = strip_tags(BBCode::convert($notification['msg'])); | ||||
| 					$default_item_when  = DateTimeFormat::local($notification['date'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notification['date']); | ||||
| 					break; | ||||
| 
 | ||||
| 				case self::HOME: | ||||
| 					$default_item_label = 'comment'; | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/display/' . $notify['parent-guid']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notify['author-link']; | ||||
| 					$default_item_text  = $this->l10n->t("%s commented on %s's post", $notify['author-name'], $notify['parent-author-name']); | ||||
| 					$default_item_when  = DateTimeFormat::local($notify['created'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notify['created']); | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/display/' . $notification['parent-guid']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notification['author-link']; | ||||
| 					$default_item_text  = $this->l10n->t("%s commented on %s's post", $notification['author-name'], $notification['parent-author-name']); | ||||
| 					$default_item_when  = DateTimeFormat::local($notification['created'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notification['created']); | ||||
| 					break; | ||||
| 
 | ||||
| 				default: | ||||
| 					$default_item_label = (($notify['id'] == $notify['parent']) ? 'post' : 'comment'); | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/display/' . $notify['parent-guid']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notify['author-link']; | ||||
| 					$default_item_text  = (($notify['id'] == $notify['parent']) | ||||
| 						? $this->l10n->t("%s created a new post", $notify['author-name']) | ||||
| 						: $this->l10n->t("%s commented on %s's post", $notify['author-name'], $notify['parent-author-name'])); | ||||
| 					$default_item_when  = DateTimeFormat::local($notify['created'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notify['created']); | ||||
| 					$default_item_label = (($notification['id'] == $notification['parent']) ? 'post' : 'comment'); | ||||
| 					$default_item_link  = $this->baseUrl->get(true) . '/display/' . $notification['parent-guid']; | ||||
| 					$default_item_image = ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO); | ||||
| 					$default_item_url   = $notification['author-link']; | ||||
| 					$default_item_text  = (($notification['id'] == $notification['parent']) | ||||
| 						? $this->l10n->t("%s created a new post", $notification['author-name']) | ||||
| 						: $this->l10n->t("%s commented on %s's post", $notification['author-name'], $notification['parent-author-name'])); | ||||
| 					$default_item_when  = DateTimeFormat::local($notification['created'], 'r'); | ||||
| 					$default_item_ago   = Temporal::getRelativeDate($notification['created']); | ||||
| 			} | ||||
| 
 | ||||
| 			// Transform the different types of notification in an usable array
 | ||||
| 			switch ($notify['verb']) { | ||||
| 			switch ($notification['verb']) { | ||||
| 				case Activity::LIKE: | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'like', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s liked %s's post", $notify['author-name'], $notify['parent-author-name']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s liked %s's post", $notification['author-name'], $notification['parent-author-name']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
| 				case Activity::DISLIKE: | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'dislike', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s disliked %s's post", $notify['author-name'], $notify['parent-author-name']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s disliked %s's post", $notification['author-name'], $notification['parent-author-name']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
| 				case Activity::ATTEND: | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'attend', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is attending %s's event", $notify['author-name'], $notify['parent-author-name']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is attending %s's event", $notification['author-name'], $notification['parent-author-name']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
| 				case Activity::ATTENDNO: | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'attendno', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is not attending %s's event", $notify['author-name'], $notify['parent-author-name']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is not attending %s's event", $notification['author-name'], $notification['parent-author-name']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
| 				case Activity::ATTENDMAYBE: | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'attendmaybe', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s may attend %s's event", $notify['author-name'], $notify['parent-author-name']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s may attend %s's event", $notification['author-name'], $notification['parent-author-name']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
| 				case Activity::FRIEND: | ||||
| 					if (!isset($notify['object'])) { | ||||
| 					if (!isset($notification['object'])) { | ||||
| 						$formattedNotify = [ | ||||
| 							'label' => 'friend', | ||||
| 							'link'  => $default_item_link, | ||||
|  | @ -314,26 +314,26 @@ final class Notify | |||
| 							'text'  => $default_item_text, | ||||
| 							'when'  => $default_item_when, | ||||
| 							'ago'   => $default_item_ago, | ||||
| 							'seen'  => $notify['seen'] | ||||
| 							'seen'  => $notification['seen'] | ||||
| 						]; | ||||
| 						break; | ||||
| 					} | ||||
| 					/// @todo Check if this part here is used at all
 | ||||
| 					$this->logger->info('Complete data.', ['notify' => $notify, 'callStack' => System::callstack(20)]); | ||||
| 					$this->logger->info('Complete data.', ['notification' => $notification, 'callStack' => System::callstack(20)]); | ||||
| 
 | ||||
| 					$xmlHead         = "<" . "?xml version='1.0' encoding='UTF-8' ?" . ">"; | ||||
| 					$obj             = XML::parseString($xmlHead . $notify['object']); | ||||
| 					$notify['fname'] = $obj->title; | ||||
| 					$xmlHead               = "<" . "?xml version='1.0' encoding='UTF-8' ?" . ">"; | ||||
| 					$obj                   = XML::parseString($xmlHead . $notification['object']); | ||||
| 					$notification['fname'] = $obj->title; | ||||
| 
 | ||||
| 					$formattedNotify = [ | ||||
| 						'label' => 'friend', | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notify['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notify['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notify['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is now friends with %s", $notify['author-name'], $notify['fname']), | ||||
| 						'link'  => $this->baseUrl->get(true) . '/display/' . $notification['parent-guid'], | ||||
| 						'image' => ProxyUtils::proxifyUrl($notification['author-avatar'], false, ProxyUtils::SIZE_MICRO), | ||||
| 						'url'   => $notification['author-link'], | ||||
| 						'text'  => $this->l10n->t("%s is now friends with %s", $notification['author-name'], $notification['fname']), | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 					break; | ||||
| 
 | ||||
|  | @ -346,7 +346,7 @@ final class Notify | |||
| 						'text'  => $default_item_text, | ||||
| 						'when'  => $default_item_when, | ||||
| 						'ago'   => $default_item_ago, | ||||
| 						'seen'  => $notify['seen'] | ||||
| 						'seen'  => $notification['seen'] | ||||
| 					]; | ||||
| 			} | ||||
| 
 | ||||
|  | @ -359,10 +359,10 @@ final class Notify | |||
| 	/** | ||||
| 	 * Get network notifications | ||||
| 	 * | ||||
| 	 * @param bool $seen    False => only include notifications into the query | ||||
| 	 * @param bool $seen          False => only include notifications into the query | ||||
| 	 *                            which aren't marked as "seen" | ||||
| 	 * @param int        $start   Start the query at this point | ||||
| 	 * @param int        $limit   Maximum number of query results | ||||
| 	 * @param int  $start         Start the query at this point | ||||
| 	 * @param int  $limit         Maximum number of query results | ||||
| 	 * | ||||
| 	 * @return array [string, array] | ||||
| 	 *    string 'ident' => Notification identifier | ||||
|  | @ -402,10 +402,10 @@ final class Notify | |||
| 	/** | ||||
| 	 * Get system notifications | ||||
| 	 * | ||||
| 	 * @param bool $seen    False => only include notifications into the query | ||||
| 	 * @param bool $seen          False => only include notifications into the query | ||||
| 	 *                            which aren't marked as "seen" | ||||
| 	 * @param int        $start   Start the query at this point | ||||
| 	 * @param int        $limit   Maximum number of query results | ||||
| 	 * @param int  $start         Start the query at this point | ||||
| 	 * @param int  $limit         Maximum number of query results | ||||
| 	 * | ||||
| 	 * @return array [string, array] | ||||
| 	 *    string 'ident' => Notification identifier | ||||
|  | @ -447,10 +447,10 @@ final class Notify | |||
| 	/** | ||||
| 	 * Get personal notifications | ||||
| 	 * | ||||
| 	 * @param bool $seen    False => only include notifications into the query | ||||
| 	 * @param bool $seen          False => only include notifications into the query | ||||
| 	 *                            which aren't marked as "seen" | ||||
| 	 * @param int        $start   Start the query at this point | ||||
| 	 * @param int        $limit   Maximum number of query results | ||||
| 	 * @param int  $start         Start the query at this point | ||||
| 	 * @param int  $limit         Maximum number of query results | ||||
| 	 * | ||||
| 	 * @return array [string, array] | ||||
| 	 *    string 'ident' => Notification identifier | ||||
|  | @ -494,10 +494,10 @@ final class Notify | |||
| 	/** | ||||
| 	 * Get home notifications | ||||
| 	 * | ||||
| 	 * @param bool $seen    False => only include notifications into the query | ||||
| 	 * @param bool $seen          False => only include notifications into the query | ||||
| 	 *                            which aren't marked as "seen" | ||||
| 	 * @param int        $start   Start the query at this point | ||||
| 	 * @param int        $limit   Maximum number of query results | ||||
| 	 * @param int  $start         Start the query at this point | ||||
| 	 * @param int  $limit         Maximum number of query results | ||||
| 	 * | ||||
| 	 * @return array [string, array] | ||||
| 	 *    string 'ident' => Notification identifier | ||||
|  | @ -8,7 +8,7 @@ use Friendica\Content\Pager; | |||
| use Friendica\Core\Renderer; | ||||
| use Friendica\Core\System; | ||||
| use Friendica\DI; | ||||
| use Friendica\Model\Notify; | ||||
| use Friendica\Model\Notification; | ||||
| use Friendica\Network\HTTPException\ForbiddenException; | ||||
| 
 | ||||
| /** | ||||
|  | @ -20,29 +20,29 @@ abstract class BaseNotifications extends BaseModule | |||
| { | ||||
| 	/** @var array Array of URL parameters */ | ||||
| 	const URL_TYPES = [ | ||||
| 		Notify::NETWORK  => 'network', | ||||
| 		Notify::SYSTEM   => 'system', | ||||
| 		Notify::HOME     => 'home', | ||||
| 		Notify::PERSONAL => 'personal', | ||||
| 		Notify::INTRO    => 'intros', | ||||
| 		Notification::NETWORK  => 'network', | ||||
| 		Notification::SYSTEM   => 'system', | ||||
| 		Notification::HOME     => 'home', | ||||
| 		Notification::PERSONAL => 'personal', | ||||
| 		Notification::INTRO    => 'intros', | ||||
| 	]; | ||||
| 
 | ||||
| 	/** @var array Array of the allowed notifies and their printable name */ | ||||
| 	const PRINT_TYPES = [ | ||||
| 		Notify::NETWORK  => 'Network', | ||||
| 		Notify::SYSTEM   => 'System', | ||||
| 		Notify::HOME     => 'Home', | ||||
| 		Notify::PERSONAL => 'Personal', | ||||
| 		Notify::INTRO    => 'Introductions', | ||||
| 		Notification::NETWORK  => 'Network', | ||||
| 		Notification::SYSTEM   => 'System', | ||||
| 		Notification::HOME     => 'Home', | ||||
| 		Notification::PERSONAL => 'Personal', | ||||
| 		Notification::INTRO    => 'Introductions', | ||||
| 	]; | ||||
| 
 | ||||
| 	/** @var array The array of access keys for notify pages */ | ||||
| 	/** @var array The array of access keys for notification pages */ | ||||
| 	const ACCESS_KEYS = [ | ||||
| 		Notify::NETWORK  => 'w', | ||||
| 		Notify::SYSTEM   => 'y', | ||||
| 		Notify::HOME     => 'h', | ||||
| 		Notify::PERSONAL => 'r', | ||||
| 		Notify::INTRO    => 'i', | ||||
| 		Notification::NETWORK  => 'w', | ||||
| 		Notification::SYSTEM   => 'y', | ||||
| 		Notification::HOME     => 'h', | ||||
| 		Notification::PERSONAL => 'r', | ||||
| 		Notification::INTRO    => 'i', | ||||
| 	]; | ||||
| 
 | ||||
| 	/** @var int The default count of items per page */ | ||||
|  | @ -54,12 +54,12 @@ abstract class BaseNotifications extends BaseModule | |||
| 	protected static $firstItemNum; | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Collects all notifies from the backend | ||||
| 	 * Collects all notifications from the backend | ||||
| 	 * | ||||
| 	 * @return array The determined notification array | ||||
| 	 *               ['header', 'notifs'] | ||||
| 	 *               ['header', 'notifications'] | ||||
| 	 */ | ||||
| 	abstract public static function getNotifies(); | ||||
| 	abstract public static function getNotifications(); | ||||
| 
 | ||||
| 	public static function init(array $parameters = []) | ||||
| 	{ | ||||
|  | @ -104,22 +104,22 @@ abstract class BaseNotifications extends BaseModule | |||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
| 		System::jsonExit(static::getNotifies()['notifs'] ?? []); | ||||
| 		System::jsonExit(static::getNotifications()['notifs'] ?? []); | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Shows the printable result of notifications for a specific tab | ||||
| 	 * | ||||
| 	 * @param string $notif_header    The notification header | ||||
| 	 * @param array  $notif_content   The array with the notifications | ||||
| 	 * @param string $notif_nocontent The string in case there are no notifications | ||||
| 	 * @param array  $notif_show_lnk  The possible links at the top | ||||
| 	 * @param string $header    The notification header | ||||
| 	 * @param array  $content   The array with the notifications | ||||
| 	 * @param string $noContent The string in case there are no notifications | ||||
| 	 * @param array  $showLink  The possible links at the top | ||||
| 	 * | ||||
| 	 * @return string The rendered output | ||||
| 	 * | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	protected static function printContent(string $notif_header, array $notif_content, string $notif_nocontent, array $notif_show_lnk) | ||||
| 	protected static function printContent(string $header, array $content, string $noContent, array $showLink) | ||||
| 	{ | ||||
| 		// Get the nav tabs for the notification pages
 | ||||
| 		$tabs = self::getTabs(); | ||||
|  | @ -129,12 +129,12 @@ abstract class BaseNotifications extends BaseModule | |||
| 
 | ||||
| 		$notif_tpl = Renderer::getMarkupTemplate('notifications/notifications.tpl'); | ||||
| 		return Renderer::replaceMacros($notif_tpl, [ | ||||
| 			'$notif_header'    => $notif_header ?? DI::l10n()->t('Notifications'), | ||||
| 			'$notif_header'    => $header ?? DI::l10n()->t('Notifications'), | ||||
| 			'$tabs'            => $tabs, | ||||
| 			'$notif_content'   => $notif_content, | ||||
| 			'$notif_nocontent' => $notif_nocontent, | ||||
| 			'$notif_show_lnk'  => $notif_show_lnk, | ||||
| 			'$notif_paginate'  => $pager->renderMinimal(count($notif_content)) | ||||
| 			'$notif_content'   => $content, | ||||
| 			'$notif_nocontent' => $noContent, | ||||
| 			'$notif_show_lnk'  => $showLink, | ||||
| 			'$notif_paginate'  => $pager->renderMinimal(count($content)) | ||||
| 		]); | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -18,16 +18,16 @@ class Introductions extends BaseNotifications | |||
| 	/** | ||||
| 	 * @inheritDoc | ||||
| 	 */ | ||||
| 	public static function getNotifies() | ||||
| 	public static function getNotifications() | ||||
| 	{ | ||||
| 		$id  = (int)DI::args()->get(2, 0); | ||||
| 		$all = DI::args()->get(2) == 'all'; | ||||
| 
 | ||||
| 		$notifs = DI::notify()->getIntroList($all, self::$firstItemNum, self::ITEMS_PER_PAGE, $id); | ||||
| 		$notifications = DI::notification()->getIntroList($all, self::$firstItemNum, self::ITEMS_PER_PAGE, $id); | ||||
| 
 | ||||
| 		return [ | ||||
| 			'header' => DI::l10n()->t('Notifications'), | ||||
| 			'notifs' => $notifs, | ||||
| 			'header'        => DI::l10n()->t('Notifications'), | ||||
| 			'notifications' => $notifications, | ||||
| 		]; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -37,52 +37,52 @@ class Introductions extends BaseNotifications | |||
| 
 | ||||
| 		$all = DI::args()->get(2) == 'all'; | ||||
| 
 | ||||
| 		$notif_content   = []; | ||||
| 		$notif_nocontent = ''; | ||||
| 		$notificationContent   = []; | ||||
| 		$notificationNoContent = ''; | ||||
| 
 | ||||
| 		$notif_result = self::getNotifies(); | ||||
| 		$notifs       = $notif_result['notifs'] ?? []; | ||||
| 		$notif_header = $notif_result['header'] ?? ''; | ||||
| 		$notificationResult = self::getNotifications(); | ||||
| 		$notifications      = $notificationResult['notifications'] ?? []; | ||||
| 		$notificationHeader = $notificationResult['header'] ?? ''; | ||||
| 
 | ||||
| 		$sugg = Renderer::getMarkupTemplate('notifications/suggestions.tpl'); | ||||
| 		$tpl  = Renderer::getMarkupTemplate('notifications/intros.tpl'); | ||||
| 		$notificationSuggestions = Renderer::getMarkupTemplate('notifications/suggestions.tpl'); | ||||
| 		$notificationTemplate    = Renderer::getMarkupTemplate('notifications/intros.tpl'); | ||||
| 
 | ||||
| 		// The link to switch between ignored and normal connection requests
 | ||||
| 		$notif_show_lnk = [ | ||||
| 		$notificationShowLink = [ | ||||
| 			'href' => (!$all ? 'notifications/intros/all' : 'notifications/intros'), | ||||
| 			'text' => (!$all ? DI::l10n()->t('Show Ignored Requests') : DI::l10n()->t('Hide Ignored Requests')) | ||||
| 		]; | ||||
| 
 | ||||
| 		// Loop through all introduction notifications.This creates an array with the output html for each
 | ||||
| 		// introduction
 | ||||
| 		foreach ($notifs['notifications'] as $notif) { | ||||
| 		foreach ($notifications['notifications'] as $notification) { | ||||
| 
 | ||||
| 			// There are two kind of introduction. Contacts suggested by other contacts and normal connection requests.
 | ||||
| 			// We have to distinguish between these two because they use different data.
 | ||||
| 			switch ($notif['label']) { | ||||
| 			switch ($notification['label']) { | ||||
| 				case 'friend_suggestion': | ||||
| 					$notif_content[] = Renderer::replaceMacros($sugg, [ | ||||
| 						'$type'           => $notif['label'], | ||||
| 					$notificationContent[] = Renderer::replaceMacros($notificationSuggestions, [ | ||||
| 						'$type'           => $notification['label'], | ||||
| 						'$str_notifytype' => DI::l10n()->t('Notification type:'), | ||||
| 						'$notify_type'    => $notif['notify_type'], | ||||
| 						'$intro_id'       => $notif['intro_id'], | ||||
| 						'$notify_type'    => $notification['notify_type'], | ||||
| 						'$intro_id'       => $notification['intro_id'], | ||||
| 						'$lbl_madeby'     => DI::l10n()->t('Suggested by:'), | ||||
| 						'$madeby'         => $notif['madeby'], | ||||
| 						'$madeby_url'     => $notif['madeby_url'], | ||||
| 						'$madeby_zrl'     => $notif['madeby_zrl'], | ||||
| 						'$madeby_addr'    => $notif['madeby_addr'], | ||||
| 						'$contact_id'     => $notif['contact_id'], | ||||
| 						'$photo'          => $notif['photo'], | ||||
| 						'$fullname'       => $notif['name'], | ||||
| 						'$url'            => $notif['url'], | ||||
| 						'$zrl'            => $notif['zrl'], | ||||
| 						'$madeby'         => $notification['madeby'], | ||||
| 						'$madeby_url'     => $notification['madeby_url'], | ||||
| 						'$madeby_zrl'     => $notification['madeby_zrl'], | ||||
| 						'$madeby_addr'    => $notification['madeby_addr'], | ||||
| 						'$contact_id'     => $notification['contact_id'], | ||||
| 						'$photo'          => $notification['photo'], | ||||
| 						'$fullname'       => $notification['name'], | ||||
| 						'$url'            => $notification['url'], | ||||
| 						'$zrl'            => $notification['zrl'], | ||||
| 						'$lbl_url'        => DI::l10n()->t('Profile URL'), | ||||
| 						'$addr'           => $notif['addr'], | ||||
| 						'$hidden'         => ['hidden', DI::l10n()->t('Hide this contact from others'), ($notif['hidden'] == 1), ''], | ||||
| 						'$knowyou'        => $notif['knowyou'], | ||||
| 						'$addr'           => $notification['addr'], | ||||
| 						'$hidden'         => ['hidden', DI::l10n()->t('Hide this contact from others'), ($notification['hidden'] == 1), ''], | ||||
| 						'$knowyou'        => $notification['knowyou'], | ||||
| 						'$approve'        => DI::l10n()->t('Approve'), | ||||
| 						'$note'           => $notif['note'], | ||||
| 						'$request'        => $notif['request'], | ||||
| 						'$note'           => $notification['note'], | ||||
| 						'$request'        => $notification['request'], | ||||
| 						'$ignore'         => DI::l10n()->t('Ignore'), | ||||
| 						'$discard'        => DI::l10n()->t('Discard'), | ||||
| 					]); | ||||
|  | @ -90,8 +90,8 @@ class Introductions extends BaseNotifications | |||
| 
 | ||||
| 				// Normal connection requests
 | ||||
| 				default: | ||||
| 					$friend_selected = (($notif['network'] !== Protocol::OSTATUS) ? ' checked="checked" ' : ' disabled '); | ||||
| 					$fan_selected    = (($notif['network'] === Protocol::OSTATUS) ? ' checked="checked" disabled ' : ''); | ||||
| 					$friend_selected = (($notification['network'] !== Protocol::OSTATUS) ? ' checked="checked" ' : ' disabled '); | ||||
| 					$fan_selected    = (($notification['network'] === Protocol::OSTATUS) ? ' checked="checked" disabled ' : ''); | ||||
| 
 | ||||
| 					$lbl_knowyou = ''; | ||||
| 					$knowyou     = ''; | ||||
|  | @ -99,31 +99,31 @@ class Introductions extends BaseNotifications | |||
| 					$helptext2   = ''; | ||||
| 					$helptext3   = ''; | ||||
| 
 | ||||
| 					if ($notif['network'] === Protocol::DFRN) { | ||||
| 					if ($notification['network'] === Protocol::DFRN) { | ||||
| 						$lbl_knowyou = DI::l10n()->t('Claims to be known to you: '); | ||||
| 						$knowyou     = (($notif['knowyou']) ? DI::l10n()->t('yes') : DI::l10n()->t('no')); | ||||
| 						$knowyou     = (($notification['knowyou']) ? DI::l10n()->t('yes') : DI::l10n()->t('no')); | ||||
| 						$helptext    = DI::l10n()->t('Shall your connection be bidirectional or not?'); | ||||
| 						$helptext2   = DI::l10n()->t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']); | ||||
| 						$helptext3   = DI::l10n()->t('Accepting %s as a subscriber allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']); | ||||
| 					} elseif ($notif['network'] === Protocol::DIASPORA) { | ||||
| 						$helptext2   = DI::l10n()->t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notification['name'], $notification['name']); | ||||
| 						$helptext3   = DI::l10n()->t('Accepting %s as a subscriber allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notification['name']); | ||||
| 					} elseif ($notification['network'] === Protocol::DIASPORA) { | ||||
| 						$helptext  = DI::l10n()->t('Shall your connection be bidirectional or not?'); | ||||
| 						$helptext2 = DI::l10n()->t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']); | ||||
| 						$helptext3 = DI::l10n()->t('Accepting %s as a sharer allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']); | ||||
| 						$helptext2 = DI::l10n()->t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notification['name'], $notification['name']); | ||||
| 						$helptext3 = DI::l10n()->t('Accepting %s as a sharer allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notification['name']); | ||||
| 					} | ||||
| 
 | ||||
| 					$dfrn_tpl  = Renderer::getMarkupTemplate('notifications/netfriend.tpl'); | ||||
| 					$dfrn_text = Renderer::replaceMacros($dfrn_tpl, [ | ||||
| 						'$intro_id'        => $notif['intro_id'], | ||||
| 						'$intro_id'        => $notification['intro_id'], | ||||
| 						'$friend_selected' => $friend_selected, | ||||
| 						'$fan_selected'    => $fan_selected, | ||||
| 						'$approve_as1'     => $helptext, | ||||
| 						'$approve_as2'     => $helptext2, | ||||
| 						'$approve_as3'     => $helptext3, | ||||
| 						'$as_friend'       => DI::l10n()->t('Friend'), | ||||
| 						'$as_fan'          => (($notif['network'] == Protocol::DIASPORA) ? DI::l10n()->t('Sharer') : DI::l10n()->t('Subscriber')) | ||||
| 						'$as_fan'          => (($notification['network'] == Protocol::DIASPORA) ? DI::l10n()->t('Sharer') : DI::l10n()->t('Subscriber')) | ||||
| 					]); | ||||
| 
 | ||||
| 					$contact = DBA::selectFirst('contact', ['network', 'protocol'], ['id' => $notif['contact_id']]); | ||||
| 					$contact = DBA::selectFirst('contact', ['network', 'protocol'], ['id' => $notification['contact_id']]); | ||||
| 
 | ||||
| 					if (($contact['network'] != Protocol::DFRN) || ($contact['protocol'] == Protocol::ACTIVITYPUB)) { | ||||
| 						$action = 'follow_confirm'; | ||||
|  | @ -131,51 +131,51 @@ class Introductions extends BaseNotifications | |||
| 						$action = 'dfrn_confirm'; | ||||
| 					} | ||||
| 
 | ||||
| 					$header = $notif['name']; | ||||
| 					$header = $notification['name']; | ||||
| 
 | ||||
| 					if ($notif['addr'] != '') { | ||||
| 						$header .= ' <' . $notif['addr'] . '>'; | ||||
| 					if ($notification['addr'] != '') { | ||||
| 						$header .= ' <' . $notification['addr'] . '>'; | ||||
| 					} | ||||
| 
 | ||||
| 					$header .= ' (' . ContactSelector::networkToName($notif['network'], $notif['url']) . ')'; | ||||
| 					$header .= ' (' . ContactSelector::networkToName($notification['network'], $notification['url']) . ')'; | ||||
| 
 | ||||
| 					if ($notif['network'] != Protocol::DIASPORA) { | ||||
| 					if ($notification['network'] != Protocol::DIASPORA) { | ||||
| 						$discard = DI::l10n()->t('Discard'); | ||||
| 					} else { | ||||
| 						$discard = ''; | ||||
| 					} | ||||
| 
 | ||||
| 					$notif_content[] = Renderer::replaceMacros($tpl, [ | ||||
| 						'$type'           => $notif['label'], | ||||
| 					$notificationContent[] = Renderer::replaceMacros($notificationTemplate, [ | ||||
| 						'$type'           => $notification['label'], | ||||
| 						'$header'         => $header, | ||||
| 						'$str_notifytype' => DI::l10n()->t('Notification type:'), | ||||
| 						'$notify_type'    => $notif['notify_type'], | ||||
| 						'$notify_type'    => $notification['notify_type'], | ||||
| 						'$dfrn_text'      => $dfrn_text, | ||||
| 						'$dfrn_id'        => $notif['dfrn_id'], | ||||
| 						'$uid'            => $notif['uid'], | ||||
| 						'$intro_id'       => $notif['intro_id'], | ||||
| 						'$contact_id'     => $notif['contact_id'], | ||||
| 						'$photo'          => $notif['photo'], | ||||
| 						'$fullname'       => $notif['name'], | ||||
| 						'$location'       => $notif['location'], | ||||
| 						'$dfrn_id'        => $notification['dfrn_id'], | ||||
| 						'$uid'            => $notification['uid'], | ||||
| 						'$intro_id'       => $notification['intro_id'], | ||||
| 						'$contact_id'     => $notification['contact_id'], | ||||
| 						'$photo'          => $notification['photo'], | ||||
| 						'$fullname'       => $notification['name'], | ||||
| 						'$location'       => $notification['location'], | ||||
| 						'$lbl_location'   => DI::l10n()->t('Location:'), | ||||
| 						'$about'          => $notif['about'], | ||||
| 						'$about'          => $notification['about'], | ||||
| 						'$lbl_about'      => DI::l10n()->t('About:'), | ||||
| 						'$keywords'       => $notif['keywords'], | ||||
| 						'$keywords'       => $notification['keywords'], | ||||
| 						'$lbl_keywords'   => DI::l10n()->t('Tags:'), | ||||
| 						'$gender'         => $notif['gender'], | ||||
| 						'$gender'         => $notification['gender'], | ||||
| 						'$lbl_gender'     => DI::l10n()->t('Gender:'), | ||||
| 						'$hidden'         => ['hidden', DI::l10n()->t('Hide this contact from others'), ($notif['hidden'] == 1), ''], | ||||
| 						'$url'            => $notif['url'], | ||||
| 						'$zrl'            => $notif['zrl'], | ||||
| 						'$hidden'         => ['hidden', DI::l10n()->t('Hide this contact from others'), ($notification['hidden'] == 1), ''], | ||||
| 						'$url'            => $notification['url'], | ||||
| 						'$zrl'            => $notification['zrl'], | ||||
| 						'$lbl_url'        => DI::l10n()->t('Profile URL'), | ||||
| 						'$addr'           => $notif['addr'], | ||||
| 						'$addr'           => $notification['addr'], | ||||
| 						'$lbl_knowyou'    => $lbl_knowyou, | ||||
| 						'$lbl_network'    => DI::l10n()->t('Network:'), | ||||
| 						'$network'        => ContactSelector::networkToName($notif['network'], $notif['url']), | ||||
| 						'$network'        => ContactSelector::networkToName($notification['network'], $notification['url']), | ||||
| 						'$knowyou'        => $knowyou, | ||||
| 						'$approve'        => DI::l10n()->t('Approve'), | ||||
| 						'$note'           => $notif['note'], | ||||
| 						'$note'           => $notification['note'], | ||||
| 						'$ignore'         => DI::l10n()->t('Ignore'), | ||||
| 						'$discard'        => $discard, | ||||
| 						'$action'         => $action, | ||||
|  | @ -184,11 +184,11 @@ class Introductions extends BaseNotifications | |||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if (count($notifs['notifications']) == 0) { | ||||
| 		if (count($notifications['notifications']) == 0) { | ||||
| 			info(DI::l10n()->t('No introductions.') . EOL); | ||||
| 			$notif_nocontent = DI::l10n()->t('No more %s notifications.', $notifs['ident']); | ||||
| 			$notificationNoContent = DI::l10n()->t('No more %s notifications.', $notifications['ident']); | ||||
| 		} | ||||
| 
 | ||||
| 		return self::printContent($notif_header, $notif_content, $notif_nocontent, $notif_show_lnk); | ||||
| 		return self::printContent($notificationHeader, $notificationContent, $notificationNoContent, $notificationShowLink); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -8,9 +8,9 @@ use Friendica\DI; | |||
| use Friendica\Network\HTTPException; | ||||
| 
 | ||||
| /** | ||||
|  * Interacting with the /notify command | ||||
|  * Interacting with the /notification command | ||||
|  */ | ||||
| class Notify extends BaseModule | ||||
| class Notification extends BaseModule | ||||
| { | ||||
| 	public static function init(array $parameters = []) | ||||
| 	{ | ||||
|  | @ -21,11 +21,9 @@ class Notify extends BaseModule | |||
| 
 | ||||
| 	public static function rawContent(array $parameters = []) | ||||
| 	{ | ||||
| 		$a = DI::app(); | ||||
| 
 | ||||
| 		// @TODO: Replace with parameter from router
 | ||||
| 		if ($a->argc > 2 && $a->argv[1] === 'mark' && $a->argv[2] === 'all') { | ||||
| 			$success              = DI::notify()->setAllSeen(); | ||||
| 		if (DI::args()->get(1) === 'mark' && DI::args()->get(2) === 'all') { | ||||
| 			$success = DI::notification()->setAllSeen(); | ||||
| 
 | ||||
| 			header('Content-type: application/json; charset=utf-8'); | ||||
| 			echo json_encode([ | ||||
|  | @ -36,22 +34,20 @@ class Notify extends BaseModule | |||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Redirect to the notifications main page or to the url for the chosen notify | ||||
| 	 * Redirect to the notifications main page or to the url for the chosen notifications | ||||
| 	 * | ||||
| 	 * @return string|void | ||||
| 	 * @throws HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public static function content(array $parameters = []) | ||||
| 	{ | ||||
| 		$a = DI::app(); | ||||
| 
 | ||||
| 		// @TODO: Replace with parameter from router
 | ||||
| 		if ($a->argc > 2 && $a->argv[1] === 'view' && intval($a->argv[2])) { | ||||
| 			$notificationsManager = DI::notify(); | ||||
| 		if (DI::args()->getArgc() > 2 && DI::args()->get(1) === 'view' && intval(DI::args()->get(2))) { | ||||
| 			$notificationManager = DI::notification(); | ||||
| 			// @TODO: Replace with parameter from router
 | ||||
| 			$note = $notificationsManager->getByID($a->argv[2]); | ||||
| 			$note = $notificationManager->getByID(DI::args()->get(2)); | ||||
| 			if (!empty($note)) { | ||||
| 				$notificationsManager->setSeen($note); | ||||
| 				$notificationManager->setSeen($note); | ||||
| 				if (!empty($note['link'])) { | ||||
| 					System::externalRedirect($note['link']); | ||||
| 				} | ||||
|  | @ -20,31 +20,31 @@ class Notifications extends BaseNotifications | |||
| 	/** | ||||
| 	 * {@inheritDoc} | ||||
| 	 */ | ||||
| 	public static function getNotifies() | ||||
| 	public static function getNotifications() | ||||
| 	{ | ||||
| 		$nm = DI::notify(); | ||||
| 		$nm = DI::notification(); | ||||
| 
 | ||||
| 		$notif_header = ''; | ||||
| 		$notificationHeader = ''; | ||||
| 
 | ||||
| 		// Get the network notifications
 | ||||
| 		if ((DI::args()->get(1) == 'network')) { | ||||
| 			$notif_header = DI::l10n()->t('Network Notifications'); | ||||
| 			$notifs       = $nm->getNetworkList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 			$notificationHeader = DI::l10n()->t('Network Notifications'); | ||||
| 			$notifications      = $nm->getNetworkList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 
 | ||||
| 			// Get the system notifications
 | ||||
| 		} elseif ((DI::args()->get(1) == 'system')) { | ||||
| 			$notif_header = DI::l10n()->t('System Notifications'); | ||||
| 			$notifs       = $nm->getSystemList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 			$notificationHeader = DI::l10n()->t('System Notifications'); | ||||
| 			$notifications      = $nm->getSystemList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 
 | ||||
| 			// Get the personal notifications
 | ||||
| 		} elseif ((DI::args()->get(1) == 'personal')) { | ||||
| 			$notif_header = DI::l10n()->t('Personal Notifications'); | ||||
| 			$notifs       = $nm->getPersonalList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 			$notificationHeader = DI::l10n()->t('Personal Notifications'); | ||||
| 			$notifications      = $nm->getPersonalList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 
 | ||||
| 			// Get the home notifications
 | ||||
| 		} elseif ((DI::args()->get(1) == 'home')) { | ||||
| 			$notif_header = DI::l10n()->t('Home Notifications'); | ||||
| 			$notifs       = $nm->getHomeList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 			$notificationHeader = DI::l10n()->t('Home Notifications'); | ||||
| 			$notifications      = $nm->getHomeList(self::$showAll, self::$firstItemNum, self::ITEMS_PER_PAGE); | ||||
| 			// fallback - redirect to main page
 | ||||
| 		} else { | ||||
| 			DI::baseUrl()->redirect('notifications'); | ||||
|  | @ -54,12 +54,12 @@ class Notifications extends BaseNotifications | |||
| 		$pager = new Pager(DI::args()->getQueryString(), self::ITEMS_PER_PAGE); | ||||
| 
 | ||||
| 		// Add additional informations (needed for json output)
 | ||||
| 		$notifs['items_page'] = $pager->getItemsPerPage(); | ||||
| 		$notifs['page']       = $pager->getPage(); | ||||
| 		$notifications['items_page'] = $pager->getItemsPerPage(); | ||||
| 		$notifications['page']       = $pager->getPage(); | ||||
| 
 | ||||
| 		return [ | ||||
| 			'header' => $notif_header, | ||||
| 			'notifs' => $notifs, | ||||
| 			'header'        => $notificationHeader, | ||||
| 			'notifications' => $notifications, | ||||
| 		]; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -67,18 +67,18 @@ class Notifications extends BaseNotifications | |||
| 	{ | ||||
| 		Nav::setSelected('notifications'); | ||||
| 
 | ||||
| 		$notif_content   = []; | ||||
| 		$notif_nocontent = ''; | ||||
| 		$notificationContent   = []; | ||||
| 		$notificationNoContent = ''; | ||||
| 
 | ||||
| 		$notif_result = self::getNotifies(); | ||||
| 		$notifs       = $notif_result['notifs'] ?? []; | ||||
| 		$notif_header = $notif_result['header'] ?? ''; | ||||
| 		$notificationResult = self::getNotifications(); | ||||
| 		$notifications      = $notificationResult['notifications'] ?? []; | ||||
| 		$notificationHeader = $notificationResult['header'] ?? ''; | ||||
| 
 | ||||
| 
 | ||||
| 		if (!empty($notifs['notifications'])) { | ||||
| 		if (!empty($notifications['notifications'])) { | ||||
| 			// Loop trough ever notification This creates an array with the output html for each
 | ||||
| 			// notification and apply the correct template according to the notificationtype (label).
 | ||||
| 			foreach ($notifs['notifications'] as $notif) { | ||||
| 			foreach ($notifications['notifications'] as $notification) { | ||||
| 				$notification_templates = [ | ||||
| 					'like'        => 'notifications/likes_item.tpl', | ||||
| 					'dislike'     => 'notifications/dislikes_item.tpl', | ||||
|  | @ -88,31 +88,31 @@ class Notifications extends BaseNotifications | |||
| 					'friend'      => 'notifications/friends_item.tpl', | ||||
| 					'comment'     => 'notifications/comments_item.tpl', | ||||
| 					'post'        => 'notifications/posts_item.tpl', | ||||
| 					'notify'      => 'notifications/notify.tpl', | ||||
| 					'notification'      => 'notifications/notification.tpl', | ||||
| 				]; | ||||
| 
 | ||||
| 				$tpl_notif = Renderer::getMarkupTemplate($notification_templates[$notif['label']]); | ||||
| 				$notificationTemplate = Renderer::getMarkupTemplate($notification_templates[$notification['label']]); | ||||
| 
 | ||||
| 				$notif_content[] = Renderer::replaceMacros($tpl_notif, [ | ||||
| 					'$item_label' => $notif['label'], | ||||
| 					'$item_link'  => $notif['link'], | ||||
| 					'$item_image' => $notif['image'], | ||||
| 					'$item_url'   => $notif['url'], | ||||
| 					'$item_text'  => $notif['text'], | ||||
| 					'$item_when'  => $notif['when'], | ||||
| 					'$item_ago'   => $notif['ago'], | ||||
| 					'$item_seen'  => $notif['seen'], | ||||
| 				$notificationContent[] = Renderer::replaceMacros($notificationTemplate, [ | ||||
| 					'$item_label' => $notification['label'], | ||||
| 					'$item_link'  => $notification['link'], | ||||
| 					'$item_image' => $notification['image'], | ||||
| 					'$item_url'   => $notification['url'], | ||||
| 					'$item_text'  => $notification['text'], | ||||
| 					'$item_when'  => $notification['when'], | ||||
| 					'$item_ago'   => $notification['ago'], | ||||
| 					'$item_seen'  => $notification['seen'], | ||||
| 				]); | ||||
| 			} | ||||
| 		} else { | ||||
| 			$notif_nocontent = DI::l10n()->t('No more %s notifications.', $notifs['ident']); | ||||
| 			$notificationNoContent = DI::l10n()->t('No more %s notifications.', $notifications['ident']); | ||||
| 		} | ||||
| 
 | ||||
| 		$notif_show_lnk = [ | ||||
| 			'href' => (self::$showAll ? 'notifications/' . $notifs['ident'] : 'notifications/' . $notifs['ident'] . '?show=all'), | ||||
| 		$notificationShowLink = [ | ||||
| 			'href' => (self::$showAll ? 'notifications/' . $notifications['ident'] : 'notifications/' . $notifications['ident'] . '?show=all'), | ||||
| 			'text' => (self::$showAll ? DI::l10n()->t('Show unread') : DI::l10n()->t('Show all')), | ||||
| 		]; | ||||
| 
 | ||||
| 		return self::printContent($notif_header, $notif_content, $notif_nocontent, $notif_show_lnk); | ||||
| 		return self::printContent($notificationHeader, $notificationContent, $notificationNoContent, $notificationShowLink); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -177,10 +177,10 @@ return [ | |||
| 		'/intros/{contact:\d+}[/json]' => [Module\Notifications\Introductions::class, [R::GET, R::POST]], | ||||
| 	], | ||||
| 
 | ||||
| 	'/notify'         => [ | ||||
| 		'[/]'            => [Module\Notifications\Notify::class, [R::GET]], | ||||
| 		'/view/{id:\d+}' => [Module\Notifications\Notify::class, [R::GET]], | ||||
| 		'/mark/all'      => [Module\Notifications\Notify::class, [R::GET]], | ||||
| 	'/notification'         => [ | ||||
| 		'[/]'            => [Module\Notifications\Notification::class, [R::GET]], | ||||
| 		'/view/{id:\d+}' => [Module\Notifications\Notification::class, [R::GET]], | ||||
| 		'/mark/all'      => [Module\Notifications\Notification::class, [R::GET]], | ||||
| 	], | ||||
| 	'/objects/{guid}' => [Module\Objects::class, [R::GET]], | ||||
| 
 | ||||
|  |  | |||
|  | @ -949,7 +949,7 @@ function checkboxhighlight(box) { | |||
| } | ||||
| 
 | ||||
| function notifyMarkAll() { | ||||
| 	$.get('notify/mark/all', function(data) { | ||||
| 	$.get('notification/mark/all', function(data) { | ||||
| 		if (timer) { | ||||
| 			clearTimeout(timer); | ||||
| 		} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| 
 | ||||
| {{include file="notifications/notify.tpl"}} | ||||
| {{include file="notifications/notification.tpl"}} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue