$name; } /** * 检查购物车内商品是否存在 * @access public * @author csdeshang * @param array $condition 检索条件 * @return bool */ public function checkCart($condition = array()) { return Db::name('cart')->where($condition)->find(); } /** * 会员购物车内商品数 * @access public * @author csdeshang * @param int $memberId 会员ID * @return int */ public function getCartCountByMemberId($memberId) { $memberId = intval($memberId); return Db::name('cart')->where(array('buyer_id' => $memberId,))->sum('goods_num'); } /** * 取得 单条购物车信息 * @access public * @author csdeshang * @param array $condition 检索条件 * @param string $field 字段 * @return array */ public function getCartInfo($condition = array(), $field = '*') { return Db::name('cart')->field($field)->where($condition)->find(); } /** * 将商品添加到购物车中 * @access public * @author csdeshang * @param array $data 商品数据信息 * @param string $save_type 保存类型,可选值 db,cookie * @param int $quantity 购物数量 * @return type */ public function addCart($data = array(), $save_type = '', $quantity = null) { $method = '_addCartdb'; $result = $this->$method($data, $quantity); if (!$result) { return false; } //更改购物车总商品数和总金额,传递数组参数只是给DB使用 $this->getCartNum('db', array('buyer_id' => isset($data['buyer_id']) ? $data['buyer_id'] : 0)); return $result; } /** * 添加数据库购物车 * @access public * @author csdeshang * @param array $goods_info 商品信息 * @param int $quantity 购物数量 * @return type */ private function _addCartDb($goods_info = array(), $quantity) { //验证购物车商品是否已经存在 $condition = array(); $condition[] = array('goods_id', '=', $goods_info['goods_id']); $condition[] = array('buyer_id', '=', $goods_info['buyer_id']); if (isset($goods_info['bl_id'])) { $condition[] = array('bl_id', '=', $goods_info['bl_id']); } else { $condition[] = array('bl_id', '=', 0); } //如果购物车 $check_cart = $this->checkCart($condition); if (!empty($check_cart)) { $quantity = $check_cart['goods_num'] + $quantity; if ($quantity > $goods_info['goods_storage']) { $this->error_code = 10001; $this->error_message = '库存不足'; return false; } //如果商品存在则更新数量 return Db::name('cart')->where($condition)->update(array('goods_num' => $quantity)); } else { //如果商品存在则插入 $array = array(); $array['buyer_id'] = $goods_info['buyer_id']; $array['store_id'] = $goods_info['store_id']; $array['goods_id'] = $goods_info['goods_id']; $array['goods_name'] = $goods_info['goods_name']; $array['goods_price'] = $goods_info['goods_price']; $array['goods_num'] = $quantity; $array['goods_image'] = $goods_info['goods_image']; $array['store_name'] = $goods_info['store_name']; $array['bl_id'] = isset($goods_info['bl_id']) ? $goods_info['bl_id'] : 0; return Db::name('cart')->insertGetId($array); } } /** * 更新购物车 * @access public * @author csdeshang * @param array $data 商品信息 * @param array $condition 检索条件 * @return bool */ public function editCart($data, $condition, $buyer_id) { $result = Db::name('cart')->where($condition)->update($data); if ($result) { $this->getCartNum('db', array('buyer_id' => $buyer_id)); } return $result; } /** * 购物车列表 * @access public * @author csdeshang * @param string $type 存储类型 db,cookie * @param array $condition 检索条件 * @param int $limit 限制 * @return array */ public function getCartList($type, $condition = array(), $limit = 0) { $cart_list = Db::name('cart')->where($condition)->limit($limit)->select()->toArray(); $cart_list = is_array($cart_list) ? $cart_list : array(); //顺便设置购物车商品数和总金额 $this->cart_goods_num = count($cart_list); $cart_all_price = 0; if (is_array($cart_list)) { foreach ($cart_list as $val) { $cart_all_price += $val['goods_price'] * $val['goods_num']; } } $this->cart_all_price = ds_price_format($cart_all_price); return !is_array($cart_list) ? array() : $cart_list; } /** * 删除购物车商品 * @access public * @author csdeshang * @param string $type 存储类型 db,cookie * @param array $condition 检索条件 * @return bool */ public function delCart($type, $condition = array(), $buyer_id) { $result = Db::name('cart')->where($condition)->delete(); //重新计算购物车商品数和总金额 if ($result) { $this->getCartNum('db', array('buyer_id' => $buyer_id)); } return $result; } /** * 清空购物车 * @access public * @author csdeshang * @param string $type 存储类型 db,cookie * @param array $condition 检索条件 * @return bool */ public function clearCart($type, $condition = array()) { //数据库暂无浅清空操作 } /** * 计算购物车总商品数和总金额 * @access public * @author csdeshang * @param string $type 购物车信息保存类型 db,cookie * @param array $condition 只有登录后操作购物车表时才会用到该参数 * @return type */ public function getCartNum($type, $condition = array()) { $cart_all_price = 0; $cart_goods = $this->getCartList('db', $condition); $this->cart_goods_num = count($cart_goods); if (!empty($cart_goods) && is_array($cart_goods)) { foreach ($cart_goods as $val) { $cart_all_price += $val['goods_price'] * $val['goods_num']; } } $this->cart_all_price = ds_price_format($cart_all_price); @cookie('cart_goods_num', $this->cart_goods_num, 2 * 3600); return $this->cart_goods_num; } }