Dotclear

source: admin/categories.php @ 2709:d70f7e2cb2c9

Revision 2709:d70f7e2cb2c9, 6.6 KB checked in by Dsls, 11 years ago (diff)

Strenghened xmlrpc auth, categories warning.

Many, many thanks to Egidio Romano for the advice.

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('categories');
16
17# Remove a categories
18if (!empty($_POST['delete'])) {
19     $keys = array_keys($_POST['delete']);
20     $cat_id = (int) $keys[0];
21
22     # Check if category to delete exists
23     $c = $core->blog->getCategory((integer) $cat_id);
24     if ($c->isEmpty()) {
25          dcPage::addErrorNotice(__('This category does not exist.'));
26          http::redirect('categories.php');
27     }
28     $name = $c->cat_title;
29     unset($c);
30
31     try {
32          # Delete category
33          $core->blog->delCategory($cat_id);
34          dcPage::addSuccessNotice(sprintf(__('The category "%s" has been successfully deleted.'),html::escapeHTML($name)));
35          http::redirect('categories.php');
36     } catch (Exception $e) {
37          $core->error->add($e->getMessage());
38     }
39}
40
41# move post into a category
42if (!empty($_POST['mov']) && !empty($_POST['mov_cat'])) {
43     try {
44          # Check if category where to move posts exists
45          $keys = array_keys($_POST['mov']);
46          $cat_id = (int) $keys[0];
47          $mov_cat = (int) $_POST['mov_cat'][$cat_id];
48
49          $mov_cat = $mov_cat ? $mov_cat : null;
50          if ($mov_cat !== null) {
51               $c = $core->blog->getCategory($mov_cat);
52               if ($c->isEmpty()) {
53                    throw new Exception(__('Category where to move posts does not exist'));
54               }
55               $name = $c->cat_title;
56               unset($c);
57          }
58          # Move posts
59          if ($mov_cat != $cat_id) {
60               $core->blog->changePostsCategory($cat_id,$mov_cat);
61          }
62          dcPage::addSuccessNotice(sprintf(__('The entries have been successfully moved to category "%s"'),
63               html::escapeHTML($name)));
64          http::redirect('categories.php');
65     } catch (Exception $e) {
66          $core->error->add($e->getMessage());
67     }
68}
69
70# Update order
71if (!empty($_POST['save_order']) && !empty($_POST['categories_order'])) {
72     $categories = json_decode($_POST['categories_order']);
73
74     foreach ($categories as $category) {
75          if (!empty($category->item_id) && !empty($category->left) && !empty($category->right)) {
76               $core->blog->updCategoryPosition($category->item_id, $category->left, $category->right);
77          }
78     }
79
80     dcPage::addSuccessNotice(__('Categories have been successfully reordered.'));
81     http::redirect('categories.php');
82}
83
84# Reset order
85if (!empty($_POST['reset']))
86{
87     try
88     {
89          $core->blog->resetCategoriesOrder();
90          dcPage::addSuccessNotice(__('Categories order has been successfully reset.'));
91          http::redirect('categories.php');
92     }
93     catch (Exception $e)
94     {
95          $core->error->add($e->getMessage());
96     }
97}
98
99
100/* Display
101-------------------------------------------------------- */
102$rs = $core->blog->getCategories(array('post_type'=>'post'));
103
104$starting_script = "";
105
106$core->auth->user_prefs->addWorkspace('accessibility');
107if (!$core->auth->user_prefs->accessibility->nodragdrop
108     && $core->auth->check('categories',$core->blog->id)
109     && $rs->count()>1) {
110          $starting_script .= dcPage::jsLoad('js/jquery/jquery-ui.custom.js');
111          $starting_script .= dcPage::jsLoad('js/jquery/jquery.mjs.nestedSortable.js');
112}
113$starting_script .= dcPage::jsLoad('js/_categories.js');
114
115dcPage::open(__('Categories'),$starting_script,
116     dcPage::breadcrumb(
117          array(
118               html::escapeHTML($core->blog->name) => '',
119               __('Categories') => ''
120          ))
121);
122
123if (!empty($_GET['del'])) {
124     dcPage::success(__('The category has been successfully removed.'));
125}
126if (!empty($_GET['reord'])) {
127     dcPage::success(__('Categories have been successfully reordered.'));
128}
129if (!empty($_GET['move'])) {
130     dcPage::success(__('Entries have been successfully moved to the category you choose.'));
131}
132
133$categories_combo = dcAdminCombos::getCategoriesCombo($rs);
134
135echo
136'<p class="top-add"><a class="button add" href="category.php">'.__('New category').'</a></p>';
137
138echo
139'<div class="col">';
140if ($rs->isEmpty())
141{
142     echo '<p>'.__('No category so far.').'</p>';
143}
144else
145{
146     echo
147     '<form action="categories.php" method="post" id="form-categories">'.
148     '<div id="categories">';
149
150     $ref_level = $level = $rs->level-1;
151     while ($rs->fetch())
152     {
153          $attr = 'id="cat_'.$rs->cat_id.'" class="cat-line clearfix"';
154
155          if ($rs->level > $level) {
156               echo str_repeat('<ul><li '.$attr.'>',$rs->level - $level);
157          } elseif ($rs->level < $level) {
158               echo str_repeat('</li></ul>',-($rs->level - $level));
159          }
160
161          if ($rs->level <= $level) {
162               echo '</li><li '.$attr.'>';
163          }
164
165          echo
166          '<p class="cat-title"><label class="classic" for="cat_'.$rs->cat_id.'"><a href="category.php?id='.$rs->cat_id.'">'.html::escapeHTML($rs->cat_title).'</a></label> </p>'.
167          '<p class="cat-nb-posts">(<a href="posts.php?cat_id='.$rs->cat_id.'">'.
168          sprintf(($rs->nb_post > 1 ? __('%d entries') : __('%d entry') ),$rs->nb_post).'</a>'.
169          ', '.__('total:').' '.$rs->nb_total.')</p>'.
170          '<p class="cat-url">'.__('URL:').' <code>'.html::escapeHTML($rs->cat_url).'</code></p>';
171
172          echo
173          '<p class="cat-buttons">';
174          if ($rs->nb_total>0) {
175               // remove current category
176               echo
177               '<label>'.__('Move entries to').'</label> '.
178               form::combo(array('mov_cat['.$rs->cat_id.']', 'mov_cat_'.$rs->cat_id),array_filter($categories_combo, create_function('$cat', 'return $cat->value!=$GLOBALS[\'rs\']->cat_id;')),'','').
179               ' <input type="submit" class="reset" name="mov['.$rs->cat_id.']" value="'.__('OK').'"/>';
180
181               $attr_disabled = ' disabled="disabled"';
182               $input_class = 'disabled ';
183          } else {
184               $attr_disabled = '';
185               $input_class = '';
186          }
187          echo
188          ' <input type="submit"'.$attr_disabled.' class="'.$input_class.'delete" name="delete['.$rs->cat_id.']" value="'.__('Delete category').'"/>'.
189          '</p>';
190
191          $level = $rs->level;
192     }
193
194     if ($ref_level - $level < 0) {
195          echo str_repeat('</li></ul>',-($ref_level - $level));
196     }
197     echo
198     '</div>';
199
200     echo '<div class="clear">';
201
202     if ($core->auth->check('categories',$core->blog->id) && $rs->count()>1) {
203          if (!$core->auth->user_prefs->accessibility->nodragdrop) {
204               echo '<p class="form-note hidden-if-no-js">'.__('To rearrange categories order, move items by drag and drop, then click on “Save categories order” button.').'</p>';
205          }
206          echo
207          '<p><span class="hidden-if-no-js">'.
208          '<input type="hidden" id="categories_order" name="categories_order" value=""/>'.
209          '<input type="submit" name="save_order" id="save-set-order" value="'.__('Save categories order').'" />'.
210          '</span> ';
211     } else {
212          echo '<p>';
213     }
214
215     echo
216     '<input type="submit" class="reset" name="reset" value="'.__('Reorder all categories on the top level').'" />'.
217     $core->formNonce().'</p>'.
218     '</div></form>';
219}
220
221echo '</div>';
222
223dcPage::helpBlock('core_categories');
224dcPage::close();
Note: See TracBrowser for help on using the repository browser.

Sites map