123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- <?php
- namespace app\common\model;
- use think\facade\Db;
- /**
- * ============================================================================
- * DSMall多用户商城
- * ============================================================================
- * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
- * 网站地址: http://www.csdeshang.com
- * ----------------------------------------------------------------------------
- * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
- * 不允许对程序代码以任何形式任何目的的再发布。
- * ============================================================================
- * 数据层模型
- */
- class Address extends BaseModel {
- /**
- * 取得买家默认收货地址
- * @author csdeshang
- * @param array $condition 获取条件
- * @param string $order 排序
- * @return array
- */
- public function getDefaultAddressInfo($condition = array(), $order = 'address_is_default desc,chain_id asc,address_id desc') {
- return $this->getAddressInfo($condition, $order);
- }
- /**
- * 取得单条地址信息
- * @author csdeshang
- * @param array $condition 条件
- * @param type $order 排序
- * @return string
- */
- public function getAddressInfo($condition, $order = '') {
- $addr_info = Db::name('address')->where($condition)->order($order)->find();
- if ($addr_info['chain_id']) {
- if(config('ds_config.chain_isuse')){
- $chain_model = model('chain');
- $chain_info = $chain_model->getChainOpenInfo(array(array('chain_id' ,'=', $addr_info['chain_id'])));
- if (!empty($chain_info)) {
- if($addr_info['city_id'] !== $chain_info['chain_area_2'] || $addr_info['area_id'] !== $chain_info['chain_area_3']){
- $addr_info['cityerror'] = true;
- }else{
- $addr_info['cityerror'] = false;
- }
- $addr_info['chain_if_pickup'] = $chain_info['chain_if_pickup'];
- $addr_info['chain_if_collect'] = $chain_info['chain_if_collect'];
- $addr_info['chain_mobile'] = $chain_info['chain_mobile'];
- $addr_info['chain_telephony'] = $chain_info['chain_telephony'];
- $addr_info['chain_addressname'] = $chain_info['chain_addressname'];
- $addr_info['chain_area_info'] = $chain_info['chain_area_info'];
- $addr_info['chain_address'] = $chain_info['chain_address'];
- $addr_info['chain_mobile'] = $chain_info['chain_mobile'];
- $addr_info['area_id'] = $chain_info['chain_area_3'];
- $addr_info['area_info'] = $chain_info['chain_area_info'];
- $addr_info['address_detail'] = '(' . $chain_info['chain_addressname'] . ') ' . $chain_info['chain_address']
- . ',电话:' . trim($chain_info['chain_mobile'] . ',' . $chain_info['chain_telephony'], ',');
- }else{
- $addr_info=false;
- }
- }else{
- $addr_info=false;
- }
- }
- if(!empty($addr_info && $addr_info['chain_id'] == 0)){
- $addr_info['cityerror'] = false;
- }
-
- return $addr_info;
- }
- /**
- * 读取地址列表
- * @author csdeshang
- * @param array $condition 查询条件
- * @param type $order 排序
- * @return array 数组格式的返回结果
- */
- public function getAddressList($condition, $order = 'address_id desc') {
- $address_list = Db::name('address')->where($condition)->order($order)->select()->toArray();
- if (empty($address_list))
- return array();
- if (config('ds_config.chain_isuse')) {
- $chain_ids = array();
- $chain_new_list = array();
- foreach ($address_list as $k => $v) {
- if ($v['chain_id']) {
- $chain_ids[] = $v['chain_id'];
- }
- }
- if (!empty($chain_ids)) {
- $chain_model = model('chain');
- $condition = array();
- $condition[] = array('chain_id','in', $chain_ids);
- $chain_list = $chain_model->getChainOpenList($condition);
- foreach ($chain_list as $k => $v) {
- $chain_new_list[$v['chain_id']] = $v;
- }
- }
- if (!empty($chain_new_list)) {
- foreach ($address_list as $k => $v) {
- if (!$v['chain_id'])
- continue;
- if($v['chain_id'] && !isset($chain_new_list[$v['chain_id']])){
- unset($address_list[$k]);
- continue;
- }
- $chain_info = $chain_new_list[$v['chain_id']];
- $address_list[$k]['area_info'] = $chain_info['chain_area_info'];
- $address_list[$k]['address_detail'] = '(' . $chain_info['chain_addressname'] . ') ' . $chain_info['chain_address']
- . ',电话:' . trim($chain_info['chain_mobile'] . ',' . $chain_info['chain_telephony'], ',');
- }
- }
- }
- $address_list=array_values($address_list);
- return $address_list;
- }
- /**
- * 取数量
- * @author csdeshang
- * @param array $condition 条件
- * @return int
- */
- public function getAddressCount($condition = array()) {
- return Db::name('address')->where($condition)->count();
- }
- /**
- * 新增地址
- * @author csdeshang
- * @param array $data 参数内容
- * @return bool 布尔类型的返回结果
- */
- public function addAddress($data) {
- //当设置为默认地址,则此用户其他的地址设置为非默认地址
- if($data['address_is_default']==1){
- Db::name('address')->where('member_id',$data['member_id'])->update(array('address_is_default'=>0));
- }
- return Db::name('address')->insertGetId($data);
- }
- /**
- * 取单个地址
- * @author csdeshang
- * @param int $id 地址ID
- * @return array 数组类型的返回结果
- */
- public function getOneAddress($id) {
- if (intval($id) > 0) {
- $result = Db::name('address')->where('address_id',intval($id))->find();
- return $result;
- } else {
- return false;
- }
- }
- /**
- * 更新地址信息
- * @author csdeshang
- * @param array $update 更新数据
- * @param array $condition 更新条件
- * @return bool 布尔类型的返回结果
- */
- public function editAddress($update, $condition) {
- return Db::name('address')->where($condition)->update($update);
- }
- /**
- * 验证地址是否属于当前用户
- * @author csdeshang
- * @param array $member_id 会员id
- * @param array $address_id 地址id
- * @return bool 布尔类型的返回结果
- */
- public function checkAddress($member_id, $address_id) {
- /**
- * 验证地址是否属于当前用户
- */
- $check_array = self::getOneAddress($address_id);
- if ($check_array['member_id'] == $member_id) {
- unset($check_array);
- return true;
- }
- unset($check_array);
- return false;
- }
- /**
- * 删除地址
- * @author csdeshang
- * @param array $condition记录ID
- * @return bool 布尔类型的返回结果
- */
- public function delAddress($condition) {
- return Db::name('address')->where($condition)->delete();
- }
- }
- ?>
|