$_W['uniacid'], ':acid' => $acid));
if(checksubmit('submit')) {
$_GPC['logo'] = trim($_GPC['logo']);
empty($_GPC['logo']) && message('请上传商户logo', referer(), 'info');
$data = array(
'uniacid' => $_W['uniacid'],
'acid' => $acid,
'logourl' => $_GPC['logo'],
);
if(empty($coupon_setting)) {
pdo_insert('coupon_setting', $data);
} else {
pdo_update('coupon_setting', $data, array('uniacid' => $_W['uniacid']));
}
message('上传商户LOGO成功', referer(), 'success');
}
}
if($do != 'logo') {
if($_W['account']['level'] != ACCOUNT_SERVICE_VERIFY && $_W['account']['level'] != ACCOUNT_SUBSCRIPTION_VERIFY) {
header('Location:' . url('activity/store/list'));
die;
}
}
if($do == 'post') {
if(checksubmit('submit')) {
$data['business_name'] = trim($_GPC['business_name']) ? urlencode(trim($_GPC['business_name'])) : message('门店名称不能为空');
$data['branch_name'] = urlencode(trim($_GPC['branch_name']));
$cate = array();
$in_cate = array();
if(!empty($_GPC['class']['cate']) && !empty($_GPC['class']['sub'])) {
$class = array($_GPC['class']['cate'], $_GPC['class']['sub']);
$in_cate = array('cate' => $_GPC['class']['cate'], 'sub' => $_GPC['class']['sub']);
if(!empty($_GPC['class']['clas'])) {
$class[] = $_GPC['class']['clas'];
$in_cate['clas'] = $_GPC['class']['clas'];
}
$cate = array(urlencode(implode($class, ',')));
}
if(empty($cate)) {
message('门店类目不能为空');
}
$data['categories'] = $cate;
$data['province'] = trim($_GPC['reside']['province']) ? urlencode(trim($_GPC['reside']['province'])) : message('请选择门店所在省');
$data['city'] = trim($_GPC['reside']['city']) ? urlencode(trim($_GPC['reside']['city'])) : message('请选择门店所在市');
$data['district'] = trim($_GPC['reside']['district']) ? urlencode(trim($_GPC['reside']['district'])) : message('请选择门店所在区');
$data['address'] = trim($_GPC['address']) ? urlencode(trim($_GPC['address'])) : message('门店详细地址不能为空');
$data['longitude'] = trim($_GPC['baidumap']['lng']) ? trim($_GPC['baidumap']['lng']) : message('请选择门店所在地理位置经度');
$data['latitude'] = trim($_GPC['baidumap']['lat']) ? trim($_GPC['baidumap']['lat']) : message('请选择门店所在地理位置维度');
$data['telephone'] = trim($_GPC['telephone']) ? trim($_GPC['telephone']) : message('门店电话不能为空');
if(empty($_GPC['photo_list'])) {
message('门店图片不能为空');
} else {
foreach($_GPC['photo_list'] as $val) {
if(empty($val)) continue;
$data['photo_list'][] = array('photo_url' => $val);
}
}
$data['avg_price'] = intval($_GPC['avg_price']);
if(empty($_GPC['open_time_start']) || empty($_GPC['open_time_end'])) {
message('营业时间不能为空');
} else {
$data['open_time'] = $_GPC['open_time_start'] . '-' . $_GPC['open_time_end'];
}
$data['recommend'] = urlencode(trim($_GPC['recommend']));
$data['special'] = trim($_GPC['special']) ? urlencode(trim($_GPC['special'])) : message('特色服务不能为空');
$data['introduction'] = urlencode(trim($_GPC['introduction']));
$data['offset_type'] = 1;
$data['sid'] = TIMESTAMP;
load()->classs('coupon');
$acc = new coupon($acid);
$status = $acc->LocationAdd($data);
if(is_error($status)) {
message($status['message'], '', 'error');
}
$insert['uniacid'] = $_W['uniacid'];
$insert['sid'] = $data['sid'];
$insert['business_name'] = trim($_GPC['business_name']);
$insert['branch_name'] = trim($_GPC['branch_name']);
$insert['category'] = iserializer($in_cate);
$insert['province'] = trim($_GPC['reside']['province']);
$insert['city'] = trim($_GPC['reside']['city']);
$insert['district'] = trim($_GPC['reside']['district']);
$insert['address'] = trim($_GPC['address']);
$insert['longitude'] = trim($_GPC['baidumap']['lng']);
$insert['latitude'] = trim($_GPC['baidumap']['lat']);
$insert['telephone'] = trim($_GPC['telephone']);
$insert['location_id'] = $status['location_id_list'][0];
$insert['photo_list'] = iserializer($data['photo_list']);
$insert['avg_price'] = intval($_GPC['avg_price']);
$insert['open_time'] = $_GPC['open_time_start'] . '-' . $_GPC['open_time_end'];
$insert['recommend'] = trim($_GPC['recommend']);
$insert['special'] = trim($_GPC['special']);
$insert['introduction'] = trim($_GPC['introduction']);
$insert['offset_type'] = 1;
$insert['status'] = 2;
$insert['type'] = 2;
pdo_insert('activity_stores', $insert);
$id = pdo_insertid();
message('添加门店成功', url('wechat/location/list'), 'success');
}
}
if($do == 'edit') {
$id = intval($_GPC['id']);
$location = pdo_fetch('SELECT * FROM ' . tablename('activity_stores') . ' WHERE uniacid = :aid AND id = :id', array(':aid' => $_W['uniacid'], ':id' => $id));
if(empty($location)) {
message('门店不存在或已删除', referer(), 'error');
}
load()->classs('coupon');
$acc = new coupon($acid);
$location = $acc->LocationGet($location['location_id']);
if(is_error($location)) {
message("从微信获取门店信息失败,错误详情:{$location['message']}", referer(), 'error');
}
$update_status = $location['business']['base_info']['update_status'];
if(checksubmit('submit')) {
if(empty($location['location_id'])) {
message('门店正在审核中或审核未通过,不能更新门店信息', referer(), 'error');
}
if($update_status == 1) {
message('服务信息正在更新中,尚未生效,不允许再次更新', referer(), 'error');
}
$data['telephone'] = trim($_GPC['telephone']) ? trim($_GPC['telephone']) : message('门店电话不能为空');
if(empty($_GPC['photo_list'])) {
message('门店图片不能为空');
} else {
foreach($_GPC['photo_list'] as $val) {
if(empty($val)) continue;
$data['photo_list'][] = array('photo_url' => $val);
}
}
$data['avg_price'] = intval($_GPC['avg_price']);
if(empty($_GPC['open_time_start']) || empty($_GPC['open_time_end'])) {
message('营业时间不能为空');
} else {
$data['open_time'] = $_GPC['open_time_start'] . '-' . $_GPC['open_time_end'];
}
$data['recommend'] = urlencode(trim($_GPC['recommend']));
$data['special'] = trim($_GPC['special']) ? urlencode(trim($_GPC['special'])) : message('特色服务不能为空');
$data['introduction'] = urlencode(trim($_GPC['introduction']));
$data['poi_id'] = $location['location_id'];
load()->classs('coupon');
$acc = new coupon($acid);
$status = $acc->LocationEdit($data);
if(is_error($status)) {
message($status['message'], '', 'error');
}
}
$location = $location['business']['base_info'];
$status2local = array('', 3, 2, 1, 3);
$location['status'] = $status2local[$location['available_state']];
$location['location_id'] = $location['poi_id'];
$category_temp = explode(',', $location['categories'][0]);
$location['category'] = iserializer(array('cate' => $category_temp[0], 'sub' => $category_temp[1], 'clas' => $category_temp[2]));
$location['photo_list'] = iserializer($location['photo_list']);
unset($location['sid'], $location['categories'], $location['poi_id'], $location['update_status'], $location['available_state']);
pdo_update('activity_stores', $location, array('uniacid' => $_W['uniacid'], 'id' => $id));
$location = array();
$location = pdo_fetch('SELECT * FROM ' . tablename('activity_stores') . ' WHERE uniacid = :aid AND id = :id', array(':aid' => $_W['uniacid'], ':id' => $id));
$location['open_time_start'] = '8:00';
$location['open_time_end'] = '24:00';
$open_time = explode('-', $location['open_time']);
if(!empty($open_time)) {
$location['open_time_start'] = $open_time[0];
$location['open_time_end'] = $open_time[1];
}
$location['category'] = iunserializer($location['category']);
$location['category'] = implode('-', $location['category']);
$location['address'] = $location['provice'].$location['city'].$location['district'].$location['address'];
$location['baidumap'] = array('lng' => $location['longitude'], 'lat' => $location['latitude']);
$photo_lists = iunserializer($location['photo_list']);
$location['photo_list'] = array();
if(!empty($photo_lists)) {
foreach($photo_lists as $li) {
if(!empty($li['photo_url'])) {
$location['photo_list'][] = $li['photo_url'];
}
}
}
}
if($do == 'list') {
$pindex = max(1, intval($_GPC['page']));
$psize = 20;
$condition = ' WHERE `uniacid`=:uniacid';
$pars = array();
$pars[':uniacid'] = $_W['uniacid'];
$total = pdo_fetchcolumn("SELECT COUNT(*) FROM ".tablename('activity_stores').$condition, $pars);
$list = pdo_fetchall("SELECT * FROM ".tablename('activity_stores') . $condition ." ORDER BY id DESC LIMIT ".($pindex - 1) * $psize.','.$psize, $pars);
if(!empty($list)) {
foreach($list as &$li) {
$temp = iunserializer($li['category']);
$li['category_'] = implode('-', $temp);
}
}
$pager = pagination($total, $pindex, $psize);
}
if($do == 'del') {
$id = intval($_GPC['id']);
$count = pdo_fetchcolumn('SELECT COUNT(*) FROM ' . tablename('activity_clerks') . ' WHERE uniacid = :uniacid AND storeid = :id', array(':id' => $_GPC['id'], ':uniacid' => $_W['uniacid']));
$count = intval($count);
if($count > 0) {
message("该门店下有{$count}名店员.请将店员变更到其他门店后,再进行删除操作", referer(), 'error');
}
$location = pdo_fetch('SELECT status,location_id FROM ' . tablename('activity_stores') . ' WHERE uniacid = :aid AND id = :id', array(':aid' => $_W['uniacid'], ':id' => $id));
if(!empty($location['location_id'])) {
load()->classs('coupon');
$acc = new coupon($acid);
$status = $acc->LocationDel($location['location_id']);
}
pdo_delete('activity_stores', array('uniacid' => $_W['uniacid'], 'id' => $id));
if(is_error($status)) {
message("删除本地门店数据成功
通过微信接口删除微信门店数据失败,请登陆微信公众平台手动删除门店
错误原因:{$status['message']}", url('wechat/location/list'), 'error');
}
message('删除门店成功', url('wechat/location/list'), 'success');
}
if($do == 'export') {
load()->classs('coupon');
$acc = new coupon($acid);
$begin = intval($_GPC['begin']);
$data = $acc->LocationBatchGet(array('begin' => $begin));
if(is_error($data)) {
message($data['message'], referer(), 'error');
}
if(!$begin) {
pdo_delete('activity_stores', array('uniacid' => $_W['uniacid']));
}
$location = $data['business_list'];
$status2local = array('', 3, 2, 1, 3);
if(!empty($location)) {
foreach($location as $row) {
$isexist = array();
$li = array();
$li = $row['base_info'];
if($li['available_state'] == 3) {
$isexist = pdo_fetchcolumn('SELECT id FROM ' . tablename('activity_stores') . ' WHERE uniacid = :uniacid AND location_id = :location_id', array(':uniacid' => $_W['uniacid'], ':location_id' => $li['poi_id']));
if(empty($isexist)) {
$li['uniacid'] = $_W['uniacid'];
$li['status'] = 1;
$li['location_id'] = $li['poi_id'];
$category_temp = explode(',', $li['categories'][0]);
$li['category'] = iserializer(array('cate' => $category_temp[0], 'sub' => $category_temp[1], 'clas' => $category_temp[2]));
$li['photo_list'] = iserializer($li['photo_list']);
if(empty($li['sid'])) {
unset($li['sid']);
}
$li['type'] = 2;
unset($li['categories'], $li['poi_id'], $li['update_status'], $li['available_state']);
pdo_insert('activity_stores', $li);
}
} else {
$select_type == 'sid';
if(!empty($li['sid'])) {
$isexist = pdo_fetch('SELECT id,sid FROM ' . tablename('activity_stores') . ' WHERE uniacid = :uniacid AND (sid = :sid OR id = :sid)', array(':uniacid' => $_W['uniacid'], ':sid' => $li['sid']));
}
if(empty($isexist)) {
$select_type = 'location';
$isexist = pdo_fetch('SELECT id,sid FROM ' . tablename('activity_stores') . ' WHERE uniacid = :uniacid AND location_id = :location_id', array(':uniacid' => $_W['uniacid'], ':location_id' => $li['poi_id']));
}
$li['uniacid'] = $_W['uniacid'];
$li['status'] = $status2local[$li['available_state']];
$li['location_id'] = $li['poi_id'];
$category_temp = explode(',', $li['categories'][0]);
$li['category'] = iserializer(array('cate' => $category_temp[0], 'sub' => $category_temp[1], 'clas' => $category_temp[2]));
$li['photo_list'] = iserializer($li['photo_list']);
$li['type'] = 2;
unset($li['categories'], $li['poi_id'], $li['update_status'], $li['available_state']);
if(empty($isexist)) {
pdo_insert('activity_stores', $li);
} else {
if($selet_type == 'sid') {
if($isexist['id'] == $li['sid']) {
pdo_update('activity_stores', $li, array('uniacid' => $_W['uniacid'], 'id' => $li['sid']));
} else {
pdo_update('activity_stores', $li, array('uniacid' => $_W['uniacid'], 'sid' => $li['sid']));
}
} else {
pdo_update('activity_stores', $li, array('uniacid' => $_W['uniacid'], 'location_id' => $li['poi_id']));
}
}
}
}
message('正在导入微信门店,请不要关闭浏览器...', url('wechat/location/export', array('begin' => $begin + 50)), 'success');
}
message('导入门店成功', url('wechat/location/list'), 'success');
}
if($do == 'sync') {
$id = intval($_GPC['id']);
$location = pdo_fetch('SELECT * FROM ' . tablename('activity_stores') . ' WHERE uniacid = :aid AND id = :id', array(':aid' => $_W['uniacid'], ':id' => $id));
if(empty($location)) {
message('门店不存在或已删除', referer(), 'error');
}
load()->classs('coupon');
$acc = new coupon($acid);
$location = $acc->LocationGet($location['location_id']);
if(is_error($location)) {
message("获取门店信息失败,错误详情:{$location['message']}", referer(), 'error');
}
$location = $location['business']['base_info'];
$status2local = array('', 3, 2, 1, 3);
$location['status'] = $status2local[$location['available_state']];
$location['location_id'] = $location['poi_id'];
$category_temp = explode(',', $location['categories'][0]);
$location['category'] = iserializer(array('cate' => $category_temp[0], 'sub' => $category_temp[1], 'clas' => $category_temp[2]));
$location['photo_list'] = iserializer($location['photo_list']);
unset($location['sid'], $location['categories'], $location['poi_id'], $location['update_status'], $location['available_state']);
pdo_update('activity_stores', $location, array('uniacid' => $_W['uniacid'], 'id' => $id));
message('更新门店信息成功', referer(), 'success');
}
template('wechat/location');