]> git.mxchange.org Git - friendica-addons.git/blobdiff - widgets/widgets.php
Update function names
[friendica-addons.git] / widgets / widgets.php
index cedaea34b1ca7167d9a99ca00bfcb22e6cce3be2..9867b884a08275e421c7e6416746a750e258ca7f 100644 (file)
@@ -1,40 +1,42 @@
 <?php
 /**
  * Name: Widgets
- * Description: Allow to embed info from friendika into another site
+ * Description: Allow to embed info from friendica into another site
  * Version: 1.0
  * Author: Fabio Comuni <http://kirgroup.com/profile/fabrix/>
  */
-        
+use Friendica\Core\Addon;
+use Friendica\Core\PConfig;
+
 function widgets_install() {
-       register_hook('plugin_settings', 'addon/widgets/widgets.php', 'widgets_settings'); 
-       register_hook('plugin_settings_post', 'addon/widgets/widgets.php', 'widgets_settings_post');
+       Addon::registerHook('addon_settings', 'addon/widgets/widgets.php', 'widgets_settings');
+       Addon::registerHook('addon_settings_post', 'addon/widgets/widgets.php', 'widgets_settings_post');
        logger("installed widgets");
 }
 function widgets_uninstall() {
-       unregister_hook('plugin_settings', 'addon/widgets/widgets.php', 'widgets_settings'); 
-       unregister_hook('plugin_settings_post', 'addon/widgets/widgets.php', 'widgets_settings_post');
+       Addon::unregisterHook('addon_settings', 'addon/widgets/widgets.php', 'widgets_settings');
+       Addon::unregisterHook('addon_settings_post', 'addon/widgets/widgets.php', 'widgets_settings_post');
 }
 
 
 function widgets_settings_post(){
-       
+       if(! local_user())
+               return;
        if (isset($_POST['widgets-submit'])){
-               del_pconfig(local_user(), 'widgets', 'key');
-               
+               PConfig::delete(local_user(), 'widgets', 'key');
+
        }
 }
 
 function widgets_settings(&$a,&$o) {
     if(! local_user())
-               return;         
-       
-       
-       $key = get_pconfig(local_user(), 'widgets', 'key' );
-       if ($key=='') { $key = mt_rand(); set_pconfig(local_user(), 'widgets', 'key', $key); }
+               return;
 
-       $widgets = array();
+
+       $key = PConfig::get(local_user(), 'widgets', 'key' );
+       if ($key=='') { $key = mt_rand(); PConfig::set(local_user(), 'widgets', 'key', $key); }
+
+       $widgets = [];
        $d = dir(dirname(__file__));
        while(false !== ($f = $d->read())) {
                 if(substr($f,0,7)=="widget_") {
@@ -42,16 +44,17 @@ function widgets_settings(&$a,&$o) {
                         $w=$m[1];
                         if ($w!=""){
                                require_once($f);
-                               $widgets[] = array($w, call_user_func($w."_widget_name"));
+                               $widgets[] = [$w, call_user_func($w."_widget_name")];
                        }
 
                 }
        }
 
-       
-       
-       $t = file_get_contents( dirname(__file__). "/settings.tpl" );
-       $o .= replace_macros($t, array(
+
+
+#      $t = file_get_contents( dirname(__file__). "/settings.tpl" );
+       $t = get_markup_template("settings.tpl", "addon/widgets/");
+       $o .= replace_macros($t, [
                '$submit' => t('Generate new key'),
                '$baseurl' => $a->get_baseurl(),
                '$title' => "Widgets",
@@ -59,8 +62,8 @@ function widgets_settings(&$a,&$o) {
                '$key' => $key,
                '$widgets_h' => t('Widgets available'),
                '$widgets' => $widgets,
-       ));
-       
+       ]);
+
 }
 
 function widgets_module() {
@@ -72,6 +75,10 @@ function _abs_url($s){
        return preg_replace("|href=(['\"])([^h][^t][^t][^p])|", "href=\$1".$a->get_baseurl()."/\$2", $s);
 }
 
+function _randomAlphaNum($length){
+       return substr(str_shuffle(str_repeat('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789',$length)),0,$length);
+}
+
 
 function widgets_content(&$a) {
 
@@ -86,12 +93,12 @@ function widgets_content(&$a) {
        if (!count($r)){
                if($a->argv[2]=="cb"){header('HTTP/1.0 400 Bad Request'); killme();}
                return;
-       }    
-       $conf = array();
+       }
+       $conf = [];
        $conf['uid'] = $r[0]['uid'];
        foreach($r as $e) { $conf[$e['k']]=$e['v']; }
-       
-       $o = "";        
+
+       $o = "";
 
        $widgetfile =dirname(__file__)."/widget_".$a->argv[1].".php";
        if (file_exists($widgetfile)){
@@ -99,23 +106,23 @@ function widgets_content(&$a) {
        } else {
                if($a->argv[2]=="cb"){header('HTTP/1.0 400 Bad Request'); killme();}
                return;
-       }               
-       
+       }
+
 
 
 
        //echo "<pre>"; var_dump($a->argv); die();
        if ($a->argv[2]=="cb"){
-               header('Access-Control-Allow-Origin: *');
+               /*header('Access-Control-Allow-Origin: *');*/
                $o .= call_user_func($a->argv[1].'_widget_content',$a, $conf);
-               
+
        } else {
 
-               
+
                if (isset($_GET['p']) && local_user()==$conf['uid'] ) {
                        $o .= "<style>.f9k_widget { float: left;border:1px solid black; }</style>";
                        $o .= "<h1>Preview Widget</h1>";
-                       $o .= '<a href="'.$a->get_baseurl().'/settings/addon">'. t("Plugin Settings") .'</a>';
+                       $o .= '<a href="'.$a->get_baseurl().'/settings/addon">'. t("Addon Settings") .'</a>';
 
                        $o .=  "<h4>".call_user_func($a->argv[1].'_widget_name')."</h4>";
                        $o .=  call_user_func($a->argv[1].'_widget_help');
@@ -124,46 +131,50 @@ function widgets_content(&$a) {
                } else {
                        header("content-type: application/x-javascript");
                }
-       
-       
 
-       
+
+
+               $widget_size = call_user_func($a->argv[1].'_widget_size');
+
                $script = file_get_contents(dirname(__file__)."/widgets.js");
-               $o .= replace_macros($script, array(
+               $o .= replace_macros($script, [
                        '$entrypoint' => $a->get_baseurl()."/widgets/".$a->argv[1]."/cb/",
                        '$key' => $conf['key'],
-                       '$widget_id' => 'f9a_'.$a->argv[1]."_". ceil(microtime(true)*100),
+                       '$widget_id' => 'f9a_'.$a->argv[1]."_"._randomAlphaNum(6),
                        '$loader' => $a->get_baseurl()."/images/rotator.gif",
                        '$args' => (isset($_GET['a'])?$_GET['a']:''),
-               ));
+                       '$width' => $widget_size[0],
+                       '$height' => $widget_size[1],
+                       '$type' => $a->argv[1],
+               ]);
+
 
-       
                if (isset($_GET['p'])) {
                        $wargs = call_user_func($a->argv[1].'_widget_args');
                        $jsargs = implode("</em>,<em>", $wargs);
                        if ($jsargs!='') $jsargs = "&a=<em>".$jsargs."</em>";
-                               
+
                        $o .= "</script>
                        <br style='clear:left'/><br/>
                        <h4>Copy and paste this code</h4>
                        <code>"
-                       
+
                        .htmlspecialchars('<script src="'.$a->get_baseurl().'/widgets/'.$a->argv[1].'?k='.$conf['key'])
                        .$jsargs
                        .htmlspecialchars('"></script>')
                        ."</code>";
 
-                       
+
                        return $o;
-               }       
-               
-       }       
-       
+               }
+
+       }
+
        echo $o;
        killme();
 }
 
 
 
+
 ?>