You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
129 lines
4.9 KiB
129 lines
4.9 KiB
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
|
// +----------------------------------------------------------------------
|
|
// | Author: CRMEB Team <admin@crmeb.com>
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace crmeb\traits;
|
|
|
|
use think\Model;
|
|
|
|
/**
|
|
* Trait ModelTrait
|
|
* @package crmeb\traits
|
|
*/
|
|
trait ModelTrait
|
|
{
|
|
/**
|
|
* 时间段搜索器
|
|
* @param Model $query
|
|
* @param $value
|
|
*/
|
|
public function searchTimeAttr($query, $value, $data)
|
|
{
|
|
if ($value) {
|
|
$timeKey = $data['timeKey'] ?? (property_exists($this, 'timeKey') && $this->timeKey ? $this->timeKey : 'add_time');
|
|
if (is_array($value)) {
|
|
$startTime = $value[0] ?? 0;
|
|
$endTime = $value[1] ?? 0;
|
|
if ($startTime || $endTime) {
|
|
try {
|
|
date('Y-m-d', $startTime);
|
|
} catch (\Throwable $e) {
|
|
$startTime = strtotime($startTime);
|
|
}
|
|
try {
|
|
date('Y-m-d', $endTime);
|
|
} catch (\Throwable $e) {
|
|
$endTime = strtotime($endTime);
|
|
}
|
|
if ($startTime == $endTime || $endTime == strtotime(date('Y-m-d', $endTime))) {
|
|
$endTime = $endTime + 86400;
|
|
}
|
|
$query->whereBetween($timeKey, [$startTime, $endTime]);
|
|
}
|
|
} elseif (is_string($value)) {
|
|
switch ($value) {
|
|
case 'today':
|
|
case 'week':
|
|
case 'month':
|
|
case 'year':
|
|
case 'yesterday':
|
|
case 'last year':
|
|
case 'last week':
|
|
case 'last month':
|
|
$query->whereTime($timeKey, $value);
|
|
break;
|
|
case 'quarter':
|
|
[$startTime, $endTime] = $this->getMonth();
|
|
$query->whereBetween($timeKey, [strtotime($startTime), strtotime($endTime)]);
|
|
break;
|
|
case 'lately7':
|
|
$query->whereBetween($timeKey, [strtotime("-7 day"), time()]);
|
|
break;
|
|
case 'lately30':
|
|
$query->whereBetween($timeKey, [strtotime("-30 day"), time()]);
|
|
break;
|
|
default:
|
|
if (strstr($value, '-') !== false) {
|
|
[$startTime, $endTime] = explode('-', $value);
|
|
$startTime = trim($startTime) ? strtotime($startTime) : 0;
|
|
$endTime = trim($endTime) ? strtotime($endTime) : 0;
|
|
if ($startTime && $endTime) {
|
|
if ($startTime == $endTime || $endTime == strtotime(date('Y-m-d', $endTime))) {
|
|
$endTime = $endTime + 86400;
|
|
}
|
|
$query->whereBetween($timeKey, [$startTime, $endTime]);
|
|
} else if (!$startTime && $endTime) {
|
|
$query->whereTime($timeKey, '<', $endTime + 86400);
|
|
} else if ($startTime && !$endTime) {
|
|
$query->whereTime($timeKey, '>=', $startTime);
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 获取本季度 time
|
|
* @param int $ceil
|
|
* @return array
|
|
*/
|
|
public function getMonth(int $ceil = 0)
|
|
{
|
|
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')));
|
|
return [$firstday, $lastday];
|
|
}
|
|
|
|
/**
|
|
* 获取某个字段内的值
|
|
* @param $value
|
|
* @param string $filed
|
|
* @param string $valueKey
|
|
* @param array|string[] $where
|
|
* @return mixed
|
|
*/
|
|
public function getFieldValue($value, string $filed, ?string $valueKey = '', ?array $where = [])
|
|
{
|
|
$model = $this->where($filed, $value);
|
|
if ($where) {
|
|
$model->where(...$where);
|
|
}
|
|
return $model->value($valueKey ?: $filed);
|
|
}
|
|
|
|
|
|
}
|
|
|