| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254 |
- <?php
- // +----------------------------------------------------------------------
- // | Laravel框架 [ Laravel ]
- // +----------------------------------------------------------------------
- // | 版权所有 2017~2021 Laravel研发中心
- // +----------------------------------------------------------------------
- // | 官方网站: http://www.laravel.cn
- // +----------------------------------------------------------------------
- // | Author: wesmiler <12345678@qq.com>
- // +----------------------------------------------------------------------
- namespace App\Services;
- use App\Models\EnshrineOrdersModel;
- /**
- * 供奉订单管理-服务类
- * @author wesmiler
- * @since 2020/11/11
- * Class EnshrineOrdersService
- * @package App\Services
- */
- class EnshrineOrdersService extends BaseService
- {
- protected static $instance = null;
- /**
- * 构造函数
- * @author wesmiler
- * @since 2020/11/11
- * EnshrineOrdersService constructor.
- */
- public function __construct()
- {
- $this->model = new EnshrineOrdersModel();
- }
- /**
- * 静态入口
- * @return EnshrineOrdersService|null
- */
- public static function make(){
- if(!self::$instance){
- self::$instance = new EnshrineOrdersService();
- }
- return self::$instance;
- }
- /**
- * 获取列表
- * @return array
- * @since 2020/11/11
- * @author wesmiler
- */
- public function getList()
- {
- $params = request()->all();
- $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
- $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
- $dataList = $this->model::from('enshrine_orders as o')
- ->leftJoin('enshrine_records as r', 'r.id', '=', 'o.source_id')
- ->leftJoin('offerings as g', 'g.id', '=', 'o.goods_id')
- ->leftJoin('member as m', 'm.id', '=', 'o.user_id')
- ->where(function ($query) use ($params) {
- $query->where('o.mark',1);
- $status = isset($params['status']) ? $params['status'] : 0;
- if ($status > 0) {
- $query->where('o.status', $status);
- } else {
- $query->where('o.status', '>', 0);
- }
- $type = isset($params['type']) ? $params['type'] : 0;
- if ($type > 0) {
- $query->where('o.type', $type);
- }
- })
- ->where(function ($query) use ($params) {
- $keyword = isset($params['keyword']) ? trim($params['keyword']) : '';
- if (!empty($keyword)) {
- $query->where('o.order_sn', 'like', "%{$keyword}%")
- ->orWhere('m.nickname', 'like', "%{$keyword}%");
- }
- })
- ->select(['o.*','g.icon as thumb','m.nickname','m.mobile'])
- ->orderBy('o.create_time', 'desc')
- ->paginate($pageSize);
- $dataList = $dataList ? $dataList->toArray() : [];
- if ($dataList) {
- foreach ($dataList['data'] as &$item) {
- $item['thumb'] = $item['thumb'] ? get_image_url($item['thumb']) : '';
- $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : '';
- }
- unset($item);
- }
- return [
- 'code' => 0,
- 'success'=> true,
- 'msg' => '操作成功',
- 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
- 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
- ];
- }
- /**
- * 统计表数据
- * @param $dateType
- * @return array
- */
- public function tableData($dateType){
- $cacheKey = "caches:statistics:table_enshrine_{$dateType}";
- $datas = RedisService::get($cacheKey);
- if($datas){
- return $datas;
- }
- $firstTime = strtotime(date('Y-m-d'));
- if($dateType == 0){
- $formatStr = "%Y-%m-%d %H:00";
- $firstTime = strtotime(date('Y-m-d'));
- for($i = 0; $i<=3; $i++){
- $i = $i<10? '0'.$i : $i;
- $ks = date('Y-m-d')." {$i}:00";
- $datas[$ks] = [
- 'date'=> $i.'点',
- 'ks'=> $ks,
- 'value'=> 0,
- ];
- }
- }else if($dateType == 1){
- $formatStr = "%Y-%m-%d";
- $firstTime = strtotime('monday this week');
- $weeks = ['周一','周二','周三','周四','周五','周六','周日'];
- for($i = 0; $i<7; $i++){
- $ks = date('Y-m-d', $firstTime+$i*86400);
- $datas[$ks] = [
- 'date'=> $weeks[$i],
- 'ks'=> $ks,
- 'value'=> 0,
- ];
- }
- }else if($dateType == 2){
- $formatStr = "%Y-%m-%d";
- $firstTime = strtotime(date('Y-m-01'));
- $num = cal_days_in_month(CAL_GREGORIAN, date('m'), date('Y'));
- for($i = 1; $i<=$num; $i++){
- $i = $i<10? '0'.$i : $i;
- $ks = date('Y-m')."-{$i}";
- $datas[$ks] = [
- 'date'=> $i.'号',
- 'ks'=> $ks,
- 'value'=> 0,
- ];
- }
- }else if($dateType == 3){
- $formatStr = "%Y-%m";
- $firstTime = strtotime(date('Y-01-01'));
- for($i = 1; $i<=12; $i++){
- $ks = date('Y')."-".($i<10? '0'.$i : $i);
- $datas[$ks] = [
- 'date'=> $i.'月',
- 'ks'=> $ks,
- 'value'=> 0,
- ];
- }
- }
- $counts = $this->model::from('enshrine_orders as a')
- ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
- ->where(['a.mark'=> 1,'m.mark'=> 1,'a.status'=>2])
- ->where('a.create_time','>=', $firstTime)
- ->where('a.create_time','<=', time())
- ->select([\DB::raw('sum('.env('DB_PREFIX').'a.`total`) as value'),\DB::raw('FROM_UNIXTIME('.env('DB_PREFIX')."a.create_time,'{$formatStr}') as ks")])
- ->groupBy(\DB::raw('FROM_UNIXTIME('.env('DB_PREFIX')."a.create_time,'{$formatStr}')"))
- ->get();
- $counts = $counts? $counts->toArray() : [];
- if($counts){
- foreach ($counts as $v){
- if(isset($datas[$v['ks']])){
- $datas[$v['ks']]['value'] = $v['value'];
- }
- }
- }
- $datas = array_values($datas);
- RedisService::set($cacheKey, $datas, rand(5, 10));
- return $datas;
- }
- /**
- * 添加或编辑
- * @return array
- * @since 2020/11/11
- * @author wesmiler
- */
- public function edit()
- {
- $data = request()->all();
- $data['update_time'] = time();
- return parent::edit($data); // TODO: Change the autogenerated stub
- }
- /**
- * 发货
- * @return array
- * @since 2020/11/11
- * @author wesmiler
- */
- public function send()
- {
- $data = request()->all();
- $id = isset($data['id'])? $data['id'] : 0;
- if(!$id){
- return message('缺少订单参数',false);
- }
- // 检验订单状态
- $orderInfo = $this->model->where(['id'=> $id])->first();
- if(!$orderInfo){
- return message('订单不存在',false);
- }
- $status = isset($orderInfo['status'])? $orderInfo['status'] : 0;
- if($status != 2){
- return message('订单状态不可操作',false);
- }
- //
- $expressNo = isset($data['express_no'])? $data['express_no'] : '';
- $expressCode = isset($data['express_code'])? $data['express_code'] : '';
- if(empty($expressNo)){
- return message('发货单号不为空',false);
- }
- if(empty($expressCode)){
- return message('请选择快递公司',false);
- }
- $orderInfo->express_no = $expressNo;
- $orderInfo->express_code = $expressCode;
- $data['update_time'] = time();
- return parent::edit($data); // TODO: Change the autogenerated stub
- }
- }
|