StoreProductAttrValue.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\model\product\sku;
  12. use app\model\activity\integral\StoreIntegral;
  13. use app\model\store\product\ProductAttrValue;
  14. use crmeb\basic\BaseModel;
  15. use crmeb\traits\ModelTrait;
  16. use think\Model;
  17. use app\model\product\product\StoreProduct;
  18. /**
  19. * Class StoreProductAttrValue
  20. * @package app\common\model\product
  21. */
  22. class StoreProductAttrValue extends BaseModel
  23. {
  24. use ModelTrait;
  25. /**
  26. * 模型名称
  27. * @var string
  28. */
  29. protected $name = 'store_product_attr_value';
  30. protected $insert = ['unique'];
  31. /**
  32. * sku 字段写入
  33. * @param $value
  34. * @return string
  35. */
  36. public function setSukAttr($value)
  37. {
  38. return is_array($value) ? implode(',', $value) : $value;
  39. }
  40. /**
  41. * Unique字段写入
  42. * @param $value
  43. * @param $data
  44. * @return mixed
  45. */
  46. public function setUniqueAttr($value, $data)
  47. {
  48. if (is_array($data['suk'])) {
  49. $data['suk'] = $this->setSukAttr($data['suk']);
  50. }
  51. return $data['unique'] ?: substr(md5($data['product_id'] . $data['suk'] . uniqid(true)), 12, 8);
  52. }
  53. /**
  54. * 门店规格表
  55. * @return \think\model\relation\HasOne
  56. */
  57. public function storeBranch()
  58. {
  59. return $this->hasOne(ProductAttrValue::class, 'unique', 'unique')->bind([
  60. 'branch_sales' => 'sales',
  61. 'branch_stock' => 'stock'
  62. ]);;
  63. }
  64. /**
  65. * 关联积分商城表
  66. * @return \think\model\relation\HasOne
  67. */
  68. public function storeIntegral()
  69. {
  70. return $this->hasOne(StoreIntegral::class, 'id', 'product_id')->where('is_show', 1)->where('is_del', 0);
  71. }
  72. /**
  73. * 商品搜索器
  74. * @param Model $query
  75. * @param $value
  76. * @param $data
  77. */
  78. public function searchProductIdAttr($query, $value)
  79. {
  80. if (is_array($value)) {
  81. $query->whereIn('product_id', $value);
  82. } else {
  83. $query->where('product_id', $value);
  84. }
  85. }
  86. /**
  87. * 商品类型搜索器
  88. * @param Model $query
  89. * @param $value
  90. * @param $data
  91. */
  92. public function searchTypeAttr($query, $value)
  93. {
  94. $query->where('type', $value);
  95. }
  96. /**
  97. * 商品属性名称搜索器
  98. * @param Model $query
  99. * @param $value
  100. * @param $data
  101. */
  102. public function searchSukAttr($query, $value)
  103. {
  104. if (is_array($value)) {
  105. if ($value) $query->whereIn('suk', $value);
  106. } else {
  107. if ($value !== '') $query->where('suk', $value);
  108. }
  109. }
  110. /**
  111. * 规格唯一值搜索器
  112. * @param Model $query
  113. * @param $value
  114. * @param $data
  115. */
  116. public function searchUniqueAttr($query, $value)
  117. {
  118. if (is_array($value)) {
  119. $query->whereIn('unique', $value);
  120. } else {
  121. if ($value) {
  122. $query->where('unique', $value);
  123. }
  124. }
  125. }
  126. public function product()
  127. {
  128. return $this->hasOne(StoreProduct::class, 'id', 'product_id')->field('store_name,id')->bind(['store_name']);
  129. }
  130. }