Dotclear

source: admin/media.php @ 3569:023a33f84af7

Revision 3569:023a33f84af7, 31.8 KB checked in by Gvx <gvx@…>, 8 years ago (diff)

Title of the image without filtering

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
13/* HTML page
14-------------------------------------------------------- */
15require dirname(__FILE__).'/../inc/admin/prepend.php';
16
17dcPage::check('media,media_admin');
18
19$post_id = !empty($_REQUEST['post_id']) ? (integer) $_REQUEST['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$plugin_id = isset($_REQUEST['plugin_id']) ? html::sanitizeURL($_REQUEST['plugin_id']) : '';
31$dir = null;
32
33// Attachement type if any
34$link_type = !empty($_REQUEST['link_type']) ? html::escapeHTML($_REQUEST['link_type']) : null;
35
36$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
37$nb_per_page = ((integer) $core->auth->user_prefs->interface->media_by_page ?: 30);
38
39# We are on home not comming from media manager
40if ($d === null && isset($_SESSION['media_manager_dir'])) {
41     # We get session information
42     $d = $_SESSION['media_manager_dir'];
43}
44
45if (!isset($_GET['page']) && isset($_SESSION['media_manager_page'])) {
46     $page = $_SESSION['media_manager_page'];
47}
48
49# We set session information about directory, page and display mode
50if ($d) {
51     $_SESSION['media_manager_dir'] = $d;
52} else {
53     unset($_SESSION['media_manager_dir']);
54}
55if ($page != 1) {
56     $_SESSION['media_manager_page'] = $page;
57} else {
58     unset($_SESSION['media_manager_page']);
59}
60
61# Get query if any
62$q = isset($_REQUEST['q']) ? html::escapeHTML($_REQUEST['q']) : null;
63
64# Sort combo
65$sort_combo = array(
66     __('By names, in ascending order') => 'name-asc',
67     __('By names, in descending order') => 'name-desc',
68     __('By dates, in ascending order') => 'date-asc',
69     __('By dates, in descending order') => 'date-desc'
70     );
71
72if (!empty($_GET['file_mode'])) {
73     $_SESSION['media_file_mode'] = $_GET['file_mode'];
74}
75$file_mode = !empty($_SESSION['media_file_mode']) ? $_SESSION['media_file_mode'] : 'grid';
76
77$file_sort = null;
78if (!empty($_GET['file_sort'])) {
79     $file_sort = $_SESSION['media_file_sort'] = $_GET['file_sort'];
80     setcookie('dc_media_sort',json_encode($file_sort));
81} elseif (isset($_COOKIE['dc_media_sort'])) {
82     $file_sort = json_decode($_COOKIE['dc_media_sort']);
83} elseif (!empty($_SESSION['media_file_sort'])) {
84     $file_sort = $_SESSION['media_file_sort'];
85}
86$file_sort =  in_array($file_sort,$sort_combo) ? $file_sort : null;
87
88$nb_per_page = !empty($_SESSION['nb_per_page']) ? (integer)$_SESSION['nb_per_page'] : $nb_per_page;
89if (!empty($_GET['nb_per_page']) && (integer)$_GET['nb_per_page'] > 0) {
90     $nb_per_page = $_SESSION['nb_per_page'] = (integer)$_GET['nb_per_page'];
91}
92
93$popup = (integer) !empty($_REQUEST['popup']);
94$select = !empty($_REQUEST['select']) ? (integer)$_REQUEST['select'] : 0;  // 0 : none, 1 : single media, >1 : multiple medias
95
96$page_url_params = new ArrayObject(array('popup' => $popup,'select' => $select,'post_id' => $post_id,'link_type' => $link_type));
97if ($d) {
98     $page_url_params['d'] = $d;
99}
100if ($plugin_id != '') {
101     $page_url_params['plugin_id'] = $plugin_id;
102}
103if ($q) {
104     $page_url_params['q'] = $q;
105}
106
107$core->callBehavior('adminMediaURLParams',$page_url_params);
108$page_url_params = (array) $page_url_params;
109
110if ($popup) {
111     $open_f = array('dcPage','openPopup');
112     $close_f = array('dcPage','closePopup');
113} else {
114     $open_f = array('dcPage','open');
115     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
116}
117
118$core_media_writable = false;
119try {
120     $core->media = new dcMedia($core);
121     if ($file_sort) {
122          $core->media->setFileSort($file_sort);
123     }
124     $query = false;
125     if ($q) {
126          $query = $core->media->searchMedia($q);
127     }
128     if (!$query) {
129          $try_d = $d;
130          // Reset current dir
131          $d = null;
132          // Change directory (may cause an exception if directory doesn't exist)
133          $core->media->chdir($try_d);
134          // Restore current dir variable
135          $d = $try_d;
136          $core->media->getDir();
137     } else {
138          $d = null;
139          $core->media->chdir($d);
140     }
141     $core_media_writable = $core->media->writable();
142     $dir =& $core->media->dir;
143     if  (!$core_media_writable) {
144//        throw new Exception('you do not have sufficient permissions to write to this folder: ');
145     }
146} catch (Exception $e) {
147     $core->error->add($e->getMessage());
148}
149
150// Local functions
151
152$mediaItemLine = function($f,$i,$query,$table=false)
153{
154     global $core, $page_url, $popup, $select, $post_id, $plugin_id, $page_url_params, $link_type;
155
156     $fname = $f->basename;
157     $file = $query ? $f->relname : $f->basename;
158
159     $class = $table ? '' : 'media-item media-col-'.($i%2);
160
161     if ($f->d) {
162          // Folder
163          $link = $core->adminurl->get('admin.media',array_merge($page_url_params,array('d' => html::sanitizeURL($f->relname) )));
164          if ($f->parent) {
165               $fname = '..';
166               $class .= ' media-folder-up';
167          } else {
168               $class .= ' media-folder';
169          }
170     } else {
171          // Item
172          $params = new ArrayObject(
173               array(
174                    'id' => $f->media_id,
175                    'plugin_id' => $plugin_id,
176                    'popup' => $popup,
177                    'select' => $select,
178                    'post_id' => $post_id,
179                    'link_type' => $link_type
180               )
181          );
182          $core->callBehavior('adminMediaURLParams',$params);
183          $params = (array) $params;
184          $link = $core->adminurl->get(
185               'admin.media.item', $params
186          );
187     }
188
189     $maxchars = 36;
190     if (strlen($fname) > $maxchars) {
191          $fname = substr($fname, 0, $maxchars-4).'...'.($f->d ? '' : files::getExtension($fname));
192     }
193
194     $act = '';
195     if (!$f->d) {
196          if ($select > 0) {
197               if ($select == 1) {
198                    // Single media selection button
199                    $act .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Select this file').'" '.
200                    'title="'.__('Select this file').'" /></a> ';
201               } else {
202                    // Multiple media selection checkbox
203                    $act .= form::checkbox(array('medias[]', 'media_'.rawurlencode($file)),$file);
204               }
205          } else {
206               // Item
207               if ($post_id) {
208                    // Media attachment button
209                    $act .=
210                    '<a class="attach-media" title="'.__('Attach this file to entry').'" href="'.
211                    $core->adminurl->get("admin.post.media",
212                         array('media_id' => $f->media_id, 'post_id' => $post_id,'attach' => 1,'link_type' => $link_type)).
213                    '">'.
214                    '<img src="images/plus.png" alt="'.__('Attach this file to entry').'"/>'.
215                    '</a>';
216               }
217               if ($popup) {
218                    // Media insertion button
219                    $act .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
220                    'title="'.__('Insert this file into entry').'" /></a> ';
221               }
222          }
223     }
224     if ($f->del) {
225          // Deletion button or checkbox
226          if (!$popup && !$f->d) {
227               if ($select < 2) {
228                    // Already set for multiple media selection
229                    $act .= form::checkbox(array('medias[]', 'media_'.rawurlencode($file)),$file);
230               }
231          } else {
232               $act .= '<a class="media-remove" '.
233               'href="'.html::escapeURL($page_url).
234               '&amp;plugin_id='.$plugin_id.
235               '&amp;d='.rawurlencode($GLOBALS['d']).
236               '&amp;q='.rawurlencode($GLOBALS['q']).
237               '&amp;remove='.rawurlencode($file).'">'.
238               '<img src="images/trash.png" alt="'.__('Delete').'" title="'.__('delete').'" /></a>';
239          }
240     }
241
242     $file_type = explode('/',$f->type);
243     $class_open = 'class="modal-'.$file_type[0].'" ';
244
245     // Render markup
246     if (!$table) {
247          $res =
248          '<div class="'.$class.'"><p><a class="media-icon media-link" href="'.rawurldecode($link).'">'.
249          '<img src="'.$f->media_icon.'" alt="" />'.($query ? $file : $fname).'</a></p>';
250
251          $lst = '';
252          if (!$f->d) {
253               $lst .=
254               '<li>'.$f->media_title.'</li>'.
255               '<li>'.
256               $f->media_dtstr.' - '.
257               files::size($f->size).' - '.
258               '<a '.$class_open.'href="'.$f->file_url.'">'.__('open').'</a>'.
259               '</li>';
260          }
261          $lst .= ($act != '' ? '<li class="media-action">&nbsp;'.$act.'</li>' : '');
262
263          // Show player if relevant
264          if ($file_type[0] == 'audio')
265          {
266               $lst .= '<li>'.dcMedia::audioPlayer($f->type,$f->file_url,$core->adminurl->get("admin.home",array('pf' => 'player_mp3.swf')),null,$core->blog->settings->system->media_flash_fallback,false).'</li>';
267          }
268
269          $res .=   ($lst != '' ? '<ul>'.$lst.'</ul>' : '');
270          $res .= '</div>';
271     } else {
272          $res = '<tr class="'.$class.'">';
273          $res .= '<td class="media-action">'.$act.'</td>';
274          $res .= '<td class="maximal" scope="row"><a class="media-flag media-link" href="'.rawurldecode($link).'">'.
275                    '<img src="'.$f->media_icon.'" alt="" />'.($query ? $file : $fname).'</a>'.
276                    '<br />'.($f->d ? '' : $f->media_title).'</td>';
277          $res .= '<td class="nowrap count">'.($f->d ? '' : $f->media_dtstr).'</td>';
278          $res .= '<td class="nowrap count">'.($f->d ? '' : files::size($f->size).' - '.
279               '<a '.$class_open.'href="'.$f->file_url.'">'.__('open').'</a>').'</td>';
280          $res .= '</tr>';
281     }
282
283     return $res;
284};
285
286// Actions
287
288# Zip download
289if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
290{
291     try
292     {
293          if (strpos(realpath($core->media->root.'/'.$d),realpath($core->media->root)) === 0) {
294               // Media folder or one of it's sub-folder(s)
295               @set_time_limit(300);
296               $fp = fopen('php://output','wb');
297               $zip = new fileZip($fp);
298               $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
299               $zip->addDirectory($core->media->root.'/'.$d,'',true);
300
301               header('Content-Disposition: attachment;filename='.date('Y-m-d').'-'.$core->blog->id.'-'.($d ?: 'media').'.zip');
302               header('Content-Type: application/x-zip');
303               $zip->write();
304               unset($zip);
305               exit;
306          } else {
307               $d = null;
308               $core->media->chdir($d);
309               throw new Exception(__('Not a valid directory'));
310          }
311     }
312     catch (Exception $e)
313     {
314          $core->error->add($e->getMessage());
315     }
316}
317
318# Cope with fav/unfav dir
319$fav_dirs = null;
320if (!empty($_GET['fav'])) {
321     if (!$q) { // Ignore search results
322          $fav_dir = rtrim($d,'/');
323          $core->auth->user_prefs->addWorkspace('interface');
324          $nb_last_dirs = (integer)($core->auth->user_prefs->interface->media_nb_last_dirs);
325          if ($nb_last_dirs > 0) {
326               $fav_dirs = $core->auth->user_prefs->interface->media_fav_dirs;
327               if (!is_array($fav_dirs)) {
328                    $fav_dirs = array();
329               }
330               if (!in_array($fav_dir,$fav_dirs) && $_GET['fav'] == 'y') {
331                    // Add directory in favorites
332                    array_unshift($fav_dirs,$fav_dir);
333               } elseif (in_array($fav_dir,$fav_dirs) && $_GET['fav'] == 'n') {
334                    // Remove directory from favorites
335                    unset($fav_dirs[array_search($fav_dir,$fav_dirs)]);
336               }
337               // Store new list
338               $core->auth->user_prefs->interface->put('media_fav_dirs',$fav_dirs,'array');
339               $core->adminurl->redirect('admin.media',$page_url_params);
340          }
341     }
342}
343
344# Recent media dirs
345$last_dirs = null;
346if (!$q) {     // Ignore search results
347     $recent_dir = rtrim($d,'/');
348     $core->auth->user_prefs->addWorkspace('interface');
349     $nb_last_dirs = (integer)($core->auth->user_prefs->interface->media_nb_last_dirs);
350     if ($nb_last_dirs > 0) {
351          $last_dirs = $core->auth->user_prefs->interface->media_last_dirs;
352          if (!is_array($last_dirs)) {
353               $last_dirs = array();
354          }
355          if (!in_array($recent_dir,$last_dirs)) {
356               // Add new dir at the top of the list
357               array_unshift($last_dirs,$recent_dir);
358               // Remove oldest dir(s)
359               while (count($last_dirs) > $nb_last_dirs) {
360                    array_pop($last_dirs);
361               }
362          } else {
363               // Move current dir at the top of list
364               unset($last_dirs[array_search($recent_dir,$last_dirs)]);
365               array_unshift($last_dirs,$recent_dir);
366          }
367          // Store new list
368          $core->auth->user_prefs->interface->put('media_last_dirs',$last_dirs,'array');
369     }
370}
371
372# New directory
373if ($dir && !empty($_POST['newdir']))
374{
375     try {
376          $core->media->makeDir($_POST['newdir']);
377          dcPage::addSuccessNotice(sprintf(
378               __('Directory "%s" has been successfully created.'),
379               html::escapeHTML($_POST['newdir']))
380          );
381          $core->adminurl->redirect('admin.media',$page_url_params);
382     } catch (Exception $e) {
383          $core->error->add($e->getMessage());
384     }
385}
386
387# Adding a file
388if ($dir && !empty($_FILES['upfile'])) {
389     // only one file per request : @see option singleFileUploads in admin/js/jsUpload/jquery.fileupload
390     $upfile = array('name' => $_FILES['upfile']['name'][0],
391          'type' => $_FILES['upfile']['type'][0],
392          'tmp_name' => $_FILES['upfile']['tmp_name'][0],
393          'error' => $_FILES['upfile']['error'][0],
394          'size' => $_FILES['upfile']['size'][0],
395          'title' => html::escapeHTML($_FILES['upfile']['name'][0])
396          );
397
398     if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
399          header('Content-type: application/json');
400          $message = array();
401
402          try {
403               files::uploadStatus($upfile);
404               $new_file_id = $core->media->uploadFile($upfile['tmp_name'],$upfile['name'],$upfile['title']);
405
406               $message['files'][] = array(
407                    'name' => $upfile['name'],
408                    'size' => $upfile['size'],
409                    'html' => $mediaItemLine($core->media->getFile($new_file_id),1,$query)
410               );
411          } catch (Exception $e) {
412               $message['files'][] = array('name' => $upfile['name'],
413                    'size' => $upfile['size'],
414                    'error' => $e->getMessage()
415                    );
416          }
417          echo json_encode($message);
418          exit();
419     } else {
420          try {
421               files::uploadStatus($upfile);
422
423               $f_title = (isset($_POST['upfiletitle']) ? html::escapeHTML($_POST['upfiletitle']) : '');
424               $f_private = (isset($_POST['upfilepriv']) ? $_POST['upfilepriv'] : false);
425
426               $core->media->uploadFile($upfile['tmp_name'],$upfile['name'],$f_title,$f_private);
427
428               dcPage::addSuccessNotice(__('Files have been successfully uploaded.'));
429               $core->adminurl->redirect('admin.media',$page_url_params);
430          } catch (Exception $e) {
431               $core->error->add($e->getMessage());
432          }
433     }
434}
435
436# Removing items
437if ($dir && !empty($_POST['medias']) && !empty($_POST['delete_medias'])) {
438     try {
439          foreach ($_POST['medias'] as $media) {
440               $core->media->removeItem(rawurldecode($media));
441          }
442          dcPage::addSuccessNotice(
443               sprintf(__('Successfully delete one media.',
444                            'Successfully delete %d medias.',
445                            count($_POST['medias'])
446                            ),
447                            count($_POST['medias'])
448               )
449          );
450          $core->adminurl->redirect('admin.media',$page_url_params);
451     } catch (Exception $e) {
452          $core->error->add($e->getMessage());
453     }
454}
455
456# Removing item from popup only
457if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
458{
459     $_POST['remove'] = rawurldecode($_POST['remove']);
460
461     try {
462          if (is_dir(path::real($core->media->getPwd().'/'.path::clean($_POST['remove'])))) {
463               $msg = __('Directory has been successfully removed.');
464          } else {
465               $msg = __('File has been successfully removed.');
466          }
467          $core->media->removeItem($_POST['remove']);
468          dcPage::addSuccessNotice($msg);
469          $core->adminurl->redirect('admin.media',$page_url_params);
470     } catch (Exception $e) {
471          $core->error->add($e->getMessage());
472     }
473}
474
475# Rebuild directory
476if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
477{
478     try {
479          $core->media->rebuild($d);
480
481          dcPage::success(sprintf(
482               __('Directory "%s" has been successfully rebuilt.'),
483               html::escapeHTML($d))
484          );
485          $core->adminurl->redirect('admin.media',$page_url_params);
486     } catch (Exception $e) {
487          $core->error->add($e->getMessage());
488     }
489}
490
491# DISPLAY confirm page for rmdir & rmfile
492if ($dir && !empty($_GET['remove']) && empty($_GET['noconfirm']))
493{
494     call_user_func($open_f,__('Media manager'),'',
495          dcPage::breadcrumb(
496               array(
497                    html::escapeHTML($core->blog->name) => '',
498                    __('Media manager') => '',
499                    __('confirm removal') => ''
500               ),
501               array('home_link' => !$popup)
502          )
503     );
504
505     echo
506     '<form action="'.html::escapeURL($core->adminurl->get('admin.media')).'" method="post">'.
507     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
508          html::escapeHTML($_GET['remove'])).'</p>'.
509     '<p><input type="submit" value="'.__('Cancel').'" /> '.
510     ' &nbsp; <input type="submit" name="rmyes" value="'.__('Yes').'" />'.
511     form::hidden('d',$d).
512     form::hidden('q',$q).
513     $core->adminurl->getHiddenFormFields('admin.media',$page_url_params).
514     $core->formNonce().
515     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
516     '</form>';
517
518     call_user_func($close_f);
519     exit;
520}
521
522/* DISPLAY Main page
523-------------------------------------------------------- */
524$core->auth->user_prefs->addWorkspace('interface');
525$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
526
527if (!isset($core->media)) {
528     $breadcrumb = dcPage::breadcrumb(
529          array(
530               html::escapeHTML($core->blog->name) => '',
531               __('Media manager') => ''
532          ),
533          array('home_link' => !$popup)
534     );
535} else {
536     $home_params = $page_url_params;
537     $home_params['d']='';
538     $home_params['q']='';
539     if ($query || (!$query && $q)) {
540          $count = $query ? count($dir['files']) : 0;
541          $breadcrumb = dcPage::breadcrumb(
542               array(
543                    html::escapeHTML($core->blog->name) => '',
544                    __('Media manager') => $core->adminurl->get('admin.media',$home_params),
545                    __('Search:').' '.$q.' ('.sprintf(__('%s file found','%s files found',$count),$count).')' => ''
546               ),
547               array('home_link' => !$popup)
548          );
549     } else {
550          $temp_params = $page_url_params;
551          $temp_params['d']='%s';
552          $bc_template = $core->adminurl->get('admin.media',$temp_params,'&amp;',true);
553          $breadcrumb_media = $core->media->breadCrumb($bc_template,'<span class="page-title">%s</span>');
554          if ($breadcrumb_media == '') {
555               $breadcrumb = dcPage::breadcrumb(
556                    array(
557                         html::escapeHTML($core->blog->name) => '',
558                         __('Media manager') => $core->adminurl->get('admin.media',$home_params)
559                    ),
560                    array('home_link' => !$popup)
561               );
562          } else {
563               $home_params = $page_url_params;
564               $home_params['d']='';
565
566               $breadcrumb = dcPage::breadcrumb(
567                    array(
568                         html::escapeHTML($core->blog->name) => '',
569                         __('Media manager') => $core->adminurl->get('admin.media',$home_params),
570                         $breadcrumb_media => ''
571                    ),
572                    array(
573                         'home_link' => !$popup,
574                         'hl' => false
575                    )
576               );
577          }
578     }
579}
580
581// Recent media folders
582$last_folders = '';
583$last_folders_item = '';
584$fav_url = '';
585$fav_img = '';
586$fav_alt = '';
587$nb_last_dirs = (integer)($core->auth->user_prefs->interface->media_nb_last_dirs);
588if ($nb_last_dirs > 0) {
589     // Favorites directories
590     $fav_dirs = $core->auth->user_prefs->interface->media_fav_dirs;
591     if (!is_array($fav_dirs)) {
592          $fav_dirs = array();
593     }
594     foreach ($fav_dirs as $ld) {
595          // Add favorites dirs on top of combo
596          $ld_params = $page_url_params;
597          $ld_params['d'] = $ld;
598          $ld_params['q'] = '';    // Reset search
599          $last_folders_item .=
600               '<option value="'.urldecode($core->adminurl->get('admin.media',$ld_params)).'"'.
601               ($ld == rtrim($d,'/') ? ' selected="selected"' : '').'>'.
602               '/'.$ld.'</option>'."\n";
603          if ($ld == rtrim($d,'/')) {
604               // Current directory is a favorite → button will un-fav
605               $ld_params['fav'] = 'n';
606               $fav_url = urldecode($core->adminurl->get('admin.media',$ld_params));
607               unset($ld_params['fav']);
608               $fav_img = 'images/fav-on.png';
609               $fav_alt = __('Remove this folder from your favorites');
610          }
611     }
612     if ($last_folders_item != '') {
613          // add a separator between favorite dirs and recent dirs
614          $last_folders_item .= '<option disabled>_________</option>';
615     }
616     // Recent directories
617     if (!is_array($last_dirs)) {
618          $last_dirs = $core->auth->user_prefs->interface->media_last_dirs;
619     }
620     if (is_array($last_dirs)) {
621          foreach ($last_dirs as $ld) {
622               if (!in_array($ld,$fav_dirs)) {
623                    $ld_params = $page_url_params;
624                    $ld_params['d'] = $ld;
625                    $ld_params['q'] = '';    // Reset search
626                    $last_folders_item .=
627                         '<option value="'.urldecode($core->adminurl->get('admin.media',$ld_params)).'"'.
628                         ($ld == rtrim($d,'/') ? ' selected="selected"' : '').'>'.
629                         '/'.$ld.'</option>'."\n";
630                    if ($ld == rtrim($d,'/')) {
631                         // Current directory is not a favorite → button will fav
632                         $ld_params['fav'] = 'y';
633                         $fav_url = urldecode($core->adminurl->get('admin.media',$ld_params));
634                         unset($ld_params['fav']);
635                         $fav_img = 'images/fav-off.png';
636                         $fav_alt = __('Add this folder to your favorites');
637                    }
638               }
639          }
640     }
641     if ($last_folders_item != '') {
642          $last_folders =
643               '<p class="media-recent hidden-if-no-js">'.
644               '<label class="classic" for="switchfolder">'.__('Goto recent folder:').'</label> '.
645               '<select name="switchfolder" id="switchfolder">'.
646               $last_folders_item.
647               '</select>'.
648               '<script type="text/javascript">var urlmenu = document.getElementById(\'switchfolder\');
649                urlmenu.onchange = function() { window.location = this.options[this.selectedIndex].value; };
650               </script>'.
651               ' <a id="media-fav-dir" href="'.$fav_url.'" title="'.$fav_alt.'"><img src="'.$fav_img.'" alt="'.$fav_alt.'" /></a>'.
652               '</p>';
653     }
654}
655
656call_user_func($open_f,__('Media manager'),
657     dcPage::jsModal().
658     dcPage::jsLoad('js/_media.js').
659     ($core_media_writable ? dcPage::jsUpload(array('d='.$d)) : ''),
660     $breadcrumb
661     );
662
663if ($popup) {
664     // Display notices
665     echo dcPage::notices();
666}
667
668if (!$core_media_writable) {
669     dcPage::warning(__('You do not have sufficient permissions to write to this folder.'));
670}
671
672if (!empty($_GET['mkdok'])) {
673     dcPage::success(__('Directory has been successfully created.'));
674}
675
676if (!empty($_GET['upok'])) {
677     dcPage::success(__('Files have been successfully uploaded.'));
678}
679
680if (!empty($_GET['rmfok'])) {
681     dcPage::success(__('File has been successfully removed.'));
682}
683
684if (!empty($_GET['rmdok'])) {
685     dcPage::success(__('Directory has been successfully removed.'));
686}
687
688if (!empty($_GET['rebuildok'])) {
689     dcPage::success(__('Directory has been successfully rebuilt.'));
690}
691
692if (!empty($_GET['unzipok'])) {
693     dcPage::success(__('Zip file has been successfully extracted.'));
694}
695
696if (!$dir) {
697     call_user_func($close_f);
698     exit;
699}
700
701if ($select) {
702     // Select mode (popup or not)
703     echo '<div class="'.($popup ? 'form-note ' : '').'info"><p>';
704     if ($select == 1) {
705          echo sprintf(__('Select a file by clicking on %s'),'<img src="images/plus.png" alt="'.__('Select this file').'" />');
706     } else {
707          echo sprintf(__('Select files and click on <strong>%s</strong> button'),__('Choose selected medias'));
708     }
709     if ($core_media_writable) {
710          echo ' '.__('or').' '.sprintf('<a href="#fileupload">%s</a>',__('upload a new file'));
711     }
712     echo '</p></div>';
713} else {
714     if ($post_id) {
715          echo '<div class="form-note info"><p>'.sprintf(__('Choose a file to attach to entry %s by clicking on %s'),
716               '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
717               '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />');
718          if ($core_media_writable) {
719               echo ' '.__('or').' '.sprintf('<a href="#fileupload">%s</a>',__('upload a new file'));
720          }
721          echo '</p></div>';
722     }
723     if ($popup) {
724          echo '<div class="info"><p>'.sprintf(__('Choose a file to insert into entry by clicking on %s'),
725               '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />');
726          if ($core_media_writable) {
727               echo ' '.__('or').' '.sprintf('<a href="#fileupload">%s</a>',__('upload a new file'));
728          }
729          echo '</p></div>';
730     }
731}
732
733// Remove hidden directories (unless DC_SHOW_HIDDEN_DIRS is set to true)
734if (!defined('DC_SHOW_HIDDEN_DIRS') || (DC_SHOW_HIDDEN_DIRS == false)) {
735     for ($i = count($dir['dirs']) - 1; $i >= 0; $i--) {
736          if ($dir['dirs'][$i]->d) {
737               if (strpos($dir['dirs'][$i]->relname,'.') !== false) {
738                    unset($dir['dirs'][$i]);
739               }
740          }
741     }
742}
743$items = array_values(array_merge($dir['dirs'],$dir['files']));
744
745$fmt_form_media = '<form action="'.$core->adminurl->get("admin.media").'" method="post" id="form-medias">'.
746     '<div class="files-group">%s</div>'.
747     '<p class="hidden">'.$core->formNonce().
748     form::hidden(array('d'),$d).
749     form::hidden(array('q'),$q).
750     form::hidden(array('popup'),$popup).
751     form::hidden(array('select'),$select).
752     form::hidden(array('plugin_id'),$plugin_id).
753     form::hidden(array('post_id'),$post_id).
754     form::hidden(array('link_type'),$link_type).
755     '</p>';
756
757if (!$popup || $select > 1) {
758     // Checkboxes and action
759     $fmt_form_media .=
760     '<div class="'.(!$popup ? 'medias-delete' : '').' '.($select > 1 ? 'medias-select' : '').'">'.
761     '<p class="checkboxes-helpers"></p>'.
762     '<p>';
763     if ($select > 1) {
764          $fmt_form_media .=
765          '<input type="submit" class="select" id="select_medias" name="select_medias" value="'.__('Choose selected medias').'"/> ';
766     }
767     if (!$popup) {
768          $fmt_form_media .=
769          '<input type="submit" class="delete" id="delete_medias" name="delete_medias" value="'.__('Remove selected medias').'"/>';
770     }
771     $fmt_form_media .=
772     '</p>'.
773     '</div>';
774}
775$fmt_form_media .=
776     '</form>';
777
778echo '<div class="media-list">';
779echo $last_folders;
780echo // Search form
781     '<form action="'.$core->adminurl->get("admin.media").'" method="get" id="search-form">'.
782     '<p><label for="search" class="classic">'.__('Search:').'</label> '.
783     form::field('q',20,255,$q).' '.
784     '<input type="submit" value="'.__('OK').'" />'.' '.
785     '<span class="form-note">'.__('Will search into media filename (including path), title and description').'</span>'.
786     form::hidden(array('popup'),$popup).
787     form::hidden(array('select'),$select).
788     form::hidden(array('plugin_id'),$plugin_id).
789     form::hidden(array('post_id'),$post_id).
790     form::hidden(array('link_type'),$link_type).
791     '</p>'.
792     '</form>';
793
794if (count($items) == 0)
795{
796     echo
797     '<p>'.__('No file.').'</p>'.
798     sprintf($fmt_form_media,'',' hide'); // need for jsUpload to append new media
799}
800else
801{
802     $pager = new dcPager($page,count($items),$nb_per_page,10);
803
804     echo
805     '<form action="'.$core->adminurl->get("admin.media").'" method="get" id="filters-form">'.
806     '<span class="media-file-mode">'.
807     '<a href="'.$core->adminurl->get("admin.media",array_merge($page_url_params,array('file_mode' => 'grid'))).'" title="'.__('Grid display mode').'">'.
808     '<img src="images/grid-'.($file_mode == 'grid' ? 'on' : 'off').'.png" alt="'.__('Grid display mode').'" />'.
809     '</a>'.
810     '<a href="'.$core->adminurl->get("admin.media",array_merge($page_url_params,array('file_mode' => 'list'))).'" title="'.__('List display mode').'">'.
811     '<img src="images/list-'.($file_mode == 'list' ? 'on' : 'off').'.png" alt="'.__('List display mode').'" />'.
812     '</a>'.
813     '</span>'.
814     '<p class="three-boxes"><label for="file_sort" class="classic">'.__('Sort files:').'</label> '.
815     form::combo('file_sort',$sort_combo,$file_sort).'</p>'.
816     '<p class="three-boxes"><label for="nb_per_page" class="classic">'.__('Number of elements displayed per page:').'</label> '.
817     form::field('nb_per_page',5,3,(integer) $nb_per_page).' '.
818     '<input type="submit" value="'.__('OK').'" />'.
819     form::hidden(array('popup'),$popup).
820     form::hidden(array('select'),$select).
821     form::hidden(array('plugin_id'),$plugin_id).
822     form::hidden(array('post_id'),$post_id).
823     form::hidden(array('link_type'),$link_type).
824     form::hidden(array('q'),$q).
825     '</p>'.
826     '</form>'.
827     $pager->getLinks();
828
829     if ($file_mode == 'list') {
830          $table =
831          '<div class="table-outer">'.
832          '<table>'.
833          '<caption class="hidden">'.__('Media list').'</caption>'.
834          '<tr>'.
835          '<th colspan="2" class="first">'.__('Name').'</th>'.
836          '<th scope="col">'.__('Date').'</th>'.
837          '<th scope="col">'.__('Size').'</th>'.
838          '</tr>';
839
840          $dlist = '';
841          $flist = '';
842          for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++,$j++)
843          {
844               if ($items[$i]->d) {
845                    $dlist .= $mediaItemLine($items[$i],$j,$query,true);
846               } else {
847                    $flist .= $mediaItemLine($items[$i],$j,$query,true);
848               }
849          }
850          $table .= $dlist.$flist;
851
852          $table .=
853          '</table></div>';
854          echo sprintf($fmt_form_media,$table,'');
855     } else {
856          $dgroup = '';
857          $fgroup = '';
858          for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++,$j++)
859          {
860               if ($items[$i]->d) {
861                    $dgroup .= $mediaItemLine($items[$i],$j,$query);
862               } else {
863                    $fgroup .= $mediaItemLine($items[$i],$j,$query);
864               }
865          }
866          echo
867          ($dgroup != '' ? '<div class="folders-group">'.$dgroup.'</div>' : '').
868          sprintf($fmt_form_media,$fgroup,'');
869     }
870
871     echo $pager->getLinks();
872}
873if (!isset($pager)) {
874     echo
875     '<p class="clear"></p>';
876}
877echo
878'</div>';
879
880$core_media_archivable = $core->auth->check('media_admin',$core->blog->id) &&
881     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent));
882
883if ((!$query) && ($core_media_writable || $core_media_archivable)) {
884     echo
885     '<div class="vertical-separator">'.
886     '<h3 class="out-of-screen-if-js">'.sprintf(__('In %s:'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h3>';
887}
888
889if ((!$query) && ($core_media_writable || $core_media_archivable)) {
890     echo
891     '<div class="two-boxes odd">';
892
893     # Create directory
894     if ($core_media_writable)
895     {
896          echo
897          '<form action="'.$core->adminurl->getBase('admin.media').'" method="post" class="fieldset">'.
898          '<div id="new-dir-f">'.
899          '<h4 class="pretty-title">'.__('Create new directory').'</h4>'.
900          $core->formNonce().
901          '<p><label for="newdir">'.__('Directory Name:').'</label>'.
902          form::field(array('newdir','newdir'),35,255).'</p>'.
903          '<p><input type="submit" value="'.__('Create').'" />'.
904          $core->adminurl->getHiddenFormFields('admin.media',$page_url_params).
905          '</p>'.
906          '</div>'.
907          '</form>';
908     }
909
910     # Get zip directory
911     if ($core_media_archivable && !$popup)
912     {
913          echo
914          '<div class="fieldset">'.
915          '<h4 class="pretty-title">'.sprintf(__('Backup content of %s'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h4>'.
916          '<p><a class="button submit" href="'.$core->adminurl->get('admin.media',
917               array_merge($page_url_params,array('zipdl' => 1))).'">'.__('Download zip file').'</a></p>'.
918          '</div>';
919     }
920
921     echo
922     '</div>';
923}
924
925if (!$query && $core_media_writable)
926{
927     echo
928     '<div class="two-boxes fieldset even">';
929     if ($user_ui_enhanceduploader) {
930          echo
931          '<div class="enhanced_uploader">';
932     } else {
933          echo
934          '<div>';
935     }
936
937     echo
938     '<h4>'.__('Add files').'</h4>'.
939     '<p class="more-info">'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
940     '<form id="fileupload" action="'.html::escapeURL($core->adminurl->get('admin.media',$page_url_params)).'" method="post" enctype="multipart/form-data" aria-disabled="false">'.
941     '<p>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
942     $core->formNonce().'</p>'.
943     '<div class="fileupload-ctrl"><p class="queue-message"></p><ul class="files"></ul></div>';
944
945     echo
946     '<div class="fileupload-buttonbar clear">';
947
948     echo
949     '<p><label for="upfile">'.'<span class="add-label one-file">'.__('Choose file').'</span>'.'</label>'.
950     '<button class="button choose_files">'.__('Choose files').'</button>'.
951     '<input type="file" id="upfile" name="upfile[]"'.($user_ui_enhanceduploader?' multiple="mutiple"':'').' data-url="'.html::escapeURL($core->adminurl->get('admin.media',$page_url_params)).'" /></p>';
952
953     echo
954     '<p class="max-sizer form-note">&nbsp;'.__('Maximum file size allowed:').' '.files::size(DC_MAX_UPLOAD_SIZE).'</p>';
955
956     echo
957     '<p class="one-file"><label for="upfiletitle">'.__('Title:').'</label>'.form::field(array('upfiletitle','upfiletitle'),35,255).'</p>'.
958     '<p class="one-file"><label for="upfilepriv" class="classic">'.__('Private').'</label> '.
959     form::checkbox(array('upfilepriv','upfilepriv'),1).'</p>';
960
961     if (!$user_ui_enhanceduploader) {
962          echo
963          '<p class="one-file form-help info">'.__('To send several files at the same time, you can activate the enhanced uploader in').
964          ' <a href="'.$core->adminurl->get("admin.user.preferences",array('tab' => 'user-options')).'">'.__('My preferences').'</a></p>';
965     }
966
967     echo
968     '<p class="clear"><button class="button clean">'.__('Refresh').'</button>'.
969     '<input class="button cancel one-file" type="reset" value="'.__('Clear all').'"/>'.
970     '<input class="button start" type="submit" value="'.__('Upload').'"/></p>'.
971     '</div>';
972
973     echo
974     '<p style="clear:both;">'.
975     form::hidden(array('d'),$d).
976     form::hidden(array('q'),$q).
977     form::hidden(array('popup'),$popup).
978     form::hidden(array('select'),$select).
979     form::hidden(array('plugin_id'),$plugin_id).
980     form::hidden(array('post_id'),$post_id).
981     form::hidden(array('link_type'),$link_type).
982     '</p>'.
983     '</form>'.
984     '</div>'.
985     '</div>';
986}
987
988# Empty remove form (for javascript actions)
989echo
990'<form id="media-remove-hide" action="'.html::escapeURL($core->adminurl->get('admin.media',$page_url_params)).'" method="post" class="hidden">'.
991'<div>'.
992form::hidden('rmyes',1).
993form::hidden('d',html::escapeHTML($d)).
994form::hidden(array('q'),$q).
995form::hidden(array('popup'),$popup).
996form::hidden(array('select'),$select).
997form::hidden(array('plugin_id'),$plugin_id).
998form::hidden(array('post_id'),$post_id).
999form::hidden(array('link_type'),$link_type).
1000form::hidden('remove','').
1001$core->formNonce().
1002'</div>'.
1003'</form>';
1004
1005if ((!$query) && ($core_media_writable || $core_media_archivable)) {
1006     echo
1007     '</div>';
1008}
1009
1010if (!$popup) {
1011     echo '<div class="info"><p>'.sprintf(__('Current settings for medias and images are defined in %s'),
1012     '<a href="'.$core->adminurl->get("admin.blog.pref").'#medias-settings">'.__('Blog parameters').'</a>').'</p></div>';
1013}
1014
1015call_user_func($close_f);
Note: See TracBrowser for help on using the repository browser.

Sites map