diff options
Diffstat (limited to 'phpBB/phpbb/notification')
| -rw-r--r-- | phpBB/phpbb/notification/manager.php | 8 | ||||
| -rw-r--r-- | phpBB/phpbb/notification/method/messenger_base.php | 4 | 
2 files changed, 9 insertions, 3 deletions
| diff --git a/phpBB/phpbb/notification/manager.php b/phpBB/phpbb/notification/manager.php index db92170dd8..222d9fe9e6 100644 --- a/phpBB/phpbb/notification/manager.php +++ b/phpBB/phpbb/notification/manager.php @@ -186,6 +186,7 @@ class manager  		if (!$options['count_total'] || $total_count)  		{  			$rowset = array(); +			$selected_unread_count = 0;  			// Get the main notifications  			$sql = 'SELECT n.*, nt.notification_type_name @@ -200,11 +201,12 @@ class manager  			while ($row = $this->db->sql_fetchrow($result))  			{  				$rowset[$row['notification_id']] = $row; +				$selected_unread_count += (int) !$row['notification_read'];  			}  			$this->db->sql_freeresult($result);  			// Get all unread notifications -			if ($unread_count && $options['all_unread'] && !empty($rowset)) +			if ($selected_unread_count < $unread_count && $options['all_unread'] && !empty($rowset))  			{  				$sql = 'SELECT n.*, nt.notification_type_name  				FROM ' . $this->notifications_table . ' n, ' . $this->notification_types_table . ' nt @@ -923,6 +925,8 @@ class manager  	{  		$notification_type_ids = $this->cache->get('notification_type_ids'); +		$this->db->sql_transaction('begin'); +  		if ($notification_type_ids === false)  		{  			$notification_type_ids = array(); @@ -957,6 +961,8 @@ class manager  			$this->cache->put('notification_type_ids', $notification_type_ids);  		} +		$this->db->sql_transaction('commit'); +  		return $notification_type_ids[$notification_type_name];  	} diff --git a/phpBB/phpbb/notification/method/messenger_base.php b/phpBB/phpbb/notification/method/messenger_base.php index c3aee088f9..3c6d617c66 100644 --- a/phpBB/phpbb/notification/method/messenger_base.php +++ b/phpBB/phpbb/notification/method/messenger_base.php @@ -74,14 +74,14 @@ abstract class messenger_base extends \phpbb\notification\method\base  				continue;  			} -			$messenger->template($template_dir_prefix . $notification->get_email_template(), $user['user_lang']); +			$messenger->template($notification->get_email_template(), $user['user_lang'], '', $template_dir_prefix);  			$messenger->set_addresses($user);  			$messenger->assign_vars(array_merge(array(  				'USERNAME'						=> $user['username'], -				'U_NOTIFICATION_SETTINGS'		=> generate_board_url() . '/ucp.' . $this->php_ext . '?i=ucp_notifications', +				'U_NOTIFICATION_SETTINGS'		=> generate_board_url() . '/ucp.' . $this->php_ext . '?i=ucp_notifications&mode=notification_options',  			), $notification->get_email_template_variables()));  			$messenger->send($notify_method); | 
