123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- <?php
- namespace app\admin\controller\cost;
- use app\admin\model\village\Village;
- use app\common\controller\Backend;
- use app\admin\model\cost\CostItem;
- class CostBillMouth extends Backend
- {
-
-
- protected $model = null;
- public function _initialize()
- {
- parent::_initialize();
- $this->model = new \app\admin\model\cost\CostBillMouth;
- }
-
-
-
- public function index()
- {
-
-
- $this->request->filter(['strip_tags']);
- if ($this->request->isAjax()) {
-
- if ($this->request->request('keyField')) {
- return $this->selectpage();
- }
- $get=$this->request->get('filter');
- $where_and=['is_delete'=>'0','pay_status'=>'1'];
- if (!empty($this->auth->village)){
- $where_and['village_id']=['in',$this->auth->village];
-
- }
- list($where, $sort, $order, $offset, $limit) = $this->buildparams();
- if (!empty($get)){
- $get=json_decode($get,true);
- if (isset($get['village_id'])){
- $where_and['village_id']=['eq',$get['village_id']];
- }
- if (isset($get['item_id'])){
- $where_and['item_id']=['eq',$get['item_id']];
- }
- if (isset($get['hu.usesr_name'])){
- $get_huid=\app\admin\model\village\VillageHu::where('usesr_name','like','%'.$get['hu.usesr_name'].'%')->field('id')->select();
- $hu_id=array_column($get_huid,'id');
- $where_and['hu_id']=['in',$hu_id];
- }
- $total = $this->model
- ->where($where_and)
-
- ->order('pay_time desc')
- ->count();
- $list = $this->model
- ->where($where_and)
-
- ->with(['village','dong','danyuan','hu','item'])
- ->order('pay_time desc')
- ->limit($offset, $limit)
- ->select();
- }else{
- $total = $this->model
- ->where($where)
- ->where($where_and)
- ->order('pay_time desc')
- ->count();
- $list = $this->model
- ->where($where)
- ->where($where_and)
- ->with(['village','dong','danyuan','hu','item','village.property'])
- ->order('pay_time desc')
- ->limit($offset, $limit)
- ->select();
- }
- foreach ($list as $k=>$v){
- $list[$k]['house']=$v['village']['property']['p_name']." ".$v['village']['name']." ".$v['dong']['name']." ".$v['danyuan']['name'];
- }
- $list = collection($list)->toArray();
- $result = array("total" => $total, "rows" => $list);
- return json($result);
- }
- return $this->view->fetch();
- }
- public function village(){
- if (!empty($this->auth->village)){
- $where_and['village_id']=['in',$this->auth->village];
-
- }
- $where_and['is_delete']=['eq','0'];
- $groupList =Village::where($where_and)->field('id as value,v_name as name')->order('id asc')->select();
- $this->success('', null, $groupList);
- }
- public function item_id(){
- $id = $this->request->get('id');
- if (!empty($this->auth->village)){
- $where_and['village_id']=['in',$this->auth->village];
-
- }
- $get_item=CostItem::where(['village_id'=>$id,'is_delete'=>'0'])->field('id as value,item')->select();
- foreach ($get_item as $k=>$v){
- if ($v['item']=='1'){
- $get_item[$k]['name']='物业费';
- }elseif($v['item']=='2'){
- $get_item[$k]['name']='生活垃圾处理费';
- }elseif($v['item']=='3'){
- $get_item[$k]['name']='车位服务费';
- }else{
- $get_item[$k]['name']='未知';
- }
- }
- $data = [
- [
- 'value'=>1,'item'=>'1','name'=>'水费',
- ],
- [
- 'value'=>2,'item'=>'2','name'=>'电费',
- ],
- [
- 'value'=>999999999,'item'=>'999999999','name'=>'车位服务费',
- ]
- ];
- $data=array_merge($data,$get_item);
- $this->success('', null, $data);
- }
- public function mouth($ids = null){
- $select=$this->request->get('select');
- $where_and=['is_delete'=>'0','pay_status'=>'1'];
- if ($select=='1'){
- $get=$this->request->get();
- if (!empty($get['village_id']) && !empty($get['village_id'])){
- $where_and['village_id']=$get['village_id'];
- }
- if (isset($get['item_id']) && !empty($get['item_id'])){
- $where_and['item_id']=['eq',$get['item_id']];
- }
- if (isset($get['pay_time'])&& !empty($get['pay_time'])){
-
- $pay_time=explode(' - ',$get['pay_time']);
- $where_and['pay_time']=['between',[strtotime($pay_time['0']),strtotime($pay_time['1'])]];
- }
- if (isset($get['hu.usesr_name']) && !empty($get['hu.usesr_name'])){
- $get_huid=\app\admin\model\village\VillageHu::where('usesr_name','like','%'.$get['hu.usesr_name'].'%')->field('id')->select();
- $hu_id=array_column($get_huid,'id');
- $where_and['hu_id']=['in',$hu_id];
- }
- }else{
- $id=$this->request->get('id');
- $ids=explode(',',$id);
- $where_and['id']=['in',$ids];
- }
- $list = $this->model
- ->where($where_and)
- ->with(['village','dong','danyuan','hu','item','village.property'])
- ->order('pay_time desc')
- ->select();
- foreach ($list as $k=>$v){
- if ($v['item_id']=='1'){
- $list[$k]['item_name']='水费';
- }elseif($v['item_id']=='2'){
- $list[$k]['item_name']='电费';
- }elseif($v['item_id']=='9999999999'){
- $list[$k]['item_name']='车位服务费';
- }else{
-
- if ($v['item']['item']=='1'){
- $list[$k]['item_name']='物业费';
- }elseif ($v['item']['item']=='2'){
- $list[$k]['item_name']='生活垃圾处理费';
- }elseif ($v['item']['item']=='3'){
- $list[$k]['item_name']='车位服务费';
- }else{
- $list[$k]['item_name']='未知';
- }
- }
- $list[$k]['pay_date']=date('Y-m-d H:i:s',$v['pay_time']);
- }
- $time=date('Y-m-d H:i:s');
- $this->view->assign('time',$time);
- $this->view->assign('list',$list);
- return $this->view->fetch();
- }
- }
|