Dotclear

source: admin/posts.php @ 2305:a767405b570f

Revision 2305:a767405b570f, 8.4 KB checked in by franck <carnet.franck.paul@…>, 12 years ago (diff)

Add "number of comments" and "number of trackbacks" in available orders in posts' list

RevLine 
[0]1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
[1179]6# Copyright (c) 2003-2013 Olivier Meunier & Association Dotclear
[0]7# Licensed under the GPL version 2.0 license.
8# See LICENSE file or
9# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
10#
11# -- END LICENSE BLOCK -----------------------------------------
12
13require dirname(__FILE__).'/../inc/admin/prepend.php';
14
15dcPage::check('usage,contentadmin');
16
17# Getting categories
18try {
19     $categories = $core->blog->getCategories(array('post_type'=>'post'));
20} catch (Exception $e) {
21     $core->error->add($e->getMessage());
22}
23
24# Getting authors
25try {
26     $users = $core->blog->getPostsUsers();
27} catch (Exception $e) {
28     $core->error->add($e->getMessage());
29}
30
31# Getting dates
32try {
33     $dates = $core->blog->getDates(array('type'=>'month'));
34} catch (Exception $e) {
35     $core->error->add($e->getMessage());
36}
37
38# Getting langs
39try {
40     $langs = $core->blog->getLangs();
41} catch (Exception $e) {
42     $core->error->add($e->getMessage());
43}
44
45# Creating filter combo boxes
46if (!$core->error->flag())
47{
48     # Filter form we'll put in html_block
[1719]49     $users_combo = array_merge(
50          array('-' => ''),
51          dcAdminCombos::getUsersCombo($users)
52     );
53
54     $categories_combo = array_merge(
[1775]55          array(
56               new formSelectOption('-',''),
57               new formSelectOption(__('(No cat)'),'NULL')),         
58          dcAdminCombos::getCategoriesCombo($categories,false)
[1719]59     );
[1775]60     $categories_values = array();
61     foreach ($categories_combo as $cat) {
62          if (isset($cat->value)) {
63               $categories_values[$cat->value]=true;
[0]64          }
65     }
66     
[1719]67     $status_combo = array_merge(
68          array('-' => ''),
69          dcAdminCombos::getPostStatusesCombo()   
[0]70     );
71     
72     $selected_combo = array(
73     '-' => '',
[1353]74     __('Selected') => '1',
75     __('Not selected') => '0'
[0]76     );
77     
78     # Months array
[1719]79     $dt_m_combo = array_merge(
80          array('-' => ''),
81          dcAdminCombos::getDatesCombo($dates)
82     );
[0]83     
[1719]84     $lang_combo = array_merge(
85          array('-' => ''),
86          dcAdminCombos::getLangsCombo($langs,false)   
87     );
[0]88     
89     $sortby_combo = array(
90     __('Date') => 'post_dt',
91     __('Title') => 'post_title',
92     __('Category') => 'cat_title',
93     __('Author') => 'user_id',
94     __('Status') => 'post_status',
[2305]95     __('Selected') => 'post_selected',
96     __('Number of comments') => 'nb_comment',
97     __('Number of trackbacks') => 'nb_trackback'
[0]98     );
99     
100     $order_combo = array(
101     __('Descending') => 'desc',
102     __('Ascending') => 'asc'
103     );
104}
105
106# Actions combo box
107
[1806]108$posts_actions_page = new dcPostsActionsPage($core,'posts.php');
[1796]109
[2072]110if ($posts_actions_page->process()) {
111     return;
112}
[0]113
[2072]114/* Get posts
115-------------------------------------------------------- */
116$user_id = !empty($_GET['user_id']) ?   $_GET['user_id'] : '';
117$cat_id = !empty($_GET['cat_id']) ?     $_GET['cat_id'] : '';
118$status = isset($_GET['status']) ? $_GET['status'] : '';
119$selected = isset($_GET['selected']) ?  $_GET['selected'] : '';
120$month = !empty($_GET['month']) ?       $_GET['month'] : '';
121$lang = !empty($_GET['lang']) ?         $_GET['lang'] : '';
122$sortby = !empty($_GET['sortby']) ?     $_GET['sortby'] : 'post_dt';
123$order = !empty($_GET['order']) ?       $_GET['order'] : 'desc';
[0]124
[2072]125$show_filters = false;
[0]126
[2072]127$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
128$nb_per_page =  30;
[0]129
[2072]130if (!empty($_GET['nb']) && (integer) $_GET['nb'] > 0) {
131     if ($nb_per_page != $_GET['nb']) {
132          $show_filters = true;
[2048]133     }
[2072]134     $nb_per_page = (integer) $_GET['nb'];
135}
[2048]136
[2072]137$params['limit'] = array((($page-1)*$nb_per_page),$nb_per_page);
138$params['no_content'] = true;
[2048]139
[2072]140# - User filter
141if ($user_id !== '' && in_array($user_id,$users_combo)) {
142     $params['user_id'] = $user_id;
143     $show_filters = true;
144} else {
145     $user_id='';
146}
147
148# - Categories filter
149if ($cat_id !== '' && isset($categories_values[$cat_id])) {
150     $params['cat_id'] = $cat_id;
151     $show_filters = true;
152} else {
153     $cat_id='';
154}
155
156# - Status filter
157if ($status !== '' && in_array($status,$status_combo)) {
158     $params['post_status'] = $status;
159     $show_filters = true;
160} else {
161     $status='';
162}
163
164# - Selected filter
165if ($selected !== '' && in_array($selected,$selected_combo)) {
166     $params['post_selected'] = $selected;
167     $show_filters = true;
168} else {
169     $selected='';
170}
171
172# - Month filter
173if ($month !== '' && in_array($month,$dt_m_combo)) {
174     $params['post_month'] = substr($month,4,2);
175     $params['post_year'] = substr($month,0,4);
176     $show_filters = true;
177} else {
178     $month='';
179}
180
181# - Lang filter
182if ($lang !== '' && in_array($lang,$lang_combo)) {
183     $params['post_lang'] = $lang;
184     $show_filters = true;
185} else {
186     $lang='';
187}
188
189# - Sortby and order filter
190if ($sortby !== '' && in_array($sortby,$sortby_combo)) {
191     if ($order !== '' && in_array($order,$order_combo)) {
192          $params['order'] = $sortby.' '.$order;
[2048]193     } else {
[796]194          $order='desc';
[0]195     }
[2072]196     
197     if ($sortby != 'post_dt' || $order != 'desc') {
198          $show_filters = true;
199     }
200} else {
201     $sortby='post_dt';
202     $order='desc';
203}
[2048]204
[2072]205# Get posts
206try {
207     $posts = $core->blog->getPosts($params);
208     $counter = $core->blog->getPosts($params,true);
209     $post_list = new adminPostList($core,$posts,$counter->f(0));
210} catch (Exception $e) {
211     $core->error->add($e->getMessage());
212}
213
214/* DISPLAY
215-------------------------------------------------------- */
[2136]216
[2145]217$form_filter_title = __('Show filters and display options');
[2135]218$starting_script  = dcPage::jsLoad('js/_posts_list.js');
219$starting_script .= dcPage::jsLoad('js/filter-controls.js');
220$starting_script .=
221     '<script type="text/javascript">'."\n".
222     "//<![CDATA["."\n".
223     dcPage::jsVar('dotclear.msg.show_filters', $show_filters ? 'true':'false')."\n".
224     dcPage::jsVar('dotclear.msg.filter_posts_list',$form_filter_title)."\n".
[2145]225     dcPage::jsVar('dotclear.msg.cancel_the_filter',__('Cancel filters and display options'))."\n".
[2135]226     "//]]>".
227     "</script>";
[2072]228
[2135]229dcPage::open(__('Entries'),$starting_script,
[2072]230     dcPage::breadcrumb(
231          array(
232               html::escapeHTML($core->blog->name) => '',
[2166]233               __('Entries') => ''
[2072]234          ))
235);
236if (!empty($_GET['upd'])) {
237     dcPage::success(__('Selected entries have been successfully updated.'));
238} elseif (!empty($_GET['del'])) {
239     dcPage::success(__('Selected entries have been successfully deleted.'));
240}
241if (!$core->error->flag())
242{
243     echo
[2134]244     '<p class="top-add"><a class="button add" href="post.php">'.__('New entry').'</a></p>'.
[2072]245     '<form action="posts.php" method="get" id="filters-form">'.
[2135]246     '<h3 class="out-of-screen-if-js">'.$form_filter_title.'</h3>'.
[2048]247
[2072]248     '<div class="table">'.
249     '<div class="cell">'.
250     '<h4>'.__('Filters').'</h4>'.
251     '<p><label for="user_id" class="ib">'.__('Author:').'</label> '.
252     form::combo('user_id',$users_combo,$user_id).'</p>'.
253     '<p><label for="cat_id" class="ib">'.__('Category:').'</label> '.
254     form::combo('cat_id',$categories_combo,$cat_id).'</p>'.
255     '<p><label for="status" class="ib">'.__('Status:').'</label> ' .
256     form::combo('status',$status_combo,$status).'</p> '.
257     '</div>'.
258     
259     '<div class="cell filters-sibling-cell">'.
260     '<p><label for="selected" class="ib">'.__('Selected:').'</label> '.
261     form::combo('selected',$selected_combo,$selected).'</p>'.
262     '<p><label for="month" class="ib">'.__('Month:').'</label> '.
263     form::combo('month',$dt_m_combo,$month).'</p>'.
264     '<p><label for="lang" class="ib">'.__('Lang:').'</label> '.
265     form::combo('lang',$lang_combo,$lang).'</p> '.
266     '</div>'.
267     
268     '<div class="cell filters-options">'.
269     '<h4>'.__('Display options').'</h4>'.
270     '<p><label for="sortby" class="ib">'.__('Order by:').'</label> '.
271     form::combo('sortby',$sortby_combo,$sortby).'</p>'.
272     '<p><label for="order" class="ib">'.__('Sort:').'</label> '.
273     form::combo('order',$order_combo,$order).'</p>'.
274     '<p><span class="label ib">'.__('Show').'</span> <label for="nb" class="classic">'.
275     form::field('nb',3,3,$nb_per_page).' '.
276     __('entries per page').'</label></p>'.
277     '</div>'.
278     '</div>'.
[2048]279
[2072]280     '<p><input type="submit" value="'.__('Apply filters and display options').'" />'.
281     '<br class="clear" /></p>'. //Opera sucks
282     '</form>';
283     
284     # Show posts
285     $post_list->display($page,$nb_per_page,
286     '<form action="posts.php" method="post" id="form-entries">'.
287     
288     '%s'.
289     
290     '<div class="two-cols">'.
291     '<p class="col checkboxes-helpers"></p>'.
292     
293     '<p class="col right"><label for="action" class="classic">'.__('Selected entries action:').'</label> '.
294     form::combo('action',$posts_actions_page->getCombo()).
295     '<input type="submit" value="'.__('ok').'" /></p>'.
296     form::hidden(array('user_id'),$user_id).
297     form::hidden(array('cat_id'),$cat_id).
298     form::hidden(array('status'),$status).
299     form::hidden(array('selected'),$selected).
300     form::hidden(array('month'),$month).
301     form::hidden(array('lang'),$lang).
302     form::hidden(array('sortby'),$sortby).
303     form::hidden(array('order'),$order).
304     form::hidden(array('page'),$page).
305     form::hidden(array('nb'),$nb_per_page).
306     $core->formNonce().
307     '</div>'.
[2134]308     '</form>',
309     $show_filters
[2048]310     );
[2072]311}
[2048]312
[2072]313dcPage::helpBlock('core_posts');
314dcPage::close();
[2048]315
[795]316?>
Note: See TracBrowser for help on using the repository browser.

Sites map