| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450 |
- <?php
- /**
- * Niushop商城系统 - 团队十年电商经验汇集巨献!
- * =========================================================
- * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
- * ----------------------------------------------
- * 官方网址: https://www.niushop.com
- * =========================================================
- */
- namespace addon\cardservice\shop\controller;
- use addon\cardservice\model\CardGoods;
- use addon\cardservice\model\MemberCard as MemberCardModel;
- use addon\form\model\Form;
- use app\model\goods\Goods as GoodsModel;
- use app\model\goods\GoodsBrand as GoodsBrandModel;
- use app\model\goods\GoodsService as GoodsServiceModel;
- use app\model\store\Store as StoreModel;
- use app\model\web\Config as ConfigModel;
- use app\shop\controller\BaseShop;
- /**
- * 虚拟商品
- * Class Virtualgoods
- * @package app\shop\controller
- */
- class Card extends BaseShop
- {
- protected $replace = [
- 'ADDON_CARDSERVICE_CSS' => __ROOT__ . '/addon/cardservice/shop/view/public/css',
- 'ADDON_CARDSERVICE_JS' => __ROOT__ . '/addon/cardservice/shop/view/public/js',
- 'ADDON_CARDSERVICE_IMG' => __ROOT__ . '/addon/cardservice/shop/view/public/img',
- ];
- /**
- * 添加商品
- * @return mixed
- */
- public function addGoods()
- {
- if (request()->isAjax()) {
- $category_id = input("category_id", 0);// 分类id
- $category_json = json_encode($category_id);//分类字符串
- $category_id = '';
- $data = [
- 'goods_name' => input("goods_name", ""),// 商品名称,
- 'goods_attr_class' => input("goods_attr_class", ""),// 商品类型id,
- 'goods_attr_name' => input("goods_attr_name", ""),// 商品类型名称,
- 'is_limit' => input("is_limit", "0"),// 商品是否限购,
- 'limit_type' => input("limit_type", "1"),// 商品限购类型,
- 'site_id' => $this->site_id,
- 'category_id' => $category_id,
- 'category_json' => $category_json,
- 'goods_image' => input("goods_image", ""),// 商品主图路径
- 'goods_content' => input("goods_content", ""),// 商品详情
- 'goods_state' => input("goods_state", ""),// 商品状态(1.正常0下架)
- 'price' => input("price", 0),// 商品价格(取第一个sku)
- 'renew_price' => input("renew_price", 0), // 续费价格
- 'market_price' => input("market_price", 0),// 市场价格(取第一个sku)
- 'cost_price' => input("cost_price", 0),// 成本价(取第一个sku)
- 'sku_no' => input("sku_no", ""),// 商品sku编码
- 'weight' => input("weight", ""),// 重量
- 'volume' => input("volume", ""),// 体积
- 'goods_stock' => input("goods_stock", 0),// 商品库存(总和)
- 'goods_stock_alarm' => input("goods_stock_alarm", 0),// 库存预警
- 'goods_spec_format' => input("goods_spec_format", ""),// 商品规格格式
- 'goods_attr_format' => input("goods_attr_format", ""),// 商品参数格式
- 'introduction' => input("introduction", ""),// 促销语
- 'keywords' => input("keywords", ""),// 关键词
- 'unit' => input("unit", ""),// 单位
- 'sort' => input("sort", 0),// 排序,
- 'video_url' => input("video_url", ""),// 视频
- 'goods_sku_data' => input("goods_sku_data", ""),// SKU商品数据
- 'goods_service_ids' => input("goods_service_ids", ''),// 商品服务id集合
- 'label_id' => input("label_id", ''),// 商品分组id
- 'brand_id' => input("brand_id", 0),//品牌id
- 'virtual_sale' => input("virtual_sale", 0),// 虚拟销量
- 'max_buy' => input("max_buy", 0),// 限购
- 'min_buy' => input("min_buy", 0),// 起售
- 'recommend_way' => input('recommend_way', 0), // 推荐方式,1:新品,2:精品,3;推荐
- 'timer_on' => strtotime(input('timer_on', 0)),//定时上架
- 'timer_off' => strtotime(input('timer_off', 0)),//定时下架
- 'is_consume_discount' => input('is_consume_discount', 0),//是否参与会员折扣
- 'qr_id' => input('qr_id', 0),// 社群二维码id
- 'template_id' => input('template_id', 0), // 商品海报id
- 'sale_show' => input('sale_show', 0),//
- 'stock_show' => input('stock_show', 0),//
- 'market_price_show' => input('market_price_show', 0),//
- 'barrage_show' => input('barrage_show', 0),//
- 'form_id' => input('form_id', 0),
- 'sale_channel' => input('sale_channel', 'all'),
- 'sale_store' => input('sale_store', 'all'),
- 'card_type' => input('card_type', ''),
- 'validity_type' => input('validity_type', 0),
- 'discount_goods_type' => input('discount_goods_type', 'all'),
- 'discount' => input('discount', 0),
- 'common_num' => input('common_num', 0),
- 'relation_goods' => input('relation_goods', '[]'),
- 'is_unify_price' => input('is_unify_price', 1),
- ];
- if ($data[ 'validity_type' ] == 1) {
- $data[ 'validity_day' ] = input("validity_day", 0);
- } else if ($data[ 'validity_type' ] == 2) {
- $data[ 'validity_time' ] = strtotime(input("validity_time", ''));
- }
- $virtual_goods_model = new CardGoods();
- $res = $virtual_goods_model->addGoods($data);
- return $res;
- } else {
- $virtual_goods_model = new CardGoods();
- // 商品服务
- $goods_service_model = new GoodsServiceModel();
- $service_list = $goods_service_model->getServiceList([ [ 'site_id', '=', $this->site_id ] ], 'id,service_name,icon')[ 'data' ];
- $this->assign("service_list", $service_list);
- // 商品品牌
- $goods_brand_model = new GoodsBrandModel();
- $brand_list = $goods_brand_model->getBrandList([ [ 'site_id', '=', $this->site_id ] ], 'brand_id,brand_name', 'sort asc')[ 'data' ];
- $this->assign("brand_list", $brand_list);
- //商品默认排序值
- $config_model = new ConfigModel();
- $sort_config = $config_model->getGoodsSort($this->site_id);
- $sort_config = $sort_config[ 'data' ][ 'value' ];
- $this->assign("sort_config", $sort_config);
- //获取商品海报
- $poster_list = event('PosterTemplate', [ 'site_id' => $this->site_id ], true);
- if (!empty($poster_list)) {
- $poster_list = $poster_list[ 'data' ];
- }
- $this->assign('poster_list', $poster_list);
- $this->assign('virtualcard_exit', addon_is_exit('virtualcard', $this->site_id));
- $form_is_exit = addon_is_exit('form', $this->site_id);
- if ($form_is_exit) {
- $form_list = ( new Form() )->getFormList([ [ 'site_id', '=', $this->site_id ], [ 'form_type', '=', 'goods' ], [ 'is_use', '=', 1 ] ], 'id desc', 'id, form_name')[ 'data' ];
- $this->assign('form_list', $form_list);
- }
- $this->assign('form_is_exit', $form_is_exit);
- $this->assign('all_goodsclass', event('GoodsClass'));
- $this->assign('goods_class', $virtual_goods_model->getGoodsClass());
- $this->assign('card_type', $virtual_goods_model->getCardType());
- $this->assign('store_is_exit', addon_is_exit('store', $this->site_id));
- return $this->fetch("card/add_goods", [], $this->replace);
- }
- }
- /**
- * 编辑商品
- * @return mixed
- */
- public function editGoods()
- {
- $virtual_goods_model = new CardGoods();
- if (request()->isAjax()) {
- $category_id = input("category_id", 0);// 分类id
- $category_json = json_encode($category_id);//分类字符串
- $category_id = '';
- $data = [
- 'goods_id' => input("goods_id", 0),// 商品id
- 'goods_name' => input("goods_name", ""),// 商品名称,
- 'goods_attr_class' => input("goods_attr_class", ""),// 商品类型id,
- 'goods_attr_name' => input("goods_attr_name", ""),// 商品类型名称,
- 'is_limit' => input("is_limit", "0"),// 商品是否限购,
- 'limit_type' => input("limit_type", "1"),// 商品限购类型,
- 'site_id' => $this->site_id,
- 'category_id' => $category_id,
- 'category_json' => $category_json,
- 'goods_image' => input("goods_image", ""),// 商品主图路径
- 'goods_content' => input("goods_content", ""),// 商品详情
- 'goods_state' => input("goods_state", ""),// 商品状态(1.正常0下架)
- 'price' => input("price", 0),// 商品价格(取第一个sku)
- 'renew_price' => input("renew_price", 0), // 续费价格
- 'market_price' => input("market_price", 0),// 市场价格(取第一个sku)
- 'cost_price' => input("cost_price", 0),// 成本价(取第一个sku)
- 'sku_no' => input("sku_no", ""),// 商品sku编码
- 'weight' => input("weight", ""),// 重量
- 'volume' => input("volume", ""),// 体积
- 'goods_stock' => input("goods_stock", 0),// 商品库存(总和)
- 'goods_stock_alarm' => input("goods_stock_alarm", 0),// 库存预警
- 'goods_spec_format' => input("goods_spec_format", ""),// 商品规格格式
- 'goods_attr_format' => input("goods_attr_format", ""),// 商品参数格式
- 'introduction' => input("introduction", ""),// 促销语
- 'keywords' => input("keywords", ""),// 关键词
- 'unit' => input("unit", ""),// 单位
- 'sort' => input("sort", 0),// 排序,
- 'video_url' => input("video_url", ""),// 视频
- 'goods_sku_data' => input("goods_sku_data", ""),// SKU商品数据
- 'goods_service_ids' => input("goods_service_ids", ''),// 商品服务id集合
- 'label_id' => input("label_id", ''),// 商品分组id
- 'brand_id' => input("brand_id", 0),//品牌id
- 'virtual_sale' => input("virtual_sale", 0),// 虚拟销量
- 'max_buy' => input("max_buy", 0),// 限购
- 'min_buy' => input("min_buy", 0),// 起售
- 'recommend_way' => input('recommend_way', 0), // 推荐方式,1:新品,2:精品,3;推荐
- 'timer_on' => strtotime(input('timer_on', 0)),//定时上架
- 'timer_off' => strtotime(input('timer_off', 0)),//定时下架
- 'spec_type_status' => input('spec_type_status', 0),
- 'is_consume_discount' => input('is_consume_discount', 0),//是否参与会员折扣
- 'qr_id' => input('qr_id', 0),// 社群二维码id
- 'template_id' => input('template_id', 0), // 商品海报id
- 'sale_show' => input('sale_show', 0),//
- 'stock_show' => input('stock_show', 0),//
- 'market_price_show' => input('market_price_show', 0),//
- 'barrage_show' => input('barrage_show', 0),//
- 'form_id' => input('form_id', 0),
- 'sale_channel' => input('sale_channel', 'all'),
- 'sale_store' => input('sale_store', 'all'),
- 'validity_type' => input('validity_type', 0),
- 'discount_goods_type' => input('discount_goods_type', 'all'),
- 'discount' => input('discount', 0),
- 'common_num' => input('common_num', 0),
- 'relation_goods' => input('relation_goods', '[]'),
- 'is_unify_price' => input('is_unify_price', 1),
- ];
- if ($data[ 'validity_type' ] == 1) {
- $data[ 'validity_day' ] = input("validity_day", 0);
- } else if ($data[ 'validity_type' ] == 2) {
- $data[ 'validity_time' ] = strtotime(input("validity_time", ''));
- }
- $res = $virtual_goods_model->editGoods($data);
- return $res;
- } else {
- $goods_model = new GoodsModel();
- $goods_id = input("goods_id", 0);
- $goods_info = $virtual_goods_model->editGetGoodsInfo([ 'goods_id' => $goods_id, 'site_id' => $this->site_id ])[ 'data' ];
- if (empty($goods_info)) $this->error('未获取到商品信息');
- $goods_sku_list = $goods_model->getGoodsSkuList([ [ 'goods_id', '=', $goods_id ], [ 'site_id', '=', $this->site_id ] ], "sku_id,sku_name,sku_no,sku_spec_format,price,market_price,cost_price,stock,virtual_indate,sku_image,sku_images,goods_spec_format,spec_name,stock_alarm,is_default", '')[ 'data' ];
- $goods_info[ 'sku_list' ] = $goods_sku_list;
- $this->assign("goods_info", $goods_info);
- // 商品服务
- $goods_service_model = new GoodsServiceModel();
- $service_list = $goods_service_model->getServiceList([ [ 'site_id', '=', $this->site_id ] ], 'id,service_name,icon')[ 'data' ];
- $this->assign("service_list", $service_list);
- // 商品品牌
- $goods_brand_model = new GoodsBrandModel();
- $brand_list = $goods_brand_model->getBrandList([ [ 'site_id', '=', $this->site_id ] ], 'brand_id,brand_name', 'sort asc')[ 'data' ];
- $this->assign("brand_list", $brand_list);
- //获取商品海报
- $poster_list = event('PosterTemplate', [ 'site_id' => $this->site_id ], true);
- if (!empty($poster_list)) {
- $poster_list = $poster_list[ 'data' ];
- }
- $this->assign('poster_list', $poster_list);
- $form_is_exit = addon_is_exit('form', $this->site_id);
- if ($form_is_exit) {
- $form_list = ( new Form() )->getFormList([ [ 'site_id', '=', $this->site_id ], [ 'form_type', '=', 'goods' ], [ 'is_use', '=', 1 ] ], 'id desc', 'id, form_name')[ 'data' ];
- $this->assign('form_list', $form_list);
- }
- $this->assign('form_is_exit', $form_is_exit);
- $store_is_exit = addon_is_exit('store', $this->site_id);
- if ($store_is_exit && $goods_info[ 'sale_store' ] != 'all') {
- $store_list = ( new StoreModel() )->getStoreList([ [ 'site_id', '=', $this->site_id ], [ 'store_id', 'in', $goods_info[ 'sale_store' ] ] ], 'store_id,store_name,status,address,full_address,is_frozen');
- $this->assign('store_list', $store_list[ 'data' ]);
- }
- $this->assign('store_is_exit', $store_is_exit);
- $this->assign('card_type', $virtual_goods_model->getCardType());
- return $this->fetch("card/edit_goods", [], $this->replace);
- }
- }
- public function goodscard()
- {
- $goods_id = input('goods_id', 0);
- $model = new MemberCardModel();
- if (request()->isAjax()) {
- $page_index = input('page', 1);
- $page_size = input('page_size', PAGE_LIST_ROWS);
- $search_text = input('search_text', '');
- $condition = [
- [ 'mgc.site_id', '=', $this->site_id ],
- [ 'mgc.goods_id', '=', $goods_id ],
- ];
- if (!empty($search_text)) {
- $condition[] = [ 'm.nickname', 'like', '%' . $search_text . '%' ];
- }
- $field = 'mgc.*, g.goods_name,g.price,g.goods_image,m.username,m.nickname,m.headimg';
- $join = [
- [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
- [ 'member m', 'mgc.member_id = m.member_id', 'left' ],
- ];
- $list = $model->getCardPageList($condition, $field, 'mgc.create_time desc', $page_index, $page_size, 'mgc', $join);
- return $list;
- } else {
- $this->assign('goods_id', $goods_id);
- $goods_model = new GoodsModel();
- $goods_info = $goods_model->getGoodsInfo([ [ 'goods_id', '=', $goods_id ], [ 'site_id', '=', $this->site_id ] ], 'goods_id, goods_name,goods_image,price,goods_state,goods_stock,sale_num');
- $this->assign('goods_info', $goods_info[ 'data' ]);
- $card_stat = $model->getCardInfo([ [ 'goods_id', '=', $goods_id ], [ 'site_id', '=', $this->site_id ] ], 'sum(total_num) as total_num, sum(total_use_num) as total_use_num')[ 'data' ] ?? [];
- $this->assign('total_num', $card_stat[ 'total_num' ] ?? 0);
- $this->assign('total_use_num', $card_stat[ 'total_use_num' ] ?? 0);
- $card_info = $model->getCardSelect([ [ 'goods_id', '=', $goods_id ], [ 'site_id', '=', $this->site_id ] ])[ 'data' ] ?? [];
- $this->assign('card_info', $card_info);
- return $this->fetch('card/goods_card');
- }
- }
- public function membergoodscard()
- {
- $member_id = input('member_id', 0);
- if (request()->isAjax()) {
- $page_index = input('page', 1);
- $page_size = input('page_size', PAGE_LIST_ROWS);
- $search_text = input('search_text', '');
- $condition = [
- [ 'mgc.site_id', '=', $this->site_id ],
- [ 'mgc.member_id', '=', $member_id ],
- ];
- if (!empty($search_text)) {
- $condition[] = [ 'g.goods_name', 'like', '%' . $search_text . '%' ];
- }
- $model = new MemberCardModel();
- $card_goods = new CardGoods();
- $field = 'mgc.*, g.goods_name,g.price,g.goods_image,m.username,m.nickname,m.headimg';
- $join = [
- [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
- [ 'member m', 'mgc.member_id = m.member_id', 'left' ],
- ];
- $list = $model->getCardPageList($condition, $field, 'mgc.create_time desc', $page_index, $page_size, 'mgc', $join);
- foreach ($list[ 'data' ][ 'list' ] as $k => $v) {
- $list[ 'data' ][ 'list' ][ $k ][ 'card_type_name' ] = $card_goods->getCardType($v[ 'card_type' ])[ 'title' ];
- }
- return $list;
- } else {
- $this->assign('member_id', $member_id);
- return $this->fetch('card/member_goods_card');
- }
- }
- public function detail()
- {
- $card_id = input('card_id', 0);
- $model = new MemberCardModel();
- $card_goods = new CardGoods();
- $condition = [
- [ 'mgc.card_id', '=', $card_id ],
- [ 'mgc.site_id', '=', $this->site_id ],
- ];
- $field = 'mgc.*, g.goods_name,g.price,g.goods_image,m.username,m.nickname,m.headimg';
- $join = [
- [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
- [ 'member m', 'mgc.member_id = m.member_id', 'left' ],
- ];
- $detail = $model->getCardInfo($condition, $field, 'mgc', $join)[ 'data' ] ?? [];
- $detail[ 'card_type_name' ] = $card_goods->getCardType($detail[ 'card_type' ])[ 'title' ];
- $this->assign('detail', $detail);
- $condition = [];
- $condition[] = [ 'mgc.card_id', '=', $card_id ];
- $condition[] = [ 'g.goods_state', '=', 1 ];
- $condition[] = [ 'g.is_delete', '=', 0 ];
- $field = 'mgc.*, g.sku_name';
- $join = [
- [ 'goods_sku g', 'mgc.sku_id = g.sku_id', 'left' ],
- ];
- $item_list = $model->getCartItemList($condition, $field, 'mgc.item_id asc', 'mgc', $join)[ 'data' ] ?? [];
- $this->assign('item_list', $item_list);
- return $this->fetch('card/detail');
- }
- public function getCardItem()
- {
- if (request()->isAjax()) {
- $page_index = input('page', 1);
- $page_size = input('page_size', PAGE_LIST_ROWS);
- $card_id = input('card_id', 0);
- $condition = [];
- $condition[] = [ 'mgc.site_id', '=', $this->site_id ];
- $condition[] = [ 'mgc.card_id', '=', $card_id ];
- $condition[] = [ 'g.goods_state', '=', 1 ];
- $condition[] = [ 'g.is_delete', '=', 0 ];
- $alias = 'mgc';
- $field = 'mgc.*, g.goods_name,g.price,g.goods_image,g.introduction,m.nickname,m.headimg,m.mobile';
- $join = [
- [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
- [ 'member m', 'mgc.member_id = m.member_id', 'left' ],
- ];
- $model = new MemberCardModel();
- $card_goods = new CardGoods();
- $list = $model->getCartItemPageList($condition, $field, 'mgc.item_id asc', $page_index, $page_size, $alias, $join);
- foreach ($list[ 'data' ][ 'list' ] as $k => $v) {
- $list[ 'data' ][ 'list' ][ $k ][ 'card_type_name' ] = $card_goods->getCardType($v[ 'card_type' ])[ 'title' ];
- }
- return $list;
- }
- }
- public function records()
- {
- if (request()->isAjax()) {
- $page_index = input('page', 1);
- $page_size = input('page_size', PAGE_LIST_ROWS);
- $card_id = input('card_id', 0);
- $item_id = input('item_id', 0);
- $condition = [];
- $condition[] = [ 'cr.site_id', '=', $this->site_id ];
- if (!empty($item_id)) {
- $condition[] = [ 'cr.card_item_id', '=', $item_id ];
- }
- if (!empty($card_id)) {
- $condition[] = [ 'cr.card_id', '=', $card_id ];
- }
- $alias = 'cr';
- $prefix = config('database.connections.mysql.prefix');
- $field = 'cr.*, sku.sku_name,sku.sku_image,sku.sku_images,sku.price,ci.num as item_num,
- IF(cr.type = \'order\', (select order_id from `' . $prefix . 'order_goods` og where og.order_goods_id = cr.relation_id), 0) as order_id, s.store_name';
- $join = [
- [ 'member_goods_card_item ci', 'ci.item_id = cr.card_item_id', 'left' ],
- [ 'goods_sku sku', 'ci.sku_id = sku.sku_id', 'left' ],
- [ 'store s', 'cr.store_id = s.store_id', 'left' ],
- ];
- $model = new MemberCardModel();
- $list = $model->getMemberCardRecordsPageList($condition, $field, 'cr.create_time desc', $page_index, $page_size, $alias, $join);
- return $list;
- }
- }
- }
|