diff --git a/adm/style/acp_mchat.html b/adm/style/acp_mchat.html
index cfe2a93..5339384 100644
--- a/adm/style/acp_mchat.html
+++ b/adm/style/acp_mchat.html
@@ -193,11 +193,11 @@
{L_MCHAT_DATE_FORMAT_EXPLAIN}
-
-
-
+ style="display:none;">
diff --git a/composer.json b/composer.json
index 796d11b..496c0d7 100644
--- a/composer.json
+++ b/composer.json
@@ -3,7 +3,7 @@
"type": "phpbb-extension",
"description": "mChat Extension for phpbb 3.1.x",
"homepage": "http://www.dmzx-web.net",
- "version": "0.1.9",
+ "version": "0.2.0",
"time": "2015-03-10",
"keywords": ["phpbb", "extension", "mchat"],
"license": "GPL-2.0",
diff --git a/event/listener.php b/event/listener.php
index aaadd2f..f792900 100644
--- a/event/listener.php
+++ b/event/listener.php
@@ -90,6 +90,7 @@ class listener implements EventSubscriberInterface
'core.page_header' => 'add_page_header_link',
'core.index_modify_page_title' => 'display_mchat_on_index',
'core.posting_modify_submit_post_after' => 'posting_modify_submit_post_after',
+ 'core.permissions' => 'permissions',
);
}
@@ -180,11 +181,11 @@ class listener implements EventSubscriberInterface
$uid = $bitfield = $options = ''; // will be modified by generate_text_for_storage
generate_text_for_storage($message, $uid, $bitfield, $options, true, false, false);
$sql_ary = array(
- 'forum_id' => $event['forum_id'],
- 'post_id' => $event['post_id'],
- 'user_id' => $this->user->data['user_id'],
- 'user_ip' => $this->user->data['session_ip'],
- 'message' => $message,
+ 'forum_id' => $event['forum_id'],
+ 'post_id' => $event['post_id'],
+ 'user_id' => $this->user->data['user_id'],
+ 'user_ip' => $this->user->data['session_ip'],
+ 'message' => $message,
'bbcode_bitfield' => $bitfield,
'bbcode_uid' => $uid,
'bbcode_options' => $options,
@@ -194,4 +195,70 @@ class listener implements EventSubscriberInterface
$this->db->sql_query($sql);
}
}
+
+ public function permissions($event)
+ {
+ $permissions = $event['permissions'];
+ $permissions += array(
+ 'u_mchat_use' => array(
+ 'lang' => 'ACL_U_MCHAT_USE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_view' => array(
+ 'lang' => 'ACL_U_MCHAT_VIEW',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_edit' => array(
+ 'lang' => 'ACL_U_MCHAT_EDIT',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_delete' => array(
+ 'lang' => 'ACL_U_MCHAT_DELETE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_ip' => array(
+ 'lang' => 'ACL_U_MCHAT_IP',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_pm' => array(
+ 'lang' => 'ACL_U_MCHAT_PM',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_like' => array(
+ 'lang' => 'ACL_U_MCHAT_LIKE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_quote' => array(
+ 'lang' => 'ACL_U_MCHAT_QUOTE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_flood_ignore' => array(
+ 'lang' => 'ACL_U_MCHAT_FLOOD_IGNORE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_archive' => array(
+ 'lang' => 'ACL_U_MCHAT_ARCHIVE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_bbcode' => array(
+ 'lang' => 'ACL_U_MCHAT_BBCODE',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_smilies' => array(
+ 'lang' => 'ACL_U_MCHAT_SMILIES',
+ 'cat' => 'mChat'
+ ),
+ 'u_mchat_urls' => array(
+ 'lang' => 'ACL_U_MCHAT_URLS',
+ 'cat' => 'mChat'
+ ),
+ 'a_mchat' => array(
+ 'lang' => 'ACL_A_MCHAT',
+ 'cat' => 'mChat'
+ ),
+ );
+ $event['permissions'] = $permissions;
+ $categories['mChat'] = 'ACP_CAT_MCHAT';
+ $event['categories'] = array_merge($event['categories'], $categories);
+ }
}
diff --git a/language/en/info_acp_mchat.php b/language/en/info_acp_mchat.php
index 562e9fb..e53303a 100644
--- a/language/en/info_acp_mchat.php
+++ b/language/en/info_acp_mchat.php
@@ -153,17 +153,17 @@ $lang = array_merge($lang, array(
// User perms
'ACL_U_MCHAT_USE' => 'Can use mChat',
'ACL_U_MCHAT_VIEW' => 'Can view mChat',
- 'ACL_U_MCHAT_EDIT' => 'Can edit mChat messages',
- 'ACL_U_MCHAT_DELETE' => 'Can delete mChat messages',
- 'ACL_U_MCHAT_IP' => 'Can use view mChat IP addresses',
- 'ACL_U_MCHAT_PM' => 'Can use private message in mChat',
- 'ACL_U_MCHAT_LIKE' => 'Can use like message in mChat',
- 'ACL_U_MCHAT_QUOTE' => 'Can use quote message in mChat',
- 'ACL_U_MCHAT_FLOOD_IGNORE' => 'Can ignore mChat flood mChat',
- 'ACL_U_MCHAT_ARCHIVE' => 'Can view the Archive mChat',
- 'ACL_U_MCHAT_BBCODE' => 'Can use bbcode in mChat',
- 'ACL_U_MCHAT_SMILIES' => 'Can use smilies in mChat',
- 'ACL_U_MCHAT_URLS' => 'Can post urls in mChat',
+ 'ACL_U_MCHAT_EDIT' => 'Can edit messages',
+ 'ACL_U_MCHAT_DELETE' => 'Can delete messages',
+ 'ACL_U_MCHAT_IP' => 'Can view IP addresses',
+ 'ACL_U_MCHAT_PM' => 'Can use private message',
+ 'ACL_U_MCHAT_LIKE' => 'Can use like message',
+ 'ACL_U_MCHAT_QUOTE' => 'Can use quote message',
+ 'ACL_U_MCHAT_FLOOD_IGNORE' => 'Can ignore flood',
+ 'ACL_U_MCHAT_ARCHIVE' => 'Can view the archive',
+ 'ACL_U_MCHAT_BBCODE' => 'Can use bbcode',
+ 'ACL_U_MCHAT_SMILIES' => 'Can use smilies',
+ 'ACL_U_MCHAT_URLS' => 'Can post urls',
// Admin perms
'ACL_A_MCHAT' => 'Can manage mChat settings',
diff --git a/migrations/mchat_schema.php b/migrations/mchat_schema.php
index b394e0b..6a1a2f0 100644
--- a/migrations/mchat_schema.php
+++ b/migrations/mchat_schema.php
@@ -11,7 +11,7 @@ namespace dmzx\mchat\migrations;
class mchat_schema extends \phpbb\db\migration\migration
{
- var $ext_version = '0.1.9';
+ var $ext_version = '0.2.0';
public function update_data()
{
@@ -29,20 +29,20 @@ class mchat_schema extends \phpbb\db\migration\migration
array('config.add', array('mchat_version', $this->ext_version)),
// Add permissions
- array('permission.add', array('u_mchat_use')),
- array('permission.add', array('u_mchat_view')),
- array('permission.add', array('u_mchat_edit')),
- array('permission.add', array('u_mchat_delete')),
- array('permission.add', array('u_mchat_ip')),
- array('permission.add', array('u_mchat_pm')),
- array('permission.add', array('u_mchat_like')),
- array('permission.add', array('u_mchat_quote')),
- array('permission.add', array('u_mchat_flood_ignore')),
- array('permission.add', array('u_mchat_archive')),
- array('permission.add', array('u_mchat_bbcode')),
- array('permission.add', array('u_mchat_smilies')),
- array('permission.add', array('u_mchat_urls')),
- array('permission.add', array('a_mchat')),
+ array('permission.add', array('u_mchat_use', true)),
+ array('permission.add', array('u_mchat_view', true)),
+ array('permission.add', array('u_mchat_edit', true)),
+ array('permission.add', array('u_mchat_delete', true)),
+ array('permission.add', array('u_mchat_ip', true)),
+ array('permission.add', array('u_mchat_pm', true)),
+ array('permission.add', array('u_mchat_like', true)),
+ array('permission.add', array('u_mchat_quote', true)),
+ array('permission.add', array('u_mchat_flood_ignore', true)),
+ array('permission.add', array('u_mchat_archive', true)),
+ array('permission.add', array('u_mchat_bbcode', true)),
+ array('permission.add', array('u_mchat_smilies', true)),
+ array('permission.add', array('u_mchat_urls', true)),
+ array('permission.add', array('a_mchat', true)),
// Set permissions
array('permission.permission_set', array('ADMINISTRATORS', 'u_mchat_use', 'group')),
@@ -61,6 +61,9 @@ class mchat_schema extends \phpbb\db\migration\migration
array('permission.permission_set', array('ADMINISTRATORS', 'a_mchat', 'group')),
array('permission.permission_set', array('REGISTERED', 'u_mchat_use', 'group')),
array('permission.permission_set', array('REGISTERED', 'u_mchat_view', 'group')),
+ array('permission.permission_set', array('REGISTERED', 'u_mchat_pm', 'group')),
+ array('permission.permission_set', array('REGISTERED', 'u_mchat_like', 'group')),
+ array('permission.permission_set', array('REGISTERED', 'u_mchat_quote', 'group')),
array('permission.permission_set', array('REGISTERED', 'u_mchat_archive', 'group')),
array('permission.permission_set', array('REGISTERED', 'u_mchat_bbcode', 'group')),
array('permission.permission_set', array('REGISTERED', 'u_mchat_smilies', 'group')),
diff --git a/styles/prosilver/template/editor.js b/styles/prosilver/template/editor.js
deleted file mode 100644
index 9eed25a..0000000
--- a/styles/prosilver/template/editor.js
+++ /dev/null
@@ -1,461 +0,0 @@
-/**
-* bbCode control by subBlue design [ www.subBlue.com ]
-* Includes unixsafe colour palette selector by SHS`
-*/
-
-// Startup variables
-var imageTag = false;
-var theSelection = false;
-
-var bbcodeEnabled = true;
-// Check for Browser & Platform for PC & IE specific bits
-// More details from: http://www.mozilla.org/docs/web-developer/sniffer/browser_type.html
-var clientPC = navigator.userAgent.toLowerCase(); // Get client info
-var clientVer = parseInt(navigator.appVersion); // Get browser version
-
-var is_ie = ((clientPC.indexOf('msie') != -1) && (clientPC.indexOf('opera') == -1));
-var is_win = ((clientPC.indexOf('win') != -1) || (clientPC.indexOf('16bit') != -1));
-var baseHeight;
-
-/**
-* Shows the help messages in the helpline window
-*/
-function helpline(help)
-{
- document.forms[form_name].helpbox.value = help_line[help];
-}
-
-/**
-* Fix a bug involving the TextRange object. From
-* http://www.frostjedi.com/terra/scripts/demo/caretBug.html
-*/
-function initInsertions()
-{
- var doc;
-
- if (document.forms[form_name])
- {
- doc = document;
- }
- else
- {
- doc = opener.document;
- }
-
- var textarea = doc.forms[form_name].elements[text_name];
-
- if (is_ie && typeof(baseHeight) != 'number')
- {
- /* === mChat focus fix Start === */
- if(!mChat.focusFix)
- {
- textarea.focus();
- }
- baseHeight = doc.selection.createRange().duplicate().boundingHeight;
- /* ==== mChat focus fix End ==== */
- if (!document.forms[form_name])
- {
- document.body.focus();
- }
- }
-}
-
-/**
-* bbstyle
-*/
-function bbstyle(bbnumber)
-{
- if (bbnumber != -1)
- {
- bbfontstyle(bbtags[bbnumber], bbtags[bbnumber+1]);
- }
- else
- {
- insert_text('[*]');
- document.forms[form_name].elements[text_name].focus();
- }
-}
-
-/**
-* Apply bbcodes
-*/
-function bbfontstyle(bbopen, bbclose)
-{
- theSelection = false;
-
- var textarea = document.forms[form_name].elements[text_name];
-
- textarea.focus();
-
- if ((clientVer >= 4) && is_ie && is_win)
- {
- // Get text selection
- theSelection = document.selection.createRange().text;
-
- if (theSelection)
- {
- // Add tags around selection
- document.selection.createRange().text = bbopen + theSelection + bbclose;
- document.forms[form_name].elements[text_name].focus();
- theSelection = '';
- return;
- }
- }
- else if (document.forms[form_name].elements[text_name].selectionEnd && (document.forms[form_name].elements[text_name].selectionEnd - document.forms[form_name].elements[text_name].selectionStart > 0))
- {
- mozWrap(document.forms[form_name].elements[text_name], bbopen, bbclose);
- document.forms[form_name].elements[text_name].focus();
- theSelection = '';
- return;
- }
-
- //The new position for the cursor after adding the bbcode
- var caret_pos = getCaretPosition(textarea).start;
- var new_pos = caret_pos + bbopen.length;
-
- // Open tag
- insert_text(bbopen + bbclose);
-
- // Center the cursor when we don't have a selection
- // Gecko and proper browsers
- if (!isNaN(textarea.selectionStart))
- {
- textarea.selectionStart = new_pos;
- textarea.selectionEnd = new_pos;
- }
- // IE
- else if (document.selection)
- {
- var range = textarea.createTextRange();
- range.move("character", new_pos);
- range.select();
- storeCaret(textarea);
- }
-
- textarea.focus();
- return;
-}
-
-/**
-* Insert text at position
-*/
-function insert_text(text, spaces, popup)
-{
- var textarea;
-
- if (!popup)
- {
- textarea = document.forms[form_name].elements[text_name];
- }
- else
- {
- textarea = opener.document.forms[form_name].elements[text_name];
- }
- if (spaces)
- {
- text = ' ' + text + ' ';
- }
-
- // Since IE9, IE also has textarea.selectionStart, but it still needs to be treated the old way.
- // Therefore we simply add a !is_ie here until IE fixes the text-selection completely.
- if (!isNaN(textarea.selectionStart) && !is_ie)
- {
- var sel_start = textarea.selectionStart;
- var sel_end = textarea.selectionEnd;
-
- mozWrap(textarea, text, '');
- textarea.selectionStart = sel_start + text.length;
- textarea.selectionEnd = sel_end + text.length;
- }
- else if (textarea.createTextRange && textarea.caretPos)
- {
- if (baseHeight != textarea.caretPos.boundingHeight)
- {
- textarea.focus();
- storeCaret(textarea);
- }
-
- var caret_pos = textarea.caretPos;
- caret_pos.text = caret_pos.text.charAt(caret_pos.text.length - 1) == ' ' ? caret_pos.text + text + ' ' : caret_pos.text + text;
- }
- else
- {
- textarea.value = textarea.value + text;
- }
- if (!popup)
- {
- textarea.focus();
- }
-}
-
-/**
-* Add inline attachment at position
-*/
-function attach_inline(index, filename)
-{
- insert_text('[attachment=' + index + ']' + filename + '[/attachment]');
- document.forms[form_name].elements[text_name].focus();
-}
-
-/**
-* Add quote text to message
-*/
-function addquote(post_id, username, l_wrote)
-{
- var message_name = 'message_' + post_id;
- var theSelection = '';
- var divarea = false;
-
- if (l_wrote === undefined)
- {
- // Backwards compatibility
- l_wrote = 'wrote';
- }
-
- if (document.all)
- {
- divarea = document.all[message_name];
- }
- else
- {
- divarea = document.getElementById(message_name);
- }
-
- // Get text selection - not only the post content :(
- // IE9 must use the document.selection method but has the *.getSelection so we just force no IE
- if (window.getSelection && !is_ie && !window.opera)
- {
- theSelection = window.getSelection().toString();
- }
- else if (document.getSelection && !is_ie)
- {
- theSelection = document.getSelection();
- }
- else if (document.selection)
- {
- theSelection = document.selection.createRange().text;
- }
-
- if (theSelection == '' || typeof theSelection == 'undefined' || theSelection == null)
- {
- if (divarea.innerHTML)
- {
- theSelection = divarea.innerHTML.replace(/
/ig, '\n');
- theSelection = theSelection.replace(/
/ig, '\n');
- theSelection = theSelection.replace(/<\;/ig, '<');
- theSelection = theSelection.replace(/>\;/ig, '>');
- theSelection = theSelection.replace(/&\;/ig, '&');
- theSelection = theSelection.replace(/ \;/ig, ' ');
- }
- else if (document.all)
- {
- theSelection = divarea.innerText;
- }
- else if (divarea.textContent)
- {
- theSelection = divarea.textContent;
- }
- else if (divarea.firstChild.nodeValue)
- {
- theSelection = divarea.firstChild.nodeValue;
- }
- }
-
- if (theSelection)
- {
- if (bbcodeEnabled)
- {
- insert_text('[quote="' + username + '"]' + theSelection + '[/quote]');
- }
- else
- {
- insert_text(username + ' ' + l_wrote + ':' + '\n');
- var lines = split_lines(theSelection);
- for (i = 0; i < lines.length; i++)
- {
- insert_text('> ' + lines[i] + '\n');
- }
- }
- }
-
- return;
-}
-
-function split_lines(text)
-{
- var lines = text.split('\n');
- var splitLines = new Array();
- var j = 0;
- for(i = 0; i < lines.length; i++)
- {
- if (lines[i].length <= 80)
- {
- splitLines[j] = lines[i];
- j++;
- }
- else
- {
- var line = lines[i];
- do
- {
- var splitAt = line.indexOf(' ', 80);
-
- if (splitAt == -1)
- {
- splitLines[j] = line;
- j++;
- }
- else
- {
- splitLines[j] = line.substring(0, splitAt);
- line = line.substring(splitAt);
- j++;
- }
- }
- while(splitAt != -1);
- }
- }
- return splitLines;
-}
-/**
-* From http://www.massless.org/mozedit/
-*/
-function mozWrap(txtarea, open, close)
-{
- var selLength = (typeof(txtarea.textLength) == 'undefined') ? txtarea.value.length : txtarea.textLength;
- var selStart = txtarea.selectionStart;
- var selEnd = txtarea.selectionEnd;
- var scrollTop = txtarea.scrollTop;
-
- if (selEnd == 1 || selEnd == 2)
- {
- selEnd = selLength;
- }
-
- var s1 = (txtarea.value).substring(0,selStart);
- var s2 = (txtarea.value).substring(selStart, selEnd);
- var s3 = (txtarea.value).substring(selEnd, selLength);
-
- txtarea.value = s1 + open + s2 + close + s3;
- txtarea.selectionStart = selStart + open.length;
- txtarea.selectionEnd = selEnd + open.length;
- txtarea.focus();
- txtarea.scrollTop = scrollTop;
-
- return;
-}
-
-/**
-* Insert at Caret position. Code from
-* http://www.faqts.com/knowledge_base/view.phtml/aid/1052/fid/130
-*/
-function storeCaret(textEl)
-{
- if (textEl.createTextRange)
- {
- textEl.caretPos = document.selection.createRange().duplicate();
- }
-}
-
-/**
-* Color pallette
-*/
-function colorPalette(dir, width, height)
-{
- var r = 0, g = 0, b = 0;
- var numberList = new Array(6);
- var color = '';
-
- numberList[0] = '00';
- numberList[1] = '40';
- numberList[2] = '80';
- numberList[3] = 'BF';
- numberList[4] = 'FF';
-
- document.writeln('');
-
- for (r = 0; r < 5; r++)
- {
- if (dir == 'h')
- {
- document.writeln('');
- }
-
- for (g = 0; g < 5; g++)
- {
- if (dir == 'v')
- {
- document.writeln('
');
- }
-
- for (b = 0; b < 5; b++)
- {
- color = String(numberList[r]) + String(numberList[g]) + String(numberList[b]);
- document.write('');
- document.write(' ');
- document.writeln(' | ');
- }
-
- if (dir == 'v')
- {
- document.writeln('
');
- }
- }
-
- if (dir == 'h')
- {
- document.writeln('');
- }
- }
- document.writeln('
');
-}
-
-/**
-* Caret Position object
-*/
-function caretPosition()
-{
- var start = null;
- var end = null;
-}
-
-/**
-* Get the caret position in an textarea
-*/
-function getCaretPosition(txtarea)
-{
- var caretPos = new caretPosition();
-
- // simple Gecko/Opera way
- if(txtarea.selectionStart || txtarea.selectionStart == 0)
- {
- caretPos.start = txtarea.selectionStart;
- caretPos.end = txtarea.selectionEnd;
- }
- // dirty and slow IE way
- else if(document.selection)
- {
-
- // get current selection
- var range = document.selection.createRange();
-
- // a new selection of the whole textarea
- var range_all = document.body.createTextRange();
- range_all.moveToElementText(txtarea);
-
- // calculate selection start point by moving beginning of range_all to beginning of range
- var sel_start;
- for (sel_start = 0; range_all.compareEndPoints('StartToStart', range) < 0; sel_start++)
- {
- range_all.moveStart('character', 1);
- }
-
- txtarea.sel_start = sel_start;
-
- // we ignore the end value for IE, this is already dirty enough and we don't need it
- caretPos.start = txtarea.sel_start;
- caretPos.end = txtarea.sel_start;
- }
-
- return caretPos;
-}
diff --git a/styles/prosilver/template/mchat_bbcodes.html b/styles/prosilver/template/mchat_bbcodes.html
index 5fe8ac7..012771f 100644
--- a/styles/prosilver/template/mchat_bbcodes.html
+++ b/styles/prosilver/template/mchat_bbcodes.html
@@ -32,6 +32,7 @@
// ]]>
+
diff --git a/styles/prosilver/template/mchat_body.html b/styles/prosilver/template/mchat_body.html
index 038f778..ddba59d 100644
--- a/styles/prosilver/template/mchat_body.html
+++ b/styles/prosilver/template/mchat_body.html
@@ -2,7 +2,6 @@
-
@@ -73,7 +72,6 @@
playSound : truefalse,
whois : truefalse,
whoisRefresh : {MCHAT_WHOIS_REFRESH},
- focusFix : falsetrue,
archiveMode : truefalse
};
// ]]>