Dotclear

source: plugins/blogroll/index.php @ 1504:fa3e0be80137

Revision 1504:fa3e0be80137, 10.0 KB checked in by Denis Jean-Christian <contact@…>, 11 years ago (diff)

Fix html validation on blogroll plugin, fixes #1572

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 -----------------------------------------
12if (!defined('DC_CONTEXT_ADMIN')) { return; }
13
14$blogroll = new dcBlogroll($core->blog);
15
16if (!empty($_REQUEST['edit']) && !empty($_REQUEST['id'])) {
17     include dirname(__FILE__).'/edit.php';
18     return;
19}
20
21$default_tab = '';
22$link_title = $link_href = $link_desc = $link_lang = '';
23$cat_title = '';
24
25# Import links
26if (!empty($_POST['import_links']) && !empty($_FILES['links_file']))
27{
28     $default_tab = 'import-links';
29     
30     try
31     {
32          files::uploadStatus($_FILES['links_file']);
33          $ifile = DC_TPL_CACHE.'/'.md5(uniqid());
34          if (!move_uploaded_file($_FILES['links_file']['tmp_name'],$ifile)) {
35               throw new Exception(__('Unable to move uploaded file.'));
36          }
37         
38          require_once dirname(__FILE__).'/class.dc.importblogroll.php';
39          try {
40               $imported = dcImportBlogroll::loadFile($ifile);
41               @unlink($ifile);
42          } catch (Exception $e) {
43               @unlink($ifile);
44               throw $e;
45          }
46         
47         
48          if (empty($imported)) {
49               unset($imported);
50               throw new Exception(__('Nothing to import'));
51          }
52     }
53     catch (Exception $e)
54     {
55          $core->error->add($e->getMessage());
56     }
57}
58
59if (!empty($_POST['import_links_do'])) {
60     foreach ($_POST['entries'] as $idx) {
61          $link_title = $_POST['title'][$idx];
62          $link_href  = $_POST['url'][$idx];
63          $link_desc  = $_POST['desc'][$idx];
64          try {
65               $blogroll->addLink($link_title,$link_href,$link_desc,'');
66          } catch (Exception $e) {
67               $core->error->add($e->getMessage());
68               $default_tab = 'import-links';
69          }
70     }
71     http::redirect($p_url.'&importlinks=1');     
72}
73
74if (!empty($_POST['cancel_import'])) {
75     $core->error->add(__('Import operation cancelled.'));
76     $default_tab = 'import-links';     
77}
78
79# Add link
80if (!empty($_POST['add_link']))
81{
82     $link_title = $_POST['link_title'];
83     $link_href = $_POST['link_href'];
84     $link_desc = $_POST['link_desc'];
85     $link_lang = $_POST['link_lang'];
86     
87     try {
88          $blogroll->addLink($link_title,$link_href,$link_desc,$link_lang);
89          http::redirect($p_url.'&addlink=1');
90     } catch (Exception $e) {
91          $core->error->add($e->getMessage());
92          $default_tab = 'add-link';
93     }
94}
95
96# Add category
97if (!empty($_POST['add_cat']))
98{
99     $cat_title = $_POST['cat_title'];
100     
101     try {
102          $blogroll->addCategory($cat_title);
103          http::redirect($p_url.'&addcat=1');
104     } catch (Exception $e) {
105          $core->error->add($e->getMessage());
106          $default_tab = 'add-cat';
107     }
108}
109
110# Delete link
111if (!empty($_POST['removeaction']) && !empty($_POST['remove'])) {
112     foreach ($_POST['remove'] as $k => $v)
113     {
114          try {
115               $blogroll->delItem($v);
116          } catch (Exception $e) {
117               $core->error->add($e->getMessage());
118               break;
119          }
120     }
121     
122     if (!$core->error->flag()) {
123          http::redirect($p_url.'&removed=1');
124     }
125}
126
127# Order links
128$order = array();
129if (empty($_POST['links_order']) && !empty($_POST['order'])) {
130     $order = $_POST['order'];
131     asort($order);
132     $order = array_keys($order);
133} elseif (!empty($_POST['links_order'])) {
134     $order = explode(',',$_POST['links_order']);
135}
136
137if (!empty($_POST['saveorder']) && !empty($order))
138{
139     foreach ($order as $pos => $l) {
140          $pos = ((integer) $pos)+1;
141         
142          try {
143               $blogroll->updateOrder($l,$pos);
144          } catch (Exception $e) {
145               $core->error->add($e->getMessage());
146          }
147     }
148     
149     if (!$core->error->flag()) {
150          http::redirect($p_url.'&neworder=1');
151     }
152}
153
154
155# Get links
156try {
157     $rs = $blogroll->getLinks();
158} catch (Exception $e) {
159     $core->error->add($e->getMessage());
160}
161
162?>
163<html>
164<head>
165  <title><?php echo __('Blogroll'); ?></title>
166  <?php echo dcPage::jsConfirmClose('links-form','add-link-form','add-category-form'); ?>
167  <?php 
168     $core->auth->user_prefs->addWorkspace('accessibility');
169     if (!$core->auth->user_prefs->accessibility->nodragdrop) {
170     echo
171          dcPage::jsLoad('js/jquery/jquery-ui.custom.js').
172          dcPage::jsLoad('index.php?pf=blogroll/blogroll.js');
173     }
174  ?>
175  <?php echo dcPage::jsPageTabs($default_tab); ?>
176</head>
177
178<body>
179<h2><?php echo html::escapeHTML($core->blog->name); ?> &rsaquo; <span class="page-title"><?php echo __('Blogroll'); ?></span></h2>
180
181<?php
182if (!empty($_GET['neworder'])) {
183     dcPage::message(__('Items order has been successfully updated'));
184}
185
186if (!empty($_GET['removed'])) {
187     dcPage::message(__('Items have been successfully removed.'));
188}
189
190if (!empty($_GET['addlink'])) {
191     dcPage::message(__('Link has been successfully created.'));
192}
193
194if (!empty($_GET['addcat'])) {
195     dcPage::message(__('category has been successfully created.'));
196}
197
198if (!empty($_GET['importlinks'])) {
199     dcPage::message(__('links have been successfully imported.'));
200}
201?>
202
203<div class="multi-part" title="<?php echo __('Blogroll'); ?>">
204
205<?php if (!$rs->isEmpty()) { ?>
206
207<form action="plugin.php" method="post" id="links-form">
208<table class="maximal dragable">
209<thead>
210<tr>
211  <th colspan="3"><?php echo __('Title'); ?></th>
212  <th><?php echo __('Description'); ?></th>
213  <th><?php echo __('URL'); ?></th>
214  <th><?php echo __('Lang'); ?></th>
215</tr>
216</thead>
217<tbody id="links-list">
218<?php
219while ($rs->fetch())
220{
221     $position = (string) $rs->index()+1;
222     
223     echo
224     '<tr class="line" id="l_'.$rs->link_id.'">'.
225     '<td class="handle minimal">'.form::field(array('order['.$rs->link_id.']'),2,5,$position,'position','',false,'title="'.__('position').'"').'</td>'.
226     '<td class="minimal">'.form::checkbox(array('remove[]'),$rs->link_id,'','','',false,'title="'.__('select this link').'"').'</td>';
227     
228     
229     if ($rs->is_cat)
230     {
231          echo
232          '<td colspan="5"><strong><a href="'.$p_url.'&amp;edit=1&amp;id='.$rs->link_id.'">'.
233          html::escapeHTML($rs->link_desc).'</a></strong></td>';
234     }
235     else
236     {
237          echo
238          '<td><a href="'.$p_url.'&amp;edit=1&amp;id='.$rs->link_id.'">'.
239          html::escapeHTML($rs->link_title).'</a></td>'.
240          '<td>'.html::escapeHTML($rs->link_desc).'</td>'.
241          '<td>'.html::escapeHTML($rs->link_href).'</td>'.
242          '<td>'.html::escapeHTML($rs->link_lang).'</td>';
243     }
244     
245     echo '</tr>';
246}
247?>
248</tbody>
249</table>
250
251<div class="two-cols">
252<p class="col">
253<?php
254     echo 
255     form::hidden('links_order','').
256     form::hidden(array('p'),'blogroll').
257     $core->formNonce();
258?>
259<input type="submit" name="saveorder" value="<?php echo __('Save order'); ?>" /></p>
260<p class="col right"><input type="submit" class="delete" name="removeaction"
261      value="<?php echo __('Delete selected links'); ?>"
262      onclick="return window.confirm('
263      <?php echo html::escapeJS(__('Are you sure you want to delete selected links?')); ?>');" /></p>
264</div>
265</form>
266
267<?php
268} else {
269     echo '<div><p>'.__('The link list is empty.').'</p></div>';
270}
271?>
272
273</div>
274
275<?php
276echo
277'<div class="multi-part clear" id="add-link" title="'.__('Add a link').'">'.
278'<form action="plugin.php" method="post" id="add-link-form">'.
279'<fieldset><legend>'.__('Add a new link').'</legend>'.
280'<p class="col"><label for="link_title" class="required"><abbr title="'.__('Required field').'">*</abbr> '.__('Title:').' '.
281form::field('link_title',30,255,$link_title).
282'</label></p>'.
283
284'<p class="col"><label for="link_href" class="required"><abbr title="'.__('Required field').'">*</abbr> '.__('URL:').' '.
285form::field('link_href',30,255,$link_href).
286'</label></p>'.
287
288'<p class="col"><label for="link_desc">'.__('Description:').' '.
289form::field('link_desc',30,255,$link_desc).
290'</label></p>'.
291
292'<p class="col"><label for="link_lang">'.__('Language:').' '.
293form::field('link_lang',5,5,$link_lang).
294'</label></p>'.
295'<p>'.form::hidden(array('p'),'blogroll').
296$core->formNonce().
297'<input type="submit" name="add_link" value="'.__('Save').'" /></p>'.
298'</fieldset>'.
299'</form>'.
300'</div>';
301
302echo
303'<div class="multi-part" id="add-cat" title="'.__('Add a category').'">'.
304'<form action="plugin.php" method="post" id="add-category-form">'.
305'<fieldset><legend>'.__('Add a new category').'</legend>'.
306'<p><label for="cat_title" class=" classic required"><abbr title="'.__('Required field').'">*</abbr> '.__('Title:').' '.
307form::field('cat_title',30,255,$cat_title).'</label> '.
308form::hidden(array('p'),'blogroll').
309$core->formNonce().
310'<input type="submit" name="add_cat" value="'.__('Save').'" /></p>'.
311'</fieldset>'.
312'</form>'.
313'</div>';
314
315echo
316'<div class="multi-part" id="import-links" title="'.__('Import links').'">';
317if (!isset($imported)) {
318     echo
319     '<form action="plugin.php" method="post" id="import-links-form" enctype="multipart/form-data">'.
320     '<fieldset><legend>'.__('Import links').'</legend>'.
321     '<p><label for="links_file" class=" classic required"><abbr title="'.__('Required field').'">*</abbr> '.__('OPML or XBEL File:').' '.
322     '<input type="file" id="links_file" name="links_file" /></label></p>'.
323     '<p>'.form::hidden(array('p'),'blogroll').
324     $core->formNonce().
325     '<input type="submit" name="import_links" value="'.__('Import').'" /></p>'.
326     '</fieldset>'.
327     '</form>';
328}
329else {
330     echo
331     '<form action="plugin.php" method="post" id="import-links-form">'.
332     '<fieldset><legend>'.__('Import links').'</legend>';
333     if (empty($imported)) {
334          echo '<p>'.__('Nothing to import').'</p>';
335     }
336     else {
337          echo
338          '<table class="clear maximal"><tr>'.
339          '<th colspan="2">'.__('Title').'</th>'.
340          '<th>'.__('Description').'</th>'.
341          '</tr>';
342         
343          $i = 0;
344          foreach ($imported as $entry) {
345               $url   = html::escapeHTML($entry->link);
346               $title = html::escapeHTML($entry->title);
347               $desc  = html::escapeHTML($entry->desc);
348               
349               echo 
350               '<tr><td>'.form::checkbox(array('entries[]'),$i,'','','').'</td>'.
351               '<td nowrap><a href="'.$url.'">'.$title.'</a>'.
352               '<input type="hidden" name="url['.$i.']" value="'.$url.'" />'.
353               '<input type="hidden" name="title['.$i.']" value="'.$title.'" />'.
354               '</td>'.
355               '<td>'.$desc.
356               '<input type="hidden" name="desc['.$i.']" value="'.$desc.'" />'.
357               '</td></tr>'."\n";           
358               $i++;
359          }
360          echo
361          '</table>'.
362          '<div class="two-cols">'.
363          '<p class="col checkboxes-helpers"></p>'.
364         
365          '<p class="col right">'.
366          form::hidden(array('p'),'blogroll').
367          $core->formNonce().
368          '<input type="submit" name="cancel_import" value="'.__('Cancel').'" />&nbsp;'.
369          '<input type="submit" name="import_links_do" value="'.__('Import').'" /></p>'.
370          '</div>';
371     }
372     echo
373     '</fieldset>'.
374     '</form>';
375}
376echo '</div>';
377
378dcPage::helpBlock('blogroll');
379?>
380
381</body>
382</html>
Note: See TracBrowser for help on using the repository browser.

Sites map