StoreProduct.php 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776
  1. <?php
  2. namespace app\admin\controller\store;
  3. use app\admin\controller\AuthController;
  4. use app\models\system\Tree;
  5. use app\admin\model\store\{
  6. StoreDescription,
  7. StoreProductAttrValue,
  8. StoreProductAttr,
  9. StoreProductAttrResult,
  10. StoreProductCate,
  11. StoreProductRelation,
  12. StoreCategory as CategoryModel,
  13. StoreProduct as ProductModel
  14. };
  15. use app\admin\model\ump\StoreBargain;
  16. use app\admin\model\ump\StoreCombination;
  17. use app\admin\model\ump\StoreSeckill;
  18. use crmeb\services\{
  19. JsonService, UtilService as Util, JsonService as Json, FormBuilder as Form
  20. };
  21. use crmeb\traits\CurdControllerTrait;
  22. use think\facade\Route as Url;
  23. use app\admin\model\system\{SystemAdmin, SystemAttachment, ShippingTemplates, SystemStore};
  24. /**
  25. * 产品管理
  26. * Class StoreProduct
  27. * @package app\admin\controller\store
  28. */
  29. class StoreProduct extends AuthController
  30. {
  31. use CurdControllerTrait;
  32. protected $bindModel = ProductModel::class;
  33. /**
  34. * 显示资源列表
  35. *
  36. * @return \think\Response
  37. */
  38. public function index()
  39. {
  40. $type = $this->request->param('type');
  41. $admin_id=$this->adminId;
  42. $mer_id = SystemAdmin::where('id',$admin_id)->value('mer_id');
  43. //获取分类
  44. $this->assign('cate', CategoryModel::getTierList(null, 1));
  45. if ($mer_id>0){
  46. //出售中产品
  47. $onsale = ProductModel::where('is_del', 0)->where('is_show', 1)->where('mer_id', $mer_id)->count();
  48. //待上架产品
  49. $forsale = ProductModel::where('is_del', 0)->where('is_show', 0)->where('mer_id', $mer_id)->count();
  50. //仓库中产品
  51. $warehouse = ProductModel::where('is_del', 0)->where('mer_id', $mer_id)->count();
  52. //已经售馨产品
  53. $outofstock = ProductModel::getModelObject()->where(ProductModel::setData(4))->where('pav.type', 0)->where('mer_id',$mer_id)->count('DISTINCT id');
  54. //警戒库存
  55. $store_stock = sys_config('store_stock');
  56. if ($store_stock < 0) $store_stock = 2;
  57. $policeforce = ProductModel::getModelObject()->where(ProductModel::setData(5))->where('p.stock', '<=', $store_stock)->where('pav.type', 0)->where('mer_id',$mer_id)->count('DISTINCT id');
  58. //回收站
  59. $recycle = ProductModel::where('is_del', 1)->where('mer_id',$mer_id)->count();
  60. }else{
  61. //出售中产品
  62. $onsale = ProductModel::where('is_del', 0)->where('is_show', 1)->count();
  63. //待上架产品
  64. $forsale = ProductModel::where('is_del', 0)->where('is_show', 0)->count();
  65. //仓库中产品
  66. $warehouse = ProductModel::where('is_del', 0)->count();
  67. //已经售馨产品
  68. $outofstock = ProductModel::getModelObject()->where(ProductModel::setData(4))->where('pav.type', 0)->count('DISTINCT id');
  69. //警戒库存
  70. $store_stock = sys_config('store_stock');
  71. if ($store_stock < 0) $store_stock = 2;
  72. $policeforce = ProductModel::getModelObject()->where(ProductModel::setData(5))->where('p.stock', '<=', $store_stock)->where('pav.type', 0)->count('DISTINCT id');
  73. //回收站
  74. $recycle = ProductModel::where('is_del', 1)->count();
  75. }
  76. if ($type == null) $type = 1;
  77. $adminInfo = $this->adminInfo;
  78. @file_put_contents('quanju.txt', json_encode($adminInfo)."-管理员信息\r\n", 8);
  79. $mer_id = $adminInfo['mer_id'];
  80. $this->assign(compact('type', 'onsale', 'forsale', 'warehouse', 'outofstock', 'policeforce', 'recycle','mer_id'));
  81. return $this->fetch();
  82. }
  83. /**
  84. * 异步查找产品
  85. *
  86. * @return json
  87. */
  88. public function product_ist()
  89. {
  90. $where = Util::getMore([
  91. ['page', 1],
  92. ['limit', 20],
  93. ['store_name', ''],
  94. ['cate_id', ''],
  95. ['excel', 0],
  96. ['order', ''],
  97. ['type', $this->request->param('type')]
  98. ]);
  99. $admin_id=$this->adminId;
  100. $mer_id = SystemAdmin::where('id',$admin_id)->value('mer_id');
  101. if ($mer_id>0){
  102. $where['mer_id'] = $mer_id;
  103. }
  104. return Json::successlayui(ProductModel::ProductList($where));
  105. }
  106. /**
  107. * 设置单个产品上架|下架
  108. *
  109. * @return json
  110. */
  111. public function set_show($is_show = '', $id = '')
  112. {
  113. ($is_show == '' || $id == '') && Json::fail('缺少参数');
  114. $res = ProductModel::where(['id' => $id])->update(['is_show' => (int)$is_show]);
  115. if ($res) {
  116. return Json::successful($is_show == 1 ? '上架成功' : '下架成功');
  117. } else {
  118. return Json::fail($is_show == 1 ? '上架失败' : '下架失败');
  119. }
  120. }
  121. /**
  122. * 快速编辑
  123. *
  124. * @return json
  125. */
  126. public function set_product($field = '', $id = '', $value = '')
  127. {
  128. $field == '' || $id == '' || $value == '' && Json::fail('缺少参数');
  129. if (ProductModel::where(['id' => $id])->update([$field => $value]))
  130. return Json::successful('保存成功');
  131. else
  132. return Json::fail('保存失败');
  133. }
  134. /**
  135. * 设置批量产品上架
  136. *
  137. * @return json
  138. */
  139. public function product_show()
  140. {
  141. $post = Util::postMore([
  142. ['ids', []]
  143. ]);
  144. if (empty($post['ids'])) {
  145. return Json::fail('请选择需要上架的产品');
  146. } else {
  147. $res = ProductModel::where('id', 'in', $post['ids'])->update(['is_show' => 1]);
  148. if ($res)
  149. return Json::successful('上架成功');
  150. else
  151. return Json::fail('上架失败');
  152. }
  153. }
  154. /**
  155. * 显示创建资源表单页.
  156. *
  157. * @return \think\Response
  158. */
  159. public function create($id = 0)
  160. {
  161. $this->assign('id', (int)$id);
  162. return $this->fetch();
  163. }
  164. /**
  165. * 获取规则属性模板
  166. * @throws \think\db\exception\DataNotFoundException
  167. * @throws \think\db\exception\DbException
  168. * @throws \think\db\exception\ModelNotFoundException
  169. */
  170. public function get_rule()
  171. {
  172. return Json::successful(\app\models\store\StoreProductRule::field(['rule_name', 'rule_value'])->select()->each(function ($item) {
  173. $item['rule_value'] = json_decode($item['rule_value'], true);
  174. })->toArray());
  175. }
  176. /**
  177. * 获取产品详细信息
  178. * @param int $id
  179. * @throws \think\db\exception\DataNotFoundException
  180. * @throws \think\db\exception\DbException
  181. * @throws \think\db\exception\ModelNotFoundException
  182. */
  183. public function get_product_info($id = 0)
  184. {
  185. $list = CategoryModel::getTierList(null, 1);
  186. $menus = [];
  187. foreach ($list as $menu) {
  188. $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0 ? 0 : 1];//,'disabled'=>$menu['pid']== 0];
  189. }
  190. $data['tempList'] = ShippingTemplates::order('sort', 'desc')->field(['id', 'name'])->select()->toArray();
  191. $data['merList'] = SystemStore::where('is_show',1)->where('is_del',0)->order('id', 'desc')->field(['id', 'name as store_name'])->select()->toArray();
  192. $data['cateList'] = $menus;
  193. $data['productInfo'] = [];
  194. if ($id) {
  195. $productInfo = ProductModel::get($id);
  196. if (!$productInfo) {
  197. return Json::fail('修改的产品不存在');
  198. }
  199. $productInfo['cate_id'] = explode(',', $productInfo['cate_id']);
  200. $productInfo['description'] = htmlspecialchars_decode(StoreDescription::getDescription($id));
  201. $productInfo['slider_image'] = is_string($productInfo['slider_image']) ? json_decode($productInfo['slider_image'], true) : [];
  202. if ($productInfo['spec_type'] == 1) {
  203. $result = StoreProductAttrResult::getResult($id);
  204. foreach ($result['value'] as $k => $v) {
  205. $num = 1;
  206. foreach ($v['detail'] as $dv) {
  207. $result['value'][$k]['value' . $num] = $dv;
  208. $num++;
  209. }
  210. }
  211. $productInfo['items'] = $result['attr'] ?? [];
  212. $productInfo['attrs'] = $result['value'] ?? [];
  213. $productInfo['attr'] = ['pic' => '', 'price' => 0, 'integral' => 0, 'cost' => 0, 'ot_price' => 0, 'stock' => 0, 'bar_code' => '', 'weight' => 0, 'volume' => 0, 'brokerage' => 0, 'brokerage_two' => 0];
  214. } else {
  215. $result = StoreProductAttrResult::getResult($id);
  216. $single = isset($result['value'][0]) ? $result['value'][0] : [];
  217. $productInfo['items'] = [];
  218. $productInfo['attrs'] = [];
  219. $productInfo['attr'] = [
  220. 'pic' => $single['pic'] ?? '',
  221. 'price' => $single['price'] ?? 0,
  222. 'integral' => $single['integral'] ?? 0,
  223. 'cost' => $single['cost'] ?? 0,
  224. 'ot_price' => $single['ot_price'] ?? 0,
  225. 'stock' => $single['stock'] ?? 0,
  226. 'bar_code' => $single['bar_code'] ?? '',
  227. 'weight' => $single['weight'] ?? 0,
  228. 'volume' => $single['volume'] ?? 0,
  229. 'brokerage' => $single['brokerage'] ?? 0,
  230. 'brokerage_two' => $single['brokerage_two'] ?? 0,
  231. ];
  232. }
  233. if ($productInfo['activity']) {
  234. $activity = explode(',', $productInfo['activity']);
  235. foreach ($activity as $k => $v) {
  236. if ($v == 1) {
  237. $activity[$k] = '秒杀';
  238. } elseif ($v == 2) {
  239. $activity[$k] = '砍价';
  240. } elseif ($v == 3) {
  241. $activity[$k] = '拼团';
  242. }
  243. }
  244. $productInfo['activity'] = $activity;
  245. } else {
  246. $productInfo['activity'] = ['秒杀', '砍价', '拼团'];
  247. }
  248. $data['productInfo'] = $productInfo;
  249. }
  250. return JsonService::successful($data);
  251. }
  252. /**
  253. * 保存新建的资源
  254. *
  255. *
  256. */
  257. public function save($id)
  258. {
  259. $data = Util::postMore([
  260. ['cate_id', []],
  261. 'store_name',
  262. 'store_info',
  263. 'keyword',
  264. ['unit_name', '件'],
  265. ['image', []],
  266. ['slider_image', []],
  267. ['postage', 0],
  268. ['is_sub', 0],
  269. ['sort', 0],
  270. ['sales', 0],
  271. ['ficti', 100],
  272. ['rebate_ratio', 0],
  273. ['give_integral', 0],
  274. ['is_show', 0],
  275. ['temp_id', 0],
  276. ['is_hot', 0],
  277. ['is_benefit', 0],
  278. ['is_best', 0],
  279. ['is_new', 0],
  280. ['is_wholesale', 0],
  281. ['mer_use', 0],
  282. ['is_postage', 0],
  283. ['is_good', 0],
  284. // ['description', ''],
  285. ['spec_type', 0],
  286. ['video_link', ''],
  287. ['items', []],
  288. ['attrs', []],
  289. ['activity', []],
  290. ['store_type', 1],
  291. ['mer_id',0]
  292. ], $this->request, false, true);
  293. $admin_id=$this->adminId;
  294. $mer_id = SystemAdmin::where('id',$admin_id)->value('mer_id');
  295. if ($mer_id>0){
  296. $data['mer_id'] = $mer_id;
  297. }
  298. foreach ($data['activity'] as $k => $v) {
  299. if ($v == '秒杀') {
  300. $data['activity'][$k] = 1;
  301. } elseif ($v == '砍价') {
  302. $data['activity'][$k] = 2;
  303. } else {
  304. $data['activity'][$k] = 3;
  305. }
  306. }
  307. $data['description'] = $this->request->post('description', '');
  308. $data['activity'] = implode(',', $data['activity']);
  309. $detail = $data['attrs'];
  310. $data['price'] = min(array_column($detail, 'price'));
  311. $data['min_integral'] = min(array_column($detail, 'integral'));
  312. $data['max_integral'] = max(array_column($detail, 'integral'));
  313. $data['ot_price'] = min(array_column($detail, 'ot_price'));
  314. $data['cost'] = min(array_column($detail, 'cost'));
  315. $attr = $data['items'];
  316. unset($data['items'], $data['video'], $data['attrs']);
  317. if (count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
  318. if (!in_array($data['store_type'], [1, 2])) return Json::fail('请选择正确的商品类型');
  319. $cate_id = $data['cate_id'];
  320. $data['cate_id'] = implode(',', $data['cate_id']);
  321. if (!$data['store_name']) return Json::fail('请输入产品名称');
  322. if (count($data['image']) < 1) return Json::fail('请上传产品图片');
  323. if (count($data['slider_image']) < 1) return Json::fail('请上传产品轮播图');
  324. if ($data['rebate_ratio']>10) return Json::fail('返利比例不能大于10%');
  325. $data['image'] = $data['image'][0];
  326. $data['slider_image'] = json_encode($data['slider_image']);
  327. $data['stock'] = array_sum(array_column($detail, 'stock'));
  328. ProductModel::beginTrans();
  329. foreach ($detail as &$item) {
  330. if (($item['brokerage'] + $item['brokerage_two']) > $item['price']) {
  331. return Json::fail('一二级返佣相加不能大于商品售价');
  332. }
  333. }
  334. if ($id) {
  335. unset($data['sales']);
  336. ProductModel::edit($data, $id);
  337. $description = $data['description'];
  338. unset($data['description']);
  339. StoreDescription::saveDescription($description, $id);
  340. StoreProductCate::where('product_id', $id)->delete();
  341. $cateData = [];
  342. foreach ($cate_id as $cid) {
  343. $cateData[] = ['product_id' => $id, 'cate_id' => $cid, 'add_time' => time()];
  344. }
  345. StoreProductCate::insertAll($cateData);
  346. if ($data['spec_type'] == 0) {
  347. $attr = [
  348. [
  349. 'value' => '规格',
  350. 'detailValue' => '',
  351. 'attrHidden' => '',
  352. 'detail' => ['默认']
  353. ]
  354. ];
  355. $detail[0]['value1'] = '规格';
  356. $detail[0]['detail'] = ['规格' => '默认'];
  357. }
  358. $attr_res = StoreProductAttr::createProductAttr($attr, $detail, $id);
  359. if ($attr_res) {
  360. ProductModel::commitTrans();
  361. return Json::success('修改成功!');
  362. } else {
  363. ProductModel::rollbackTrans();
  364. return Json::fail(StoreProductAttr::getErrorInfo());
  365. }
  366. } else {
  367. $data['add_time'] = time();
  368. $data['code_path'] = '';
  369. $res = ProductModel::create($data);
  370. $description = $data['description'];
  371. StoreDescription::saveDescription($description, $res['id']);
  372. $cateData = [];
  373. foreach ($cate_id as $cid) {
  374. $cateData[] = ['product_id' => $res['id'], 'cate_id' => $cid, 'add_time' => time()];
  375. }
  376. StoreProductCate::insertAll($cateData);
  377. if ($data['spec_type'] == 0) {
  378. $attr = [
  379. [
  380. 'value' => '规格',
  381. 'detailValue' => '',
  382. 'attrHidden' => '',
  383. 'detail' => ['默认']
  384. ]
  385. ];
  386. $detail[0]['value1'] = '规格';
  387. $detail[0]['detail'] = ['规格' => '默认'];
  388. }
  389. $attr_res = StoreProductAttr::createProductAttr($attr, $detail, $res['id']);
  390. if ($attr_res) {
  391. ProductModel::commitTrans();
  392. return Json::success('添加产品成功!');
  393. } else {
  394. ProductModel::rollbackTrans();
  395. return Json::fail(StoreProductAttr::getErrorInfo());
  396. }
  397. }
  398. }
  399. public function edit_content($id)
  400. {
  401. if (!$id) return $this->failed('数据不存在');
  402. $product = ProductModel::get($id);
  403. if (!$product) return Json::fail('数据不存在!');
  404. $this->assign([
  405. 'content' => $product->description,
  406. 'field' => 'description',
  407. 'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
  408. ]);
  409. return $this->fetch('public/edit_content');
  410. }
  411. /**
  412. * 显示编辑资源表单页.
  413. *
  414. * @param int $id
  415. * @return \think\Response
  416. */
  417. public function edit($id)
  418. {
  419. if (!$id) return $this->failed('数据不存在');
  420. $product = ProductModel::get($id);
  421. if (!$product) return Json::fail('数据不存在!');
  422. $field = [
  423. Form::select('cate_id', '产品分类', explode(',', $product->getData('cate_id')))->setOptions(function () {
  424. $list = CategoryModel::getTierList(null, 1);
  425. $menus = [];
  426. foreach ($list as $menu) {
  427. $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0];//,'disabled'=>$menu['pid']== 0];
  428. }
  429. return $menus;
  430. })->filterable(1)->multiple(1),
  431. Form::input('store_name', '产品名称', $product->getData('store_name')),
  432. Form::input('store_info', '产品简介', $product->getData('store_info'))->type('textarea'),
  433. Form::input('keyword', '产品关键字', $product->getData('keyword'))->placeholder('多个用英文状态下的逗号隔开'),
  434. Form::input('unit_name', '产品单位', $product->getData('unit_name'))->col(12),
  435. Form::input('bar_code', '产品条码', $product->getData('bar_code'))->col(12),
  436. Form::frameImageOne('image', '产品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px'),
  437. Form::frameImages('slider_image', '产品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'slider_image')), json_decode($product->getData('slider_image'), 1) ?: [])->maxLength(5)->icon('images')->width('100%')->height('500px'),
  438. Form::number('price', '产品售价', $product->getData('price'))->min(0)->col(8),
  439. Form::number('ot_price', '产品市场价', $product->getData('ot_price'))->min(0)->col(8),
  440. Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->col(8),
  441. Form::number('postage', '邮费', $product->getData('postage'))->min(0)->col(8),
  442. Form::number('sales', '销量', $product->getData('sales'))->min(0)->precision(0)->col(8)->readonly(1),
  443. Form::number('ficti', '虚拟销量', $product->getData('ficti'))->min(0)->precision(0)->col(8),
  444. Form::number('rebate_ratio', '返利点数', $product->getData('rebate_ratio'))->min(0)->precision(0)->col(8),
  445. Form::number('stock', '库存', ProductModel::getStock($id) > 0 ? ProductModel::getStock($id) : $product->getData('stock'))->min(0)->precision(0)->col(8),
  446. Form::number('cost', '产品成本价', $product->getData('cost'))->min(0)->col(8),
  447. Form::number('sort', '排序', $product->getData('sort'))->col(8),
  448. Form::radio('is_show', '产品状态', $product->getData('is_show'))->options([['label' => '上架', 'value' => 1], ['label' => '下架', 'value' => 0]])->col(8),
  449. Form::radio('is_hot', '热卖单品', $product->getData('is_hot'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  450. Form::radio('is_benefit', '促销单品', $product->getData('is_benefit'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  451. Form::radio('is_best', '精品推荐', $product->getData('is_best'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  452. Form::radio('is_new', '首发新品', $product->getData('is_new'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  453. Form::radio('is_postage', '是否包邮', $product->getData('is_postage'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  454. Form::radio('is_good', '是否优品推荐', $product->getData('is_good'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  455. Form::radio('is_wholesale', '是否批发商品', $product->getData('is_wholesale'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
  456. ];
  457. $form = Form::make_post_form('编辑产品', $field, Url::buildUrl('update', array('id' => $id)), 2);
  458. $this->assign(compact('form'));
  459. return $this->fetch('public/form-builder');
  460. }
  461. /**
  462. * 保存更新的资源
  463. *
  464. * @param $id
  465. */
  466. public function update($id)
  467. {
  468. $data = Util::postMore([
  469. ['cate_id', []],
  470. 'store_name',
  471. 'store_info',
  472. 'keyword',
  473. 'bar_code',
  474. ['unit_name', '件'],
  475. ['image', []],
  476. ['slider_image', []],
  477. ['postage', 0],
  478. ['ot_price', 0],
  479. ['price', 0],
  480. ['sort', 0],
  481. ['stock', 0],
  482. ['temp_id', 0],
  483. ['ficti', 100],
  484. ['rebate_ratio', 0],
  485. ['give_integral', 0],
  486. ['is_show', 0],
  487. ['cost', 0],
  488. ['is_hot', 0],
  489. ['is_benefit', 0],
  490. ['is_best', 0],
  491. ['is_new', 0],
  492. ['mer_use', 0],
  493. ['is_postage', 0],
  494. ['is_good', 0],
  495. ['is_wholesale',0],
  496. ['mer_id',0]
  497. ]);
  498. if (count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
  499. $cate_id = $data['cate_id'];
  500. $data['cate_id'] = implode(',', $data['cate_id']);
  501. if (!$data['store_name']) return Json::fail('请输入产品名称');
  502. if (count($data['image']) < 1) return Json::fail('请上传产品图片');
  503. if (count($data['slider_image']) < 1) return Json::fail('请上传产品轮播图');
  504. // if(count($data['slider_image'])>8) return Json::fail('轮播图最多5张图');
  505. if ($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品售价');
  506. if ($data['ot_price'] == '' || $data['ot_price'] < 0) return Json::fail('请输入产品市场价');
  507. if ($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
  508. if($data['rebate_ratio']>10) return Json::fail('返利比例不能大于10%');
  509. $data['image'] = $data['image'][0];
  510. $data['slider_image'] = json_encode($data['slider_image']);
  511. ProductModel::edit($data, $id);
  512. StoreProductCate::where('product_id', $id)->delete();
  513. foreach ($cate_id as $cid) {
  514. StoreProductCate::insert(['product_id' => $id, 'cate_id' => $cid, 'add_time' => time()]);
  515. }
  516. return Json::successful('修改成功!');
  517. }
  518. public function attr($id)
  519. {
  520. if (!$id) return $this->failed('数据不存在!');
  521. // $result = StoreProductAttrResult::getResult($id);
  522. $result = StoreProductAttrValue::getStoreProductAttrResult($id);
  523. $image = ProductModel::where('id', $id)->value('image');
  524. $this->assign(compact('id', 'result', 'image'));
  525. return $this->fetch();
  526. }
  527. /**
  528. * 生成属性
  529. * @param int $id
  530. */
  531. public function is_format_attr($id = 0)
  532. {
  533. $data = Util::postMore([
  534. ['attrs', []],
  535. ['items', []]
  536. ]);
  537. $attr = $data['attrs'];
  538. $value = attr_format($attr)[1];
  539. $valueNew = [];
  540. $count = 0;
  541. foreach ($value as $key => $item) {
  542. $detail = $item['detail'];
  543. // sort($item['detail'], SORT_STRING);
  544. $suk = implode(',', $item['detail']);
  545. if ($id) {
  546. $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', 0)->where('suk', $suk)->column('bar_code,cost,price,ot_price,integral,stock,image as pic,weight,volume,brokerage,brokerage_two', 'suk');
  547. if (!count($sukValue)) {
  548. $sukValue[$suk]['pic'] = '';
  549. $sukValue[$suk]['price'] = 0;
  550. $sukValue[$suk]['integral'] = 0;
  551. $sukValue[$suk]['cost'] = 0;
  552. $sukValue[$suk]['ot_price'] = 0;
  553. $sukValue[$suk]['stock'] = 0;
  554. $sukValue[$suk]['bar_code'] = '';
  555. $sukValue[$suk]['weight'] = 0;
  556. $sukValue[$suk]['volume'] = 0;
  557. $sukValue[$suk]['brokerage'] = 0;
  558. $sukValue[$suk]['brokerage_two'] = 0;
  559. }
  560. } else {
  561. $sukValue[$suk]['pic'] = '';
  562. $sukValue[$suk]['price'] = 0;
  563. $sukValue[$suk]['integral'] = 0;
  564. $sukValue[$suk]['cost'] = 0;
  565. $sukValue[$suk]['ot_price'] = 0;
  566. $sukValue[$suk]['stock'] = 0;
  567. $sukValue[$suk]['bar_code'] = '';
  568. $sukValue[$suk]['weight'] = 0;
  569. $sukValue[$suk]['volume'] = 0;
  570. $sukValue[$suk]['brokerage'] = 0;
  571. $sukValue[$suk]['brokerage_two'] = 0;
  572. }
  573. foreach (array_keys($detail) as $k => $title) {
  574. $header[$k]['title'] = $title;
  575. $header[$k]['align'] = 'center';
  576. $header[$k]['minWidth'] = 130;
  577. }
  578. foreach (array_values($detail) as $k => $v) {
  579. $valueNew[$count]['value' . ($k + 1)] = $v;
  580. $header[$k]['key'] = 'value' . ($k + 1);
  581. }
  582. $valueNew[$count]['detail'] = $detail;
  583. $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
  584. $valueNew[$count]['price'] = $sukValue[$suk]['price'] ? floatval($sukValue[$suk]['price']) : 0;
  585. $valueNew[$count]['integral'] = $sukValue[$suk]['integral'] ? floatval($sukValue[$suk]['integral']) : 0;
  586. $valueNew[$count]['cost'] = $sukValue[$suk]['cost'] ? floatval($sukValue[$suk]['cost']) : 0;
  587. $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
  588. $valueNew[$count]['stock'] = $sukValue[$suk]['stock'] ? intval($sukValue[$suk]['stock']) : 0;
  589. $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
  590. $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
  591. $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
  592. $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
  593. $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
  594. $count++;
  595. }
  596. $header[] = ['title' => '图片', 'slot' => 'pic', 'align' => 'center', 'minWidth' => 80];
  597. $header[] = ['title' => '售价', 'slot' => 'price', 'align' => 'center', 'minWidth' => 120];
  598. $header[] = ['title' => '积分', 'slot' => 'integral', 'align' => 'center', 'minWidth' => 120];
  599. $header[] = ['title' => '成本价', 'slot' => 'cost', 'align' => 'center', 'minWidth' => 140];
  600. $header[] = ['title' => '原价', 'slot' => 'ot_price', 'align' => 'center', 'minWidth' => 140];
  601. $header[] = ['title' => '库存', 'slot' => 'stock', 'align' => 'center', 'minWidth' => 140];
  602. $header[] = ['title' => '产品编号', 'slot' => 'bar_code', 'align' => 'center', 'minWidth' => 140];
  603. $header[] = ['title' => '重量(KG)', 'slot' => 'weight', 'align' => 'center', 'minWidth' => 140];
  604. $header[] = ['title' => '体积(m³)', 'slot' => 'volume', 'align' => 'center', 'minWidth' => 140];
  605. $header[] = ['title' => '操作', 'slot' => 'action', 'align' => 'center', 'minWidth' => 70];
  606. $info = ['attr' => $attr, 'value' => $valueNew, 'header' => $header];
  607. return Json::successful($info);
  608. }
  609. public function set_attr($id)
  610. {
  611. if (!$id) return $this->failed('产品不存在!');
  612. list($attr, $detail) = Util::postMore([
  613. ['items', []],
  614. ['attrs', []]
  615. ], null, true);
  616. $res = StoreProductAttr::createProductAttr($attr, $detail, $id);
  617. if ($res)
  618. return $this->successful('编辑属性成功!');
  619. else
  620. return $this->failed(StoreProductAttr::getErrorInfo());
  621. }
  622. public function clear_attr($id)
  623. {
  624. if (!$id) return $this->failed('产品不存在!');
  625. if (false !== StoreProductAttr::clearProductAttr($id) && false !== StoreProductAttrResult::clearResult($id))
  626. return $this->successful('清空产品属性成功!');
  627. else
  628. return $this->failed(StoreProductAttr::getErrorInfo('清空产品属性失败!'));
  629. }
  630. /**
  631. * 删除指定资源
  632. *
  633. * @param int $id
  634. * @return \think\Response
  635. */
  636. public function delete($id)
  637. {
  638. if (!$id) return $this->failed('数据不存在');
  639. if (!ProductModel::be(['id' => $id])) return $this->failed('产品数据不存在');
  640. if (ProductModel::be(['id' => $id, 'is_del' => 1])) {
  641. $data['is_del'] = 0;
  642. if (!ProductModel::edit($data, $id))
  643. return Json::fail(ProductModel::getErrorInfo('恢复失败,请稍候再试!'));
  644. else
  645. return Json::successful('成功恢复产品!');
  646. } else {
  647. $res1 = StoreSeckill::where('product_id', $id)->where('is_del', 0)->find();
  648. $res2 = StoreBargain::where('product_id', $id)->where('is_del', 0)->find();
  649. $res3 = StoreCombination::where('product_id', $id)->where('is_del', 0)->find();
  650. if ($res1 || $res2 || $res3) {
  651. return Json::fail(ProductModel::getErrorInfo('该商品已参加活动,无法删除!'));
  652. } else {
  653. $data['is_del'] = 1;
  654. if (!ProductModel::edit($data, $id))
  655. return Json::fail(ProductModel::getErrorInfo('删除失败,请稍候再试!'));
  656. else
  657. return Json::successful('成功移到回收站!');
  658. }
  659. }
  660. }
  661. /**
  662. * 点赞
  663. * @param $id
  664. * @return mixed|\think\response\Json|void
  665. */
  666. public function collect($id)
  667. {
  668. if (!$id) return $this->failed('数据不存在');
  669. $product = ProductModel::get($id);
  670. if (!$product) return Json::fail('数据不存在!');
  671. $this->assign(StoreProductRelation::getCollect($id));
  672. return $this->fetch();
  673. }
  674. /**
  675. * 收藏
  676. * @param $id
  677. * @return mixed|\think\response\Json|void
  678. */
  679. public function like($id)
  680. {
  681. if (!$id) return $this->failed('数据不存在');
  682. $product = ProductModel::get($id);
  683. if (!$product) return Json::fail('数据不存在!');
  684. $this->assign(StoreProductRelation::getLike($id));
  685. return $this->fetch();
  686. }
  687. /**
  688. * 修改产品价格
  689. */
  690. public function edit_product_price()
  691. {
  692. $data = Util::postMore([
  693. ['id', 0],
  694. ['price', 0],
  695. ]);
  696. if (!$data['id']) return Json::fail('参数错误');
  697. $res = ProductModel::edit(['price' => $data['price']], $data['id']);
  698. if ($res) return Json::successful('修改成功');
  699. else return Json::fail('修改失败');
  700. }
  701. /**
  702. * 修改产品库存
  703. *
  704. */
  705. public function edit_product_stock()
  706. {
  707. $data = Util::postMore([
  708. ['id', 0],
  709. ['stock', 0],
  710. ]);
  711. if (!$data['id']) return Json::fail('参数错误');
  712. $res = ProductModel::edit(['stock' => $data['stock']], $data['id']);
  713. if ($res) return Json::successful('修改成功');
  714. else return Json::fail('修改失败');
  715. }
  716. /**
  717. * 检测商品是否开活动
  718. * @param $id
  719. * @throws \think\db\exception\DataNotFoundException
  720. * @throws \think\db\exception\DbException
  721. * @throws \think\db\exception\ModelNotFoundException
  722. */
  723. public function check_activity($id)
  724. {
  725. if ($id != 0) {
  726. $res1 = StoreSeckill::where('product_id', $id)->where('is_del', 0)->find();
  727. $res2 = StoreBargain::where('product_id', $id)->where('is_del', 0)->find();
  728. $res3 = StoreCombination::where('product_id', $id)->where('is_del', 0)->find();
  729. if ($res1 || $res2 || $res3) {
  730. return Json::successful('该商品有活动开启,无法删除属性');
  731. } else {
  732. return Json::fail();
  733. }
  734. } else {
  735. return Json::fail();
  736. }
  737. }
  738. }