www.gusucode.com > Destoon B2B仿淘宝电子商务网站 UTF8 v6.0源码程序 > destoon/module/member/alert.inc.php

    <?php 
defined('IN_DESTOON') or exit('Access Denied');
login();
require DT_ROOT.'/module/'.$module.'/common.inc.php';
$MOD['alertid'] or message($L['feature_close']);
$MG['alert_limit'] > -1 or dalert(lang('message->without_permission_and_upgrade'), 'goback');
$mids = array();
$tmp = explode('|', $MOD['alertid']);
foreach($tmp as $v) {
	if($v > 4 && isset($MODULE[$v])) $mids[] = $v;
}
require DT_ROOT.'/include/post.func.php';
require MD_ROOT.'/alert.class.php';
$do = new alert();

switch($action) {
	case 'add':
		if($MG['alert_limit']) {
			$r = $db->get_one("SELECT COUNT(*) AS num FROM {$DT_PRE}alert WHERE username='$_username' AND status>0");
			if($r['num'] >= $MG['alert_limit']) dalert(lang($L['limit_add'], array($MG['alert_limit'], $r['num'])), 'goback');
		}
		if($submit) {
			if($do->pass($post)) {
				$post['username'] = $_username;
				$post['email'] = $_email;
				$need_check =  $MOD['alert_check'] == 2 ? $MG['check'] : $MOD['alert_check'];
				$post['status'] = get_status(3, $need_check);
				$post['addtime'] = $DT_TIME;
				$do->add($post);
				$msg = $L['op_add_success'];
				if($post['status'] == 2) $msg = $msg.' '.$L['op_checking'];
				dmsg($msg, '?status='.$post['status']);
			} else {
				message($do->errmsg);
			}
		} else {
			if(in_array($mid, $mids)) {
				$_mid = $mid;
				foreach($do->fields as $v) {
					$$v = '';
				}
				$mid = $_mid;
			} else {
				$action = 'choose';
			}
			$head_title = $L['alert_add_title'];
		}
	break;
	case 'edit':
		$itemid or message();
		$do->itemid = $itemid;
		$r = $do->get_one();
		if(!$r || $r['username'] != $_username) message();
		if($submit) {
			if($do->pass($post)) {
				$post['username'] = $_username;
				$post['email'] = $_email;
				$need_check =  $MOD['alert_check'] == 2 ? $MG['check'] : $MOD['alert_check'];
				$post['status'] = get_status($r['status'], $need_check);
				$do->edit($post);
				dmsg($L['op_edit_success'], $forward);
			} else {
				message($do->errmsg);
			}
		} else {
			extract($r);
		}
	break;
	case 'delete':
		$itemid or message();
		$do->itemid = $itemid;
		$r = $do->get_one();
		if(!$r || $r['username'] != $_username) message();
		$do->delete($itemid);
		dmsg($L['op_del_success'], $forward);
	break;
	default:
		$status = isset($status) ? intval($status) : 3;
		in_array($status, array(2, 3)) or $status = 3;
		$typeid = isset($typeid) ? ($typeid === '' ? -1 : intval($typeid)) : -1;
		$type_select = type_select('alert-'.$_userid, 0, 'typeid', $L['default_type'], $typeid, '', $L['all_type']);
		$condition = "username='$_username' AND status=$status";
		$lists = $do->get_list($condition);
		if($lists) {
			$tmp = $MOD['linkurl'];
			foreach($lists as $k=>$v) {
				if($v['catid']) {
					$lists[$k]['cate'] = cat_pos(get_cat($v['catid']), '-', 1);
				}
				if($v['email'] != $_email) $db->query("UPDATE {$DT_PRE}alert SET email='$_email' WHERE itemid=$v[itemid]");
			}
			$MOD['linkurl'] = $tmp;
		}
		$head_title = $L['alert_title'];
	break;
}
$nums = array();
$limit_used = 0;
for($i = 2; $i < 4; $i++) {
	$r = $db->get_one("SELECT COUNT(*) AS num FROM {$DT_PRE}alert WHERE username='$_username' AND status=$i");
	$nums[$i] = $r['num'];
	$limit_used += $r['num'];
}
$limit_free = $MG['alert_limit'] && $MG['alert_limit'] > $limit_used ? $MG['alert_limit'] - $limit_used : 0;
include template('alert', $module);
?>