Sku.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <?php namespace Api\Lib;
  2. use Dever;
  3. class Sku
  4. {
  5. # 获取当前最低价格
  6. public function getPrice($where, $spec_type, $app)
  7. {
  8. $result = [];
  9. if ($spec_type == 2) {
  10. $where['key'] = '-1';
  11. $sku = Dever::db($app . '/sku')->find($where);
  12. } elseif ($spec_type == 3) {
  13. $where['price'] = ['!=', 'null'];
  14. //$where['code'] = ['!=', 'null'];
  15. $sku = Dever::db($app . '/sku')->find($where, ['order' => 'price asc']);
  16. }
  17. if (isset($sku) && $sku && $sku['key']) {
  18. $result['price'] = $sku['price'];
  19. $result['id'] = $sku['id'];
  20. if (isset($sku['unum'])) {
  21. $result['unum'] = $sku['unum'];
  22. }
  23. $result['key'] = str_replace(',', '_', $sku['key']);
  24. $result['name'] = $this->getName($sku['key'], $app);
  25. } else {
  26. Dever::error('价格传入错误');
  27. }
  28. return $result;
  29. }
  30. # 获取价格信息
  31. public function getInfo($where, $app)
  32. {
  33. $where['state'] = 1;
  34. $info = Dever::db($app . '/sku')->find($where);
  35. if ($info) {
  36. unset($info['state']);
  37. unset($info['cdate']);
  38. $info['name'] = $this->getName($info['key'], $app);
  39. if (!$info['pic']) {
  40. $key = explode(',', $info['key']);
  41. $value = Dever::db($app . '/spec_value')->find($key[0], ['col' => 'id,value,pic']);
  42. if ($value && $value['pic']) {
  43. $info['pic'] = $value['pic'];
  44. }
  45. }
  46. }
  47. return $info;
  48. }
  49. # 获取价格列表 废弃 一次性读取不好
  50. /*
  51. public function getList($where, $sku_id, $app)
  52. {
  53. $result = [];
  54. $where['state'] = 1;
  55. $sku = Dever::db($app . '/sku')->select($where);
  56. if ($sku) {
  57. $spec = [];
  58. $result['info'] = [];
  59. foreach ($sku as $k => $v) {
  60. unset($v['state']);
  61. unset($v['cdate']);
  62. $k = $v['key'];
  63. $v['name'] = $this->getName($v['key'], $app);
  64. //$result['price'][$k] = $v;
  65. if ($sku_id && $sku_id == $v['id']) {
  66. $result['info'] = $v;
  67. $spec = explode(',', $v['key']);
  68. }
  69. }
  70. $result['spec'] = Dever::load(Spec::class)->getList($where, $app, $spec);
  71. }
  72. return $result;
  73. }*/
  74. # 获取某个sku的名称
  75. public function getName($key, $app, $show = false)
  76. {
  77. if (!$key || $key == '-1') {
  78. return '默认规格';
  79. } else {
  80. $name = [];
  81. $where['id'] = ['in', $key];
  82. $data = Dever::db($app . '/spec_value')->select($where, array('order' => 'field(id, '.$key.')'));
  83. if ($data) {
  84. foreach ($data as $k => $v) {
  85. $info = Dever::db($app . '/spec')->find($v['spec_id']);
  86. if ($show) {
  87. $name[] = $info['name'] . ':' . $v['value'];
  88. } else {
  89. $name[] = $v['value'];
  90. }
  91. }
  92. }
  93. return implode(' & ', $name);
  94. }
  95. }
  96. # 获取
  97. }