1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096 |
- <?php
- namespace app\admin\controller;
- use app\admin\library\Auth;
- use app\admin\model\Admin;
- use app\admin\model\MobileOrderAdmin;
- use app\admin\model\MobileOrderRefundLog;
- use app\admin\model\MobileOrderSubAnchor;
- use app\admin\model\ShortcutContent;
- use app\common\controller\Backend;
- use app\common\model\Area;
- use app\common\model\LogisticsCompany;
- use app\common\model\MobileOrder;
- use app\common\model\MobileOrderOperation;
- use app\common\model\Produce;
- use app\common\service\MobileOrderExport;
- use app\common\service\ProduceOrderService;
- use app\common\service\TransferCheck;
- use app\common\service\ZopOrderService;
- use app\common\validate\RefundValidate;
- use app\service\byte_dance\ByteDanceSettle;
- use Exception;
- use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
- use PhpOffice\PhpSpreadsheet\Reader\Csv;
- use PhpOffice\PhpSpreadsheet\Reader\Xls;
- use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
- use think\Db;
- use think\db\Query;
- use think\exception\PDOException;
- use think\exception\ValidateException;
- use think\Loader;
- /**
- *
- *
- * @icon fa fa-circle-o
- */
- class Produceorder extends Backend
- {
- protected $noNeedRight=['status','pay_type'];
- /**
- * MobileOrder模型对象
- * @var \app\admin\model\MobileOrder
- */
- protected $model = null;
- protected $proxy = 0;
- public function _initialize()
- {
- parent::_initialize();
- $this->model = new \app\admin\model\MobileOrder;
- $this->assign('status',\app\common\model\MobileOrder::$status);
- $this->assign('logistics_list',json_encode(LogisticsCompany::all()));
- if(in_array(2, $this->auth->getGroupIds())){
- $this->proxy = 1;
- $this->assign('status',\app\common\model\MobileOrder::$GongYSStatus);
- }
- $platformSourceList = [
- '1' => '自动生产',
- '0' => '手动生产',
- ];
- $this->assign('platformSourceList', $platformSourceList);
- }
- public function import_old()
- {
- $file = $this->request->request('file');
- if (!$file) {
- $this->error(__('Parameter %s can not be empty', 'file'));
- }
- $file=parse_url($file,PHP_URL_PATH);
- $filePath = ROOT_PATH . DS . 'public' . DS . $file;
- if (!is_file($filePath)) {
- $this->error(__('No results were found'));
- }
- //实例化reader
- $ext = pathinfo($filePath, PATHINFO_EXTENSION);
- if (!in_array($ext, ['csv', 'xls', 'xlsx'])) {
- $this->error(__('Unknown data format'));
- }
- if ($ext === 'csv') {
- $file = fopen($filePath, 'r');
- $filePath = tempnam(sys_get_temp_dir(), 'import_csv');
- $fp = fopen($filePath, "w");
- $n = 0;
- while ($line = fgets($file)) {
- $line = rtrim($line, "\n\r\0");
- $encoding = mb_detect_encoding($line, ['utf-8', 'gbk', 'latin1', 'big5']);
- if ($encoding != 'utf-8') {
- $line = mb_convert_encoding($line, 'utf-8', $encoding);
- }
- if ($n == 0 || preg_match('/^".*"$/', $line)) {
- fwrite($fp, $line . "\n");
- } else {
- fwrite($fp, '"' . str_replace(['"', ','], ['""', '","'], $line) . "\"\n");
- }
- $n++;
- }
- fclose($file) || fclose($fp);
- $reader = new Csv();
- } elseif ($ext === 'xls') {
- $reader = new Xls();
- } else {
- $reader = new Xlsx();
- }
- //导入文件首行类型,默认是注释,如果需要使用字段名称请使用name
- $importHeadType = isset($this->importHeadType) ? $this->importHeadType : 'comment';
- $table = $this->model->getQuery()->getTable();
- $database = \think\Config::get('database.database');
- $fieldArr = [];
- $list = db()->query("SELECT COLUMN_NAME,COLUMN_COMMENT FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = ? AND TABLE_SCHEMA = ?", [$table, $database]);
- foreach ($list as $k => $v) {
- if ($importHeadType == 'comment') {
- $fieldArr[$v['COLUMN_COMMENT']] = $v['COLUMN_NAME'];
- } else {
- $fieldArr[$v['COLUMN_NAME']] = $v['COLUMN_NAME'];
- }
- }
- //加载文件
- $insert = [];
- try {
- if (!$PHPExcel = $reader->load($filePath)) {
- $this->error(__('Unknown data format'));
- }
- $currentSheet = $PHPExcel->getSheet(0); //读取文件中的第一个工作表
- $allColumn = $currentSheet->getHighestDataColumn(); //取得最大的列号
- $allRow = $currentSheet->getHighestRow(); //取得一共有多少行
- $maxColumnNumber = Coordinate::columnIndexFromString($allColumn);
- $fields = [];
- for ($currentRow = 1; $currentRow <= 1; $currentRow++) {
- for ($currentColumn = 1; $currentColumn <= $maxColumnNumber; $currentColumn++) {
- $val = $currentSheet->getCellByColumnAndRow($currentColumn, $currentRow)->getValue();
- $fields[] = $val;
- }
- }
- for ($currentRow = 2; $currentRow <= $allRow; $currentRow++) {
- $values = [];
- for ($currentColumn = 1; $currentColumn <= $maxColumnNumber; $currentColumn++) {
- $val = $currentSheet->getCellByColumnAndRow($currentColumn, $currentRow)->getValue();
- $values[] = is_null($val) ? '' : $val;
- }
- $row = [];
- $temp = array_combine($fields, $values);
- foreach ($temp as $k => $v) {
- if (isset($fieldArr[$k]) && $k !== '') {
- $row[$fieldArr[$k]] = $v;
- }
- }
- if ($row) {
- $insert[] = $row;
- }
- }
- } catch (Exception $exception) {
- $this->error($exception->getMessage());
- }
- if (!$insert) {
- $this->error(__('No rows were updated'));
- }
- try {
- //是否包含admin_id字段
- $has_admin_id = false;
- foreach ($fieldArr as $name => $key) {
- if ($key == 'admin_id') {
- $has_admin_id = true;
- break;
- }
- }
- if ($has_admin_id) {
- $auth = Auth::instance();
- foreach ($insert as &$val) {
- if (!isset($val['admin_id']) || empty($val['admin_id'])) {
- $val['admin_id'] = $auth->isLogin() ? $auth->id : 0;
- }
- $val['is_auto'] = 0;
- }
- }
- (new MobileOrder)->insertAll($insert);
- } catch (PDOException $exception) {
- $msg = $exception->getMessage();
- if (preg_match("/.+Integrity constraint violation: 1062 Duplicate entry '(.+)' for key '(.+)'/is", $msg, $matches)) {
- $msg = "导入失败,包含【{$matches[1]}】的记录已存在";
- };
- $this->error($msg);
- } catch (Exception $e) {
- $this->error($e->getMessage());
- }
- $this->success();
- }
- /**
- * 导入
- *
- * @return void
- */
- public function import()
- {
- ProduceOrderService::saveFile(input('file'),$this->auth->id);
-
- $this->success('上传成功,请等待导入');
- }
- /**
- * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
- * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
- * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
- */
- /**
- * 查看
- */
- public function index()
- {
- //当前是否为关联查询
- $this->relationSearch = true;
- //设置过滤方法
- $this->request->filter(['strip_tags', 'trim']);
- $map=[];
- if($this->admin('is_sub')){
- $map['s_id']=$this->admin('id');
- }
- //if(!$this->admin('is_manager')){
- // $map['s_id']=$this->admin('id');
- //}
- $export=input('export');
- if($export){
- list($where, $sort, $order, $offset, $limit) = $this->buildparams();
- $list = $this->model
- ->where($where)
- ->where($map)
- ->where('type',1)
- // ->where(['platform_source'=>'敢探号','api_goods_id'=>123564678989,'or'])
- // ->whereOr('platform_source','敢探号')
- // ->whereOr('api_goods_id','123564678989')
- ->where('is_need_push', 1)
- ->where(function($q) {
- //供应商
- if($this->proxy){
- return $q->where('mobile_order.admin_id', $this->auth->id);
- }
- })
- ->with(['produce'])
- ->order($sort, $order)
- ->paginate($limit);
- return MobileOrderExport::export($list,$this->admin());
- }
- if ($this->request->isAjax()) {
- //如果发送的来源是Selectpage,则转发到Selectpage
- if ($this->request->request('keyField')) {
- return $this->selectpage();
- }
- // status需要组装的搜索条件
- $filter = json_decode($this->request->get('filter'),true);
- $op = json_decode($this->request->get('op'),true);
- list($where, $sort, $order, $offset, $limit) = $this->buildparams();
- if($this->admin('is_manager')){
- // 注销关联 ,'refund_log.refunduser'
- $relation=['operation','operation.admin','admin','admin.admin','refund_log',
- 'sub_remark','sub_remark.admin','anchor','sub_anchor','sub_anchor.mobileAnchor','proxy','payment'];
- }else{
- // 注销关联 ,'refund_log.refunduser'
- $relation=['admin','admin.admin','refund_log','sub_remark'=>function(Query $query){
- $query->where('sub_admin_id',$this->auth->id);
- },'sub_remark.admin','anchor','sub_anchor','sub_anchor.mobileAnchor','proxy','payment'];
- }
- $list = $this->model
- ->where($where)
- ->where($map)
- ->where('type',1)
- // ->where(['platform_source'=>'敢探号','api_goods_id'=>123564678989,'or'])
- ->where(function($q) {
- //供应商
- if($this->proxy){
- return $q->where('mobile_order.admin_id', $this->auth->id);
- }
- })
- // ->where(function ($q){
- // $q->whereOr('platform_source','敢探号')->whereOr('api_goods_id','123564678989');
- // })
- ->where('is_need_push', 1)
- // ->whereOr('platform_source','敢探号')
- ->order($sort, $order)
- ->with(['produce'])
- ->paginate($limit);
- // print_r($list->getLastSql());
- $upStatus=[];
- if($list->items()) {
- $upStatus = \app\admin\model\Mobile::whereIn('id', array_column($list->items(), 'mobile_id'))->where('status', '<>',0)->column('id');
- }
- foreach ($list as $row) {
- $row['pay_link']=h5_link("oder-detail/{$row['id']}");
- $row->append(['phone_order_count']);
- $row['mobile_can_up']=!in_array($row['mobile_id'],$upStatus);
- if($row['s_id']) {
- $row['s_name'] = Admin::where('id', $row['s_id'])->value('nickname');
- }else{
- $row['s_name']='';
- }
- $row['create_time'] = date('Y-m-d H:i:s', $row['create_time']);
- $row['update_time'] = date('Y-m-d H:i:s', $row['update_time']);
- $row['produce_status_name'] = $row['produce_status'] == 1 ? '已开户' : '未开户';
- $row['produce_activation_name'] = $row['produce_activation'] == 1 ? '已激活' : '未激活';
- $row['produce_is_recharge_name'] = $row['produce_is_recharge'] == 1 ? '已首充' : '未首充';
- $row['is_arrearage_name'] = $row['is_arrearage'] == 1 ? '已欠费' : '未欠费';
- $row['logistics_numbers'] = $row['logistics_numbers'] ?: '';
- $row['first_amount'] = $row['first_amount'] ?: '';
- }
- $extend=[];
- $amountMap=[];
- $amountMap['type']=1;
- if(!$this->admin('is_manager')){
- $amountMap['s_id']=$this->admin('id');
- }
- /*$amountBase=$this->model->filterSaled()->where($where)->where($amountMap)->sum('amount_base');
- $amountDi=$this->model->filterSaled()->where($where)->where($amountMap)->sum('amount_di');
- $extend['total']=bcsub($amountBase,$amountDi);*/
- $extend['total']=$this->model->filterSaled()->where($where)->where($amountMap)->sum('amount_base');
- $extend['alipay']=$this->model->filterSaled()->where($where)->where($amountMap)->where('pay_type',2)->sum('amount');
- $extend['wechat']=$this->model->filterSaled()->where($where)->where($amountMap)->where('pay_type',1)->sum('amount');
- $extend['jd']=$this->model->filterSaled()->where($where)->where($amountMap)->where('pay_type',3)->sum('amount');
- $extend['dy']=$this->model->filterSaled()->where($where)->where($amountMap)->where('pay_type',4)->sum('amount');
- $extend['ks']=$this->model->filterSaled()->where($where)->where($amountMap)->where('pay_type',5)->sum('amount');
- $extend['di']=$this->model->filterSaled()->where($where)->where($amountMap)->sum('amount_di');
- $extend['profit']=$this->model->filterSaled()->where($where)->where($amountMap)->sum('amount_profit');
- $extend['refund']=$this->model->where($where)->where($amountMap)->sum('amount_refund');
- // select count(id) as total,status from mobile_order where type=1 GROUP BY status; 角标查询
- if (isset($filter['status'])){
- unset($filter['status']);
- unset($op['status']);
- }
- $this->request->get(['filter'=>json_encode($filter)]);
- $this->request->get(['op'=>json_encode($op)]);
- list($where, $sort, $order, $offset, $limit) = $this->buildparams();
- // if($this->admin('is_manager')){
- // $relation=['mobile','anchor'];
- // }else{
- // $relation=['mobile'];
- // }
- $status_list = $this->model
- //->with($relation)
- ->field('count(mobile_order.id) as total,mobile_order.status')
- ->where($where)
- ->where($map)
- ->where('mobile_order.type',1)
- ->where(function($q) {
- //供应商
- if($this->proxy){
- return $q->where('mobile_order.admin_id', $this->auth->id)->whereIn('status',[15,17,20,25,60]);
- }
- })
- ->group('mobile_order.status')
- ->select();
- $status_10_count=0;
- if (!$this->proxy) {
- // 状态10的数据统计
- $status_10_count = $this->model
- // ->with($relation)
- ->where($where)
- ->whereNotIn('status', [0, 50, 90])
- ->where($map)
- ->where('mobile_order.type', 1)
- ->with(['produce'])
- ->where(function ($q) {
- //供应商
- if ($this->proxy) {
- return $q->where('mobile_order.admin_id', $this->auth->id);
- }
- })->count();
- }
- $result = array("total" => $list->total(), "rows" => $list->items(),'extend'=>$extend,'status_list'=>$status_list,'status_10_count'=>$status_10_count);
- $result['link']=$this->request->url().'&export=1';
- return json($result);
- }
- // print_r(123);
- // exit();
- $this->assign('admins',Admin::getAdmins());
- $this->assign('subs',Admin::getSubs());
- $this->assign('is_proxy',$this->proxy);
- $this->assignconfig('is_proxy',$this->proxy);
- return $this->view->fetch();
- }
- protected function buildparams($searchfields = null, $relationSearch = null)
- {
- $searchfields = is_null($searchfields) ? $this->searchFields : $searchfields;
- $relationSearch = is_null($relationSearch) ? $this->relationSearch : $relationSearch;
- $search = $this->request->get("search", '');
- $filter = $this->request->get("filter", '');
- $op = $this->request->get("op", '', 'trim');
- $sort = $this->request->get("sort", !empty($this->model) && $this->model->getPk() ? $this->model->getPk() : 'id');
- $order = $this->request->get("order", "DESC");
- $offset = $this->request->get("offset/d", 0);
- $limit = $this->request->get("limit/d", 999999);
- //新增自动计算页码
- $page = $limit ? intval($offset / $limit) + 1 : 1;
- if ($this->request->has("page")) {
- $page = $this->request->get("page/d", 1);
- }
- $this->request->get([config('paginate.var_page') => $page]);
- $filter = (array)json_decode($filter, true);
- $op = (array)json_decode($op, true);
- $filter = $filter ? $filter : [];
- $where = [];
- $alias = [];
- $bind = [];
- $name = '';
- $aliasName = '';
- if (!empty($this->model) && $this->relationSearch) {
- $name = $this->model->getTable();
- $alias[$name] = Loader::parseName(basename(str_replace('\\', '/', get_class($this->model))));
- $aliasName = $alias[$name] . '.';
- }
- $sortArr = explode(',', $sort);
- foreach ($sortArr as $index => & $item) {
- $item = stripos($item, ".") === false ? $aliasName . trim($item) : $item;
- }
- unset($item);
- $sort = implode(',', $sortArr);
- $adminIds = $this->getDataLimitAdminIds();
- if (is_array($adminIds)) {
- $where[] = [$aliasName . $this->dataLimitField, 'in', $adminIds];
- }
- if ($search) {
- $searcharr = is_array($searchfields) ? $searchfields : explode(',', $searchfields);
- foreach ($searcharr as $k => &$v) {
- $v = stripos($v, ".") === false ? $aliasName . $v : $v;
- }
- unset($v);
- $where[] = [implode("|", $searcharr), "LIKE", "%{$search}%"];
- }
- $index = 0;
- foreach ($filter as $k => $v) {
- if (!preg_match('/^[a-zA-Z0-9_\-\.]+$/', $k)) {
- continue;
- }
- $sym = isset($op[$k]) ? $op[$k] : '=';
- if (stripos($k, ".") === false) {
- $k = $aliasName . $k;
- }
- $v = !is_array($v) ? trim($v) : $v;
- $sym = strtoupper(isset($op[$k]) ? $op[$k] : $sym);
- //null和空字符串特殊处理
- if (!is_array($v)) {
- if (in_array(strtoupper($v), ['NULL', 'NOT NULL'])) {
- $sym = strtoupper($v);
- }
- if (in_array($v, ['""', "''"])) {
- $v = '';
- $sym = '=';
- }
- }
- switch ($sym) {
- case '=':
- case '<>':
- $where[] = [$k, $sym, (string)$v];
- break;
- case 'LIKE':
- case 'NOT LIKE':
- case 'LIKE %...%':
- case 'NOT LIKE %...%':
- $where[] = [$k, trim(str_replace('%...%', '', $sym)), "%{$v}%"];
- break;
- case '>':
- case '>=':
- case '<':
- case '<=':
- $where[] = [$k, $sym, intval($v)];
- break;
- case 'FINDIN':
- case 'FINDINSET':
- case 'FIND_IN_SET':
- $v = is_array($v) ? $v : explode(',', str_replace(' ', ',', $v));
- $findArr = array_values($v);
- foreach ($findArr as $idx => $item) {
- $bindName = "item_" . $index . "_" . $idx;
- $bind[$bindName] = $item;
- $where[] = "FIND_IN_SET(:{$bindName}, `" . str_replace('.', '`.`', $k) . "`)";
- }
- break;
- case 'IN':
- case 'IN(...)':
- case 'NOT IN':
- case 'NOT IN(...)':
- $where[] = [$k, str_replace('(...)', '', $sym), is_array($v) ? $v : explode(',', $v)];
- break;
- case 'BETWEEN':
- case 'NOT BETWEEN':
- $arr = array_slice(explode(',', $v), 0, 2);
- if (stripos($v, ',') === false || !array_filter($arr)) {
- continue 2;
- }
- //当出现一边为空时改变操作符
- if ($arr[0] === '') {
- $sym = $sym == 'BETWEEN' ? '<=' : '>';
- $arr = $arr[1];
- } elseif ($arr[1] === '') {
- $sym = $sym == 'BETWEEN' ? '>=' : '<';
- $arr = $arr[0];
- }
- $where[] = [$k, $sym, $arr];
- break;
- case 'RANGE':
- case 'NOT RANGE':
- $v = str_replace(' - ', ',', $v);
- $arr = array_slice(explode(',', $v), 0, 2);
- if (stripos($v, ',') === false || !array_filter($arr)) {
- continue 2;
- }
- //当出现一边为空时改变操作符
- if ($arr[0] === '') {
- $sym = $sym == 'RANGE' ? '<=' : '>';
- $arr = $arr[1];
- } elseif ($arr[1] === '') {
- $sym = $sym == 'RANGE' ? '>=' : '<';
- $arr = $arr[0];
- }
- $tableArr = explode('.', $k);
- if (count($tableArr) > 1 && $tableArr[0] != $name && !in_array($tableArr[0], $alias) && !empty($this->model)) {
- //修复关联模型下时间无法搜索的BUG
- $relation = Loader::parseName($tableArr[0], 1, false);
- $alias[$this->model->$relation()->getTable()] = $tableArr[0];
- }
- $where[] = [$k, str_replace('RANGE', 'BETWEEN', $sym) . ' TIME', $arr];
- break;
- case 'NULL':
- case 'IS NULL':
- case 'NOT NULL':
- case 'IS NOT NULL':
- $where[] = [$k, strtolower(str_replace('IS ', '', $sym))];
- break;
- default:
- break;
- }
- $index++;
- }
- if (!empty($this->model)) {
- $this->model->alias($alias);
- }
- $model = $this->model;
- $where = function (Query $query) use ($where, $alias, $bind, &$model) {
- if (!empty($model)) {
- $model->alias($alias);
- $model->bind($bind);
- }
- foreach ($where as $k => $v) {
- if (is_array($v)) {
- if($v[0]=='rules.rule'){
- $query->whereExists("select * from mobile_order_rules where mobile_order_rules.mobile_order_id=mobile_order.id and rule='{$v[2]}'");
- continue;
- }elseif ($v[0]=='admin.admin_id'){
- $query->whereExists("select * from mobile_order_admin where mobile_order_admin.mobile_order_id=mobile_order.id and admin_id={$v[2]}");
- continue;
- }elseif ($v[0]=='mobile_order.sub_mobile_anchor_id'){
- $query->whereExists("select * from mobile_order_sub_anchor where mobile_order_sub_anchor.mobile_order_id=mobile_order.id and sub_mobile_anchor_id={$v[2]}");
- continue;
- }elseif ($v[0]=='status'){
- $v[0]='mobile_order.status';
- }elseif ($v[0]=='create_time'){
- $v[0]='mobile_order.create_time';
- }elseif ($v[0]=='update_time'){
- $v[0]='mobile_order.update_time';
- }elseif ($v[0]=='mobile_order.status' && $v[2]==10){
- $query->whereNotIn('status',[0,50,90]);
- continue;
- }
- call_user_func_array([$query, 'where'], $v);
- } else {
- $query->where($v);
- }
- }
- };
- return [$where, $sort, $order, $offset, $limit, $page, $alias, $bind];
- }
- /**
- * 添加
- */
- public function add()
- {
- if ($this->request->isPost()) {
- $params = $this->request->post("row/a");
- if ($params) {
- $params = $this->preExcludeFields($params);
- if ($this->dataLimit && $this->dataLimitFieldAutoFill) {
- $params[$this->dataLimitField] = $this->auth->id;
- }
- $result = false;
- Db::startTrans();
- try {
- //是否采用模型验证
- if ($this->modelValidate) {
- $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
- $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate;
- $this->model->validateFailException(true)->validate($validate);
- }
- // $params['city'] = implode('/', Area::getTreeId($params['city']));
- if (!empty($params['city'])) {
- $params['city'] = implode(',',Area::getTreeId(explode('/',$params['city'])[2]));
- }
- $params['status'] = 10;
- $params['pay_time'] = strtotime($params['pay_time']);
- $params['create_time'] = time();
- $params['update_time'] = time();
- $params['order_no'] = order_no();
- $params['is_need_push'] = 1;
- $params['is_push_zop'] = 0;
- $params['is_auto'] = 0;
- $result = MobileOrder::insertGetId($params);
- // exit();
- // $result = $this->model->allowField(true)->save($params);
- Db::commit();
- } catch (ValidateException $e) {
- Db::rollback();
- $this->error($e->getMessage());
- } catch (PDOException $e) {
- Db::rollback();
- $this->error($e->getMessage());
- } catch (Exception $e) {
- Db::rollback();
- throw $e;
- //$this->error($e->getMessage());
- }
- if ($result !== false) {
- // 推送订单
- ZopOrderService::push($result);
-
- $this->success();
- } else {
- $this->error(__('No rows were inserted'));
- }
- }
- $this->error(__('Parameter %s can not be empty', ''));
- }
- $produces = Produce::all();
- $this->assign('produces', $produces);
- return $this->view->fetch();
- }
- /**
- * 详情
- *
- * @param [type] $ids
- * @return void
- */
- public function detail($ids = null)
- {
- $model = $this->model->with('produce')->where('id', $ids)->find();
- $row = $model->toArray();
- $row['produce_activation_name'] = $row['produce_activation'] == 1 ? '已激活' : '未激活';
- $row['produce_is_recharge_name'] = $row['produce_is_recharge'] == 1 ? '已首充' : '未首充';
- $row['create_time'] = date('Y-m-d H:i:s', $row['create_time']);
- $row['update_time'] = date('Y-m-d H:i:s', $row['update_time']);
- $this->assign('row', $row);
- $this->assign('produce', $model->produce ?? []);
- return $this->view->fetch();
- }
- public function edit($ids = null)
- {
- $model=$this->model->find($ids);
- $originStatus=$model['status'];
- $row=$model->toArray();
- if($this->request->isGet()){
- $row['address']=$model->originData()['address'];
- $row['city']=\app\common\model\Area::getNameString($row['city'],'/');
- $this->assign('row',$row);
- return view();
- }else{
- $field=[
- 'name',
- 'phone',
- 'id_no',
- 'address',
- 'trans_no',
- 'trans_id',
- 'status',
- 'city',
- 'address_name',
- ];
- $data=input('row/a');
- Db::startTrans();
- if(isset($data['city'])){
- $data['city']=\app\common\model\Area::whereIn('name|shortname',str_replace('/',',',$data['city']))->column('id');
- }
- $this->validate($data,[
- 'status'=>'in:'.implode(',',array_keys(\app\common\model\MobileOrder::$status))
- ]);
- foreach ($data as $key=>$value){
- if(in_array($key,$field)) {
- $model[$key] = $value;
- }
- }
- MobileOrderAdmin::add($model,$originStatus!=$model['status'],$this->auth->id);
- $model->save();
- // 只有未推送过, 并且产品信息已绑定的订单才推送
- if ($model->is_push_zop == 0) {
- ZopOrderService::push($ids);
- }
- Db::commit();
- $this->success('');
- }
- }
- public function refund($ids){
- $model=$this->model->find($ids);
- $this->assign('row',$model);
- if($this->request->isGet()){
- return view();
- }else{
- $data=input('row/a');
- $this->validate($data,RefundValidate::class);
- Db::startTrans();
- $model=$this->model->where('id',$ids)->lock(true)->findOrFail();
- $model->makeRefund('admin',$this->admin(),$data);
- Db::commit();
- $this->success();
- }
- }
- public function status(){
- return \app\common\model\MobileOrder::$status;
- }
- public function pay_type(){
- return \app\common\model\MobileOrder::$payTypes;
- }
- public function add_operation(){
- $id=input('ids/d');
- if($this->request->isGet()){
- $this->assign('shortcut',ShortcutContent::getList());
- return view();
- }else{
- $content=input('row.content');
- $this->validate(compact('content'),[
- 'content'=>'max:250',
- ]);
- MobileOrderOperation::create([
- 'mobile_order_id'=>$id,
- 'admin_id'=>$this->auth->id,
- 'content'=>$content,
- ]);
- $this->success();
- }
- }
- public function send(){
- $id=input('ids/d');
- if($this->request->isGet()){
- $row=$this->model->find($id);
- $this->assign('row',$row);
- return view();
- }else{
- $data=input('row/a');
- Db::startTrans();
- $row=$this->model->lock(true)->findOrFail($id);
- $row->dealSend($data['trans_no'],$data['trans_id']);
- Db::commit();
- $this->success();
- }
- }
- #展示开卡资料
- public function show_open_data($id){
- $row=$this->model->find($id);
- return view('',compact('row'));
- }
- public function see_logistics($ids){
- $order=$this->model->find($ids);
- $data=TransferCheck::instance()->setNo($order['trans_no'])->setName($order['name'])->setPhone($order['phone'])->setLogisticsCompany(LogisticsCompany::get($order['trans_id']))->get();
- $this->assign('data',$data);
- return view('mobile_order/see_logistics');
- }
- /**
- * 添加备注等信息
- *
- * @param [type] $id
- * @return void
- */
- public function sub_remark($id)
- {
- $order=$this->model->find($id);
- if($this->request->isGet()){
- // 获取旗子数据
- $flags = [
- '#FF0000' => "<span style='color: #FF0000;font-size: 24px; '>🏳</span>",
- '#FFFF00' => "<span style='color: #FFFF00;font-size: 24px; '>🏳</span>",
- '#00FF33' => "<span style='color: #00FF33;font-size: 24px; '>🏳</span>",
- '#0033FF' => "<span style='color: #0033FF;font-size: 24px; '>🏳</span>",
- '#9900FF' => "<span style='color: #9900FF;font-size: 24px; '>🏳</span>",
- '#00CCFF' => "<span style='color: #00CCFF;font-size: 24px; '>🏳</span>",
- ];
- $this->assign('flags', $flags);
- $this->assign('row', $order);
- return view();
- }else{
- $data=input('row/a');
- $order->produce_id = $data['produce_id'] ?? 0;
- $order->produce_type = $data['produce_type'] ?? '';
- $order->remark = $data['remark'] ?? '';
- $order->flag = $data['flag'] ?? '';
- $order->save();
-
- $this->success();
- }
- }
- public function set_anchor($ids){
- $order=$this->model->find($ids);
- if(!$order){
- $this->error('订单不存在');
- }
- if($this->request->isGet()){
- if($this->admin('is_manager')){
- $anchor_id=$order['mobile_anchor_id'];
- $this->assign('mobile_anchor_id',$anchor_id);
- }
- $sub_anchor_id=$order->subAnchor()->value('sub_mobile_anchor_id');
- $this->assign('sub_mobile_anchor_id',$sub_anchor_id);
- $this->assign('order',$order);
- return view('sub_anchor');
- }else{
- $data=input('row/a');
- if(!empty($data['mobile_anchor_id']) && !\app\admin\model\MobileAnchor::find($data['mobile_anchor_id'])){
- $this->error('主播不存在');
- }
- if(!empty($data['sub_mobile_anchor_id']) && !\app\admin\model\MobileAnchor::find($data['sub_mobile_anchor_id'])){
- $this->error('主播不存在');
- }
- if($this->admin('is_manager')){
- if(!empty($data['mobile_anchor_id'])){
- $order['mobile_anchor_id']=$data['mobile_anchor_id'];
- if(!$order->save()){
- $this->error('保存失败');
- }
- }
- if(!empty($data['sub_mobile_anchor_id'])){
- MobileOrderSubAnchor::sync($order,$data['sub_mobile_anchor_id']);
- }
- }elseif ($this->admin('is_sub') && $this->admin('id')==$order['s_id']){
- if(!empty($data['sub_mobile_anchor_id'])){
- if($order->subAnchor()->find()){
- $this->error('无法再次设置');
- }
- MobileOrderSubAnchor::sync($order,$data['sub_mobile_anchor_id']);
- }
- }
- $this->success();
- }
- }
- public function mobile_up($ids){
- $order=$this->model->find($ids);
- $mobile=$order->mobile()->find();
- if($this->request->isGet()) {
- $this->assign('row', $mobile);
- $this->assign('disabled', 1);
- $this->assign('otherSubDisabled', 1);
- return view();
- }else{
- if($mobile){
- $mobile->again_sell();
- }
- $this->success();
- }
- }
- public function refund_log(){
- if($this->request->isAjax()){
- list($where, $sort, $order, $offset, $limit) = $this->buildparams();
- $this->relationSearch=true;
- /*$limit=input('limit',10);
- $offset=input('offset',0);*/
- $filter=json_decode(input('filter'),true)?:[];
- $map=[];
- if(!empty($filter['od.mobile_id'])){
- $map['mobile_order.mobile_id']=['eq',$filter['od.mobile_id']];
- }
- if(!empty($filter['od.s_id'])){
- $map['mobile_order.s_id']=['eq',$filter['od.s_id']];
- }
- if(isset($filter['pass'])){
- $map['pass']=['eq',$filter['pass']];
- }
- if(!empty($filter['od.no'])){
- $map['mobile_order.no']=['like',"%{$filter['od.no']}%"];
- }
- if(!empty($filter['od.order_no'])){
- $map['mobile_order.order_no']=['like',"%{$filter['od.order_no']}%"];
- }
- if(!empty($filter['reason'])){
- $map['reason']=['like',"%{$filter['reason']}%"];
- }
- if(!empty($filter['admin.nickname'])){
- $map['admin.nickname']=['like',"%{$filter['admin.nickname']}%"];
- }
- if(!empty($filter['od.amount'])){
- $amountArr=explode(',',$filter['od.amount']);
- if(empty($amountArr[0])){
- $amountArr[0]=0;
- }
- if(empty($amountArr[1])){
- $amountArr[1]=10000000000000;
- }
- $map['mobile_order.amount']=['between',$amountArr];
- }
- if(!empty($filter['amount_backend'])){
- $amountArr=explode(',',$filter['amount_backend']);
- if(empty($amountArr[0])){
- $amountArr[0]=0;
- }
- if(empty($amountArr[1])){
- $amountArr[1]=10000000000000;
- }
- $map['amount_backend']=['between',$amountArr];
- }
- $log=(new MobileOrderRefundLog)->getTable();
- if(!empty($filter['create_time'])){
- list($s,$e)=explode(' - ',$filter['create_time']);
- $map["{$log}.create_time"]=['between',[strtotime($s),strtotime($e)]];
- }
- //$page=$offset/$limit+1;
- $data=MobileOrderRefundLog::where($map)
- ->where(function (Query $query){
- if(!$this->admin('is_manager')){
- $query->where('mobile_order.s_id',$this->admin('id'));
- }
- })
- ->with(['od','admin'])
- ->order('id','desc')
- ->paginate($limit,false);
- /* foreach ($data as $model){
- $model->setAttr('s_name',Admin::where('id',$model['od']['s_id'])->value('nickname'));
- }*/
- return json([
- 'total'=>$data->total(),
- 'rows'=>$data->items(),
- 'filter'=>$filter,
- ]);
- }
- return $this->fetch();
- }
- #dy结算
- public function dy_settle(){
- $id=input('ids');
- if(empty($id)){
- $this->error('id必须');
- }
- Db::startTrans();
- $order=$this->model->lock(true)->find($id);
- if(!$order){
- $this->error('订单不存在');
- }
- $order->dySettle();
- Db::commit();
- $this->success();
- }
- public function aaa(){
- $admin = admin::where('proxy',0)
- ->where('sub',1)
- ->field(['id','nickname'])
- ->select();
- return "$admin";
- }
- /**
- * 重新提交
- *
- * @return void
- */
- public function resubmit()
- {
- $id=input('ids');
- if(empty($id)){
- $this->error('id必须');
- }
-
- $result = ZopOrderService::push($id);
- if ($result['code'] != 0) {
- $this->error($result['message']);
- }
- $this->success();
- }
- /**
- * 取消订单
- *
- * @return void
- */
- public function cancel()
- {
- $id=input('ids');
- if(empty($id)){
- $this->error('id必须');
- }
-
- $order = MobileOrder::where('id', $id)->find();
- $order->is_cancel = 1;
- $order->canceled_by = $this->auth->id;
- $order->canceled_at = date('Y-m-d H:i:s');
- $order->save();
- $this->success();
- }
- /**
- * 批量编辑
- *
- * @param [type] $ids
- * @return void
- */
- public function multi_edit($ids)
- {
- if($this->request->isGet()) {
- // 获取旗子数据
- $flags = [
- '#FF0000' => "<span style='color: #FF0000;font-size: 24px; '>🏳</span>",
- '#FFFF00' => "<span style='color: #FFFF00;font-size: 24px; '>🏳</span>",
- '#00FF33' => "<span style='color: #00FF33;font-size: 24px; '>🏳</span>",
- '#0033FF' => "<span style='color: #0033FF;font-size: 24px; '>🏳</span>",
- '#9900FF' => "<span style='color: #9900FF;font-size: 24px; '>🏳</span>",
- '#00CCFF' => "<span style='color: #00CCFF;font-size: 24px; '>🏳</span>",
- ];
- $this->assign('flags', $flags);
- return view();
- }else{
- $tempData=input('row/a');
- $data=[];
- $infoData=[];
- if(!empty($tempData['flag'])){
- $data['flag']=$tempData['flag'];
- }
- if(!empty($tempData['produce_id'])){
- $data['produce_id']=$tempData['produce_id'];
- }
- if(!empty($tempData['produce_type'])){
- $data['produce_type']=$tempData['produce_type'];
- }
- if(!empty($tempData['remark'])){
- $data['remark']=$tempData['remark'];
- }
- if($data) {
- $orders = $this->model->whereIn('id', $ids)->select();
- foreach ($orders as $order) {
- foreach ($data as $key => $value) {
- $order->$key = $value;
- $order->save();
- }
- // 只有未推送过, 并且产品信息已绑定的订单才推送
- if ($order->is_push_zop == 0) {
- ZopOrderService::push($ids);
- }
- }
- }
- $this->success();
- }
- }
- }
|