Михаил Базаров: Сообщения

Михаил Базаров

Дата последнего входа: 3 часа назад
Дата регистрации: 7 февраля 2012 21:17
День рождения: 7 ноября
Пол: Мужской
Михаил Базаров -> Всем
авг 13 1:55 pm

Стартовое приложение Cordova для начала разработки

Установлены все официальные плагины Cordova. Установлены платформы android и ios5.1.1 Дополнительные плагины:

  • cordova-plugin-wkwebview-engine
  • yandex-appmetrica-plugin-cordova
  • cordova-plugin-remote-injection

Движек рендеринга переключен на wkwebview (иначе, не пройдет публикацию в AppStore).

Заготовка для разработки мобильного приложения на #Cordova
Обновление от августа 2020:
- Платформы обновлены до ios-6.1.1 и android-9;
- Обновлен плагин remote-injection (удален UIWeb, не проходил проверку в Appstore);
- Удален плагин inappbrowser (не поддерживается ios6)

PS: Если inappbrowser нужен:
- cordova platform rm ios
- cordova platform add ios@5.1.1
- cordova plugin add cordova-plugin-inappbrowser

https://github.com/mibazarow/Cordova-S...rt-Project
mibazarow/Cordova-Start-Project
Стартовое приложение Cordova для начала разработки - mibazarow/Cordova-Start-Project
Михаил Базаров -> Всем
июн 20 4:45 pm
Скелет-шаблон для создания мобильного приложения в Cordova.
Базовая верстка для 1С-Битрикс, включены js плагины:
- SNAP : боковая панель при протягивании по контенту
- Pull To Refresh : Обновление контейнера с контентом при протягивании вниз

Видео работы:
https://www.youtube.com/watch?v=XJ2q86-LAWE

Скачать:
https://camouf.ru/upload/fo_all/mobile...late-bx.7z

Плейлист - создание мобильного приложения для любого сайта:
https://www.youtube.com/playlist?list=...SGZcyhbgx3
Скелет-шаблон для мобильного приложения (#Cordova) для 1С-Битрикс
Заготовка скелет-шаблон для создания мобильного приложения в Cordova. Включены js плагины: Snap panel и Putt to refresh. Скачать: https://camouf.ru/club/user...
Михаил Базаров -> Всем
июн 3 12:28 am
Вывести минимальную и максимальную цену в разделе каталога Битрикс.

Что бы вывести минимальную и максимальную цены в разделе каталога (до товаров  например) вставляем:
$resPrice = CIBlockElement::GetList(
  Array("CATALOG_PRICE_2" => "ASC"),
  Array("SECTION_ID"=>$arResult['~ID']),
  false,
  false,
   Array("CATALOG_GROUP_2")
);
while($getPrices = $resPrice->Fetch()) {
          $arPrices[] = $getPrices['CATALOG_PRICE_2'];
}
$minPrice = array_shift($arPrices);
$maxPrice = array_pop($arPrices);

Пояснения:
- С помощью CIBlockElement::GetList получили список элементов раздела с ID равным "$arResult['~ID']" (текущий раздел инфоблока)
- Отсортировали их по полю стоимости по возрастанию "CATALOG_PRICE_2" (ID нужного типа цен, в моем случае, 2)
- Создали массив  $arPrices - который наполнили ценами всех товаров (по возрастанию соответственно).
- C помощью array_shift и array_pop - выдернули первый и последний элемент массива (таки минимальную и максимальную цену)

В переменных minPrice и maxPrice  - минимальная и максимальная цена товаров текущего раздела инфоблока.
PS: Использован Fetch вместо GetNext и явно указано поле для получения, для скорости работы.


Михаил Базаров -> Всем
май 10 12:53 pm
Вывести количество не прочитанных, персональных сообщений форума в любом месте сайта.

Что бы вывести количество не прочитанных (именно персональных) сообщений из модуля форума.
В любом, нужном, месте сайта вызываем метод
<?
CModule::IncludeModule("forum");
      $messs = CForumPrivateMessage::GetNewPM(
              array("FOLDER_ID" => 1)
     );
?>

<?
 echo $messs['UNREAD_PM']
?>

Михаил Базаров -> Всем
фев 25 3:48 pm
Компонент добавления элемента в инфоблок с отправкой письма о добавлении и AJAX отправкой.

Сделан по быстрому, в качестве базовой заготовки для дальнейшего развития.
Развиваться будет, в полноценный компонент, в рамках видеокурса "Разработка доски объявлений на Битрикс" https://bxstore.ru/

Пока, можно использовать как форму обратной связи, с записью в инфоблок и отправкой письма.

На данный момент умеет:
- Выводить, на заполнение,  свойства инфоблока. Только не множественные.
- Загружать файлы в свойство "Файл". Использует штатный компонент main.file.input (dragn_n_drop).
- Защита, от совсем простых ботов (проверка скрытого поля на заполнение)
- Поддерживает AJAX
- Отправляет письмо о добавлении элемента
- Все параметры управляемые (картинка 1)
- Шаблон маскимально простой (картинка 2)
- Легко дорабатывается, управляется и расширяется.

Письма отправляет обычной функцией php-mail, но в файле component.php есть закомментированый участок
(картинка 3):
Можно использовать штатный метод Битрикс Event::send - который передаст поля в штатное же почтовое событие FEEDBACK_FORM

Пример работы: https://camouf.ru/1/index.php

PS: В рамках видеокурса будет превращен в полноценный компонент добавления объявления на доску. С гугло капчей, работой с любыми типами полей И так далее.

Фото:
feedback.form.element.zip ( 25.08 КБ)
Михаил Базаров
Создаем массив со свойствами файлов, методом CFile::MakeFileArray и передаем в $PROP["MORE_PHOTO"] (в моем случае, свойство с доп картинками)
$arMorePhoto["VALUE"];
$i = 0;    
foreach ($_POST["MORE_PHOTO"] as $morePhoto) {        
      $arMorePhoto['n'.$i] = array("VALUE"=>CFile::MakeFileArray($morePhoto));        
      $i++;
}
$PROP["MORE_PHOTO"] = $arMorePhoto;

Михаил Базаров -> Всем
апр 1 11:05 am
Заполнить коэффициент единицы измерения (MEASURE_RATIO) из свойства элемента.

Перенесено в блог: https://camouf.ru/blog-note/9255/
Михаил Базаров -> Всем
марта 20, 2019 10:57 am
bitrix.sale.order.ajax раскрыть блоки доставки и оплаты.

Если в компоненте одношагового оформления заказа, нужно раскрыть блоки доставки и оплаты:
В самый низ template.php добавляем
$(window).on('ready', function(event){
    BX.Sale.OrderAjaxComponent.editDeliveryBlock(true);
    BX.Sale.OrderAjaxComponent.editPaySystemBlock(true);
});
Для блоков оплаты и доставки добавляем селектор bx-selected

Тоже самое, можно делать со всеми блоками:
BX.Sale.OrderAjaxComponent.editActiveBasketBlock(true);
BX.Sale.OrderAjaxComponent.editActiveRegionBlock(true);
BX.Sale.OrderAjaxComponent.this.editActiveDeliveryBlock(true);
BX.Sale.OrderAjaxComponent.editActivePaySystemBlock(true);
BX.Sale.OrderAjaxComponent.editActivePickUpBlock(true);
BX.Sale.OrderAjaxComponent.editActivePropsBlock(true);

И можно убрать кнопки "Далее - Назад" в файле order_ajax.js

Для доставки: найти и закомментировать
this.getBlockFooter(deliveryContent);
Для оплаты:
this.getBlockFooter(paySystemContent);

Денис Чучумашев
работает, только после выбора доставки или оплаты, блоки все равно оказываются закрытыми.
Денис Чучумашев
Запускать

   BX.Sale.OrderAjaxComponent.editActiveDeliveryBlock(true);
   BX.Sale.OrderAjaxComponent.editActivePaySystemBlock(true);
...

после каждой валидации - тоже не вариант. Должно быть более гибкое решение
Денис Чучумашев
Нашел способ другой. Причем, блоки изначально остаются открытыми. Я сделал так:

1. комментируем строчки:
/*if (this.activeSectionId !== this.regionBlockNode.id)
this.editFadeRegionContent(this.regionBlockNode.querySelector('.bx-soa-section-content'));

if (this.activeSectionId != this.propsBlockNode.id)
this.editFadePropsContent(this.propsBlockNode.querySelector('.bx-soa-section-content'));*/

2. меняем:
var active = section.id == this.activeSectionId,

на:
var active = true,

3. скрываем кнопки "далее" и "назад" и изменить стилями:
.pull-left.btn-default.btn-md, .pull-right.btn-default.btn-md, .bx-soa-editstep {
   display: none!important;
}
Михаил Базаров -> Всем
мар 10 1:26 pm
Вывести дату создания файла в формате сайта

Что бы это сделать можно воспользоваться методом
CFile::GetFileArray

В параметр передаем ID нужного файла или переменную с нужным ID и классом DateTime
приводим к строке:
<?
$arItem = 123; // ID нужного файла
$rsFile = CFile::GetFileArray($arItem);
echo $rsFile['TIMESTAMP_X']->toString();
?>
Если нужна вся информация о конкретном файле (вес, формат, путь на сервере, описание итд)
Распечатываем массив
<?
print_r($rsFile);
?>

Михаил Базаров -> Всем
июня 18, 2018 3:57 am
Вывести разделы инфоблока по первым буквам (алфавитный указатель типа) не меняя структуру каталога.

Например: у нас есть инфоблок с большим количеством разделов (картинка 1).
И мы хотим, на выводе на сайте разбить разделы по буквам (картинка 2).

Самый простой способ, это конечно же добавить буквы в разделы каталога, и перераспределить сами разделы по своим буквам.
Но... а если и разделов более 2000-ч и вообще не вариант, так менять структуру инфоблока.

Можно поступить следующим образом:
В шаблоне компонента catalog.section.list (Разделы инфоблока) удаляем все и меняем на такой код:
<?
foreach ($arResult["SECTIONS"] as $arSectionArray) {
      $sectFName = $arSectionArray['NAME'];
      $sectFLetter = mb_substr($sectFName, 0, 1, 'UTF-8');
      $arrayFirsletter .= '\'' . $sectFLetter . '\',';
}

eval('$FirstLetter=array(' . $arrayFirsletter . ');');
extract($FirstLetter);
$uniuLetter = array_unique($FirstLetter);

foreach ($uniuLetter as $onlyOnceLetter) {
       echo '<h3>' . $onlyOnceLetter . '</h3>';
      foreach ($arResult["SECTIONS"] as $arSection) {
         if (mb_substr($arSection['NAME'], 0, 1) == $onlyOnceLetter) { ?>
             <a href="<?= $arSection["SECTION_PAGE_URL"] ?>">
                 <?echo $arSection['NAME']; ?>
            </a>
          <?
          }
     }
}
?>

Пояснения:

Сначала собираем первые буквы всех разделов в одну переменную $arrayFirsletter , так как названия разделов
могут быть как на латинице, так и на кириллице используем mb_substr- с помощью которого и "отрубили" первые буквы названий разделов
foreach ($arResult["SECTIONS"] as $arSectionArray) {
      $sectFName = $arSectionArray['NAME'];
      $sectFLetter = mb_substr($sectFName, 0, 1, 'UTF-8');
      $arrayFirsletter .= '\'' . $sectFLetter . '\',';
}

Далее, с помощью eval, загоняем все буквы в массив array. Так как первые буквы разделов могут повторяться. Переводим array в array_unique - он отберет только уникальные буквы (то бишь без повторов)
eval('$FirstLetter=array(' . $arrayFirsletter . ');');
extract($FirstLetter);
$uniuLetter = array_unique($FirstLetter);

Собственно выводим эти буквы с помощью foreach
foreach ($uniuLetter as $onlyOnceLetter) {
       echo '<h3>' . $onlyOnceLetter . '</h3>';

Внутри которого еще один foreach - который отберет все разделы, начинающиеся на конкретную букву, ну и ссылка на раздел в каталоге.
Если первая буква названия раздела, совпадает с переменной $onlyOnceLetter (в которой, собственно первая буква)
foreach ($arResult["SECTIONS"] as $arSection) {
         if (mb_substr($arSection['NAME'], 0, 1) == $onlyOnceLetter) { ?>
             <a href="<?= $arSection["SECTION_PAGE_URL"] ?>">
                 <?echo $arSection['NAME']; ?>
            </a>
         



Фото:
Михаил Базаров
Кого коробит использование eval. В принципе не рекомендую им злоупотреблять.
Можно сразу загнать результат работы foreach в массив

$FirstLetter   = array();
foreach ($arResult["SECTIONS"] as $arSectionArray) {
     $sectFName = $arSectionArray['NAME'];
     $sectFLetter = mb_substr($sectFName, 0, 1, 'UTF-8');
     $FirstLetter[]   = $sectFLetter;
}
Андрей Белый
Спасибо, Михаил
Все работает!)
Михаил Базаров -> Всем
янв 13 7:52 am
Ошибка "Mysql query error: (1146) Table '.b_sale_trading_platform' doesn't exist (400)" при просмотре заказа в Битрикс

Если, при попытке просмотреть подробную информацию о заказе, получаете ошибку
"Mysql query error: (1146) Table '.b_sale_trading_platform' doesn't exist (400)"

Ошибка может возникнуть при обновлении ядра Битрикс, если прыгаете с версии 17 на 20 и выше.

Удалите, лишний файл /bitrix/modules/sale/lib/tradingplatform.php
Его не должно быть в ядре, после этого проблема решится.

Возможно файл появился после восстановления сайта из резервной копии или перезагрузки файлов ядра.
Ранее этот файл по ошибке был добавлен, но с версии sale 17.8.25 (18.0.3) его убрали.

PS: Если, при просмотре заказа, видите только:
"Произошла ошибка, включите расширенный вывод ошибок в .settings.php"
Откройте файл /bitrix/.settings.php и переключите "debug" = "false" в "debug" = "true"



Авторизация

На сайте работает вход через социальные сети. Просто, выберите наиболее удобную сеть и авторизация произойдет автоматически:
Проходя авторизацию, Вы безоговорочно принимаете условия политики конфеденциальности