CardListForm.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. /**
  3. * 重庆赤晓店信息科技有限公司
  4. * https://www.chixiaodian.com
  5. * Copyright (c) 2023 赤店商城 All rights reserved.
  6. */
  7. namespace app\modules\client\models\v1;
  8. use app\models\UserCard;
  9. use app\modules\client\models\ApiModel;
  10. use yii\data\Pagination;
  11. class CardListForm extends ApiModel
  12. {
  13. public $store_id;
  14. public $user_id;
  15. public $page;
  16. public $limit;
  17. public $status;
  18. public $user_card_id;
  19. public function rules()
  20. {
  21. return [
  22. [['user_card_id'], 'integer'],
  23. [['page'], 'default','value' => 1],
  24. [['limit'], 'default','value' => 10],
  25. [['status'], 'default','value' => 1]
  26. ];
  27. }
  28. /**
  29. * @return array
  30. */
  31. public function detail()
  32. {
  33. if (!$this->validate()) {
  34. return [
  35. 'code' => 1,
  36. 'msg' => $this->getErrorSummary(false)[0],
  37. ];
  38. }
  39. $list = UserCard::findOne([
  40. 'store_id' => $this->store_id,
  41. 'user_id' => $this->user_id,
  42. 'id' => $this->user_card_id,
  43. 'is_delete' => 0,
  44. ]);
  45. return [
  46. 'code'=>0,
  47. 'msg'=> '',
  48. 'data'=> [
  49. 'list' => $list,
  50. ]
  51. ];
  52. }
  53. /**
  54. * @return array
  55. */
  56. public function search()
  57. {
  58. if (!$this->validate()) {
  59. return [
  60. 'code' => 1,
  61. 'msg' => $this->getErrorSummary(false)[0],
  62. ];
  63. }
  64. $query = UserCard::find()->where([
  65. 'store_id' => $this->store_id, 'user_id' => $this->user_id, 'is_delete' => 0]);
  66. if ($this->status == 1) {
  67. $query->andWhere(['is_use' => 0]);
  68. }
  69. if ($this->status == 2) {
  70. $query->andWhere(['is_use' => 1]);
  71. }
  72. $count = $query->count();
  73. $p = new Pagination(['totalCount' => $count,'pageSize' => $this->limit]);
  74. $list = $query->limit($p->limit)->offset($p->offset)->orderBy(['created_at' => SORT_DESC])->asArray()->all();
  75. foreach ($list as $k => $v) {
  76. $list[$k]['clerk_time'] = date('Y-m-d H:i:s', $v['clerk_time']);
  77. }
  78. return [
  79. 'code'=>0,
  80. 'msg'=>'',
  81. 'data'=>[
  82. 'list' => $list,
  83. 'page_count' => $p->pageCount,
  84. 'row_count' => $count
  85. ]
  86. ];
  87. }
  88. }