Sku.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php namespace Api\Lib;
  2. use Dever;
  3. class Sku
  4. {
  5. # 获取当前最低价格
  6. public function getPrice($where, $spec_type, $app)
  7. {
  8. $result = array();
  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, array('order' => 'price asc,id desc'));
  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 getList($where, $sku_id, $app)
  30. {
  31. $result = array();
  32. $sku = Dever::db('sku', $app)->select($where);
  33. if ($sku) {
  34. $spec = array();
  35. $result['info'] = array();
  36. foreach ($sku as $k => $v) {
  37. $t = $where;
  38. $k = str_replace(',', '_', $v['key']);
  39. $t['id'] = $v['id'];
  40. $t['key'] = $k;
  41. $t['pic'] = $v['pic'];
  42. $t['price'] = $v['price'];
  43. if (isset($v['unum'])) {
  44. $t['unum'] = $v['unum'];
  45. }
  46. $t['name'] = $this->getName($v['key'], $app);
  47. $result['price'][$k] = $t;
  48. if ($sku_id && $sku_id == $v['id']) {
  49. $result['info'] = $t;
  50. $spec = explode(',', $v['key']);
  51. }
  52. }
  53. $result['spec'] = Dever::load('spec', 'api')->getList($where, $app, $spec);
  54. }
  55. return $result;
  56. }
  57. # 获取某个sku的名称
  58. public function getName($key, $app)
  59. {
  60. if (!$key || $key == '-1') {
  61. return '默认规格';
  62. } else {
  63. $name = array();
  64. $where['id'] = array('in', $key);
  65. $data = Dever::db('spec_value', $app)->select($where, array('order' => 'field(id, '.$key.')'));
  66. if ($data) {
  67. foreach ($data as $k => $v) {
  68. $info = Dever::db('spec', $app)->find($v['spec_id']);
  69. //$name[] = $info['name'] . ':' . $v['value'];
  70. $name[] = $v['value'];
  71. }
  72. }
  73. return implode(' & ', $name);
  74. }
  75. }
  76. }