]> git.mxchange.org Git - friendica.git/blobdiff - mod/fbrowser.php
Replace *.ini.php by *.config.php in comments
[friendica.git] / mod / fbrowser.php
index 92c6bd3b4becf14456c51e2ccdf9cbc78d3b7f64..cc51d41995301def0f1fe7f7a43ed910da538aa2 100644 (file)
  * @author             Fabio Comuni <fabrixxm@kirgroup.com>
  */
 
-require_once('include/Photo.php');
+use Friendica\App;
+use Friendica\Core\L10n;
+use Friendica\Core\Renderer;
+use Friendica\Core\System;
+use Friendica\Database\DBA;
+use Friendica\Object\Image;
 
 /**
  * @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 "<pre>"; 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 = [["", L10n::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())
+
+                       if ($a->argc==2) {
+                               $albums = q("SELECT distinct(`album`) AS `album` FROM `photo` WHERE `uid` = %d AND `album` != '%s' AND `album` != '%s' ",
+                                       intval(local_user()),
+                                       DBA::escape('Contact Photos'),
+                                       DBA::escape(L10n::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 [bin2hex($el['album']),$el['album']];
+                               };
+
+                               $albums = array_map("_map_folder1", $albums);
                        }
-                       
+
                        $album = "";
-                       if ($a->argc==3){
+                       if ($a->argc==3) {
                                $album = hex2bin($a->argv[2]);
-                               $sql_extra = sprintf("AND `album` = '%s' ",dbesc($album));
+                               $sql_extra = sprintf("AND `album` = '%s' ", DBA::escape($album));
                                $sql_extra2 = "";
-                               $path[]=array($a->get_baseurl()."/fbrowser/image/".$a->argv[2]."/", $album);
+                               $path[]=[$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`, ANY_VALUE(`id`) AS `id`, ANY_VALUE(`filename`) AS `filename`, ANY_VALUE(`type`) AS `type`,
+                                       min(`scale`) AS `hiq`, max(`scale`) AS `loq`, ANY_VALUE(`desc`) AS `desc`, ANY_VALUE(`created`) AS `created`
+                                       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()),
+                               DBA::escape('Contact Photos'),
+                               DBA::escape(L10n::t('Contact Photos'))
                        );
-                       
-                       function files1($rr){ 
-                               global $a;
-                               $types = Photo::supportedTypes();
+
+                       function _map_files1($rr)
+                       {
+                               $a = get_app();
+                               $types = Image::supportedTypes();
                                $ext = $types[$rr['type']];
+                               $filename_e = $rr['filename'];
 
-                               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",
+                                       DBA::escape($rr['resource-id']));
+                               if ($p) {
+                                       $scale = $p[0]["scale"];
+                               } else {
+                                       $scale = $rr['loq'];
                                }
 
-                               return array( 
-                                       $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['hiq'] . '.' .$ext, 
-                                       $filename_e, 
-                                       $a->get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $rr['loq'] . '.'. $ext
-                               );
+                               return [
+                                       System::baseUrl() . '/photos/' . $a->user['nickname'] . '/image/' . $rr['resource-id'],
+                                       $filename_e,
+                                       System::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 = Renderer::getMarkupTemplate($template_file);
+
+                       $o =  Renderer::replaceMacros($tpl, [
+                               '$type'     => 'image',
+                               '$baseurl'  => System::baseUrl(),
+                               '$path'     => $path,
+                               '$folders'  => $albums,
+                               '$files'    => $files,
+                               '$cancel'   => L10n::t('Cancel'),
+                               '$nickname' => $a->user['nickname'],
+                               '$upload'   => L10n::t('Upload')
+                       ]);
+
                        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; 
-                                       list($m1,$m2) = explode("/",$rr['filetype']);
-                                       $filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip");
 
-                                       if($a->theme['template_engine'] === 'internal') {
-                                               $filename_e = template_escape($rr['filename']);
-                                       }
-                                       else {
-                                               $filename_e = $rr['filename'];
-                                       }
+                               function _map_files2($rr)
+                               {
+                                       $a = get_app();
+                                       list($m1,$m2) = explode("/", $rr['filetype']);
+                                       $filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip");
+                                       $filename_e = $rr['filename'];
 
-                                       return array( $a->get_baseurl() . '/attach/' . $rr['id'], $filename_e, $a->get_baseurl() . '/images/icons/16/' . $filetype . '.png'); 
+                                       return [System::baseUrl() . '/attach/' . $rr['id'], $filename_e, System::baseUrl() . '/images/icons/16/' . $filetype . '.png'];
                                }
-                               $files = array_map("files2", $files);
-                               //echo "<pre>"; 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 = Renderer::getMarkupTemplate($template_file);
+                               $o = Renderer::replaceMacros($tpl, [
+                                       '$type'     => 'file',
+                                       '$baseurl'  => System::baseUrl(),
+                                       '$path'     => [ [ "", L10n::t("Files")] ],
+                                       '$folders'  => false,
+                                       '$files'    => $files,
+                                       '$cancel'   => L10n::t('Cancel'),
+                                       '$nickname' => $a->user['nickname'],
+                                       '$upload'   => L10n::t('Upload')
+                               ]);
                        }
-               
+
                        break;
        }
-       
 
-       killme();
-       
+       if (x($_GET, 'mode')) {
+               return $o;
+       } else {
+               echo $o;
+               killme();
+       }
 }