mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-24 21:26:24 +02:00 
			
		
		
		
	Merge branch 'develop-ascraeus' into develop
* develop-ascraeus: [ticket/12703] Only query database for subscription types once
This commit is contained in:
		| @@ -23,6 +23,9 @@ class manager | ||||
| 	/** @var array */ | ||||
| 	protected $notification_types; | ||||
|  | ||||
| 	/** @var array */ | ||||
| 	protected $subscription_types; | ||||
|  | ||||
| 	/** @var array */ | ||||
| 	protected $notification_methods; | ||||
|  | ||||
| @@ -524,33 +527,36 @@ class manager | ||||
| 	*/ | ||||
| 	public function get_subscription_types() | ||||
| 	{ | ||||
| 		$subscription_types = array(); | ||||
|  | ||||
| 		foreach ($this->notification_types as $type_name => $data) | ||||
| 		if ($this->subscription_types === null) | ||||
| 		{ | ||||
| 			$type = $this->get_item_type_class($type_name); | ||||
| 			$this->subscription_types = array(); | ||||
|  | ||||
| 			if ($type instanceof \phpbb\notification\type\type_interface && $type->is_available()) | ||||
| 			foreach ($this->notification_types as $type_name => $data) | ||||
| 			{ | ||||
| 				$options = array_merge(array( | ||||
| 					'id'		=> $type->get_type(), | ||||
| 					'lang'		=> 'NOTIFICATION_TYPE_' . strtoupper($type->get_type()), | ||||
| 					'group'		=> 'NOTIFICATION_GROUP_MISCELLANEOUS', | ||||
| 				), (($type::$notification_option !== false) ? $type::$notification_option : array())); | ||||
| 				$type = $this->get_item_type_class($type_name); | ||||
|  | ||||
| 				$subscription_types[$options['group']][$options['id']] = $options; | ||||
| 				if ($type instanceof \phpbb\notification\type\type_interface && $type->is_available()) | ||||
| 				{ | ||||
| 					$options = array_merge(array( | ||||
| 						'id' => $type->get_type(), | ||||
| 						'lang' => 'NOTIFICATION_TYPE_' . strtoupper($type->get_type()), | ||||
| 						'group' => 'NOTIFICATION_GROUP_MISCELLANEOUS', | ||||
| 					), (($type::$notification_option !== false) ? $type::$notification_option : array())); | ||||
|  | ||||
| 					$this->subscription_types[$options['group']][$options['id']] = $options; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// Move Miscellaneous to the very last section | ||||
| 			if (isset($this->subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS'])) | ||||
| 			{ | ||||
| 				$miscellaneous = $this->subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']; | ||||
| 				unset($this->subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']); | ||||
| 				$this->subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS'] = $miscellaneous; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// Move Miscellaneous to the very last section | ||||
| 		if (isset($subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS'])) | ||||
| 		{ | ||||
| 			$miscellaneous = $subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']; | ||||
| 			unset($subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']); | ||||
| 			$subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS'] = $miscellaneous; | ||||
| 		} | ||||
|  | ||||
| 		return $subscription_types; | ||||
| 		return $this->subscription_types; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
|   | ||||
		Reference in New Issue
	
	Block a user