删除2.6

This commit is contained in:
liaofei 2019-08-28 14:42:24 +08:00
parent e4958fa252
commit 32dfc44d27
6337 changed files with 0 additions and 1331085 deletions

195
README.md
View File

@ -1,195 +0,0 @@
<p align="center">
<img src="https://images.gitee.com/uploads/images/2018/1214/151026_2299df23_892944.gif" />
</p>
<h1 align="center"> CRMEB客户管理+电商营销系统</h1>
<p align="center">
<a href="http://www.crmeb.com">
<img src="https://img.shields.io/badge/OfficialWebsite-CRMEB-yellow.svg" />
</a>
<a href="http://www.crmeb.com">
<img src="https://img.shields.io/badge/Licence-GPL3.0-green.svg?style=flat" />
</a>
<a href="http://www.crmeb.com">
<img src="https://img.shields.io/badge/Edition-2.6-blue.svg" />
</a>
<a href="https://gitee.com/ZhongBangKeJi/CRMEB/repository/archive/master.zip">
<img src="https://img.shields.io/badge/download-80m-red.svg" />
</a>
</p>
### 如果对您有帮助,您可以点右上角 "Star" 支持一下 谢谢!
### github地址
https://github.com/xazbkj/CRMEB
### 纯小程序版:
https://gitee.com/ZhongBangKeJi/CRMEB_WeChatMiniProgram
### 帮助文档:
https://help.crmeb.net/crmeb
### 论坛地址:
http://bbs.crmeb.net
QQ群: 710729856 <a target="_blank" href="//shang.qq.com/wpa/qunwpa?idkey=1794ec6e9fd6ac21bd6519d459d4495e824553693ab0a98a9899e61d68a494d0"><img border="0" src="//pub.idqqimg.com/wpa/images/group.png" alt="CRMEB微信开发四群" title="CRMEB微信开发四群"></a>
## 获得荣誉
![输入图片说明](https://images.gitee.com/uploads/images/2019/0805/111208_eb4fe823_892944.jpeg "WechatIMG2434.jpeg")
## 演示地址
演示站后台:[<a href='http://demo25.crmeb.net' target="_blank"> crmeb_v2.6 </a>]
<a href='http://demo25.crmeb.net' target="_blank">http://demo26.crmeb.net</a>
账号demo
密码crmeb.com
![输入图片说明](https://images.gitee.com/uploads/images/2019/0302/165543_801cf1e6_892944.jpeg "二维码.jpg")
## CRMEB推荐服务器配置
<table><tr><td>
入门级配置
```
CPU1核
内存1G
实例规格突发性能t5实例
带宽1M
系统CentOS 7.4 64位(推荐)
价格366元/年 933.3 元/三年
```
<a href="https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=dligum2z">查看服务器详情</a>
</td>
<td>
标准级配置
```
CPU2核
内存4G
实例规格突发性能t5实例
带宽2M
系统CentOS 7.4 64位(推荐)
价格936元/年 2386.8 元/三年
```
<a href="https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=dligum2z">查看服务器详情</a>
</td></tr></table>
## 项目介绍
基于ThinkPhp5.0+Vue+EasyWeChat 开发的一套CRMEB新零售商城系统
CRMEB系统就是集客户关系管理+营销电商系统能够真正帮助企业基于微信公众号、小程序、wap、pc、app等实现会员管理、数据分析,精准营销的电子商务管理系统。可满足企业新零售、批发、分销、预约、O2O、多店等各种业务需求
CRMEB的优势:快速积累客户、会员数据分析、智能转化客户、有效提高销售、会员维护;
## 技术亮点
~~~
1.后台应用form-builder PHP快速生成现代化表单
2.前端以Vue + RequireJS模块化开发
3.PHPExcel数据导出,导出表格更加美观,可视;
4.EasyWeChat部署微信开发,微信接入更加快捷,简单;
5.后台应用ECharts实现完善的数据统计和分析
6.内部预留事件钩子,方面用户二次开发;
7.后台多任务窗口化操作界面;
8.内置强大灵活的权限管理;
9.内置组合数据,系统配置,管理碎片化数据;
10.客户端完善的交互效果和动画;
11.对接公众号和小程序,并且数据同步;
12.内置客服系统;
13.高频数据缓存;
14.数据备份和恢复
15.一键安装;
~~~
## 功能
1.商品: 能够对商品的状态分类管理 (出售中、待上架、库存中、已售馨、库存警戒、回收站)、添加产品、添加商品分类等功能
2.会员:站内会员的管理 (发放优惠劵、发通知、发图文消息、增加余额、会员行为详情)、站内通知 、微信端用户管理 (微信用
户的管理、分组、行为观察、添加标签) 等功能
3.营销:能够管理优惠的发放和制作、用户积分的统计使用情况、秒杀产品的管理等
4.财务:能够对用户的消费、充值、返佣的记录
5.订单:能够完成用户的订单管理(发货、订单详情、修改订单、订单备注、订单记录、订单退款) 、售后服务 (评论的回复与删除)
6.分销:后台有分销统计管理,分销可以设置人人分销和指定人分销,也可以自己稍微开发一下修改规则,例如下单后成为分销等
7.数据统计图表统计分析(财务统计、产品统计、会员统计、营销统计、分销统计、交易统计等)
8.设置:能够完成管理员对网站的商品资料(添加大类、添加小类、商品添加、属性快速生成、商品审查)、商品交易(外理订单、发货查询)、会员管理(会员审查)、操作管理(管理员添加、管理员审查、管理员退出)、系统配置、后台通知等功能
9.内容:管理文章分类 (添加分类、删除分类、修改分类) 、 管理文章
10.维护:查看系统日志、文件变动效验、刷新网站缓存、在线更新系统、清除数据、文件管理等功能
11.权限管理:可以创建不同身份,不同管理员,同一个管理员可以拥有多重身份,权限可以控制到每一个控制器函数,例如:张三
1.可以控制他可以查看产品,但不能编辑产品;
2.可以添加产品,但不能删除产品;
3.可以查看用户但不能给用户发信息、加积分、开通分销等等;
。。。灵活应用,权限想怎么配就怎么配
## 付费版
淘宝超值版:
CRMEB微信公众号小程序打通v2.6版:除了以上功能还带砍价、拼团功能,永久免费升级提供升级包
还有定制开发服务例如预约系统、O2O、付费阅读、多店版、多商家版
### 详情[<a href='https://s.click.taobao.com/W7hVkLw' target="_blank"> 进入淘宝 </a>]
[![输入图片说明](https://images.gitee.com/uploads/images/2019/0122/114739_a48f5bfd_892944.gif "tasheng jo(1).gif")](https://s.click.taobao.com/W7hVkLw)
官网线下定制服务版http://www.crmeb.com
## 用法
下载:
```
Git clone https://gitee.com/ZhongBangKeJi/CRMEB.git
```
小程序前端目录view/crmebNewUI
## 目录结构
目录结构[查看](http://help.crmeb.net/1039499)
## 系统组件开源项目
#### form-builder
tp5 PHP表单生成器快速生成现代化的form表单。包含复选框、单选框、输入框、下拉选择框等元素以及,省市区三级联动,时间选择,日期选择,颜色选择,文件/图片上传等功能。
form-builder : https://github.com/xaboy/form-builder
## 特别鸣谢
感谢以下的项目,排名不分先后
ThinkPHPhttp://www.thinkphp.cn
Bootstraphttp://getbootstrap.com
jQueryhttp://jquery.com
iViewhttps://www.iviewui.com
Vuehttps://cn.vuejs.org/
font-awesome https://fontawesome.com/?from=io
requirejs http://requirejs.org/
umeditorhttp://ueditor.baidu.com/website/umeditor.html
版权信息
CRMEB v2.6.* 遵循GPL3.0开源协议发布,并提供免费使用。
本项目包含的第三方源码和二进制文件之版权信息另行标注。
版权所有Copyright © 2017-2019 by CRMEB (http://www.crmeb.com)
All rights reserved。

View File

@ -1,119 +0,0 @@
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 流年 <liu21st@gmail.com>
// +----------------------------------------------------------------------
// 应用公共文件
/**
* 格式化属性
* @param $arr
* @return array
*/
function attrFormat($arr){
$data = [];
$res = [];
if(count($arr) > 1){
for ($i=0; $i < count($arr)-1; $i++) {
if($i == 0) $data = $arr[$i]['detail'];
//替代变量1
$rep1 = [];
foreach ($data as $v) {
foreach ($arr[$i+1]['detail'] as $g) {
//替代变量2
$rep2 = ($i!=0?'':$arr[$i]['value']."_").$v."-".$arr[$i+1]['value']."_".$g;
$tmp[] = $rep2;
if($i==count($arr)-2){
foreach (explode('-', $rep2) as $k => $h) {
//替代变量3
$rep3 = explode('_', $h);
//替代变量4
$rep4['detail'][$rep3[0]] = isset($rep3[1]) ? $rep3[1] : '';
}
$res[] = $rep4;
}
}
}
$data = isset($tmp) ? $tmp : [];
}
}else{
$dataArr = [];
foreach ($arr as $k=>$v){
foreach ($v['detail'] as $kk=>$vv){
$dataArr[$kk] = $v['value'].'_'.$vv;
$res[$kk]['detail'][$v['value']] = $vv;
}
}
$data[] = implode('-',$dataArr);
}
return [$data,$res];
}
/**
* 格式化月份
* @param string $time
* @param int $ceil
* @return array
*/
function getMonth($time='',$ceil=0){
if(empty($time)){
$firstday = date("Y-m-01",time());
$lastday = date("Y-m-d",strtotime("$firstday +1 month -1 day"));
}else if($time=='n'){
if($ceil!=0)
$season = ceil(date('n') /3)-$ceil;
else
$season = ceil(date('n') /3);
$firstday=date('Y-m-01',mktime(0,0,0,($season - 1) *3 +1,1,date('Y')));
$lastday=date('Y-m-t',mktime(0,0,0,$season * 3,1,date('Y')));
}else if($time=='y'){
$firstday=date('Y-01-01');
$lastday=date('Y-12-31');
}else if($time=='h'){
$firstday = date('Y-m-d', strtotime('this week +'.$ceil.' day')) . ' 00:00:00';
$lastday = date('Y-m-d', strtotime('this week +'.($ceil+1).' day')) . ' 23:59:59';
}
return array($firstday,$lastday);
}
/**删除目录下所有文件
* @param $path 目录或者文件路径
* @param string $ext
* @return bool
*/
function clearfile($path,$ext = '*.log')
{
$files = (array) glob($path.DS.'*');
foreach ($files as $path) {
if (is_dir($path)) {
$matches = glob($path . '/'.$ext);
if (is_array($matches)) {
array_map('unlink', $matches);
}
rmdir($path);
} else {
unlink($path);
}
}
return true;
}
/**获取当前类方法
* @param $class
* @return array
*/
function get_this_class_methods($class,$unarray = []) {
$arrayall = get_class_methods($class);
if ($parent_class = get_parent_class($class)) {
$arrayparent = get_class_methods($parent_class);
$arraynow = array_diff($arrayall, $arrayparent);//去除父级的
} else {
$arraynow = $arrayall;
}
return array_diff($arraynow, $unarray);//去除无用的
}

View File

@ -1,37 +0,0 @@
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006~2016 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
// +----------------------------------------------------------------------
return [
'session' => [
// SESSION 前缀
'prefix' => 'admin',
// 驱动方式 支持redis memcache memcached
'type' => '',
// 是否自动开启 SESSION
'auto_start' => true,
],
'app_debug' => true,
// 应用Trace
'app_trace' => false,
'exception_handle' => app\admin\controller\AdminException::class,
'empty_controller' =>'Index',
// 视图输出字符串内容替换
'view_replace_str' => [
'{__PUBLIC_PATH}' => PUBILC_PATH, //public 目录
'{__STATIC_PATH}' => PUBILC_PATH.'static/', //全局静态目录
'{__PLUG_PATH}' => PUBILC_PATH.'static/plug/', //全局静态插件
'{__ADMIN_PATH}' => PUBILC_PATH.'system/', //后台目录
'{__FRAME_PATH}' => PUBILC_PATH.'system/frame/', //后台框架
'{__MODULE_PATH}' => PUBILC_PATH.'system/module/',//后台模块
]
];

View File

@ -1,57 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2018/01/10
*/
namespace app\admin\controller;
use Exception;
use service\JsonService;
use think\exception\Handle;
use think\exception\HttpException;
use think\exception\ValidateException;
use think\Log;
use think\Request;
use think\Url;
/**后台异常处理
* Class AdminException
* @package app\admin\controller
*/
class AdminException extends Handle
{
public function render(Exception $e){
// 参数验证错误
if ($e instanceof ValidateException) {
return json($e->getError(), 422);
}
// 请求异常
if ($e instanceof HttpException && request()->isAjax()) {
return JsonService::fail('系统错误');
}else{
if(config("app_debug")==true){ //如是开启调试,就走原来的方法
return parent::render($e);
}else {
$title = '系统错误';
$msg = addslashes($e->getMessage());
$this->recordErrorLog($e);
exit(view('public/500', compact('title', 'msg'))->getContent());
}
}
}
/*
* 将异常写入日志
*/
private function recordErrorLog(Exception $e) {
Log::init([
'type' => 'File',
'path' => LOG_PATH,
'level' => ['error'],
]);
Log::record($e->getMessage(), 'error');
}
}

View File

@ -1,111 +0,0 @@
<?php
namespace app\admin\controller;
use app\admin\model\ump\StoreBargain;
use app\admin\model\ump\StoreCombination;
use app\admin\model\ump\StoreSeckill;
use basic\SystemBasic;
use app\admin\model\store\StoreProduct;
use service\JsonService;
use service\UtilService;
/**
* 异步请求控制器
* Class AuthApi
* @package app\admin\controller
*/
class AuthApi extends SystemBasic
{
/**
* 获取砍价产品曲线图数据
*/
public function get_echarts_product($type='',$data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::getChatrdata($type,$data));
if($model) return JsonService::successful(StoreSeckill::getChatrdata($type,$data));
}
/**
* 获取销量
*/
public function get_echarts_maxlist($data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::getMaxList(compact('data')));
if($model) return JsonService::successful(StoreSeckill::getMaxList(compact('data')));
}
/**
* 获取利润
*/
public function get_echarts_profity($data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::ProfityTop10(compact('data')));
if($model) return JsonService::successful(StoreSeckill::ProfityTop10(compact('data')));
}
/**
* 获取补货的砍价产品
*/
public function getLackList($model = 0){
$where = UtilService::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getLackList($where));
if($model) return JsonService::successlayui(StoreSeckill::getLackList($where));
}
/**
* 获取砍价产品的评论
*/
public function getnegativelist($model = 0){
$where = UtilService::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getNegativeList($where));
if($model) return JsonService::successlayui(StoreSeckill::getNegativeList($where));
}
/**
* 获取砍价产品的退货
*/
public function get_bargain_refund_list($model = 0){
$where = UtilService::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getBargainRefundList($where));
if($model) return JsonService::successlayui(StoreSeckill::getBargainRefundList($where));
}
/**
* 修改拼团状态
* @param $status
* @param int $idd
*/
public function set_combination_status($status,$id = 0){
if(!$id) return JsonService::fail('参数错误');
$res = StoreCombination::edit(['is_show'=>$status],$id);
if($res) return JsonService::successful('修改成功');
else return JsonService::fail('修改失败');
}
/**
* 修改砍价状态
* @param $status
* @param int $id
*/
public function set_bargain_status($status,$id = 0){
if(!$id) return JsonService::fail('参数错误');
$res = StoreBargain::edit(['status'=>$status],$id);
if($res) return JsonService::successful('修改成功');
else return JsonService::fail('修改失败');
}
/**
* 修改秒杀产品状态
* @param $status
* @param int $id
*/
public function set_seckill_status($status,$id = 0){
if(!$id) return JsonService::fail('参数错误');
$res = StoreSeckill::edit(['status'=>$status],$id);
if($res) return JsonService::successful('修改成功');
else return JsonService::fail('修改失败');
}
}

View File

@ -1,88 +0,0 @@
<?php
namespace app\admin\controller;
use app\admin\model\system\SystemAdmin;
use app\admin\model\system\SystemMenus;
use app\admin\model\system\SystemRole;
use behavior\admin\SystemBehavior;
use service\HookService;
use think\Url;
/**
* 基类 所有控制器继承的类
* Class AuthController
* @package app\admin\controller
*/
class AuthController extends SystemBasic
{
/**
* 当前登陆管理员信息
* @var
*/
protected $adminInfo;
/**
* 当前登陆管理员ID
* @var
*/
protected $adminId;
/**
* 当前管理员权限
* @var array
*/
protected $auth = [];
protected $skipLogController = ['index','common'];
protected function _initialize()
{
parent::_initialize();
if(!SystemAdmin::hasActiveAdmin()) return $this->redirect('Login/index');
try{
$adminInfo = SystemAdmin::activeAdminInfoOrFail();
}catch (\Exception $e){
return $this->failed(SystemAdmin::getErrorInfo($e->getMessage()),Url::build('Login/index'));
}
$this->adminInfo = $adminInfo;
$this->adminId = $adminInfo['id'];
$this->getActiveAdminInfo();
$this->auth = SystemAdmin::activeAdminAuthOrFail();
$this->adminInfo->level === 0 || $this->checkAuth();
$this->assign('_admin',$this->adminInfo);
HookService::listen('admin_visit',$this->adminInfo,'system',false,SystemBehavior::class);
}
protected function checkAuth($action = null,$controller = null,$module = null,array $route = [])
{
static $allAuth = null;
if($allAuth === null) $allAuth = SystemRole::getAllAuth();
if($module === null) $module = $this->request->module();
if($controller === null) $controller = $this->request->controller();
if($action === null) $action = $this->request->action();
if(!count($route)) $route = $this->request->route();
if(in_array(strtolower($controller),$this->skipLogController,true)) return true;
$nowAuthName = SystemMenus::getAuthName($action,$controller,$module,$route);
$baseNowAuthName = SystemMenus::getAuthName($action,$controller,$module,[]);
if((in_array($nowAuthName,$allAuth) && !in_array($nowAuthName,$this->auth)) || (in_array($baseNowAuthName,$allAuth) && !in_array($baseNowAuthName,$this->auth)))
exit($this->failed('没有权限访问!'));
return true;
}
/**
* 获得当前用户最新信息
* @return SystemAdmin
*/
protected function getActiveAdminInfo()
{
$adminId = $this->adminId;
$adminInfo = SystemAdmin::getValidAdminInfoOrFail($adminId);
if(!$adminInfo) $this->failed(SystemAdmin::getErrorInfo('请登陆!'));
$this->adminInfo = $adminInfo;
SystemAdmin::setLoginInfo($adminInfo);
return $adminInfo;
}
}

View File

@ -1,28 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/12/07
*/
namespace app\admin\controller;
use service\UtilService;
class Common extends AuthController
{
public function rmPublicResource($url)
{
if(strpos($url,'public') !== false){
$res = UtilService::rmPublicResource($url);
}else{
$url = ltrim('public'.$url);
$res = UtilService::rmPublicResource($url);
}
if($res->status)
return $this->successful('删除成功!');
else
return $this->failed($res->msg);
}
}

View File

@ -1,583 +0,0 @@
<?php
namespace app\admin\controller;
use app\admin\model\store\StoreProduct;
use app\admin\model\system\SystemConfig;
use app\admin\model\system\SystemMenus;
use app\admin\model\system\SystemRole;
use app\admin\model\order\StoreOrder as StoreOrderModel;//订单
use app\admin\model\user\UserExtract as UserExtractModel;//分销
use app\admin\model\user\User as UserModel;//用户
use app\admin\model\store\StoreProductReply as StoreProductReplyModel;//评论
use app\admin\model\store\StoreProduct as ProductModel;//产品
use app\core\util\SystemConfigService;
use FormBuilder\Json;
use think\DB;
/**
* 首页控制器
* Class Index
* @package app\admin\controller
*
*/
class Index extends AuthController
{
public function index()
{
//获取当前登录后台的管理员信息
$adminInfo = $this->adminInfo->toArray();
$roles = explode(',',$adminInfo['roles']);
$site_logo = SystemConfig::getOneConfig('menu_name','site_logo')->toArray();
$this->assign([
'menuList'=>SystemMenus::menuList(),
'site_logo'=>json_decode($site_logo['value'],true),
'new_order_audio_link'=>str_replace('\\','/',SystemConfigService::get('new_order_audio_link')),
'role_name'=>SystemRole::where('id',$roles[0])->field('role_name')->find()
]);
return $this->fetch();
}
//后台首页内容
public function main()
{
/*首页第一行统计*/
$now_month = strtotime(date('Y-m'));//本月
$pre_month = strtotime(date('Y-m',strtotime('-1 month')));//上月
$now_day = strtotime(date('Y-m-d'));//今日
$pre_day = strtotime(date('Y-m-d',strtotime('-1 day')));//昨天时间戳
$beforyester_day = strtotime(date('Y-m-d',strtotime('-2 day')));//前天时间戳
//待发货数量
$topData['orderDeliveryNum'] = StoreOrderModel::where('status',0)
->where('paid',1)
->where('refund_status',0)
->count();
//退换货订单数
$topData['orderRefundNum'] = StoreOrderModel::where('paid',1)
->where('refund_status','IN','1')
->count();
//库存预警
$replenishment_num = SystemConfig::getValue('store_stock') > 0 ? SystemConfig::getValue('store_stock') : 20;//库存预警界限
$topData['stockProduct'] = StoreProduct::where('stock','<=',$replenishment_num)->where('is_show',1)->where('is_del',0)->count();
//待处理提现
$topData['treatedExtract'] = UserExtractModel::where('status',0)->count();
//订单数->昨日
$now_day_order_p = StoreOrderModel::where('paid',1)->whereTime('pay_time','yesterday')->count();
$pre_day_order_p = StoreOrderModel::where('paid',1)->where('pay_time','gt',$pre_day)->where('pay_time','lt',$now_day)->count();
$first_line['d_num'] = [
'data' => $now_day_order_p ? $now_day_order_p : 0,
'percent' => abs($now_day_order_p - $pre_day_order_p),
'is_plus' => $now_day_order_p - $pre_day_order_p > 0 ? 1 : ($now_day_order_p - $pre_day_order_p == 0 ? -1 : 0)
];
//交易额->昨天
$now_month_order_p = StoreOrderModel::where('paid',1)->whereTime('pay_time','yesterday')->sum('pay_price');
$pre_month_order_p = StoreOrderModel::where('paid',1)->where('pay_time','gt',$beforyester_day)->where('pay_time','lt',$pre_day)->sum('pay_price');
$first_line['d_price'] = [
'data' => $now_month_order_p > 0 ? $now_month_order_p : 0,
'percent' => abs($now_month_order_p - $pre_month_order_p),
'is_plus' => $now_month_order_p - $pre_month_order_p > 0 ? 1 : ($now_month_order_p - $pre_month_order_p == 0 ? -1 : 0)
];
//交易额->月
$now_month_order_p = StoreOrderModel::where('paid',1)->whereTime('pay_time','month')->sum('pay_price');
$pre_month_order_p = StoreOrderModel::where('paid',1)->where('pay_time','gt',$pre_month)->where('pay_time','lt',$now_month)->value('sum(pay_price)');
$first_line['m_price'] = [
'data' => $now_month_order_p > 0 ? $now_month_order_p : 0,
'percent' => abs($now_month_order_p - $pre_month_order_p),
'is_plus' => $now_month_order_p - $pre_month_order_p > 0 ? 1 : ($now_month_order_p - $pre_month_order_p == 0 ? -1 : 0)
];
//新粉丝->日
$now_day_user = DB::name('User')->where('add_time','gt',$now_day)->count();
$pre_day_user = DB::name('User')->where('add_time','gt',$pre_day)->where('add_time','lt',$now_day)->count();
$pre_day_user = $pre_day_user ? $pre_day_user : 0;
$first_line['day'] = [
'data' => $now_day_user ? $now_day_user : 0,
'percent' => abs($now_day_user - $pre_day_user),
'is_plus' => $now_day_user - $pre_day_user > 0 ? 1 : ($now_day_user - $pre_day_user == 0 ? -1 : 0)
];
//新粉丝->月
$now_month_user = DB::name('User')->where('add_time','gt',$now_month)->count();
$pre_month_user = DB::name('User')->where('add_time','gt',$pre_month)->where('add_time','lt',$now_month)->count();
$first_line['month'] = [
'data' => $now_month_user ? $now_month_user : 0,
'percent' => abs($now_month_user - $pre_month_user),
'is_plus' => $now_month_user - $pre_month_user > 0 ? 1 : ($now_month_user - $pre_month_user == 0 ? -1 : 0)
];
//本月订单总数
$now_order_info_c = StoreOrderModel::where('add_time','gt',$now_month)->count();
$pre_order_info_c = StoreOrderModel::where('add_time','gt',$pre_month)->where('add_time','lt',$now_month)->count();
$order_info['first'] = [
'data' => $now_order_info_c ? $now_order_info_c : 0,
'percent' => abs($now_order_info_c - $pre_order_info_c),
'is_plus' => $now_order_info_c - $pre_order_info_c > 0 ? 1 : ($now_order_info_c - $pre_order_info_c == 0 ? -1 : 0)
];
//上月订单总数
$second_now_month = strtotime(date('Y-m',strtotime('-1 month')));
$second_pre_month = strtotime(date('Y-m',strtotime('-2 month')));
$now_order_info_c = StoreOrderModel::where('add_time','gt',$pre_month)->where('add_time','lt',$now_month)->count();
$pre_order_info_c = StoreOrderModel::where('add_time','gt',$second_pre_month)->where('add_time','lt',$second_now_month)->count();
$order_info["second"] = [
'data' => $now_order_info_c ? $now_order_info_c : 0,
'percent' => abs($now_order_info_c - $pre_order_info_c),
'is_plus' => $now_order_info_c - $pre_order_info_c > 0 ? 1 : ($now_order_info_c - $pre_order_info_c == 0 ? -1 : 0)
];
$second_line['order_info'] = $order_info;
$this->assign([
'first_line' => $first_line,
'second_line' => $second_line,
'topData' => $topData,
]);
return $this->fetch();
}
/**
* 订单图表
*/
public function orderchart(){
header('Content-type:text/json');
$cycle = $this->request->param('cycle')?:'thirtyday';//默认30天
$datalist = [];
switch ($cycle){
case 'thirtyday':
$datebefor = date('Y-m-d',strtotime('-30 day'));
$dateafter = date('Y-m-d');
//上期
$pre_datebefor = date('Y-m-d',strtotime('-60 day'));
$pre_dateafter = date('Y-m-d',strtotime('-30 day'));
for($i=-30;$i < 0;$i++){
$datalist[date('m-d',strtotime($i.' day'))] = date('m-d',strtotime($i.' day'));
}
$order_list = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("FROM_UNIXTIME(add_time,'%m-%d') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m%d')")
->order('add_time asc')
->select()->toArray();
if(empty($order_list)) return Json::fail('无数据');
foreach ($order_list as $k=>&$v){
$order_list[$v['day']] = $v;
}
$cycle_list = [];
foreach ($datalist as $dk=>$dd){
if(!empty($order_list[$dd])){
$cycle_list[$dd] = $order_list[$dd];
}else{
$cycle_list[$dd] = ['count'=>0,'day'=>$dd,'price'=>''];
}
}
$chartdata = [];
$data = [];//临时
$chartdata['yAxis']['maxnum'] = 0;//最大值数量
$chartdata['yAxis']['maxprice'] = 0;//最大值金额
foreach ($cycle_list as $k=>$v){
$data['day'][] = $v['day'];
$data['count'][] = $v['count'];
$data['price'][] = round($v['price'],2);
if($chartdata['yAxis']['maxnum'] < $v['count'])
$chartdata['yAxis']['maxnum'] = $v['count'];//日最大订单数
if($chartdata['yAxis']['maxprice'] < $v['price'])
$chartdata['yAxis']['maxprice'] = $v['price'];//日最大金额
}
$chartdata['legend'] = ['订单金额','订单数'];//分类
$chartdata['xAxis'] = $data['day'];//X轴值
//,'itemStyle'=>$series
$series= ['normal'=>['label'=>['show'=>true,'position'=>'top']]];
$chartdata['series'][] = ['name'=>$chartdata['legend'][0],'type'=>'bar','itemStyle'=>$series,'data'=>$data['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][1],'type'=>'bar','itemStyle'=>$series,'data'=>$data['count']];//分类2值
//统计总数上期
$pre_total = StoreOrderModel::where('add_time','between time',[$pre_datebefor,$pre_dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($pre_total){
$chartdata['pre_cycle']['count'] = [
'data' => $pre_total['count']? : 0
];
$chartdata['pre_cycle']['price'] = [
'data' => $pre_total['price']? : 0
];
}
//统计总数
$total = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($total){
$cha_count = intval($pre_total['count']) - intval($total['count']);
$pre_total['count'] = $pre_total['count']==0 ? 1 : $pre_total['count'];
$chartdata['cycle']['count'] = [
'data' => $total['count']? : 0,
'percent' => round((abs($cha_count)/intval($pre_total['count'])*100),2),
'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
];
$cha_price = round($pre_total['price'],2) - round($total['price'],2);
$pre_total['price'] = $pre_total['price']==0 ? 1 : $pre_total['price'];
$chartdata['cycle']['price'] = [
'data' => $total['price']? : 0,
'percent' => round(abs($cha_price)/$pre_total['price']*100,2),
'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
];
}
return Json::succ('ok',$chartdata);
break;
case 'week':
$weekarray=array(['周日'],['周一'],['周二'],['周三'],['周四'],['周五'],['周六']);
$datebefor = date('Y-m-d',strtotime('-1 week Monday'));
$dateafter = date('Y-m-d',strtotime('-1 week Sunday'));
$order_list = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("FROM_UNIXTIME(add_time,'%w') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理
$new_order_list = [];
foreach ($order_list as $k=>$v){
$new_order_list[$v['day']] = $v;
}
$now_datebefor = date('Y-m-d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600));
$now_dateafter = date('Y-m-d',strtotime("+1 day"));
$now_order_list = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("FROM_UNIXTIME(add_time,'%w') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理 key 变为当前值
$new_now_order_list = [];
foreach ($now_order_list as $k=>$v){
$new_now_order_list[$v['day']] = $v;
}
foreach ($weekarray as $dk=>$dd){
if(!empty($new_order_list[$dk])){
$weekarray[$dk]['pre'] = $new_order_list[$dk];
}else{
$weekarray[$dk]['pre'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
if(!empty($new_now_order_list[$dk])){
$weekarray[$dk]['now'] = $new_now_order_list[$dk];
}else{
$weekarray[$dk]['now'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
}
$chartdata = [];
$data = [];//临时
$chartdata['yAxis']['maxnum'] = 0;//最大值数量
$chartdata['yAxis']['maxprice'] = 0;//最大值金额
foreach ($weekarray as $k=>$v){
$data['day'][] = $v[0];
$data['pre']['count'][] = $v['pre']['count'];
$data['pre']['price'][] = round($v['pre']['price'],2);
$data['now']['count'][] = $v['now']['count'];
$data['now']['price'][] = round($v['now']['price'],2);
if($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']){
$chartdata['yAxis']['maxnum'] = $v['pre']['count']>$v['now']['count']?$v['pre']['count']:$v['now']['count'];//日最大订单数
}
if($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']){
$chartdata['yAxis']['maxprice'] = $v['pre']['price']>$v['now']['price']?$v['pre']['price']:$v['now']['price'];//日最大金额
}
}
$chartdata['legend'] = ['上周金额','本周金额','上周订单数','本周订单数'];//分类
$chartdata['xAxis'] = $data['day'];//X轴值
//,'itemStyle'=>$series
$series= ['normal'=>['label'=>['show'=>true,'position'=>'top']]];
$chartdata['series'][] = ['name'=>$chartdata['legend'][0],'type'=>'bar','itemStyle'=>$series,'data'=>$data['pre']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][1],'type'=>'bar','itemStyle'=>$series,'data'=>$data['now']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][2],'type'=>'line','itemStyle'=>$series,'data'=>$data['pre']['count']];//分类2值
$chartdata['series'][] = ['name'=>$chartdata['legend'][3],'type'=>'line','itemStyle'=>$series,'data'=>$data['now']['count']];//分类2值
//统计总数上期
$pre_total = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($pre_total){
$chartdata['pre_cycle']['count'] = [
'data' => $pre_total['count']? : 0
];
$chartdata['pre_cycle']['price'] = [
'data' => $pre_total['price']? : 0
];
}
//统计总数
$total = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($total){
$cha_count = intval($pre_total['count']) - intval($total['count']);
$pre_total['count'] = $pre_total['count']==0 ? 1 : $pre_total['count'];
$chartdata['cycle']['count'] = [
'data' => $total['count']? : 0,
'percent' => round((abs($cha_count)/intval($pre_total['count'])*100),2),
'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
];
$cha_price = round($pre_total['price'],2) - round($total['price'],2);
$pre_total['price'] = $pre_total['price']==0 ? 1 : $pre_total['price'];
$chartdata['cycle']['price'] = [
'data' => $total['price']? : 0,
'percent' => round(abs($cha_price)/$pre_total['price']*100,2),
'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
];
}
return Json::succ('ok',$chartdata);
break;
case 'month':
$weekarray=array('01'=>['1'],'02'=>['2'],'03'=>['3'],'04'=>['4'],'05'=>['5'],'06'=>['6'],'07'=>['7'],'08'=>['8'],'09'=>['9'],'10'=>['10'],'11'=>['11'],'12'=>['12'],'13'=>['13'],'14'=>['14'],'15'=>['15'],'16'=>['16'],'17'=>['17'],'18'=>['18'],'19'=>['19'],'20'=>['20'],'21'=>['21'],'22'=>['22'],'23'=>['23'],'24'=>['24'],'25'=>['25'],'26'=>['26'],'27'=>['27'],'28'=>['28'],'29'=>['29'],'30'=>['30'],'31'=>['31']);
$datebefor = date('Y-m-01',strtotime('-1 month'));
$dateafter = date('Y-m-d',strtotime(date('Y-m-01')));
$order_list = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("FROM_UNIXTIME(add_time,'%d') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理
$new_order_list = [];
foreach ($order_list as $k=>$v){
$new_order_list[$v['day']] = $v;
}
$now_datebefor = date('Y-m-01');
$now_dateafter = date('Y-m-d',strtotime("+1 day"));
$now_order_list = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("FROM_UNIXTIME(add_time,'%d') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理 key 变为当前值
$new_now_order_list = [];
foreach ($now_order_list as $k=>$v){
$new_now_order_list[$v['day']] = $v;
}
foreach ($weekarray as $dk=>$dd){
if(!empty($new_order_list[$dk])){
$weekarray[$dk]['pre'] = $new_order_list[$dk];
}else{
$weekarray[$dk]['pre'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
if(!empty($new_now_order_list[$dk])){
$weekarray[$dk]['now'] = $new_now_order_list[$dk];
}else{
$weekarray[$dk]['now'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
}
$chartdata = [];
$data = [];//临时
$chartdata['yAxis']['maxnum'] = 0;//最大值数量
$chartdata['yAxis']['maxprice'] = 0;//最大值金额
foreach ($weekarray as $k=>$v){
$data['day'][] = $v[0];
$data['pre']['count'][] = $v['pre']['count'];
$data['pre']['price'][] = round($v['pre']['price'],2);
$data['now']['count'][] = $v['now']['count'];
$data['now']['price'][] = round($v['now']['price'],2);
if($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']){
$chartdata['yAxis']['maxnum'] = $v['pre']['count']>$v['now']['count']?$v['pre']['count']:$v['now']['count'];//日最大订单数
}
if($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']){
$chartdata['yAxis']['maxprice'] = $v['pre']['price']>$v['now']['price']?$v['pre']['price']:$v['now']['price'];//日最大金额
}
}
$chartdata['legend'] = ['上月金额','本月金额','上月订单数','本月订单数'];//分类
$chartdata['xAxis'] = $data['day'];//X轴值
//,'itemStyle'=>$series
$series= ['normal'=>['label'=>['show'=>true,'position'=>'top']]];
$chartdata['series'][] = ['name'=>$chartdata['legend'][0],'type'=>'bar','itemStyle'=>$series,'data'=>$data['pre']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][1],'type'=>'bar','itemStyle'=>$series,'data'=>$data['now']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][2],'type'=>'line','itemStyle'=>$series,'data'=>$data['pre']['count']];//分类2值
$chartdata['series'][] = ['name'=>$chartdata['legend'][3],'type'=>'line','itemStyle'=>$series,'data'=>$data['now']['count']];//分类2值
//统计总数上期
$pre_total = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($pre_total){
$chartdata['pre_cycle']['count'] = [
'data' => $pre_total['count']? : 0
];
$chartdata['pre_cycle']['price'] = [
'data' => $pre_total['price']? : 0
];
}
//统计总数
$total = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($total){
$cha_count = intval($pre_total['count']) - intval($total['count']);
$pre_total['count'] = $pre_total['count']==0 ? 1 : $pre_total['count'];
$chartdata['cycle']['count'] = [
'data' => $total['count']? : 0,
'percent' => round((abs($cha_count)/intval($pre_total['count'])*100),2),
'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
];
$cha_price = round($pre_total['price'],2) - round($total['price'],2);
$pre_total['price'] = $pre_total['price']==0 ? 1 : $pre_total['price'];
$chartdata['cycle']['price'] = [
'data' => $total['price']? : 0,
'percent' => round(abs($cha_price)/$pre_total['price']*100,2),
'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
];
}
return Json::succ('ok',$chartdata);
break;
case 'year':
$weekarray=array('01'=>['一月'],'02'=>['二月'],'03'=>['三月'],'04'=>['四月'],'05'=>['五月'],'06'=>['六月'],'07'=>['七月'],'08'=>['八月'],'09'=>['九月'],'10'=>['十月'],'11'=>['十一月'],'12'=>['十二月']);
$datebefor = date('Y-01-01',strtotime('-1 year'));
$dateafter = date('Y-12-31',strtotime('-1 year'));
$order_list = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("FROM_UNIXTIME(add_time,'%m') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理
$new_order_list = [];
foreach ($order_list as $k=>$v){
$new_order_list[$v['day']] = $v;
}
$now_datebefor = date('Y-01-01');
$now_dateafter = date('Y-m-d');
$now_order_list = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("FROM_UNIXTIME(add_time,'%m') as day,count(*) as count,sum(pay_price) as price")
->group("FROM_UNIXTIME(add_time, '%Y%m')")
->order('add_time asc')
->select()->toArray();
//数据查询重新处理 key 变为当前值
$new_now_order_list = [];
foreach ($now_order_list as $k=>$v){
$new_now_order_list[$v['day']] = $v;
}
foreach ($weekarray as $dk=>$dd){
if(!empty($new_order_list[$dk])){
$weekarray[$dk]['pre'] = $new_order_list[$dk];
}else{
$weekarray[$dk]['pre'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
if(!empty($new_now_order_list[$dk])){
$weekarray[$dk]['now'] = $new_now_order_list[$dk];
}else{
$weekarray[$dk]['now'] = ['count'=>0,'day'=>$weekarray[$dk][0],'price'=>'0'];
}
}
$chartdata = [];
$data = [];//临时
$chartdata['yAxis']['maxnum'] = 0;//最大值数量
$chartdata['yAxis']['maxprice'] = 0;//最大值金额
foreach ($weekarray as $k=>$v){
$data['day'][] = $v[0];
$data['pre']['count'][] = $v['pre']['count'];
$data['pre']['price'][] = round($v['pre']['price'],2);
$data['now']['count'][] = $v['now']['count'];
$data['now']['price'][] = round($v['now']['price'],2);
if($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']){
$chartdata['yAxis']['maxnum'] = $v['pre']['count']>$v['now']['count']?$v['pre']['count']:$v['now']['count'];//日最大订单数
}
if($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']){
$chartdata['yAxis']['maxprice'] = $v['pre']['price']>$v['now']['price']?$v['pre']['price']:$v['now']['price'];//日最大金额
}
}
$chartdata['legend'] = ['去年金额','今年金额','去年订单数','今年订单数'];//分类
$chartdata['xAxis'] = $data['day'];//X轴值
//,'itemStyle'=>$series
$series= ['normal'=>['label'=>['show'=>true,'position'=>'top']]];
$chartdata['series'][] = ['name'=>$chartdata['legend'][0],'type'=>'bar','itemStyle'=>$series,'data'=>$data['pre']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][1],'type'=>'bar','itemStyle'=>$series,'data'=>$data['now']['price']];//分类1值
$chartdata['series'][] = ['name'=>$chartdata['legend'][2],'type'=>'line','itemStyle'=>$series,'data'=>$data['pre']['count']];//分类2值
$chartdata['series'][] = ['name'=>$chartdata['legend'][3],'type'=>'line','itemStyle'=>$series,'data'=>$data['now']['count']];//分类2值
//统计总数上期
$pre_total = StoreOrderModel::where('add_time','between time',[$datebefor,$dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($pre_total){
$chartdata['pre_cycle']['count'] = [
'data' => $pre_total['count']? : 0
];
$chartdata['pre_cycle']['price'] = [
'data' => $pre_total['price']? : 0
];
}
//统计总数
$total = StoreOrderModel::where('add_time','between time',[$now_datebefor,$now_dateafter])
->field("count(*) as count,sum(pay_price) as price")
->find();
if($total){
$cha_count = intval($pre_total['count']) - intval($total['count']);
$pre_total['count'] = $pre_total['count']==0 ? 1 : $pre_total['count'];
$chartdata['cycle']['count'] = [
'data' => $total['count']? : 0,
'percent' => round((abs($cha_count)/intval($pre_total['count'])*100),2),
'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
];
$cha_price = round($pre_total['price'],2) - round($total['price'],2);
$pre_total['price'] = $pre_total['price']==0 ? 1 : $pre_total['price'];
$chartdata['cycle']['price'] = [
'data' => $total['price']? : 0,
'percent' => round(abs($cha_price)/$pre_total['price']*100,2),
'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
];
}
return Json::succ('ok',$chartdata);
break;
default:
break;
}
}
/**
* 用户图表
*/
public function userchart(){
header('Content-type:text/json');
$starday = date('Y-m-d',strtotime('-30 day'));
$yesterday = date('Y-m-d');
$user_list = UserModel::where('add_time','between time',[$starday,$yesterday])
->field("FROM_UNIXTIME(add_time,'%m-%e') as day,count(*) as count")
->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
->order('add_time asc')
->select()->toArray();
$chartdata = [];
$data = [];
$chartdata['legend'] = ['用户数'];//分类
$chartdata['yAxis']['maxnum'] = 0;//最大值数量
$chartdata['xAxis'] = [date('m-d')];//X轴值
$chartdata['series'] = [0];//分类1值
if(!empty($user_list)) {
foreach ($user_list as $k=>$v){
$data['day'][] = $v['day'];
$data['count'][] = $v['count'];
if($chartdata['yAxis']['maxnum'] < $v['count'])
$chartdata['yAxis']['maxnum'] = $v['count'];
}
$chartdata['xAxis'] = $data['day'];//X轴值
$chartdata['series'] = $data['count'];//分类1值
}
return Json::succ('ok',$chartdata);
}
/**待办事统计
* @param Request|null $request
*/
public function Jnotice($newTime=30)
{
header('Content-type:text/json');
$data = [];
$data['ordernum'] = StoreOrderModel::statusByWhere(1)->count();//待发货
$replenishment_num = SystemConfig::getValue('store_stock') > 0 ? SystemConfig::getValue('store_stock') : 2;//库存预警界限
$data['inventory'] = ProductModel::where('stock','<=',$replenishment_num)->where('is_show',1)->where('is_del',0)->count();//库存
$data['commentnum'] = StoreProductReplyModel::where(['is_reply'=>0,'is_del'=>0])->count();//评论
$data['reflectnum'] = UserExtractModel::where('status',0)->count();;//提现
$data['msgcount'] = intval($data['ordernum'])+intval($data['inventory'])+intval($data['commentnum'])+intval($data['reflectnum']);
//新订单提醒
$data['newOrderId']=StoreOrderModel::statusByWhere(1)->where('is_remind',0)->column('order_id');
if(count($data['newOrderId'])) StoreOrderModel::where('order_id','in',$data['newOrderId'])->update(['is_remind'=>1]);
return Json::succ('ok',$data);
}
}

View File

@ -1,73 +0,0 @@
<?php
namespace app\admin\controller;
use app\admin\model\system\SystemAdmin;
use service\CacheService;
use service\UtilService;
use think\Request;
use think\Response;
use think\Session;
use think\Url;
/**
* 登录验证控制器
* Class Login
* @package app\admin\controller
*/
class Login extends SystemBasic
{
public function index()
{
return $this->fetch();
}
/**
* 登录验证 + 验证码验证
*/
public function verify(Request $request)
{
if(!$request->isPost()) return $this->failed('请登陆!');
list($account,$pwd,$verify) = UtilService::postMore([
'account','pwd','verify'
],$request,true);
//检验验证码
if(!captcha_check($verify)) return $this->failed('验证码错误,请重新输入');
$error = Session::get('login_error')?:['num'=>0,'time'=>time()];
$error['num'] = 0;
if($error['num'] >=5 && $error['time'] > strtotime('- 5 minutes'))
return $this->failed('错误次数过多,请稍候再试!');
//检验帐号密码
$res = SystemAdmin::login($account,$pwd);
if($res){
Session::set('login_error',null);
return $this->redirect(Url::build('Index/index'));
}else{
$error['num'] += 1;
$error['time'] = time();
Session::set('login_error',$error);
return $this->failed(SystemAdmin::getErrorInfo('用户名错误,请重新输入'));
}
}
public function captcha()
{
ob_clean();
$captcha = new \think\captcha\Captcha([
'codeSet'=>'0123456789',
'length'=>4,
'fontSize'=>30
]);
return $captcha->entry();
}
/**
* 退出登陆
*/
public function logout()
{
SystemAdmin::clearLoginInfo();
$this->redirect('Login/index');
}
}

View File

@ -1,117 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/10/09
*/
namespace app\admin\controller;
use service\JsonService;
use think\Controller;
class SystemBasic extends Controller
{
/**
* 操作失败提示框
* @param string $msg 提示信息
* @param string $backUrl 跳转地址
* @param string $title 标题
* @param int $duration 持续时间
* @return mixed
*/
protected function failedNotice($msg = '操作失败', $backUrl = 0, $info = '', $duration = 3)
{
$type = 'error';
$this->assign(compact('msg','backUrl','info','duration','type'));
return $this->fetch('public/notice');
}
/**
* 失败提示一直持续
* @param $msg
* @param int $backUrl
* @param string $title
* @return mixed
*/
protected function failedNoticeLast($msg = '操作失败', $backUrl = 0, $info = '')
{
return $this->failedNotice($msg,$backUrl,$info,0);
}
/**
* 操作成功提示框
* @param string $msg 提示信息
* @param string $backUrl 跳转地址
* @param string $title 标题
* @param int $duration 持续时间
* @return mixed
*/
protected function successfulNotice($msg = '操作成功',$backUrl = 0,$info = '',$duration = 3)
{
$type = 'success';
$this->assign(compact('msg','backUrl','info','duration','type'));
return $this->fetch('public/notice');
}
/**
* 成功提示一直持续
* @param $msg
* @param int $backUrl
* @param string $title
* @return mixed
*/
protected function successfulNoticeLast($msg = '操作成功',$backUrl = 0,$info = '')
{
return $this->successfulNotice($msg,$backUrl,$info,0);
}
/**
* 错误提醒页面
* @param string $msg
* @param int $url
*/
protected function failed($msg = '哎呀…亲…您访问的页面出现错误', $url = 0)
{
if($this->request->isAjax()){
exit(JsonService::fail($msg,$url)->getContent());
}else{
$this->assign(compact('msg','url'));
exit($this->fetch('public/error'));
}
}
/**
* 成功提醒页面
* @param string $msg
* @param int $url
*/
protected function successful($msg, $url = 0)
{
if($this->request->isAjax()){
exit(JsonService::successful($msg,$url)->getContent());
}else{
$this->assign(compact('msg','url'));
exit($this->fetch('public/success'));
}
}
/**异常抛出
* @param $name
*/
protected function exception($msg = '无法打开页面')
{
$this->assign(compact('msg'));
exit($this->fetch('public/exception'));
}
/**找不到页面
* @param $name
*/
public function _empty($name)
{
exit($this->fetch('public/404'));
}
}

View File

@ -1,290 +0,0 @@
<?php
namespace app\admin\controller\agent;
use app\admin\controller\AuthController;
use app\admin\model\order\StoreOrder;
use app\admin\model\system\SystemAttachment;
use app\admin\model\user\User;
use app\admin\model\wechat\WechatUser as UserModel;
use app\admin\library\FormBuilder;
use app\core\model\routine\RoutineQrcode;
use app\core\model\user\UserBill;
use service\JsonService;
use service\UploadService;
use service\UtilService as Util;
/**
* 分销商管理控制器
* Class AgentManage
* @package app\admin\controller\agent
*/
class AgentManage extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$this->assign( 'year',getMonth('y'));
$this->assign('store_brokerage_statu',\app\core\util\SystemConfigService::get('store_brokerage_statu'));
return $this->fetch();
}
public function get_spread_list()
{
$where=Util::getMore([
['nickname',''],
['start_time',''],
['end_time',''],
['sex',''],
['excel',''],
['subscribe',''],
['order',''],
['data',''],
['page',1],
['limit',20],
['user_type',''],
]);
return JsonService::successlayui(UserModel::agentSystemPage($where));
}
public function get_badge()
{
$where = Util::postMore([
['data',''],
['nickname',''],
['excel',''],
]);
return JsonService::successful(UserModel::getSpreadBadge($where));
}
/**
* 推荐人页面
* @return mixed
*/
public function stair($uid = '')
{
if($uid == '') return $this->failed('参数错误');
$this->assign('uid',$uid ? : 0);
$this->assign( 'year',getMonth('y'));
return $this->fetch();
}
/*
* 统计推广订单
* @param int $uid
* */
public function stair_order($uid = 0)
{
if($uid == '') return $this->failed('参数错误');
$this->assign('uid',$uid ? : 0);
$this->assign( 'year',getMonth('y'));
return $this->fetch();
}
public function get_stair_order_list(){
$where = Util::getMore([
['uid',$this->request->param('uid',0)],
['data',''],
['order_id',''],
['type',''],
['page',1],
['limit',20],
]);
return JsonService::successlayui(UserModel::getStairOrderList($where));
}
public function get_stair_order_badge()
{
$where = Util::getMore([
['uid',''],
['data',''],
['order_id',''],
['type',''],
]);
return JsonService::successful(UserModel::getStairOrderBadge($where));
}
public function get_stair_list()
{
$where = Util::getMore([
['uid',$this->request->param('uid',0)],
['data',''],
['nickname',''],
['type',''],
['page',1],
['limit',20],
]);
return JsonService::successlayui(UserModel::getStairList($where));
}
public function get_stair_badge()
{
$where = Util::getMore([
['uid',''],
['data',''],
['nickname',''],
['type',''],
]);
return JsonService::successful(UserModel::getSairBadge($where));
}
/**
* 二级推荐人页面
* @return mixed
*/
public function stair_two($uid = '')
{
if($uid == '') return $this->failed('参数错误');
$spread_uid=User::where('spread_uid',$uid)->column('uid');
if(count($spread_uid))
$spread_uid_two=User::where('spread_uid','in',$spread_uid)->column('uid');
else
$spread_uid_two=[0];
$list = User::alias('u')
->where('u.uid','in',$spread_uid_two)
->field('u.avatar,u.nickname,u.now_money,u.spread_time,u.uid')
->where('u.status',1)
->order('u.add_time DESC')
->select()
->toArray();
foreach ($list as $key=>$value) $list[$key]['orderCount'] = StoreOrder::getOrderCount($value['uid'])?:0;
$this->assign('list',$list);
return $this->fetch('stair');
}
/*
* 批量清除推广权限
* */
public function delete_promoter()
{
list($uids)=Util::postMore([
['uids',[]]
],$this->request,true);
if(!count($uids)) return JsonService::fail('请选择需要解除推广权限的用户!');
User::beginTrans();
try{
if(User::where('uid','in',$uids)->update(['is_promoter'=>0])){
User::commitTrans();
return JsonService::successful('解除成功');
}else{
User::rollbackTrans();
return JsonService::fail('解除失败');
}
}catch (\PDOException $e){
User::rollbackTrans();
return JsonService::fail('数据库操作错误',['line'=>$e->getLine(),'message'=>$e->getMessage()]);
}catch (\Exception $e){
User::rollbackTrans();
return JsonService::fail('系统错误',['line'=>$e->getLine(),'message'=>$e->getMessage()]);
}
}
/*
* 查看公众号推广二维码
* @param int $uid
* @return json
* */
public function look_code($uid='',$action='')
{
if(!$uid || !$action) return JsonService::fail('缺少参数');
try{
if(method_exists($this,$action)){
$res = $this->$action($uid);
if($res)
return JsonService::successful($res);
else
return JsonService::fail(isset($res['msg']) ? $res['msg'] : '获取失败,请稍后再试!' );
}else
return JsonService::fail('暂无此方法');
}catch (\Exception $e){
return JsonService::fail('获取推广二维码失败,请检查您的微信配置',['line'=>$e->getLine(),'messag'=>$e->getMessage()]);
}
}
/*
* 获取小程序二维码
* */
public function routine_code($uid)
{
$userInfo = User::getUserInfos($uid);
$name = $userInfo['uid'].'_'.$userInfo['is_promoter'].'_user.jpg';
$imageInfo = SystemAttachment::getInfo($name,'name');
if(!$imageInfo){
$res = \app\core\model\routine\RoutineCode::getShareCode($uid, 'spread', '', '');
if(!$res) throw new \think\Exception('二维码生成失败');
$imageInfo = UploadService::imageStream($name,$res['res'],'routine/spread/code');
if(!is_array($imageInfo)) return $imageInfo;
SystemAttachment::attachmentAdd($imageInfo['name'],$imageInfo['size'],$imageInfo['type'],$imageInfo['dir'],$imageInfo['thumb_path'],1,$imageInfo['image_type'],$imageInfo['time']);
RoutineQrcode::setRoutineQrcodeFind($res['id'],['status'=>1,'time'=>time(),'qrcode_url'=>$imageInfo['dir']]);
$urlCode = $imageInfo['dir'];
}else $urlCode = $imageInfo['att_dir'];
return ['code_src'=>$urlCode];
}
/*
*
* */
public function wechant_code($uid)
{
$qr_code = \app\core\util\QrcodeService::getForeverQrcode('spread',$uid);
if(isset($qr_code['url']))
return ['code_src'=>$qr_code['url']];
else
throw new \think\Exception('获取失败,请稍后再试!');
}
/**
* TODO 查看小程序推广二维码
* @param string $uid
*/
public function look_xcx_code($uid = '')
{
if(!strlen(trim($uid))) return JsonService::fail('缺少参数');
try{
}catch (\Exception $e){
return JsonService::fail('查看推广二维码失败!',['line'=>$e->getLine(),'meassge'=>$e->getMessage()]);
}
}
/*
* 解除单个用户的推广权限
* @param int $uid
* */
public function delete_spread($uid=0)
{
if(!$uid) return JsonService::fail('缺少参数');
if(User::where('uid',$uid)->update(['is_promoter'=>0]))
return JsonService::successful('解除成功');
else
return JsonService::fail('解除失败');
}
/*
* 清除自己的上级推广人
* */
public function empty_spread($uid=0)
{
if(!$uid) return JsonService::fail('缺少参数');
if(User::where('uid',$uid)->update(['spread_uid'=>0]))
return JsonService::successful('清除成功');
else
return JsonService::fail('清除失败');
}
/**
* 个人资金详情页面
* @return mixed
*/
public function now_money($uid = ''){
if($uid == '') return $this->failed('参数错误');
$list = UserBill::where('uid',$uid)->where('category','now_money')
->field('mark,pm,number,add_time')
->where('status',1)->order('add_time DESC')->select()->toArray();
foreach ($list as &$v){
$v['add_time'] = date('Y-m-d H:i:s',$v['add_time']);
}
$this->assign('list',$list);
return $this->fetch();
}
}

View File

@ -1,194 +0,0 @@
<?php
namespace app\admin\controller\article;
use app\admin\controller\AuthController;
use service\UtilService as Util;
use service\PHPTreeService as Phptree;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\article\ArticleCategory as ArticleCategoryModel;
use app\admin\model\article\Article as ArticleModel;
use app\admin\model\system\SystemAttachment;
/**
* 图文管理
* Class WechatNews
* @package app\admin\controller\wechat
*/
class Article extends AuthController
{
/**
* TODO 显示后台管理员添加的图文
* @return mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function index()
{
$where = Util::getMore([
['title',''],
['cid','']
],$this->request);
$pid = $this->request->param('pid');
$this->assign('where',$where);
$where['merchant'] = 0;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$cateList = ArticleCategoryModel::getArticleCategoryList();
$tree = [];
//获取分类列表
if(count($cateList)){
$tree = Phptree::makeTreeForHtml($cateList);
if($pid){
$pids = Util::getChildrenPid($tree,$pid);
$where['cid'] = ltrim($pid.$pids);
}
}
$this->assign(compact('tree'));
$this->assign(ArticleModel::getAll($where));
return $this->fetch();
}
/**
* TODO 文件添加和修改
* @return mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function create(){
$id = $this->request->param('id');
$cid = $this->request->param('cid');
$news = [];
$all = [];
$news['id'] = '';
$news['image_input'] = '';
$news['title'] = '';
$news['author'] = '';
$news['is_banner'] = '';
$news['is_hot'] = '';
$news['content'] = '';
$news['synopsis'] = '';
$news['url'] = '';
$news['cid'] = [];
$select = 0;
if($id){
$news = ArticleModel::where('n.id',$id)->alias('n')->field('n.*,c.content')->join('ArticleContent c','c.nid=n.id')->find();
if(!$news) return $this->failedNotice('数据不存在!');
$news['cid'] = explode(',',$news['cid']);
}
if($cid && in_array($cid, ArticleCategoryModel::getArticleCategoryInfo(0,'id'))){
$all = ArticleCategoryModel::getArticleCategoryInfo($cid);
$select = 1;
}
if(!$select){
$list = ArticleCategoryModel::getTierList();
foreach ($list as $menu){
$all[$menu['id']] = $menu['html'].$menu['title'];
}
}
$this->assign('all',$all);
$this->assign('news',$news);
$this->assign('cid',$cid);
$this->assign('select',$select);
return $this->fetch();
}
/**
* 上传图文图片
* @return \think\response\Json
*/
public function upload_image(){
$res = Upload::Image($_POST['file'],'wechat/image/'.date('Ymd'));
if(!is_array($res)) return Json::fail($res);
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],5,$res['image_type'],$res['time']);
return Json::successful('上传成功!',['url'=>$res['dir']]);
}
/**
* 添加和修改图文
* @param Request $request
* @return \think\response\Json
*/
public function add_new(Request $request){
$post = $request->post();
$data = Util::postMore([
['id',0],
['cid',[]],
'title',
'author',
'image_input',
'content',
'synopsis',
'share_title',
'share_synopsis',
['visit',0],
['sort',0],
'url',
['is_banner',0],
['is_hot',0],
['status',1],],$request);
$data['cid'] = implode(',',$data['cid']);
$content = $data['content'];
unset($data['content']);
if($data['id']){
$id = $data['id'];
unset($data['id']);
$res = false;
ArticleModel::beginTrans();
$res1 = ArticleModel::edit($data,$id,'id');
$res2 = ArticleModel::setContent($id,$content);
if($res1 && $res2){
$res = true;
}
ArticleModel::checkTrans($res);
if($res)
return Json::successful('修改图文成功!',$id);
else
return Json::fail('修改图文失败,您并没有修改什么!',$id);
}else{
$data['add_time'] = time();
$data['admin_id'] = $this->adminId;
$res = false;
ArticleModel::beginTrans();
$res1 = ArticleModel::set($data);
$res2 = false;
if($res1)
$res2 = ArticleModel::setContent($res1->id,$content);
if($res1 && $res2){
$res = true;
}
ArticleModel::checkTrans($res);
if($res)
return Json::successful('添加图文成功!',$res1->id);
else
return Json::successful('添加图文失败!',$res1->id);
}
}
/**
* 删除图文
* @param $id
* @return \think\response\Json
*/
public function delete($id)
{
$res = ArticleModel::del($id);
if(!$res)
return Json::fail('删除失败,请稍候再试!');
else
return Json::successful('删除成功!');
}
public function merchantIndex(){
$where = Util::getMore([
['title','']
],$this->request);
$this->assign('where',$where);
$where['cid'] = input('cid');
$where['merchant'] = 1;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$this->assign(ArticleModel::getAll($where));
return $this->fetch();
}
}

View File

@ -1,184 +0,0 @@
<?php
namespace app\admin\controller\article;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemAttachment;
use service\FormBuilder as Form;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use think\Url;
use app\admin\model\article\ArticleCategory as ArticleCategoryModel;
use app\admin\model\article\Article as ArticleModel;
/**
* 文章分类管理 控制器
* */
class ArticleCategory extends AuthController
{
/**
* 分类管理
* */
public function index(){
$where = Util::getMore([
['status',''],
['title',''],
],$this->request);
$this->assign('where',$where);
$this->assign(ArticleCategoryModel::systemPage($where));
return $this->fetch();
}
/**
* 添加分类管理
* */
public function create(){
$f = array();
$f[] = Form::select('pid','父级id')->setOptions(function(){
$list = ArticleCategoryModel::getTierList();
$menus[] = ['value'=>0,'label'=>'顶级分类'];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['title']];
}
return $menus;
})->filterable(1);
$f[] = Form::input('title','分类名称');
$f[] = Form::input('intr','分类简介')->type('textarea');
// $f[] = Form::select('new_id','图文列表')->setOptions(function(){
// $list = ArticleModel::getNews();
// $options = [];
// foreach ($list as $id=>$roleName){
// $options[] = ['label'=>$roleName,'value'=>$id];
// }
// return $options;
// })->multiple(1)->filterable(1);
$f[] = Form::formFrameImageOne('image','分类图片');
$f[] = Form::number('sort','排序',0);
$f[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>0,'label'=>'隐藏']]);
$form = Form::make_post_form('添加分类',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* s上传图片
* */
public function upload(){
$res = Upload::image('file','article');
if(!is_array($res)) return Json::fail($res);
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],5,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}
/**
* 保存分类管理
* */
public function save(Request $request){
$data = Util::postMore([
'title',
'pid',
'intr',
['new_id',[]],
['image',[]],
['sort',0],
'status',],$request);
if(!$data['title']) return Json::fail('请输入分类名称');
if(count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
if($data['sort'] < 0) return Json::fail('排序不能是负数');
$data['add_time'] = time();
$data['image'] = $data['image'][0];
$new_id = $data['new_id'];
unset($data['new_id']);
$res = ArticleCategoryModel::set($data);
if(!ArticleModel::saveBatchCid($res['id'],implode(',',$new_id))) return Json::fail('文章列表添加失败');
return Json::successful('添加分类成功!');
}
/**
* 修改分类
* */
public function edit($id){
if(!$id) return $this->failed('参数错误');
$article = ArticleCategoryModel::get($id)->getData();
if(!$article) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::select('pid','父级id',(string)$article['pid'])->setOptions(function(){
$list = ArticleCategoryModel::getTierList();
$menus[] = ['value'=>0,'label'=>'顶级分类'];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['title']];
}
return $menus;
})->filterable(1);
$f[] = Form::input('title','分类名称',$article['title']);
$f[] = Form::input('intr','分类简介',$article['intr'])->type('textarea');
// $f[] = Form::select('new_id','图文列表',explode(',',$article->getData('new_id')))->setOptions(function(){
// $list = ArticleModel::getNews();
// $options = [];
// foreach ($list as $id=>$roleName){
// $options[] = ['label'=>$roleName,'value'=>$id];
// }
// return $options;
// })->multiple(1)->filterable(1);
$f[] = Form::formFrameImageOne('image','分类图片',$article['image']);
$f[] = Form::number('sort','排序',0);
$f[] = Form::radio('status','状态',$article['status'])->options([['value'=>1,'label'=>'显示'],['value'=>0,'label'=>'隐藏']]);
$form = Form::make_post_form('编辑分类',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'pid',
'title',
'intr',
// ['new_id',[]],
['image',[]],
['sort',0],
'status',],$request);
if(!$data['title']) return Json::fail('请输入分类名称');
if(count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
if($data['sort'] < 0) return Json::fail('排序不能是负数');
$data['image'] = $data['image'][0];
if(!ArticleCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
// if(!ArticleModel::saveBatchCid($id,implode(',',$data['new_id']))) return Json::fail('文章列表添加失败');
// unset($data['new_id']);
ArticleCategoryModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除分类
* */
public function delete($id)
{
$res = ArticleCategoryModel::delArticleCategory($id);
if(!$res)
return Json::fail(ArticleCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,186 +0,0 @@
<?php
namespace app\admin\controller\article;
use app\admin\controller\AuthController;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\article\ArticleCategory as ArticleCategoryModel;
use app\admin\model\article\Article as ArticleModel;
use app\admin\model\system\SystemAttachment;
/**
* 图文管理
* Class WechatNews
* @package app\admin\controller\wechat
*/
class WechatNews extends AuthController
{
/**
* 显示后台管理员添加的图文
* @return mixed
*/
public function index($cid = 0)
{
$where = Util::getMore([
['title','']
],$this->request);
if($cid)
$where['cid'] = $cid;
else
$where['cid'] = '';
$this->assign('where',$where);
$where['merchant'] = 0;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$this->assign('cid',$cid);
$this->assign(ArticleModel::getAll($where));
return $this->fetch();
}
/**
* 展示页面 添加和删除
* @return mixed
*/
public function create(){
$id = input('id');
$cid = input('cid');
$news = array();
$news['id'] = '';
$news['image_input'] = '';
$news['title'] = '';
$news['author'] = '';
$news['content'] = '';
$news['synopsis'] = '';
$news['url'] = '';
$news['cid'] = array();
if($id){
$news = \app\admin\model\wechat\WechatNews::where('n.id',$id)->alias('n')->field('n.*,c.content')->join('__WECHAT_NEWS_CONTENT__ c','c.nid=n.id')->find();
if(!$news) return $this->failedNotice('数据不存在!');
$news['cid'] = explode(',',$news['cid']);
// dump($news);
}
$all = array();
$select = 0;
if(!$cid)
$cid = '';
else {
if($id){
$all = ArticleCategoryModel::where('id',$cid)->where('hidden','neq',0)->column('id,title');
$select = 1;
}else{
$all = ArticleCategoryModel::where('id',$cid)->column('id,title');
$select = 1;
}
}
if(empty($all)){
$all = ArticleCategoryModel::getField('id,title');//新闻分类
$select = 0;
}
$this->assign('all',$all);
$this->assign('news',$news);
$this->assign('cid',$cid);
$this->assign('select',$select);
return $this->fetch();
}
/**
* 上传图文图片
* @return \think\response\Json
*/
public function upload_image(){
$res = Upload::Image($_POST['file'],'wechat/image/'.date('Ymd'));
//产品图片上传记录
$fileInfo = $res->fileInfo->getinfo();
SystemAttachment::attachmentAdd($res->fileInfo->getSaveName(),$fileInfo['size'],$fileInfo['type'],$res->dir,'',5);
if(!$res->status) return Json::fail($res->error);
return Json::successful('上传成功!',['url'=>$res->filePath]);
}
/**
* 添加和修改图文
* @param Request $request
* @return \think\response\Json
*/
public function add_new(Request $request){
$post = $request->post();
$data = Util::postMore([
['id',0],
['cid',[]],
'title',
'author',
'image_input',
'content',
'synopsis',
'share_title',
'share_synopsis',
['visit',0],
['sort',0],
'url',
['status',1],],$request);
$data['cid'] = implode(',',$data['cid']);
$content = $data['content'];
unset($data['content']);
if($data['id']){
$id = $data['id'];
unset($data['id']);
ArticleModel::beginTrans();
$res1 = ArticleModel::edit($data,$id,'id');
$res2 = ArticleModel::setContent($id,$content);
if($res1 && $res2)
$res = true;
else
$res =false;
// dump($res);
// exit();
ArticleModel::checkTrans($res);
if($res)
return Json::successful('修改图文成功!',$id);
else
return Json::fail('修改图文失败!',$id);
}else{
$data['add_time'] = time();
$data['admin_id'] = $this->adminId;
ArticleModel::beginTrans();
$res1 = ArticleModel::set($data);
$res2 = false;
if($res1)
$res2 = ArticleModel::setContent($res1->id,$content);
if($res1 && $res2)
$res = true;
else
$res =false;
ArticleModel::checkTrans($res);
if($res)
return Json::successful('添加图文成功!',$res1->id);
else
return Json::successful('添加图文失败!',$res1->id);
}
}
/**
* 删除图文
* @param $id
* @return \think\response\Json
*/
public function delete($id)
{
$res = ArticleModel::del($id);
if(!$res)
return Json::fail('删除失败,请稍候再试!');
else
return Json::successful('删除成功!');
}
public function merchantIndex(){
$where = Util::getMore([
['title','']
],$this->request);
$this->assign('where',$where);
$where['cid'] = input('cid');
$where['merchant'] = 1;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$this->assign(ArticleModel::getAll($where));
return $this->fetch();
}
}

View File

@ -1,127 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: xurongyao <763569752@qq.com>
* Date: 2018/6/14 下午5:25
*/
namespace app\admin\controller\finance;
use app\admin\controller\AuthController;
use app\admin\model\user\UserBill;
use service\JsonService as Json;
use app\admin\model\finance\FinanceModel;
use service\UtilService as Util;
use service\FormBuilder as Form;
//use FormBuilder\Form;
use service\HookService;
use think\Url;
use app\admin\model\user\User;
use app\admin\model\user\UserExtract;
/**
* 微信充值记录
* Class UserRecharge
* @package app\admin\controller\user
*/
class Finance extends AuthController
{
/**
* 显示资金记录
*/
public function bill(){
$list=UserBill::where('type','not in',['gain','system_sub','deduction','sign'])
->where('category','not in','integral')
->field(['title','type'])
->group('type')
->distinct(true)
->select()
->toArray();
$this->assign('selectList',$list);
return $this->fetch();
}
/**
* 显示资金记录ajax列表
*/
public function billlist(){
$where = Util::getMore([
['start_time',''],
['end_time',''],
['nickname',''],
['limit',20],
['page',1],
['type',''],
]);
return Json::successlayui(FinanceModel::getBillList($where));
}
/**
*保存资金监控的excel表格
*/
public function save_bell_export(){
$where = Util::getMore([
['start_time',''],
['end_time',''],
['nickname',''],
['type',''],
]);
FinanceModel::SaveExport($where);
}
/**
* 显示佣金记录
*/
public function commission_list(){
$this->assign('is_layui',true);
return $this->fetch();
}
/**
* 佣金记录异步获取
*/
public function get_commission_list(){
$get=Util::getMore([
['page',1],
['limit',20],
['nickname',''],
['price_max',''],
['price_min',''],
['order',''],
['excel',''],
]);
return Json::successlayui(User::getCommissionList($get));
}
/**
* 显示操作记录
*/
public function index3(){
}
/**
* 佣金详情
*/
public function content_info($uid=''){
if($uid=='') return $this->failed('缺少参数');
$this->assign('userinfo',User::getUserinfo($uid));
$this->assign('uid',$uid);
return $this->fetch();
}
/**
* 佣金提现记录个人列表
*/
public function get_extract_list($uid=''){
if($uid=='') return Json::fail('缺少参数');
$where=Util::getMore([
['page',1],
['limit',20],
['start_time',''],
['end_time',''],
['nickname','']
]);
return Json::successlayui(UserBill::getExtrctOneList($where,$uid));
}
}

View File

@ -1,127 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: lianghuan
* Date: 2018-03-03
* Time: 16:37
*/
namespace app\admin\controller\finance;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\user\UserExtract as UserExtractModel;
use service\JsonService;
use think\Request;
use service\UtilService as Util;
use think\Url;
/* 用户提现管理
* */
class UserExtract extends AuthController
{
public function index(){
$where = Util::getMore([
['status',''],
['nickname',''],
['extract_type',''],
['nireid',''],
],$this->request);
$this->assign('where',$where);
$this->assign(UserExtractModel::systemPage($where));
return $this->fetch();
}
public function edit($id){
if(!$id) return $this->failed('数据不存在');
$UserExtract = UserExtractModel::get($id);
if(!$UserExtract) return JsonService::fail('数据不存在!');
$f = array();
$f[] = Form::input('real_name','姓名',$UserExtract['real_name']);
$f[] = Form::number('extract_price','提现金额',$UserExtract['extract_price'])->precision(2);
if($UserExtract['extract_type']=='alipay'){
$f[] = Form::input('alipay_code','支付宝账号',$UserExtract['alipay_code']);
}else if($UserExtract['extract_type']=='weixin'){
$f[] = Form::input('wechat','微信号',$UserExtract['wechat']);
}else{
$f[] = Form::input('bank_code','银行卡号',$UserExtract['bank_code']);
$f[] = Form::input('bank_address','开户行',$UserExtract['bank_address']);
}
$f[] = Form::input('mark','备注',$UserExtract['mark'])->type('textarea');
$form = Form::make_post_form('编辑',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request,$id)
{
$UserExtract = UserExtractModel::get($id);
if(!$UserExtract) return JsonService::fail('数据不存在!');
if($UserExtract['extract_type']=='alipay'){
$data = Util::postMore([
'real_name',
'mark',
'extract_price',
'alipay_code',
],$request);
if(!$data['real_name']) return JsonService::fail('请输入姓名');
if($data['extract_price']<=-1) return JsonService::fail('请输入提现金额');
if(!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
}else if($UserExtract['extract_type']=='weixin'){
$data = Util::postMore([
'real_name',
'mark',
'extract_price',
'wechat',
],$request);
// if(!$data['real_name']) return JsonService::fail('请输入姓名');
if($data['extract_price']<=-1) return JsonService::fail('请输入提现金额');
if(!$data['wechat']) return JsonService::fail('请输入微信账号');
}else{
$data = Util::postMore([
'real_name',
'extract_price',
'mark',
'bank_code',
'bank_address',
],$request);
if(!$data['real_name']) return JsonService::fail('请输入姓名');
if($data['extract_price']<=-1) return JsonService::fail('请输入提现金额');
if(!$data['bank_code']) return JsonService::fail('请输入银行卡号');
if(!$data['bank_address']) return JsonService::fail('请输入开户行');
}
if(!UserExtractModel::edit($data,$id))
return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
else
return JsonService::successful('修改成功!');
}
public function fail(Request $request,$id)
{
if(!UserExtractModel::be(['id'=>$id,'status'=>0])) return JsonService::fail('操作记录不存在或状态错误!');
$fail_msg =$request->post();
$extract=UserExtractModel::get($id);
if(!$extract) return JsonService::fail('操作记录不存在!');
if($extract->status==1) return JsonService::fail('已经提现,错误操作');
if($extract->status==-1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
$res = UserExtractModel::changeFail($id,$fail_msg['message']);
if($res){
return JsonService::successful('操作成功!');
}else{
return JsonService::fail('操作失败!');
}
}
public function succ($id)
{
if(!UserExtractModel::be(['id'=>$id,'status'=>0]))
return JsonService::fail('操作记录不存在或状态错误!');
UserExtractModel::beginTrans();
$extract=UserExtractModel::get($id);
if(!$extract) return JsonService::fail('操作记录不存!');
if($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
if($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
$res = UserExtractModel::changeSuccess($id);
if($res){
UserExtractModel::commitTrans();
return JsonService::successful('操作成功!');
}else{
UserExtractModel::rollbackTrans();
return JsonService::fail('操作失败!');
}
}
}

View File

@ -1,108 +0,0 @@
<?php
namespace app\admin\controller\finance;
use app\admin\controller\AuthController;
use app\admin\model\user\User;
use app\admin\model\user\UserRecharge as UserRechargeModel;
use app\core\model\routine\RoutineTemplate;
use app\core\model\user\UserBill;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Url;
use service\FormBuilder as Form;
use think\Request;
use service\HookService;
use behavior\wechat\PaymentBehavior;
use app\core\util\WechatTemplateService;
use app\wap\model\user\WechatUser as WechatUserWap;
/**
* 微信充值记录
* Class UserRecharge
* @package app\admin\controller\user
*/
class UserRecharge extends AuthController
{
/**
* 显示操作记录
*/
public function index(){
$where = Util::getMore([
['order_id',''],
],$this->request);
$this->assign('where',$where);
$this->assign(UserRechargeModel::systemPage($where));
return $this->fetch();
}
/**退款
* @param $id
* @return mixed|void
*/
public function edit($id){
if(!$id) return $this->failed('数据不存在');
$UserRecharge = UserRechargeModel::get($id);
if(!$UserRecharge) return Json::fail('数据不存在!');
if($UserRecharge['paid'] == 1){
$f = array();
$f[] = Form::input('order_id','退款单号',$UserRecharge->getData('order_id'))->disabled(1);
$f[] = Form::number('refund_price','退款金额',$UserRecharge->getData('price'))->precision(2)->min(0)->max($UserRecharge->getData('price'));
$form = Form::make_post_form('编辑',$f,Url::build('updateRefundY',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
else return Json::fail('数据不存在!');
}
/**退款更新
* @param Request $request
* @param $id
*/
public function updateRefundY(Request $request, $id){
$data = Util::postMore([
'refund_price',
],$request);
if(!$id) return $this->failed('数据不存在');
$UserRecharge = UserRechargeModel::get($id);
if(!$UserRecharge) return Json::fail('数据不存在!');
if($UserRecharge['price'] == $UserRecharge['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
if(!$data['refund_price']) return Json::fail('请输入退款金额');
$refund_price = $data['refund_price'];
$data['refund_price'] = bcadd($data['refund_price'],$UserRecharge['refund_price'],2);
$bj = bccomp((float)$UserRecharge['price'],(float)$data['refund_price'],2);
if($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
$refund_data['pay_price'] = $UserRecharge['price'];
$refund_data['refund_price'] = $refund_price;
// $refund_data['refund_account']='REFUND_SOURCE_RECHARGE_FUNDS';
try{
HookService::listen('user_recharge_refund',$UserRecharge['order_id'],$refund_data,true,PaymentBehavior::class);
}catch(\Exception $e){
return Json::fail($e->getMessage());
}
UserRechargeModel::edit($data,$id);
User::bcDec($UserRecharge['uid'],'now_money',$refund_price,'uid');
switch (strtolower($UserRecharge['recharge_type'])){
case 'weixin':
WechatTemplateService::sendTemplate(WechatUserWap::where('uid',$UserRecharge['uid'])->value('openid'),WechatTemplateService::ORDER_REFUND_STATUS, [
'first'=>'亲,您充值的金额已退款,本次退款'.
$data['refund_price'].'金额',
'keyword1'=>$UserRecharge['order_id'],
'keyword2'=>$UserRecharge['price'],
'keyword3'=>date('Y-m-d H:i:s',$UserRecharge['add_time']),
'remark'=>'点击查看订单详情'
],Url::build('wap/My/balance','',true,true));
break;
case 'routine':
RoutineTemplate::sendOut('ORDER_REFUND_SUCCESS',$UserRecharge['uid'],[
'keyword1'=>$UserRecharge['order_id'],
'keyword2'=>date('Y-m-d H:i:s',time()),
'keyword3'=>$UserRecharge['price'],
'keyword4'=>'余额充值退款',
'keyword5'=>'亲,您充值的金额已退款,本次退款'. $data['refund_price'].'金额',
]);
break;
}
UserBill::expend('系统退款',$UserRecharge['uid'],'now_money','user_recharge_refund',$refund_price,$id,$UserRecharge['price'],'退款给用户'.$refund_price.'元');
return Json::successful('退款成功!');
}
}

View File

@ -1,674 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\controller\order;
use Api\Express;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\order\StoreOrderStatus;
use app\admin\model\ump\StorePink;
use app\admin\model\user\User;
use app\admin\model\user\UserBill;
use basic\ModelBasic;
use behavior\admin\OrderBehavior;
use behavior\wechat\PaymentBehavior;
use EasyWeChat\Core\Exception;
use service\CacheService;
use service\HookService;
use service\JsonService;
use app\core\util\SystemConfigService;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Db;
use think\Request;
use think\Url;
use app\admin\model\order\StoreOrder as StoreOrderModel;
/**
* 订单管理控制器 同一个订单表放在一个控制器
* Class StoreOrder
* @package app\admin\controller\store
*/
class StoreOrder extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$this->assign([
'year'=>getMonth('y'),
'real_name'=>$this->request->get('real_name',''),
'status'=>$this->request->param('status',''),
'orderCount'=>StoreOrderModel::orderCount(),
]);
return $this->fetch();
}
/**
* 获取头部订单金额等信息
* return json
*
*/
public function getBadge(){
$where = Util::postMore([
['status',''],
['real_name',''],
['is_del',0],
['data',''],
['type',''],
['order','']
]);
return JsonService::successful(StoreOrderModel::getBadge($where));
}
/**
* 获取订单列表
* return json
*/
public function order_list(){
$where = Util::getMore([
['status',''],
['real_name',$this->request->param('real_name','')],
['is_del',0],
['data',''],
['type',''],
['order',''],
['page',1],
['limit',20],
['excel',0]
]);
return JsonService::successlayui(StoreOrderModel::OrderList($where));
}
/*
* 发送货
* @param int $id
* @return html
* */
public function order_goods($id = 0)
{
$list = Db::name('express')->where('is_show',1)->order('sort DESC')->column('id,name');
$this->assign([
'list'=>$list,
'id'=>$id
]);
return $this->fetch();
}
/*
* 删除订单
* */
public function del_order($ids=[])
{
if(!count($ids)) return JsonService::fail('请选择需要删除的订单');
if(StoreOrderModel::where('is_del',0)->where('id','in',$ids)->count()) return JsonService::fail('您选择的的订单存在用户未删除的订单,无法删除用户未删除的订单');
$res=StoreOrderModel::where('id','in',$ids)->update(['is_system_del'=>1]);
if($res)
return JsonService::successful('删除成功');
else
return JsonService::fail('删除失败');
}
public function orderchart(){
$where = Util::getMore([
['status',''],
['real_name',''],
['is_del',0],
['data',''],
['combination_id',''],
['export',0],
['order','id desc']
],$this->request);
$limitTimeList = [
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
if($where['data'] == '') $where['data'] = $limitTimeList['today'];
$orderCount = [
urlencode('未支付')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(0))->count(),
urlencode('未发货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(1))->count(),
urlencode('待收货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(2))->count(),
urlencode('待评价')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(3))->count(),
urlencode('交易完成')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(4))->count(),
urlencode('退款中')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-1))->count(),
urlencode('已退款')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-2))->count()
];
$model = StoreOrderModel::getOrderWhere($where,new StoreOrderModel())->field('sum(total_num) total_num,count(*) count,sum(total_price) total_price,sum(refund_price) refund_price,from_unixtime(add_time,\'%Y-%m-%d\') add_time')
->group('from_unixtime(add_time,\'%Y-%m-%d\')');
$orderPrice = $model->select()->toArray();
$orderDays = [];
$orderCategory = [
['name'=>'商品数','type'=>'line','data'=>[]],
['name'=>'订单数','type'=>'line','data'=>[]],
['name'=>'订单金额','type'=>'line','data'=>[]],
['name'=>'退款金额','type'=>'line','data'=>[]]
];
foreach ($orderPrice as $price){
$orderDays[] = $price['add_time'];
$orderCategory[0]['data'][] = $price['total_num'];
$orderCategory[1]['data'][] = $price['count'];
$orderCategory[2]['data'][] = $price['total_price'];
$orderCategory[3]['data'][] = $price['refund_price'];
}
$this->assign(StoreOrderModel::systemPage($where,$this->adminId));
$this->assign('price',StoreOrderModel::getOrderPrice($where));
$this->assign(compact('limitTimeList','where','orderCount','orderPrice','orderDays','orderCategory'));
return $this->fetch();
}
/**
* 修改支付金额等
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('order_id','订单编号',$product->getData('order_id'))->disabled(1);
$f[] = Form::number('total_price','商品总价',$product->getData('total_price'))->min(0);
$f[] = Form::number('total_postage','原始邮费',$product->getData('total_postage'))->min(0);
$f[] = Form::number('pay_price','实际支付金额',$product->getData('pay_price'))->min(0);
$f[] = Form::number('pay_postage','实际支付邮费',$product->getData('pay_postage'));
$f[] = Form::number('gain_integral','赠送积分',$product->getData('gain_integral'));
// $f[] = Form::radio('status','状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('修改订单',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/** 修改订单提交更新
* @param Request $request
* @param $id
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'order_id',
'total_price',
'total_postage',
'pay_price',
'pay_postage',
'gain_integral',
],$request);
if($data['total_price'] <= 0) return Json::fail('请输入商品总价');
if($data['pay_price'] <= 0) return Json::fail('请输入实际支付金额');
$data['order_id'] = StoreOrderModel::changeOrderId($data['order_id']);
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_edit',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'order_edit','修改商品总价为:'.$data['total_price'].' 实际支付金额'.$data['pay_price']);
return Json::successful('修改成功!');
}
/**
* TODO 填写送货信息
* @param $id
* @return mixed|void
* @throws \think\exception\DbException
*/
public function delivery($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1 && $product['status'] == 0) {
$f = array();
$f[] = Form::input('delivery_name','送货人姓名')->required('送货人姓名不能为空','required:true;');
$f[] = Form::input('delivery_id','送货人电话')->required('请输入正确电话号码','telephone');
$form = Form::make_post_form('修改订单',$f,Url::build('updateDelivery',array('id'=>$id)),7);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
else $this->failedNotice('订单状态错误');
}
/**
* TODO 送货信息提交
* @param Request $request
* @param $id
*/
public function update_delivery(Request $request, $id){
$data = Util::postMore([
['type',1],
'delivery_name',
'delivery_id',
['sh_delivery_name',''],
['sh_delivery_id',''],
],$request);
switch ((int)$data['type']){
case 1:
//发货
$data['delivery_type'] = 'express';
if(!$data['delivery_name']) return Json::fail('请选择快递公司');
if(!$data['delivery_id']) return Json::fail('请输入快递单号');
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery_goods',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery_goods','已发货 快递公司:'.$data['delivery_name'].' 快递单号:'.$data['delivery_id']);
break;
case 2:
//送货
$data['delivery_type'] = 'send';
$data['delivery_name'] = $data['sh_delivery_name'];
$data['delivery_id'] = $data['sh_delivery_id'];
unset($data['sh_delivery_name'],$data['sh_delivery_id']);
if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery','已配送 发货人:'.$data['delivery_name'].' 发货人电话:'.$data['delivery_id']);
break;
case 3:
//虚拟发货
$data['delivery_type'] = 'fictitious';
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery_fictitious','已虚拟发货');
StoreOrderStatus::setStatus($id,'take_delivery','虚拟物品已收货');
break;
default:
return Json::fail('暂时不支持其他发货类型');
break;
}
return Json::successful('修改成功!');
}
/**
* TODO 填写发货信息
* @param $id
* @return mixed|void
* @throws \think\exception\DbException
*/
public function deliver_goods($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1 && $product['status'] == 0){
$f = array();
$f[] = Form::select('delivery_name','快递公司')->setOptions(function(){
$list = Db::name('express')->where('is_show',1)->order('sort DESC')->column('id,name');
$menus = [];
foreach ($list as $k=>$v){
$menus[] = ['value'=>$v,'label'=>$v];
}
return $menus;
})->filterable(1);
$f[] = Form::input('delivery_id','快递单号');
$form = Form::make_post_form('修改订单',$f,Url::build('updateDeliveryGoods',array('id'=>$id)),7);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
else return $this->failedNotice('订单状态错误');
}
/**
* TODO 发货信息提交
* @param Request $request
* @param $id
*/
public function updateDeliveryGoods(Request $request, $id){
$data = Util::postMore([
'delivery_name',
'delivery_id',
],$request);
$data['delivery_type'] = 'express';
if(!$data['delivery_name']) return Json::fail('请选择快递公司');
if(!$data['delivery_id']) return Json::fail('请输入快递单号');
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery_goods',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery_goods','已发货 快递公司:'.$data['delivery_name'].' 快递单号:'.$data['delivery_id']);
return Json::successful('修改成功!');
}
/**
* 修改状态为已收货
* @param $id
* @return \think\response\Json|void
*/
public function take_delivery($id){
if(!$id) return $this->failed('数据不存在');
$order = StoreOrderModel::get($id);
if(!$order) return Json::fail('数据不存在!');
if($order['status'] == 2) return Json::fail('不能重复收货!');
if($order['paid'] == 1 && $order['status'] == 1) $data['status'] = 2;
else if($order['pay_type'] == 'offline') $data['status'] = 2;
else return Json::fail('请先发货或者送货!');
if(!StoreOrderModel::edit($data,$id))
return Json::fail(StoreOrderModel::getErrorInfo('收货失败,请稍候再试!'));
else{
try{
HookService::listen('store_product_order_take_delivery',$order,$id,false,OrderBehavior::class);
}catch (\Exception $e){
return Json::fail($e->getMessage());
}
StoreOrderStatus::setStatus($id,'take_delivery','已收货');
return Json::successful('收货成功!');
}
}
/**
* 修改退款状态
* @param $id
* @return \think\response\Json|void
*/
public function refund_y($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1){
$f = array();
$f[] = Form::input('order_id','退款单号',$product->getData('order_id'))->disabled(1);
$f[] = Form::number('refund_price','退款金额',$product->getData('pay_price'))->precision(2)->min(0.01);
$f[] = Form::radio('type','状态',1)->options([['label'=>'直接退款','value'=>1],['label'=>'退款后,返回原状态','value'=>2]]);
$form = Form::make_post_form('退款处理',$f,Url::build('updateRefundY',array('id'=>$id)),7);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
else return Json::fail('数据不存在!');
}
/**退款处理
* @param Request $request
* @param $id
*/
public function updateRefundY(Request $request, $id){
$data = Util::postMore([
'refund_price',
['type',1],
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['pay_price'] == $product['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
if(!$data['refund_price']) return Json::fail('请输入退款金额');
$refund_price = $data['refund_price'];
$data['refund_price'] = bcadd($data['refund_price'],$product['refund_price'],2);
$bj = bccomp((float)$product['pay_price'],(float)$data['refund_price'],2);
if($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
if($data['type'] == 1){
$data['refund_status'] = 2;
}else if($data['type'] == 2){
$data['refund_status'] = 0;
}
$type = $data['type'];
unset($data['type']);
$refund_data['pay_price'] = $product['pay_price'];
$refund_data['refund_price'] = $refund_price;
if($product['pay_type'] == 'weixin'){
if($product['is_channel']){//小程序
try{
HookService::listen('routine_pay_order_refund',$product['order_id'],$refund_data,true,PaymentBehavior::class);
}catch(\Exception $e){
return Json::fail($e->getMessage());
}
}else{
try{
HookService::listen('wechat_pay_order_refund',$product['order_id'],$refund_data,true,PaymentBehavior::class);
}catch(\Exception $e){
return Json::fail($e->getMessage());
}
}
}else if($product['pay_type'] == 'yue'){
ModelBasic::beginTrans();
$usermoney = User::where('uid',$product['uid'])->value('now_money');
$res1 = User::bcInc($product['uid'],'now_money',$refund_price,'uid');
$res2 = $res2 = UserBill::income('商品退款',$product['uid'],'now_money','pay_product_refund',$refund_price,$product['id'],bcadd($usermoney,$refund_price,2),'订单退款到余额'.floatval($refund_price).'元');
try{
HookService::listen('store_order_yue_refund',$product,$refund_data,false,OrderBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
$res = $res1 && $res2;
ModelBasic::checkTrans($res);
if(!$res) return Json::fail('余额退款失败!');
}
$resEdit = StoreOrderModel::edit($data,$id);
if($resEdit){
$data['type'] = $type;
if($data['type'] == 1) StorePink::setRefundPink($id);
try{
HookService::afterListen('store_product_order_refund_y',$data,$id,false,OrderBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元');
ModelBasic::commitTrans();
return Json::successful('修改成功!');
}else{
StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元失败');
return Json::successful('修改失败!');
}
}
public function order_info($oid = '')
{
if(!$oid || !($orderInfo = StoreOrderModel::get($oid)))
return $this->failed('订单不存在!');
$userInfo = User::getUserInfos($orderInfo['uid']);
if($userInfo['spread_uid']){
$spread = User::where('uid',$userInfo['spread_uid'])->value('nickname');
}else{
$spread ='';
}
$this->assign(compact('orderInfo','userInfo','spread'));
return $this->fetch();
}
public function express($oid = '')
{
if(!$oid || !($order = StoreOrderModel::get($oid)))
return $this->failed('订单不存在!');
if($order['delivery_type'] != 'express' || !$order['delivery_id']) return $this->failed('该订单不存在快递单号!');
$cacheName = $order['order_id'].$order['delivery_id'];
$result = CacheService::get($cacheName,null);
if($result === null || 1==1){
$result = Express::query($order['delivery_id']);
if(is_array($result) &&
isset($result['result']) &&
isset($result['result']['deliverystatus']) &&
$result['result']['deliverystatus'] >= 3)
$cacheTime = 0;
else
$cacheTime = 1800;
CacheService::set($cacheName,$result,$cacheTime);
}
$this->assign([
'order'=>$order,
'express'=>$result
]);
return $this->fetch();
}
/**
* 修改配送信息
* @param $id
* @return mixed|\think\response\Json|void
*/
public function distribution($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('order_id','退款单号',$product->getData('order_id'))->disabled(1);
if($product['delivery_type'] == 'send'){
$f[] = Form::input('delivery_name','送货人姓名',$product->getData('delivery_name'));
$f[] = Form::input('delivery_id','送货人电话',$product->getData('delivery_id'));
}else if($product['delivery_type'] == 'express'){
$f[] = Form::select('delivery_name','快递公司',$product->getData('delivery_name'))->setOptions(function (){
$list = Db::name('express')->where('is_show',1)->column('id,name');
$menus = [];
foreach ($list as $k=>$v){
$menus[] = ['value'=>$v,'label'=>$v];
}
return $menus;
});
$f[] = Form::input('delivery_id','快递单号',$product->getData('delivery_id'));
}
$form = Form::make_post_form('配送信息',$f,Url::build('updateDistribution',array('id'=>$id)),7);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**修改配送信息
* @param Request $request
* @param $id
*/
public function updateDistribution(Request $request, $id){
$data = Util::postMore([
'delivery_name',
'delivery_id',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['delivery_type'] == 'send'){
if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
}else if($product['delivery_type'] == 'express'){
if(!$data['delivery_name']) return Json::fail('请选择快递公司');
if(!$data['delivery_id']) return Json::fail('请输入快递单号');
}
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_distribution',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'distribution','修改发货信息为'.$data['delivery_name'].'号'.$data['delivery_id']);
return Json::successful('修改成功!');
}
/**
* 修改退款状态
* @param $id
* @return mixed|\think\response\Json|void
*/
public function refund_n($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f[] = Form::input('order_id','退款单号',$product->getData('order_id'))->disabled(1);
$f[] = Form::input('refund_reason','退款原因')->type('textarea');
$form = Form::make_post_form('退款',$f,Url::build('updateRefundN',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**不退款原因
* @param Request $request
* @param $id
*/
public function updateRefundN(Request $request, $id){
$data = Util::postMore([
'refund_reason',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if(!$data['refund_reason']) return Json::fail('请输入退款原因');
$data['refund_status'] = 0;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_refund_n',$data['refund_reason'],$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'refund_n','不退款原因:'.$data['refund_reason']);
return Json::successful('修改成功!');
}
/**
* 立即支付
* @param $id
*/
public function offline($id){
$res = StoreOrderModel::updateOffline($id);
if($res){
try{
HookService::listen('store_product_order_offline',$id,false,OrderBehavior::class);
}catch (Exception $e){
return Json::fail($e->getMessage());
}
StoreOrderStatus::setStatus($id,'offline','线下付款');
return Json::successful('修改成功!');
}else{
return Json::fail('修改失败!');
}
}
/**
* 修改积分和金额
* @param $id
* @return mixed|\think\response\Json|void
*/
public function integral_back($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1){
$f[] = Form::input('order_id','退款单号',$product->getData('order_id'))->disabled(1);
$f[] = Form::number('use_integral','使用的积分',$product->getData('use_integral'))->min(0)->disabled(1);
$f[] = Form::number('use_integrals','已退积分',$product->getData('back_integral'))->min(0)->disabled(1);
$f[] = Form::number('back_integral','可退积分',bcsub($product->getData('use_integral'),$product->getData('use_integral')))->min(0);
$form = Form::make_post_form('退积分',$f,Url::build('updateIntegralBack',array('id'=>$id)),7);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}else{
return Json::fail('参数错误!');
}
return $this->fetch('public/form-builder');
}
/** 退积分保存
* @param Request $request
* @param $id
*/
public function updateIntegralBack(Request $request, $id){
$data = Util::postMore([
'back_integral',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($data['back_integral'] <= 0) return Json::fail('请输入积分');
if($product['use_integral'] == $product['back_integral']) return Json::fail('已退完积分!不能再积分了');
$back_integral = $data['back_integral'];
$data['back_integral'] = bcadd($data['back_integral'],$product['back_integral'],2);
$bj = bccomp((float)$product['use_integral'],(float)$data['back_integral'],2);
if($bj < 0) return Json::fail('退积分大于支付积分,请修改退积分');
ModelBasic::beginTrans();
$integral = User::where('uid',$product['uid'])->value('integral');
$res1 = User::bcInc($product['uid'],'integral',$back_integral,'uid');
$res2 = UserBill::income('商品退积分',$product['uid'],'integral','pay_product_integral_back',$back_integral,$product['id'],bcadd($integral,$back_integral,2),'订单退积分'.floatval($back_integral).'积分到用户积分');
try{
HookService::listen('store_order_integral_back',$product,$back_integral,false,OrderBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
$res = $res1 && $res2;
ModelBasic::checkTrans($res);
if(!$res) return Json::fail('退积分失败!');
StoreOrderModel::edit($data,$id);
StoreOrderStatus::setStatus($id,'integral_back','商品退积分:'.$data['back_integral']);
return Json::successful('退积分成功!');
}
public function remark(Request $request){
$data = Util::postMore(['id','remark'],$request);
if(!$data['id']) return Json::fail('参数错误!');
if($data['remark'] == '') return Json::fail('请输入要备注的内容!');
$id = $data['id'];
unset($data['id']);
StoreOrderModel::edit($data,$id);
return Json::successful('备注成功!');
}
public function order_status($oid){
if(!$oid) return $this->failed('数据不存在');
$this->assign(StoreOrderStatus::systemPage($oid));
return $this->fetch();
}
}

View File

@ -1,583 +0,0 @@
<?php
namespace app\admin\controller\order;
use Api\Express;
use basic\ModelBasic;
use behavior\admin\OrderBehavior;
use behavior\wechat\PaymentBehavior;
use EasyWeChat\Core\Exception;
use service\CacheService;
use service\HookService;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Db;
use think\Request;
use think\Url;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\order\StoreOrderStatus;
use app\admin\model\ump\StorePink;
use app\admin\model\user\User;
use app\admin\model\user\UserBill;
use app\admin\model\order\StoreOrder as StoreOrderModel;
/**
* 订单管理控制器
* Class StoreOrder
* @package app\admin\controller\store
*/
class CombinationOrder extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$where = Util::getMore([
['status',''],
['real_name',''],
['is_del',0],
['data',''],
['combination_id',''],
['export',0],
['order','id desc']
],$this->request);
$limitTimeList = [
'yesterday'=>implode(' - ',[date('Y/m/d',strtotime('-1 day')),date('Y/m/d')]),
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
$this->assign(StoreOrderModel::systemPage($where,$this->adminId));
$this->assign('price',StoreOrderModel::getOrderPrice($where));
$this->assign(compact('where','limitTimeList'));
return $this->fetch();
}
public function orderchart(){
$where = Util::getMore([
['status',''],
['real_name',''],
['is_del',0],
['data',''],
['combination_id',''],
['export',0],
['order','id desc']
],$this->request);
$limitTimeList = [
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
if($where['data'] == '') $where['data'] = $limitTimeList['today'];
$orderCount = [
urlencode('未支付')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(0))->count(),
urlencode('未发货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(1))->count(),
urlencode('待收货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(2))->count(),
urlencode('待评价')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(3))->count(),
urlencode('交易完成')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(4))->count(),
urlencode('退款中')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-1))->count(),
urlencode('已退款')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-2))->count()
];
$model = StoreOrderModel::getOrderWhere($where,new StoreOrderModel())->field('sum(total_num) total_num,count(*) count,sum(total_price) total_price,sum(refund_price) refund_price,from_unixtime(add_time,\'%Y-%m-%d\') add_time')
->group('from_unixtime(add_time,\'%Y-%m-%d\')');
$orderPrice = $model->select()->toArray();
$orderDays = [];
$orderCategory = [
['name'=>'商品数','type'=>'line','data'=>[]],
['name'=>'订单数','type'=>'line','data'=>[]],
['name'=>'订单金额','type'=>'line','data'=>[]],
['name'=>'退款金额','type'=>'line','data'=>[]]
];
foreach ($orderPrice as $price){
$orderDays[] = $price['add_time'];
$orderCategory[0]['data'][] = $price['total_num'];
$orderCategory[1]['data'][] = $price['count'];
$orderCategory[2]['data'][] = $price['total_price'];
$orderCategory[3]['data'][] = $price['refund_price'];
}
$this->assign(StoreOrderModel::systemPage($where,$this->adminId));
$this->assign('price',StoreOrderModel::getOrderPrice($where));
$this->assign(compact('limitTimeList','where','orderCount','orderPrice','orderDays','orderCategory'));
return $this->fetch();
}
/**
* 修改支付金额等
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign([
'title'=>'修改订单','rules'=>$this->read($id)->getContent(),
'action'=>Url::build('update',array('id'=>$id))
]);
return $this->fetch('public/common_form');
}
public function read($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::text('order_id','订单编号',$product->getData('order_id'))->readonly();
Form::number('total_price','商品总价',$product->getData('total_price'))->min(0);
Form::number('total_postage','原始邮费',$product->getData('total_postage'))->min(0);
Form::number('pay_price','实际支付金额',$product->getData('pay_price'))->min(0);
Form::number('pay_postage','实际支付邮费',$product->getData('pay_postage'))->min(0);
Form::number('gain_integral','赠送积分',$product->getData('gain_integral'))->min(0);
return Form::builder();
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'order_id',
'total_price',
'total_postage',
'pay_price',
'pay_postage',
'gain_integral',
],$request);
if($data['total_price'] <= 0) return Json::fail('请输入商品总价');
if($data['pay_price'] <= 0) return Json::fail('请输入实际支付金额');
$data['order_id'] = StoreOrderModel::changeOrderId($data['order_id']);
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_edit',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'order_edit','修改商品总价为:'.$data['total_price'].' 实际支付金额'.$data['pay_price']);
return Json::successful('修改成功!');
}
/**
* 送货
* @param $id
* send
*/
public function delivery($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1 && $product['status'] == 0) {
$this->assign([
'title' => '送货信息', 'rules' => $this->readDelivery($id)->getContent(),
'action' => Url::build('updateDelivery', array('id' => $id))
]);
return $this->fetch('public/common_form');
}
else return Json::fail('数据不存在!');
}
public function readDelivery($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::text('delivery_name','送货人姓名');
Form::text('delivery_id','送货人电话')->number();
return Form::builder();
}
public function updateDelivery(Request $request, $id){
$data = Util::postMore([
'delivery_name',
'delivery_id',
],$request);
$data['delivery_type'] = 'send';
if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery','已配送 发货人:'.$data['delivery_name'].' 发货人电话:'.$data['delivery_id']);
return Json::successful('修改成功!');
}
/**
* 发货
* @param $id
* express
*/
public function deliver_goods($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1 && $product['status'] == 0){
$this->assign([
'title'=>'发货信息','rules'=>$this->readDeliveryGoods($id)->getContent(),
'action'=>Url::build('updateDeliveryGoods',array('id'=>$id))
]);
return $this->fetch('public/common_form');
}
else return Json::fail('数据不存在!');
}
public function readDeliveryGoods($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::select('delivery_name','快递公司',function(){
$list = Db::name('express')->where('is_show',1)->order('sort DESC')->column('id,name');
$menus = [];
foreach ($list as $k=>$v){
$menus[] = ['value'=>$v,'label'=>$v];
}
return $menus;
})->filterable();
Form::text('delivery_id','快递单号');
return Form::builder();
}
public function updateDeliveryGoods(Request $request, $id){
$data = Util::postMore([
'delivery_name',
'delivery_id',
],$request);
$data['delivery_type'] = 'express';
if(!$data['delivery_name']) return Json::fail('请选择快递公司');
if(!$data['delivery_id']) return Json::fail('请输入快递单号');
$data['status'] = 1;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_delivery_goods',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'delivery_goods','已发货 快递公司:'.$data['delivery_name'].' 快递单号:'.$data['delivery_id']);
return Json::successful('修改成功!');
}
/**
* 修改状态为已收货
* @param $id
* @return \think\response\Json|void
*/
public function take_delivery($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['status'] == 2) return Json::fail('不能重复收货!');
if($product['paid'] == 1 && $product['status'] == 1) $data['status'] = 2;
else if($product['pay_type'] == 'offline') $data['status'] = 2;
else return Json::fail('请先发货或者送货!');
if(!StoreOrderModel::edit($data,$id))
return Json::fail(StoreOrderModel::getErrorInfo('收货失败,请稍候再试!'));
else{
try{
HookService::listen('store_product_order_take_delivery',$data,$id,false,OrderBehavior::class);
}catch (Exception $e){
return Json::fail($e->getMessage());
}
StoreOrderStatus::setStatus($id,'take_delivery','已收货');
return Json::successful('收货成功!');
}
}
/**
* 修改退款状态
* @param $id
* @return \think\response\Json|void
*/
public function refund_y($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1){
$this->assign([
'title'=>'退款','rules'=>$this->readRefundY($id)->getContent(),
'action'=>Url::build('updateRefundY',array('id'=>$id))
]);
return $this->fetch('public/common_form');
}
else return Json::fail('数据不存在!');
}
public function readRefundY($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::text('order_id','退款单号',$product->getData('order_id'))->readonly();
Form::number('refund_price','退款金额',$product->getData('pay_price'))->min(0);
Form::radio('type','状态',[['label'=>'直接退款','value'=>1],['label'=>'退款后,返回原状态','value'=>2]],1);
return Form::builder();
}
public function updateRefundY(Request $request, $id){
$data = Util::postMore([
'refund_price',
['type',1],
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['pay_price'] == $product['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
if(!$data['refund_price']) return Json::fail('请输入退款金额');
$refund_price = $data['refund_price'];
$data['refund_price'] = bcadd($data['refund_price'],$product['refund_price'],2);
$bj = bccomp((float)$product['pay_price'],(float)$data['refund_price'],2);
if($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
if($data['type'] == 1){
$data['refund_status'] = 2;
}else if($data['type'] == 2){
$data['refund_status'] = 0;
}
$type = $data['type'];
unset($data['type']);
$refund_data['pay_price'] = $product['pay_price'];
$refund_data['refund_price'] = $refund_price;
if($product['pay_type'] == 'weixin'){
try{
HookService::listen('wechat_pay_order_refund',$product['order_id'],$refund_data,true,PaymentBehavior::class);
}catch(\Exception $e){
return Json::fail($e->getMessage());
}
}else if($product['pay_type'] == 'yue'){
ModelBasic::beginTrans();
$usermoney = User::where('uid',$product['uid'])->value('now_money');
$res1 = User::bcInc($product['uid'],'now_money',$refund_price,'uid');
$res2 = $res2 = UserBill::income('商品退款',$product['uid'],'now_money','pay_product_refund',$refund_price,$product['id'],bcadd($usermoney,$refund_price,2),'订单退款到余额'.floatval($refund_price).'元');
try{
HookService::listen('store_order_yue_refund',$product,$refund_data,false,OrderBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
$res = $res1 && $res2;
ModelBasic::checkTrans($res);
if(!$res) return Json::fail('余额退款失败!');
}
$resEdit = StoreOrderModel::edit($data,$id);
if($resEdit){
$data['type'] = $type;
if($data['type'] == 1) StorePink::setRefundPink($id);
HookService::afterListen('store_product_order_refund_y',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元');
return Json::successful('修改成功!');
}else{
StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元失败');
return Json::successful('修改失败!');
}
}
public function order_info($oid = '')
{
if(!$oid || !($orderInfo = StoreOrderModel::get($oid)))
return $this->failed('订单不存在!');
$userInfo = User::getUserInfo($orderInfo['uid']);
if($userInfo['spread_uid']){
$spread = User::where('uid',$userInfo['spread_uid'])->value('nickname');
}else{
$spread ='';
}
$this->assign(compact('orderInfo','userInfo','spread'));
return $this->fetch();
}
public function express($oid = '')
{
if(!$oid || !($order = StoreOrderModel::get($oid)))
return $this->failed('订单不存在!');
if($order['delivery_type'] != 'express' || !$order['delivery_id']) return $this->failed('该订单不存在快递单号!');
$cacheName = $order['order_id'].$order['delivery_id'];
$result = CacheService::get($cacheName,null);
if($result === null){
$result = Express::query($order['delivery_id']);
if(is_array($result) &&
isset($result['result']) &&
isset($result['result']['deliverystatus']) &&
$result['result']['deliverystatus'] >= 3)
$cacheTime = 0;
else
$cacheTime = 1800;
CacheService::set($cacheName,$result,$cacheTime);
}
$this->assign([
'order'=>$order,
'express'=>$result
]);
return $this->fetch();
}
/**
* 修改配送信息
* @param $id
* @return mixed|\think\response\Json|void
*/
public function distribution($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign([
'title'=>'配送信息','rules'=>$this->readDistribution($id)->getContent(),
'action'=>Url::build('updateDistribution',array('id'=>$id))
]);
return $this->fetch('public/common_form');
}
public function readDistribution($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['delivery_type'] == 'send'){
Form::text('delivery_name','送货人姓名',$product->getData('delivery_name'));
Form::text('delivery_id','送货人电话',$product->getData('delivery_id'))->number();
}else if($product['delivery_type'] == 'express'){
Form::select('delivery_name','快递公司',function(){
$list = Db::name('express')->where('is_show',1)->column('id,name');
$menus = [];
foreach ($list as $k=>$v){
$menus[] = ['value'=>$v,'label'=>$v];
}
return $menus;
},$product->getData('delivery_name'))->filterable();
Form::text('delivery_id','快递单号',$product->getData('delivery_id'));
}
return Form::builder();
}
public function updateDistribution(Request $request, $id){
$data = Util::postMore([
'delivery_name',
'delivery_id',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['delivery_type'] == 'send'){
if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
}else if($product['delivery_type'] == 'express'){
if(!$data['delivery_name']) return Json::fail('请选择快递公司');
if(!$data['delivery_id']) return Json::fail('请输入快递单号');
}
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_distribution',$data,$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'distribution','修改发货信息为'.$data['delivery_name'].'号'.$data['delivery_id']);
return Json::successful('修改成功!');
}
/**
* 修改退款状态
* @param $id
* @return mixed|\think\response\Json|void
*/
public function refund_n($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign([
'title'=>'退款','rules'=>$this->readRefundN($id)->getContent(),
'action'=>Url::build('updateRefundN',array('id'=>$id))
]);
return $this->fetch('public/common_form');
}
public function readRefundN($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::text('order_id','退款单号',$product->getData('order_id'))->readonly();
Form::textarea('refund_reason','退款原因');
return Form::builder();
}
public function updateRefundN(Request $request, $id){
$data = Util::postMore([
'refund_reason',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if(!$data['refund_reason']) return Json::fail('请输入退款原因');
$data['refund_status'] = 0;
StoreOrderModel::edit($data,$id);
HookService::afterListen('store_product_order_refund_n',$data['refund_reason'],$id,false,OrderBehavior::class);
StoreOrderStatus::setStatus($id,'refund_n','不退款原因:'.$data['refund_reason']);
return Json::successful('修改成功!');
}
/**
* 立即支付
* @param $id
*/
public function offline($id){
$res = StoreOrderModel::updateOffline($id);
if($res){
try{
HookService::listen('store_product_order_offline',$id,false,OrderBehavior::class);
}catch (Exception $e){
return Json::fail($e->getMessage());
}
StoreOrderStatus::setStatus($id,'offline','线下付款');
return Json::successful('修改成功!');
}else{
return Json::fail('修改失败!');
}
}
/**
* 修改积分和金额
* @param $id
* @return mixed|\think\response\Json|void
*/
public function integral_back($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['paid'] == 1){
$this->assign([
'title'=>'退积分','rules'=>$this->readIntegralBack($id)->getContent(),
'action'=>Url::build('updateIntegralBack',array('id'=>$id))
]);
}else{
return Json::fail('参数错误!');
}
return $this->fetch('public/common_form');
}
public function readIntegralBack($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
Form::text('order_id','退积分单号',$product->getData('order_id'))->readonly();
Form::number('back_integral','退积分')->min(0);
return Form::builder();
}
public function updateIntegralBack(Request $request, $id){
$data = Util::postMore([
'back_integral',
],$request);
if(!$id) return $this->failed('数据不存在');
$product = StoreOrderModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($data['back_integral'] <= 0) return Json::fail('请输入积分');
if($product['use_integral'] == $product['back_integral']) return Json::fail('已退完积分!不能再积分了');
$back_integral = $data['back_integral'];
$data['back_integral'] = bcadd($data['back_integral'],$product['back_integral'],2);
$bj = bccomp((float)$product['use_integral'],(float)$data['back_integral'],2);
if($bj < 0) return Json::fail('退积分大于支付积分,请修改退积分');
ModelBasic::beginTrans();
$integral = User::where('uid',product['uid'])->value('integral');
$res1 = User::bcInc($product['uid'],'integral',$back_integral,'uid');
$res2 = UserBill::income('商品退积分',$product['uid'],'integral','pay_product_integral_back',$back_integral,$product['id'],bcadd($integral,$back_integral,2),'订单退积分'.floatval($back_integral).'积分到用户积分');
try{
HookService::listen('store_order_integral_back',$product,$back_integral,false,OrderBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
$res = $res1 && $res2;
ModelBasic::checkTrans($res);
if(!$res) return Json::fail('退积分失败!');
StoreOrderModel::edit($data,$id);
StoreOrderStatus::setStatus($id,'integral_back','商品退积分:'.$data['back_integral']);
return Json::successful('退积分成功!');
}
public function remark(Request $request){
$data = Util::postMore(['id','remark'],$request);
if(!$data['id']) return Json::fail('参数错误!');
if($data['remark'] == '') return Json::fail('请输入要备注的内容!');
$id = $data['id'];
unset($data['id']);
StoreOrderModel::edit($data,$id);
return Json::successful('备注成功!');
}
public function order_status($oid){
if(!$oid) return $this->failed('数据不存在');
$this->assign(StoreOrderStatus::systemPage($oid));
return $this->fetch();
}
}

View File

@ -1,604 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: xurongyao <763569752@qq.com>
* Date: 2018/6/14 下午5:25
*/
namespace app\admin\controller\record;
use app\admin\controller\AuthController;
use app\admin\model\store\StoreProduct;
use app\admin\model\order\StoreOrder;
use app\admin\model\ump\StoreBargain;
use app\admin\model\ump\StoreSeckill;
use app\admin\model\ump\StoreCombination;
use service\JsonService;
use service\UtilService as Util;
use app\admin\model\user\User;
use app\admin\model\user\UserBill;
use app\admin\model\user\UserExtract;
use app\admin\model\store\StoreCouponUser;
/**
* 微信充值记录
* Class UserRecharge
* @package app\admin\controller\user
*/
class Record extends AuthController
{
/**
* 显示操作记录
*/
public function index(){
}
/**
* 显示订单记录
*/
public function chart_order(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
public function get_echarts_order(){
$where=Util::getMore([
['type',''],
['status',''],
['data',''],
]);
return JsonService::successful(StoreOrder::getEchartsOrder($where));
}
/**
* 显示产品记录
*/
public function chart_product(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取产品曲线图数据
*/
public function get_echarts_product($type='',$data=''){
return JsonService::successful(StoreProduct::getChatrdata($type,$data));
}
/**
* 获取销量
*/
public function get_echarts_maxlist($data=''){
return JsonService::successful(StoreProduct::getMaxList(compact('data')));
}
/**
* 获取利润
*/
public function get_echarts_profity($data=''){
return JsonService::successful(StoreProduct::ProfityTop10(compact('data')));
}
/**
* 获取缺货列表
*/
public function getLackList(){
$where=Util::getMore([
['page',1],
['limit',20],
]);
return JsonService::successlayui(StoreProduct::getLackList($where));
}
/**
* 表单快速修改
*/
public function editField($id=''){
$post=$this->request->post();
StoreProduct::beginTrans();
try{
StoreProduct::edit($post,$id);
StoreProduct::commitTrans();
return JsonService::successful('修改成功');
}catch (\Exception $e){
StoreProduct::rollbackTrans();
return JsonService::fail($e->getMessage());
}
}
//获取差评
public function getnegativelist(){
$where=Util::getMore([
['page',1],
['limit',10],
]);
return JsonService::successful(StoreProduct::getnegativelist($where));
}
/**
* 获取退货
*/
public function getTuiPriesList(){
return JsonService::successful(StoreProduct::TuiProductList());
}
//营销统计
/**
* 显示积分统计
*/
public function chart_score(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取积分头部信息
*/
public function getScoreBadgeList($data=''){
return JsonService::successful(UserBill::getScoreBadgeList(compact('data')));
}
/**
* 获取积分曲线图和柱状图
*/
public function getScoreCurve($data='',$limit=20){
return JsonService::successful(UserBill::getScoreCurve(compact('data','limit')));
}
/**
* 显示优惠券统计
*/
public function chart_coupon(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取优惠劵头部信息
*/
public function getCouponBadgeList($data=''){
return JsonService::successful(StoreCouponUser::getCouponBadgeList(compact('data')));
}
/**
* 获取优惠劵数据图表
*/
public function getConponCurve($data=''){
return JsonService::successful(StoreCouponUser::getConponCurve(compact('data')));
}
/**
* 显示拼团统计
*/
public function chart_combination(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 显示砍价统计
*/
public function chart_bargain(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 显示秒杀统计
*/
public function chart_seckill(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
//财务统计
/**
* 显示反佣统计
*/
public function chart_rebate(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
//获取用户返佣柱状图
public function getUserBillBrokerage($data=''){
return JsonService::successful(UserBill::getUserBillChart(compact('data')));
}
//获取用户返佣头部信息
public function getRebateBadge($data=''){
return JsonService::successful(UserBill::getRebateBadge(compact('data')));
}
//获得 返佣列表,带分页
public function getFanList($page=1,$limit=20){
return JsonService::successful(UserBill::getFanList(compact('page','limit')));
}
//获得 返佣总次数
public function getFanCount(){
return JsonService::successful(UserBill::getFanCount());
}
/**
* 显示充值统计
*/
public function chart_recharge(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取用户充值柱状图和曲线图
*/
public function getEchartsRecharge($data=''){
return JsonService::successful(UserBill::getEchartsRecharge(compact('data')));
}
/**
* 显示提现统计
*/
public function chart_cash(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
//获取提现头部信息
public function getExtractHead($data=''){
return JsonService::successful(UserExtract::getExtractHead(compact('data')));
}
//会员统计
/**
* 显示用户统计
*/
public function user_chart(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取头部信息
*
* 人数 增长 分销人数 分销增长
*/
public function getBadgeList($data='',$is_promoter='',$status=''){
return JsonService::successful(User::getBadgeList(compact('data','is_promoter','status')));
}
/*
* 获取用户增长曲线图
*
*/
public function getUserChartList($data='',$is_promoter='',$status=''){
return JsonService::successful(User::getUserChartList(compact('data','is_promoter','status')));
}
/*
* 获取提现分布图和提现人数金额曲线图
*
*/
public function getExtractData($data=''){
return JsonService::successful(UserExtract::getExtractList(compact('data')));
}
/*
* 分销会员统计
*
*/
public function user_distribution_chart(){
$limit=10;
$top10list=User::getUserDistributionTop10List($limit);
$this->assign([
'is_layui'=>true,
'limit'=>$limit,
'year'=>getMonth('y'),
'commissionList'=>$top10list['commission'],
'extractList'=>$top10list['extract'],
]);
return $this->fetch();
}
/*
* 获取分销会员统计会员头部详情
*
*/
public function getDistributionBadgeList($data=''){
return JsonService::successful(User::getDistributionBadgeList(compact('data')));
}
/*
* 获取分销会员统计图表数据
*
* $data 时间范围
*
*/
public function getUserDistributionChart($data=''){
return JsonService::successful(User::getUserDistributionChart(compact('data')));
}
/**
* 会员业务
*/
public function user_business_chart(){
$limit=10;
$top10list=User::getUserTop10List($limit);
$this->assign([
'is_layui'=>true,
'limit'=>$limit,
'year'=>getMonth('y'),
'integralList'=>$top10list['integral'],
'moneyList'=>$top10list['now_money'],
'shopcountList'=>$top10list['shopcount'],
'orderList'=>$top10list['order'],
'lastorderList'=>$top10list['lastorder']
]);
return $this->fetch();
}
/*
* 获取 会员业务的
* 购物会员统计
* 分销商业务人数和提现人数统计
* 分销商业务佣金和提现金额统计
* 曲线图
* $data 时间
*/
public function getUserBusinessChart($data=''){
return JsonService::successful(User::getUserBusinessChart(compact('data')));
}
/*
* 获取 会员业务
* 会员总余额 分销商总佣金 分销商总佣金余额 分销商总提现佣金 本月分销商业务佣金 本月分销商佣金提现金额
* 上月分销商业务佣金 上月分销商佣金提现金额
* $where 查询条件
*
* return array
*/
public function getUserBusinesHeade($data){
return JsonService::successful(User::getUserBusinesHeade(compact('data')));
}
/**
* 显示用户属性统计
*/
public function user_attr(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
/**
* 获取用户属性统计
*/
public function getEchartsData($data=''){
return JsonService::successful(User::getEchartsData(compact('data')));
}
//排行榜
/**
* 显示产品排行榜
*/
public function ranking_saleslists(){
$this->assign([
'is_layui'=>true,
]);
return $this->fetch();
}
/*
*获取产品排行 带分页
*/
public function getSaleslists($start_time='',$end_time='',$title='',$page=1,$limit=20){
return JsonService::successlayui(StoreProduct::getSaleslists(compact('start_time','end_time','title','page','limit')));
}
/*
*生成表格,并下载
*/
public function save_product_export($start_time='',$end_time='',$title=''){
return JsonService::successlayui(StoreProduct::SaveProductExport(compact('start_time','end_time','title')));
}
/*
*获取单个商品的详情
*/
public function product_info($id=''){
if($id=='') $this->failed('缺少商品id');
if(!StoreProduct::be(['id'=>$id])) return $this->failed('商品不存在!');
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y'),
'id'=>$id,
]);
return $this->fetch();
}
/*
*获取单个商品的详情头部信息
*/
public function getProductBadgeList($id='',$data=''){
return JsonService::successful(StoreProduct::getProductBadgeList($id,$data));
}
/*
*获取单个商品的销售曲线图
*/
public function getProductCurve($id='',$data='',$limit=20){
return JsonService::successful(StoreProduct::getProductCurve(compact('id','data','limit')));
}
/*
*获取单个商品的销售总条数
*/
public function getProductCount($id,$data=''){
return JsonService::successful(StoreProduct::setWhere(compact('data'))
->where('a.product_id',$id)
->join('user c','c.uid=a.uid')
->where('a.is_pay',1)
->count());
}
/*
*获取单个商品的销售列表
*/
public function getSalelList($data='',$id=0,$page=1,$limit=20){
return JsonService::successful(StoreProduct::getSalelList(compact('data','id','page','limit')));
}
/**
* 显示反佣排行榜
*/
public function ranking_commission(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
public function getcommissionlist($page=1,$limit=20){
return JsonService::successful(UserExtract::where('status',1)
->field(['real_name','extract_price','balance'])
->order('extract_price desc')
->page($page,$limit)
->select());
}
public function getmonthcommissionlist($page=1,$limit=20){
return JsonService::successful(UserExtract::where('status',1)
->whereTime('add_time','month')
->field(['real_name','extract_price','balance'])
->order('extract_price desc')
->page($page,$limit)
->select());
}
//获取佣金返现总条数
public function getCommissonCount(){
return JsonService::successful(UserExtract::where('status',1)->count());
}
//获取本月佣金返现条数
public function getMonthCommissonCount(){
return JsonService::successful(UserExtract::where('status',1)->whereTime('add_time','month')->count());
}
/**
* 显示积分排行榜
*/
public function ranking_point(){
$this->assign([
'is_layui'=>true,
'year'=>getMonth('y')
]);
return $this->fetch();
}
//获取所有积分排行总人数
public function getPountCount(){
return JsonService::successful(User::where(['status'=>1])->where('integral','neq',0)->count());
}
//获取积分排行列表
public function getpointList($page=1,$limit=20){
return JsonService::successful(($list=User::where(['status'=>1])
->where('integral','neq',0)
->field(['nickname','integral'])
->order('integral desc')
->page($page,$limit)
->select()) && count($list) ? $list->toArray():[]);
}
//获取本月积分排行别表
public function getMonthpountList($page=1,$limit=20){
return JsonService::successful(($list=User::where('status',1)
->where('integral','neq',0)
->whereTime('add_time','month')
->order('integral desc')
->field(['nickname','integral'])
->page($page,$limit)
->select()) && count($list) ? $list->toArray():[]);
}
public function getMonthPountCount(){
return JsonService::successful(User::where('status',1)->where('integral','neq',0)->whereTime('add_time','month')->count());
}
/**
*
* 显示下级会员排行榜
*/
public function ranking_lower(){
echo " 复购率 复购增长率 活跃度 活跃率 分销总金额 增长率 消费会员 非消费会员 消费排行榜 积分排行榜 余额排行榜 分销总金额排行榜 分销人数排行榜 分销余额排行榜 购物金额排行榜 购物次数排行榜 提现排行榜 ";
}
/**
* 获取砍价产品曲线图数据
*/
public function get_mark_echarts_product($type='',$data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::getChatrdata($type,$data));
if($model) return JsonService::successful(StoreSeckill::getChatrdata($type,$data));
}
/**
* 获取拼团产品曲线图数据
*/
public function get_combination_echarts_product($type='',$data=''){
return JsonService::successful(StoreCombination::getChatrdata($type,$data));
}
/*
* 获取拼团销量
*/
public function get_combination_maxlist($data=''){
return JsonService::successful(StoreCombination::getMaxList(compact('data')));
}
/*
* 拼团盈利
*/
public function get_combination_profity($data=''){
return JsonService::successful(StoreCombination::ProfityTop10(compact('data')));
}
/*
* 拼团退货
*/
public function get_combination_refund_list(){
$where = Util::getMore([
['page',1],
['limit',20],
]);
return JsonService::successlayui(StoreCombination::getBargainRefundList($where));
}
/**
* 获取销量
*/
public function get_mark_echarts_maxlist($data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::getMaxList(compact('data')));
if($model) return JsonService::successful(StoreSeckill::getMaxList(compact('data')));
}
/**
* 获取利润
*/
public function get_mark_echarts_profity($data='',$model = 0){
if(!$model) return JsonService::successful(StoreBargain::ProfityTop10(compact('data')));
if($model) return JsonService::successful(StoreSeckill::ProfityTop10(compact('data')));
}
/**
* 获取补货的砍价产品
*/
public function get_mark_lack_list($model = 0){
$where = Util::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getLackList($where));
if($model) return JsonService::successlayui(StoreSeckill::getLackList($where));
}
/**
* 获取砍价产品的评论
*/
public function get_mark_negative_list($model = 0){
$where = Util::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getNegativeList($where));
if($model) return JsonService::successlayui(StoreSeckill::getNegativeList($where));
}
/**
* 获取砍价产品的退货
*/
public function get_mark_bargain_refund_list($model = 0){
$where = Util::getMore([
['page',1],
['limit',20],
]);
if(!$model) return JsonService::successlayui(StoreBargain::getBargainRefundList($where));
if($model) return JsonService::successlayui(StoreSeckill::getBargainRefundList($where));
}
}

View File

@ -1,83 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/16 0016
* Time: 10:39
*/
namespace app\admin\controller\record;
use app\admin\controller\AuthController;
use service\UtilService as Util;
use app\admin\model\record\StoreStatistics as StatisticsModel;
class StoreStatistics extends AuthController
{
/**
* 显示列表
*/
public function index()
{
$where = Util::getMore([
['date',''],
['export',''],
['data','']
],$this->request);
$where['date']=$this->request->param('date');
$where['data']=$this->request->param('data');
$where['export']=$this->request->param('export');
$trans=StatisticsModel::trans();//最近交易
$seckill=StatisticsModel::getSeckill($where);//秒杀商品
$ordinary=StatisticsModel::getOrdinary($where);//普通商品
$pink=StatisticsModel::getPink($where);//拼团商品
$recharge=StatisticsModel::getRecharge($where);//充值
$extension=StatisticsModel::getExtension($where);//推广金
$orderCount = [
urlencode('微信支付')=>StatisticsModel::getTimeWhere($where,StatisticsModel::statusByWhere('weixin'))->count(),
urlencode('余额支付')=>StatisticsModel::getTimeWhere($where,StatisticsModel::statusByWhere('yue'))->count(),
urlencode('线下支付')=>StatisticsModel::getTimeWhere($where,StatisticsModel::statusByWhere('offline'))->count(),
];
$Statistic = [
['name'=>'营业额','type'=>'line','data'=>[]],
['name'=>'支出','type'=>'line','data'=>[]],
['name'=>'盈利','type'=>'line','data'=>[]],
];
$orderinfos=StatisticsModel::getOrderInfo($where);
$orderinfo=$orderinfos['orderinfo'];
$orderDays=[];
if (empty($orderinfo)){
$orderDays[]=date('Y-m-d',time());
$Statistic[0]['data'][] = 0;
$Statistic[1]['data'][] = 0;
$Statistic[2]['data'][] = 0;
}
foreach($orderinfo as $info){
$orderDays[]=$info['pay_time'];
$Statistic[0]['data'][] = $info['total_price']+$info['pay_postage'];
$Statistic[1]['data'][] = $info['coupon_price']+$info['deduction_price']+$info['cost'];
$Statistic[2]['data'][] = ($info['total_price']+$info['pay_postage'])-($info['coupon_price']+$info['deduction_price']+$info['cost']);
}
$price=$orderinfos['price']+$orderinfos['postage'];
$cost=$orderinfos['deduction']+$orderinfos['coupon']+$orderinfos['cost'];
$Consumption=StatisticsModel::getConsumption($where)['number'];
$header=[
['name'=>'总营业额', 'class'=>'fa-line-chart', 'value'=>'¥'.$price, 'color'=>'red'],
['name'=>'总支出', 'class'=>'fa-area-chart', 'value'=>'¥'.($cost+$extension), 'color'=>'lazur'],
['name'=>'总盈利', 'class'=>'fa-bar-chart', 'value'=>'¥'.bcsub($price,$cost,0), 'color'=>'navy'],
['name'=>'新增消费', 'class'=>'fa-pie-chart', 'value'=>'¥'.($Consumption==0?0:$Consumption), 'color'=>'yellow']
];
$data=[
['value'=>$orderinfos['cost'], 'name'=>'商品成本'],
['value'=>$orderinfos['coupon'], 'name'=>'优惠券抵扣'],
['value'=>$orderinfos['deduction'], 'name'=>'积分抵扣'],
['value'=>$extension, 'name'=>'推广人佣金']
];
$this->assign(StatisticsModel::systemTable($where));
$this->assign(compact('where','trans','orderCount','orderDays','header','Statistic','ordinary','pink','recharge','data','seckill'));
$this->assign('price',StatisticsModel::getOrderPrice($where));
return $this->fetch();
}
}

View File

@ -1,116 +0,0 @@
<?php
namespace app\admin\controller\routine;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\routine\RoutineTemplate as RoutineTemplateModel;
/**
* 小程序模板消息控制器
* Class RoutineTemplate
* @package app\admin\controller\routine
*/
class RoutineTemplate extends AuthController
{
public function index()
{
$where = Util::getMore([
['name',''],
['status','']
],$this->request);
$this->assign('where',$where);
$this->assign(RoutineTemplateModel::SystemPage($where));
return $this->fetch();
}
/**
* 添加模板消息
* @return mixed
*/
public function create()
{
$f = array();
$f[] = Form::input('tempkey','模板编号');
$f[] = Form::input('tempid','模板ID');
$f[] = Form::input('name','模板名');
$f[] = Form::input('content','回复内容')->type('textarea');
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加模板消息',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function save(Request $request)
{
$data = Util::postMore([
'tempkey',
'tempid',
'name',
'content',
['status',0]
],$request);
if($data['tempkey'] == '') return Json::fail('请输入模板编号');
if($data['tempkey'] != '' && RoutineTemplateModel::be($data['tempkey'],'tempkey'))
return Json::fail('请输入模板编号已存在,请重新输入');
if($data['tempid'] == '') return Json::fail('请输入模板ID');
if($data['name'] == '') return Json::fail('请输入模板名');
if($data['content'] == '') return Json::fail('请输入回复内容');
$data['add_time'] = time();
RoutineTemplateModel::set($data);
return Json::successful('添加模板消息成功!');
}
/**
* 编辑模板消息
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = RoutineTemplateModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('tempkey','模板编号',$product->getData('tempkey'))->disabled(1);
$f[] = Form::input('name','模板名',$product->getData('name'))->disabled(1);
$f[] = Form::input('tempid','模板ID',$product->getData('tempid'));
$f[] = Form::radio('status','状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('编辑模板消息',$f,Url::build('update',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'tempid',
['status',0]
],$request);
if($data['tempid'] == '') return Json::fail('请输入模板ID');
if(!$id) return $this->failed('数据不存在');
$product = RoutineTemplateModel::get($id);
if(!$product) return Json::fail('数据不存在!');
RoutineTemplateModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除模板消息
* @param $id
* @return \think\response\Json
*/
public function delete($id)
{
if(!$id) return Json::fail('数据不存在!');
if(!RoutineTemplateModel::del($id))
return Json::fail(RoutineTemplateModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,215 +0,0 @@
<?php
namespace app\admin\controller\setting;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use app\admin\model\system\SystemRole;
use think\Url;
use app\admin\model\system\SystemAdmin as AdminModel;
/**
* 管理员列表控制器
* Class SystemAdmin
* @package app\admin\controller\system
*/
class SystemAdmin extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$admin = $this->adminInfo;
$where = Util::getMore([
['name',''],
['roles',''],
['level',bcadd($admin->level,1,0)]
],$this->request);
$this->assign('where',$where);
$this->assign('role',SystemRole::getRole(bcadd($admin->level,1,0)));
$this->assign(AdminModel::systemPage($where));
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
$admin = $this->adminInfo;
$f = array();
$f[] = Form::input('account','管理员账号');
$f[] = Form::input('pwd','管理员密码')->type('password');
$f[] = Form::input('conf_pwd','确认密码')->type('password');
$f[] = Form::input('real_name','管理员姓名');
$f[] = Form::select('roles','管理员身份')->setOptions(function ()use($admin){
$list = SystemRole::getRole(bcadd($admin->level,1,0));
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
})->multiple(1);
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加管理员',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
'account',
'conf_pwd',
'pwd',
'real_name',
['roles',[]],
['status',0]
],$request);
if(!$data['account']) return Json::fail('请输入管理员账号');
if(!$data['roles']) return Json::fail('请选择至少一个管理员身份');
if(!$data['pwd']) return Json::fail('请输入管理员登陆密码');
if($data['pwd'] != $data['conf_pwd']) return Json::fail('两次输入密码不想同');
if(AdminModel::be($data['account'],'account')) return Json::fail('管理员账号已存在');
$data['pwd'] = md5($data['pwd']);
unset($data['conf_pwd']);
$data['level'] = $this->adminInfo['level'] + 1;
AdminModel::set($data);
return Json::successful('添加管理员成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
if(!$id) return $this->failed('参数错误');
$admin = AdminModel::get($id);
if(!$admin) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('account','管理员账号',$admin->account);
$f[] = Form::input('pwd','管理员密码')->type('password');
$f[] = Form::input('conf_pwd','确认密码')->type('password');
$f[] = Form::input('real_name','管理员姓名',$admin->real_name);
$f[] = Form::select('roles','管理员身份',explode(',',$admin->roles))->setOptions(function ()use($admin){
$list = SystemRole::getRole($admin->level);
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
})->multiple(1);
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('编辑管理员',$f,Url::build('update',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'account',
'conf_pwd',
'pwd',
'real_name',
['roles',[]],
['status',0]
],$request);
if(!$data['account']) return Json::fail('请输入管理员账号');
if(!$data['roles']) return Json::fail('请选择至少一个管理员身份');
if(!$data['pwd'])
unset($data['pwd']);
else{
if(isset($data['pwd']) && $data['pwd'] != $data['conf_pwd']) return Json::fail('两次输入密码不想同');
$data['pwd'] = md5($data['pwd']);
}
if(AdminModel::where('account',$data['account'])->where('id','<>',$id)->count()) return Json::fail('管理员账号已存在');
unset($data['conf_pwd']);
AdminModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id)
return JsonService::fail('删除失败!');
if(AdminModel::edit(['is_del'=>1,'status'=>0],$id,'id'))
return JsonService::successful('删除成功!');
else
return JsonService::fail('删除失败!');
}
/**
* 个人资料 展示
* */
public function adminInfo(){
$adminInfo = $this->adminInfo;//获取当前登录的管理员
$this->assign('adminInfo',$adminInfo);
return $this->fetch();
}
/**保存信息
* @param Request $request
*/
public function setAdminInfo(Request $request){
$adminInfo = $this->adminInfo;//获取当前登录的管理员
if($request->isPost()){
$data = Util::postMore([
['new_pwd',''],
['new_pwd_ok',''],
['pwd',''],
'real_name',
],$request);
// if ($data['pwd'] == '') unset($data['pwd']);
if($data['pwd'] != ''){
$pwd = md5($data['pwd']);
if($adminInfo['pwd'] != $pwd) return Json::fail('原始密码错误');
}
if($data['new_pwd'] != ''){
if(!$data['new_pwd_ok']) return Json::fail('请输入确认新密码');
if($data['new_pwd'] != $data['new_pwd_ok']) return Json::fail('俩次密码不一样');
}
if($data['pwd'] != '' && $data['new_pwd'] != ''){
$data['pwd'] = md5($data['new_pwd']);
}else{
unset($data['pwd']);
}
unset($data['new_pwd']);
unset($data['new_pwd_ok']);
AdminModel::edit($data,$adminInfo['id']);
return Json::successful('修改成功!,请重新登录');
}
}
}

View File

@ -1,334 +0,0 @@
<?php
namespace app\admin\controller\setting;
use think\Url;
use service\FormBuilder as Form;
use think\Request;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemConfig as ConfigModel;
/**
* 配置列表控制器
* Class SystemConfig
* @package app\admin\controller\system
*/
class SystemConfig extends AuthController
{
/**
* 基础配置
* */
public function index(){
$type = input('type')!=0?input('type'):0;
$tab_id = input('tab_id');
if(!$tab_id) $tab_id = 1;
$this->assign('tab_id',$tab_id);
$list = ConfigModel::getAll($tab_id);
if($type==3){//其它分类
$config_tab = null;
}else{
$config_tab = ConfigModel::getConfigTabAll($type);
foreach ($config_tab as $kk=>$vv){
$arr = ConfigModel::getAll($vv['value'])->toArray();
if(empty($arr)){
unset($config_tab[$kk]);
}
}
}
foreach ($list as $k=>$v){
if(!is_null(json_decode($v['value'])))
$list[$k]['value'] = json_decode($v['value'],true);
if($v['type'] == 'upload' && !empty($v['value'])){
if($v['upload_type'] == 1 || $v['upload_type'] == 3) $list[$k]['value'] = explode(',',$v['value']);
}
}
$this->assign('config_tab',$config_tab);
$this->assign('list',$list);
return $this->fetch();
}
/**
* 基础配置 单个
* @return mixed|void
*/
public function index_alone(){
$tab_id = input('tab_id');
if(!$tab_id) return $this->failed('参数错误,请重新打开');
$this->assign('tab_id',$tab_id);
$list = ConfigModel::getAll($tab_id);
foreach ($list as $k=>$v){
if(!is_null(json_decode($v['value'])))
$list[$k]['value'] = json_decode($v['value'],true);
if($v['type'] == 'upload' && !empty($v['value'])){
if($v['upload_type'] == 1 || $v['upload_type'] == 3) $list[$k]['value'] = explode(',',$v['value']);
}
}
$this->assign('list',$list);
return $this->fetch();
}
/**
* 添加字段
* */
public function create(Request $request){
$data = Util::getMore(['type',],$request);//接收参数
$tab_id = !empty($request->param('tab_id'))?$request->param('tab_id'):1;
$formbuider = array();
switch ($data['type']){
case 0://文本框
$formbuider = ConfigModel::createInputRule($tab_id);
break;
case 1://多行文本框
$formbuider = ConfigModel::createTextAreaRule($tab_id);
break;
case 2://单选框
$formbuider = ConfigModel::createRadioRule($tab_id);
break;
case 3://文件上传
$formbuider = ConfigModel::createUploadRule($tab_id);
break;
case 4://多选框
$formbuider = ConfigModel::createCheckboxRule($tab_id);
break;
}
$form = Form::make_post_form('添加字段',$formbuider,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存字段
* */
public function save(Request $request){
$data = Util::postMore([
'menu_name',
'type',
'config_tab_id',
'parameter',
'upload_type',
'required',
'width',
'high',
'value',
'info',
'desc',
'sort',
'status',],$request);
if(!$data['info']) return Json::fail('请输入配置名称');
if(!$data['menu_name']) return Json::fail('请输入字段名称');
if($data['menu_name']){
$oneConfig = ConfigModel::getOneConfig('menu_name',$data['menu_name']);
if(!empty($oneConfig)) return Json::fail('请重新输入字段名称,之前的已经使用过了');
}
if(!$data['desc']) return Json::fail('请输入配置简介');
if($data['sort'] < 0){
$data['sort'] = 0;
}
if($data['type'] == 'text'){
if(!ConfigModel::valiDateTextRole($data)) return Json::fail(ConfigModel::getErrorInfo());
}
if($data['type'] == 'textarea'){
if(!ConfigModel::valiDateTextareaRole($data)) return Json::fail(ConfigModel::getErrorInfo());
}
if($data['type'] == 'radio' || $data['type'] == 'checkbox' ){
if(!$data['parameter']) return Json::fail('请输入配置参数');
if(!ConfigModel::valiDateRadioAndCheckbox($data)) return Json::fail(ConfigModel::getErrorInfo());
$data['value'] = json_encode($data['value']);
}
ConfigModel::set($data);
return Json::successful('添加菜单成功!');
}
/**
* @param Request $request
* @param $id
* @return \think\response\Json
*/
public function update_config(Request $request, $id)
{
$type = $request->post('type');
if($type =='text' || $type =='textarea'|| $type == 'radio' || ($type == 'upload' && ($request->post('upload_type') == 1 || $request->post('upload_type') == 3))){
$value = $request->post('value');
}else{
$value = $request->post('value/a');
}
$data = Util::postMore(['status','info','desc','sort','config_tab_id','required','parameter',['value',$value],'upload_type'],$request);
$data['value'] = json_encode($data['value']);
if(!ConfigModel::get($id)) return Json::fail('编辑的记录不存在!');
ConfigModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 修改是否显示子子段
* @param $id
* @return mixed
*/
public function edit_cinfig($id){
$menu = ConfigModel::get($id)->getData();
if(!$menu) return Json::fail('数据不存在!');
$formbuider = array();
$formbuider[] = Form::input('menu_name','字段变量',$menu['menu_name'])->disabled(1);
// $formbuider[] = Form::input('type','字段类型',$menu['type'])->disabled(1);
$formbuider[] = Form::hidden('type',$menu['type']);
$formbuider[] = Form::select('config_tab_id','分类',(string)$menu['config_tab_id'])->setOptions(ConfigModel::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称',$menu['info'])->autofocus(1);
$formbuider[] = Form::input('desc','配置简介',$menu['desc']);
switch ($menu['type']){
case 'text':
$menu['value'] = json_decode($menu['value'],true);
//输入框验证规则
$formbuider[] = Form::input('value','默认值',$menu['value']);
if(!empty($menu['required'])){
$formbuider[] = Form::number('width','文本框宽(%)',$menu['width']);
$formbuider[] = Form::input('required','验证规则',$menu['required'])->placeholder('多个请用,隔开例如required:true,url:true');
}
break;
case 'textarea':
$menu['value'] = json_decode($menu['value'],true);
//多行文本
if(!empty($menu['high'])){
$formbuider[] = Form::textarea('value','默认值',$menu['value'])->rows(5);
$formbuider[] = Form::number('width','文本框宽(%)',$menu['width']);
$formbuider[] = Form::number('high','多行文本框高(%)',$menu['high']);
}else{
$formbuider[] = Form::input('value','默认值',$menu['value']);
}
break;
case 'radio':
$menu['value'] = json_decode($menu['value'],true);
$parameter = explode("\n",$menu['parameter']);
$options = [];
if($parameter){
foreach ($parameter as $v){
$data = explode("=>",$v);
$options[] = ['label'=>$data[1],'value'=>$data[0]];
}
$formbuider[] = Form::radio('value','默认值',$menu['value'])->options($options);
}
//单选和多选参数配置
if(!empty($menu['parameter'])){
$formbuider[] = Form::textarea('parameter','配置参数',$menu['parameter'])->placeholder("参数方式例如:\n1=白色\n2=红色\n3=黑色");
}
break;
case 'checkbox':
$menu['value'] = json_decode($menu['value'],true)?:[];
$parameter = explode("\n",$menu['parameter']);
$options = [];
if($parameter) {
foreach ($parameter as $v) {
$data = explode("=>", $v);
$options[] = ['label' => $data[1], 'value' => $data[0]];
}
$formbuider[] = Form::checkbox('value', '默认值', $menu['value'])->options($options);
}
//单选和多选参数配置
if(!empty($menu['parameter'])){
$formbuider[] = Form::textarea('parameter','配置参数',$menu['parameter'])->placeholder("参数方式例如:\n1=白色\n2=红色\n3=黑色");
}
break;
case 'upload':
if($menu['upload_type'] == 1 ){
$menu['value'] = json_decode($menu['value'],true);
$formbuider[] = Form::frameImageOne('value','图片',Url::build('admin/widget.images/index',array('fodder'=>'value')),(string)$menu['value'])->icon('image')->width('100%')->height('550px');
}elseif ($menu['upload_type'] == 2 ){
$menu['value'] = json_decode($menu['value'],true)?:[];
$formbuider[] = Form::frameImages('value','多图片',Url::build('admin/widget.images/index',array('fodder'=>'value')),$menu['value'])->maxLength(5)->icon('images')->width('100%')->height('550px')->spin(0);
}else{
$menu['value'] = json_decode($menu['value'],true);
$formbuider[] = Form::uploadFileOne('value','文件',Url::build('file_upload'))->name('file');
}
//上传类型选择
if(!empty($menu['upload_type'])){
$formbuider[] = Form::radio('upload_type','上传类型',$menu['upload_type'])->options([['value'=>1,'label'=>'单图'],['value'=>2,'label'=>'多图'],['value'=>3,'label'=>'文件']]);
}
break;
}
$formbuider[] = Form::number('sort','排序',$menu['sort']);
$formbuider[] = Form::radio('status','状态',$menu['status'])->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
$form = Form::make_post_form('编辑字段',$formbuider,Url::build('update_config',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 删除子字段
* @return \think\response\Json
*/
public function delete_cinfig(){
$id = input('id');
if(!ConfigModel::del($id))
return Json::fail(ConfigModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 保存数据 true
* */
public function save_basics(){
$request = Request::instance();
if($request->isPost()){
$post = $request->post();
$tab_id = $post['tab_id'];
unset($post['tab_id']);
foreach ($post as $k=>$v){
if(is_array($v)){
$res = ConfigModel::where('menu_name',$k)->column('type,upload_type');
foreach ($res as $kk=>$vv){
if($kk == 'upload'){
if($vv == 1 || $vv == 3){
$post[$k] = $v[0];
}
}
}
}
}
foreach ($post as $k=>$v){
ConfigModel::edit(['value' => json_encode($v)],$k,'menu_name');
}
return $this->successfulNotice('修改成功');
}
}
/**
* 模板表单提交
* */
public function view_upload(){
if($_POST['type'] == 3){
$res = Upload::file($_POST['file'],'config/file');
}else{
$res = Upload::Image($_POST['file'],'config/image');
}
if(!$res->status) return Json::fail($res->error);
return Json::successful('上传成功!',['url'=>$res->dir]);
}
/**
* 文件上传
* */
public function file_upload(){
$res = Upload::file($_POST['file'],'config/file');
if(!$res->status) return Json::fail($res->error);
return Json::successful('上传成功!',['url'=>$res->dir]);
}
/**
* 获取文件名
* */
public function getImageName(){
$request = Request::instance();
$post = $request->post();
$src = $post['src'];
$data['name'] = basename($src);
exit(json_encode($data));
}
/**
* 删除原来图片
* @param $url
*/
public function rmPublicResource($url)
{
$res = Util::rmPublicResource($url);
if($res->status)
return $this->successful('删除成功!');
else
return $this->failed($res->msg);
}
}

View File

@ -1,129 +0,0 @@
<?php
namespace app\admin\controller\setting;
use think\Url;
use service\FormBuilder as Form;
use think\Request;
use service\UtilService as Util;
use service\JsonService as Json;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemConfigTab as ConfigTabModel;
use app\admin\model\system\SystemConfig as ConfigModel;
/**
* 配置分类控制器
* Class SystemConfigTab
* @package app\admin\controller\system
*/
class SystemConfigTab extends AuthController
{
/**
* 子子段
* @return mixed|\think\response\Json
*/
public function sonconfigtab(){
$tab_id = input('tab_id');
if(!$tab_id) return Json::fail('参数错误');
$this->assign('tab_id',$tab_id);
$list = ConfigModel::getAll($tab_id);
foreach ($list as $k=>$v){
$list[$k]['value'] = json_decode($v['value'],true)?:'';
if($v['type'] == 'radio' || $v['type'] == 'checkbox'){
$list[$k]['value'] = ConfigTabModel::getRadioOrCheckboxValueInfo($v['menu_name'],$v['value']);
}
if($v['type'] == 'upload' && !empty($v['value'])){
// if($v['upload_type'] == 1 || $v['upload_type'] == 3) $list[$k]['value'] = explode(',',$v['value']);
}
}
$this->assign('list',$list);
return $this->fetch();
}
/**
* 基础配置
* @return mixed
*/
public function index(){
$where = Util::getMore([
['status',''],
['title',''],
],$this->request);
$this->assign('where',$where);
$this->assign(ConfigTabModel::getSystemConfigTabPage($where));
return $this->fetch();
}
/**
* 添加配置分类
* @return mixed
*/
public function create(){
$form = Form::create(Url::build('save'),[
Form::input('title','分类昵称'),
Form::input('eng_title','分类字段'),
Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')))->icon('ionic'),
Form::radio('type','类型',0)->options([['value'=>0,'label'=>'系统'],['value'=>1,'label'=>'公众号'],['value'=>2,'label'=>'小程序'],['value'=>3,'label'=>'其它']]),
Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']])
]);
$form->setMethod('post')->setTitle('添加分类配置');
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存分类名称
* @param Request $request
* @return \think\response\Json
*/
public function save(Request $request){
$data = Util::postMore([
'eng_title',
'status',
'title',
'icon',
'type'],$request);
if(!$data['title']) return Json::fail('请输入按钮名称');
ConfigTabModel::set($data);
return Json::successful('添加菜单成功!');
}
/**
* 修改分类
* @param $id
* @return mixed
*/
public function edit($id){
$menu = ConfigTabModel::get($id)->getData();
if(!$menu) return Json::fail('数据不存在!');
$form = Form::create(Url::build('update',array('id'=>$id)),[
Form::input('title','分类昵称',$menu['title']),
Form::input('eng_title','分类字段',$menu['eng_title']),
Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')),$menu['icon'])->icon('ionic'),
Form::radio('type','类型',$menu['type'])->options([['value'=>0,'label'=>'系统'],['value'=>1,'label'=>'公众号'],['value'=>2,'label'=>'小程序'],['value'=>3,'label'=>'其它']]),
Form::radio('status','状态',$menu['status'])->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']])
]);
$form->setMethod('post')->setTitle('添加分类配置');
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* @param Request $request
* @param $id
* @return \think\response\Json
*/
public function update(Request $request, $id)
{
$data = Util::postMore(['title','status','eng_title','icon','type'],$request);
if(!$data['title']) return Json::fail('请输入分类昵称');
if(!$data['eng_title']) return Json::fail('请输入分类字段');
if(!ConfigTabModel::get($id)) return Json::fail('编辑的记录不存在!');
ConfigTabModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* @param $id
* @return \think\response\Json
*/
public function delete($id){
if(!ConfigTabModel::del($id))
return Json::fail(ConfigTabModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,137 +0,0 @@
<?php
namespace app\admin\controller\setting;
use EasyWeChat\ShakeAround\Group;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\system\SystemGroup as GroupModel;
use app\admin\model\system\SystemGroupData as GroupDataModel;
use app\admin\controller\AuthController;
/**
* 组合数据控制器
* Class SystemGroup
* @package app\admin\controller\system
*/
class SystemGroup extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$this->assign(GroupModel::page());
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
$this->assign(['title'=>'添加数据组','save'=>Url::build('save')]);
return $this->fetch();
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$params = Util::postMore([
['id',''],
['name',''],
['config_name',''],
['info',''],
['typelist',[]],
],$this->request);
//数据组名称判断
if(!$params['name'])return Json::fail('请输入数据组名称!');
if(!$params['config_name'])return Json::fail('请输入配置名称!');
//判断ID是否存在存在就是编辑不存在就是添加
if(!$params['id']){
if(GroupModel::be($params['config_name'],'config_name')) return Json::fail('数据关键字已存在!');
}
$data["name"] = $params['name'];
$data["config_name"] = $params['config_name'];
$data["info"] = $params['info'];
//字段信息判断
if(!count($params['typelist']))
return Json::fail('字段至少存在一个!');
else{
$validate = ["name","type","title","description"];
foreach ($params["typelist"] as $key => $value) {
foreach ($value as $name => $field) {
if(empty($field["value"]) && in_array($name,$validate))
return Json::fail("字段".($key + 1)."".$field["placeholder"]."不能为空!");
else
$data["fields"][$key][$name] = $field["value"];
}
}
}
$data["fields"] = json_encode($data["fields"]);
//判断ID是否存在存在就是编辑不存在就是添加
if(!$params['id']) {
GroupModel::set($data);
return Json::successful('添加数据组成功!');
}else{
GroupModel::edit($data,$params['id']);
return Json::successful('编辑数据组成功!');
}
}
/**编辑数组
* @param $id
*/
public function edit($id)
{
$Groupinfo = GroupModel::get($id);
$fields = json_decode($Groupinfo['fields'],true);
$typelist = [];
foreach ($fields as $key => $v){
$typelist[$key]['name']['value'] = $v['name'];
$typelist[$key]['title']['value'] = $v['title'];
$typelist[$key]['type']['value'] = $v['type'];
$typelist[$key]['param']['value'] = $v['param'];
}
$Groupinfo['fields'] = json_encode($typelist);
$this->assign(compact('Groupinfo'));
$this->assign(['title'=>'添加数据组','save'=>Url::build('save')]);
return $this->fetch();
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!GroupModel::del($id))
return Json::fail(GroupModel::getErrorInfo('删除失败,请稍候再试!'));
else{
GroupDataModel::del(["gid"=>$id]);
return Json::successful('删除成功!');
}
}
}

View File

@ -1,259 +0,0 @@
<?php
namespace app\admin\controller\setting;
use app\admin\common\Error;
use service\FormBuilder as Form;
use service\JsonService as Json;
use service\UploadService as Upload;
use service\UtilService as Util;
use think\Request;
use think\Url;
use app\admin\model\system\SystemGroup as GroupModel;
use app\admin\model\system\SystemGroupData as GroupDataModel;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemAttachment;
/**
* 数据列表控制器 在组合数据中
* Class SystemGroupData
* @package app\admin\controller\system
*/
class SystemGroupData extends AuthController
{
/**
* 显示资源列表
* @return \think\Response
*/
public function index($gid)
{
$where = Util::getMore([
['status','']
],$this->request);
$this->assign('where',$where);
$this->assign(compact("gid"));
$this->assign(GroupModel::getField($gid));
$where['gid'] = $gid;
$this->assign(GroupDataModel::getList($where));
return $this->fetch();
}
/**
* 显示创建资源表单页.
* @return \think\Response
*/
public function create($gid)
{
$Fields = GroupModel::getField($gid);
$f = array();
foreach ($Fields["fields"] as $key => $value) {
$info = [];
if(isset($value["param"])){
$value["param"] = str_replace("\r\n","\n",$value["param"]);//防止不兼容
$params = explode("\n",$value["param"]);
if(is_array($params) && !empty($params)){
foreach ($params as $index => $v) {
$vl = explode('=>',$v);
if(isset($vl[0]) && isset($vl[1])){
$info[$index]["value"] = $vl[0];
$info[$index]["label"] = $vl[1];
}
}
}
}
switch ($value["type"]){
case 'input':
$f[] = Form::input($value["title"],$value["name"]);
break;
case 'textarea':
$f[] = Form::input($value["title"],$value["name"])->type('textarea')->placeholder($value['param']);
break;
case 'radio':
$f[] = Form::radio($value["title"],$value["name"],isset($info[0]["value"]) ? $info[0]["value"] : '')->options($info);
break;
case 'checkbox':
$f[] = Form::checkbox($value["title"],$value["name"],isset($info[0]) ? $info[0] : '')->options($info);
break;
case 'select':
$f[] = Form::select($value["title"],$value["name"],isset($info[0]) ? $info[0] : '')->options($info)->multiple(false);
break;
case 'upload':
$f[] = Form::formFrameImageOne($value["title"],$value["name"]);
break;
case 'uploads':
$f[] = Form::formFrameImages($value["title"],$value["name"]);
break;
default:
$f[] = Form::input($value["title"],$value["name"]);
break;
}
}
$f[] = Form::number('sort','排序',1);
$f[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
$form = Form::make_post_form('添加数据',$f,Url::build('save',compact('gid')),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request,$gid)
{
$Fields = GroupModel::getField($gid);
$params = $request->post();
foreach ($params as $key => $param) {
foreach ($Fields['fields'] as $index => $field) {
if($key == $field["title"]){
// if($param == "" || count($param) == 0)
if($param == "")
return Json::fail($field["name"]."不能为空!");
else{
$value[$key]["type"] = $field["type"];
$value[$key]["value"] = $param;
}
}
}
}
$data = array("gid"=>$gid,"add_time"=>time(),"value"=>json_encode($value),"sort"=>$params["sort"],"status"=>$params["status"]);
GroupDataModel::set($data);
return Json::successful('添加数据成功!');
}
/**
* 显示指定的资源
*
* @param int $id
* @return \think\Response
*/
public function read($id)
{
//
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($gid,$id)
{
$GroupData = GroupDataModel::get($id);
$GroupDataValue = json_decode($GroupData["value"],true);
$Fields = GroupModel::getField($gid);
$f = array();
foreach ($Fields['fields'] as $key => $value) {
$info = [];
if(isset($value["param"])){
$value["param"] = str_replace("\r\n","\n",$value["param"]);//防止不兼容
$params = explode("\n",$value["param"]);
if(is_array($params) && !empty($params)){
foreach ($params as $index => $v) {
$vl = explode('=>',$v);
if(isset($vl[0]) && isset($vl[1])){
$info[$index]["value"] = $vl[0];
$info[$index]["label"] = $vl[1];
}
}
}
}
$fvalue = isset($GroupDataValue[$value['title']]['value'])?$GroupDataValue[$value['title']]['value']:'';
switch ($value['type']){
case 'input':
$f[] = Form::input($value['title'],$value['name'],$fvalue);
break;
case 'textarea':
$f[] = Form::input($value['title'],$value['name'],$fvalue)->type('textarea');
break;
case 'radio':
$f[] = Form::radio($value['title'],$value['name'],$fvalue)->options($info);
break;
case 'checkbox':
$f[] = Form::checkbox($value['title'],$value['name'],$fvalue)->options($info);
break;
case 'upload':
if(!empty($fvalue)){
$image = is_string($fvalue) ? $fvalue : $fvalue[0];
}else{
$image = '';
}
$f[] = Form::formFrameImageOne($value['title'],$value['name'],$image);
break;
case 'uploads':
$images = !empty($fvalue) ? $fvalue:[];
$f[] = Form::formFrameImages($value['title'],$value['name'],$images);
break;
case 'select':
$f[] = Form::select($value['title'],$value['name'],$fvalue)->setOptions($info);
break;
default:
$f[] = Form::input($value['title'],$value['name'],$fvalue);
break;
}
}
$f[] = Form::input('sort','排序',$GroupData["sort"]);
$f[] = Form::radio('status','状态',$GroupData["status"])->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
$form = Form::make_post_form('添加用户通知',$f,Url::build('update',compact('id')),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$GroupData = GroupDataModel::get($id);
$Fields = GroupModel::getField($GroupData["gid"]);
$params = $request->post();
foreach ($params as $key => $param) {
foreach ($Fields['fields'] as $index => $field) {
if($key == $field["title"]){
if(trim($param) == '')
return Json::fail($field["name"]."不能为空!");
else{
$value[$key]["type"] = $field["type"];
$value[$key]["value"] = $param;
}
}
}
}
$data = array("value"=>json_encode($value),"sort"=>$params["sort"],"status"=>$params["status"]);
GroupDataModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!GroupDataModel::del($id))
return Json::fail(GroupDataModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
public function upload()
{
$res = Upload::image('file','common');
if(!is_array($res)) return Json::fail($res);
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],6,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}
}

View File

@ -1,222 +0,0 @@
<?php
namespace app\admin\controller\setting;
use service\FormBuilder as Form;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use think\Url;
use app\admin\model\system\SystemMenus as MenusModel;
use app\admin\controller\AuthController;
/**
* 菜单管理控制器
* Class SystemMenus
* @package app\admin\controller\system
*/
class SystemMenus extends AuthController
{
use CurdControllerTrait;
public $bindModel = MenusModel::class;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$pid = $this->request->param('pid')?$this->request->param('pid'):0;
$params = Util::getMore([
['is_show',''],
// ['access',''],
['keyword',''],
['pid',$pid]
],$this->request);
$this->assign(MenusModel::getAdminPage($params));
$addurl = Url::build('create',['cid'=>input('pid')]);
$this->assign(compact('params','addurl'));
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create($cid = 0)
{
$field = [];
$field[] = Form::input('menu_name','按钮名称')->required('按钮名称必填');
$field[] = Form::select('pid','父级id',$cid)->setOptions(function(){
$list = (Util::sortListTier(MenusModel::all(function($m){
$m->order('sort DESC,id ASC');
})->toArray(),'顶级','pid','menu_name'));
$menus = [['value'=>0,'label'=>'顶级按钮']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['menu_name']];
}
return $menus;
})->filterable(1);
$field[] = Form::select('module','模块名')->options([['label'=>'总后台','value'=>'admin']]);
if($cid)$controller = MenusModel::where('id',$cid)->value('controller')?:'';
else $controller = '';
$field[] = Form::input('controller','控制器名',$controller);
if (!empty($controller))
{
$controller = preg_replace_callback('/([.]+([a-z]{1}))/i', function ($matches) {
return '\\' . strtoupper($matches[2]);
}, $controller);
if(class_exists('\app\admin\controller\\' . $controller))
{
$list = get_this_class_methods('\app\admin\controller\\' . $controller);
$field[] = Form::select('action','方法名')->setOptions(function()use($list){
$menus = [['value'=>0,'label'=>'默认函数']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu,'label'=>$menu];
}
return $menus;
})->filterable(1);
}else{
$field[] = Form::input('action','方法名');
}
}else{
$field[] = Form::input('action','方法名');
}
$field[] = Form::input('params','参数')->placeholder('举例:a/123/b/234');
$field[] = Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')))->icon('ionic');
$field[] = Form::number('sort','排序',0);
$field[] = Form::radio('is_show','是否菜单',0)->options([['value'=>0,'label'=>'隐藏'],['value'=>1,'label'=>'显示(菜单只显示三级)']]);
$form = Form::make_post_form('添加权限',$field,Url::build('save'),3);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
'menu_name',
'controller',
['module','admin'],
['action',''],
'icon',
'params',
['pid',0],
['sort',0],
['is_show',0],
['access',1]],$request);
if(!$data['menu_name']) return Json::fail('请输入按钮名称');
MenusModel::set($data);
return Json::successful('添加菜单成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$menu = MenusModel::get($id);
if (!$menu) return Json::fail('数据不存在!');
$field = array();
$field[] = Form::input('menu_name','按钮名称',$menu['menu_name']);
$field[] = Form::select('pid','父级id',(string)$menu->getData('pid'))->setOptions(function()use($id){
$list = (Util::sortListTier(MenusModel::all(function($m){
$m->order('sort DESC,id ASC');
})->toArray(),'顶级','pid','menu_name'));
$menus = [['value'=>0,'label'=>'顶级按钮']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['menu_name']];
}
return $menus;
})->filterable(1);
$field[] = Form::select('module','模块名',$menu['module'])->options([['label'=>'总后台','value'=>'admin']]);
$field[] = Form::input('controller','控制器名',$menu['controller']);
if (!empty($menu['controller']))
{
$controller = preg_replace_callback('/([.]+([a-z]{1}))/i', function ($matches) {
return '\\' . strtoupper($matches[2]);
}, $menu['controller']);
if(class_exists('\app\admin\controller\\' . $controller))
{
$list = get_this_class_methods('\app\admin\controller\\' . $controller);
$field[] = Form::select('action','方法名',(string)$menu->getData('action'))->setOptions(function()use($list){
$menus = [['value'=>0,'label'=>'默认函数']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu,'label'=>$menu];
}
return $menus;
})->filterable(1);
}else{
$field[] = Form::input('action','方法名',$menu['action']);
}
}else{
$field[] = Form::input('action','方法名');
}
$field[] = Form::input('params','参数',MenusModel::paramStr($menu['params']))->placeholder('举例:a/123/b/234');
$field[] = Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')),$menu['icon'])->icon('ionic');
$field[] = Form::number('sort','排序',$menu['sort']);
$field[] = Form::radio('is_show','是否菜单',$menu['is_show'])->options([['value'=>0,'label'=>'隐藏'],['value'=>1,'label'=>'显示(菜单只显示三级)']]);
$form = Form::make_post_form('添加权限',$field,Url::build('update',array('id'=>$id)),3);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'menu_name',
'controller',
['module','admin'],
'action',
'params',
'icon',
['sort',0],
['pid',0],
['is_show',0],
['access',1]],$request);
if(!$data['menu_name']) return Json::fail('请输入按钮名称');
if(!MenusModel::get($id)) return Json::fail('编辑的记录不存在!');
MenusModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return $this->failed('参数错误,请重新打开');
$res = MenusModel::delMenu($id);
if(!$res)
return Json::fail(MenusModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,126 +0,0 @@
<?php
namespace app\admin\controller\setting;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\system\SystemAdmin;
use app\admin\model\system\SystemNotice as NoticeModel;
use service\JsonService;
use service\UtilService;
use think\Request;
use think\Url;
/**
* 管理员消息通知 控制器
* Class SystemNotice
* @package app\admin\controller\system
*/
class SystemNotice extends AuthController
{
public function index(){
$this->assign(NoticeModel::page(function($notice){
$notice->push_admin_name = !empty($notice->push_admin) ? implode(',',SystemAdmin::where('id','IN',$notice->push_admin)->column('real_name')) : '';
}));
return $this->fetch();
}
public function create()
{
$f = array();
$f[] = Form::input('title','通知标题');
$f[] = Form::input('type','通知类型');
$f[] = Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')))->icon('ionic');
$f[] = Form::input('template','通知模板');
$f[] = Form::input('table_title','通知数据')->type('textarea')->placeholder('数据1-key1,数据2-key2');
$f[] = Form::select('push_admin','通知管理员')->setOptions(function(){
$list = SystemAdmin::getOrdAdmin('real_name,id')?:[];
$options = [];
foreach ($list as $admin){
$options[] = ['label'=>$admin['real_name'],'value'=>$admin['id']];
}
return $options;
})->multiple(1);
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加通知模板',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function save(Request $request)
{
$data = UtilService::postMore([
'title', 'type', 'icon', 'template','table_title',
['push_admin', []], ['status', 0]
], $request);
$data['push_admin'] = array_unique(array_filter($data['push_admin']));
if (!$data['template']) return $this->failed('请填写通知模板');
if (!$data['title']) return $this->failed('请输入模板标题');
if (!$data['type']) return $this->failed('请输入模板类型');
if (NoticeModel::set($data))
return $this->successful('添加通知成功');
else
return $this->failed('添加失败!');
}
/**编辑通知模板
* @param $id
* @return mixed|void
*/
public function edit($id)
{
$data = NoticeModel::get($id);
if(!$data) return JsonService::fail('数据不存在!');
$data->tableTitle = implode(',',array_map(function($value){
return $value['title'].'-'.$value['key'];
},$data->table_title));
$data->tableTitleStr = implode(',',array_map(function($value){
return $value['title'].'-'.$value['key'];
},$data->table_title));
$f = array();
$f[] = Form::input('title','通知标题',$data->title);
$f[] = Form::input('type','通知类型',$data->type);
$f[] = Form::frameInputOne('icon','图标',Url::build('admin/widget.widgets/icon',array('fodder'=>'icon')),$data->icon)->icon('ionic');
$f[] = Form::input('template','通知模板',$data->template);
$f[] = Form::input('table_title','通知数据',$data->tableTitleStr)->type('textarea')->placeholder('数据1-key1,数据2-key2');
$f[] = Form::select('push_admin','通知管理员',$data->push_admin)->setOptions(function(){
$list = SystemAdmin::getOrdAdmin('real_name,id')?:[];
$options = [];
foreach ($list as $admin){
$options[] = ['label'=>$admin['real_name'],'value'=>$admin['id']];
}
return $options;
})->multiple(1);
$f[] = Form::radio('status','状态',$data->status)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('编辑通知模板',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request, $id)
{
$data = UtilService::postMore([
'title','type','icon','template','table_title',
['push_admin',[]],['status',0]
],$request);
$data['push_admin'] = array_unique(array_filter($data['push_admin']));
if(!$data['template']) return $this->failed('请填写通知模板');
if(!$data['title']) return $this->failed('请输入模板标题');
if(!$data['type']) return $this->failed('请输入模板类型');
NoticeModel::edit($data,$id);
return $this->successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
$res = NoticeModel::del($id);
if(!$res)
return $this->failed(('删除失败,请稍候再试!'));
else
return $this->successful('删除成功!');
}
public function message($type = 'all')
{
return $this->fetch();
}
}

View File

@ -1,145 +0,0 @@
<?php
namespace app\admin\controller\setting;
use app\admin\model\system\SystemMenus;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\system\SystemRole as RoleModel;
use app\admin\controller\AuthController;
/*
* 身份管理 控制器
* */
class SystemRole extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$where = Util::getMore([
['status',''],
['role_name',''],
],$this->request);
$where['level'] = $this->adminInfo['level'];
$this->assign('where',$where);
$this->assign(RoleModel::systemPage($where));
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
// if(0 == 0){
// }else{
// dump($this->adminInfo['level']);
// }
$menus = $this->adminInfo['level'] == 0 ? SystemMenus::ruleList() : SystemMenus::rolesByRuleList($this->adminInfo['roles']);
$this->assign(['menus'=>json($menus)->getContent(),'saveUrl'=>Url::build('save')]);
return $this->fetch();
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
'role_name',
['status',0],
['checked_menus',[],'','rules']
],$request);
if(!$data['role_name']) return Json::fail('请输入身份名称');
if(!is_array($data['rules']) || !count($data['rules']) )
return Json::fail('请选择最少一个权限');
foreach ($data['rules'] as $v){
$pid = SystemMenus::where('id',$v)->value('pid');
if(!in_array($pid,$data['rules'])) $data['rules'][] = $pid;
}
$data['rules'] = implode(',',$data['rules']);
$data['level'] = $this->adminInfo['level']+1;
RoleModel::set($data);
return Json::successful('添加身份成功!');
}
/**
* 显示指定的资源
*
* @param int $id
* @return \think\Response
*/
public function read($id)
{
//
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
//
$role = RoleModel::get($id);
$menus = $this->adminInfo['level'] == 0 ? SystemMenus::ruleList() : SystemMenus::rolesByRuleList($this->adminInfo['roles']);
$this->assign(['role'=>$role->toJson(),'menus'=>json($menus)->getContent(),'updateUrl'=>Url::build('update',array('id'=>$id))]);
return $this->fetch();
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'role_name',
['status',0],
['checked_menus',[],'','rules']
],$request);
if(!$data['role_name']) return Json::fail('请输入身份名称');
if(!is_array($data['rules']) || !count($data['rules']) )
return Json::fail('请选择最少一个权限');
foreach ($data['rules'] as $v){
$pid = SystemMenus::where('id',$v)->value('pid');
if(!in_array($pid,$data['rules'])) $data['rules'][] = $pid;
}
$data['rules'] = implode(',',$data['rules']);
RoleModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!RoleModel::del($id))
return Json::fail(RoleModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,885 +0,0 @@
<?php
/**
* Project: 快速复制 淘宝、天猫、1688、京东 商品到CRMEB系统
* Author: 有一片天 <810806442@qq.com> 微信szktor
* Date: 2019-04-25
*/
namespace app\admin\controller\store;
use service\HttpService;
use service\UploadService;
use think\exception\PDOException;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemConfig;
use traits\CurdControllerTrait;
use service\JsonService;
use service\UtilService;
use app\admin\model\store\StoreCategory as CategoryModel;
use app\admin\model\store\StoreProduct as ProductModel;
use app\admin\model\system\SystemAttachment;
use app\admin\model\system\SystemAttachmentCategory;
/**
* 产品管理
* Class StoreProduct
* @package app\admin\controller\store
*/
class CopyTaobao extends AuthController
{
use CurdControllerTrait;
protected $bindModel = ProductModel::class;
//错误信息
protected $errorInfo=true;
//产品默认字段
protected $productInfo=[
'cate_id'=>'',
'store_name' =>'',
'store_info' => '',
'unit_name' => '件',
'price' => 0,
'keyword' => '',
'ficti' => 0,
'ot_price' => 0,
'give_integral' => 0,
'postage' => 0,
'cost' => 0,
'image' => '',
'slider_image' => '',
'add_time' => 0,
'stock' => 0,
'description' => '',
'soure_link' => ''
];
//抓取网站主域名
protected $grabName=[
'taobao',
'1688',
'tmall',
'jd'
];
//远程下载附件图片分类名称
protected $AttachmentCategoryName='远程下载';
/**
* 显示资源
* @return html
*/
public function index()
{
$list = CategoryModel::getTierList();
$menus=[];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['cate_name'],'disabled'=>$menu['pid']== 0];//,'disabled'=>$menu['pid']== 0];
}
$this->assign('menus',$menus);
$this->assign('is_layui',1);
return $this->fetch();
}
/*
* 设置错误信息
* @param string $msg 错误信息
* */
public function setErrorInfo($msg='')
{
$this->errorInfo=$msg;
return false;
}
/*
* 设置字符串字符集
* @param string $str 需要设置字符集的字符串
* @return string
* */
public function Utf8String($str)
{
$encode=mb_detect_encoding($str, array("ASCII",'UTF-8',"GB2312","GBK",'BIG5'));
if(strtoupper($encode) != 'UTF-8') $str=mb_convert_encoding($str, 'utf-8',$encode);
return $str;
}
/**
* 获取资源,并解析出对应的商品参数
* @return json
*/
public function get_request_contents()
{
list($link)=UtilService::postMore([
['link','']
],$this->request,true);
$url=$this->checkurl($link);
if($url===false) return JsonService::fail($this->errorInfo);
$this->errorInfo=true;
$html=$this->curl_Get($url,60);
if(!$html) return JsonService::fail('商品HTML信息获取失败');
$html=$this->Utf8String($html);
preg_match('/<title>([^<>]*)<\/title>/', $html, $title);
//商品标题
$this->productInfo['store_name'] = isset($title['1']) ? str_replace(['-淘宝网','-tmall.com天猫',' - 阿里巴巴',' ','-','【图片价格品牌报价】京东','京东','【行情报价价格评测】'],'',trim($title['1'])) :'';
$this->productInfo['store_info'] = $this->productInfo['store_name'];
try{
//获取url信息
$pathinfo=pathinfo($url);
if(!isset($pathinfo['dirname'])) return JsonService::fail('解析URL失败');
//提取域名
$parse_url=parse_url($pathinfo['dirname']);
if(!isset($parse_url['host'])) return JsonService::fail('获取域名失败');
//获取第一次.出现的位置
$strLeng=strpos($parse_url['host'],'.')+1;
//截取域名中的真实域名不带.com后的
$funsuffix=substr($parse_url['host'],$strLeng,strrpos($parse_url['host'],'.')-$strLeng);
if(!in_array($funsuffix,$this->grabName)) return JsonService::fail('您输入的地址不在复制范围内!');
//设拼接设置产品函数
$funName="setProductInfo".ucfirst($funsuffix);
//执行方法
if(method_exists($this,$funName))
$this->$funName($html);
else
return JsonService::fail('设置产品函数不存在');
if(!$this->productInfo['slider_image']) return JsonService::fail('未能获取到商品信息,请确保商品信息有效!');
return JsonService::successful($this->productInfo);
}catch (\Exception $e){
return JsonService::fail('系统错误',['line'=>$e->getLine(),'meass'=>$e->getMessage()]);
}
}
/*
* 淘宝设置产品
* @param string $html 网页内容
* */
public function setProductInfoTaobao($html)
{
//获取轮播图
$images = $this->getTaobaoImg($html);
$images = array_merge($images);
$this->productInfo['slider_image']=isset($images['gaoqing']) ? $images['gaoqing'] : (array)$images;
//获取产品详情请求链接
$link=$this->getTaobaoDesc($html);
//获取请求内容
$desc_json = HttpService::getRequest($link);
//转换字符集
$desc_json = $this->Utf8String($desc_json);
//截取掉多余字符
$this->productInfo['test']=$desc_json;
$desc_json = str_replace('var desc=\'','',$desc_json);
$desc_json = str_replace(["\n","\t","\r"],'',$desc_json);
$content = substr($desc_json,0,-2);
$this->productInfo['description']=$content;
//获取详情图
$description_images=$this->decodedesc($this->productInfo['description']);
$this->productInfo['description_images']=is_array($description_images) ? $description_images : [];
$this->productInfo['image']=is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
}
/*
* 天猫设置产品
* @param string $html 网页内容
* */
public function setProductInfoTmall($html)
{
//获取轮播图
$images = $this->getTianMaoImg($html);
$images = array_merge($images);
$this->productInfo['slider_image'] = $images;
$this->productInfo['image'] = is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
//获取产品详情请求链接
$link=$this->getTianMaoDesc($html);
//获取请求内容
$desc_json = HttpService::getRequest($link);
//转换字符集
$desc_json = $this->Utf8String($desc_json);
//截取掉多余字符
$desc_json = str_replace('var desc=\'','',$desc_json);
$desc_json = str_replace(["\n","\t","\r"],'',$desc_json);
$content = substr($desc_json,0,-2);
$this->productInfo['description']=$content;
//获取详情图
$description_images=$this->decodedesc($this->productInfo['description']);
$this->productInfo['description_images']=is_array($description_images) ? $description_images : [];
}
/*
* 1688设置产品
* @param string $html 网页内容
* */
public function setProductInfo1688($html)
{
//获取轮播图
$images = $this->get1688Img($html);
if(isset($images['gaoqing'])){
$images['gaoqing'] = array_merge($images['gaoqing']);
$this->productInfo['slider_image'] = $images['gaoqing'];
}else
$this->productInfo['slider_image'] = $images;
$this->productInfo['image'] = is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
//获取产品详情请求链接
$link = $this->get1688Desc($html);
//获取请求内容
$desc_json = HttpService::getRequest($link);
//转换字符集
$desc_json = $this->Utf8String($desc_json);
$this->productInfo['test']=$desc_json;
//截取掉多余字符
$desc_json = str_replace('var offer_details=','',$desc_json);
$desc_json = str_replace(["\n","\t","\r"],'',$desc_json);
$desc_json = substr($desc_json,0,-1);
$descArray = json_decode($desc_json,true);
if(!isset($descArray['content'])) $descArray['content'] = '';
$this->productInfo['description']=$descArray['content'];
//获取详情图
$description_images=$this->decodedesc($this->productInfo['description']);
$this->productInfo['description_images']=is_array($description_images) ? $description_images : [];
}
/*
* JD设置产品
* @param string $html 网页内容
* */
public function setProductInfoJd($html)
{
//获取产品详情请求链接
$desc_url = $this->getJdDesc($html);
//获取请求内容
$desc_json=HttpService::getRequest($desc_url);
//转换字符集
$desc_json = $this->Utf8String($desc_json);
//截取掉多余字符
if(substr($desc_json,0,8) == 'showdesc') $desc_json = str_replace('showdesc','',$desc_json);
$desc_json = str_replace('data-lazyload=','src=',$desc_json);
$descArray=json_decode($desc_json,true);
if(!$descArray) $descArray=['content'=>''];
//获取轮播图
$images=$this->getJdImg($html);
$images = array_merge($images);
$this->productInfo['slider_image']=$images;
$this->productInfo['image']=is_array($this->productInfo['slider_image']) ? $this->productInfo['slider_image'][0] : '';
$this->productInfo['description']=$descArray['content'];
//获取详情图
$description_images=$this->decodedesc($descArray['content']);
$this->productInfo['description_images']=is_array($description_images) ? $description_images : [];
}
/*
* 检查淘宝天猫1688的商品链接
* @return string
*/
public function checkurl($link)
{
$link=strtolower($link);
if(!$link) return $this->setErrorInfo('请输入链接地址');
if(substr($link,0,4)!='http') return $this->setErrorInfo('链接地址必须以http开头');
$arrLine=explode('?',$link);
if(!count($arrLine)) return $this->setErrorInfo('链接地址有误(ERR:1001)');
if(!isset($arrLine[1])){
if(strpos($link,'1688')!==false && strpos($link,'offer')!==false) return trim($arrLine[0]);
else if(strpos($link,'item.jd')!==false) return trim($arrLine[0]);
else return $this->setErrorInfo('链接地址有误(ERR:1002)');
}
if(strpos($link,'1688')!==false && strpos($link,'offer')!==false) return trim($arrLine[0]);
if(strpos($link,'item.jd')!==false) return trim($arrLine[0]);
$arrLineValue = explode('&',$arrLine[1]);
if(!is_array($arrLineValue)) return $this->setErrorInfo('链接地址有误(ERR:1003)');
if(!strpos(trim($arrLine[0]),'item.htm')) $this->setErrorInfo('链接地址有误(ERR:1004)');
//链接参数
$lastStr='';
foreach ($arrLineValue as $k => $v){
if(substr(strtolower($v),0,3) == 'id='){
$lastStr = trim($v);
break;
}
}
if(!$lastStr) return $this->setErrorInfo('链接地址有误(ERR:1005)');
return trim($arrLine[0]) . '?' . $lastStr;
}
/*
* 保存图片保存产品信息
* */
public function save_product()
{
$data=UtilService::postMore([
['cate_id',''],
['store_name',''],
['store_info',''],
['keyword',''],
['unit_name',''],
['image',''],
['slider_image',[]],
['price',''],
['ot_price',''],
['give_integral',''],
['postage',''],
['sales',''],
['ficti',''],
['stock',''],
['cost',''],
['description_images',[]],
['description',''],
['is_show',0],
['soure_link',''],
]);
if(!$data['cate_id']) return JsonService::fail('请选择分类!');
if(!$data['store_name']) return JsonService::fail('请填写产品名称');
if(!$data['unit_name']) return JsonService::fail('请填写产品单位');
if(!$data['image']) return JsonService::fail('商品主图暂无,无法保存商品,您可选择其他链接进行复制产品');
if($data['price'] == '' || $data['price'] < 0) return JsonService::fail('请输入产品售价');
if($data['ot_price'] == '' || $data['ot_price'] < 0) return JsonService::fail('请输入产品市场价');
if($data['stock'] == '' || $data['stock'] < 0) return JsonService::fail('请输入库存');
//查询附件分类
$AttachmentCategory = SystemAttachmentCategory::where(['name' =>$this->AttachmentCategoryName])->find();
//不存在则创建
if(!$AttachmentCategory) $AttachmentCategory = SystemAttachmentCategory::set(['pid' =>'0','name' =>$this->AttachmentCategoryName,'enname'=>'']);
//生成附件目录
if(makePathToUrl('attach',3) == '') return JsonService::fail('无法创建文件夹,请检查您的上传目录权限:'.UPLOAD_PATH.'/attach/');
ini_set("max_execution_time", 600);
//开始图片下载处理
ProductModel::beginTrans();
try{
//放入主图
$images=[
['w'=>305, 'h'=>305, 'line'=>$data['image'],'valuename'=>'image']
];
//放入轮播图
foreach ($data['slider_image'] as $item){
$value=['w'=>640, 'h'=>640, 'line'=>$item,'valuename'=>'slider_image','isTwoArray'=>true];
array_push($images,$value);
}
//执行下载
$res=$this->uploadImage($images,false,0,$AttachmentCategory['id']);
if(!is_array($res)) return JsonService::fail($this->errorInfo ? $this->errorInfo : '保存图片失败');
if(isset($res['image'])) $data['image']=$res['image'];
if(isset($res['slider_image'])) $data['slider_image']=$res['slider_image'];
$data['slider_image']=count($data['slider_image']) ? json_encode($data['slider_image']) : '';
//替换并下载详情里面的图片默认下载全部图片
$data['description']=preg_replace('#<style>.*?</style>#is','',$data['description']);
$data['description']=$this->uploadImage($data['description_images'],$data['description'],1,$AttachmentCategory['id']);
unset($data['description_images']);
$data['add_time']=time();
$cate_id = explode(',',$data['cate_id']);
//产品存在
if($productInfo=ProductModel::where(['soure_link'=>$data['soure_link']])->find()){
$productInfo->description=$data['description'];
$productInfo->slider_image=$data['slider_image'];
$productInfo->image=$data['image'];
$productInfo->store_name=$data['store_name'];
$productInfo->save();
ProductModel::commitTrans();
return JsonService::successful('商品存在,信息已被更新成功');
}else {
//不存在时新增
if ($res = ProductModel::set($data)) {
foreach ($cate_id as $cid) {
\think\Db::name('store_product_cate')->insert(['product_id' => $res['id'], 'cate_id' => $cid, 'add_time' => time()]);
}
ProductModel::commitTrans();
return JsonService::successful('生成产品成功');
} else {
ProductModel::rollbackTrans();
return JsonService::fail('生成产品失败');
}
}
}catch (PDOException $e){
ProductModel::rollbackTrans();
return JsonService::fail('插入数据库错误',['line'=>$e->getLine(),'messag'=>$e->getMessage()]);
}catch (\Exception $e){
ProductModel::rollbackTrans();
return JsonService::fail('系统错误',['line'=>$e->getLine(),'messag'=>$e->getMessage()]);
}
}
/*
* 上传图片处理
* @param array $image 图片路径
* @param int $uploadType 上传方式 0=远程下载
* */
public function uploadImage(array $images=[],$html='',$uploadType=0,$AttachmentCategoryId=0)
{
$uploadImage=[];
$siteUrl = SystemConfig::getValue('site_url');
switch ($uploadType){
case 0:
foreach ($images as $item){
//下载图片文件
if($item['w'] && $item['h'])
$uploadValue=$this->downloadImage($item['line'],'',0,30,$item['w'],$item['h']);
else
$uploadValue=$this->downloadImage($item['line']);
//下载成功更新数据库
if(is_array($uploadValue)){
//TODO 拼接图片地址
if($uploadValue['image_type'] == 1) $imagePath=$siteUrl.$uploadValue['path'];
else $imagePath = $uploadValue['path'];
//写入数据库
if(!$uploadValue['is_exists'] && $AttachmentCategoryId) SystemAttachment::attachmentAdd($uploadValue['name'],$uploadValue['size'],$uploadValue['mime'],$imagePath,$imagePath,$AttachmentCategoryId,$uploadValue['image_type'],time(),1);
//组装数组
if(isset($item['isTwoArray']) && $item['isTwoArray'])
$uploadImage[$item['valuename']][]=$imagePath;
else
$uploadImage[$item['valuename']]=$imagePath;
}
}
break;
case 1:
preg_match_all('#<img.*?src="([^"]*)"[^>]*>#i', $html, $match);
if(isset($match[1])){
foreach ($match[1] as $item){
if(is_int(strpos($item, 'http')))
$arcurl = $item;
else
$arcurl = 'http://'.ltrim($item,'\//');
$uploadValue=$this->downloadImage($arcurl);
//下载成功更新数据库
if(is_array($uploadValue)){
//TODO 拼接图片地址
if($uploadValue['image_type'] == 1) $imagePath=$siteUrl.$uploadValue['path'];
else $imagePath = $uploadValue['path'];
//写入数据库
if(!$uploadValue['is_exists'] && $AttachmentCategoryId) SystemAttachment::attachmentAdd($uploadValue['name'],$uploadValue['size'],$uploadValue['mime'],$imagePath,$imagePath,$AttachmentCategoryId,$uploadValue['image_type'],time(),1);
//替换图片
$html=str_replace($item,$imagePath,$html);
}else{
//替换掉没有下载下来的图片
$html=preg_replace('#<img.*?src="'.$item.'"*>#i','',$html);
}
}
}
return $html;
break;
default:
return $this->setErrorInfo('上传方式错误');
break;
}
return $uploadImage;
}
//提取商品描述中的所有图片
public function decodedesc($desc = '')
{
$desc =trim($desc);
if(!$desc) return '';
preg_match_all('/<img[^>]*?src="([^"]*?)"[^>]*?>/i',$desc,$match);
if(!isset($match[1]) || count($match[1]) <= 0){
preg_match_all('/:url(([^"]*?));/i',$desc,$match);
if(!isset($match[1]) || count($match[1]) <= 0) return $desc;
}else{
preg_match_all('/:url(([^"]*?));/i',$desc,$newmatch);
if(isset($newmatch[1]) && count($newmatch[1]) > 0) $match[1] = array_merge($match[1],$newmatch[1]);
}
$match[1] = array_unique($match[1]); //去掉重复
foreach($match[1] as $k => &$v) {
$_tmp_img = str_replace([')','(',';'],'',$v);
$_tmp_img = strpos($_tmp_img,'http') ? $_tmp_img : 'http:' . $_tmp_img;
if(strpos($v,'?')) {
$_tarr = explode('?',$v);
$_tmp_img = trim($_tarr[0]);
}
$_urls = str_replace(['\'','"'],'',$_tmp_img);
if($this->_img_exists($_urls)) $v = $_urls;
}
return $match[1];
}
//获取京东商品组图
public function getJdImg($html = '')
{
//获取图片服务器网址
preg_match('/<img(.*?)id="spec-img"(.*?)data-origin=\"(.*?)\"[^>]*>/', $html, $img);
if(!isset($img[3])) return '';
$info = parse_url(trim($img[3]));
if(!$info['host']) return '';
if(!$info['path']) return '';
$_tmparr = explode('/',trim($info['path']));
$url = 'http://' . $info['host'] . '/' . $_tmparr[1] . '/' . str_replace(['jfs',' '],'',trim($_tmparr[2]));
preg_match('/imageList:(.*?)"],/is', $html, $img);
if(!isset($img[1]))
{
return '';
}
$_arr = explode(',',$img[1]);
foreach ($_arr as $k => &$v){
$_str = $url . str_replace(['"','[',']',' '],'',trim($v));
if(strpos($_str,'?'))
{
$_tarr = explode('?',$_str);
$_str = trim($_tarr[0]);
}
if($this->_img_exists($_str))
{
$v = $_str;
}else{
unset($_arr[$k]);
}
}
return array_unique($_arr);
}
//获取京东商品描述
public function getJdDesc($html = '')
{
preg_match('/,(.*?)desc:([^<>]*)\',/i', $html, $descarr);
if(!isset($descarr[1]) && !isset($descarr[2])) return '';
$tmpArr = explode(',',$descarr[2]);
if(count($tmpArr) > 0)
{
$descarr[2] = trim($tmpArr[0]);
}
$replace_arr = ['\'','\',',' ',',','/*','*/'];
if(isset($descarr[2]))
{
$d_url = str_replace($replace_arr,'',$descarr[2]);
return $this->formatDescUrl(strpos($d_url,'http') ? $d_url : 'http:' . $d_url);
}
$d_url = str_replace($replace_arr,'',$descarr[1]);
$d_url = $this->formatDescUrl($d_url);
$d_url = rtrim(rtrim($d_url,"?"),"&");
return substr($d_url,0,4) == 'http' ? $d_url : 'http:' . $d_url;
}
//处理下京东商品描述网址
public function formatDescUrl($url = '')
{
if(!$url) return '';
$url = substr($url,0,4) == 'http' ? $url : 'http:' . $url;
if(!strpos($url,'&'))
{
$_arr = explode('?',$url);
if(!is_array($_arr) || count($_arr) <= 0) return $url;
return trim($_arr[0]);
}else{
$_arr = explode('&',$url);
}
if(!is_array($_arr) || count($_arr) <= 0) return $url;
unset($_arr[count($_arr)-1]);
$new_url = '';
foreach ($_arr as $k => $v) {
$new_url .= $v . '&';
}
return !$new_url ? $url : $new_url;
}
//获取1688商品组图
public function get1688Img($html = '')
{
preg_match('/<ul class=\"nav nav-tabs fd-clr\">(.*?)<\/ul>/is', $html, $img);
if(!isset($img[0]))
{
return '';
}
preg_match_all('/preview":"(.*?)\"\}\'>/is', $img[0], $arrb);
if(!isset($arrb[1]) || count($arrb[1]) <= 0)
{
return '';
}
$thumb = [];
$gaoqing = [];
$res = ['thumb' => '', 'gaoqing' => '']; //缩略图片和高清图片
foreach($arrb[1] as $k => $v)
{
$_str = str_replace(['","original":"'],'*',$v);
$_arr = explode('*',$_str);
if(is_array($_arr) && isset($_arr[0]) && isset($_arr[1]))
{
if(strpos($_arr[0],'?'))
{
$_tarr = explode('?',$_arr[0]);
$_arr[0] = trim($_tarr[0]);
}
if(strpos($_arr[1],'?'))
{
$_tarr = explode('?',$_arr[1]);
$_arr[1] = trim($_tarr[0]);
}
if($this->_img_exists($_arr[0])) $thumb[] = trim($_arr[0]);
if($this->_img_exists($_arr[1])) $gaoqing[] = trim($_arr[1]);
}
}
$res = ['thumb' => array_unique($thumb), 'gaoqing' => array_unique($gaoqing)]; //缩略图片和高清图片
return $res;
}
//获取1688商品描述
public function get1688Desc($html = '')
{
preg_match('/data-tfs-url="([^<>]*)data-enable="true"/', $html, $descarr);
if(!isset($descarr[1])) return '';
return str_replace(['"',' '],'',$descarr[1]);
}
//获取天猫商品组图
public function getTianMaoImg($html = '')
{
$pic_size = '430';
preg_match('/<img[^>]*id="J_ImgBooth"[^r]*rc=\"([^"]*)\"[^>]*>/', $html, $img);
if(isset($img[1]))
{
$_arr = explode('x',$img[1]);
$filename = $_arr[count($_arr)-1];
$pic_size = intval(substr($filename,0,3));
}
preg_match('|<ul id="J_UlThumb" class="tb-thumb tm-clear">(.*)</ul>|isU',$html, $match);
preg_match_all('/<img src="(.*?)" \//',$match[1],$images);
if(!isset($images[1])) return '';
foreach($images[1] as $k => &$v)
{
$tmp_v = trim($v);
$_arr = explode('x',$tmp_v);
$_fname = $_arr[count($_arr)-1];
$_size = intval(substr($_fname,0,3));
if(strpos($tmp_v,'://'))
{
$_arr = explode(':',$tmp_v);
$r_url = trim($_arr[1]);
}else{
$r_url = $tmp_v;
}
$str = str_replace($_size, $pic_size, $r_url);
if(strpos($str,'?'))
{
$_tarr = explode('?',$str);
$str = trim($_tarr[0]);
}
$_i_url = strpos($str,'http') ? $str : 'http:' . $str;
if($this->_img_exists($_i_url))
{
$v = $_i_url;
}else{
unset($images[1][$k]);
}
}
return array_unique($images[1]);
}
//获取天猫商品描述
public function getTianMaoDesc($html = '')
{
preg_match('/descUrl":"([^<>]*)","httpsDescUrl":"/', $html, $descarr);
if(!isset($descarr[1]))
{
preg_match('/httpsDescUrl":"([^<>]*)","fetchDcUrl/', $html, $descarr);
if(!isset($descarr[1])) return '';
}
return strpos($descarr[1],'http') ? $descarr[1] : 'http:' . $descarr[1];
}
//获取淘宝商品组图
public function getTaobaoImg($html = '')
{
preg_match('/auctionImages([^<>]*)"]/', $html, $imgarr);
if(!isset($imgarr[1])) return '';
$arr = explode(',', $imgarr[1]);
foreach($arr as $k => &$v)
{
$str = trim($v);
$str = str_replace(['"',' ','',':['], '', $str);
if(strpos($str,'?'))
{
$_tarr = explode('?',$str);
$str = trim($_tarr[0]);
}
$_i_url = strpos($str,'http') ? $str : 'http:' . $str;
if($this->_img_exists($_i_url))
{
$v = $_i_url;
}else{
unset($arr[$k]);
}
}
return array_unique($arr);
}
//获取淘宝商品描述
public function getTaobaoDesc($html = '')
{
preg_match('/descUrl([^<>]*)counterApi/', $html, $descarr);
if(!isset($descarr[1])) return '';
$arr = explode(':', $descarr[1]);
$url = [];
foreach($arr as $k => $v)
{
if(strpos($v,'//'))
{
$str = str_replace(['\'',',',' ','?',':'], '', $v);
$url[] = trim($str);
}
}
if($url)
{
return strpos($url[0],'http') ? $url[0] : 'http:' . $url[0];
}else{
return '';
}
}
/**
* GET 请求
* @param string $url
*/
public function curl_Get($url = '',$time_out = 25)
{
if(!$url) return '';
$ch = curl_init();
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
if(stripos($url,"https://")!==FALSE)
{
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 从证书中检查SSL加密算法是否存在
}
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('user-agent:'.$_SERVER['HTTP_USER_AGENT']));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_TIMEOUT,$time_out);
$response = curl_exec($ch);
if($error=curl_error($ch)){
return false;
}
curl_close($ch);
return mb_convert_encoding($response, 'utf-8','GB2312');
}
//检测远程文件是否存在
public function _img_exists($url = '')
{
ini_set("max_execution_time", 0);
$str = @file_get_contents($url,0,null,0,1);
if(strlen($str) <= 0) return false;
if($str)
return true;
else
return false;
}
//TODO 下载图片
public function downloadImage($url = '', $name = '', $type = 0, $timeout = 30, $w = 0, $h = 0)
{
if(!strlen(trim($url))) return '';
if(!strlen(trim($name)))
{
//TODO 获取要下载的文件名称
$downloadImageInfo = $this->getImageExtname($url);
$name = $downloadImageInfo['file_name'];
if(!strlen(trim($name))) return '';
}
//TODO 获取远程文件所采用的方法
if($type){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, false);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //TODO 跳过证书检查
if(stripos($url,"https://") !== FALSE) curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); //TODO 从证书中检查SSL加密算法是否存在
curl_setopt($ch, CURLOPT_HTTPHEADER, array('user-agent:'.$_SERVER['HTTP_USER_AGENT']));
if(ini_get('open_basedir') == '' && ini_get('safe_mode' == 'Off')) curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);//TODO 是否采集301、302之后的页面
$content = curl_exec($ch);
curl_close($ch);
}else{
try{
ob_start();
readfile($url);
$content = ob_get_contents();
ob_end_clean();
}catch (\Exception $e){
return $e->getMessage();
}
}
$size = strlen(trim($content));
if(!$content || $size <= 2) return '图片流获取失败';
$date_dir = date('Y') . DS . date('m') . DS . date('d');
$imageInfo = UploadService::imageStream($name, $content, 'attach' . DS . $date_dir. DS);
if(!is_array($imageInfo)) return $imageInfo;
$date['path'] = $imageInfo['dir'];
$date['name'] = $imageInfo['name'];
$date['size'] = $imageInfo['size'];
$date['mime'] = $imageInfo['type'];
$date['image_type'] = $imageInfo['image_type'];
$date['is_exists'] = false;
return $date;
}
//获取即将要下载的图片扩展名
public function getImageExtname($url = '', $ex = 'jpg')
{
$_empty = ['file_name' => '', 'ext_name' => $ex];
if(!$url) return $_empty;
if(strpos($url,'?'))
{
$_tarr = explode('?',$url);
$url = trim($_tarr[0]);
}
$arr = explode('.',$url);
if(!is_array($arr) || count($arr) <= 1) return $_empty;
$ext_name = trim($arr[count($arr)-1]);
$ext_name = !$ext_name ? $ex : $ext_name;
return ['file_name' => md5($url) . '.' . $ext_name, 'ext_name' => $ext_name];
}
/*
$filepath = 绝对路径,末尾有斜杠 /
$name = 图片文件名
$maxwidth 定义生成图片的最大宽度(单位:像素)
$maxheight 生成图片的最大高度(单位:像素)
$filetype 最终生成的图片类型(.jpg/.png/.gif
*/
public function resizeImage($filepath = '',$name = '', $maxwidth = 0,$maxheight = 0)
{
$pic_file = $filepath . $name; //图片文件
$img_info = getimagesize($pic_file); //索引 2 是图像类型的标记1 = GIF2 = JPG3 = PNG4 = SWF5 = PSD
if($img_info[2] == 1)
{
$im = imagecreatefromgif($pic_file); //打开图片
$filetype = '.gif';
}elseif($img_info[2] == 2){
$im = imagecreatefromjpeg($pic_file); //打开图片
$filetype = '.jpg';
}elseif($img_info[2] == 3){
$im = imagecreatefrompng($pic_file); //打开图片
$filetype = '.png';
}else{
return ['path' => $filepath, 'file' => $name, 'mime' => ''];
}
$file_name = md5('_tmp_' . microtime() . '_' .rand(0,10)) . $filetype;
$pic_width = imagesx($im);
$pic_height = imagesy($im);
$resizewidth_tag = false;
$resizeheight_tag = false;
if(($maxwidth && $pic_width > $maxwidth) || ($maxheight && $pic_height > $maxheight))
{
if($maxwidth && $pic_width>$maxwidth)
{
$widthratio = $maxwidth/$pic_width;
$resizewidth_tag = true;
}
if($maxheight && $pic_height>$maxheight)
{
$heightratio = $maxheight/$pic_height;
$resizeheight_tag = true;
}
if($resizewidth_tag && $resizeheight_tag)
{
if($widthratio<$heightratio)
$ratio = $widthratio;
else
$ratio = $heightratio;
}
if($resizewidth_tag && !$resizeheight_tag)
$ratio = $widthratio;
if($resizeheight_tag && !$resizewidth_tag)
$ratio = $heightratio;
$newwidth = $pic_width * $ratio;
$newheight = $pic_height * $ratio;
if(function_exists("imagecopyresampled"))
{
$newim = imagecreatetruecolor($newwidth,$newheight);
imagecopyresampled($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height);
}else{
$newim = imagecreate($newwidth,$newheight);
imagecopyresized($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height);
}
if($filetype == '.png')
{
imagepng($newim,$filepath . $file_name);
}else if($filetype == '.gif'){
imagegif($newim,$filepath . $file_name);
}else{
imagejpeg($newim,$filepath . $file_name);
}
imagedestroy($newim);
}else{
if($filetype == '.png')
{
imagepng($im,$filepath . $file_name);
}else if($filetype == '.gif'){
imagegif($im,$filepath . $file_name);
}else{
imagejpeg($im,$filepath . $file_name);
}
imagedestroy($im);
}
@unlink($pic_file);
return ['path' => $filepath, 'file' => $file_name, 'mime' => $img_info['mime']];
}
}

View File

@ -1,213 +0,0 @@
<?php
namespace app\admin\controller\store;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\store\StoreCategory as CategoryModel;
use think\Url;
use app\admin\model\system\SystemAttachment;
/**
* 产品分类控制器
* Class StoreCategory
* @package app\admin\controller\system
*/
class StoreCategory extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$this->assign('pid',$this->request->get('pid',0));
$this->assign('cate',CategoryModel::getTierList());
return $this->fetch();
}
/*
* 异步获取分类列表
* @return json
*/
public function category_list(){
$where = Util::getMore([
['is_show',''],
['pid',$this->request->param('pid','')],
['cate_name',''],
['page',1],
['limit',20],
['order','']
]);
return JsonService::successlayui(CategoryModel::CategoryList($where));
}
/**
* 设置单个产品上架|下架
*
* @return json
*/
public function set_show($is_show='',$id=''){
($is_show=='' || $id=='') && JsonService::fail('缺少参数');
$res=CategoryModel::where(['id'=>$id])->update(['is_show'=>(int)$is_show]);
if($res){
return JsonService::successful($is_show==1 ? '显示成功':'隐藏成功');
}else{
return JsonService::fail($is_show==1 ? '显示失败':'隐藏失败');
}
}
/**
* 快速编辑
*
* @return json
*/
public function set_category($field='',$id='',$value=''){
$field=='' || $id=='' || $value=='' && JsonService::fail('缺少参数');
if(CategoryModel::where(['id'=>$id])->update([$field=>$value]))
return JsonService::successful('保存成功');
else
return JsonService::fail('保存失败');
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
$field = [
Form::select('pid','父级')->setOptions(function(){
$list = CategoryModel::getTierList();
$menus = [['value'=>0,'label'=>'顶级菜单']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['cate_name']];
}
return $menus;
})->filterable(1),
Form::input('cate_name','分类名称'),
Form::formFrameImageOne('pic','分类图标'),
Form::number('sort','排序'),
Form::radio('is_show','状态',1)->options([['label'=>'显示','value'=>1],['label'=>'隐藏','value'=>0]])
];
$form = Form::make_post_form('添加分类',$field,Url::build('save'),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/category'.date('Ymd'));
if(is_array($res)){
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],1,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}else
return Json::fail($res);
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
'pid',
'cate_name',
['pic',[]],
'sort',
['is_show',0]
],$request);
if($data['pid'] == '') return Json::fail('请选择父类');
if(!$data['cate_name']) return Json::fail('请输入分类名称');
if(count($data['pic'])<1) return Json::fail('请上传分类图标');
if($data['sort'] <0 ) $data['sort'] = 0;
$data['pic'] = $data['pic'][0];
$data['add_time'] = time();
CategoryModel::set($data);
return Json::successful('添加分类成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$c = CategoryModel::get($id);
if(!$c) return Json::fail('数据不存在!');
$field = [
Form::select('pid','父级',(string)$c->getData('pid'))->setOptions(function() use($id){
$list = CategoryModel::getTierList(CategoryModel::where('id','<>',$id));
// $list = (Util::sortListTier(CategoryModel::where('id','<>',$id)->select()->toArray(),'顶级','pid','cate_name'));
$menus = [['value'=>0,'label'=>'顶级菜单']];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['cate_name']];
}
return $menus;
})->filterable(1),
Form::input('cate_name','分类名称',$c->getData('cate_name')),
// Form::frameImageOne('pic','分类图标',Url::build('admin/widget.images/index',array('fodder'=>'pic')),$c->getData('pic'))->icon('image')->width('100%')->height('500px'),
Form::formFrameImageOne('pic','分类图标',$c->getData('pic')),
Form::number('sort','排序',$c->getData('sort')),
Form::radio('is_show','状态',$c->getData('is_show'))->options([['label'=>'显示','value'=>1],['label'=>'隐藏','value'=>0]])
];
$form = Form::make_post_form('编辑分类',$field,Url::build('update',array('id'=>$id)),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'pid',
'cate_name',
['pic',[]],
'sort',
['is_show',0]
],$request);
if($data['pid'] == '') return Json::fail('请选择父类');
if(!$data['cate_name']) return Json::fail('请输入分类名称');
if(count($data['pic'])<1) return Json::fail('请上传分类图标');
if($data['sort'] <0 ) $data['sort'] = 0;
$data['pic'] = $data['pic'][0];
CategoryModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!CategoryModel::delCategory($id))
return Json::fail(CategoryModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,174 +0,0 @@
<?php
namespace app\admin\controller\store;
use app\admin\controller\AuthController;
use app\admin\library\FormBuilder;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use think\Url;
use app\admin\model\wechat\ArticleCategory as ArticleCategoryModel;
use app\admin\model\wechat\WechatNews as WechatNewsModel;
/**
* 资讯管理 控制器
* Class StoreInfoMana
* @package app\admin\controller\store
*/
class StoreInfoMana extends AuthController
{
/**
* 新闻管理
* */
public function index($is_list=0){
if(!$is_list) return $this->failed('数据不存在');
echo $is_list;
exit();
$where = Util::getMore([
['status',''],
['title',''],
],$this->request);
$this->assign('where',$where);
$this->assign(ArticleCategoryModel::systemPage($where));
return $this->fetch();
}
/**
* 添加分类管理
* */
public function create(){
FormBuilder::text('title','分类昵称');
FormBuilder::textarea('intr','分类简介');
FormBuilder::select('new_id','图文列表',function(){
$list = \app\admin\model\wechat\WechatNews::getNews();
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
})->multiple()->filterable();
FormBuilder::upload('image','分类图片');
FormBuilder::number('sort','排序',0);
FormBuilder::radio('status','状态',[['value'=>1,'label'=>'显示'],['value'=>0,'label'=>'隐藏']],1);
$rules = FormBuilder::builder()->getContent();
$this->assign(['title'=>'编辑菜单','rules'=>$rules,'save'=>Url::build('save')]);
return $this->fetch();
}
/**
* s上传图片
* */
public function upload(){
$res = Upload::image('file','article');
$thumbPath = Upload::thumb($res->dir);
if($res->status == 200)
return Json::successful('图片上传成功!',['name'=>$res->fileInfo->getSaveName(),'url'=>Upload::pathToUrl($thumbPath)]);
else
return Json::fail($res->error);
}
/**
* 保存分类管理
* */
public function save(Request $request){
$data = Util::postMore([
'title',
'intr',
['new_id',[]],
['image',[]],
['sort',0],
'status',],$request);
if(!$data['title']) return Json::fail('请输入分类名称');
if(count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
if($data['sort'] < 0) return Json::fail('排序不能是负数');
$data['add_time'] = time();
$data['image'] = $data['image'][0];
$new_id = $data['new_id'];
unset($data['new_id']);
$res = ArticleCategoryModel::set($data);
if(!WechatNewsModel::saveBatchCid($res['id'],implode(',',$new_id))) return Json::fail('文章列表添加失败');
return Json::successful('添加分类成功!');
}
/**
* 修改分类
* */
public function edit($id){
$this->assign(['title'=>'编辑菜单','read'=>Url::build('read',array('id'=>$id)),'update'=>Url::build('update',array('id'=>$id))]);
return $this->fetch();
}
public function read($id)
{
$article = ArticleCategoryModel::get($id)->getData();
if(!$article) return Json::fail('数据不存在!');
FormBuilder::text('title','分类昵称',$article['title']);
FormBuilder::textarea('intr','分类简介',$article['intr']);
$arr = ArticleCategoryModel::getArticle($id,'id,title,cid');//子文章
$new_id = array();
foreach ($arr as $k=>$v){
$new_id[$k] = $k;
}
FormBuilder::select('new_id','文章列表',function(){
$list = \app\admin\model\wechat\WechatNews::getNews();
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
},$new_id)->multiple();
FormBuilder::upload('image','分类图片')->defaultFileList($article['image']);
FormBuilder::number('sort','排序',$article['sort']);
FormBuilder::radio('status','状态',[['value'=>1,'label'=>'显示'],['value'=>0,'label'=>'隐藏']],$article['status']);
return FormBuilder::builder();
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'title',
'intr',
['new_id',[]],
['image',[]],
['sort',0],
'status',],$request);
if(!$data['title']) return Json::fail('请输入分类名称');
if(count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
if($data['sort'] < 0) return Json::fail('排序不能是负数');
$data['image'] = $data['image'][0];
// dump($data);
// exit;
if(!ArticleCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
if(!WechatNewsModel::saveBatchCid($id,implode(',',$data['new_id']))) return Json::fail('文章列表添加失败');
unset($data['new_id']);
ArticleCategoryModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除分类
* */
public function delete($id)
{
$res = ArticleCategoryModel::delArticleCategory($id);
if(!$res)
return Json::fail(ArticleCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,516 +0,0 @@
<?php
namespace app\admin\controller\store;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\store\StoreProductAttr;
use app\admin\model\store\StoreProductAttrResult;
use app\admin\model\store\StoreProductRelation;
use app\admin\model\system\SystemConfig;
use service\JsonService;
use think\Db;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\store\StoreCategory as CategoryModel;
use app\admin\model\store\StoreProduct as ProductModel;
use think\Url;
use app\admin\model\system\SystemAttachment;
/**
* 产品管理
* Class StoreProduct
* @package app\admin\controller\store
*/
class StoreProduct extends AuthController
{
use CurdControllerTrait;
protected $bindModel = ProductModel::class;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$type=$this->request->param('type');
//获取分类
$this->assign('cate',CategoryModel::getTierList());
//出售中产品
$onsale = ProductModel::where(['is_show'=>1,'is_del'=>0])->count();
//待上架产品
$forsale = ProductModel::where(['is_show'=>0,'is_del'=>0])->count();
//仓库中产品
$warehouse = ProductModel::where(['is_del'=>0])->count();
//已经售馨产品
$outofstock = ProductModel::getModelObject()->where(ProductModel::setData(4))->count();
//警戒库存
$policeforce =ProductModel::getModelObject()->where(ProductModel::setData(5))->count();
//回收站
$recycle = ProductModel::where(['is_del'=>1])->count();
$this->assign(compact('type','onsale','forsale','warehouse','outofstock','policeforce','recycle'));
return $this->fetch();
}
/**
* 异步查找产品
*
* @return json
*/
public function product_ist(){
$where=Util::getMore([
['page',1],
['limit',20],
['store_name',''],
['cate_id',''],
['excel',0],
['order',''],
['type',$this->request->param('type')]
]);
return JsonService::successlayui(ProductModel::ProductList($where));
}
/**
* 设置单个产品上架|下架
*
* @return json
*/
public function set_show($is_show='',$id=''){
($is_show=='' || $id=='') && JsonService::fail('缺少参数');
$res=ProductModel::where(['id'=>$id])->update(['is_show'=>(int)$is_show]);
if($res){
return JsonService::successful($is_show==1 ? '上架成功':'下架成功');
}else{
return JsonService::fail($is_show==1 ? '上架失败':'下架失败');
}
}
/**
* 快速编辑
*
* @return json
*/
public function set_product($field='',$id='',$value=''){
$field=='' || $id=='' || $value=='' && JsonService::fail('缺少参数');
if(ProductModel::where(['id'=>$id])->update([$field=>$value]))
return JsonService::successful('保存成功');
else
return JsonService::fail('保存失败');
}
/**
* 设置批量产品上架
*
* @return json
*/
public function product_show(){
$post=Util::postMore([
['ids',[]]
]);
if(empty($post['ids'])){
return JsonService::fail('请选择需要上架的产品');
}else{
$res=ProductModel::where('id','in',$post['ids'])->update(['is_show'=>1]);
if($res)
return JsonService::successful('上架成功');
else
return JsonService::fail('上架失败');
}
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
// $this->assign(['title'=>'添加产品','action'=>Url::build('save'),'rules'=>$this->rules()->getContent()]);
// return $this->fetch('public/common_form');
$field = [
Form::select('cate_id','产品分类')->setOptions(function(){
$list = CategoryModel::getTierList();
$menus=[];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['cate_name'],'disabled'=>$menu['pid']== 0];//,'disabled'=>$menu['pid']== 0];
}
return $menus;
})->filterable(1)->multiple(1),
Form::input('store_name','产品名称')->col(Form::col(24)),
Form::input('store_info','产品简介')->type('textarea'),
Form::input('keyword','产品关键字')->placeholder('多个用英文状态下的逗号隔开'),
Form::input('unit_name','产品单位','件'),
Form::formFrameImageOne('image','产品主图片(305*305px)'),
Form::formFrameImages('slider_image','产品轮播图(640*640px)'),
Form::number('price','产品售价')->min(0)->col(8),
Form::number('ot_price','产品市场价')->min(0)->col(8),
Form::number('give_integral','赠送积分')->min(0)->precision(0)->col(8),
Form::number('postage','邮费')->min(0)->col(Form::col(8)),
Form::number('sales','销量',0)->min(0)->precision(0)->col(8)->readonly(1),
Form::number('ficti','虚拟销量')->min(0)->precision(0)->col(8),
Form::number('stock','库存')->min(0)->precision(0)->col(8),
Form::number('cost','产品成本价')->min(0)->col(8),
Form::number('sort','排序')->col(8),
Form::radio('is_show','产品状态',0)->options([['label'=>'上架','value'=>1],['label'=>'下架','value'=>0]])->col(8),
Form::radio('is_hot','热卖单品',0)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_benefit','促销单品',0)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_best','精品推荐',0)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_new','首发新品',0)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_postage','是否包邮',0)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8)
];
$form = Form::make_post_form('添加产品',$field,Url::build('save'),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/product/'.date('Ymd'));
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],1,$res['image_type'],$res['time']);
if(is_array($res))
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
else
return Json::fail($res);
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
['cate_id',[]],
'store_name',
'store_info',
'keyword',
['unit_name','件'],
['image',[]],
['slider_image',[]],
['postage',0],
['ot_price',0],
['price',0],
['sort',0],
['stock',100],
'sales',
['ficti',100],
['give_integral',0],
['is_show',0],
['cost',0],
['is_hot',0],
['is_benefit',0],
['is_best',0],
['is_new',0],
['mer_use',0],
['is_postage',0],
],$request);
if(count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
$cate_id=$data['cate_id'];
$data['cate_id'] = implode(',',$data['cate_id']);
if(!$data['store_name']) return Json::fail('请输入产品名称');
if(count($data['image'])<1) return Json::fail('请上传产品图片');
if(count($data['slider_image'])<1) return Json::fail('请上传产品轮播图');
if($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品售价');
if($data['ot_price'] == '' || $data['ot_price'] < 0) return Json::fail('请输入产品市场价');
if($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
$data['image'] = $data['image'][0];
$data['slider_image'] = json_encode($data['slider_image']);
$data['add_time'] = time();
$data['description'] = '';
$res=ProductModel::set($data);
foreach ($cate_id as $cid){
Db::name('store_product_cate')->insert(['product_id'=>$res['id'],'cate_id'=>$cid,'add_time'=>time()]);
}
return Json::successful('添加产品成功!');
}
public function edit_content($id){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign([
'content'=>ProductModel::where('id',$id)->value('description'),
'field'=>'description',
'action'=>Url::build('change_field',['id'=>$id,'field'=>'description'])
]);
return $this->fetch('public/edit_content');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$field = [
Form::select('cate_id','产品分类',explode(',',$product->getData('cate_id')))->setOptions(function(){
$list = CategoryModel::getTierList();
$menus=[];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['html'].$menu['cate_name'],'disabled'=>$menu['pid']== 0];//,'disabled'=>$menu['pid']== 0];
}
return $menus;
})->filterable(1)->multiple(1),
Form::input('store_name','产品名称',$product->getData('store_name')),
Form::input('store_info','产品简介',$product->getData('store_info'))->type('textarea'),
Form::input('keyword','产品关键字',$product->getData('keyword'))->placeholder('多个用英文状态下的逗号隔开'),
Form::input('unit_name','产品单位',$product->getData('unit_name')),
// Form::frameImageOne('image','产品主图片(305*305px)',Url::build('admin/widget.images/index',array('fodder'=>'image')),$product->getData('image'))->icon('image')->width('80%')->height('500px'),
Form::formFrameImageOne('image','产品主图片(305*305px)',$product->getData('image')),
// Form::frameImages('slider_image','产品轮播图(640*640px)',Url::build('admin/widget.images/index',array('fodder'=>'slider_image')),json_decode($product->getData('slider_image'),1) ? : [])->maxLength(5)->icon('images')->width('945px')->height('600px'),
Form::formFrameImages('slider_image','产品轮播图(640*640px)',json_decode($product->getData('slider_image'),1) ? : []),
Form::number('price','产品售价',$product->getData('price'))->min(0)->precision(2)->col(8),
Form::number('ot_price','产品市场价',$product->getData('ot_price'))->min(0)->col(8),
Form::number('give_integral','赠送积分',$product->getData('give_integral'))->min(0)->precision(0)->col(8),
Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(8),
Form::number('sales','销量',$product->getData('sales'))->min(0)->precision(0)->col(8)->readonly(1),
Form::number('ficti','虚拟销量',$product->getData('ficti'))->min(0)->precision(0)->col(8),
Form::number('stock','库存',ProductModel::getStock($id)>0?ProductModel::getStock($id):$product->getData('stock'))->min(0)->precision(0)->col(8),
Form::number('cost','产品成本价',$product->getData('cost'))->min(0)->col(8),
Form::number('sort','排序',$product->getData('sort'))->col(8),
Form::radio('is_show','产品状态',$product->getData('is_show'))->options([['label'=>'上架','value'=>1],['label'=>'下架','value'=>0]])->col(8),
Form::radio('is_hot','热卖单品',$product->getData('is_hot'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_benefit','促销单品',$product->getData('is_benefit'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_best','精品推荐',$product->getData('is_best'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_new','首发新品',$product->getData('is_new'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8),
Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(8)
];
$form = Form::make_post_form('编辑产品',$field,Url::build('update',array('id'=>$id)),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
['cate_id',[]],
'store_name',
'store_info',
'keyword',
['unit_name','件'],
['image',[]],
['slider_image',[]],
['postage',0],
['ot_price',0],
['price',0],
['sort',0],
['stock',0],
['ficti',100],
['give_integral',0],
['is_show',0],
['cost',0],
['is_hot',0],
['is_benefit',0],
['is_best',0],
['is_new',0],
['mer_use',0],
['is_postage',0],
],$request);
if(count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
$cate_id=$data['cate_id'];
$data['cate_id'] = implode(',',$data['cate_id']);
if(!$data['store_name']) return Json::fail('请输入产品名称');
if(count($data['image'])<1) return Json::fail('请上传产品图片');
if(count($data['slider_image'])<1) return Json::fail('请上传产品轮播图');
// if(count($data['slider_image'])>8) return Json::fail('轮播图最多5张图');
if($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品售价');
if($data['ot_price'] == '' || $data['ot_price'] < 0) return Json::fail('请输入产品市场价');
if($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
$data['image'] = $data['image'][0];
$data['slider_image'] = json_encode($data['slider_image']);
ProductModel::edit($data,$id);
Db::name('store_product_cate')->where('product_id',$id)->delete();
foreach ($cate_id as $cid){
Db::name('store_product_cate')->insert(['product_id'=>$id,'cate_id'=>$cid,'add_time'=>time()]);
}
return Json::successful('修改成功!');
}
public function attr($id)
{
if(!$id) return $this->failed('数据不存在!');
$result = StoreProductAttrResult::getResult($id);
$image = ProductModel::where('id',$id)->value('image');
$this->assign(compact('id','result','image'));
return $this->fetch();
}
/**
* 生成属性
* @param int $id
*/
public function is_format_attr($id = 0){
if(!$id) return Json::fail('产品不存在');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$product = ProductModel::get($id);
if(!$product) return Json::fail('产品不存在');
$attrFormat = attrFormat($attr)[1];
if(count($detail)){
foreach ($attrFormat as $k=>$v){
foreach ($detail as $kk=>$vv){
if($v['detail'] == $vv['detail']){
$attrFormat[$k]['price'] = $vv['price'];
$attrFormat[$k]['cost'] = isset($vv['cost']) ? $vv['cost'] : $product['cost'];
$attrFormat[$k]['sales'] = $vv['sales'];
$attrFormat[$k]['pic'] = $vv['pic'];
$attrFormat[$k]['check'] = false;
break;
}else{
$attrFormat[$k]['cost'] = $product['cost'];
$attrFormat[$k]['price'] = '';
$attrFormat[$k]['sales'] = '';
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = true;
}
}
}
}else{
foreach ($attrFormat as $k=>$v){
$attrFormat[$k]['cost'] = $product['cost'];
$attrFormat[$k]['price'] = $product['price'];
$attrFormat[$k]['sales'] = $product['stock'];
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = false;
}
}
return Json::successful($attrFormat);
}
public function set_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$res = StoreProductAttr::createProductAttr($attr,$detail,$id);
if($res)
return $this->successful('编辑属性成功!');
else
return $this->failed(StoreProductAttr::getErrorInfo());
}
public function clear_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
if(false !== StoreProductAttr::clearProductAttr($id) && false !== StoreProductAttrResult::clearResult($id))
return $this->successful('清空产品属性成功!');
else
return $this->failed(StoreProductAttr::getErrorInfo('清空产品属性失败!'));
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return $this->failed('数据不存在');
if(!ProductModel::be(['id'=>$id])) return $this->failed('产品数据不存在');
if(ProductModel::be(['id'=>$id,'is_del'=>1])){
$data['is_del'] = 0;
if(!ProductModel::edit($data,$id))
return Json::fail(ProductModel::getErrorInfo('恢复失败,请稍候再试!'));
else
return Json::successful('成功恢复产品!');
}else{
$data['is_del'] = 1;
if(!ProductModel::edit($data,$id))
return Json::fail(ProductModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('成功移到回收站!');
}
}
/**
* 点赞
* @param $id
* @return mixed|\think\response\Json|void
*/
public function collect($id){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign(StoreProductRelation::getCollect($id));
return $this->fetch();
}
/**
* 收藏
* @param $id
* @return mixed|\think\response\Json|void
*/
public function like($id){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign(StoreProductRelation::getLike($id));
return $this->fetch();
}
/**
* 修改产品价格
* @param Request $request
*/
public function edit_product_price(Request $request){
$data = Util::postMore([
['id',0],
['price',0],
],$request);
if(!$data['id']) return Json::fail('参数错误');
$res = ProductModel::edit(['price'=>$data['price']],$data['id']);
if($res) return Json::successful('修改成功');
else return Json::fail('修改失败');
}
/**
* 修改产品库存
* @param Request $request
*/
public function edit_product_stock(Request $request){
$data = Util::postMore([
['id',0],
['stock',0],
],$request);
if(!$data['id']) return Json::fail('参数错误');
$res = ProductModel::edit(['stock'=>$data['stock']],$data['id']);
if($res) return Json::successful('修改成功');
else return Json::fail('修改失败');
}
}

View File

@ -1,118 +0,0 @@
<?php
namespace app\admin\controller\store;
use app\admin\controller\AuthController;
use service\JsonService;
use service\UtilService;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\store\StoreProductReply as ProductReplyModel;
use think\Url;
/**
* 评论管理 控制器
* Class StoreProductReply
* @package app\admin\controller\store
*/
class StoreProductReply extends AuthController
{
use CurdControllerTrait;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$where = Util::getMore([
['is_reply',''],
['comment',''],
],$this->request);
$product_id = 0;
$product_id = input('product_id');
if($product_id)
$where['product_id'] = $product_id;
else
$where['product_id'] = 0;
$this->assign('where',$where);
$this->assign('is_layui',true);
$this->assign(ProductReplyModel::systemPage($where));
return $this->fetch();
}
public function get_product_imaes_list()
{
$where=UtilService::getMore([
['page',1],
['limit',10],
['title',''],
['is_reply',''],
]);
return JsonService::successful(ProductReplyModel::getProductImaesList($where));
}
public function get_product_reply_list()
{
$where=UtilService::getMore([
['limit',10],
['title',''],
['is_reply',''],
['message_page',1],
['producr_id',0],
]);
return JsonService::successful(ProductReplyModel::getProductReplyList($where));
}
/**
* @param $id
* @return \think\response\Json|void
*/
public function delete($id){
if(!$id) return $this->failed('数据不存在');
$data['is_del'] = 1;
if(!ProductReplyModel::edit($data,$id))
return Json::fail(ProductReplyModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
public function set_reply(Request $request){
$data = Util::postMore([
'id',
'content',
],$request);
if(!$data['id']) return Json::fail('参数错误');
if($data['content'] == '') return Json::fail('请输入回复内容');
$save['merchant_reply_content'] = $data['content'];
$save['merchant_reply_time'] = time();
$save['is_reply'] = 2;
$res = ProductReplyModel::edit($save,$data['id']);
if(!$res)
return Json::fail(ProductReplyModel::getErrorInfo('回复失败,请稍候再试!'));
else
return Json::successful('回复成功!');
}
public function edit_reply(Request $request){
$data = Util::postMore([
'id',
'content',
],$request);
if(!$data['id']) return Json::fail('参数错误');
if($data['content'] == '') return Json::fail('请输入回复内容');
$save['merchant_reply_content'] = $data['content'];
$save['merchant_reply_time'] = time();
$save['is_reply'] = 2;
$res = ProductReplyModel::edit($save,$data['id']);
if(!$res)
return Json::fail(ProductReplyModel::getErrorInfo('回复失败,请稍候再试!'));
else
return Json::successful('回复成功!');
}
}

View File

@ -1,79 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\controller\AuthController;
use service\CacheService;
use service\JsonService as Json;
use think\Log;
use think\Cache;
/**
* 首页控制器
* Class Clear
* @package app\admin\controller
*
*/
class Clear extends AuthController
{
public function index()
{
return $this->fetch();
}
/**
* 刷新数据缓存
*/
public function refresh_cache(){
if(function_exists('shell_exec')){
`php think optimize:schema`;
`php think optimize:autoload`;
`php think optimize:route`;
`php think optimize:config`;
}else if(function_exists('exec')){
exec('php think optimize:schema');
exec('php think optimize:autoload');
exec('php think optimize:route');
exec('php think optimize:config');
}else{
return Json::successful('请开启shell_exec或者exec函数!');
}
return Json::successful('数据缓存刷新成功!');
}
/**
* 删除缓存
*/
public function delete_cache(){
$this->delDirAndFile(TEMP_PATH);
$this->delDirAndFile(CACHE_PATH);
return Json::successful('清除缓存成功!');
}
/**
* 删除日志
*/
public function delete_log(){
$this->delDirAndFile(LOG_PATH);
return Json::successful('清除日志成功!');
}
/** 递归删除文件
* @param $dirName
* @param bool $subdir
*/
function delDirAndFile($dirName,$subdir = true){
if ($handle = opendir("$dirName")){
while(false !== ($item = readdir($handle))){
if($item != "." && $item != ".."){
if(is_dir("$dirName/$item"))
$this->delDirAndFile("$dirName/$item",false);
else
@unlink("$dirName/$item");
}
}
closedir($handle);
if(!$subdir) @rmdir($dirName);
}
}
}

View File

@ -1,131 +0,0 @@
<?php
namespace app\admin\controller\system;
use service\FormBuilder as Form;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\system\Express as ExpressModel;
use app\admin\controller\AuthController;
/**
* 物流公司管理控制器
* Class SystemMenus
* @package app\admin\controller\system
*/
class Express extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$params = Util::getMore([
['keyword','']
],$this->request);
$this->assign(ExpressModel::systemPage($params));
$this->assign(compact('params'));
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create($cid = 0)
{
$formbuider = [
Form::input('name','公司名称')->required('公司名称名称必填'),
Form::input('code','编码'),
Form::number('sort','排序',0),
Form::radio('is_show','是否启用',1)->options([['value'=>0,'label'=>'隐藏'],['value'=>1,'label'=>'启用']]),
];
$form = Form::make_post_form('添加物流公司',$formbuider,Url::build('save'),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request)
{
$data = Util::postMore([
'name',
'code',
['sort',0],
['is_show',0]],$request);
if(!$data['name']) return Json::fail('请输入公司名称');
ExpressModel::set($data);
return Json::successful('添加公司成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$menu = ExpressModel::get($id);
if(!$menu) return Json::fail('数据不存在!');
$formbuider = [
Form::input('name','公司名称',$menu['name']),
Form::input('code','编码',$menu['code']),
Form::number('sort','排序',$menu['sort']),
Form::radio('is_show','是否启用',$menu['is_show'])->options([['value'=>0,'label'=>'隐藏'],['value'=>1,'label'=>'启用']])
];
$form = Form::make_post_form('添加物流公司',$formbuider,Url::build('update',array('id'=>$id)),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'name',
'code',
['sort',0],
['is_show',0]],$request);
if(!$data['name']) return Json::fail('请输入公司名称');
if(!ExpressModel::get($id)) return Json::fail('编辑的记录不存在!');
ExpressModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return $this->failed('参数错误,请重新打开');
$res = ExpressModel::destroy($id);
if(!$res)
return Json::fail(ExpressModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,41 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\model\system\SystemAttachment as SystemAttachmentModel;
use app\admin\controller\AuthController;
use app\core\util\SystemConfigService;
use service\UploadService as Upload;
/**
* 附件管理控制器
* Class SystemAttachment
* @package app\admin\controller\system
*
*/
class SystemAttachment extends AuthController
{
/**
* TODO 编辑器上传图片
*/
public function upload()
{
$res = Upload::image('upfile','editor/'.date('Ymd'));
if(is_array($res)){
SystemAttachmentModel::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],0,$res['image_type'],$res['time']);
$info["originalName"] = $res['name'];
$info["name"] = $res['name'];
$info["url"] = $res['dir'];
$info["size"] = $res['size'];
$info["type"] = $res['type'];
$info["state"] = "SUCCESS";
if(strstr($info['url'],'http') === false) $info['url'] = SystemConfigService::get('site_url').str_replace('\\','/',$res['dir']);
}else
$info = array(
"msg" => $res,
"state" => "ERROR"
);
echo json_encode($info);
}
}

View File

@ -1,158 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: sugar1569
* Date: 2018/5/24
* Time: 10:58
*/
namespace app\admin\controller\system;
use app\admin\controller\AuthController;
use service\JsonService as Json;
use think\db;
use think\Config;
/**
* 清除默认数据理控制器
* Class SystemclearData
* @package app\admin\controller\system
*
*/
class SystemclearData extends AuthController
{
public function index(){
return $this->fetch();
}
//清除用户数据
public function userRelevantData(){
self::clearData('user_recharge',1);
self::clearData('user_address',1);
self::clearData('user_bill',1);
self::clearData('user_enter',1);
self::clearData('user_extract',1);
self::clearData('user_notice',1);
self::clearData('user_notice_see',1);
self::clearData('wechat_qrcode',1);
self::clearData('wechat_message',1);
self::clearData('store_visit',1);
self::clearData('store_coupon_user',1);
self::clearData('store_coupon_issue_user',1);
self::clearData('store_bargain_user',1);
self::clearData('store_bargain_user_help',1);
self::clearData('store_product_reply',1);
self::clearData('routine_qrcode',1);
self::clearData('routine_form_id',1);
self::clearData('user_sign',1);
self::clearData('user_task_finish',1);
self::clearData('user_level',1);
self::clearData('token',1);
self::clearData('user_group',1);
$this->delDirAndFile('./public/uploads/store/comment');
self::clearData('store_product_relation',1);
return Json::successful('清除数据成功!');
}
//清除商城数据
public function storeData(){
self::clearData('store_coupon',1);
self::clearData('store_coupon_issue',1);
self::clearData('store_bargain',1);
self::clearData('store_combination',1);
self::clearData('store_combination_attr',1);
self::clearData('store_combination_attr_result',1);
self::clearData('store_combination_attr_value',1);
self::clearData('store_product_attr',1);
self::clearData('store_product_attr_result',1);
self::clearData('store_product_attr_value',1);
self::clearData('store_seckill',1);
self::clearData('store_seckill_attr',1);
self::clearData('store_seckill_attr_result',1);
self::clearData('store_seckill_attr_value',1);
self::clearData('store_product',1);
self::clearData('store_visit',1);
return Json::successful('清除数据成功!');
}
//清除产品分类
public function categoryData(){
self::clearData('store_category',1);
return Json::successful('清除数据成功!');
}
//清除订单数据
public function orderData(){
self::clearData('store_order',1);
self::clearData('store_order_cart_info',1);
self::clearData('store_order_status',1);
self::clearData('store_pink',1);
self::clearData('store_cart',1);
self::clearData('store_order_status',1);
return Json::successful('清除数据成功!');
}
//清除客服数据
public function kefuData(){
self::clearData('store_service',1);
$this->delDirAndFile('./public/uploads/store/service');
self::clearData('store_service_log',1);
return Json::successful('清除数据成功!');
}
//清除微信管理数据
public function wechatData(){
self::clearData('wechat_media',1);
self::clearData('wechat_reply',1);
self::clearData('cache',1);
$this->delDirAndFile('./public/uploads/wechat');
return Json::successful('清除数据成功!');
}
//清除所有附件
public function uploadData(){
self::clearData('system_attachment',1);
self::clearData('system_attachment_category',1);
$this->delDirAndFile('./public/uploads/');
return Json::successful('清除上传文件成功!');
}
//清除微信用户
public function wechatuserData(){
self::clearData('wechat_user',1);
self::clearData('user',1);
return Json::successful('清除数据成功!');
}
//清除内容分类
public function articledata(){
self::clearData('article_category',1);
self::clearData('article',1);
self::clearData('article_content',1);
return Json::successful('清除数据成功!');
}
//清除系统记录
public function systemdata(){
self::clearData('system_notice_admin',1);
self::clearData('system_log',1);
return Json::successful('清除数据成功!');
}
//清除制定表数据
public function clearData($table_name,$status){
$table_name = Config::get('database')['prefix'].$table_name;
if($status){
@db::execute('TRUNCATE TABLE '.$table_name);
}else{
@db::execute('DELETE FROM'.$table_name);
}
}
//递归删除文件
function delDirAndFile($dirName,$subdir=true){
if ($handle = @opendir("$dirName")){
while(false !== ($item = readdir($handle))){
if($item != "." && $item != ".."){
if(is_dir("$dirName/$item"))
$this->delDirAndFile("$dirName/$item",false);
else
@unlink("$dirName/$item");
}
}
closedir($handle);
if(!$subdir) @rmdir($dirName);
}
}
}

View File

@ -1,209 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use think\Request;
use service\JsonService as Json;
use \tp5er\Backup;
use think\Session;
use think\Db;
/**
* 文件校验控制器
* Class SystemDatabackup
* @package app\admin\controller\system
*
*/
class SystemDatabackup extends AuthController
{
protected $DB;
public function _initialize()
{
parent::_initialize();
$config = array(
'path' => '.'.PUBILC_PATH.'backup/data/',
//数据库备份路径
'part' => 20971520,
//数据库备份卷大小
'compress' => 1,
//数据库备份文件是否启用压缩 0不压缩 1 压缩
'level' => 5,
);
$this->DB = new Backup($config);
}
/**
* 数据类表列表
*/
public function index(){
return $this->fetch();
}
/**
* 获取数据库表
* @param Request|null $request
*/
public function tablelist(Request $request = null)
{
$db= $this->DB;
return Json::result(0,'sucess',$db->dataList(),count($db->dataList()));
}
/**
* 查看表结构
* @param Request|null $request
*/
public function seetable(Request $request = null)
{
$database = config("database.database");
$tablename = $request->param('tablename');
$res = Db::query("select * from information_schema.columns where table_name = '".$tablename."' and table_schema = '".$database."'" );
$html = '';
$html .= '<table border="1" cellspacing="0" cellpadding="0" align="center">';
$html .= '<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th><th>允许非空</th><th>自动递增</th><th>备注</th></tr>';
$html .= '';
foreach($res AS $f)
{
$html .= '<td class="c1">' . $f['COLUMN_NAME'] . '</td>';
$html .= '<td class="c2">' . $f['COLUMN_TYPE'] . '</td>';
$html .= '<td class="c3">' . $f['COLUMN_DEFAULT'] . '</td>';
$html .= '<td class="c4">' . $f['IS_NULLABLE'] . '</td>';
$html .= '<td class="c5">' . ($f['EXTRA'] == 'auto_increment'?'是':' ') . '</td>';
$html .= '<td class="c6">' . $f['COLUMN_COMMENT'] . '</td>';
$html .= '</tr>';
}
$html .= '</tbody></table></p>';
$html .= '<p style="text-align:left;margin:20px auto;">总共:' . count($res) . '个字段</p>';
$html .= '</body></html>';
echo '<style>
body,td,th {font-family:"宋体"; font-size:12px;}
table,h1,p{width:960px;margin:0px auto;}
table{border-collapse:collapse;border:1px solid #CCC;background:#efefef;}
table caption{text-align:left; background-color:#fff; line-height:2em; font-size:14px; font-weight:bold; }
table th{text-align:left; font-weight:bold;height:26px; line-height:26px; font-size:12px; border:1px solid #CCC;padding-left:5px;}
table td{height:20px; font-size:12px; border:1px solid #CCC;background-color:#fff;padding-left:5px;}
.c1{ width: 150px;}
.c2{ width: 150px;}
.c3{ width: 80px;}
.c4{ width: 100px;}
.c5{ width: 100px;}
.c6{ width: 300px;}
</style>';
echo $html;
}
/**
* 优化表
* @param Request|null $request
*/
public function optimize(Request $request = null)
{
$tables = $request->post('tables/a');
$db= $this->DB;
$res = $db->optimize($tables);
return Json::successful($res ? '优化成功':'优化失败');
}
/**修复表
* @param Request|null $request
*/
public function repair(Request $request = null)
{
$tables = $request->post('tables/a');
$db = $this->DB;
$res = $db->repair($tables);
return Json::successful($res ? '修复成功':'修复失败');
}
/**备份表
* @param Request|null $request
*/
public function backup(Request $request = null)
{
$tables = $request->post('tables/a');
$db= $this->DB;
$data = '';
foreach ($tables as $t){
$res = $db->backup($t,0);
if($res == false && $res != 0){
$data .= $t.'|';
}
}
return Json::successful($data? '备份失败'.$data:'备份成功');
}
/**获取备份记录表
*/
public function fileList()
{
$db = $this->DB;
$files = $db->fileList();
$data = [];
foreach ($files as $key=>$t){
$data[$key]['filename'] = $t['filename'];
$data[$key]['part'] = $t['part'];
$data[$key]['size'] = $t['size'].'B';
$data[$key]['compress'] = $t['compress'];
$data[$key]['backtime'] = $key;
$data[$key]['time'] = $t['time'];
}
krsort($data);//根据时间降序
return Json::result(0,'sucess',$data,count($data));
}
/**删除备份记录表
* @param Request|null $request
*/
public function delFile(Request $request = null)
{
$feilname = intval($request->post('feilname'));
$files = $this->DB->delFile($feilname);
return Json::result(0,'sucess');
}
/**倒入备份记录表
* @param Request|null $request
*/
public function import(Request $request = null)
{
$part = $request->post('part') != '' ? intval($request->post('part')) :null;
$start = $request->post('start') != '' ? intval($request->post('start')) : null;
$time = intval($request->post('time'));
$db = $this->DB;
if(is_numeric($time) && is_null($part) && is_null($start)){
$list= $db->getFile('timeverif',$time);
if(is_array($list)){
session::set('backup_list',$list);
$this->success('初始化完成!','',array('part' =>1,'start'=>0));
}else{
$this->error('备份文件可能已经损坏,请检查!');
}
}else if(is_numeric($part)&&is_numeric($start)){
$list=session::get('backup_list');
$start=$db->setFile($list)->import($start);
if(false===$start){
$this->error('还原数据出错!');
}elseif(0===$start){
if(isset($list[++$part])){
$data=array('part'=>$part,'start'=>0);
$this->success("正在还原...#{$part}",'',$data);
}else{
session::delete('backup_list');
$this->success('还原完成!');
}
}else{
$data=array('part'=>$part,'start'=>$start[0]);
if($start[1]){
$rate=floor(100*($start[0]/$start[1]));
$this->success("正在还原...#{$part}({$rate}%)",'',$data);
}else{
$data['gz']=1;
$this->success("正在还原...#{$part}",'',$data);
}
$this->success("正在还原...#{$part}",'');
}
}else{
$this->error('参数错误!');
}
// return Json::result(0,'sucess',$data,count($data));
}
/**下载备份记录表
* @param Request|null $request
*/
public function downloadFile(Request $request = null)
{
$time = intval($request->param('feilname'));
$this->DB->downloadFile($time);
}
}

View File

@ -1,277 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\model\system\SystemFile as SystemFileModel;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use think\Request;
use service\FileService as FileClass;
use service\JsonService as Json;
/**
* 文件校验控制器
* Class SystemFile
* @package app\admin\controller\system
*
*/
class SystemFile extends AuthController
{
//打开目录
public function opendir($filedir=''){
$fileAll = array('dir'=>[],'file'=>[]);
if(Request::instance()->param('superior') && !empty(Request::instance()->param('dir'))){
$path = './'.Request::instance()->param('dir');
$path = dirname($path);
}else{
$path = !empty(Request::instance()->param('dir'))?Request::instance()->param('dir'):'.';
$path = $path.'/'.Request::instance()->param('filedir');
}
$list = scandir($path);
foreach($list as $key=>$v) {
if($v !='.' && $v !='..'){
if (is_dir($path.'/'.$v)) {
$fileAll['dir'][] = FileClass::list_info($path.'/'.$v);
}
if(is_file($path.'/'.$v)){
$fileAll['file'][] = FileClass::list_info($path.'/'.$v);
}
}
}
// var_dump($fileAll['file']);
//兼容windows
$uname=php_uname('s');
if(strstr($uname,'Windows')!==false) $path = ltrim($path,'\\');
$dir = ltrim($path,'./');
$this->assign(compact('fileAll','dir'));
return $this->fetch();
}
//读取文件
public function openfile($file='')
{
$file = $this->request->param('file');
if(empty($file))return Json::fail('出现错误');
$filepath = '.'.DS.$file;
$content = htmlspecialchars(FileClass::read_file($filepath));//防止页面内嵌textarea标签
$ext = FileClass::get_ext($filepath);
$extarray = [
'js'=>'text/javascript'
,'php'=>'text/x-php'
,'html'=>'text/html'
,'sql'=>'text/x-mysql'
,'css'=>'text/x-scss'];
$mode = empty($extarray[$ext])?'':$extarray[$ext];
$this->assign(compact('content','mode','filepath'));
return $this->fetch();
}
//保存文件
public function savefile(){
$comment = $this->request->post('comment');
$filepath = $this->request->post('filepath');
if(!empty($comment) && !empty($filepath)){
//兼容windows
$uname=php_uname('s');
if(strstr($uname,'Windows')!==false)
$filepath = ltrim(str_replace('/', DS, $filepath),'.');
$res = FileClass::write_file($filepath,$comment);
if($res){
return Json::successful('保存成功!');
}else{
return Json::fail('保存失败');
}
}else{
return Json::fail('出现错误');
}
}
public function index(){
$app = $this->getDir('./application');
$extend = $this->getDir('./extend');
$public = $this->getDir('./public');
$arr = array();
$arr = array_merge($app,$extend);
$arr = array_merge($arr,$public);
$fileAll = array();//本地文件
$cha = array();//不同的文件
foreach ($arr as $k=>$v) {
$fp = fopen($v, 'r');
if (filesize($v)) $ct = fread($fp, filesize($v));
else $ct = null;
fclose($fp);
$cthash = md5($ct);
$update_time = stat($v);
$fileAll[$k]['cthash'] = $cthash;
$fileAll[$k]['filename'] = $v;
$fileAll[$k]['atime'] = $update_time['atime'];
$fileAll[$k]['mtime'] = $update_time['mtime'];
$fileAll[$k]['ctime'] = $update_time['ctime'];
}
$file = SystemFileModel::all(function($query){
$query->order('atime', 'desc');
})->toArray();//数据库中的文件
if(empty($file)){
$data_num = array_chunk($fileAll,10);
SystemFileModel::beginTrans();
$res = true;
foreach ($data_num as $k=>$v){
$res = $res && SystemFileModel::insertAll($v);
}
SystemFileModel::checkTrans($res);
if($res){
$cha = array();//不同的文件
}else{
$cha = $fileAll;
}
}else{
$cha = array();//差异文件
foreach ($file as $k=>$v){
foreach ($fileAll as $ko=>$vo){
if($v['filename'] == $vo['filename']){
if($v['cthash'] != $vo['cthash']){
$cha[$k]['filename'] = $v['filename'];
$cha[$k]['cthash'] = $v['cthash'];
$cha[$k]['atime'] = $v['atime'];
$cha[$k]['mtime'] = $v['mtime'];
$cha[$k]['ctime'] = $v['ctime'];
$cha[$k]['type'] = '已修改';
}
unset($fileAll[$ko]);
unset($file[$k]);
}
}
}
foreach ($file as $k=>$v){
$cha[$k]['filename'] = $v['filename'];
$cha[$k]['cthash'] = $v['cthash'];
$cha[$k]['atime'] = $v['atime'];
$cha[$k]['mtime'] = $v['mtime'];
$cha[$k]['ctime'] = $v['ctime'];
$cha[$k]['type'] = '已删除';
}
foreach ($fileAll as $k=>$v){
$cha[$k]['filename'] = $v['filename'];
$cha[$k]['cthash'] = $v['cthash'];
$cha[$k]['atime'] = $v['atime'];
$cha[$k]['mtime'] = $v['mtime'];
$cha[$k]['ctime'] = $v['ctime'];
$cha[$k]['type'] = '新增的';
}
}
// dump($file);
// dump($fileAll);
$this->assign('cha',$cha);
return $this->fetch();
}
/**
* 获取文件夹中的文件 不包括子文件
* @param $dir
* @return array
*/
public function getNextDir(){
$dir = './';
$list = scandir($dir);
$dirlist = array();
$filelist = array();
foreach($list as $key=>$v) {
if($v !='.' && $v !='..'){
if (is_dir($dir.'/'.$v)) {
$dirlist['dir'][$key] = $v;
}
if(is_file($dir.'/'.$v)){
$filelist['file'][$key] = $v;
}
}
}
$filesarr = array_merge($dirlist,$filelist);
print_r($filesarr);
}
/**
* 获取文件夹中的文件 包括子文件 不能直接用 直接使用 $this->getDir()方法 P156
* @param $path
* @param $data
*/
public function searchDir($path,&$data){
if(is_dir($path) && !strpos($path,'uploads')){
$dp=dir($path);
while($file=$dp->read()){
if($file!='.'&& $file!='..'){
$this->searchDir($path.'/'.$file,$data);
}
}
$dp->close();
}
if(is_file($path)){
$data[]=$path;
}
}
/**
* 获取文件夹中的文件 包括子文件
* @param $dir
* @return array
*/
public function getDir($dir){
$data=array();
$this->searchDir($dir,$data);
return $data;
}
//测试
public function ceshi(){
//创建form
$form = Form::create('/save.php',[
Form::input('goods_name','商品名称')
,Form::input('goods_name1','password')->type('password')
,Form::input('goods_name2','textarea')->type('textarea')
,Form::input('goods_name3','email')->type('email')
,Form::input('goods_name4','date')->type('date')
,Form::city('address','cityArea',
'陕西省','西安市'
)
,Form::dateRange('limit_time','dateRange',
strtotime('- 10 day'),
time()
)
,Form::dateTime('add_time','dateTime')
,Form::color('color','color','#ff0000')
,Form::checkbox('checkbox','checkbox',[1])->options([['value'=>1,'label'=>'白色'],['value'=>2,'label'=>'红色'],['value'=>31,'label'=>'黑色']])
,Form::date('riqi','date','2018-03-1')
,Form::dateTimeRange('dateTimeRange','区间时间段')
,Form::year('year','year')
,Form::month('month','month')
,Form::frame('frame','frame','/admin/system.system_attachment/index.html?fodder=frame')
,Form::frameInputs('frameInputs','frameInputs','/admin/system.system_attachment/index.html?fodder=frameInputs')
,Form::frameFiles('month1','frameFiles','/admin/system.system_attachment/index.html?fodder=month1')
,Form::frameImages('fodder1','frameImages','/admin/system.system_attachment/index.html?fodder=fodder1')->maxLength(3)->width('800px')->height('400px')
,Form::frameImages('fodder11','frameImages','/admin/system.system_attachment/index.html?fodder=fodder11')->icon('images')
,Form::frameInputOne('month3','frameInputOne','/admin/system.system_attachment/index.html?fodder=month3')->icon('ionic')
,Form::frameFileOne('month4','frameFileOne','/admin/system.system_attachment/index.html?fodder=month4')
,Form::frameImageOne('month5','frameImageOne','/admin/system.system_attachment/index.html?fodder=month5')->icon('image')
,Form::hidden('month6','hidden')
,Form::number('month7','number')
// ,Form::input input输入框,其他type: text类型Form::text,password类型Form::password,textarea类型Form::textarea,url类型Form::url,email类型Form::email,date类型Form::idate
,Form::radio('month8','radio')->options([['value'=>1,'label'=>'白色'],['value'=>2,'label'=>'红色'],['value'=>31,'label'=>'黑色']])
,Form::rate('month9','rate')
,Form::select('month10','select')->options([['value'=>1,'label'=>'白色'],['value'=>2,'label'=>'红色'],['value'=>31,'label'=>'黑色']])
,Form::selectMultiple('month11','selectMultiple')
,Form::selectOne('month12','selectOne')
,Form::slider('month13','slider',2)
,Form::sliderRange('month23','sliderRange',2,13)
,Form::switches('month14','区间时间段')
,Form::timePicker('month15','区间时间段')
,Form::time('month16','区间时间段')
,Form::timeRange('month17','区间时间段')
// ,Form::upload('month','区间时间段')
// ,Form::uploadImages('month','区间时间段')
// ,Form::uploadFiles('month','区间时间段')
// ,Form::uploadImageOne('month','区间时间段')
// ,Form::uploadFileOne('month','区间时间段')
]);
$html = $form->setMethod('get')->setTitle('编辑商品')->view();
echo $html;
}
}

View File

@ -1,42 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemAdmin;
use app\admin\model\system\SystemLog as LogModel;
use service\UtilService as Util;
/**
* 管理员操作记录表控制器
* Class SystemLog
* @package app\admin\controller\system
*/
class SystemLog extends AuthController
{
/**
* 显示操作记录
*/
public function index(){
LogModel::deleteLog();
$where = Util::getMore([
['pages',''],
['path',''],
['ip',''],
['admin_id',''],
['data',''],
],$this->request);
$where['level'] = $this->adminInfo['level'];
$this->assign('where',$where);
$this->assign('admin',SystemAdmin::getOrdAdmin('id,real_name',$this->adminInfo['level']));
$this->assign(LogModel::systemPage($where));
return $this->fetch();
}
}

View File

@ -1,196 +0,0 @@
<?php
namespace app\admin\controller\system;
use app\admin\controller\AuthController;
use service\JsonService as Json;
use service\UpgradeService as uService;
use think\Db;
use app\admin\model\system\SystemConfig;
/**
* 在线升级控制器
* Class SystemUpgradeclient
* @package app\admin\controller\system
*
*/
class SystemUpgradeclient extends AuthController
{
protected $serverweb = array('version'=>'1.0','version_code'=>0);//本站点信息
public function _initialize()
{
parent::_initialize();
//屏蔽所有错误避免操作文件夹发生错误提示
ini_set('display_errors',0);
error_reporting(0);
self::snyweninfo();//更新站点信息
$this->assign(['auth'=>self::isauth(),'app'=>uService::isWritable(APP_PATH),'extend'=>uService::isWritable(EXTEND_PATH),'public'=>uService::isWritable(ROOT_PATH.'public')]);
}
//同步更新站点信息
public function snyweninfo(){
$this->serverweb['ip'] = $this->request->ip();
$this->serverweb['host'] = $this->request->host();
$this->serverweb['https'] = !empty($this->request->domain())?$this->request->domain():SystemConfig::getValue('site_url');
$this->serverweb['webname'] = SystemConfig::getValue('site_name');
$local=uService::getVersion();
if($local['code']==200 && isset($local['msg']['version']) && isset($local['msg']['version_code'])){
$this->serverweb['version'] = uService::replace($local['msg']['version']);
$this->serverweb['version_code'] = (int)uService::replace($local['msg']['version_code']);
}
uService::snyweninfo($this->serverweb);
}
//是否授权
public function isauth(){
return uService::isauth();
}
public function index(){
$server=uService::start();
$version=$this->serverweb['version'];
$version_code=$this->serverweb['version_code'];
$this->assign(compact('server','version','version_code'));
return $this->fetch();
}
public function get_list(){
$list=uService::request_post(uService::$isList,['page'=>input('post.page/d'),'limit'=>input('post.limit/d')]);
if(is_array($list) && isset($list['code']) && isset($list['data']) && $list['code']==200){
$list=$list['data'];
}else{
$list=[];
}
Json::successful('ok',['list'=>$list,'page'=>input('post.page/d')+1]);
}
//删除备份文件
public function setcopydel(){
$post=input('post.');
if(!isset($post['id'])) Json::fail('删除备份文件失败缺少参数ID');
if(!isset($post['ids'])) Json::fail('删除备份文件失败缺少参数IDS');
$fileservice=new uService;
if(is_array($post['ids'])){
foreach ($post['ids'] as $file){
$fileservice->del_dir(ROOT_PATH.'public'.DS.'copyfile'.$file);
}
}
if($post['id']){
$copyFile=ROOT_PATH.'public'.DS.'copyfile'.$post['id'];
$fileservice->del_dir($copyFile);
}
Json::successful('删除成功');
}
public function get_new_version_conte(){
$post=$this->request->post();
if(!isset($post['id'])) Json::fail('缺少参数ID');
$versionInfo=uService::request_post(uService::$NewVersionCount,['id'=>$post['id']]);
if(isset($versionInfo['code']) && isset($versionInfo['data']['count']) && $versionInfo['code']==200){
return Json::successful(['count'=>$versionInfo['data']['count']]);
}else{
return Json::fail('服务器异常');
}
}
//一键升级
public function auto_upgrad(){
$prefix=config('database.prefix');
$fileservice=new uService;
$post=$this->request->post();
if(!isset($post['id'])) Json::fail('缺少参数ID');
$versionInfo=$fileservice->request_post(uService::$isNowVersion,['id'=>$post['id']]);
if($versionInfo===null) Json::fail('服务器异常,请稍后再试');
if(isset($versionInfo['code']) && $versionInfo['code']==400) Json::fail(isset($versionInfo['msg'])?$versionInfo['msg']:'您暂时没有权限升级,请联系管理员!');
if(is_array($versionInfo) && isset($versionInfo['data'])){
$list=$versionInfo['data'];
$id=[];
foreach ($list as $key=>$val){
$savefile=ROOT_PATH . 'public' . DS.'upgrade_lv';
//1检查远程下载文件并下载
if(($save_path=$fileservice->check_remote_file_exists($val['zip_name'],$savefile))===false) Json::fail('远程升级包不存在');
//2首先解压文件
$savename=ROOT_PATH.'public'.DS.'upgrade_lv'.DS.time();
$fileservice->zipopen($save_path,$savename);
//3执行SQL文件
Db::startTrans();
try{
//参数3不介意大小写的
$sqlfile=$fileservice->list_dir_info($savename.DS,true,'sql');
if(is_array($sqlfile) && !empty($sqlfile)){
foreach($sqlfile as $file){
if(file_exists($file)){
//为一键安装做工作记得表前缀要改为[#DB_PREFIX#]哦
$execute_sql=explode(";\r",str_replace(['[#DB_PREFIX#]', "\n"], [$prefix, "\r"], file_get_contents($file)));
foreach($execute_sql as $_sql){
if ($query_string = trim(str_replace(array(
"\r",
"\n",
"\t"
), '', $_sql))) Db::execute($query_string);
}
//执行完sql记得删掉哦
$fileservice->unlink_file($file);
}
}
}
Db::commit();
}catch(\Exception $e){
Db::rollback();
//删除解压下的文件
$fileservice->del_dir(ROOT_PATH.'public'.DS.'upgrade_lv');
//删除压缩包
$fileservice->unlink_file($save_path);
//升级失败发送错误信息
$fileservice->request_post(uService::$isInsertLog,[
'content'=>'升级失败,错误信息为:'.$e->getMessage(),
'add_time'=>time(),
'ip'=>$this->request->ip(),
'http'=>$this->request->domain(),
'type'=>'error',
'version'=>$val['version']
]);
return Json::fail('升级失败SQL文件执行有误');
}
//4,备份文件
$copyFile=ROOT_PATH.'public'.DS.'copyfile'.$val['id'];
$copyList=$fileservice->get_dirs($savename.DS);
if(isset($copyList['dir'])){
if($copyList['dir'][0]=='.' && $copyList['dir'][1]=='..'){
array_shift($copyList['dir']);
array_shift($copyList['dir']);
}
foreach($copyList['dir'] as $dir){
if(file_exists(ROOT_PATH.$dir,$copyFile.DS.$dir)){
$fileservice->copy_dir(ROOT_PATH.$dir,$copyFile.DS.$dir);
}
}
}
//5覆盖文件
$fileservice->handle_dir($savename,ROOT_PATH);
//6,删除升级生成的目录
$fileservice->del_dir(ROOT_PATH.'public'.DS.'upgrade_lv');
//7,删除压缩包
$fileservice->unlink_file($save_path);
//8,改写本地升级文件
$handle=fopen(APP_PATH.'version.php','w+');
if($handle===false) Json::fail(APP_PATH.'version.php'.'无法写入打开');
$content=<<<EOT
version={$val['version']}
version_code={$val['id']}
EOT;
if(fwrite($handle,$content)===false) Json::fail('升级包写入失败');
fclose($handle);
//9,向服务端发送升级日志
$posts=[
'ip'=>$this->request->ip(),
'https'=>$this->request->domain(),
'update_time'=>time(),
'content'=>'一键升级成功,升级版本号为:'.$val['version'].'。版本code为'.$val['id'],
'type'=>'log',
'versionbefor'=>$this->serverweb['version'],
'versionend'=>$val['version']
];
$inset=$fileservice->request_post(uService::$isInsertLog,$posts);
$id[]=$val['id'];
}
//10,升级完成
Json::successful('升级成功',['code'=>end($id),'version'=>$val['version']]);
}else{
Json::fail('服务器异常,请稍后再试');
}
}
}

View File

@ -1,345 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/16 0016
* Time: 10:39
*/
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use app\admin\model\store\StoreProduct;
use service\JsonService;
use service\UtilService as Util;
use service\FormBuilder as Form;
use service\UtilService;
use traits\CurdControllerTrait;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use think\Url;
use app\admin\model\store\StoreProduct as ProductModel;
use app\admin\model\ump\StoreBargain as StoreBargainModel;
use app\admin\model\system\SystemAttachment;
//砍价
class StoreBargain extends AuthController
{
use CurdControllerTrait;
protected $bindModel = StoreBargainModel::class;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$where = Util::getMore([
['status',''],
['store_name',''],
['export',0],
['data',''],
],$this->request);
$limitTimeList = [
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y/m/d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
$this->assign('where',$where);
$this->assign('countBargain',StoreBargainModel::getCountBargain());
$this->assign('limitTimeList',$limitTimeList);
$this->assign(StoreBargainModel::systemPage($where));
$this->assign('bargainId',StoreBargainModel::getBargainIdAll($where));
return $this->fetch();
}
/**
* 异步获取砍价数据
*/
public function get_bargain_list(){
$where=Util::getMore([
['page',1],
['limit',20],
['export',0],
['store_name',''],
['status',''],
['data','']
]);
$bargainList = StoreBargainModel::systemPage($where);
if(is_object($bargainList['list'])) $bargainList['list'] = $bargainList['list']->toArray();
$data = $bargainList['list']['data'];
foreach ($data as $k=>$v){
$data[$k]['_stop_time'] = date('Y/m/d H:i:s',$v['stop_time']);
}
return Json::successlayui(['count'=>$bargainList['list']['total'],'data'=>$data]);
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/bargain/'.date('Ymd'));
if(is_array($res)){
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],3,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}else
return Json::fail($res);
}
/**
* 添加砍价
* @param int $id
* @return \think\Response
*/
public function create()
{
$f = array();
$f[] = Form::input('title','砍价活动名称');
$f[] = Form::input('info','砍价活动简介')->type('textarea');
$f[] = Form::input('store_name','砍价产品名称');
$f[] = Form::input('unit_name','单位')->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间');
$f[] = Form::formFrameImageOne('image','产品主图片(305*305px)');
$f[] = Form::formFrameImages('images','产品轮播图(640*640px)');
$f[] = Form::number('price','显示原价')->min(0)->col(12);
$f[] = Form::number('min_price','最低购买价')->min(0);
$f[] = Form::number('bargain_max_price','单次砍价的最大金额')->min(0)->col(12);
$f[] = Form::number('bargain_min_price','单次砍价的最小金额')->min(0)->col(12);
$f[] = Form::number('cost','成本价')->min(0)->col(12);
$f[] = Form::number('bargain_num','单次砍价的次数')->min(0)->col(12);
$f[] = Form::number('stock','库存')->min(0)->col(12);
$f[] = Form::number('sales','销量')->min(0)->col(12);
$f[] = Form::number('sort','排序')->col(12);
$f[] = Form::number('num','单次允许购买数量')->col(12);
$f[] = Form::number('give_integral','赠送积分')->min(0)->col(12);
$f[] = Form::number('postage','邮费')->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',1)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('update'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreBargainModel::get($id);
if(!$product) return $this->failed('数据不存在!');
$f = array();
$f[] = Form::input('title','砍价活动名称',$product->getData('title'));
$f[] = Form::hidden('product_id',$product->getData('product_id'));
$f[] = Form::input('info','砍价活动简介',$product->getData('info'))->type('textarea');
$f[] = Form::input('store_name','砍价产品名称',$product->getData('store_name'));
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间',$product->getData('start_time'),$product->getData('stop_time'));//->format("yyyy-MM-dd HH:mm:ss");
$f[] = Form::formFrameImageOne('image','产品主图片(305*305px)',$product->getData('image'));
$f[] = Form::formFrameImages('images','产品轮播图(640*640px)',json_decode($product->getData('images'),1));
$f[] = Form::number('price','显示原价',$product->getData('price'))->min(0)->col(12);
$f[] = Form::number('min_price','最低购买价',$product->getData('min_price'))->min(0)->col(12);
$f[] = Form::number('bargain_max_price','单次砍价的最大金额',$product->getData('bargain_max_price'))->min(0)->col(12);
$f[] = Form::number('bargain_min_price','单次砍价的最小金额',$product->getData('bargain_min_price'))->min(0)->col(12);
$f[] = Form::number('cost','成本价',$product->getData('cost'))->min(0)->col(12);
$f[] = Form::number('bargain_num','单次砍价的次数',$product->getData('bargain_num'))->min(0)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(0)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->col(12);
$f[] = Form::number('sort','排序',$product->getData('sort'))->col(12);
$f[] = Form::number('num','单次允许购买数量',$product->getData('num'))->col(12);
$f[] = Form::number('give_integral','赠送积分',$product->getData('give_integral'))->min(0)->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',$product->getData('is_hot'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id='')
{
$data = UtilService::postMore([
['title',''],
['info',''],
['store_name',''],
['unit_name',''],
['section_time',[]],
['image',''],
['images',[]],
['price',0],
['min_price',0],
['bargain_max_price',0],
['bargain_min_price',0],
['cost',0],
['bargain_num',0],
['stock',0],
['sales',0],
['sort',0],
['num',0],
['give_integral',0],
['postage',0],
['is_postage',0],
['is_hot',0],
['status',0],
['product_id',0]
],$request);
if($data['title'] == '') return JsonService::fail('请输入砍价活动名称');
if($data['info'] == '') return JsonService::fail('请输入砍价活动简介');
if($data['store_name'] == '') return JsonService::fail('请输入砍价产品名称');
if($data['unit_name'] == '') return JsonService::fail('请输入产品单位');
if(count($data['section_time'])<1) return JsonService::fail('请选择活动时间');
if(!$data['section_time'][0]) return JsonService::fail('请选择活动时间');
if(!$data['section_time'][1]) return JsonService::fail('请选择活动时间');
$data['start_time'] = strtotime($data['section_time'][0]);
$data['stop_time'] = strtotime($data['section_time'][1]);
unset($data['section_time']);
if(!($data['image'])) return JsonService::fail('请选择推荐图');
if(count($data['images'])<1) return JsonService::fail('请选择轮播图');
$data['images'] = json_encode($data['images']);
if($data['price'] == '' || $data['price'] < 0) return JsonService::fail('请输入砍价金额');
if($data['min_price'] == '' || $data['min_price'] < 0) return JsonService::fail('请输入砍价最低金额');
if($data['bargain_max_price'] == '' || $data['bargain_max_price'] < 0) return JsonService::fail('请输入用户单次砍价的最大金额');
if($data['bargain_min_price'] == '' || $data['bargain_min_price'] < 0) return JsonService::fail('请输入用户单次砍价的最小金额');
if($data['cost'] == '' || $data['cost'] < 0) return JsonService::fail('请输入成本价');
if($data['bargain_num'] == '' || $data['bargain_num'] < 0) return JsonService::fail('请输入用户单次砍价的次数');
if($data['stock'] == '' || $data['stock'] < 0) return JsonService::fail('请输入库存');
if($data['num'] == '' || $data['num'] < 0) return JsonService::fail('请输入单次购买的砍价产品数量');
unset($data['img']);
if($id){
$product = StoreBargainModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$res = StoreBargainModel::edit($data,$id);
if($res) return JsonService::successful('修改成功');
else return JsonService::fail('修改失败');
}
else{
$data['add_time'] = time();
$res = StoreBargainModel::set($data);
if($res) return JsonService::successful('添加成功');
else return JsonService::fail('添加成功');
}
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return Json::fail('数据不存在');
$product = StoreBargainModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['is_del']) return Json::fail('已删除!');
$data['is_del'] = 1;
if(StoreBargainModel::edit($data,$id))
return Json::successful('删除成功!');
else
return Json::fail(StoreBargainModel::getErrorInfo('删除失败,请稍候再试!'));
}
/**
* 显示内容窗口
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit_content($id){
if(!$id) return $this->failed('数据不存在');
$seckill = StoreBargainModel::get($id);
if(!$seckill) return $this->failed('数据不存在');
$this->assign([
'content'=>StoreBargainModel::where('id',$id)->value('description'),
'field'=>'description',
'action'=>Url::build('change_field',['id'=>$id,'field'=>'description'])
]);
return $this->fetch('public/edit_content');
}
public function edit_rule($id){
if(!$id) return $this->failed('数据不存在');
$seckill = StoreBargainModel::get($id);
if(!$seckill) return $this->failed('数据不存在');
$this->assign([
'content'=>StoreBargainModel::where('id',$id)->value('rule'),
'field'=>'rule',
'action'=>Url::build('change_field',['id'=>$id,'field'=>'rule'])
]);
return $this->fetch('public/edit_content');
}
/**
* 开启砍价产品
* @param int $id
* @return mixed|\think\response\Json|void
*/
public function bargain($id = 0){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('title','砍价活动名称');
$f[] = Form::input('info','砍价活动简介')->type('textarea');
$f[] = Form::hidden('product_id',$product->getData('id'));
$f[] = Form::input('store_name','砍价产品名称',$product->getData('store_name'));
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间');//->format("yyyy-MM-dd HH:mm:ss");
$f[] = Form::formFrameImageOne('image','产品主图片(305*305px)',$product->getData('image'));
$f[] = Form::formFrameImages('images','产品轮播图(640*640px)',json_decode($product->getData('slider_image'),1));
$f[] = Form::number('price','砍价金额')->min(0)->col(12);
$f[] = Form::number('min_price','砍价最低金额',0)->min(0)->col(12);
$f[] = Form::number('bargain_max_price','单次砍价的最大金额',10)->min(0)->col(12);
$f[] = Form::number('bargain_min_price','单次砍价的最小金额',0.01)->min(0)->precision(2)->col(12);
$f[] = Form::number('cost','成本价',$product->getData('cost'))->min(0)->col(12);
$f[] = Form::number('bargain_num','单次砍价的次数',1)->min(0)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(1)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->col(12);
$f[] = Form::number('sort','排序',$product->getData('sort'))->col(12);
$f[] = Form::number('num','单次购买的砍价产品数量',1)->col(12);
$f[] = Form::number('give_integral','赠送积分',$product->getData('give_integral'))->min(0)->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',$product->getData('is_hot'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('开启砍价活动',$f,Url::build('update'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 修改砍价状态
* @param $status
* @param int $id
*/
public function set_bargain_status($status,$id = 0){
if(!$id) return JsonService::fail('参数错误');
$res = StoreBargainModel::edit(['status'=>$status],$id);
if($res) return JsonService::successful('修改成功');
else return JsonService::fail('修改失败');
}
}

View File

@ -1,397 +0,0 @@
<?php
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\store\StoreProduct as ProductModel;
use app\admin\model\ump\StoreCombinationAttr;
use app\admin\model\ump\StoreCombinationAttrResult;
use app\admin\model\ump\StoreCombination as StoreCombinationModel;
use think\Url;
use app\admin\model\system\SystemAttachment;
use app\admin\model\ump\StorePink;
/**
* 拼团管理
* Class StoreCombination
* @package app\admin\controller\store
*/
class StoreCombination extends AuthController
{
use CurdControllerTrait;
protected $bindModel = StoreCombinationModel::class;
/**
* @return mixed
*/
public function index()
{
$this->assign('countCombination',StoreCombinationModel::getCombinationCount());
$this->assign(StoreCombinationModel::getStatistics());
$this->assign('combinationId',StoreCombinationModel::getCombinationIdAll());
return $this->fetch();
}
public function save_excel(){
$where = Util::getMore([
['is_show',''],
['store_name',''],
]);
StoreCombinationModel::SaveExcel($where);
}
/**
* 异步获取拼团数据
*/
public function get_combination_list(Request $request){
$where=Util::getMore([
['page',1],
['limit',20],
['export',0],
['is_show',''],
['is_host',''],
['store_name','']
],$request);
$combinationList = StoreCombinationModel::systemPage($where);
if(is_object($combinationList['list'])) $combinationList['list'] = $combinationList['list']->toArray();
$data = $combinationList['list']['data'];
foreach ($data as $k=>$v){
$data[$k]['_stop_time'] = date('Y/m/d H:i:s',$v['stop_time']);
}
return Json::successlayui(['count'=>$combinationList['list']['total'],'data'=>$data]);
}
public function combination($id = 0){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::hidden('product_id',$id);
// $f[] = Form::select('product_id','产品名称')->setOptions(function(){
// $list = ProductModel::getTierList();
// foreach ($list as $menu){
// $menus[] = ['value'=>$menu['id'],'label'=>$menu['store_name'].'/'.$menu['id']];
// }
// return $menus;
// })->filterable(1);
$f[] = Form::input('title','拼团名称',$product->getData('store_name'));
$f[] = Form::input('info','拼团简介',$product->getData('store_info'))->type('textarea');
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','拼团时间');
$f[] = Form::frameImageOne('image','产品主图片(305*305px)',Url::build('admin/widget.images/index',array('fodder'=>'image')),$product->getData('image'))->icon('image')->width('100%')->height('500px');
$f[] = Form::frameImages('images','产品轮播图(640*640px)',Url::build('admin/widget.images/index',array('fodder'=>'images')),json_decode($product->getData('slider_image')))->maxLength(5)->icon('images')->width('100%')->height('500px');
$f[] = Form::number('price','拼团价')->min(0)->col(12);
$f[] = Form::number('people','拼团人数')->min(2)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序')->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_host','热门推荐',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('is_show','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create()
{
$f = array();
$f[] = Form::select('product_id','产品名称')->setOptions(function(){
$list = ProductModel::getTierList();
foreach ($list as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['store_name'].'/'.$menu['id']];
}
return $menus;
})->filterable(1);
$f[] = Form::input('title','拼团名称');
$f[] = Form::input('info','拼团简介')->type('textarea');
$f[] = Form::input('unit_name','单位')->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','拼团时间');
$f[] = Form::formFrameImageOne('image','产品主图片(305*305px)');
$f[] = Form::formFrameImages('images','产品轮播图(640*640px)');
$f[] = Form::number('price','拼团价')->min(0)->col(12);
$f[] = Form::number('people','拼团人数')->min(2)->col(12);
$f[] = Form::number('stock','库存')->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量')->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序')->col(12);
$f[] = Form::number('postage','邮费')->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',1)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_host','热门推荐',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('is_show','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request,$id=0)
{
$data = Util::postMore([
'product_id',
'title',
'info',
['image',''],
['images',[]],
['section_time',[]],
'postage',
'price',
'people',
'sort',
'stock',
'sales',
['is_show',0],
['is_host',0],
['is_postage',0],
],$request);
if(!$data['title']) return Json::fail('请输入拼团名称');
if(!$data['info']) return Json::fail('请输入拼团简介');
if(!$data['image']) return Json::fail('请上传产品图片');
if(count($data['images'])<1) return Json::fail('请上传产品轮播图');
if($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品售价');
if($data['people'] == '' || $data['people'] < 1) return Json::fail('请输入拼团人数');
if(count($data['section_time'])<1) return Json::fail('请选择活动时间');
if($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
$data['images'] = json_encode($data['images']);
$data['start_time'] = strtotime($data['section_time'][0]);
$data['stop_time'] = strtotime($data['section_time'][1]);
unset($data['section_time']);
if($id){
$product = StoreCombinationModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$data['product_id']=$product['product_id'];
StoreCombinationModel::edit($data,$id);
return Json::successful('编辑成功!');
}else{
$data['add_time'] = time();
$data['description'] = '';
StoreCombinationModel::set($data);
return Json::successful('添加拼团成功!');
}
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreCombinationModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::hidden('product_id',$product->getData('product_id'));
$f[] = Form::input('title','拼团名称',$product->getData('title'));
$f[] = Form::input('info','拼团简介',$product->getData('info'))->type('textarea');
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','拼团时间',$product->getData('start_time'),$product->getData('stop_time'));
$f[] = Form::frameImageOne('image','产品主图片(305*305px)',Url::build('admin/widget.images/index',array('fodder'=>'image')),$product->getData('image'))->icon('image')->width('100%')->height('500px');
$f[] = Form::frameImages('images','产品轮播图(640*640px)',Url::build('admin/widget.images/index',array('fodder'=>'images')),json_decode($product->getData('images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
$f[] = Form::number('price','拼团价',$product->getData('price'))->min(0)->col(12);
$f[] = Form::number('people','拼团人数',$product->getData('people'))->min(2)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序',$product->getData('sort'))->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_host','热门推荐',$product->getData('is_host'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('is_show','活动状态',$product->getData('is_show'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
// $this->assign([
// 'title'=>'编辑产品','rules'=>$this->read($id)->getContent(),
// 'action'=>Url::build('update',array('id'=>$id))
// ]);
// return $this->fetch('public/common_form');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreCombinationModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['is_del']) return Json::fail('已删除!');
$data['is_del'] = 1;
if(!StoreCombinationModel::edit($data,$id))
return Json::fail(StoreCombinationModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 属性页面
* @param $id
* @return mixed|void
*/
public function attr($id)
{
if(!$id) return $this->failed('数据不存在!');
$result = StoreCombinationAttrResult::getResult($id);
$image = StoreCombinationModel::where('id',$id)->value('image');
$this->assign(compact('id','result','product','image'));
return $this->fetch();
}
/**
* 生成属性
* @param int $id
*/
public function is_format_attr($id = 0){
if(!$id) return Json::fail('产品不存在');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$product = StoreCombinationModel::get($id);
if(!$product) return Json::fail('产品不存在');
$attrFormat = attrFormat($attr)[1];
if(count($detail)){
foreach ($attrFormat as $k=>$v){
foreach ($detail as $kk=>$vv){
if($v['detail'] == $vv['detail']){
$attrFormat[$k]['price'] = $vv['price'];
$attrFormat[$k]['sales'] = $vv['sales'];
$attrFormat[$k]['pic'] = $vv['pic'];
$attrFormat[$k]['check'] = false;
break;
}else{
$attrFormat[$k]['price'] = '';
$attrFormat[$k]['sales'] = '';
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = true;
}
}
}
}else{
foreach ($attrFormat as $k=>$v){
$attrFormat[$k]['price'] = $product['price'];
$attrFormat[$k]['sales'] = $product['stock'];
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = false;
}
}
return Json::successful($attrFormat);
}
/**
* 添加 修改属性
* @param $id
*/
public function set_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$res = StoreCombinationAttr::createProductAttr($attr,$detail,$id);
if($res)
return $this->successful('编辑属性成功!');
else
return $this->failed(StoreCombinationAttr::getErrorInfo());
}
/**
* 清除属性
* @param $id
*/
public function clear_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
if(false !== StoreCombinationAttr::clearProductAttr($id) && false !== StoreCombinationAttrResult::clearResult($id))
return $this->successful('清空产品属性成功!');
else
return $this->failed(StoreCombinationAttr::getErrorInfo('清空产品属性失败!'));
}
public function edit_content($id){
if(!$id) return $this->failed('数据不存在');
$product = StoreCombinationModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$this->assign([
'content'=>StoreCombinationModel::where('id',$id)->value('description'),
'field'=>'description',
'action'=>Url::build('change_field',['id'=>$id,'field'=>'description'])
]);
return $this->fetch('public/edit_content');
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/product/'.date('Ymd'));
if(is_array($res)){
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],2,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}else
return Json::fail($res);
}
/**拼团列表
* @return mixed
*/
public function combina_list()
{
$where = Util::getMore([
['status',''],
['data',''],
],$this->request);
$this->assign('where',$where);
$this->assign(StorePink::systemPage($where));
return $this->fetch();
}
/**拼团人列表
* @return mixed
*/
public function order_pink($id){
if(!$id) return $this->failed('数据不存在');
$StorePink = StorePink::getPinkUserOne($id);
if(!$StorePink) return $this->failed('数据不存在!');
$list = StorePink::getPinkMember($id);
$list[] = $StorePink;
$this->assign('list',$list);
return $this->fetch();
}/**
* 修改拼团状态
* @param $status
* @param int $idd
*/
public function set_combination_status($status,$id = 0){
if(!$id) return Json::fail('参数错误');
$res = StoreCombinationModel::edit(['is_show'=>$status],$id);
if($res) return Json::successful('修改成功');
else return Json::fail('修改失败');
}
}

View File

@ -1,281 +0,0 @@
<?php
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use app\admin\model\ump\StoreCouponIssue;
use app\admin\model\wechat\WechatUser as UserModel;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UtilService;
use think\Request;
use app\admin\model\ump\StoreCoupon as CouponModel;
use think\Url;
/**
* 优惠券控制器
* Class StoreCategory
* @package app\admin\controller\system
*/
class StoreCoupon extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$where = Util::getMore([
['status',''],
['title',''],
],$this->request);
$this->assign('where',$where);
$this->assign(CouponModel::systemPage($where));
return $this->fetch();
}
/**
* @return mixed
*/
public function create()
{
$f = array();
$f[] = Form::input('title','优惠券名称');
$f[] = Form::number('coupon_price','优惠券面值',0)->min(0);
$f[] = Form::number('use_min_price','优惠券最低消费')->min(0);
$f[] = Form::number('coupon_time','优惠券有效期限')->min(0);
$f[] = Form::number('sort','排序');
$f[] = Form::radio('status','状态',0)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加优惠券',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* @param Request $request
* @return \think\response\Json
*/
public function save(Request $request)
{
$data = Util::postMore([
'title',
'coupon_price',
'use_min_price',
'coupon_time',
'sort',
['status',0]
],$request);
if(!$data['title']) return Json::fail('请输入优惠券名称');
if(!$data['coupon_price']) return Json::fail('请输入优惠券面值');
if(!$data['coupon_time']) return Json::fail('请输入优惠券有效期限');
$data['add_time'] = time();
CouponModel::set($data);
return Json::successful('添加优惠券成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$coupon = CouponModel::get($id);
if(!$coupon) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('title','优惠券名称',$coupon->getData('title'));
$f[] = Form::number('coupon_price','优惠券面值',$coupon->getData('coupon_price'))->min(0);
$f[] = Form::number('use_min_price','优惠券最低消费',$coupon->getData('use_min_price'))->min(0);
$f[] = Form::number('coupon_time','优惠券有效期限',$coupon->getData('coupon_time'))->min(0);
$f[] = Form::number('sort','排序',$coupon->getData('sort'));
$f[] = Form::radio('status','状态',$coupon->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加优惠券',$f,Url::build('update',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存更新的资源
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id)
{
$data = Util::postMore([
'title',
'coupon_price',
'use_min_price',
'coupon_time',
'sort',
['status',0]
],$request);
if(!$data['title']) return Json::fail('请输入优惠券名称');
if(!$data['coupon_price']) return Json::fail('请输入优惠券面值');
if(!$data['coupon_time']) return Json::fail('请输入优惠券有效期限');
CouponModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return Json::fail('数据不存在!');
$data['is_del'] = 1;
if(!CouponModel::edit($data,$id))
return Json::fail(CouponModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 修改优惠券状态
* @param $id
* @return \think\response\Json
*/
public function status($id)
{
if(!$id) return Json::fail('数据不存在!');
if(!CouponModel::editIsDel($id))
return Json::fail(CouponModel::getErrorInfo('修改失败,请稍候再试!'));
else
return Json::successful('修改成功!');
}
/**
* @return mixed
*/
public function grant_subscribe(){
$where = Util::getMore([
['status',''],
['title',''],
['is_del',0],
],$this->request);
$this->assign('where',$where);
$this->assign(CouponModel::systemPageCoupon($where));
return $this->fetch();
}
/**
* @return mixed
*/
public function grant_all(){
$where = Util::getMore([
['status',''],
['title',''],
['is_del',0],
],$this->request);
$this->assign('where',$where);
$this->assign(CouponModel::systemPageCoupon($where));
return $this->fetch();
}
/**
* @param $id
*/
public function grant($id){
$where = Util::getMore([
['status',''],
['title',''],
['is_del',0],
],$this->request);
$nickname = UserModel::where('uid','IN',$id)->column('uid,nickname');
$this->assign('where',$where);
$this->assign('uid',$id);
$this->assign('nickname',implode(',',$nickname));
$this->assign(CouponModel::systemPageCoupon($where));
return $this->fetch();
}
public function issue($id)
{
if(!CouponModel::be(['id'=>$id,'status'=>1,'is_del'=>0]))
return $this->failed('发布的优惠劵已失效或不存在!');
$f = array();
$f[] = Form::input('id','优惠劵ID',$id)->disabled(1);
$f[] = Form::dateTimeRange('range_date','领取时间')->placeholder('不填为永久有效');
$f[] = Form::number('count','发布数量',0)->min(0)->placeholder('不填或填0,为不限量');
$f[] = Form::radio('is_permanent','是否不限量',0)->options([['label'=>'限量','value'=>0],['label'=>'不限量','value'=>1]]);
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加优惠券',$f,Url::build('update_issue',array('id'=>$id)));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
// FormBuilder::text('id','优惠劵ID',$id)->disabled();
// FormBuilder::dateTimeRange('range_date','领取时间')->placeholder('不填为永久有效');
// FormBuilder::text('count','发布数量')->placeholder('不填或填0,为不限量');
// FormBuilder::radio('status','是否开启',[
// ['value'=>1,'label'=>'开启'],
// ['value'=>0,'label'=>'关闭']
// ],1);
// $this->assign(['title'=>'发布优惠券','rules'=>FormBuilder::builder()->getContent(),'action'=>Url::build('update_issue',array('id'=>$id))]);
// return $this->fetch('public/common_form');
}
public function update_issue(Request $request,$id)
{
list($_id,$rangeTime,$count,$status,$is_permanent) = UtilService::postMore([
'id',['range_date',['','']],['count',0],['status',0],['is_permanent',0]
],$request,true);
if($_id != $id) return JsonService::fail('操作失败,信息不对称');
if(!$count) $count = 0;
if(!CouponModel::be(['id'=>$id,'status'=>1,'is_del'=>0])) return JsonService::fail('发布的优惠劵已失效或不存在!');
if(count($rangeTime)!=2) return JsonService::fail('请选择正确的时间区间');
list($startTime,$endTime) = $rangeTime;
// echo $startTime;echo $endTime;var_dump($rangeTime);die;
if(!$startTime) $startTime = 0;
if(!$endTime) $endTime = 0;
if(!$startTime && $endTime) return JsonService::fail('请选择正确的开始时间');
if($startTime && !$endTime) return JsonService::fail('请选择正确的结束时间');
if(StoreCouponIssue::setIssue($id,$count,strtotime($startTime),strtotime($endTime),$count,$status,$is_permanent))
return JsonService::successful('发布优惠劵成功!');
else
return JsonService::fail('发布优惠劵失败!');
}
/**
* 给分组用户发放优惠券
*/
public function grant_group(){
$where = Util::getMore([
['status',''],
['title',''],
['is_del',0],
],$this->request);
$group = UserModel::getUserGroup();
$this->assign('where',$where);
$this->assign('group',json_encode($group));
$this->assign(CouponModel::systemPageCoupon($where));
return $this->fetch();
}
/**
* 给标签用户发放优惠券
*/
public function grant_tag(){
$where = Util::getMore([
['status',''],
['title',''],
['is_del',0],
],$this->request);
$tag = UserModel::getUserTag();;//获取所有标签
$this->assign('where',$where);
$this->assign('tag',json_encode($tag));
$this->assign(CouponModel::systemPageCoupon($where));
return $this->fetch();
}
}

View File

@ -1,63 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2018/01/17
*/
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\ump\StoreCouponIssue as CouponIssueModel;
use app\admin\model\ump\StoreCouponIssueUser;
use service\JsonService;
use think\Url;
use traits\CurdControllerTrait;
use service\UtilService as Util;
class StoreCouponIssue extends AuthController
{
use CurdControllerTrait;
protected $bindModel = CouponIssueModel::class;
public function index()
{
$where=Util::getMore([
['status',''],
['coupon_title','']
]);
$this->assign(CouponIssueModel::stsypage($where));
$this->assign('where',$where);
return $this->fetch();
}
public function delete($id = '')
{
if(!$id) return JsonService::fail('参数有误!');
if(CouponIssueModel::edit(['is_del'=>1],$id,'id'))
return JsonService::successful('删除成功!');
else
return JsonService::fail('删除失败!');
}
public function edit($id = '')
{
if(!$id) return JsonService::fail('参数有误!');
$issueInfo = CouponIssueModel::get($id);
if(-1 == $issueInfo['status'] || 1 == $issueInfo['is_del']) return $this->failed('状态错误,无法修改');
$f = [Form::radio('status','是否开启',$issueInfo['status'])->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])];
$form = Form::make_post_form('状态修改',$f,Url::build('change_field',array('id'=>$id,'field'=>'status')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function issue_log($id = '')
{
if(!$id) return JsonService::fail('参数有误!');
$this->assign(StoreCouponIssueUser::systemCouponIssuePage($id));
return $this->fetch();
}
}

View File

@ -1,114 +0,0 @@
<?php
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use app\admin\model\wechat\WechatUser;
use service\UtilService as Util;
use service\JsonService as Json;
use app\admin\model\ump\StoreCoupon as CouponModel;
use app\admin\model\ump\StoreCouponUser as CouponUserModel;
use app\admin\model\wechat\WechatUser as UserModel;
use think\Request;
/**
* 优惠券发放记录控制器
* Class StoreCategory
* @package app\admin\controller\system
*/
class StoreCouponUser extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$where = Util::getMore([
['status',''],
['is_fail',''],
['coupon_title',''],
['nickname',''],
],$this->request);
$this->assign('where',$where);
$this->assign(CouponUserModel::systemPage($where));
return $this->fetch();
}
/**
* 给已关注的用户发放优惠券
* @param $id
*/
public function grant_subscribe($id){
if(!$id) return Json::fail('数据不存在!');
$coupon = CouponModel::get($id)->toArray();
if(!$coupon) return Json::fail('数据不存在!');
$user = UserModel::getSubscribe('uid');
if(!CouponUserModel::setCoupon($coupon,$user))
return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
else
return Json::successful('发放成功!');
}
/**
* 给所有人发放优惠券
* @param $id
*/
public function grant_all($id){
if(!$id) return Json::fail('数据不存在!');
$coupon = CouponModel::get($id)->toArray();
if(!$coupon) return Json::fail('数据不存在!');
$user = UserModel::getUserAll('uid');
if(!CouponUserModel::setCoupon($coupon,$user))
return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
else
return Json::successful('发放成功!');
}
/**
* 发放优惠券到指定个人
* @param $id
* @param $uid
* @return \think\response\Json
*/
public function grant($id,$uid){
if(!$id) return Json::fail('数据不存在!');
$coupon = CouponModel::get($id)->toArray();
if(!$coupon) return Json::fail('数据不存在!');
$user = explode(',',$uid);
if(!CouponUserModel::setCoupon($coupon,$user))
return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
else
return Json::successful('发放成功!');
}
public function grant_group($id,Request $request){
$data = Util::postMore([
['group',0]
],$request);
if(!$id) return Json::fail('数据不存在!');
$coupon = CouponModel::get($id)->toArray();
if(!$coupon) return Json::fail('数据不存在!');
$user = WechatUser::where('groupid',$data['group'])->column('uid','uid');
if(!CouponUserModel::setCoupon($coupon,$user))
return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
else
return Json::successful('发放成功!');
}
public function grant_tag($id,Request $request){
$data = Util::postMore([
['tag',0]
],$request);
if(!$id) return Json::fail('数据不存在!');
$coupon = CouponModel::get($id)->toArray();
if(!$coupon) return Json::fail('数据不存在!');
$user = WechatUser::where("tagid_list","LIKE","%$data[tag]%")->column('uid','uid');
if(!CouponUserModel::setCoupon($coupon,$user))
return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
else
return Json::successful('发放成功!');
}
}

View File

@ -1,379 +0,0 @@
<?php
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\store\StoreProduct as ProductModel;
use think\Url;
use app\admin\model\ump\StoreSeckillAttr;
use app\admin\model\ump\StoreSeckillAttrResult;
use app\admin\model\ump\StoreSeckill as StoreSeckillModel;
use app\admin\model\system\SystemAttachment;
/**
* 限时秒杀 控制器
* Class StoreSeckill
* @package app\admin\controller\store
*/
class StoreSeckill extends AuthController
{
use CurdControllerTrait;
protected $bindModel = StoreSeckillModel::class;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$this->assign('countSeckill',StoreSeckillModel::getSeckillCount());
$this->assign('seckillId',StoreSeckillModel::getSeckillIdAll());
return $this->fetch();
}
public function save_excel(){
$where=Util::getMore([
['status',''],
['store_name','']
]);
StoreSeckillModel::SaveExcel($where);
}
/**
* 异步获取砍价数据
*/
public function get_seckill_list(){
$where=Util::getMore([
['page',1],
['limit',20],
['status',''],
['store_name','']
]);
$seckillList = StoreSeckillModel::systemPage($where);
if(is_object($seckillList['list'])) $seckillList['list'] = $seckillList['list']->toArray();
$data = $seckillList['list']['data'];
foreach ($data as $k=>$v){
$data[$k]['_stop_time'] =$v['stop_time'] ? date('Y/m/d H:i:s',$v['stop_time']) : '';
}
return Json::successlayui(['count'=>$seckillList['list']['total'],'data'=>$data]);
}
public function get_seckill_id(){
return Json::successlayui(StoreSeckillModel::getSeckillIdAll());
}
/**
* 添加秒杀产品
* @return form-builder
*/
public function create()
{
$f = array();
$f[] = Form::input('title','产品标题');
$f[] = Form::input('info','秒杀活动简介')->type('textarea');
$f[] = Form::input('unit_name','单位')->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间');
$f[] = Form::formFrameImageOne('image','产品主图片(305*305px)');
$f[] = Form::formFrameImages('images','产品轮播图(640*640px)');
$f[] = Form::number('price','秒杀价')->min(0)->col(12);
$f[] = Form::number('ot_price','原价')->min(0)->col(12);
$f[] = Form::number('cost','成本价')->min(0)->col(12);
$f[] = Form::number('stock','库存')->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量')->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序')->col(12);
$f[] = Form::number('num','单次购买产品个数')->precision(0)->col(12);
$f[] = Form::number('give_integral','赠送积分')->min(0)->precision(0)->col(12);
$f[] = Form::number('postage','邮费')->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',1)->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**保存秒杀产品
* @param Request $request
* @param int $id
*/
public function save(Request $request,$id = 0)
{
$data = Util::postMore([
'title',
'product_id',
'info',
'unit_name',
['image',''],
['images',[]],
'price',
'ot_price',
'cost',
'sales',
'stock',
'sort',
'give_integral',
'postage',
['section_time',[]],
['is_postage',0],
['cost',0],
['is_hot',0],
['status',0],
['num',0]
],$request);
if(!$data['title']) return Json::fail('请输入产品标题');
if(!$data['unit_name']) return Json::fail('请输入产品单位');
if(!$data['product_id']) return Json::fail('产品ID不能为空');
// var_dump($this->request->post());
if(count($data['section_time'])<1) return Json::fail('请选择活动时间');
$data['start_time'] = strtotime($data['section_time'][0]);
$data['stop_time'] = strtotime($data['section_time'][1]);
unset($data['section_time']);
if(!$data['image']) return Json::fail('请选择推荐图');
if(count($data['images'])<1) return Json::fail('请选择轮播图');
$data['images'] = json_encode($data['images']);
if($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品秒杀售价');
if($data['ot_price'] == '' || $data['ot_price'] < 0) return Json::fail('请输入产品原售价');
if($data['cost'] == '' || $data['cost'] < 0) return Json::fail('请输入产品成本价');
if($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
if($data['num']<1) return Json::fail('请输入单次秒杀个数');
if($id){
$product = StoreSeckillModel::get($id);
if(!$product) return Json::fail('数据不存在!');
StoreSeckillModel::edit($data,$id);
return Json::successful('编辑成功!');
}else{
$data['add_time'] = time();
StoreSeckillModel::set($data);
return Json::successful('添加成功!');
}
}
/** 开启秒杀
* @param $id
* @return mixed|void
*/
public function seckill($id){
if(!$id) return $this->failed('数据不存在');
$product = ProductModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('title','产品标题',$product->getData('store_name'));
$f[] = Form::hidden('product_id',$id);
$f[] = Form::input('info','秒杀活动简介',$product->getData('store_info'))->type('textarea');
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间');
$f[] = Form::frameImageOne('image','产品主图片(305*305px)',Url::build('admin/widget.images/index',array('fodder'=>'image')),$product->getData('image'))->icon('image')->width('100%')->height('500px');
$f[] = Form::frameImages('images','产品轮播图(640*640px)',Url::build('admin/widget.images/index',array('fodder'=>'images')),json_decode($product->getData('slider_image')))->maxLength(5)->icon('images')->width('100%')->height('500px');
$f[] = Form::number('price','秒杀价')->min(0)->col(12);
$f[] = Form::number('ot_price','原价',$product->getData('price'))->min(0)->col(12);
$f[] = Form::number('cost','成本价',$product->getData('cost'))->min(0)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序',$product->getData('sort'))->col(12);
$f[] = Form::number('num','单次购买产品个数',1)->precision(0)->col(12);
$f[] = Form::number('give_integral','赠送积分',$product->getData('give_integral'))->min(0)->precision(0)->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/product/'.date('Ymd'));
if(is_array($res)){
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],4,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}else
return Json::fail($res);
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreSeckillModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::hidden('product_id',$product->getData('product_id'));
$f[] = Form::input('title','产品标题',$product->getData('title'));
$f[] = Form::input('info','秒杀活动简介',$product->getData('info'))->type('textarea');
$f[] = Form::input('unit_name','单位',$product->getData('unit_name'))->placeholder('个、位');
$f[] = Form::dateTimeRange('section_time','活动时间',$product->getData('start_time'),$product->getData('stop_time'));
$f[] = Form::frameImageOne('image','产品主图片(305*305px)',Url::build('admin/widget.images/index',array('fodder'=>'image')),$product->getData('image'))->icon('image')->width('100%')->height('500px');
$f[] = Form::frameImages('images','产品轮播图(640*640px)',Url::build('admin/widget.images/index',array('fodder'=>'images')),json_decode($product->getData('images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
$f[] = Form::number('price','秒杀价',$product->getData('price'))->min(0)->col(12);
$f[] = Form::number('ot_price','原价',$product->getData('ot_price'))->min(0)->col(12);
$f[] = Form::number('cost','成本价',$product->getData('cost'))->min(0)->col(12);
$f[] = Form::number('stock','库存',$product->getData('stock'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sales','销量',$product->getData('sales'))->min(0)->precision(0)->col(12);
$f[] = Form::number('sort','排序',$product->getData('sort'))->col(12);
$f[] = Form::number('num','单次购买产品个数',$product->getData('num'))->precision(0)->col(12);
$f[] = Form::number('give_integral','赠送积分',$product->getData('give_integral'))->min(0)->precision(0)->col(12);
$f[] = Form::number('postage','邮费',$product->getData('postage'))->min(0)->col(12);
$f[] = Form::radio('is_postage','是否包邮',$product->getData('is_postage'))->options([['label'=>'是','value'=>1],['label'=>'否','value'=>0]])->col(12);
$f[] = Form::radio('is_hot','热门推荐',$product->getData('is_hot'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$f[] = Form::radio('status','活动状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]])->col(12);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!$id) return $this->failed('数据不存在');
$product = StoreSeckillModel::get($id);
if(!$product) return Json::fail('数据不存在!');
if($product['is_del']) return Json::fail('已删除!');
$data['is_del'] = 1;
if(!StoreSeckillModel::edit($data,$id))
return Json::fail(StoreSeckillModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
public function edit_content($id){
if(!$id) return $this->failed('数据不存在');
$seckill = StoreSeckillModel::get($id);
if(!$seckill) return Json::fail('数据不存在!');
$this->assign([
'content'=>StoreSeckillModel::where('id',$id)->value('description'),
'field'=>'description',
'action'=>Url::build('change_field',['id'=>$id,'field'=>'description'])
]);
return $this->fetch('public/edit_content');
}
public function change_field(Request $request,$id,$field){
if(!$id) return $this->failed('数据不存在');
$seckill = StoreSeckillModel::get($id);
if(!$seckill) return Json::fail('数据不存在!');
$data['description'] = $request->post('description');
$res = StoreSeckillModel::edit($data,$id);
if($res)
return Json::successful('添加成功');
else
return Json::fail('添加失败');
}
/**
* 属性页面
* @param $id
* @return mixed|void
*/
public function attr($id)
{
if(!$id) return $this->failed('数据不存在!');
$result = StoreSeckillAttrResult::getResult($id);
$image = StoreSeckillModel::where('id',$id)->value('image');
$this->assign(compact('id','result','product','image'));
return $this->fetch();
}
/**
* 生成属性
* @param int $id
*/
public function is_format_attr($id = 0){
if(!$id) return Json::fail('产品不存在');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$product = StoreSeckillModel::get($id);
if(!$product) return Json::fail('产品不存在');
$attrFormat = attrFormat($attr)[1];
if(count($detail)){
foreach ($attrFormat as $k=>$v){
foreach ($detail as $kk=>$vv){
if($v['detail'] == $vv['detail']){
$attrFormat[$k]['price'] = $vv['price'];
$attrFormat[$k]['sales'] = $vv['sales'];
$attrFormat[$k]['pic'] = $vv['pic'];
$attrFormat[$k]['check'] = false;
break;
}else{
$attrFormat[$k]['price'] = '';
$attrFormat[$k]['sales'] = '';
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = true;
}
}
}
}else{
foreach ($attrFormat as $k=>$v){
$attrFormat[$k]['price'] = $product['price'];
$attrFormat[$k]['sales'] = $product['stock'];
$attrFormat[$k]['pic'] = $product['image'];
$attrFormat[$k]['check'] = false;
}
}
return Json::successful($attrFormat);
}
/**
* 添加 修改属性
* @param $id
*/
public function set_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
list($attr,$detail) = Util::postMore([
['items',[]],
['attrs',[]]
],$this->request,true);
$res = StoreSeckillAttr::createProductAttr($attr,$detail,$id);
if($res)
return $this->successful('编辑属性成功!');
else
return $this->failed(StoreSeckillAttr::getErrorInfo());
}
/**
* 清除属性
* @param $id
*/
public function clear_attr($id)
{
if(!$id) return $this->failed('产品不存在!');
if(false !== StoreSeckillAttr::clearProductAttr($id) && false !== StoreSeckillAttrResult::clearResult($id))
return $this->successful('清空产品属性成功!');
else
return $this->failed(StoreSeckillAttr::getErrorInfo('清空产品属性失败!'));
}
/**
* 修改秒杀产品状态
* @param $status
* @param int $id
*/
public function set_seckill_status($status,$id = 0){
if(!$id) return Json::fail('参数错误');
$res = StoreSeckillModel::edit(['status'=>$status],$id);
if($res) return Json::successful('修改成功');
else return Json::fail('修改失败');
}
}

View File

@ -1,73 +0,0 @@
<?php
namespace app\admin\controller\ump;
use app\admin\controller\AuthController;
use service\UtilService as Util;
use app\admin\model\user\UserPoint AS UserPointModel;
use think\Url;
use service\JsonService;
use app\admin\model\user\UserBill;
/**
* 优惠券控制器
* Class StoreCategory
* @package app\admin\controller\system
*/
class UserPoint extends AuthController
{
/**
* @return mixed
*/
public function index()
{
$this->assign([
// 'sum_point'=>UserBill::where(['category'=>'integral','type'=>'system_add'])->sum('number'),
// 'count'=>UserBill::where(['category'=>'integral','type'=>'sign'])->group('uid')->count(),
// 'song_point'=>UserBill::where(['category'=>'integral','type'=>'sign'])->group('uid')->sum('number'),
'is_layui'=>true,
'year'=>getMonth('y'),
]);
return $this->fetch();
}
/**
* @return mixed
*/
public function create()
{
$this->assign(['title'=>'添加优惠券','action'=>Url::build('save'),'rules'=>$this->rules()->getContent()]);
return $this->fetch('public/common_form');
}
//异步获取积分列表
public function getponitlist(){
$where = Util::getMore([
['start_time',''],
['end_time',''],
['nickname',''],
['page',1],
['limit',10],
]);
return JsonService::successlayui(UserPointModel::getpointlist($where));
}
//导出Excel表格
public function export(){
$where = Util::getMore([
['start_time',''],
['end_time',''],
['nickname',''],
]);
UserPointModel::SaveExport($where);
}
//获取积分日志头部信息
public function getuserpointbadgelist(){
$where = Util::getMore([
['start_time',''],
['end_time',''],
['nickname',''],
]);
return JsonService::successful(UserPointModel::getUserpointBadgelist($where));
}
}

View File

@ -1,726 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\controller\user;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemUserLevel;
use service\FormBuilder as Form;
use service\JsonService;
use think\Db;
use traits\CurdControllerTrait;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\user\User as UserModel;
use app\admin\model\user\UserBill AS UserBillAdmin;
use basic\ModelBasic;
use service\HookService;
use app\admin\model\user\UserLevel;
use behavior\user\UserBehavior;
use app\admin\model\store\StoreVisit;
use app\admin\model\wechat\WechatMessage;
use app\admin\model\order\StoreOrder;
use app\admin\model\store\StoreCouponUser;
/**
* 用户管理控制器
* Class User
* @package app\admin\controller\user
*/
class User extends AuthController
{
use CurdControllerTrait;
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index(){
$this->assign('count_user',UserModel::getcount());
$this->assign('level_list',SystemUserLevel::where(['is_show'=>1,'is_del'=>0])->field(['id','name'])->select());
return $this->fetch();
}
/*
* 赠送会员等级
* @paran int $uid
* */
public function give_level($uid=0)
{
if(!$uid) return $this->failed('缺少参数');
$level=\app\core\model\user\UserLevel::getUserLevel($uid);
//获取当前会员等级
if($level===false)
$grade=0;
else
$grade=\app\core\model\user\UserLevel::getUserLevelInfo($level,'grade');
//查询高于当前会员的所有会员等级
$systemLevelList=SystemUserLevel::where('grade','>',$grade)->where(['is_show'=>1,'is_del'=>0])->field(['name','id'])->select();
$field[]=Form::select('level_id','会员等级')->setOptions(function() use($systemLevelList) {
$menus=[];
foreach ($systemLevelList as $menu){
$menus[] = ['value'=>$menu['id'],'label'=>$menu['name']];
}
return $menus;
})->filterable(1);
$form = Form::make_post_form('赠送会员',$field,Url::build('save_give_level',['uid'=>$uid]),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/*
* 赠送会员等级
* @paran int $uid
* @return json
* */
public function save_give_level($uid=0)
{
if(!$uid) return JsonService::fail('缺少参数');
list($level_id)=Util::postMore([
['level_id',0],
],$this->request,true);
//查询当前选择的会员等级
$systemLevel=SystemUserLevel::where(['is_show'=>1,'is_del'=>0,'id'=>$level_id])->find();
if(!$systemLevel) return JsonService::fail('您选择赠送的会员等级不存在!');
//检查是否拥有此会员等级
$level=UserLevel::where(['uid'=>$uid,'level_id'=>$level_id,'is_del'=>0])->field('valid_time,is_forever')->find();
if($level) if(!$level['is_forever'] && time() < $level['valid_time']) return JsonService::fail('此用户已有该会员等级,无法再次赠送');
//设置会员过期时间
$add_valid_time=(int)$systemLevel->valid_date*86400;
UserModel::commitTrans();
try{
//保存会员信息
$res=UserLevel::set([
'is_forever'=>$systemLevel->is_forever,
'status'=>1,
'is_del'=>0,
'grade'=>$systemLevel->grade,
'uid'=>$uid,
'add_time'=>time(),
'level_id'=>$level_id,
'discount'=>$systemLevel->discount,
'valid_time'=>$systemLevel->discount ? $add_valid_time : 0,
'mark'=>'尊敬的用户【'.UserModel::where('uid',$uid)->value('nickname').'】在'.date('Y-m-d H:i:s',time()).'赠送会员等级成为'.$systemLevel['name'].'会员',
]);
//提取等级任务并记录完成情况
$levelIds=[$level_id];
$lowGradeLevelIds=SystemUserLevel::where('grade','<',$systemLevel->grade)->where(['is_show'=>1,'is_del'=>0])->column('id');
if(count($lowGradeLevelIds)) $levelIds=array_merge($levelIds,$lowGradeLevelIds);
$taskIds=Db::name('system_user_task')->where('level_id','in',$levelIds)->column('id');
$inserValue=[];
foreach ($taskIds as $id){
$inserValue[]=['uid'=>$uid,'task_id'=>$id,'status'=>1,'add_time'=>time()];
}
$res=$res && Db::name('user_task_finish')->insertAll($inserValue);
if($res){
UserModel::commitTrans();
return JsonService::successful('赠送成功');
}else{
UserModel::rollbackTrans();
return JsonService::successful('赠送失败');
}
}catch (\Exception $e){
UserModel::rollbackTrans();
return JsonService::fail('赠送失败');
}
}
/*
* 清除会员等级
* @param int $uid
* @return json
* */
public function del_level($uid=0)
{
if(!$uid) return JsonService::fail('缺少参数');
if(UserLevel::cleanUpLevel($uid))
return JsonService::successful('清除成功');
else
return JsonService::fail('清除失败');
}
/**
* 修改user表状态
*
* @return json
*/
public function set_status($status='',$uid=0,$is_echo=0){
if($is_echo==0) {
if ($status == '' || $uid == 0) return Json::fail('参数错误');
UserModel::where(['uid' => $uid])->update(['status' => $status]);
}else{
$uids=Util::postMore([
['uids',[]]
]);
UserModel::destrSyatus($uids['uids'],$status);
}
return Json::successful($status==0 ? '禁用成功':'解禁成功');
}
/**
* 获取user表
*
* @return json
*/
public function get_user_list(){
$where=Util::getMore([
['page',1],
['limit',20],
['nickname',''],
['status',''],
['pay_count',''],
['is_promoter',''],
['order',''],
['data',''],
['user_type',''],
['country',''],
['province',''],
['city',''],
['user_time_type',''],
['user_time',''],
['sex',''],
['level_id',''],
['birthday',''],
]);
return Json::successlayui(UserModel::getUserList($where));
}
/**
* 编辑模板消息
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit($uid)
{
if(!$uid) return $this->failed('数据不存在');
$user = UserModel::get($uid);
if(!$user) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('uid','用户编号',$user->getData('uid'))->disabled(1);
$f[] = Form::input('real_name','真实姓名',$user->getData('real_name'));
$f[] = Form::date('birthday','生日',$user->getData('birthday') ? date('Y-m-d',$user->getData('birthday')) : 0);
$f[] = Form::input('card_id','身份证号',$user->getData('card_id'));
$f[] = Form::textarea('mark','用户备注',$user->getData('mark'));
$f[] = Form::radio('is_promoter','推广员',$user->getData('is_promoter'))->options([['value'=>1,'label'=>'开启'],['value'=>0,'label'=>'关闭']]);
$f[] = Form::radio('status','状态',$user->getData('status'))->options([['value'=>1,'label'=>'开启'],['value'=>0,'label'=>'锁定']]);
$form = Form::make_post_form('添加用户通知',$f,Url::build('update',array('uid'=>$uid)),5);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function edit_other($uid)
{
if(!$uid) return $this->failed('数据不存在');
$user = UserModel::get($uid);
if(!$user) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::radio('money_status','修改余额',1)->options([['value'=>1,'label'=>'增加'],['value'=>2,'label'=>'减少']]);
$f[] = Form::number('money','余额')->min(0);
$f[] = Form::radio('integration_status','修改积分',1)->options([['value'=>1,'label'=>'增加'],['value'=>2,'label'=>'减少']]);
$f[] = Form::number('integration','积分')->min(0);
$form = Form::make_post_form('修改其他',$f,Url::build('update_other',array('uid'=>$uid)),5);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update_other($uid=0)
{
$data = Util::postMore([
['money_status',0],
['money',0],
['integration_status',0],
['integration',0],
],$this->request);
if(!$uid) return $this->failed('数据不存在');
$user = UserModel::get($uid);
if(!$user) return Json::fail('数据不存在!');
ModelBasic::beginTrans();
$res1 = false;
$res2 = false;
$edit = array();
if($data['money_status'] && $data['money']){//余额增加或者减少
if($data['money_status'] == 1){//增加
$edit['now_money'] = bcadd($user['now_money'],$data['money'],2);
$res1 = UserBillAdmin::income('系统增加余额',$user['uid'],'now_money','system_add',$data['money'],$this->adminId,$edit['now_money'],'系统增加了'.floatval($data['money']).'余额');
try{
HookService::listen('admin_add_money',$user,$data['money'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}else if($data['money_status'] == 2){//减少
$edit['now_money'] = bcsub($user['now_money'],$data['money'],2);
$res1 = UserBillAdmin::expend('系统减少余额',$user['uid'],'now_money','system_sub',$data['money'],$this->adminId,$edit['now_money'],'系统扣除了'.floatval($data['money']).'余额');
try{
HookService::listen('admin_sub_money',$user,$data['money'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}
}else{
$res1 = true;
}
if($data['integration_status'] && $data['integration']){//积分增加或者减少
if($data['integration_status'] == 1){//增加
$edit['integral'] = bcadd($user['integral'],$data['integration'],2);
$res2 = UserBillAdmin::income('系统增加积分',$user['uid'],'integral','system_add',$data['integration'],$this->adminId,$edit['integral'],'系统增加了'.floatval($data['integration']).'积分');
try{
HookService::listen('admin_add_integral',$user,$data['integration'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}else if($data['integration_status'] == 2){//减少
$edit['integral'] = bcsub($user['integral'],$data['integration'],2);
$res2 = UserBillAdmin::expend('系统减少积分',$user['uid'],'integral','system_sub',$data['integration'],$this->adminId,$edit['integral'],'系统扣除了'.floatval($data['integration']).'积分');
try{
HookService::listen('admin_sub_integral',$user,$data['integration'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}
}else{
$res2 = true;
}
if($edit) $res3 = UserModel::edit($edit,$uid);
else $res3 = true;
if($res1 && $res2 && $res3) $res =true;
else $res = false;
ModelBasic::checkTrans($res);
if($res) return Json::successful('修改成功!');
else return Json::fail('修改失败');
}
public function update(Request $request, $uid)
{
$data = Util::postMore([
['money_status',0],
['is_promoter',1],
['real_name',''],
['card_id',''],
['birthday',''],
['mark',''],
['money',0],
['integration_status',0],
['integration',0],
['status',0],
],$request);
if(!$uid) return $this->failed('数据不存在');
$user = UserModel::get($uid);
if(!$user) return Json::fail('数据不存在!');
$data['birthday'] = strtotime($data['birthday']);
if($data['card_id'] && !Util::setCard($data['card_id'])) return JsonService::successful('输入正确的身份证号码');
ModelBasic::beginTrans();
$res1 = false;
$res2 = false;
$edit = array();
if($data['money_status'] && $data['money']){//余额增加或者减少
if($data['money_status'] == 1){//增加
$edit['now_money'] = bcadd($user['now_money'],$data['money'],2);
$res1 = UserBillAdmin::income('系统增加余额',$user['uid'],'now_money','system_add',$data['money'],$this->adminId,$edit['now_money'],'系统增加了'.floatval($data['money']).'余额');
try{
HookService::listen('admin_add_money',$user,$data['money'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}else if($data['money_status'] == 2){//减少
$edit['now_money'] = bcsub($user['now_money'],$data['money'],2);
$res1 = UserBillAdmin::expend('系统减少余额',$user['uid'],'now_money','system_sub',$data['money'],$this->adminId,$edit['now_money'],'系统扣除了'.floatval($data['money']).'余额');
try{
HookService::listen('admin_sub_money',$user,$data['money'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}
}else{
$res1 = true;
}
if($data['integration_status'] && $data['integration']){//积分增加或者减少
if($data['integration_status'] == 1){//增加
$edit['integral'] = bcadd($user['integral'],$data['integration'],2);
$res2 = UserBillAdmin::income('系统增加积分',$user['uid'],'integral','system_add',$data['integration'],$this->adminId,$edit['integral'],'系统增加了'.floatval($data['integration']).'积分');
try{
HookService::listen('admin_add_integral',$user,$data['integration'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}else if($data['integration_status'] == 2){//减少
$edit['integral'] = bcsub($user['integral'],$data['integration'],2);
$res2 = UserBillAdmin::expend('系统减少积分',$user['uid'],'integral','system_sub',$data['integration'],$this->adminId,$edit['integral'],'系统扣除了'.floatval($data['integration']).'积分');
try{
HookService::listen('admin_sub_integral',$user,$data['integration'],false,UserBehavior::class);
}catch (\Exception $e){
ModelBasic::rollbackTrans();
return Json::fail($e->getMessage());
}
}
}else{
$res2 = true;
}
$edit['status'] = $data['status'];
$edit['real_name'] = $data['real_name'];
$edit['card_id'] = $data['card_id'];
$edit['birthday'] = $data['birthday'];
$edit['mark'] = $data['mark'];
$edit['is_promoter'] = $data['is_promoter'];
if($edit) $res3 = UserModel::edit($edit,$uid);
else $res3 = true;
if($res1 && $res2 && $res3) $res =true;
else $res = false;
ModelBasic::checkTrans($res);
if($res) return Json::successful('修改成功!');
else return Json::fail('修改失败');
}
/**
* 用户图表
* @return mixed
*/
public function user_analysis(){
$where = Util::getMore([
['nickname',''],
['status',''],
['is_promoter',''],
['date',''],
['user_type',''],
['export',0]
],$this->request);
$user_count=UserModel::consume($where,'',true);
//头部信息
$header=[
[
'name'=>'新增用户',
'class'=>'fa-line-chart',
'value'=>$user_count,
'color'=>'red'
],
[
'name'=>'用户留存',
'class'=>'fa-area-chart',
'value'=>$this->gethreaderValue(UserModel::consume($where,'',true),$where).'%',
'color'=>'lazur'
],
[
'name'=>'新增用户总消费',
'class'=>'fa-bar-chart',
'value'=>'¥'.UserModel::consume($where),
'color'=>'navy'
],
[
'name'=>'用户活跃度',
'class'=>'fa-pie-chart',
'value'=>$this->gethreaderValue(UserModel::consume($where,'',true)).'%',
'color'=>'yellow'
],
];
$name=['新增用户','用户消费'];
$dates=$this->get_user_index($where,$name);
$user_index=['name'=>json_encode($name), 'date'=>json_encode($dates['time']), 'series'=>json_encode($dates['series'])];
//用户浏览分析
$view=StoreVisit::getVisit($where['date'],['','warning','info','danger']);
$view_v1=WechatMessage::getViweList($where['date'],['','warning','info','danger']);
$view=array_merge($view,$view_v1);
$view_v2=[];
foreach ($view as $val){
$view_v2['color'][]='#'.rand(100000,339899);
$view_v2['name'][]=$val['name'];
$view_v2['value'][]=$val['value'];
}
$view=$view_v2;
//消费会员排行用户分析
$user_null=UserModel::getUserSpend($where['date']);
//消费数据
$now_number=UserModel::getUserSpend($where['date'],true);
list($paren_number,$title)=UserModel::getPostNumber($where['date']);
if($paren_number==0) {
$rightTitle=[
'number'=>$now_number>0?$now_number:0,
'icon'=>'fa-level-up',
'title'=>$title
];
}else{
$number=(float)bcsub($now_number,$paren_number,4);
if($now_number==0){
$icon='fa-level-down';
}else{
$icon=$now_number>$paren_number?'fa-level-up':'fa-level-down';
}
$rightTitle=['number'=>$number, 'icon'=>$icon, 'title'=>$title];
}
unset($title,$paren_number,$now_number);
list($paren_user_count,$title)=UserModel::getPostNumber($where['date'],true,'add_time','');
if($paren_user_count==0){
$count=$user_count==0?0:$user_count;
$icon=$user_count==0?'fa-level-down':'fa-level-up';
}else{
$count=(float)bcsub($user_count,$paren_user_count,4);
$icon=$user_count<$paren_user_count?'fa-level-down':'fa-level-up';
}
$leftTitle=[
'count'=>$count,
'icon'=>$icon,
'title'=>$title
];
unset($count,$icon,$title);
$consume=[
'title'=>'消费金额为¥'.UserModel::consume($where),
'series'=>UserModel::consume($where,'xiaofei'),
'rightTitle'=>$rightTitle,
'leftTitle'=>$leftTitle,
];
$form=UserModel::consume($where,'form');
$grouping=UserModel::consume($where,'grouping');
$this->assign(compact('header','user_index','view','user_null','consume','form','grouping','where'));
return $this->fetch();
}
public function gethreaderValue($chart,$where=[]){
if($where){
switch($where['date']){
case null:case 'today':case 'week':case 'year':
if($where['date']==null){
$where['date']='month';
}
$sum_user=UserModel::whereTime('add_time',$where['date'])->count();
if($sum_user==0) return 0;
$counts=bcdiv($chart,$sum_user,4)*100;
return $counts;
break;
case 'quarter':
$quarter=UserModel::getMonth('n');
$quarter[0]=strtotime($quarter[0]);
$quarter[1]=strtotime($quarter[1]);
$sum_user=UserModel::where('add_time','between',$quarter)->count();
if($sum_user==0) return 0;
$counts=bcdiv($chart,$sum_user,4)*100;
return $counts;
default:
//自定义时间
$quarter=explode('-',$where['date']);
$quarter[0]=strtotime($quarter[0]);
$quarter[1]=strtotime($quarter[1]);
$sum_user=UserModel::where('add_time','between',$quarter)->count();
if($sum_user==0) return 0;
$counts=bcdiv($chart,$sum_user,4)*100;
return $counts;
break;
}
}else{
$num=UserModel::count();
$chart=$num!=0?bcdiv($chart,$num,5)*100:0;
return $chart;
}
}
public function get_user_index($where,$name){
switch ($where['date']){
case null:
$days = date("t",strtotime(date('Y-m',time())));
$dates=[];
$series=[];
$times_list=[];
foreach ($name as $key=>$val){
for($i=1;$i<=$days;$i++){
if(!in_array($i.'号',$times_list)){
array_push($times_list,$i.'号');
}
$time=$this->gettime(date("Y-m",time()).'-'.$i);
if($key==0){
$dates['data'][]=UserModel::where('add_time','between',$time)->count();
}else if($key==1){
$dates['data'][]=UserModel::consume(true,$time);
}
}
$dates['name']=$val;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
case 'today':
$dates=[];
$series=[];
$times_list=[];
foreach ($name as $key=>$val){
for($i=0;$i<=24;$i++){
$strtitle=$i.'点';
if(!in_array($strtitle,$times_list)){
array_push($times_list,$strtitle);
}
$time=$this->gettime(date("Y-m-d ",time()).$i);
if($key==0){
$dates['data'][]=UserModel::where('add_time','between',$time)->count();
}else if($key==1){
$dates['data'][]=UserModel::consume(true,$time);
}
}
$dates['name']=$val;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
case "week":
$dates=[];
$series=[];
$times_list=[];
foreach ($name as $key=>$val){
for($i=0;$i<=6;$i++){
if(!in_array('星期'.($i+1),$times_list)){
array_push($times_list,'星期'.($i+1));
}
$time=UserModel::getMonth('h',$i);
if($key==0){
$dates['data'][]=UserModel::where('add_time','between',[strtotime($time[0]),strtotime($time[1])])->count();
}else if($key==1){
$dates['data'][]=UserModel::consume(true,[strtotime($time[0]),strtotime($time[1])]);
}
}
$dates['name']=$val;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
case 'year':
$dates=[];
$series=[];
$times_list=[];
$year=date('Y');
foreach ($name as $key=>$val){
for($i=1;$i<=12;$i++){
if(!in_array($i.'月',$times_list)){
array_push($times_list,$i.'月');
}
$t = strtotime($year.'-'.$i.'-01');
$arr= explode('/',date('Y-m-01',$t).'/'.date('Y-m-',$t).date('t',$t));
if($key==0){
$dates['data'][]=UserModel::where('add_time','between',[strtotime($arr[0]),strtotime($arr[1])])->count();
}else if($key==1){
$dates['data'][]=UserModel::consume(true,[strtotime($arr[0]),strtotime($arr[1])]);
}
}
$dates['name']=$val;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
case 'quarter':
$dates=[];
$series=[];
$times_list=[];
foreach ($name as $key=>$val){
for($i=1;$i<=4;$i++){
$arr=$this->gettime('quarter',$i);
if(!in_array(implode('--',$arr).'季度',$times_list)){
array_push($times_list,implode('--',$arr).'季度');
}
if($key==0){
$dates['data'][]=UserModel::where('add_time','between',[strtotime($arr[0]),strtotime($arr[1])])->count();
}else if($key==1){
$dates['data'][]=UserModel::consume(true,[strtotime($arr[0]),strtotime($arr[1])]);
}
}
$dates['name']=$val;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
default:
$list=UserModel::consume($where,'default');
$dates=[];
$series=[];
$times_list=[];
foreach ($name as $k=>$v){
foreach ($list as $val){
$date=$val['add_time'];
if(!in_array($date,$times_list)){
array_push($times_list,$date);
}
if($k==0){
$dates['data'][]=$val['num'];
}else if($k==1){
$dates['data'][]=UserBillAdmin::where(['uid'=>$val['uid'],'type'=>'pay_product'])->sum('number');
}
}
$dates['name']=$v;
$dates['type']='line';
$series[]=$dates;
unset($dates);
}
return ['time'=>$times_list,'series'=>$series];
}
}
public function gettime($time='',$season=''){
if(!empty($time) && empty($season)){
$timestamp0 = strtotime($time);
$timestamp24 =strtotime($time)+86400;
return [$timestamp0,$timestamp24];
}else if(!empty($time) && !empty($season)){
$firstday=date('Y-m-01',mktime(0,0,0,($season - 1) *3 +1,1,date('Y')));
$lastday=date('Y-m-t',mktime(0,0,0,$season * 3,1,date('Y')));
return [$firstday,$lastday];
}
}
/**
* 会员等级首页
*/
public function group(){
return $this->fetch();
}
/**
* 会员详情
*/
public function see($uid=''){
$this->assign([
'uid'=>$uid,
'userinfo'=>UserModel::getUserDetailed($uid),
'is_layui'=>true,
'headerList'=>UserModel::getHeaderList($uid),
'count'=>UserModel::getCountInfo($uid),
]);
return $this->fetch();
}
/*
* 获取某个用户的推广下线
* */
public function getSpreadList($uid,$page=1,$limit=20){
return Json::successful(UserModel::getSpreadList($uid,(int)$page,(int)$limit));
}
/**
* 获取某用户的订单列表
*/
public function getOneorderList($uid,$page=1,$limit=20){
return Json::successful(StoreOrder::getOneorderList(compact('uid','page','limit')));
}
/**
* 获取某用户的积分列表
*/
public function getOneIntegralList($uid,$page=1,$limit=20){
return Json::successful(UserBillAdmin::getOneIntegralList(compact('uid','page','limit')));
}
/**
* 获取某用户的积分列表
*/
public function getOneSignList($uid,$page=1,$limit=20){
return Json::successful(UserBillAdmin::getOneSignList(compact('uid','page','limit')));
}
/**
* 获取某用户的持有优惠劵
*/
public function getOneCouponsList($uid,$page=1,$limit=20){
return Json::successful(StoreCouponUser::getOneCouponsList(compact('uid','page','limit')));
}
/**
* 获取某用户的余额变动记录
*/
public function getOneBalanceChangList($uid,$page=1,$limit=20){
return Json::successful(UserBillAdmin::getOneBalanceChangList(compact('uid','page','limit')));
}
}

View File

@ -1,337 +0,0 @@
<?php
namespace app\admin\controller\user;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemUserLevel;
use app\admin\model\system\SystemUserTask;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService;
use think\Url;
use traits\CurdControllerTrait;
use app\admin\model\user\UserLevel as UserLevelModel;
/**
* 会员设置
* Class UserLevel
* @package app\admin\controller\user
*/
class UserLevel extends AuthController
{
use CurdControllerTrait;
/*
* 等级展示
* */
public function index()
{
return $this->fetch();
}
/*
* 创建form表单
* */
public function create($id=0)
{
if($id) $vipinfo=SystemUserLevel::get($id);
$field[]= Form::input('name','等级名称',isset($vipinfo) ? $vipinfo->name : '')->col(Form::col(24));
$field[]= Form::radio('is_forever','是否为永久',isset($vipinfo) ? $vipinfo->is_forever : 0)->options([['label'=>'永久','value'=>1],['label'=>'非永久','value'=>0]])->col(24);
$field[]= Form::number('money','等级价格',isset($vipinfo) ? $vipinfo->money : 0)->min(0)->col(24);
$field[]= Form::radio('is_pay','是否需要购买',isset($vipinfo) ? $vipinfo->is_pay : 0)->options([['label'=>'需要','value'=>1],['label'=>'免费','value'=>0]])->col(24);
$field[]= Form::number('valid_date','有效时间(天)',isset($vipinfo) ? $vipinfo->valid_date : 0)->min(0)->col(8);
$field[]= Form::number('grade','等级',isset($vipinfo) ? $vipinfo->grade : 0)->min(0)->col(8);
$field[]= Form::number('discount','享受折扣',isset($vipinfo) ? $vipinfo->discount : 0)->min(0)->col(8);
$field[]= Form::formFrameImageOne('icon','图标',isset($vipinfo) ? $vipinfo->icon : '');
$field[]= Form::formFrameImageOne('image','会员背景',isset($vipinfo) ? $vipinfo->image : '');
$field[]= Form::radio('is_show','是否显示',isset($vipinfo) ? $vipinfo->is_show : 0)->options([['label'=>'显示','value'=>1],['label'=>'隐藏','value'=>0]])->col(8);
$field[]= Form::textarea('explain','等级说明',isset($vipinfo) ? $vipinfo->explain : '');
$form = Form::make_post_form('添加等级设置',$field,Url::build('save',['id'=>$id]),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/*
* 会员等级添加或者修改
* @param $id 修改的等级id
* @return json
* */
public function save($id=0)
{
$data=UtilService::postMore([
['name',''],
['is_forever',0],
['money',0],
['is_pay',0],
['valid_date',0],
['grade',0],
['discount',0],
['icon',''],
['image',''],
['is_show',''],
['explain',''],
]);
if(!$data['name']) return JsonService::fail('请输入等级名称');
if(!$data['grade']) return JsonService::fail('请输入等级');
if(!$data['explain']) return JsonService::fail('请输入等级说明');
if($data['is_forever']==0 && !$data['valid_date']) return JsonService::fail('请输入有效时间(天)');
if($data['is_pay']) return JsonService::fail('会员等级购买功能正在开发中,暂时关闭可购买功能!');
if($data['is_pay'] && !$data['money']) return JsonService::fail('请输入购买金额');
if(!$data['icon']) return JsonService::fail('请上传等级图标');
if(!$data['image']) return JsonService::fail('请上传等级背景图标');
if(!$id && SystemUserLevel::be(['is_del'=>0,'grade'=>$data['grade']])) return JsonService::fail('已检测到您设置过的会员等级,此等级不可重复');
SystemUserLevel::beginTrans();
try{
//修改
if($id){
if(SystemUserLevel::edit($data,$id)){
SystemUserLevel::commitTrans();
return JsonService::successful('修改成功');
}else{
SystemUserLevel::rollbackTrans();
return JsonService::fail('修改失败');
}
}else{
//新增
$data['add_time']=time();
if(SystemUserLevel::set($data)){
SystemUserLevel::commitTrans();
return JsonService::successful('添加成功');
}else{
SystemUserLevel::rollbackTrans();
return JsonService::fail('添加失败');
}
}
}catch (\Exception $e){
SystemUserLevel::rollbackTrans();
return JsonService::fail($e->getMessage());
}
}
/*
* 获取系统设置的vip列表
* @param int page
* @param int limit
* */
public function get_system_vip_list()
{
$where=UtilService::getMore([
['page',0],
['limit',10],
['title',''],
['is_show',''],
]);
return JsonService::successlayui(SystemUserLevel::getSytemList($where));
}
/*
* 删除会员等级
* @param int $id
* */
public function delete($id=0)
{
if(SystemUserLevel::edit(['is_del'=>1],$id))
return JsonService::successful('删除成功');
else
return JsonService::fail('删除失败');
}
/**
* 设置单个产品上架|下架
*
* @return json
*/
public function set_show($is_show='',$id=''){
($is_show=='' || $id=='') && Json::fail('缺少参数');
$res=SystemUserLevel::where(['id'=>$id])->update(['is_show'=>(int)$is_show]);
if($res){
return JsonService::successful($is_show==1 ? '显示成功':'隐藏成功');
}else{
return JsonService::fail($is_show==1 ? '显示失败':'隐藏失败');
}
}
/**
* 快速编辑
*
* @return json
*/
public function set_value($field='',$id='',$value=''){
$field=='' || $id=='' || $value=='' && Json::fail('缺少参数');
if(SystemUserLevel::where(['id'=>$id])->update([$field=>$value]))
return JsonService::successful('保存成功');
else
return JsonService::fail('保存失败');
}
/*
* 等级任务列表
* @param int $vip_id 等级id
* @return json
* */
public function tash($level_id=0)
{
$this->assign('level_id',$level_id);
return $this->fetch();
}
/**
* 快速编辑
*
* @return json
*/
public function set_tash_value($field='',$id='',$value=''){
$field=='' || $id=='' || $value=='' && Json::fail('缺少参数');
if(SystemUserTask::where(['id'=>$id])->update([$field=>$value]))
return JsonService::successful('保存成功');
else
return JsonService::fail('保存失败');
}
/**
* 设置单个产品上架|下架
*
* @return json
*/
public function set_tash_show($is_show='',$id=''){
($is_show=='' || $id=='') && Json::fail('缺少参数');
$res=SystemUserTask::where(['id'=>$id])->update(['is_show'=>(int)$is_show]);
if($res){
return JsonService::successful($is_show==1 ? '显示成功':'隐藏成功');
}else{
return JsonService::fail($is_show==1 ? '显示失败':'隐藏失败');
}
}
/**
* 设置单个产品上架|下架
*
* @return json
*/
public function set_tash_must($is_must='',$id=''){
($is_must=='' || $id=='') && Json::fail('缺少参数');
$res=SystemUserTask::where(['id'=>$id])->update(['is_must'=>(int)$is_must]);
if($res){
return JsonService::successful('设置成功');
}else{
return JsonService::fail('设置失败');
}
}
/*
* 生成任务表单
* @param int $id 任务id
* @param int $vip_id 会员id
* @return html
* */
public function create_tash($id=0,$level_id=0)
{
if($id) $tash=SystemUserTask::get($id);
$field[]= Form::select('task_type','任务类型',isset($tash) ? $tash->task_type : '')->setOptions(function(){
$list = SystemUserTask::getTaskTypeAll();
$menus=[];
foreach ($list as $menu){
$menus[] = ['value'=>$menu['type'],'label'=>$menu['name'].'----单位['.$menu['unit'].']'];
}
return $menus;
})->filterable(1);
$field[]= Form::number('number','限定数量',isset($tash) ? $tash->number : 0)->min(0)->col(24);
$field[]= Form::number('sort','排序',isset($tash) ? $tash->sort : 0)->min(0)->col(24);
$field[]= Form::radio('is_show','是否显示',isset($tash) ? $tash->is_show : 1)->options([['label'=>'显示','value'=>1],['label'=>'隐藏','value'=>0]])->col(24);
$field[]= Form::radio('is_must','是否务必达成',isset($tash) ? $tash->is_must : 1)->options([['label'=>'务必达成','value'=>1],['label'=>'完成其一','value'=>0]])->col(24);
$field[]= Form::textarea('illustrate','任务说明',isset($tash) ? $tash->illustrate : '');
$form = Form::make_post_form('添加任务',$field,Url::build('save_tash',['id'=>$id,'level_id'=>$level_id]),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/*
* 保存或者修改任务
* @param int $id 任务id
* @param int $vip_id 会员id
* */
public function save_tash($id=0,$level_id=0)
{
if(!$level_id) return JsonService::fail('缺少参数');
$data=UtilService::postMore([
['task_type',''],
['number',0],
['is_show',0],
['sort',0],
['is_must',0],
['illustrate',''],
]);
if(!$data['task_type']) return JsonService::fail('请选择任务类型');
if($data['number'] < 0) return JsonService::fail('请输入限定数量');
$tash=SystemUserTask::getTaskType($data['task_type']);
if($tash['max_number']!=0 && $data['number'] > $tash['max_number']) return JsonService::fail('您设置的限定数量超出最大限制,最大限制为:'.$tash['max_number']);
$data['name']=SystemUserTask::setTaskName($data['task_type'],$data['number']);
try{
if($id){
SystemUserTask::edit($data,$id);
return JsonService::successful('修改成功');
}else{
$data['level_id']=$level_id;
$data['add_time']=time();
$data['real_name']=$tash['real_name'];
if(SystemUserTask::set($data))
return JsonService::successful('添加成功');
else
return JsonService::fail('添加失败');
}
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
}
/*
* 异步获取等级任务列表
* @param int $vip_id 会员id
* @param int $page 分页
* @param int $limit 显示条数
* @return json
* */
public function get_tash_list($level_id=0)
{
list($page,$limit)=UtilService::getMore([
['page',1],
['limit',10],
],$this->request,true);
return JsonService::successlayui(SystemUserTask::getTashList($level_id,(int)$page,(int)$limit));
}
/*
* 删除任务
* @param int 任务id
* */
public function delete_tash($id=0)
{
if(!$id) return JsonService::fail('缺少差参数');
if(SystemUserTask::del($id))
return JsonService::successful('删除成功');
else
return JsonService::fail('删除失败');
}
/*
* 会员等级展示
*
* */
public function user_level_list()
{
$this->assign('level',SystemUserLevel::where('is_del',0)->where('is_show',1)->order('grade asc')->field(['id','name'])->select());
return $this->fetch();
}
public function get_user_vip_list()
{
$where=UtilService::getMore([
['page',1],
['limit',10],
['nickname',''],
['level_id',''],
]);
return JsonService::successlayui(UserLevelModel::getUserVipList($where));
}
}

View File

@ -1,305 +0,0 @@
<?php
namespace app\admin\controller\user;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService as Util;
use service\JsonService as Json;
use think\Request;
use think\Url;
use app\admin\model\user\UserNotice as UserNoticeModel;
use app\admin\model\user\UserNoticeSee as UserNoticeSeeModel;
use app\admin\model\wechat\WechatUser as UserModel;
/**
* 用户通知
* Class UserNotice
* @package app\admin\controller\user
*/
class UserNotice extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
if($this->request->isAjax()){
$where=Util::getMore([
['page',1],
['limit',20]
]);
return Json::successlayui(UserNoticeModel::getList($where));
}else{
return $this->fetch();
}
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create(){
$f = array();
$f[] = Form::input('user','发送人','系统管理员');
$f[] = Form::input('title','通知标题');
$f[] = Form::input('content','通知内容')->type('textarea');
$f[] = Form::radio('type','消息类型',1)->options([['label'=>'系统消息','value'=>1],['label'=>'用户通知','value'=>2]]);
$form = Form::make_post_form('添加用户通知',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request){
return Json::fail('站内消息暂不可用');
$params = $request->post();
if(!$params["user"])return Json::fail('请输入发送人!');
if(!$params["title"])return Json::fail('请输入通知标题!');
if(!$params["content"])return Json::fail('请输入通知内容!');
if($params["type"] == 2){
$uids = UserModel::order('uid desc')->column("uid");
$params["uid"] = count($uids) > 0 ? ",".implode(",",$uids)."," : "";
}
$params["add_time"] = time();
UserNoticeModel::set($params);
return Json::successful('添加成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$notice = UserNoticeModel::get($id);
if(!$notice) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('user','发送人',$notice["user"]);
$f[] = Form::input('title','通知标题',$notice["title"]);
$f[] = Form::input('content','通知内容',$notice["content"])->type('textarea');
$f[] = Form::radio('type','消息类型',$notice["type"])->options([['label'=>'系统消息','value'=>1],['label'=>'用户通知','value'=>2]]);
$form = Form::make_post_form('编辑通知',$f,Url::build('update',["id"=>$id]),2);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function update(Request $request,$id)
{
$params = $request->post();
if(!$params["user"])return Json::fail('请输入发送人!');
if(!$params["title"])return Json::fail('请输入通知标题!');
if(!$params["content"])return Json::fail('请输入通知内容!');
UserNoticeModel::edit($params,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function send($id)
{
UserNoticeModel::edit(array("is_send"=>1,"send_time"=>time()),$id);
return Json::successful('发送成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!UserNoticeModel::del($id))
return Json::fail(UserNoticeModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 查询发送信息的用户资源
*
* @param int $id
* @return \think\Response
*/
public function user($id){
$notice = UserNoticeModel::get($id)->toArray();
$model = new UserModel;
$model = $model::alias('A');
$model = $model->field('A.*');
if($notice["type"] == 2){
if($notice["uid"] != ""){
$uids = explode(",",$notice["uid"]);
array_splice($uids,0,1);
array_splice($uids,count($uids)-1,1);
$model = $model->where("A.uid","in",$uids);
}else{
$model = $model->where("A.uid",$notice['uid']);
}
$model->order('A.uid desc');
}else{
$model = $model->join('__USER_NOTICE_SEE__ B','A.uid = B.uid','RIGHT');
$model = $model->where("B.nid",$notice['id']);
$model->order('B.add_time desc');
}
$this->assign(UserModel::page($model,function($item,$key) use ($notice){
$item["is_see"] = UserNoticeSeeModel::where("uid",$item["uid"])->where("nid",$notice["id"])->count() > 0 ? 1 : 0;
}));
$this->assign(compact('notice'));
return $this->fetch();
}
/**
* 添加发送信息的用户
*
* @param \think\Request $request
* @return \think\Response
*/
public function user_create($id){
$where = Util::getMore([
['nickname',''],
['data',''],
],$this->request);
$this->assign('where',$where);
$this->assign(UserModel::systemPage($where));
$this->assign(['title'=>'添加发送用户','save'=>Url::build('user_save',array('id'=>$id))]);
return $this->fetch();
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function user_save(Request $request,$id){
$notice = UserNoticeModel::get($id)->toArray();
if(!$notice) return Json::fail('通知信息不存在!');
if($notice["type"] == 1) return Json::fail('系统通知不能管理用户!');
//查找当前选中的uid
$params = $request->post();
if(isset($params["search"])){
$model = new UserModel;
if($params['search']['nickname'] !== '') $model = $model->where('nickname','LIKE',"%".$params['search']['nickname']."%");
if($params['search']['data'] !== ''){
list($startTime,$endTime) = explode(' - ',$params['search']['data']);
$model = $model->where('add_time','>',strtotime($startTime));
$model = $model->where('add_time','<',strtotime($endTime));
}
$model = $model->order('uid desc');
$uids = $model->column("uid");
}else{
$uids = $params["checked_menus"];
}
if(count($uids) <= 0)return Json::fail('请选择要添加的用户!');
//合并原来和现在的uid
if($notice["uid"] != ""){
$now_uids = explode(",",$notice["uid"]);
array_splice($now_uids,0,1);
array_splice($now_uids,count($now_uids)-1,1);
$now_uids = array_merge($now_uids,$uids);
}else{
$now_uids = $uids;
}
//编辑合并之后的uid
$res_uids = UserModel::where("uid","in",$now_uids)->order('uid desc')->column("uid");
UserNoticeModel::edit(array("uid"=>",".implode(",",$res_uids).","),$notice["id"]);
return Json::successful('添加成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function user_delete($id,$uid)
{
$notice = UserNoticeModel::get($id)->toArray();
if(!$notice) return Json::fail('通知信息不存在!');
if($notice["type"] == 1) return Json::fail('系统通知不能管理用户!');
if($notice["uid"] != ""){
$res_uids = explode(",",$notice["uid"]);
array_splice($res_uids,0,1);
array_splice($res_uids,count($res_uids)-1,1);
}
array_splice($res_uids,array_search($uid,$res_uids),1);
$value = count($res_uids) > 0 ? ",".implode(",",$res_uids)."," : "";
UserNoticeModel::edit(array("uid"=>$value),$notice["id"]);
return Json::successful('删除成功!');
}
/**
* 删除指定的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function user_select_delete(Request $request,$id){
$params = $request->post();
if(count($params["checked_menus"]) <= 0)return Json::fail('删除数据不能为空!');
$notice = UserNoticeModel::get($id)->toArray();
if(!$notice) return Json::fail('通知信息不存在!');
$res_uids = explode(",",$notice["uid"]);
array_splice($res_uids,0,1);
array_splice($res_uids,count($res_uids)-1,1);
foreach ($params["checked_menus"] as $key => $value) {
array_splice($res_uids,array_search($value,$res_uids),1);
}
$value = count($res_uids) > 0 ? ",".implode(",",$res_uids)."," : "";
UserNoticeModel::edit(array("uid"=>$value),$notice["id"]);
return Json::successful('删除成功!');
}
/**
* @param $id
* @return mixed
*/
public function notice($id){
$where = Util::getMore([
['title',''],
],$this->request);
$nickname = UserModel::where('uid','IN',$id)->column('uid,nickname');
$this->assign('where',$where);
$this->assign('uid',$id);
$this->assign('nickname',implode(',',$nickname));
$this->assign(UserNoticeModel::getUserList($where));
return $this->fetch();
}
/**
* 给指定用户发送站内信息
* @param $id
*/
public function send_user($id = 0,$uid = '')
{
if(!$id || $uid == '') return JsonService::fail('参数错误');
$uids = UserNoticeModel::where(['id'=>$id])->value('uid');
$uid = rtrim($uids,',').",".$uid.",";
UserNoticeModel::edit(array("send_time"=>time(),'uid'=>$uid),$id);
return Json::successful('发送成功!');
}
}

File diff suppressed because one or more lines are too long

View File

@ -1,38 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use app\core\util\WechatService;
use think\Cache;
use think\Db;
use think\Request;
/**
* 微信菜单 控制器
* Class Menus
* @package app\admin\controller\wechat
*/
class Menus extends AuthController
{
public function index()
{
$menus = Db::name('cache')->where('key','wechat_menus')->value('result');
$menus = $menus ? : '[]';
$this->assign('menus',$menus);
return $this->fetch();
}
public function save(Request $request)
{
$buttons = $request->post('button/a',[]);
if(!count($buttons)) return $this->failed('请添加至少一个按钮');
try{
WechatService::menuService()->add($buttons);
Db::name('cache')->insert(['key'=>'wechat_menus','result'=>json_encode($buttons),'add_time'=>time()],true);
return $this->successful('修改成功!');
}catch (\Exception $e){
return $this->failed($e->getMessage());
}
}
}

View File

@ -1,184 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemAttachment;
use app\admin\model\wechat\WechatReply;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
/**
* 关键字管理 控制器
* Class Reply
* @package app\admin\controller\wechat
*/
class Reply extends AuthController
{
/**关注回复
* @return mixed|void
*/
public function index()
{
if(empty(input('key'))) return $this->failed('请输入参数key');
if(empty(input('title'))) return $this->failed('请输入参数title');
$key = input('key');
switch($key){
case 'subscribe':
$title = '编辑关注回复';
break;
case 'default':
$title = '编辑关键字默认回复';
break;
default:
$title = '编辑关键字回复';
break;
}
$replay = WechatReply::getDataByKey($key);
$this->assign('replay_arr',json_encode($replay));
$this->assign('key',$key);
$this->assign('title',$title);
return $this->fetch();
}
public function one_reply(){
$where = Util::postMore([
['key'],
['add',0],
],$this->request);
// dump($where);
// exit();
if(!empty($where['key'])) $replay_arr = WechatReply::getDataByKey($where['key']);
$replay_arr['code'] = 200;
if(empty($replay_arr)) {
$replay_arr['code'] = 0;
}
if($where['add'] && empty($where['key'])){
$replay_arr['code'] = 0;
}
exit(json_encode($replay_arr));
}
public function save(Request $request)
{
$data = Util::postMore([
'type',
'key',
['status',0],
['data',[]],
],$request);
if(!isset($data['type']) && empty($data['type']))
return Json::fail('请选择回复类型');
if(!in_array($data['type'],WechatReply::$reply_type))
return Json::fail('回复类型有误!');
if(!isset($data['data']) || !is_array($data['data']))
return Json::fail('回复消息参数有误!');
$res = WechatReply::redact($data['data'],$data['key'],$data['type'],$data['status']);
if(!$res)
return Json::fail(WechatReply::getErrorInfo());
else
return Json::successful('保存成功!',$data);
}
public function upload_img(Request $request)
{
$name = $request->post('file');
if(!$name) return Json::fail('请上传图片');
$res = Upload::image($name,'wechat/image',true,true,null,'uniqid',1);
if(!is_array($res)) return Json::fail($res);
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],0,$res['image_type'],$res['time']);
return Json::successful('上传成功',$res['dir']);
}
public function upload_file(Request $request)
{
$name = $request->post('file');
if(!$name) return Json::fail('请上传声音');
$autoValidate['size'] = 2097152;
$res = Upload::file($name,'wechat/voice',true,$autoValidate);
return $res->status === true ? Json::successful('上传成功',$res->filePath) : Json::fail($res->error);
}
/**
* 关键字回复
* */
public function keyword(){
$where = Util::getMore([
['key',''],
['type',''],
],$this->request);
$this->assign('where',$where);
$this->assign(WechatReply::getKeyAll($where));
return $this->fetch();
}
/**
* 添加关键字
* */
public function add_keyword(){
$key = input('key');
if(empty($key)) $key = '';
$this->assign('key',$key);
$this->assign('dis',1);
$this->assign('replay_arr',json_encode(array()));
return $this->fetch();
}
/**
* 修改关键字
* */
public function info_keyword(){
$key = input('key');
if(empty($key)) return $this->failed('参数错误,请重新修改');
$replay = WechatReply::getDataByKey($key);
$this->assign('replay_arr',json_encode($replay));
$this->assign('key',$key);
$this->assign('dis',2);
return $this->fetch('add_keyword');
}
/**
* 保存关键字
* */
public function save_keyword(Request $request)
{
$data = Util::postMore([
'key',
'type',
['status',0],
['data',[]],
],$request);
// dump($data);
// exit();
if(!isset($data['key']) && empty($data['key']))
return Json::fail('请输入关键字');
if(isset($data['key']) && !empty($data['key'])){
if(trim($data['key']) == 'subscribe') return Json::fail('请重新输入关键字');
if(trim($data['key']) == 'default') return Json::fail('请重新输入关键字');
}
if(!isset($data['type']) && empty($data['type']))
return Json::fail('请选择回复类型');
if(!in_array($data['type'],WechatReply::$reply_type))
return Json::fail('回复类型有误!');
if(!isset($data['data']) || !is_array($data['data']))
return Json::fail('回复消息参数有误!');
$res = WechatReply::redact($data['data'],$data['key'],$data['type'],$data['status']);
if(!$res)
return Json::fail(WechatReply::getErrorInfo());
else
return Json::successful('保存成功!',$data);
}
/**
* 删除关键字
* */
public function delete($id){
if(!WechatReply::del($id))
return Json::fail(WechatReply::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,172 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use app\admin\model\system\SystemAttachment;
use service\FormBuilder as Form;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use think\Url;
use app\admin\model\wechat\StoreService as ServiceModel;
use app\admin\model\wechat\StoreServiceLog as StoreServiceLog;
use app\admin\model\wechat\WechatUser as UserModel;
/**
* 客服管理
* Class StoreService
* @package app\admin\controller\store
*/
class StoreService extends AuthController
{
/**
* 显示资源列表
*
* @return \think\Response
*/
public function index()
{
$this->assign(ServiceModel::getList(0));
return $this->fetch();
}
/**
* 显示创建资源表单页.
*
* @return \think\Response
*/
public function create(){
$where = Util::getMore([
['nickname',''],
['data',''],
['tagid_list',''],
['groupid','-1'],
['sex',''],
['export',''],
['stair',''],
['second',''],
['order_stair',''],
['order_second',''],
['subscribe',''],
['now_money',''],
['is_promoter',''],
],$this->request);
$this->assign('where',$where);
$this->assign(UserModel::systemPage($where));
$this->assign(['title'=>'添加客服','save'=>Url::build('save')]);
return $this->fetch();
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request){
$params = $request->post();
if(count($params["checked_menus"]) <= 0)return Json::fail('请选择要添加的用户!');
if(ServiceModel::where('mer_id',0)->where(array("uid"=>array("in",$params["checked_menus"])))->count())return Json::fail('添加用户中存在已有的客服!');
foreach ($params["checked_menus"] as $key => $value) {
$now_user = UserModel::get($value);
$data[$key]["mer_id"] = 0;
$data[$key]["uid"] = $now_user["uid"];
$data[$key]["avatar"] = $now_user["headimgurl"];
$data[$key]["nickname"] = $now_user["nickname"];
$data[$key]["add_time"] = time();
}
ServiceModel::setAll($data);
return Json::successful('添加成功!');
}
/**
* 显示编辑资源表单页.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
$service = ServiceModel::get($id);
if(!$service) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::formFrameImageOne('avatar','客服头像',$service['avatar']);
$f[] = Form::input('nickname','客服名称',$service["nickname"]);
$f[] = Form::switches('notify','订单通知',$service["notify"])->trueValue(1)->falseValue(0)->openStr('开启')->closeStr('关闭');
$f[] = Form::radio('status','客服状态',$service['status'])->options([['value'=>1,'label'=>'显示'],['value'=>0,'label'=>'隐藏']]);
$form = Form::make_post_form('修改数据',$f,Url::build('update',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 保存新建的资源
*
* @param \think\Request $request
* @return \think\Response
*/
public function update(Request $request,$id)
{
$params = $request->post();
if(empty($params["nickname"]))return Json::fail("客服名称不能为空!");
// print_r($params);die;
$data = array("avatar"=>$params["avatar"]
,"nickname"=>$params["nickname"]
,'status'=>$params['status']
,'notify'=>$params['notify']
);
ServiceModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete($id)
{
if(!ServiceModel::del($id))
return Json::fail(ServiceModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 上传图片
* @return \think\response\Json
*/
public function upload()
{
$res = Upload::image('file','store/product/'.date('Ymd'));
if(is_array($res)){
SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],2,$res['image_type'],$res['time']);
return Json::successful('图片上传成功!',['name'=>$res['name'],'url'=>Upload::pathToUrl($res['thumb_path'])]);
}else
return Json::fail($res);
}
/**
* 显示资源列表
*
* @return \think\Response
*/
public function chat_user($id)
{
$now_service = ServiceModel::get($id);
if(!$now_service) return Json::fail('数据不存在!');
$list = ServiceModel::getChatUser($now_service,0);
$this->assign(compact('list','now_service'));
return $this->fetch();
}
/**
* 显示资源列表
*
* @return \think\Response
*/
public function chat_list($uid,$to_uid)
{
$this->assign(StoreServiceLog::getChatList($uid,$to_uid,0));
$this->assign('to_uid',$to_uid);
return $this->fetch();
}
}

View File

@ -1,35 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use app\admin\model\wechat\WechatMessage as MessageModel;
use service\UtilService as Util;
/**
* 用户扫码点击事件
* Class SystemMessage
* @package app\admin\controller\system
*/
class WechatMessage extends AuthController
{
/**
* 显示操作记录
*/
public function index(){
$where = Util::getMore([
['nickname',''],
['type',''],
['data',''],
],$this->request);
$this->assign('where',$where);
$this->assign('mold',MessageModel::$mold);
$this->assign(MessageModel::systemPage($where));
return $this->fetch();
}
}

View File

@ -1,186 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use service\UtilService as Util;
use service\JsonService as Json;
use service\UploadService as Upload;
use think\Request;
use app\admin\model\wechat\ArticleCategory as ArticleCategoryModel;
use app\admin\model\wechat\WechatNews as WechatNewsModel;
use app\admin\model\system\SystemAttachment;
/**
* 图文管理
* Class WechatNews
* @package app\admin\controller\wechat
*/
class WechatNews extends AuthController
{
/**
* 显示后台管理员添加的图文
* @return mixed
*/
public function index($cid = 0)
{
$where = Util::getMore([
['title','']
],$this->request);
if($cid)
$where['cid'] = $cid;
else
$where['cid'] = '';
$this->assign('where',$where);
$where['merchant'] = 0;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$this->assign('cid',$cid);
$this->assign(WechatNewsModel::getAll($where));
return $this->fetch();
}
/**
* 展示页面 添加和删除
* @return mixed
*/
public function create(){
$id = input('id');
$cid = input('cid');
$news = array();
$news['id'] = '';
$news['image_input'] = '';
$news['title'] = '';
$news['author'] = '';
$news['content'] = '';
$news['synopsis'] = '';
$news['url'] = '';
$news['cid'] = array();
if($id){
$news = \app\admin\model\wechat\WechatNews::where('n.id',$id)->alias('n')->field('n.*,c.content')->join('__WECHAT_NEWS_CONTENT__ c','c.nid=n.id')->find();
if(!$news) return $this->failedNotice('数据不存在!');
$news['cid'] = explode(',',$news['cid']);
// dump($news);
}
$all = array();
$select = 0;
if(!$cid)
$cid = '';
else {
if($id){
$all = ArticleCategoryModel::where('id',$cid)->where('hidden','neq',0)->column('id,title');
$select = 1;
}else{
$all = ArticleCategoryModel::where('id',$cid)->column('id,title');
$select = 1;
}
}
if(empty($all)){
$all = ArticleCategoryModel::getField('id,title');//新闻分类
$select = 0;
}
$this->assign('all',$all);
$this->assign('news',$news);
$this->assign('cid',$cid);
$this->assign('select',$select);
return $this->fetch();
}
/**
* 上传图文图片
* @return \think\response\Json
*/
public function upload_image(){
$res = Upload::Image($_POST['file'],'wechat/image/'.date('Ymd'));
//产品图片上传记录
$fileInfo = $res->fileInfo->getinfo();
SystemAttachment::attachmentAdd($res->fileInfo->getSaveName(),$fileInfo['size'],$fileInfo['type'],$res->dir,'',5);
if(!$res->status) return Json::fail($res->error);
return Json::successful('上传成功!',['url'=>$res->filePath]);
}
/**
* 添加和修改图文
* @param Request $request
* @return \think\response\Json
*/
public function add_new(Request $request){
$post = $request->post();
$data = Util::postMore([
['id',0],
['cid',[]],
'title',
'author',
'image_input',
'content',
'synopsis',
'share_title',
'share_synopsis',
['visit',0],
['sort',0],
'url',
['status',1],],$request);
$data['cid'] = implode(',',$data['cid']);
$content = $data['content'];
unset($data['content']);
if($data['id']){
$id = $data['id'];
unset($data['id']);
WechatNewsModel::beginTrans();
$res1 = WechatNewsModel::edit($data,$id,'id');
$res2 = WechatNewsModel::setContent($id,$content);
if($res1 && $res2)
$res = true;
else
$res =false;
// dump($res);
// exit();
WechatNewsModel::checkTrans($res);
if($res)
return Json::successful('修改图文成功!',$id);
else
return Json::fail('修改图文失败!',$id);
}else{
$data['add_time'] = time();
$data['admin_id'] = $this->adminId;
WechatNewsModel::beginTrans();
$res1 = WechatNewsModel::set($data);
$res2 = false;
if($res1)
$res2 = WechatNewsModel::setContent($res1->id,$content);
if($res1 && $res2)
$res = true;
else
$res =false;
WechatNewsModel::checkTrans($res);
if($res)
return Json::successful('添加图文成功!',$res1->id);
else
return Json::successful('添加图文失败!',$res1->id);
}
}
/**
* 删除图文
* @param $id
* @return \think\response\Json
*/
public function delete($id)
{
$res = WechatNewsModel::del($id);
if(!$res)
return Json::fail('删除失败,请稍候再试!');
else
return Json::successful('删除成功!');
}
public function merchantIndex(){
$where = Util::getMore([
['title','']
],$this->request);
$this->assign('where',$where);
$where['cid'] = input('cid');
$where['merchant'] = 1;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1
$this->assign(WechatNewsModel::getAll($where));
return $this->fetch();
}
}

View File

@ -1,286 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use app\admin\model\article\Article;
use service\FormBuilder as Form;
use service\JsonService;
use service\UtilService as Util;
use service\JsonService as Json;
use app\admin\model\wechat\WechatReply;
use app\admin\model\wechat\WechatUser;
use service\UtilService;
use think\Db;
use think\Request;
use think\Url;
use app\core\util\WechatService;
use \app\admin\model\wechat\WechatNewsCategory as WechatNewsCategoryModel;
use app\admin\model\article\Article as ArticleModel;
/**
* 图文信息
* Class WechatNewsCategory
* @package app\admin\controller\wechat
*
*/
class WechatNewsCategory extends AuthController
{
public function select($callback = '_selectNews$eb'){
$where = Util::getMore([
['cate_name','']
],$this->request);
$this->assign('where',$where);
$this->assign('callback',$callback);
$this->assign(WechatNewsCategoryModel::getAll($where));
return $this->fetch();
}
public function index()
{
$where = Util::getMore([
['cate_name','']
],$this->request);
$this->assign('where',$where);
$this->assign(WechatNewsCategoryModel::getAll($where));
return $this->fetch();
}
public function create(){
$f = array();
$f[] = Form::input('cate_name','分类名称')->autofocus(1);
$f[] = Form::select('new_id','图文列表')->setOptions(function(){
$list = ArticleModel::getNews();
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
})->filterable(1)->multiple(1);
$form = Form::make_post_form('编辑菜单',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function save(Request $request){
$data = Util::postMore([
'cate_name',
['new_id',[]],
['sort',0],
['add_time',time()],
['status',1],],$request);
if(!$data['cate_name']) return Json::fail('请输入图文名称');
if(empty($data['new_id'])) return Json::fail('请选择图文列表');
$data['new_id'] = array_unique($data['new_id']);
if(count($data['new_id']) > 8){
$data['new_id'] = array_slice($data['new_id'], 0, 8);
};
$data['new_id'] = implode(',',$data['new_id']);
WechatNewsCategoryModel::set($data);
return Json::successful('添加菜单成功!');
}
public function edit($id){
$menu = WechatNewsCategoryModel::get($id);
if(!$menu) return Json::fail('数据不存在!');
$arr_new_id = array_unique(explode(',',$menu->new_id));
foreach ($arr_new_id as $k=>$v){
$arr_new_id[$k] = intval($v);
}
$f = array();
$f[] = Form::input('cate_name','分类名称',$menu['cate_name'])->autofocus(1);
$f[] = Form::select('new_id','图文列表',$arr_new_id)->setOptions(function(){
$list = ArticleModel::getNews();
$options = [];
foreach ($list as $id=>$roleName){
$options[] = ['label'=>$roleName,'value'=>$id];
}
return $options;
})->filterable(1)->multiple(1);
$form = Form::make_post_form('编辑图文',$f,Url::build('update',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'cate_name',
['new_id',[]],
['sort',0],
['status',1],],$request);
if(!$data['cate_name']) return Json::fail('请输入图文名称');
if(empty($data['new_id'])) return Json::fail('请选择图文列表');
if(count($data['new_id']) > 8){
$data['new_id'] = array_slice($data['new_id'], 0, 8);
};
$data['new_id'] = implode(',',$data['new_id']);;
if(!WechatNewsCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
WechatNewsCategoryModel::edit($data,$id);
return Json::successful('修改成功!');
}
public function delete($id){
if(!WechatNewsCategoryModel::del($id))
return Json::fail(WechatNewsCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
/**
* 发送消息
* @param int $id
* @param string $wechat
* $wechat 不为空 发消息 / 群发消息
*/
public function push($id = 0,$wechat = ''){
if(!$id) return Json::fail('参数错误');
$list = WechatNewsCategoryModel::getWechatNewsItem($id);
$wechatNews = [];
if($list){
if($list['new'] && is_array($list['new'])){
foreach ($list['new'] as $kk=>$vv){
$wechatNews[$kk]['title'] = $vv['title'];
$wechatNews[$kk]['image'] = $vv['image_input'];
$wechatNews[$kk]['date'] = date('m月d日',time());
$wechatNews[$kk]['description'] = $vv['synopsis'];
$wechatNews[$kk]['id'] = $vv['id'];
}
}
}
if($wechat != ''){//客服消息
$wechatNews = WechatReply::tidyNews($wechatNews);
$message = WechatService::newsMessage($wechatNews);
$errorLog = [];//发送失败的用户
$user = WechatUser::where('uid','IN',$wechat)->column('nickname,subscribe,openid','uid');
if($user){
foreach ($user as $v){
if($v['subscribe'] && $v['openid']){
try {
WechatService::staffService()->message($message)->to($v['openid'])->send();
} catch (\Exception $e) {
$errorLog[] = $v['nickname'].'发送失败';
}
}else{
$errorLog[] = $v['nickname'].'没有关注发送失败(不是微信公众号用户)';
}
}
}else return Json::fail('发送失败,参数不正确');
if(!count($errorLog)) return Json::successful('全部发送成功');
else return Json::successful(implode(',',$errorLog).',剩余的发送成功');
}else{//群发消息
// if($list){
// if($list['new'] && is_array($list['new'])){
// foreach ($list['new'] as $kk=>$vv){
// $wechatNews[$kk]['title'] = $vv['title'];
// $wechatNews[$kk]['thumb_media_id'] = $vv['image_input'];
// $wechatNews[$kk]['author'] = $vv['author'];
// $wechatNews[$kk]['digest'] = $vv['synopsis'];
// $wechatNews[$kk]['show_cover_pic'] = 1;
// $wechatNews[$kk]['content'] = Db::name('articleContent')->where('nid',$vv["id"])->value('content');
// $wechatNews[$kk]['content_source_url'] = $vv['url'];
// }
// }
// }
//6sFx6PzPF2v_Lv4FGOMzz-oQunU2Z3wrOWb-7zS508E
//6sFx6PzPF2v_Lv4FGOMzz7SUUuamgWwlqdVfhQ5ALT4
// foreach ($wechatNews as $k=>$v){
// $material = WechatService::materialService()->uploadImage(UtilService::urlToPath($v['thumb_media_id']));
// dump($material);
// $wechatNews[$k]['thumb_media_id'] = $material->media_id;
// }
// $mediaIdNews = WechatService::uploadNews($wechatNews);
// $res = WechatService::sendNewsMessage($mediaIdNews->media_id);
// if($res->errcode) return Json::fail($res->errmsg);
// else return Json::successful('推送成功');
// dump($mediaIdNews);
// dump($res);
}
}
public function send_news($id = ''){
if($id == '') return $this->failed('参数错误');
$where = Util::getMore([
['cate_name','']
],$this->request);
$this->assign('where',$where);
$this->assign('wechat',$id);
$this->assign(WechatNewsCategoryModel::getAll($where));
return $this->fetch();
}
public function append(){
$this->assign('list',[
[
'id'=>0,
'title'=>'',
'author'=>$this->adminInfo->real_name,
'content'=>'',
'image_input'=>'/public/system/module/wechat/news/images/image.png',
'synopsis'=>'',
]
]);
$this->assign('id',0);
$this->assign('author',$this->adminInfo->real_name);
return $this->fetch();
}
public function append_save(Request $request){
$data = UtilService::postMore([
['list',[]],
['id',0]
],$request);
$id = [];
$countList = count($data['list']);
if(!$countList) return JsonService::fail('请添加图文');
Article::beginTrans();
foreach ($data['list'] as $k=>$v){
if($v['title'] == '') return JsonService::fail('标题不能为空');
if($v['author'] == '') return JsonService::fail('作者不能为空');
if($v['content'] == '') return JsonService::fail('正文不能为空');
if($v['synopsis'] == '') return JsonService::fail('摘要不能为空');
$v['status'] = 1;
$v['add_time'] = time();
if($v['id']){
$idC = $v['id'];
unset($v['id']);
Article::edit($v,$idC);
Db::name('ArticleContent')->where('nid',$idC)->update(['content'=>$v['content']]);
$data['list'][$k]['id'] = $idC;
$id[] = $idC;
}else{
unset($v['id']);
$res = Article::set($v)->toArray();
$id[] = $res['id'];
$data['list'][$k]['id'] = $res['id'];
Db::name('ArticleContent')->insert(['content'=>$v['content'],'nid'=>$res['id']]);
}
}
$countId = count($id);
if($countId != $countList){
Article::checkTrans(false);
if($data['id']) return JsonService::fail('修改失败');
else return JsonService::fail('添加失败');
}else{
Article::checkTrans(true);
$newsCategory['cate_name'] = $data['list'][0]['title'];
$newsCategory['new_id'] = implode(',',$id);
$newsCategory['sort'] = 0;
$newsCategory['add_time'] = time();
$newsCategory['status'] = 1;
if($data['id']) {
WechatNewsCategoryModel::edit($newsCategory,$data['id']);
return JsonService::successful('修改成功');
}else{
WechatNewsCategoryModel::set($newsCategory);
return JsonService::successful('添加成功');
}
}
}
public function modify($id){
$menu = WechatNewsCategoryModel::get($id);
$list = Article::getArticleList($menu['new_id']);
$this->assign('list',$list);
$this->assign('id',$id);
$this->assign('author',$this->adminInfo->real_name);
return $this->fetch('append');
}
}

View File

@ -1,135 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use service\UtilService as Util;
use service\JsonService as Json;
use app\core\util\WechatTemplateService;
use think\Cache;
use think\Request;
use think\Url;
use app\admin\model\wechat\WechatTemplate as WechatTemplateModel;
use app\admin\model\system\SystemConfig;
/**
* 微信模板消息控制器
* Class WechatTemplate
* @package app\admin\controller\wechat
*/
class WechatTemplate extends AuthController
{
protected $cacheTag = '_system_wechat';
public function index()
{
$where = Util::getMore([
['name',''],
['status','']
],$this->request);
$this->assign('where',$where);
$this->assign(WechatTemplateModel::SystemPage($where));
$industry = Cache::tag($this->cacheTag)->remember('_wechat_industry',function(){
try{
$cache = WechatTemplateService::getIndustry();
if(!$cache) return [];
Cache::tag($this->cacheTag,['_wechat_industry']);
return $cache->toArray();
}catch (\Exception $e){
return $e->getMessage();
}
},0)?:[];
!is_array($industry) && $industry = [];
$this->assign('industry',$industry);
return $this->fetch();
}
/**
* 添加模板消息
* @return mixed
*/
public function create()
{
$f = array();
$f[] = Form::input('tempkey','模板编号');
$f[] = Form::input('tempid','模板ID');
$f[] = Form::input('name','模板名');
$f[] = Form::input('content','回复内容')->type('textarea');
$f[] = Form::radio('status','状态',1)->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('添加模板消息',$f,Url::build('save'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function save(Request $request)
{
$data = Util::postMore([
'tempkey',
'tempid',
'name',
'content',
['status',0]
],$request);
if($data['tempkey'] == '') return Json::fail('请输入模板编号');
if($data['tempkey'] != '' && WechatTemplateModel::be($data['tempkey'],'tempkey'))
return Json::fail('请输入模板编号已存在,请重新输入');
if($data['tempid'] == '') return Json::fail('请输入模板ID');
if($data['name'] == '') return Json::fail('请输入模板名');
if($data['content'] == '') return Json::fail('请输入回复内容');
$data['add_time'] = time();
WechatTemplateModel::set($data);
return Json::successful('添加模板消息成功!');
}
/**
* 编辑模板消息
* @param $id
* @return mixed|\think\response\Json|void
*/
public function edit($id)
{
if(!$id) return $this->failed('数据不存在');
$product = WechatTemplateModel::get($id);
if(!$product) return Json::fail('数据不存在!');
$f = array();
$f[] = Form::input('tempkey','模板编号',$product->getData('tempkey'))->disabled(1);
$f[] = Form::input('name','模板名',$product->getData('name'))->disabled(1);
$f[] = Form::input('tempid','模板ID',$product->getData('tempid'));
$f[] = Form::radio('status','状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
$form = Form::make_post_form('编辑模板消息',$f,Url::build('update',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update(Request $request, $id)
{
$data = Util::postMore([
'tempid',
['status',0]
],$request);
if($data['tempid'] == '') return Json::fail('请输入模板ID');
if(!$id) return $this->failed('数据不存在');
$product = WechatTemplateModel::get($id);
if(!$product) return Json::fail('数据不存在!');
WechatTemplateModel::edit($data,$id);
return Json::successful('修改成功!');
}
/**
* 删除模板消息
* @param $id
* @return \think\response\Json
*/
public function delete($id)
{
if(!$id) return Json::fail('数据不存在!');
if(!WechatTemplateModel::del($id))
return Json::fail(WechatTemplateModel::getErrorInfo('删除失败,请稍候再试!'));
else
return Json::successful('删除成功!');
}
}

View File

@ -1,398 +0,0 @@
<?php
namespace app\admin\controller\wechat;
use app\admin\controller\AuthController;
use service\FormBuilder as Form;
use app\admin\model\user\User;
use app\admin\model\wechat\WechatUser as UserModel;
use app\core\model\user\UserBill;
use service\JsonService;
use service\UtilService as Util;
use app\core\util\WechatService;
use think\Collection;
use think\Request;
use think\Url;
/**
* 管理员操作记录表控制器
* Class WechatUser
* @package app\admin\controller\wechat
*/
class WechatUser extends AuthController
{
/**
* 显示操作记录
*/
public function index(){
$where = Util::getMore([
['nickname',''],
['data',''],
['tagid_list',''],
['groupid','-1'],
['sex',''],
['export',''],
['stair',''],
['second',''],
['order_stair',''],
['order_second',''],
['subscribe',''],
['now_money',''],
['is_promoter',''],
],$this->request);
$tagidList = explode(',',$where['tagid_list']);
foreach ($tagidList as $k=>$v){
if(!$v){
unset($tagidList[$k]);
}
}
$tagidList = array_unique($tagidList);
$where['tagid_list'] = implode(',',$tagidList);
try{
$groupList=UserModel::getUserGroup();
$tagList=UserModel::getUserTag();
}catch (\Exception $e){
$groupList=[];
$tagList=[];
}
$this->assign([
'where'=>$where,
'groupList'=>$groupList,
'tagList'=>$tagList
]);
$limitTimeList = [
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
$uidAll = UserModel::getAll($where);
$this->assign(compact('limitTimeList','uidAll'));
$this->assign(UserModel::systemPage($where));
return $this->fetch();
}
public function edit_user_tag($openid)
{
if(!$openid) return JsonService::fail('参数错误!');
$list = Collection::make(UserModel::getUserTag())->each(function($item){
return ['value'=>$item['id'],'label'=>$item['name']];
});
$tagList = UserModel::where('openid',$openid)->value('tagid_list');
$tagList = explode(',',$tagList)?:[];
$f = [Form::select('tag_id','用户标签',$tagList)->setOptions($list->toArray())->multiple(1)];
$form = Form::make_post_form('标签名称',$f,Url::build('update_user_tag',compact('openid')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update_user_tag(Request $request,$openid)
{
if(!$openid) return JsonService::fail('参数错误!');
$tagId = $request->post('tag_id/a',[]);
if(!$tagId) return JsonService::fail('请选择用户标签!');
$tagList = explode(',',UserModel::where('openid',$openid)->value('tagid_list'))?:[];
UserModel::edit(['tagid_list'=>$tagId],$openid,'openid');
if(!$tagId[0])unset($tagId[0]);
UserModel::edit(['tagid_list'=>$tagId],$openid,'openid');
try{
foreach ($tagList as $tag){
if($tag) WechatService::userTagService()->batchUntagUsers([$openid],$tag);
}
foreach ($tagId as $tag){
WechatService::userTagService()->batchTagUsers([$openid],$tag);
}
}catch (\Exception $e){
UserModel::rollbackTrans();
return JsonService::fail($e->getMessage());
}
UserModel::commitTrans();
return JsonService::successful('修改成功!');
}
public function edit_user_group($openid)
{
if(!$openid) return JsonService::fail('参数错误!');
$list = Collection::make(UserModel::getUserGroup())->each(function($item){
return ['value'=>$item['id'],'label'=>$item['name']];
});
$groupId = UserModel::where('openid',$openid)->value('groupid');
$f = [Form::select('group_id','用户分组',(string)$groupId)->setOptions($list->toArray())];
$form = Form::make_post_form('用户分组',$f,Url::build('update_user_group',compact('openid')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
public function update_user_group(Request $request,$openid)
{
if(!$openid) return JsonService::fail('参数错误!');
$groupId = $request->post('group_id');
// if(!$groupId) return JsonService::fail('请选择用户分组!');
UserModel::beginTrans();
UserModel::edit(['groupid'=>$groupId],$openid,'openid');
try{
WechatService::userGroupService()->moveUser($openid,$groupId);
}catch (\Exception $e){
UserModel::rollbackTrans();
return JsonService::fail($e->getMessage());
}
UserModel::commitTrans();
return JsonService::successful('修改成功!');
}
/**
* 用户标签列表
*/
public function tag($refresh = 0)
{
$list=[];
if($refresh == 1) {
UserModel::clearUserTag();
$this->redirect(Url::build('tag'));
}
try{
$list = UserModel::getUserTag();
}catch (\Exception $e){}
$this->assign(compact('list'));
return $this->fetch();
}
/**
* 添加标签
* @return mixed
*/
public function create_tag()
{
$f = [Form::input('name','标签名称')];
$form = Form::make_post_form('标签名称',$f,Url::build('save_tag'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 添加
* @param Request $request
* @return \think\response\Json
*/
public function save_tag(Request $request)
{
$tagName = $request->post('name');
if(!$tagName) return JsonService::fail('请输入标签名称!');
try{
WechatService::userTagService()->create($tagName);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserTag();
return JsonService::successful('添加标签成功!');
}
/**
* 修改标签
* @param $id
* @return mixed
*/
public function edit_tag($id)
{
$f = [Form::input('name','标签名称')];
$form = Form::make_post_form('标签名称',$f,Url::build('update_tag',['id'=>$id]));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 修改标签
* @param Request $request
* @param $id
* @return \think\response\Json
*/
public function update_tag(Request $request, $id)
{
$tagName = $request->post('name');
if(!$tagName) return JsonService::fail('请输入标签名称!');
try{
WechatService::userTagService()->update($id,$tagName);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserTag();
return JsonService::successful('修改标签成功!');
}
/**
* 删除标签
* @param $id
* @return \think\response\Json
*/
public function delete_tag($id)
{
try{
WechatService::userTagService()->delete($id);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserTag();
return JsonService::successful('删除标签成功!');
}
/**
* 用户分组列表
*/
public function group($refresh = 0)
{
$list=[];
if($refresh == 1) {
UserModel::clearUserGroup();
$this->redirect(Url::build('group'));
}
try{
$list = UserModel::getUserGroup();
}catch (\Exception $e){}
$this->assign(compact('list'));
return $this->fetch();
}
/**
* 添加分组
* @return mixed
*/
public function create_group()
{
$f = [Form::input('name','分组名称')];
$form = Form::make_post_form('标签名称',$f,Url::build('save_group'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 添加
* @param Request $request
* @return \think\response\Json
*/
public function save_group(Request $request)
{
$tagName = $request->post('name');
if(!$tagName) return JsonService::fail('请输入分组名称!');
try{
WechatService::userGroupService()->create($tagName);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserGroup();
return JsonService::successful('添加分组成功!');
}
/**
* 修改分组
* @param $id
* @return mixed
*/
public function edit_group($id)
{
$f = [Form::input('name','分组名称')];
$form = Form::make_post_form('标签名称',$f,Url::build('update_group',compact('id')));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 修改分组
* @param Request $request
* @param $id
* @return \think\response\Json
*/
public function update_group(Request $request, $id)
{
$tagName = $request->post('name');
if(!$tagName) return JsonService::fail('请输入分组名称!');
try{
WechatService::userGroupService()->update($id,$tagName);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserGroup();
return JsonService::successful('修改分组成功!');
}
/**
* 删除分组
* @param $id
* @return \think\response\Json
*/
public function delete_group($id)
{
try{
WechatService::userTagService()->delete($id);
}catch (\Exception $e){
return JsonService::fail($e->getMessage());
}
UserModel::clearUserGroup();
return JsonService::successful('删除分组成功!');
}
public function synchro_tag($openid){
if(!$openid) return JsonService::fail('参数错误!');
$data = array();
if(UserModel::be($openid,'openid')){
try{
$tag = WechatService::userTagService()->userTags($openid)->toArray();
}catch (\Exception $e) {
return JsonService::fail($e->getMessage());
}
if($tag['tagid_list']) $data['tagid_list'] = implode(',',$tag['tagid_list']);
else $data['tagid_list'] = '';
$res = UserModel::edit($data,$openid,'openid');
if($res) return JsonService::successful('同步成功');
else return JsonService::fail('同步失败!');
}else return JsonService::fail('参数错误!');
}
/**
* 一级推荐人页面
* @return mixed
*/
public function stair($uid = ''){
if($uid == '') return $this->failed('参数错误');
$list = User::alias('u')
->where('u.spread_uid',$uid)
->field('u.avatar,u.nickname,u.now_money,u.add_time,u.uid')
->where('u.status',1)
->order('u.add_time DESC')
->select()
->toArray();
foreach ($list as $key=>$value) $list[$key]['orderCount'] = StoreOrder::getOrderCount($value['uid']);
$this->assign('list',$list);
return $this->fetch();
}
/**
* 个人资金详情页面
* @return mixed
*/
public function now_money($uid = ''){
if($uid == '') return $this->failed('参数错误');
$list = UserBill::where('uid',$uid)->where('category','now_money')
->field('mark,pm,number,add_time')
->where('status',1)->order('add_time DESC')->select()->toArray();
foreach ($list as &$v){
$v['add_time'] = date('Y-m-d H:i:s',$v['add_time']);
}
$this->assign('list',$list);
return $this->fetch();
}
}

View File

@ -1,7 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/18 0018
* Time: 上午 10:44
*/

View File

@ -1,264 +0,0 @@
<?php
namespace app\admin\controller\widget;
use Api\Storage\COS\COS;
use Api\Storage\OSS\OSS;
use Api\Storage\Qiniu\Qiniu;
use think\Request;
use think\Url;
use app\admin\model\system\SystemAttachment as SystemAttachmentModel;
use app\admin\model\system\SystemAttachmentCategory as Category;
use app\admin\controller\AuthController;
use service\UploadService as Upload;
use service\JsonService as Json;
use service\UtilService as Util;
use service\FormBuilder as Form;
/**
* TODO 附件控制器
* Class Images
* @package app\admin\controller\widget
*/
class Images extends AuthController
{
/**
* 附件列表
* @return \think\response\Json
*/
public function index()
{
$pid = $this->request->param('pid');
if($pid === NULL)
{
$pid = session('pid') ? session('pid') : 0;
}
session('pid',$pid);
$this->assign('pid',$pid);
return $this->fetch('widget/images');
}
public function get_image_list()
{
$where = Util::getMore([
['page',1],
['limit',18],
['pid',0]
]);
return Json::successful(SystemAttachmentModel::getImageList($where));
}
public function get_image_cate($name = '')
{
return Json::successful(Category::getAll($name));
}
/**
* 图片管理上传图片
* @return \think\response\Json
*/
public function upload()
{
$pid = input('pid')!= NULL ?input('pid'):session('pid');
$upload_type = $this->request->get('upload_type',0);
if(!$pid) {
$info =['code'=>400,'msg'=>'请选择分类,再进行上传!','src'=>''];
}else{
try{
$res = Upload::image('file','attach'.DS.date('Y').DS.date('m').DS.date('d'),true,true,null,'uniqid',$upload_type);
if(is_object($res) && $res->status === false){
$info = array(
'code' =>400,
'msg' =>'上传失败:'.$res->error,
'src' =>''
);
}else if(is_string($res)){
$info = array(
'code' =>400,
'msg' =>'上传失败:'.$res,
'src' =>''
);
}else if(is_array($res)){
SystemAttachmentModel::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],$pid,$res['image_type'],$res['time']);
$info = array(
'code' =>200,
'msg' =>'上传成功',
'src' =>$res['dir']
);
}
}catch (\Exception $e){
$info = ['code'=>400,'msg'=>$e->getMessage(),'src'=>''];
}
}
echo json_encode($info);
}
/**
* ajax 提交删除
*/
public function delete(){
$request = Request::instance();
$post = $request->post();
if(empty($post['imageid'] ))
Json::fail('还没选择要删除的图片呢?');
foreach ($post['imageid'] as $v){
self::deleteimganddata($v);
}
Json::successful('删除成功');
}
/**删除图片和数据记录
* @param $att_id
*/
public function deleteimganddata($att_id){
$attinfo = SystemAttachmentModel::get($att_id)->toArray();
if($attinfo){
if($attinfo['image_type'] == 1){
@unlink(ROOT_PATH.ltrim($attinfo['att_dir'],'.'));
@unlink(ROOT_PATH.ltrim($attinfo['satt_dir'],'.'));
}else if($attinfo['image_type'] == 2){
Qiniu::delete($attinfo['name']);
}else if($attinfo['image_type'] == 3){
OSS::delete($attinfo['name']);
}else if($attinfo['image_type'] == 4){
COS::delete($attinfo['name']);
}
SystemAttachmentModel::where(['att_id'=>$att_id])->delete();
}
}
/**
* 移动图片分类显示
*/
public function moveimg($imgaes){
$formbuider = [];
$formbuider[] = Form::hidden('imgaes',$imgaes);
$formbuider[] = Form::select('pid','选择分类')->setOptions(function (){
$list = Category::getCateList();
$options = [['value'=>0,'label'=>'所有分类']];
foreach ($list as $id=>$cateName){
$options[] = ['label'=>$cateName['html'].$cateName['name'],'value'=>$cateName['id']];
}
return $options;
})->filterable(1);
$form = Form::make_post_form('编辑分类',$formbuider,Url::build('moveImgCecate'));
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**移动图片分类操作
* @param Request $request
* @param $id
*/
public function moveImgCecate(Request $request)
{
$data = Util::postMore([
'pid',
'imgaes'
],$request);
if($data['imgaes'] == '') return Json::fail('请选择图片');
if(!$data['pid']) return Json::fail('请选择分类');
$res = SystemAttachmentModel::where('att_id','in',$data['imgaes'])->update(['pid'=>$data['pid']]);
if($res)
Json::successful('移动成功');
else
Json::fail('移动失败!');
}
/**
* ajax 添加分类
*/
public function addcate($id=0){
$formbuider = [];
$formbuider[] = Form::selectOne('pid','上级分类',$id)->setOptions(function (){
$list = Category::getCateList(0);
$options = [['value'=>0,'label'=>'所有分类']];
foreach ($list as $id=>$cateName){
$options[] = ['label'=>$cateName['html'].$cateName['name'],'value'=>$cateName['id']];
}
return $options;
})->filterable(1);
$formbuider[] = Form::input('name','分类名称');
$jsContent = <<<SCRIPT
parent.SuccessCateg();
parent.layer.close(parent.layer.getFrameIndex(window.name));
SCRIPT;
$form = Form::make_post_form('添加分类',$formbuider,Url::build('saveCate'),$jsContent);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 添加分类
*/
public function saveCate(){
$request = Request::instance();
$post = $request->post();
$data['pid'] = $post['pid'];
$data['name'] = $post['name'];
if(empty($post['name'] ))
Json::fail('分类名称不能为空!');
$res = Category::create($data);
if($res)
Json::successful('添加成功');
else
Json::fail('添加失败!');
}
/**
* 编辑分类
*/
public function editcate($id){
$Category = Category::get($id);
if(!$Category) return Json::fail('数据不存在!');
$formbuider = [];
$formbuider[] = Form::hidden('id',$id);
$formbuider[] = Form::select('pid','上级分类',(string)$Category->getData('pid'))->setOptions(function ()use($id){
$list = Category::getCateList();
$options = [['value'=>0,'label'=>'所有分类']];
foreach ($list as $id=>$cateName){
$options[] = ['label'=>$cateName['html'].$cateName['name'],'value'=>$cateName['id']];
}
return $options;
})->filterable(1);
$formbuider[] = Form::input('name','分类名称',$Category->getData('name'));
$jsContent = <<<SCRIPT
parent.SuccessCateg();
parent.layer.close(parent.layer.getFrameIndex(window.name));
SCRIPT;
$form = Form::make_post_form('编辑分类',$formbuider,Url::build('updateCate'),$jsContent);
$this->assign(compact('form'));
return $this->fetch('public/form-builder');
}
/**
* 更新分类
*
* @param \think\Request $request
* @return \think\Response
*/
public function updateCate(Request $request,$id)
{
$data = Util::postMore([
'pid',
'name'
],$request);
if($data['pid'] == '') return Json::fail('请选择父类');
if(!$data['name']) return Json::fail('请输入分类名称');
Category::edit($data,$id);
return Json::successful('分类编辑成功!');
}
/**
* 删除分类
*/
public function deletecate($id){
$chdcount = Category::where('pid',$id)->count();
if($chdcount) return Json::fail('有子栏目不能删除');
$chdcount = SystemAttachmentModel::where('pid',$id)->count();
if($chdcount) return Json::fail('栏目内有图片不能删除');
if(Category::del($id))
return Json::successful('删除成功!');
else
return Json::fail('删除失败');
}
}

View File

@ -1,49 +0,0 @@
<?php
namespace app\admin\controller\widget;
use app\admin\controller\AuthController;
/**
* 文件校验控制器
* Class SystemFile
* @package app\admin\controller\system
*
*/
class Widgets extends AuthController
{
/**
* icon
* @return \think\response\Json
*/
public function icon()
{
return $this->fetch('widget/icon');
}
/**
* 会员列页面
* @return \think\response\Json
*/
public function userlist()
{
return $this->fetch('widget/icon');
}
/**
* 产品列表页
* @return \think\response\Json
*/
public function productlist()
{
return $this->fetch('widget/icon');
}
/**
* 图文列表页
* @return \think\response\Json
*/
public function newtlist()
{
return $this->fetch('widget/icon');
}
}

View File

@ -1,153 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\article;
use app\admin\model\system\SystemAdmin;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Db;
/**
* 图文管理 Model
* Class WechatNews
* @package app\admin\model\wechat
*/
class Article extends ModelBasic {
use ModelTrait;
/**
* 获取配置分类
* @param array $where
* @return array
*/
public static function getAll($where = array()){
$model = new self;
// if($where['status'] !== '') $model = $model->where('status',$where['status']);
// if($where['access'] !== '') $model = $model->where('access',$where['access']);
if($where['title'] !== '') $model = $model->where('title','LIKE',"%$where[title]%");
if($where['cid'] !== '')
$model = $model->where('cid','in',$where['cid']);
else
if($where['merchant'])
$model = $model->where('mer_id','GT',0);
else
$model = $model->where('mer_id',0);
$model = $model->where('status',1)->where('hide',0);
return self::page($model,function($item){
if(!$item['mer_id']) $item['admin_name'] = '总后台管理员---》'.SystemAdmin::where('id',$item['admin_id'])->value('real_name');
else $item['admin_name'] = Merchant::where('id',$item['mer_id'])->value('mer_name').'---》'.MerchantAdmin::where('id',$item['admin_id'])->value('real_name');
$item['content'] = Db::name('ArticleContent')->where('nid',$item['id'])->value('content');
$item['catename'] = Db::name('ArticleCategory')->where('id',$item['cid'])->value('title');
},$where);
}
/**
* 删除图文
* @param $id
* @return bool
*/
public static function del($id){
return self::edit(['status'=>0],$id,'id');
}
/**
* 获取指定字段的值
* @return array
*/
public static function getNews()
{
return self::where('status',1)->where('hide',0)->order('id desc')->column('id,title');
}
/**
* 给表中的字符串类型追加值
* 删除所有有当前分类的id之后重新添加
* @param $cid
* @param $id
* @return bool
*/
public static function saveBatchCid($cid,$id){
$res_all = self::where('cid','LIKE',"%$cid%")->select();//获取所有有当前分类的图文
foreach ($res_all as $k=>$v){
$cid_arr = explode(',',$v['cid']);
if(in_array($cid,$cid_arr)){
$key = array_search($cid, $cid_arr);
array_splice($cid_arr, $key, 1);
}
if(empty($cid_arr)) {
$data['cid'] = 0;
self::edit($data,$v['id']);
}else{
$data['cid'] = implode(',',$cid_arr);
self::edit($data,$v['id']);
}
}
$res = self::where('id','IN',$id)->select();
foreach ($res as $k=>$v){
if(!in_array($cid,explode(',',$v['cid']))){
if(!$v['cid']){
$data['cid'] = $cid;
}else{
$data['cid'] = $v['cid'].','.$cid;
}
self::edit($data,$v['id']);
}
}
return true;
}
public static function setContent($id,$content){
$count = Db::name('ArticleContent')->where('nid',$id)->count();
$data['nid'] = $id;
$data['content'] = $content;
// dump($data);
if($count){
$res = Db::name('ArticleContent')->where('nid',$id)->setField('content',$content);
if($res !== false) $res = true;
}
else
$res = Db::name('ArticleContent')->insert($data);
// echo Db::getLastSql();
// exit();
return $res;
}
public static function merchantPage($where = array()){
$model = new self;
if($where['title'] !== '') $model = $model->where('title','LIKE',"%$where[title]%");
if($where['cid'] !== '') $model = $model->where('cid','LIKE',"%$where[cid]%");
$model = $model
->where('status',1)
->where('hide',0)
->where('admin_id',$where['admin_id'])
->where('mer_id',$where['mer_id']);
return self::page($model,function($item){
$item['content'] = Db::name('ArticleContent')->where('nid',$item['id'])->value('content');
},$where);
}
/**
* 获取指定文章列表 图文管理使用
* @param string $id
* @param string $field
* @return false|\PDOStatement|string|\think\Collection
*/
public static function getArticleList($id = '',$field = 'title,author,image_input,synopsis,id'){
$list = self::where('id','IN',$id)->field($field)->select();
foreach ($list as $k=>$v){
$list[$k]['content'] = Db::name('ArticleContent')->where('nid',$v['id'])->value('content');
}
return $list;
}
}

View File

@ -1,113 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\article;
use traits\ModelTrait;
use app\admin\model\article\Article as ArticleModel;
use basic\ModelBasic;
use service\UtilService as Util;
/**
* 文章分类model
* Class ArticleCategory
* @package app\admin\model\wechat
*/
class ArticleCategory extends ModelBasic
{
use ModelTrait;
/**
* 获取系统分页数据 分类
* @param array $where
* @return array
*/
public static function systemPage($where = array()){
$model = new self;
if($where['title'] !== '') $model = $model->where('title','LIKE',"%$where[title]%");
if($where['status'] !== '') $model = $model->where('status',$where['status']);
$model = $model->where('is_del',0);
$model = $model->where('hidden',0);
return self::page($model);
}
/**
* 删除分类
* @param $id
* @return bool
*/
public static function delArticleCategory($id)
{
if(count(self::getArticle($id,'*'))>0)
return self::setErrorInfo('请先删除改分类下的文章!');
return self::edit(['is_del'=>1],$id,'id');
}
/**
* 获取分类名称和id field
* @param $field
* @return array
*/
public static function getField($field){
return self::where('is_del','eq',0)->where('status','eq',1)->where('hidden','eq',0)->column($field);
}
/**
* 分级排序列表
* @param null $model
* @return array
*/
public static function getTierList($model = null)
{
if($model === null) $model = new self();
return Util::sortListTier($model->where('is_del',0)->where('status',1)->select()->toArray());
}
/**
* 获取分类底下的文章
* id 分类表中的分类id
* return array
* */
public static function getArticle($id,$field){
$res = ArticleModel::where('status',1)->where('hide',0)->column($field,'id');
$new_res = array();
foreach ($res as $k=>$v){
$cid_arr = explode(',',$v['cid']);
if(in_array($id,$cid_arr)){
$new_res[$k] = $res[$k];
}
}
return $new_res;
}
/**
* TODO 获取文章分类
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getArticleCategoryList(){
$list = self::where('is_del',0)->where('status',1)->select();
if($list) return $list->toArray();
return [];
}
/**
* TODO 获取文章分类信息
* @param $id
* @param string $field
* @return mixed
*/
public static function getArticleCategoryInfo($id, $field = 'id,title')
{
$model = new self;
if($id) $model = $model->where('id',$id);
$model = $model->where('is_del',0);
$model = $model->where('status',1);
return $model->column($field);
}
}

View File

@ -1,262 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/16 0016
* Time: 11:07
*/
namespace app\admin\model\finance;
use traits\ModelTrait;
use basic\ModelBasic;
use service\ExportService;
use app\core\model\user\UserBill;
use app\admin\model\user\User;
use service\PHPExcelService;
/*数据统计处理*/
class FinanceModel extends ModelBasic
{
protected $name = 'user_bill';
use ModelTrait;
/**
* 处理金额
* @param $where
* @return array
*/
public static function systemPage($where)
{
$model = new self;
//翻页
$limit = $where['limit'];
$offset= $where['offset'];
$limit = $offset.','.$limit;
//排序
$order = '';
if(!empty($where['sort'])&&!empty($where['sortOrder'])){
$order = $where['sort'].' '.$where['sortOrder'];
}
unset($where['limit']);unset($where['offset']);
unset($where['sort']);unset($where['sortOrder']);
if(!empty($where['add_time'])){
list($startTime,$endTime) = explode(' - ',$where['add_time']);
$where['add_time'] = array('between',[strtotime($startTime),strtotime($endTime)]);
}else{
$where['add_time'] = array('between',[strtotime(date('Y/m').'/01'),strtotime(date('Y/m').'/'.date('t'))]);
}
if(empty($where['title'])){
unset($where['title']);
}
$total = $model->where($where)->count();
$rows = $model->where($where)->order($order)->limit($limit)->select()->each(function($e){
return $e['add_time'] = date('Y-m-d H:i:s',$e['add_time']);
})->toArray();
return compact('total','rows');
}
public static function getBillList($where){
// \think\Db::listen(function($sql, $time, $explain){
// // 记录SQL
// echo $sql. ' ['.$time.'s]';
// // 查看性能分析结果
//// dump($explain);
// });
$data=($data=self::setWhereList($where)->page((int)$where['page'],(int)$where['limit'])->select()) && count($data) ? $data->toArray():[];
$count=self::setWhereList($where)->count();
return compact('data','count');
}
public static function SaveExport($where){
$data=($data=self::setWhereList($where)->select()) && count($data) ? $data->toArray():[];
$export = [];
foreach ($data as $value){
$export[]=[
$value['uid'],
$value['nickname'],
$value['pm']==0 ? '-'.$value['number']:$value['number'],
$value['title'],
$value['mark'],
$value['add_time'],
];
}
PHPExcelService::setExcelHeader(['会员ID','昵称','金额/积分','类型','备注','创建时间'])
->setExcelTile('资金监控', '资金监控',date('Y-m-d H:i:s',time()))
->setExcelContent($export)
->ExcelSave();
}
public static function setWhereList($where){
$time['data']='';
if($where['start_time']!='' && $where['end_time']!=''){
$time['data']=$where['start_time'].' - '.$where['end_time'];
}
$model=self::getModelTime($time,self::alias('A')
->join('user B','B.uid=A.uid')
->where('A.category','not in','integral')
->order('A.add_time desc'),'A.add_time');
if(trim($where['type'])!=''){
$model=$model->where('A.type',$where['type']);
}else{
$model=$model->where('A.type','not in','gain,system_sub,deduction,sign');
}
if($where['nickname']!=''){
$model=$model->where('B.nickname|B.uid','like',"%$where[nickname]%");
}
return $model->field(['A.*','FROM_UNIXTIME(A.add_time,"%Y-%m-%d %H:%i:%s") as add_time','B.uid','B.nickname']);
}
/**
* 获取营业数据
*/
public static function getOrderInfo($where)
{
$orderinfo = self::getTimeWhere($where)
->field('sum(total_price) total_price,sum(cost) cost,sum(pay_postage) pay_postage,sum(pay_price) pay_price,sum(coupon_price) coupon_price,sum(deduction_price) deduction_price,from_unixtime(pay_time,\'%Y-%m-%d\') pay_time')->order('pay_time')->group('from_unixtime(pay_time,\'%Y-%m-%d\')')->select()->toArray();
$price = 0;
$postage = 0;
$deduction = 0;
$coupon = 0;
$cost = 0;
foreach ($orderinfo as $info) {
$price = bcadd($price, $info['total_price'], 2);//应支付
$postage = bcadd($postage, $info['pay_postage'], 2);//邮费
$deduction = bcadd($deduction, $info['deduction_price'], 2);//抵扣
$coupon = bcadd($coupon, $info['coupon_price'], 2);//优惠券
$cost = bcadd($cost, $info['cost'], 2);//成本
}
return compact('orderinfo', 'price', 'postage', 'deduction', 'coupon', 'cost');
}
/**
* 处理where条件
*/
public static function statusByWhere($status, $model = null)
{
if ($model == null) $model = new self;
if ('' === $status)
return $model;
else if ($status == 'weixin')//微信支付
return $model->where('pay_type', 'weixin');
else if ($status == 'yue')//余额支付
return $model->where('pay_type', 'yue');
else if ($status == 'offline')//线下支付
return $model->where('pay_type', 'offline');
else
return $model;
}
public static function getTimeWhere($where, $model = null)
{
return self::getTime($where)->where('paid', 1)->where('refund_status', 0);
}
/**
* 获取时间区间
*/
public static function getTime($where,$model=null,$prefix='add_time'){
if ($model == null) $model = new self;
if ($where['data'] == '') {
switch ($where['date']){
case 'today':case 'week':case 'month':case 'year':
$model=$model->whereTime($prefix,$where['date']);
break;
case 'quarter':
list($startTime,$endTime)=User::getMonth('n');
$model = $model->where($prefix, '>', strtotime($startTime));
$model = $model->where($prefix, '<', strtotime($endTime));
break;
}
}else{
list($startTime, $endTime) = explode(' - ', $where['data']);
$model = $model->where($prefix, '>', strtotime($startTime));
$model = $model->where($prefix, '<', strtotime($endTime));
}
return $model;
}
/**
* 获取新增消费
*/
public static function getConsumption($where)
{
$consumption=self::getTime($where,new UserBill,'b.add_time')->alias('a')->join('user b','a.uid = b.uid')
->field('sum(a.number) number')
->where('a.type','pay_product')->find()->toArray();
return $consumption;
}
/**
* 获取拼团商品
*/
public static function getPink($where)
{
$pink = self::getTimeWhere($where)->where('pink_id', 'neq', 0)->sum('pay_price');
return $pink;
}
/**
* 获取秒杀商品
*/
public static function getSeckill($where){
$seckill=self::getTimeWhere($where)->where('seckill_id', 'neq', 0)->sum('pay_price');
return $seckill;
}
/**
* 获取普通商品数
*/
public static function getOrdinary($where)
{
$ordinary = self::getTimeWhere($where)->where('pink_id', 'eq', 0)->where('seckill_id','eq','0')->sum('pay_price');
return $ordinary;
}
/**
* 获取用户充值
*/
public static function getRecharge($where)
{
$Recharge = self::getTime($where,new UserBill)->where('type', 'system_add')->where('category','now_money')->sum('number');
return $Recharge;
}
/**
* 获取推广金
*/
public static function getExtension($where)
{
$extension = self::getTime($where,new UserBill)->where('type', 'brokerage')->where('category','now_money')->sum('number');
return $extension;
}
/**
* 最近交易
*/
public static function trans()
{
$trans = self::alias('a')
->join('user b', 'a.uid=b.uid')
->join('__STORE_ORDER_CART_INFO__ c', 'a.id=c.oid')
->join('__STORE_PRODUCT__ d', 'c.product_id=d.id')
->field('b.nickname,a.pay_price,d.store_name')
->order('a.add_time DESC')
->limit('6')
->select()->toArray();
return $trans;
}
/**
* 导出表格
*/
public static function systemTable($where){
$orderinfos=self::getOrderInfo($where);
if($where['export'] == 1){
$export = [];
$orderinfo=$orderinfos['orderinfo'];
foreach($orderinfo as $info){
$time=$info['pay_time'];
$price = $info['total_price']+$info['pay_postage'];
$zhichu = $info['coupon_price']+$info['deduction_price']+$info['cost'];
$profit = ($info['total_price']+$info['pay_postage'])-($info['coupon_price']+$info['deduction_price']+$info['cost']);
$deduction=$info['deduction_price'];//积分抵扣
$coupon=$info['coupon_price'];//优惠
$cost=$info['cost'];//成本
$export[] = [$time,$price,$zhichu,$cost,$coupon,$deduction,$profit];
}
// ExportService::exportCsv($export,'统计'.time(),['时间','营业额(元)','支出(元)','成本','优惠','积分抵扣','盈利(元)']);
dump($export);
PHPExcelService::setExcelHeader(['时间','营业额(元)','支出(元)','成本','优惠','积分抵扣','盈利(元)'])->setExcelTile('财务统计', '财务统计',date('Y-m-d H:i:s',time()))->setExcelContent($export)->ExcelSave();
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -1,33 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/12/26
*/
namespace app\admin\model\order;
use basic\ModelBasic;
use traits\ModelTrait;
class StoreOrderCartInfo extends ModelBasic
{
use ModelTrait;
/** 获取订单产品列表
* @param $oid
* @return array
*/
public static function getProductNameList($oid)
{
$cartInfo = self::where('oid',$oid)->select();
$goodsName = [];
foreach ($cartInfo as $cart){
$suk = isset($cart['cart_info']['productInfo']['attrInfo']) ? '('.$cart['cart_info']['productInfo']['attrInfo']['suk'].')' : '';
$goodsName[] = $cart['cart_info']['productInfo']['store_name'].$suk;
}
return $goodsName;
}
}

View File

@ -1,56 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\order;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 订单操作纪律model
* Class StoreOrderStatus
* @package app\admin\model\store
*/
class StoreOrderStatus extends ModelBasic
{
use ModelTrait;
/**
* @param $oid
* @param $type
* @param $message
*/
public static function setStatus($oid,$type,$message){
$data['oid'] = (int)$oid;
$data['change_type'] = $type;
$data['change_message'] = $message;
$data['change_time'] = time();
self::set($data);
}
/**
* @param $where
* @return array
*/
public static function systemPage($oid){
$model = new self;
$model = $model->where('oid',$oid);
$model = $model->order('change_time asc');
return self::page($model);
}
/**
* @param $where
* @return array
*/
public static function systemPageMer($oid){
$model = new self;
$model = $model->where('oid',$oid);
// $model = $model->where('change_type','LIKE','mer_%');
$model = $model->order('change_time asc');
return self::page($model);
}
}

View File

@ -1,214 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/16 0016
* Time: 11:07
*/
namespace app\admin\model\record;
use traits\ModelTrait;
use basic\ModelBasic;
use service\ExportService;
use app\core\model\user\UserBill;
use app\admin\model\user\User;
use service\PHPExcelService;
class StoreStatistics extends ModelBasic
{
protected $name = 'store_order';
use ModelTrait;
/**
* 处理金额
* @param $where
* @return array
*/
public static function getOrderPrice($where)
{
$model = new self;
$price = array();
$price['pay_price_wx'] = 0;//微信支付金额
$price['pay_price_yue'] = 0;//余额支付金额
$price['pay_price_offline'] = 0;//线下支付金额
$list = self::getTimeWhere($where, $model)->field('pay_price,total_price,deduction_price,coupon_price,total_postage,pay_type,pay_time')->select()->toArray();
if (empty($list)) {
$price['pay_price_wx'] = 0;
$price['pay_price_yue'] = 0;
$price['pay_price_offline'] = 0;
}
foreach ($list as $v) {
if ($v['pay_type'] == 'weixin') {
$price['pay_price_wx'] = bcadd($price['pay_price_wx'], $v['pay_price'], 2);
} elseif ($v['pay_type'] == 'yue') {
$price['pay_price_yue'] = bcadd($price['pay_price_yue'], $v['pay_price'], 2);
} elseif ($v['pay_type'] == 'offline') {
$price['pay_price_offline'] = bcadd($price['pay_price_offline'], $v['pay_price'], 2);
}
}
return $price;
}
/**
* 获取营业数据
*/
public static function getOrderInfo($where)
{
$orderinfo = self::getTimeWhere($where)
->field('sum(total_price) total_price,sum(cost) cost,sum(pay_postage) pay_postage,sum(pay_price) pay_price,sum(coupon_price) coupon_price,sum(deduction_price) deduction_price,from_unixtime(pay_time,\'%Y-%m-%d\') pay_time')->order('pay_time')->group('from_unixtime(pay_time,\'%Y-%m-%d\')')->select()->toArray();
$price = 0;
$postage = 0;
$deduction = 0;
$coupon = 0;
$cost = 0;
foreach ($orderinfo as $info) {
$price = bcadd($price, $info['total_price'], 2);//应支付
$postage = bcadd($postage, $info['pay_postage'], 2);//邮费
$deduction = bcadd($deduction, $info['deduction_price'], 2);//抵扣
$coupon = bcadd($coupon, $info['coupon_price'], 2);//优惠券
$cost = bcadd($cost, $info['cost'], 2);//成本
}
return compact('orderinfo', 'price', 'postage', 'deduction', 'coupon', 'cost');
}
/**
* 处理where条件
*/
public static function statusByWhere($status, $model = null)
{
if ($model == null) $model = new self;
if ('' === $status)
return $model;
else if ($status == 'weixin')//微信支付
return $model->where('pay_type', 'weixin');
else if ($status == 'yue')//余额支付
return $model->where('pay_type', 'yue');
else if ($status == 'offline')//线下支付
return $model->where('pay_type', 'offline');
else
return $model;
}
public static function getTimeWhere($where, $model = null)
{
return self::getTime($where)->where('paid', 1)->where('refund_status', 0);
}
/**
* 获取时间区间
*/
public static function getTime($where,$model=null,$prefix='add_time'){
if ($model == null) $model = new self;
if(!$where['date']) return $model;
if ($where['data'] == '') {
$limitTimeList = [
'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
'week'=>implode(' - ',[
date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
]),
'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
'quarter'=>implode(' - ',[
date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
]),
'year'=>implode(' - ',[
date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
])
];
$where['data'] = $limitTimeList[$where['date']];
}
list($startTime, $endTime) = explode(' - ', $where['data']);
$model = $model->where($prefix, '>', strtotime($startTime));
$model = $model->where($prefix, '<', strtotime($endTime));
return $model;
}
/**
* 获取新增消费
*/
public static function getConsumption($where)
{
$consumption=self::getTime($where,new UserBill,'b.add_time')->alias('a')->join('__USER__ b','a.uid = b.uid')
->field('sum(a.number) number')
->where('a.type','pay_product')->find()->toArray();
return $consumption;
}
/**
* 获取拼团商品
*/
public static function getPink($where)
{
$pink = self::getTimeWhere($where)->where('pink_id', 'neq', 0)->sum('pay_price');
return $pink;
}
/**
* 获取秒杀商品
*/
public static function getSeckill($where){
$seckill=self::getTimeWhere($where)->where('seckill_id', 'neq', 0)->sum('pay_price');
return $seckill;
}
/**
* 获取普通商品数
*/
public static function getOrdinary($where)
{
$ordinary = self::getTimeWhere($where)->where('pink_id', 'eq', 0)->where('seckill_id','eq','0')->sum('pay_price');
return $ordinary;
}
/**
* 获取用户充值
*/
public static function getRecharge($where)
{
$Recharge = self::getTime($where,new UserBill)->where('type', 'system_add')->where('category','now_money')->sum('number');
return $Recharge;
}
/**
* 获取推广金
*/
public static function getExtension($where)
{
$extension = self::getTime($where,new UserBill)->where('type', 'brokerage')->where('category','now_money')->sum('number');
return $extension;
}
/**
* 最近交易
*/
public static function trans()
{
$trans = self::alias('a')
->join('__USER__ b', 'a.uid=b.uid','left')
->join('__STORE_ORDER_CART_INFO__ c', 'a.id=c.oid')
->join('__STORE_PRODUCT__ d', 'c.product_id=d.id')
->field('b.nickname,a.pay_price,d.store_name')
->order('a.add_time DESC')
->limit('6')
->select()->toArray();
return $trans;
}
/**
* 导出表格
*/
public static function systemTable($where){
$orderinfos=self::getOrderInfo($where);
if($where['export'] == 1){
$export = [];
$orderinfo=$orderinfos['orderinfo'];
foreach($orderinfo as $info){
$time=$info['pay_time'];
$price = $info['total_price']+$info['pay_postage'];
$zhichu = $info['coupon_price']+$info['deduction_price']+$info['cost'];
$profit = ($info['total_price']+$info['pay_postage'])-($info['coupon_price']+$info['deduction_price']+$info['cost']);
$deduction=$info['deduction_price'];//积分抵扣
$coupon=$info['coupon_price'];//优惠
$cost=$info['cost'];//成本
$export[] = [$time,$price,$zhichu,$cost,$coupon,$deduction,$profit];
}
// ExportService::exportCsv($export,'统计'.time(),['时间','营业额(元)','支出(元)','成本','优惠','积分抵扣','盈利(元)']);
dump($export);
PHPExcelService::setExcelHeader(['时间','营业额(元)','支出(元)','成本','优惠','积分抵扣','盈利(元)'])->setExcelTile('财务统计', '财务统计',date('Y-m-d H:i:s',time()))->setExcelContent($export)->ExcelSave();
}
}
}

View File

@ -1,57 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
use app\admin\model\user\User;
/**
*
* Class StoreOrder
* @package app\admin\model\store
*/
class StoreVisit extends ModelBasic
{
use ModelTrait;
/**
* @param $where
* @return array
*/
public static function getVisit($date,$class=[]){
$model=new self();
switch ($date){
case null:case 'today':case 'week':case 'year':
if($date==null) $date='month';
$model=$model->whereTime('add_time',$date);
break;
case 'quarter':
list($startTime,$endTime)=User::getMonth('n');
$model = $model->where('add_time','>',$startTime);
$model = $model->where('add_time','<',$endTime);
break;
default:
list($startTime,$endTime)=explode('-',$date);
$model = $model->where('add_time','>',strtotime($startTime));
$model = $model->where('add_time','<',strtotime($endTime));
break;
}
$list=$model->group('type')->field('sum(count) as sum,product_id,cate_id,type,content')->order('sum desc')->limit(0,10)->select()->toArray();
$view=[];
foreach ($list as $key=>$val){
$now_list['name']=$val['type']=='viwe'?'浏览量':'搜索';
$now_list['value']=$val['sum'];
$now_list['class']=isset($class[$key])?$class[$key]:'';
$view[]=$now_list;
}
if(empty($list)){
$view=[['name'=>'暂无数据', 'value'=>100, 'class'=>'']];
}
return $view;
}
}

View File

@ -1,43 +0,0 @@
<?php
namespace app\admin\model\routine;
use basic\ModelBasic;
use traits\ModelTrait;
/**
* 表单ID表
* Class RoutineFormId
* @package app\admin\model\routine
*/
class RoutineFormId extends ModelBasic {
use ModelTrait;
/**
* 删除已失效的formID
* @return int
*/
public static function delStatusInvalid(){
return self::where('status',2)->where('stop_time','LT',time())->delete();
}
/**
* 获取一个可以使用的formId
* @return bool|mixed
*/
public static function getFormIdOne($uid = 0){
$formId = self::where('status',1)->where('stop_time','GT',time())->where('uid',$uid)->order('id asc')->find();
if($formId) return $formId['form_id'];
else return false;
}
/**
* 修改一个FormID为已使用
* @param string $formId
* @return $this|bool
*/
public static function delFormIdOne($formId = ''){
if($formId == '') return true;
return self::where('form_id',$formId)->update(['status'=>2]);
}
}

View File

@ -1,40 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\routine;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Cache;
/**
* 小程序模板消息Model
* Class RoutineTemplate
* @package app\admin\model\wechat
*/
class RoutineTemplate extends ModelBasic
{
use ModelTrait;
/**
* 获取系统分页数据 分类
* @param array $where
* @return array
*/
public static function systemPage($where = array()){
$model = new self;
if($where['name'] !== '') $model = $model->where('name','LIKE',"%$where[name]%");
if($where['status'] !== '') $model = $model->where('status',$where['status']);
return self::page($model);
}
/**
* 根据模版编号获取模版ID
* @param $tempkey
*/
public static function getTempid($tempkey){
return self::where('tempkey',$tempkey)->where('status',1)->cache(true,3600)->value('tempid');
}
}

View File

@ -1,81 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/4/16 0016
* Time: 11:07
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
use service\PHPExcelService;
/**
* 砍价Model
* Class StoreBargain
* @package app\admin\model\store
*/
class StoreBargain extends ModelBasic
{
use ModelTrait;
/**
* @param $where
* @return array
*/
public static function systemPage($where){
$model = new self;
if($where['status'] != '') $model = $model->where('status',$where['status']);
if($where['store_name'] != ''){
$model = $model->where('title','LIKE',"%$where[store_name]%");
$model = $model->whereOr('store_name','LIKE',"%$where[store_name]%");
}
if($where['data'] != '') $model = $model->whereTime('add_time', 'between', explode('-',$where['data']));
$model = $model->order('id desc');
$model = $model->where('is_del',0);
if($where['export'] == 1){
$list = $model->select()->toArray();
$export = [];
foreach ($list as $index=>$item){
$export[] = [
$item['title'],
$item['info'],
$item['store_name'],
'¥'.$item['price'],
'¥'.$item['cost'],
$item['num'],
'¥'.$item['bargain_max_price'],
'¥'.$item['bargain_min_price'],
$item['bargain_num'],
$item['status'] ? '开启' : '关闭',
date('Y-m-d H:i:s',$item['start_time']),
date('Y-m-d H:i:s',$item['stop_time']),
$item['sales'],
$item['stock'],
$item['give_integral'],
date('Y-m-d H:i:s',$item['add_time']),
];
$list[$index] = $item;
}
PHPExcelService::setExcelHeader(['砍价活动名称','砍价活动简介','砍价产品名称','砍价金额','成本价','每次购买的砍价产品数量','用户每次砍价的最大金额','用户每次砍价的最小金额',
'用户每次砍价的次数','砍价状态','砍价开启时间','砍价结束时间','销量','库存','返多少积分','添加时间'])
->setExcelTile('砍价产品导出','产品信息'.time(),' 生成时间:'.date('Y-m-d H:i:s',time()))
->setExcelContent($export)
->ExcelSave();
}
return self::page($model,function($item){
if($item['status']){
if($item['start_time'] > time())
$item['start_name'] = '活动未开始';
else if($item['stop_time'] < time())
$item['start_name'] = '活动已结束';
else if($item['stop_time'] > time() && $item['start_time'] < time())
$item['start_name'] = '正在进行中';
}
},$where);
}
}

View File

@ -1,94 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
use service\UtilService;
/**
* Class StoreCategory
* @package app\admin\model\store
*/
class StoreCategory extends ModelBasic
{
use ModelTrait;
/*
* 异步获取分类列表
* @param $where
* @return array
*/
public static function CategoryList($where){
$data=($data=self::systemPage($where,true)->page((int)$where['page'],(int)$where['limit'])->select()) && count($data) ? $data->toArray() :[];
foreach ($data as &$item){
if($item['pid']){
$item['pid_name'] = self::where('id',$item['pid'])->value('cate_name');
}else{
$item['pid_name'] = '顶级';
}
}
$count=self::systemPage($where,true)->count();
return compact('count','data');
}
/**
* @param $where
* @return array
*/
public static function systemPage($where,$isAjax=false){
$model = new self;
if($where['pid'] != '') $model = $model->where('pid',$where['pid']);
else if($where['pid']=='' && $where['cate_name']=='') $model = $model->where('pid',0);
if($where['is_show'] != '') $model = $model->where('is_show',$where['is_show']);
if($where['cate_name'] != '') $model = $model->where('cate_name','LIKE',"%$where[cate_name]%");
if($isAjax===true){
if(isset($where['order']) && $where['order']!=''){
$model=$model->order(self::setOrder($where['order']));
}else{
$model=$model->order('sort desc,id desc');
}
return $model;
}
return self::page($model,function ($item){
if($item['pid']){
$item['pid_name'] = self::where('id',$item['pid'])->value('cate_name');
}else{
$item['pid_name'] = '顶级';
}
},$where);
}
/**
* 获取顶级分类
* @return array
*/
public static function getCategory($field = 'id,cate_name')
{
return self::where('is_show',1)->column($field);
}
/**
* 分级排序列表
* @param null $model
* @return array
*/
public static function getTierList($model = null)
{
if($model === null) $model = new self();
return UtilService::sortListTier($model->order('sort desc,id desc')->select()->toArray());
}
public static function delCategory($id){
$count = self::where('pid',$id)->count();
if($count)
return false;
else{
return self::del($id);
}
}
}

View File

@ -1,104 +0,0 @@
<?php
namespace app\admin\model\store;
use basic\ModelBasic;
use traits\ModelTrait;
use think\Db;
class StoreCouponUser extends ModelBasic
{
use ModelTrait;
public static function tidyCouponList($couponList)
{
$time = time();
foreach ($couponList as &$coupon){
$coupon['_add_time'] = date('Y/m/d',$coupon['add_time']);
$coupon['_end_time'] = date('Y/m/d',$coupon['end_time']);
$coupon['use_min_price'] = floatval($coupon['use_min_price']);
$coupon['coupon_price'] = floatval($coupon['coupon_price']);
if($coupon['is_fail']){
$coupon['_type'] = 0;
$coupon['_msg'] = '已失效';
}else if ($coupon['status'] == 1){
$coupon['_type'] = 0;
$coupon['_msg'] = '已使用';
}else if ($coupon['status'] == 2){
$coupon['_type'] = 0;
$coupon['_msg'] = '已过期';
}else if($coupon['add_time'] > $time || $coupon['end_time'] < $time){
$coupon['_type'] = 0;
$coupon['_msg'] = '已过期';
}else{
if($coupon['add_time']+ 3600*24 > $time){
$coupon['_type'] = 2;
$coupon['_msg'] = '可使用';
}else{
$coupon['_type'] = 1;
$coupon['_msg'] = '可使用';
}
}
$coupon['integral']= Db::name('store_coupon')->where(['id'=>$coupon['cid']])->value('integral');
}
return $couponList;
}
//获取个人优惠券列表
public static function getOneCouponsList($where){
$list=self::where(['uid'=>$where['uid']])->page((int)$where['page'],(int)$where['limit'])->select();
return self::tidyCouponList($list);
}
//获取优惠劵头部信息
public static function getCouponBadgeList($where){
return [
[
'name'=>'总发放优惠券',
'field'=>'张',
'count'=>self::getModelTime($where, Db::name('store_coupon_issue'))->where('status',1)->sum('total_count'),
'background_color'=>'layui-bg-blue',
'col'=>6,
],
[
'name'=>'总使用优惠券',
'field'=>'张',
'count'=>self::getModelTime($where,new self())->where('status',1)->count(),
'background_color'=>'layui-bg-blue',
'col'=>6,
]
];
}
//获取优惠劵图表
public static function getConponCurve($where,$limit=20){
//优惠劵发放记录
$list=self::getModelTime($where, Db::name('store_coupon_issue')
->where('status',1)
->field(['FROM_UNIXTIME(add_time,"%Y-%m-%d") as _add_time','sum(total_count) as total_count'])->group('_add_time')->order('_add_time asc'))->select();
$date=[];
$seriesdata=[];
$zoom='';
foreach ($list as $item){
$date[]=$item['_add_time'];
$seriesdata[]=$item['total_count'];
}
unset($item);
if(count($date)>$limit){
$zoom=$date[$limit-5];
}
//优惠劵使用记录
$componList=self::getModelTime($where,self::where('status',1)->field(['FROM_UNIXTIME(add_time,"%Y-%m-%d") as _add_time','sum(coupon_price) as coupon_price'])
->group('_add_time')->order('_add_time asc'))->select();
count($componList) && $componList=$componList->toArray();
$compon_date=[];
$compon_data=[];
$compon_zoom='';
foreach($componList as $item){
$compon_date[]=$item['_add_time'];
$compon_data[]=$item['coupon_price'];
}
if(count($compon_date)>$limit){
$compon_zoom=$compon_date[$limit-5];
}
return compact('date','seriesdata','zoom','compon_date','compon_data','compon_zoom');
}
}

View File

@ -1,656 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use app\admin\model\ump\StoreBargain;
use app\admin\model\ump\StoreCombination;
use app\admin\model\ump\StoreSeckill;
use service\PHPExcelService;
use think\Db;
use traits\ModelTrait;
use basic\ModelBasic;
use app\admin\model\store\StoreCategory as CategoryModel;
use app\admin\model\order\StoreOrder;
use app\admin\model\system\SystemConfig;
/**
* 产品管理 model
* Class StoreProduct
* @package app\admin\model\store
*/
class StoreProduct extends ModelBasic
{
use ModelTrait;
/**删除产品
* @param $id
*/
public static function proDelete($id){
// //删除产品
// //删除属性
// //删除秒杀
// //删除拼团
// //删除砍价
// //删除拼团
// $model=new self();
// self::beginTrans();
// $res0 = $model::del($id);
// $res1 = StoreSeckillModel::where(['product_id'=>$id])->delete();
// $res2 = StoreCombinationModel::where(['product_id'=>$id])->delete();
// $res3 = StoreBargainModel::where(['product_id'=>$id])->delete();
// //。。。。
// $res = $res0 && $res1 && $res2 && $res3;
// self::checkTrans($res);
// return $res;
}
/**
* 获取连表查询条件
* @param $type
* @return array
*/
public static function setData($type){
switch ((int)$type){
case 1:
$data = ['p.is_show'=>1,'p.is_del'=>0];
break;
case 2:
$data = ['p.is_show'=>0,'p.is_del'=>0];
break;
case 3:
$data = ['p.is_del'=>0];
break;
case 4:
$data = ['p.is_show'=>1,'p.is_del'=>0,'pav.stock|p.stock'=>0];
break;
case 5:
$min = SystemConfig::getValue('store_stock');
$data = ['p.is_show'=>1,'p.is_del'=>0,'pav.stock|p.stock'=>['elt',$min]];
break;
case 6:
$data = ['p.is_del'=>1];
break;
};
return isset($data) ? $data: [];
}
/**
* 获取连表MOdel
* @param $model
* @return object
*/
public static function getModelObject($where=[]){
$model=new self();
$model=$model->alias('p')->join('StoreProductAttrValue pav','p.id=pav.product_id','LEFT');
if(!empty($where)){
$model=$model->group('p.id');
if(isset($where['type']) && $where['type']!='' && ($data=self::setData($where['type']))){
$model = $model->where($data);
}
if(isset($where['store_name']) && $where['store_name']!=''){
$model = $model->where('p.store_name|p.keyword|p.id','LIKE',"%$where[store_name]%");
}
if(isset($where['cate_id']) && trim($where['cate_id'])!=''){
$catid1 = $where['cate_id'].',';//匹配最前面的cateid
$catid2 = ','.$where['cate_id'].',';//匹配中间的cateid
$catid3 = ','.$where['cate_id'];//匹配后面的cateid
$catid4 = $where['cate_id'];//匹配全等的cateid
// $model = $model->whereOr('p.cate_id','LIKE',["%$catid%",$catidab]);
$sql = " LIKE '$catid1%' OR `cate_id` LIKE '%$catid2%' OR `cate_id` LIKE '%$catid3' OR `cate_id`=$catid4";
$model->where(self::getPidSql($where['cate_id']));
}
if(isset($where['order']) && $where['order']!=''){
$model = $model->order(self::setOrder($where['order']));
}
}
return $model;
}
/**根据cateid查询产品 拼sql语句
* @param $cateid
* @return string
*/
protected static function getCateSql($cateid){
$lcateid = $cateid.',%';//匹配最前面的cateid
$ccatid = '%,'.$cateid.',%';//匹配中间的cateid
$ratidid = '%,'.$cateid;//匹配后面的cateid
return " `cate_id` LIKE '$lcateid' OR `cate_id` LIKE '$ccatid' OR `cate_id` LIKE '$ratidid' OR `cate_id`=$cateid";
}
/** 如果有子分类查询子分类获取拼接查询sql
* @param $cateid
* @return string
*/
protected static function getPidSql($cateid){
$sql = self::getCateSql($cateid);
$ids = CategoryModel::where('pid', $cateid)->column('id');
//查询如果有子分类获取子分类查询sql语句
if($ids) foreach ($ids as $v) $sql .= " OR ".self::getcatesql($v);
return $sql;
}
/*
* 获取产品列表
* @param $where array
* @return array
*
*/
public static function ProductList($where){
$model=self::getModelObject($where)->field(['p.*','sum(pav.stock) as vstock']);
if($where['excel']==0) $model=$model->page((int)$where['page'],(int)$where['limit']);
$data=($data=$model->select()) && count($data) ? $data->toArray():[];
foreach ($data as &$item){
$cateName = CategoryModel::where('id', 'IN', $item['cate_id'])->column('cate_name', 'id');
$item['cate_name']=is_array($cateName) ? implode(',',$cateName) : '';
$item['collect'] = StoreProductRelation::where('product_id',$item['id'])->where('type','collect')->count();//收藏
$item['like'] = StoreProductRelation::where('product_id',$item['id'])->where('type','like')->count();//点赞
$item['stock'] = self::getStock($item['id'])>0?self::getStock($item['id']):$item['stock'];//库存
$item['stock_attr'] = self::getStock($item['id'])>0 ? true : false;//库存
$item['sales_attr'] = self::getSales($item['id']);//属性销量
$item['visitor'] = Db::name('store_visit')->where('product_id',$item['id'])->where('product_type','product')->count();
}
unset($item);
if($where['excel']==1){
$export = [];
foreach ($data as $index=>$item){
$export[] = [
$item['store_name'],
$item['store_info'],
$item['cate_name'],
'¥'.$item['price'],
$item['stock'],
$item['sales'],
$item['like'],
$item['collect']
];
}
PHPExcelService::setExcelHeader(['产品名称','产品简介','产品分类','价格','库存','销量','点赞人数','收藏人数'])
->setExcelTile('产品导出','产品信息'.time(),' 生成时间:'.date('Y-m-d H:i:s',time()))
->setExcelContent($export)
->ExcelSave();
}
$count=self::getModelObject($where)->count();
return compact('count','data');
}
public static function getChatrdata($type,$data){
$legdata=['销量','数量','点赞','收藏'];
$model=self::setWhereType(self::order('id desc'),$type);
$list=self::getModelTime(compact('data'),$model)
->field('FROM_UNIXTIME(add_time,"%Y-%c-%d") as un_time,count(id) as count,sum(sales) as sales')
->group('un_time')
->distinct(true)
->select()
->each(function($item) use($data){
$item['collect']=self::getModelTime(compact('data'),new StoreProductRelation)->where(['type'=>'collect'])->count();
$item['like']=self::getModelTime(compact('data'),new StoreProductRelation)->where(['type'=>'like'])->count();
})->toArray();
$chatrList=[];
$datetime=[];
$data_item=[];
$itemList=[0=>[],1=>[],2=>[],3=>[]];
foreach ($list as $item){
$itemList[0][]=$item['sales'];
$itemList[1][]=$item['count'];
$itemList[2][]=$item['like'];
$itemList[3][]=$item['collect'];
array_push($datetime,$item['un_time']);
}
foreach ($legdata as $key=>$leg){
$data_item['name']=$leg;
$data_item['type']='line';
$data_item['data']=$itemList[$key];
$chatrList[]=$data_item;
unset($data_item);
}
unset($leg);
$badge=self::getbadge(compact('data'),$type);
$count=self::setWhereType(self::getModelTime(compact('data'),new self()),$type)->count();
return compact('datetime','chatrList','legdata','badge','count');
}
//获取 badge 内容
public static function getbadge($where,$type){
$replenishment_num = SystemConfig::getValue('replenishment_num');
$replenishment_num = $replenishment_num > 0 ? $replenishment_num : 20;
$sum = [];
$lack = 0;
//获取普通产品缺货
$stock1 = self::getModelTime($where,new self())->where('stock','<',$replenishment_num)->column('stock');
$sum_stock = self::where('stock','<',$replenishment_num)->column('stock');
$stk = [];
foreach ($stock1 as $item){
$stk[] = $replenishment_num-$item;
}
$lack = bcadd($lack,array_sum($stk),0);
foreach ($sum_stock as $val){
$sum[] = $replenishment_num-$val;
}
unset($stk,$sum_stock,$stock1);
//获取砍价缺货产品
$stock1 = self::getModelTime($where,new StoreBargain())->where('stock','<',$replenishment_num)->column('stock');
$sum_stock = StoreBargain::where('stock','<',$replenishment_num)->column('stock');
$stk = [];
foreach ($stock1 as $item){
$stk[] = $replenishment_num-$item;
}
$lack = bcadd($lack,array_sum($stk),0);
foreach ($sum_stock as $val){
$sum[] = $replenishment_num-$val;
}
unset($stk,$sum_stock,$stock1);
//获取拼团缺货产品
$stock1 = self::getModelTime($where,new StoreCombination())->where('stock','<',$replenishment_num)->column('stock');
$sum_stock = StoreCombination::where('stock','<',$replenishment_num)->column('stock');
$stk = [];
foreach ($stock1 as $item){
$stk[] = $replenishment_num - $item;
}
$lack = bcadd($lack,array_sum($stk),0);
foreach ($sum_stock as $val){
$sum[] = $replenishment_num - $val;
}
unset($stk,$sum_stock,$stock1);
return [
[
'name'=>'商品种类',
'field'=>'件',
'count'=>self::setWhereType(new self(),$type)->where('add_time','<',mktime(0,0,0,date('m'),date('d'),date('Y')))->count(),
'content'=>'商品数量总数',
'background_color'=>'layui-bg-blue',
'sum'=>self::count(),
'class'=>'fa fa fa-ioxhost',
],
[
'name'=>'新增商品',
'field'=>'件',
'count'=>self::setWhereType(self::getModelTime($where,new self),$type)->where('is_new',1)->sum('stock'),
'content'=>'新增商品总数',
'background_color'=>'layui-bg-cyan',
'sum'=>self::where('is_new',1)->sum('stock'),
'class'=>'fa fa-line-chart',
],
[
'name'=>'活动商品',
'field'=>'件',
'count'=>self::getActivityProductSum($where),
'content'=>'活动商品总数',
'background_color'=>'layui-bg-green',
'sum'=>self::getActivityProductSum(),
'class'=>'fa fa-bar-chart',
],
[
'name'=>'缺货商品',
'field'=>'件',
'count'=>$lack,
'content'=>'总商品数量',
'background_color'=>'layui-bg-orange',
'sum'=>array_sum($sum),
'class'=>'fa fa-cube',
],
];
}
/*
* 获取活动产品总和
* @param array $where 查询条件
* */
public static function getActivityProductSum($where=false)
{
if($where){
$bargain=self::getModelTime($where,new StoreBargain())->sum('stock');
$pink=self::getModelTime($where,new StoreCombination())->sum('stock');
$seckill=self::getModelTime($where,new StoreSeckill())->sum('stock');
}else{
$bargain=StoreBargain::sum('stock');
$pink=StoreCombination::sum('stock');
$seckill=StoreSeckill::sum('stock');
}
return bcadd(bcadd($bargain,$pink,0),$seckill,0);
}
public static function setWhereType($model,$type){
switch ($type){
case 1:
$data = ['is_show'=>1,'is_del'=>0];
break;
case 2:
$data = ['is_show'=>0,'is_del'=>0];
break;
case 3:
$data = ['is_del'=>0];
break;
case 4:
$data = ['is_show'=>1,'is_del'=>0,'stock'=>0];
break;
case 5:
$data = ['is_show'=>1,'is_del'=>0,'stock'=>['elt',1]];
break;
case 6:
$data = ['is_del'=>1];
break;
}
if(isset($data)) $model = $model->where($data);
return $model;
}
/*
* layui-bg-red layui-bg-orange layui-bg-green 绿 layui-bg-blue layui-bg-cyan
* 销量排行 top 10
*/
public static function getMaxList($where){
$classs=['layui-bg-red','layui-bg-orange','layui-bg-green','layui-bg-blue','layui-bg-cyan'];
$model=StoreOrder::alias('a')->join('StoreOrderCartInfo c','a.id=c.oid')->join('__STORE_PRODUCT__ b','b.id=c.product_id');
$list=self::getModelTime($where,$model,'a.add_time')->group('c.product_id')->order('p_count desc')->limit(10)
->field(['count(c.product_id) as p_count','b.store_name','sum(b.price) as sum_price'])->select();
if(count($list)) $list=$list->toArray();
$maxList=[];
$sum_count=0;
$sum_price=0;
foreach ($list as $item){
$sum_count+=$item['p_count'];
$sum_price=bcadd($sum_price,$item['sum_price'],2);
}
unset($item);
foreach ($list as $key=>&$item){
$item['w']=bcdiv($item['p_count'],$sum_count,2)*100;
$item['class']=isset($classs[$key]) ?$classs[$key]:( isset($classs[$key-count($classs)]) ? $classs[$key-count($classs)]:'');
$item['store_name']=self::getSubstrUTf8($item['store_name']);
}
$maxList['sum_count']=$sum_count;
$maxList['sum_price']=$sum_price;
$maxList['list']=$list;
return $maxList;
}
//获取利润
public static function ProfityTop10($where){
$classs=['layui-bg-red','layui-bg-orange','layui-bg-green','layui-bg-blue','layui-bg-cyan'];
$model=StoreOrder::alias('a')->join('StoreOrderCartInfo c','a.id=c.oid')->join('__STORE_PRODUCT__ b','b.id=c.product_id');
$list=self::getModelTime($where,$model,'a.add_time')->group('c.product_id')->order('profity desc')->limit(10)
->field(['count(c.product_id) as p_count','b.store_name','sum(b.price) as sum_price','(b.price-b.cost) as profity'])
->select();
if(count($list)) $list=$list->toArray();
$maxList=[];
$sum_count=0;
$sum_price=0;
foreach ($list as $item){
$sum_count+=$item['p_count'];
$sum_price=bcadd($sum_price,$item['sum_price'],2);
}
foreach ($list as $key=>&$item){
$item['w']=bcdiv($item['sum_price'],$sum_price,2)*100;
$item['class']=isset($classs[$key]) ?$classs[$key]:( isset($classs[$key-count($classs)]) ? $classs[$key-count($classs)]:'');
$item['store_name']=self::getSubstrUTf8($item['store_name'],30);
}
$maxList['sum_count']=$sum_count;
$maxList['sum_price']=$sum_price;
$maxList['list']=$list;
return $maxList;
}
//获取缺货
public static function getLackList($where){
$replenishment_num = SystemConfig::getValue('replenishment_num');
$replenishment_num = $replenishment_num > 0 ? $replenishment_num : 20;
$list=self::where('stock','<',$replenishment_num)->field(['id','store_name','stock','price'])->page((int)$where['page'],(int)$where['limit'])->order('stock asc')->select();
if(count($list)) $list=$list->toArray();
$count=self::where('stock','<',$replenishment_num)->count();
return ['count'=>$count,'data'=>$list];
}
//获取差评
public static function getnegativelist($where){
$list=self::alias('s')->join('StoreProductReply r','s.id=r.product_id')
->field('s.id,s.store_name,s.price,count(r.product_id) as count')
->page((int)$where['page'],(int)$where['limit'])
->where('r.product_score',1)
->order('count desc')
->group('r.product_id')
->select();
if(count($list)) $list=$list->toArray();
$count=self::alias('s')->join('StoreProductReply r','s.id=r.product_id')->group('r.product_id')->where('r.product_score',1)->count();
return ['count'=>$count,'data'=>$list];
}
public static function TuiProductList(){
$perd=StoreOrder::alias('s')->join('StoreOrderCartInfo c','s.id=c.oid')
->field('count(c.product_id) as count,c.product_id as id')
->group('c.product_id')
->where('s.status',-1)
->order('count desc')
->limit(10)
->select();
if(count($perd)) $perd=$perd->toArray();
foreach ($perd as &$item){
$item['store_name']=self::where(['id'=>$item['id']])->value('store_name');
$item['price']=self::where(['id'=>$item['id']])->value('price');
}
return $perd;
}
//编辑库存
public static function changeStock($stock,$productId)
{
return self::edit(compact('stock'),$productId);
}
//获取库存数量
public static function getStock($productId)
{
return StoreProductAttrValue::where(['product_id'=>$productId])->sum('stock');
}
//获取总销量
public static function getSales($productId)
{
return StoreProductAttrValue::where(['product_id'=>$productId])->sum('sales');
}
public static function getTierList($model = null)
{
if($model === null) $model = new self();
return $model->field('id,store_name')->where('is_del',0)->select()->toArray();
}
/**
* 设置查询条件
* @param array $where
* @return array
*/
public static function setWhere($where){
$time['data']='';
if(isset($where['start_time']) && $where['start_time']!='' && isset($where['end_time']) && $where['end_time']!=''){
$time['data']=$where['start_time'].' - '.$where['end_time'];
}else{
$time['data']=isset($where['data'])? $where['data']:'';
}
$model=self::getModelTime($time, Db::name('store_cart')->alias('a')->join('__STORE_PRODUCT__ b','a.product_id=b.id'),'a.add_time');
if(isset($where['title']) && $where['title']!=''){
$model=$model->where('b.store_name|b.id','like',"%$where[title]%");
}
return $model;
}
/**
* 获取真实销量排行
* @param array $where
* @return array
*/
public static function getSaleslists($where){
$data=self::setWhere($where)->where('a.is_pay',1)
->group('a.product_id')
->field(['sum(a.cart_num) as num_product','b.store_name','b.image','b.price','b.id'])
->order('num_product desc')
->page((int)$where['page'],(int)$where['limit'])
->select();
$count=self::setWhere($where)->where('a.is_pay',1)->group('a.product_id')->count();
foreach ($data as &$item){
$item['sum_price']=bcmul($item['num_product'],$item['price'],2);
}
return compact('data','count');
}
public static function SaveProductExport($where){
$list=self::setWhere($where)
->where('a.is_pay',1)
->field(['sum(a.cart_num) as num_product','b.store_name','b.image','b.price','b.id'])
->order('num_product desc')
->group('a.product_id')
->select();
$export=[];
foreach ($list as $item){
$export[]=[
$item['id'],
$item['store_name'],
$item['price'],
bcmul($item['num_product'],$item['price'],2),
$item['num_product'],
];
}
PHPExcelService::setExcelHeader(['商品编号','商品名称','商品售价','销售额','销量'])
->setExcelTile('产品销量排行','产品销量排行',' 生成时间:'.date('Y-m-d H:i:s',time()))
->setExcelContent($export)
->ExcelSave();
}
/*
* 单个商品详情的头部查询
* $id 商品id
* $where 条件
*/
public static function getProductBadgeList($id,$where){
$data['data']=$where;
$list=self::setWhere($data)
->field(['sum(a.cart_num) as num_product','b.id','b.price'])
->where('a.is_pay',1)
->group('a.product_id')
->order('num_product desc')
->select();
//排名
$ranking=0;
//销量
$xiaoliang=0;
//销售额 数组
$list_price=[];
foreach ($list as $key=>$item){
if($item['id']==$id){
$ranking=$key+1;
$xiaoliang=$item['num_product'];
}
$value['sum_price']=$item['price']*$item['num_product'];
$value['id']=$item['id'];
$list_price[]=$value;
}
//排序
$list_price=self::my_sort($list_price,'sum_price',SORT_DESC);
//销售额排名
$rank_price=0;
//当前销售额
$num_price=0;
if($list_price!==false && is_array($list_price)){
foreach ($list_price as $key=>$item){
if($item['id']==$id){
$num_price=$item['sum_price'];
$rank_price=$key+1;
continue;
}
}
}
return [
[
'name'=>'销售额排名',
'field'=>'名',
'count'=>$rank_price,
'background_color'=>'layui-bg-blue',
],
[
'name'=>'销量排名',
'field'=>'名',
'count'=>$ranking,
'background_color'=>'layui-bg-blue',
],
[
'name'=>'商品销量',
'field'=>'名',
'count'=>$xiaoliang,
'background_color'=>'layui-bg-blue',
],
[
'name'=>'点赞次数',
'field'=>'个',
'count'=>Db::name('store_product_relation')->where('product_id',$id)->where('type','like')->count(),
'background_color'=>'layui-bg-blue',
],
[
'name'=>'销售总额',
'field'=>'元',
'count'=>$num_price,
'background_color'=>'layui-bg-blue',
'col'=>12,
],
];
}
/*
* 处理二维数组排序
* $arrays 需要处理的数组
* $sort_key 需要处理的key名
* $sort_order 排序方式
* $sort_type 类型 可不填写
*/
public static function my_sort($arrays,$sort_key,$sort_order=SORT_ASC,$sort_type=SORT_NUMERIC ){
if(is_array($arrays)){
foreach ($arrays as $array){
if(is_array($array)){
$key_arrays[] = $array[$sort_key];
}else{
return false;
}
}
}
if(isset($key_arrays)){
array_multisort($key_arrays,$sort_order,$sort_type,$arrays);
return $arrays;
}
return false;
}
/*
* 查询单个商品的销量曲线图
*
*/
public static function getProductCurve($where){
$list=self::setWhere($where)
->where('a.product_id',$where['id'])
->where('a.is_pay',1)
->field(['FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as _add_time','sum(a.cart_num) as num'])
->group('_add_time')
->order('_add_time asc')
->select();
$seriesdata=[];
$date=[];
$zoom='';
foreach ($list as $item){
$date[]=$item['_add_time'];
$seriesdata[]=$item['num'];
}
if(count($date)>$where['limit']) $zoom=$date[$where['limit']-5];
return compact('seriesdata','date','zoom');
}
/*
* 查询单个商品的销售列表
*
*/
public static function getSalelList($where){
return self::setWhere($where)
->where(['a.product_id'=>$where['id'],'a.is_pay'=>1])
->join('user c','c.uid=a.uid')
->field(['FROM_UNIXTIME(a.add_time,"%Y-%m-%d") as _add_time','c.nickname','b.price','a.id','a.cart_num as num'])
->page((int)$where['page'],(int)$where['limit'])
->select();
}
/**
* TODO 获取某个字段值
* @param $id
* @param string $field
* @return mixed
*/
public static function getProductField($id,$field = 'store_name'){
return self::where('id',$id)->value($field);
}
}

View File

@ -1,117 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/12/08
*/
namespace app\admin\model\store;
use basic\ModelBasic;
use traits\ModelTrait;
class StoreProductAttr extends ModelBasic
{
use ModelTrait;
protected function setAttrValuesAttr($value)
{
return is_array($value) ? implode(',',$value) : $value;
}
protected function getAttrValuesAttr($value)
{
return explode(',',$value);
}
public static function createProductAttr($attrList,$valueList,$productId)
{
$result = ['attr'=>$attrList,'value'=>$valueList];
$attrValueList = [];
$attrNameList = [];
foreach ($attrList as $index=>$attr){
if(!isset($attr['value'])) return self::setErrorInfo('请输入规则名称!');
$attr['value'] = trim($attr['value']);
if(!isset($attr['value'])) return self::setErrorInfo('请输入规则名称!!');
if(!isset($attr['detail']) || !count($attr['detail'])) return self::setErrorInfo('请输入属性名称!');
foreach ($attr['detail'] as $k=>$attrValue){
$attrValue = trim($attrValue);
if(empty($attrValue)) return self::setErrorInfo('请输入正确的属性');
$attr['detail'][$k] = $attrValue;
$attrValueList[] = $attrValue;
$attr['detail'][$k] = $attrValue;
}
$attrNameList[] = $attr['value'];
$attrList[$index] = $attr;
}
$attrCount = count($attrList);
foreach ($valueList as $index=>$value){
if(!isset($value['detail']) || count($value['detail']) != $attrCount) return self::setErrorInfo('请填写正确的商品信息');
if(!isset($value['price']) || !is_numeric($value['price']) || floatval($value['price']) != $value['price'])
return self::setErrorInfo('请填写正确的商品价格');
if(!isset($value['sales']) || !is_numeric($value['sales']) || intval($value['sales']) != $value['sales'])
return self::setErrorInfo('请填写正确的商品库存');
if(!isset($value['cost']) || !is_numeric($value['cost']) || floatval($value['cost']) != $value['cost'])
return self::setErrorInfo('请填写正确的商品成本价格');
if(!isset($value['pic']) || empty($value['pic']))
return self::setErrorInfo('请上传商品图片');
foreach ($value['detail'] as $attrName=>$attrValue){
$attrName = trim($attrName);
$attrValue = trim($attrValue);
if(!in_array($attrName,$attrNameList,true)) return self::setErrorInfo($attrName.'规则不存在');
if(!in_array($attrValue,$attrValueList,true)) return self::setErrorInfo($attrName.'属性不存在');
if(empty($attrName)) return self::setErrorInfo('请输入正确的属性');
$value['detail'][$attrName] = $attrValue;
}
$valueList[$index] = $value;
}
$attrGroup = [];
$valueGroup = [];
foreach ($attrList as $k=>$value){
$attrGroup[] = [
'product_id'=>$productId,
'attr_name'=>$value['value'],
'attr_values'=>$value['detail']
];
}
foreach ($valueList as $k=>$value){
sort($value['detail'],SORT_STRING);
$suk = implode(',',$value['detail']);
$valueGroup[$suk] = [
'product_id'=>$productId,
'suk'=>$suk,
'price'=>$value['price'],
'cost'=>$value['cost'],
'stock'=>$value['sales'],
'image'=>$value['pic']
];
}
if(!count($attrGroup) || !count($valueGroup)) return self::setErrorInfo('请设置至少一个属性!');
$attrModel = new self;
$attrValueModel = new StoreProductAttrValue;
self::beginTrans();
if(!self::clearProductAttr($productId)) return false;
$res = false !== $attrModel->saveAll($attrGroup)
&& false !== $attrValueModel->saveAll($valueGroup)
&& false !== StoreProductAttrResult::setResult($result,$productId);
self::checkTrans($res);
if($res)
return true;
else
return self::setErrorInfo('编辑商品属性失败!');
}
public static function clearProductAttr($productId)
{
if (empty($productId) && $productId != 0) return self::setErrorInfo('商品不存在!');
$res = false !== self::where('product_id',$productId)->delete()
&& false !== StoreProductAttrValue::clearProductAttrValue($productId);
if(!$res)
return self::setErrorInfo('编辑属性失败,清除旧属性失败!');
else
return true;
}
}

View File

@ -1,47 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/12/09
*/
namespace app\admin\model\store;
use basic\ModelBasic;
use traits\ModelTrait;
class StoreProductAttrResult extends ModelBasic
{
use ModelTrait;
protected $insert = ['change_time'];
protected static function setChangeTimeAttr($value)
{
return time();
}
protected static function setResultAttr($value)
{
return is_array($value) ? json_encode($value) : $value;
}
public static function setResult($result,$product_id)
{
$result = self::setResultAttr($result);
$change_time = self::setChangeTimeAttr(0);
return self::insert(compact('product_id','result','change_time'),true);
}
public static function getResult($productId)
{
return json_decode(self::where('product_id',$productId)->value('result'),true) ?: [];
}
public static function clearResult($productId)
{
return self::del($productId);
}
}

View File

@ -1,62 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/12/08
*/
namespace app\admin\model\store;
use basic\ModelBasic;
use traits\ModelTrait;
class StoreProductAttrValue extends ModelBasic
{
use ModelTrait;
protected $insert = ['unique'];
protected function setSukAttr($value)
{
return is_array($value) ? implode(',',$value) : $value;
}
protected function setUniqueAttr($value,$data)
{
if(is_array($data['suk'])) $data['suk'] = $this->setSukAttr($data['suk']);
return self::uniqueId($data['product_id'].$data['suk'].uniqid(true));
}
/*
* 减少销量增加库存
* */
public static function incProductAttrStock($productId,$unique,$num)
{
$productAttr=self::where(['product_id'=>$productId,'unique'=>$unique])->field(['stock','sales'])->find();
if(!$productAttr) return true;
if($productAttr->sales > 0) $productAttr->sales=bcsub($productAttr->sales,$num,0);
if($productAttr->sales < 0) $productAttr->sales=0;
$productAttr->stock = bcadd($productAttr->stock, $num,0);
return $productAttr->save();
}
public static function decProductAttrStock($productId,$unique,$num)
{
return false !== self::where('product_id',$productId)->where('unique',$unique)
->dec('stock',$num)->inc('sales',$num)->update();
}
public static function uniqueId($key)
{
return substr(md5($key),12,8);
}
public static function clearProductAttrValue($productId)
{
return self::where('product_id',$productId)->delete();
}
}

View File

@ -1,38 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 点赞and收藏 model
* Class StoreProductRelation
* @package app\admin\model\store
*/
class StoreProductRelation extends ModelBasic
{
use ModelTrait;
public static function getCollect($pid){
$model = new self();
$model = $model->where('r.product_id',$pid)->where('r.type','collect');
$model = $model->alias('r')->join('__WECHAT_USER__ u','u.uid=r.uid');
$model = $model->field('r.*,u.nickname');
return self::page($model);
}
public static function getLike($pid){
$model = new self();
$model = $model->where('r.product_id',$pid)->where('r.type','like');
$model = $model->alias('r')->join('__WECHAT_USER__ u','u.uid=r.uid');
$model = $model->field('r.*,u.nickname');
return self::page($model);
}
}

View File

@ -1,96 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 评论管理 model
* Class StoreProductReply
* @package app\admin\model\store
*/
class StoreProductReply extends ModelBasic
{
use ModelTrait;
protected function getPicsAttr($value)
{
return json_decode($value,true);
}
/*
* 设置where条件
* @param array $where
* @param string $alias
* @param object $model
* */
public static function valiWhere($where,$alias='',$model=null)
{
$model=is_null($model) ? new self() : $model;
if($alias){
$model=$model->alias($alias);
$alias.='.';
}
if(isset($where['title']) && $where['title']!='') $model=$model->where("{$alias}comment",'LIKE',"%$where[title]%");
if(isset($where['is_reply']) && $where['is_reply']!='') $model= $where['is_reply'] >= 0 ? $model->where("{$alias}is_reply",$where['is_reply']) : $model->where("{$alias}is_reply",'GT',0);
if(isset($where['producr_id']) && $where['producr_id']!=0) $model=$model->where('product_id',$where['producr_id']);
return $model->where("{$alias}is_del",0);
}
public static function getProductImaesList($where)
{
$list=self::valiWhere($where,'a')->group('p.id')->join('__WECHAT_USER__ u','u.uid=a.uid')->join("__STORE_PRODUCT__ p",'a.product_id=p.id')->field(['p.id','p.image','p.store_name','p.price'])->page($where['page'],$where['limit'])->select();
$list=count($list) ? $list->toArray() : [];
foreach ($list as &$item){
$item['store_name']=self::getSubstrUTf8($item['store_name'],10,'UTF-8','');
}
return $list;
}
public static function getProductReplyList($where)
{
$data=self::valiWhere($where,'a')->join("__STORE_PRODUCT__ p",'a.product_id=p.id')
->join('__WECHAT_USER__ u','u.uid=a.uid')
->order('a.add_time desc,a.is_reply asc')
->field('a.*,u.nickname,u.headimgurl as avatar')
->page((int)$where['message_page'],(int)$where['limit'])
->select();
$data=count($data) ? $data->toArray() : [];
foreach ($data as &$item){
$item['time']=\service\UtilService::timeTran($item['add_time']);
}
$count=self::valiWhere($where,'a')->join('__WECHAT_USER__ u','u.uid=a.uid')->join("__STORE_PRODUCT__ p",'a.product_id=p.id')->count();
return ['list'=>$data,'count'=>$count];
}
/**
* @param $where
* @return array
*/
public static function systemPage($where){
$model = new self;
if($where['comment'] != '') $model = $model->where('r.comment','LIKE',"%$where[comment]%");
if($where['is_reply'] != ''){
if($where['is_reply'] >= 0){
$model = $model->where('r.is_reply',$where['is_reply']);
}else{
$model = $model->where('r.is_reply','GT',0);
}
}
if($where['product_id']) $model = $model->where('r.product_id',$where['product_id']);
$model = $model->alias('r')->join('__WECHAT_USER__ u','u.uid=r.uid');
$model = $model->join('__STORE_PRODUCT__ p','p.id=r.product_id');
$model = $model->where('r.is_del',0);
$model = $model->field('r.*,u.nickname,u.headimgurl,p.store_name');
$model = $model->order('r.add_time desc,r.is_reply asc');
return self::page($model,function($itme){
},$where);
}
}

View File

@ -1,55 +0,0 @@
<?php
namespace app\admin\model\store;
use app\admin\model\store\StoreServiceLog as ServiceLogModel;
use app\admin\model\wechat\WechatUser;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 客服管理 model
* Class StoreProduct
* @package app\admin\model\store
*/
class StoreService extends ModelBasic
{
use ModelTrait;
/**
* @return array
*/
public static function getList($mer_id){
$model = new self;
$model->alias('a');
$model->join('__USER__ b ','b.uid = a.uid');
$model->field('a.*,b.nickname as wx_name');
$model->where("mer_id",$mer_id);
$model->order('a.id desc');
return self::page($model,function($item,$key){
});
}
/**
* @return array
*/
public static function getChatUser($now_service,$mer_id){
$where = 'mer_id = '.$mer_id.' AND (uid = '.$now_service["uid"].' OR to_uid='.$now_service["uid"].')';
$chat_list = ServiceLogModel::field("uid,to_uid")->where($where)->group("uid,to_uid")->select();
if(count($chat_list) > 0){
$arr_user = $arr_to_user = [];
foreach ($chat_list as $key => $value) {
array_push($arr_user,$value["uid"]);
array_push($arr_to_user,$value["to_uid"]);
}
$uids = array_merge($arr_user,$arr_to_user);
$list = WechatUser::field("uid,nickname,headimgurl")->where(array("uid"=>array(array("in",$uids),array("neq",$now_service["uid"]))))->select();
foreach ($list as $index => $user) {
$service = self::field("uid,nickname,avatar as headimgurl")->where(array("uid"=>$user["uid"]))->find();
if($service)$list[$index] = $service;
}
}else{
$list = null;
}
return $list;
}
}

View File

@ -1,32 +0,0 @@
<?php
namespace app\admin\model\store;
use app\admin\model\store\StoreService as ServiceModel;
use app\wap\model\user\User;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 客服管理 model
* Class StoreProduct
* @package app\admin\model\store
*/
class StoreServiceLog extends ModelBasic
{
use ModelTrait;
/**
* @return array
*/
public static function getChatList($uid,$to_uid,$mer_id){
$model = new self;
$where = "mer_id = ".$mer_id." AND ((uid = ".$uid." AND to_uid = ".$to_uid.") OR (uid = ".$to_uid." AND to_uid = ".$uid."))";
$model->where($where);
$model->order("add_time desc");
return self::page($model,function($item,$key) use ($mer_id){
$user = StoreService::field("nickname,avatar")->where('mer_id',$mer_id)->where(array("uid"=>$item["uid"]))->find();
if(!$user)$user = User::field("nickname,avatar")->where(array("uid"=>$item["uid"]))->find();
$item["nickname"] = $user["nickname"];
$item["avatar"] = $user["avatar"];
});
}
}

View File

@ -1,57 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\store;
use traits\ModelTrait;
use basic\ModelBasic;
use app\admin\model\user\User;
/**
* 商品浏览分析
* Class StoreOrder
* @package app\admin\model\store
*/
class StoreVisit extends ModelBasic
{
use ModelTrait;
/**
* @param $where
* @return array
*/
public static function getVisit($date,$class=[]){
$model=new self();
switch ($date){
case null:case 'today':case 'week':case 'year':
if($date==null) $date='month';
$model=$model->whereTime('add_time',$date);
break;
case 'quarter':
list($startTime,$endTime)=User::getMonth('n');
$model = $model->where('add_time','>',$startTime);
$model = $model->where('add_time','<',$endTime);
break;
default:
list($startTime,$endTime)=explode('-',$date);
$model = $model->where('add_time','>',strtotime($startTime));
$model = $model->where('add_time','<',strtotime($endTime));
break;
}
$list=$model->group('type')->field('sum(count) as sum,product_id,cate_id,type,content')->order('sum desc')->limit(0,10)->select()->toArray();
$view=[];
foreach ($list as $key=>$val){
$now_list['name']=$val['type']=='viwe'?'浏览量':'搜索';
$now_list['value']=$val['sum'];
$now_list['class']=isset($class[$key])?$class[$key]:'';
$view[]=$now_list;
}
if(empty($list)){
$view=[['name'=>'暂无数据', 'value'=>100, 'class'=>'']];
}
return $view;
}
}

View File

@ -1,27 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* Class Express
* @package app\admin\model\system
*/
class Express extends ModelBasic
{
use ModelTrait;
public static function systemPage($params)
{
$model = new self;
if($params['keyword'] !== '') $model = $model->where('name|code','LIKE',"%$params[keyword]%");
$model = $model->order('sort DESC,id DESC');
return self::page($model,$params);
}
}

View File

@ -1,158 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/11
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use behavior\admin\SystemBehavior;
use service\HookService;
use think\Session;
/**
* Class SystemAdmin
* @package app\admin\model\system
*/
class SystemAdmin extends ModelBasic
{
use ModelTrait;
protected $insert = ['add_time'];
public static function setAddTimeAttr($value)
{
return time();
}
public static function setRolesAttr($value)
{
return is_array($value) ? implode(',', $value) : $value;
}
/**
* 用户登陆
* @param string $account 账号
* @param string $pwd 密码
* @param string $verify 验证码
* @return bool 登陆成功失败
*/
public static function login($account,$pwd)
{
$adminInfo = self::get(compact('account'));
if(!$adminInfo) return self::setErrorInfo('登陆的账号不存在!');
if($adminInfo['pwd'] != md5($pwd)) return self::setErrorInfo('账号或密码错误,请重新输入');
if(!$adminInfo['status']) return self::setErrorInfo('该账号已被关闭!');
self::setLoginInfo($adminInfo);
HookService::afterListen('system_admin_login',$adminInfo,null,false,SystemBehavior::class);
return true;
}
/**
* 保存当前登陆用户信息
*/
public static function setLoginInfo($adminInfo)
{
Session::set('adminId',$adminInfo['id']);
Session::set('adminInfo',$adminInfo);
}
/**
* 清空当前登陆用户信息
*/
public static function clearLoginInfo()
{
Session::delete('adminInfo');
Session::delete('adminId');
Session::clear();
}
/**
* 检查用户登陆状态
* @return bool
*/
public static function hasActiveAdmin()
{
return Session::has('adminId') && Session::has('adminInfo');
}
/**
* 获得登陆用户信息
* @return mixed
*/
public static function activeAdminInfoOrFail()
{
$adminInfo = Session::get('adminInfo');
if(!$adminInfo) exception('请登陆');
if(!$adminInfo['status']) exception('该账号已被关闭!');
return $adminInfo;
}
/**
* 获得登陆用户Id 如果没有直接抛出错误
* @return mixed
*/
public static function activeAdminIdOrFail()
{
$adminId = Session::get('adminId');
if(!$adminId) exception('访问用户为登陆登陆!');
return $adminId;
}
/**
* @return array
*/
public static function activeAdminAuthOrFail()
{
$adminInfo = self::activeAdminInfoOrFail();
return $adminInfo->level === 0 ? SystemRole::getAllAuth() : SystemRole::rolesByAuth($adminInfo->roles);
}
/**
* 获得有效管理员信息
* @param $id
* @return static
*/
public static function getValidAdminInfoOrFail($id)
{
$adminInfo = self::get($id);
if(!$adminInfo) exception('用户不能存在!');
if(!$adminInfo['status']) exception('该账号已被关闭!');
return $adminInfo;
}
/**
* @param $field
* @return false|\PDOStatement|string|\think\Collection
*/
public static function getOrdAdmin($field = 'real_name,id',$level = 0){
return self::where('level','>=',$level)->field($field)->select();
}
public static function getTopAdmin($field = 'real_name,id')
{
return self::where('level',0)->field($field)->select();
}
/**
* @param $where
* @return array
*/
public static function systemPage($where){
$model = new self;
if($where['name'] != ''){
$model = $model->where('account|real_name','LIKE',"%$where[name]%");
}
if($where['roles'] != '')
$model = $model->where("CONCAT(',',roles,',') LIKE '%,$where[roles],%'");
$model = $model->where('level','=',$where['level'])->where('is_del',0);
return self::page($model,function($admin,$key){
$admin->roles = SystemRole::where('id','IN',$admin->roles)->column('role_name');
},$where);
}
}

View File

@ -1,100 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/13
*/
namespace app\admin\model\system;
use Api\Storage\Qiniu\Qiniu;
use app\core\util\SystemConfigService;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 文件检验model
* Class SystemFile
* @package app\admin\model\system
*/
class SystemAttachment extends ModelBasic
{
use ModelTrait;
/**
* TODO 添加附件记录
* @param $name
* @param $att_size
* @param $att_type
* @param $att_dir
* @param string $satt_dir
* @param int $pid
* @param int $imageType
* @param int $time
* @return SystemAttachment
*/
public static function attachmentAdd($name,$att_size,$att_type,$att_dir,$satt_dir='',$pid = 0,$imageType = 1 ,$time = 0 , $module_type=1)
{
$data['name'] = $name;
$data['att_dir'] = $att_dir;
$data['satt_dir'] = $satt_dir;
$data['att_size'] = $att_size;
$data['att_type'] = $att_type;
$data['image_type'] = $imageType;
$data['module_type'] = $module_type;
$data['time'] = $time ? $time : time();
$data['pid'] = $pid;
return self::create($data);
}
/**
* TODO 获取分类图
* @param $id
* @return array
*/
public static function getAll($id){
$model = new self;
$where['pid'] = $id;
$where['module_type'] = 1;
$model->where($where)->order('att_id desc');
return $model->page($model,$where,'',24);
}
public static function getImageList($where)
{
$list = self::where(['pid'=>$where['pid'],'module_type'=>1])->page((int)$where['page'],(int)$where['limit'])->order('att_id desc,time desc')->select();
$list = count($list) ? $list->toArray() : [];
$site_url = SystemConfig::getValue('site_url');
foreach ($list as &$item){
$item['satt_dir'] = (strpos($item['satt_dir'],$site_url) !== false || strstr($item['satt_dir'],'http') !== false) ? $item['satt_dir']:$site_url.$item['satt_dir'];
$item['att_dir'] = (strpos($item['att_dir'],$site_url) !== false || strstr($item['att_dir'],'http') !== false) ? $item['satt_dir']:$site_url.$item['att_dir'];
}
$count = self::where(['pid'=>$where['pid'],'module_type'=>1])->count();
return compact('list','count');
}
/**
* TODO 获取单条信息
* @param $value
* @param string $field
* @return array
* @throws \think\Exception
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getInfo($value,$field = 'att_id'){
$where[$field] = $value;
$count = self::where($where)->count();
if(!$count) return false;
return self::where($where)->find()->toArray();
}
/*
* 清除昨日海报
* */
public static function emptyYesterDayAttachment()
{
self::whereTime('time','yesterday')->where(['module_type'=>2])->delete();
}
}

View File

@ -1,80 +0,0 @@
<?php
/**
* 附件目录
*
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use service\UtilService;
/**
* 文件检验model
* Class SystemFile
* @package app\admin\model\system
*/
class SystemAttachmentCategory extends ModelBasic
{
use ModelTrait;
/**添加分类
*/
public static function Add($name,$att_size,$att_type,$att_dir,$satt_dir='',$pid = 0 )
{
$data['name'] = $name;
$data['att_dir'] = $att_dir;
$data['satt_dir'] = $satt_dir;
$data['att_size'] = $att_size;
$data['att_type'] = $att_type;
$data['time'] = time();
$data['pid'] = $pid;
return self::create($data);
}
public static function getAll($name){
$model = new self;
if($name) $model = $model->where('name','LIKE',"%$name%");
$navList = $model->select();
$navList = count($navList) ? $navList->toArray() : [];
$navPidList = [];
if($name) {
foreach ($navList as $value) {
if ($value['pid']) $navPidList [] = self::where('id', $value['pid'])->find();
}
}
return self::tidyMenuTier(array_merge($navList,$navPidList),0);
}
public static function tidyMenuTier($menusList,$pid = 0,$navList = [])
{
foreach ($menusList as $k=>$menu){
$menu = is_object($menu) ? $menu->getData() : $menu;
if($menu['pid'] == $pid){
unset($menusList[$k]);
$menu['child'] = self::tidyMenuTier($menusList,$menu['id']);
$navList[] = $menu;
}
}
return $navList;
}
/**获取分类下拉列表
* @return array
*/
public static function getCateList($id = 10000){
$model = new self();
if($id == 0)
$model->where('pid',$id);
return UtilService::sortListTier($model->select()->toArray());
}
/**
* 获取单条信息
* */
public static function getinfo($att_id){
$model = new self;
$where['att_id'] = $att_id;
return $model->where($where)->select()->toArray()[0];
}
}

View File

@ -1,51 +0,0 @@
<?php
/**
* 附件目录
*
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 文件检验model
* Class SystemFile
* @package app\admin\model\system
*/
class SystemAttachmentType extends ModelBasic
{
use ModelTrait;
/**添加附件记录
*/
public static function attachmentAdd($name,$att_size,$att_type,$att_dir,$satt_dir='',$pid = 0 )
{
$data['name'] = $name;
$data['att_dir'] = $att_dir;
$data['satt_dir'] = $satt_dir;
$data['att_size'] = $att_size;
$data['att_type'] = $att_type;
$data['time'] = time();
$data['pid'] = $pid;
return self::create($data);
}
/**
* 获取分类图
* */
public static function getAll($id){
$model = new self;
$where['pid'] = $id;
$model->where($where)->order('att_id desc');
return $model->page($model,$where,'',30);
}
/**
* 获取单条信息
* */
public static function getinfo($att_id){
$model = new self;
$where['att_id'] = $att_id;
return $model->where($where)->select()->toArray()[0];
}
}

View File

@ -1,294 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\system;
use basic\ModelBasic;
use service\FormBuilder as Form;
use traits\ModelTrait;
use \app\admin\model\system\SystemConfigTab;
class SystemConfig extends ModelBasic {
use ModelTrait;
/**
* 修改单个配置
* */
public static function setValue($menu,$value){
if(empty($menu) || !($config_one = self::get(['menu_name'=>$menu]))) return self::setErrorInfo('字段名称错误');
if($config_one['type'] == 'radio' || $config_one['type'] == 'checkbox'){
$parameter = array();
$option = array();
$parameter = explode(',',$config_one['parameter']);
foreach ($parameter as $k=>$v){
if(isset($v) && !empty($v)){
$option[$k] = explode('-',$v);
}
}
$value_arr = array();//选项的值
foreach ($option as $k=>$v){
foreach ($v as $kk=>$vv)
if(!$kk){
$value_arr[$k] = $vv;
}
}
$i = 0;//
if(is_array($value)){
foreach ($value as $value_v){
if(in_array($value_v,$value_arr)){
$i++;
}
}
if(count($value) != $i) return self::setErrorInfo('输入的值不属于选项中的参数');
}else{
if(in_array($value,$value_arr)){
$i++;
}
if(!$i) return self::setErrorInfo('输入的值不属于选项中的参数');
}
if($config_one['type'] == 'radio' && is_array($value)) return self::setErrorInfo('单选按钮的值是字符串不是数组');
}
$bool = self::edit(['value' => json_encode($value)],$menu,'menu_name');
return $bool;
}
/**
* 获取单个参数配置
* */
public static function getValue($menu){
if(empty($menu) || !($config_one = self::get(['menu_name'=>$menu]))) return false;
return json_decode($config_one['value'],true);
}
/**
* 获取单个参数配置
* @param $menu
* @return bool|mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getConfigValue($menu){
if(empty($menu) || !($config_one = self::where('menu_name', $menu)->find())) return false;
return json_decode($config_one['value'],true);
}
/**
* 获得多个参数
* @param $menus
* @return array
*/
public static function getMore($menus)
{
$menus = is_array($menus) ? implode(',',$menus) : $menus;
$list = self::where('menu_name','IN',$menus)->column('value','menu_name')?:[];
foreach ($list as $menu => $value){
$list[$menu] = json_decode($value,true);
}
return $list;
}
public static function getAllConfig()
{
$list = self::column('value','menu_name')?:[];
foreach ($list as $menu => $value){
$list[$menu] = json_decode($value,true);
}
return $list;
}
/**
* text 判断
* */
public static function valiDateTextRole($data){
if (!$data['width']) return self::setErrorInfo('请输入文本框的宽度');
if ($data['width'] <= 0) return self::setErrorInfo('请输入正确的文本框的宽度');
return true;
}
/**
* radio checkbox规则的判断
* */
public static function valiDateRadioAndCheckbox($data){
$parameter = array();
$option = array();
$option_new = array();
$data['parameter'] = str_replace("\r\n","\n",$data['parameter']);//防止不兼容
$parameter = explode("\n",$data['parameter']);
if(count($parameter) < 2)return self::setErrorInfo('请输入正确格式的配置参数');
foreach ($parameter as $k=>$v){
if(isset($v) && !empty($v)){
$option[$k] = explode('=>',$v);
}
}
if(count($option) < 2)return self::setErrorInfo('请输入正确格式的配置参数');
$bool = 1;
foreach ($option as $k=>$v){
$option_new[$k] = $option[$k][0];
foreach ($v as $kk=>$vv){
$vv_num = strlen($vv);
if(!$vv_num){
$bool = 0;
}
}
}
// dump($option);
if(!$bool)return self::setErrorInfo('请输入正确格式的配置参数');
$num1 = count($option_new);//提取该数组的数目
$arr2 = array_unique($option_new);//合并相同的元素
$num2 = count($arr2);//提取合并后数组个数
if($num1>$num2)return self::setErrorInfo('请输入正确格式的配置参数');
return true;
}
/**
* textarea 判断
* */
public static function valiDateTextareaRole($data){
if (!$data['width']) return self::setErrorInfo('请输入多行文本框的宽度');
if (!$data['high']) return self::setErrorInfo('请输入多行文本框的高度');
if ($data['width'] < 0) return self::setErrorInfo('请输入正确的多行文本框的宽度');
if ($data['high'] < 0) return self::setErrorInfo('请输入正确的多行文本框的宽度');
return true;
}
/**
* 获取一数据
* */
public static function getOneConfig($filed,$value){
$where[$filed] = $value;
return self::where($where)->find();
}
/**
* 获取配置分类
* */
public static function getAll($id){
$where['config_tab_id'] = $id;
$where['status'] = 1;
return self::where($where)->order('sort desc,id asc')->select();
}
/**
* 获取所有配置分类
* */
public static function getConfigTabAll($type=0){
$configAll = SystemConfigTab::getAll($type);
$config_tab = array();
foreach ($configAll as $k=>$v){
if(!$v['info']){
$config_tab[$k]['value'] = $v['id'];
$config_tab[$k]['label'] = $v['title'];
$config_tab[$k]['icon'] = $v['icon'];
$config_tab[$k]['type'] = $v['type'];
}
}
return $config_tab;
}
/**
* 选择类型
* */
public static function radiotype($type='text'){
return [
['value'=>'text','label'=>'文本框','disabled'=>1]
,['value'=>'textarea','label'=>'多行文本框','disabled'=>1]
,['value'=>'radio','label'=>'单选按钮','disabled'=>1]
,['value'=>'upload','label'=>'文件上传','disabled'=>1]
,['value'=>'checkbox','label'=>'多选按钮','disabled'=>1]
];
}
/**
* 文本框
* */
public static function createInputRule($tab_id){
$formbuider = array();
$formbuider[] = Form::radio('type','类型','text')->options(self::radiotype());
$formbuider[] = Form::select('config_tab_id','分类',$tab_id)->setOptions(SystemConfig::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称')->autofocus(1);
$formbuider[] = Form::input('menu_name','字段变量')->placeholder('例如site_url');
$formbuider[] = Form::input('desc','配置简介');
$formbuider[] = Form::input('value','默认值');
$formbuider[] = Form::number('width','文本框宽(%)',100);
$formbuider[] = Form::input('required','验证规则')->placeholder('多个请用,隔开例如required:true,url:true');
$formbuider[] = Form::number('sort','排序');
$formbuider[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
return $formbuider;
}
/**
* 多行文本框
* */
public static function createTextAreaRule($tab_id){
$formbuider = array();
$formbuider[] = Form::radio('type','类型','textarea')->options(self::radiotype());
$formbuider[] = Form::select('config_tab_id','分类',$tab_id)->setOptions(SystemConfig::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称')->autofocus(1);
$formbuider[] = Form::input('menu_name','字段变量')->placeholder('例如site_url');
$formbuider[] = Form::input('desc','配置简介');
$formbuider[] = Form::textarea('value','默认值');
$formbuider[] = Form::number('width','文本框宽(%)',100);
$formbuider[] = Form::number('high','多行文本框高(%)',5);
$formbuider[] = Form::number('sort','排序');
$formbuider[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
return $formbuider;
}
/**
* 单选按钮
* */
public static function createRadioRule($tab_id){
$formbuider = array();
$formbuider[] = Form::radio('type','类型','radio')->options(self::radiotype());
$formbuider[] = Form::select('config_tab_id','分类',$tab_id)->setOptions(SystemConfig::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称')->autofocus(1);
$formbuider[] = Form::input('menu_name','字段变量')->placeholder('例如site_url');
$formbuider[] = Form::input('desc','配置简介');
$formbuider[] = Form::textarea('parameter','配置参数')->placeholder("参数方式例如:\n1=>男\n2=>女\n3=>保密");
$formbuider[] = Form::input('value','默认值');
$formbuider[] = Form::number('sort','排序');
$formbuider[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
return $formbuider;
}
/**
* 文件上传
* */
public static function createUploadRule($tab_id){
$formbuider = array();
$formbuider[] = Form::radio('type','类型','upload')->options(self::radiotype());
$formbuider[] = Form::select('config_tab_id','分类',$tab_id)->setOptions(SystemConfig::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称')->autofocus(1);
$formbuider[] = Form::input('menu_name','字段变量')->placeholder('例如site_url');
$formbuider[] = Form::input('desc','配置简介');
$formbuider[] = Form::radio('upload_type','上传类型',1)->options([['value'=>1,'label'=>'单图'],['value'=>2,'label'=>'多图'],['value'=>3,'label'=>'文件']]);
$formbuider[] = Form::number('sort','排序');
$formbuider[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
return $formbuider;
}
/**
* 多选框
* */
public static function createCheckboxRule($tab_id){
$formbuider = array();
$formbuider[] = Form::radio('type','类型','checkbox')->options(self::radiotype());
$formbuider[] = Form::select('config_tab_id','分类',$tab_id)->setOptions(SystemConfig::getConfigTabAll(-1));
$formbuider[] = Form::input('info','配置名称')->autofocus(1);
$formbuider[] = Form::input('menu_name','字段变量')->placeholder('例如site_url');
$formbuider[] = Form::input('desc','配置简介');
$formbuider[] = Form::textarea('parameter','配置参数')->placeholder("参数方式例如:\n1=>白色\n2=>红色\n3=>黑色");
// $formbuider[] = Form::input('value','默认值');
$formbuider[] = Form::number('sort','排序');
$formbuider[] = Form::radio('status','状态',1)->options([['value'=>1,'label'=>'显示'],['value'=>2,'label'=>'隐藏']]);
return $formbuider;
}
/**
* 插入数据到数据库
* */
public static function set($data)
{
return self::create($data);
}
}

View File

@ -1,106 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Db;
/**
* 配置分类model
*
* Class SystemConfigTab
* @package app\admin\model\system
*/
class SystemConfigTab extends ModelBasic {
use ModelTrait;
/**
* 获取单选按钮或者多选按钮的显示值
* */
public static function getRadioOrCheckboxValueInfo($menu_name,$value){
$parameter = array();
$option = array();
$config_one = SystemConfig::getOneConfig('menu_name',$menu_name);
$parameter = explode("\n",$config_one['parameter']);
foreach ($parameter as $k=>$v){
if(isset($v) && strlen($v)>0){
$data = explode('=>',$v);
$option[$data[0]] = $data[1];
}
}
$str = '';
if(is_array($value)){
foreach ($value as $v){
$str .= $option[$v].',';
}
}else{
$str .= !empty($value)?$option[$value]:$option[0];
}
return $str;
}
/**
* 插入数据到数据库
* */
public static function set($data)
{
return self::create($data);
}
/**
* 获取全部
* */
public static function getAll($type = 0){
$where['status'] = 1;
if($type>-1)$where['type'] = $type;
return Db::name('SystemConfigTab')->where($where)->select();
}
/**
* 获取配置分类
* */
public static function getSystemConfigTabPage($where = array())
{
$model = new self;
if($where['title'] != '') $model = $model->where('title','LIKE',"%$where[title]%");
if($where['status'] != '') $model = $model->where('status',$where['status']);
return self::page($model,$where);
}
public static function edit($data,$id,$field='id')
{
return self::update($data,[$field=>$id]);
}
/**
* 更新数据
* @access public
* @param array $data 数据数组
* @param array $where 更新条件
* @param array|true $field 允许字段
* @return $this
*/
public static function update($data = [], $where = [], $field = null)
{
$model = new static();
if (!empty($field)) {
$model->allowField($field);
}
$result = $model->isUpdate(true)->save($data, $where);
return $model;
}
}

View File

@ -1,23 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/13
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 附件管理model
* Class SystemAttachment
* @package app\admin\model\system
*/
class SystemFile extends ModelBasic
{
use ModelTrait;
}

View File

@ -1,31 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/13
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 数据组model
* Class SystemGroup
* @package app\admin\model\system
*/
class SystemGroup extends ModelBasic
{
use ModelTrait;
/**
* 根据id获取当前记录中的fields值
* @param $id
* @return array
*/
public static function getField($id){
$fields = json_decode(self::where('id',$id)->value("fields"),true);
return compact('fields');
}
}

View File

@ -1,118 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/13
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
/**
* 数据列表 model
* Class SystemGroupData
* @package app\admin\model\system
*/
class SystemGroupData extends ModelBasic
{
use ModelTrait;
/**
* 根据where条件获取当前表中的前20条数据
* @param $params
* @return array
*/
public static function getList($params){
$model = new self;
if($params['gid'] !== '') $model = $model->where('gid',$params['gid']);
if($params['status'] !== '') $model = $model->where('status',$params['status']);
$model = $model->order('sort desc,id ASC');
return self::page($model,function($item,$key){
$info = json_decode($item->value,true);
foreach ($info as $index => $value) {
if($value["type"] == "checkbox")$info[$index]["value"] = implode(",",$value["value"]);
if($value["type"] == "upload" || $value["type"] == "uploads"){
$html_img = '';
if(is_array($value["value"])){
foreach ($value["value"] as $img) {
$html_img .= '<img class="image" data-image="'.$img.'" width="45" height="45" src="'.$img.'" /><br>';
}
}else{
$html_img = '<img class="image" data-image="'.$value["value"].'" width="45" height="45" src="'.$value["value"].'" />';
}
$info[$index]["value"] = $html_img;
}
}
$item->value = $info;
});
}
/**获得组合数据信息+组合数据列表
* @param $config_name
* @param int $limit
* @return array|bool|false|\PDOStatement|string|\think\Model
*/
public static function getGroupData($config_name,$limit = 0)
{
$group = SystemGroup::where('config_name',$config_name)->field('name,info,config_name')->find();
if(!$group) return false;
$group['data'] = self::getAllValue($config_name,$limit);
return $group;
}
/**
* 获取单个值
* @param $config_name
* @param int $limit
* @return mixed
*/
public static function getAllValue($config_name,$limit = 0){
$model = new self;
$model->alias('a')->field('a.*,b.config_name')->join('system_group b','a.gid = b.id')->where(array("b.config_name"=>$config_name,"a.status"=>1))->order('sort desc,id ASC');
if($limit > 0) $model->limit($limit);
$data = [];
$result = $model->select();
if(!$result) return $data;
foreach ($result as $key => $value) {
$data[$key]["id"] = $value["id"];
$fields = json_decode($value["value"],true);
foreach ($fields as $index => $field) {
// $data[$key][$index] = $field['type'] == 'upload' ? (isset($field["value"][0]) ? $field["value"][0]: ''):$field["value"];
$data[$key][$index] = $field["value"];
}
}
return $data;
}
public static function tidyList($result)
{
$data = [];
if(!$result) return $data;
foreach ($result as $key => $value) {
$data[$key]["id"] = $value["id"];
$fields = json_decode($value["value"],true);
foreach ($fields as $index => $field) {
$data[$key][$index] = $field['type'] == 'upload' ? (isset($field["value"][0]) ? $field["value"][0]: ''):$field["value"];
}
}
return $data;
}
/**
* 根据id获取当前记录中的数据
* @param $id
* @return mixed
*/
public static function getDateValue($id){
$value = self::alias('a')->where(array("id"=>$id))->find();
$data["id"] = $value["id"];
$fields = json_decode($value["value"],true);
foreach ($fields as $index => $field) {
$data[$index] = $field["value"];
}
return $data;
}
}

View File

@ -1,111 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/28
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Request;
use app\admin\model\system\SystemMenus;
use app\admin\model\system\SystemAdmin;
/**
* 管理员操作记录
* Class SystemLog
* @package app\admin\model\system
*/
class SystemLog extends ModelBasic
{
use ModelTrait;
protected $insert = ['add_time'];
protected function setAddTimeAttr()
{
return time();
}
/**
* 管理员访问记录
* @param Request $request
*/
public static function adminVisit($adminId,$adminName,$type)
{
$request = Request::instance();
$module = $request->module();
$controller = $request->controller();
$action = $request->action();
$route = $request->route();
$data = [
'method'=>$request->method(),
'admin_id'=>$adminId,
'admin_name'=>$adminName,
'path'=>SystemMenus::getAuthName($action,$controller,$module,$route),
'page'=>SystemMenus::getVisitName($action,$controller,$module,$route)?:'未知',
'ip'=>$request->ip(),
'type'=>$type
];
return self::set($data);
}
/**
* 手动添加管理员当前页面访问记录
* @param array $adminInfo
* @param string $page 页面名称
* @return object
*/
public static function setCurrentVisit($adminInfo, $page)
{
$request = Request::instance();
$module = $request->module();
$controller = $request->controller();
$action = $request->action();
$route = $request->route();
$data = [
'method'=>$request->method(),
'admin_id'=>$adminInfo['id'],
'path'=>SystemMenus::getAuthName($action,$controller,$module,$route),
'page'=>$page,
'ip'=>$request->ip()
];
return self::set($data);
}
/**
* 获取管理员访问记录
* */
public static function systemPage($where = array()){
$model = new self;
$model = $model->alias('l');
if($where['pages'] !== '') $model = $model->where('l.page','LIKE',"%$where[pages]%");
if($where['path'] !== '') $model = $model->where('l.path','LIKE',"%$where[path]%");
if($where['ip'] !== '') $model = $model->where('l.ip','LIKE',"%$where[ip]%");
if($where['admin_id'] != '')
$adminIds = $where['admin_id'];
else
$adminIds = SystemAdmin::where('level','>=',$where['level'])->column('id');
$model = $model->where('l.admin_id','IN',$adminIds);
if($where['data'] !== ''){
list($startTime,$endTime) = explode(' - ',$where['data']);
$model = $model->where('l.add_time','>',strtotime($startTime));
$model = $model->where('l.add_time','<',strtotime($endTime));
}
$model->where('l.type','system');
$model = $model->order('l.id desc');
return self::page($model,$where);
}
/**
* 删除超过90天的日志
*/
public static function deleteLog(){
$model = new self;
$model->where('add_time','<',time()-7776000);
$model->delete();
}
}

View File

@ -1,152 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Url;
/**
* 菜单 model
* Class SystemMenus
* @package app\admin\model\system
*/
class SystemMenus extends ModelBasic
{
use ModelTrait;
public static $isShowStatus = [1=>'显示',0=>'不显示'];
public static $accessStatus = [1=>'管理员可用',0=>'管理员不可用'];
public static function legalWhere($where = [])
{
$where['is_show'] = 1;
}
public function setParamsAttr($value)
{
$value = $value ? explode('/',$value) : [];
$params = array_chunk($value,2);
$data = [];
foreach ($params as $param){
if(isset($param[0]) && isset($param[1])) $data[$param[0]] = $param[1];
}
return json_encode($data);
}
protected function setControllerAttr($value)
{
return lcfirst($value);
}
public function getParamsAttr($_value)
{
return json_decode($_value,true);
}
public function getPidAttr($value)
{
return !$value ? '顶级' : self::get($value)['menu_name'];
}
public static function getParentMenu($field='*',$filter=false)
{
$where = ['pid'=>0];
$query = self::field($field);
$query = $filter ? $query->where(self::legalWhere($where)) : $query->where($where);
return $query->order('sort DESC')->select();
}
public static function menuList()
{
$menusList = self::where('is_show','1')->where('access','1')->order('sort DESC')->select();
return self::tidyMenuTier(true,$menusList);
}
public static function ruleList()
{
$ruleList = self::order('sort DESC')->select();
return self::tidyMenuTier(false,$ruleList);
}
public static function rolesByRuleList($rules)
{
$res = SystemRole::where('id','IN',$rules)->field('GROUP_CONCAT(rules) as ids')->find();
$ruleList = self::where('id','IN',$res['ids'])->whereOr('pid',0)->order('sort DESC')->select();
return self::tidyMenuTier(false,$ruleList);
}
public static function getAuthName($action,$controller,$module,$route)
{
return strtolower($module.'/'.$controller.'/'.$action.'/'.SystemMenus::paramStr($route));
}
public static function tidyMenuTier($adminFilter = false,$menusList,$pid = 0,$navList = [])
{
static $allAuth = null;
static $adminAuth = null;
if($allAuth === null) $allAuth = $adminFilter == true ? SystemRole::getAllAuth() : [];//所有的菜单
if($adminAuth === null) $adminAuth = $adminFilter == true ? SystemAdmin::activeAdminAuthOrFail() : [];//当前登录用户的菜单
foreach ($menusList as $k=>$menu){
$menu = $menu->getData();
if($menu['pid'] == $pid){
unset($menusList[$k]);
$params = json_decode($menu['params'],true);//获取参数
$authName = self::getAuthName($menu['action'],$menu['controller'],$menu['module'],$params);// 按钮链接
if($pid != 0 && $adminFilter && in_array($authName,$allAuth) && !in_array($authName,$adminAuth)) continue;
$menu['child'] = self::tidyMenuTier($adminFilter,$menusList,$menu['id']);
if($pid != 0 && !count($menu['child']) && !$menu['controller'] && !$menu['action']) continue;
$menu['url'] = !count($menu['child']) ? Url::build($menu['module'].'/'.$menu['controller'].'/'.$menu['action'],$params) : 'javascript:void(0);';
if($pid == 0 && !count($menu['child'])) continue;
$navList[] = $menu;
}
}
return $navList;
}
public static function delMenu($id)
{
if(self::where('pid',$id)->count())
return self::setErrorInfo('请先删除改菜单下的子菜单!');
return self::del($id);
}
public static function getAdminPage($params)
{
$model = new self;
if($params['is_show'] !== '') $model = $model->where('is_show',$params['is_show']);
// if($params['access'] !== '') $model = $model->where('access',$params['access']);//子管理员是否可用
if($params['pid'] !== ''&& !$params['keyword'] ) $model = $model->where('pid',$params['pid']);
if($params['keyword'] !== '') $model = $model->where('menu_name|id|pid','LIKE',"%$params[keyword]%");
$model = $model->order('sort DESC,id ASC');
return self::page($model,$params);
}
public static function paramStr($params)
{
if(!is_array($params)) $params = json_decode($params,true)?:[];
$p = [];
foreach ($params as $key => $param){
$p[] = $key;
$p[] = $param;
}
return implode('/',$p);
}
public static function getVisitName($action,$controller,$module,array $route = [])
{
$params = json_encode($route);
return self::where('action',$action)
->where('controller',lcfirst($controller))
->where('module',lcfirst($module))
->where('params',['=',$params],['=','[]'],'or')
->order('id DESC')
->value('menu_name');
}
}

View File

@ -1,121 +0,0 @@
<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2017/11/02
*/
namespace app\admin\model\system;
use traits\ModelTrait;
use basic\ModelBasic;
use think\Db;
/**
* 后台通知model
* Class SystemNotice
* @package app\admin\model\system
*/
class SystemNotice extends ModelBasic
{
use ModelTrait;
protected function setResultAttr($value)
{
return json_encode($value);
}
protected function setTableTitleAttr($value)
{
$list = [];
if(!empty($value)){
$group = explode(',',$value);
$list = array_map(function($v){
list($title,$key) = explode('-',$v);
return compact('title','key');
},$group);
}
return json_encode($list);
}
protected function getTableTitleAttr($value)
{
return json_decode($value,true);
}
protected function getResultAttr($value)
{
return json_decode($value,true);
}
protected function setPushAdminAttr($value)
{
$value = is_array($value) ? array_unique(array_filter($value)) : [];
return implode(',',$value);
}
protected function getPushAdminAttr($value)
{
return array_filter(explode(',',$value));
}
public static function typeByAdminList($type,$field = 'id')
{
return self::where('type',$type)->field($field)->find();
}
public static function systemNoticeAdminDb()
{
return Db::name('SystemNoticeAdmin');
}
public static function adminMessage($notice_type,$admin_id,$link_id,array $table_data = [])
{
$table_data = json_encode($table_data);
$add_time = time();
return self::systemNoticeAdminDb()->insert(compact('notice_type','admin_id','link_id','table_data','add_time'));
}
public static function noticeMessage($noticeType,$linkId,array $tableData = [])
{
$noticeInfo = self::get(['type'=>$noticeType]);
if(!$noticeInfo) return self::setErrorInfo('通知模板消息不存在!');
$adminIds = array_merge(array_map(function($v){
return $v['id'];
},SystemAdmin::getTopAdmin('id')->toArray())?:[],self::typeByAdminList($noticeType,'push_admin')->push_admin?:[]);
$adminIds = array_unique(array_filter($adminIds));
if(!count($adminIds)) return self::setErrorInfo('没有有效的通知用户!');
foreach ($adminIds as $id){
self::adminMessage($noticeType,$id,$linkId,$tableData);
}
return true;
}
public static function getAdminNoticeTotal($adminId)
{
$list = self::alias('A')->join('__SYSTEM_NOTICE_ADMIN__ B','B.notice_type = A.type')
->where('A.status',1)->where('B.is_visit',0)->where('B.is_click',0)->where('B.admin_id',$adminId)
->field('count(B.id) total')->group('A.id')->select()->toArray();
if(!$list) return 0;
return array_reduce($list,function($initial,$res){
return $initial+$res['total'];
},0);
}
public static function getAdminNotice($adminId)
{
$list = self::alias('A')->join('__SYSTEM_NOTICE_ADMIN__ B','B.notice_type = A.type')
->where('A.status',1)->where('B.is_visit',0)->where('B.is_click',0)->where('B.admin_id',$adminId)
->field('A.id,A.type,A.title,A.icon,count(B.id) total,A.template,max(B.add_time) as last_time')
->group('A.id')->having('total > 0')->select()->toArray();
$noticeTypeList = [];
array_walk($list,function(&$notice) use(&$noticeTypeList){
$notice['message'] = sprintf($notice['template'],$notice['total']);
$noticeTypeList[] = $notice['type'];
});
if(count($noticeTypeList))
self::systemNoticeAdminDb()->where('notice_type','IN',$noticeTypeList)->where('admin_id',$adminId)
->update(['is_visit'=>1,'visit_time'=>time()]);
return $list;
}
}

Some files were not shown because too many files have changed in this diff Show More