mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-07 20:08:53 +00:00
[ticket/17326] Add font icon field for custom BBCodes
Adds a new field to the custom BBCode add/edit form that allows admins to define a Font Awesome icon to be displayed instead of the BBCodes name on the posting.php editor page. PHPBB-17326
This commit is contained in:
parent
f6c9d15b0c
commit
f5bb065a4d
8 changed files with 92 additions and 4 deletions
|
@ -47,6 +47,17 @@
|
||||||
</dl>
|
</dl>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
|
|
||||||
|
<fieldset>
|
||||||
|
<legend>{{ lang('APPEARANCE') }}</legend>
|
||||||
|
<dl>
|
||||||
|
<dt><label for="bbcode_font_icon">{{ lang('BBCODE_FONT_ICON') }}</label><br /><span>{{ lang('BBCODE_FONT_ICON_EXPLAIN') }}</span></dt>
|
||||||
|
<dd>
|
||||||
|
<input type="text" name="bbcode_font_icon" id="bbcode_font_icon" value="{{ BBCODE_FONT_ICON }}" />
|
||||||
|
{{ Icon('font', BBCODE_FONT_ICON, '', false, '', {'id':'bbcode_icon_preview'}) }}
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
<!-- EVENT acp_bbcodes_edit_fieldsets_after -->
|
<!-- EVENT acp_bbcodes_edit_fieldsets_after -->
|
||||||
|
|
||||||
<fieldset class="submit-buttons">
|
<fieldset class="submit-buttons">
|
||||||
|
|
|
@ -277,5 +277,10 @@ function parse_document(container)
|
||||||
$('.actions a:has(i.acp-icon)').mouseover(function () {
|
$('.actions a:has(i.acp-icon)').mouseover(function () {
|
||||||
$(this).css("text-decoration", "none");
|
$(this).css("text-decoration", "none");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Live update BBCode font icon preview
|
||||||
|
$('#bbcode_font_icon').on('keyup', function(e) {
|
||||||
|
$('#bbcode_icon_preview').attr('class', "o-icon o-icon-font fa-fw fas icon fa-" + $(this).val());
|
||||||
|
});
|
||||||
});
|
});
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
|
@ -44,12 +44,12 @@ class acp_bbcodes
|
||||||
switch ($action)
|
switch ($action)
|
||||||
{
|
{
|
||||||
case 'add':
|
case 'add':
|
||||||
$bbcode_match = $bbcode_tpl = $bbcode_helpline = '';
|
$bbcode_match = $bbcode_tpl = $bbcode_helpline = $bbcode_font_icon = '';
|
||||||
$display_on_posting = 0;
|
$display_on_posting = 0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'edit':
|
case 'edit':
|
||||||
$sql = 'SELECT bbcode_match, bbcode_tpl, display_on_posting, bbcode_helpline
|
$sql = 'SELECT bbcode_match, bbcode_tpl, display_on_posting, bbcode_helpline, bbcode_font_icon
|
||||||
FROM ' . BBCODES_TABLE . '
|
FROM ' . BBCODES_TABLE . '
|
||||||
WHERE bbcode_id = ' . $bbcode_id;
|
WHERE bbcode_id = ' . $bbcode_id;
|
||||||
$result = $db->sql_query($sql);
|
$result = $db->sql_query($sql);
|
||||||
|
@ -65,6 +65,7 @@ class acp_bbcodes
|
||||||
$bbcode_tpl = htmlspecialchars($row['bbcode_tpl'], ENT_COMPAT);
|
$bbcode_tpl = htmlspecialchars($row['bbcode_tpl'], ENT_COMPAT);
|
||||||
$display_on_posting = $row['display_on_posting'];
|
$display_on_posting = $row['display_on_posting'];
|
||||||
$bbcode_helpline = $row['bbcode_helpline'];
|
$bbcode_helpline = $row['bbcode_helpline'];
|
||||||
|
$bbcode_font_icon = $row['bbcode_font_icon'];
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'modify':
|
case 'modify':
|
||||||
|
@ -88,6 +89,7 @@ class acp_bbcodes
|
||||||
$bbcode_match = $request->variable('bbcode_match', '');
|
$bbcode_match = $request->variable('bbcode_match', '');
|
||||||
$bbcode_tpl = html_entity_decode($request->variable('bbcode_tpl', '', true), ENT_COMPAT);
|
$bbcode_tpl = html_entity_decode($request->variable('bbcode_tpl', '', true), ENT_COMPAT);
|
||||||
$bbcode_helpline = $request->variable('bbcode_helpline', '', true);
|
$bbcode_helpline = $request->variable('bbcode_helpline', '', true);
|
||||||
|
$bbcode_font_icon = $request->variable('bbcode_font_icon', '');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,6 +108,7 @@ class acp_bbcodes
|
||||||
'BBCODE_MATCH' => $bbcode_match,
|
'BBCODE_MATCH' => $bbcode_match,
|
||||||
'BBCODE_TPL' => $bbcode_tpl,
|
'BBCODE_TPL' => $bbcode_tpl,
|
||||||
'BBCODE_HELPLINE' => $bbcode_helpline,
|
'BBCODE_HELPLINE' => $bbcode_helpline,
|
||||||
|
'BBCODE_FONT_ICON' => $bbcode_font_icon,
|
||||||
'DISPLAY_ON_POSTING' => $display_on_posting,
|
'DISPLAY_ON_POSTING' => $display_on_posting,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -157,6 +160,7 @@ class acp_bbcodes
|
||||||
* @var string bbcode_match The bbcode usage string to match
|
* @var string bbcode_match The bbcode usage string to match
|
||||||
* @var string bbcode_tpl The bbcode HTML replacement string
|
* @var string bbcode_tpl The bbcode HTML replacement string
|
||||||
* @var string bbcode_helpline The bbcode help line string
|
* @var string bbcode_helpline The bbcode help line string
|
||||||
|
* @var string bbcode_font_icon The name of the Font Awesome BBCode icon
|
||||||
* @var array hidden_fields Array of hidden fields for use when
|
* @var array hidden_fields Array of hidden fields for use when
|
||||||
* submitting form when $warn_unsafe is true
|
* submitting form when $warn_unsafe is true
|
||||||
* @since 3.1.0-a3
|
* @since 3.1.0-a3
|
||||||
|
@ -169,6 +173,7 @@ class acp_bbcodes
|
||||||
'bbcode_match',
|
'bbcode_match',
|
||||||
'bbcode_tpl',
|
'bbcode_tpl',
|
||||||
'bbcode_helpline',
|
'bbcode_helpline',
|
||||||
|
'bbcode_font_icon',
|
||||||
'hidden_fields',
|
'hidden_fields',
|
||||||
);
|
);
|
||||||
extract($phpbb_dispatcher->trigger_event('core.acp_bbcodes_modify_create', compact($vars)));
|
extract($phpbb_dispatcher->trigger_event('core.acp_bbcodes_modify_create', compact($vars)));
|
||||||
|
@ -232,6 +237,11 @@ class acp_bbcodes
|
||||||
trigger_error($user->lang['BBCODE_HELPLINE_TOO_LONG'] . adm_back_link($this->u_action), E_USER_WARNING);
|
trigger_error($user->lang['BBCODE_HELPLINE_TOO_LONG'] . adm_back_link($this->u_action), E_USER_WARNING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strlen($bbcode_font_icon) > 50)
|
||||||
|
{
|
||||||
|
trigger_error($user->lang['BBCODE_FONT_ICON_TOO_LONG'] . adm_back_link($this->u_action), E_USER_WARNING);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Replace Emojis and other 4bit UTF-8 chars not allowed by MySQL to UCR/NCR.
|
* Replace Emojis and other 4bit UTF-8 chars not allowed by MySQL to UCR/NCR.
|
||||||
* Using their Numeric Character Reference's Hexadecimal notation.
|
* Using their Numeric Character Reference's Hexadecimal notation.
|
||||||
|
@ -244,6 +254,7 @@ class acp_bbcodes
|
||||||
'bbcode_tpl' => $bbcode_tpl,
|
'bbcode_tpl' => $bbcode_tpl,
|
||||||
'display_on_posting' => $display_on_posting,
|
'display_on_posting' => $display_on_posting,
|
||||||
'bbcode_helpline' => $bbcode_helpline,
|
'bbcode_helpline' => $bbcode_helpline,
|
||||||
|
'bbcode_font_icon' => $bbcode_font_icon,
|
||||||
'first_pass_match' => $data['first_pass_match'],
|
'first_pass_match' => $data['first_pass_match'],
|
||||||
'first_pass_replace' => $data['first_pass_replace'],
|
'first_pass_replace' => $data['first_pass_replace'],
|
||||||
'second_pass_match' => $data['second_pass_match'],
|
'second_pass_match' => $data['second_pass_match'],
|
||||||
|
@ -328,6 +339,7 @@ class acp_bbcodes
|
||||||
'bbcode_match' => $bbcode_match,
|
'bbcode_match' => $bbcode_match,
|
||||||
'bbcode_tpl' => htmlspecialchars($bbcode_tpl, ENT_COMPAT),
|
'bbcode_tpl' => htmlspecialchars($bbcode_tpl, ENT_COMPAT),
|
||||||
'bbcode_helpline' => $bbcode_helpline,
|
'bbcode_helpline' => $bbcode_helpline,
|
||||||
|
'bbcode_font_icon' => $bbcode_font_icon,
|
||||||
'display_on_posting' => $display_on_posting,
|
'display_on_posting' => $display_on_posting,
|
||||||
)))
|
)))
|
||||||
, 'confirm_bbcode.html');
|
, 'confirm_bbcode.html');
|
||||||
|
|
|
@ -1081,7 +1081,7 @@ function display_custom_bbcodes()
|
||||||
$num_predefined_bbcodes = NUM_PREDEFINED_BBCODES;
|
$num_predefined_bbcodes = NUM_PREDEFINED_BBCODES;
|
||||||
|
|
||||||
$sql_ary = [
|
$sql_ary = [
|
||||||
'SELECT' => 'b.bbcode_id, b.bbcode_tag, b.bbcode_helpline, b.bbcode_match',
|
'SELECT' => 'b.bbcode_id, b.bbcode_tag, b.bbcode_helpline, b.bbcode_font_icon, b.bbcode_match',
|
||||||
'FROM' => [BBCODES_TABLE => 'b'],
|
'FROM' => [BBCODES_TABLE => 'b'],
|
||||||
'WHERE' => 'b.display_on_posting = 1',
|
'WHERE' => 'b.display_on_posting = 1',
|
||||||
'ORDER_BY' => 'b.bbcode_tag',
|
'ORDER_BY' => 'b.bbcode_tag',
|
||||||
|
@ -1124,6 +1124,7 @@ function display_custom_bbcodes()
|
||||||
'BBCODE_TAG' => $row['bbcode_tag'],
|
'BBCODE_TAG' => $row['bbcode_tag'],
|
||||||
'BBCODE_TAG_CLEAN' => str_replace('=', '-', $row['bbcode_tag']),
|
'BBCODE_TAG_CLEAN' => str_replace('=', '-', $row['bbcode_tag']),
|
||||||
'BBCODE_HELPLINE' => $row['bbcode_helpline'],
|
'BBCODE_HELPLINE' => $row['bbcode_helpline'],
|
||||||
|
'BBCODE_FONT_ICON' => $row['bbcode_font_icon'],
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -53,6 +53,9 @@ $lang = array_merge($lang, array(
|
||||||
'BBCODE_HELPLINE_EXPLAIN' => 'This field contains the mouse over text of the BBCode.',
|
'BBCODE_HELPLINE_EXPLAIN' => 'This field contains the mouse over text of the BBCode.',
|
||||||
'BBCODE_HELPLINE_TEXT' => 'Help line text',
|
'BBCODE_HELPLINE_TEXT' => 'Help line text',
|
||||||
'BBCODE_HELPLINE_TOO_LONG' => 'The help line you entered is too long.',
|
'BBCODE_HELPLINE_TOO_LONG' => 'The help line you entered is too long.',
|
||||||
|
'BBCODE_FONT_ICON' => 'BBCode icon',
|
||||||
|
'BBCODE_FONT_ICON_EXPLAIN' => 'Enter the name of a Font Awesome icon (without the fa prefix) to display instead of the BBCode name appearing on the button. <a href="https://fontawesome.com/v6/icons/" target="_blank">Click here</a> to view the list of available icons.',
|
||||||
|
'BBCODE_FONT_ICON_TOO_LONG' => 'The icon name you have entered is too long.',
|
||||||
|
|
||||||
'BBCODE_INVALID_TAG_NAME' => 'The BBCode tag name that you selected already exists.',
|
'BBCODE_INVALID_TAG_NAME' => 'The BBCode tag name that you selected already exists.',
|
||||||
'BBCODE_INVALID' => 'Your BBCode is constructed in an invalid form.',
|
'BBCODE_INVALID' => 'Your BBCode is constructed in an invalid form.',
|
||||||
|
|
|
@ -78,6 +78,7 @@ $lang = array_merge($lang, array(
|
||||||
'ALL_TOPICS' => 'All Topics',
|
'ALL_TOPICS' => 'All Topics',
|
||||||
'ALT_TEXT' => 'Alternative text',
|
'ALT_TEXT' => 'Alternative text',
|
||||||
'AND' => 'And',
|
'AND' => 'And',
|
||||||
|
'APPEARANCE' => 'Appearance',
|
||||||
'ARE_WATCHING_FORUM' => 'You have subscribed to be notified of new posts in this forum.',
|
'ARE_WATCHING_FORUM' => 'You have subscribed to be notified of new posts in this forum.',
|
||||||
'ARE_WATCHING_TOPIC' => 'You have subscribed to be notified of new posts in this topic.',
|
'ARE_WATCHING_TOPIC' => 'You have subscribed to be notified of new posts in this topic.',
|
||||||
'ASCENDING' => 'Ascending',
|
'ASCENDING' => 'Ascending',
|
||||||
|
|
51
phpBB/phpbb/db/migration/data/v400/add_bbcode_font_icon.php
Normal file
51
phpBB/phpbb/db/migration/data/v400/add_bbcode_font_icon.php
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* This file is part of the phpBB Forum Software package.
|
||||||
|
*
|
||||||
|
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||||
|
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||||
|
*
|
||||||
|
* For full copyright and license information, please see
|
||||||
|
* the docs/CREDITS.txt file.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace phpbb\db\migration\data\v400;
|
||||||
|
|
||||||
|
class add_bbcode_font_icon extends \phpbb\db\migration\migration
|
||||||
|
{
|
||||||
|
public function effectively_installed()
|
||||||
|
{
|
||||||
|
return $this->db_tools->sql_column_exists($this->table_prefix . 'bbcodes', 'bbcode_font_icon');
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function depends_on()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'\phpbb\db\migration\data\v400\dev'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update_schema()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'add_columns' => [
|
||||||
|
$this->table_prefix . 'bbcodes' => [
|
||||||
|
'bbcode_font_icon' => ['VCHAR:50', ''],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function revert_schema()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'drop_columns' => [
|
||||||
|
$this->table_prefix . 'bbcodes' => [
|
||||||
|
'bbcode_font_icon',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
|
@ -97,7 +97,11 @@
|
||||||
|
|
||||||
<!-- BEGIN custom_tags -->
|
<!-- BEGIN custom_tags -->
|
||||||
<button type="button" class="button button-secondary bbcode-{custom_tags.BBCODE_TAG_CLEAN}" name="addbbcode{custom_tags.BBCODE_ID}" value="{custom_tags.BBCODE_TAG}" onclick="bbstyle({custom_tags.BBCODE_ID})" title="{{ custom_tags.BBCODE_HELPLINE }}">
|
<button type="button" class="button button-secondary bbcode-{custom_tags.BBCODE_TAG_CLEAN}" name="addbbcode{custom_tags.BBCODE_ID}" value="{custom_tags.BBCODE_TAG}" onclick="bbstyle({custom_tags.BBCODE_ID})" title="{{ custom_tags.BBCODE_HELPLINE }}">
|
||||||
{custom_tags.BBCODE_TAG}
|
{% if custom_tags.BBCODE_FONT_ICON != '' %}
|
||||||
|
{{ Icon('font', custom_tags.BBCODE_FONT_ICON, '', false, custom_tags.BBCODE_TAG_CLEAN) }}
|
||||||
|
{% else %}
|
||||||
|
{{ custom_tags.BBCODE_TAG }}
|
||||||
|
{%
|
||||||
</button>
|
</button>
|
||||||
<!-- END custom_tags -->
|
<!-- END custom_tags -->
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Add table
Reference in a new issue