Перейти к содержанию
korish

Автозаполнение списка городов

Рекомендуемые сообщения

Создаем таблицу в БД

CREATE TABLE IF NOT EXISTS `oc_city` (
  `city_id` int(11) NOT NULL AUTO_INCREMENT,
  `zone_id` int(11) NOT NULL,
  `name` varchar(50) DEFAULT NULL,
  `free_shipping` tinyint(1) NOT NULL DEFAULT '0',
  PRIMARY KEY (`city_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8;

В файле catalogviewthemedefaulttemplateaccountregister.tpl после

<script type="text/javascript"><!--
добавляем

var $state = $('#zone_id'), $province = $('#city');
$state.change(function () {
if ($state.val() > 0) {
  $province.removeAttr('disabled');
} else {
  $province.attr('disabled', 'disabled').val('');
}
}).trigger('change');

$(function(){
function ShowTip(content) {
   $("#resSearch").show("slow");
   $("#resSearch").html(content);
  };
  $('#city').autocomplete({
	  source: function(request, response) {
		$.ajax({
		  url: "s.php",
		  dataType: "json",
	async: true,
		  data: {
			term : request.term,
			country : $('#zone_id').val()
		  },
		  success: function(data) {
   response(data);
		  }
		});
	  },
   select: function(value, data){
	if (data.item.free == 0) { ShowTip("Платная доставка. <a href="#">Подробнее</a>"); } else { ShowTip("Бесплатная доставка. <a href="#">Подробнее</a>"); }
			  },
	minLength: 2
  }).data('autocomplete')._renderItem = function( ul, item ) {
		return $( "<li></li>" )
			.data( "item.autocomplete", item )
			.append( '<a>' + item.label + '</a>' )
			.appendTo( ul );
  
	};
});

Так как я не смог разобраться как добавить это в controller движка, я сделал отдельный файл для выборки результатов.

Содержимое s.php в корне сайта

include ('config.php');
if ( !isset($_REQUEST['term']) )
exit;

$dblink = mysql_connect(DB_HOSTNAME,DB_USERNAME,DB_PASSWORD) or die( mysql_error() );
mysql_select_db(DB_DATABASE);
$rs = mysql_query("SELECT `name`, `free_shipping` FROM `".DB_PREFIX."city` WHERE `zone_id`= ".mysql_real_escape_string($_REQUEST['country'])." AND `name` LIKE '%".mysql_real_escape_string($_REQUEST['term']). "%' ORDER BY `name` LIMIT 5", $dblink);

$data = array();
if ( $rs && mysql_num_rows($rs) )
{
while( $row = mysql_fetch_array($rs, MYSQL_ASSOC) )
{
  $data[] = array('value' => $row['name'], 'free' => $row['free_shipping']);
}
}
else $data[] = array('value' => 'Не найдено ничего');
echo json_encode($data);
flush();

Буду благодарен кто поможет файл s.php "втулить" в файл движка ))

Прикрепляю таблицу с небольшим списком городов Украины

base_city.zip

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Посмотрите код моего модуля там все есть и как контролер создать и как js код добавить.. Нельзя так писать.. если есть апи то нужно использовать именно это апи! и для создания контроллеров и для подключения к базе итд. А не создать свой файл, а потом с помощью каких-то костылей пробовать его прикрутить к движку.. Это, имхо, очень не правильно.

  • +1 1

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Посмотрите код моего модуля там все есть и как контролер создать и как js код добавить.. Нельзя так писать.. если есть апи то нужно использовать именно это апи! и для создания контроллеров и для подключения к базе итд. А не создать свой файл, а потом с помощью каких-то костылей пробовать его прикрутить к движку.. Это, имхо, очень не правильно.

Спасибо за наводку) буду пробовать...

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Создаем таблицу в БД

CREATE TABLE IF NOT EXISTS `oc_city` (
  `city_id` int(11) NOT NULL AUTO_INCREMENT,
  `zone_id` int(11) NOT NULL,
  `name` varchar(50) DEFAULT NULL,
  `free_shipping` tinyint(1) NOT NULL DEFAULT '0',
  PRIMARY KEY (`city_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8;

В файле catalogviewthemedefaulttemplateaccountregister.tpl после

<script type="text/javascript"><!--
добавляем

var $state = $('#zone_id'), $province = $('#city');
$state.change(function () {
if ($state.val() > 0) {
  $province.removeAttr('disabled');
} else {
  $province.attr('disabled', 'disabled').val('');
}
}).trigger('change');

$(function(){
function ShowTip(content) {
   $("#resSearch").show("slow");
   $("#resSearch").html(content);
  };
  $('#city').autocomplete({
	  source: function(request, response) {
		$.ajax({
		  url: "s.php",
		  dataType: "json",
	async: true,
		  data: {
			term : request.term,
			country : $('#zone_id').val()
		  },
		  success: function(data) {
   response(data);
		  }
		});
	  },
   select: function(value, data){
	if (data.item.free == 0) { ShowTip("Платная доставка. <a href="#">Подробнее</a>"); } else { ShowTip("Бесплатная доставка. <a href="#">Подробнее</a>"); }
			  },
	minLength: 2
  }).data('autocomplete')._renderItem = function( ul, item ) {
		return $( "<li></li>" )
			.data( "item.autocomplete", item )
			.append( '<a>' + item.label + '</a>' )
			.appendTo( ul );
  
	};
});

Так как я не смог разобраться как добавить это в controller движка, я сделал отдельный файл для выборки результатов.

Содержимое s.php в корне сайта

include ('config.php');
if ( !isset($_REQUEST['term']) )
exit;

$dblink = mysql_connect(DB_HOSTNAME,DB_USERNAME,DB_PASSWORD) or die( mysql_error() );
mysql_select_db(DB_DATABASE);
$rs = mysql_query("SELECT `name`, `free_shipping` FROM `".DB_PREFIX."city` WHERE `zone_id`= ".mysql_real_escape_string($_REQUEST['country'])." AND `name` LIKE '%".mysql_real_escape_string($_REQUEST['term']). "%' ORDER BY `name` LIMIT 5", $dblink);

$data = array();
if ( $rs && mysql_num_rows($rs) )
{
while( $row = mysql_fetch_array($rs, MYSQL_ASSOC) )
{
  $data[] = array('value' => $row['name'], 'free' => $row['free_shipping']);
}
}
else $data[] = array('value' => 'Не найдено ничего');
echo json_encode($data);
flush();

Буду благодарен кто поможет файл s.php "втулить" в файл движка ))

Прикрепляю таблицу с небольшим списком городов Украины

Autocomplete это расширение к jQuery которое работает через AJAX запросы. Сам s.php может быть сервером запросов и его ни куда не нужно встраивать. Укажите его как источник данных для JS и все. Остальное найдете в описании плагина. Скорее всего придется только формат вывод подправить.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.