/**
* Name: Smileybutton
* Description: Adds a smileybutton to the Inputbox
- * Version: 0.2
+ * Version: 1.0
* Author: Johannes Schwab <https://friendica.jschwab.org/profile/ddorian>
+ * Maintainer: Hypolite Petovan <https://friendica.mrpetovan.com/profile/hypolite>
*/
+use Friendica\App;
+use Friendica\Core\Hook;
+use Friendica\DI;
-function smileybutton_install() {
- //Register hooks
- register_hook('jot_tool', 'addon/smileybutton/smileybutton.php', 'show_button');
-
- logger("installed smileybutton");
+function smileybutton_install()
+{
+ //Register hooks
+ Hook::register('jot_tool', 'addon/smileybutton/smileybutton.php', 'smileybutton_jot_tool');
}
-
-function smileybutton_uninstall() {
- //Delet registered hooks
- unregister_hook('jot_tool', 'addon/smileybutton/smileybutton.php', 'show_button');
-
- logger("removed smileybutton");
-}
-
-
-
-function show_button($a, &$b) {
+function smileybutton_jot_tool(string &$body)
+{
// Disable if theme is quattro
- // TODO add style for quattro
- if (current_theme() == 'quattro')
+ if (DI::app()->getCurrentTheme() == 'quattro') {
return;
+ }
- // Disable for mobile because most mobiles have a smiley key for ther own
- if ($a->is_mobile || $a->is_tablet)
+ // Disable for mobile because they have a smiley key of their own
+ if (DI::mode()->isMobile() || DI::mode()->isMobile()) {
return;
+ }
- /**
- *
- * I have copied this from /include/text.php, removed doubles
- * and escaped them.
- *
- */
-
- $texts = array(
- '<3',
- '</3',
- ':-)',
- ';-)',
- ':-(',
- ':-P',
- ':-X',
- ':-D',
- ':-O',
- '\\\\o/',
- 'O_o',
- ":\'(",
- ":-!",
- ":-/",
- ":-[",
- "8-)",
- ':beer',
- ':coffee',
+ $texts = [
+ '<3',
+ '</3',
+ ':-)',
+ ';-)',
+ ':-(',
+ ':-P',
+ ':-X',
+ ':-D',
+ ':-O',
+ '\\\\o/',
+ 'O_o',
+ ':\'(',
+ ':-!',
+ ':-/',
+ ':-[',
+ '8-)',
+ ':beer',
+ ':coffee',
':facepalm',
':like',
':dislike',
- '~friendica',
- 'red#'
-
- );
-
- $icons = array(
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-heart.gif" alt="<3" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-brokenheart.gif" alt="</3" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-smile.gif" alt=":-)" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-wink.gif" alt=";-)" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-frown.gif" alt=":-(" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-tongue-out.gif" alt=":-P" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-kiss.gif" alt=":-X" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-laughing.gif" alt=":-D" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-surprised.gif" alt=":-O" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-thumbsup.gif" alt="\\o/" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-Oo.gif" alt="O_o" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-cry.gif" alt=":\'(" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-foot-in-mouth.gif" alt=":-!" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-undecided.gif" alt=":-/" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-embarassed.gif" alt=":-[" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-cool.gif" alt="8-)" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/beer_mug.gif" alt=":beer" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/coffee.gif" alt=":coffee" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/smiley-facepalm.gif" alt=":facepalm" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/like.gif" alt=":like" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/dislike.gif" alt=":dislike" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/friendica-16.png" alt="~friendica" />',
- '<img class="smiley" src="' . $a->get_baseurl() . '/images/rhash-16.png" alt="red" />'
- );
-
+ '~friendica',
+ 'red#',
+ ];
+
+ $icons = [
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-heart.gif" alt="<3" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-brokenheart.gif" alt="</3" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-smile.gif" alt=":-)" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-wink.gif" alt=";-)" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-frown.gif" alt=":-(" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-tongue-out.gif" alt=":-P" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-kiss.gif" alt=":-X" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-laughing.gif" alt=":-D" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-surprised.gif" alt=":-O" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-thumbsup.gif" alt="\\o/" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-Oo.gif" alt="O_o" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-cry.gif" alt=":\'(" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-foot-in-mouth.gif" alt=":-!" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-undecided.gif" alt=":-/" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-embarassed.gif" alt=":-[" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-cool.gif" alt="8-)" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/beer_mug.gif" alt=":beer" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/coffee.gif" alt=":coffee" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/smiley-facepalm.gif" alt=":facepalm" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/like.gif" alt=":like" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/dislike.gif" alt=":dislike" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/friendica-16.png" alt="~friendica" />',
+ '<img class="smiley" src="' . DI::baseUrl() . '/images/rhash-16.png" alt="red" />'
+ ];
+
// Call hooks to get aditional smileies from other addons
- $params = array('texts' => $texts, 'icons' => $icons, 'string' => ""); //changed
- call_hooks('smilie', $params);
+ $params = ['texts' => $texts, 'icons' => $icons, 'string' => '']; //changed
+ Hook::callAll('smilie', $params);
//Generate html for smiley list
- $s = "<table class=\"smiley-preview\"><tr>\n\t";
- for($x = 0; $x < count($params['texts']); $x ++) {
+ $s = '<table class="smiley-preview"><tr>';
+ for ($x = 0; $x < count($params['texts']); $x++) {
$icon = $params['icons'][$x];
- $icon = str_replace('/>', 'onclick="smileybutton_addsmiley(\'' . $params['texts'][$x] . '\')"/>', $icon);
- $icon = str_replace('class="smiley"', 'class="smiley_preview"', $icon);
- $s .= "<td>" . $icon . "</td>";
- if (($x+1) % (sqrt(count($params['texts']))+1) == 0) {
- $s .= "</tr>\n\t<tr>";
+ $s .= '<td onclick="smileybutton_addsmiley(\'' . $params['texts'][$x] . '\')">' . $icon . '</td>';
+ if (($x + 1) % (floor(sqrt(count($params['texts']))) + 1) == 0) {
+ $s .= '</tr><tr>';
}
}
- $s .= "\t</tr></table>";
+ $s .= '</tr></table>';
//Add css to header
- $css_file = 'addon/smileybutton/view/'.current_theme().'.css';
- if (! file_exists($css_file))
- $css_file = 'addon/smileybutton/view/default.css';
- $css_url = $a->get_baseurl().'/'.$css_file;
+ $css_file = __DIR__ . '/view/' . DI::app()->getCurrentTheme() . '.css';
+ if (!file_exists($css_file)) {
+ $css_file = __DIR__ . '/view/default.css';
+ }
- $a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="'.$css_url.'" media="all" />'."\r\n";
+ DI::page()->registerStylesheet($css_file);
-
//Get the correct image for the theme
- $image = 'addon/smileybutton/view/'.current_theme().'.png';
- if (! file_exists($image))
+ $image = 'addon/smileybutton/view/' . DI::app()->getCurrentTheme() . '.png';
+ if (!file_exists($image)) {
$image = 'addon/smileybutton/view/default.png';
- $image_url = $a->get_baseurl().'/'.$image;
+ }
- //Add the hmtl and script to the page
- $b = <<< EOT
- <div id="profile-smiley-wrapper" style="display: block;" >
- <img src="$image_url" class="smiley_button" onclick="toggle_smileybutton()" alt="smiley">
- </div>
+ $image_url = DI::baseUrl() . '/' . $image;
- <div id="smileybutton" style="display:none;">
- $s
+ //Add the hmtl and script to the page
+ $body = <<< EOT
+ <div id="profile-smiley-wrapper">
+ <button type="button" class="btn btn-link smiley_button" onclick="toggle_smileybutton()"><img src="$image_url" alt="smiley"></button>
+ <div id="smileybutton">
+ $s
+ </div>
</div>
<script>
}
function smileybutton_addsmiley(text) {
- if(plaintext == "none") {
- var v = $("#profile-jot-text").val();
- v = v + text;
- $("#profile-jot-text").val(v);
- $("#profile-jot-text").focus();
- } else {
- var v = tinymce.activeEditor.getContent();
- v = v + text;
- tinymce.activeEditor.setContent(v);
- tinymce.activeEditor.focus();
- }
+ var v = $("#profile-jot-text").val();
+ v = v + text;
+ $("#profile-jot-text").val(v).focus();
}
</script>
EOT;
}
+