2012-04-18 11:23:42 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package Friendica\modules
|
|
|
|
* @subpackage FileBrowser
|
|
|
|
* @author Fabio Comuni <fabrixxm@kirgroup.com>
|
|
|
|
*/
|
2012-06-07 18:17:31 +00:00
|
|
|
|
|
|
|
require_once('include/Photo.php');
|
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
/**
|
|
|
|
* @param App $a
|
|
|
|
*/
|
2017-01-09 12:12:54 +00:00
|
|
|
function fbrowser_content(App $a) {
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2017-01-27 04:04:38 +00:00
|
|
|
if (!local_user()) {
|
2012-04-18 11:23:42 +00:00
|
|
|
killme();
|
2017-01-27 04:04:38 +00:00
|
|
|
}
|
2012-04-18 11:23:42 +00:00
|
|
|
|
2017-01-27 04:04:38 +00:00
|
|
|
if ($a->argc == 1) {
|
2012-04-18 11:23:42 +00:00
|
|
|
killme();
|
2017-01-27 04:04:38 +00:00
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2015-07-28 15:20:40 +00:00
|
|
|
$template_file = "filebrowser.tpl";
|
|
|
|
$mode = "";
|
|
|
|
if (x($_GET,'mode')) {
|
|
|
|
$mode = "?mode=".$_GET['mode'];
|
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2017-01-27 04:04:38 +00:00
|
|
|
switch ($a->argv[1]) {
|
2012-04-18 11:23:42 +00:00
|
|
|
case "image":
|
2017-01-27 04:04:38 +00:00
|
|
|
$path = array(array("", t("Photos")));
|
2012-04-18 12:56:03 +00:00
|
|
|
$albums = false;
|
2012-04-18 13:15:52 +00:00
|
|
|
$sql_extra = "";
|
|
|
|
$sql_extra2 = " ORDER BY created DESC LIMIT 0, 10";
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
if ($a->argc==2){
|
2015-10-28 22:22:42 +00:00
|
|
|
$albums = q("SELECT distinct(`album`) AS `album` FROM `photo` WHERE `uid` = %d AND `album` != '%s' AND `album` != '%s' ",
|
|
|
|
intval(local_user()),
|
|
|
|
dbesc('Contact Photos'),
|
|
|
|
dbesc( t('Contact Photos'))
|
2012-04-18 11:23:42 +00:00
|
|
|
);
|
2015-11-08 11:05:23 +00:00
|
|
|
|
|
|
|
function _map_folder1($el){return array(bin2hex($el['album']),$el['album']);};
|
|
|
|
$albums = array_map( "_map_folder1" , $albums);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2012-04-18 12:56:03 +00:00
|
|
|
$album = "";
|
2012-04-18 11:23:42 +00:00
|
|
|
if ($a->argc==3){
|
|
|
|
$album = hex2bin($a->argv[2]);
|
2012-04-18 12:56:03 +00:00
|
|
|
$sql_extra = sprintf("AND `album` = '%s' ",dbesc($album));
|
2012-04-18 13:15:52 +00:00
|
|
|
$sql_extra2 = "";
|
2015-07-29 09:55:26 +00:00
|
|
|
$path[]=array($a->argv[2], $album);
|
2012-04-18 12:56:03 +00:00
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
|
|
|
$r = q("SELECT `resource-id`, `id`, `filename`, type, min(`scale`) AS `hiq`,max(`scale`) AS `loq`, `desc`
|
2015-10-28 22:22:42 +00:00
|
|
|
FROM `photo` WHERE `uid` = %d $sql_extra AND `album` != '%s' AND `album` != '%s'
|
2012-04-18 13:15:52 +00:00
|
|
|
GROUP BY `resource-id` $sql_extra2",
|
2015-10-28 22:22:42 +00:00
|
|
|
intval(local_user()),
|
|
|
|
dbesc('Contact Photos'),
|
|
|
|
dbesc( t('Contact Photos'))
|
2012-04-18 12:56:03 +00:00
|
|
|
);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2015-11-08 11:05:23 +00:00
|
|
|
function _map_files1($rr){
|
2016-12-13 09:16:36 +00:00
|
|
|
$a = get_app();
|
2012-06-07 18:17:31 +00:00
|
|
|
$types = Photo::supportedTypes();
|
|
|
|
$ext = $types[$rr['type']];
|
2012-12-22 19:57:29 +00:00
|
|
|
|
2017-01-26 14:23:30 +00:00
|
|
|
if ($a->theme['template_engine'] === 'internal') {
|
2012-12-22 19:57:29 +00:00
|
|
|
$filename_e = template_escape($rr['filename']);
|
2017-01-26 14:23:30 +00:00
|
|
|
} else {
|
2012-12-22 19:57:29 +00:00
|
|
|
$filename_e = $rr['filename'];
|
|
|
|
}
|
|
|
|
|
2016-04-10 11:36:26 +00:00
|
|
|
// Take the largest picture that is smaller or equal 640 pixels
|
|
|
|
$p = q("SELECT `scale` FROM `photo` WHERE `resource-id` = '%s' AND `height` <= 640 AND `width` <= 640 ORDER BY `resource-id`, `scale` LIMIT 1",
|
|
|
|
dbesc($rr['resource-id']));
|
2016-03-20 09:30:06 +00:00
|
|
|
if ($p)
|
|
|
|
$scale = $p[0]["scale"];
|
|
|
|
else
|
|
|
|
$scale = $rr['loq'];
|
|
|
|
|
2015-08-24 11:54:41 +00:00
|
|
|
return array(
|
2016-12-19 13:26:13 +00:00
|
|
|
App::get_baseurl() . '/photos/' . $a->user['nickname'] . '/image/' . $rr['resource-id'],
|
2015-08-24 11:54:41 +00:00
|
|
|
$filename_e,
|
2016-12-19 13:26:13 +00:00
|
|
|
App::get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $scale . '.'. $ext
|
2012-06-07 18:17:31 +00:00
|
|
|
);
|
|
|
|
}
|
2015-11-08 11:05:23 +00:00
|
|
|
$files = array_map("_map_files1", $r);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2015-07-28 15:20:40 +00:00
|
|
|
$tpl = get_markup_template($template_file);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2015-07-28 15:20:40 +00:00
|
|
|
$o = replace_macros($tpl, array(
|
2016-12-22 14:30:23 +00:00
|
|
|
'$type' => 'image',
|
|
|
|
'$baseurl' => App::get_baseurl(),
|
|
|
|
'$path' => $path,
|
|
|
|
'$folders' => $albums,
|
|
|
|
'$files' => $files,
|
|
|
|
'$cancel' => t('Cancel'),
|
2015-07-28 15:20:40 +00:00
|
|
|
'$nickname' => $a->user['nickname'],
|
2012-04-18 12:56:03 +00:00
|
|
|
));
|
2015-08-24 11:54:41 +00:00
|
|
|
|
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
break;
|
|
|
|
case "file":
|
2016-12-22 14:30:23 +00:00
|
|
|
if ($a->argc==2) {
|
2015-10-28 22:22:42 +00:00
|
|
|
$files = q("SELECT `id`, `filename`, `filetype` FROM `attach` WHERE `uid` = %d ",
|
2012-04-18 11:23:42 +00:00
|
|
|
intval(local_user())
|
|
|
|
);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2016-12-13 09:16:36 +00:00
|
|
|
function _map_files2($rr){
|
|
|
|
$a = get_app();
|
2012-04-18 11:23:42 +00:00
|
|
|
list($m1,$m2) = explode("/",$rr['filetype']);
|
|
|
|
$filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip");
|
2012-12-22 19:57:29 +00:00
|
|
|
|
2016-12-22 14:30:23 +00:00
|
|
|
if ($a->theme['template_engine'] === 'internal') {
|
2012-12-22 19:57:29 +00:00
|
|
|
$filename_e = template_escape($rr['filename']);
|
2016-12-22 14:30:23 +00:00
|
|
|
} else {
|
2012-12-22 19:57:29 +00:00
|
|
|
$filename_e = $rr['filename'];
|
|
|
|
}
|
|
|
|
|
2016-12-19 13:26:13 +00:00
|
|
|
return array( App::get_baseurl() . '/attach/' . $rr['id'], $filename_e, App::get_baseurl() . '/images/icons/16/' . $filetype . '.png');
|
2012-04-18 11:23:42 +00:00
|
|
|
}
|
2015-11-08 11:05:23 +00:00
|
|
|
$files = array_map("_map_files2", $files);
|
2015-08-24 11:54:41 +00:00
|
|
|
|
|
|
|
|
2015-07-28 15:20:40 +00:00
|
|
|
$tpl = get_markup_template($template_file);
|
|
|
|
$o = replace_macros($tpl, array(
|
2016-12-22 14:30:23 +00:00
|
|
|
'$type' => 'file',
|
|
|
|
'$baseurl' => App::get_baseurl(),
|
|
|
|
'$path' => array( array( "", t("Files")) ),
|
|
|
|
'$folders' => false,
|
|
|
|
'$files' =>$files,
|
|
|
|
'$cancel' => t('Cancel'),
|
2015-07-28 15:20:40 +00:00
|
|
|
'$nickname' => $a->user['nickname'],
|
2012-04-18 11:23:42 +00:00
|
|
|
));
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
break;
|
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2015-07-28 15:20:40 +00:00
|
|
|
if (x($_GET,'mode')) {
|
|
|
|
return $o;
|
|
|
|
} else {
|
|
|
|
echo $o;
|
|
|
|
killme();
|
|
|
|
}
|
2015-08-24 11:54:41 +00:00
|
|
|
|
2016-02-07 14:11:34 +00:00
|
|
|
|
2012-04-18 11:23:42 +00:00
|
|
|
}
|