modular widgets
This commit is contained in:
		
					parent
					
						
							
								7b59ea7b13
							
						
					
				
			
			
				commit
				
					
						cd34051b68
					
				
			
		
					 3 changed files with 70 additions and 33 deletions
				
			
		
							
								
								
									
										28
									
								
								addon/widgets/widget_friends.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								addon/widgets/widget_friends.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,28 @@ | ||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | function widget_help(&$a, &$o, $conf) { | ||||||
|  | 	$o .= "Shows profile contacts"; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function widget_args(){ | ||||||
|  | 	return Array(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function widget_content(&$a, &$o, $conf){ | ||||||
|  | 
 | ||||||
|  | 	$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `user`.* FROM `profile` 
 | ||||||
|  | 			LEFT JOIN `user` ON `profile`.`uid` = `user`.`uid` | ||||||
|  | 			WHERE `user`.`uid` = %s AND `profile`.`is-default` = 1 LIMIT 1",
 | ||||||
|  | 			intval($conf['uid']) | ||||||
|  | 	); | ||||||
|  | 	 | ||||||
|  | 	if(!count($r)) return; | ||||||
|  | 	$a->profile = $r[0]; | ||||||
|  | 
 | ||||||
|  | 	$o .= "<style>
 | ||||||
|  | 		.f9k_widget .contact-block-div { display: block !important; float: left!important; width: 50px!important; height: 50px!important; margin: 2px!important;} | ||||||
|  | 		.f9k_widget #contact-block-end { clear: left; }
 | ||||||
|  | 	</style>";
 | ||||||
|  | 	$o .= _abs_url(contact_block()); | ||||||
|  | 	$o .= "<a href='".$a->get_baseurl().'/profile/'.$a->profile['nickname']."'>". t('Connect on Friendika!') ."</a>"; | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								addon/widgets/widget_like.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								addon/widgets/widget_like.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | ||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | function widget_help(&$a, &$o, $conf) { | ||||||
|  | 	$o .= "<p>Shows likes<br>Search "; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function widget_args(){ | ||||||
|  | 	return Array("KEY"); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function widget_content(&$a, &$o, $conf){ | ||||||
|  | } | ||||||
|  | @ -56,6 +56,7 @@ function widgets_settings(&$a,&$o) { | ||||||
| 		$o.='<h4>Widgets:</h4> | 		$o.='<h4>Widgets:</h4> | ||||||
| 		<ul> | 		<ul> | ||||||
| 			<li><a href="'.$a->get_baseurl().'/widgets/friends/?p=1&k='.$key.'">Friend list</a></li> | 			<li><a href="'.$a->get_baseurl().'/widgets/friends/?p=1&k='.$key.'">Friend list</a></li> | ||||||
|  | 			<li><a href="'.$a->get_baseurl().'/widgets/like/?p=1&k='.$key.'">Likes count</a></li> | ||||||
| 		</ul> | 		</ul> | ||||||
| 		'; | 		'; | ||||||
| 	} | 	} | ||||||
|  | @ -92,22 +93,38 @@ function widgets_content(&$a) { | ||||||
| 
 | 
 | ||||||
| 	$o = "";	 | 	$o = "";	 | ||||||
| 
 | 
 | ||||||
| //	echo "<pre>"; var_dump($a->argv); die();
 | 	$widgetfile =dirname(__file__)."/widget_".$a->argv[1].".php"; | ||||||
|  | 	if (file_exists($widgetfile)){ | ||||||
|  | 		require_once($widgetfile); | ||||||
|  | 	} 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"){ | 	if ($a->argv[2]=="cb"){ | ||||||
| 		switch($a->argv[1]) { | 		if (!local_user()){ | ||||||
| 			case 'friends':  | 			if (!isset($_GET['s'])) | ||||||
| 				widget_friends_content($a, $o, $conf); | 				{header('HTTP/1.0 400 Bad Request'); killme();} | ||||||
| 				break; | 			 | ||||||
|  | 			if (substr($_GET['s'],0,strlen($conf['site'])) !== $conf['site']) | ||||||
|  | 				{header('HTTP/1.0 400 Bad Request'); killme();} | ||||||
| 		}  | 		}  | ||||||
|  | 		widget_content($a, $o, $conf); | ||||||
| 		 | 		 | ||||||
| 	} else { | 	} else { | ||||||
| 
 | 
 | ||||||
| 		 | 		 | ||||||
| 		if (isset($_GET['p'])) { | 		if (isset($_GET['p']) && local_user()==$conf['uid'] ) { | ||||||
| 			$o .= "<style>.f9k_widget { float: left;border:1px solid black; }</style>"; | 			$o .= "<style>.f9k_widget { float: left;border:1px solid black; }</style>"; | ||||||
| 			$o .= "<h1>Preview Widget</h1>"; | 			$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("Plugin Settings") .'</a>'; | ||||||
| 			$o .= "<br style='clear:left'/><br/>";			 | 			$o .= "<br style='clear:left'/><br/>";			 | ||||||
|  | 			widget_help($a, $o, $conf); | ||||||
|  | 			$o .= "<br style='clear:left'/><br/>"; | ||||||
| 			$o .= "<script>"; | 			$o .= "<script>"; | ||||||
| 		} else { | 		} else { | ||||||
| 			header("content-type: application/x-javascript"); | 			header("content-type: application/x-javascript"); | ||||||
|  | @ -126,12 +143,17 @@ function widgets_content(&$a) { | ||||||
| 
 | 
 | ||||||
| 	 | 	 | ||||||
| 		if (isset($_GET['p'])) { | 		if (isset($_GET['p'])) { | ||||||
|  | 			$jsargs = implode("</em>,<em>", widget_args()); | ||||||
|  | 			if ($jsargs!='') $jsargs = "&a=<em>".$jsargs."</em>"; | ||||||
|  | 				 | ||||||
| 			$o .= "</script>
 | 			$o .= "</script>
 | ||||||
| 			<br style='clear:left'/><br/> | 			<br style='clear:left'/><br/> | ||||||
| 			<h4>Copy and paste this code</h4> | 			<h4>Copy and paste this code</h4> | ||||||
| 			<code>" | 			<code>" | ||||||
| 			 | 			 | ||||||
| 			.htmlspecialchars('<script src="'.$a->get_baseurl().'/widgets/'.$a->argv[1].'?k='.$conf['key'].'"></script>') | 			.htmlspecialchars('<script src="'.$a->get_baseurl().'/widgets/'.$a->argv[1].'?k='.$conf['key']) | ||||||
|  | 			.$jsargs | ||||||
|  | 			.htmlspecialchars('"></script>') | ||||||
| 			."</code>"; | 			."</code>"; | ||||||
| 			return $o; | 			return $o; | ||||||
| 		}	 | 		}	 | ||||||
|  | @ -143,31 +165,6 @@ function widgets_content(&$a) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| function widget_friends_content(&$a, &$o, $conf){ |  | ||||||
| 	if (!local_user()){ |  | ||||||
| 		if (!isset($_GET['s'])) |  | ||||||
| 			header('HTTP/1.0 400 Bad Request'); |  | ||||||
| 
 | 
 | ||||||
| 		if (substr($_GET['s'],0,strlen($conf['site'])) !== $conf['site']) |  | ||||||
| 			header('HTTP/1.0 400 Bad Request'); |  | ||||||
| 	}  |  | ||||||
| 	$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `user`.* FROM `profile` 
 |  | ||||||
| 			LEFT JOIN `user` ON `profile`.`uid` = `user`.`uid` |  | ||||||
| 			WHERE `user`.`uid` = %s AND `profile`.`is-default` = 1 LIMIT 1",
 |  | ||||||
| 			intval($conf['uid']) |  | ||||||
| 	); |  | ||||||
| 	 |  | ||||||
| 	if(!count($r)) return; |  | ||||||
| 	$a->profile = $r[0]; |  | ||||||
| 
 |  | ||||||
| 	$o .= "<style>
 |  | ||||||
| 		.f9k_widget .contact-block-div { display: block !important; float: left!important; width: 50px!important; height: 50px!important; margin: 2px!important;} |  | ||||||
| 		.f9k_widget #contact-block-end { clear: left; }
 |  | ||||||
| 	</style>";
 |  | ||||||
| 	$o .= _abs_url(contact_block()); |  | ||||||
| 	$o .= "<a href='".$a->get_baseurl().'/profile/'.$a->profile['nickname']."'>". t('Connect on Friendika!') ."</a>"; |  | ||||||
| 	 |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|   |   | ||||||
| ?>
 | ?>
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue