Sku.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. namespace Scm_product\Lib;
  3. use Dever;
  4. class Sku
  5. {
  6. # 获取当前的sku
  7. public function get_api()
  8. {
  9. $id = Dever::input('id');
  10. $result = array();
  11. if ($id) {
  12. $result = Dever::db('scm_product/info_sku')->getAll(array('info_id' => $id));
  13. }
  14. return $result;
  15. }
  16. # 获取某个商品的sku商品列表
  17. public function getList($info, &$data)
  18. {
  19. if ($info['spec_type']) {
  20. $where['info_id'] = $info['id'];
  21. if (isset($info['sku_id'])) {
  22. $where['id'] = $info['sku_id'];
  23. }
  24. $sku = Dever::db('scm_product/info_sku')->select($where);
  25. if ($sku) {
  26. foreach ($sku as $k => $v) {
  27. $copy = $info;
  28. $copy['id'] .= '-' . $v['id'];
  29. if (isset($info['supplier_id']) && isset($info['cost_price'])) {
  30. $copy['id'] .= '-' . $info['cost_price'];
  31. }
  32. $key = str_replace('-', ',', $v['key']);
  33. $spec = Dever::db('scm_product/info_spec_value')->getGroupData(array('ids' => $key));
  34. if ($spec) {
  35. $copy['name'] .= '-' . $spec['name'];
  36. if (isset($copy['value'])) {
  37. $copy['value'] = $copy['id'];
  38. }
  39. }
  40. $data[] = $copy;
  41. }
  42. }
  43. } else {
  44. $data[] = $info;
  45. }
  46. return $data;
  47. }
  48. # 获取基本信息列表
  49. public function getData($info_id, $sku_id = false, $type = 1)
  50. {
  51. $seller_id = Dever::input('seller_id');
  52. if ($seller_id) {
  53. $seller = Dever::db('scm_role/seller')->find($seller_id);
  54. }
  55. $where['info_id'] = $info_id;
  56. if ($sku_id) {
  57. $where['id'] = $sku_id;
  58. }
  59. $sku = Dever::db('scm_product/info_sku')->getData($where);
  60. if ($sku) {
  61. foreach ($sku as $k => $v) {
  62. unset($sku[$k]['key']);
  63. if ($seller_id && $seller) {
  64. list($sku[$k]['price'], $sku[$k]['buy_price']) = Dever::load('scm_product/lib/price')->get($seller['price_id'], array('id' => $info_id), $v, $sku[$k]['price'], $sku[$k]['buy_price']);
  65. }
  66. if ($type == 1) {
  67. unset($sku[$k]['buy_price']);
  68. unset($sku[$k]['cost_price']);
  69. } elseif ($type == 2) {
  70. unset($sku[$k]['price']);
  71. unset($sku[$k]['un_price']);
  72. }
  73. }
  74. }
  75. return $sku;
  76. }
  77. }