home *** CD-ROM | disk | FTP | other *** search
/ Cricao de Sites - 650 Layouts Prontos / WebMasters.iso / CMS / drupal-6.0.exe / drupal-6.0 / modules / forum / forum.admin.inc < prev    next >
Encoding:
Text File  |  2008-01-30  |  10.5 KB  |  294 lines

  1. <?php
  2. // $Id: forum.admin.inc,v 1.8 2008/01/30 10:14:42 goba Exp $
  3.  
  4. /**
  5.  * @file
  6.  * Administrative page callbacks for the forum module.
  7.  */
  8.  
  9. function forum_form_main($type, $edit = array()) {
  10.   if ((isset($_POST['op']) && $_POST['op'] == t('Delete')) || !empty($_POST['confirm'])) {
  11.     return drupal_get_form('forum_confirm_delete', $edit['tid']);
  12.   }
  13.   switch ($type) {
  14.     case 'forum':
  15.       return drupal_get_form('forum_form_forum', $edit);
  16.       break;
  17.     case 'container':
  18.       return drupal_get_form('forum_form_container', $edit);
  19.       break;
  20.   }
  21. }
  22.  
  23. /**
  24.  * Returns a form for adding a forum to the forum vocabulary
  25.  *
  26.  * @param $edit Associative array containing a forum term to be added or edited.
  27.  * @ingroup forms
  28.  * @see forum_form_submit()
  29.  */
  30. function forum_form_forum(&$form_state, $edit = array()) {
  31.   $edit += array(
  32.     'name' => '',
  33.     'description' => '',
  34.     'tid' => NULL,
  35.     'weight' => 0,
  36.   );
  37.   $form['name'] = array('#type' => 'textfield',
  38.     '#title' => t('Forum name'),
  39.     '#default_value' => $edit['name'],
  40.     '#maxlength' => 255,
  41.     '#description' => t('Short but meaningful name for this collection of threaded discussions.'),
  42.     '#required' => TRUE,
  43.   );
  44.   $form['description'] = array('#type' => 'textarea',
  45.     '#title' => t('Description'),
  46.     '#default_value' => $edit['description'],
  47.     '#description' => t('Description and guidelines for discussions within this forum.'),
  48.   );
  49.   $form['parent']['#tree'] = TRUE;
  50.   $form['parent'][0] = _forum_parent_select($edit['tid'], t('Parent'), 'forum');
  51.   $form['weight'] = array('#type' => 'weight',
  52.     '#title' => t('Weight'),
  53.     '#default_value' => $edit['weight'],
  54.     '#description' => t('Forums are displayed in ascending order by weight (forums with equal weights are displayed alphabetically).'),
  55.   );
  56.  
  57.   $form['vid'] = array('#type' => 'hidden', '#value' => variable_get('forum_nav_vocabulary', ''));
  58.   $form['submit' ] = array('#type' => 'submit', '#value' => t('Save'));
  59.   if ($edit['tid']) {
  60.     $form['delete'] = array('#type' => 'submit', '#value' => t('Delete'));
  61.     $form['tid'] = array('#type' => 'hidden', '#value' => $edit['tid']);
  62.   }
  63.   $form['#submit'][] = 'forum_form_submit';
  64.   $form['#theme'] = 'forum_form';
  65.  
  66.   return $form;
  67. }
  68.  
  69. /**
  70.  * Process forum form and container form submissions.
  71.  */
  72. function forum_form_submit($form, &$form_state) {
  73.   if ($form['form_id']['#value'] == 'forum_form_container') {
  74.     $container = TRUE;
  75.     $type = t('forum container');
  76.   }
  77.   else {
  78.     $container = FALSE;
  79.     $type = t('forum');
  80.   }
  81.  
  82.   $status = taxonomy_save_term($form_state['values']);
  83.   switch ($status) {
  84.     case SAVED_NEW:
  85.       if ($container) {
  86.         $containers = variable_get('forum_containers', array());
  87.         $containers[] = $form_state['values']['tid'];
  88.         variable_set('forum_containers', $containers);
  89.       }
  90.       drupal_set_message(t('Created new @type %term.', array('%term' => $form_state['values']['name'], '@type' => $type)));
  91.       break;
  92.     case SAVED_UPDATED:
  93.       drupal_set_message(t('The @type %term has been updated.', array('%term' => $form_state['values']['name'], '@type' => $type)));
  94.       break;
  95.   }
  96.   $form_state['redirect'] = 'admin/content/forum';
  97.   return;
  98. }
  99.  
  100. /**
  101.  * Returns a form for adding a container to the forum vocabulary
  102.  *
  103.  * @param $edit Associative array containing a container term to be added or edited.
  104.  * @ingroup forms
  105.  * @see forum_form_submit()
  106.  */
  107. function forum_form_container(&$form_state, $edit = array()) {
  108.   $edit += array(
  109.     'name' => '',
  110.     'description' => '',
  111.     'tid' => NULL,
  112.     'weight' => 0,
  113.   );
  114.   // Handle a delete operation.
  115.   $form['name'] = array(
  116.     '#title' => t('Container name'),
  117.     '#type' => 'textfield',
  118.     '#default_value' => $edit['name'],
  119.     '#maxlength' => 255,
  120.     '#description' => t('Short but meaningful name for this collection of related forums.'),
  121.     '#required' => TRUE
  122.   );
  123.  
  124.   $form['description'] = array(
  125.     '#type' => 'textarea',
  126.     '#title' => t('Description'),
  127.     '#default_value' => $edit['description'],
  128.     '#description' => t('Description and guidelines for forums within this container.')
  129.   );
  130.   $form['parent']['#tree'] = TRUE;
  131.   $form['parent'][0] = _forum_parent_select($edit['tid'], t('Parent'), 'container');
  132.   $form['weight'] = array(
  133.     '#type' => 'weight',
  134.     '#title' => t('Weight'),
  135.     '#default_value' => $edit['weight'],
  136.     '#description' => t('Containers are displayed in ascending order by weight (containers with equal weights are displayed alphabetically).')
  137.   );
  138.  
  139.   $form['vid'] = array(
  140.     '#type' => 'hidden',
  141.     '#value' => variable_get('forum_nav_vocabulary', ''),
  142.   );
  143.   $form['submit'] = array(
  144.     '#type' => 'submit',
  145.     '#value' => t('Save')
  146.   );
  147.   if ($edit['tid']) {
  148.     $form['delete'] = array('#type' => 'submit', '#value' => t('Delete'));
  149.     $form['tid'] = array('#type' => 'value', '#value' => $edit['tid']);
  150.   }
  151.   $form['#submit'][] = 'forum_form_submit';
  152.   $form['#theme'] = 'forum_form';
  153.  
  154.   return $form;
  155. }
  156.  
  157. /**
  158.  * Returns a confirmation page for deleting a forum taxonomy term.
  159.  *
  160.  * @param $tid ID of the term to be deleted
  161.  */
  162. function forum_confirm_delete(&$form_state, $tid) {
  163.   $term = taxonomy_get_term($tid);
  164.  
  165.   $form['tid'] = array('#type' => 'value', '#value' => $tid);
  166.   $form['name'] = array('#type' => 'value', '#value' => $term->name);
  167.  
  168.   return confirm_form($form, t('Are you sure you want to delete the forum %name?', array('%name' => $term->name)), 'admin/content/forum', t('Deleting a forum or container will also delete its sub-forums, if any. To delete posts in this forum, visit <a href="@content">content administration</a> first. This action cannot be undone.', array('@content' => url('admin/content/node'))), t('Delete'), t('Cancel'));
  169. }
  170.  
  171. /**
  172.  * Implementation of forms api _submit call. Deletes a forum after confirmation.
  173.  */
  174. function forum_confirm_delete_submit($form, &$form_state) {
  175.   taxonomy_del_term($form_state['values']['tid']);
  176.   drupal_set_message(t('The forum %term and all sub-forums and associated posts have been deleted.', array('%term' => $form_state['values']['name'])));
  177.   watchdog('content', 'forum: deleted %term and all its sub-forums and associated posts.', array('%term' => $form_state['values']['name']));
  178.  
  179.   $form_state['redirect'] = 'admin/content/forum';
  180.   return;
  181. }
  182.  
  183. /**
  184.  * Form builder for the forum settings page.
  185.  *
  186.  * @see system_settings_form()
  187.  */
  188. function forum_admin_settings() {
  189.   $form = array();
  190.   $number = drupal_map_assoc(array(5, 10, 15, 20, 25, 30, 35, 40, 50, 60, 80, 100, 150, 200, 250, 300, 350, 400, 500));
  191.   $form['forum_hot_topic'] = array('#type' => 'select',
  192.     '#title' => t('Hot topic threshold'),
  193.     '#default_value' => variable_get('forum_hot_topic', 15),
  194.     '#options' => $number,
  195.     '#description' => t('The number of posts a topic must have to be considered "hot".'),
  196.   );
  197.   $number = drupal_map_assoc(array(10, 25, 50, 75, 100));
  198.   $form['forum_per_page'] = array('#type' => 'select',
  199.     '#title' => t('Topics per page'),
  200.     '#default_value' => variable_get('forum_per_page', 25),
  201.     '#options' => $number,
  202.     '#description' => t('Default number of forum topics displayed per page.'),
  203.   );
  204.   $forder = array(1 => t('Date - newest first'), 2 => t('Date - oldest first'), 3 => t('Posts - most active first'), 4 => t('Posts - least active first'));
  205.   $form['forum_order'] = array('#type' => 'radios',
  206.     '#title' => t('Default order'),
  207.     '#default_value' => variable_get('forum_order', '1'),
  208.     '#options' => $forder,
  209.     '#description' => t('Default display order for topics.'),
  210.   );
  211.   return system_settings_form($form);
  212. }
  213.  
  214. /**
  215.  * Returns an overview list of existing forums and containers
  216.  */
  217. function forum_overview(&$form_state) {
  218.   module_load_include('inc', 'taxonomy', 'taxonomy.admin');
  219.  
  220.   $vid = variable_get('forum_nav_vocabulary', '');
  221.   $vocabulary = taxonomy_vocabulary_load($vid);
  222.   $form = taxonomy_overview_terms($form_state, $vocabulary);
  223.   drupal_set_title('Forums');
  224.  
  225.   foreach (element_children($form) as $key) {
  226.     if (isset($form[$key]['#term'])) {
  227.       $term = $form[$key]['#term'];
  228.       $form[$key]['view']['#value'] = l($term['name'], 'forum/'. $term['tid']);
  229.       if (in_array($form[$key]['#term']['tid'], variable_get('forum_containers', array()))) {
  230.         $form[$key]['edit']['#value'] = l(t('edit container'), 'admin/content/forum/edit/container/'. $term['tid']);
  231.       }
  232.       else {
  233.         $form[$key]['edit']['#value'] = l(t('edit forum'), 'admin/content/forum/edit/forum/'. $term['tid']);
  234.       }
  235.     }
  236.   }
  237.  
  238.   // Remove the alphabetical reset.
  239.   unset($form['reset_alphabetical']);
  240.  
  241.   // The form needs to have submit and validate handlers set explicitly.
  242.   $form['#theme'] = 'taxonomy_overview_terms';
  243.   $form['#submit'] = array('taxonomy_overview_terms_submit'); // Use the existing taxonomy overview submit handler.
  244.   $form['#validate'] = array('taxonomy_overview_terms_validate');
  245.   $form['#empty_text'] = '<em>'. t('There are no existing containers or forums. Containers and forums may be added using the <a href="@container">add container</a> and <a href="@forum">add forum</a> pages.', array('@container' => url('admin/content/forum/add/container'), '@forum' => url('admin/content/forum/add/forum'))) .'</em>';
  246.   return $form;
  247. }
  248.  
  249. /**
  250.  * Returns a select box for available parent terms
  251.  *
  252.  * @param $tid ID of the term which is being added or edited
  253.  * @param $title Title to display the select box with
  254.  * @param $child_type Whether the child is forum or container
  255.  */
  256. function _forum_parent_select($tid, $title, $child_type) {
  257.  
  258.   $parents = taxonomy_get_parents($tid);
  259.   if ($parents) {
  260.     $parent = array_shift($parents);
  261.     $parent = $parent->tid;
  262.   }
  263.   else {
  264.     $parent = 0;
  265.   }
  266.  
  267.   $vid = variable_get('forum_nav_vocabulary', '');
  268.   $children = taxonomy_get_tree($vid, $tid);
  269.  
  270.   // A term can't be the child of itself, nor of its children.
  271.   foreach ($children as $child) {
  272.     $exclude[] = $child->tid;
  273.   }
  274.   $exclude[] = $tid;
  275.  
  276.   $tree = taxonomy_get_tree($vid);
  277.   $options[0] = '<'. t('root') .'>';
  278.   if ($tree) {
  279.     foreach ($tree as $term) {
  280.       if (!in_array($term->tid, $exclude)) {
  281.         $options[$term->tid] = str_repeat(' -- ', $term->depth) . $term->name;
  282.       }
  283.     }
  284.   }
  285.   if ($child_type == 'container') {
  286.     $description = t('Containers are usually placed at the top (root) level, but may also be placed inside another container or forum.');
  287.   }
  288.   else if ($child_type == 'forum') {
  289.     $description = t('Forums may be placed at the top (root) level, or inside another container or forum.');
  290.   }
  291.  
  292.   return array('#type' => 'select', '#title' => $title, '#default_value' => $parent, '#options' => $options, '#description' => $description, '#required' => TRUE);
  293. }
  294.