AisStore.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2017 https://www.sapixx.com All rights reserved.
  4. * @license Licensed (http://www.apache.org/licenses/LICENSE-2.0).
  5. * @author pillar<ltmn@qq.com>
  6. * 商家管理
  7. */
  8. namespace app\ais\model;
  9. use app\common\facade\Inform;
  10. use think\Model;
  11. use util\Util;
  12. class AisStore extends Model{
  13. protected $autoWriteTimestamp = true;
  14. protected $updateTime = false;
  15. protected $json = ['citypath','imgs']; //数组存到数据库变JSON
  16. //加入的群组
  17. public function group(){
  18. return $this->belongsToMany('AisStoreGroup','AisStoreUnion','group_id','store_id');
  19. }
  20. //所属管理员
  21. public function user(){
  22. return $this->hasOne('app\common\model\SystemUser','id','manage_uid');
  23. }
  24. public function cate(){
  25. return $this->hasOne('AisStoreCate','id','cate_id');
  26. }
  27. //连锁门店
  28. public function chain(){
  29. return $this->hasMany('AisStoreChain','store_id','id');
  30. }
  31. //Tags字符串转数组
  32. public function getTagsAttr($value,$data){
  33. if(empty($data['tags'])){
  34. return [];
  35. }
  36. return explode(',',$data['tags']);
  37. }
  38. //搜索好店名称
  39. public function searchNameAttr($query,$value){
  40. if(!empty($value)){
  41. $query->where('name','like', '%'.$value .'%');
  42. }
  43. }
  44. //添加或编辑
  45. public static function edit($param){
  46. $data['manage_uid'] = $param['manage_uid'];
  47. $data['cate_id'] = $param['cate_id'];
  48. $data['cate_sid'] = $param['cate_sid'];
  49. $data['name'] = $param['name'];
  50. $data['address'] = $param['address'];
  51. $data['longitude'] = $param['longitude'];
  52. $data['latitude'] = $param['latitude'];
  53. $data['telphone'] = $param['telphone'];
  54. $data['citypath'] = $param['citypath'];
  55. $data['citycode'] = $param['citycode'];
  56. $data['img'] = $param['img'];
  57. $data['mch_id'] = $param['mch_id'];
  58. $data['charge'] = $param['charge'];
  59. $data['tags'] = empty($param['tags']) ? '': sbc2Dbc($param['tags']);
  60. $data['imgs'] = json_encode($param['imgs']);
  61. if(empty($param['id'])){
  62. $data['member_miniapp_id'] = $param['member_miniapp_id'];
  63. $data['is_top'] = 0;
  64. $data['create_time'] = time();
  65. $data['sort'] = 0;
  66. return self::insertGetId($data);
  67. }else{
  68. self::update($data,['id'=>(int)$param['id']]);
  69. return $param['id'];
  70. }
  71. }
  72. /**
  73. * 置顶或取消
  74. * @param integer $id
  75. */
  76. public static function isTop(int $id){
  77. $result = self::where(['id' => $id])->field('is_top')->find();
  78. $result->is_top = $result->is_top ? 0 : 1;
  79. return $result->save();
  80. }
  81. /**
  82. * 锁定或取消
  83. * @param integer $id
  84. */
  85. public static function isLock(int $id,$member_miniapp_id){
  86. $result = self::where(['id' => $id])->field('is_lock')->find();
  87. $result->is_lock = $result->is_lock ? 0 : 1;
  88. return $result->save();
  89. }
  90. //根据管理ID获取所属商户
  91. public static function manageStore(int $uid){
  92. return self::with(['chain' => function($query) {
  93. $query->field('id,store_id,title,address,telphone,longitude,latitude');
  94. }])->where(['manage_uid' => $uid])->field('citycode,id,name,address,img,telphone,longitude,latitude,mch_id')->find();
  95. }
  96. }