123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- <?php
- namespace App\Http\Controllers\MoneyDetail;
- use App\Http\Controllers\AdminBaseController;
- use App\Http\Requests\MoneyDetailCreateRequest;
- use App\Http\Requests\MoneyDetailUpdateRequest;
- use App\Models\MoneyDetail;
- use App\Repositories\Eloquent\MoneyDetailRepositoryEloquent;
- use App\Servers\MoneyDetailServer;
- use App\Validators\MoneyDetailValidator;
- /**
- * Class MoneyDetailsController.
- *
- * @package namespace App\Http\Controllers;
- */
- class MoneyDetailsController extends AdminBaseController
- {
- /**
- * @var MoneyDetailRepositoryEloquent
- */
- protected $repository;
- /**
- * @var MoneyDetailValidator
- */
- protected $validator;
- /**
- * MoneyDetailsController constructor.
- *
- * @param MoneyDetailRepositoryEloquent $repository
- * @param MoneyDetailValidator $validator
- */
- public function __construct(MoneyDetailRepositoryEloquent $repository, MoneyDetailValidator $validator)
- {
- parent::__construct($repository, $validator);
- }
- /**
- * 数据检索
- */
- public function _indexScopeQuery()
- {
- $where = [];
- $search = explode(";", request()->input('search', ""));
- $start = $end = null;
- $fieldSearchable = $this->repository->getFieldsSearchable();
- foreach ($search as $value) {
- if (!empty($value)) {
- list($one, $tow) = explode(":", $value);
- if (!empty($fieldSearchable[$one])) {
- if ($fieldSearchable[$one] == 'like') $tow = "%{$tow}%";
- $where[] = [$one, $fieldSearchable[$one], $tow];
- } elseif ($one == 'start') {
- $start = $tow . " 00:00:00";
- } elseif ($one == 'end') {
- $end = $tow . " 23:59:59";
- } else {
- continue;
- }
- }
- }
- return function ($query) use ($where, $start, $end) {
- if ($start) $where[] = ['created_at', '>=', $start];
- if ($end) $where[] = ['created_at', '<=', $end];
- if ($where) {
- $query->where($where);
- }
- };
- }
- /**
- * 数据更新
- */
- protected function _indexPost($datum)
- {
- foreach ($datum as $value){
- $value->{'type'}=MoneyDetailServer::creatServer()->getTypeArr($value->{'type'});
- $value->{'status'}=MoneyDetailServer::creatServer()->getStatusArr($value->{'status'});
- $value->{'add_reduce'}=MoneyDetailServer::creatServer()->getAddReduceArr($value->{'add_reduce'});
- }
- return $datum;
- }
- function _indexGet(){
- $type=MoneyDetailServer::creatServer()->getType();
- $status=MoneyDetailServer::creatServer()->getStatus();
- return ['type'=>$type,'status'=>$status];
- }
- function _indexJoin()
- {
- $model = MoneyDetail::from('money_details as d')
- ->leftJoin('members as m', 'm.id', '=', 'd.m_id');
- return $model;
- }
- function _indexSelect()
- {
- return ['d.*', 'm.address'];
- }
- }
|