Dotclear

source: admin/media.php @ 3099:82ce3d85c6be

Revision 3099:82ce3d85c6be, 21.7 KB checked in by franck <carnet.franck.paul@…>, 10 years ago (diff)

Add a search engine on media management page, closes #2138

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$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
34$nb_per_page = ((integer) $core->auth->user_prefs->interface->media_by_page ? (integer) $core->auth->user_prefs->interface->media_by_page : 30);
35
36# We are on home not comming from media manager
37if ($d === null && isset($_SESSION['media_manager_dir'])) {
38     # We get session information
39     $d = $_SESSION['media_manager_dir'];
40}
41
42if (!isset($_GET['page']) && isset($_SESSION['media_manager_page'])) {
43     $page = $_SESSION['media_manager_page'];
44}
45
46# We set session information about directory and page
47if ($d) {
48     $_SESSION['media_manager_dir'] = $d;
49} else {
50     unset($_SESSION['media_manager_dir']);
51}
52if ($page != 1) {
53     $_SESSION['media_manager_page'] = $page;
54} else {
55     unset($_SESSION['media_manager_page']);
56}
57
58# Get query in any
59$q = isset($_REQUEST['q']) ? $_REQUEST['q'] : null;
60
61# Sort combo
62$sort_combo = array(
63     __('By names, in ascending order') => 'name-asc',
64     __('By names, in descending order') => 'name-desc',
65     __('By dates, in ascending order') => 'date-asc',
66     __('By dates, in descending order') => 'date-desc'
67     );
68
69if (!empty($_GET['file_sort']) && in_array($_GET['file_sort'],$sort_combo)) {
70     $_SESSION['media_file_sort'] = $_GET['file_sort'];
71}
72$file_sort = !empty($_SESSION['media_file_sort']) ? $_SESSION['media_file_sort'] : null;
73$nb_per_page = !empty($_SESSION['nb_per_page']) ? (integer)$_SESSION['nb_per_page'] : $nb_per_page;
74if (!empty($_GET['nb_per_page']) && (integer)$_GET['nb_per_page'] > 0) {
75     $nb_per_page = $_SESSION['nb_per_page'] = (integer)$_GET['nb_per_page'];
76}
77
78$popup = (integer) !empty($_REQUEST['popup']);
79
80$page_url_params = new ArrayObject(array('popup' => $popup,'post_id' => $post_id));
81if ($d) {
82     $page_url_params['d'] = $d;
83}
84if ($plugin_id != '') {
85     $page_url_params['plugin_id'] = $plugin_id;
86}
87if ($q) {
88     $page_url_params['q'] = $q;
89}
90
91$core->callBehavior('adminMediaURLParams',$page_url_params);
92$page_url_params = (array) $page_url_params;
93
94if ($popup) {
95     $open_f = array('dcPage','openPopup');
96     $close_f = array('dcPage','closePopup');
97} else {
98     $open_f = array('dcPage','open');
99     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
100}
101
102$core_media_writable = false;
103try {
104     $core->media = new dcMedia($core);
105     if ($file_sort) {
106          $core->media->setFileSort($file_sort);
107     }
108     $query = false;
109     if ($q) {
110          $query = $core->media->searchMedia($q);
111     }
112     if (!$query) {
113          $core->media->chdir($d);
114          $core->media->getDir();
115     } else {
116          $d = null;
117          $core->media->chdir($d);
118     }
119     $core_media_writable = $core->media->writable();
120     $dir =& $core->media->dir;
121     if  (!$core_media_writable) {
122//        throw new Exception('you do not have sufficient permissions to write to this folder: ');
123     }
124} catch (Exception $e) {
125     $core->error->add($e->getMessage());
126}
127
128# Zip download
129if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
130{
131     try
132     {
133          @set_time_limit(300);
134          $fp = fopen('php://output','wb');
135          $zip = new fileZip($fp);
136          $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
137          $zip->addDirectory($core->media->root.'/'.$d,'',true);
138
139          header('Content-Disposition: attachment;filename='.date('Y-m-d').'-'.$core->blog->id.'-'.($d ? $d : 'media').'.zip');
140          header('Content-Type: application/x-zip');
141          $zip->write();
142          unset($zip);
143          exit;
144     }
145     catch (Exception $e)
146     {
147          $core->error->add($e->getMessage());
148     }
149}
150
151# New directory
152if ($dir && !empty($_POST['newdir']))
153{
154     try {
155          $core->media->makeDir($_POST['newdir']);
156          dcPage::addSuccessNotice(sprintf(
157               __('Directory "%s" has been successfully created.'),
158               html::escapeHTML($_POST['newdir']))
159          );
160          $core->adminurl->redirect('admin.media',$page_url_params);
161     } catch (Exception $e) {
162          $core->error->add($e->getMessage());
163     }
164}
165
166# Adding a file
167if ($dir && !empty($_FILES['upfile'])) {
168     // only one file per request : @see option singleFileUploads in admin/js/jsUpload/jquery.fileupload
169     $upfile = array('name' => $_FILES['upfile']['name'][0],
170          'type' => $_FILES['upfile']['type'][0],
171          'tmp_name' => $_FILES['upfile']['tmp_name'][0],
172          'error' => $_FILES['upfile']['error'][0],
173          'size' => $_FILES['upfile']['size'][0]
174          );
175
176     if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
177          header('Content-type: application/json');
178          $message = array();
179
180          try {
181               files::uploadStatus($upfile);
182               $new_file_id = $core->media->uploadFile($upfile['tmp_name'], $upfile['name']);
183
184               $message['files'][] = array(
185                    'name' => $upfile['name'],
186                    'size' => $upfile['size'],
187                    'html' => mediaItemLine($core->media->getFile($new_file_id),1,$query)
188               );
189          } catch (Exception $e) {
190               $message['files'][] = array('name' => $upfile['name'],
191                    'size' => $upfile['size'],
192                    'error' => $e->getMessage()
193                    );
194          }
195          echo json_encode($message);
196          exit();
197     } else {
198          try {
199               files::uploadStatus($upfile);
200
201               $f_title = (isset($_POST['upfiletitle']) ? $_POST['upfiletitle'] : '');
202               $f_private = (isset($_POST['upfilepriv']) ? $_POST['upfilepriv'] : false);
203
204               $core->media->uploadFile($upfile['tmp_name'],$upfile['name'],$f_title,$f_private);
205
206               dcPage::addSuccessNotice(__('Files have been successfully uploaded.'));
207               $core->adminurl->redirect('admin.media',$page_url_params);
208          } catch (Exception $e) {
209               $core->error->add($e->getMessage());
210          }
211     }
212}
213
214# Removing items
215if ($dir && !empty($_POST['medias']) && !empty($_POST['delete_medias'])) {
216     try {
217          foreach ($_POST['medias'] as $media) {
218               $core->media->removeItem(rawurldecode($media));
219          }
220          dcPage::addSuccessNotice(
221               sprintf(__('Successfully delete one media.',
222                            'Successfully delete %d medias.',
223                            count($_POST['medias'])
224                            ),
225                            count($_POST['medias'])
226               )
227          );
228          $core->adminurl->redirect('admin.media',$page_url_params);
229     } catch (Exception $e) {
230          $core->error->add($e->getMessage());
231     }
232}
233
234# Removing item from popup only
235if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
236{
237     $_POST['remove'] = rawurldecode($_POST['remove']);
238
239     try {
240          if (is_dir(path::real($core->media->getPwd().'/'.path::clean($_POST['remove'])))) {
241               $msg = __('Directory has been successfully removed.');
242          } else {
243               $msg = __('File has been successfully removed.');
244          }
245          $core->media->removeItem($_POST['remove']);
246          dcPage::addSuccessNotice($msg);
247          $core->adminurl->redirect('admin.media',$page_url_params);
248     } catch (Exception $e) {
249          $core->error->add($e->getMessage());
250     }
251}
252
253# Rebuild directory
254if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
255{
256     try {
257          $core->media->rebuild($d);
258
259          dcPage::success(sprintf(
260               __('Directory "%s" has been successfully rebuilt.'),
261               html::escapeHTML($d))
262          );
263          $core->adminurl->redirect('admin.media',$page_url_params);
264     } catch (Exception $e) {
265          $core->error->add($e->getMessage());
266     }
267}
268
269# DISPLAY confirm page for rmdir & rmfile
270if ($dir && !empty($_GET['remove']) && empty($_GET['noconfirm']))
271{
272     call_user_func($open_f,__('Media manager'),'',
273          dcPage::breadcrumb(
274               array(
275                    html::escapeHTML($core->blog->name) => '',
276                    __('Media manager') => '',
277                    __('confirm removal') => ''
278               ),
279               array('home_link' => !$popup)
280          )
281     );
282
283     echo
284     '<form action="'.html::escapeURL($core->adminurl->get('admin.media')).'" method="post">'.
285     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
286          html::escapeHTML($_GET['remove'])).'</p>'.
287     '<p><input type="submit" value="'.__('Cancel').'" /> '.
288     ' &nbsp; <input type="submit" name="rmyes" value="'.__('Yes').'" />'.
289     form::hidden('d',$d).
290     form::hidden('q',$q).
291     $core->adminurl->getHiddenFormFields('admin.media',$page_url_params).
292     $core->formNonce().
293     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
294     '</form>';
295
296     call_user_func($close_f);
297     exit;
298}
299
300/* DISPLAY Main page
301-------------------------------------------------------- */
302$core->auth->user_prefs->addWorkspace('interface');
303$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
304
305if (!isset($core->media)) {
306     $breadcrumb = dcPage::breadcrumb(
307          array(
308               html::escapeHTML($core->blog->name) => '',
309               __('Media manager') => ''
310          ),
311          array('home_link' => !$popup)
312     );
313} else {
314     if ($query || (!$query && $q)) {
315          $count = $query ? count($dir['files']) : 0;
316          $home_params = $page_url_params;
317          $home_params['d']='';
318          $home_params['q']='';
319          $breadcrumb = dcPage::breadcrumb(
320               array(
321                    html::escapeHTML($core->blog->name) => '',
322                    __('Media manager') => $core->adminurl->get('admin.media',$home_params),
323                    __('Search:').' '.$q.' ('.sprintf(__('%s file found','%s files found',$count),$count).')' => ''
324               ),
325               array('home_link' => !$popup)
326          );
327     } else {
328          $temp_params = $page_url_params;
329          $temp_params['d']='%s';
330          $bc_template = $core->adminurl->get('admin.media',$temp_params,'&amp;',true);
331          $breadcrumb_media = $core->media->breadCrumb($bc_template,'<span class="page-title">%s</span>');
332          if ($breadcrumb_media == '') {
333               $breadcrumb = dcPage::breadcrumb(
334                    array(
335                         html::escapeHTML($core->blog->name) => '',
336                         __('Media manager') => ''
337                    ),
338                    array('home_link' => !$popup)
339               );
340          } else {
341               $home_params = $page_url_params;
342               $home_params['d']='';
343
344               $breadcrumb = dcPage::breadcrumb(
345                    array(
346                         html::escapeHTML($core->blog->name) => '',
347                         __('Media manager') => $core->adminurl->get('admin.media',$home_params),
348                         $breadcrumb_media => ''
349                    ),
350                    array(
351                         'home_link' => !$popup,
352                         'hl' => false
353                    )
354               );
355          }
356     }
357}
358
359call_user_func($open_f,__('Media manager'),
360     dcPage::jsLoad('js/_media.js').
361     ($core_media_writable ? dcPage::jsUpload(array('d='.$d)) : ''),
362     $breadcrumb
363     );
364
365if ($popup) {
366     // Display notices
367     echo dcPage::notices();
368}
369
370if (!$core_media_writable) {
371     dcPage::warning(__('You do not have sufficient permissions to write to this folder.'));
372}
373
374if (!empty($_GET['mkdok'])) {
375     dcPage::success(__('Directory has been successfully created.'));
376}
377
378if (!empty($_GET['upok'])) {
379     dcPage::success(__('Files have been successfully uploaded.'));
380}
381
382if (!empty($_GET['rmfok'])) {
383     dcPage::success(__('File has been successfully removed.'));
384}
385
386if (!empty($_GET['rmdok'])) {
387     dcPage::success(__('Directory has been successfully removed.'));
388}
389
390if (!empty($_GET['rebuildok'])) {
391     dcPage::success(__('Directory has been successfully rebuilt.'));
392}
393
394if (!empty($_GET['unzipok'])) {
395     dcPage::success(__('Zip file has been successfully extracted.'));
396}
397
398if (!$dir) {
399     call_user_func($close_f);
400     exit;
401}
402
403if ($post_id) {
404     echo '<div class="form-note info"><p>'.sprintf(__('Choose a file to attach to entry %s by clicking on %s'),
405          '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
406          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />');
407     if ($core_media_writable) {
408          echo ' '.__('or').' '.sprintf('<a href="#fileupload">%s</a>',__('upload a new file'));
409     }
410     echo '</p></div>';
411}
412if ($popup) {
413     echo '<div class="info"><p>'.sprintf(__('Choose a file to insert into entry by clicking on %s'),
414          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />');
415     if ($core_media_writable) {
416          echo ' '.__('or').' '.sprintf('<a href="#fileupload">%s</a>',__('upload a new file'));
417     }
418     echo '</p></div>';
419}
420
421// Remove hidden directories (unless DC_SHOW_HIDDEN_DIRS is set to true)
422if (!defined('DC_SHOW_HIDDEN_DIRS') || (DC_SHOW_HIDDEN_DIRS == false)) {
423     for ($i = count($dir['dirs']) - 1; $i >= 0; $i--) {
424          if ($dir['dirs'][$i]->d) {
425               if (strpos($dir['dirs'][$i]->relname,'.') !== false) {
426                    unset($dir['dirs'][$i]);
427               }
428          }
429     }
430}
431$items = array_values(array_merge($dir['dirs'],$dir['files']));
432
433$fmt_form_media = '<form action="'.$core->adminurl->get("admin.media").'" method="post" id="form-medias">'.
434     '<div class="files-group">%s</div>'.
435     '<p class="hidden">'.$core->formNonce().
436     form::hidden(array('d'),$d).
437     form::hidden(array('q'),$q).
438     form::hidden(array('plugin_id'),$plugin_id).
439     '</p>';
440
441if (!$popup) {
442     $fmt_form_media .=
443     '<div class="medias-delete%s">'.
444     '<p class="checkboxes-helpers"></p>'.
445     '<p><input type="submit" class="delete" name="delete_medias" value="'.__('Remove selected medias').'"/></p>'.
446     '</div>';
447}
448$fmt_form_media .=
449     '</form>';
450
451echo '<div class="media-list">';
452if (count($items) == 0)
453{
454     echo
455     '<p>'.__('No file.').'</p>'.
456     sprintf($fmt_form_media,'',' hide'); // need for jsUpload to append new media
457}
458else
459{
460     $pager = new dcPager($page,count($items),$nb_per_page,10);
461
462     echo
463     '<form action="'.$core->adminurl->get("admin.media").'" method="get" id="search-form">'.
464     '<p><label for="search" class="classic">'.__('Search:').'</label> '.
465     form::field('q',20,255,$q).' '.
466     '<input type="submit" value="'.__('OK').'" />'.' '.
467     '<span class="form-note">'.__('Will search into media filename (including path), title and description').'</span>'.
468     form::hidden(array('popup'),$popup).
469     form::hidden(array('plugin_id'),$plugin_id).
470     form::hidden(array('post_id'),$post_id).
471     '</p>'.
472     '</form>'.
473     '<form action="'.$core->adminurl->get("admin.media").'" method="get" id="filters-form">'.
474     '<p class="two-boxes"><label for="file_sort" class="classic">'.__('Sort files:').'</label> '.
475     form::combo('file_sort',$sort_combo,$file_sort).'</p>'.
476     '<p class="two-boxes"><label for="nb_per_page" class="classic">'.__('Number of elements displayed per page:').'</label> '.
477     form::field('nb_per_page',5,3,(integer) $nb_per_page).' '.
478     '<input type="submit" value="'.__('OK').'" />'.
479     form::hidden(array('popup'),$popup).
480     form::hidden(array('plugin_id'),$plugin_id).
481     form::hidden(array('post_id'),$post_id).
482     form::hidden(array('q'),$q).
483     '</p>'.
484     '</form>'.
485     $pager->getLinks();
486
487     $dgroup = '';
488     $fgroup = '';
489     for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++,$j++)
490     {
491          if ($items[$i]->d) {
492               $dgroup .= mediaItemLine($items[$i],$j,$query);
493          } else {
494               $fgroup .= mediaItemLine($items[$i],$j,$query);
495          }
496     }
497
498     echo
499     ($dgroup != '' ? '<div class="folders-group">'.$dgroup.'</div>' : '').
500     sprintf($fmt_form_media,$fgroup,'');
501
502     echo $pager->getLinks();
503}
504if (!isset($pager)) {
505     echo
506     '<p class="clear"></p>';
507}
508echo
509'</div>';
510
511$core_media_archivable = $core->auth->check('media_admin',$core->blog->id) &&
512     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent));
513
514if ((!$query) && ($core_media_writable || $core_media_archivable)) {
515     echo
516     '<div class="vertical-separator">'.
517     '<h3 class="out-of-screen-if-js">'.sprintf(__('In %s:'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h3>';
518}
519
520if ((!$query) && ($core_media_writable || $core_media_archivable)) {
521     echo
522     '<div class="two-boxes odd">';
523
524     # Create directory
525     if ($core_media_writable)
526     {
527          echo
528          '<form action="'.$core->adminurl->getBase('admin.media').'" method="post" class="fieldset">'.
529          '<div id="new-dir-f">'.
530          '<h4 class="pretty-title">'.__('Create new directory').'</h4>'.
531          $core->formNonce().
532          '<p><label for="newdir">'.__('Directory Name:').'</label>'.
533          form::field(array('newdir','newdir'),35,255).'</p>'.
534          '<p><input type="submit" value="'.__('Create').'" />'.
535          $core->adminurl->getHiddenFormFields('admin.media',$page_url_params).
536          '</p>'.
537          '</div>'.
538          '</form>';
539     }
540
541     # Get zip directory
542     if ($core_media_archivable && !$popup)
543     {
544          echo
545          '<div class="fieldset">'.
546          '<h4 class="pretty-title">'.sprintf(__('Backup content of %s'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h4>'.
547          '<p><a class="button submit" href="'.$core->adminurl->get('admin.media',
548               array_merge($page_url_params,array('zipdl' => 1))).'">'.__('Download zip file').'</a></p>'.
549          '</div>';
550     }
551
552     echo
553     '</div>';
554}
555
556if (!$query && $core_media_writable)
557{
558     echo
559     '<div class="two-boxes fieldset even">';
560     if ($user_ui_enhanceduploader) {
561          echo
562          '<div class="enhanced_uploader">';
563     } else {
564          echo
565          '<div>';
566     }
567
568     echo
569     '<h4>'.__('Add files').'</h4>'.
570     '<p>'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
571     '<form id="fileupload" action="'.html::escapeURL($page_url).'" method="post" enctype="multipart/form-data" aria-disabled="false">'.
572     '<p>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
573     $core->formNonce().'</p>'.
574     '<div class="fileupload-ctrl"><p class="queue-message"></p><ul class="files"></ul></div>';
575
576     echo
577     '<div class="fileupload-buttonbar clear">';
578
579     echo
580     '<p><label for="upfile">'.'<span class="add-label one-file">'.__('Choose file').'</span>'.'</label>'.
581     '<button class="button choose_files">'.__('Choose files').'</button>'.
582     '<input type="file" id="upfile" name="upfile[]"'.($user_ui_enhanceduploader?' multiple="mutiple"':'').' data-url="'.html::escapeURL($page_url).'" /></p>';
583
584     echo
585     '<p class="max-sizer form-note">&nbsp;'.__('Maximum file size allowed:').' '.files::size(DC_MAX_UPLOAD_SIZE).'</p>';
586
587     echo
588     '<p class="one-file"><label for="upfiletitle">'.__('Title:').'</label>'.form::field(array('upfiletitle','upfiletitle'),35,255).'</p>'.
589     '<p class="one-file"><label for="upfilepriv" class="classic">'.__('Private').'</label> '.
590     form::checkbox(array('upfilepriv','upfilepriv'),1).'</p>';
591
592     if (!$user_ui_enhanceduploader) {
593          echo
594          '<p class="one-file form-help info">'.__('To send several files at the same time, you can activate the enhanced uploader in').
595          ' <a href="'.$core->adminurl->get("admin.user.preferences",array('tab' => 'user-options')).'">'.__('My preferences').'</a></p>';
596     }
597
598     echo
599     '<p class="clear"><button class="button clean">'.__('Refresh').'</button>'.
600     '<input class="button cancel one-file" type="reset" value="'.__('Clear all').'"/>'.
601     '<input class="button start" type="submit" value="'.__('Upload').'"/></p>'.
602     '</div>';
603
604     echo
605     '<p style="clear:both;">'.form::hidden(array('d'),$d).'</p>'.
606     '</form>'.
607     '</div>'.
608     '</div>';
609}
610
611# Empty remove form (for javascript actions)
612echo
613'<form id="media-remove-hide" action="'.html::escapeURL($page_url).'" method="post" class="hidden">'.
614'<div>'.
615form::hidden('rmyes',1).form::hidden('d',html::escapeHTML($d)).
616form::hidden(array('plugin_id'),$plugin_id).form::hidden('remove','').
617form::hidden(array('q'),$q).
618$core->formNonce().
619'</div>'.
620'</form>';
621
622if ((!$query) && ($core_media_writable || $core_media_archivable)) {
623     echo
624     '</div>';
625}
626
627if (!$popup) {
628     echo '<div class="info"><p>'.sprintf(__('Current settings for medias and images are defined in %s'),
629     '<a href="'.$core->adminurl->get("admin.blog.pref").'#medias-settings">'.__('Blog parameters').'</a>').'</p></div>';
630}
631
632call_user_func($close_f);
633
634/* ----------------------------------------------------- */
635function mediaItemLine($f,$i,$query)
636{
637     global $core, $page_url, $popup, $post_id, $plugin_id,$page_url_params;
638
639     $fname = $f->basename;
640     $file = $query ? $f->relname : $f->basename;
641
642     $class = 'media-item media-col-'.($i%2);
643
644     if ($f->d) {
645
646          $link = $core->adminurl->get('admin.media',array_merge($page_url_params,array('d' => html::sanitizeURL($f->relname) )));
647          if ($f->parent) {
648               $fname = '..';
649               $class .= ' media-folder-up';
650          } else {
651               $class .= ' media-folder';
652          }
653     } else {
654          $params = new ArrayObject(
655               array(
656                    'id' => $f->media_id,
657                    'plugin_id' => $plugin_id,
658                    'popup' => $popup,
659                    'post_id' => $post_id
660               )
661          );
662          $core->callBehavior('adminMediaURLParams',$params);
663          $params = (array) $params;
664          $link = $core->adminurl->get(
665               'admin.media.item', $params
666          );
667     }
668
669     $maxchars = 36;
670     if (strlen($fname) > $maxchars) {
671          $fname = substr($fname, 0, $maxchars-4).'...'.($f->d ? '' : files::getExtension($fname));
672     }
673     $res =
674     '<div class="'.$class.'"><p><a class="media-icon media-link" href="'.rawurldecode($link).'">'.
675     '<img src="'.$f->media_icon.'" alt="" />'.($query ? $file : $fname).'</a></p>';
676
677     $lst = '';
678
679     if (!$f->d) {
680          $lst .=
681          '<li>'.$f->media_title.'</li>'.
682          '<li>'.
683          $f->media_dtstr.' - '.
684          files::size($f->size).' - '.
685          '<a href="'.$f->file_url.'">'.__('open').'</a>'.
686          '</li>';
687     }
688
689     $act = '';
690
691     if ($post_id && !$f->d) {
692          $act .=
693          '<a class="attach-media" title="'.__('Attach this file to entry').'" href="'.
694          $core->adminurl->get("admin.post.media", array('media_id' => $f->media_id, 'post_id' => $post_id,'attach' => 1)).
695          '">'.
696          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'"/>'.
697          '</a>';
698     }
699
700     if ($popup && !$f->d) {
701          $act .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
702          'title="'.__('Insert this file into entry').'" /></a> ';
703     }
704
705     if ($f->del) {
706          if (!$popup && !$f->d) {
707               $act .= form::checkbox(array('medias[]', 'media_'.rawurlencode($file)),$file);
708          } else {
709               $act .= '<a class="media-remove" '.
710               'href="'.html::escapeURL($page_url).
711               '&amp;plugin_id='.$plugin_id.
712               '&amp;d='.rawurlencode($GLOBALS['d']).
713               '&amp;q='.rawurlencode($GLOBALS['q']).
714               '&amp;remove='.rawurlencode($file).'">'.
715               '<img src="images/trash.png" alt="'.__('Delete').'" title="'.__('delete').'" /></a>';
716          }
717     }
718
719     $lst .= ($act != '' ? '<li class="media-action">&nbsp;'.$act.'</li>' : '');
720
721     // Show player if relevant
722     $file_type = explode('/',$f->type);
723     if ($file_type[0] == 'audio')
724     {
725          $lst .= '<li>'.dcMedia::audioPlayer($f->type,$f->file_url,$core->adminurl->get("admin.home",array('pf' => 'player_mp3.swf'))).'</li>';
726     }
727
728     $res .=   ($lst != '' ? '<ul>'.$lst.'</ul>' : '');
729
730     $res .= '</div>';
731
732     return $res;
733}
Note: See TracBrowser for help on using the repository browser.

Sites map