*/ /* * Menu callback: content administration. */ function moderation_node_queue() { drupal_add_css(drupal_get_path('module', 'moderation') .'/moderation.css'); $settings = array('moderationType' => 'node'); drupal_add_js('jQuery.extend(Drupal.settings, '. drupal_to_js($settings) .')', 'inline'); drupal_add_js(drupal_get_path('module', 'moderation') .'/moderation.js'); $query = "SELECT n.*, u.name, u.uid, mm.status as moderate FROM {node} n INNER JOIN {users} u ON n.uid = u.uid LEFT JOIN {moderation_moderation} mm ON n.nid = mm.obj_id WHERE mm.obj_type = 'node' AND (mm.status IS NULL OR mm.status=0) AND n.type IN ('" . implode('\' ,\'', variable_get('moderation_moderated_types', array())) ."') ORDER BY n.created DESC, n.title ASC"; $result = pager_query(db_rewrite_sql($query), 50); $destination = drupal_get_destination(); while ($node = db_fetch_object($result)) { $query = "SELECT m.*, u.name FROM {moderation} m LEFT JOIN {users} u ON m.uid = u.uid WHERE m.obj_id=%d AND m.obj_type='node' ORDER BY m.created DESC LIMIT 1"; $moderation = db_fetch_object(db_query($query, $node->nid)); $token = drupal_get_token('node-'. $node->nid); $item = '
'; $item .= '
'; $item .= format_date($node->created, 'small') .' '; $item .= l($node->title, 'moderation/node/'. $node->nid .'/get/preview'); $item .= theme('mark', node_mark($node->nid, $node->changed)); if ($moderation) { $item .= '
'. t('(!user - !action - !date)', array('!user' => theme('username', (object) array('uid' => $moderation->uid, 'name' => $moderation->name)), '!action' => moderation_log_message($moderation->attribute, $moderation->status, $moderation->obj_type), '!date' => format_date($moderation->created, 'small'))) .'
'; } $item .= '
'; $item .= '
'; $item .= '
'; $item .= ' '. l(t('edit'), 'node/'. $node->nid .'/edit', array('query' => drupal_get_destination())) .''; $item .= ' '. t('By !user', array('!user' => theme('username', $node))) .''; $item .= ' '. check_plain(node_get_types('name', $node)) .''; $item .= ' '. l(($node->status ? t('published') : t('not published')), 'moderation/node/'. $node->nid .'/set/status', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-status-link-'. $node->nid, 'class' => 'moderation-status-link'))) .''; $item .= ' '. l(($node->promote ? t('promoted') : t('not promoted')), 'moderation/node/'. $node->nid .'/set/promote', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-promote-link-'. $node->nid, 'class' => 'moderation-promote-link'))) .''; $item .= ' '. l(($node->sticky ? t('sticky') : t('not sticky')), 'moderation/node/'. $node->nid .'/set/sticky', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-sticky-link-'. $node->nid, 'class' => 'moderation-sticky-link'))) .''; $item .= ' '. l(($node->moderate ? t('moderated') : t('not moderated')), 'moderation/node/'. $node->nid .'/set/moderate', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-moderate-link-'. $node->nid, 'class' => 'moderation-moderate-link'))) .''; $item .= '
'; $rows[] = array('data' => array( array( 'data' => $item, ), ) ); } if (!$rows) { $output = t('No posts available.'); } $output .= theme('table', array(), $rows); $output .= theme('pager', NULL, 50); return $output; } /** * Menu callback; present an administrative comment listing. */ function moderation_comment_queue() { drupal_add_css(drupal_get_path('module', 'moderation') .'/moderation.css'); $settings = array('moderationType' => 'comment'); drupal_add_js('jQuery.extend(Drupal.settings, '. drupal_to_js($settings) .')', 'inline'); drupal_add_js(drupal_get_path('module', 'moderation') .'/moderation.js'); $query = "SELECT c.*, mm.status as moderate FROM {comments} c LEFT JOIN {moderation_moderation} mm ON c.cid = mm.obj_id WHERE mm.obj_type = 'comment' AND (mm.status IS NULL OR mm.status=0) ORDER BY c.timestamp DESC, c.subject ASC"; $result = pager_query(db_rewrite_sql($query), 50); $destination = drupal_get_destination(); while ($comment = db_fetch_object($result)) { $query = "SELECT m.*, u.name FROM {moderation} m LEFT JOIN {users} u ON m.uid = u.uid WHERE m.obj_id=%d AND m.obj_type='comment' ORDER BY m.created DESC LIMIT 1"; $moderation = db_fetch_object(db_query($query, $comment->cid)); $token = drupal_get_token('comment-'. $comment->cid); $item = '
'; $item .= '
'; $item .= format_date($comment->timestamp, 'small') .' '; $item .= l($comment->subject, 'moderation/comment/'. $comment->cid .'/get/preview'); $item .= theme('mark', node_mark($comment->cid, $comment->changed)); if ($moderation) { $item .= '
'. t('(!user - !action - !date)', array('!user' => theme('username', (object) array('uid' => $moderation->uid, 'name' => $moderation->name)), '!action' => moderation_log_message($moderation->attribute, $moderation->status, $moderation->obj_type), '!date' => format_date($moderation->created, 'small'))) .'
'; } $item .= '
'; $item .= '
'; $item .= '
'; $item .= ' '. l(t('edit'), 'comment/edit/'. $comment->cid, array('query' => drupal_get_destination())) .''; $item .= ' '. t('By !user', array('!user' => theme('username', $comment))) .''; $item .= ' '. l(($comment->moderate ? t('moderated') : t('not moderated')), 'moderation/comment/'. $comment->cid .'/set/moderate', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-moderate-link-'. $comment->cid, 'class' => 'moderation-moderate-link'))) .''; $item .= ' '. l(($comment->status ? t('not published') : t('published')), 'moderation/comment/'. $comment->cid .'/set/status', array('query' => drupal_get_destination() .'&token='. $token, 'attributes' => array('id' => 'moderation-status-link-'. $comment->cid, 'class' => 'moderation-status-link'))) .''; $item .= '
'; $rows[] = array('data' => array( array( 'data' => $item, ), ) ); } if (!$rows) { $output = t('No comments available.'); } $output .= theme('table', array(), $rows); $output .= theme('pager', NULL, 50); return $output; } function moderation_log($type = 'node', $obj_id = NULL) { switch ($type) { case 'comment': $sql = "SELECT m.*, c.nid, c.cid, c.subject, u.uid, u.name FROM {moderation} m LEFT JOIN {comments} c ON c.cid = m.obj_id LEFT JOIN {users} u ON u.uid = m.uid WHERE m.obj_type = 'comment' " . ($obj_id ? 'AND m.obj_id = ' . $obj_id : '') . " ORDER BY m.created DESC"; break; case 'node': $sql = "SELECT m.*, n.title, n.nid, u.uid, u.name FROM {moderation} m LEFT JOIN {node} n ON n.nid = m.obj_id LEFT JOIN {users} u ON u.uid = m.uid WHERE m.obj_type = 'node' " . ($obj_id ? 'AND m.obj_id = ' . $obj_id : '') . " ORDER BY m.created DESC"; break; } $result = pager_query($sql, 25, 0, NULL); while ($moderation = db_fetch_object($result)) { $title = $moderation->subject ? $moderation->subject : $moderation->title; $fragment = $moderation->cid ? 'comment-' . $moderation->cid : NULL; $user->uid = $moderation->uid; $user->name = $moderation->name; $moderations[] = array( l($title, 'node/' . $moderation->nid, array('fragment' => $fragment)), theme('username', $user), moderation_log_message($moderation->attribute, $moderation->status, $type), format_date($moderation->created), ); } $header = array( t('Title'), t('User'), t('Action'), t('Date'), ); $output = theme('table', $header, $moderations); $output .= theme('pager'); return $output; } function moderation_log_message($attribute, $status, $type) { switch ($attribute) { case 'status': $message = $status ? t('Published') : t('Unpublished'); break; case 'moderate': $message = $status ? t('Moderated') : t('Unmoderated'); break; case 'sticky': $message = $status ? t('Made sticky') : t('Removed stickyness'); break; case 'promote': $message = $status ? t('Promoted') : t('Not promoted'); break; } return $message; }