### 根據商品ID查詢滿足的滿折活動詳情(詳情頁展示用)
**位置:**
Common\Lib\EventLib.class.php
**參數:**
* @param $no_id int 商品編碼ID
* @param $type int 商品編碼ID類型, 1表示傳入的是唯一碼,2表示傳入的是SKU, 3表示傳入的是SKC
**調用:**
* $event = new EventLib();
* $discount_event = $event->getTotalDiscount($sku_id, 2);
**返回:**
返回滿折活動多維數組$event,遍歷數組獲取每個活動的信息,活動各項含義如下:
['id'] // 活動ID
['event_name'] // 活動名稱
['start_time'] // 活動開始時間
['end_time'] // 活動結束時間
['rules] // 活動規則數組
活動規則格式:
滿[full]打[event_reduce]折
['shops_ids'] // 參與門店ID(1表示全部門店參與)
['shops'] // 參與門店數組(為空表示全部門店參與)
['actor'] // 參與人員數組,為空表示所有人都參與
['enjoy'] // 是否同時參與會員折扣,1表示是,0表示否
['prior'] // 會員是否優先參與活動,1表示是,0表示否
['prior_days'] // 會員優先天數
['rate'] // 積分倍率
**完整代碼:**
~~~
/**
* 根據商品ID查詢滿足的滿折活動詳情
* QuJinming 2018-07-18
* @param int $no_id 商品ID
* @param int $type 商品ID類型 1表示傳入的是唯一碼,2表示傳入的是SKU,3表示傳入的SKC
* @return array $event 商品滿足的滿折活動信息
*/
function getTotalDiscount($no_id, $type) {
// 1、調用封裝的查詢是否有滿減活動的方法,獲取滿減活動列表
$active = check_total_discount($no_id, $type);
// 2、如果查詢到的活動為空,直接返回
if (empty($active)) {
return;
}
// 3、遍歷活動列表,依次查詢活動信息
foreach ($active as $key => $value) {
// 查詢最優活動基本信息
$event_basic = M('event_basic')->where('id='.$value['id'])->find();
// 查詢活動規則
$event_rules = M('event_rules')->field('full, event_reduce')->where('event_id='.$value['id'])->select();
// 查詢活動參與門店
$shops_ids = M('event_shop')->where('event_id='.$value['id'])->getField('shops_id',true);
foreach ($shops_ids as $kk => $vv) {
if ($vv == 1) {
$event_shops = '';
break;
}
$event_shops[$kk] = M('shops')->where('id='.$vv)->getField('shops_name');
}
$event[$key]['id'] = $event_basic['id']; // 活動ID
$event[$key]['event_name'] = $event_basic['event_name']; // 活動名稱
$event[$key]['start_time'] = $event_basic['start_time']; // 活動開始時間
$event[$key]['end_time'] = $event_basic['end_time']; // 活動結束時間
$event[$key]['rules'] = $event_rules; // 活動規則
$event[$key]['shops_ids'] = $shops_ids; // 參與門店ID
$event[$key]['shops'] = $event_shops; // 參與門店
$actor = explode(",", $event_basic['actor']); // 參與人員
if ($actor[0] == 0) {
$event[$key]['actor'] = ''; // 參與人員
} else {
$event[$key]['actor'] = $actor; // 參與人員
}
$event[$key]['enjoy'] = $event_basic['enjoy']; // 會員顧客可同時參與會員折扣
$event[$key]['prior'] = $event_basic['prior']; // 會員優先參與活動
$event[$key]['prior_days'] = $event_basic['prior_days']; // 會員優先天數
$event[$key]['rate'] = $event_basic['rate']; // 積分倍率
}
// 4、返回活動信息列表
return $event;
}
~~~
- 模版
- 前言
- 項目架構
- 項目規范
- HTML
- CSS
- Javascript
- PHP
- MySQL
- 注意規范
- 開發版本管理
- 開發流程
- 系統配置
- 阿里云服務器配置
- 計劃任務配置說明
- 開發示例
- Page分頁
- Search_param搜索結果賦值
- Add新增
- Edit編輯
- Ajax表單驗證
- Ajax二級聯動
- Excel 導出數據首位不去0的方法
- POS總部控制
- 下載CSV格式的模板
- 訂單唯一碼表和訂單SKU表實收金額生成
- 快捷日期選擇
- JS函數
- ajax_send
- ajax_result
- createQrCodes
- createBarCodes
- printTpl
- JS插件
- BootstrapValidator表單驗證插件
- Address省市區插件
- Bootstrap-datepicker日期插件
- Bootstrap-select多選框插件
- Toastr消息提示插件
- PalyAudit掃描聲音提示插件
- WebUploader多圖片上傳插件
- Ueditor富文本編輯器插件
- Function
- alert
- object_to_array
- array_to_object
- get_address
- set_param_url
- get_shops_name
- get_user_name
- get_warehouse
- get_cheapest_sku
- print_attr(新)
- print_img(新)
- get_spu_no(新)
- get_type_name(新)
- get_brand_en(新)
- get_cat_name(新)
- get_attr_name(新)
- spu_cat_info(新)
- get_time_event_price
- get_vendors
- check_total_reduce
- check_total_discount
- get_inventory
- get_delivery
- get_sale_inventory
- get_customer_name
- phone_protection
- get_order_no
- get_event_name
- get_order_status
- get_item_status
- get_ditch_name
- get_card_no
- get_shop_sales
- get_pay_name
- get_season
- amt_format
- get_cat_parent
- print_attr_id
- round_bcadd
- round_bcsub
- round_bcmul
- round_bcdiv
- get_account_name
- Controller
- Common_BaseController
- check_membership_card
- get_menu_list
- importErrorMassage
- Wpos_IndexController
- get_customer_vip_card
- get_shops_id
- calculate_active_integral
- check_numbers_active
- check_goods_active
- Woms_IndexController
- Model
- View
- category
- cycle_date.html
- shop_select門店多選搜索框
- 品牌A-Z排序多選brand_mc.html
- 供應商代碼A-Z排序vendor_no_mc.html
- Lib
- BuyerLib
- WarehouseLib
- EventLib
- getTimeEventPrice
- getVipType
- getEvent
- orderTotalEvent
- orderTimeEvent
- getTotalReduce
- getTotalDiscount
- SaleLib
- CustomerLib
- addCustomerService
- GiftcardLib
- WechatLib
- wxRefund
- OrdersLib
- orderLog
- calculatePayinAmount
- calculateSubtotal
- correctPayinAmount
- saveOrderAddress
- getOrderAddress
- setDeliveryNo
- SyncLib
- updateOuterStock
- UserLib
- createCommission
- FlowLib
- orderList
- addOrder
- addLog
- orderInfo
- checkSku
- orderSave
- orderStop
- orderExecute
- skuEdit
- orderPrinta
- scanGoods
- boxClose
- orderOut
- take
- bview
- check
- deliveryStatus
- checkGoods
- GoodsLib
- createGoodsNo
- createNewGoodsNo
- getSystemStyleNo
- getDim
- MallLib
- smsLog
- GoodsBaseLib
- getBrandInfo
- getBrandsInfo
- getAttrIdArray
- getPrintAttr
- getMustAttr
- getCatIdInfo
- valTypeId
- valsTypeId
- getCatNoInfo
- getCatInfo
- getAttrArr
- getAttrInfo
- getValInfo
- getAttrId
- getValId
- getAttrSeaon
- getValueId
- PointsLog
- pointsIn
- pointsUp
- EcGoodsLib
- getSkuInventory
- Tools
- CsvTools
- csvImport
- csvExport
- ExcelTools
- importExcel
- exportExcel
- exportHeadExcel
- MailTools
- SmsTools
- sendMessage
- UploadTools
- ExportTools
- exportData
- TaobaoTools
- getOnsaleItems
- getSkusItems
- PicturesTools
- uploadPicture
- Plugins
- WxBase
- Taobao
- 問題反饋