Sku.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php namespace Api\Lib;
  2. use Dever;
  3. class Sku
  4. {
  5. # 获取当前价格
  6. public function getPrice($where, $spec_type, $app)
  7. {
  8. $result['price'] = 0;
  9. $result['id'] = 0;
  10. $result['name'] = '';
  11. if ($spec_type == 2) {
  12. $where['key'] = '-1';
  13. $sku = Dever::db('sku', $app)->find($where);
  14. } elseif ($spec_type == 3) {
  15. $sku = Dever::db('sku', $app)->find($where, array('order' => 'price asc,id desc'));
  16. }
  17. if (isset($sku) && $sku) {
  18. $result['price'] = $sku['price'];
  19. $result['id'] = $sku['id'];
  20. $result['name'] = $this->getName($sku['key'], $app);
  21. }
  22. return $result;
  23. }
  24. # 多规格获取多个价格
  25. public function getList($where, $sku_id, $app)
  26. {
  27. $result = array();
  28. $sku = Dever::db('sku', $app)->select($where, array('order' => 'price asc,id desc'));
  29. if ($sku) {
  30. $result['info'] = array();
  31. $result['spec'] = Dever::load('spec', 'api')->getList($where, $app);
  32. foreach ($sku as $k => $v) {
  33. $t = array();
  34. $k = str_replace(',', '_', $v['key']);
  35. $t['id'] = $v['id'];
  36. $t['pic'] = $v['pic'];
  37. $t['value'] = $v['price'];
  38. $result['price'][$k] = $t;
  39. if ($sku_id && $sku_id == $v['id']) {
  40. $t['name'] = $this->getName($v['key'], $app);
  41. $result['info'] = $t;
  42. }
  43. }
  44. }
  45. return $result;
  46. }
  47. # 获取某个sku的名称
  48. public function getName($key, $app)
  49. {
  50. if (!$key || $key == '-1') {
  51. return '';
  52. } else {
  53. $name = array();
  54. $where['id'] = array('in', $key);
  55. $data = Dever::db('spec_value', $app)->select($where);
  56. if ($data) {
  57. foreach ($data as $k => $v) {
  58. $info = Dever::db('spec', $app)->find($v['spec_id']);
  59. $name[] = $info['name'] . ':' . $v['value'];
  60. }
  61. }
  62. return implode(',', $name);
  63. }
  64. }
  65. }