Dotclear

source: admin/posts.php @ 3105:5411dc9bea4a

Revision 3105:5411dc9bea4a, 10.3 KB checked in by franck <carnet.franck.paul@…>, 10 years ago (diff)

Users (lists) are now sorted in lexical order as far as possible, addresses #1850

Line 
1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
6# Copyright (c) 2003-2013 Olivier Meunier & Association Dotclear
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
49     $users_combo = dcAdminCombos::getUsersCombo($users);
50     dcUtils::lexicalKeySort($users_combo);
51     $users_combo = array_merge(
52          array('-' => ''),
53          $users_combo
54     );
55
56     $categories_combo = array_merge(
57          array(
58               new formSelectOption('-',''),
59               new formSelectOption(__('(No cat)'),'NULL')),
60          dcAdminCombos::getCategoriesCombo($categories,false)
61     );
62     $categories_values = array();
63     foreach ($categories_combo as $cat) {
64          if (isset($cat->value)) {
65               $categories_values[$cat->value]=true;
66          }
67     }
68
69     $status_combo = array_merge(
70          array('-' => ''),
71          dcAdminCombos::getPostStatusesCombo()
72     );
73
74     $selected_combo = array(
75     '-' => '',
76     __('Selected') => '1',
77     __('Not selected') => '0'
78     );
79
80     $attachment_combo = array(
81     '-' => '',
82     __('With attachments') => '1',
83     __('Without attachments') => '0'
84     );
85
86     $password_combo = array(
87     '-' => '',
88     __('With password') => '1',
89     __('Without password') => '0'
90     );
91
92     # Months array
93     $dt_m_combo = array_merge(
94          array('-' => ''),
95          dcAdminCombos::getDatesCombo($dates)
96     );
97
98     $lang_combo = array_merge(
99          array('-' => ''),
100          dcAdminCombos::getLangsCombo($langs,false)
101     );
102
103     # Post formats
104     $core_formaters = $core->getFormaters();
105     $available_formats = array();
106     foreach ($core_formaters as $editor => $formats) {
107          foreach ($formats as $format) {
108               $available_formats[$format] = $format;
109          }
110     }
111     $format_combo = array_merge(
112          array('-' => ''),
113          $available_formats
114     );
115
116     $sortby_combo = array(
117     __('Date') => 'post_dt',
118     __('Title') => 'post_title',
119     __('Category') => 'cat_title',
120     __('Author') => 'user_id',
121     __('Status') => 'post_status',
122     __('Selected') => 'post_selected',
123     __('Number of comments') => 'nb_comment',
124     __('Number of trackbacks') => 'nb_trackback'
125     );
126
127     $order_combo = array(
128     __('Descending') => 'desc',
129     __('Ascending') => 'asc'
130     );
131}
132
133# Actions combo box
134
135$posts_actions_page = new dcPostsActionsPage($core,$core->adminurl->get("admin.posts"));
136
137if ($posts_actions_page->process()) {
138     return;
139}
140
141/* Get posts
142-------------------------------------------------------- */
143$user_id = !empty($_GET['user_id']) ? $_GET['user_id'] : '';
144$cat_id = !empty($_GET['cat_id']) ? $_GET['cat_id'] : '';
145$status = isset($_GET['status']) ? $_GET['status'] : '';
146$password = isset($_GET['password']) ? $_GET['password'] : '';
147$selected = isset($_GET['selected']) ? $_GET['selected'] : '';
148$attachment = isset($_GET['attachment']) ? $_GET['attachment'] : '';
149$month = !empty($_GET['month']) ? $_GET['month'] : '';
150$lang = !empty($_GET['lang']) ?    $_GET['lang'] : '';
151$format = !empty($_GET['format']) ? $_GET['format'] : '';
152$sortby = !empty($_GET['sortby']) ?     $_GET['sortby'] : 'post_dt';
153$order = !empty($_GET['order']) ? $_GET['order'] : 'desc';
154
155$show_filters = false;
156
157$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
158$nb_per_page =  30;
159
160if (!empty($_GET['nb']) && (integer) $_GET['nb'] > 0) {
161     if ($nb_per_page != $_GET['nb']) {
162          $show_filters = true;
163     }
164     $nb_per_page = (integer) $_GET['nb'];
165}
166
167$params['limit'] = array((($page-1)*$nb_per_page),$nb_per_page);
168$params['no_content'] = true;
169$params['where'] = '';
170
171# - User filter
172if ($user_id !== '' && in_array($user_id,$users_combo)) {
173     $params['user_id'] = $user_id;
174     $show_filters = true;
175} else {
176     $user_id='';
177}
178
179# - Categories filter
180if ($cat_id !== '' && isset($categories_values[$cat_id])) {
181     $params['cat_id'] = $cat_id;
182     $show_filters = true;
183} else {
184     $cat_id='';
185}
186
187# - Status filter
188if ($status !== '' && in_array($status,$status_combo)) {
189     $params['post_status'] = $status;
190     $show_filters = true;
191} else {
192     $status='';
193}
194
195# - Password filter
196if ($password !== '' && in_array($password,$password_combo)) {
197     $params['where'] .= ' AND post_password IS '.($password ? 'NOT ' : '').'NULL ';
198     $show_filters = true;
199} else {
200     $password='';
201}
202
203# - Selected filter
204if ($selected !== '' && in_array($selected,$selected_combo)) {
205     $params['post_selected'] = $selected;
206     $show_filters = true;
207} else {
208     $selected='';
209}
210
211# - Attachment filter
212if ($attachment !== '' && in_array($attachment,$attachment_combo)) {
213     $params['media'] = $attachment;
214     $params['link_type'] = 'attachment';
215     $show_filters = true;
216} else {
217     $attachment='';
218}
219
220# - Month filter
221if ($month !== '' && in_array($month,$dt_m_combo)) {
222     $params['post_month'] = substr($month,4,2);
223     $params['post_year'] = substr($month,0,4);
224     $show_filters = true;
225} else {
226     $month='';
227}
228
229# - Lang filter
230if ($lang !== '' && in_array($lang,$lang_combo)) {
231     $params['post_lang'] = $lang;
232     $show_filters = true;
233} else {
234     $lang='';
235}
236
237# - Format filter
238if ($format !== '' && in_array($format,$format_combo)) {
239     $params['where'] .= " AND post_format = '".$format."' ";
240     $show_filters = true;
241} else {
242     $format='';
243}
244
245# - Sortby and order filter
246if ($sortby !== '' && in_array($sortby,$sortby_combo)) {
247     if ($order !== '' && in_array($order,$order_combo)) {
248          $params['order'] = $sortby.' '.$order;
249     } else {
250          $order='desc';
251     }
252
253     if ($sortby != 'post_dt' || $order != 'desc') {
254          $show_filters = true;
255     }
256} else {
257     $sortby='post_dt';
258     $order='desc';
259}
260
261# Get posts
262try {
263     $posts = $core->blog->getPosts($params);
264     $counter = $core->blog->getPosts($params,true);
265     $post_list = new adminPostList($core,$posts,$counter->f(0));
266} catch (Exception $e) {
267     $core->error->add($e->getMessage());
268}
269
270/* DISPLAY
271-------------------------------------------------------- */
272
273$form_filter_title = __('Show filters and display options');
274$starting_script  = dcPage::jsLoad('js/_posts_list.js');
275$starting_script .= dcPage::jsLoad('js/filter-controls.js');
276$starting_script .=
277     '<script type="text/javascript">'."\n".
278     "//<![CDATA["."\n".
279     dcPage::jsVar('dotclear.msg.show_filters', $show_filters ? 'true':'false')."\n".
280     dcPage::jsVar('dotclear.msg.filter_posts_list',$form_filter_title)."\n".
281     dcPage::jsVar('dotclear.msg.cancel_the_filter',__('Cancel filters and display options'))."\n".
282     "//]]>".
283     "</script>";
284
285dcPage::open(__('Entries'),$starting_script,
286     dcPage::breadcrumb(
287          array(
288               html::escapeHTML($core->blog->name) => '',
289               __('Entries') => ''
290          ))
291);
292if (!empty($_GET['upd'])) {
293     dcPage::success(__('Selected entries have been successfully updated.'));
294} elseif (!empty($_GET['del'])) {
295     dcPage::success(__('Selected entries have been successfully deleted.'));
296}
297if (!$core->error->flag())
298{
299     echo
300     '<p class="top-add"><a class="button add" href="'.$core->adminurl->get("admin.post").'">'.__('New entry').'</a></p>'.
301     '<form action="'.$core->adminurl->get("admin.posts").'" method="get" id="filters-form">'.
302     '<h3 class="out-of-screen-if-js">'.$form_filter_title.'</h3>'.
303
304     '<div class="table">'.
305     '<div class="cell">'.
306     '<h4>'.__('Filters').'</h4>'.
307     '<p><label for="user_id" class="ib">'.__('Author:').'</label> '.
308     form::combo('user_id',$users_combo,$user_id).'</p>'.
309     '<p><label for="cat_id" class="ib">'.__('Category:').'</label> '.
310     form::combo('cat_id',$categories_combo,$cat_id).'</p>'.
311     '<p><label for="status" class="ib">'.__('Status:').'</label> ' .
312     form::combo('status',$status_combo,$status).'</p> '.
313     '<p><label for="format" class="ib">'.__('Format:').'</label> '.
314     form::combo('format',$format_combo,$format).'</p>'.
315     '<p><label for="password" class="ib">'.__('Password:').'</label> '.
316     form::combo('password',$password_combo,$password).'</p>'.
317     '</div>'.
318
319     '<div class="cell filters-sibling-cell">'.
320     '<p><label for="selected" class="ib">'.__('Selected:').'</label> '.
321     form::combo('selected',$selected_combo,$selected).'</p>'.
322     '<p><label for="attachment" class="ib">'.__('Attachments:').'</label> '.
323     form::combo('attachment',$attachment_combo,$attachment).'</p>'.
324     '<p><label for="month" class="ib">'.__('Month:').'</label> '.
325     form::combo('month',$dt_m_combo,$month).'</p>'.
326     '<p><label for="lang" class="ib">'.__('Lang:').'</label> '.
327     form::combo('lang',$lang_combo,$lang).'</p> '.
328     '</div>'.
329
330     '<div class="cell filters-options">'.
331     '<h4>'.__('Display options').'</h4>'.
332     '<p><label for="sortby" class="ib">'.__('Order by:').'</label> '.
333     form::combo('sortby',$sortby_combo,$sortby).'</p>'.
334     '<p><label for="order" class="ib">'.__('Sort:').'</label> '.
335     form::combo('order',$order_combo,$order).'</p>'.
336     '<p><span class="label ib">'.__('Show').'</span> <label for="nb" class="classic">'.
337     form::field('nb',3,3,$nb_per_page).' '.
338     __('entries per page').'</label></p>'.
339     '</div>'.
340     '</div>'.
341
342     '<p><input type="submit" value="'.__('Apply filters and display options').'" />'.
343     '<br class="clear" /></p>'. //Opera sucks
344     '</form>';
345
346     # Show posts
347     $post_list->display($page,$nb_per_page,
348     '<form action="'.$core->adminurl->get("admin.posts").'" method="post" id="form-entries">'.
349
350     '%s'.
351
352     '<div class="two-cols">'.
353     '<p class="col checkboxes-helpers"></p>'.
354
355     '<p class="col right"><label for="action" class="classic">'.__('Selected entries action:').'</label> '.
356     form::combo('action',$posts_actions_page->getCombo()).
357     '<input type="submit" value="'.__('ok').'" /></p>'.
358     form::hidden(array('user_id'),$user_id).
359     form::hidden(array('cat_id'),$cat_id).
360     form::hidden(array('status'),$status).
361     form::hidden(array('password'),$password).
362     form::hidden(array('selected'),$selected).
363     form::hidden(array('attachment'),$attachment).
364     form::hidden(array('month'),$month).
365     form::hidden(array('lang'),$lang).
366     form::hidden(array('sortby'),$sortby).
367     form::hidden(array('order'),$order).
368     form::hidden(array('page'),$page).
369     form::hidden(array('nb'),$nb_per_page).
370     $core->formNonce().
371     '</div>'.
372     '</form>',
373     $show_filters
374     );
375}
376
377dcPage::helpBlock('core_posts');
378dcPage::close();
Note: See TracBrowser for help on using the repository browser.

Sites map