<?php
/*
=====================================================
DataLife Engine - by SoftNews Media Group
-----------------------------------------------------
http://dle-news.ru/
-----------------------------------------------------
Copyright (c) 2004-2026 SoftNews Media Group
=====================================================
This code is protected by copyright
=====================================================
File: comments.php
-----------------------------------------------------
Use: WYSIWYG for comments
=====================================================
*/
if (!defined('DATALIFEENGINE')) {
header("HTTP/1.1 403 Forbidden");
header('Location: ../../');
die("Hacking attempt!");
}
$get_lang = isset($_GET['lang']) ? totranslit($_GET['lang']) : 'en';
$lang_list = get_folder_list();
$language = 'English';
foreach($lang_list as $value) {
if( isset($value['code']) AND $value['code'] == $get_lang ) {
$language = $value['folder'];
break;
}
}
include ROOT_DIR . '/language/' . $language . '/website.lng';
if( $config['emoji'] ) {
$emoji_script = <<<HTML
var text_last_emoji = "{$lang['emoji_last']}";
function emojiFromHex(hex) {
try {
if ( navigator.platform.indexOf('Win') > -1 && hex.match( /^1F1(E[6-9A-F]|F[0-9A-F])/ ) ) {
return null;
}
var decimals = [];
var hexPoints = hex.split('-');
for ( var p = 0; p < hexPoints.length; p++ ) {
decimals.push( parseInt( hexPoints[p], 16 ) );
}
return String.fromCodePoint.apply( null, decimals );
} catch ( err ) {
return null;
}
}
function get_emoji() {
try {
return JSON.parse(localStorage.getItem('last_emoji'));
} catch (e) {
return null;
}
}
function set_emoji(value) {
try {
localStorage.setItem('last_emoji', JSON.stringify(value));
} catch (e) {
}
}
function in_array(needle, haystack){
for (var i=0, len=haystack.length;i<len;i++) {
if (haystack[i] == needle) return true;
}
return false;
}
function display_editor_last_emoji(){
var emoji_array = get_emoji();
var emoji = '';
var div = '';
if( Array.isArray( emoji_array ) && emoji_array.length ) {
div += '<div class="emoji_category"><b>'+text_last_emoji+'</b></div>';
div += '<div class="emoji_list">';
for (var i=0, len=emoji_array.length;i<len;i++) {
emoji = emojiFromHex(emoji_array[i]);
if(emoji) {
div += '<div class="emoji_symbol" data-emoji="'+emoji_array[i]+'"><a onclick="insert_editor_emoji(\''+emoji+'\', \''+emoji_array[i]+'\'); return false;">'+emoji+'</a></div>';
}
}
div += '</div>';
divs = document.getElementsByClassName( 'last_emoji' );
$('.last_emoji').html(div);
}
}
function insert_editor_emoji(emoji, code) {
parent.tinyMCE.execCommand('mceInsertContent',false,'<span class="native-emoji noncontenteditable">'+emoji+'</span>');
var emoji_array = get_emoji();
if( Array.isArray( emoji_array ) ) {
if( !in_array( code, emoji_array ) ) {
if(emoji_array.length > 15 ) {
emoji_array.pop();
}
emoji_array.unshift(code);
}
} else {
emoji_array = [];
emoji_array.push(code);
}
set_emoji(emoji_array);
display_editor_last_emoji();
parent.tinyMCE.activeEditor.windowManager.close();
}
$(function(){
var p = parent;
var parentDoc = window.parent.document;
var root = parentDoc.documentElement;
var fontSize = window.parent.getComputedStyle(root).getPropertyValue('--font-size-base').trim();
if (fontSize) {
fontSize = window.parent.getComputedStyle(parentDoc.body).fontSize;
} else {
fontSize = '0.9rem';
}
document.body.style.fontSize = fontSize;
if(p.$('body').hasClass('dle_theme_dark')){
var body = document.body;
body.classList.add("dle_theme_dark");
}
$(".emoji_box div[data-emoji]").each(function(){
var code = $(this).data('emoji');
var emoji = emojiFromHex($(this).data('emoji'));
if(emoji) {
$(this).html('<a onclick="insert_editor_emoji(\''+emoji+'\', \''+code+'\'); return false;">'+emoji+'</a>');
} else {
$(this).remove();
}
});
display_editor_last_emoji();
var parenthtmlElement = parent.document.getElementsByTagName("html")[0];
if( parenthtmlElement.className ) {
var htmlElement = document.querySelector("html");
var htmlclasses = htmlElement.classList;
htmlclasses.add(parenthtmlElement.className);
}
});
HTML;
$output = <<<HTML
<div class="emoji_box"><div class="last_emoji"></div>
HTML;
$emoji = json_decode (file_get_contents (ROOT_DIR . "/public/emoticons/emoji.json" ) );
foreach ($emoji as $key => $value ) {
$i = 0;
$output .= "<div class=\"emoji_category\"><b>".$lang['emoji_'.$value->category]."</b></div>
<div class=\"emoji_list\">";
foreach ($value->emoji as $symbol ) {
$i++;
$output .= "<div class=\"emoji_symbol\" data-emoji=\"{$symbol->code}\"></div>";
}
$output .= "</div>";
}
$output .= "</div>";
} else {
$emoji_script = "";
$i = 0;
$output = "<table style=\"width:100%;border: 0px;padding: 0px;\"><tr>";
$smilies = explode(",", $config['smilies']);
$count_smilies = count($smilies);
foreach($smilies as $smile)
{
$i++;
$smile = trim($smile);
$sm_image ="";
if( file_exists( ROOT_DIR . "/public/emoticons/" . $smile . ".png" ) ) {
if( file_exists( ROOT_DIR . "/public/emoticons/" . $smile . "@2x.png" ) ) {
$sm_image = "<img alt=\"{$smile}\" class=\"emoji\" src=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}.png\" srcset=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}@2x.png 2x\" />";
} else {
$sm_image = "<img alt=\"{$smile}\" class=\"emoji\" src=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}.png\" />";
}
} elseif ( file_exists( ROOT_DIR . "/public/emoticons/" . $smile . ".gif" ) ) {
if( file_exists( ROOT_DIR . "/public/emoticons/" . $smile . "@2x.gif" ) ) {
$sm_image = "<img alt=\"{$smile}\" class=\"emoji\" src=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}.gif\" srcset=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}@2x.gif 2x\" />";
} else {
$sm_image = "<img alt=\"{$smile}\" class=\"emoji\" src=\"{$_ROOT_DLE_URL}public/emoticons/{$smile}.gif\" />";
}
}
$output .= "<td style=\"padding:5px;text-align: center;\"><a href=\"#\" onclick=\"dle_smiley(this); return false;\">{$sm_image}</a></td>";
if ($i%7 == 0 AND $i < $count_smilies) $output .= "</tr><tr>";
}
$output .= "</tr></table>";
}
echo <<<HTML
<html>
<head>
<meta charset="UTF-8">
<style>
.emoji_box {
width:100%;
}
.emoji_category {
padding:0.487em;
clear:both;
}
.emoji_list {
margin-top:0.348em;
margin-bottom:0.348em;
width:100%;
font-family:'Apple Color Emoji', 'Segoe UI Emoji', 'NotoColorEmoji', 'Segoe UI Symbol', 'Android Emoji', 'EmojiSymbols';
font-size:1.667em;
}
.emoji_symbol {
float:left;
margin-bottom: 0.694em;
width:12.5%;
text-align:center;
}
.emoji_symbol a, .emoji_symbol a:hover {
cursor: pointer;
text-decoration:none;
}
img.emoji {
width: 2em;
height: 2em;
}
body {
font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
line-height: 1.4285715;
word-spacing: 0.1em;
overflow-x:hidden;
overflow-y:auto;
}
body.dle_theme_dark {
color: #b3b3b3;
}
html.htmlfontsize-50 {
font-size: .5rem
}
html.htmlfontsize-75 {
font-size: .75rem
}
html.htmlfontsize-80 {
font-size: .8rem
}
html.htmlfontsize-85 {
font-size: .85rem
}
html.htmlfontsize-90 {
font-size: .9rem
}
html.htmlfontsize-95 {
font-size: .95rem
}
html.htmlfontsize-100 {
font-size: .9rem
}
html.htmlfontsize-105 {
font-size: 1.05rem
}
html.htmlfontsize-110 {
font-size: 1.1rem
}
html.htmlfontsize-115 {
font-size: 1.15rem
}
html.htmlfontsize-120 {
font-size: 1.2rem
}
html.htmlfontsize-125 {
font-size: 1.25rem
}
html.htmlfontsize-130 {
font-size: 1.3rem
}
html.htmlfontsize-135 {
font-size: 1.35rem
}
html.htmlfontsize-140 {
font-size: 1.4rem
}
html.htmlfontsize-145 {
font-size: 1.45rem
}
html.htmlfontsize-150 {
font-size: 1.5rem
}
html.htmlfontsize-175 {
font-size: 1.75rem
}
html.htmlfontsize-200 {
font-size: 2rem
}
</style>
<script src="{$_ROOT_DLE_URL}public/js/jquery.js"></script>
</head>
<body>
{$output}
<script>
<!--
function dle_smiley(finalImage) {
finalImage = '<span class="emoji noncontenteditable">' + $(finalImage).html() + "</span>";
parent.tinyMCE.execCommand('mceInsertContent',false,finalImage);
parent.tinyMCE.activeEditor.windowManager.close();
}
{$emoji_script}
-->
</script>
</body>
</html>
HTML;
?>