Сортировка массива по ключу
Функция сортировки массива по ключу
function _ksort($data, $name, $sort = SORT_ASC)
{
foreach ($data as $key => $row)
{
$value[$key] = $row[$name];
}
array_multisort($value, $sort, $data);
return $data;
}
TypeError: Joomla.optionsStorage is undefined - быстрый fix
Если часть плагинов не работает в админке сайта и консоль разработчика выдает ошибку:
TypeError: Joomla.optionsStorage is undefined
как описывал в другой статье (Joomla 3.7.x - если не работает плагин TinyMCE), это связано с косяком параметров. Так вот нашел более предпочтительный вариант чем везде и всюду вставлять парсер параметров. Для решения задачи нам необходимо в исполняемом .js вставить кусок кода.
Joomla 3.7.x - если не работает плагин TinyMCE
Если не работает TinyMCE плагин и в консоле разработчика выдает вот такие ошибки:
TypeError: Joomla.optionsStorage is undefined - tinymce-builder.js:278:1
TypeError: Joomla.optionsStorage is undefined - tinymce.min.js:1:361
, это значит что плагин не может вытащить параметры передаваемые Joomla в json формате
Не стал долго и упорно выяснять причину и ковыряться во всей джумловской каше, а попросту написал свой парсер в обход core.js. Не стоит забывать, что это временное решение и с обновлением скорей всего слетит, а может это мой косяк в движке. В общем не удивлюсь, что вскоре косяк исправят.
И так приступим:
canonical bitrix
Для улучшения рейтинга одинакового содержания размещенного на разных страницах, необходимо использовать канонические URL. Как правило это относится к страницам пагинации. На сайтах Битрикс, делаем так:
Добавляем в /bitrix/php_interface/init.php
if ($_REQUEST['PAGEN_1']) {
global $APPLICATION;
$APPLICATION->AddHeadString('<link href="http://'.$_SERVER['HTTP_HOST'].$APPLICATION->sDirPath.'" rel="canonical" />',true);
}
Соответственно в шаблоне должна быть объявлена функция:
<?$APPLICATION->ShowHead();?>
Готово!
Joomla 2.5 - API reCaptcha для работы с ajax формой
Если необходимо быстро без сторонних компонентов и модулей реализовать отправку jquery.ajax формы обратной связи и при этом защититься reCaptcha - вот решение. Сразу оговорюсь, не буду описывать как для начинающих, кому надо тот поймет как применить.
Вывод капчи в форме:
<?
JPluginHelper::importPlugin('captcha');
$dispatcher = JDispatcher::getInstance();
// Обрабатываем блок dynamic_recaptcha_1 капчей
$dispatcher->trigger('onInit','dynamic_recaptcha_1');
?>
<form action="<?=JURI::root()?>?tmpl=ajax" method="POST">
<input type="text" name="name" value="" />
<input type="text" name="phone" value="" />
<div id="dynamic_recaptcha_1"></div>
<input type="submit" value="ОТПРАВИТЬ" class="submit" />
</form>
<script>
// Сценарий отправки формы на адрес обработчика
</script>
Скрипт обработчик:
$post = JRequest::get('post');
JPluginHelper::importPlugin('captcha');
$dispatcher = JDispatcher::getInstance();
$captcha = $dispatcher->trigger('onCheckAnswer',$post['recaptcha_response_field']);
if ($captcha[0] == false) {
echo 'false';
} else {
echo 'true';
}
Вот и все. Естественно не забываем выбрать reCaptcha по умолчанию и прописать в плагине ключики.
catalog.smart.filter - ajax обновление списка без AXAJ_MODE
Не нравится мне работа режима AJAX_MODE в компоненте catalog. Вот хоть убей, но ничего с битриксом в лучшую сторону с годами не меняется. Как был коммерческим продуктом, так им и остался. Где технологичность? Короче простое решение обновления списка с помощью ajax.get
В шаблоне bitrix:catalog.smart.filter редактируем script.js - ищим функцию JCSmartFilter.prototype.postHandler и редактируем следующее
//if (modef.style.display === 'none')
//{
// modef.style.display = 'inline-block';
//}
$.get(
result.FILTER_AJAX_URL,
function (data) {
$('.catalog-list').html($(data).find('.catalog-list').html());
}
);
.catalog-list - селектор который необходимо обновить. Естественно jQuery должен быть подключен.
Если не работает SECTION_CODE_PATH в bitrix:catalog
В помощь трудящимся!
Если в шаблоне bitrix:catalog.section компонента catalog не работает путь из символьных кодов, как правило это вылазит когда используется вывод товаров и из подразделов - поможет небольшой код в result_modifier.php
$ids = array();
foreach ($arResult['ITEMS'] as $arItem)
$ids[] = $arItem['ID'];
$res = CIBlockElement::GetList(array("SORT" => "ASC"), array('IBLOCK_ID' => $arParams['IBLOCK_ID'], 'ACTIVE' => 'Y', 'ID' => $ids), false, false, array('ID', 'CODE', 'IBLOCK_ID' ,'DETAIL_PAGE_URL'));
while($obj = $res->GetNext())
$arRes[$obj['ID']] = $obj['DETAIL_PAGE_URL'];
foreach ($arResult['ITEMS'] as &$arItem)
$arItem['DETAIL_PAGE_URL'] = $arRes[$arItem['ID']];
Теперь в независимости от уровня нахождения в каталоге, путь к карточке товара будет выводиться истинный.
Спасибо за внимание! Всем чистого кода!
Joomla - как убрать id материала
Не буду рассказывать про ARTIO JoomSEF, SH404SEF так как не уважаю подобные компоненты/расширения. Предпочитаю следовать архитектуре Joomla, чего и другим советую.
Изучай архитектуру движка, а не ломайте сайты как тебе привычно.
И так, доставучие seo'шники требуют убрать id из url'а материала типа блог. Проделать подобное можно подправив router.php компонента com_content. В функция build() и parse() находим:
$advanced = $params->get('sef_advanced_link', 0);
и меняем на:
$advanced = $params->get('sef_advanced_link', 1);
Так же в функции parse() находим кусок кода и комментируем его:
Joomla слэш на конце
Joomla не любит слэши на конце, сталкивался с глюками Virtuemart. Но иногда сделать это жизненно необходимо. Конечно можно воспользоваться 301 редиректом .htaccess, но ПС все-равно видит ее без слэша, а перейдя получает 301 редирект. Немножко облегчим задачу роботам )
(j2.5) редактируем includes/router.php в классе JRouterSite находим функцию _buildSefRoute() в ней меняем последнюю строчку
$uri->setPath($route.'/');
(j3.x) редактируем libraries/cms/router/site.php в классе JRouterSite находим функцию buildSefRoute() в ней меняем последнюю строчку
$uri->setPath($route.'/');
Да, этот способ плох тем что после обновления слетит. Но SEO'шники неисправимы, требуют.
Ну и для верности сделать 301 редирект через .htaccess с без слэша на слэшь. Ссылку на статью приводил выше.
Joomla подключение языкового файла
Бывает необходимо подключить языковой файл другого компонента или модуля. Все просто
JFactory::getLanguage()->load('com_namecomponent')
Вот как то так
