Shopnearby.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. namespace app\home\controller;
  3. use think\facade\View;
  4. use think\facade\Lang;
  5. use think\facade\Db;
  6. /**
  7. * ============================================================================
  8. * DSMall多用户商城
  9. * ============================================================================
  10. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  11. * 网站地址: http://www.csdeshang.com
  12. * ----------------------------------------------------------------------------
  13. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  14. * 不允许对程序代码以任何形式任何目的的再发布。
  15. * ============================================================================
  16. * 控制器
  17. */
  18. class Shopnearby extends BaseMall {
  19. public function initialize() {
  20. parent::initialize();
  21. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/shopnearby.lang.php');
  22. }
  23. /*
  24. * 首页显示
  25. */
  26. public function index() {
  27. $storeclass_list = model('storeclass')->getStoreclassList();
  28. View::assign('storeclass_list', $storeclass_list);
  29. $area_mod = model('area');
  30. $city_list = $area_mod->getAreaList(array('area_parent_id' => '0'));
  31. $sort_city_list = array();
  32. foreach ($city_list as $k => $v) {
  33. if (!isset($sort_city_list[$v['area_region']])) {
  34. $sort_city_list[$v['area_region']] = array(
  35. 'region' => $v['area_region'],
  36. 'child' => array()
  37. );
  38. }
  39. $sort_city_list[$v['area_region']]['child'][] = $v;
  40. }
  41. View::assign('city_list', $sort_city_list);
  42. View::assign('baidu_ak', config('ds_config.baidu_ak'));
  43. return View::fetch($this->template_dir . 'index');
  44. }
  45. public function get_Own_Store_List() {
  46. $store_list = array();
  47. //查询条件
  48. $condition = array(array('store_state', '=', 1));
  49. if (!empty(input('get.keyword'))) {
  50. $condition[] = array('store_name', 'like', '%' . input('get.keyword') . '%');
  51. }
  52. $storeclass_id = intval(input('get.storeclass_id'));
  53. if ($storeclass_id) {
  54. $condition[] = array('storeclass_id', '=', $storeclass_id);
  55. }
  56. $lat = input('get.latitude');
  57. $lng = input('get.longitude');
  58. if (!is_numeric($lat) || !is_numeric($lng)) {
  59. ds_json_encode(10001, lang('param_error'));
  60. }
  61. if ($lat && $lng) {
  62. $page = intval(input('get.page'));
  63. $store_list = Db::name('store')->where($condition)->where('(2 * 6378.137* ASIN(SQRT(POW(SIN(PI()*(' . $lat . '-store_latitude)/360),2)+COS(PI()*' . $lat . '/180)* COS(store_latitude * PI()/180)*POW(SIN(PI()*(' . $lng . '-store_longitude)/360),2)))) < 100000')->field('store_phone,store_latitude,store_longitude,store_id,is_platform_store,store_name,area_info,store_address,store_logo,store_avatar,store_banner,(2 * 6378.137* ASIN(SQRT(POW(SIN(PI()*(' . $lat . '-store_latitude)/360),2)+COS(PI()*' . $lat . '/180)* COS(store_latitude * PI()/180)*POW(SIN(PI()*(' . $lng . '-store_longitude)/360),2)))) as distance')->order('distance asc')->page($page, 30)->select()->toArray();
  64. foreach ($store_list as $key => $value) {
  65. $goods_conditions = array();
  66. $goods_conditions[] = array('goods_verify', '=', 1);
  67. $goods_conditions[] = array('goods_state', '=', 1);
  68. $store_list[$key]['store_banner'] && $store_list[$key]['store_banner'] = ds_get_pic( ATTACH_STORE . '/' . $value['store_id'] , $value['store_banner']);
  69. $store_list[$key]['distance'] = round($value['distance'], 2);
  70. $store_list[$key]['store_logo'] = get_store_logo($value['store_logo'], 'store_logo');
  71. $store_list[$key]['store_avatar'] = get_store_logo($value['store_avatar'], 'store_avatar');
  72. $goods_conditions[] = array('store_id', '=', $value['store_id']);
  73. $store_list[$key]['goods_list'] = Db::name('goods')->where($goods_conditions)->field('goods_name,goods_id,goods_image,goods_price')->order('goods_addtime desc')->page($page, 4)->select()->toArray();
  74. if (empty($value['area_info'])) {
  75. $store_list[$key]['area_info'] = lang('store_doesn_fill_area');
  76. }
  77. if (empty($value['store_address'])) {
  78. $store_list[$key]['store_address'] = lang('store_not_filled_detailed_address');
  79. }
  80. foreach ($store_list[$key]['goods_list'] as $key2 => $goods) {
  81. $store_list[$key]['goods_list'][$key2]['goods_image'] = goods_cthumb($goods['goods_image']);
  82. }
  83. }
  84. }
  85. if ($store_list) {
  86. echo json_encode($store_list);
  87. exit;
  88. } else {
  89. echo json_encode(false);
  90. exit;
  91. }
  92. }
  93. }