Business.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php namespace App\Models;
  2. use Illuminate\Database\Eloquent\Factories\HasFactory;
  3. use Illuminate\Database\Eloquent\Model;
  4. /**
  5. * 店铺模型
  6. *
  7. */
  8. class Business extends Model
  9. {
  10. use HasFactory;
  11. // 与模型关联的表名
  12. protected $table = 'business';
  13. // 是否主动维护时间戳
  14. public $timestamps = false;
  15. // 定义时间戳字段名
  16. // const CREATED_AT = 'insert_time';
  17. // const UPDATED_AT = 'update_time';
  18. /**
  19. * 添加数据
  20. *
  21. */
  22. public function add($data)
  23. {
  24. // 时间
  25. $data['insert_time'] = time();
  26. $data['update_time'] = time();
  27. // 写入数据表
  28. $id = $this->query()->insertGetId($data);
  29. // 如果操作失败
  30. if( !$id ) return $id;
  31. // 更新缓存
  32. $this->getList(true);
  33. // 返回结果
  34. return $id;
  35. }
  36. /**
  37. * 添加数据
  38. *
  39. */
  40. public function edit($id,$data)
  41. {
  42. // 更新时间
  43. $data['update_time'] = time();
  44. // 写入数据表
  45. $result = $this->query()->where(['id'=>$id])->update($data);
  46. // 如果操作失败
  47. if( !$result ) return $result;
  48. // 更新缓存
  49. $this->getList(true);
  50. // 返回结果
  51. return $result;
  52. }
  53. /**
  54. * 获取列表
  55. * @param Bool $force 是否强制更新
  56. *
  57. */
  58. public function getList($force = false)
  59. {
  60. // 结果数据
  61. $list = $force ? [] : cache('admin:business:list');
  62. // 不存在数据
  63. if ( !$list ) {
  64. // 从数据库获取数据
  65. $data = $this->query()->where([['status','=',0]])->get()->toArray();
  66. // 循环处理数据
  67. $list = [];
  68. // 进行更新
  69. foreach ($data as $value) {
  70. // 重组数据
  71. $list[$value['id']] = $value;
  72. }
  73. // 存起来
  74. cache(['admin:business:list'=>$list]);
  75. }
  76. // 返回结果
  77. return $list;
  78. }
  79. /**
  80. * 获取列表
  81. * @param Bool $force 是否强制更新
  82. *
  83. */
  84. public function getListByAdmin()
  85. {
  86. // 结果数据
  87. $list = [];
  88. // 不存在数据
  89. if ( !$list ) {
  90. $session = session('userRule') ? session('userRule') : ['company_id'=>1,'business_id'=>0,'menu_type'=>0,'data_type'=>0];
  91. $map = [['status','=',0]];
  92. if( $session['company_id'] ) $map[] = ['company_id','=',$session['company_id']];
  93. if( $session['business_id'] ) $map[] = ['id','=',$session['business_id']];
  94. if ($session['menu_type'] == 1 && $session['data_type'] == 2) $map[] = ['leader_uid','=',$session['admin_uid']];
  95. // 从数据库获取数据
  96. $data = $this->query()->where($map)->get();
  97. // 是否有数据
  98. $data = $data ? $data->toArray() : [];
  99. // 循环处理数据
  100. $list = [];
  101. // 进行更新
  102. foreach ($data as $value) {
  103. // 重组数据
  104. $list[$value['id']] = $value;
  105. }
  106. }
  107. // 返回结果
  108. return $list;
  109. }
  110. /**
  111. * 获取配置平台对应的应用数据
  112. *
  113. * @param Array 用户ID
  114. * @param String 指定字段
  115. *
  116. */
  117. public function getOne($id,$field='')
  118. {
  119. // 获取列表数据
  120. $list = $this->getList(true);
  121. // 获取数据
  122. $one = isset($list[$id]) ? $list[$id] : [];
  123. // 返回值
  124. return empty($field) ? $one : ( isset($one[$field]) ? $one[$field] : null);
  125. }
  126. /**
  127. * 获取配置平台对应的应用数据
  128. *
  129. * @param Array 用户ID
  130. * @param String 指定字段
  131. *
  132. */
  133. public function getIdByName($name)
  134. {
  135. // 获取列表数据
  136. $list = $this->getList();
  137. // 获取数据
  138. foreach ($list as $value) {
  139. // 如果有名称
  140. if( $name == $value['name'] ) return $value['id'];
  141. }
  142. // 写入数据表
  143. $id = $this->add(['name'=>$name]);
  144. // 返回结果
  145. return $id;
  146. }
  147. /**
  148. * 编码转id
  149. *
  150. * @param string $code 编码
  151. *
  152. */
  153. public function codeToId($code){
  154. return intval(str_ireplace('klsj','',$code));
  155. }
  156. /**
  157. * id转编码
  158. *
  159. * @param int $id 编码
  160. *
  161. */
  162. public function idToCode($id){
  163. return 'klsj'. str_pad($id, 9, '0', STR_PAD_LEFT);
  164. }
  165. }