<?php

use Friendica\Core\L10n;
use Friendica\Core\Renderer;
use Friendica\Database\DBA;
use Friendica\DI;

function like_widget_name() {
	return "Shows likes";
}
function like_widget_help() {
	return "Search first item which contains <em>KEY</em> and print like/dislike count";
}

function like_widget_args(){
	return ["KEY"];
}

function like_widget_size(){
	return ['60px','20px'];
}


function like_widget_content(&$a, $conf){
	$args = explode(",",$_GET['a']);


	$baseq="SELECT COUNT(`item`.`id`) as `c`, `p`.`id`
					FROM `item`,
						(SELECT `i`.`id` FROM `item` as `i` WHERE
							`i`.`visible` = 1 AND `i`.`deleted` = 0
							AND (( `i`.`wall` = 1 AND `i`.`allow_cid` = ''
									AND `i`.`allow_gid` = ''
									AND `i`.`deny_cid`  = ''
									AND `i`.`deny_gid`  = '' )
								  OR `i`.`uid` = %d )
							AND `i`.`body` LIKE '%%%s%%' LIMIT 1) as `p`
					WHERE `item`.`parent` = `p`.`id` ";

	// count likes
	$r = q( $baseq . "AND `item`.`verb` = 'http://activitystrea.ms/schema/1.0/like'",
			intval($conf['uid']),
			DBA::escape($args[0])
	);
	$likes = $r[0]['c'];

	$dislikes = 0;
	$strdislike = '';
	if (!DI::pConfig()->get(local_user(), 'system', 'hide_dislike')) {
		// count dislikes
		$r = q( $baseq . "AND `item`.`verb` = 'http://purl.org/macgirvin/dfrn/1.0/dislike'",
				intval($conf['uid']),
				DBA::escape($args[0])
		);
		$dislikes = $r[0]['c'];
		$strdislike = DI::l10n()->tt("%d person doesn't like this", "%d people don't like this", $dislikes);
	}


	$o = "";

#	$t = file_get_contents( dirname(__file__). "/widget_like.tpl" );
	$t = Renderer::getMarkupTemplate("widget_like.tpl", "addon/widgets/");
	$o .= Renderer::replaceMacros($t, [
		'$like'		=> $likes,
		'$strlike'	=> DI::l10n()->tt("%d person likes this", "%d people like this", $likes),

		'$dislike'	=> $dislikes,
		'$strdislike'=> $strdislike,
	]);

	return $o;
}