Bill.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. namespace app\api\model\user;
  3. use app\api\model\BaseModel;
  4. class Bill extends BaseModel
  5. {
  6. // 表名
  7. protected $name = 'user_bill';
  8. // 自动写入时间戳字段
  9. protected $autoWriteTimestamp = 'integer';
  10. // 定义时间戳字段名
  11. protected $createTime = 'createtime';
  12. protected $updateTime = false;
  13. protected $deleteTime = false;
  14. // 追加属性
  15. protected $append = [
  16. 'type_text'
  17. ];
  18. public function getTypeList()
  19. {
  20. return ['money' => __('Money'), 'score' => __('Score')];
  21. }
  22. public function getTypeTextAttr($value, $data)
  23. {
  24. $value = $value ? $value : (isset($data['type']) ? $data['type'] : '');
  25. $list = $this->getTypeList();
  26. return isset($list[$value]) ? $list[$value] : '';
  27. }
  28. public function user()
  29. {
  30. return $this->belongsTo('app\admin\model\User', 'user_id', 'id', [], 'LEFT')->setEagerlyType(0);
  31. }
  32. public function getBill($user_id, $currency_type, $change_type, $relation_no)
  33. {
  34. return $this->where([
  35. "user_id" => $user_id,
  36. "currency_type" => $currency_type,
  37. "change_type" => $change_type,
  38. "relation_no" => $relation_no
  39. ])
  40. ->order("createtime", "desc")
  41. ->find();
  42. }
  43. public function fetchBill($user_id, $currency_type, $change_types, $page = 1, $size = 10)
  44. {
  45. $query = $this->where([
  46. "user_id" => $user_id,
  47. "currency_type" => $currency_type,
  48. "is_del" => 0
  49. ]);
  50. if (!in_array("*", $change_types)) {
  51. $query->where("change_type", "in", $change_types);
  52. }
  53. return $query
  54. ->order("createtime", "desc")
  55. ->page($page)
  56. ->paginate($size);
  57. }
  58. }