mirror of
https://gitee.com/ShopeX/OMS
synced 2026-04-07 07:15:33 +08:00
84 lines
2.6 KiB
PHP
84 lines
2.6 KiB
PHP
<?php
|
|
/**
|
|
* Copyright 2012-2026 ShopeX (https://www.shopex.cn)
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
class o2o_mdl_store_refuse_analysis extends dbeav_model
|
|
{
|
|
|
|
/**
|
|
* 获取_reason_analysis
|
|
* @param mixed $filter filter
|
|
* @return mixed 返回结果
|
|
*/
|
|
public function get_reason_analysis($filter = null)
|
|
{
|
|
$sql = 'SELECT count(sra.reason_id) as num , rr.reason_name as name FROM sdb_o2o_store_refuse_analysis as sra right join sdb_o2o_refuse_reason as rr on sra.reason_id = rr.reason_id and ' . $this->_get_filter($filter) . ' GROUP BY rr.reason_id,rr.reason_name ORDER BY rr.reason_name';
|
|
|
|
$row = $this->db->select($sql);
|
|
return $row;
|
|
}
|
|
|
|
/**
|
|
* _get_filter
|
|
* @param mixed $filter filter
|
|
* @param mixed $tableAlias tableAlias
|
|
* @param mixed $baseWhere baseWhere
|
|
* @return mixed 返回值
|
|
*/
|
|
public function _get_filter($filter, $tableAlias = null, $baseWhere = null)
|
|
{
|
|
$where = array(1);
|
|
if (isset($filter['time_from']) && $filter['time_from']) {
|
|
$where[] = ' sra.createtime >=' . strtotime($filter['time_from']);
|
|
}
|
|
|
|
if (isset($filter['time_to']) && $filter['time_to']) {
|
|
$where[] = ' sra.createtime <' . (strtotime($filter['time_to']) + 86400);
|
|
}
|
|
|
|
if (isset($filter['type_id']) && $filter['type_id']) {
|
|
$where[] = ' sra.store_bn = \'' . $filter['type_id'] . '\'';
|
|
}
|
|
|
|
return parent::_filter($filter, 'sra', $baseWhere) . " AND " . implode(' AND ', $where);
|
|
}
|
|
|
|
/**
|
|
* 获取订单拒绝门店
|
|
*
|
|
* @return void
|
|
* @author
|
|
**/
|
|
public function get_refuse_stores($order_id)
|
|
{
|
|
$stores = array();
|
|
|
|
$delivery_order = app::get('ome')->model('delivery_order')->getList('*', array('order_id' => $order_id));
|
|
|
|
if (!$delivery_order) {
|
|
return $stores;
|
|
}
|
|
|
|
$delivery_id = array_column($delivery_order, 'delivery_id');
|
|
|
|
$refuse_list = $this->getList('store_bn', array('delivery_id' => $delivery_id));
|
|
|
|
$stores = array_column($refuse_list, 'store_bn');
|
|
|
|
return $stores;
|
|
}
|
|
}
|