Dotclear

source: admin/media.php @ 3916:15f69243f128

Revision 3916:15f69243f128, 37.5 KB checked in by franck <carnet.franck.paul@…>, 7 years ago (diff)

Cope better with the hidden dirs, show the final name of the newly created dir - closes #2290

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

Sites map