Thank Post Mod

Hier kommen die Support Anfragen für phpBB 3.0.x MODs hinein.
Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Thank Post Mod

Beitragvon Texas » 26. Jan 2009 13:50

Your phpBB Version: 3.0.4
Your phpBB Type: Standard phpBB (also called Vanilla (phpBB2) or Olympus (phpBB3))
MODs installed: Yes
Your knowledge: Beginner
Boardlink: http://www.thecoldwars.com/forum

What have you done before the problem was there?
I just installed the Thank Post Mod 0.2.0

What have you already tryed to solve the problem?
Mainly just rechecked all the code and the files.

Description and Message
I installed the Thank Post Mod 0.2.0 and am not getting any errors, but...the THANKS button or any forum of link or button for thanking a post doesn't appear anywhere. The manual says there is a way to enable/disable the mod, but it doesn't say where in the ACP to do this and I haven't been able to find where.

I have not installed the hide_mod_addon yet.

Where do I look to enable the mod?

Benutzeravatar
Mahony
Site Admin
Site Admin
Beiträge: 749
Registriert: 3. Dez 2006 22:09
Hat sich bedankt: 1 Mal
Danksagung erhalten: 4 Mal

Re: Thank Post Mod

Beitragvon Mahony » 26. Jan 2009 17:23

Hello
Have you The MOD enabled for a Forum?
You will find it under ACP ==> Forums > Click on a category ==> Then edit a forum where you want the thanks is enabled (under "General forum settings" you will find the Option).


Best regards: Mahony
Diejenigen, die lautstark darüber diskutieren, warum es nicht geht, mögen bitte jene nicht stören, die es gerade tun.
Klug ist, wer nur die Hälfte von dem glaubt, was er hört. Weise ist, wer erkennt, welche Hälfte richtig ist.

Bild

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 17:28

Mahony hat geschrieben:Hello
Have you The MOD enabled for a Forum?
You will find it under ACP ==> Forums > Click on a category ==> Then edit a forum where you want the thanks is enabled (under "General forum settings" you will find the Option).


Best regards: Mahony


There is no option there for the thanks mod.

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 17:30

Only options showing are:

Forum Status:
Enable the SupportTicket Assistant:
List subforums in legend:
List subforum in parent-forum’s legend:
Enable post review:
Enable search indexing:
Enable topic icons:
Display active topics:
Topics per page:

Benutzeravatar
Mahony
Site Admin
Site Admin
Beiträge: 749
Registriert: 3. Dez 2006 22:09
Hat sich bedankt: 1 Mal
Danksagung erhalten: 4 Mal

Re: Thank Post Mod

Beitragvon Mahony » 26. Jan 2009 17:41

Hello
Have you clear your cache?

Best regards: Mahony
Diejenigen, die lautstark darüber diskutieren, warum es nicht geht, mögen bitte jene nicht stören, die es gerade tun.
Klug ist, wer nur die Hälfte von dem glaubt, was er hört. Weise ist, wer erkennt, welche Hälfte richtig ist.

Bild

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 18:02

I refresehed the templates, the imagesets, the themes, and even cleared the cache on my personal pc. Still nothing.

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 18:12

Here is my edited adm/styles/acp_forums:

Code: Alles auswählen

<!-- INCLUDE overall_header.html -->

<a name="maincontent"></a>

<!-- IF S_EDIT_FORUM -->

   <script type="text/javascript">
   // <![CDATA[
      /**
      * Handle displaying/hiding several options based on the forum type
      */
      function display_options(value)
      {
         <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_POST -->
            if (value == {FORUM_POST})
            {
               dE('type_actions', -1);
            }
            else
            {
               dE('type_actions', 1);
            }
         <!-- ENDIF -->

         <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
            if (value == {FORUM_LINK})
            {
               dE('cat_to_link_actions', 1);
            }
            else
            {
               dE('cat_to_link_actions', -1);
            }
         <!-- ENDIF -->

         if (value == {FORUM_POST})
         {
            dE('forum_post_options', 1);
            dE('forum_link_options', -1);
            dE('forum_rules_options', 1);
            dE('forum_cat_options', -1);
         }
         else if (value == {FORUM_LINK})
         {
            dE('forum_post_options', -1);
            dE('forum_link_options', 1);
            dE('forum_rules_options', -1);
            dE('forum_cat_options', -1);
         }
         else if (value == {FORUM_CAT})
         {
            dE('forum_post_options', -1);
            dE('forum_link_options', -1);
            dE('forum_rules_options', 1);
            dE('forum_cat_options', 1);
         }
      }

      /**
      * Init the wanted display functionality if javascript is enabled.
      * If javascript is not available, the user is still able to properly administrate.
      */
      onload = function()
      {
         <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_POST -->
            <!-- IF S_FORUM_POST -->
               dE('type_actions', -1);
            <!-- ENDIF -->
         <!-- ENDIF -->

         <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
            <!-- IF S_FORUM_CAT -->
               dE('cat_to_link_actions', -1);
            <!-- ENDIF -->
         <!-- ENDIF -->

         <!-- IF not S_FORUM_POST -->
            dE('forum_post_options', -1);
         <!-- ENDIF -->

         <!-- IF not S_FORUM_CAT -->
            dE('forum_cat_options', -1);
         <!-- ENDIF -->

         <!-- IF not S_FORUM_LINK -->
            dE('forum_link_options', -1);
         <!-- ENDIF -->

         <!-- IF S_FORUM_LINK -->
         dE('forum_rules_options', -1);
         <!-- ENDIF -->
      }

   // ]]>
   </script>

   <a href="{U_BACK}" style="float: {S_CONTENT_FLOW_END};">&laquo; {L_BACK}</a>

   <h1>{L_TITLE} <!-- IF FORUM_NAME -->:: {FORUM_NAME}<!-- ENDIF --></h1>

   <p>{L_FORUM_EDIT_EXPLAIN}</p>

   <!-- IF S_ERROR -->
      <div class="errorbox">
         <h3>{L_WARNING}</h3>
         <p>{ERROR_MSG}</p>
      </div>
   <!-- ENDIF -->

   <form id="forumedit" method="post" action="{U_EDIT_ACTION}">

   <fieldset>
      <legend>{L_FORUM_SETTINGS}</legend>
   <dl>
      <dt><label for="forum_type">{L_FORUM_TYPE}:</label></dt>
      <dd><select id="forum_type" name="forum_type" onchange="display_options(this.options[this.selectedIndex].value);">{S_FORUM_TYPE_OPTIONS}</select></dd>
   </dl>
   <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_POST -->
   <div id="type_actions">
      <dl>
         <dt><label for="type_action">{L_DECIDE_MOVE_DELETE_CONTENT}:</label></dt>
         <dd><label><input type="radio" class="radio" name="type_action" value="delete"<!-- IF not S_MOVE_FORUM_OPTIONS --> checked="checked" id="type_action"<!-- ENDIF --> /> {L_DELETE_ALL_POSTS}</label></dd>
         <!-- IF S_MOVE_FORUM_OPTIONS --><dd><label><input type="radio" class="radio" name="type_action" id="type_action" value="move" checked="checked" /> {L_MOVE_POSTS_TO}</label> <select name="to_forum_id">{S_MOVE_FORUM_OPTIONS}</select></dd><!-- ENDIF -->
      </dl>
   </div>
   <!-- ENDIF -->
   <!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
   <div id="cat_to_link_actions">
      <dl>
         <dt><label for="action_subforums">{L_DECIDE_MOVE_DELETE_SUBFORUMS}:</label></dt>
         <!-- IF S_FORUMS_LIST -->
            <dd><label><input type="radio" class="radio" id="action_subforums" name="action_subforums" value="move" checked="checked" /> {L_MOVE_SUBFORUMS_TO}</label> <select name="subforums_to_id">{S_FORUMS_LIST}</select></dd>
         <!-- ELSE -->
            <dd><label><input type="radio" class="radio" id="action_subforums" name="action_subforums" value="delete" checked="checked" /> {L_DELETE_SUBFORUMS}</label></dd>
         <!-- ENDIF -->
      </dl>
   </div>
   <!-- ENDIF -->
   <dl>
      <dt><label for="parent">{L_FORUM_PARENT}:</label></dt>
      <dd><select id="parent" name="forum_parent_id"><option value="0"<!-- IF not S_FORUM_PARENT_ID --> selected="selected"<!-- ENDIF -->>{L_NO_PARENT}</option>{S_PARENT_OPTIONS}</select></dd>
   </dl>
   <dl>
      <dt><label for="forum_name">{L_FORUM_NAME}:</label></dt>
      <dd><input class="text medium" type="text" id="forum_name" name="forum_name" value="{FORUM_NAME}" maxlength="255" /></dd>
   </dl>
   <dl>
      <dt><label for="forum_desc">{L_FORUM_DESC}:</label><br /><span>{L_FORUM_DESC_EXPLAIN}</span></dt>
      <dd><textarea id="forum_desc" name="forum_desc" rows="5" cols="45">{FORUM_DESC}</textarea></dd>
      <dd><label><input type="checkbox" class="radio" name="desc_parse_bbcode"<!-- IF S_DESC_BBCODE_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_BBCODE}</label>
         <label><input type="checkbox" class="radio" name="desc_parse_smilies"<!-- IF S_DESC_SMILIES_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_SMILIES}</label>
         <label><input type="checkbox" class="radio" name="desc_parse_urls"<!-- IF S_DESC_URLS_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_URLS}</label></dd>
   </dl>
   <dl>
      <dt><label for="forum_image">{L_FORUM_IMAGE}:</label><br /><span>{L_FORUM_IMAGE_EXPLAIN}</span></dt>
      <dd><input class="text medium" type="text" id="forum_image" name="forum_image" value="{FORUM_IMAGE}" maxlength="255" /></dd>
      <!-- IF FORUM_IMAGE_SRC -->
         <dd><img src="{FORUM_IMAGE_SRC}" alt="{L_FORUM_IMAGE}" /></dd>
      <!-- ENDIF -->
   </dl>
   <dl>
      <dt><label for="forum_password">{L_FORUM_PASSWORD}:</label><br /><span>{L_FORUM_PASSWORD_EXPLAIN}</span></dt>
      <dd><input type="password" id="forum_password" name="forum_password" value="<!-- IF S_FORUM_PASSWORD_SET -->&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;<!-- ENDIF -->" /></dd>
   </dl>
   <dl>
      <dt><label for="forum_password_confirm">{L_FORUM_PASSWORD_CONFIRM}:</label><br /><span>{L_FORUM_PASSWORD_CONFIRM_EXPLAIN}</span></dt>
      <dd><input type="password" id="forum_password_confirm" name="forum_password_confirm" value="<!-- IF S_FORUM_PASSWORD_SET -->&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;<!-- ENDIF -->" /></dd>
   </dl>
   <!-- IF S_FORUM_PASSWORD_SET -->
   <dl>
      <dt><label for="forum_password_unset">{L_FORUM_PASSWORD_UNSET}:</label><br /><span>{L_FORUM_PASSWORD_UNSET_EXPLAIN}</span></dt>
      <dd><input id="forum_password_unset" name="forum_password_unset" type="checkbox" /></dd>
   </dl>
   <!-- ENDIF -->
   <dl>
      <dt><label for="forum_style">{L_FORUM_STYLE}:</label></dt>
      <dd><select id="forum_style" name="forum_style"><option value="0">{L_DEFAULT_STYLE}</option>{S_STYLES_OPTIONS}</select></dd>
   </dl>
   <!-- IF S_CAN_COPY_PERMISSIONS -->
      <dl>
         <dt><label for="forum_perm_from">{L_COPY_PERMISSIONS}:</label><br /><span>{L_COPY_PERMISSIONS_EXPLAIN}</span></dt>
         <dd><select id="forum_perm_from" name="forum_perm_from"><option value="0">{L_NO_PERMISSIONS}</option>{S_FORUM_OPTIONS}</select></dd>
      </dl>
   <!-- ENDIF -->
   </fieldset>

   <div id="forum_cat_options">
      <fieldset>
         <legend>{L_GENERAL_FORUM_SETTINGS}</legend>
      <dl>
         <dt><label for="display_active">{L_DISPLAY_ACTIVE_TOPICS}:</label><br /><span>{L_DISPLAY_ACTIVE_TOPICS_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="display_active" value="1"<!-- IF S_DISPLAY_ACTIVE_TOPICS --> id="display_active" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="display_active" value="0"<!-- IF not S_DISPLAY_ACTIVE_TOPICS --> id="display_active" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      </fieldset>
   </div>

[b]   <div id="forum_post_options">
      <fieldset>
         <legend>{L_GENERAL_FORUM_SETTINGS}</legend>
      <dl>
         <dt><label for="forum_status">{L_FORUM_STATUS}:</label></dt>
         <dd><select id="forum_status" name="forum_status">{S_STATUS_OPTIONS}</select></dd>
      </dl>

<!-- mod : Thanks Post MOD -->
         <dl>
         <dt><label for="enable_thanks">{L_THANKS_ENABLE}:</label><br /></dt>
         <dd><label><input type="radio" class="radio" name="enable_thanks" value="1"<!-- IF S_THANKS_ENABLE --> id="enable_thanks" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_thanks" value="0"<!-- IF not S_THANKS_ENABLE --> id="enable_thanks" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
        <!-- fin mod : Thanks Post MOD -->[/b]

   <!-- mod : Support Ticket System -->
         <dl>
         <dt><label for="enable_sts">{L_STS_ENABLE}:</label><br /></dt>
         <dd><label><input type="radio" class="radio" name="enable_sts" value="1"<!-- IF S_STS_ENABLE --> id="enable_sts" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_sts" value="0"<!-- IF not S_STS_ENABLE --> id="enable_sts" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
        <!-- fin mod : Support Ticket System -->
      <dl>
         <dt><label for="display_subforum_list">{L_LIST_SUBFORUMS}:</label><br /><span>{L_LIST_SUBFORUMS_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="display_subforum_list" value="1"<!-- IF S_DISPLAY_SUBFORUM_LIST --> id="display_subforum_list" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="display_subforum_list" value="0"<!-- IF not S_DISPLAY_SUBFORUM_LIST --> id="display_subforum_list" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="display_on_index">{L_LIST_INDEX}:</label><br /><span>{L_LIST_INDEX_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="display_on_index" value="1"<!-- IF S_DISPLAY_ON_INDEX --> id="display_on_index" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="display_on_index" value="0"<!-- IF not S_DISPLAY_ON_INDEX --> id="display_on_index" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="enable_post_review">{L_ENABLE_POST_REVIEW}:</label><br /><span>{L_ENABLE_POST_REVIEW_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="enable_post_review" value="1"<!-- IF S_ENABLE_POST_REVIEW --> id="enable_post_review" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_post_review" value="0"<!-- IF not S_ENABLE_POST_REVIEW --> id="enable_post_review" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="enable_indexing">{L_ENABLE_INDEXING}:</label><br /><span>{L_ENABLE_INDEXING_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="enable_indexing" value="1"<!-- IF S_ENABLE_INDEXING --> id="enable_indexing" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_indexing" value="0"<!-- IF not S_ENABLE_INDEXING --> id="enable_indexing" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="enable_icons">{L_ENABLE_TOPIC_ICONS}:</label></dt>
         <dd><label><input type="radio" class="radio" name="enable_icons" value="1"<!-- IF S_TOPIC_ICONS --> id="enable_icons" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_icons" value="0"<!-- IF not S_TOPIC_ICONS --> id="enable_icons" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="display_recent">{L_ENABLE_RECENT}:</label><br /><span>{L_ENABLE_RECENT_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="display_recent" value="1"<!-- IF S_DISPLAY_ACTIVE_TOPICS --> id="display_recent" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="display_recent" value="0"<!-- IF not S_DISPLAY_ACTIVE_TOPICS --> id="display_recent" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="topics_per_page">{L_FORUM_TOPICS_PAGE}:</label><br /><span>{L_FORUM_TOPICS_PAGE_EXPLAIN}</span></dt>
         <dd><input type="text" id="topics_per_page" name="topics_per_page" value="{TOPICS_PER_PAGE}" size="4" maxlength="4" /></dd>
      </dl>
      </fieldset>

      <fieldset>
         <legend>{L_FORUM_PRUNE_SETTINGS}</legend>
      <dl>
         <dt><label for="enable_prune">{L_FORUM_AUTO_PRUNE}:</label><br /><span>{L_FORUM_AUTO_PRUNE_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="enable_prune" value="1"<!-- IF S_PRUNE_ENABLE --> id="enable_prune" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="enable_prune" value="0"<!-- IF not S_PRUNE_ENABLE --> id="enable_prune" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="prune_freq">{L_AUTO_PRUNE_FREQ}:</label><br /><span>{L_AUTO_PRUNE_FREQ_EXPLAIN}</span></dt>
         <dd><input type="text" id="prune_freq" name="prune_freq" value="{PRUNE_FREQ}" maxlength="4" size="4" /> {L_DAYS}</dd>
      </dl>
      <dl>
         <dt><label for="prune_days">{L_AUTO_PRUNE_DAYS}:</label><br /><span>{L_AUTO_PRUNE_DAYS_EXPLAIN}</span></dt>
         <dd><input type="text" id="prune_days" name="prune_days" value="{PRUNE_DAYS}" maxlength="4" size="4" /> {L_DAYS}</dd>
      </dl>
      <dl>
         <dt><label for="prune_viewed">{L_AUTO_PRUNE_VIEWED}:</label><br /><span>{L_AUTO_PRUNE_VIEWED_EXPLAIN}</span></dt>
         <dd><input type="text" id="prune_viewed" name="prune_viewed" value="{PRUNE_VIEWED}" maxlength="4" size="4" /> {L_DAYS}</dd>
      </dl>
      <dl>
         <dt><label for="prune_old_polls">{L_PRUNE_OLD_POLLS}:</label><br /><span>{L_PRUNE_OLD_POLLS_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="prune_old_polls" value="1"<!-- IF S_PRUNE_OLD_POLLS --> id="prune_old_polls" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="prune_old_polls" value="0"<!-- IF not S_PRUNE_OLD_POLLS --> id="prune_old_polls" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="prune_announce">{L_PRUNE_ANNOUNCEMENTS}:</label></dt>
         <dd><label><input type="radio" class="radio" name="prune_announce" value="1"<!-- IF S_PRUNE_ANNOUNCE --> id="prune_announce" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="prune_announce" value="0"<!-- IF not S_PRUNE_ANNOUNCE --> id="prune_announce" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="prune_sticky">{L_PRUNE_STICKY}:</label></dt>
         <dd><label><input type="radio" class="radio" name="prune_sticky" value="1"<!-- IF S_PRUNE_STICKY --> id="prune_sticky" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="prune_sticky" value="0"<!-- IF not S_PRUNE_STICKY --> id="prune_sticky" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      </fieldset>
   </div>

   <div id="forum_link_options">
      <fieldset>
         <legend>{L_GENERAL_FORUM_SETTINGS}</legend>
      <dl>
         <dt><label for="link_display_on_index">{L_LIST_INDEX}:</label><br /><span>{L_LIST_INDEX_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="link_display_on_index" value="1"<!-- IF S_DISPLAY_ON_INDEX --> id="link_display_on_index" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="link_display_on_index" value="0"<!-- IF not S_DISPLAY_ON_INDEX --> id="link_display_on_index" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      <dl>
         <dt><label for="forum_link">{L_FORUM_LINK}:</label><br /><span>{L_FORUM_LINK_EXPLAIN}</span></dt>
         <dd><input class="text medium" type="text" id="forum_link" name="forum_link" value="{FORUM_DATA_LINK}" maxlength="255" /></dd>
      </dl>
      <dl>
         <dt><label for="forum_link_track">{L_FORUM_LINK_TRACK}:</label><br /><span>{L_FORUM_LINK_TRACK_EXPLAIN}</span></dt>
         <dd><label><input type="radio" class="radio" name="forum_link_track" value="1"<!-- IF S_FORUM_LINK_TRACK --> id="forum_link_track" checked="checked"<!-- ENDIF --> /> {L_YES}</label>
            <label><input type="radio" class="radio" name="forum_link_track" value="0"<!-- IF not S_FORUM_LINK_TRACK --> id="forum_link_track" checked="checked"<!-- ENDIF --> /> {L_NO}</label></dd>
      </dl>
      </fieldset>
   </div>

   <div id="forum_rules_options">
      <fieldset>
         <legend>{L_FORUM_RULES}</legend>
      <dl>
         <dt><label for="forum_rules_link">{L_FORUM_RULES_LINK}:</label><br /><span>{L_FORUM_RULES_LINK_EXPLAIN}</span></dt>
         <dd><input class="text medium" type="text" id="forum_rules_link" name="forum_rules_link" value="{FORUM_RULES_LINK}" maxlength="255" /></dd>
      </dl>
   <!-- IF FORUM_RULES_PREVIEW -->
      <dl>
         <dt><label>{L_FORUM_RULES_PREVIEW}:</label></dt>
         <dd>{FORUM_RULES_PREVIEW}</dd>
      </dl>
   <!-- ENDIF -->
      <dl>
         <dt><label for="forum_rules">{L_FORUM_RULES}:</label><br /><span>{L_FORUM_RULES_EXPLAIN}</span></dt>
         <dd><textarea id="forum_rules" name="forum_rules" rows="4" cols="70">{FORUM_RULES_PLAIN}</textarea></dd>
         <dd><label><input type="checkbox" class="radio" name="rules_parse_bbcode"<!-- IF S_BBCODE_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_BBCODE}</label>
            <label><input type="checkbox" class="radio" name="rules_parse_smilies"<!-- IF S_SMILIES_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_SMILIES}</label>
            <label><input type="checkbox" class="radio" name="rules_parse_urls"<!-- IF S_URLS_CHECKED --> checked="checked"<!-- ENDIF --> /> {L_PARSE_URLS}</label></dd>
      </dl>
      </fieldset>
   </div>


   <!-- INCLUDE acp_forum_sponsor.html -->


   <fieldset class="submit-buttons">
      <legend>{L_SUBMIT}</legend>
      <input class="button1" type="submit" id="submit" name="update" value="{L_SUBMIT}" />&nbsp;
      <input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />
      {S_FORM_TOKEN}
   </fieldset>
   </form>

<!-- ELSEIF S_DELETE_FORUM -->

   <a href="{U_BACK}" style="float: {S_CONTENT_FLOW_END};">&laquo; {L_BACK}</a>

   <h1>{L_FORUM_DELETE}</h1>

   <p>{L_FORUM_DELETE_EXPLAIN}</p>

   <!-- IF S_ERROR -->
      <div class="errorbox">
         <h3>{L_WARNING}</h3>
         <p>{ERROR_MSG}</p>
      </div>
   <!-- ENDIF -->

   <form id="acp_forum" method="post" action="{U_ACTION}">

   <fieldset>
      <legend>{L_FORUM_DELETE}</legend>
   <dl>
      <dt><label>{L_FORUM_NAME}:</label></dt>
      <dd><strong>{FORUM_NAME}</strong></dd>
   </dl>
   <!-- IF S_FORUM_POST -->
      <dl>
         <dt><label for="delete_action">{L_ACTION}:</label></dt>
         <dd><label><input type="radio" class="radio" id="delete_action" name="action_posts" value="delete" checked="checked" /> {L_DELETE_ALL_POSTS}</label></dd>
         <!-- IF S_MOVE_FORUM_OPTIONS -->
            <dd><label><input type="radio" class="radio" name="action_posts" value="move" /> {L_MOVE_POSTS_TO}</label> <select name="posts_to_id">{S_MOVE_FORUM_OPTIONS}</select></dd>
         <!-- ENDIF -->
      </dl>
   <!-- ENDIF -->
   <!-- IF S_HAS_SUBFORUMS -->
      <dl>
         <dt><label for="sub_delete_action">{L_ACTION}:</label></dt>
         <dd><label><input type="radio" class="radio" id="sub_delete_action" name="action_subforums" value="delete" checked="checked" /> {L_DELETE_SUBFORUMS}</label></dd>
         <!-- IF S_FORUMS_LIST -->
            <dd><label><input type="radio" class="radio" name="action_subforums" value="move" /> {L_MOVE_SUBFORUMS_TO}</label> <select name="subforums_to_id">{S_FORUMS_LIST}</select></dd>
         <!-- ENDIF -->
      </dl>
   <!-- ENDIF -->

   <p class="quick">
      <input class="button1" type="submit" name="update" value="{L_SUBMIT}" />
   </p>
   {S_FORM_TOKEN}
   </fieldset>
   </form>

<!-- ELSEIF S_CONTINUE_SYNC -->

   <script type="text/javascript">
   // <![CDATA[
      var close_waitscreen = 0;
      // no scrollbars...
      popup('{UA_PROGRESS_BAR}', 400, 240, '_sync');
   // ]]>
   </script>

   <h1>{L_FORUM_ADMIN}</h1>

   <p>{L_FORUM_ADMIN_EXPLAIN}</p>

   <p>{L_PROGRESS_EXPLAIN}</p>

<!-- ELSE -->

   <script type="text/javascript">
   // <![CDATA[
      /**
      * Popup search progress bar
      */
      function popup_progress_bar()
      {
         var close_waitscreen = 0;
         // no scrollbars...
         popup('{UA_PROGRESS_BAR}', 400, 240, '_sync');
      }
   // ]]>
   </script>

   <h1>{L_FORUM_ADMIN}</h1>

   <p>{L_FORUM_ADMIN_EXPLAIN}</p>

   <!-- IF ERROR_MSG -->
      <div class="errorbox">
         <h3>{L_WARNING}</h3>
         <p>{ERROR_MSG}</p>
      </div>
   <!-- ENDIF -->

   <!-- IF S_RESYNCED -->
      <script type="text/javascript">
      // <![CDATA[
         var close_waitscreen = 1;
      // ]]>
      </script>

      <div class="successbox">
         <h3>{L_NOTIFY}</h3>
         <p>{L_FORUM_RESYNCED}</p>
      </div>
   <!-- ENDIF -->

   <p><strong>{NAVIGATION}<!-- IF S_NO_FORUMS --> [<a href="{U_EDIT}">{L_EDIT}</a> | <a href="{U_DELETE}">{L_DELETE}</a><!-- IF not S_LINK --> | <a href="{U_SYNC}">{L_RESYNC}</a><!-- ENDIF --->]<!-- ENDIF --></strong></p>

   <!-- IF .forums -->
      <table cellspacing="1">
         <col class="row1" /><col class="row1" /><col class="row2" />
      <tbody>
      <!-- BEGIN forums -->
         <tr>
            <td style="width: 5%; text-align: center;">{forums.FOLDER_IMAGE}</td>
            <td>
               <!-- IF forums.FORUM_IMAGE --><div style="float: {S_CONTENT_FLOW_BEGIN}; margin-right: 5px;">{forums.FORUM_IMAGE}</div><!-- ENDIF -->
               <strong><!-- IF forums.S_FORUM_LINK -->{forums.FORUM_NAME}<!-- ELSE --><a href="{forums.U_FORUM}">{forums.FORUM_NAME}</a><!-- ENDIF --></strong>
               <!-- IF forums.FORUM_DESCRIPTION --><br /><span>{forums.FORUM_DESCRIPTION}</span><!-- ENDIF -->
               <!-- IF forums.S_FORUM_POST --><br /><br /><span>{L_TOPICS}: <strong>{forums.FORUM_TOPICS}</strong> / {L_POSTS}: <b>{forums.FORUM_POSTS}</b></span><!-- ENDIF -->
            </td>
            <td style="vertical-align: top; width: 100px; text-align: right; white-space: nowrap;">
               <!-- IF forums.S_FIRST_ROW && not forums.S_LAST_ROW -->
                  {ICON_MOVE_UP_DISABLED}
                  <a href="{forums.U_MOVE_DOWN}">{ICON_MOVE_DOWN}</a>
               <!-- ELSEIF not forums.S_FIRST_ROW && not forums.S_LAST_ROW -->
                  <a href="{forums.U_MOVE_UP}">{ICON_MOVE_UP}</a>
                  <a href="{forums.U_MOVE_DOWN}">{ICON_MOVE_DOWN}</a>
               <!-- ELSEIF forums.S_LAST_ROW && not forums.S_FIRST_ROW -->
                  <a href="{forums.U_MOVE_UP}">{ICON_MOVE_UP}</a>
                  {ICON_MOVE_DOWN_DISABLED}
               <!-- ELSE -->
                  {ICON_MOVE_UP_DISABLED}
                  {ICON_MOVE_DOWN_DISABLED}
               <!-- ENDIF -->
               <a href="{forums.U_EDIT}">{ICON_EDIT}</a>
               <!-- IF not forums.S_FORUM_LINK -->
                  <a href="{forums.U_SYNC}" onclick="popup_progress_bar();">{ICON_SYNC}</a>
               <!-- ELSE -->
                  {ICON_SYNC_DISABLED}
               <!-- ENDIF -->
               <a href="{forums.U_DELETE}">{ICON_DELETE}</a>
            </td>
         </tr>
      <!-- END forums -->
      </tbody>
      </table>
   <!-- ENDIF -->

   <form id="fselect" method="post" action="{U_SEL_ACTION}">

   <fieldset class="quick">
      {L_SELECT_FORUM}: <select name="parent_id" onchange="if(this.options[this.selectedIndex].value != -1){ this.form.submit(); }">{FORUM_BOX}</select>

      <input class="button2" type="submit" value="{L_GO}" />
      {S_FORM_TOKEN}
   </fieldset>
   </form>

   <form id="forums" method="post" action="{U_ACTION}">

   <fieldset class="quick">
      <input type="hidden" name="action" value="add" />

      <input type="text" name="forum_name" value="" maxlength="255" />
      <input class="button2" name="addforum" type="submit" value="{L_CREATE_FORUM}" />
      {S_FORM_TOKEN}
   </fieldset>
   </form>

<!-- ENDIF -->

<!-- INCLUDE overall_footer.html -->

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 18:14

And here is my adm/style/acp_main:

Code: Alles auswählen

<!-- INCLUDE overall_header.html -->

<a name="maincontent"></a>

<!-- IF S_RESTORE_PERMISSIONS -->

   <h1>{L_PERMISSIONS_TRANSFERRED}</h1>

   <p>{L_PERMISSIONS_TRANSFERRED_EXPLAIN}</p>

<!-- ELSE -->

   <h1>{L_WELCOME_PHPBB}</h1>

   <p>{L_ADMIN_INTRO}</p>

   <!-- IF S_REMOVE_INSTALL -->
      <div class="errorbox">
         <h3>{L_WARNING}</h3>
         <p>{L_REMOVE_INSTALL}</p>
      </div>
   <!-- ENDIF -->

   <!-- IF S_WRITABLE_CONFIG -->
      <div class="errorbox notice">
         <p>{L_WRITABLE_CONFIG}</p>
      </div>
   <!-- ENDIF -->

   <table cellspacing="1">
      <caption>{L_FORUM_STATS}</caption>
      <col class="col1" /><col class="col2" /><col class="col1" /><col class="col2" />
   <thead>
   <tr>
      <th>{L_STATISTIC}</th>
      <th>{L_VALUE}</th>
      <th>{L_STATISTIC}</th>
      <th>{L_VALUE}</th>
   </tr>
   </thead>
   <tbody>
   <tr>
      <td>{L_NUMBER_POSTS}: </td>
      <td><strong>{TOTAL_POSTS}</strong></td>
      <td>{L_POSTS_PER_DAY}: </td>
      <td><strong>{POSTS_PER_DAY}</strong></td>
   </tr>
   <tr>
      <td>{L_NUMBER_TOPICS}: </td>
      <td><strong>{TOTAL_TOPICS}</strong></td>
      <td>{L_TOPICS_PER_DAY}: </td>
      <td><strong>{TOPICS_PER_DAY}</strong></td>
   </tr>
   <tr>
      <td>{L_NUMBER_USERS}: </td>
      <td><strong>{TOTAL_USERS}</strong></td>
      <td>{L_USERS_PER_DAY}: </td>
      <td><strong>{USERS_PER_DAY}</strong></td>
   </tr>
   <tr>
      <td>{L_NUMBER_FILES}: </td>
      <td><strong>{TOTAL_FILES}</strong></td>
      <td>{L_FILES_PER_DAY}: </td>
      <td><strong>{FILES_PER_DAY}</strong></td>
   </tr>


   <tr>
      <td>{L_BOARD_STARTED}: </td>
      <td><strong>{START_DATE}</strong></td>
      <td>{L_AVATAR_DIR_SIZE}: </td>
      <td><strong>{AVATAR_DIR_SIZE}</strong></td>
   </tr>
   <tr>
      <td>{L_DATABASE_SIZE}: </td>
      <td><strong>{DBSIZE}</strong></td>
      <td>{L_UPLOAD_DIR_SIZE}: </td>
      <td><strong>{UPLOAD_DIR_SIZE}</strong></td>
   </tr>
   <tr>
      <td>{L_DATABASE_SERVER_INFO}: </td>
      <td><strong>{DATABASE_INFO}</strong></td>
      <td>{L_GZIP_COMPRESSION}: </td>
      <td><strong>{GZIP_COMPRESSION}</strong></td>
   </tr>
   <tr>
      <td>{L_BOARD_VERSION}: </td>
      <td><strong>{BOARD_VERSION}</strong></td>
   <!-- IF S_TOTAL_ORPHAN -->
      <td>{L_NUMBER_ORPHAN}: </td>
      <td><strong>{TOTAL_ORPHAN}</strong></td>
   <!-- ELSE -->
      <td>&nbsp;</td>
      <td>&nbsp;</td>
   <!-- ENDIF -->
   </tr>
   </tbody>
   </table>

   <!-- IF S_ACTION_OPTIONS -->
      <fieldset>
         <legend>{L_STATISTIC_RESYNC_OPTIONS}</legend>

         <form id="action_online_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_online">{L_RESET_ONLINE}</label><br /><span>&nbsp;</span></dt>
               <dd><input type="hidden" name="action" value="online" /><input class="button2" type="submit" id="action_online" name="action_online" value="{L_RUN}" /></dd>
            </dl>
         </form>

         <form id="action_date_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_date">{L_RESET_DATE}</label><br /><span>&nbsp;</span></dt>
               <dd><input type="hidden" name="action" value="date" /><input class="button2" type="submit" id="action_date" name="action_date" value="{L_RUN}" /></dd>
            </dl>
         </form>

         <form id="action_stats_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_stats">{L_RESYNC_STATS}</label><br /><span>{L_RESYNC_STATS_EXPLAIN}</span></dt>
               <dd><input type="hidden" name="action" value="stats" /><input class="button2" type="submit" id="action_stats" name="action_stats" value="{L_RUN}" /></dd>
            </dl>
         </form>

[b]         <form id="action_user_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_user">{L_RESYNC_POSTCOUNTS}</label><br /><span>{L_RESYNC_POSTCOUNTS_EXPLAIN}</span></dt>
               <dd><input type="hidden" name="action" value="user" /><input class="button2" type="submit" id="action_user" name="action_user" value="{L_RUN}" /></dd>
            </dl>
         </form>

<form id="action_thanks_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_user">{L_RESYNC_THANKSCOUNTS}</label><br /><span>{L_RESYNC_THANKSCOUNTS_EXPLAIN}</span></dt>
               <dd><input type="hidden" name="action" value="thanks" /><input class="button2" type="submit" id="action_thanks" name="action_user" value="{L_RUN}" /></dd>
            </dl>
         </form>[/b]

         <form id="action_db_track_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_db_track">{L_RESYNC_POST_MARKING}</label><br /><span>{L_RESYNC_POST_MARKING_EXPLAIN}</span></dt>
               <dd><input type="hidden" name="action" value="db_track" /><input class="button2" type="submit" id="action_db_track" name="action_db_track" value="{L_RUN}" /></dd>
            </dl>
         </form>

         <!-- IF S_FOUNDER -->
         <form id="action_purge_cache_form" method="post" action="{U_ACTION}">
            <dl>
               <dt><label for="action_purge_cache">{L_PURGE_CACHE}</label><br /><span>{L_PURGE_CACHE_EXPLAIN}</span></dt>
               <dd><input type="hidden" name="action" value="purge_cache" /><input class="button2" type="submit" id="action_purge_cache" name="action_purge_cache" value="{L_RUN}" /></dd>
            </dl>
         </form>
         <!-- ENDIF -->
        </fieldset>
   <!-- ENDIF -->

   <!-- IF .log -->
      <h2>{L_ADMIN_LOG}</h2>

      <p>{L_ADMIN_LOG_INDEX_EXPLAIN}</p>

      <div style="text-align: right;"><a href="{U_ADMIN_LOG}">&raquo; {L_VIEW_ADMIN_LOG}</a></div>

      <table cellspacing="1">
      <thead>
      <tr>
         <th>{L_USERNAME}</th>
         <th>{L_IP}</th>
         <th>{L_TIME}</th>
         <th>{L_ACTION}</th>
      </tr>
      </thead>
      <tbody>
      <!-- BEGIN log -->
         <!-- IF log.S_ROW_COUNT is even --><tr class="row1"><!-- ELSE --><tr class="row2"><!-- ENDIF -->

            <td>{log.USERNAME}</td>
            <td style="text-align: center;">{log.IP}</td>
            <td style="text-align: center;">{log.DATE}</td>
            <td>{log.ACTION}</td>
         </tr>
      <!-- END log -->
      </tbody>
      </table>

      <br />

   <!-- ENDIF -->

   <!-- IF S_INACTIVE_USERS -->
      <h2>{L_INACTIVE_USERS}</h2>

      <p>{L_INACTIVE_USERS_EXPLAIN_INDEX}</p>

      <div style="text-align: right;"><a href="{U_INACTIVE_USERS}">&raquo; {L_VIEW_INACTIVE_USERS}</a></div>

      <table cellspacing="1">
      <thead>
      <tr>
         <th>{L_USERNAME}</th>
         <th>{L_JOINED}</th>
         <th>{L_INACTIVE_DATE}</th>
         <th>{L_INACTIVE_REASON}</th>
         <th>{L_LAST_VISIT}</th>
      </tr>
      </thead>
      <tbody>
      <!-- BEGIN inactive -->
         <!-- IF inactive.S_ROW_COUNT is even --><tr class="row1"><!-- ELSE --><tr class="row2"><!-- ENDIF -->

            <td><a href="{inactive.U_USER_ADMIN}">{inactive.USERNAME}</a></td>
            <td>{inactive.JOINED}</td>
            <td>{inactive.INACTIVE_DATE}</td>
            <td>{inactive.REASON}</td>
            <td>{inactive.LAST_VISIT}</td>
         </tr>
      <!-- BEGINELSE -->
         <tr>
            <td colspan="5" style="text-align: center;">{L_NO_INACTIVE_USERS}</td>
         </tr>
      <!-- END inactive -->
      </tbody>
      </table>

   <!-- ENDIF -->

<!-- ENDIF -->

<!-- INCLUDE overall_footer.html -->

Benutzeravatar
Mahony
Site Admin
Site Admin
Beiträge: 749
Registriert: 3. Dez 2006 22:09
Hat sich bedankt: 1 Mal
Danksagung erhalten: 4 Mal

Re: Thank Post Mod

Beitragvon Mahony » 26. Jan 2009 18:34

Hello
The files are correct. Check the includes/acp/acp_forums.php.

Best regards: Mahony
Diejenigen, die lautstark darüber diskutieren, warum es nicht geht, mögen bitte jene nicht stören, die es gerade tun.
Klug ist, wer nur die Hälfte von dem glaubt, was er hört. Weise ist, wer erkennt, welche Hälfte richtig ist.

Bild

Benutzeravatar
Texas
Beiträge: 14
Registriert: 25. Jan 2009 17:43

Re: Thank Post Mod

Beitragvon Texas » 26. Jan 2009 18:39

Code: Alles auswählen

<?php
/**
*
* @package acp
* @version $Id: acp_forums.php 8898 2008-09-19 17:07:13Z acydburn $
* @copyright (c) 2005 phpBB Group
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
*
*/

/**
* @ignore
*/
if (!defined('IN_PHPBB'))
{
   exit;
}

/**
* @package acp
*/
class acp_forums
{
   var $u_action;
   var $parent_id = 0;

   function main($id, $mode)
   {
      global $db, $user, $auth, $template, $cache;
      global $config, $phpbb_admin_path, $phpbb_root_path, $phpEx;

      $user->add_lang('acp/forums');
      $this->tpl_name = 'acp_forums';
      $this->page_title = 'ACP_MANAGE_FORUMS';

      $form_key = 'acp_forums';
      add_form_key($form_key);

      $action      = request_var('action', '');
      $update      = (isset($_POST['update'])) ? true : false;
      $forum_id   = request_var('f', 0);

      $this->parent_id   = request_var('parent_id', 0);
      $forum_data = $errors = array();
      if ($update && !check_form_key($form_key))
      {
         $update = false;
         $errors[] = $user->lang['FORM_INVALID'];
      }

      // Check additional permissions
      switch ($action)
      {
         case 'progress_bar':
            $start = request_var('start', 0);
            $total = request_var('total', 0);

            $this->display_progress_bar($start, $total);
            exit;
         break;

         case 'delete':

            if (!$auth->acl_get('a_forumdel'))
            {
               trigger_error($user->lang['NO_PERMISSION_FORUM_DELETE'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

         break;

         case 'add':

            if (!$auth->acl_get('a_forumadd'))
            {
               trigger_error($user->lang['NO_PERMISSION_FORUM_ADD'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

         break;
      }

      // Start Forum Sponsor
      $user->add_lang('mods/forum_sponsor');

      if ($action == 'edit')
      {
         $fs_data = $this->get_forum_info($forum_id);

         if (!$fs_data['forum_sponsor_html'])
         {
            decode_message($fs_data['forum_sponsor'], $fs_data['forum_sponsor_uid']);
            $fs_data['allow_bbcode'] = ($fs_data['forum_sponsor_options'] & OPTION_FLAG_BBCODE) ? true : false;
            $fs_data['allow_smilies'] = ($fs_data['forum_sponsor_options'] & OPTION_FLAG_SMILIES) ? true : false;
            $fs_data['allow_urls'] = ($fs_data['forum_sponsor_options'] & OPTION_FLAG_LINKS) ? true : false;
         }
         else
         {
            $fs_data['allow_bbcode'] = $fs_data['allow_smilies'] = $fs_data['allow_urls'] = false;
         }

         $template->assign_vars(array(
            'FORUM_SPONSOR'            => $fs_data['forum_sponsor'],
            'S_SPONSOR_HTML_CHECKED'   => $fs_data['forum_sponsor_html'],
            'S_SPONSOR_BBCODE_CHECKED'   => $fs_data['allow_bbcode'],
            'S_SPONSOR_SMILIES_CHECKED'   => $fs_data['allow_smilies'],
            'S_SPONSOR_URLS_CHECKED'   => $fs_data['allow_urls'],
         ));

         unset($fs_data);
      }
      else if ($action == 'add')
      {
         $template->assign_vars(array(
            'S_SPONSOR_BBCODE_CHECKED'   => true,
            'S_SPONSOR_SMILIES_CHECKED'   => true,
            'S_SPONSOR_URLS_CHECKED'   => true,
         ));
      }
      // End Forum Sponsor

      // Major routines
      if ($update)
      {
         switch ($action)
         {
            case 'delete':
               $action_subforums   = request_var('action_subforums', '');
               $subforums_to_id   = request_var('subforums_to_id', 0);
               $action_posts      = request_var('action_posts', '');
               $posts_to_id      = request_var('posts_to_id', 0);

               $errors = $this->delete_forum($forum_id, $action_posts, $action_subforums, $posts_to_id, $subforums_to_id);

               if (sizeof($errors))
               {
                  break;
               }

               $auth->acl_clear_prefetch();
               $cache->destroy('sql', FORUMS_TABLE);

               trigger_error($user->lang['FORUM_DELETED'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id));

            break;

            case 'edit':
               $forum_data = array(
                  'forum_id'      =>   $forum_id
               );

            // No break here

            case 'add':

               // Start Forum Sponsor
               $forum_data += array(
                  'forum_sponsor'            => utf8_normalize_nfc(request_var('forum_sponsor', '', true)),
                  'forum_sponsor_uid'         => '',
                  'forum_sponsor_options'      => 7,
                  'forum_sponsor_bitfield'   => '',
                  'forum_sponsor_html'      => request_var('sponsor_parse_html', false),
               );

               if ($forum_data['forum_sponsor'])
               {
                  if ($forum_data['forum_sponsor_html'])
                  {
                     $forum_data['forum_sponsor'] = htmlspecialchars_decode($forum_data['forum_sponsor']);
                     $forum_data['forum_sponsor_options'] = 0;
                  }
                  else
                  {
                     generate_text_for_storage($forum_data['forum_sponsor'], $forum_data['forum_sponsor_uid'], $forum_data['forum_sponsor_bitfield'], $forum_data['forum_sponsor_options'], request_var('sponsor_parse_bbcode', false), request_var('sponsor_parse_urls', false), request_var('sponsor_parse_smilies', false));
                  }
               }
               // End Forum Sponsor

               $forum_data += array(
                  'parent_id'            => request_var('forum_parent_id', $this->parent_id),
                  'forum_type'         => request_var('forum_type', FORUM_POST),
                  'type_action'         => request_var('type_action', ''),
                  'forum_status'         => request_var('forum_status', ITEM_UNLOCKED),
                  'forum_parents'         => '',
                  'forum_name'         => utf8_normalize_nfc(request_var('forum_name', '', true)),
                  'forum_link'         => request_var('forum_link', ''),
                  'forum_link_track'      => request_var('forum_link_track', false),
                  'forum_desc'         => utf8_normalize_nfc(request_var('forum_desc', '', true)),
                  'forum_desc_uid'      => '',
                  'forum_desc_options'   => 7,
                  'forum_desc_bitfield'   => '',
                  'forum_rules'         => utf8_normalize_nfc(request_var('forum_rules', '', true)),
                  'forum_rules_uid'      => '',
                  'forum_rules_options'   => 7,
                  'forum_rules_bitfield'   => '',
                  'forum_rules_link'      => request_var('forum_rules_link', ''),
                  'forum_image'         => request_var('forum_image', ''),
                  'forum_style'         => request_var('forum_style', 0),
                  'display_subforum_list'   => request_var('display_subforum_list', false),
                  'display_on_index'      => request_var('display_on_index', false),
                  'forum_topics_per_page'   => request_var('topics_per_page', 0),
                  'enable_indexing'      => request_var('enable_indexing', true),
                  'enable_icons'         => request_var('enable_icons', false),
                  'enable_prune'         => request_var('enable_prune', false),
//Begin Thank Post MOD
                  'enable_thanks'         => request_var('enable_thanks', false),
                  //End Thank Post MOD
                                                //Support Ticket System MOD Beginn
                  'enable_sts'         => request_var('enable_sts', false),
                  //Support Ticket System MOD End
                  'enable_post_review'   => request_var('enable_post_review', true),
                  'prune_days'         => request_var('prune_days', 7),
                  'prune_viewed'         => request_var('prune_viewed', 7),
                  'prune_freq'         => request_var('prune_freq', 1),
                  'prune_old_polls'      => request_var('prune_old_polls', false),
                  'prune_announce'      => request_var('prune_announce', false),
                  'prune_sticky'         => request_var('prune_sticky', false),
                  'forum_password'      => request_var('forum_password', '', true),
                  'forum_password_confirm'=> request_var('forum_password_confirm', '', true),
                  'forum_password_unset'   => request_var('forum_password_unset', false),
               );

               // Use link_display_on_index setting if forum type is link
               if ($forum_data['forum_type'] == FORUM_LINK)
               {
                  $forum_data['display_on_index'] = request_var('link_display_on_index', false);
               }

               // Linked forums and categories are not able to be locked...
               if ($forum_data['forum_type'] == FORUM_LINK || $forum_data['forum_type'] == FORUM_CAT)
               {
                  $forum_data['forum_status'] = ITEM_UNLOCKED;
               }

               $forum_data['show_active'] = ($forum_data['forum_type'] == FORUM_POST) ? request_var('display_recent', false) : request_var('display_active', false);

               // Get data for forum rules if specified...
               if ($forum_data['forum_rules'])
               {
                  generate_text_for_storage($forum_data['forum_rules'], $forum_data['forum_rules_uid'], $forum_data['forum_rules_bitfield'], $forum_data['forum_rules_options'], request_var('rules_parse_bbcode', false), request_var('rules_parse_urls', false), request_var('rules_parse_smilies', false));
               }

               // Get data for forum description if specified
               if ($forum_data['forum_desc'])
               {
                  generate_text_for_storage($forum_data['forum_desc'], $forum_data['forum_desc_uid'], $forum_data['forum_desc_bitfield'], $forum_data['forum_desc_options'], request_var('desc_parse_bbcode', false), request_var('desc_parse_urls', false), request_var('desc_parse_smilies', false));
               }

               $errors = $this->update_forum_data($forum_data);

               if (!sizeof($errors))
               {
                  $forum_perm_from = request_var('forum_perm_from', 0);

                  // Copy permissions?
                  if ($forum_perm_from && !empty($forum_perm_from) && $forum_perm_from != $forum_data['forum_id'] &&
                     (($action != 'edit') || empty($forum_id) || ($auth->acl_get('a_fauth') && $auth->acl_get('a_authusers') && $auth->acl_get('a_authgroups') && $auth->acl_get('a_mauth'))))
                  {
                     // if we edit a forum delete current permissions first
                     if ($action == 'edit')
                     {
                        $sql = 'DELETE FROM ' . ACL_USERS_TABLE . '
                           WHERE forum_id = ' . (int) $forum_data['forum_id'];
                        $db->sql_query($sql);

                        $sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . '
                           WHERE forum_id = ' . (int) $forum_data['forum_id'];
                        $db->sql_query($sql);
                     }

                     // From the mysql documentation:
                     // Prior to MySQL 4.0.14, the target table of the INSERT statement cannot appear in the FROM clause of the SELECT part of the query. This limitation is lifted in 4.0.14.
                     // Due to this we stay on the safe side if we do the insertion "the manual way"

                     // Copy permisisons from/to the acl users table (only forum_id gets changed)
                     $sql = 'SELECT user_id, auth_option_id, auth_role_id, auth_setting
                        FROM ' . ACL_USERS_TABLE . '
                        WHERE forum_id = ' . $forum_perm_from;
                     $result = $db->sql_query($sql);

                     $users_sql_ary = array();
                     while ($row = $db->sql_fetchrow($result))
                     {
                        $users_sql_ary[] = array(
                           'user_id'         => (int) $row['user_id'],
                           'forum_id'         => (int) $forum_data['forum_id'],
                           'auth_option_id'   => (int) $row['auth_option_id'],
                           'auth_role_id'      => (int) $row['auth_role_id'],
                           'auth_setting'      => (int) $row['auth_setting']
                        );
                     }
                     $db->sql_freeresult($result);

                     // Copy permisisons from/to the acl groups table (only forum_id gets changed)
                     $sql = 'SELECT group_id, auth_option_id, auth_role_id, auth_setting
                        FROM ' . ACL_GROUPS_TABLE . '
                        WHERE forum_id = ' . $forum_perm_from;
                     $result = $db->sql_query($sql);

                     $groups_sql_ary = array();
                     while ($row = $db->sql_fetchrow($result))
                     {
                        $groups_sql_ary[] = array(
                           'group_id'         => (int) $row['group_id'],
                           'forum_id'         => (int) $forum_data['forum_id'],
                           'auth_option_id'   => (int) $row['auth_option_id'],
                           'auth_role_id'      => (int) $row['auth_role_id'],
                           'auth_setting'      => (int) $row['auth_setting']
                        );
                     }
                     $db->sql_freeresult($result);

                     // Now insert the data
                     $db->sql_multi_insert(ACL_USERS_TABLE, $users_sql_ary);
                     $db->sql_multi_insert(ACL_GROUPS_TABLE, $groups_sql_ary);
                     cache_moderators();
                  }

                  $auth->acl_clear_prefetch();
                  $cache->destroy('sql', FORUMS_TABLE);

                  $acl_url = '&amp;mode=setting_forum_local&amp;forum_id[]=' . $forum_data['forum_id'];

                  $message = ($action == 'add') ? $user->lang['FORUM_CREATED'] : $user->lang['FORUM_UPDATED'];

                  // Redirect to permissions
                  if ($auth->acl_get('a_fauth'))
                  {
                     $message .= '<br /><br />' . sprintf($user->lang['REDIRECT_ACL'], '<a href="' . append_sid("{$phpbb_admin_path}index.$phpEx", 'i=permissions' . $acl_url) . '">', '</a>');
                  }

                  // redirect directly to permission settings screen if authed
                  if ($action == 'add' && !$forum_perm_from && $auth->acl_get('a_fauth'))
                  {
                     meta_refresh(4, append_sid("{$phpbb_admin_path}index.$phpEx", 'i=permissions' . $acl_url));
                  }

                  trigger_error($message . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id));
               }

            break;
         }
      }

      switch ($action)
      {
         case 'move_up':
         case 'move_down':

            if (!$forum_id)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            $sql = 'SELECT *
               FROM ' . FORUMS_TABLE . "
               WHERE forum_id = $forum_id";
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            $move_forum_name = $this->move_forum_by($row, $action, 1);

            if ($move_forum_name !== false)
            {
               add_log('admin', 'LOG_FORUM_' . strtoupper($action), $row['forum_name'], $move_forum_name);
               $cache->destroy('sql', FORUMS_TABLE);
            }

         break;

         case 'sync':
            if (!$forum_id)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            @set_time_limit(0);

            $sql = 'SELECT forum_name, forum_topics_real
               FROM ' . FORUMS_TABLE . "
               WHERE forum_id = $forum_id";
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            if ($row['forum_topics_real'])
            {
               $sql = 'SELECT MIN(topic_id) as min_topic_id, MAX(topic_id) as max_topic_id
                  FROM ' . TOPICS_TABLE . '
                  WHERE forum_id = ' . $forum_id;
               $result = $db->sql_query($sql);
               $row2 = $db->sql_fetchrow($result);
               $db->sql_freeresult($result);

               // Typecast to int if there is no data available
               $row2['min_topic_id'] = (int) $row2['min_topic_id'];
               $row2['max_topic_id'] = (int) $row2['max_topic_id'];

               $start = request_var('start', $row2['min_topic_id']);

               $batch_size = 2000;
               $end = $start + $batch_size;

               // Sync all topics in batch mode...
               sync('topic_approved', 'range', 'topic_id BETWEEN ' . $start . ' AND ' . $end, true, false);
               sync('topic', 'range', 'topic_id BETWEEN ' . $start . ' AND ' . $end, true, true);

               if ($end < $row2['max_topic_id'])
               {
                  // We really need to find a way of showing statistics... no progress here
                  $sql = 'SELECT COUNT(topic_id) as num_topics
                     FROM ' . TOPICS_TABLE . '
                     WHERE forum_id = ' . $forum_id . '
                        AND topic_id BETWEEN ' . $start . ' AND ' . $end;
                  $result = $db->sql_query($sql);
                  $topics_done = request_var('topics_done', 0) + (int) $db->sql_fetchfield('num_topics');
                  $db->sql_freeresult($result);

                  $start += $batch_size;

                  $url = $this->u_action . "&amp;parent_id={$this->parent_id}&amp;f=$forum_id&amp;action=sync&amp;start=$start&amp;topics_done=$topics_done&amp;total={$row['forum_topics_real']}";

                  meta_refresh(0, $url);

                  $template->assign_vars(array(
                     'U_PROGRESS_BAR'      => $this->u_action . "&amp;action=progress_bar&amp;start=$topics_done&amp;total={$row['forum_topics_real']}",
                     'UA_PROGRESS_BAR'      => addslashes($this->u_action . "&amp;action=progress_bar&amp;start=$topics_done&amp;total={$row['forum_topics_real']}"),
                     'S_CONTINUE_SYNC'      => true,
                     'L_PROGRESS_EXPLAIN'   => sprintf($user->lang['SYNC_IN_PROGRESS_EXPLAIN'], $topics_done, $row['forum_topics_real']))
                  );

                  return;
               }
            }

            $url = $this->u_action . "&amp;parent_id={$this->parent_id}&amp;f=$forum_id&amp;action=sync_forum";
            meta_refresh(0, $url);

            $template->assign_vars(array(
               'U_PROGRESS_BAR'      => $this->u_action . '&amp;action=progress_bar',
               'UA_PROGRESS_BAR'      => addslashes($this->u_action . '&amp;action=progress_bar'),
               'S_CONTINUE_SYNC'      => true,
               'L_PROGRESS_EXPLAIN'   => sprintf($user->lang['SYNC_IN_PROGRESS_EXPLAIN'], 0, $row['forum_topics_real']))
            );

            return;

         break;

         case 'sync_forum':

            $sql = 'SELECT forum_name, forum_type
               FROM ' . FORUMS_TABLE . "
               WHERE forum_id = $forum_id";
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            sync('forum', 'forum_id', $forum_id, false, true);

            add_log('admin', 'LOG_FORUM_SYNC', $row['forum_name']);
            $cache->destroy('sql', FORUMS_TABLE);

            $template->assign_var('L_FORUM_RESYNCED', sprintf($user->lang['FORUM_RESYNCED'], $row['forum_name']));

         break;

         case 'add':
         case 'edit':

            if ($update)
            {
               $forum_data['forum_flags'] = 0;
               $forum_data['forum_flags'] += (request_var('forum_link_track', false)) ? FORUM_FLAG_LINK_TRACK : 0;
               $forum_data['forum_flags'] += (request_var('prune_old_polls', false)) ? FORUM_FLAG_PRUNE_POLL : 0;
               $forum_data['forum_flags'] += (request_var('prune_announce', false)) ? FORUM_FLAG_PRUNE_ANNOUNCE : 0;
               $forum_data['forum_flags'] += (request_var('prune_sticky', false)) ? FORUM_FLAG_PRUNE_STICKY : 0;
               $forum_data['forum_flags'] += ($forum_data['show_active']) ? FORUM_FLAG_ACTIVE_TOPICS : 0;
               $forum_data['forum_flags'] += (request_var('enable_post_review', true)) ? FORUM_FLAG_POST_REVIEW : 0;
            }

            // Show form to create/modify a forum
            if ($action == 'edit')
            {
               $this->page_title = 'EDIT_FORUM';
               $row = $this->get_forum_info($forum_id);
               $old_forum_type = $row['forum_type'];

               if (!$update)
               {
                  $forum_data = $row;
               }
               else
               {
                  $forum_data['left_id'] = $row['left_id'];
                  $forum_data['right_id'] = $row['right_id'];
               }

               // Make sure no direct child forums are able to be selected as parents.
               $exclude_forums = array();
               foreach (get_forum_branch($forum_id, 'children') as $row)
               {
                  $exclude_forums[] = $row['forum_id'];
               }

               $parents_list = make_forum_select($forum_data['parent_id'], $exclude_forums, false, false, false);

               $forum_data['forum_password_confirm'] = $forum_data['forum_password'];
            }
            else
            {
               $this->page_title = 'CREATE_FORUM';

               $forum_id = $this->parent_id;
               $parents_list = make_forum_select($this->parent_id, false, false, false, false);

               // Fill forum data with default values
               if (!$update)
               {
                  $forum_data = array(
                     'parent_id'            => $this->parent_id,
                     'forum_type'         => FORUM_POST,
                     'forum_status'         => ITEM_UNLOCKED,
//Begin Thank Post MOD
                     'thanks_yes'          => true,
                     'thanks_no'              => false,
                     //End Thank Post MOD
                                                        //Support Ticket System MOD Beginn
                     'sts_yes'              => true,
                     'sts_no'              => false,
                     //Support Ticket System MOD End
                     'forum_name'         => utf8_normalize_nfc(request_var('forum_name', '', true)),
                     'forum_link'         => '',
                     'forum_link_track'      => false,
                     'forum_desc'         => '',
                     'forum_rules'         => '',
                     'forum_rules_link'      => '',
                     'forum_image'         => '',
                     'forum_style'         => 0,
                     'display_subforum_list'   => true,
                     'display_on_index'      => false,
                     'forum_topics_per_page'   => 0,
                     'enable_indexing'      => true,
                     'enable_icons'         => false,
                     'enable_prune'         => false,
//Begin Thank Post MOD
                     'enable_thanks'         => false,
                     //End Thank Post MOD
//Support Ticket System MOD Beginn
                     'enable_sts'         => false,
                     //Support Ticket System MOD End
                     'prune_days'         => 7,
                     'prune_viewed'         => 7,
                     'prune_freq'         => 1,
                     'forum_flags'         => FORUM_FLAG_POST_REVIEW,
                     'forum_password'      => '',
                     'forum_password_confirm'=> '',
                  );
               }
            }

            $forum_rules_data = array(
               'text'         => $forum_data['forum_rules'],
               'allow_bbcode'   => true,
               'allow_smilies'   => true,
               'allow_urls'   => true
            );

            $forum_desc_data = array(
               'text'         => $forum_data['forum_desc'],
               'allow_bbcode'   => true,
               'allow_smilies'   => true,
               'allow_urls'   => true
            );

            $forum_rules_preview = '';

            // Parse rules if specified
            if ($forum_data['forum_rules'])
            {
               if (!isset($forum_data['forum_rules_uid']))
               {
                  // Before we are able to display the preview and plane text, we need to parse our request_var()'d value...
                  $forum_data['forum_rules_uid'] = '';
                  $forum_data['forum_rules_bitfield'] = '';
                  $forum_data['forum_rules_options'] = 0;

                  generate_text_for_storage($forum_data['forum_rules'], $forum_data['forum_rules_uid'], $forum_data['forum_rules_bitfield'], $forum_data['forum_rules_options'], request_var('rules_allow_bbcode', false), request_var('rules_allow_urls', false), request_var('rules_allow_smilies', false));
               }

               // Generate preview content
               $forum_rules_preview = generate_text_for_display($forum_data['forum_rules'], $forum_data['forum_rules_uid'], $forum_data['forum_rules_bitfield'], $forum_data['forum_rules_options']);

               // decode...
               $forum_rules_data = generate_text_for_edit($forum_data['forum_rules'], $forum_data['forum_rules_uid'], $forum_data['forum_rules_options']);
            }

            // Parse desciption if specified
            if ($forum_data['forum_desc'])
            {
               if (!isset($forum_data['forum_desc_uid']))
               {
                  // Before we are able to display the preview and plane text, we need to parse our request_var()'d value...
                  $forum_data['forum_desc_uid'] = '';
                  $forum_data['forum_desc_bitfield'] = '';
                  $forum_data['forum_desc_options'] = 0;

                  generate_text_for_storage($forum_data['forum_desc'], $forum_data['forum_desc_uid'], $forum_data['forum_desc_bitfield'], $forum_data['forum_desc_options'], request_var('desc_allow_bbcode', false), request_var('desc_allow_urls', false), request_var('desc_allow_smilies', false));
               }

               // decode...
               $forum_desc_data = generate_text_for_edit($forum_data['forum_desc'], $forum_data['forum_desc_uid'], $forum_data['forum_desc_options']);
            }

            $forum_type_options = '';
            $forum_type_ary = array(FORUM_CAT => 'CAT', FORUM_POST => 'FORUM', FORUM_LINK => 'LINK');

            foreach ($forum_type_ary as $value => $lang)
            {
               $forum_type_options .= '<option value="' . $value . '"' . (($value == $forum_data['forum_type']) ? ' selected="selected"' : '') . '>' . $user->lang['TYPE_' . $lang] . '</option>';
            }

            $styles_list = style_select($forum_data['forum_style'], true);

            $statuslist = '<option value="' . ITEM_UNLOCKED . '"' . (($forum_data['forum_status'] == ITEM_UNLOCKED) ? ' selected="selected"' : '') . '>' . $user->lang['UNLOCKED'] . '</option><option value="' . ITEM_LOCKED . '"' . (($forum_data['forum_status'] == ITEM_LOCKED) ? ' selected="selected"' : '') . '>' . $user->lang['LOCKED'] . '</option>';

            $sql = 'SELECT forum_id
               FROM ' . FORUMS_TABLE . '
               WHERE forum_type = ' . FORUM_POST . "
                  AND forum_id <> $forum_id";
            $result = $db->sql_query($sql);

            if ($db->sql_fetchrow($result))
            {
               $template->assign_vars(array(
                  'S_MOVE_FORUM_OPTIONS'      => make_forum_select($forum_data['parent_id'], $forum_id, false, true, false))
               );
            }
            $db->sql_freeresult($result);

            // Subforum move options
            if ($action == 'edit' && $forum_data['forum_type'] == FORUM_CAT)
            {
               $subforums_id = array();
               $subforums = get_forum_branch($forum_id, 'children');

               foreach ($subforums as $row)
               {
                  $subforums_id[] = $row['forum_id'];
               }

               $forums_list = make_forum_select($forum_data['parent_id'], $subforums_id);

               $sql = 'SELECT forum_id
                  FROM ' . FORUMS_TABLE . '
                  WHERE forum_type = ' . FORUM_POST . "
                     AND forum_id <> $forum_id";
               $result = $db->sql_query($sql);

               if ($db->sql_fetchrow($result))
               {
                  $template->assign_vars(array(
                     'S_MOVE_FORUM_OPTIONS'      => make_forum_select($forum_data['parent_id'], $subforums_id)) // , false, true, false???
                  );
               }
               $db->sql_freeresult($result);

               $template->assign_vars(array(
                  'S_HAS_SUBFORUMS'      => ($forum_data['right_id'] - $forum_data['left_id'] > 1) ? true : false,
                  'S_FORUMS_LIST'         => $forums_list)
               );
            }

            $s_show_display_on_index = false;

            if ($forum_data['parent_id'] > 0)
            {
               // if this forum is a subforum put the "display on index" checkbox
               if ($parent_info = $this->get_forum_info($forum_data['parent_id']))
               {
                  if ($parent_info['parent_id'] > 0 || $parent_info['forum_type'] == FORUM_CAT)
                  {
                     $s_show_display_on_index = true;
                  }
               }
            }

            if (strlen($forum_data['forum_password']) == 32)
            {
               $errors[] = $user->lang['FORUM_PASSWORD_OLD'];
            }

            $template->assign_vars(array(
               'S_EDIT_FORUM'      => true,
               'S_ERROR'         => (sizeof($errors)) ? true : false,
               'S_PARENT_ID'      => $this->parent_id,
               'S_FORUM_PARENT_ID'   => $forum_data['parent_id'],
               'S_ADD_ACTION'      => ($action == 'add') ? true : false,

               'U_BACK'      => $this->u_action . '&amp;parent_id=' . $this->parent_id,
               'U_EDIT_ACTION'   => $this->u_action . "&amp;parent_id={$this->parent_id}&amp;action=$action&amp;f=$forum_id",

               'L_COPY_PERMISSIONS_EXPLAIN'   => $user->lang['COPY_PERMISSIONS_' . strtoupper($action) . '_EXPLAIN'],
               'L_TITLE'                  => $user->lang[$this->page_title],
               'ERROR_MSG'                  => (sizeof($errors)) ? implode('<br />', $errors) : '',

               'FORUM_NAME'            => $forum_data['forum_name'],
               'FORUM_DATA_LINK'         => $forum_data['forum_link'],
               'FORUM_IMAGE'            => $forum_data['forum_image'],
               'FORUM_IMAGE_SRC'         => ($forum_data['forum_image']) ? $phpbb_root_path . $forum_data['forum_image'] : '',
               'FORUM_POST'            => FORUM_POST,
               'FORUM_LINK'            => FORUM_LINK,
               'FORUM_CAT'               => FORUM_CAT,
               'PRUNE_FREQ'            => $forum_data['prune_freq'],
               'PRUNE_DAYS'            => $forum_data['prune_days'],
               'PRUNE_VIEWED'            => $forum_data['prune_viewed'],
               'TOPICS_PER_PAGE'         => $forum_data['forum_topics_per_page'],
               'FORUM_RULES_LINK'         => $forum_data['forum_rules_link'],
               'FORUM_RULES'            => $forum_data['forum_rules'],
               'FORUM_RULES_PREVIEW'      => $forum_rules_preview,
               'FORUM_RULES_PLAIN'         => $forum_rules_data['text'],
               'S_BBCODE_CHECKED'         => ($forum_rules_data['allow_bbcode']) ? true : false,
               'S_SMILIES_CHECKED'         => ($forum_rules_data['allow_smilies']) ? true : false,
               'S_URLS_CHECKED'         => ($forum_rules_data['allow_urls']) ? true : false,
               'S_FORUM_PASSWORD_SET'      => (empty($forum_data['forum_password'])) ? false : true,

               'FORUM_DESC'            => $forum_desc_data['text'],
               'S_DESC_BBCODE_CHECKED'      => ($forum_desc_data['allow_bbcode']) ? true : false,
               'S_DESC_SMILIES_CHECKED'   => ($forum_desc_data['allow_smilies']) ? true : false,
               'S_DESC_URLS_CHECKED'      => ($forum_desc_data['allow_urls']) ? true : false,

               'S_FORUM_TYPE_OPTIONS'      => $forum_type_options,
               'S_STATUS_OPTIONS'         => $statuslist,
               'S_PARENT_OPTIONS'         => $parents_list,
               'S_STYLES_OPTIONS'         => $styles_list,
               'S_FORUM_OPTIONS'         => make_forum_select(($action == 'add') ? $forum_data['parent_id'] : false, ($action == 'edit') ? $forum_data['forum_id'] : false, false, false, false),
               'S_SHOW_DISPLAY_ON_INDEX'   => $s_show_display_on_index,
               'S_FORUM_POST'            => ($forum_data['forum_type'] == FORUM_POST) ? true : false,
               'S_FORUM_ORIG_POST'         => (isset($old_forum_type) && $old_forum_type == FORUM_POST) ? true : false,
               'S_FORUM_ORIG_CAT'         => (isset($old_forum_type) && $old_forum_type == FORUM_CAT) ? true : false,
               'S_FORUM_ORIG_LINK'         => (isset($old_forum_type) && $old_forum_type == FORUM_LINK) ? true : false,
               'S_FORUM_LINK'            => ($forum_data['forum_type'] == FORUM_LINK) ? true : false,
               'S_FORUM_CAT'            => ($forum_data['forum_type'] == FORUM_CAT) ? true : false,
               'S_ENABLE_INDEXING'         => ($forum_data['enable_indexing']) ? true : false,
               'S_TOPIC_ICONS'            => ($forum_data['enable_icons']) ? true : false,
               'S_DISPLAY_SUBFORUM_LIST'   => ($forum_data['display_subforum_list']) ? true : false,
               'S_DISPLAY_ON_INDEX'      => ($forum_data['display_on_index']) ? true : false,
               'S_PRUNE_ENABLE'         => ($forum_data['enable_prune']) ? true : false,
//Begin Thank Post MOD
               'S_THANKS_ENABLE'          => ($forum_data['enable_thanks']) ? true : false,
               //End Thank Post MOD
//Support Ticket System MOD Beginn
               'S_STS_ENABLE'             => ($forum_data['enable_sts']) ? true : false,
               //Support Ticket System MOD End
               'S_FORUM_LINK_TRACK'      => ($forum_data['forum_flags'] & FORUM_FLAG_LINK_TRACK) ? true : false,
               'S_PRUNE_OLD_POLLS'         => ($forum_data['forum_flags'] & FORUM_FLAG_PRUNE_POLL) ? true : false,
               'S_PRUNE_ANNOUNCE'         => ($forum_data['forum_flags'] & FORUM_FLAG_PRUNE_ANNOUNCE) ? true : false,
               'S_PRUNE_STICKY'         => ($forum_data['forum_flags'] & FORUM_FLAG_PRUNE_STICKY) ? true : false,
               'S_DISPLAY_ACTIVE_TOPICS'   => ($forum_data['forum_flags'] & FORUM_FLAG_ACTIVE_TOPICS) ? true : false,
               'S_ENABLE_POST_REVIEW'      => ($forum_data['forum_flags'] & FORUM_FLAG_POST_REVIEW) ? true : false,
               'S_CAN_COPY_PERMISSIONS'   => ($action != 'edit' || empty($forum_id) || ($auth->acl_get('a_fauth') && $auth->acl_get('a_authusers') && $auth->acl_get('a_authgroups') && $auth->acl_get('a_mauth'))) ? true : false,
            ));

            return;

         break;

         case 'delete':

            if (!$forum_id)
            {
               trigger_error($user->lang['NO_FORUM'] . adm_back_link($this->u_action . '&amp;parent_id=' . $this->parent_id), E_USER_WARNING);
            }

            $forum_data = $this->get_forum_info($forum_id);

            $subforums_id = array();
            $subforums = get_forum_branch($forum_id, 'children');

            foreach ($subforums as $row)
            {
               $subforums_id[] = $row['forum_id'];
            }

            $forums_list = make_forum_select($forum_data['parent_id'], $subforums_id);

            $sql = 'SELECT forum_id
               FROM ' . FORUMS_TABLE . '
               WHERE forum_type = ' . FORUM_POST . "
                  AND forum_id <> $forum_id";
            $result = $db->sql_query($sql);

            if ($db->sql_fetchrow($result))
            {
               $template->assign_vars(array(
                  'S_MOVE_FORUM_OPTIONS'      => make_forum_select($forum_data['parent_id'], $subforums_id, false, true)) // , false, true, false???
               );
            }
            $db->sql_freeresult($result);

            $parent_id = ($this->parent_id == $forum_id) ? 0 : $this->parent_id;

            $template->assign_vars(array(
               'S_DELETE_FORUM'      => true,
               'U_ACTION'            => $this->u_action . "&amp;parent_id={$parent_id}&amp;action=delete&amp;f=$forum_id",
               'U_BACK'            => $this->u_action . '&amp;parent_id=' . $this->parent_id,

               'FORUM_NAME'         => $forum_data['forum_name'],
               'S_FORUM_POST'         => ($forum_data['forum_type'] == FORUM_POST) ? true : false,
               'S_FORUM_LINK'         => ($forum_data['forum_type'] == FORUM_LINK) ? true : false,
               'S_HAS_SUBFORUMS'      => ($forum_data['right_id'] - $forum_data['left_id'] > 1) ? true : false,
               'S_FORUMS_LIST'         => $forums_list,
               'S_ERROR'            => (sizeof($errors)) ? true : false,
               'ERROR_MSG'            => (sizeof($errors)) ? implode('<br />', $errors) : '')
            );

            return;
         break;
      }

      // Default management page
      if (!$this->parent_id)
      {
         $navigation = $user->lang['FORUM_INDEX'];
      }
      else
      {
         $navigation = '<a href="' . $this->u_action . '">' . $user->lang['FORUM_INDEX'] . '</a>';

         $forums_nav = get_forum_branch($this->parent_id, 'parents', 'descending');
         foreach ($forums_nav as $row)
         {
            if ($row['forum_id'] == $this->parent_id)
            {
               $navigation .= ' -&gt; ' . $row['forum_name'];
            }
            else
            {
               $navigation .= ' -&gt; <a href="' . $this->u_action . '&amp;parent_id=' . $row['forum_id'] . '">' . $row['forum_name'] . '</a>';
            }
         }
      }

      // Jumpbox
      $forum_box = make_forum_select($this->parent_id, false, false, false, false); //make_forum_select($this->parent_id);

      if ($action == 'sync' || $action == 'sync_forum')
      {
         $template->assign_var('S_RESYNCED', true);
      }

      $sql = 'SELECT *
         FROM ' . FORUMS_TABLE . "
         WHERE parent_id = $this->parent_id
         ORDER BY left_id";
      $result = $db->sql_query($sql);

      if ($row = $db->sql_fetchrow($result))
      {
         do
         {
            $forum_type = $row['forum_type'];

            if ($row['forum_status'] == ITEM_LOCKED)
            {
               $folder_image = '<img src="images/icon_folder_lock.gif" alt="' . $user->lang['LOCKED'] . '" />';
            }
            else
            {
               switch ($forum_type)
               {
                  case FORUM_LINK:
                     $folder_image = '<img src="images/icon_folder_link.gif" alt="' . $user->lang['LINK'] . '" />';
                  break;

                  default:
                     $folder_image = ($row['left_id'] + 1 != $row['right_id']) ? '<img src="images/icon_subfolder.gif" alt="' . $user->lang['SUBFORUM'] . '" />' : '<img src="images/icon_folder.gif" alt="' . $user->lang['FOLDER'] . '" />';
                  break;
               }
            }

            $url = $this->u_action . "&amp;parent_id=$this->parent_id&amp;f={$row['forum_id']}";

            $forum_title = ($forum_type != FORUM_LINK) ? '<a href="' . $this->u_action . '&amp;parent_id=' . $row['forum_id'] . '">' : '';
            $forum_title .= $row['forum_name'];
            $forum_title .= ($forum_type != FORUM_LINK) ? '</a>' : '';

            $template->assign_block_vars('forums', array(
               'FOLDER_IMAGE'      => $folder_image,
               'FORUM_IMAGE'      => ($row['forum_image']) ? '<img src="' . $phpbb_root_path . $row['forum_image'] . '" alt="" />' : '',
               'FORUM_IMAGE_SRC'   => ($row['forum_image']) ? $phpbb_root_path . $row['forum_image'] : '',
               'FORUM_NAME'      => $row['forum_name'],
               'FORUM_DESCRIPTION'   => generate_text_for_display($row['forum_desc'], $row['forum_desc_uid'], $row['forum_desc_bitfield'], $row['forum_desc_options']),
               'FORUM_TOPICS'      => $row['forum_topics'],
               'FORUM_POSTS'      => $row['forum_posts'],

               'S_FORUM_LINK'      => ($forum_type == FORUM_LINK) ? true : false,
               'S_FORUM_POST'      => ($forum_type == FORUM_POST) ? true : false,

               'U_FORUM'         => $this->u_action . '&amp;parent_id=' . $row['forum_id'],
               'U_MOVE_UP'         => $url . '&amp;action=move_up',
               'U_MOVE_DOWN'      => $url . '&amp;action=move_down',
               'U_EDIT'         => $url . '&amp;action=edit',
               'U_DELETE'         => $url . '&amp;action=delete',
               'U_SYNC'         => $url . '&amp;action=sync')
            );
         }
         while ($row = $db->sql_fetchrow($result));
      }
      else if ($this->parent_id)
      {
         $row = $this->get_forum_info($this->parent_id);

         $url = $this->u_action . '&amp;parent_id=' . $this->parent_id . '&amp;f=' . $row['forum_id'];

         $template->assign_vars(array(
            'S_NO_FORUMS'      => true,

            'U_EDIT'         => $url . '&amp;action=edit',
            'U_DELETE'         => $url . '&amp;action=delete',
            'U_SYNC'         => $url . '&amp;action=sync')
         );
      }
      $db->sql_freeresult($result);

      $template->assign_vars(array(
         'ERROR_MSG'      => (sizeof($errors)) ? implode('<br />', $errors) : '',
         'NAVIGATION'   => $navigation,
         'FORUM_BOX'      => $forum_box,
         'U_SEL_ACTION'   => $this->u_action,
         'U_ACTION'      => $this->u_action . '&amp;parent_id=' . $this->parent_id,

         'U_PROGRESS_BAR'   => $this->u_action . '&amp;action=progress_bar',
         'UA_PROGRESS_BAR'   => addslashes($this->u_action . '&amp;action=progress_bar'),
      ));
   }

   /**
   * Get forum details
   */
   function get_forum_info($forum_id)
   {
      global $db;

      $sql = 'SELECT *
         FROM ' . FORUMS_TABLE . "
         WHERE forum_id = $forum_id";
      $result = $db->sql_query($sql);
      $row = $db->sql_fetchrow($result);
      $db->sql_freeresult($result);

      if (!$row)
      {
         trigger_error("Forum #$forum_id does not exist", E_USER_ERROR);
      }

      return $row;
   }

   /**
   * Update forum data
   */
   function update_forum_data(&$forum_data)
   {
      global $db, $user, $cache;

      $errors = array();

      if (!$forum_data['forum_name'])
      {
         $errors[] = $user->lang['FORUM_NAME_EMPTY'];
      }

      if (utf8_strlen($forum_data['forum_desc']) > 4000)
      {
         $errors[] = $user->lang['FORUM_DESC_TOO_LONG'];
      }

      if (utf8_strlen($forum_data['forum_rules']) > 4000)
      {
         $errors[] = $user->lang['FORUM_RULES_TOO_LONG'];
      }

      if ($forum_data['forum_password'] || $forum_data['forum_password_confirm'])
      {
         if ($forum_data['forum_password'] != $forum_data['forum_password_confirm'])
         {
            $forum_data['forum_password'] = $forum_data['forum_password_confirm'] = '';
            $errors[] = $user->lang['FORUM_PASSWORD_MISMATCH'];
         }
      }

      if ($forum_data['prune_days'] < 0 || $forum_data['prune_viewed'] < 0 || $forum_data['prune_freq'] < 0)
      {
         $forum_data['prune_days'] = $forum_data['prune_viewed'] = $forum_data['prune_freq'] = 0;
         $errors[] = $user->lang['FORUM_DATA_NEGATIVE'];
      }

      $range_test_ary = array(
         array('lang' => 'FORUM_TOPICS_PAGE', 'value' => $forum_data['forum_topics_per_page'], 'column_type' => 'TINT:0'),
      );

      validate_range($range_test_ary, $errors);

      // Set forum flags
      // 1 = link tracking
      // 2 = prune old polls
      // 4 = prune announcements
      // 8 = prune stickies
      // 16 = show active topics
      // 32 = enable post review
      $forum_data['forum_flags'] = 0;
      $forum_data['forum_flags'] += ($forum_data['forum_link_track']) ? FORUM_FLAG_LINK_TRACK : 0;
      $forum_data['forum_flags'] += ($forum_data['prune_old_polls']) ? FORUM_FLAG_PRUNE_POLL : 0;
      $forum_data['forum_flags'] += ($forum_data['prune_announce']) ? FORUM_FLAG_PRUNE_ANNOUNCE : 0;
      $forum_data['forum_flags'] += ($forum_data['prune_sticky']) ? FORUM_FLAG_PRUNE_STICKY : 0;
      $forum_data['forum_flags'] += ($forum_data['show_active']) ? FORUM_FLAG_ACTIVE_TOPICS : 0;
      $forum_data['forum_flags'] += ($forum_data['enable_post_review']) ? FORUM_FLAG_POST_REVIEW : 0;

      // Unset data that are not database fields
      $forum_data_sql = $forum_data;

      unset($forum_data_sql['forum_link_track']);
      unset($forum_data_sql['prune_old_polls']);
      unset($forum_data_sql['prune_announce']);
      unset($forum_data_sql['prune_sticky']);
      unset($forum_data_sql['show_active']);
      unset($forum_data_sql['enable_post_review']);
      unset($forum_data_sql['forum_password_confirm']);

      // What are we going to do tonight Brain? The same thing we do everynight,
      // try to take over the world ... or decide whether to continue update
      // and if so, whether it's a new forum/cat/link or an existing one
      if (sizeof($errors))
      {
         return $errors;
      }

      // As we don't know the old password, it's kinda tricky to detect changes
      if ($forum_data_sql['forum_password_unset'])
      {
         $forum_data_sql['forum_password'] = '';
      }
      else if (empty($forum_data_sql['forum_password']))
      {
         unset($forum_data_sql['forum_password']);
      }
      else
      {
         $forum_data_sql['forum_password'] = phpbb_hash($forum_data_sql['forum_password']);
      }
      unset($forum_data_sql['forum_password_unset']);

      if (!isset($forum_data_sql['forum_id']))
      {
         // no forum_id means we're creating a new forum
         unset($forum_data_sql['type_action']);

         if ($forum_data_sql['parent_id'])
         {
            $sql = 'SELECT left_id, right_id, forum_type
               FROM ' . FORUMS_TABLE . '
               WHERE forum_id = ' . $forum_data_sql['parent_id'];
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               trigger_error($user->lang['PARENT_NOT_EXIST'] . adm_back_link($this->u_action . '&amp;' . $this->parent_id), E_USER_WARNING);
            }

            if ($row['forum_type'] == FORUM_LINK)
            {
               $errors[] = $user->lang['PARENT_IS_LINK_FORUM'];
               return $errors;
            }

            $sql = 'UPDATE ' . FORUMS_TABLE . '
               SET left_id = left_id + 2, right_id = right_id + 2
               WHERE left_id > ' . $row['right_id'];
            $db->sql_query($sql);

            $sql = 'UPDATE ' . FORUMS_TABLE . '
               SET right_id = right_id + 2
               WHERE ' . $row['left_id'] . ' BETWEEN left_id AND right_id';
            $db->sql_query($sql);

            $forum_data_sql['left_id'] = $row['right_id'];
            $forum_data_sql['right_id'] = $row['right_id'] + 1;
         }
         else
         {
            $sql = 'SELECT MAX(right_id) AS right_id
               FROM ' . FORUMS_TABLE;
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            $forum_data_sql['left_id'] = $row['right_id'] + 1;
            $forum_data_sql['right_id'] = $row['right_id'] + 2;
         }

         $sql = 'INSERT INTO ' . FORUMS_TABLE . ' ' . $db->sql_build_array('INSERT', $forum_data_sql);
         $db->sql_query($sql);

         $forum_data['forum_id'] = $db->sql_nextid();

         add_log('admin', 'LOG_FORUM_ADD', $forum_data['forum_name']);
      }
      else
      {
         $row = $this->get_forum_info($forum_data_sql['forum_id']);

         if ($row['forum_type'] == FORUM_POST && $row['forum_type'] != $forum_data_sql['forum_type'])
         {
            // Has subforums and want to change into a link?
            if ($row['right_id'] - $row['left_id'] > 1 && $forum_data_sql['forum_type'] == FORUM_LINK)
            {
               $errors[] = $user->lang['FORUM_WITH_SUBFORUMS_NOT_TO_LINK'];
               return $errors;
            }

            // we're turning a postable forum into a non-postable forum
            if ($forum_data_sql['type_action'] == 'move')
            {
               $to_forum_id = request_var('to_forum_id', 0);

               if ($to_forum_id)
               {
                  $errors = $this->move_forum_content($forum_data_sql['forum_id'], $to_forum_id);
               }
               else
               {
                  return array($user->lang['NO_DESTINATION_FORUM']);
               }
            }
            else if ($forum_data_sql['type_action'] == 'delete')
            {
               $errors = $this->delete_forum_content($forum_data_sql['forum_id']);
            }
            else
            {
               return array($user->lang['NO_FORUM_ACTION']);
            }

            $forum_data_sql['forum_posts'] = $forum_data_sql['forum_topics'] = $forum_data_sql['forum_topics_real'] = $forum_data_sql['forum_last_post_id'] = $forum_data_sql['forum_last_poster_id'] = $forum_data_sql['forum_last_post_time'] = 0;
            $forum_data_sql['forum_last_poster_name'] = $forum_data_sql['forum_last_poster_colour'] = '';
         }
         else if ($row['forum_type'] == FORUM_CAT && $forum_data_sql['forum_type'] == FORUM_LINK)
         {
            // Has subforums?
            if ($row['right_id'] - $row['left_id'] > 1)
            {
               // We are turning a category into a link - but need to decide what to do with the subforums.
               $action_subforums = request_var('action_subforums', '');
               $subforums_to_id = request_var('subforums_to_id', 0);

               if ($action_subforums == 'delete')
               {
                  $rows = get_forum_branch($row['forum_id'], 'children', 'descending', false);

                  foreach ($rows as $_row)
                  {
                     // Do not remove the forum id we are about to change. ;)
                     if ($_row['forum_id'] == $row['forum_id'])
                     {
                        continue;
                     }

                     $forum_ids[] = $_row['forum_id'];
                     $errors = array_merge($errors, $this->delete_forum_content($_row['forum_id']));
                  }

                  if (sizeof($errors))
                  {
                     return $errors;
                  }

                  if (sizeof($forum_ids))
                  {
                     $sql = 'DELETE FROM ' . FORUMS_TABLE . '
                        WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
                     $db->sql_query($sql);

                     $sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . '
                        WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
                     $db->sql_query($sql);

                     $sql = 'DELETE FROM ' . ACL_USERS_TABLE . '
                        WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
                     $db->sql_query($sql);

                     // Delete forum ids from extension groups table
                     $sql = 'SELECT group_id, allowed_forums
                        FROM ' . EXTENSION_GROUPS_TABLE;
                     $result = $db->sql_query($sql);

                     while ($_row = $db->sql_fetchrow($result))
                     {
                        if (!$_row['allowed_forums'])
                        {
                           continue;
                        }

                        $allowed_forums = unserialize(trim($_row['allowed_forums']));
                        $allowed_forums = array_diff($allowed_forums, $forum_ids);

                        $sql = 'UPDATE ' . EXTENSION_GROUPS_TABLE . "
                           SET allowed_forums = '" . ((sizeof($allowed_forums)) ? serialize($allowed_forums) : '') . "'
                           WHERE group_id = {$_row['group_id']}";
                        $db->sql_query($sql);
                     }
                     $db->sql_freeresult($result);

                     $cache->destroy('_extensions');
                  }
               }
               else if ($action_subforums == 'move')
               {
                  if (!$subforums_to_id)
                  {
                     return array($user->lang['NO_DESTINATION_FORUM']);
                  }

                  $sql = 'SELECT forum_name
                     FROM ' . FORUMS_TABLE . '
                     WHERE forum_id = ' . $subforums_to_id;
                  $result = $db->sql_query($sql);
                  $_row = $db->sql_fetchrow($result);
                  $db->sql_freeresult($result);

                  if (!$_row)
                  {
                     return array($user->lang['NO_FORUM']);
                  }

                  $subforums_to_name = $_row['forum_name'];

                  $sql = 'SELECT forum_id
                     FROM ' . FORUMS_TABLE . "
                     WHERE parent_id = {$row['forum_id']}";
                  $result = $db->sql_query($sql);

                  while ($_row = $db->sql_fetchrow($result))
                  {
                     $this->move_forum($_row['forum_id'], $subforums_to_id);
                  }
                  $db->sql_freeresult($result);

                  $sql = 'UPDATE ' . FORUMS_TABLE . "
                     SET parent_id = $subforums_to_id
                     WHERE parent_id = {$row['forum_id']}";
                  $db->sql_query($sql);
               }

               // Adjust the left/right id
               $sql = 'UPDATE ' . FORUMS_TABLE . '
                  SET right_id = left_id + 1
                  WHERE forum_id = ' . $row['forum_id'];
               $db->sql_query($sql);
            }
         }
         else if ($row['forum_type'] == FORUM_CAT && $forum_data_sql['forum_type'] == FORUM_POST)
         {
            // Changing a category to a forum? Reset the data (you can't post directly in a cat, you must use a forum)
            $forum_data_sql['forum_posts'] = 0;
            $forum_data_sql['forum_topics'] = 0;
            $forum_data_sql['forum_topics_real'] = 0;
            $forum_data_sql['forum_last_post_id'] = 0;
            $forum_data_sql['forum_last_post_subject'] = '';
            $forum_data_sql['forum_last_post_time'] = 0;
            $forum_data_sql['forum_last_poster_id'] = 0;
            $forum_data_sql['forum_last_poster_name'] = '';
            $forum_data_sql['forum_last_poster_colour'] = '';
         }

         if (sizeof($errors))
         {
            return $errors;
         }

         if ($row['parent_id'] != $forum_data_sql['parent_id'])
         {
            if ($row['forum_id'] != $forum_data_sql['parent_id'])
            {
               $errors = $this->move_forum($forum_data_sql['forum_id'], $forum_data_sql['parent_id']);
            }
            else
            {
               $forum_data_sql['parent_id'] = $row['parent_id'];
            }
         }

         if (sizeof($errors))
         {
            return $errors;
         }

         unset($forum_data_sql['type_action']);

         if ($row['forum_name'] != $forum_data_sql['forum_name'])
         {
            // the forum name has changed, clear the parents list of all forums (for safety)
            $sql = 'UPDATE ' . FORUMS_TABLE . "
               SET forum_parents = ''";
            $db->sql_query($sql);
         }

         // Setting the forum id to the forum id is not really received well by some dbs. ;)
         $forum_id = $forum_data_sql['forum_id'];
         unset($forum_data_sql['forum_id']);

         $sql = 'UPDATE ' . FORUMS_TABLE . '
            SET ' . $db->sql_build_array('UPDATE', $forum_data_sql) . '
            WHERE forum_id = ' . $forum_id;
         $db->sql_query($sql);

         // Add it back
         $forum_data['forum_id'] = $forum_id;

         add_log('admin', 'LOG_FORUM_EDIT', $forum_data['forum_name']);
      }

      return $errors;
   }

   /**
   * Move forum
   */
   function move_forum($from_id, $to_id)
   {
      global $db, $user;

      $to_data = $moved_ids = $errors = array();

      // Check if we want to move to a parent with link type
      if ($to_id > 0)
      {
         $to_data = $this->get_forum_info($to_id);

         if ($to_data['forum_type'] == FORUM_LINK)
         {
            $errors[] = $user->lang['PARENT_IS_LINK_FORUM'];
            return $errors;
         }
      }

      $moved_forums = get_forum_branch($from_id, 'children', 'descending');
      $from_data = $moved_forums[0];
      $diff = sizeof($moved_forums) * 2;

      $moved_ids = array();
      for ($i = 0; $i < sizeof($moved_forums); ++$i)
      {
         $moved_ids[] = $moved_forums[$i]['forum_id'];
      }

      // Resync parents
      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET right_id = right_id - $diff, forum_parents = ''
         WHERE left_id < " . $from_data['right_id'] . "
            AND right_id > " . $from_data['right_id'];
      $db->sql_query($sql);

      // Resync righthand side of tree
      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET left_id = left_id - $diff, right_id = right_id - $diff, forum_parents = ''
         WHERE left_id > " . $from_data['right_id'];
      $db->sql_query($sql);

      if ($to_id > 0)
      {
         // Retrieve $to_data again, it may have been changed...
         $to_data = $this->get_forum_info($to_id);

         // Resync new parents
         $sql = 'UPDATE ' . FORUMS_TABLE . "
            SET right_id = right_id + $diff, forum_parents = ''
            WHERE " . $to_data['right_id'] . ' BETWEEN left_id AND right_id
               AND ' . $db->sql_in_set('forum_id', $moved_ids, true);
         $db->sql_query($sql);

         // Resync the righthand side of the tree
         $sql = 'UPDATE ' . FORUMS_TABLE . "
            SET left_id = left_id + $diff, right_id = right_id + $diff, forum_parents = ''
            WHERE left_id > " . $to_data['right_id'] . '
               AND ' . $db->sql_in_set('forum_id', $moved_ids, true);
         $db->sql_query($sql);

         // Resync moved branch
         $to_data['right_id'] += $diff;

         if ($to_data['right_id'] > $from_data['right_id'])
         {
            $diff = '+ ' . ($to_data['right_id'] - $from_data['right_id'] - 1);
         }
         else
         {
            $diff = '- ' . abs($to_data['right_id'] - $from_data['right_id'] - 1);
         }
      }
      else
      {
         $sql = 'SELECT MAX(right_id) AS right_id
            FROM ' . FORUMS_TABLE . '
            WHERE ' . $db->sql_in_set('forum_id', $moved_ids, true);
         $result = $db->sql_query($sql);
         $row = $db->sql_fetchrow($result);
         $db->sql_freeresult($result);

         $diff = '+ ' . ($row['right_id'] - $from_data['left_id'] + 1);
      }

      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET left_id = left_id $diff, right_id = right_id $diff, forum_parents = ''
         WHERE " . $db->sql_in_set('forum_id', $moved_ids);
      $db->sql_query($sql);

      return $errors;
   }

   /**
   * Move forum content from one to another forum
   */
   function move_forum_content($from_id, $to_id, $sync = true)
   {
      global $db;

      $table_ary = array(LOG_TABLE, POSTS_TABLE, TOPICS_TABLE, DRAFTS_TABLE, TOPICS_TRACK_TABLE);

      foreach ($table_ary as $table)
      {
         $sql = "UPDATE $table
            SET forum_id = $to_id
            WHERE forum_id = $from_id";
         $db->sql_query($sql);
      }
      unset($table_ary);

      $table_ary = array(FORUMS_ACCESS_TABLE, FORUMS_TRACK_TABLE, FORUMS_WATCH_TABLE, MODERATOR_CACHE_TABLE);

      foreach ($table_ary as $table)
      {
         $sql = "DELETE FROM $table
            WHERE forum_id = $from_id";
         $db->sql_query($sql);
      }

      if ($sync)
      {
         // Delete ghost topics that link back to the same forum then resync counters
         sync('topic_moved');
         sync('forum', 'forum_id', $to_id, false, true);
      }

      return array();
   }

   /**
   * Remove complete forum
   */
   function delete_forum($forum_id, $action_posts = 'delete', $action_subforums = 'delete', $posts_to_id = 0, $subforums_to_id = 0)
   {
      global $db, $user, $cache;

      $forum_data = $this->get_forum_info($forum_id);

      $errors = array();
      $log_action_posts = $log_action_forums = $posts_to_name = $subforums_to_name = '';
      $forum_ids = array($forum_id);

      if ($action_posts == 'delete')
      {
         $log_action_posts = 'POSTS';
         $errors = array_merge($errors, $this->delete_forum_content($forum_id));
      }
      else if ($action_posts == 'move')
      {
         if (!$posts_to_id)
         {
            $errors[] = $user->lang['NO_DESTINATION_FORUM'];
         }
         else
         {
            $log_action_posts = 'MOVE_POSTS';

            $sql = 'SELECT forum_name
               FROM ' . FORUMS_TABLE . '
               WHERE forum_id = ' . $posts_to_id;
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               $errors[] = $user->lang['NO_FORUM'];
            }
            else
            {
               $posts_to_name = $row['forum_name'];
               $errors = array_merge($errors, $this->move_forum_content($forum_id, $posts_to_id));
            }
         }
      }

      if (sizeof($errors))
      {
         return $errors;
      }

      if ($action_subforums == 'delete')
      {
         $log_action_forums = 'FORUMS';
         $rows = get_forum_branch($forum_id, 'children', 'descending', false);

         foreach ($rows as $row)
         {
            $forum_ids[] = $row['forum_id'];
            $errors = array_merge($errors, $this->delete_forum_content($row['forum_id']));
         }

         if (sizeof($errors))
         {
            return $errors;
         }

         $diff = sizeof($forum_ids) * 2;

         $sql = 'DELETE FROM ' . FORUMS_TABLE . '
            WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
         $db->sql_query($sql);

         $sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . '
            WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
         $db->sql_query($sql);

         $sql = 'DELETE FROM ' . ACL_USERS_TABLE . '
            WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
         $db->sql_query($sql);
      }
      else if ($action_subforums == 'move')
      {
         if (!$subforums_to_id)
         {
            $errors[] = $user->lang['NO_DESTINATION_FORUM'];
         }
         else
         {
            $log_action_forums = 'MOVE_FORUMS';

            $sql = 'SELECT forum_name
               FROM ' . FORUMS_TABLE . '
               WHERE forum_id = ' . $subforums_to_id;
            $result = $db->sql_query($sql);
            $row = $db->sql_fetchrow($result);
            $db->sql_freeresult($result);

            if (!$row)
            {
               $errors[] = $user->lang['NO_FORUM'];
            }
            else
            {
               $subforums_to_name = $row['forum_name'];

               $sql = 'SELECT forum_id
                  FROM ' . FORUMS_TABLE . "
                  WHERE parent_id = $forum_id";
               $result = $db->sql_query($sql);

               while ($row = $db->sql_fetchrow($result))
               {
                  $this->move_forum($row['forum_id'], $subforums_to_id);
               }
               $db->sql_freeresult($result);

               // Grab new forum data for correct tree updating later
               $forum_data = $this->get_forum_info($forum_id);

               $sql = 'UPDATE ' . FORUMS_TABLE . "
                  SET parent_id = $subforums_to_id
                  WHERE parent_id = $forum_id";
               $db->sql_query($sql);

               $diff = 2;
               $sql = 'DELETE FROM ' . FORUMS_TABLE . "
                  WHERE forum_id = $forum_id";
               $db->sql_query($sql);

               $sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . "
                  WHERE forum_id = $forum_id";
               $db->sql_query($sql);

               $sql = 'DELETE FROM ' . ACL_USERS_TABLE . "
                  WHERE forum_id = $forum_id";
               $db->sql_query($sql);
            }
         }

         if (sizeof($errors))
         {
            return $errors;
         }
      }
      else
      {
         $diff = 2;
         $sql = 'DELETE FROM ' . FORUMS_TABLE . "
            WHERE forum_id = $forum_id";
         $db->sql_query($sql);

         $sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . "
            WHERE forum_id = $forum_id";
         $db->sql_query($sql);

         $sql = 'DELETE FROM ' . ACL_USERS_TABLE . "
            WHERE forum_id = $forum_id";
         $db->sql_query($sql);
      }

      // Resync tree
      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET right_id = right_id - $diff
         WHERE left_id < {$forum_data['right_id']} AND right_id > {$forum_data['right_id']}";
      $db->sql_query($sql);

      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET left_id = left_id - $diff, right_id = right_id - $diff
         WHERE left_id > {$forum_data['right_id']}";
      $db->sql_query($sql);

      // Delete forum ids from extension groups table
      $sql = 'SELECT group_id, allowed_forums
         FROM ' . EXTENSION_GROUPS_TABLE;
      $result = $db->sql_query($sql);

      while ($row = $db->sql_fetchrow($result))
      {
         if (!$row['allowed_forums'])
         {
            continue;
         }

         $allowed_forums = unserialize(trim($row['allowed_forums']));
         $allowed_forums = array_diff($allowed_forums, $forum_ids);

         $sql = 'UPDATE ' . EXTENSION_GROUPS_TABLE . "
            SET allowed_forums = '" . ((sizeof($allowed_forums)) ? serialize($allowed_forums) : '') . "'
            WHERE group_id = {$row['group_id']}";
         $db->sql_query($sql);
      }
      $db->sql_freeresult($result);

      $cache->destroy('_extensions');

      $log_action = implode('_', array($log_action_posts, $log_action_forums));

      switch ($log_action)
      {
         case 'MOVE_POSTS_MOVE_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_MOVE_POSTS_MOVE_FORUMS', $posts_to_name, $subforums_to_name, $forum_data['forum_name']);
         break;

         case 'MOVE_POSTS_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_MOVE_POSTS_FORUMS', $posts_to_name, $forum_data['forum_name']);
         break;

         case 'POSTS_MOVE_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_POSTS_MOVE_FORUMS', $subforums_to_name, $forum_data['forum_name']);
         break;

         case '_MOVE_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_MOVE_FORUMS', $subforums_to_name, $forum_data['forum_name']);
         break;

         case 'MOVE_POSTS_':
            add_log('admin', 'LOG_FORUM_DEL_MOVE_POSTS', $posts_to_name, $forum_data['forum_name']);
         break;

         case 'POSTS_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_POSTS_FORUMS', $forum_data['forum_name']);
         break;

         case '_FORUMS':
            add_log('admin', 'LOG_FORUM_DEL_FORUMS', $forum_data['forum_name']);
         break;

         case 'POSTS_':
            add_log('admin', 'LOG_FORUM_DEL_POSTS', $forum_data['forum_name']);
         break;

         default:
            add_log('admin', 'LOG_FORUM_DEL_FORUM', $forum_data['forum_name']);
         break;
      }

      return $errors;
   }

   /**
   * Delete forum content
   */
   function delete_forum_content($forum_id)
   {
      global $db, $config, $phpbb_root_path, $phpEx;

      include_once($phpbb_root_path . 'includes/functions_posting.' . $phpEx);

      $db->sql_transaction('begin');

      // Select then delete all attachments
      $sql = 'SELECT a.topic_id
         FROM ' . POSTS_TABLE . ' p, ' . ATTACHMENTS_TABLE . " a
         WHERE p.forum_id = $forum_id
            AND a.in_message = 0
            AND a.topic_id = p.topic_id";
      $result = $db->sql_query($sql);

      $topic_ids = array();
      while ($row = $db->sql_fetchrow($result))
      {
         $topic_ids[] = $row['topic_id'];
      }
      $db->sql_freeresult($result);

      delete_attachments('topic', $topic_ids, false);

      // Before we remove anything we make sure we are able to adjust the post counts later. ;)
      $sql = 'SELECT poster_id
         FROM ' . POSTS_TABLE . '
         WHERE forum_id = ' . $forum_id . '
            AND post_postcount = 1
            AND post_approved = 1';
      $result = $db->sql_query($sql);

      $post_counts = array();
      while ($row = $db->sql_fetchrow($result))
      {
         $post_counts[$row['poster_id']] = (!empty($post_counts[$row['poster_id']])) ? $post_counts[$row['poster_id']] + 1 : 1;
      }
      $db->sql_freeresult($result);

      switch ($db->sql_layer)
      {
         case 'mysql4':
         case 'mysqli':

            // Delete everything else and thank MySQL for offering multi-table deletion
            $tables_ary = array(
               SEARCH_WORDMATCH_TABLE   => 'post_id',
               REPORTS_TABLE         => 'post_id',
               WARNINGS_TABLE         => 'post_id',
               BOOKMARKS_TABLE         => 'topic_id',
               TOPICS_WATCH_TABLE      => 'topic_id',
               TOPICS_POSTED_TABLE      => 'topic_id',
               POLL_OPTIONS_TABLE      => 'topic_id',
               POLL_VOTES_TABLE      => 'topic_id',
            );

            $sql = 'DELETE ' . POSTS_TABLE;
            $sql_using = "nFROM " . POSTS_TABLE;
            $sql_where = "nWHERE " . POSTS_TABLE . ".forum_id = $forum_idn";

            foreach ($tables_ary as $table => $field)
            {
               $sql .= ", $table ";
               $sql_using .= ", $table ";
               $sql_where .= "nAND $table.$field = " . POSTS_TABLE . ".$field";
            }

            $db->sql_query($sql . $sql_using . $sql_where);

         break;

         default:

            // Delete everything else and curse your DB for not offering multi-table deletion
            $tables_ary = array(
               'post_id'   =>   array(
                  SEARCH_WORDMATCH_TABLE,
                  REPORTS_TABLE,
                  WARNINGS_TABLE,
               ),

               'topic_id'   =>   array(
                  BOOKMARKS_TABLE,
                  TOPICS_WATCH_TABLE,
                  TOPICS_POSTED_TABLE,
                  POLL_OPTIONS_TABLE,
                  POLL_VOTES_TABLE,
               )
            );

            foreach ($tables_ary as $field => $tables)
            {
               $start = 0;

               do
               {
                  $sql = "SELECT $field
                     FROM " . POSTS_TABLE . '
                     WHERE forum_id = ' . $forum_id;
                  $result = $db->sql_query_limit($sql, 500, $start);

                  $ids = array();
                  while ($row = $db->sql_fetchrow($result))
                  {
                     $ids[] = $row[$field];
                  }
                  $db->sql_freeresult($result);

                  if (sizeof($ids))
                  {
                     $start += sizeof($ids);

                     foreach ($tables as $table)
                     {
                        $db->sql_query("DELETE FROM $table WHERE " . $db->sql_in_set($field, $ids));
                     }
                  }
               }
               while ($row);
            }
            unset($ids);

         break;
      }

      $table_ary = array(FORUMS_ACCESS_TABLE, FORUMS_TRACK_TABLE, FORUMS_WATCH_TABLE, LOG_TABLE, MODERATOR_CACHE_TABLE, POSTS_TABLE, TOPICS_TABLE, TOPICS_TRACK_TABLE);

      foreach ($table_ary as $table)
      {
         $db->sql_query("DELETE FROM $table WHERE forum_id = $forum_id");
      }

      // Set forum ids to 0
      $table_ary = array(DRAFTS_TABLE);

      foreach ($table_ary as $table)
      {
         $db->sql_query("UPDATE $table SET forum_id = 0 WHERE forum_id = $forum_id");
      }

      // Adjust users post counts
      if (sizeof($post_counts))
      {
         foreach ($post_counts as $poster_id => $substract)
         {
            $sql = 'UPDATE ' . USERS_TABLE . '
               SET user_posts = 0
               WHERE user_id = ' . $poster_id . '
               AND user_posts < ' . $substract;
            $db->sql_query($sql);

            $sql = 'UPDATE ' . USERS_TABLE . '
               SET user_posts = user_posts - ' . $substract . '
               WHERE user_id = ' . $poster_id . '
               AND user_posts >= ' . $substract;
            $db->sql_query($sql);
         }
      }

      $db->sql_transaction('commit');

      // Make sure the overall post/topic count is correct...
      $sql = 'SELECT COUNT(post_id) AS stat
         FROM ' . POSTS_TABLE . '
         WHERE post_approved = 1';
      $result = $db->sql_query($sql);
      $row = $db->sql_fetchrow($result);
      $db->sql_freeresult($result);

      set_config('num_posts', (int) $row['stat'], true);

      $sql = 'SELECT COUNT(topic_id) AS stat
         FROM ' . TOPICS_TABLE . '
         WHERE topic_approved = 1';
      $result = $db->sql_query($sql);
      $row = $db->sql_fetchrow($result);
      $db->sql_freeresult($result);

      set_config('num_topics', (int) $row['stat'], true);

      $sql = 'SELECT COUNT(attach_id) as stat
         FROM ' . ATTACHMENTS_TABLE;
      $result = $db->sql_query($sql);
      $row = $db->sql_fetchrow($result);
      $db->sql_freeresult($result);

      set_config('num_files', (int) $row['stat'], true);

      $sql = 'SELECT SUM(filesize) as stat
         FROM ' . ATTACHMENTS_TABLE;
      $result = $db->sql_query($sql);
      $row = $db->sql_fetchrow($result);
      $db->sql_freeresult($result);

      set_config('upload_dir_size', (float) $row['stat'], true);

      return array();
   }

   /**
   * Move forum position by $steps up/down
   */
   function move_forum_by($forum_row, $action = 'move_up', $steps = 1)
   {
      global $db;

      /**
      * Fetch all the siblings between the module's current spot
      * and where we want to move it to. If there are less than $steps
      * siblings between the current spot and the target then the
      * module will move as far as possible
      */
      $sql = 'SELECT forum_id, forum_name, left_id, right_id
         FROM ' . FORUMS_TABLE . "
         WHERE parent_id = {$forum_row['parent_id']}
            AND " . (($action == 'move_up') ? "right_id < {$forum_row['right_id']} ORDER BY right_id DESC" : "left_id > {$forum_row['left_id']} ORDER BY left_id ASC");
      $result = $db->sql_query_limit($sql, $steps);

      $target = array();
      while ($row = $db->sql_fetchrow($result))
      {
         $target = $row;
      }
      $db->sql_freeresult($result);

      if (!sizeof($target))
      {
         // The forum is already on top or bottom
         return false;
      }

      /**
      * $left_id and $right_id define the scope of the nodes that are affected by the move.
      * $diff_up and $diff_down are the values to substract or add to each node's left_id
      * and right_id in order to move them up or down.
      * $move_up_left and $move_up_right define the scope of the nodes that are moving
      * up. Other nodes in the scope of ($left_id, $right_id) are considered to move down.
      */
      if ($action == 'move_up')
      {
         $left_id = $target['left_id'];
         $right_id = $forum_row['right_id'];

         $diff_up = $forum_row['left_id'] - $target['left_id'];
         $diff_down = $forum_row['right_id'] + 1 - $forum_row['left_id'];

         $move_up_left = $forum_row['left_id'];
         $move_up_right = $forum_row['right_id'];
      }
      else
      {
         $left_id = $forum_row['left_id'];
         $right_id = $target['right_id'];

         $diff_up = $forum_row['right_id'] + 1 - $forum_row['left_id'];
         $diff_down = $target['right_id'] - $forum_row['right_id'];

         $move_up_left = $forum_row['right_id'] + 1;
         $move_up_right = $target['right_id'];
      }

      // Now do the dirty job
      $sql = 'UPDATE ' . FORUMS_TABLE . "
         SET left_id = left_id + CASE
            WHEN left_id BETWEEN {$move_up_left} AND {$move_up_right} THEN -{$diff_up}
            ELSE {$diff_down}
         END,
         right_id = right_id + CASE
            WHEN right_id BETWEEN {$move_up_left} AND {$move_up_right} THEN -{$diff_up}
            ELSE {$diff_down}
         END,
         forum_parents = ''
         WHERE
            left_id BETWEEN {$left_id} AND {$right_id}
            AND right_id BETWEEN {$left_id} AND {$right_id}";
      $db->sql_query($sql);

      return $target['forum_name'];
   }

   /**
   * Display progress bar for syncinc forums
   */
   function display_progress_bar($start, $total)
   {
      global $template, $user;

      adm_page_header($user->lang['SYNC_IN_PROGRESS']);

      $template->set_filenames(array(
         'body'   => 'progress_bar.html')
      );

      $template->assign_vars(array(
         'L_PROGRESS'         => $user->lang['SYNC_IN_PROGRESS'],
         'L_PROGRESS_EXPLAIN'   => ($start && $total) ? sprintf($user->lang['SYNC_IN_PROGRESS_EXPLAIN'], $start, $total) : $user->lang['SYNC_IN_PROGRESS'])
      );

      adm_page_footer();
   }
}

?>


Zurück zu „Support für phpBB 3.0.x MODs“

Wer ist online?

Mitglieder in diesem Forum: 0 Mitglieder und 1 Gast