初始上传
This commit is contained in:
151
addon/cardservice/storeapi/controller/Membercard.php
Executable file
151
addon/cardservice/storeapi/controller/Membercard.php
Executable file
@@ -0,0 +1,151 @@
|
||||
<?php
|
||||
/**
|
||||
* Niushop商城系统 - 团队十年电商经验汇集巨献!
|
||||
* =========================================================
|
||||
* Copy right 2019-2029 上海牛之云网络科技有限公司, 保留所有权利。
|
||||
* ----------------------------------------------
|
||||
* 官方网址: https://www.niushop.com
|
||||
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
|
||||
* 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
|
||||
* =========================================================
|
||||
*/
|
||||
|
||||
namespace addon\cardservice\storeapi\controller;
|
||||
|
||||
use addon\cardservice\model\MemberCard as MemberCardModel;
|
||||
use app\storeapi\controller\BaseStoreApi;
|
||||
|
||||
/**
|
||||
* 会员管理 控制器
|
||||
*/
|
||||
class Membercard extends BaseStoreApi
|
||||
{
|
||||
/**
|
||||
* 会员卡项
|
||||
*/
|
||||
public function lists()
|
||||
{
|
||||
$member_id = $this->params[ 'member_id' ] ?? 0;
|
||||
$page = $this->params[ 'page' ] ?? 1;
|
||||
$page_size = $this->params[ 'page_size' ] ?? PAGE_LIST_ROWS;
|
||||
$status = $this->params[ 'status' ] ?? 'all';
|
||||
|
||||
$member_oncecard_model = new MemberCardModel();
|
||||
$condition = [
|
||||
[ 'mgc.member_id', '=', $member_id ],
|
||||
[ 'mgc.site_id', '=', $this->site_id ],
|
||||
[ 'g.is_delete', '=', 0 ]
|
||||
];
|
||||
if ($status != 'all') $condition[] = [ 'mgc.status', '=', $status ];
|
||||
|
||||
$field = 'mgc.card_id, mgc.create_time, mgc.end_time, mgc.status, mgc.card_code, mgc.card_type, mgc.goods_name, mgc.total_num, mgc.total_use_num';
|
||||
$res = $member_oncecard_model->getCardPageList($condition, $field, 'mgc.create_time desc', $page, $page_size, 'mgc', [
|
||||
[ 'goods g', 'g.goods_id = mgc.goods_id', 'inner' ]
|
||||
]);
|
||||
|
||||
if (empty($res[ 'data' ])) return $res;
|
||||
|
||||
foreach ($res[ 'data' ][ 'list' ] as $k => &$v) {
|
||||
$alias = 'i';
|
||||
$join = [
|
||||
[ 'goods g', 'i.goods_id = g.goods_id', 'inner' ],
|
||||
[ 'goods_sku gs', 'i.sku_id = gs.sku_id', 'inner' ],
|
||||
[ 'verify mv', 'i.member_verify_id = mv.id', 'inner' ],
|
||||
[ 'store_goods_sku sgs', 'i.sku_id=sgs.sku_id and sgs.store_id=' . $this->store_id, 'inner' ],
|
||||
[ 'store s', 's.store_id = sgs.store_id', 'left' ]
|
||||
];
|
||||
$field = 'i.*, gs.sku_name,gs.sku_image, gs.is_virtual, mv.verify_code, IF(g.is_unify_price = 1,gs.price,sgs.price) as price,IF(s.stock_type = "store",sgs.stock, gs.stock) as stock';
|
||||
$order = 'i.item_id asc';
|
||||
$res[ 'data' ][ 'list' ][ $k ][ 'item_list' ] = $member_oncecard_model->getCartItemList([
|
||||
[ 'i.card_id', '=', $v[ 'card_id' ] ],
|
||||
[ 'i.site_id', '=', $this->site_id ],
|
||||
[ 'i.member_id', '=', $member_id ],
|
||||
[ 'sgs.status', '=', 1 ],
|
||||
[ 'g.is_delete', '=', 0 ]
|
||||
], $field, $order, $alias, $join)[ 'data' ];
|
||||
foreach ($res[ 'data' ][ 'list' ][ $k ][ 'item_list' ] as $ck => $cv) {
|
||||
$res[ 'data' ][ 'list' ][ $k ][ 'item_list' ][ $ck ][ 'stock' ] = numberFormat($res[ 'data' ][ 'list' ][ $k ][ 'item_list' ][ $ck ][ 'stock' ]);
|
||||
}
|
||||
}
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 卡项详情
|
||||
*/
|
||||
public function detail()
|
||||
{
|
||||
$card_id = $this->params[ 'card_id' ] ?? 0;
|
||||
$member_id = $this->params[ 'member_id' ] ?? 0;
|
||||
if (empty($card_id)) {
|
||||
return $this->response($this->error('', 'REQUEST_ID'));
|
||||
}
|
||||
|
||||
$model = new MemberCardModel();
|
||||
$condition = [
|
||||
[ 'mgc.site_id', '=', $this->site_id ],
|
||||
[ 'mgc.member_id', '=', $member_id ],
|
||||
[ 'mgc.card_id', '=', $card_id ],
|
||||
[ 'g.is_delete', '=', 0 ],
|
||||
];
|
||||
$field = 'mgc.*, g.goods_name,g.price,g.goods_image,g.introduction,g.goods_content';
|
||||
$join = [
|
||||
[ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
|
||||
];
|
||||
$info = $model->getCardInfo($condition, $field, 'mgc', $join)[ 'data' ];
|
||||
|
||||
if (empty($info)) return $this->response($this->error('', '未获取到卡项信息'));
|
||||
$condition = [
|
||||
[ 'mgci.card_id', '=', $info[ 'card_id' ] ],
|
||||
[ 'sku.is_delete', '=', 0 ],
|
||||
];
|
||||
$info[ 'card_item' ] = $model->getCartItemList($condition, 'mgci.*,sku.sku_name,sku.price,sku.sku_image,sku.sku_images,sku.goods_class_name,sku.stock,
|
||||
v.verify_code,v.verify_type,v.verify_type_name,v.verify_content_json,v.verifier_id,v.verifier_name,v.is_verify,v.verify_time,v.expire_time,v.verify_from,v.verify_remark,v.verify_total_count,v.verify_use_num', 'mgci.card_id asc', 'mgci', [
|
||||
[ 'goods_sku sku', 'mgci.sku_id = sku.sku_id', 'inner' ],
|
||||
[ 'verify v', 'mgci.member_verify_id = v.id', 'left' ],
|
||||
])[ 'data' ] ?? [];
|
||||
foreach ($info[ 'card_item' ] as $k => $v) {
|
||||
$info[ 'card_item' ][ $k ][ 'stock' ] = numberFormat($info[ 'card_item' ][ $k ][ 'stock' ]);
|
||||
}
|
||||
|
||||
return $this->response($this->success($info));
|
||||
}
|
||||
|
||||
/**
|
||||
* 使用记录
|
||||
*/
|
||||
public function records()
|
||||
{
|
||||
$card_id = $this->params[ 'card_id' ] ?? 0;
|
||||
$item_id = $this->params[ 'item_id' ] ?? 0;
|
||||
$member_id = $this->params[ 'member_id' ] ?? 0;
|
||||
$page = $this->params[ 'page' ] ?? 1;
|
||||
$page_size = $this->params[ 'page_size' ] ?? PAGE_LIST_ROWS;
|
||||
if (empty($member_id) || ( empty($card_id) && empty($item_id) )) {
|
||||
return $this->response($this->error([], '请传入必要参数'));
|
||||
}
|
||||
|
||||
$condition = [];
|
||||
$condition[] = [ 'cr.site_id', '=', $this->site_id ];
|
||||
$condition[] = [ 'ci.member_id', '=', $member_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';
|
||||
|
||||
$join = [
|
||||
[ 'member_goods_card_item ci', 'ci.item_id = cr.card_item_id', 'left' ],
|
||||
[ 'goods_sku sku', 'ci.sku_id = sku.sku_id', 'left' ],
|
||||
];
|
||||
|
||||
$model = new MemberCardModel();
|
||||
$list = $model->getMemberCardRecordsPageList($condition, $field, 'cr.create_time desc', $page, $page_size, $alias, $join);
|
||||
return $this->response($list);
|
||||
}
|
||||
}
|
||||
388
addon/cardservice/storeapi/controller/Reserve.php
Executable file
388
addon/cardservice/storeapi/controller/Reserve.php
Executable file
@@ -0,0 +1,388 @@
|
||||
<?php
|
||||
/**
|
||||
* Niushop商城系统 - 团队十年电商经验汇集巨献!
|
||||
* =========================================================
|
||||
* Copy right 2019-2029 上海牛之云网络科技有限公司, 保留所有权利。
|
||||
* ----------------------------------------------
|
||||
* 官方网址: https://www.niushop.com
|
||||
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
|
||||
* 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
|
||||
* =========================================================
|
||||
*/
|
||||
|
||||
namespace addon\cardservice\storeapi\controller;
|
||||
|
||||
use addon\cardservice\model\Reserve as ReserveModel;
|
||||
use app\dict\goods\GoodsDict;
|
||||
use app\model\goods\Goods as GoodsModel;
|
||||
use app\model\member\Member as MemberModel;
|
||||
use app\model\system\UserGroup;
|
||||
use app\storeapi\controller\BaseStoreApi;
|
||||
|
||||
class Reserve extends BaseStoreApi
|
||||
{
|
||||
/**
|
||||
* 预约状态
|
||||
* @return false|string
|
||||
*/
|
||||
public function status()
|
||||
{
|
||||
$reserve_state = ( new ReserveModel )->reserve_state;
|
||||
return $this->response($this->success($reserve_state));
|
||||
}
|
||||
|
||||
/**
|
||||
* 预约记录(按周)
|
||||
* @return false|string
|
||||
*/
|
||||
public function getReserveByWeek()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_model = new ReserveModel();
|
||||
|
||||
$length = $this->params[ 'length' ] ?? 0;
|
||||
$data = $this->getWeekDay();
|
||||
|
||||
foreach ($data as $wk => $w_item) {
|
||||
$field = 'noy.reserve_id,noy.reserve_state,noy.reserve_time,nm.nickname';
|
||||
$list = $reserve_model->getReservePageList([
|
||||
[ 'noy.site_id', '=', $this->site_id ],
|
||||
[ 'noy.reserve_time', 'between', [ $w_item[ 'start' ], $w_item[ 'end' ] ] ]
|
||||
], 1, PAGE_LIST_ROWS, 'noy.create_time desc', $field);
|
||||
if (!empty($list[ 'data' ][ 'list' ])) {
|
||||
foreach ($list[ 'data' ][ 'list' ] as $k => $item) {
|
||||
$list[ 'data' ][ 'list' ][ $k ][ 'item' ] = $reserve_model->getReserveItemList([
|
||||
[
|
||||
'oyi.reserve_id', '=', $item[ 'reserve_id' ]
|
||||
]
|
||||
], 'g.goods_name,g.goods_id,g.sku_id', 'reserve_item_id desc', 'oyi',
|
||||
[ [ 'goods g', 'g.sku_id = oyi.reserve_goods_sku_id', 'right' ] ])[ 'data' ];
|
||||
}
|
||||
}
|
||||
$data[ $wk ][ 'data' ] = $list[ 'data' ];
|
||||
}
|
||||
|
||||
return $this->response($this->success($data));
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加预约
|
||||
* @return mixed
|
||||
*/
|
||||
public function add()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_model = new ReserveModel();
|
||||
$data = $reserve_model->addReserve([
|
||||
'site_id' => $this->site_id,
|
||||
'app_module' => $this->app_module,
|
||||
'member_id' => $this->params[ 'member_id' ] ?? 0,
|
||||
'goods' => isset($this->params[ 'goods' ]) ? json_decode($this->params[ 'goods' ], true) : [],
|
||||
'store_id' => $this->store_id,
|
||||
'date' => $this->params[ 'date' ] ?? '',
|
||||
'time' => $this->params[ 'time' ] ?? '',
|
||||
'remark' => $this->params[ 'desc' ] ?? '',
|
||||
'source' => 'store'
|
||||
]);
|
||||
return $this->response($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改预约
|
||||
* @return mixed
|
||||
*/
|
||||
public function update()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->editReserve([
|
||||
'site_id' => $this->site_id,
|
||||
'app_module' => $this->app_module,
|
||||
'reserve_id' => $this->params[ 'reserve_id' ] ?? 0,
|
||||
'goods' => isset($this->params[ 'goods' ]) ? json_decode($this->params[ 'goods' ], true) : [],
|
||||
'date' => $this->params[ 'date' ] ?? '',
|
||||
'time' => $this->params[ 'time' ] ?? '',
|
||||
'remark' => $this->params[ 'desc' ] ?? '',
|
||||
]);
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 预约配置
|
||||
*/
|
||||
public function getConfig()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_model = new ReserveModel();
|
||||
$config = $reserve_model->getReserveConfig($this->site_id, $this->store_id);
|
||||
return $this->response($this->success($config[ 'data' ][ 'value' ]));
|
||||
}
|
||||
|
||||
/**
|
||||
* 预约配置
|
||||
*/
|
||||
public function setConfig()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$week = $this->params[ 'week' ] ?? '';
|
||||
$data = [
|
||||
'week' => json_encode(explode(',', $week)),
|
||||
'start' => $this->params[ 'start' ] ?? 32400,
|
||||
'end' => $this->params[ 'end' ] ?? 79200,
|
||||
'interval' => $this->params[ 'interval' ] ?? 30,
|
||||
'advance' => $this->params[ 'advance' ] ?? 1,
|
||||
'max' => $this->params[ 'max' ] ?? 1,
|
||||
];
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->setReserveConfig($data, $this->site_id, $this->store_id);
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 预约列表
|
||||
*/
|
||||
public function lists()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
$page = $this->params['page'] ?? 1;
|
||||
$page_size = $this->params['page_size'] ?? PAGE_LIST_ROWS;
|
||||
$search_text = $this->params['search_text'] ?? '';
|
||||
$reserve_state = $this->params['reserve_state'] ?? 'all';
|
||||
$start = $this->params['start'] ?? 0;
|
||||
$end = $this->params['end'] ?? 0;
|
||||
|
||||
$condition = [
|
||||
[ 'noy.site_id', '=', $this->site_id ],
|
||||
[ 'noy.store_id', '=', $this->store_id ],
|
||||
];
|
||||
if ($reserve_state != 'all') {
|
||||
$condition[] = [ 'noy.reserve_state', '=', $reserve_state ];
|
||||
}
|
||||
if (!empty($search_text)) {
|
||||
$condition[] = [ 'nm.mobile|nm.nickname', 'like', '%' . $search_text . '%' ];
|
||||
}
|
||||
if ($start && $end) {
|
||||
$condition[] = [ 'noy.reserve_time', 'between', [ $start, $end ] ];
|
||||
} else {
|
||||
if ($start && !$end) {
|
||||
$condition[] = [ 'noy.reserve_time', '>=', $start ];
|
||||
} else {
|
||||
if (!$start && $end) {
|
||||
$condition[] = [ 'noy.reserve_time', '<=', $end ];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$field = 'noy.member_id, noy.remark, noy.reserve_id, noy.reserve_name, noy.reserve_state_name, noy.reserve_state, noy.reserve_time, noy.create_time, nm.headimg, nm.nickname, nm.mobile, nm.headimg';
|
||||
$reserve_model = new ReserveModel();
|
||||
$result = $reserve_model->getReservePageList($condition, $page, $page_size, 'noy.create_time desc', $field);
|
||||
if (!empty($result[ 'data' ][ 'list' ])) {
|
||||
foreach ($result[ 'data' ][ 'list' ] as $k => $item) {
|
||||
$result[ 'data' ][ 'list' ][ $k ][ 'item' ] = $reserve_model->getReserveItemList([
|
||||
[
|
||||
'oyi.reserve_id', '=', $item[ 'reserve_id' ]
|
||||
]
|
||||
], 'g.goods_name,g.goods_id,g.sku_id', 'reserve_item_id desc', 'oyi',
|
||||
[ [ 'goods g', 'g.sku_id = oyi.reserve_goods_sku_id', 'right' ] ])[ 'data' ];
|
||||
}
|
||||
}
|
||||
|
||||
return $this->response($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 员工管理
|
||||
* @return mixed
|
||||
*/
|
||||
public function servicer()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
$store_id = $this->store_id;
|
||||
$condition = [
|
||||
[ 'u.site_id', '=', $this->site_id ],
|
||||
];
|
||||
$condition[] = [ 'ug.store_id', '=', $store_id ];
|
||||
|
||||
if (!empty($search_text)) {
|
||||
$condition[] = [ 'u.username', 'like', "%{$search_text}%" ];
|
||||
}
|
||||
|
||||
$user_model = new UserGroup();
|
||||
$result = $user_model->getUserList($condition, 'u.username,u.status,u.uid,u.group_name', 'u.uid desc', 'ug', [
|
||||
[ 'user u', 'ug.uid=u.uid', 'left' ]
|
||||
]);
|
||||
|
||||
return $this->response($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取一周内的时间段
|
||||
* @return false|string
|
||||
*/
|
||||
public function getWeekDay()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$length = $this->params[ 'length' ] ?? 0;
|
||||
|
||||
$first_day = mktime(0, 0, 0, date("m"), date("d") - date("w") + 1, date("Y"));
|
||||
$first_day = strtotime($length . ' week', $first_day);
|
||||
|
||||
$week = [ '周日', '周一', '周二', '周三', '周四', '周五', '周六' ];
|
||||
$data = [];
|
||||
for ($i = 0; $i < 7; $i++) {
|
||||
$time = strtotime("+ {$i} day", $first_day);
|
||||
$data[] = [
|
||||
'start' => $time,
|
||||
'end' => strtotime(date('Y-m-d 23:59:59', $time)),
|
||||
'date' => date('m/d', $time),
|
||||
'w' => date('w', $time),
|
||||
'week' => $week[date('w', $time)],
|
||||
'currday' => date('Y-m-d', $time) == date('Y-m-d') ? 1 : 0
|
||||
];
|
||||
}
|
||||
return $this->response($this->success($data));
|
||||
}
|
||||
|
||||
/**
|
||||
* 确认预约
|
||||
* @return false|string
|
||||
*/
|
||||
public function confirm()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_id = $this->params['reserve_id'] ?? 0;
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->confirmReserve($reserve_id, $this->site_id);
|
||||
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 取消预约
|
||||
* @return false|string
|
||||
*/
|
||||
public function cancel()
|
||||
{
|
||||
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$reserve_id = $this->params['reserve_id'] ?? 0;
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->cancelReserve($reserve_id, $this->site_id);
|
||||
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 确认到店
|
||||
* @return false|string
|
||||
*/
|
||||
public function confirmToStore()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
$reserve_id = $this->params['reserve_id'] ?? 0;
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->confirmToStore($reserve_id, $this->site_id);
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 确认完成
|
||||
* @return false|string
|
||||
*/
|
||||
public function complete()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
$reserve_id = $this->params['reserve_id'] ?? 0;
|
||||
|
||||
$reserve_model = new ReserveModel();
|
||||
$res = $reserve_model->confirmComplete($reserve_id, $this->site_id);
|
||||
return $this->response($res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 服务列表
|
||||
* @return false|string
|
||||
*/
|
||||
public function serviceList()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
|
||||
$page_index = $this->params['page'] ?? 1;
|
||||
$page_size = $this->params['page_size'] ?? PAGE_LIST_ROWS;
|
||||
|
||||
$goods = new GoodsModel();
|
||||
$condition = [];
|
||||
$condition[] = [ 'gs.site_id', '=', $this->site_id ];
|
||||
$condition[] = [ 'g.goods_class', '=', GoodsDict::service ];
|
||||
$condition[] = [ 'g.goods_state', '=', 1 ];
|
||||
$condition[] = [ 'g.is_delete', '=', 0 ];
|
||||
$alias = 'gs';
|
||||
|
||||
$field = 'gs.is_consume_discount,gs.discount_config,gs.discount_method,gs.member_price,gs.goods_id,gs.sort,gs.sku_id,gs.sku_name,gs.price,gs.market_price,gs.discount_price,gs.stock,(g.sale_num + g.virtual_sale) as sale_num,(gs.sale_num + gs.virtual_sale) as sale_sort,gs.sku_image,gs.goods_name,gs.site_id,gs.is_free_shipping,gs.introduction,gs.promotion_type,g.goods_image,g.promotion_addon,gs.is_virtual,g.goods_spec_format,g.recommend_way,gs.max_buy,gs.min_buy,gs.unit,gs.is_limit,gs.limit_type,g.label_name,g.stock_show,g.sale_show,g.market_price_show,g.barrage_show,g.sale_channel,g.sale_store';
|
||||
$join = [
|
||||
[ 'goods g', 'gs.sku_id = g.sku_id', 'inner' ]
|
||||
];
|
||||
|
||||
$list = $goods->getGoodsSkuPageList($condition, $page_index, $page_size, 'g.sort desc', $field, $alias, $join);
|
||||
|
||||
return $this->response($list);
|
||||
}
|
||||
|
||||
/**
|
||||
* 预约详情
|
||||
* @return mixed|void
|
||||
*/
|
||||
public function detail()
|
||||
{
|
||||
$token = $this->checkToken();
|
||||
if ($token[ 'code' ] < 0) return $this->response($token);
|
||||
$reserve_id = $this->params['reserve_id'] ?? 0;
|
||||
|
||||
$model = new ReserveModel();
|
||||
|
||||
$info = $model->getReserveInfo([
|
||||
[ 'reserve_id', '=', $reserve_id ],
|
||||
[ 'oy.site_id', '=', $this->site_id ]
|
||||
], 'oy.*, nm.headimg, nm.nickname, nm.mobile,os.store_name', 'oy', [
|
||||
[ 'member nm', 'oy.member_id = nm.member_id', 'left' ],
|
||||
[ 'store os', 'oy.store_id = os.store_id', 'left' ]
|
||||
])[ 'data' ];
|
||||
|
||||
if (empty($info)) return $this->response($this->error('', '缺少必须参数'));
|
||||
|
||||
$info[ 'item' ] = $model->getReserveItemList([
|
||||
[
|
||||
'oyi.reserve_id', '=', $reserve_id
|
||||
],
|
||||
|
||||
], 'g.goods_name,g.goods_id,g.sku_id,g.price,sku.service_length,ys.username,oyi.reserve_user_id as uid', 'reserve_item_id desc', 'oyi',
|
||||
[ [ 'goods g', 'g.sku_id = oyi.reserve_goods_sku_id', 'right' ], [ 'goods_sku sku', 'sku.sku_id = oyi.reserve_goods_sku_id', 'right' ], [ 'user ys', 'oyi.reserve_user_id = ys.uid', 'left' ] ])[ 'data' ];
|
||||
|
||||
$member_model = new MemberModel();
|
||||
|
||||
$info[ 'member' ] = $member_model->getMemberInfo([ [ 'member_id', '=', $info[ 'member_id' ] ], [ 'site_id', '=', $this->site_id ] ], 'nickname,mobile,member_id')[ 'data' ] ?? [];
|
||||
|
||||
return $this->response($this->success($info));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user