Area.php 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. namespace app\admin\model;
  3. use think\Model;
  4. class Area extends Model
  5. {
  6. // 表名
  7. protected $name = 'area';
  8. // 自动写入时间戳字段
  9. protected $autoWriteTimestamp = false;
  10. // 定义时间戳字段名
  11. protected $createTime = false;
  12. protected $updateTime = false;
  13. protected $deleteTime = false;
  14. // 追加属性
  15. protected $append = [
  16. 'level_text'
  17. ];
  18. public function getLevelList()
  19. {
  20. return ['1' => __('Level 1'), '2' => __('Level 2'), '3' => __('Level 3')];
  21. }
  22. public function getLevelTextAttr($value, $data)
  23. {
  24. $value = $value ? $value : (isset($data['level']) ? $data['level'] : '');
  25. $list = $this->getLevelList();
  26. return isset($list[$value]) ? $list[$value] : '';
  27. }
  28. public function findAreaByAdmin($admin)
  29. {
  30. $where = [
  31. ["level", "=", 2],
  32. ["use", "=", 1]
  33. ];
  34. $query = $this;
  35. if ($admin) {
  36. if (\E_IDENTITY_TYPE::Agency === $admin["type"]) {
  37. array_push($where, ["area_code", "in", explode(",", $admin["city_codes"])]);
  38. }
  39. if(\E_IDENTITY_TYPE::Store === $admin["type"]) {
  40. return [];
  41. }
  42. }
  43. foreach ($where as $item) {
  44. $query->where($item[0], $item[1], $item[2]);
  45. }
  46. return $query->select();
  47. }
  48. }