DiscuzX/upload/source/function/function_followcode.php

523 lines
22 KiB
PHP

<?php
/**
* [Discuz!] (C)2001-2099 Comsenz Inc.
* This is NOT a freeware, use is subject to license terms
*
* $Id: function_followcode.php 36284 2016-12-12 00:47:50Z nemohou $
*/
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
$_G['post_attach'] = array();
function fcodedisp($code, $type='codehtml') {
global $_G;
$_G['forum_discuzcode']['pcodecount']++;
$_G['forum_discuzcode'][$type][$_G['forum_discuzcode']['pcodecount']] = $code;
$_G['forum_discuzcode']['codecount']++;
return "[\tD_".$_G['forum_discuzcode']['pcodecount']."\t]";
}
function followcode($message, $tid = 0, $pid = 0, $length = 0, $allowimg = true) {
global $_G;
include_once libfile('function/post');
$message = strip_tags($message);
$message = messagesafeclear($message);
if((strpos($message, '[/code]') || strpos($message, '[/CODE]')) !== FALSE) {
$message = preg_replace("/\s?\[code\](.+?)\[\/code\]\s?/is", "", $message);
}
$msglower = strtolower($message);
$htmlon = 0;
$message = dhtmlspecialchars($message);
if($_G['setting']['plugins']['func'][HOOKTYPE]['discuzcode']) {
$_G['discuzcodemessage'] = & $message;
$param = func_get_args();
hookscript('discuzcode', 'global', 'funcs', array('param' => $param, 'caller' => 'discuzcode'), 'discuzcode');
}
$_G['delattach'] = array();
$message = fparsesmiles($message);
if(strpos($msglower, 'attach://') !== FALSE) {
$message = preg_replace("/attach:\/\/(\d+)\.?(\w*)/i", '', $message);
}
if(strpos($msglower, 'ed2k://') !== FALSE) {
$message = preg_replace("/ed2k:\/\/(.+?)\//", '', $message);
}
if(strpos($msglower, '[/i]') !== FALSE) {
$message = preg_replace("/\s*\[i=s\][\n\r]*(.+?)[\n\r]*\[\/i\]\s*/is", '', $message);
}
$message = str_replace('[/p]', "\n", $message);
$message = str_replace(array(
'[/color]', '[/backcolor]', '[/size]', '[/font]', '[/align]', '[b]', '[/b]', '[s]', '[/s]', '[hr]',
'[i=s]', '[i]', '[/i]', '[u]', '[/u]', '[list]', '[list=1]', '[list=a]',
'[list=A]', "\r\n[*]", '[*]', '[/list]', '[indent]', '[/indent]', '[/float]'
), '', preg_replace(array(
"/\[color=([#\w]+?)\]/i",
"/\[color=((rgb|rgba)\([\d\s,]+?\))\]/i",
"/\[backcolor=([#\w]+?)\]/i",
"/\[backcolor=((rgb|rgba)\([\d\s,]+?\))\]/i",
"/\[size=(\d{1,2}?)\]/i",
"/\[size=(\d{1,2}(\.\d{1,2}+)?(px|pt)+?)\]/i",
"/\[font=([^\[\<]+?)\]/i",
"/\[align=(left|center|right)\]/i",
"/\[float=left\]/i",
"/\[float=right\]/i"
), '', $message));
if(strpos($msglower, '[/p]') !== FALSE) {
$message = preg_replace("/\[p=(\d{1,2}|null), (\d{1,2}|null), (left|center|right)\]/i", "<p style=\"line-height:\\1px;text-indent:\\2em;text-align:left;\">", $message);
$message = str_replace('[/p]', '</p>', $message);
}
if(strpos($msglower, '[/quote]') !== FALSE) {
$message = preg_replace("/\s?\[quote\][\n\r]*(.+?)[\n\r]*\[\/quote\]\s?/is", '', $message);
}
if(strpos($msglower, '[/free]') !== FALSE) {
$message = preg_replace("/\s*\[free\][\n\r]*(.+?)[\n\r]*\[\/free\]\s*/is", '', $message);
}
if(isset($_G['cache']['bbcodes'][-$allowbbcode])) {
$message = preg_replace($_G['cache']['bbcodes'][-$allowbbcode]['searcharray'], '', $message);
}
if(strpos($msglower, '[/hide]') !== FALSE) {
preg_replace_callback("/\[hide.*?\]\s*(.*?)\s*\[\/hide\]/is", 'followcode_callback_hideattach_1', $message);
if(strpos($msglower, '[hide]') !== FALSE) {
$message = preg_replace("/\[hide\]\s*(.*?)\s*\[\/hide\]/is", '', $message);
}
if(strpos($msglower, '[hide=') !== FALSE) {
$message = preg_replace("/\[hide=(d\d+)?[,]?(\d+)?\]\s*(.*?)\s*\[\/hide\]/is", '', $message);
}
}
if(strpos($msglower, '[/url]') !== FALSE) {
$message = preg_replace_callback("/\[url(=((https?|ftp|gopher|news|telnet|rtsp|mms|callto|bctp|thunder|qqdl|synacast){1}:\/\/|www\.|mailto:)?([^\r\n\[\"']+?))?\](.+?)\[\/url\]/is", 'followcode_callback_fparseurl_152', $message);
}
if(strpos($msglower, '[/email]') !== FALSE) {
$message = preg_replace_callback("/\[email(=([a-z0-9\-_.+]+)@([a-z0-9\-_]+[.][a-z0-9\-_.]+))?\](.+?)\[\/email\]/is", 'followcode_callback_fparseemail_14', $message);
}
$nest = 0;
while(strpos($msglower, '[table') !== FALSE && strpos($msglower, '[/table]') !== FALSE){
$message = preg_replace_callback("/\[table(?:=(\d{1,4}%?)(?:,([\(\)%,#\w ]+))?)?\]\s*(.+?)\s*\[\/table\]/is", 'followcode_callback_fparsetable_123', $message);
if(++$nest > 4) break;
}
if(strpos($msglower, '[/media]') !== FALSE) {
$message = preg_replace_callback("/\[media=([\w,]+)\]\s*([^\[\<\r\n]+?)\s*\[\/media\]/is", 'followcode_callback_fparsemedia_12', $message);
}
if(strpos($msglower, '[/audio]') !== FALSE) {
$message = preg_replace_callback("/\[audio(=1)*\]\s*([^\[\<\r\n]+?)\s*\[\/audio\]/is", 'followcode_callback_fparseaudio_2', $message);
}
if(strpos($msglower, '[/flash]') !== FALSE) {
$message = preg_replace_callback("/\[flash(=(\d+),(\d+))?\]\s*([^\[\<\r\n]+?)\s*\[\/flash\]/is", 'followcode_callback_fparseflash_4', $message);
}
if($parsetype != 1 && strpos($msglower, '[swf]') !== FALSE) {
$message = preg_replace_callback("/\[swf\]\s*([^\[\<\r\n]+?)\s*\[\/swf\]/is", 'followcode_callback_bbcodeurl_1', $message);
}
$flag = $length ? 1 : 0;
if($tid) {
$extra = "onclick=\"changefeed($tid, $pid, $flag, this)\"";
}
if(strpos($msglower, '[/img]') !== FALSE) {
$message = preg_replace_callback("/\[img\]\s*([^\[\<\r\n]+?)\s*\[\/img\]/is", create_function('$matches', 'return '.intval($allowimg).' ? fparseimg($matches[1], \''.addslashes($extra).'\') : \'\';'), $message);
$message = preg_replace_callback("/\[img=(\d{1,4})[x|\,](\d{1,4})\]\s*([^\[\<\r\n]+?)\s*\[\/img\]/is", create_function('$matches', 'return '.intval($allowimg).' ? fparseimg($matches[3], \''.addslashes($extra).'\') : \'\';'), $message);
}
if($tid && $pid) {
$_G['post_attach'] = C::t('forum_attachment_n')->fetch_all_by_id(getattachtableid($tid), 'pid', $pid);
foreach($_G['post_attach'] as $aid => $attach) {
if(!empty($_G['delattach']) && in_array($aid, $_G['delattach'])) {
continue;
}
$message .= "[attach]$attach[aid][/attach]";
$message = preg_replace("/\[attach\]$attach[aid]\[\/attach\]/i", fparseattach($attach['aid'], $length, $extra), $message, 1);
}
}
if(strpos($msglower, '[/attach]') !== FALSE) {
$message = preg_replace("/\[attach\]\s*([^\[\<\r\n]+?)\s*\[\/attach\]/is", '', $message);
}
$message = clearnl($message);
if($length) {
$sppos = strpos($message, chr(0).chr(0).chr(0));
if($sppos !== false) {
$message = substr($message, 0, $sppos);
}
$checkstr = cutstr($message, $length, '');
if(strpos($checkstr, '[') && strpos(strrchr($checkstr, "["), ']') === FALSE) {
$length = strpos($message, ']', strrpos($checkstr, strrchr($checkstr, "[")));
}
$message = cutstr($message, $length+1, ' <a href="javascript:;" class="flw_readfull xi2 xs1"'.$extra.'>'.lang('space', 'follow_view_fulltext').'</a>');
} elseif($allowimg && !empty($extra)) {
$message .= '<div class="ptm cl"><a href="javascript:;" class="flw_readfull y xi2 xs1"'.$extra.'>'.lang('space', 'follow_retract').'</a></div>';
}
for($i = 0; $i <= $_G['forum_discuzcode']['pcodecount']; $i++) {
$code = '';
if(isset($_G['forum_discuzcode']['codehtml'][$i]) && !empty($_G['forum_discuzcode']['codehtml'][$i])) {
$code = $_G['forum_discuzcode']['codehtml'][$i];
} elseif(!$length) {
if(isset($_G['forum_discuzcode']['audio'][$i]) && !empty($_G['forum_discuzcode']['audio'][$i])) {
$code = $_G['forum_discuzcode']['audio'][$i];
} elseif(isset($_G['forum_discuzcode']['video'][$i]) && !empty($_G['forum_discuzcode']['video'][$i])) {
$code = $_G['forum_discuzcode']['video'][$i];
} elseif(isset($_G['forum_discuzcode']['media'][$i]) && !empty($_G['forum_discuzcode']['media'][$i])) {
$code = $_G['forum_discuzcode']['media'][$i];
} elseif(isset($_G['forum_discuzcode']['image'][$i]) && !empty($_G['forum_discuzcode']['image'][$i])) {
$code = $_G['forum_discuzcode']['image'][$i];
} elseif(isset($_G['forum_discuzcode']['attach'][$i]) && !empty($_G['forum_discuzcode']['attach'][$i])) {
$code = $_G['forum_discuzcode']['attach'][$i];
}
}
$message = str_replace("[\tD_$i\t]", $code, $message);
}
$message = clearnl($message);
if(!empty($_GET['highlight'])) {
$highlightarray = explode('+', $_GET['highlight']);
$sppos = strrpos($message, chr(0).chr(0).chr(0));
if($sppos !== FALSE) {
$specialextra = substr($message, $sppos + 3);
$message = substr($message, 0, $sppos);
}
followcode_callback_highlightword_21($highlightarray, 1);
$message = preg_replace_callback("/(^|>)([^<]+)(?=<|$)/sU", 'followcode_callback_highlightword_21', $message);
$message = preg_replace("/<highlight>(.*)<\/highlight>/siU", "<strong><font color=\"#FF0000\">\\1</font></strong>", $message);
if($sppos !== FALSE) {
$message = $message.chr(0).chr(0).chr(0).$specialextra;
}
}
unset($msglower);
if($length) {
$count = 0;
$imagecode = $mediacode = $videocode = $audiocode = $mediahtml = '';
for($i = 0; $i <= $_G['forum_discuzcode']['pcodecount']; $i++) {
if(isset($_G['forum_discuzcode']['audio'][$i]) && !empty($_G['forum_discuzcode']['audio'][$i])) {
$audiocode .= '<li>'.$_G['forum_discuzcode']['audio'][$attachcodei].'</li>';
} elseif(isset($_G['forum_discuzcode']['video'][$i]) && !empty($_G['forum_discuzcode']['video'][$i])) {
$videocode .= '<li>'.$_G['forum_discuzcode']['video'][$i].'</li>';
} elseif(isset($_G['forum_discuzcode']['media'][$i]) && !empty($_G['forum_discuzcode']['media'][$i])) {
$mediacode .= '<li>'.$_G['forum_discuzcode']['media'][$i].'</li>';
} elseif(isset($_G['forum_discuzcode']['image'][$i]) && !empty($_G['forum_discuzcode']['image'][$i]) && $count < 4) {
$imagecode .= '<li>'.$_G['forum_discuzcode']['image'][$i].'</li>';
$count++;
} elseif(isset($_G['forum_discuzcode']['attach'][$i]) && !empty($_G['forum_discuzcode']['attach'][$i])) {
$attachcode .= '<li>'.$_G['forum_discuzcode']['attach'][$i].'</li>';
}
}
if(!empty($audiocode)) {
$message .= '<div class="flw_music"><ul>'.$audiocode.'</ul></div>';
}
if(!empty($videocode)) {
$message .= '<div class="flw_video"><ul>'.$videocode.'</ul></div>';
}
if(!empty($mediacode)) {
$message .= '<div class="flw_video"><ul>'.$mediacode.'</ul></div>';
}
if(!empty($imagecode)) {
$message = '<div class="flw_image'.($count < 2 ? ' flw_image_1' : '').'"><ul>'.$imagecode.'</ul></div>'.$message;
}
if(!empty($attachcode)) {
$message .= '<div class="flw_attach"><ul>'.$attachcode.'</ul></div>';
}
}
return $htmlon ? $message : nl2br(str_replace(array("\t", ' ', ' '), ' ', $message));
}
function followcode_callback_hideattach_1($matches) {
return hideattach($matches[1]);
}
function followcode_callback_fparseurl_152($matches) {
return fparseurl($matches[1], $matches[5], $matches[2]);
}
function followcode_callback_fparseemail_14($matches) {
return fparseemail($matches[1], $matches[4]);
}
function followcode_callback_fparsetable_123($matches) {
return fparsetable($matches[1], $matches[2], $matches[3]);
}
function followcode_callback_fparsemedia_12($matches) {
return fparsemedia($matches[1], $matches[2]);
}
function followcode_callback_fparseaudio_2($matches) {
return fparseaudio($matches[2]);
}
function followcode_callback_fparseflash_4($matches) {
return fparseflash($matches[4]);
}
function followcode_callback_bbcodeurl_1($matches) {
return bbcodeurl($matches[1], ' <img src="'.STATICURL.'image/filetype/flash.gif" align="absmiddle" alt="" /> <a href="{url}" target="_blank">Flash: {url}</a> ');
}
function followcode_callback_highlightword_21($matches, $action = 0) {
static $highlightarray = array();
if($action == 1) {
$highlightarray = $matches;
} else {
return highlightword($matches[2], $highlightarray, $matches[1]);
}
}
function clearnl($message) {
$message = preg_replace("/[\r\n|\n|\r]\s*[\r\n|\n|\r]/i", "\n", $message);
$message = preg_replace("/^[\r\n|\n|\r]{1,}/i", "", $message);
$message = preg_replace("/[\r\n|\n|\r]{2,}/i", "\n", $message);
return $message;
}
function hideattach($hidestr) {
global $_G;
preg_match_all("/\[attach\]\s*(.*?)\s*\[\/attach\]/is", $hidestr, $del);
foreach($del[1] as $aid) {
$_G['delattach'][$aid] = $aid;
}
}
function fparseurl($url, $text, $scheme) {
global $_G;
$html = '';
if(!$url && preg_match("/((https?|ftp|gopher|news|telnet|rtsp|mms|callto|bctp|thunder|qqdl|synacast){1}:\/\/|www\.)[^\[\"']+/i", trim($text), $matches)) {
$url = $matches[0];
$length = 65;
if(strlen($url) > $length) {
$text = substr($url, 0, intval($length * 0.5)).' ... '.substr($url, - intval($length * 0.3));
}
$html = '<a href="'.(substr(strtolower($url), 0, 4) == 'www.' ? 'http://'.$url : $url).'" target="_blank">'.$text.'</a>';
} else {
$url = substr($url, 1);
if(substr(strtolower($url), 0, 4) == 'www.') {
$url = 'http://'.$url;
}
$url = !$scheme ? $_G['siteurl'].$url : $url;
$atclass = substr(strtolower($text), 0, 1) == '@' ? ' class="xi2" ' : '';
$html = '<a href="'.$url.'" target="_blank" '.$atclass.'>'.$text.'</a>';
}
return fcodedisp($html);
}
function fparseattach($aid, $length = 0, $extra = '') {
global $_G;
$html = '';
if(!empty($_G['post_attach']) && !empty($_G['post_attach'][$aid])) {
$attach = $_G['post_attach'][$aid];
unset($_G['post_attach'][$attach['aid']]);
$attach['url'] = ($attach['remote'] ? $_G['setting']['ftp']['attachurl'] : $_G['setting']['attachurl']).'forum/';
$attach['isimage'] = $attach['isimage'] && !$attach['price'] ? $attach['isimage'] : 0;
$attach['refcheck'] = (!$attach['remote'] && $_G['setting']['attachrefcheck']) || ($attach['remote'] && ($_G['setting']['ftp']['hideurl'] || ($attach['isimage'] && $_G['setting']['attachimgpost'] && strtolower(substr($_G['setting']['ftp']['attachurl'], 0, 3)) == 'ftp')));
$rimg_id = random(5).$attach['aid'];
if($attach['isimage'] && !$attach['price'] && !$attach['readperm']) {
$nothumb = $length ? 0 : 1;
$src = $attach['url'].(!$attach['thumb'] ? $attach['attachment'] : getimgthumbname($attach['attachment']));
$html = bbcodeurl($src, '<img id="aimg_'.$rimg_id.'" src="'.$src.'" border="0" alt="'.$attach['filename'].'" '.$extra.' style="cursor: pointer;" />');
return fcodedisp($html, 'image');
} else {
if($attach['price'] || $attach['readperm']) {
$html = '<a href="forum.php?mod=viewthread&tid='.$attach['tid'].'" id="attach_'.$rimg_id.'" target="_blank" class="flw_attach_price"><strong>'.$attach['filename'].'</strong><span>'.sizecount($attach['filesize']).'</span></a>';
} else {
require_once libfile('function/attachment');
$aidencode = packaids($attach);
$attachurl = "forum.php?mod=attachment&aid=$aidencode";
$html = '<a href="'.$attachurl.'" id="attach_'.$rimg_id.'"><strong>'.$attach['filename'].'</strong><span>'.sizecount($attach['filesize']).'</span></a>';
}
return fcodedisp($html, 'attach');
}
}
return '';
}
function fparseflash($url) {
preg_match("/((https?){1}:\/\/|www\.)[^\[\"']+/i", $url, $matches);
$url = $matches[0];
if(fileext($url) != 'flv') {
$rimg_id = 'swf_'.random(5);
$html = bbcodeurl($url, '<img src="'.IMGDIR.'/flash.gif" alt="'.lang('space', 'follow_click_play').'" onclick="javascript:showFlash(\'flash\', \''.$url.'\', this, \''.$rimg_id.'\');" class="tn" style="cursor: pointer;" />');
return fcodedisp($html, 'media');
} else {
$url = STATICURL.'image/common/flvplayer.swf?&autostart=true&file='.urlencode($matches[0]);
return fmakeflv($url);
}
}
function fparseemail($email, $text) {
global $_G;
$text = str_replace('\"', '"', $text);
$html = '';
if(!$email && preg_match("/\s*([a-z0-9\-_.+]+)@([a-z0-9\-_]+[.][a-z0-9\-_.]+)\s*/i", $text, $matches)) {
$email = trim($matches[0]);
$html = '<a href="mailto:'.$email.'">'.$email.'</a>';
} else {
$html = '<a href="mailto:'.substr($email, 1).'">'.$text.'</a>';
}
return fcodedisp($html);
}
function fparsetable($width, $bgcolor, $message) {
global $_G;
$html = '';
if(strpos($message, '[/tr]') === FALSE && strpos($message, '[/td]') === FALSE) {
$rows = explode("\n", $message);
$html = '<table cellspacing="0" class="t_table" '.
($width == '' ? NULL : 'style="width:'.$width.'"').
($bgcolor ? ' bgcolor="'.$bgcolor.'">' : '>');
foreach($rows as $row) {
$html .= '<tr><td>'.str_replace(array('\|', '|', '\n'), array('&#124;', '</td><td>', "\n"), $row).'</td></tr>';
}
$html .= '</table>';
} else {
if(!preg_match("/^\[tr(?:=([\(\)\s%,#\w]+))?\]\s*\[td([=\d,%]+)?\]/", $message) && !preg_match("/^<tr[^>]*?>\s*<td[^>]*?>/", $message)) {
return str_replace('\\"', '"', preg_replace("/\[tr(?:=([\(\)\s%,#\w]+))?\]|\[td([=\d,%]+)?\]|\[\/td\]|\[\/tr\]/", '', $message));
}
if(substr($width, -1) == '%') {
$width = substr($width, 0, -1) <= 98 ? intval($width).'%' : '98%';
} else {
$width = intval($width);
$width = $width ? ($width <= 560 ? $width.'px' : '98%') : '';
}
$message = preg_replace_callback("/\[tr(?:=([\(\)\s%,#\w]+))?\]\s*\[td(?:=(\d{1,4}%?))?\]/i", 'fparsetable_callback_parsetrtd_12', $message);
$message = preg_replace_callback("/\[\/td\]\s*\[td(?:=(\d{1,4}%?))?\]/i", 'fparsetable_callback_parsetrtd_1', $message);
$message = preg_replace_callback("/\[tr(?:=([\(\)\s%,#\w]+))?\]\s*\[td(?:=(\d{1,2}),(\d{1,2})(?:,(\d{1,4}%?))?)?\]/i", 'fparsetable_callback_parsetrtd_1234', $message);
$message = preg_replace_callback("/\[\/td\]\s*\[td(?:=(\d{1,2}),(\d{1,2})(?:,(\d{1,4}%?))?)?\]/i", 'fparsetable_callback_parsetrtd_123', $message);
$html = '<table cellspacing="0" class="t_table" '.
($width == '' ? NULL : 'style="width:'.$width.'"').
($bgcolor ? ' bgcolor="'.$bgcolor.'">' : '>').
str_replace('\\"', '"', preg_replace("/\[\/td\]\s*\[\/tr\]\s*/i", '</td></tr>', $message)
).'</table>';
}
return fcodedisp($html);
}
function fparsetable_callback_parsetrtd_12($matches) {
return parsetrtd($matches[1], 0, 0, $matches[2]);
}
function fparsetable_callback_parsetrtd_1($matches) {
return parsetrtd('td', 0, 0, $matches[1]);
}
function fparsetable_callback_parsetrtd_1234($matches) {
return parsetrtd($matches[1], $matches[2], $matches[3], $matches[4]);
}
function fparsetable_callback_parsetrtd_123($matches) {
return parsetrtd('td', $matches[1], $matches[2], $matches[3]);
}
function fparseaudio($url) {
$url = addslashes($url);
if(!in_array(strtolower(substr($url, 0, 6)), array('http:/', 'https:', 'ftp://', 'rtsp:/', 'mms://')) && !preg_match('/^static\//', $url) && !preg_match('/^data\//', $url)) {
return dhtmlspecialchars($url);
}
if(fileext($url) == 'mp3') {
$randomid = 'music_'.random(3);
$html = '<img src="'.IMGDIR.'/music.gif" alt="'.lang('space', 'follow_click_play').'" onclick="javascript:showFlash(\'music\', \''.$url.'\', this, \''.$randomid.'\');" class="tn" style="cursor: pointer;" />';
return fcodedisp($html, 'audio');
} else {
$html = '<a href="'.$url.'" target="_blank">'.$url.'</a>';
return $html;
}
}
function fmakeflv($flv) {
$randomid = 'video_'.random(3);
$flv = is_array($flv) ? $flv : array('flv' => $flv);
if(!preg_match("/^((https?){1}:\/\/|www\.)[^\[\"']+$/i", $flv['flv'])) {
return fcodedisp('', 'video');
}
if(!empty($flv['imgurl'])) {
if(!preg_match("/^((https?){1}:\/\/|www\.)[^\[\"']+$/i", $flv['imgurl'])) {
$html = '';
} else {
$html = '<table class="mtm" title="'.lang('space', 'follow_click_play').'" onclick="javascript:showFlash(\'flash\', \''.$flv['flv'].'\', this, \''.$randomid.'\');"><tr><td class="vdtn hm" style="background: url('.$flv['imgurl'].') no-repeat; border: 1px solid #CDCDCD; cursor: pointer; height: 95px; width: 126px;"><img src="'.IMGDIR.'/vds.png" alt="'.lang('space', 'follow_click_play').'" /> </td></tr></table>';
}
} else {
$html = '<img src="'.IMGDIR.'/vd.gif" alt="'.lang('space', 'follow_click_play').'" onclick="javascript:showFlash(\'flash\', \''.$flv['flv'].'\', this, \''.$randomid.'\');" class="tn" style="cursor: pointer;" />';
}
return fcodedisp($html, 'video');
}
function fparsemedia($params, $url) {
$params = explode(',', $params);
$url = addslashes($url);
$html = '';
if($flv = parseflv($url, 0, 0)) {
return fmakeflv($flv);
}
if(in_array(count($params), array(3, 4))) {
$type = $params[0];
$url = str_replace(array('<', '>'), '', str_replace('\\"', '\"', $url));
switch($type) {
case 'mp3':
return fparseaudio($url);
break;
case 'flv':
$url = STATICURL.'image/common/flvplayer.swf?&autostart=true&file='.urlencode($url);
return fmakeflv($url);
break;
case 'swf':
return fparseflash($url);
break;
default:
$html = '<a href="'.$url.'" target="_blank">'.$url.'</a>';
break;
}
}
return fcodedisp($html, 'media');
}
function fparseimg($src, $extra = '') {
global $_G;
$rimg_id = random(5);
$html = bbcodeurl($src, '<img id="iimg_'.$rimg_id.'" src="'.$src.'" border="0" alt="" '.$extra.' style="cursor: pointer;" />');
return fcodedisp($html, 'image');
}
function fparsesmiles(&$message) {
global $_G;
static $enablesmiles;
if($enablesmiles === null) {
$enablesmiles = false;
if(!empty($_G['cache']['smilies']) && is_array($_G['cache']['smilies'])) {
foreach($_G['cache']['smilies']['replacearray'] AS $key => $smiley) {
if(substr($_G['cache']['smilies']['replacearray'][$key], 0, 1) == '<') {
break;
}
$_G['cache']['smilies']['replacearray'][$key] = '<img src="'.STATICURL.'image/smiley/'.$_G['cache']['smileytypes'][$_G['cache']['smilies']['typearray'][$key]]['directory'].'/'.$smiley.'" smilieid="'.$key.'" border="0" class="s" alt="" />';
}
$enablesmiles = true;
}
}
$enablesmiles && $message = preg_replace($_G['cache']['smilies']['searcharray'], $_G['cache']['smilies']['replacearray'], $message, $_G['setting']['maxsmilies']);
return $message;
}
?>