509 lines
15 KiB
PHP
509 lines
15 KiB
PHP
<?php
|
|
if( !defined( 'DATALIFEENGINE' ) OR !defined( 'LOGGED_IN' ) ) {
|
|
die("Hacking attempt!");
|
|
}
|
|
|
|
if( $member_id['user_group'] != 1 ) {
|
|
msg( "error", $lang['addnews_denied'], $lang['db_denied'] );
|
|
}
|
|
|
|
if (isset ($_REQUEST['empfanger'])) $empfanger = intval($_REQUEST['empfanger']); else $empfanger = "";
|
|
if (isset ($_REQUEST['editor'])) $editor = $_REQUEST['editor']; else $editor = "";
|
|
if (isset ($_REQUEST['type'])) $type = $_REQUEST['type']; else $type = "";
|
|
if (isset ($_REQUEST['action'])) $action = $_REQUEST['action']; else $action = "";
|
|
if (isset ($_REQUEST['a_mail'])) $a_mail = intval($_REQUEST['a_mail']); else $a_mail = "";
|
|
|
|
|
|
if ($action=="send") {
|
|
|
|
include_once SYSTEM_DIR.'/classes/parse.class.php';
|
|
|
|
$parse = new ParseFilter(Array(), Array(), 1, 1);
|
|
|
|
$title = strip_tags(stripslashes($parse->process($_POST['title'])));
|
|
$message = stripslashes($parse->process($_POST['message']));
|
|
$start_from = intval($_GET['start_from']);
|
|
$limit = intval($_GET['limit']);
|
|
$interval = intval($_GET['interval']) * 1000;
|
|
|
|
if ($limit < 1) {
|
|
|
|
$limit = 20;
|
|
|
|
}
|
|
|
|
$message = $parse->BB_Parse($message, false);
|
|
|
|
$where = array();
|
|
|
|
if ($empfanger != "all") $where[] = "user_group = '{$empfanger}'";
|
|
if ($a_mail) $where[] = "allow_mail = '1'";
|
|
|
|
if (count($where)) $where = " WHERE ".implode (" AND ", $where);
|
|
else $where = "";
|
|
|
|
$row = $db->super_query("SELECT COUNT(*) as count FROM " . USERPREFIX . "_users".$where);
|
|
|
|
if ($start_from > $row['count'] OR $start_from < 0) $start_from = 0;
|
|
|
|
if ($type == "email")
|
|
$type_send = $lang['bb_b_mail'];
|
|
else
|
|
$type_send = $lang['nl_pm'];
|
|
|
|
echo <<<HTML
|
|
<html>
|
|
<head>
|
|
<meta content="text/html; charset={$config['charset']}" http-equiv="content-type" />
|
|
<title>{$lang['nl_seng']}</title>
|
|
<style type="text/css">
|
|
html,body{
|
|
height:100%;
|
|
margin:0px;
|
|
padding: 0px;
|
|
background: #F4F3EE;
|
|
}
|
|
|
|
form {
|
|
margin:0px;
|
|
padding: 0px;
|
|
}
|
|
|
|
table{
|
|
border:0px;
|
|
border-collapse:collapse;
|
|
}
|
|
|
|
table td{
|
|
padding:0px;
|
|
font-size: 11px;
|
|
font-family: verdana;
|
|
}
|
|
|
|
a:active,
|
|
a:visited,
|
|
a:link {
|
|
color: #4b719e;
|
|
text-decoration:none;
|
|
}
|
|
|
|
a:hover {
|
|
color: #4b719e;
|
|
text-decoration: underline;
|
|
}
|
|
|
|
.navigation {
|
|
color: #999898;
|
|
font-size: 11px;
|
|
font-family: tahoma;
|
|
}
|
|
.unterline {
|
|
background: url(system/skins/images/line_bg.gif);
|
|
width: 100%;
|
|
height: 9px;
|
|
font-size: 3px;
|
|
font-family: tahoma;
|
|
margin-bottom: 4px;
|
|
}
|
|
.hr_line {
|
|
background: url(system/skins/images/line.gif);
|
|
width: 100%;
|
|
height: 7px;
|
|
font-size: 3px;
|
|
font-family: tahoma;
|
|
margin-top: 4px;
|
|
margin-bottom: 4px;
|
|
}
|
|
.edit {
|
|
border:1px solid #9E9E9E;
|
|
color: #000000;
|
|
font-size: 11px;
|
|
font-family: Verdana; BACKGROUND-COLOR: #ffffff
|
|
}
|
|
.buttons {
|
|
background: #FFF;
|
|
border: 1px solid #9E9E9E;
|
|
color: #666666;
|
|
font-family: Verdana, Tahoma, helvetica, sans-serif;
|
|
padding: 0px;
|
|
vertical-align: absmiddle;
|
|
font-size: 11px;
|
|
height: 21px;
|
|
}
|
|
select, option {
|
|
color: #000000;
|
|
font-size: 11px;
|
|
font-family: Verdana;
|
|
background-color: #ffffff
|
|
}
|
|
|
|
textarea {
|
|
border: #9E9E9E 1px solid;
|
|
color: #000000;
|
|
font-size: 11px;
|
|
font-family: Verdana;
|
|
background-color: #ffffff
|
|
}
|
|
#hintbox{ /*CSS for pop up hint box */
|
|
position:absolute;
|
|
top: 0;
|
|
background-color: lightyellow;
|
|
width: 150px; /*Default width of hint.*/
|
|
padding: 3px;
|
|
border:1px solid #787878;
|
|
font:normal 11px Verdana;
|
|
line-height:18px;
|
|
z-index:100;
|
|
border-right: 2px solid #787878;
|
|
border-bottom: 2px solid #787878;
|
|
visibility: hidden;
|
|
}
|
|
|
|
.hintanchor{
|
|
padding-left: 8px;
|
|
}
|
|
</style>
|
|
<script type="text/javascript" src="system/js/jquery.js"></script>
|
|
<script type="text/javascript" src="system/js/jqueryui.js"></script>
|
|
</head>
|
|
<body>
|
|
<script language="javascript" type="text/javascript">
|
|
var total = {$row['count']};
|
|
$(function() {
|
|
$("#status").ajaxError(function(event, request, settings){
|
|
$(this).html('{$lang['nl_error']}');
|
|
$('#button').attr("disabled", false);
|
|
});
|
|
$( "#progressbar" ).progressbar({
|
|
value: 0
|
|
});
|
|
$('#button').click(function() {
|
|
$('#status').html('{$lang['nl_sinfo']}');
|
|
$('#button').attr("disabled", "disabled");
|
|
$('#button').val("{$lang['send_forw']}");
|
|
senden( $('#sendet_ok').val() );
|
|
return false;
|
|
});
|
|
});
|
|
|
|
function senden( startfrom ){
|
|
|
|
var title = $('#title').html();
|
|
var message = $('#message').html();
|
|
|
|
$.post("system/ajax/newsletter.php", { startfrom: startfrom, title: title, message: message, type: '{$type}', empfanger: '{$empfanger}', a_mail: '{$a_mail}', limit: '{$limit}' },
|
|
function(data){
|
|
if (data) {
|
|
if (data.status == "ok") {
|
|
$('#gesendet').html(data.count);
|
|
$('#sendet_ok').val(data.count);
|
|
var proc = Math.round( (100 * data.count) / total );
|
|
if ( proc > 100 ) proc = 100;
|
|
$('#progressbar').progressbar( "option", "value", proc );
|
|
if (data.count >= total)
|
|
{
|
|
$('#status').html('{$lang['nl_finish']}');
|
|
}
|
|
else
|
|
{
|
|
setTimeout("senden(" + data.count + ")", {$interval} );
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|
|
}, "json");
|
|
|
|
return false;
|
|
}
|
|
</script>
|
|
<table align="center" width="97%">
|
|
<tr>
|
|
<td width="4" height="16"><img src="system/skins/images/tb_left.gif" width="4" height="16" border="0" /></td>
|
|
<td background="system/skins/images/tb_top.gif"><img src="system/skins/images/tb_top.gif" width="1" height="16" border="0" /></td>
|
|
<td width="4"><img src="system/skins/images/tb_right.gif" width="3" height="16" border="0" /></td>
|
|
</tr>
|
|
<tr>
|
|
<td width="4" background="system/skins/images/tb_lt.gif"><img src="system/skins/images/tb_lt.gif" width="4" height="1" border="0" /></td>
|
|
<td valign="top" style="padding:8px;" bgcolor="#FFFFFF">
|
|
HTML;
|
|
|
|
echo <<<HTML
|
|
<table width="100%">
|
|
<tr>
|
|
<td bgcolor="#EFEFEF" height="29" style="padding-left:10px;"><div class="navigation">{$lang['nl_seng']}</div></td>
|
|
</tr>
|
|
</table>
|
|
<div class="unterline"></div>
|
|
<table width="100%">
|
|
<tr>
|
|
<td width="100" style="padding:4px;">{$lang['nl_empf']}</td>
|
|
<td>{$row['count']}</td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:4px;">{$lang['nl_type']}</td>
|
|
<td>{$type_send}</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2"><div class="hr_line"></div></td>
|
|
</tr>
|
|
</table>
|
|
<table width="100%">
|
|
<tr>
|
|
<td><div id="progressbar"></div>{$lang['nl_sendet']} <span style="color:red;" id='gesendet'>{$start_from}</span> {$lang['mass_i']} <span style="color:blue;">{$row['count']}</span> {$lang['nl_status']} <span id="status"></span><br /><br /><input id="button" type="button" value="{$lang['nl_start']}" class="edit" style="width:190px;"><input type="hidden" id="sendet_ok" name="sendet_ok" value="{$start_from}"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><div class="hr_line"></div></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="navigation">{$lang['nl_info']}</td>
|
|
</tr>
|
|
</table>
|
|
HTML;
|
|
|
|
$message = stripslashes($message);
|
|
|
|
echo <<<HTML
|
|
</td>
|
|
<td width="4" background="system/skins/images/tb_rt.gif"><img src="system/skins/images/tb_rt.gif" width="4" height="1" border="0" /></td>
|
|
</tr>
|
|
<tr>
|
|
<td height="16" background="system/skins/images/tb_lb.gif"></td>
|
|
<td background="system/skins/images/tb_tb.gif"></td>
|
|
<td background="system/skins/images/tb_rb.gif"></td>
|
|
</tr>
|
|
</table>
|
|
<pre style="display:none;" id="title">{$title}</pre>
|
|
<pre style="display:none;" id="message">{$message}</pre>
|
|
</body>
|
|
|
|
</html>
|
|
HTML;
|
|
|
|
}
|
|
elseif ($action=="preview")
|
|
{
|
|
include_once SYSTEM_DIR.'/classes/parse.class.php';
|
|
|
|
$parse = new ParseFilter(Array(), Array(), 1, 1);
|
|
|
|
$title = strip_tags(stripslashes($parse->process($_POST['title'])));
|
|
$message = stripslashes($parse->process($_POST['message']));
|
|
|
|
$message = $parse->BB_Parse($message, false);
|
|
|
|
echo <<<HTML
|
|
<html><title>{$title}</title>
|
|
<meta content="text/html; charset={$config['charset']}" http-equiv=Content-Type>
|
|
<style type="text/css">
|
|
html,body{
|
|
height:100%;
|
|
margin:0px;
|
|
padding: 0px;
|
|
font-size: 11px;
|
|
font-family: verdana;
|
|
}
|
|
|
|
table{
|
|
border:0px;
|
|
border-collapse:collapse;
|
|
}
|
|
|
|
table td{
|
|
padding:0px;
|
|
font-size: 11px;
|
|
font-family: verdana;
|
|
}
|
|
|
|
a:active,
|
|
a:visited,
|
|
a:link {
|
|
color: #4b719e;
|
|
text-decoration:none;
|
|
}
|
|
|
|
a:hover {
|
|
color: #4b719e;
|
|
text-decoration: underline;
|
|
}
|
|
</style>
|
|
<body>
|
|
HTML;
|
|
|
|
echo "<fieldset style=\"border-style:solid; border-width:1; border-color:black;\"><legend> <span style=\"font-size: 10px; font-family: Verdana\">{$title}</span> </legend>{$message}</fieldset>";
|
|
|
|
|
|
}
|
|
elseif ($action=="message") {
|
|
echoheader("newsletter", "");
|
|
|
|
|
|
echo "
|
|
<SCRIPT LANGUAGE=\"JavaScript\">
|
|
function send(){";
|
|
|
|
echo "if(document.addnews.message.value == '' || document.addnews.title.value == ''){ alert('$lang[vote_alert]'); }
|
|
else{
|
|
dd=window.open('','snd','height=210,width=480,resizable=1,scrollbars=1')
|
|
document.addnews.action.value='send';document.addnews.target='snd'
|
|
document.addnews.submit();dd.focus()
|
|
}
|
|
}
|
|
</SCRIPT>";
|
|
|
|
echo "
|
|
<SCRIPT LANGUAGE=\"JavaScript\">
|
|
function preview(){";
|
|
|
|
echo "if(document.addnews.message.value == '' || document.addnews.title.value == ''){ alert('$lang[vote_alert]'); }
|
|
else{
|
|
dd=window.open('','prv','height=300,width=600,resizable=1,scrollbars=1')
|
|
document.addnews.action.value='preview';document.addnews.target='prv'
|
|
document.addnews.submit();dd.focus()
|
|
setTimeout(\"document.addnews.action.value='send';document.addnews.target='_self'\",500)
|
|
}
|
|
}
|
|
</SCRIPT>";
|
|
|
|
echo <<<HTML
|
|
<script type="text/javascript" src="system/ajax/dle_ajax.js"></script>
|
|
<div id='loading-layer' style='display:none;font-family: Verdana;font-size: 11px;width:200px;height:50px;background:#FFF;padding:10px;text-align:center;border:1px solid #000'><div style='font-weight:bold' id='loading-layer-text'>{$lang['ajax_info']}</div><br /><img src='system/ajax/loading.gif' border='0' /></div>
|
|
<form method="POST" name="addnews" id="addnews" action="">
|
|
<div style="padding-top:5px;padding-bottom:2px;">
|
|
<table width="100%">
|
|
<tr>
|
|
<td width="4"><img src="system/skins/images/tl_lo.gif" width="4" height="4" border="0"></td>
|
|
<td background="system/skins/images/tl_oo.gif"><img src="system/skins/images/tl_oo.gif" width="1" height="4" border="0"></td>
|
|
<td width="6"><img src="system/skins/images/tl_ro.gif" width="6" height="4" border="0"></td>
|
|
</tr>
|
|
<tr>
|
|
<td background="system/skins/images/tl_lb.gif"><img src="system/skins/images/tl_lb.gif" width="4" height="1" border="0"></td>
|
|
<td style="padding:5px;" bgcolor="#FFFFFF">
|
|
<table width="100%">
|
|
<tr>
|
|
<td bgcolor="#EFEFEF" height="29" style="padding-left:10px;"><div class="navigation">{$lang['nl_main']}</div></td>
|
|
</tr>
|
|
</table>
|
|
<div class="unterline"></div>
|
|
<table width="100%">
|
|
<tr>
|
|
<td width="150" style="padding:6px;">{$lang['edit_title']}</td>
|
|
<td><input class="edit" type="text" size="55" name="title"></td>
|
|
</tr>
|
|
HTML;
|
|
|
|
include(SYSTEM_DIR.'/inc/include/inserttag.php');
|
|
|
|
echo <<<HTML
|
|
<tr>
|
|
<td width="140" height="29" style="padding-left:5px;">{$lang['nl_message']}</td>
|
|
<td>
|
|
<table width="100%"><tr><td>{$bb_code}
|
|
<textarea rows=17 style="width:98%;" onclick=setFieldName(this.name) name="message" id="message"></textarea><br><br>{$lang['nl_info_1']} <b>{$lang['nl_info_2']}</b><script type=text/javascript>var selField = "message";</script></td>
|
|
</tr></table>
|
|
</td></tr>
|
|
HTML;
|
|
|
|
$start_from = intval($_GET['start_from']);
|
|
|
|
echo <<<HTML
|
|
<tr>
|
|
<td style="padding:6px;"> </td>
|
|
<td><input type="hidden" name="mod" value="newsletter">
|
|
<input type="hidden" name="action" value="send">
|
|
<input type="hidden" name="empfanger" value="{$empfanger}">
|
|
<input type="hidden" name="type" value="{$type}">
|
|
<input type="hidden" name="a_mail" value="{$a_mail}">
|
|
<input type="hidden" name="editor" value="{$editor}">
|
|
<input type="hidden" name="start_from" value="{$start_from}">
|
|
<br /><input type="button" onClick="send(); return false;" class="buttons" value="{$lang['btn_send']}" style="width:100px;">
|
|
<input onClick="preview()" type="button" class="buttons" value="{$lang['btn_preview']}" style="width:100px;"></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td background="system/skins/images/tl_rb.gif"><img src="system/skins/images/tl_rb.gif" width="6" height="1" border="0"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><img src="system/skins/images/tl_lu.gif" width="4" height="6" border="0"></td>
|
|
<td background="system/skins/images/tl_ub.gif"><img src="system/skins/images/tl_ub.gif" width="1" height="6" border="0"></td>
|
|
<td><img src="system/skins/images/tl_ru.gif" width="6" height="6" border="0"></td>
|
|
</tr>
|
|
</table>
|
|
</div></form>
|
|
HTML;
|
|
|
|
echofooter();
|
|
}
|
|
else {
|
|
|
|
echoheader("newsletter", "");
|
|
$group_list = get_groups ();
|
|
|
|
echo <<<HTML
|
|
<form method="GET" action="">
|
|
<div style="padding-top:5px;padding-bottom:2px;">
|
|
<table width="100%">
|
|
<tr>
|
|
<td width="4"><img src="system/skins/images/tl_lo.gif" width="4" height="4" border="0"></td>
|
|
<td background="system/skins/images/tl_oo.gif"><img src="system/skins/images/tl_oo.gif" width="1" height="4" border="0"></td>
|
|
<td width="6"><img src="system/skins/images/tl_ro.gif" width="6" height="4" border="0"></td>
|
|
</tr>
|
|
<tr>
|
|
<td background="system/skins/images/tl_lb.gif"><img src="system/skins/images/tl_lb.gif" width="4" height="1" border="0"></td>
|
|
<td style="padding:5px;" bgcolor="#FFFFFF">
|
|
<table width="100%">
|
|
<tr>
|
|
<td bgcolor="#EFEFEF" height="29" style="padding-left:10px;"><div class="navigation">{$lang['nl_main']}</div></td>
|
|
</tr>
|
|
</table>
|
|
<div class="unterline"></div>
|
|
<table width="100%">
|
|
<tr>
|
|
<td width="220" style="padding:6px;">{$lang['nl_empf']}</td>
|
|
<td><select name="empfanger">
|
|
<option value="all">{$lang['edit_all']}</option>
|
|
{$group_list}
|
|
</select></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;">{$lang['nl_type']}</td>
|
|
<td><select name="type">
|
|
<option value="email">{$lang['bb_b_mail']}</option>
|
|
<option value="pm">{$lang['nl_pm']}</option></select></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;">{$lang['nl_startfrom']}</td>
|
|
<td><input class="edit" type="text" size="10" name="start_from" value="0"> {$lang['nl_user']}</td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;">{$lang['nl_n_mail']}</td>
|
|
<td><input class="edit" type="text" size="10" name="limit" value="20"></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;">{$lang['nl_interval']}</td>
|
|
<td><input class="edit" type="text" size="10" name="interval" value="3"></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;">{$lang['nl_amail']}</td>
|
|
<td><input type="checkbox" name="a_mail" value="1"></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="padding:6px;"> </td>
|
|
<td><input type="hidden" name="mod" value="newsletter"><input type="hidden" name="action" value="message"><input type="submit" class="buttons" value="{$lang['edit_next']}" style="width:100px;"></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td background="system/skins/images/tl_rb.gif"><img src="system/skins/images/tl_rb.gif" width="6" height="1" border="0"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><img src="system/skins/images/tl_lu.gif" width="4" height="6" border="0"></td>
|
|
<td background="system/skins/images/tl_ub.gif"><img src="system/skins/images/tl_ub.gif" width="1" height="6" border="0"></td>
|
|
<td><img src="system/skins/images/tl_ru.gif" width="6" height="6" border="0"></td>
|
|
</tr>
|
|
</table>
|
|
</div></form>
|
|
HTML;
|
|
echofooter();
|
|
}
|
|
?>
|