123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769 |
- // *** QuickModifyTopic object.
- function QuickModifyTopic(oOptions)
- {
- this.opt = oOptions;
- this.aHidePrefixes = this.opt.aHidePrefixes;
- this.iCurTopicId = 0;
- this.sCurMessageId = '';
- this.sBuffSubject = '';
- this.oCurSubjectDiv = null;
- this.oTopicModHandle = document;
- this.bInEditMode = false;
- this.bMouseOnDiv = false;
- this.bXmlHttpCapable = this.isXmlHttpCapable();
- this.init();
- }
- // @todo Determine if this is even needed anymore opera meh
- // Ajax supported?
- QuickModifyTopic.prototype.isXmlHttpCapable = function ()
- {
- if (typeof(window.XMLHttpRequest) == 'undefined')
- return false;
- // Opera didn't always support POST requests. So test it first.
- if ('opera' in window)
- {
- var oTest = new XMLHttpRequest();
- if (!('setRequestHeader' in oTest))
- return false;
- }
- return true;
- }
- // Used to initialise the object event handlers
- QuickModifyTopic.prototype.init = function ()
- {
- // Attach some events to it so we can respond to actions
- this.oTopicModHandle.instanceRef = this;
- // detect and act on keypress
- this.oTopicModHandle.onkeydown = function (oEvent) {return this.instanceRef.modify_topic_keypress(oEvent);};
- // Used to detect when we've stopped editing.
- this.oTopicModHandle.onclick = function (oEvent) {return this.instanceRef.modify_topic_click(oEvent);};
- }
- // called from the double click in the div
- QuickModifyTopic.prototype.modify_topic = function (topic_id, first_msg_id)
- {
- // Add backwards compatibility with old themes.
- if (typeof(cur_session_var) == 'undefined')
- cur_session_var = 'sesc';
- // already editing
- if (this.bInEditMode)
- {
- // same message then just return, otherwise drop out of this edit.
- if (this.iCurTopicId == topic_id)
- return;
- else
- this.modify_topic_cancel();
- }
- this.bInEditMode = true;
- this.bMouseOnDiv = true;
- this.iCurTopicId = topic_id;
- // Get the topics current subject
- ajax_indicator(true);
- sendXMLDocument.call(this, smf_prepareScriptUrl(smf_scripturl) + "action=quotefast;quote=" + first_msg_id + ";modify;xml", '', this.onDocReceived_modify_topic);
- }
- // callback function from the modify_topic ajax call
- QuickModifyTopic.prototype.onDocReceived_modify_topic = function (XMLDoc)
- {
- // If it is not valid then clean up
- if (!XMLDoc || !XMLDoc.getElementsByTagName('message'))
- {
- this.modify_topic_cancel();
- return true;
- }
-
- this.sCurMessageId = XMLDoc.getElementsByTagName("message")[0].getAttribute("id");
- this.oCurSubjectDiv = document.getElementById('msg_' + this.sCurMessageId.substr(4));
- this.sBuffSubject = getInnerHTML(this.oCurSubjectDiv);
- // Here we hide any other things they want hidden on edit.
- this.set_hidden_topic_areas('none');
- // Show we are in edit mode and allow the edit
- ajax_indicator(false);
- this.modify_topic_show_edit(XMLDoc.getElementsByTagName("subject")[0].childNodes[0].nodeValue);
- }
- // Cancel out of an edit and return things to back to what they were
- QuickModifyTopic.prototype.modify_topic_cancel = function ()
- {
- setInnerHTML(this.oCurSubjectDiv, this.sBuffSubject);
- this.set_hidden_topic_areas('');
- this.bInEditMode = false;
-
- return false;
- }
- // Simply restore/show any hidden bits during topic editing.
- QuickModifyTopic.prototype.set_hidden_topic_areas = function (set_style)
- {
- for (var i = 0; i < this.aHidePrefixes.length; i++)
- {
- if (document.getElementById(this.aHidePrefixes[i] + this.sCurMessageId.substr(4)) != null)
- document.getElementById(this.aHidePrefixes[i] + this.sCurMessageId.substr(4)).style.display = set_style;
- }
- }
- // For templating, shown that an inline edit is being made.
- QuickModifyTopic.prototype.modify_topic_show_edit = function (subject)
- {
- // Just template the subject.
- setInnerHTML(this.oCurSubjectDiv, '<input type="text" name="subject" value="' + subject + '" size="60" style="width: 95%;" maxlength="80" class="input_text" /><input type="hidden" name="topic" value="' + this.iCurTopicId + '" /><input type="hidden" name="msg" value="' + this.sCurMessageId.substr(4) + '" />');
-
- // attach mouse over and out events to this new div
- this.oCurSubjectDiv.instanceRef = this;
- this.oCurSubjectDiv.onmouseout = function (oEvent) {return this.instanceRef.modify_topic_mouseout(oEvent);};
- this.oCurSubjectDiv.onmouseover = function (oEvent) {return this.instanceRef.modify_topic_mouseover(oEvent);};
- }
- // Yup thats right, save it
- QuickModifyTopic.prototype.modify_topic_save = function (cur_session_id, cur_session_var)
- {
- if (!this.bInEditMode)
- return true;
- // Add backwards compatibility with old themes.
- if (typeof(cur_session_var) == 'undefined')
- cur_session_var = 'sesc';
- var i, x = new Array();
- x[x.length] = 'subject=' + document.forms.quickModForm['subject'].value.replace(/&#/g, "&#").php_to8bit().php_urlencode();
- x[x.length] = 'topic=' + parseInt(document.forms.quickModForm.elements['topic'].value);
- x[x.length] = 'msg=' + parseInt(document.forms.quickModForm.elements['msg'].value);
- // send in the call to save the updated topic subject
- ajax_indicator(true);
- sendXMLDocument.call(this, smf_prepareScriptUrl(smf_scripturl) + "action=jsmodify;topic=" + parseInt(document.forms.quickModForm.elements['topic'].value) + ";" + cur_session_var + "=" + cur_session_id + ";xml", x.join("&"), this.modify_topic_done);
- return false;
- }
- // done with the edit, if all went well show the new topic title
- QuickModifyTopic.prototype.modify_topic_done = function (XMLDoc)
- {
- ajax_indicator(false);
-
- // If it is not valid then clean up
- if (!XMLDoc || !XMLDoc.getElementsByTagName('subject'))
- {
- this.modify_topic_cancel();
- return true;
- }
- var message = XMLDoc.getElementsByTagName("smf")[0].getElementsByTagName("message")[0];
- var subject = message.getElementsByTagName("subject")[0];
- var error = message.getElementsByTagName("error")[0];
- // No subject or other error?
- if (!subject || error)
- return false;
- this.modify_topic_hide_edit(subject.childNodes[0].nodeValue);
- this.set_hidden_topic_areas('');
- this.bInEditMode = false;
- // redo tips if they are on since we just pulled the rug out on this one
- if ($.isFunction($.fn.SMFtooltip));
- $('.preview').SMFtooltip().smf_tooltip_off;
-
- return false;
- }
- // Done with the edit, put in new subject and link.
- QuickModifyTopic.prototype.modify_topic_hide_edit = function (subject)
- {
- // Re-template the subject!
- setInnerHTML(this.oCurSubjectDiv, '<a href="' + smf_scripturl + '?topic=' + this.iCurTopicId + '.0">' + subject + '<' +'/a>');
- }
- // keypress event ... like enter or escape
- QuickModifyTopic.prototype.modify_topic_keypress = function (oEvent)
- {
- if (typeof(oEvent.keyCode) != "undefined" && this.bInEditMode)
- {
- if (oEvent.keyCode == 27)
- {
- this.modify_topic_cancel();
- if (typeof(oEvent.preventDefault) == "undefined")
- oEvent.returnValue = false;
- else
- oEvent.preventDefault();
- }
- else if (oEvent.keyCode == 13)
- {
- this.modify_topic_save(smf_session_id, smf_session_var);
- if (typeof(oEvent.preventDefault) == "undefined")
- oEvent.returnValue = false;
- else
- oEvent.preventDefault();
- }
- }
- }
- // A click event to signal the finish of the edit
- QuickModifyTopic.prototype.modify_topic_click = function (oEvent)
- {
- if (this.bInEditMode && !this.bMouseOnDiv)
- this.modify_topic_save(smf_session_id, smf_session_var);
- }
- // Moved out of the editing div
- QuickModifyTopic.prototype.modify_topic_mouseout = function (oEvent)
- {
- this.bMouseOnDiv = false;
- }
- // Moved back over the editing div
- QuickModifyTopic.prototype.modify_topic_mouseover = function (oEvent)
- {
- this.bMouseOnDiv = true;
- }
- // *** QuickReply object.
- function QuickReply(oOptions)
- {
- this.opt = oOptions;
- this.bCollapsed = this.opt.bDefaultCollapsed;
- this.bIsFull = this.opt.bIsFull;
- }
- // When a user presses quote, put it in the quick reply box (if expanded).
- QuickReply.prototype.quote = function (iMessageId, xDeprecated)
- {
- // Compatibility with older templates.
- if (typeof(xDeprecated) != 'undefined')
- return true;
- if (this.bCollapsed)
- {
- window.location.href = smf_prepareScriptUrl(this.opt.sScriptUrl) + 'action=post;quote=' + iMessageId + ';topic=' + this.opt.iTopicId + '.' + this.opt.iStart;
- return false;
- }
- else
- {
- // Doing it the XMLhttp way?
- if (window.XMLHttpRequest)
- {
- ajax_indicator(true);
- if (this.bIsFull)
- insertQuoteFast(iMessageId);
- else
- getXMLDocument(smf_prepareScriptUrl(this.opt.sScriptUrl) + 'action=quotefast;quote=' + iMessageId + ';xml', this.onQuoteReceived);
- }
- // Or with a smart popup!
- else
- reqWin(smf_prepareScriptUrl(this.opt.sScriptUrl) + 'action=quotefast;quote=' + iMessageId, 240, 90);
- // Move the view to the quick reply box.
- if (navigator.appName == 'Microsoft Internet Explorer')
- window.location.hash = this.opt.sJumpAnchor;
- else
- window.location.hash = '#' + this.opt.sJumpAnchor;
- return false;
- }
- }
- // This is the callback function used after the XMLhttp request.
- QuickReply.prototype.onQuoteReceived = function (oXMLDoc)
- {
- var sQuoteText = '';
- for (var i = 0; i < oXMLDoc.getElementsByTagName('quote')[0].childNodes.length; i++)
- sQuoteText += oXMLDoc.getElementsByTagName('quote')[0].childNodes[i].nodeValue;
- replaceText(sQuoteText, document.forms.postmodify.message);
- ajax_indicator(false);
- }
- // The function handling the swapping of the quick reply.
- QuickReply.prototype.swap = function ()
- {
- document.getElementById(this.opt.sImageId).src = this.opt.sImagesUrl + "/" + (this.bCollapsed ? this.opt.sImageCollapsed : this.opt.sImageExpanded);
- $('#' + this.opt.sContainerId).slideToggle();
- this.bCollapsed = !this.bCollapsed;
- }
- // *** QuickModify object.
- function QuickModify(oOptions)
- {
- this.opt = oOptions;
- this.bInEditMode = false;
- this.sCurMessageId = '';
- this.oCurMessageDiv = null;
- this.oCurSubjectDiv = null;
- this.sMessageBuffer = '';
- this.sSubjectBuffer = '';
- this.bXmlHttpCapable = this.isXmlHttpCapable();
- this.aAccessKeys = new Array();
- // Show the edit buttons
- if (this.bXmlHttpCapable)
- {
- var aShowQuickModify = document.getElementsByClassName(this.opt.sClassName);
- for (var i = 0, length = aShowQuickModify.length; i < length; i++) {
- aShowQuickModify[i].style.display = "inline";
- }
- }
- }
- // Determine whether the quick modify can actually be used.
- QuickModify.prototype.isXmlHttpCapable = function ()
- {
- if (typeof(window.XMLHttpRequest) == 'undefined')
- return false;
- // Opera didn't always support POST requests. So test it first.
- if ('opera' in window)
- {
- var oTest = new XMLHttpRequest();
- if (!('setRequestHeader' in oTest))
- return false;
- }
- return true;
- }
- // Function called when a user presses the edit button.
- QuickModify.prototype.modifyMsg = function (iMessageId)
- {
- if (!this.bXmlHttpCapable)
- return;
- // Add backwards compatibility with old themes.
- if (typeof(sSessionVar) == 'undefined')
- sSessionVar = 'sesc';
- // Removes the accesskeys from the quickreply inputs and saves them in an array to use them later
- if (typeof(this.opt.sFormRemoveAccessKeys) != 'undefined')
- {
- if (typeof(document.forms[this.opt.sFormRemoveAccessKeys]))
- {
- var aInputs = document.forms[this.opt.sFormRemoveAccessKeys].getElementsByTagName('input');
- for (var i = 0; i < aInputs.length; i++)
- {
- if (aInputs[i].accessKey != '')
- {
- this.aAccessKeys[aInputs[i].name] = aInputs[i].accessKey;
- aInputs[i].accessKey = '';
- }
- }
- }
- }
- // First cancel if there's another message still being edited.
- if (this.bInEditMode)
- this.modifyCancel();
- // At least NOW we're in edit mode
- this.bInEditMode = true;
- // Send out the XMLhttp request to get more info
- ajax_indicator(true);
- sendXMLDocument.call(this, smf_prepareScriptUrl(smf_scripturl) + 'action=quotefast;quote=' + iMessageId + ';modify;xml', '', this.onMessageReceived);
- }
- // The callback function used for the XMLhttp request retrieving the message.
- QuickModify.prototype.onMessageReceived = function (XMLDoc)
- {
- var sBodyText = '', sSubjectText = '';
- // No longer show the 'loading...' sign.
- ajax_indicator(false);
- // Grab the message ID.
- this.sCurMessageId = XMLDoc.getElementsByTagName('message')[0].getAttribute('id');
- // If this is not valid then simply give up.
- if (!document.getElementById(this.sCurMessageId))
- return this.modifyCancel();
- // Replace the body part.
- for (var i = 0; i < XMLDoc.getElementsByTagName("message")[0].childNodes.length; i++)
- sBodyText += XMLDoc.getElementsByTagName("message")[0].childNodes[i].nodeValue;
- this.oCurMessageDiv = document.getElementById(this.sCurMessageId);
- this.sMessageBuffer = getInnerHTML(this.oCurMessageDiv);
- // We have to force the body to lose its dollar signs thanks to IE.
- sBodyText = sBodyText.replace(/\$/g, '{&dollarfix;$}');
- // Actually create the content, with a bodge for disappearing dollar signs.
- setInnerHTML(this.oCurMessageDiv, this.opt.sTemplateBodyEdit.replace(/%msg_id%/g, this.sCurMessageId.substr(4)).replace(/%body%/, sBodyText).replace(/\{&dollarfix;\$\}/g, '$'));
- // Replace the subject part.
- this.oCurSubjectDiv = document.getElementById('subject_' + this.sCurMessageId.substr(4));
- this.sSubjectBuffer = getInnerHTML(this.oCurSubjectDiv);
- sSubjectText = XMLDoc.getElementsByTagName('subject')[0].childNodes[0].nodeValue.replace(/\$/g, '{&dollarfix;$}');
- setInnerHTML(this.oCurSubjectDiv, this.opt.sTemplateSubjectEdit.replace(/%subject%/, sSubjectText).replace(/\{&dollarfix;\$\}/g, '$'));
- return true;
- }
- // Function in case the user presses cancel (or other circumstances cause it).
- QuickModify.prototype.modifyCancel = function ()
- {
- // Roll back the HTML to its original state.
- if (this.oCurMessageDiv)
- {
- setInnerHTML(this.oCurMessageDiv, this.sMessageBuffer);
- setInnerHTML(this.oCurSubjectDiv, this.sSubjectBuffer);
- }
- // No longer in edit mode, that's right.
- this.bInEditMode = false;
- // Let's put back the accesskeys to their original place
- if (typeof(this.opt.sFormRemoveAccessKeys) != 'undefined')
- {
- if (typeof(document.forms[this.opt.sFormRemoveAccessKeys]))
- {
- var aInputs = document.forms[this.opt.sFormRemoveAccessKeys].getElementsByTagName('input');
- for (var i = 0; i < aInputs.length; i++)
- {
- if (typeof(this.aAccessKeys[aInputs[i].name]) != 'undefined')
- {
- aInputs[i].name = this.aAccessKeys[aInputs[i].name];
- }
- }
- }
- }
- return false;
- }
- // The function called after a user wants to save his precious message.
- QuickModify.prototype.modifySave = function (sSessionId, sSessionVar)
- {
- // We cannot save if we weren't in edit mode.
- if (!this.bInEditMode)
- return true;
- // Add backwards compatibility with old themes.
- if (typeof(sSessionVar) == 'undefined')
- sSessionVar = 'sesc';
- // Let's put back the accesskeys to their original place
- if (typeof(this.opt.sFormRemoveAccessKeys) != 'undefined')
- {
- if (typeof(document.forms[this.opt.sFormRemoveAccessKeys]))
- {
- var aInputs = document.forms[this.opt.sFormRemoveAccessKeys].getElementsByTagName('input');
- for (var i = 0; i < aInputs.length; i++)
- {
- if (typeof(this.aAccessKeys[aInputs[i].name]) != 'undefined')
- {
- aInputs[i].name = this.aAccessKeys[aInputs[i].name];
- }
- }
- }
- }
- var i, x = new Array();
- x[x.length] = 'subject=' + escape(document.forms.quickModForm['subject'].value.replace(/&#/g, "&#").php_to8bit()).replace(/\+/g, "%2B");
- x[x.length] = 'message=' + escape(document.forms.quickModForm['message'].value.replace(/&#/g, "&#").php_to8bit()).replace(/\+/g, "%2B");
- x[x.length] = 'topic=' + parseInt(document.forms.quickModForm.elements['topic'].value);
- x[x.length] = 'msg=' + parseInt(document.forms.quickModForm.elements['msg'].value);
- // Send in the XMLhttp request and let's hope for the best.
- ajax_indicator(true);
- sendXMLDocument.call(this, smf_prepareScriptUrl(this.opt.sScriptUrl) + "action=jsmodify;topic=" + this.opt.iTopicId + ";" + smf_session_var + "=" + smf_session_id + ";xml", x.join("&"), this.onModifyDone);
- return false;
- }
- // Callback function of the XMLhttp request sending the modified message.
- QuickModify.prototype.onModifyDone = function (XMLDoc)
- {
- // We've finished the loading stuff.
- ajax_indicator(false);
- // If we didn't get a valid document, just cancel.
- if (!XMLDoc || !XMLDoc.getElementsByTagName('smf')[0])
- {
- // Mozilla will nicely tell us what's wrong.
- if (XMLDoc.childNodes.length > 0 && XMLDoc.firstChild.nodeName == 'parsererror')
- setInnerHTML(document.getElementById('error_box'), XMLDoc.firstChild.textContent);
- else
- this.modifyCancel();
- return;
- }
- var message = XMLDoc.getElementsByTagName('smf')[0].getElementsByTagName('message')[0];
- var body = message.getElementsByTagName('body')[0];
- var error = message.getElementsByTagName('error')[0];
- if (body)
- {
- // Show new body.
- var bodyText = '';
- for (var i = 0; i < body.childNodes.length; i++)
- bodyText += body.childNodes[i].nodeValue;
- this.sMessageBuffer = this.opt.sTemplateBodyNormal.replace(/%body%/, bodyText.replace(/\$/g, '{&dollarfix;$}')).replace(/\{&dollarfix;\$\}/g,'$');
- setInnerHTML(this.oCurMessageDiv, this.sMessageBuffer);
- // Show new subject.
- var oSubject = message.getElementsByTagName('subject')[0];
- var sSubjectText = oSubject.childNodes[0].nodeValue.replace(/\$/g, '{&dollarfix;$}');
- this.sSubjectBuffer = this.opt.sTemplateSubjectNormal.replace(/%msg_id%/g, this.sCurMessageId.substr(4)).replace(/%subject%/, sSubjectText).replace(/\{&dollarfix;\$\}/g,'$');
- setInnerHTML(this.oCurSubjectDiv, this.sSubjectBuffer);
- // If this is the first message, also update the topic subject.
- if (oSubject.getAttribute('is_first') == '1')
- setInnerHTML(document.getElementById('top_subject'), this.opt.sTemplateTopSubject.replace(/%subject%/, sSubjectText).replace(/\{&dollarfix;\$\}/g, '$'));
- // Show this message as 'modified on x by y'.
- if (this.opt.bShowModify)
- setInnerHTML(document.getElementById('modified_' + this.sCurMessageId.substr(4)), message.getElementsByTagName('modified')[0].childNodes[0].nodeValue);
- }
- else if (error)
- {
- setInnerHTML(document.getElementById('error_box'), error.childNodes[0].nodeValue);
- document.forms.quickModForm.message.style.border = error.getAttribute('in_body') == '1' ? this.opt.sErrorBorderStyle : '';
- document.forms.quickModForm.subject.style.border = error.getAttribute('in_subject') == '1' ? this.opt.sErrorBorderStyle : '';
- }
- }
- function InTopicModeration(oOptions)
- {
- this.opt = oOptions;
- this.bButtonsShown = false;
- this.iNumSelected = 0;
- // Add backwards compatibility with old themes.
- if (typeof(this.opt.sSessionVar) == 'undefined')
- this.opt.sSessionVar = 'sesc';
- this.init();
- }
- InTopicModeration.prototype.init = function()
- {
- // Add checkboxes to all the messages.
- for (var i = 0, n = this.opt.aMessageIds.length; i < n; i++)
- {
- // Create the checkbox.
- var oCheckbox = document.createElement('input');
- oCheckbox.type = 'checkbox';
- oCheckbox.className = 'input_check';
- oCheckbox.name = 'msgs[]';
- oCheckbox.value = this.opt.aMessageIds[i];
- oCheckbox.instanceRef = this;
- oCheckbox.onclick = function () {
- this.instanceRef.handleClick(this);
- }
- // Append it to the container
- var oCheckboxContainer = document.getElementById(this.opt.sCheckboxContainerMask + this.opt.aMessageIds[i]);
- oCheckboxContainer.appendChild(oCheckbox);
- oCheckboxContainer.style.display = '';
- }
- }
- InTopicModeration.prototype.handleClick = function(oCheckbox)
- {
- if (!this.bButtonsShown && this.opt.sButtonStripDisplay)
- {
- var oButtonStrip = document.getElementById(this.opt.sButtonStrip);
- var oButtonStripDisplay = document.getElementById(this.opt.sButtonStripDisplay);
- // Make sure it can go somewhere.
- if (typeof(oButtonStripDisplay) == 'object' && oButtonStripDisplay != null)
- oButtonStripDisplay.style.display = "";
- else
- {
- var oNewDiv = document.createElement('div');
- var oNewList = document.createElement('ul');
- oNewDiv.id = this.opt.sButtonStripDisplay;
- oNewDiv.className = this.opt.sButtonStripClass ? this.opt.sButtonStripClass : 'buttonlist floatbottom';
- oNewDiv.appendChild(oNewList);
- oButtonStrip.appendChild(oNewDiv);
- }
- // Add the 'remove selected items' button.
- if (this.opt.bCanRemove)
- smf_addButton(this.opt.sButtonStrip, this.opt.bUseImageButton, {
- sId: this.opt.sSelf + '_remove_button',
- sText: this.opt.sRemoveButtonLabel,
- sImage: this.opt.sRemoveButtonImage,
- sUrl: '#',
- sCustom: ' onclick="return ' + this.opt.sSelf + '.handleSubmit(\'remove\')"'
- });
- // Add the 'restore selected items' button.
- if (this.opt.bCanRestore)
- smf_addButton(this.opt.sButtonStrip, this.opt.bUseImageButton, {
- sId: this.opt.sSelf + '_restore_button',
- sText: this.opt.sRestoreButtonLabel,
- sImage: this.opt.sRestoreButtonImage,
- sUrl: '#',
- sCustom: ' onclick="return ' + this.opt.sSelf + '.handleSubmit(\'restore\')"'
- });
- // Add the 'split selected items' button.
- if (this.opt.bCanSplit)
- smf_addButton(this.opt.sButtonStrip, this.opt.bUseImageButton, {
- sId: this.opt.sSelf + '_split_button',
- sText: this.opt.sSplitButtonLabel,
- sImage: this.opt.sSplitButtonImage,
- sUrl: '#',
- sCustom: ' onclick="return ' + this.opt.sSelf + '.handleSubmit(\'split\')"'
- });
- // Adding these buttons once should be enough.
- this.bButtonsShown = true;
- }
- // Keep stats on how many items were selected.
- this.iNumSelected += oCheckbox.checked ? 1 : -1;
- // Show the number of messages selected in the button.
- if (this.opt.bCanRemove && !this.opt.bUseImageButton)
- {
- setInnerHTML(document.getElementById(this.opt.sSelf + '_remove_button_text'), this.opt.sRemoveButtonLabel + ' [' + this.iNumSelected + ']');
- document.getElementById(this.opt.sSelf + '_remove_button').style.display = this.iNumSelected < 1 ? "none" : "";
- }
- if (this.opt.bCanRestore && !this.opt.bUseImageButton)
- {
- setInnerHTML(document.getElementById(this.opt.sSelf + '_restore_button_text'), this.opt.sRestoreButtonLabel + ' [' + this.iNumSelected + ']');
- document.getElementById(this.opt.sSelf + '_restore_button').style.display = this.iNumSelected < 1 ? "none" : "";
- }
- if (this.opt.bCanSplit && !this.opt.bUseImageButton)
- {
- setInnerHTML(document.getElementById(this.opt.sSelf + '_split_button_text'), this.opt.sSplitButtonLabel + ' [' + this.iNumSelected + ']');
- document.getElementById(this.opt.sSelf + '_split_button').style.display = this.iNumSelected < 1 ? "none" : "";
- }
- // Try to restore the correct position.
- var aItems = document.getElementById(this.opt.sButtonStrip).getElementsByTagName('span');
- if (aItems.length > 3)
- {
- if (this.iNumSelected < 1)
- {
- aItems[aItems.length - 3].className = aItems[aItems.length - 3].className.replace(/\s*position_holder/, 'last');
- aItems[aItems.length - 2].className = aItems[aItems.length - 2].className.replace(/\s*position_holder/, 'last');
- }
- else
- {
- aItems[aItems.length - 2].className = aItems[aItems.length - 2].className.replace(/\s*last/, 'position_holder');
- aItems[aItems.length - 3].className = aItems[aItems.length - 3].className.replace(/\s*last/, 'position_holder');
- }
- }
- }
- InTopicModeration.prototype.handleSubmit = function (sSubmitType)
- {
- var oForm = document.getElementById(this.opt.sFormId);
- // Make sure this form isn't submitted in another way than this function.
- var oInput = document.createElement('input');
- oInput.type = 'hidden';
- oInput.name = this.opt.sSessionVar;
- oInput.value = this.opt.sSessionId;
- oForm.appendChild(oInput);
- switch (sSubmitType)
- {
- case 'remove':
- if (!confirm(this.opt.sRemoveButtonConfirm))
- return false;
- oForm.action = oForm.action.replace(/;split_selection=1/, '');
- oForm.action = oForm.action.replace(/;restore_selected=1/, '');
- break;
- case 'restore':
- if (!confirm(this.opt.sRestoreButtonConfirm))
- return false;
- oForm.action = oForm.action.replace(/;split_selection=1/, '');
- oForm.action = oForm.action + ';restore_selected=1';
- break;
- case 'split':
- if (!confirm(this.opt.sRestoreButtonConfirm))
- return false;
- oForm.action = oForm.action.replace(/;restore_selected=1/, '');
- oForm.action = oForm.action + ';split_selection=1';
- break;
- default:
- return false;
- break;
- }
- oForm.submit();
- return true;
- }
- // *** Other functions...
- function expandThumb(thumbID)
- {
- var img = document.getElementById('thumb_' + thumbID);
- var link = document.getElementById('link_' + thumbID);
-
- // save the currently displayed image attributes
- var tmp_src = img.src;
- var tmp_height = img.style.height;
- var tmp_width = img.style.width;
-
- // set the displayed image attributes to the link attributes, this will expand in place
- img.src = link.href;
- img.style.width = link.style.width;
- img.style.height = link.style.height;
-
- // place the image attributes back
- link.href = tmp_src;
- link.style.width = tmp_width;
- link.style.height = tmp_height;
-
- return false;
- }
- function ignore_toggles(msgids, text)
- {
- for (i = 0; i < msgids.length; i++)
- {
- var msgid = msgids[i];
- new smc_Toggle({
- bToggleEnabled: true,
- bCurrentlyCollapsed: true,
- aSwappableContainers: [
- 'msg_' + msgid + '_extra_info',
- 'msg_' + msgid,
- 'msg_' + msgid + '_footer',
- 'msg_' + msgid + '_quick_mod',
- 'modify_button_' + msgid,
- 'msg_' + msgid + '_signature'
- ],
- aSwapLinks: [
- {
- sId: 'msg_' + msgid + '_ignored_link',
- msgExpanded: '',
- msgCollapsed: text
- }
- ]
- });
- }
- }
|