Dotclear

source: admin/media.php @ 3212:b3683f2f5050

Revision 3212:b3683f2f5050, 28.8 KB checked in by franck <carnet.franck.paul@…>, 9 years ago (diff)

Some hidden fields missing

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

Sites map