277 lines
12 KiB
PHP
277 lines
12 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* 积分管理
|
||
|
*/
|
||
|
|
||
|
namespace app\admin\controller;
|
||
|
use think\facade\View;
|
||
|
use think\facade\Lang;
|
||
|
/**
|
||
|
* ============================================================================
|
||
|
* 联课教育商城系统
|
||
|
* ============================================================================
|
||
|
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
|
||
|
* 网站地址: http://www.o1h.cn
|
||
|
* ----------------------------------------------------------------------------
|
||
|
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
|
||
|
* 不允许对程序代码以任何形式任何目的的再发布。
|
||
|
* ============================================================================
|
||
|
* 控制器
|
||
|
*/
|
||
|
class Points extends AdminControl {
|
||
|
|
||
|
const EXPORT_SIZE = 5000;
|
||
|
public function initialize() {
|
||
|
parent::initialize();
|
||
|
Lang::load(base_path() . 'admin/lang/'.config('lang.default_lang').'/points.lang.php');
|
||
|
}
|
||
|
|
||
|
public function index() {
|
||
|
if (!request()->isPost()) {
|
||
|
$condition = array();
|
||
|
$mname = input('param.mname');
|
||
|
if (!empty($mname)) {
|
||
|
$condition[] = array('pl_membername','like', '%' . $mname . '%');
|
||
|
}
|
||
|
$aname = input('param.aname');
|
||
|
if (!empty($aname)) {
|
||
|
$condition[] = array('pl_adminname','like', '%' . $aname . '%');
|
||
|
}
|
||
|
$stage = input('get.stage');
|
||
|
if ($stage) {
|
||
|
$condition[] = array('pl_stage','=',trim($stage));
|
||
|
}
|
||
|
$stime = input('get.stime');
|
||
|
$etime = input('get.etime');
|
||
|
$if_start_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $stime);
|
||
|
$if_end_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $etime);
|
||
|
$start_unixtime = $if_start_time ? strtotime($stime) : null;
|
||
|
$end_unixtime = $if_end_time ? strtotime($etime) : null;
|
||
|
if ($start_unixtime) {
|
||
|
$condition_arr[] = array('pl_addtime','>=', $start_unixtime);
|
||
|
}
|
||
|
if ($end_unixtime) {
|
||
|
$end_unixtime=$end_unixtime+86399;
|
||
|
$condition_arr[] = array('pl_addtime','<=', $end_unixtime);
|
||
|
}
|
||
|
|
||
|
$search_desc = trim(input('param.description'));
|
||
|
if (!empty($search_desc)) {
|
||
|
$condition[] = array('pl_desc','like', "%" . $search_desc . "%");
|
||
|
}
|
||
|
|
||
|
|
||
|
$points_model = model('points');
|
||
|
$list_log = $points_model->getPointslogList($condition, 10, '*', '');
|
||
|
|
||
|
View::assign('pointslog', $list_log);
|
||
|
View::assign('show_page', $points_model->page_info->render());
|
||
|
$this->setAdminCurItem('index');
|
||
|
return View::fetch();
|
||
|
}
|
||
|
}
|
||
|
//积分规则设置
|
||
|
public function setting(){
|
||
|
$config_model = model('config');
|
||
|
if (request()->isPost()) {
|
||
|
$update_array = array();
|
||
|
$update_array['points_reg'] = intval(input('post.points_reg'));
|
||
|
$update_array['points_login'] = intval(input('post.points_login'));
|
||
|
$update_array['points_comments'] = intval(input('post.points_comments'));
|
||
|
$update_array['points_orderrate'] = intval(input('post.points_orderrate'));
|
||
|
$update_array['points_ordermax'] = intval(input('post.points_ordermax'));
|
||
|
$update_array['points_invite'] = intval(input('post.points_invite'));
|
||
|
$update_array['points_rebate'] = intval(input('post.points_rebate'));
|
||
|
|
||
|
|
||
|
$result = $config_model->editConfig($update_array);
|
||
|
if ($result === true) {
|
||
|
$this->success(lang('ds_common_save_succ'));
|
||
|
} else {
|
||
|
$this->error(lang('ds_common_save_fail'));
|
||
|
}
|
||
|
} else {
|
||
|
$list_setting = rkcache('config', true);
|
||
|
View::assign('list_setting', $list_setting);
|
||
|
$this->setAdminCurItem('setting');
|
||
|
return View::fetch('setting');
|
||
|
}
|
||
|
|
||
|
}
|
||
|
//积分明细查询
|
||
|
function pointslog() {
|
||
|
if (!request()->isPost()) {
|
||
|
return View::fetch();
|
||
|
} else {
|
||
|
$data = [
|
||
|
'member_name' => input('post.member_name'),
|
||
|
'points_type' => input('post.points_type'),
|
||
|
'points_num' => intval(input('post.points_num')),
|
||
|
'points_desc' => input('post.points_desc'),
|
||
|
];
|
||
|
$point_validate = ds_validate('point');
|
||
|
if (!$point_validate->scene('pointslog')->check($data)) {
|
||
|
$this->error($point_validate->getError());
|
||
|
}
|
||
|
$member_name = $data['member_name'];
|
||
|
$member_info = model('member')->getMemberInfo(array('member_name' => $member_name));
|
||
|
if (!is_array($member_info) || count($member_info) <= 0) {
|
||
|
$this->error(lang('admin_points_userrecord_error'));
|
||
|
}
|
||
|
if ($data['points_type'] == 2 && $data['points_num'] > $member_info['member_points']) {
|
||
|
$this->error(lang('admin_points_points_short_error') . $member_info['member_points']);
|
||
|
}
|
||
|
//积分数据记录
|
||
|
$insert_arr['pl_memberid'] = $member_info['member_id'];
|
||
|
$insert_arr['pl_membername'] = $member_info['member_name'];
|
||
|
if ($data['points_type'] == 2) {
|
||
|
$insert_arr['pl_points'] = -$data['points_num'];
|
||
|
} else {
|
||
|
$insert_arr['pl_points'] = $data['points_num'];
|
||
|
}
|
||
|
$insert_arr['pl_desc'] = $data['points_desc'];
|
||
|
$insert_arr['pl_adminname'] = session('admin_name');
|
||
|
|
||
|
$result = model('points')->savePointslog('system', $insert_arr);
|
||
|
if ($result) {
|
||
|
dsLayerOpenSuccess(lang('ds_common_op_succ'));
|
||
|
} else {
|
||
|
$this->error(lang('error'), 'Points/index');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function checkmember() {
|
||
|
$name = trim(input('param.name'));
|
||
|
if (!$name) {
|
||
|
exit(json_encode(array('id' => 0)));
|
||
|
}
|
||
|
$member_info = model('member')->getMemberInfo(array('member_name' => $name));
|
||
|
if (is_array($member_info) && count($member_info) > 0) {
|
||
|
echo json_encode(array('id' => $member_info['member_id'], 'name' => $member_info['member_name'], 'points' => $member_info['member_points']));
|
||
|
} else {
|
||
|
exit(json_encode(array('id' => 0)));
|
||
|
die;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 积分日志列表导出
|
||
|
*/
|
||
|
public function export_step1() {
|
||
|
$condition = array();
|
||
|
|
||
|
$mname = input('param.mname');
|
||
|
if (!empty($mname)) {
|
||
|
$condition[] = array('pl_membername','like', '%' . $mname . '%');
|
||
|
}
|
||
|
$aname = input('param.aname');
|
||
|
if (!empty($aname)) {
|
||
|
$condition[] = array('pl_adminname','like', '%' . $aname . '%');
|
||
|
}
|
||
|
|
||
|
$stage = input('get.stage');
|
||
|
if ($stage) {
|
||
|
$condition[] = array('pl_stage','=',trim($stage));
|
||
|
}
|
||
|
$stime = input('get.stime');
|
||
|
$etime = input('get.etime');
|
||
|
$if_start_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $stime);
|
||
|
$if_end_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $etime);
|
||
|
$start_unixtime = $if_start_time ? strtotime($stime) : null;
|
||
|
$end_unixtime = $if_end_time ? strtotime($etime) : null;
|
||
|
if ($start_unixtime || $end_unixtime) {
|
||
|
$condition[] = array('pl_addtime','between', array($start_unixtime, $end_unixtime));
|
||
|
}
|
||
|
$search_desc = trim(input('param.description'));
|
||
|
if (!empty($search_desc)) {
|
||
|
$condition[] = array('pl_desc','like', "%" . $search_desc . "%");
|
||
|
}
|
||
|
|
||
|
|
||
|
$points_model = model('points');
|
||
|
|
||
|
if (!is_numeric(input('param.page'))) {
|
||
|
$count = $points_model->getPointsCount($condition);
|
||
|
$array = array();
|
||
|
if ($count > self::EXPORT_SIZE) { //显示下载链接
|
||
|
$page = ceil($count / self::EXPORT_SIZE);
|
||
|
for ($i = 1; $i <= $page; $i++) {
|
||
|
$limit1 = ($i - 1) * self::EXPORT_SIZE + 1;
|
||
|
$limit2 = $i * self::EXPORT_SIZE > $count ? $count : $i * self::EXPORT_SIZE;
|
||
|
$array[$i] = $limit1 . ' ~ ' . $limit2;
|
||
|
}
|
||
|
View::assign('export_list', $array);
|
||
|
return View::fetch('/public/excel');
|
||
|
} else { //如果数量小,直接下载
|
||
|
$list_log = $points_model->getPointsLogList($condition, '', '*', self::EXPORT_SIZE);
|
||
|
$this->createExcel($list_log);
|
||
|
}
|
||
|
} else { //下载
|
||
|
$limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
|
||
|
$limit2 = self::EXPORT_SIZE;
|
||
|
$list_log = $points_model->getPointsLogList($condition, $limit2);
|
||
|
$this->createExcel($list_log);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 生成excel
|
||
|
*
|
||
|
* @param array $data
|
||
|
*/
|
||
|
private function createExcel($data = array()) {
|
||
|
Lang::load(base_path() .'admin/lang/'.config('lang.default_lang').'/export.lang.php');
|
||
|
$excel_obj = new \excel\Excel();
|
||
|
$excel_data = array();
|
||
|
//设置样式
|
||
|
$excel_obj->setStyle(array('id' => 's_title', 'Font' => array('FontName' => '宋体', 'Size' => '12', 'Bold' => '1')));
|
||
|
//header
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_member'));
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_system'));
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_point'));
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_time'));
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_jd'));
|
||
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_pi_ms'));
|
||
|
$state_cn = array(lang('admin_points_stage_regist'), lang('admin_points_stage_login'), lang('admin_points_stage_comments'), lang('admin_points_stage_order'), lang('admin_points_stage_system'), lang('admin_points_stage_pointorder'), lang('admin_points_stage_app'));
|
||
|
foreach ((array) $data as $k => $v) {
|
||
|
$tmp = array();
|
||
|
$tmp[] = array('data' => $v['pl_membername']);
|
||
|
$tmp[] = array('data' => $v['pl_adminname']);
|
||
|
$tmp[] = array('format' => 'Number', 'data' => ds_price_format($v['pl_points']));
|
||
|
$tmp[] = array('data' => date('Y-m-d H:i:s', $v['pl_addtime']));
|
||
|
$tmp[] = array('data' => str_replace(array('regist', 'login', 'comments', 'order', 'system', 'pointorder', 'app'), $state_cn, $v['pl_stage']));
|
||
|
$tmp[] = array('data' => $v['pl_desc']);
|
||
|
|
||
|
$excel_data[] = $tmp;
|
||
|
}
|
||
|
$excel_data = $excel_obj->charset($excel_data, CHARSET);
|
||
|
$excel_obj->addArray($excel_data);
|
||
|
$excel_obj->addWorksheet($excel_obj->charset(lang('exp_pi_jfmx'), CHARSET));
|
||
|
$excel_obj->generateXML($excel_obj->charset(lang('exp_pi_jfmx'), CHARSET) . input('param.page') . '-' . date('Y-m-d-H', TIMESTAMP));
|
||
|
}
|
||
|
|
||
|
protected function getAdminItemList() {
|
||
|
$menu_array = array(
|
||
|
array(
|
||
|
'name' => 'index',
|
||
|
'text' => '积分明细',
|
||
|
'url' => url('Points/index')
|
||
|
),
|
||
|
array(
|
||
|
'name' => 'pointslog',
|
||
|
'text' => '积分调整',
|
||
|
'url' => "javascript:dsLayerOpen('".url('Points/pointslog')."','积分调整')"
|
||
|
),
|
||
|
array(
|
||
|
'name' => 'setting',
|
||
|
'text' => '积分规则',
|
||
|
'url' => url('Points/setting')
|
||
|
),
|
||
|
);
|
||
|
return $menu_array;
|
||
|
}
|
||
|
|
||
|
}
|