123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- <?php
- /**
- * 秒杀活动模型
- *
- */
- namespace app\common\model;
- use think\facade\Db;
- /**
-
- *
-
- *
- * ----------------------------------------------------------------------------
- *
-
- * 数据层模型
- */
- class Pxianshi extends BaseModel
- {
- public $page_info;
- const XIANSHI_STATE_NORMAL = 1;
- const XIANSHI_STATE_CLOSE = 2;
- const XIANSHI_STATE_CANCEL = 3;
- private $xianshi_state_array = array(
- 0 => '全部',
- self::XIANSHI_STATE_NORMAL => '正常',
- self::XIANSHI_STATE_CLOSE => '已结束',
- self::XIANSHI_STATE_CANCEL => '管理员关闭'
- );
- /**
- * 读取秒杀列表
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @param type $pagesize 分页
- * @param type $order 排序
- * @param type $field 字段
- * @return type
- */
- public function getXianshiList($condition, $pagesize = null, $order = '', $field = '*')
- {
- if ($pagesize) {
- $res = Db::name('pxianshi')->field($field)->where($condition)->order($order)->paginate(['list_rows' => $pagesize, 'query' => request()->param()], false);
- $this->page_info = $res;
- $xianshi_list = $res->items();
- } else {
- $xianshi_list = Db::name('pxianshi')->field($field)->where($condition)->order($order)->select()->toArray();
- }
- if (!empty($xianshi_list)) {
- for ($i = 0, $j = count($xianshi_list); $i < $j; $i++) {
- $xianshi_list[$i] = $this->getXianshiExtendInfo($xianshi_list[$i]);
- }
- }
- return $xianshi_list;
- }
- /**
- * 根据条件读取限制折扣信息
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @return type
- */
- public function getXianshiInfo($condition)
- {
- $xianshi_info = Db::name('pxianshi')->where($condition)->find();
- $xianshi_info = $this->getXianshiExtendInfo($xianshi_info);
- return $xianshi_info;
- }
- /**
- * 根据秒杀编号读取限制折扣信息
- * @access public
- * @author csdeshang
- * @param type $xianshi_id 限制折扣活动编号
- * @param type $store_id 如果提供店铺编号,判断是否为该店铺活动,如果不是返回null
- * @return array
- */
- public function getXianshiInfoByID($xianshi_id, $store_id = 0)
- {
- if (intval($xianshi_id) <= 0) {
- return null;
- }
- $condition = array();
- $condition[] = array('xianshi_id', '=', $xianshi_id);
- $xianshi_info = $this->getXianshiInfo($condition);
- if ($store_id > 0 && $xianshi_info['store_id'] != $store_id) {
- return null;
- } else {
- return $xianshi_info;
- }
- }
- /**
- * 秒杀状态数组
- * @access public
- * @author csdeshang
- * @return type
- */
- public function getXianshiStateArray()
- {
- return $this->xianshi_state_array;
- }
- /**
- * 增加
- * @access public
- * @author csdeshang
- * @param array $data 数据
- * @return bool
- */
- public function addXianshi($data)
- {
- $data['xianshi_state'] = self::XIANSHI_STATE_NORMAL;
- return Db::name('pxianshi')->insertGetId($data);
- }
- /**
- * 更新
- * @access public
- * @author csdeshang
- * @param type $update 数据
- * @param type $condition 条件
- * @return type
- */
- public function editXianshi($update, $condition)
- {
- return Db::name('pxianshi')->where($condition)->update($update);
- }
- /**
- * 删除秒杀活动,同时删除秒杀商品
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @return bool
- */
- public function delXianshi($condition)
- {
- $xianshi_list = $this->getXianshiList($condition);
- $xianshi_id_string = '';
- if (!empty($xianshi_list)) {
- foreach ($xianshi_list as $value) {
- $xianshi_id_string .= $value['xianshi_id'] . ',';
- }
- }
- //删除秒杀商品
- if ($xianshi_id_string !== '') {
- $xianshigoods_model = model('pxianshigoods');
- $xianshigoods_model->delXianshigoods(array(array('xianshi_id', 'in', $xianshi_id_string)));
- }
- return Db::name('pxianshi')->where($condition)->delete();
- }
- /**
- * 取消秒杀活动,同时取消秒杀商品
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @return type
- */
- public function cancelXianshi($condition)
- {
- $xianshi_list = $this->getXianshiList($condition);
- $xianshi_id_string = '';
- if (!empty($xianshi_list)) {
- foreach ($xianshi_list as $value) {
- $xianshi_id_string .= $value['xianshi_id'] . ',';
- }
- }
- $update = array();
- $update['xianshi_state'] = self::XIANSHI_STATE_CANCEL;
- //删除秒杀商品
- if ($xianshi_id_string !== '') {
- $xianshigoods_model = model('pxianshigoods');
- $condition = array();
- $condition[] = array('xianshi_id', 'in', $xianshi_id_string);
- $xianshigoods_model->editXianshigoods(array('xianshigoods_state' => self::XIANSHI_STATE_CANCEL), $condition);
- }
- return $this->editXianshi($update, $condition);
- }
- /**
- * 获取秒杀扩展信息,包括状态文字和是否可编辑状态
- * @access public
- * @author csdeshang
- * @param type $xianshi_info 秒杀信息
- * @return boolean
- */
- public function getXianshiExtendInfo($xianshi_info)
- {
- if ($xianshi_info['xianshi_end_time'] > TIMESTAMP) {
- $xianshi_info['xianshi_state_text'] = $this->xianshi_state_array[$xianshi_info['xianshi_state']];
- } else {
- $xianshi_info['xianshi_state_text'] = '已结束';
- }
- if ($xianshi_info['xianshi_state'] == self::XIANSHI_STATE_NORMAL && $xianshi_info['xianshi_end_time'] > TIMESTAMP) {
- $xianshi_info['editable'] = true;
- } else {
- $xianshi_info['editable'] = false;
- }
- return $xianshi_info;
- }
- /**
- * 编辑过期修改状态
- * @access public
- * @author csdeshang
- * @param type $condition
- * @return boolean
- */
- public function editExpireXianshi($condition)
- {
- $condition[] = array('xianshi_end_time', '<', TIMESTAMP);
- // 更新商品促销价格
- $xianshigoods_list = model('pxianshigoods')->getXianshigoodsList(array(array('xianshigoods_end_time', '<', TIMESTAMP)));
- if (!empty($xianshigoods_list)) {
- $goodsid_array = array();
- foreach ($xianshigoods_list as $val) {
- $goodsid_array[] = $val['goods_id'];
- }
- // 更新商品促销价格,需要考虑抢购是否在进行中
- model('cron')->addCron(array('cron_exetime' => TIMESTAMP, 'cron_type' => 'updateGoodsPromotionPriceByGoodsId', 'cron_value' => serialize($goodsid_array)));
- }
- $condition[] = array('xianshi_state', '=', self::XIANSHI_STATE_NORMAL);
- $updata = array();
- $update['xianshi_state'] = self::XIANSHI_STATE_CLOSE;
- $result = $this->editXianshi($update, $condition);
- if ($result) {
- foreach ($xianshigoods_list as $value) {
- $this->_unlockGoods($value['goods_commonid']);
- }
- }
- return true;
- }
- /**
- * 解锁商品
- * @access private
- * @author csdeshang
- * @param type $goods_commonid 商品编号ID
- */
- private function _unlockGoods($goods_commonid)
- {
- $goods_model = model('goods');
- $goods_model->editGoodsCommonUnlock(array('goods_commonid' => $goods_commonid));
- $goods_model->editGoodsUnlock(array('goods_commonid' => $goods_commonid));
- // 添加对列 更新商品促销价格
- model('cron')->addCron(array('cron_exetime' => TIMESTAMP, 'cron_type' => 'updateGoodsPromotionPriceByGoodsCommonId', 'cron_value' => serialize($goods_commonid)));
- }
- }
|