Sellerpromotionwholesale.php 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523
  1. <?php
  2. namespace app\home\controller;
  3. use think\facade\View;
  4. use think\facade\Lang;
  5. use think\facade\Db;
  6. /**
  7. * ============================================================================
  8. * DSMall多用户商城
  9. * ============================================================================
  10. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  11. * 网站地址: http://www.csdeshang.com
  12. * ----------------------------------------------------------------------------
  13. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  14. * 不允许对程序代码以任何形式任何目的的再发布。
  15. * ============================================================================
  16. * 控制器
  17. */
  18. class Sellerpromotionwholesale extends BaseSeller {
  19. public function initialize() {
  20. parent::initialize(); // TODO: Change the autogenerated stub
  21. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/sellerpromotionwholesale.lang.php');
  22. if (intval(config('ds_config.promotion_allow')) !== 1) {
  23. $this->error(lang('promotion_unavailable'), 'seller/index');
  24. }
  25. }
  26. public function index() {
  27. $wholesalequota_model = model('wholesalequota');
  28. $wholesale_model = model('wholesale');
  29. if (check_platform_store()) {
  30. View::assign('isPlatformStore', true);
  31. } else {
  32. $current_wholesale_quota = $wholesalequota_model->getWholesalequotaCurrent(session('store_id'));
  33. View::assign('current_wholesale_quota', $current_wholesale_quota);
  34. }
  35. $condition = array();
  36. $condition[] = array('store_id', '=', session('store_id'));
  37. if ((input('param.wholesale_name'))) {
  38. $condition[] = array('goods_name', 'like', '%' . input('param.wholesale_name') . '%');
  39. }
  40. if ((input('param.state'))) {
  41. $condition[] = array('wholesale_state', '=', intval(input('param.state')));
  42. }
  43. $wholesale_list = $wholesale_model->getWholesaleList($condition, 10, 'wholesale_state desc, wholesale_end_time desc');
  44. View::assign('wholesale_list', $wholesale_list);
  45. View::assign('show_page', $wholesale_model->page_info->render());
  46. View::assign('wholesale_state_array', $wholesale_model->getWholesaleStateArray());
  47. $this->setSellerCurMenu('Sellerpromotionwholesale');
  48. $this->setSellerCurItem('wholesale_list');
  49. return View::fetch($this->template_dir . 'index');
  50. }
  51. /**
  52. * 添加批发活动
  53. * */
  54. public function wholesale_add() {
  55. if (check_platform_store()) {
  56. View::assign('isPlatformStore', true);
  57. } else {
  58. View::assign('isPlatformStore', false);
  59. $wholesalequota_model = model('wholesalequota');
  60. $current_wholesale_quota = $wholesalequota_model->getWholesalequotaCurrent(session('store_id'));
  61. if (empty($current_wholesale_quota)) {
  62. if (intval(config('ds_config.promotion_wholesale_price')) != 0) {
  63. $this->error(lang('wholesale_quota_current_error1'));
  64. } else {
  65. $current_wholesale_quota = array('wholesalequota_starttime' => TIMESTAMP, 'wholesalequota_endtime' => TIMESTAMP + 86400 * 30); //没有套餐时,最多一个月
  66. }
  67. }
  68. View::assign('current_wholesale_quota', $current_wholesale_quota);
  69. }
  70. //输出导航
  71. $this->setSellerCurMenu('Sellerpromotionwholesale');
  72. $this->setSellerCurItem('wholesale_add');
  73. return View::fetch($this->template_dir . 'wholesale_add');
  74. }
  75. /**
  76. * 保存添加的批发活动
  77. * */
  78. public function wholesale_save() {
  79. //验证输入
  80. $wholesale_if_mix = intval(input('param.wholesale_if_mix'));
  81. $goods_commonid = intval(input('param.goods_commonid'));
  82. $start_time = strtotime(input('post.start_time'));
  83. $end_time = strtotime(input('post.end_time'));
  84. $wholesale_json = explode(',', input('param.wholesale_json'));
  85. if (!$goods_commonid || empty($wholesale_json)) {
  86. ds_json_encode(10001, lang('param_error'));
  87. }
  88. if ($start_time >= $end_time) {
  89. ds_json_encode(10001, lang('greater_than_start_time'));
  90. }
  91. if (!check_platform_store()) {
  92. //获取当前套餐
  93. $wholesalequota_model = model('wholesalequota');
  94. $current_wholesale_quota = $wholesalequota_model->getWholesalequotaCurrent(session('store_id'));
  95. if (empty($current_wholesale_quota)) {
  96. if (intval(config('ds_config.promotion_wholesale_price')) != 0) {
  97. ds_json_encode(10001, lang('please_buy_package_first'));
  98. } else {
  99. $current_wholesale_quota = array('wholesalequota_starttime' => TIMESTAMP, 'wholesalequota_endtime' => TIMESTAMP + 86400 * 30); //没有套餐时,最多一个月
  100. }
  101. }
  102. $quota_start_time = intval($current_wholesale_quota['wholesalequota_starttime']);
  103. $quota_end_time = intval($current_wholesale_quota['wholesalequota_endtime']);
  104. if ($start_time < $quota_start_time) {
  105. ds_json_encode(10001, sprintf(lang('wholesale_add_start_time_explain'), date('Y-m-d', $current_wholesale_quota['wholesalequota_starttime'])));
  106. }
  107. if ($end_time > $quota_end_time) {
  108. ds_json_encode(10001, sprintf(lang('wholesale_add_end_time_explain'), date('Y-m-d', $current_wholesale_quota['wholesalequota_endtime'])));
  109. }
  110. }
  111. $goods_model = model('goods');
  112. $wholesale_model = model('wholesale');
  113. $wholesalegoods_model = model('wholesalegoods');
  114. Db::startTrans();
  115. try {
  116. $goodscommon_info = $goods_model->getGoodsCommonInfoByID($goods_commonid);
  117. if (!$goodscommon_info || $goodscommon_info['store_id'] != session('store_id') || $goodscommon_info['goods_verify'] != 1 || $goodscommon_info['goods_state'] != 1 || $goodscommon_info['goods_lock']) {
  118. throw new \think\Exception(lang('goods_not_exist'), 10006);
  119. }
  120. $param = array();
  121. $param['wholesalequota_id'] = isset($current_wholesale_quota['wholesalequota_id']) ? $current_wholesale_quota['wholesalequota_id'] : 0;
  122. $param['wholesale_starttime'] = $start_time;
  123. $param['wholesale_end_time'] = $end_time;
  124. $param['goods_commonid'] = $goods_commonid;
  125. $param['goods_name'] = $goodscommon_info['goods_name'];
  126. $param['wholesale_if_mix'] = $wholesale_if_mix;
  127. $param['store_id'] = session('store_id');
  128. $param['store_name'] = session('store_name');
  129. $param['member_id'] = session('member_id');
  130. $param['member_name'] = session('member_name');
  131. $wholesale_id = $wholesale_model->addWholesale($param);
  132. foreach ($wholesale_json as $val) {
  133. $wholesalegoods_data = $this->getWholesaleGoods($val);
  134. $wholesalegoods_data['wholesale_id'] = $wholesale_id;
  135. $wholesalegoods_data['wholesale_starttime'] = $start_time;
  136. $wholesalegoods_data['wholesale_end_time'] = $end_time;
  137. $wholesalegoods_model->addWholesalegoods($wholesalegoods_data);
  138. }
  139. } catch (\Exception $e) {
  140. Db::rollback();
  141. ds_json_encode(10001, $e->getMessage());
  142. }
  143. Db::commit();
  144. // 添加计划任务
  145. $this->addcron(array('exetime' => $end_time, 'exeid' => $wholesale_id, 'type' => 8), true);
  146. $this->recordSellerlog(lang('add_limited_time_discount_activity') . $goodscommon_info['goods_name'] . lang('activity_number') . $wholesale_id);
  147. ds_json_encode(10000, lang('ds_common_op_succ'));
  148. }
  149. /**
  150. * 获取批发商品
  151. *
  152. * @param array $val
  153. * @param type $goods_commonid
  154. * @return array
  155. *
  156. */
  157. private function getWholesaleGoods($val) {
  158. $temp = explode('|', $val);
  159. $goods_id = $temp[0];
  160. $temp = explode('_', $temp[1]);
  161. $goods_model = model('goods');
  162. $goods_info = $goods_model->getGoodsInfoByID($goods_id);
  163. if ($goods_info && $goods_info['goods_verify'] == 1 && $goods_info['goods_state'] == 1) {
  164. if (empty($temp)) {
  165. throw new \think\Exception($goods_info['goods_name'] . lang('wholesale_price_empty'), 10006);
  166. }
  167. $wholesalegoods_price = array();
  168. foreach ($temp as $v) {
  169. $m_temp = explode('-', $v);
  170. $num = intval($m_temp[0]);
  171. $price = floatval($m_temp[1]);
  172. if ($num <= 0 || $price <= 0) {
  173. throw new \think\Exception(lang('wholesale_set_error'), 10006);
  174. }
  175. $wholesalegoods_price[] = array(
  176. 'num' => $num,
  177. 'price' => $price,
  178. );
  179. }
  180. $wholesalegoods_price = $this->arraySort($wholesalegoods_price, 'num', 'asc');
  181. $wholesalegoods_price = array_values($wholesalegoods_price);
  182. for ($i = 0; $i < count($wholesalegoods_price); $i++) {
  183. if ($i < (count($wholesalegoods_price) - 1)) {
  184. $wholesalegoods_price[$i]['num_text'] = $wholesalegoods_price[$i]['num'] . '-' . $wholesalegoods_price[$i + 1]['num'];
  185. } else {
  186. $wholesalegoods_price[$i]['num_text'] = '≥' . $wholesalegoods_price[$i]['num'];
  187. }
  188. if ($i > 0) {
  189. if ($wholesalegoods_price[$i]['price'] >= $wholesalegoods_price[$i - 1]['price']) {
  190. throw new \think\Exception(lang('wholesale_set_error'), 10006);
  191. }
  192. if ($wholesalegoods_price[$i]['num'] == $wholesalegoods_price[$i - 1]['num']) {
  193. throw new \think\Exception(lang('wholesale_set_error'), 10006);
  194. }
  195. }
  196. }
  197. if ($wholesalegoods_price[0]['price'] > $goods_info['goods_price']) {
  198. throw new \think\Exception($goods_info['goods_name'] . lang('wholesale_price_error'), 10006);
  199. }
  200. $wholesalegoods_data = array(
  201. 'goods_id' => $goods_info['goods_id'],
  202. 'goods_commonid' => $goods_info['goods_commonid'],
  203. 'store_id' => $goods_info['store_id'],
  204. 'goods_name' => $goods_info['goods_name'],
  205. 'goods_price' => $goods_info['goods_price'],
  206. 'goods_image' => $goods_info['goods_image'],
  207. 'wholesalegoods_price' => serialize($wholesalegoods_price),
  208. );
  209. return $wholesalegoods_data;
  210. } else {
  211. throw new \think\Exception(lang('goods_not_exist'), 10006);
  212. }
  213. }
  214. /**
  215. * 多维数组排序(多用于文件数组数据)
  216. *
  217. * @param array $array
  218. * @param array $cols
  219. * @return array
  220. *
  221. */
  222. private function arraySort($array, $keys, $sort = 'asc') {
  223. $newArr = $valArr = array();
  224. foreach ($array as $key => $value) {
  225. $valArr[$key] = $value[$keys];
  226. }
  227. ($sort == 'asc') ? asort($valArr) : arsort($valArr);
  228. reset($valArr);
  229. foreach ($valArr as $key => $value) {
  230. $newArr[$key] = $array[$key];
  231. }
  232. return $newArr;
  233. }
  234. /**
  235. * 编辑批发活动
  236. * */
  237. public function wholesale_edit() {
  238. if (check_platform_store()) {
  239. View::assign('isPlatformStore', true);
  240. } else {
  241. View::assign('isPlatformStore', false);
  242. }
  243. $wholesale_model = model('wholesale');
  244. $wholesale_info = $wholesale_model->getWholesaleInfoByID(input('param.wholesale_id'));
  245. if (empty($wholesale_info) || !$wholesale_info['editable']) {
  246. $this->error(lang('param_error'));
  247. }
  248. View::assign('wholesale_info', $wholesale_info);
  249. //获取批发商品列表
  250. $goods_model = model('goods');
  251. $condition = array();
  252. $condition[] = array('goods_commonid', '=', $wholesale_info['goods_commonid']);
  253. $goods_list = $goods_model->getGoodsOnlineList($condition);
  254. $wholesalegoods_model = model('wholesalegoods');
  255. $wholesalegoods_list = array();
  256. foreach ($goods_list as $key => $val) {
  257. $val['goods_image'] = goods_thumb($val, 240);
  258. $condition = array();
  259. $condition[] = array('wholesale_id', '=', $wholesale_info['wholesale_id']);
  260. $condition[] = array('goods_id', '=', $val['goods_id']);
  261. $wholesalegoods_info = $wholesalegoods_model->getWholesalegoodsInfo($condition);
  262. if (!$wholesalegoods_info) {
  263. $val['inactive'] = 1;
  264. } else {
  265. $val['wholesale_info'] = unserialize($wholesalegoods_info['wholesalegoods_price']);
  266. $val['goods_lock'] = 0;
  267. }
  268. $wholesalegoods_list[] = $val;
  269. }
  270. View::assign('wholesalegoods_list', json_encode($wholesalegoods_list));
  271. //输出导航
  272. $this->setSellerCurMenu('Sellerpromotionwholesale');
  273. $this->setSellerCurItem('wholesale_edit');
  274. return View::fetch($this->template_dir . 'wholesale_add');
  275. }
  276. /**
  277. * 编辑保存批发活动
  278. * */
  279. public function wholesale_edit_save() {
  280. $wholesale_id = input('param.wholesale_id');
  281. $wholesale_model = model('wholesale');
  282. $wholesalegoods_model = model('wholesalegoods');
  283. $wholesale_if_mix = intval(input('param.wholesale_if_mix'));
  284. $wholesale_json = explode(',', input('param.wholesale_json'));
  285. if (!$wholesale_id || empty($wholesale_json)) {
  286. ds_json_encode(10001, lang('param_error'));
  287. }
  288. $wholesale_info = $wholesale_model->getWholesaleInfoByID($wholesale_id);
  289. if (empty($wholesale_info) || !$wholesale_info['editable']) {
  290. $this->error(lang('param_error'));
  291. }
  292. Db::startTrans();
  293. try {
  294. //生成活动
  295. $param = array();
  296. $param['wholesale_if_mix'] = $wholesale_if_mix;
  297. $wholesale_model->editWholesale($param, array(array('wholesale_id', '=', $wholesale_id)));
  298. $goods_ids = array();
  299. foreach ($wholesale_json as $val) {
  300. $wholesalegoods_data = $this->getWholesaleGoods($val);
  301. $goods_ids[] = $wholesalegoods_data['goods_id'];
  302. $wholesalegoods_info = $wholesalegoods_model->getWholesalegoodsInfo(array(array('wholesale_id', '=', $wholesale_id), array('goods_id', '=', $wholesalegoods_data['goods_id'])));
  303. if ($wholesalegoods_info) {
  304. $wholesalegoods_model->editWholesalegoods($wholesalegoods_data, array(array('wholesalegoods_id', '=', $wholesalegoods_info['wholesalegoods_id'])));
  305. } else {
  306. $wholesalegoods_data['wholesale_id'] = $wholesale_id;
  307. $wholesalegoods_data['wholesale_starttime'] = $wholesale_info['wholesale_starttime'];
  308. $wholesalegoods_data['wholesale_end_time'] = $wholesale_info['wholesale_end_time'];
  309. $wholesalegoods_model->addWholesalegoods($wholesalegoods_data);
  310. }
  311. }
  312. $wholesalegoods_ids = Db::name('wholesalegoods')->where(array(array('wholesale_id', '=', $wholesale_id), array('goods_id', 'not in', $goods_ids)))->column('wholesalegoods_id');
  313. if (!empty($wholesalegoods_ids)) {
  314. $wholesalegoods_model->delWholesalegoods(array(array('wholesalegoods_id', 'in', $wholesalegoods_ids)));
  315. }
  316. } catch (\Exception $e) {
  317. Db::rollback();
  318. ds_json_encode(10001, $e->getMessage());
  319. }
  320. Db::commit();
  321. $this->recordSellerlog(lang('edit_limited_time_discount_activity') . $wholesale_info['goods_name'] . lang('activity_number') . $wholesale_id);
  322. ds_json_encode(10000, lang('ds_common_op_succ'));
  323. }
  324. /**
  325. * 批发活动删除
  326. * */
  327. public function wholesale_del() {
  328. $wholesale_id = intval(input('param.wholesale_id'));
  329. $wholesale_model = model('wholesale');
  330. $data = array();
  331. $data['result'] = true;
  332. $wholesale_info = $wholesale_model->getWholesaleInfoByID($wholesale_id, session('store_id'));
  333. if (!$wholesale_info) {
  334. ds_json_encode(10001, lang('param_error'));
  335. }
  336. $result = $wholesale_model->delWholesale(array('wholesale_id' => $wholesale_id));
  337. if ($result) {
  338. $this->recordSellerlog(lang('delete_limited_time_discount_activity') . $wholesale_info['goods_name'] . lang('activity_number') . $wholesale_id);
  339. ds_json_encode(10000, lang('ds_common_op_succ'));
  340. } else {
  341. ds_json_encode(10001, lang('ds_common_op_fail'));
  342. }
  343. }
  344. /**
  345. * 批发套餐购买
  346. * */
  347. public function wholesale_quota_add() {
  348. //输出导航
  349. $this->setSellerCurMenu('Sellerpromotionwholesale');
  350. $this->setSellerCurItem('wholesale_quota_add');
  351. return View::fetch($this->template_dir . 'wholesale_quota_add');
  352. }
  353. /**
  354. * 批发套餐购买保存
  355. * */
  356. public function wholesale_quota_add_save() {
  357. if (intval(config('ds_config.promotion_wholesale_price')) == 0) {
  358. ds_json_encode(10001, lang('param_error'));
  359. }
  360. $wholesale_quota_quantity = intval(input('post.wholesale_quota_quantity'));
  361. if ($wholesale_quota_quantity <= 0 || $wholesale_quota_quantity > 12) {
  362. ds_json_encode(10001, lang('wholesale_quota_quantity_error'));
  363. }
  364. //获取当前价格
  365. $current_price = intval(config('ds_config.promotion_wholesale_price'));
  366. //获取该用户已有套餐
  367. $wholesalequota_model = model('wholesalequota');
  368. $current_wholesale_quota = $wholesalequota_model->getWholesalequotaCurrent(session('store_id'));
  369. $wholesale_add_time = 86400 * 30 * $wholesale_quota_quantity;
  370. if (empty($current_wholesale_quota)) {
  371. //生成套餐
  372. $param = array();
  373. $param['member_id'] = session('member_id');
  374. $param['member_name'] = session('member_name');
  375. $param['store_id'] = session('store_id');
  376. $param['store_name'] = session('store_name');
  377. $param['wholesalequota_starttime'] = TIMESTAMP;
  378. $param['wholesalequota_endtime'] = TIMESTAMP + $wholesale_add_time;
  379. $wholesalequota_model->addWholesalequota($param);
  380. } else {
  381. $param = array();
  382. $param['wholesalequota_endtime'] = Db::raw('wholesalequota_endtime+' . $wholesale_add_time);
  383. $wholesalequota_model->editWholesalequota($param, array('wholesalequota_id' => $current_wholesale_quota['wholesalequota_id']));
  384. }
  385. //记录店铺费用
  386. $this->recordStorecost($current_price * $wholesale_quota_quantity, lang('buy_limited_time_discount'));
  387. $this->recordSellerlog(lang('buy') . $wholesale_quota_quantity . lang('limited_time_discount_package') . $current_price . lang('ds_yuan'));
  388. ds_json_encode(10000, lang('wholesale_quota_add_success'));
  389. }
  390. /**
  391. * 选择活动商品
  392. * */
  393. public function goods_select() {
  394. $goods_model = model('goods');
  395. $condition = array();
  396. $condition[] = array('goods.store_id', '=', session('store_id'));
  397. $condition[] = array('goods.goods_name', 'like', '%' . input('param.goods_name') . '%');
  398. $goods_list = $goods_model->getGoodsListForPromotion($condition, 'goods.goods_id,goods.goods_commonid,goods.goods_name,goods.goods_image,goods.goods_price', 10, 'wholesale');
  399. View::assign('goods_list', $goods_list);
  400. View::assign('show_page', $goods_model->page_info->render());
  401. echo View::fetch($this->template_dir . 'goods_select');
  402. }
  403. public function goods_info() {
  404. $goods_commonid = intval(input('param.goods_commonid'));
  405. $data = array();
  406. $data['result'] = true;
  407. $goods_model = model('goods');
  408. $condition = array();
  409. $condition[] = array('goods_commonid', '=', $goods_commonid);
  410. $goods_list = $goods_model->getGoodsOnlineList($condition);
  411. if (empty($goods_list)) {
  412. $data['result'] = false;
  413. $data['message'] = lang('param_error');
  414. echo json_encode($data);
  415. die;
  416. }
  417. foreach ($goods_list as $key => $val) {
  418. $goods_list[$key]['goods_image'] = goods_thumb($val, 240);
  419. }
  420. $data['goods_list'] = $goods_list;
  421. echo json_encode($data);
  422. die;
  423. }
  424. /**
  425. * 用户中心右边,小导航
  426. *
  427. * @param string $menu_type 导航类型
  428. * @param string $name 当前导航的name
  429. * @param array $array 附加菜单
  430. * @return
  431. */
  432. protected function getSellerItemList() {
  433. $menu_array = array(
  434. array(
  435. 'name' => 'wholesale_list', 'text' => lang('promotion_active_list'),
  436. 'url' => (string) url('Sellerpromotionwholesale/index')
  437. ),
  438. );
  439. switch (request()->action()) {
  440. case 'wholesale_add':
  441. $menu_array[] = array(
  442. 'name' => 'wholesale_add', 'text' => lang('promotion_join_active'),
  443. 'url' => (string) url('Sellerpromotionwholesale/wholesale_add')
  444. );
  445. break;
  446. case 'wholesale_edit':
  447. $menu_array[] = array(
  448. 'name' => 'wholesale_edit', 'text' => lang('editing_activity'), 'url' => 'javascript:;'
  449. );
  450. break;
  451. case 'wholesale_quota_add':
  452. $menu_array[] = array(
  453. 'name' => 'wholesale_quota_add', 'text' => lang('promotion_buy_product'),
  454. 'url' => (string) url('Sellerpromotionwholesale/wholesale_quota_add')
  455. );
  456. break;
  457. case 'wholesale_manage':
  458. $menu_array[] = array(
  459. 'name' => 'wholesale_manage', 'text' => lang('promotion_goods_manage'),
  460. 'url' => (string) url('Sellerpromotionwholesale/wholesale_manage', ['wholesale_id' => input('param.wholesale_id')])
  461. );
  462. break;
  463. }
  464. return $menu_array;
  465. }
  466. }