Dotclear

source: admin/media.php @ 1144:4af82896ca3d

Revision 1144:4af82896ca3d, 12.9 KB checked in by Nicolas <nikrou77@…>, 12 years ago (diff)

Remplacement de l'upload utilisant swfupload par le plugin jQuery-File-Upload

Todo:

  • Gestion des suppressions
  • Gestion des annulations
  • Gestion des mises de l'interface sans rechargement de la page
  • Simplification (moins de javascript) ?
Line 
1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
6# Copyright (c) 2003-2011 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
13/* HTML page
14-------------------------------------------------------- */
15require dirname(__FILE__).'/../inc/admin/prepend.php';
16
17dcPage::check('media,media_admin');
18
19$post_id = !empty($_GET['post_id']) ? (integer) $_GET['post_id'] : null;
20if ($post_id) {
21     $post = $core->blog->getPosts(array('post_id'=>$post_id,'post_type'=>''));
22     if ($post->isEmpty()) {
23          $post_id = null;
24     }
25     $post_title = $post->post_title;
26     $post_type = $post->post_type;
27     unset($post);
28}
29$d = isset($_REQUEST['d']) ? $_REQUEST['d'] : null;
30$dir = null;
31
32$page = !empty($_GET['page']) ? $_GET['page'] : 1;
33$nb_per_page =  30;
34
35# We are on home not comming from media manager
36if ($d === null && isset($_SESSION['media_manager_dir'])) {
37     # We get session information
38     $d = $_SESSION['media_manager_dir'];
39}
40
41if (!isset($_GET['page']) && isset($_SESSION['media_manager_page'])) {
42     $page = $_SESSION['media_manager_page'];
43}
44
45# We set session information about directory and page
46if ($d) {
47     $_SESSION['media_manager_dir'] = $d;
48} else {
49     unset($_SESSION['media_manager_dir']);
50}
51if ($page != 1) {
52     $_SESSION['media_manager_page'] = $page;
53} else {
54     unset($_SESSION['media_manager_page']);
55}
56
57# Sort combo
58$sort_combo = array(
59     __('By names, in ascending order') => 'name-asc',
60     __('By names, in descending order') => 'name-desc',
61     __('By dates, in ascending order') => 'date-asc',
62     __('By dates, in descending order') => 'date-desc'
63);
64
65if (!empty($_GET['file_sort']) && in_array($_GET['file_sort'],$sort_combo)) {
66     $_SESSION['media_file_sort'] = $_GET['file_sort'];
67}
68$file_sort = !empty($_SESSION['media_file_sort']) ? $_SESSION['media_file_sort'] : null;
69
70$popup = (integer) !empty($_GET['popup']);
71
72$page_url = 'media.php?popup='.$popup.'&post_id='.$post_id;
73
74if ($popup) {
75     $open_f = array('dcPage','openPopup');
76     $close_f = array('dcPage','closePopup');
77} else {
78     $open_f = array('dcPage','open');
79     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
80}
81
82$core_media_writable = false;
83try {
84     $core->media = new dcMedia($core);
85     if ($file_sort) {
86          $core->media->setFileSort($file_sort);
87     }
88     $core->media->chdir($d);
89     $core->media->getDir();
90     $core_media_writable = $core->media->writable();
91     $dir =& $core->media->dir;
92     if  (!$core_media_writable) {
93          throw new Exception('you do not have sufficient permissions to write to this folder: ');
94     }
95} catch (Exception $e) {
96     $core->error->add($e->getMessage());
97}
98
99# Zip download
100if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
101{
102     try
103     {
104          @set_time_limit(300);
105          $fp = fopen('php://output','wb');
106          $zip = new fileZip($fp);
107          $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
108          $zip->addDirectory($core->media->root.'/'.$d,'',true);
109         
110          header('Content-Disposition: attachment;filename='.($d ? $d : 'media').'.zip');
111          header('Content-Type: application/x-zip');
112          $zip->write();
113          unset($zip);
114          exit;
115     }
116     catch (Exception $e)
117     {
118          $core->error->add($e->getMessage());
119     }
120}
121
122# New directory
123if ($dir && !empty($_POST['newdir']))
124{
125     try {
126          $core->media->makeDir($_POST['newdir']);
127          http::redirect($page_url.'&d='.rawurlencode($d).'&mkdok=1');
128     } catch (Exception $e) {
129          $core->error->add($e->getMessage());
130     }
131}
132
133# Adding a file
134if ($dir && !empty($_FILES['upfile']))
135{
136  $upfile = array('name' => $_FILES['upfile']['name'][0],
137                  'type' => $_FILES['upfile']['type'][0],
138                  'tmp_name' => $_FILES['upfile']['tmp_name'][0],
139                  'error' => $_FILES['upfile']['error'][0],
140                  'size' => $_FILES['upfile']['size'][0]
141                  );
142
143     try {
144    files::uploadStatus($upfile);
145
146    $core->media->uploadFile($upfile['tmp_name'],$upfile['name']);
147
148    if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
149      header('Content-type: application/json');
150      $message = array();
151      $message['files'][] = array('name' => $upfile['name']);
152
153      echo json_encode($message);
154      exit();
155    } else {
156        http::redirect($page_url.'&d='.rawurlencode($d).'&upok=1');
157    }
158     } catch (Exception $e) {
159    if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
160      header('Content-type: application/json');
161      $message = array();
162      $message['files'][] = array('name' => $upfile['name'],
163                                  'error' => $e->getMessage()
164                                  );
165      echo json_encode($message);
166      exit();
167    } else {
168      $core->error->add($e->getMessage());
169    }
170     }
171}
172
173# Removing item
174if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
175{
176     $_POST['remove'] = rawurldecode($_POST['remove']);
177     
178     try {
179          $core->media->removeItem($_POST['remove']);
180          http::redirect($page_url.'&d='.rawurlencode($d).'&rmfok=1');
181     } catch (Exception $e) {
182          $core->error->add($e->getMessage());
183     }
184}
185
186# Rebuild directory
187if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
188{
189     try {
190          $core->media->rebuild($d);
191          http::redirect($page_url.'&d='.rawurlencode($d).'&rebuildok=1');
192     } catch (Exception $e) {
193          $core->error->add($e->getMessage());
194     }
195}
196
197# DISPLAY confirm page for rmdir & rmfile
198if ($dir && !empty($_GET['remove']) && empty($_GET['noconfirm']))
199{
200     call_user_func($open_f,__('Media manager'));
201     
202     echo '<h2>'.html::escapeHTML($core->blog->name).' &rsaquo; '.__('Media manager').' &rsaquo; <span class="page-title">'.__('confirm removal').'</span></h2>';
203     
204     echo
205     '<form action="'.html::escapeURL($page_url).'" method="post">'.
206     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
207     html::escapeHTML($_GET['remove'])).'</p>'.
208     '<p><input type="submit" value="'.__('Cancel').'" /> '.
209     ' &nbsp; <input type="submit" name="rmyes" value="'.__('Yes').'" />'.
210     form::hidden('d',$d).
211     $core->formNonce().
212     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
213     '</form>';
214     
215     call_user_func($close_f);
216     exit;
217}
218
219/* DISPLAY Main page
220-------------------------------------------------------- */
221$core->auth->user_prefs->addWorkspace('interface');
222$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
223
224call_user_func($open_f,__('Media manager'),
225     dcPage::jsLoad('js/_media.js').
226     ($core_media_writable ? dcPage::jsUpload(array('d='.$d)) : '')
227     );
228
229if (!empty($_GET['mkdok'])) {
230     dcPage::message(__('Directory has been successfully created.'));
231}
232
233if (!empty($_GET['upok'])) {
234     dcPage::message(__('Files have been successfully uploaded.'));
235}
236
237if (!empty($_GET['rmfok'])) {
238     dcPage::message(__('File has been successfully removed.'));
239}
240
241if (!empty($_GET['rmdok'])) {
242     dcPage::message(__('Directory has been successfully removed.'));
243}
244
245if (!empty($_GET['rebuildok'])) {
246     dcPage::message(__('Directory has been successfully rebuilt.'));
247}
248
249if (!empty($_GET['unzipok'])) {
250     dcPage::message(__('Zip file has been successfully extracted.'));
251}
252
253echo '<h2>'.html::escapeHTML($core->blog->name).' &rsaquo; ';
254if (!isset($core->media)) {
255     echo '<span class="page-title">'.__('Media manager').'</span></h2>';
256} else {
257     $breadcrumb = $core->media->breadCrumb(html::escapeURL($page_url).'&amp;d=%s','<span class="page-title">%s</span>');
258     if ($breadcrumb == '') {
259          echo '<span class="page-title">'.__('Media manager').'</span></h2>';
260     } else {
261          echo '<a href="'.html::escapeURL($page_url.'&d=').'">'.__('Media manager').'</a>'.' / '.$breadcrumb.'</h2>';
262     }
263}
264
265if (!$dir) {
266     call_user_func($close_f);
267     exit;
268}
269
270if ($post_id) {
271     echo '<p><strong>'.sprintf(__('Choose a file to attach to entry %s by clicking on %s.'),
272     '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
273     '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</strong></p>';
274}
275if ($popup) {
276     echo '<p><strong>'.sprintf(__('Choose a file to insert into entry by clicking on %s.'),
277     '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</strong></p>';
278}
279
280
281$items = array_values(array_merge($dir['dirs'],$dir['files']));
282if (count($items) == 0)
283{
284     echo '<p><strong>'.__('No file.').'</strong></p>';
285}
286else
287{
288     $pager = new pager($page,count($items),$nb_per_page,10);
289     $pager->html_prev = __($pager->html_prev);
290     $pager->html_next = __($pager->html_next);
291     
292     echo
293     '<form action="media.php" method="get">'.
294     '<p><label for="file_sort" class="classic">'.__('Sort files:').' '.
295     form::combo('file_sort',$sort_combo,$file_sort).'</label>'.
296     form::hidden(array('popup'),$popup).
297     form::hidden(array('post_id'),$post_id).
298     '<input type="submit" value="'.__('Sort').'" /></p>'.
299     '</form>'.
300     
301     '<div class="media-list">'.
302     '<p>'.__('Page(s)').' : '.$pager->getLinks().'</p>';
303     
304     for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++, $j++)
305     {
306          echo mediaItemLine($items[$i],$j);
307     }
308     
309     echo
310     '<p class="clear">'.__('Page(s)').' : '.$pager->getLinks().'</p>'.
311     '</div>';
312}
313
314
315if ($core_media_writable)
316{
317     echo '<div class="two-cols">';
318     
319     echo
320  '<div class="col">'.
321  '<fieldset id="add-file-f"><legend>'.__('Add files').'</legend>'.
322  '<p>'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
323  ' <form id="fileupload" action="'.html::escapeURL($page_url).'" method="POST" enctype="multipart/form-data">'.
324  '<div>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
325    $core->formNonce().'</div>'.
326  '<div class="fileupload-buttonbar">'.
327  '<span class="button-add button"><label for="upfile">'.__('Add files').'</label>'.
328  '<input type="file" id="upfile" name="upfile[]" size="20" multiple="multiple" data-url="'.html::escapeURL($page_url).'" />'.
329  '</span>'.
330  '<button type="submit" class="button start"><span>'.__('Send').'</span></button>'.
331  '</div>'.
332  '<table role="presentation" class="table table-striped"><tbody class="files" data-toggle="modal-gallery" data-target="#modal-gallery"></tbody></table>'.
333    form::hidden(array('d'),$d).'</p>'.
334  '</fieldset>'.
335  '</form>'.
336  '</div>';
337     
338     echo
339     '<div class="col">'.
340     '<form class="clear" action="'.html::escapeURL($page_url).'" method="post">'.
341     '<fieldset id="new-dir-f">'.
342     '<legend>'.__('New directory').'</legend>'.
343     $core->formNonce().
344     '<p><label for="newdir">'.__('Directory Name:').
345     form::field(array('newdir','newdir'),35,255).'</label></p>'.
346     '<p><input type="submit" value="'.__('Create').'" />'.
347     form::hidden(array('d'),html::escapeHTML($d)).'</p>'.
348     '</fieldset>'.
349     '</form></div>';
350     
351     echo '</div>';
352}
353
354# Empty remove form (for javascript actions)
355echo
356'<form id="media-remove-hide" action="'.html::escapeURL($page_url).'" method="post"><div class="clear">'.
357form::hidden('rmyes',1).form::hidden('d',html::escapeHTML($d)).
358form::hidden('remove','').
359$core->formNonce().
360'</div></form>';
361
362# Get zip directory
363if ($core->auth->check('media_admin',$core->blog->id) && 
364     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent)))
365{
366     echo
367     '<p class="zip-dl"><a href="'.html::escapeURL($page_url).'&amp;zipdl=1">'.
368     __('Download this directory as a zip file').'</a></p>';
369}
370
371call_user_func($close_f);
372
373/* ----------------------------------------------------- */
374function mediaItemLine($f,$i)
375{
376     global $core, $page_url, $popup, $post_id;
377     
378     $fname = $f->basename;
379     
380     if ($f->d) {
381          $link = html::escapeURL($page_url).'&amp;d='.html::sanitizeURL($f->relname);
382          if ($f->parent) {
383               $fname = '..';
384          }
385     } else {
386          $link =
387          'media_item.php?id='.$f->media_id.'&amp;popup='.$popup.'&amp;post_id='.$post_id;
388     }
389     
390     $class = 'media-item media-col-'.($i%2);
391     
392     $res =
393     '<div class="'.$class.'"><a class="media-icon media-link" href="'.$link.'">'.
394     '<img src="'.$f->media_icon.'" alt="" /></a>'.
395     '<ul>'.
396     '<li><a class="media-link" href="'.$link.'">'.$fname.'</a></li>';
397     
398     if (!$f->d) {
399          $res .=
400          '<li>'.$f->media_title.'</li>'.
401          '<li>'.
402          $f->media_dtstr.' - '.
403          files::size($f->size).' - '.
404          '<a href="'.$f->file_url.'">'.__('open').'</a>'.
405          '</li>';
406     }
407     
408     $res .= '<li class="media-action">&nbsp;';
409     
410     if ($post_id && !$f->d) {
411          $res .= '<form action="post_media.php" method="post">'.
412          '<input type="image" src="images/plus.png" alt="'.__('Attach this file to entry').'" '.
413          'title="'.__('Attach this file to entry').'" /> '.
414          form::hidden('media_id',$f->media_id).
415          form::hidden('post_id',$post_id).
416          form::hidden('attach',1).
417          $core->formNonce().
418          '</form>';
419     }
420     
421     if ($popup && !$f->d) {
422          $res .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
423          'title="'.__('Insert this file into entry').'" /></a> ';
424     }
425     
426     if ($f->del) {
427          $res .= '<a class="media-remove" '.
428          'href="'.html::escapeURL($page_url).'&amp;d='.
429          rawurlencode($GLOBALS['d']).'&amp;remove='.rawurlencode($f->basename).'">'.
430          '<img src="images/trash.png" alt="'.__('Delete').'" title="'.__('delete').'" /></a>';
431     }
432     
433     $res .= '</li>';
434     
435     if ($f->type == 'audio/mpeg3') {
436          $res .= '<li>'.dcMedia::mp3player($f->file_url,'index.php?pf=player_mp3.swf').'</li>';
437     }
438     
439     $res .= '</ul></div>';
440     
441     return $res;
442}
443?>
Note: See TracBrowser for help on using the repository browser.

Sites map