Smilies to src
This commit is contained in:
Michael Vogel 2017-11-11 13:44:01 +01:00 committed by GitHub
commit be13332807
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 49 additions and 39 deletions

View file

@ -1,6 +1,7 @@
<?php
use Friendica\App;
use Friendica\Content\Smilies;
use Friendica\Core\Cache;
use Friendica\Core\System;
use Friendica\Core\Config;
@ -11,7 +12,6 @@ require_once 'include/map.php';
require_once 'mod/proxy.php';
require_once 'include/Contact.php';
require_once 'include/plaintext.php';
require_once 'include/Smilies.php';
function bb_PictureCacheExt($matches) {
if (strpos($matches[3], "data:image/") === 0) {

View file

@ -1,13 +1,13 @@
<?php
use Friendica\App;
use Friendica\Content\Smilies;
use Friendica\Core\Config;
use Friendica\Core\PConfig;
use Friendica\Core\System;
use Friendica\Database\DBM;
require_once "include/friendica_smarty.php";
require_once "include/Smilies.php";
require_once "include/map.php";
require_once "mod/proxy.php";

View file

@ -1,12 +1,12 @@
<?php
use Friendica\App;
use Friendica\Content\Smilies;
use Friendica\Core\System;
use Friendica\Database\DBM;
require_once('include/acl_selectors.php');
require_once('include/message.php');
require_once('include/Smilies.php');
require_once 'include/acl_selectors.php';
require_once 'include/message.php';
function message_init(App $a) {

View file

@ -4,10 +4,10 @@
* @file mod/smilies.php
*/
use Friendica\App;
use Friendica\Content\Smilies;
require_once("include/Smilies.php");
function smilies_content(App $a) {
function smilies_content(App $a)
{
if ($a->argv[1] === "json") {
$tmp = Smilies::get_list();
$results = array();

View file

@ -1,7 +1,7 @@
<?php
/**
* @file include/Smilies.php
* @file src/Content/Smilies.php
* @brief This file contains the Smilies class which contains functions to handle smiles
*
* @todo Use the shortcodes from here:
@ -12,6 +12,7 @@
* Have also a look here:
* https://www.webpagefx.com/tools/emoji-cheat-sheet/
*/
namespace Friendica\Content;
use Friendica\App;
use Friendica\Core\Config;
@ -22,8 +23,8 @@ use Friendica\Core\System;
* This class contains functions to handle smiles
*/
class Smilies {
class Smilies
{
/**
* @brief Replaces/adds the emoticon list
*
@ -33,7 +34,8 @@ class Smilies {
* @param string $smiley The text smilie
* @param string $representation The replacement
*/
public static function add(&$b, $smiley, $representation) {
public static function add(&$b, $smiley, $representation)
{
$found = array_search($smiley, $b['texts']);
if (!is_int($found)) {
@ -55,8 +57,8 @@ class Smilies {
*
* @hook smilie ('texts' => smilies texts array, 'icons' => smilies html array)
*/
public static function get_list() {
public static function get_list()
{
$texts = array(
'&lt;3',
'&lt;/3',
@ -157,10 +159,13 @@ class Smilies {
*
* @return string HML Output of the Smilie
*/
public static function replace($s, $sample = false, $no_images = false) {
public static function replace($s, $sample = false, $no_images = false)
{
if (intval(Config::get('system', 'no_smilies'))
|| (local_user() && intval(PConfig::get(local_user(),'system','no_smilies'))))
|| (local_user() && intval(PConfig::get(local_user(), 'system', 'no_smilies')))
) {
return $s;
}
$s = preg_replace_callback('/<pre>(.*?)<\/pre>/ism', 'self::encode', $s);
$s = preg_replace_callback('/<code>(.*?)<\/code>/ism', 'self::encode', $s);
@ -170,7 +175,7 @@ class Smilies {
if ($no_images) {
$cleaned = array('texts' => array(), 'icons' => array());
$icons = $params['icons'];
foreach ($icons AS $key => $icon) {
foreach ($icons as $key => $icon) {
if (!strstr($icon, '<img ')) {
$cleaned['texts'][] = $params['texts'][$key];
$cleaned['icons'][] = $params['icons'][$key];
@ -186,8 +191,7 @@ class Smilies {
for ($x = 0; $x < count($params['texts']); $x ++) {
$s .= '<dl><dt>' . $params['texts'][$x] . '</dt><dd>' . $params['icons'][$x] . '</dd></dl>';
}
}
else {
} else {
$params['string'] = preg_replace_callback('/&lt;(3+)/', 'self::preg_heart', $params['string']);
$s = str_replace($params['texts'], $params['icons'], $params['string']);
}
@ -198,11 +202,13 @@ class Smilies {
return $s;
}
private static function encode($m) {
private static function encode($m)
{
return(str_replace($m[1], base64url_encode($m[1]), $m[0]));
}
private static function decode($m) {
private static function decode($m)
{
return(str_replace($m[1], base64url_decode($m[1]), $m[0]));
}
@ -211,16 +217,20 @@ class Smilies {
* @brief expand <3333 to the correct number of hearts
*
* @param string $x
*
* @return string HTML Output
*
* @todo: Rework because it doesn't work correctly
*/
private static function preg_heart($x) {
if(strlen($x[1]) == 1)
private static function preg_heart($x)
{
if (strlen($x[1]) == 1) {
return $x[0];
}
$t = '';
for($cnt = 0; $cnt < strlen($x[1]); $cnt ++)
for ($cnt = 0; $cnt < strlen($x[1]); $cnt ++) {
$t .= '<img class="smiley" src="' . System::baseUrl() . '/images/smiley-heart.gif" alt="&lt;3" />';
}
$r = str_replace($x[0], $t, $x[0]);
return $r;
}