diff options
author | redmatrix <git@macgirvin.com> | 2016-04-18 20:38:38 -0700 |
---|---|---|
committer | redmatrix <git@macgirvin.com> | 2016-04-18 20:38:38 -0700 |
commit | 2a4e8972e0edfa3156d9ce54d68ce0e54c0ec289 (patch) | |
tree | 2376d950ba2bdc7753336a3e2b94865c95c238f2 /Zotlabs/Module/Fbrowser.php | |
parent | 2a61817bad96526994c0499f1fc0a843a9cc9405 (diff) | |
download | volse-hubzilla-2a4e8972e0edfa3156d9ce54d68ce0e54c0ec289.tar.gz volse-hubzilla-2a4e8972e0edfa3156d9ce54d68ce0e54c0ec289.tar.bz2 volse-hubzilla-2a4e8972e0edfa3156d9ce54d68ce0e54c0ec289.zip |
module updates
Diffstat (limited to 'Zotlabs/Module/Fbrowser.php')
-rw-r--r-- | Zotlabs/Module/Fbrowser.php | 136 |
1 files changed, 136 insertions, 0 deletions
diff --git a/Zotlabs/Module/Fbrowser.php b/Zotlabs/Module/Fbrowser.php new file mode 100644 index 000000000..eef3cb67d --- /dev/null +++ b/Zotlabs/Module/Fbrowser.php @@ -0,0 +1,136 @@ +<?php +namespace Zotlabs\Module; +/** + * @package Friendica\modules + * @subpackage FileBrowser + * @author Fabio Comuni <fabrixxm@kirgroup.com> + */ + +require_once('include/photo/photo_driver.php'); + +/** + * @param App $a + */ + +class Fbrowser extends \Zotlabs\Web\Controller { + + function get(){ + + if (!local_channel()) + killme(); + + if (\App::$argc==1) + killme(); + + //echo "<pre>"; var_dump(\App::$argv); killme(); + + switch(\App::$argv[1]){ + case "image": + $path = array( array(z_root()."/fbrowser/image/", t("Photos"))); + $albums = false; + $sql_extra = ""; + $sql_extra2 = " ORDER BY created DESC LIMIT 0, 10"; + + if (\App::$argc==2){ + $albums = q("SELECT distinct(`album`) AS `album` FROM `photo` WHERE `uid` = %d ", + intval(local_channel()) + ); + // anon functions only from 5.3.0... meglio tardi che mai.. + $albums = array_map( "self::folder1" , $albums); + + } + + $album = ""; + if (\App::$argc==3){ + $album = hex2bin(\App::$argv[2]); + $sql_extra = sprintf("AND `album` = '%s' ",dbesc($album)); + $sql_extra2 = ""; + $path[]=array(z_root()."/fbrowser/image/".\App::$argv[2]."/", $album); + } + + $r = q("SELECT `resource_id`, `id`, `filename`, type, min(`scale`) AS `hiq`,max(`scale`) AS `loq`, `description` + FROM `photo` WHERE `uid` = %d $sql_extra + GROUP BY `resource_id` $sql_extra2", + intval(local_channel()) + ); + + $files = array_map("self::files1", $r); + + $tpl = get_markup_template("filebrowser.tpl"); + echo replace_macros($tpl, array( + '$type' => 'image', + '$baseurl' => z_root(), + '$path' => $path, + '$folders' => $albums, + '$files' =>$files, + '$cancel' => t('Cancel'), + )); + + + break; + case "file": + if (\App::$argc==2){ + $files = q("SELECT id, filename, filetype FROM `attach` WHERE `uid` = %d ", + intval(local_channel()) + ); + + $files = array_map("self::files2", $files); + //echo "<pre>"; var_dump($files); killme(); + + + $tpl = get_markup_template("filebrowser.tpl"); + echo replace_macros($tpl, array( + '$type' => 'file', + '$baseurl' => z_root(), + '$path' => array( array(z_root()."/fbrowser/image/", t("Files")) ), + '$folders' => false, + '$files' =>$files, + '$cancel' => t('Cancel'), + )); + + } + + break; + } + + + killme(); + + } + + private static function folder1($el){ + return array(bin2hex($el['album']),$el['album']); + } + + + private static function files1($rr){ + + $ph = photo_factory(''); + $types = $ph->supportedTypes(); + $ext = $types[$rr['type']]; + + $filename_e = $rr['filename']; + + return array( + z_root() . '/photo/' . $rr['resource_id'] . '-' . $rr['hiq'] . '.' .$ext, + $filename_e, + z_root() . '/photo/' . $rr['resource_id'] . '-' . $rr['loq'] . '.'. $ext + ); + } + + private static function files2($rr){ + list($m1,$m2) = explode("/",$rr['filetype']); + $filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip"); + + if(\App::get_template_engine() === 'internal') { + $filename_e = template_escape($rr['filename']); + } + else { + $filename_e = $rr['filename']; + } + + return array( z_root() . '/attach/' . $rr['id'], $filename_e, z_root() . '/images/icons/16/' . $filetype . '.png'); + } + + +} |