|
@@ -6,6 +6,7 @@ use app\admin\validate\life\CinemaIlkValidate;
|
|
|
use app\admin\validate\member\WellnessRecordValidate;
|
|
|
use app\controller\Curd;
|
|
|
use app\model\CinemaIlk as CinemaIlkModel;
|
|
|
+use app\model\Customer;
|
|
|
use app\model\WellnessRecord;
|
|
|
use support\exception\BusinessException;
|
|
|
use support\Request;
|
|
@@ -35,10 +36,20 @@ class VisitingController extends Curd
|
|
|
[$where, $format, $limit, $field, $order] = $this->selectInput($request);
|
|
|
$field = $field ?? 'wellness_record_addtimes';
|
|
|
$order = $request->get('order', 'desc');
|
|
|
- $where['wellness_record_category'] = '来访';
|
|
|
+ $where['wellness_record_category'] = 'Visiting';
|
|
|
+
|
|
|
+ $m = $request->get('m', 'MEMBER');
|
|
|
+ if ($m == 'MEMBER') {
|
|
|
+ $isOwner = 'N';
|
|
|
+ $query = $this->doSelect($where, $field, $order, $isOwner);
|
|
|
+ } elseif ($m == 'OWNER') {
|
|
|
+ $isOwner = 'Y';
|
|
|
+ $query = $this->doSelect($where, $field, $order, $isOwner);
|
|
|
+ } elseif ($m == 'CUSTOMER') {
|
|
|
+ $field = 'created_at';
|
|
|
+ $query = $this->doSelectCustomer($where, $field, $order);
|
|
|
+ }
|
|
|
|
|
|
- $isOwner = $request->post('is_owner', 'N');
|
|
|
- $query = $this->doSelect($where, $field, $order, $isOwner);
|
|
|
return $this->doFormat($query, $format, $limit);
|
|
|
}
|
|
|
|
|
@@ -91,6 +102,55 @@ class VisitingController extends Curd
|
|
|
return $model;
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+ protected function doSelectCustomer(array $where, string $field = null, string $order = 'desc')
|
|
|
+ {
|
|
|
+ $model = $this->model->leftJoin('customer', 'customer.id', '=', 'wellness_record.join_wellness_record_member_id')
|
|
|
+ ->select('customer.name', 'customer.mobile', 'wellness_record.*')
|
|
|
+ ->where('customer.name','<>', "");
|
|
|
+// ->with([
|
|
|
+// 'member' => function ($query) {
|
|
|
+// $query->where('member_is_owner', 'N')->select('member_id', 'member_mobile');
|
|
|
+// },
|
|
|
+// 'cert' => function ($query) {
|
|
|
+// $query->select('join_cert_member_id', 'member_cert_name');
|
|
|
+// }
|
|
|
+// ]);
|
|
|
+ foreach ($where as $column => $value) {
|
|
|
+ if (is_array($value)) {
|
|
|
+ if ($value[0] === 'like' || $value[0] === 'not like') {
|
|
|
+ $model = $model->where($column, $value[0], "%$value[1]%");
|
|
|
+ } elseif (in_array($value[0], ['>', '=', '<', '<>'])) {
|
|
|
+ $model = $model->where($column, $value[0], $value[1]);
|
|
|
+ } elseif ($value[0] == 'in' && !empty($value[1])) {
|
|
|
+ $valArr = $value[1];
|
|
|
+ if (is_string($value[1])) {
|
|
|
+ $valArr = explode(",", trim($value[1]));
|
|
|
+ }
|
|
|
+ $model = $model->whereIn($column, $valArr);
|
|
|
+ } elseif ($value[0] == 'not in' && !empty($value[1])) {
|
|
|
+ $valArr = $value[1];
|
|
|
+ if (is_string($value[1])) {
|
|
|
+ $valArr = explode(",", trim($value[1]));
|
|
|
+ }
|
|
|
+ $model = $model->whereNotIn($column, $valArr);
|
|
|
+ } elseif ($value[0] == 'null') {
|
|
|
+ $model = $model->whereNull($column);
|
|
|
+ } elseif ($value[0] == 'not null') {
|
|
|
+ $model = $model->whereNotNull($column);
|
|
|
+ } elseif ($value[0] !== '' || $value[1] !== '') {
|
|
|
+ $model = $model->whereBetween($column, $value);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ $model = $model->where($column, $value);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if ($field) {
|
|
|
+ $model = $model->orderBy($field, $order);
|
|
|
+ }
|
|
|
+ return $model;
|
|
|
+ }
|
|
|
+
|
|
|
protected function afterQuery($items)
|
|
|
{
|
|
|
foreach ($items as &$item) {
|