aboutsummaryrefslogtreecommitdiffstats
path: root/include/widgets.php
diff options
context:
space:
mode:
authorHabeas Codice <habeascodice@federated.social>2014-11-21 15:39:14 -0800
committerHabeas Codice <habeascodice@federated.social>2014-11-21 15:39:14 -0800
commitcf739c0361cce7f1c454a0e52809fba99cb40e84 (patch)
treeff75671dc4075cef1b35553680222fc166cdb401 /include/widgets.php
parentb224f8056cbf9b41994b44e48a7ad154976d1c88 (diff)
parentf17ef6aa90bc283e122a88e627cb464f065af2a6 (diff)
downloadvolse-hubzilla-cf739c0361cce7f1c454a0e52809fba99cb40e84.tar.gz
volse-hubzilla-cf739c0361cce7f1c454a0e52809fba99cb40e84.tar.bz2
volse-hubzilla-cf739c0361cce7f1c454a0e52809fba99cb40e84.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'include/widgets.php')
-rw-r--r--include/widgets.php60
1 files changed, 59 insertions, 1 deletions
diff --git a/include/widgets.php b/include/widgets.php
index 74bdb5d74..076a8fa91 100644
--- a/include/widgets.php
+++ b/include/widgets.php
@@ -810,7 +810,65 @@ function widget_photo($arr) {
$o .= '<img ' . (($zrl) ? ' class="zrl" ' : '')
. (($style) ? ' style="' . $style . '"' : '')
- . ' src="' . $url . '" />';
+ . ' src="' . $url . '" alt="' . t('photo/image') . '" />';
+
+ $o .= '</div>';
+
+ return $o;
+}
+
+
+function widget_photo_rand($arr) {
+
+ require_once('include/photos.php');
+ $style = $zrl = false;
+ $params = '';
+ if(array_key_exists('album',$arr) && isset($arr['album']))
+ $album = $arr['album'];
+ else
+ $album = '';
+
+ $channel_id = 0;
+ if(array_key_exists('channel_id',$arr) && intval($arr['channel_id']))
+ $channel_id = intval($arr['channel_id']);
+ if(! $channel_id)
+ $channel_id = get_app()->profile_uid;
+ if(! $channel_id)
+ return '';
+
+ $scale = ((array_key_exists('scale',$arr)) ? intval($arr['scale']) : 0);
+
+ $ret = photos_list_photos(array('channel_id' => $channel_id),get_app()->get_observer(),$album);
+
+ $filtered = array();
+ if($ret['success'] && $ret['photos'])
+ foreach($ret['photos'] as $p)
+ if($p['scale'] == $scale)
+ $filtered[] = $p['src'];
+
+ if($filtered) {
+ $e = mt_rand(0,count($filtered)-1);
+ $url = $filtered[$e];
+ }
+
+ if(strpos($url,'http') !== 0)
+ return '';
+
+ if(array_key_exists('style',$arr) && isset($arr['style']))
+ $style = $arr['style'];
+
+ // ensure they can't sneak in an eval(js) function
+
+ if(strpos($style,'(') !== false)
+ return '';
+
+ $url = zid($url);
+
+ $o = '<div class="widget">';
+
+ $o .= '<img class="zrl" '
+ . (($style) ? ' style="' . $style . '"' : '')
+ . ' src="' . $url . '" alt="' . t('photo/image') . '" />';
$o .= '</div>';