dever 6 years ago
parent
commit
123ed244cf

+ 3 - 0
doc/onepage_project_update.sql

@@ -109,4 +109,7 @@ ALTER TABLE lottery_events ADD `top_display` int(10) DEFAULT 1;
 ALTER TABLE lottery_events ADD `category_id` int(10) DEFAULT 1;
 
 ALTER TABLE lottery_user_participate_log ADD `audit` int(10) DEFAULT 1;
+ALTER TABLE lottery_events_forms ADD `audit` int(10) DEFAULT 1;
+ALTER TABLE lottery_data ADD `audit` int(10) DEFAULT 2;
+ALTER TABLE lottery_data ADD `platform_id` int(10) DEFAULT 2;
 ALTER TABLE lottery_events_help_user ADD `num` int(10) DEFAULT 0;

+ 12 - 0
kissy/public/static/css/base.css

@@ -37,6 +37,18 @@ table {	border-collapse:collapse}
 .v_nav dl.on p.d{ display:none;}
 .v_nav dl dd{ line-height:1.8em;}
 
+.v_nav_mrhi{ height:44px; border-top:1px #d1d1d1 solid; background:#f2f2f4; width:100%; position:fixed; bottom:0px; left:0px; color:#999; overflow:hidden; z-index:990;}
+.v_nav_mrhi dl{ float:left; width:25%; height:100%; text-align:center; font-size:12px;}
+.v_nav_mrhi dl a{ display:block; width:100%; height:100%; color:#999}
+.v_nav_mrhi dl.on a{ color:#f00;}
+.v_nav_mrhi dl dt{ height:42.4%; margin-top:4px;}
+.v_nav_mrhi dl dt p{ height:100%;}
+.v_nav_mrhi dl dt img{ height:100%; display:block; margin:0 auto;}
+.v_nav_mrhi dl dt p.c{ display:none;}
+.v_nav_mrhi dl.on p.c{ display:block;}
+.v_nav_mrhi dl.on p.d{ display:none;}
+.v_nav_mrhi dl dd{ line-height:1.8em;}
+
 /**/
 .v_404_box{ position:relative; top:50%; -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%); -o-transform:translateY(-50%); -ms-transform:translateY(-50%);transform:translateY(-50%); font-size:1.6em;}
 .v_404_box img{ width:22%;}

+ 1 - 1
tm/compile_dir/%%48^48D^48DE5A4F%%bottom.html.php

@@ -1,4 +1,4 @@
-<?php /* Smarty version 2.6.17, created on 2018-04-25 14:58:24
+<?php /* Smarty version 2.6.17, created on 2018-05-25 16:01:16
          compiled from bottom.html */ ?>
 <div class="v_block"></div>
 <?php if (! $this->_tpl_vars['cutScreenInfo'] && $this->_tpl_vars['display'] == 1): ?>

+ 1 - 1
tm/compile_dir/%%A1^A1B^A1B92DB5%%user_participate_log.html.php

@@ -1,4 +1,4 @@
-<?php /* Smarty version 2.6.17, created on 2018-05-22 19:13:18
+<?php /* Smarty version 2.6.17, created on 2018-05-24 11:47:41
          compiled from admin/activity/user_participate_log.html */ ?>
 <?php require_once(SMARTY_CORE_DIR . 'core.load_plugins.php');
 smarty_core_load_plugins(array('plugins' => array(array('modifier', 'date', 'admin/activity/user_participate_log.html', 81, false),)), $this); ?>

+ 63 - 2
tm/compile_dir/%%C3^C33^C3389195%%user_participate_form.html.php

@@ -1,7 +1,7 @@
-<?php /* Smarty version 2.6.17, created on 2018-05-22 19:21:13
+<?php /* Smarty version 2.6.17, created on 2018-05-24 14:26:14
          compiled from admin/activity/user_participate_form.html */ ?>
 <?php require_once(SMARTY_CORE_DIR . 'core.load_plugins.php');
-smarty_core_load_plugins(array('plugins' => array(array('modifier', 'date', 'admin/activity/user_participate_form.html', 73, false),)), $this); ?>
+smarty_core_load_plugins(array('plugins' => array(array('modifier', 'date', 'admin/activity/user_participate_form.html', 76, false),)), $this); ?>
 <?php $_smarty_tpl_vars = $this->_tpl_vars;
 $this->_smarty_include(array('smarty_include_tpl_file' => "./admin/header.html", 'smarty_include_vars' => array()));
 $this->_tpl_vars = $_smarty_tpl_vars;
@@ -87,6 +87,9 @@ unset($_smarty_tpl_vars);
 								<th>UID</th>
 								<th>时间</th>
 								<th>行为</th>
+								<?php if ($this->_tpl_vars['audit']): ?>
+								<th>审核状态</th>
+								<?php endif; ?>
 							</tr>
 						</thead>
 						<tbody>
@@ -118,6 +121,11 @@ unset($_smarty_tpl_vars);
 </span>&nbsp;  
 								<?php endforeach; endif; unset($_from); ?>
 								</td>
+								<?php if ($this->_tpl_vars['audit']): ?>
+								<th><input type="checkbox" class="audit" name="audit[<?php echo $this->_tpl_vars['data']['id']; ?>
+]" value="<?php echo $this->_tpl_vars['data']['id']; ?>
+" <?php if ($this->_tpl_vars['data']['audit'] == 2): ?>checked<?php endif; ?>/></th>
+								<?php endif; ?>
 							</tr>
 							<?php endforeach; endif; unset($_from); ?>
 							<?php else: ?>
@@ -127,6 +135,16 @@ unset($_smarty_tpl_vars);
 							<?php endif; ?>
 						</tbody>
 					</table>
+					<?php if ($this->_tpl_vars['audit']): ?>
+					
+					<div style="float:right" ><input type="checkbox" id="audit" value="2" />全选&nbsp;&nbsp;&nbsp;&nbsp;
+
+					<a id="audit_submit" href="javascript:;" class="button button-default button-rounded">更新状态</a>
+
+					</div>
+
+					<br /><br /><br />
+					<?php endif; ?>
 					<div class="page"><?php echo $this->_tpl_vars['page_html']; ?>
 </div><p  style="float:right" >参与人数:<?php echo $this->_tpl_vars['total_num']; ?>
 </p>
@@ -150,6 +168,49 @@ KISSY.use('node, io, event', function (S, Node, IO, Event) {
 	var $ = S.all;
 	
 });
+
+
+function checkAll()
+{
+	$("#audit").click(function(){
+		if ($(this).prop('checked')) {
+			$(".audit").prop('checked',true);
+		} else {
+			$(".audit").prop('checked',false);
+		}
+	})
+}
+
+function submit()
+{
+	$("#audit_submit").click(function()
+	{
+		var yes = [];
+		var no = [];
+		$(".audit").each(function(){
+			if ($(this).prop('checked')) {
+				yes.push($(this).val());
+			} else {
+				no.push($(this).val());
+			}
+		});
+
+		var state = true;
+		if (state) {
+			var id = '<?php echo $this->_tpl_vars['eventData']['id']; ?>
+';
+			var url = '<?php echo $this->_tpl_vars['web_cfg']['domain']; ?>
+/?c=Admin_Activity_UserParticipateLog&a=Audit';
+			$.post(url, {id:id,yes:yes.join(','),no:no.join(',')}, function(res) {
+				alert('更新成功');
+			});
+		} else {
+			alert('请选择一个选项');
+		}
+	})
+}
+checkAll();
+submit();
 </script>
 
 <?php $_smarty_tpl_vars = $this->_tpl_vars;

+ 46 - 3
tm/compile_dir/%%C4^C4B^C4B7643A%%user_participate_win.html.php

@@ -1,7 +1,7 @@
-<?php /* Smarty version 2.6.17, created on 2018-05-17 18:55:31
+<?php /* Smarty version 2.6.17, created on 2018-05-24 17:10:08
          compiled from admin/activity/user_participate_win.html */ ?>
 <?php require_once(SMARTY_CORE_DIR . 'core.load_plugins.php');
-smarty_core_load_plugins(array('plugins' => array(array('modifier', 'date', 'admin/activity/user_participate_win.html', 71, false),)), $this); ?>
+smarty_core_load_plugins(array('plugins' => array(array('modifier', 'date', 'admin/activity/user_participate_win.html', 73, false),)), $this); ?>
 <?php $_smarty_tpl_vars = $this->_tpl_vars;
 $this->_smarty_include(array('smarty_include_tpl_file' => "./admin/header.html", 'smarty_include_vars' => array()));
 $this->_tpl_vars = $_smarty_tpl_vars;
@@ -64,6 +64,10 @@ unset($_smarty_tpl_vars);
 /?c=Admin_Activity_UserParticipateLog&a=PageLotteryDataList&events_id=<?php echo $this->_tpl_vars['eventData']['id']; ?>
 &action=win">中奖</a> &nbsp;
 	<?php endif; ?>
+
+	<a href="<?php echo $this->_tpl_vars['web_cfg']['domain']; ?>
+/?c=Admin_Activity_UserHelp&a=PageList&events_id=<?php echo $this->_tpl_vars['eventData']['id']; ?>
+">助力排行</a> &nbsp;
 	
 	<?php if ($this->_tpl_vars['download_url']): ?>
 	<a href="<?php echo $this->_tpl_vars['download_url']; ?>
@@ -105,16 +109,55 @@ unset($_smarty_tpl_vars);
 </td>
 								<td><?php echo ((is_array($_tmp="Y-m-d H:i:s")) ? $this->_run_mod_handler('date', true, $_tmp, $this->_tpl_vars['data']['create_time']) : date($_tmp, $this->_tpl_vars['data']['create_time'])); ?>
 </td>
+
+								<?php if ($this->_tpl_vars['data']['prize_id']): ?>
 								<td>
 									获得奖品: <span class="text-muted"><?php echo $this->_tpl_vars['prizeData'][$this->_tpl_vars['data']['prize_id']]['prize_name']; ?>
 </span>&nbsp; 
-									<?php if ($this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['user_name']): ?>
+									<?php if ($this->_tpl_vars['data']['express']): ?>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<?php echo $this->_tpl_vars['data']['express']['user_name']; ?>
+  收货地址:<?php echo $this->_tpl_vars['data']['express']['address']; ?>
+ 电话:<?php echo $this->_tpl_vars['data']['express']['phone']; ?>
+</span>&nbsp; 
+
+									<?php elseif ($this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['user_name']): ?>
 									<br><br>用户收货地址: <span class="text-muted">姓名:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['user_name']; ?>
   收货地址:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['address']; ?>
  电话:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['phone']; ?>
 </span>&nbsp; 
 									<?php endif; ?>
 									</td>
+								<?php else: ?>
+								<td>
+									获得奖品: <span class="text-muted"><?php echo $this->_tpl_vars['data']['run_time_data']['prize'][0]['prize_name']; ?>
+</span>&nbsp; 
+
+									<?php if ($this->_tpl_vars['data']['express']): ?>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<?php echo $this->_tpl_vars['data']['express']['user_name']; ?>
+  收货地址:<?php echo $this->_tpl_vars['data']['express']['address']; ?>
+ 电话:<?php echo $this->_tpl_vars['data']['express']['phone']; ?>
+</span>&nbsp; 
+
+									<?php elseif ($this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['user_name']): ?>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['user_name']; ?>
+  收货地址:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['address']; ?>
+ 电话:<?php echo $this->_tpl_vars['newUserExpData'][$this->_tpl_vars['data']['uid']]['phone']; ?>
+</span>&nbsp; 
+									<?php endif; ?>
+
+									<?php if ($this->_tpl_vars['formUserData'][$this->_tpl_vars['data']['uid']]): ?>
+									<br><br>
+									表单信息:<br />
+									<?php $_from = $this->_tpl_vars['formType']; if (!is_array($_from) && !is_object($_from)) { settype($_from, 'array'); }if (count($_from)):
+    foreach ($_from as $this->_tpl_vars['name']):
+?>
+									<?php echo $this->_tpl_vars['name']; ?>
+:<span class="text-muted"><?php echo $this->_tpl_vars['formUserData'][$this->_tpl_vars['data']['uid']][$this->_tpl_vars['name']]; ?>
+</span>&nbsp;  
+									<?php endforeach; endif; unset($_from); ?>
+									<?php endif; ?>
+									</td>
+								<?php endif; ?>
 							</tr>
 							<?php endforeach; endif; unset($_from); ?>
 							<?php else: ?>

+ 8 - 0
tm/config/route.inc.php

@@ -68,6 +68,14 @@ return array(
 			'c'	=> 'Index',
 			'url' =>'$1',
 	),
+
+	# 新增分类列表页
+	'cate/([0-9]+)/([a-zA-Z]+)/?'	=> array(
+			'c'	=> 'Cate',
+			'cate' =>'$1',
+			'url' =>'$2',
+	),
+
 	'SetUser/?'	=> array(
 			'c'	=> 'API_SetUser',
 			'a' =>'page',

+ 2 - 1
tm/lib/Controller/Admin/Activity/UserHelp.class.php

@@ -111,7 +111,8 @@ class UserHelp  extends Controller {
 		
 		$navConfig = $this->getUpPageNav($events_id, 'UserLog');
 		$eventsDisplayStatus = LotteryEvents::getDisplay (); // [活动] 是否显示
-		
+		$isPrizes = in_array($eventData['type'], array(LotteryEvents::TYPE_EVENTS_TURNTABLE, LotteryEvents::TYPE_EVENTS_SCRATCH, LotteryEvents::TYPE_EVENTS_TRY, LotteryEvents::TYPE_EVENTS_INVITATION));
+		$this->setOutput('isPrizes', $isPrizes);
 		$this->setOutput ( 'eventsDisplayStatus', $eventsDisplayStatus );
 		$this->setOutput ( 'groupByUid', $groupByUid );
 		$this->setOutput ( 'navConfig', $navConfig ); //公用内部导航信息

+ 131 - 15
tm/lib/Controller/Admin/Activity/UserParticipateLog.class.php

@@ -60,12 +60,7 @@ class UserParticipateLog  extends Controller {
 		$objMLotteryLog = new LotteryLog ( null, $events_id );
 		$eventData = $this->objLottery->getOneLotteryEvents ( $events_id );
 		$this->setOutput ( 'eventData', $eventData );
-		# 审核状态只有在邀请函和试用才有,type=6&4
-		$audit = false;
-		if (in_array($eventData['type'], array(4,6))) {
-			$audit = true;
-		}
-		$this->setOutput ( 'audit', $audit );
+		
 		$page = Request::varGetInt ( 'page', 1 );
 		$size = 10;
 		$offset = ($page - 1) * $size;
@@ -128,7 +123,7 @@ class UserParticipateLog  extends Controller {
 		$this->setOutput('displayDesc', LotteryEvents::getDisplay());
 		$this->setOutput('pagePublicData', $this->getPagePublicData($events_id)); // 后台管理相关数据
 		
-		$isPrizes = in_array($eventData['type'], array(LotteryEvents::TYPE_EVENTS_TURNTABLE, LotteryEvents::TYPE_EVENTS_SCRATCH));
+		$isPrizes = in_array($eventData['type'], array(LotteryEvents::TYPE_EVENTS_TURNTABLE, LotteryEvents::TYPE_EVENTS_SCRATCH, LotteryEvents::TYPE_EVENTS_TRY, LotteryEvents::TYPE_EVENTS_INVITATION));
 		$this->setOutput('isPrizes', $isPrizes);
 		
 		if ($groupByUid) {
@@ -148,8 +143,11 @@ class UserParticipateLog  extends Controller {
 	public function doAudit() {
 		$tableInfo = $_POST;
 
-		$this->objDLotteryUserParticipateLog = new LotteryUserParticipateLog();// 用户"参与"活动日志
+		$events_id = $tableInfo['id'];
+		$eventData = $this->objLottery->getOneLotteryEvents ( $events_id );
 
+		$this->objDLotteryEventsForms = new LotteryEventsForms();// 用户"参与"活动日志
+		$this->objDLotteryData = new LotteryData();
 		if (isset($tableInfo['yes']) && $tableInfo['yes']) {
 			$tableInfo['yes'] = explode(',', $tableInfo['yes']);
 			foreach ($tableInfo['yes'] as $k => $v) {
@@ -157,9 +155,11 @@ class UserParticipateLog  extends Controller {
 					'audit' => 2,
 					'operator_uid' => $operator_uid
 				);
-				$this->objDLotteryUserParticipateLog->modify( $info, array (
+				$this->objDLotteryEventsForms->modify( $info, array (
 						'id' => $v 
 				));
+				# 审核成功后,要把数据加到中奖表中
+				$this->updateAuditData(2, $events_id, $eventData, $v, 0);
 			}
 		}
 
@@ -167,17 +167,78 @@ class UserParticipateLog  extends Controller {
 			$tableInfo['no'] = explode(',', $tableInfo['no']);
 			foreach ($tableInfo['no'] as $k => $v) {
 				$info = array(
-					'audit' => 1,
+					'audit' => 3,
 					'operator_uid' => $operator_uid
 				);
-				$this->objDLotteryUserParticipateLog->modify( $info, array (
+				$this->objDLotteryEventsForms->modify( $info, array (
 						'id' => $v 
 				));
+				# 审核失败后,要把数据从中奖表中拿出来
+				$this->updateAuditData(3, $events_id, $eventData, $v, 0);
 			}
 		}
 		
 		$this->ajax_success_exit();
 	}
+
+	private function updateAuditData($audit, $events_id, $eventData, $formId, $prize_id)
+	{
+		$form = $this->objDLotteryEventsForms->get($formId);
+		if ($eventData['type'] == 4) {
+			# 试用
+			$img = $eventData['weixinShare']['imgUrl'];
+			$img = $img ? $img : $eventData['img_url'];
+			$prize = array(
+				0 => array(
+					'events_id' => $events_id,
+					'prize_name'  =>$eventData['events_name'],
+					'img_url' => $img,
+					'type' => LotteryPrize::TYPE_VIRTUAL,
+				)
+			);
+			$virtual_data = "/?c=EventsTry&events_id={$events_id}&formsId=" . $form['id'];
+
+		} elseif ($eventData['type'] == 6) {
+			# 邀请函
+			$prize = array(
+				0 => array(
+					'events_id' => $events_id,
+					'prize_name'  =>$eventData['events_name'],
+					'img_url' => '/public/static/img/qricon.png',
+					'type' => LotteryPrize::TYPE_ENTITY,
+				)
+			);
+			$virtual_data = "/?c=EventsInvitation&a=Qrcode&events_id={$events_id}&formsId=" . $form['id'];
+		}
+
+		$info  = array(
+				'events_id' => $events_id,
+				'form_id' => $form['id'],
+				'prize_id' => $prize_id,
+				'audit' => $audit,
+				'uid' => $form['uid'],
+				'winners_time' => $form['update_time'],
+				'winning_time' => $form['update_time'],
+				'run_time_data' => array(
+					'events' => $eventData,
+					'prize' => $prize,
+				),
+				'virtual_data' => $virtual_data,
+		);
+
+		$dataInfo = $this->objDLotteryData->fetchOne(array
+		(
+			'events_id' => $events_id,
+			'uid' => $info['uid'],
+			'prize_id' => $prize_id,
+		));
+
+		if (!$dataInfo) {
+			$this->objDLotteryData -> add($info);
+		} else {
+			$this->objDLotteryData -> modify($info, array('id' => $dataInfo['id']));
+		}
+	}
 	
 	/**
 	 *  显示 用户调查问卷 选择的结果集
@@ -375,7 +436,9 @@ class UserParticipateLog  extends Controller {
 		$offset = ($page - 1) * $size;
 		$limit = "{$offset},{$size}";
 		$condition = array (
-				'events_id' => $events_id
+				'events_id' => $events_id,
+				# 只有审核通过的才显示
+				'audit' => 2,
 		);
 		
 		// 刮刮卡 跳将特殊处理
@@ -439,7 +502,28 @@ class UserParticipateLog  extends Controller {
 			$newUserExpData[$data['uid']] = $data;
 		}
 		
-		
+		$objLotteryEventsForms = new LotteryEventsForms();
+		$formCondition = array(
+			'events_id' => $events_id,
+		);
+		$ids = $objLotteryEventsForms->fetchOne($formCondition);
+		if ($ids) {
+			$formData = $objLotteryEventsForms->gets($ids);
+			if ($formData) {
+				foreach ($formData as $k => $v) {
+					$formUserData[$v['uid']] = $v;
+				}
+
+				# 表单类型数据
+				$formType = array();
+				foreach ($eventsAndPrizeData['events']['forms'] as $tmpForms) {
+					$formType[] = $tmpForms['name'];
+				}
+				$this->setOutput ( 'formType', $formType );
+				$this->setOutput ( 'formUserData', $formUserData );
+			}
+		}
+
 		$objDLotteryPrize = new LotteryPrize();
 		$prizeType  = $objDLotteryPrize -> getType();
 		$prizeDisplayStatus  = $objDLotteryPrize ->getDisplay();
@@ -475,7 +559,9 @@ class UserParticipateLog  extends Controller {
 	public function doExportWinData() {
 		$events_id = Request::g ( 'events_id' );
 		$condition = array (
-				'events_id' => $events_id
+				'events_id' => $events_id,
+				# 只有审核通过的才显示
+				'audit' => 2,
 		);
 		$order = 'id desc';
 		$lotteryData = $this->objLottery->getLotteryDataList ( $condition, null, $order );
@@ -568,6 +654,13 @@ class UserParticipateLog  extends Controller {
 	
 		$objLotteryEvents = new LotteryEvents();
 		$eventData = $objLotteryEvents->get($events_id);
+
+		# 审核状态只有在邀请函和试用才有,type=6&4
+		$audit = false;
+		if (in_array($eventData['type'], array(4,6))) {
+			$audit = true;
+		}
+		$this->setOutput ( 'audit', $audit );
 	
 		# 表单类型数据
 		$formType = array();
@@ -592,6 +685,9 @@ class UserParticipateLog  extends Controller {
 		$this->setOutput('menu_active', array('name' => 'mypublish', 'item' => '')); //激活菜单
 		$this->addNavMenu('活动列表');
 		$this->addNavMenu($title);
+
+		$isPrizes = in_array($eventData['type'], array(LotteryEvents::TYPE_EVENTS_TURNTABLE, LotteryEvents::TYPE_EVENTS_SCRATCH, LotteryEvents::TYPE_EVENTS_TRY, LotteryEvents::TYPE_EVENTS_INVITATION));
+		$this->setOutput('isPrizes', $isPrizes);
 		
 		$this->setOutput('eventData', $eventData);
 		$this->setOutput ( 'page_html', $page_html );
@@ -650,8 +746,17 @@ class UserParticipateLog  extends Controller {
 		header ( "Expires: 0" );
 		header ( 'Content-Disposition: attachment; filename=' . $fileName );
 		
-		
+		# 审核状态只有在邀请函和试用才有,type=6&4
+		$audit = false;
+		if (in_array($eventData['type'], array(4,6))) {
+			$audit = true;
+		}
+		$this->setOutput ( 'audit', $audit );
+
 		$title = "用户ID,昵称,时间,行为\r\n";
+		if ($audit) {
+			$title = "用户ID,昵称,时间,行为,审核状态\r\n";
+		}
 		echo Convert::u82gb($title);
 		
 		foreach ($formData as $tmpData) {
@@ -662,6 +767,17 @@ class UserParticipateLog  extends Controller {
 				$formInfo = "{$formName}:{$tmpData[$formName]} ";
 			}
 			$info = "{$uid},{$users[$uid]['nickname']},{$date},{$formInfo}\r\n";
+			if ($audit) {
+				$status = $tmpData['audit'];
+				if ($status == 1) {
+					$status = '未审核';
+				} elseif ($status == 2) {
+					$status = '审核通过';
+				} elseif ($status == 3) {
+					$status = '审核未通过';
+				}
+				$info = "{$uid},{$users[$uid]['nickname']},{$date},{$formInfo},{$status}\r\n";
+			}
 			echo Convert::u82gb($info);
 		}
 		exit;

+ 137 - 0
tm/lib/Controller/Cate.class.php

@@ -0,0 +1,137 @@
+<?php
+namespace Cas\Controller;
+use KIF\Core\Request;
+use Cas\Dao\LotteryEvents;
+use Cas\Module\Lottery;
+use KIF\Dao\SqlHelper;
+use Cas\Dao\UserInfo;
+use Cas\Module\LotteryLog;
+use Cas\Dao\LotteryData;
+use Cas\Module\User;
+use Cas\Dao\LotteryUserExpress;
+use Cas\Dao\Category;
+/**
+ * 分类下的活动列表页 - 首页
+ * lihuanchun
+ */
+class Cate extends EventsController {
+	
+	/**
+	 * 页面:默认首页
+	 */
+	public function doDefault() {
+		
+		$cate = Request::varGetInt('cate', 1);
+		$objCategory = new Category();
+		$cateInfo = $objCategory->fetchOne(array
+		(
+			'id' => $cate,
+		));
+
+		if (!$cateInfo) {
+			echo '错误的分类信息';die;
+		}
+
+		# 检查是否移动端
+		$title = '精彩活动';
+		$this->checkIsFromMobile($title);
+		
+		$plat_form_id = $this->getPlatFormId();
+		
+		$thisTime = time();
+		$objMLottery = new Lottery();
+		$condition = array(
+			'category_id' => $cate,
+			'display' => LotteryEvents::EVENT_DISPLAY_SHOW, // 已发布的
+			'list_display' => LotteryEvents::LIST_DISPLAY_SHOW, // 列表中是否显示
+			'begin_time'	=> SqlHelper::addCompareOperator('<=', time()),
+			'platform_ids' => SqlHelper::addCompareOperator('&', $plat_form_id),
+		);
+		
+		
+		# 获取登录地址
+		$url = Request::g('url');
+		$thisUrl = Request::schemeDomain().'/cate/'.$cate . '/' . $url;
+		$loginUrl = $this -> getLoginUrl($thisUrl);
+		$this->setOutput('loginUrl', $loginUrl);
+		
+		# 判断是否需要登录
+		$ckLogin = $this->ckLogin();
+		$this->setOutput('ckLogin', $ckLogin);
+		
+		# 获取用户信息
+		$objUserData = new UserInfo();
+		$uid = $this->getRunTimeUid();
+		$userData = $objUserData -> get($uid);
+		$this->setOutput('userData', $userData);
+		
+		
+		
+		$totals = $objMLottery -> getLotteryEventsListNum($condition);
+		$offset = 0;
+		$size = 6;
+		$order = 'id desc';
+		$eventsData = $allLotteryEventsIds =  $objMLottery -> getLotteryEventsList($condition, "{$offset},{$size}", $order);
+
+		# 剩余天数
+		$TIME = time();
+		foreach ($eventsData as $tmpKey => $tmpData) {
+			$rday = ($tmpData['end_time'] - $TIME) / (24 * 60 * 60);
+			$eventsData[$tmpKey]['rday'] = ceil($rday);
+			# 参与人数
+			$objMLotteryLog = new LotteryLog ( null, $tmpData['id'] );
+			$eventsData[$tmpKey]['user_total'] = $objMLotteryLog->getUserParticipateLogNumGroupByUid ();
+		}
+		
+		$this->setOutput('eventsData', $eventsData);
+		$this->setOutput('title', $title);
+		$this->setOutput('totals', ceil($totals / $size));
+		$this->tpl = 'mrhi/list';
+		$this->setOutput('plat_form_id', $plat_form_id);
+		$this->setOutput('url', $url);
+	}
+	
+	/**
+	 * 事件:ajax翻页
+	 */
+	public function doAjax() {
+		$page = Request::varGetInt('page', 1);
+		$cate = Request::varGetInt('cate', 1);
+		$thisTime = time();
+		$objMLottery = new Lottery();
+		$plat_form_id = Request::g('plat_form_id');
+		$condition = array(
+			'category_id' => $cate,
+			'display' => LotteryEvents::EVENT_DISPLAY_SHOW, // 已发布的
+			'list_display' => LotteryEvents::LIST_DISPLAY_SHOW, // 列表中是否显示
+			'begin_time'	=> SqlHelper::addCompareOperator('<=', time()),
+			'platform_ids' => SqlHelper::addCompareOperator('&', $plat_form_id),
+		);
+		$totals = $objMLottery -> getLotteryEventsListNum($condition);
+		$order = 'begin_time desc';
+		$size = 10;
+		$offset = ($page - 1) * $size;
+		$limit = "{$offset},{$size}";
+		$eventsData = $allLotteryEventsIds =  $objMLottery -> getLotteryEventsList($condition,$limit,$order);
+		
+		# 剩余天数
+		$TIME = time();
+		foreach ($eventsData as $tmpKey => $tmpData) {
+			$rday = ($tmpData['end_time'] - $TIME) / (24 * 60 * 60);
+			$eventsData[$tmpKey]['rday'] = ceil($rday);
+			# 参与人数
+			$objMLotteryLog = new LotteryLog ( null, $tmpData['id'] );
+			$eventsData[$tmpKey]['user_total'] = $objMLotteryLog->getUserParticipateLogNumGroupByUid ();
+		}
+		
+		$this->tpl = 'ajax_index';
+		$data = array_fill(0, 4, 1);
+		$this->setOutput('eventsData', $eventsData);
+		$this->ajax_success_exit($this->render(true));
+	}
+	
+	public function display() {
+		$this->setOutput('action', 'index');
+		return $this->render();
+	}
+}

+ 1 - 0
tm/lib/Controller/EventsInvitation.class.php

@@ -162,6 +162,7 @@ class EventsInvitation extends EventsController {
 				'events_id' => $events_id,
 				'prize_id' => 0,
 				'uid' => $uid,
+				'audit' => 1,//未审核
 				'winners_time' => $thisTime,
 				'winning_time' => $thisTime,
 				'run_time_data' => array(

+ 7 - 0
tm/lib/Controller/EventsTry.class.php

@@ -117,6 +117,7 @@ class EventsTry extends EventsController {
 		# 2.活动信息&用户行为验证
 		$tmpData = $objLotteryEventsTypeTry -> userTry() ;
 		if(!$tmpData->isSuccess()){
+			print_r($tmpData);die;
 			self::ajax_fail_exit($tmpData->getData());
 		}
 		
@@ -171,6 +172,12 @@ class EventsTry extends EventsController {
 		# 以下为数据验证 
 		if ($type == 4) {
 			# 验证是否有试用权限
+			$objLotteryEventsTypeTry = new LotteryEventsTypeTry($uid, $events_id);
+
+			$tmpData = $objLotteryEventsTypeTry -> userTry() ;
+			if($tmpData->isSuccess()){
+				self::ajax_fail_exit('没有申请');
+			}
 		}
 
 		if ($type == 6) {

+ 147 - 3
tm/lib/Controller/Index.class.php

@@ -5,6 +5,11 @@ use Cas\Dao\LotteryEvents;
 use Cas\Module\Lottery;
 use KIF\Dao\SqlHelper;
 use Cas\Dao\UserInfo;
+use Cas\Module\LotteryLog;
+use Cas\Dao\LotteryData;
+use Cas\Module\User;
+use Cas\Dao\LotteryUserExpress;
+use Cas\Dao\Category;
 /**
  * 活动列表页 - 首页
  * lihuanchun
@@ -12,7 +17,7 @@ use Cas\Dao\UserInfo;
 class Index extends EventsController {
 	
 	/**
-	 * 页面:默认首页
+	 * 页面:默认新版首页
 	 */
 	public function doDefault() {
 		
@@ -22,6 +27,144 @@ class Index extends EventsController {
 		
 		$plat_form_id = $this->getPlatFormId();
 		
+		$thisTime = time();
+		$objMLottery = new Lottery();
+
+		# 获取登录地址
+		$url = Request::g('url');
+		$thisUrl = Request::schemeDomain().'/list/'.$url;
+		$loginUrl = $this -> getLoginUrl($thisUrl);
+		$this->setOutput('loginUrl', $loginUrl);
+		
+		# 判断是否需要登录
+		$ckLogin = $this->ckLogin();
+		$this->setOutput('ckLogin', $ckLogin);
+		
+		# 获取用户信息
+		$objUserData = new UserInfo();
+		$uid = $this->getRunTimeUid();
+		$userData = $objUserData -> get($uid);
+		$this->setOutput('userData', $userData);
+		
+		# 获取焦点图
+		$order = 'begin_time desc';
+		$focusCondition = array(
+			'display' => LotteryEvents::EVENT_DISPLAY_SHOW, // 已发布的
+			'focus_display' => LotteryEvents::FOCUS_DISPLAY_SHOW,//焦点图
+			'begin_time'	=> SqlHelper::addCompareOperator('<=', time()),
+			'platform_ids' => SqlHelper::addCompareOperator('&', $plat_form_id),
+		);
+		$focusData =  $objMLottery -> getLotteryEventsList($focusCondition, "0,5", 'id desc');
+
+
+		# 热门活动
+		$condition = array(
+			'display' => LotteryEvents::EVENT_DISPLAY_SHOW, // 已发布的
+			//'list_display' => LotteryEvents::LIST_DISPLAY_SHOW, // 列表中是否显示
+			'top_display' => LotteryEvents::TOP_DISPLAY_SHOW, // 是否置顶
+			'begin_time'	=> SqlHelper::addCompareOperator('<=', time()),
+			'platform_ids' => SqlHelper::addCompareOperator('&', $plat_form_id),
+		);
+
+		$totals = $objMLottery -> getLotteryEventsListNum($condition);
+		$offset = 0;
+		$size = 10;
+		# 开始时间排序
+		$order = 'begin_time desc';
+		# 热门活动
+		$eventsData =  $objMLottery -> getLotteryEventsList($condition, "{$offset},{$size}", $order);
+
+		$TIME = time();
+
+		foreach ($eventsData as $tmpKey => $tmpData) {
+			# 剩余天数
+			$rday = ($tmpData['end_time'] - $TIME) / (24 * 60 * 60);
+			$eventsData[$tmpKey]['rday'] = ceil($rday);
+			# 参与人数
+			$objMLotteryLog = new LotteryLog ( null, $tmpData['id'] );
+			$eventsData[$tmpKey]['user_total'] = $objMLotteryLog->getUserParticipateLogNumGroupByUid ();
+		}
+
+		# 获得福利
+		$condition = array('platform_id' => SqlHelper::addCompareOperator('&', $plat_form_id), 'scratch_receive' => LotteryData::EVENT_SCRATCH_RECEIVE_TRUE);
+		$totals = $objMLottery -> getLotteryDataListNum($condition);
+		$offset = 0;
+		$size = 6;
+		$order = 'update_time desc';
+		$data = $objMLottery->getLotteryDataList($condition,  "{$offset},{$size}", $order);
+
+		if ($data) {
+			$uids = array();
+			foreach ($data as $k => $v) {
+				$uids[] = $v['uid'];
+			}
+			# 通过UIDs 获取用户信息
+			$objMUser = new User();
+			$users = $objMUser -> gets($uids);
+
+			$objLotteryUserExpress = new LotteryUserExpress();
+			$condition = array(
+				'uid' => $uids
+			);
+			$tmpUserExpIds = $objLotteryUserExpress->findIdsBy($condition);
+			$userExpData = $objLotteryUserExpress -> gets($tmpUserExpIds);
+			$newUserExpData = array();
+			foreach($userExpData as $k => $v){
+				$newUserExpData[$v['uid']] = $v;
+			}
+			$this->setOutput('newUserExpData', $newUserExpData);
+
+			//138****1234 的用户 2018.4.20 15:10 获得 某某某某活动 奖品。
+			foreach ($data as $k => $v) {
+				$data[$k]['user'] = array();
+				$data[$k]['user']['cdate'] = $v['winners_time'];
+				$data[$k]['user']['events'] = $eventsData[$v['events_id']]['events_name'];
+				if (isset($users[$v['uid']]['headimgurl']) && $users[$v['uid']]['headimgurl']) {
+					$data[$k]['user']['headimgurl'] = $users[$v['uid']]['headimgurl'];
+				} else {
+					$data[$k]['user']['headimgurl'] = 'http://news.mydrivers.com/Img/20110518/04481549.png';
+				}
+
+				if (isset($v['express']['phone']) && $v['express']['phone']) {
+					$data[$k]['user']['mobile'] = substr_replace($v['express']['phone'],'****',3,4);
+				} elseif (isset($newUserExpData[$v['uid']]['phone']) && $newUserExpData[$v['uid']]['phone']) {
+					$data[$k]['user']['mobile'] = substr_replace($newUserExpData[$v['uid']]['phone'],'****',3,4);
+				} else {
+					unset($data[$k]);
+				}
+			}
+
+			$this->setOutput('userData', $data);
+		}
+
+		# 获取分类
+		$this->objDCategory = new Category ();
+		$order = 'id desc';
+		$condition = array ();
+		$ids = $this->objDCategory->findIdsBy ( $condition, '0,5', $order );
+		$categoryData = $this->objDCategory->gets ( $ids );
+		$this->setOutput('categoryData', $categoryData);
+
+
+		$this->setOutput('eventsData', $eventsData);
+		$this->setOutput('title', '精彩活动');
+		$this->setOutput('totals', ceil($totals / $size));
+		$this->tpl = 'mrhi/index';
+		$this->setOutput('plat_form_id', $plat_form_id);
+		$this->setOutput('url', $url);
+	}
+
+	/**
+	 * 页面:默认首页
+	 *
+	public function doOldDefault() {
+		
+		# 检查是否移动端
+		$title = '精彩活动';
+		$this->checkIsFromMobile($title);
+		
+		$plat_form_id = $this->getPlatFormId();
+		
 		$thisTime = time();
 		$objMLottery = new Lottery();
 		$condition = array(
@@ -82,12 +225,13 @@ class Index extends EventsController {
 		$condition = array(
 			'display' => LotteryEvents::EVENT_DISPLAY_SHOW, // 已发布的
 			'list_display' => LotteryEvents::LIST_DISPLAY_SHOW, // 列表中是否显示
+			'top_display' => LotteryEvents::TOP_DISPLAY_SHOW, // 是否置顶
 			'begin_time'	=> SqlHelper::addCompareOperator('<=', time()),
 			'platform_ids' => SqlHelper::addCompareOperator('&', $plat_form_id),
 		);
 		$totals = $objMLottery -> getLotteryEventsListNum($condition);
-		$order = 'id desc';
-		$size = 6;
+		$order = 'begin_time desc';
+		$size = 10;
 		$offset = ($page - 1) * $size;
 		$limit = "{$offset},{$size}";
 		$eventsData = $allLotteryEventsIds =  $objMLottery -> getLotteryEventsList($condition,$limit,$order);

+ 34 - 2
tm/lib/Controller/Member.class.php

@@ -7,6 +7,7 @@ use Cas\Dao\LotteryEvents;
 use KIF\Core\Request;
 use Cas\Module\Lottery;
 use Cas\Dao\UserInfo;
+use Cas\Dao\LotteryUserFeedback;
 /**
  * 
  * 用户资料设置
@@ -24,6 +25,7 @@ class Member extends EventsController {
 	 * 我的礼品
 	 */
 	public function doGifts() {
+		//填写收货地址 c=Express&lottery_data_id=3
 		$objLottery = new Lottery();
 		$thisTime = time();
 	
@@ -43,15 +45,45 @@ class Member extends EventsController {
 		$newData = array();
 		$events_ids = array();
 		
-		
+		$objLotteryUserFeedback = new LotteryUserFeedback();
 		foreach($data as $key=> $d){
+			$data[$key]['feedback'] = 1;//不需要填写反馈
 			$events_ids[$d['run_time_data']['events']['id']] = $d['run_time_data']['events']['id'];
+
+			if (in_array($d['run_time_data']['events']['type'], array(4,6))) {
+				if (isset($v['express']) && $v['express']) {
+					$data[$key]['feedback'] = 2;//未填写反馈
+					$where = array();
+					$where['uid'] = $d['uid'];
+					$where['events_id'] = $d['run_time_data']['events']['id'];
+					$where['status'] = 1;
+					
+					$ids = $objLotteryUserFeedback->findIdsBy ( $where, 1, $order = ' id desc');
+					$info = $objLotteryUserFeedback->gets ( $ids );
+					if ($info) {
+						$data[$key]['feedback'] = 3;//已填写反馈
+					}
+				} else {
+					$data[$key]['feedback'] = 4;//未填写收货地址
+				}
+			}
 		}
+
 		$objDLotteryEvents = new LotteryEvents();
 		$eventsData = $objDLotteryEvents -> gets($events_ids);
-		
+
+		$time = time();
+
 		foreach($data as $key=> $d){
+			if ($v['feedback'] == 3) {
+				# 查看是否过期
+				$eventsInfo = $eventsData[$d['run_time_data']['events']['id']];
+				if ($time > $eventsInfo['end_time']) {
+					$data[$key]['feedback'] = 5;//未填写收货地址并且已经过期
+				}
+			}
 			$newData[$key] = array();
+			$newData[$key]['feedback'] = $d['feedback'];
 			$thisEventID = $d['run_time_data']['events']['id'];
 			$newData[$key]['prize_id'] = $d['prize_id'];
 			$newData[$key]['prize_name'] = $d['run_time_data']['prize'][$d['prize_id']]['prize_name'];

+ 5 - 1
tm/lib/Dao/LotteryData.class.php

@@ -26,7 +26,11 @@ class LotteryData extends DBAgileDev {
 		'uid',
 		'scratch_receive',// 对刮挂卡领取奖品的特殊处理
 		'winning_time',
-		'winners_time'
+		'winners_time',
+		# 审核字段 1未审核 2审核通过 3审核不通过 默认为审核通过2
+		'audit',
+		# 平台id 适用于多个平台下的领取记录
+		'platform_id',
 	);
 	
 	

+ 4 - 4
tm/lib/Dao/LotteryEvents.class.php

@@ -112,13 +112,13 @@ class LotteryEvents extends DBAgileDev {
 	 * FOCUS_DISPLAY_HIDE  不推荐到焦点图
 	 * @var int
 	 */
-	const FOCUS_DISPLAY_HIDE = 0;
+	const FOCUS_DISPLAY_HIDE = 1;
 	
 	/**
 	 * FOCUS_DISPLAY_SHOW 推荐到焦点图
 	 * @var int
 	 */
-	const FOCUS_DISPLAY_SHOW = 1;
+	const FOCUS_DISPLAY_SHOW = 2;
 	
 	public static $focusDisplay= array(
 			self::FOCUS_DISPLAY_HIDE => array(
@@ -144,13 +144,13 @@ class LotteryEvents extends DBAgileDev {
 	 * TOP_DISPLAY_HIDE  是否置顶
 	 * @var int
 	 */
-	const TOP_DISPLAY_HIDE = 0;
+	const TOP_DISPLAY_HIDE = 1;
 	
 	/**
 	 * TOP_DISPLAY_SHOW 是否置顶
 	 * @var int
 	 */
-	const TOP_DISPLAY_SHOW = 1;
+	const TOP_DISPLAY_SHOW = 2;
 	
 	public static $topDisplay= array(
 			self::TOP_DISPLAY_HIDE => array(

+ 2 - 0
tm/lib/Dao/LotteryEventsForms.class.php

@@ -16,6 +16,8 @@ class LotteryEventsForms extends DBAgileDev {
 	protected $other_field = array(
 		'events_id',
 		'uid',
+		# 审核字段 1未审核 2审核通过 3审核不通过
+		'audit',
 	);
 	
 	/**

+ 57 - 0
tm/template_dir/admin/activity/user_participate_form.html

@@ -55,6 +55,9 @@
 								<th>UID</th>
 								<th>时间</th>
 								<th>行为</th>
+								<{if $audit}>
+								<th>审核状态</th>
+								<{/if}>
 							</tr>
 						</thead>
 						<tbody>
@@ -76,6 +79,9 @@
 									<{$name}>:<span class="text-muted"><{$data.$name}></span>&nbsp;  
 								<{/foreach}>
 								</td>
+								<{if $audit}>
+								<th><input type="checkbox" class="audit" name="audit[<{$data.id}>]" value="<{$data.id}>" <{if $data.audit == 2}>checked<{/if}>/></th>
+								<{/if}>
 							</tr>
 							<{/foreach}>
 							<{else}>
@@ -85,6 +91,16 @@
 							<{/if}>
 						</tbody>
 					</table>
+					<{if $audit}>
+					
+					<div style="float:right" ><input type="checkbox" id="audit" value="2" />全选&nbsp;&nbsp;&nbsp;&nbsp;
+
+					<a id="audit_submit" href="javascript:;" class="button button-default button-rounded">更新状态</a>
+
+					</div>
+
+					<br /><br /><br />
+					<{/if}>
 					<div class="page"><{$page_html}></div><p  style="float:right" >参与人数:<{$total_num}></p>
 				</div>
 			</div>
@@ -102,6 +118,47 @@ KISSY.use('node, io, event', function (S, Node, IO, Event) {
 	var $ = S.all;
 	
 });
+
+
+function checkAll()
+{
+	$("#audit").click(function(){
+		if ($(this).prop('checked')) {
+			$(".audit").prop('checked',true);
+		} else {
+			$(".audit").prop('checked',false);
+		}
+	})
+}
+
+function submit()
+{
+	$("#audit_submit").click(function()
+	{
+		var yes = [];
+		var no = [];
+		$(".audit").each(function(){
+			if ($(this).prop('checked')) {
+				yes.push($(this).val());
+			} else {
+				no.push($(this).val());
+			}
+		});
+
+		var state = true;
+		if (state) {
+			var id = '<{$eventData.id}>';
+			var url = '<{$web_cfg.domain}>/?c=Admin_Activity_UserParticipateLog&a=Audit';
+			$.post(url, {id:id,yes:yes.join(','),no:no.join(',')}, function(res) {
+				alert('更新成功');
+			});
+		} else {
+			alert('请选择一个选项');
+		}
+	})
+}
+checkAll();
+submit();
 </script>
 
 <{include file="./admin/bottom.html"}>

+ 26 - 1
tm/template_dir/admin/activity/user_participate_win.html

@@ -71,12 +71,37 @@
 									<{if $userData[$data.uid].nickname}><{$userData[$data.uid].nickname}><{else}>游客<{/if}></td>
 								<td><{$data.uid}></td>
 								<td><{"Y-m-d H:i:s"|date:$data.create_time}></td>
+
+								<{if $data.prize_id}>
 								<td>
 									获得奖品: <span class="text-muted"><{$prizeData[$data.prize_id].prize_name}></span>&nbsp; 
-									<{if $newUserExpData[$data.uid].user_name}>
+									<{if $data.express}>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<{$data.express.user_name}>  收货地址:<{$data.express.address}> 电话:<{$data.express.phone}></span>&nbsp; 
+
+									<{elseif $newUserExpData[$data.uid].user_name}>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<{$newUserExpData[$data.uid].user_name}>  收货地址:<{$newUserExpData[$data.uid].address}> 电话:<{$newUserExpData[$data.uid].phone}></span>&nbsp; 
+									<{/if}>
+									</td>
+								<{else}>
+								<td>
+									获得奖品: <span class="text-muted"><{$data.run_time_data.prize[0].prize_name}></span>&nbsp; 
+
+									<{if $data.express}>
+									<br><br>用户收货地址: <span class="text-muted">姓名:<{$data.express.user_name}>  收货地址:<{$data.express.address}> 电话:<{$data.express.phone}></span>&nbsp; 
+
+									<{elseif $newUserExpData[$data.uid].user_name}>
 									<br><br>用户收货地址: <span class="text-muted">姓名:<{$newUserExpData[$data.uid].user_name}>  收货地址:<{$newUserExpData[$data.uid].address}> 电话:<{$newUserExpData[$data.uid].phone}></span>&nbsp; 
 									<{/if}>
+
+									<{if $formUserData[$data.uid]}>
+									<br><br>
+									表单信息:<br />
+									<{foreach from=$formType item=name}>
+									<{$name}>:<span class="text-muted"><{$formUserData[$data.uid][$name]}></span>&nbsp;  
+									<{/foreach}>
+									<{/if}>
 									</td>
+								<{/if}>
 							</tr>
 							<{/foreach}>
 							<{else}>

+ 120 - 0
tm/template_dir/index_new.html

@@ -0,0 +1,120 @@
+<{include file="header.html"}>
+<style>
+.vogue_top_list img {
+    background: #fff url("<{$web_cfg.cdn}>/public/static/img/m-load.gif") no-repeat scroll 50% center / 20px 20px;
+}
+</style>
+<{include file="common_header.html"}>
+
+<div class="wrapper clear">    
+    <div class="vogue_top_list">
+    	<{foreach from=$eventsData item=events}>
+        <dl>
+        	<a href="<{$events.url}>">
+                <dt><img src="<{$web_cfg.cdn}>/public/static/img/bg_alpha.png" data-ks-lazyload="<{$events.img_url}>"></dt>
+                <dd>
+                	<p><{$events.events_name}></p>
+                    <p class="v_time">                    	
+                        <{if $events.rday>=1}>
+                        <em class="time_icon"></em><span>剩余<{$events.rday}>天</span>
+                        <{else}>
+                        已结束
+                        <{/if}>
+                    </p>
+                </dd>
+            </a>
+        </dl>
+        <{/foreach}>
+    </div>
+    
+    <div class="clear"></div>
+    <{if $totals}>
+    <div class="loading">
+    	<img
+    		id="loadPage"
+    		data-ks-lazyload="<{$web_cfg.cdn}>/public/static/img/loading_new.gif"
+    		data-request-url="<{$web_cfg.domain}>/?c=index&a=ajax&plat_form_id=<{$plat_form_id}>&url=<{$url}>"
+    		data-page="2"
+    		data-totals="<{$totals}>"
+    		style="width:0px;"
+    	/>
+	    <div class="loader-inner ball-pulse">
+	        <div></div><div></div><div></div><div></div><div></div><div></div>
+	    </div>
+	</div>
+    <{/if}>
+    <br>
+        
+</div>
+
+
+<!--loading 样式1-->
+<!--<div class="loading">
+    <div class="loader-inner line-spin-fade-loader">
+        <div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
+    </div>
+</div>-->
+
+<!--loading 样式2-->
+<!--<div class="loading">
+    <div class="loader-inner ball-pulse">
+        <div></div><div></div><div></div><div></div><div></div><div></div>
+    </div>
+</div>-->
+
+
+<script>
+
+KISSY.use('node, io, gallery/datalazyload/2.0/index', function (S, Node, IO, Datalazyload) {
+	var $ = S.all;
+	var lock = false;
+	
+	new Datalazyload({
+		load: function(el){
+			if (lock) return false;
+			lock = true;
+			
+			var requesrUrl = $(el).attr('data-request-url');
+			var page = Number($(el).attr('data-page'));
+			var totals = Number($(el).attr('data-totals'));
+			if (!requesrUrl) {
+				lock = false;
+				return false;
+			}
+			
+			if (page > totals) {
+				$('.loading').hide();
+				return false;
+			}
+			
+			IO.get(
+				requesrUrl
+				, {page: page}
+				, function (data) {
+					if (data.ok) {
+						var next_page = page + 1;
+						$('#loadPage').attr('data-page', next_page);
+						var new_dl = $(data.msg);
+						$(".vogue_top_list").append(new_dl);
+						//new Datalazyload();
+						lock = false;
+						
+						if (next_page > totals) {
+							$('.loading').hide();
+						}
+					}
+				}
+				, 'json'
+			);
+		}
+	});
+});
+
+
+//判断当前页图片加载完成loading消失
+/* $(".vogue_top_list").find("img").load(function(){
+	$(this).parent().css("background","none");
+}); */
+
+</script>
+<{include file="bottom.html"}>

+ 204 - 0
tm/template_dir/mrhi/bottom.html

@@ -0,0 +1,204 @@
+<div class="v_block"></div>
+<{if !$cutScreenInfo}>
+<!--nav begin-->
+<div class="<{if $platform.zs_img_link}>v_nav_mrhi<{else}>v_nav<{/if}>">
+	<dl <{if $action != 'gift'}>class="on"<{/if}>>
+    	<a href="<{$listUrl}>">
+        <dt>
+        	<p class="d"><img src="<{$platform.home_img_url}>"></p>
+            <p class="c"><img src="<{$platform.home_img_url_hover}>"></p>
+        </dt>
+        <dd><{$platform.home_img_text}></dd>
+        </a>
+    </dl>    
+    <dl <{if $action == 'gift'}>class="on"<{/if}>>
+    	<a href="<{$giftsUrl}>">
+    	<dt>
+        	<p class="d"><img src="<{$platform.gift_img_url}>"></p>
+            <p class="c"><img src="<{$platform.gift_img_url_hover}>"></p>
+        </dt>
+        <dd><{$platform.gift_img_text}></dd>
+        </a>
+    </dl>
+    <{if $platform.zs_img_link}>
+    <dl <{if $action == 'zs'}>class="on"<{/if}>>
+        <a href="<{$platform.zs_img_link}>">
+        <dt>
+            <p class="d"><img src="<{$platform.zs_img_url}>"></p>
+            <p class="c"><img src="<{$platform.zs_img_url_hover}>"></p>
+        </dt>
+        <dd><{$platform.zs_img_text}></dd>
+        </a>
+    </dl>
+    <{/if}>
+    <dl class="bottom_follow">
+        <a href="<{$platform.follow_url}>" target="_blank">
+        <dt>
+            <p class="d"><img src="<{$platform.follow_img_url}>"></p>
+            <p class="c"><img src="<{$platform.follow_img_url_hover}>"></p>
+        </dt>
+        <dd><{$platform.follow_img_text}></dd>
+        </a>
+    </dl>
+
+    <dl style="display:none">
+        <a  class="bottom_share" href="<{$platform.share_url}>" target="_blank">
+        <dt>
+            <p class="d"><img src="<{$platform.share_img_url}>"></p>
+            <p class="c"><img src="<{$platform.share_img_url_hover}>"></p>
+        </dt>
+        <dd><{$platform.share_img_text}></dd>
+        </a>
+    </dl>
+    <!--<dl>
+    	<a href="#">
+    	<dt>
+        	<p class="d"><img src="<{$web_cfg.cdn}>/public/static/img/nav_icon_4.png"></p>
+            <p class="c"><img src="<{$web_cfg.cdn}>/public/static/img/nav_icon_4_on.png"></p>
+        </dt>
+        <dd>分享</dd>
+        </a>
+    </dl>-->
+</div>
+<!--nav end-->
+<{/if}>
+<{if !$notShowWeixinShare && !$weixinShare.notAllow}>
+<script type="text/javascript">
+
+function checkApp() {
+    var u = navigator.userAgent.toLowerCase();
+    var isApple = /iphone|ipad|ipod|ios/i.test(u);
+    var isAndroid = /android/i.test(u);
+    if (isApple || isAndroid) {
+        return true;
+    } else {
+        return false;
+    }
+}
+
+function share_button(e, title, url, img, content) {
+    console.log(title);
+    if (checkApp()) {
+        e.parent().show();
+        e.click(function()
+        {
+            WX_share(url, content, title, img);
+        })
+    } else {
+        e.parent().hide();
+    }
+}
+
+/*
+function share_ios(title, url, img, content) {
+    window.location = 'myscheme://share_title/' + title + '/share_url/' + url + '/share_img/' + img + '/share_content/' + content;
+}
+
+function share_android(title, url, img, content) {
+    window.AndroidBridge.openShare(title, url, img, content);
+}
+*/
+
+var URL = window.location.href, site;
+site = 1;
+
+<{if $weixinShare.weixinShare_title }>
+new brickjs.MShare({
+    website : 'sg',
+    site: site,
+    catalog: "",
+    sUrl: "<{$web_cfg.url}>", //分享地址
+    title: "<{$weixinShare.title}>",
+    imgUrl: "<{$weixinShare.imgUrl}>",
+    imgWidth: "640",
+    imgHeight: "640",
+    source_id : 1,
+    source_table : 'onepage',
+    desc: "<{$weixinShare.content}>",
+    appKey: {
+        tsina: "2412621184"
+    },
+    ralateUid: '1658402750',
+    wxGuide: {
+        imgUrl: '<{$weixinShare.imgUrl}>',
+        width: 100,
+        height: 100,
+        style: {
+            right: 0,
+            top: 0
+        }
+    }
+});
+
+$(function()
+{
+    if ($('.share_button').length) {
+        share_button($('.share_button'), '<{$weixinShare.title}>', '<{$web_cfg.url}>', '<{$weixinShare.imgUrl}>', '<{$weixinShare.content}>');
+    }
+
+    if (checkApp()) {
+        if ($('.bottom_share').length) {
+            $('.bottom_follow').hide();
+            share_button($('.bottom_share'), '<{$weixinShare.title}>', '<{$web_cfg.url}>', '<{$weixinShare.imgUrl}>', '<{$weixinShare.content}>');
+        }
+    }
+})
+
+
+<{else}>
+
+var url = '<{if $weixinShare.jump_url}><{$weixinShare.jump_url}><{else}><{$web_cfg.url}><{/if}>';
+var title = '<{if $weixinShare.title}><{$weixinShare.title}><{else}><{$platform.weixinShare_title}><{/if}>';
+var img = '<{if $weixinShare.imgUrl}><{$weixinShare.imgUrl}><{else}><{$platform.weixinShare_img_url}><{/if}>';
+var content = '<{if $weixinShare.content}><{$weixinShare.content}><{else}><{$platform.weixinShare_content}><{/if}>';
+
+$(function()
+{
+    if ($('.share_button').length) {
+        share_button($('.share_button'), title, url, img, content);
+    }
+
+    if (checkApp()) {
+        if ($('.bottom_share').length) {
+            $('.bottom_follow').hide();
+            share_button($('.bottom_share'), title, url, img, content);
+        }
+    }
+});
+
+new brickjs.MShare({
+    website : 'sg',
+    site: site,
+    catalog: "",
+    sUrl: url, //分享地址
+    title: title,
+    imgUrl: img,
+    imgWidth: "640",
+    imgHeight: "640",
+    source_id : 1,
+    source_table : 'onepage',
+    desc: content,
+    appKey: {
+        tsina: "2412621184"
+    },
+    ralateUid: '1658402750',
+    wxGuide: {
+        imgUrl: img,
+        width: 100,
+        height: 100,
+        style: {
+            right: 0,
+            top: 0
+        }
+    }
+});
+<{/if}>
+</script>
+<{else}>
+<script>
+//关闭分享按钮
+wx.hideOptionMenu();
+</script>
+<{/if}>
+</body>
+</html>

+ 120 - 0
tm/template_dir/mrhi/index.html

@@ -0,0 +1,120 @@
+<{include file="header.html"}>
+<style>
+.vogue_top_list img {
+    background: #fff url("<{$web_cfg.cdn}>/public/static/img/m-load.gif") no-repeat scroll 50% center / 20px 20px;
+}
+</style>
+<{include file="common_header.html"}>
+
+<div class="wrapper clear">    
+    <div class="vogue_top_list">
+    	<{foreach from=$eventsData item=events}>
+        <dl>
+        	<a href="<{$events.url}>">
+                <dt><img src="<{$web_cfg.cdn}>/public/static/img/bg_alpha.png" data-ks-lazyload="<{$events.img_url}>"></dt>
+                <dd>
+                	<p><{$events.events_name}></p>
+                    <p class="v_time">                    	
+                        <{if $events.rday>=1}>
+                        <em class="time_icon"></em><span>剩余<{$events.rday}>天</span>
+                        <{else}>
+                        已结束
+                        <{/if}>
+                    </p>
+                </dd>
+            </a>
+        </dl>
+        <{/foreach}>
+    </div>
+    
+    <div class="clear"></div>
+    <{if $totals}>
+    <div class="loading">
+    	<img
+    		id="loadPage"
+    		data-ks-lazyload="<{$web_cfg.cdn}>/public/static/img/loading_new.gif"
+    		data-request-url="<{$web_cfg.domain}>/?c=index&a=ajax&plat_form_id=<{$plat_form_id}>&url=<{$url}>"
+    		data-page="2"
+    		data-totals="<{$totals}>"
+    		style="width:0px;"
+    	/>
+	    <div class="loader-inner ball-pulse">
+	        <div></div><div></div><div></div><div></div><div></div><div></div>
+	    </div>
+	</div>
+    <{/if}>
+    <br>
+        
+</div>
+
+
+<!--loading 样式1-->
+<!--<div class="loading">
+    <div class="loader-inner line-spin-fade-loader">
+        <div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
+    </div>
+</div>-->
+
+<!--loading 样式2-->
+<!--<div class="loading">
+    <div class="loader-inner ball-pulse">
+        <div></div><div></div><div></div><div></div><div></div><div></div>
+    </div>
+</div>-->
+
+
+<script>
+
+KISSY.use('node, io, gallery/datalazyload/2.0/index', function (S, Node, IO, Datalazyload) {
+	var $ = S.all;
+	var lock = false;
+	
+	new Datalazyload({
+		load: function(el){
+			if (lock) return false;
+			lock = true;
+			
+			var requesrUrl = $(el).attr('data-request-url');
+			var page = Number($(el).attr('data-page'));
+			var totals = Number($(el).attr('data-totals'));
+			if (!requesrUrl) {
+				lock = false;
+				return false;
+			}
+			
+			if (page > totals) {
+				$('.loading').hide();
+				return false;
+			}
+			
+			IO.get(
+				requesrUrl
+				, {page: page}
+				, function (data) {
+					if (data.ok) {
+						var next_page = page + 1;
+						$('#loadPage').attr('data-page', next_page);
+						var new_dl = $(data.msg);
+						$(".vogue_top_list").append(new_dl);
+						//new Datalazyload();
+						lock = false;
+						
+						if (next_page > totals) {
+							$('.loading').hide();
+						}
+					}
+				}
+				, 'json'
+			);
+		}
+	});
+});
+
+
+//判断当前页图片加载完成loading消失
+/* $(".vogue_top_list").find("img").load(function(){
+	$(this).parent().css("background","none");
+}); */
+
+</script>
+<{include file="mrhi/bottom.html"}>