www.lightcourse.com/app/admin/controller/Exppoints.php

257 lines
10 KiB
PHP

<?php
/**
* 经验值管理
*/
namespace app\admin\controller;
use think\facade\View;
use think\facade\Lang;
/**
* ============================================================================
* 联课教育商城系统
* ============================================================================
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
* 网站地址: http://www.o1h.cn
* ----------------------------------------------------------------------------
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
* 不允许对程序代码以任何形式任何目的的再发布。
* ============================================================================
* 控制器
*/
class Exppoints extends AdminControl
{
const EXPORT_SIZE = 5000;
public function initialize()
{
parent::initialize();
Lang::load(base_path() . 'admin/lang/'.config('lang.default_lang').'/membergrade.lang.php');
}
/**
* 设置经验值获取规则
*/
public function expsetting() {
$config_model = model('config');
if (request()->isPost()) {
$exp_arr = array();
$exp_arr['exp_login'] = intval(input('post.exp_login'));
$exp_arr['exp_comments'] = intval(input('post.exp_comments'));
$exp_arr['exp_orderrate'] = intval(input('post.exp_orderrate'));
$exp_arr['exp_ordermax'] = intval(input('post.exp_ordermax'));
$result = $config_model->editConfig(array('exppoints_rule' => serialize($exp_arr)));
if ($result === true) {
$this->log(lang('ds_edit') . lang('ds_exppoints_manage') . lang('ds_exppoints_setting'), 1);
dsLayerOpenSuccess(lang('ds_common_save_succ'));
} else {
$this->error(lang('ds_common_save_fail'));
}
} else {
$list_setting = $config_model->getOneConfigByCode('exppoints_rule');
$list_setting = unserialize($list_setting['value']);
View::assign('list_setting', $list_setting);
return View::fetch();
}
}
/**
* 经验值日志列表
*/
public function index(){
$where = array();
$search_mname = trim(input('param.mname'));
if(!empty($search_mname)){
$where[] = array('explog_membername','like',"%{$search_mname}%");
}
if (input('param.stage')){
$where[] = array('explog_stage','=',trim(input('param.stage')));
}
$stime = input('param.stime')?strtotime(input('param.stime')):0;
$etime = input('param.etime')?strtotime(input('param.etime')):0;
if ($stime > 0){
$where[]=array('explog_addtime','>=',$stime);
}
if ($etime > 0){
$etime=$etime+86399;
$where[]=array('explog_addtime','<=',$etime);
}
$search_desc = trim(input('param.description'));
if(!empty($search_desc)){
$where[] = array('explog_desc','like',"%".$search_desc."%");
}
//查询经验值日志列表
$exppoints_model = model('exppoints');
$list_log = $exppoints_model->getExppointslogList($where, '*', 20, 'explog_id desc');
//信息输出
View::assign('stage_arr',$exppoints_model->getStage());
View::assign('show_page',$exppoints_model->page_info->render());
View::assign('list_log',$list_log);
$this->setAdminCurItem('explog');
return View::fetch();
}
/**
* 经验值调整
*/
public function edit()
{
if (!request()->isPost()) {
return View::fetch();
} else {
$data = [
'member_name' => input('post.member_name'),
'exppoints_type' => input('post.exppoints_type'),
'exppoints_num' => intval(input('post.exppoints_num')),
'exppoints_desc' => input('post.exppoints_desc'),
];
if(empty($data['member_name']) || intval($data['exppoints_type'])<=0){
$this->error(lang('param_error'));
}
$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_exppoints_userrecord_error'));
}
if ($data['exppoints_type'] == 2 && $data['exppoints_num'] > $member_info['member_exppoints']) {
$this->error(lang('admin_exppoints_short_error') . $member_info['member_exppoints']);
}
//积分数据记录
$insert_arr['explog_memberid'] = $member_info['member_id'];
$insert_arr['explog_membername'] = $member_info['member_name'];
if ($data['exppoints_type'] == 2) {
$insert_arr['explog_points'] = -$data['exppoints_num'];
} else {
$insert_arr['explog_points'] = $data['exppoints_num'];
}
$insert_arr['explog_desc'] = $data['exppoints_desc'];
$result = model('exppoints')->saveExppointslog('system', $insert_arr);
if ($result) {
dsLayerOpenSuccess(lang('ds_common_op_succ'));
} else {
$this->error(lang('error'), 'Exppoints/index');
}
}
}
public function checkmember() {
$member_name = trim(input('param.member_name'));
if (!$member_name) {
exit(json_encode(array('member_id' => 0)));
}
$obj_member = model('member');
$member_info = $obj_member->getMemberInfo(array('member_name' => $member_name));
if (is_array($member_info) && count($member_info) > 0) {
echo json_encode(array('member_id' => $member_info['member_id'], 'member_name' => $member_info['member_name'], 'member_exppoints' => $member_info['member_exppoints']));
} else {
exit(json_encode(array('member_id' => 0)));
die;
}
}
/**
* 经验值日志列表导出
*/
public function export_step1(){
$where = array();
$search_mname = trim(input('param.mname'));
$where[] = array('explog_membername','like',"%{$search_mname}%");
if (input('param.stage')){
$where[] = array('explog_stage','=',trim(input('param.stage')));
}
$stime = input('param.stime')?strtotime(input('param.stime')):0;
$etime = input('param.etime')?strtotime(input('param.etime')):0;
if ($stime > 0 && $etime>0){
$where[] = array('explog_addtime','between',array($stime,$etime));
}elseif ($stime > 0){
$where[] = array('explog_addtime','>=',$stime);
}elseif ($etime > 0){
$where[] = array('explog_addtime','<=',$etime);
}
$search_desc = trim(input('param.description'));
$where[] = array('explog_desc','like',"%$search_desc%");
//查询经验值日志列表
$exppoints_model = model('exppoints');
$list_log = $exppoints_model->getExppointslogList($where, '*', self::EXPORT_SIZE, 'explog_id desc');
if (!is_numeric(input('param.page'))){
$count = $exppoints_model->getExppointslogCount($where);
$export_list = 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;
$export_list[$i] = $limit1.' ~ '.$limit2 ;
}
View::assign('export_list',$export_list);
return View::fetch('/public/excel');
}else{ //如果数量小,直接下载
$this->createExcel($list_log);
}
}else{ //下载
$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'=>'会员名称');
$excel_data[0][] = array('styleid'=>'s_title','data'=>'经验值');
$excel_data[0][] = array('styleid'=>'s_title','data'=>'添加时间');
$excel_data[0][] = array('styleid'=>'s_title','data'=>'操作阶段');
$excel_data[0][] = array('styleid'=>'s_title','data'=>'描述');
$stage_arr = model('exppoints')->getStage();
foreach ((array)$data as $k=>$v){
$tmp = array();
$tmp[] = array('data'=>$v['explog_membername']);
$tmp[] = array('format'=>'Number','data'=>ds_price_format($v['explog_points']));
$tmp[] = array('data'=>date('Y-m-d H:i:s',$v['explog_addtime']));
$tmp[] = array('data'=>$stage_arr[$v['explog_stage']]);
$tmp[] = array('data'=>$v['explog_desc']);
$excel_data[] = $tmp;
}
$excel_data = $excel_obj->charset($excel_data,CHARSET);
$excel_obj->addArray($excel_data);
$excel_obj->addWorksheet($excel_obj->charset('经验值明细',CHARSET));
$excel_obj->generateXML($excel_obj->charset('经验值明细',CHARSET).input('param.page').'-'.date('Y-m-d-H',TIMESTAMP));
}
/**
* 获取卖家栏目列表,针对控制器下的栏目
*/
protected function getAdminItemList() {
$menu_array = array(
array(
'name' => 'explog',
'text' => '经验值明细',
'url' => url('Exppoints/index')
),
array(
'name' => 'expset',
'text' => '规则设置',
'url' => "javascript:dsLayerOpen('".url('Exppoints/expsetting')."','规则设置')"
),
array(
'name' => 'edit',
'text' => '调整经验值',
'url' => "javascript:dsLayerOpen('".url('Exppoints/edit')."','调整经验值')"
),
);
return $menu_array;
}
}