Site.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Niucloud-admin 企业快速开发的saas管理平台
  4. // +----------------------------------------------------------------------
  5. // | 官方网址:https://www.niucloud.com
  6. // +----------------------------------------------------------------------
  7. // | niucloud团队 版权所有 开源版本可自由商用
  8. // +----------------------------------------------------------------------
  9. // | Author: Niucloud Team
  10. // +----------------------------------------------------------------------
  11. namespace app\model\site;
  12. use app\model\shop\Shop;
  13. use app\dict\site\SiteDict;
  14. use app\model\shop\ShopCategory;
  15. use core\base\BaseModel;
  16. use think\db\Query;
  17. use think\model\relation\HasOne;
  18. /**
  19. * 站点模型
  20. * Class Site
  21. * @package app\model\site
  22. */
  23. class Site extends BaseModel
  24. {
  25. /**
  26. * 模型名称
  27. * @var string
  28. */
  29. protected $name = 'site';
  30. protected $type = [
  31. 'expire_time' => 'timestamp',
  32. ];
  33. /**
  34. * 数据表主键
  35. * @var string
  36. */
  37. protected $pk = 'site_id';
  38. protected $json = ['addons', 'app', 'initalled_addon'];
  39. protected $jsonAssoc = true;
  40. /**
  41. * 状态字段转化
  42. * @param $value
  43. * @param $data
  44. * @return mixed
  45. */
  46. public function getStatusNameAttr($value, $data)
  47. {
  48. if (empty($data['status']))
  49. return '';
  50. return SiteDict::getStatus()[$data['status']] ?? '';
  51. }
  52. public function getSiteStatusNameAttr($value, $data)
  53. {
  54. if (empty($data['status']))
  55. return '';
  56. return SiteDict::getStatus()[$data['status']] ?? '';
  57. }
  58. /**
  59. * 关键字搜索
  60. * @param $query
  61. * @param $value
  62. * @param $data
  63. */
  64. public function searchKeywordsAttr($query, $value, $data)
  65. {
  66. if ($value) {
  67. $query->where('site_name|keywords', 'like', '%' . $value . '%');
  68. }
  69. }
  70. /**
  71. * 关键字搜索
  72. * @param $query
  73. * @param $value
  74. * @param $data
  75. */
  76. public function searchKeywordAttr($query, $value, $data)
  77. {
  78. if ($value) {
  79. $query->where('site_name|keywords', 'like', '%' . $value . '%');
  80. }
  81. }
  82. /**
  83. * 站点域名搜索
  84. * @param $query
  85. * @param $value
  86. * @param $data
  87. * @return void
  88. */
  89. public function searchSiteDomainAttr($query, $value, $data)
  90. {
  91. if ($value) {
  92. $query->where('site_domain', 'like', '%' . $value . '%');
  93. }
  94. }
  95. /**
  96. * 关键字搜索
  97. * @param $query
  98. * @param $value
  99. * @param $data
  100. */
  101. public function searchAppAttr($query, $value, $data)
  102. {
  103. if ($value) {
  104. $query->where('app', 'like', '%"' . $value . '"%');
  105. }
  106. }
  107. /**
  108. * 站点状态搜索
  109. * @param $query
  110. * @param $value
  111. * @param $data
  112. */
  113. public function searchStatusAttr($query, $value, $data)
  114. {
  115. if ($value) {
  116. $query->where('status', '=', $value);
  117. }
  118. }
  119. /**
  120. * 站点分组搜索
  121. * @param $query
  122. * @param $value
  123. * @param $data
  124. */
  125. public function searchGroupIdAttr($query, $value, $data)
  126. {
  127. if ($value) {
  128. $query->where('group_id', '=', $value);
  129. }
  130. }
  131. /**
  132. * 是否自营搜索
  133. * @param $query
  134. * @param $value
  135. * @param $data
  136. */
  137. public function searchIsSelfAttr($query, $value, $data)
  138. {
  139. if ($value) {
  140. $query->where('is_self', '=', $value);
  141. }
  142. }
  143. /**
  144. * 商家分类搜索
  145. * @param $query
  146. * @param $value
  147. * @param $data
  148. */
  149. public function searchCategoryIdAttr($query, $value, $data)
  150. {
  151. if ($value) {
  152. $query->where('category_id', '=', $value);
  153. }
  154. }
  155. /**
  156. * 分组名称
  157. * @return HasOne
  158. */
  159. public function groupName()
  160. {
  161. return $this->hasOne(SiteGroup::class, 'group_id', 'group_id')->joinType('left')->field('group_id, group_name')->bind(['group_name' => 'group_name']);
  162. }
  163. /**
  164. * 分类名称
  165. * @return HasOne
  166. */
  167. public function categoryName()
  168. {
  169. return $this->hasOne(ShopCategory::class, 'category_id', 'category_id')->field('category_id, category_name')->bind(['category_name' => 'category_name']);
  170. }
  171. /**
  172. * 关联站点分组
  173. * @return HasOne
  174. */
  175. public function siteGroup() {
  176. return $this->hasOne(SiteGroup::class, 'group_id', 'group_id');
  177. }
  178. /**
  179. * 创建时间搜索器
  180. * @param Query $query
  181. * @param $value
  182. * @param $data
  183. */
  184. public function searchCreateTimeAttr(Query $query, $value, $data)
  185. {
  186. $start_time = empty($value[0]) ? 0 : strtotime($value[0]);
  187. $end_time = empty($value[1]) ? 0 : strtotime($value[1]);
  188. if ($start_time > 0 && $end_time > 0) {
  189. $query->whereBetweenTime('create_time', $start_time, $end_time);
  190. } else if ($start_time > 0 && $end_time == 0) {
  191. $query->where([['create_time', '>=', $start_time]]);
  192. } else if ($start_time == 0 && $end_time > 0) {
  193. $query->where([['create_time', '<=', $end_time]]);
  194. }
  195. }
  196. /**
  197. * 到期时间搜索器
  198. * @param Query $query
  199. * @param $value
  200. * @param $data
  201. */
  202. public function searchExpireTimeAttr(Query $query, $value, $data)
  203. {
  204. $start_time = empty($value[0]) ? 0 : strtotime($value[0]);
  205. $end_time = empty($value[1]) ? 0 : strtotime($value[1]);
  206. if ($start_time > 0 && $end_time > 0) {
  207. $query->whereBetweenTime('expire_time', $start_time, $end_time);
  208. } else if ($start_time > 0 && $end_time == 0) {
  209. $query->where([['expire_time', '>=', $start_time]]);
  210. } else if ($start_time == 0 && $end_time > 0) {
  211. $query->where([['expire_time', '<=', $end_time]]);
  212. }
  213. }
  214. /**
  215. * 店铺扩展信息
  216. * @return HasOne
  217. */
  218. public function shop(){
  219. return $this->hasOne(Shop::class, 'site_id', 'site_id');
  220. }
  221. }