Sku.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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('sku', $app)->find($where);
  12. } elseif ($spec_type == 3) {
  13. $sku = Dever::db('sku', $app)->find($where, ['order' => 'price asc']);
  14. }
  15. if (isset($sku) && $sku && $sku['key']) {
  16. $result['price'] = $sku['price'];
  17. $result['id'] = $sku['id'];
  18. if (isset($sku['unum'])) {
  19. $result['unum'] = $sku['unum'];
  20. }
  21. $result['key'] = str_replace(',', '_', $sku['key']);
  22. $result['name'] = $this->getName($sku['key'], $app);
  23. } else {
  24. Dever::error('价格传入错误');
  25. }
  26. return $result;
  27. }
  28. # 获取价格信息
  29. public function getInfo($where, $app)
  30. {
  31. $where['state'] = 1;
  32. $info = Dever::db('sku', $app)->find($where);
  33. if ($info) {
  34. $info['name'] = $this->getName($info['key'], $app);
  35. if (!$info['pic']) {
  36. $key = explode(',', $info['key']);
  37. $value = Dever::db('spec_value', $app)->find($key[0], ['col' => 'id,value,pic']);
  38. if ($value && $value['pic']) {
  39. $info['pic'] = $value['pic'];
  40. }
  41. }
  42. }
  43. return $info;
  44. }
  45. # 获取价格列表
  46. public function getList($where, $sku_id, $app)
  47. {
  48. $result = [];
  49. $where['state'] = 1;
  50. $sku = Dever::db('sku', $app)->select($where);
  51. if ($sku) {
  52. $spec = [];
  53. $result['info'] = [];
  54. foreach ($sku as $k => $v) {
  55. unset($v['state']);
  56. unset($v['cdate']);
  57. $k = $v['key'];
  58. $v['name'] = $this->getName($v['key'], $app);
  59. $result['price'][$k] = $v;
  60. if ($sku_id && $sku_id == $v['id']) {
  61. $result['info'] = $v;
  62. $spec = explode(',', $v['key']);
  63. }
  64. }
  65. $result['spec'] = Dever::load('spec', 'api')->getList($where, $app, $spec);
  66. }
  67. return $result;
  68. }
  69. # 获取某个sku的名称
  70. public function getName($key, $app, $show = false)
  71. {
  72. if (!$key || $key == '-1') {
  73. return '默认规格';
  74. } else {
  75. $name = [];
  76. $where['id'] = ['in', $key];
  77. $data = Dever::db('spec_value', $app)->select($where, array('order' => 'field(id, '.$key.')'));
  78. if ($data) {
  79. foreach ($data as $k => $v) {
  80. $info = Dever::db('spec', $app)->find($v['spec_id']);
  81. if ($show) {
  82. $name[] = $info['name'] . ':' . $v['value'];
  83. } else {
  84. $name[] = $v['value'];
  85. }
  86. }
  87. }
  88. return implode(' & ', $name);
  89. }
  90. }
  91. # 获取
  92. }