X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Ffbrowser.php;h=9a0e9244c1cbb617511187d7273f58f853e077db;hb=05dcedb54c8c8f2b48e47fa11cb6dd4586bdd9bb;hp=5ee813b4d68f1dc6e5efe66325eb251047e40561;hpb=cd2557303836a4f3cf595518c159f5d449b776f2;p=friendica.git diff --git a/mod/fbrowser.php b/mod/fbrowser.php index 5ee813b4d6..9a0e9244c1 100644 --- a/mod/fbrowser.php +++ b/mod/fbrowser.php @@ -10,100 +10,143 @@ require_once('include/Photo.php'); /** * @param App $a */ -function fbrowser_content($a){ - - if (!local_user()) +function fbrowser_content(App $a) { + + if (!local_user()) { killme(); + } - if ($a->argc==1) + if ($a->argc == 1) { killme(); - - //echo "
"; var_dump($a->argv); killme(); - - switch($a->argv[1]){ + } + + $template_file = "filebrowser.tpl"; + $mode = ""; + if (x($_GET,'mode')) { + $mode = "?mode=".$_GET['mode']; + } + + switch ($a->argv[1]) { case "image": - $path = array( array($a->get_baseurl()."/fbrowser/image/", t("Photos"))); + $path = array(array("", t("Photos"))); $albums = false; $sql_extra = ""; $sql_extra2 = " ORDER BY created DESC LIMIT 0, 10"; - + if ($a->argc==2){ - $albums = q("SELECT distinct(`album`) AS `album` FROM `photo` WHERE `uid` = %d ", - intval(local_user()) + $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')) ); - // anon functions only from 5.3.0... meglio tardi che mai.. - function folder1($el){return array(bin2hex($el['album']),$el['album']);} - $albums = array_map( "folder1" , $albums); - + + function _map_folder1($el){return array(bin2hex($el['album']),$el['album']);}; + $albums = array_map( "_map_folder1" , $albums); + } - + $album = ""; if ($a->argc==3){ $album = hex2bin($a->argv[2]); $sql_extra = sprintf("AND `album` = '%s' ",dbesc($album)); $sql_extra2 = ""; - $path[]=array($a->get_baseurl()."/fbrowser/image/".$a->argv[2]."/", $album); + $path[]=array($a->argv[2], $album); } - - $r = q("SELECT `resource-id`, `id`, `filename`, type, min(`scale`) AS `hiq`,max(`scale`) AS `loq`, `desc` - FROM `photo` WHERE `uid` = %d AND (height <= 320 AND width <= 320) $sql_extra + + $r = q("SELECT `resource-id`, `id`, `filename`, type, min(`scale`) AS `hiq`,max(`scale`) AS `loq`, `desc` + FROM `photo` WHERE `uid` = %d $sql_extra AND `album` != '%s' AND `album` != '%s' GROUP BY `resource-id` $sql_extra2", - intval(local_user()) + intval(local_user()), + dbesc('Contact Photos'), + dbesc( t('Contact Photos')) ); - - function files1($rr){ - global $a; + + function _map_files1($rr){ + $a = get_app(); $types = Photo::supportedTypes(); $ext = $types[$rr['type']]; - return array( - $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['hiq'] . '.' .$ext, - template_escape($rr['filename']), - $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['loq'] . '.'. $ext + + if($a->theme['template_engine'] === 'internal') { + $filename_e = template_escape($rr['filename']); + } + else { + $filename_e = $rr['filename']; + } + + // 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'])); + if ($p) + $scale = $p[0]["scale"]; + else + $scale = $rr['loq']; + + return array( + App::get_baseurl() . '/photos/' . $a->user['nickname'] . '/image/' . $rr['resource-id'], + $filename_e, + App::get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $scale . '.'. $ext ); } - $files = array_map("files1", $r); - - $tpl = get_markup_template("filebrowser.tpl"); - echo replace_macros($tpl, array( - '$type' => 'image', - '$baseurl' => $a->get_baseurl(), - '$path' => $path, - '$folders' => $albums, - '$files' =>$files, + $files = array_map("_map_files1", $r); + + $tpl = get_markup_template($template_file); + + $o = replace_macros($tpl, array( + '$type' => 'image', + '$baseurl' => App::get_baseurl(), + '$path' => $path, + '$folders' => $albums, + '$files' => $files, + '$cancel' => t('Cancel'), + '$nickname' => $a->user['nickname'], )); - - + + break; case "file": - if ($a->argc==2){ - $files = q("SELECT id, filename, filetype FROM `attach` WHERE `uid` = %d ", + if ($a->argc==2) { + $files = q("SELECT `id`, `filename`, `filetype` FROM `attach` WHERE `uid` = %d ", intval(local_user()) ); - - function files2($rr){ global $a; + + function _map_files2($rr){ + $a = get_app(); list($m1,$m2) = explode("/",$rr['filetype']); $filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip"); - return array( $a->get_baseurl() . '/attach/' . $rr['id'], template_escape($rr['filename']), $a->get_baseurl() . '/images/icons/16/' . $filetype . '.png'); + + if ($a->theme['template_engine'] === 'internal') { + $filename_e = template_escape($rr['filename']); + } else { + $filename_e = $rr['filename']; + } + + return array( App::get_baseurl() . '/attach/' . $rr['id'], $filename_e, App::get_baseurl() . '/images/icons/16/' . $filetype . '.png'); } - $files = array_map("files2", $files); - //echo ""; var_dump($files); killme(); - - - $tpl = get_markup_template("filebrowser.tpl"); - echo replace_macros($tpl, array( - '$type' => 'file', - '$baseurl' => $a->get_baseurl(), - '$path' => array( array($a->get_baseurl()."/fbrowser/image/", t("Files")) ), - '$folders' => false, - '$files' =>$files, + $files = array_map("_map_files2", $files); + + + $tpl = get_markup_template($template_file); + $o = replace_macros($tpl, array( + '$type' => 'file', + '$baseurl' => App::get_baseurl(), + '$path' => array( array( "", t("Files")) ), + '$folders' => false, + '$files' =>$files, + '$cancel' => t('Cancel'), + '$nickname' => $a->user['nickname'], )); - + } - + break; } - - killme(); - + if (x($_GET,'mode')) { + return $o; + } else { + echo $o; + killme(); + } + + }