diff options
Diffstat (limited to 'phpBB')
| -rw-r--r-- | phpBB/docs/CHANGELOG.html | 1 | ||||
| -rw-r--r-- | phpBB/includes/acp/acp_board.php | 25 | ||||
| -rw-r--r-- | phpBB/includes/db/dbal.php | 18 | ||||
| -rw-r--r-- | phpBB/includes/db/firebird.php | 5 | ||||
| -rw-r--r-- | phpBB/includes/db/oracle.php | 5 | ||||
| -rw-r--r-- | phpBB/includes/functions_admin.php | 20 | ||||
| -rw-r--r-- | phpBB/language/en/acp/board.php | 1 | 
7 files changed, 72 insertions, 3 deletions
| diff --git a/phpBB/docs/CHANGELOG.html b/phpBB/docs/CHANGELOG.html index aef5d601d0..494d325e2b 100644 --- a/phpBB/docs/CHANGELOG.html +++ b/phpBB/docs/CHANGELOG.html @@ -185,6 +185,7 @@  		<li>[Change] Warn users about potentially dangerous BBcodes.</li>  		<li>[Feature] Ability to use HTTP authentication in ATOM feeds by passing the GET parameter "auth=http".</li>  		<li>[Feature] Add INTTEXT token type to custom bbcodes to allow non-ASCII letters in html attributes.</li> +		<li>[Feature] Add ability to enable quick reply in all forums.</li>  	</ul> diff --git a/phpBB/includes/acp/acp_board.php b/phpBB/includes/acp/acp_board.php index 20a63e646e..a5feac1902 100644 --- a/phpBB/includes/acp/acp_board.php +++ b/phpBB/includes/acp/acp_board.php @@ -34,7 +34,7 @@ class acp_board  		$user->add_lang('acp/board');  		$action	= request_var('action', ''); -		$submit = (isset($_POST['submit'])) ? true : false; +		$submit = (isset($_POST['submit']) || isset($_POST['allow_quick_reply_enable'])) ? true : false;  		$form_key = 'acp_board';  		add_form_key($form_key); @@ -89,7 +89,7 @@ class acp_board  						'allow_nocensors'		=> array('lang' => 'ALLOW_NO_CENSORS',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true),  						'allow_bookmarks'		=> array('lang' => 'ALLOW_BOOKMARKS',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true),  						'allow_birthdays'		=> array('lang' => 'ALLOW_BIRTHDAYS',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), -						'allow_quick_reply'		=> array('lang' => 'ALLOW_QUICK_REPLY',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), +						'allow_quick_reply'		=> array('lang' => 'ALLOW_QUICK_REPLY',		'validate' => 'bool',	'type' => 'custom', 'method' => 'quick_reply', 'explain' => true),  						'legend2'				=> 'ACP_LOAD_SETTINGS',  						'load_birthdays'		=> array('lang' => 'YES_BIRTHDAYS',			'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), @@ -173,7 +173,7 @@ class acp_board  						'allow_nocensors'		=> array('lang' => 'ALLOW_NO_CENSORS',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true),  						'allow_bookmarks'		=> array('lang' => 'ALLOW_BOOKMARKS',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true),  						'enable_post_confirm'	=> array('lang' => 'VISUAL_CONFIRM_POST',	'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), -						'allow_quick_reply'		=> array('lang' => 'ALLOW_QUICK_REPLY',		'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), +						'allow_quick_reply'		=> array('lang' => 'ALLOW_QUICK_REPLY',		'validate' => 'bool',	'type' => 'custom', 'method' => 'quick_reply', 'explain' => true),  						'legend2'				=> 'POSTING',  						'bump_type'				=> false, @@ -472,6 +472,11 @@ class acp_board  			if ($submit)  			{  				set_config($config_name, $config_value); + +				if ($config_name == 'allow_quick_reply' && isset($_POST['allow_quick_reply_enable'])) +				{ +					enable_bitfield_column_flag(FORUMS_TABLE, 'forum_flags', log(FORUM_FLAG_QUICK_REPLY, 2)); +				}  			}  		} @@ -859,6 +864,20 @@ class acp_board  	}  	/** +	* Global quick reply enable/disable setting and button to enable in all forums +	*/ +	function quick_reply($value, $key) +	{ +		global $user; + +		$radio_ary = array(1 => 'YES', 0 => 'NO'); + +		return h_radio('config[allow_quick_reply]', $radio_ary, $value) . +			'<br /><br /><input class="button2" type="submit" id="' . $key . '_enable" name="' . $key . '_enable" value="' . $user->lang['ALLOW_QUICK_REPLY_BUTTON'] . '" />'; +	} + + +	/**  	* Select default dateformat  	*/  	function dateformat_select($value, $key) diff --git a/phpBB/includes/db/dbal.php b/phpBB/includes/db/dbal.php index a962696bb8..eeddf1f41b 100644 --- a/phpBB/includes/db/dbal.php +++ b/phpBB/includes/db/dbal.php @@ -430,6 +430,24 @@ class dbal  	}  	/** +	* Run binary OR operator on DB column. +	* Results in sql statement: "{$column_name} | (1 << {$bit}) {$compare}" +	* +	* @param string $column_name The column name to use +	* @param int $bit The value to use for the OR operator, will be converted to (1 << $bit). Is used by options, using the number schema... 0, 1, 2...29 +	* @param string $compare Any custom SQL code after the check (for example "= 0") +	*/ +	function sql_bit_or($column_name, $bit, $compare = '') +	{ +		if (method_exists($this, '_sql_bit_or')) +		{ +			return $this->_sql_bit_or($column_name, $bit, $compare); +		} + +		return $column_name . ' | ' . (1 << $bit) . (($compare) ? ' ' . $compare : ''); +	} + +	/**  	* Run more than one insert statement.  	*  	* @param string $table table name to run the statements on diff --git a/phpBB/includes/db/firebird.php b/phpBB/includes/db/firebird.php index fb1ef44c55..e554b0f2fb 100644 --- a/phpBB/includes/db/firebird.php +++ b/phpBB/includes/db/firebird.php @@ -451,6 +451,11 @@ class dbal_firebird extends dbal  		return 'BIN_AND(' . $column_name . ', ' . (1 << $bit) . ')' . (($compare) ? ' ' . $compare : '');  	} +	function _sql_bit_or($column_name, $bit, $compare = '') +	{ +		return 'BIN_OR(' . $column_name . ', ' . (1 << $bit) . ')' . (($compare) ? ' ' . $compare : ''); +	} +  	/**  	* return sql error array  	* @access private diff --git a/phpBB/includes/db/oracle.php b/phpBB/includes/db/oracle.php index 63cdb7126d..55b3599800 100644 --- a/phpBB/includes/db/oracle.php +++ b/phpBB/includes/db/oracle.php @@ -622,6 +622,11 @@ class dbal_oracle extends dbal  		return 'BITAND(' . $column_name . ', ' . (1 << $bit) . ')' . (($compare) ? ' ' . $compare : '');  	} +	function _sql_bit_or($column_name, $bit, $compare = '') +	{ +		return 'BITOR(' . $column_name . ', ' . (1 << $bit) . ')' . (($compare) ? ' ' . $compare : ''); +	} +  	/**  	* return sql error array  	* @access private diff --git a/phpBB/includes/functions_admin.php b/phpBB/includes/functions_admin.php index 41999bdbb0..c033684ae1 100644 --- a/phpBB/includes/functions_admin.php +++ b/phpBB/includes/functions_admin.php @@ -3309,4 +3309,24 @@ function obtain_latest_version_info($force_update = false, $warn_fail = false, $  	return $info;  } +/** + * Enables a particular flag in a bitfield column of a given table. + * + * @param string	$table_name		The table to update + * @param string	$column_name	The column containing a bitfield to update + * @param int		$flag			The binary flag which is OR-ed with the current column value + * @param string	$sql_more		This string is attached to the sql query generated to update the table. + * + * @return void + */ +function enable_bitfield_column_flag($table_name, $column_name, $flag, $sql_more = '') +{ +	global $db; + +	$sql = 'UPDATE ' . $table_name . ' +		SET ' . $column_name . ' = ' . $db->sql_bit_or($column_name, $flag) . ' +		' . $sql_more; +	$db->sql_query($sql); +} +  ?>
\ No newline at end of file diff --git a/phpBB/language/en/acp/board.php b/phpBB/language/en/acp/board.php index 9bb76cd354..967f6e68db 100644 --- a/phpBB/language/en/acp/board.php +++ b/phpBB/language/en/acp/board.php @@ -74,6 +74,7 @@ $lang = array_merge($lang, array(  	'ALLOW_PM_REPORT_EXPLAIN'	=> 'If this setting is enabled, users have the option of reporting a private message they have received or sent to the board’s moderators. These private messages will then be visible in the Moderator Control Panel.',  	'ALLOW_QUICK_REPLY'			=> 'Allow quick reply',  	'ALLOW_QUICK_REPLY_EXPLAIN'	=> 'This setting defines if quick reply is enabled or not. If this setting is enabled, forums need to have their quick reply option enabled too.', +	'ALLOW_QUICK_REPLY_BUTTON'	=> 'Submit and enable quick reply in all forums',  	'ALLOW_SIG'					=> 'Allow signatures',  	'ALLOW_SIG_BBCODE'			=> 'Allow BBCode in user signatures',  	'ALLOW_SIG_FLASH'			=> 'Allow use of <code>[FLASH]</code> BBCode tag in user signatures', | 
