Product.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <?php
  2. namespace App\Models;
  3. use Dcat\Admin\Traits\HasDateTimeFormatter;
  4. use Illuminate\Database\Eloquent\Relations\BelongsTo;
  5. use Illuminate\Database\Eloquent\Relations\HasMany;
  6. use Illuminate\Database\Eloquent\SoftDeletes;
  7. use Illuminate\Database\Eloquent\Model;
  8. /**
  9. * App\Models\Product
  10. *
  11. * @property int $id
  12. * @property string $name 名称
  13. * @property string $cover_img 封面图
  14. * @property string $cases 案例
  15. * @property string $origin_price 原价
  16. * @property string $sale_price 现价
  17. * @property int $sort 排序越大越靠前
  18. * @property int $is_opened 上架状态 0-下架 1-上架
  19. * @property string $tech_param 集数参数文件
  20. * @property string $cad_model CAD模型文件
  21. * @property string $cad_design CAD设计文件
  22. * @property string $su_model SU模型文件
  23. * @property string $other 其他文件
  24. * @property \Illuminate\Support\Carbon|null $updated_at
  25. * @property \Illuminate\Support\Carbon|null $deleted_at
  26. * @property \Illuminate\Support\Carbon|null $created_at
  27. * @method static \Illuminate\Database\Eloquent\Builder|Product newModelQuery()
  28. * @method static \Illuminate\Database\Eloquent\Builder|Product newQuery()
  29. * @method static \Illuminate\Database\Query\Builder|Product onlyTrashed()
  30. * @method static \Illuminate\Database\Eloquent\Builder|Product query()
  31. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCadDesign($value)
  32. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCadModel($value)
  33. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCases($value)
  34. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCoverImg($value)
  35. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCreatedAt($value)
  36. * @method static \Illuminate\Database\Eloquent\Builder|Product whereDeletedAt($value)
  37. * @method static \Illuminate\Database\Eloquent\Builder|Product whereId($value)
  38. * @method static \Illuminate\Database\Eloquent\Builder|Product whereIsOpened($value)
  39. * @method static \Illuminate\Database\Eloquent\Builder|Product whereName($value)
  40. * @method static \Illuminate\Database\Eloquent\Builder|Product whereOriginPrice($value)
  41. * @method static \Illuminate\Database\Eloquent\Builder|Product whereOther($value)
  42. * @method static \Illuminate\Database\Eloquent\Builder|Product whereSalePrice($value)
  43. * @method static \Illuminate\Database\Eloquent\Builder|Product whereSort($value)
  44. * @method static \Illuminate\Database\Eloquent\Builder|Product whereSuModel($value)
  45. * @method static \Illuminate\Database\Eloquent\Builder|Product whereTechParam($value)
  46. * @method static \Illuminate\Database\Eloquent\Builder|Product whereUpdatedAt($value)
  47. * @method static \Illuminate\Database\Query\Builder|Product withTrashed()
  48. * @method static \Illuminate\Database\Query\Builder|Product withoutTrashed()
  49. * @mixin \Eloquent
  50. * @property int $cate_id 分类ID
  51. * @property-read \App\Models\ProductCategory|null $cate
  52. * @method static \Illuminate\Database\Eloquent\Builder|Product whereCateId($value)
  53. * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\ProductSpec[] $specs
  54. * @property-read int|null $specs_count
  55. * @property-write mixed $files
  56. * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\StatProductDownload[] $download
  57. * @property-read int|null $download_count
  58. * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\StatProduct[] $viewer
  59. * @property-read int|null $viewer_count
  60. */
  61. class Product extends Model
  62. {
  63. use HasDateTimeFormatter;
  64. use SoftDeletes;
  65. protected $casts = [
  66. 'cases' => 'json',
  67. 'tech_param' => 'json',
  68. 'cad_model' => 'json',
  69. 'cad_design' => 'json',
  70. 'su_model' => 'json',
  71. 'other' => 'json',
  72. ];
  73. public function cate(): BelongsTo
  74. {
  75. return $this->belongsTo(ProductCategory::class,'cate_id','id');
  76. }
  77. public function specs(): HasMany
  78. {
  79. return $this->hasMany(ProductSpec::class,'product_id');
  80. }
  81. public function setFilesAttribute(Product $product)
  82. {
  83. $files = [];
  84. foreach ($product->tech_param as $item){
  85. $files[] = [
  86. 'name' => '产品技术参数下载',
  87. 'url' => $item['url']
  88. ];
  89. }
  90. foreach ($product->cad_model as $item){
  91. $files[] = [
  92. 'name' => '产品CAD模型下载',
  93. 'url' => $item['url']
  94. ];
  95. }
  96. foreach ($product->cad_design as $item){
  97. $files[] = [
  98. 'name' => '产品CAD设计下载',
  99. 'url' => $item['url']
  100. ];
  101. }
  102. foreach ($product->su_model as $item){
  103. $files[] = [
  104. 'name' => '产品SU模型下载',
  105. 'url' => $item['url']
  106. ];
  107. }
  108. $files = array_merge($files,$product->other);
  109. $this->attributes['files'] = $files;
  110. }
  111. public function viewer(): HasMany
  112. {
  113. return $this->hasMany(StatProduct::class,'product_id','id');
  114. }
  115. public function download(): HasMany
  116. {
  117. return $this->hasMany(StatProductDownload::class,'product_id','id');
  118. }
  119. }