Выбор города

This commit is contained in:
Konstantin
2026-05-30 11:47:38 +03:00
parent 640af8f4d9
commit af9b7b13a4
7 changed files with 173 additions and 6 deletions
+44
View File
@@ -0,0 +1,44 @@
<?php
class ControllerCommonCity extends Controller {
public function index() {
$this->load->model('localisation/zone');
$country_id = $this->config->get('config_country_id');
$zones = $this->model_localisation_zone->getZonesByCountryId($country_id);
$current_zone_id = isset($this->session->data['city_id']) ? (int)$this->session->data['city_id'] : (int)$this->config->get('config_zone_id');
$data['zones'] = array();
foreach ($zones as $zone) {
$data['zones'][] = array(
'zone_id' => $zone['zone_id'],
'name' => $zone['name'],
'active' => ($zone['zone_id'] == $current_zone_id),
);
}
$data['action'] = $this->url->link('common/city/save');
$this->response->setOutput($this->load->view('common/city_list', $data));
}
public function save() {
$json = array();
if (isset($this->request->post['city_id'])) {
$this->session->data['city_id'] = (int)$this->request->post['city_id'];
$json['success'] = true;
$this->load->model('localisation/zone');
$zone = $this->model_localisation_zone->getZone($this->session->data['city_id']);
$json['name'] = $zone ? $zone['name'] : '';
} else {
$json['success'] = false;
}
$this->response->addHeader('Content-Type: application/json');
$this->response->setOutput(json_encode($json));
}
}
+16
View File
@@ -104,6 +104,22 @@ foreach(['name','email','telephone','address','open', 'comment'] as $item){
$data['cart'] = $this->load->controller('common/cart');
$data['menu'] = $this->load->controller('common/menu');
$this->load->model('localisation/zone');
$country_id = $this->config->get('config_country_id');
$zones = $this->model_localisation_zone->getZonesByCountryId($country_id);
$current_zone_id = isset($this->session->data['city_id']) ? (int)$this->session->data['city_id'] : (int)$this->config->get('config_zone_id');
$data['current_city_name'] = '';
foreach ($zones as $zone) {
if ($zone['zone_id'] == $current_zone_id) {
$data['current_city_name'] = $zone['name'];
break;
}
}
$data['city_list_url'] = 'index.php?route=common/city';
return $this->load->view('common/header', $data);
}
}
@@ -444,6 +444,30 @@ function addLoading(elem){
}
function citySelect(el){
var url = $(el).data('city-url');
$.get(url, function(html){
modal.create({
modal: html,
title: 'Выберите город',
width: 400,
});
$('.city-item').click(function(e){
e.preventDefault();
var cityId = $(this).data('city-id');
var cityName = $(this).text();
send.post('index.php?route=common/city/save', {city_id: cityId}, function(json){
if (json.success) {
$('.current-city-name').text(json.name);
$('.modal').modal('hide');
}
});
});
});
}
function SendRequest(product_id = 0){
var params = {};
@@ -0,0 +1,40 @@
<div class="city-grid">
{% for zone in zones %}
<button type="button" class="city-item{% if zone.active %} active{% endif %}" data-city-id="{{ zone.zone_id }}">{{ zone.name }}</button>
{% endfor %}
</div>
<style>
.city-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 8px;
padding: 0 4px;
}
.city-item {
background: #fff;
border: 1px solid #e5e5e5;
border-radius: 8px;
padding: 10px 12px;
font-size: 14px;
color: #222;
cursor: pointer;
text-align: center;
transition: all 0.15s ease;
font-family: inherit;
line-height: 1.3;
}
.city-item:hover {
border-color: #aaa;
background: #f9f9f9;
}
.city-item.active {
background: #222;
color: #fff;
border-color: #222;
}
@media (max-width: 380px) {
.city-grid {
grid-template-columns: repeat(2, 1fr);
}
}
</style>
@@ -58,11 +58,14 @@
<div class="row gx-3 flex-nowrap align-items-center">
<div class="col">
<div class="d-none d-lg-inline-block">
<ul class="menu left-menu">
{{ menu }}
{{ blog_menu }}
{{ service_menu }}
</ul>
<ul class="menu left-menu">
{{ menu }}
{{ blog_menu }}
{{ service_menu }}
{% if current_city_name %}
<li><a href="#" data-city-url="{{ city_list_url }}" onclick="citySelect(this);return false;"><svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M8 0C5.083 0 2.667 2.416 2.667 5.333C2.667 9.333 8 16 8 16S13.333 9.333 13.333 5.333C13.333 2.416 10.917 0 8 0ZM8 7.2C6.97 7.2 6.133 6.364 6.133 5.333C6.133 4.303 6.97 3.467 8 3.467C9.03 3.467 9.867 4.303 9.867 5.333C9.867 6.364 9.03 7.2 8 7.2Z" fill="currentColor"/></svg> <span class="d-none d-lg-inline-block ms-1 current-city-name">{{ current_city_name }}</span></a></li>
{% endif %}
</ul>
</div>
<div class="d-lg-none">
<div class="menu-btn" >